/* --- Product ตาราง สินค้า test1-8 --- */
table {
    width: 100%;
    border-collapse: collapse;
    margin-top: 20px;
    background-color: white;
}

th, td {
    border: 1px solid #ddd;
    padding: 10px;
    text-align: center;
}

th {
    background-color: #007bff;
    color: white;
}

tr:nth-child(even) {
    background-color: #f9f9f9;
}

tr:hover {
    background-color: #f1f1f1;
}
/* --- Product Detail Layout --- */
.product-detail-section {
    padding: 40px 20px;
    background: #fff;
    margin-top: 20px;
    border-radius: 8px;
    box-shadow: 0 2px 15px rgba(0,0,0,0.05);
}

.product-main {
    display: grid;
    grid-template-columns: 1fr 1fr; /* แบ่งครึ่ง ซ้าย-ขวา */
    gap: 40px;
    margin-bottom: 40px;
}

/* 1. Image Styles */
.product-image-column {
    text-align: center;
}
.zoom-img {
    max-width: 100%;
    height: auto;
    border: 1px solid #eee;
    padding: 10px;
    cursor: zoom-in;
    transition: 0.3s;
}
.zoom-img:hover { transform: scale(1.02); }
.text-hint { font-size: 0.8rem; color: #888; margin-top: 5px; }

/* 2. Info Styles */
.product-title { font-size: 1.8rem; margin-bottom: 20px; color: var(--dark-color); }
.price-box p { margin-bottom: 8px; font-size: 1.1rem; }
.old-price del { color: #999; }
.sale-price span { color: #cc0000; font-size: 1.5rem; font-weight: bold; }
.discount { color: #28a745; font-weight: bold; }

/* คลุม Select ด้วย Div เพื่อสร้างลูกศรจำลอง */
.variant-select-wrapper {
    position: relative;
    max-width: 350px;
}

#size-select {
    appearance: none; /* ซ่อนลูกศรเดิม */
    -webkit-appearance: none;
    -moz-appearance: none;
    width: 100%;
    padding: 10px 40px 10px 15px;
    border: 2px solid #ddd;
    border-radius: 8px;
    background-color: #fff;
    cursor: pointer;
    font-size: 16px;
    transition: all 0.2s ease;
}

/* สร้างลูกศรใหม่ด้วย CSS (ไม่ใช้รูปภาพ) */
.variant-select-wrapper::after {
    content: "";
    position: absolute;
    right: 15px;
    top: 50%;
    transform: translateY(-50%);
    width: 0; 
    height: 0; 
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 7px solid #666; /* สีของลูกศร */
    pointer-events: none; /* ทำให้คลิกทะลุไปที่ select ได้ */
}

/* Hover Effect: เมื่อเมาส์วางชี้ */
#size-select:hover {
    border-color: #007bff;
    background-color: #f8f9fa;
}

#size-select:hover + .variant-select-wrapper::after {
    border-top-color: #007bff; /* เปลี่ยนสีลูกศรตอน hover */
}

/* Focus Effect: เมื่อคลิกเลือก */
#size-select:focus {
    outline: none;
    border-color: #007bff;
    box-shadow: 0 0 0 3px rgba(0, 123, 255, 0.15);
}


.btn-order {
    background: #28a745; color: white; border: none;
    padding: 15px 30px; border-radius: 5px; cursor: pointer;
    font-size: 1.1rem; width: 100%; transition: 0.3s;
}
.btn-order:hover { background: #218838; }

/* 3. Description Section */
.section-divider { margin: 40px 0; border: 0; border-top: 1px solid #eee; }
.desc-content { display: flex; gap: 30px; align-items: flex-start; }
.desc-img-side { width: 300px; border-radius: 8px; }
.desc-text { flex: 1; }

/* --- 1. พื้นหลังเทาจาง --- */
#imageModal {
    display: none;
    position: fixed;
    z-index: 9999;
    left: 0; top: 0;
    width: 100%; height: 100%;
    background-color: rgba(0, 0, 0, 0.5); /* เพิ่มความเข้มเล็กน้อยเพื่อให้รูปเด่น */
    backdrop-filter: blur(3px);
    justify-content: center;
    align-items: center;
    display: none; /* จะถูกเปลี่ยนเป็น flex โดย JS */
}

/* --- 2. ตัวหุ้ม (หัวใจสำคัญที่ทำให้ปุ่ม X เกาะรูป) --- */
.modal-wrapper {
    position: relative; /* เพื่อให้ปุ่ม close อ้างอิงตำแหน่งจากตรงนี้ */
    display: inline-block;
    max-width: 90%;
    max-height: 90vh;
}

/* --- 3. รูปภาพ --- */
#img01 {
    display: block;
    max-width: 100%; /* ให้กว้างเต็ม wrapper */
    max-height: 85vh;
    border: 5px solid #fff;
    border-radius: 8px;
    box-shadow: 0 10px 40px rgba(0,0,0,0.5);
    animation: zoomAnim 0.3s ease-out;
}

/* --- 4. ปุ่มกากบาท (ย้ายมาอยู่บนรูป) --- */
.close {
    position: absolute;
    /* วางทับมุมขวาบนของรูป */
    top: -15px; 
    right: -15px;
    width: 35px;
    height: 35px;
    background-color: #FFFFFF; /* สีแดงเพื่อให้เห็นชัดบนมือถือ */
    color: #000000;
    border-radius: 50%; /* วงกลม */
    display: flex;
    justify-content: center;
    align-items: center;
    font-size: 24px;
    font-weight: bold;
    cursor: pointer;
    z-index: 10001;
    box-shadow: 0 2px 10px rgba(0,0,0,0.6);
    line-height: 0;
}

.close:hover {
    background-color: #D8D8D6;
}
/* --- 4. คำบรรยายใต้รูป --- */
#caption {
    margin-top: 15px;
    color: #333;
    font-weight: bold;
    text-shadow: 0 0 5px #fff; /* ช่วยให้เห็นชัดบนพื้นหลังเทา */
}

@keyframes zoomAnim {
    from {transform:scale(0.8); opacity: 0;} 
    to {transform:scale(1); opacity: 1;}
}

/* --- 5. ปรับแต่งสำหรับมือถือ ปุ่มกากบาท --- */
@media (max-width: 1024px) {
    .close {
        top: 5px; /* บนมือถือให้ขยับเข้ามาในรูปนิดหน่อยกันหลุดจอ */
        right: 5px;
        width: 40px; /* ใหญ่ขึ้นนิดนึงเพื่อให้กดง่าย */
        height: 40px;
    }
}

/* Responsive สำหรับมือถือ */
@media (max-width: 1024px) {
    .product-main { grid-template-columns: 1fr; } /* ยุบรวมเป็นแถวเดียวใน Tablet/Mobile */
    .desc-content { flex-direction: column; }
    .desc-img-side { width: 100%; }
}
/* --- Featured Products Grid --- */
.featured-section { padding: 60px 0; background: #fff; }

/* --- ส่วนจัดการกลุ่มกล่องสินค้า --- */
.product-grid {
    display: grid;
    /* บังคับ 4 คอลัมน์ และให้ยืดหยุ่นตามความกว้างของ Container (ไม่ล้น) */
    grid-template-columns: repeat(4, 1fr); 
    /* เว้นระยะห่างตามที่คุณต้องการ */
    gap: 6px; 
    width: 100%;           /* บังคับให้กว้างเท่ากับ Container เท่านั้น */
    margin: 0 auto;
    box-sizing: border-box; /* ป้องกัน Padding/Gap ไปดันขนาดจนล้น */
}

/* --- ส่วนกล่องสินค้ารายชิ้น --- */
.product-card {
    background: #fff;
    border: 1px solid #eee;
    border-radius: 12px;
    overflow: hidden;
    padding: 6px;          /* เว้นระยะห่างตามที่คุณต้องการ */
    display: flex;
    flex-direction: column;
    align-items: center;
    box-shadow: 5px 5px 15px rgba(0,0,0,0.08);
    width: 100%;           /* ให้กว้างตามคอลัมน์ของ Grid */
    box-sizing: border-box;
    position: relative; /* บังคับให้ป้ายเกาะติดกับกล่องนี้ */
}
.badge-best {
    position: absolute;
    top: 10px;          /* ห่างจากด้านบน 10px */
    right: 10px;        /* ห่างจากด้านขวา 10px */
    background-color: #cc0000; /* สีแดงเดียวกับธีมเว็บ */
    color: #ffffff;
    width: 60px;        /* ความกว้างวงกลม */
    height: 60px;       /* ความสูงวงกลม */
    border-radius: 50%; /* ทำเป็นวงกลม */
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 0.75rem;
    font-weight: bold;
    line-height: 1.2;
    z-index: 10;        /* ให้อยู่เหนือรูปภาพ */
    box-shadow: 0 4px 8px rgba(0,0,0,0.2); /* เพิ่มเงาให้ดูนูน */
    transform: rotate(15deg); /* เอียงเล็กน้อยเพื่อให้ดูทันสมัย */
    border: 2px solid #fff;   /* ขอบขาวตัดกับสีแดงให้เด่นขึ้น */
}
/* เอฟเฟกต์สั่นเบาๆ เมื่อเอาเมาส์ชี้กล่องสินค้า */
.product-card:hover .badge-best {
    animation: pulse 1s infinite;
}
@keyframes pulse {
    0% { transform: rotate(15deg) scale(1); }
    50% { transform: rotate(15deg) scale(1.1); }
    100% { transform: rotate(15deg) scale(1); }
}
/* --- ป้าย Badge Hot สีเหลืองทอง --- */
/* --- ป้าย Badge Hot สีเหลืองทองแบบโปร่งแสง --- */
.badge-hot {
    position: absolute;
    top: 10px;
    right: 10px;
    
    /* 1. ปรับสีทองแบบโปร่งแสง (เลข 0.8 คือความโปร่งใส ปรับได้ 0.1 - 1.0) */
    background: rgba(255, 215, 0, 0.4); 
    
    /* 2. ถ้าต้องการให้ดูหรูแบบกระจกฝ้า (Glassmorphism) ให้เปิดใช้บรรทัดนี้ */
    backdrop-filter: blur(4px); 
    
    color: #333;
    width: 55px;
    height: 55px;
    border-radius: 50%;
    display: flex;
    align-items: center;
    justify-content: center;
    text-align: center;
    font-size: 0.85rem;
    font-weight: 900;
    text-transform: uppercase;
    z-index: 10;
    
    /* 3. ปรับขอบให้จางลงตามเพื่อให้เข้ากับความโปร่งแสง */
    border: 2px solid rgba(255, 255, 255, 0.5); 
    
    box-shadow: 0 4px 10px rgba(0, 0, 0, 0.1);
    transform: rotate(-10deg);
    transition: all 0.3s ease;
}

/* เอฟเฟกต์เมื่อเอาเมาส์ชี้ (Hover) ให้สว่างขึ้น */
.product-card:hover .badge-hot {
    background: rgba(255, 215, 0, 1); /* กลับมาเข้ม 100% เมื่อชี้ */
    transform: rotate(-10deg) scale(1.1);
    box-shadow: 0 0 15px rgba(255, 215, 0, 0.5);
}


.product-card:hover {
    /* เมื่อเอาเมาส์ชี้ เงาจะเข้มขึ้นและกล่องลอยขึ้นเล็กน้อย */
    box-shadow: 8px 8px 25px rgba(0, 0, 0, 0.15);
    transform: translateY(-5px);
}

/* --- ตกแต่ง Dropdown (Size Select) --- */
.card-variant {
    margin: 20px 10px; /* เพิ่มระยะห่างบน-ล่าง ไม่ให้ติดเนื้อหาอื่น */
}

.size-select-featured {
    width: 100%;
    padding: 10px 12px;
    font-size: 0.9rem;
    color: #333;
    border: 1px solid #dcdcdc;
    border-radius: 6px;
    cursor: pointer;
    outline: none;

    /* การไล่เฉดสี Gradient ให้ดูนูน (จากขาวสว่างไปเทาอ่อนมาก) */
    background: linear-gradient(to bottom, #ffffff 0%, #f9f9f9 100%);
    
    /* เพิ่มเงาด้านในและด้านนอกเล็กน้อยให้ดูมีมิติ (นูน) */
    box-shadow: inset 0 1px 0 rgba(255,255,255,0.8), 0 2px 4px rgba(0,0,0,0.05);
    
    appearance: none; /* ลบปุ่มลูกศรเดิมของระบบออกเพื่อแต่งเอง */
    background-image: url("data:image/svg+xml;charset=US-ASCII,%3Csvg%20xmlns%3D%22http%3A//www.w3.org/2000/svg%22%20width%3D%22292.4%22%20height%3D%22292.4%22%3E%3Cpath%20fill%3D%22%23666%22%20d%3D%22M287%2069.4a17.6%2017.6%200%200%200-13-5.4H18.4c-5%200-9.3%201.8-12.9%205.4A17.6%2017.6%200%200%200%200%2082.2c0%205%201.8%209.3%205.4%2012.9l128%20127.9c3.6%203.6%207.8%205.4%2012.8%205.4s9.2-1.8%2012.8-5.4L287%2095c3.5-3.5%205.4-7.8%205.4-12.8%200-5-1.9-9.2-5.5-12.8z%22/%3E%3C/svg%3E");
    background-repeat: no-repeat;
    background-position: right 12px top 50%;
    background-size: 10px auto;
}

.size-select-featured:hover {
    border-color: #bbb;
    background: linear-gradient(to bottom, #f9f9f9 0%, #f0f0f0 100%);
}

.size-select-featured:focus {
    border-color: var(--dark-color); /* ขอบเปลี่ยนเป็นสีแดงเมื่อคลิก */
    box-shadow: 0 0 0 3px rgba(179, 0, 0, 0.1);
}


/* บังคับขนาดรูปภาพ 363x242px */
.card-img {
    width: 100%;           /* ขยายเต็มความกว้างของ Card */
    max-width: 363px;      /* แต่ห้ามเกินขนาดภาพจริงของคุณ */
    aspect-ratio: 3 / 2;   /* บังคับสัดส่วน 363:242 (3:2) */
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
    background-color: #fff;
}

.card-img img {
    width: 100%;
    height: 100%;
    /* 'contain' จะช่วยให้เห็นภาพครบ 100% ไม่โดนตัดขอบแม้อยู่ในจอที่เล็กลง */
    object-fit: contain;   
    padding: 6px;          /* ระยะห่างตามที่คุณต้องการ */
    display: block;
    box-sizing: border-box; /* สำคัญมาก: เพื่อให้ padding ไม่ทำให้ภาพล้น */
}

/* เอฟเฟกต์ซูมภาพเล็กน้อยเมื่อเอาเมาส์ชี้ (โดยไม่ล้นกรอบ) */
.product-card:hover .card-img img {
    transform: scale(1.05);
}


.card-info { padding: 15px; }

.card-title {
    font-size: 1.1rem;
    color: #333;
    margin-bottom: 15px;
    text-align: center;
    
    /* แก้ไขปัญหาการทับซ้อน */
    line-height: 1.4;       /* กำหนดความสูงระหว่างบรรทัด */
    min-height: 2.8em;     /* บังคับความสูงให้เท่ากับ 2 บรรทัดเสมอ (1.4 x 2) */
    display: -webkit-box;
    -webkit-line-clamp: 2; /* แสดงผลสูงสุดแค่ 2 บรรทัด ถ้าเกินจะใส่ ... (Dots) */
    -webkit-box-orient: vertical;
    overflow: hidden;      /* ตัดส่วนที่เกินออก ไม่ให้ไปบังส่วนราคา */
}


.card-old-price { color: #999; font-size: 0.9rem; margin-bottom: 5px; }
.card-sale-price {
    font-family: impact, sans-serif; /* ใช้ฟอนต์ Impact ตามที่คุณชอบ */
    color: #cc0000;
    font-size: 1.6rem;
    margin-bottom: 5px;
}

.card-discount {
    color: #28a745;
    font-weight: bold;
    font-size: 0.85rem;
    margin-bottom: 15px;
}
.price-container {
    display: flex;         /* จัดให้อยู่บรรทัดเดียวกัน */
    justify-content: center; /* จัดกึ่งกลางกล่อง */
    align-items: center;   /* จัดให้อยู่แนวระนาบเดียวกัน */
    gap: 5px;              /* ระยะห่างระหว่างข้อความกับตัวเลข */
    margin: 10px 0;
}
/* --- ปุ่มรายละเอียดสินค้าพร้อมเอฟเฟกต์เรืองแสง --- */
.btn-detail {
    display: block;
    background-color: var(--dark-color); /* สีแดง #cc0000 ตามที่คุณตั้งไว้ */
    color: #ffffff;
    padding: 12px 20px;
    text-decoration: none;
    border-radius: 6px;
    font-weight: bold;
    text-align: center;
    transition: all 0.4s ease; /* กำหนดความนุ่มนวลของการเปลี่ยนสไตล์ */
    border: none;
    cursor: pointer;
    position: relative;
    overflow: hidden;
    margin-top: 10px;
}

/* เอฟเฟกต์เมื่อเอาเมาส์ชี้ (Hover) */
.btn-detail:hover {
    background-color: #ff0000; /* เปลี่ยนเป็นแดงสว่างขึ้นเล็กน้อย */
    color: #fff;
    transform: translateY(-2px); /* ปุ่มลอยขึ้นเล็กน้อย */
    
    /* การทำ Glow Effect (ขอบเรืองแสง) */
    /* ใช้สีแดงโปร่งแสงกระจายตัวออกไป 15px-20px */
    box-shadow: 0 0 15px rgba(204, 0, 0, 0.6), 
                0 0 30px rgba(204, 0, 0, 0.4); 
    
    /* เพิ่มความสว่างให้ตัวปุ่มเล็กน้อย */
    filter: brightness(1.1);
}

/* เอฟเฟกต์เมื่อกดปุ่ม (Active) */
.btn-detail:active {
    transform: translateY(0);
    box-shadow: 0 0 5px rgba(204, 0, 0, 0.8);
}

/* ข้อความปกติ */
.label-text, .card-old-price, .card-discount, .card-variant label {
    font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
    font-size: 14px;
    color: #333;
}

/* เฉพาะตัวเลขราคาขาย และเครื่องหมาย ฿ */
.display-sale-price, .currency {
    font-family: impact, "Trebuchet MS", arial, sans-serif;
    font-size: 22px;
    color: #cc0000;
}

/* จัดระยะห่างเล็กน้อย */
.card-sale-price {
    margin: 10px 0;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 5px;
}

/* --- Footer Professional Look --- */
.main-footer {
    background: #1a1a1a; /* สีดำเข้มดูพรีเมียม */
    color: #ddd;
    padding: 60px 0 20px;
    margin-top: 50px;
}

.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1.5fr; /* แบ่งสัดส่วนคอลัมน์ */
    gap: 40px;
}

.footer-box h4 {
    color: #fff;
    margin-bottom: 20px;
    border-left: 3px solid #cc0000; /* เส้นแดงนำสายตา */
    padding-left: 10px;
}

.footer-box ul { list-style: none; }
.footer-box ul li { margin-bottom: 10px; }
.footer-box a { color: #aaa; text-decoration: none; transition: 0.3s; }
.footer-box a:hover { color: #fff; padding-left: 5px; }

.footer-bottom {
    border-top: 1px solid #333;
    margin-top: 40px;
    padding-top: 20px;
    text-align: center;
    font-size: 0.85rem;
}

/* --- ปุ่ม Line สีเขียวมาตรฐาน --- */
.btn-line {
    background: #06c755; /* สีเขียว Line */
    color: white;
    border: none;
    padding: 12px 20px;
    border-radius: 5px;
    cursor: pointer;
    font-weight: bold;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    width: 100%;
    margin-top: 15px;
    transition: 0.3s;
}
.btn-line:hover { background: #05a346; transform: scale(1.02); }

/* แก้ไขส่วนรายละเอียดสินค้าให้แสดงผลเต็มบรรทัด ไม่ให้วีดีโอเด้งสวนขึ้นมา */
.product-description {
    width: 100%;
    margin-top: 50px;
    clear: both; /* ล้างค่า float เก่าจากส่วนบน */
}

.desc-content {
    display: block; /* เปลี่ยนจาก flex เป็น block เพื่อให้เนื้อหาไหลลงล่างตามปกติ */
    width: 100%;
    line-height: 1.8;
}

/* 1. ปรับระยะห่างรูปภาพในเนื้อหาให้ชิดกัน (2-4px) */
.desc-content img {
    margin: 2px auto !important; /* ระยะห่างบน-ล่าง 2px */
    display: block;
    max-width: 100%;
    height: auto;
}
/* 1. สั่งให้ตัวตัดบรรทัด (br) ในส่วนเนื้อหาไม่มีความสูง */
.desc-content br {
    display: block; /* หรือ none หากต้องการให้ชิดสนิท */
    content: "";
    margin-top: 0;
    margin-bottom: 0;
    line-height: 0;
    height: 0;
}

/* 2. บังคับรูปภาพให้เป็น Block เพื่อให้มันขึ้นบรรทัดใหม่เองโดยไม่พึ่ง <br /> */
.desc-content img {
    display: block; 
    margin: 0 auto 4px auto !important; /* เว้นระยะห่างด้านล่างแค่ 4px ตามที่คุณต้องการ */
    padding: 0 !important;
    max-width: 100%;
    height: auto;
}

/* 3. หากมีข้อความที่ต้องการให้เว้นบรรทัดปกติ */
.desc-content p {
    margin-bottom: 15px !important;
}

/* 2. คืนค่าขนาดวีดีโอตาม Database (560x315) */
.desc-content iframe, 
.desc-content video {
    display: block;
    margin: 20px auto; /* จัดกึ่งกลางเฉยๆ แต่ไม่บังคับ width 100% */
    max-width: 100%; /* กันหลุดขอบมือถือเท่านั้น */
    border: none;
}

/* Responsive สำหรับมือถือ */
@media (max-width: 768px) {
    .footer-grid { grid-template-columns: 1fr; text-align: center; }
    .footer-box h4 { border-left: none; padding-left: 0; }
}

/* Responsive สำหรับมือถือและแท็บเล็ต */
@media (max-width: 1024px) {
    .product-grid { grid-template-columns: repeat(2, 1fr); } /* แท็บเล็ตเหลือแถวละ 2 */
}
@media (max-width: 480px) {
    .product-grid { grid-template-columns: 1fr; } /* มือถือเหลือแถวละ 1 */
}
/* หากต้องการล็อกขนาดกล่องให้เป๊ะ 363x242 ในหน้าจอคอม */
@media (max-width: 1200px) {
    .product-grid {
        grid-template-columns: repeat(2, 1fr); /* จอเล็กลงเหลือ 2 คอลัมน์ */
    }
}

@media (max-width: 600px) {
    .product-grid {
        grid-template-columns: 1fr; /* มือถือเหลือ 1 คอลัมน์ */
    }
}