@import url('https://fonts.googleapis.com/css2?family=Playwrite+SK:wght@100..400&family=Poppins:ital,wght@0,100;0,200;0,300;0,400;0,500;0,600;0,700;0,800;0,900;1,100;1,200;1,300;1,400;1,500;1,600;1,700;1,800;1,900&display=swap');

* {
    font-family: 'Poppins', sans-serif;
    margin: 0;
    padding: 0;
    box-sizing: border-box;
    outline: none;
    border: none;
    text-decoration: none;
    /* text-transform: capitalize; */
    /* transition: all 0.2s linear; */
}

html {
    font-size: 62.5%;
    overflow-x: scroll;
    overflow-y: scroll;
    scroll-padding-top: 7rem;
    scroll-behavior: smooth;
}

body {
    background-color: white;
}

ul {
    list-style: none;
}

.grid-container {
    display: grid;
    grid-template-columns: 1fr;
    grid-template-rows: auto 1fr auto;
    min-height: 100vh;
}


/* ========================================================= */
/* Header */
/* ========================================================= */

.header_menu {
    /* position: fixed; */
    top: 0;
    left: 0;
    right: 0;
    background: #505c87;
    z-index: 1000;
    padding: 0 5%;
    box-shadow: 0 5px 10px rgba(0, 0, 0, 0.1);
}

.header_menu .menubar {
    display: flex;
    align-items: center;
    justify-content: space-between;
    height: 70px;
    max-width: 1200px;
    margin: 0 auto;
}

.header_menu .menubar .logo {
    display: flex;
    align-items: center;
    gap: 30px;
}

.header_menu .menubar .logo .logo-img {
    display: flex;
    align-items: center;
    gap: 15px;
    color: #fff;
    font-size: 2.5rem;
    font-weight: 800;
}

.header_menu .menubar .logo .logo-img img {
    width: 40px;
    height: 40px;
}

.header_menu .menubar .logo .navbartogger {
    /* display: none; */
}

.header_menu .menubar .logo .navbartogger .menuopen {
    display: none;
}

.header_menu .menubar .logo .navbartogger .menuopen img {
    width: 30px;
    height: 35px;
}

.header_menu .menubar .logo .navbartogger .menuclose {
    display: none;
}

.header_menu .menubar .logo .navbartogger .menuclose img {
    width: 30px;
    height: 35px;
}

.navbarmenu ul {
    display: flex;
    justify-content: end;
    gap: 20px;
}

.navbarmenu ul li {
    margin: 5px;
    padding: 2px;
    /* cursor: pointer; */
}

.navbarmenu ul li a {
    /* color: #fff; */
    /* cursor: pointer; */
}

.navbarmenu ul li a .un {
    /* color: black; */
    color: white;
    padding: 5px;
    font-size: 1.8rem;
    font-weight: 550;
    text-transform: capitalize;
    display: inline-block;
    /* cursor: pointer; */
}

.navbarmenu ul li a .un::after {
    content: '';
    width: 0;
    height: 2px;
    display: block;
    margin-top: -5px;
    background-color: white;
    transition: 300ms;
}

.navbarmenu ul li .un:hover::after {
    width: 100%;
}


/* ========================================================= */
/* Main Content - html_main */
/* ========================================================= */

.html_main {
    padding: 20px 5%;
    max-width: 1200px;
    margin: 0 auto;
    grid-row: 2;
    z-index: 10; /* ให้ Main Content อยู่ด้านล่างเมนู */
    position: relative;
}

/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
* โค้ดที่เพิ่ม: Dark Overlay สำหรับปิดบัง Content เมื่อเมนูเปิดบนมือถือ (นอก Media Query)
* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
*/
.html_main.dark-overlay,
.home.dark-overlay {
    position: relative; /* ให้ Pseudo-element อ้างอิงได้ */
}

.html_main.dark-overlay::before,
.home.dark-overlay::before {
    content: '';
    position: fixed; /* ใช้ fixed เพื่อให้คลุมเต็มจอ */
    top: 0;
    left: 0;
    width: 100%;
    height: 100vh; /* เต็มความสูงของหน้าจอ */
    background-color: rgba(0, 0, 0, 0.5); /* สีดำโปร่งแสง 50% */
    z-index: 999; /* ให้อยู่ใต้เมนู (z-index: 1000) */
    pointer-events: none; /* ป้องกันไม่ให้ Overlay บล็อกการคลิกเมนู */
}
/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */


.lesson-header {
    text-align: center;
    margin-bottom: 20px;
}

.lesson-title {
    font-size: 3rem;
    font-weight: 700;
    color: #333;
    margin-bottom: 5px;
}

.lesson-date {
    font-size: 1.4rem;
    color: #666;
}

.topic-summary {
    background-color: #f7f7f7;
    padding: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 4px rgba(0, 0, 0, 0.05);
    margin-bottom: 30px;
}

.topic-summary h2 {
    font-size: 2.2rem;
    color: #505c87;
    margin-bottom: 10px;
}

.topic-summary #topic-count {
    color: #e93f1a;
    font-weight: 800;
}

.topic-summary p {
    font-size: 1.6rem;
    color: #555;
    line-height: 1.6;
}

/* ========================================================= */
/* Topic List (สารบัญ) */
/* ========================================================= */

.ordered-topic-list {
    counter-reset: lesson-counter;
    padding-left: 0;
}

.ordered-topic-list > li {
    list-style: none;
    margin-bottom: 10px;
    padding: 10px 15px;
    background-color: #fff;
    border: 1px solid #ddd;
    border-radius: 5px;
    transition: background-color 0.3s;
    font-size: 1.6rem;
    font-weight: 500;
}

.ordered-topic-list > li:not(.topic-section-header)::before {
    counter-increment: lesson-counter;
    content: "บทที่ " counter(lesson-counter) ": ";
    color: #e93f1a;
    font-weight: 700;
    margin-right: 8px;
}

.ordered-topic-list > li a {
    color: #505c87;
    text-decoration: none;
    display: block;
}

.ordered-topic-list > li:hover {
    background-color: #f0f0ff;
}

.ordered-topic-list > li.topic-section-header {
    background-color: #505c87;
    color: #fff;
    font-size: 2rem;
    font-weight: 700;
    text-align: center;
    margin-top: 20px;
    margin-bottom: 15px;
    padding: 15px;
    border: none;
}

.ordered-topic-list > li.topic-section-header::before {
    content: none;
}


/* ========================================================= */
/* Lesson Content */
/* ========================================================= */

.lesson-content h3 {
    font-size: 2.5rem;
    color: #e93f1a;
    margin: 30px 0 15px;
    border-bottom: 2px solid #505c87;
    padding-bottom: 5px;
}

.lesson-content p {
    font-size: 1.6rem;
    line-height: 1.8;
    color: #333;
    margin-bottom: 15px;
}

.lesson-content strong {
    color: #505c87;
    font-weight: 700;
}

.lesson-content ul,
.lesson-content ol {
    margin: 15px 0 15px 20px;
    padding-left: 20px;
    font-size: 1.6rem;
    line-height: 1.8;
    color: #333;
}

.lesson-content ul li {
    list-style-type: disc;
    margin-bottom: 8px;
}

.lesson-content ol li {
    list-style-type: decimal;
    margin-bottom: 8px;
}

.lesson-content a {
    color: #e93f1a;
    text-decoration: underline;
    font-weight: 500;
}

/* Code Block Styling */
.code-block-container {
    margin: 20px 0;
    border: 1px solid #ddd;
    border-radius: 8px;
    overflow: hidden;
}

.code-header {
    background-color: #505c87;
    color: white;
    padding: 10px 15px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    font-size: 1.4rem;
    font-weight: 600;
}

.code-header .language {
    text-transform: uppercase;
}

.copy-button {
    background-color: #e93f1a;
    color: white;
    border: none;
    padding: 5px 10px;
    border-radius: 4px;
    cursor: pointer;
    font-size: 1.2rem;
    transition: background-color 0.3s;
}

.copy-button:hover {
    background-color: #c93414;
}

.code-wrapper {
    background-color: #2d2d2d;
    overflow-x: auto;
    padding: 15px;
}

.code-wrapper code {
    font-family: 'Consolas', 'Monaco', 'Andale Mono', 'Ubuntu Mono', monospace;
    font-size: 1.5rem;
    color: #f8f8f2;
    white-space: pre;
    display: block; /* ทำให้โค้ดเต็มความกว้าง */
    line-height: 1.5;
}


/* ========================================================= */
/* Footer */
/* ========================================================= */

footer {
    grid-row: 3;
    background-color: #505c87;
    padding: 20px 5%;
    color: white;
    text-align: center;
    font-size: 1.4rem;
}

footer .footer-content {
    max-width: 1200px;
    margin: 0 auto;
}

footer p {
    margin: 5px 0;
}

footer a {
    color: #e93f1a;
    text-decoration: none;
    font-weight: 600;
}

/* ========================================================= */
/* @media: การปรับสำหรับหน้าจอแท็บเล็ตและมือถือ (น้อยกว่า 992px) */
/* ========================================================= */
@media (max-width: 991px) {

    html {
        font-size: 55%;
    }

    .header_menu {
        padding: 0 20px;
    }

    .header_menu .menubar .logo {
        width: 100%; /* ให้ Logo/Menu Icon กินพื้นที่เต็ม */
        justify-content: space-between;
    }

    .header_menu .menubar .logo .navbartogger .menuopen {
        display: block; /* แสดงปุ่ม Menu (Hamburger) */
    }

    /* ซ่อนเมนูสำหรับหน้าจอใหญ่ */
    .navbarmenu ul {
        display: none; 
    }

    /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
    * โค้ดที่แก้ไข: ทำให้ Mobile Menu เป็น Full-Screen Overlay 
    * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *
    */
    .navbarmenu ul.active {
        /* *** แก้ไขตรงนี้: จากเดิม display: none; *** */
        position: fixed; /* ทำให้เมนู Fixed ลอยอยู่ด้านบนสุด */
        top: 0;
        left: 0;
        
        width: 100%;
        height: 100vh; /* ความสูงเต็มหน้าจอ */
        
        display: flex; /* ใช้ Flexbox จัดรายการเมนูให้อยู่กึ่งกลาง */
        flex-direction: column; 
        justify-content: center; 
        align-items: center; 
        
        background-color: rgba(0, 0, 0, 0.95); /* พื้นหลังสีดำเข้ม */
        z-index: 10000; /* ค่าที่สูงมากเพื่อให้ลอยอยู่ด้านบนสุด */
        overflow-y: auto; 
    }

    .navbarmenu ul li {
        margin: 30px; /* เพิ่มระยะห่างระหว่างรายการเมนู */
        display: block;
        text-align: center;
    }

    .navbarmenu ul li a .un {
        font-size: 2.8rem; /* เพิ่มขนาดตัวอักษรในเมนู */
        font-weight: 600;
    }

    /* ทำให้ Header (ปุ่มปิด/โลโก้) ลอยอยู่ด้านบนเมนูด้วย */
    .header_menu.active {
        position: fixed; 
        top: 0;
        left: 0;
        width: 100%;
        z-index: 10001; /* สูงกว่าเมนูเล็กน้อย */
    }
    /* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * */


    /* สลับปุ่ม Menu/Close */
    .menuopen.active {
        display: block;
    }

    .menuopen {
        margin-right: 30px;
    }

    .menuclose {
        width: 50px;
        height: 55px;
        margin-top: -8px;
        margin-right: -15px;
    }

    .menuclose.active {
        display: none;
    }

}

/* ========================================================= */
/* @media: การปรับสำหรับหน้าจอสมาร์ทโฟน (แก้ปัญหาข้อความถูกตัด) */
/* ========================================================= */
@media (max-width: 500px) { /* หน้าจอขนาดเล็กกว่า 500px */
    
    /* 1. ปรับขนาดตัวอักษรพื้นฐานของรายการหัวข้อ */
    .ordered-topic-list > li {
        font-size: 1.4rem; /* ลดขนาดตัวอักษรลงจาก 1.6rem */
        padding: 5px 10px; /* ลด Padding เล็กน้อย */
        /* คำสั่งป้องกันข้อความยาวเกินไป ทำให้ข้อความตัดขึ้นบรรทัดใหม่แทนที่จะล้นขอบ */
        word-break: break-word;
        overflow-wrap: break-word; 
    }

    /* 2. ปรับขนาดตัวอักษรของเลขบทเรียน (::before) */
    .ordered-topic-list > li:not(.topic-section-header)::before {
        font-size: 1.4rem; /* ให้ขนาดเท่ากับข้อความหลัก */
        font-weight: 700;
        margin-right: 5px; /* ลดระยะห่าง */
    }

    /* 3. ปรับขนาดหัวข้อหลักของส่วนสารบัญ */
    .ordered-topic-list > li.topic-section-header {
        font-size: 1.6rem; 
        padding: 10px;
    }
}