* {
    font-family: 'Kanit', sans-serif!important;
}

/*
 * ============================================
 * 1. เส้นใต้เมนู (แบบใหม่: กว้าง 80% และอยู่กลาง)
 * ============================================
 */
/*
 * ============================================
 * 1. เส้นใต้เมนู (แบบใหม่: กว้าง 80% และอยู่กลาง)
 * ============================================
 */

.navbar-nav .nav-link {
    position: relative;
    border-bottom: none;
    padding-bottom: 0.5rem;
}

/* * [แก้ไข] เปลี่ยนจาก ::after เป็น ::before 
 * เพื่อไม่ให้ตีกับลูกศร dropdown
*/
.navbar-nav .nav-link::before {
    content: '';
    display: block;
    height: 3px;
    width: 80%;
    background-color: deeppink;
    transform: scaleX(0);
    transition: transform 0.3s ease;
    position: absolute;
    bottom: 0.25rem;
    left: 10%;
}

/* [แก้ไข] เปลี่ยนเป็น ::before */
.navbar-nav .nav-link:hover::before {
    transform: scaleX(1);
}

/* [แก้ไข] เปลี่ยนเป็น ::before */
.navbar-nav .nav-link.active::before {
    transform: scaleX(1);
}

/*
 * แก้ปัญหา "เส้นสีดำ"
 * บังคับให้ .nav-link ที่ active ไม่มี border-bottom ใดๆ 
*/
.navbar-nav .nav-link.active {
    border-bottom: none !important;
}

/* [เพิ่ม] เพิ่มกฎนี้เพื่อความชัวร์ สำหรับตัว dropdown โดยเฉพาะ */
.navbar-nav .nav-link.dropdown-toggle.active {
    border-bottom: none !important;
}


/*
 * ============================================
 * 2. ปรับ Submenu ให้สวยงาม (Hover + Animation)
 * ============================================
 */

.dropdown-menu {
    border-radius: 0.5rem;
    border: none;
    box-shadow: 0 4px 12px rgba(0, 0, 0, 0.1);
    margin-top: 0.5rem !important;
}

.dropdown-item {
    transition: background-color 0.2s ease, color 0.2s ease;
    border-radius: 0.25rem;
    margin: 0.1rem 0.25rem;
    width: auto;
}

/*
 * [แก้ไข] เพิ่ม .dropdown-item.active และ :active เข้าไป
 * เพื่อบังคับให้เมนูย่อยที่ถูกเลือก (active) เป็นสีชมพู ไม่ใช่สีฟ้า
*/
.dropdown-item.active,
.dropdown-item:active,
.dropdown-item:hover,
.dropdown-item:focus {
    background-color: #fff0f5; /* สีชมพูอ่อน (Lavender Blush) */
    color: #c71585; /* สีชมพูเข้ม (Medium Violet Red) */
}


@media (min-width: 992px) {
    .dropdown .dropdown-menu {
        display: block;
        opacity: 0;
        visibility: hidden;
        transform: translateY(10px);
        transition: opacity 0.3s ease,
            transform 0.3s ease,
            visibility 0.3s ease;
    }

    .dropdown:hover .dropdown-menu {
        opacity: 1;
        visibility: visible;
        transform: translateY(0);
    }
}

/*
 * ============================================
 * 3. อนิเมชันสีชมพูตอนเปลี่ยน Carousel
 * ============================================
 */

/* เพิ่ม class ให้กับ carousel เพื่อกำหนด transition เอง */
.carousel.slide .carousel-item {
    transition: transform 0.6s ease-in-out;
    /* ใช้ default transition ของ Bootstrap */
}

/* สร้าง overlay สีชมพู */
.carousel-overlay {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: rgba(255, 105, 180, 0);
    /* เริ่มต้นด้วยสีชมพูโปร่งใส */
    z-index: 10;
    /* ให้ overlay อยู่เหนือรูปภาพ */
    pointer-events: none;
    /* ทำให้คลิกผ่าน overlay ไปโดน carousel ได้ */
    transition: background-color 0.3s ease-in-out;
    /* เพิ่ม transition ให้สีเปลี่ยนนุ่มนวล */
}

/* คีย์เฟรมสำหรับอนิเมชัน overlay */
@keyframes pinkFadeOut {
    0% {
        background-color: rgba(255, 105, 180, 0.8);
    }

    /* เริ่มต้นเป็นชมพูเข้ม */
    100% {
        background-color: rgba(255, 105, 180, 0);
    }

    /* จบด้วยชมพูโปร่งใส */
}

/*
 * เมื่อ carousel กำลังเปลี่ยนภาพ (ก่อนเปลี่ยน) ให้แสดง overlay สีชมพู
 * (โค้ด JavaScript ด้านล่างจะช่วยจัดการตรงนี้)
 */
.carousel-item.pink-fade-out .carousel-overlay {
    animation: pinkFadeOut 0.6s forwards;
    /* ใช้ animation ที่สร้างไว้ */
}

/* ปรับ Indicator ให้เป็นสีชมพู */
.carousel-indicators [data-bs-target] {
    background-color: #ff69b4;
    /* สีชมพู */
}

.carousel-indicators .active {
    background-color: #c71585;
    /* สีชมพูเข้มขึ้นเมื่อ active */
}

/* ปรับปุ่มควบคุม (Prev/Next) */
.carousel-control-prev-icon,
.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23c71585'%3e%3cpath d='M11.354 1.646a.5.5 0 0 1 0 .708L5.707 8l5.647 5.646a.5.5 0 0 1-.708.708l-6-6a.5.5 0 0 1 0-.708l6-6a.5.5 0 0 1 .708 0z'/%3e%3c/svg%3e");
}

.carousel-control-next-icon {
    background-image: url("data:image/svg+xml,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='%23c71585'%3e%3cpath d='M4.646 1.646a.5.5 0 0 1 .708 0l6 6a.5.5 0 0 1 0 .708l-6 6a.5.5 0 0 1-.708-.708L10.293 8 4.646 2.354a.5.5 0 0 1 0-.708z'/%3e%3c/svg%3e");
}

/*
 * ============================================
 * 4. สไตล์ Sidebar Menu (Active/Hover/Collapse)
 * ============================================
 */

/* * 1. สไตล์สำหรับ Hover (สีชมพูอ่อน)
 * (ใช้ :not(.active) เพื่อไม่ให้ทับสไตล์ของเมนูที่กำลัง active)
 */
.sidebar-menu .list-group-item-action:hover:not(.active),
.sidebar-menu .list-group-item-action:focus:not(.active) {
    background-color: #fff0f5;
    /* สีชมพูอ่อน (Lavender Blush) */
    color: #c71585;
    /* สีชมพูเข้ม */
}

/* * 2. สไตล์สำหรับ Active (สีชมพูเข้ม)
 * (ใช้ !important เพื่อบังคับใช้สไตล์ของเราทับสีฟ้า default ของ Bootstrap)
 */
.sidebar-menu .list-group-item.active {
    background-color: #c71585 !important;
    color: #fff !important;
    border-color: #c71585 !important;
}

/* * 3. อนิเมชันหมุนไอคอน (chevron) ตอนพับ/กาง
 */
.sidebar-menu .card-header[data-bs-toggle="collapse"] .toggle-icon {
    transition: transform 0.3s ease;
    /* เอฟเฟกต์หมุน 0.3 วินาที */
}

/* * 4. สั่งให้หมุน 180 องศา (ชี้ขึ้น)
 * เมื่อปุ่ม *ไม่ได้* อยู่ในสถานะ .collapsed (คือตอนที่เมนูกำลังแสดงผล)
 * (Bootstrap จะเพิ่ม/ลบ คลาส .collapsed ให้อัตโนมัติ)
 */
.sidebar-menu .card-header[data-bs-toggle="collapse"]:not(.collapsed) .toggle-icon {
    transform: rotate(-180deg);
}

/*
 * ============================================
 * 5. Sticky Sidebar (เฉพาะจอคอมพิวเตอร์)
 * ============================================
 */

/* * เราจะสั่งให้ "aside" (แถบด้านข้างทั้งหมด) ลอยตาม
 * โดยจะทำงานเฉพาะจอ lg (992px) ขึ้นไปเท่านั้น
 */
@media (min-width: 992px) {
    aside.col-lg-3 {
        position: -webkit-sticky; /* สำหรับ Safari */
        position: sticky;
        top: 1.5rem; /* เว้นระยะห่างจากขอบบน 1.5 rem (ประมาณ 24px) */
        
        /* * สำคัญมาก: บอก .row (ที่เป็น flex) ว่าให้จัด item นี้
         * ชิดบนสุดเสมอ (ไม่งั้นมันจะถูกจัดกึ่งกลาง)
         */
        align-self: flex-start; 
        
        /* * กำหนด z-index ให้น้อยกว่า Navbar (ที่มักจะ 1030)
         * เพื่อให้ Navbar ทับ Sidebar ได้ตอนเลื่อน
         */
        z-index: 1000;
    }
}

/*
 * ============================================
 * 6. สไตล์ปุ่ม Back to Top (อัปเดต)
 * ============================================
 */

.back-to-top {
    position: fixed;
    bottom: 25px;
    right: 25px;
    
    /* 1. ซ่อนไว้เป็นค่าเริ่มต้น */
    opacity: 0;
    visibility: hidden;
    
    /* 2. สไตล์สีชมพู (เข้าธีม) */
    background-color: #c71585;
    color: white;
    
    /* 3. ขนาดและรูปทรง (กลม) */
    border-radius: 50%;
    width: 50px; /* กว้าง */
    height: 50px; /* สูง */
    
    /* 4. ⭐ [ใหม่] ใช้ Flexbox จัดไอคอนให้อยู่กลางเป๊ะ ⭐ */
    display: flex;
    justify-content: center; /* จัดกลางแนวนอน */
    align-items: center; /* จัดกลางแนวตั้ง */
    
    /* 5. ปรับขนาดไอคอน (ลบ line-height เก่าทิ้ง) */
    font-size: 1.5rem; /* เพิ่มขนาดไอคอนเล็กน้อย */
    
    z-index: 1050; /* ให้อยู่เหนือทุกอย่าง */
    
    /* 6. เอฟเฟกต์ Fade in/out และเพิ่มเงา */
    transition: opacity 0.3s ease, 
                visibility 0.3s ease, 
                background-color 0.2s ease,
                transform 0.2s ease, /* เพิ่ม transition สำหรับ hover */
                box-shadow 0.2s ease; /* เพิ่ม transition สำหรับเงา */
    
    border: none; /* เอาขอบ (ถ้ามี) ออก */
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15); /* เพิ่มเงาจางๆ */
}

/* คลาส .show (ที่ JS จะเพิ่มให้) เพื่อให้ปุ่มแสดงผล */
.back-to-top.show {
    opacity: 1;
    visibility: visible;
}

/* สไตล์ตอน Hover (เพิ่มเอฟเฟกต์ "ขยับขึ้น" เล็กน้อย) */
.back-to-top:hover {
    background-color: #a6126d; /* สีชมพูเข้มขึ้น */
    color: white;
    transform: translateY(-3px); /* ขยับขึ้นเล็กน้อยตอน hover */
    box-shadow: 0 6px 12px rgba(0, 0, 0, 0.2); /* เงาชัดขึ้น */
}

/*
 * ============================================
 * 7. Preloader (ภาพโรงเรียน + สีชมพู)
 * ============================================
 */

#preloader {
    position: fixed;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    background-color: #fff0f5; /* สีชมพูอ่อนมากสำหรับพื้นหลัง */
    z-index: 9999; /* ให้ Preloader อยู่เหนือทุกอย่าง */
    
    display: flex; /* ใช้ Flexbox จัดเนื้อหา */
    justify-content: center; /* จัดกลางแนวนอน */
    align-items: center; /* จัดกลางแนวตั้ง */
    
    opacity: 1; /* แสดงผลเป็นค่าเริ่มต้น */
    visibility: visible;
    transition: opacity 0.5s ease-out, visibility 0.5s ease-out; /* อนิเมชัน Fade out */
}

/* คลาสที่ JS จะเพิ่มเมื่อโหลดเสร็จ เพื่อสั่ง Fade out */
#preloader.hide {
    opacity: 0;
    visibility: hidden;
    pointer-events: none; /* ป้องกันไม่ให้คลิกผ่านเมื่อหายไปแล้ว */
}

.preloader-content {
    display: flex;
    flex-direction: column; /* วางภาพและ spinner ซ้อนกันในแนวตั้ง */
    align-items: center; /* จัดกลางแนวนอนของตัวเอง */
}

.preloader-image {
    max-width: 150px; /* ขนาดสูงสุดของภาพ (ปรับได้) */
    height: auto;
    margin-bottom: 20px; /* เว้นระยะห่างจาก spinner */
    animation: bounce 1.5s infinite ease-in-out; /* เพิ่มอนิเมชันเด้งเบาๆ */
}

/* Spinner ของ Bootstrap ให้เปลี่ยนเป็นสีชมพู */
.spinner-grow.text-pink {
    color: #c71585 !important; /* ใช้สีชมพูเข้มของคุณ */
}

/* Keyframe สำหรับอนิเมชันเด้ง */
@keyframes bounce {
    0%, 100% {
        transform: translateY(0);
    }
    50% {
        transform: translateY(-10px);
    }
}