body {
    margin: 0;
    font-family: 'Kanit', sans-serif !important;
}

a {
    text-decoration: none !important;
}

.content {
    flex-grow: 1;        /* ให้ content ขยายเต็มพื้นที่ที่เหลือ */
    background: #f8f9fa;
    padding: 0;          /* ลบ padding */
    min-height: 94vh;    /* สูงเท่ากับความสูง sidebar เพื่อไม่ให้สั้นเกินไป */
    overflow: auto;      /* กรณี content เยอะให้เลื่อน */
}

.main-wrapper {
    display: flex;
    flex-direction: row;
    min-height: 94vh;
}

/* Sidebar เล็ก 70px กว้าง */
.sidebar {
    width: 90px;
    background-color: #003049;
    display: flex;
    flex-direction: column;
    align-items: center;
    padding-top: 10px;
    position: relative;
}

/* เมนูหลัก */
.menu-item {
    position: relative;
    width: 100%;
}

/* ลิงก์เมนูหลัก จัดให้อยู่กลาง icon + ชื่อใต้กัน */
.menu-item > a {
    color: white;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    padding: 10px 0;
    font-size: 1.1rem;
    text-decoration: none;
    white-space: nowrap;
    cursor: pointer;
    user-select: none;
    transition: background-color 0.3s;
    position: relative;
}

/* โชว์ชื่อเมนูใต้ icon */
.menu-item > a p {
    margin: 3px 0 0 0;
    font-size: 11px;
    text-align: center;
    line-height: 1.1;
    color: white;
}

/* hover เมนู */
.menu-item > a:hover,
.menu-item:hover > a {
    margin-left: auto;
    font-size: 1.2rem;
    transition: transform 0.3s;
    /* position: absolute; */
    /* right: 8px; */
    /* top: 50%; */
    transform: translateY(-5%);
    color: #fcbf49;
}

.active-bg {
    background-color: #d1a042d1;
}

.menu-item:hover > a.has-submenu .submenu-arrow {
    /* transform: translateY(-50%) rotate(90deg); */
    color: #fcbf49;
}

/* submenu ระดับ 1 */
.submenu {
    display: none;
    position: absolute;
    top: 0;
    left: 70px;  /* เลื่อนขวาเท่ากับ sidebar width */
    background-color: #669bbc;
    /* width: 240px; */
    width: auto;
    flex-direction: column;
    padding: 10px 0;
    border-radius: 5px;
    box-shadow: 2px 2px 8px rgba(0,0,0,0.4);
    z-index: 9999;
}

/* submenu ระดับ 2 */
.submenu.level-2 {
    top: 0;
    left: 100%;
    background-color: #5588aa;
    width: 220px;
}

/* submenu ระดับ 3 */
.submenu.level-3 {
    top: 0;
    left: 100%;
    background-color: #446688;
    width: 200px;
}

/* แสดง submenu เมื่อ hover */
.menu-item:hover > .submenu,
.submenu-item:hover > .submenu {
    display: flex;
    width: auto;
}

/* ลิงก์ submenu */
.submenu a {
    color: white;
    padding: 8px 20px;
    text-decoration: none;
    display: flex;
    align-items: center;
    gap: 8px;
    font-size: 15px;
    white-space: nowrap;
    cursor: pointer;
    transition: background-color 0.3s;
    position: relative;
}

/* ลูกศรใน submenu ถ้ามี submenu ต่อ */
.submenu a.has-submenu .submenu-arrow {
    position: absolute;
    right: 12px;
    top: 50%;
    transform: translateY(-50%);
    font-size: 1rem;
    color: white;
    transition: transform 0.3s;
}

.submenu-item:hover > a.has-submenu .submenu-arrow {
    transform: rotate(90deg);
    color: #fcbf49;
}

.submenu a:hover {
    background-color: rgba(255, 255, 255, 0.2);
}

/* submenu item แยกบรรทัดและ position relative เพื่อให้ submenu ย่อยไปอยู่ถูกตำแหน่ง */
.submenu-item {
    position: relative;
}

/* Responsive: จอเล็ก ให้ sidebar เลื่อนลงมา และเมนูเป็นแนวนอน */
@media (max-width: 768px) {
    .main-wrapper {
        flex-direction: column;
    }
    .sidebar {
        width: 100%;
        height: auto;
        flex-direction: row;
        overflow-x: auto;
        padding: 5px 10px;
        align-items: center;
    }
    .menu-item {
        flex: 0 0 auto;
        width: auto;
        margin-right: 15px;
    }
    .menu-item > a {
        flex-direction: row;
        padding: 5px 10px;
        font-size: 1rem;
    }
    .menu-item > a p {
        display: none; /* ซ่อนชื่อเมนูบนมือถือ */
    }
    /* ซ่อน submenu ทั้งหมดบนมือถือ (ถ้าต้องการ dropdown ต้องเพิ่ม JS) */
    .submenu,
    .submenu.level-2,
    .submenu.level-3 {
        position: static;
        display: none !important;
        width: 100%;
        background-color: transparent;
        box-shadow: none;
        padding: 0;
    }
}