/* ============================================================
   SITE-PREMIUM.CSS — Global premium styles for all pages
   MG Consulting Formation
   Brand tokens inherited from brand.css (:root)
   ============================================================ */

/* ─── Shared scroll-reveal (mirrors about/contact pages) ─────── */
.mg-reveal {
    opacity: 0;
    transform: translateY(44px);
    transition: opacity 0.85s cubic-bezier(0.4,0,0.2,1),
                transform 0.85s cubic-bezier(0.4,0,0.2,1);
}
.mg-reveal-left {
    opacity: 0;
    transform: translateX(-52px);
    transition: opacity 0.85s cubic-bezier(0.4,0,0.2,1),
                transform 0.85s cubic-bezier(0.4,0,0.2,1);
}
.mg-reveal-right {
    opacity: 0;
    transform: translateX(52px);
    transition: opacity 0.85s cubic-bezier(0.4,0,0.2,1),
                transform 0.85s cubic-bezier(0.4,0,0.2,1);
}
.mg-reveal.mg-in,
.mg-reveal-left.mg-in,
.mg-reveal-right.mg-in { opacity: 1; transform: none; }
.mg-d1 { transition-delay: 0.08s; }
.mg-d2 { transition-delay: 0.18s; }
.mg-d3 { transition-delay: 0.28s; }
.mg-d4 { transition-delay: 0.40s; }
.mg-d5 { transition-delay: 0.52s; }
.mg-d6 { transition-delay: 0.66s; }


/* ============================================================
   1. PAGE BANNER (page-banner + inner titles)
   ============================================================ */
.page-banner {
    position: relative;
    min-height: 280px;
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.page-banner::before {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
        rgba(26,24,14,0.78) 0%,
        rgba(154,139,82,0.45) 50%,
        rgba(28,37,96,0.62) 100%);
    z-index: 1;
}
/* Animated shimmer stripe */
.page-banner::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(90deg,
        transparent 0%, rgba(212,168,67,0.12) 50%, transparent 100%);
    background-size: 200% 100%;
    animation: sp-banner-shine 4s linear infinite;
    z-index: 2;
}
@keyframes sp-banner-shine {
    0% { background-position: -200% 0; }
    100% { background-position: 200% 0; }
}
/* Overlay div used in some pages */
.page-banner .overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(135deg,
        rgba(26,24,14,0.70) 0%,
        rgba(28,37,96,0.55) 100%);
    z-index: 1;
}
.page-banner .inner,
.page-banner .page-banner-inner {
    position: relative;
    z-index: 3;
    text-align: center;
    padding: 60px 20px;
}
.page-banner h1,
.page-banner .inner h1,
.page-banner .page-banner-inner h1 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.8rem, 4vw, 3rem);
    font-weight: 700;
    color: #fff;
    margin: 0;
    text-shadow: 0 2px 24px rgba(0,0,0,0.45);
    letter-spacing: 1px;
}
/* Gold underline decoration */
.page-banner h1::after {
    content: '';
    display: block;
    width: 64px;
    height: 3px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#d4a843));
    border-radius: 2px;
    margin: 14px auto 0;
}


/* ============================================================
   2. SECTION HEADLINES (used in index.php, catalogue, etc.)
   ============================================================ */
.headline {
    text-align: center;
    margin-bottom: 44px;
    padding-top: 10px;
}
.headline h2 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 700;
    color: var(--mg-dark, #1a180e);
    position: relative;
    display: inline-block;
    margin-bottom: 10px;
}
.headline h2::after {
    content: '';
    display: block;
    width: 56px;
    height: 3px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#d4a843));
    border-radius: 2px;
    margin: 10px auto 0;
}
.headline h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
    font-weight: 400;
    color: #777;
    margin-top: 4px;
}


/* ============================================================
   3. .page CONTAINER (generic page sections)
   ============================================================ */
.page {
    padding: 60px 0;
    background: #f9f8f4;
    min-height: 50vh;
}
.page > .container { max-width: 1200px; }


/* ============================================================
   4. PRODUCT CARDS (carousels + category grids)
   ============================================================ */
/* Product card .item */
.product .item {
    background: #fff;
    border-radius: 16px;
    overflow: hidden;
    box-shadow: 0 4px 18px rgba(107,96,56,0.10);
    transition: transform 0.30s cubic-bezier(0.4,0,0.2,1),
                box-shadow 0.30s cubic-bezier(0.4,0,0.2,1);
    margin: 8px;
}
.product .item:hover {
    transform: translateY(-6px);
    box-shadow: 0 12px 36px rgba(107,96,56,0.22);
}
/* Product thumbnail */
.product .item .thumb {
    position: relative;
    overflow: hidden;
    height: 220px;
}
.product .item .thumb .photo {
    width: 100%;
    height: 100%;
    background-size: cover;
    background-position: center;
    transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
}
.product .item:hover .thumb .photo {
    transform: scale(1.07);
}
/* Overlay gradient on hover */
.product .item .thumb .overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        transparent 40%, rgba(26,24,14,0.55) 100%);
    opacity: 0;
    transition: opacity 0.30s ease;
}
.product .item:hover .thumb .overlay {
    opacity: 1;
}
/* Text section of card */
.product .item .text {
    padding: 18px 16px 20px;
}
.product .item .text h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    font-weight: 600;
    margin: 0 0 8px;
    line-height: 1.4;
}
.product .item .text h3 a {
    color: var(--mg-dark, #1a180e);
    text-decoration: none;
    transition: color 0.22s ease;
}
.product .item .text h3 a:hover {
    color: var(--mg-accent, #d4a843);
}
/* Price */
.product .item .text h4 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: var(--mg-primary, #9a8b52);
    margin: 0 0 10px;
}
.product .item .text h4 del {
    font-size: 0.85rem;
    font-weight: 400;
    color: #aaa;
    margin-left: 6px;
}
/* Stars */
.product .item .text .rating i {
    color: var(--mg-accent, #d4a843);
    font-size: 0.8rem;
}
/* Add to cart link */
.product .item .text p a {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin-top: 12px;
    padding: 9px 20px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038));
    color: #fff;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    text-decoration: none;
    letter-spacing: 0.3px;
    transition: all 0.26s cubic-bezier(0.4,0,0.2,1);
    box-shadow: 0 3px 12px rgba(154,139,82,0.30);
}
.product .item .text p a:hover {
    transform: translateY(-2px);
    box-shadow: 0 6px 20px rgba(154,139,82,0.45);
    background: linear-gradient(135deg, #d4a843, #9a8b52);
}
/* Out of stock badge */
.product .item .out-of-stock .inner {
    display: inline-block;
    margin-top: 12px;
    padding: 5px 16px;
    background: #f8d7da;
    color: #c0392b;
    border-radius: 999px;
    font-size: 0.78rem;
    font-weight: 600;
}


/* ============================================================
   5. PRODUCT CATEGORY / SEARCH GRID (product-cat)
   ============================================================ */
.product.product-cat .col-md-3 {
    margin-bottom: 28px;
}
/* Shared product-list .photo-box pattern */
.product-cat .product-card,
.product-cat .item {
    border-radius: 16px !important;
}

/* Product-category CTA (Reserver) */
.product.product-cat .item .text p {
    margin-top: 16px;
    margin-bottom: 10px;
}
.product.product-cat .item .text p a {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 8px;
    min-height: 44px;
    padding: 0 24px;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.96rem;
    font-weight: 700;
    letter-spacing: 0.2px;
    line-height: 1;
}
.product.product-cat .item .text p a i {
    font-size: 0.92rem;
}

/* Breadcrumb */
.breadcrumb {
    background: none;
    padding: 8px 0 18px;
    margin-bottom: 0;
}
.breadcrumb ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 6px;
}
.breadcrumb ul li {
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    color: #888;
}
.breadcrumb ul li a {
    color: var(--mg-primary, #9a8b52);
    text-decoration: none;
    font-weight: 500;
    transition: color 0.2s;
}
.breadcrumb ul li a:hover { color: var(--mg-accent, #d4a843); }

/* Pagination */
.pagination {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    justify-content: center;
    padding: 30px 0 10px;
}
.pagination a,
.pagination span {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 38px;
    height: 38px;
    padding: 0 12px;
    border-radius: 8px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.85rem;
    font-weight: 500;
    background: #fff;
    color: var(--mg-dark, #1a180e);
    border: 1px solid #e0dac8;
    text-decoration: none;
    transition: all 0.22s ease;
}
.pagination a:hover {
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038));
    color: #fff;
    border-color: transparent;
}
.pagination .current,
.pagination span.current {
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038));
    color: #fff;
    border-color: transparent;
}


/* ============================================================
   6. HOMEPAGE — Service / References section
   ============================================================ */
.service.bg-gray {
    background: #f4f1e8 !important;
    padding: 70px 0;
}
.service {
    padding: 70px 0;
}

/* Infinite-scroll references slider */
.service .wrapper {
    overflow: hidden;
    position: relative;
    padding: 20px 0;
}
.service .wrapper::before,
.service .wrapper::after {
    content: '';
    position: absolute;
    top: 0; bottom: 0;
    width: 100px;
    z-index: 2;
    pointer-events: none;
}
.service .wrapper::before {
    left: 0;
    background: linear-gradient(to right, #f4f1e8, transparent);
}
.service .wrapper::after {
    right: 0;
    background: linear-gradient(to left, #f4f1e8, transparent);
}
.service .slider .slide-track {
    display: flex;
    gap: 32px;
    animation: sp-scroll 28s linear infinite;
    width: max-content;
}
@keyframes sp-scroll {
    0% { transform: translateX(0); }
    100% { transform: translateX(-50%); }
}
.service .slider .slide img {
    height: 72px;
    width: auto;
    object-fit: contain;
    filter: grayscale(30%);
    opacity: 0.85;
    transition: filter 0.3s, opacity 0.3s, transform 0.3s;
    border-radius: 6px;
}
.service .slider .slide img:hover {
    filter: grayscale(0%);
    opacity: 1;
    transform: scale(1.06);
}

/* Homepage catalogue-catalog credit section */
.service .credit {
    padding: 10px 0;
}


/* ============================================================
   7. HOMEPAGE — CTA section
   ============================================================ */
.cta-section,
.home-cta {
    background: linear-gradient(135deg,
        var(--mg-dark,#1a180e) 0%,
        var(--mg-secondary,#1c2560) 100%);
    padding: 80px 0;
    text-align: center;
    position: relative;
    overflow: hidden;
}
.cta-section h2,
.home-cta h2 {
    font-family: 'Poppins', sans-serif;
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 700;
    color: #fff;
    margin-bottom: 16px;
}
.cta-section p,
.home-cta p {
    color: rgba(255,255,255,0.80);
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
    margin-bottom: 32px;
}


/* ============================================================
   8. AUTH FORMS — Login / Register / Forgot Password
   ============================================================ */
/* Page wrapper for auth pages */
section.contact.section-bg,
.section-bg {
    background: linear-gradient(135deg, #f9f8f4 0%, #ede8d8 100%);
    padding: 60px 0 80px;
    min-height: 70vh;
}
div.main {
    position: relative;
    /* Override dark theme from login-register.css */
    background: linear-gradient(135deg, #f9f8f4 0%, #ede8d8 100%) !important;
    color: var(--mg-dark, #1a180e) !important;
    padding-top: 40px !important;
    padding-bottom: 50px !important;
}

/* Form card */
.form-container-2 {
    background: #fff !important;
    border-radius: 20px !important;
    padding: 44px 40px !important;
    box-shadow: 0 8px 40px rgba(107,96,56,0.14) !important;
    position: relative;
    overflow: visible;
    max-width: 900px;
    margin: 0 auto;
    /* Override dark glass style from login-register.css */
    border: none !important;
    backdrop-filter: none !important;
    color: var(--mg-dark, #1a180e) !important;
}
/* Animated gold top border via pseudo-element fallback */
.form-container-2::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 4px;
    background: linear-gradient(90deg,#b09e60,#d4a843,#b09e60);
    border-radius: 20px 20px 0 0;
}

/* Decorative circles — override login-register.css dark navy */
.form-container-2 .circle {
    position: absolute;
    border-radius: 50%;
    pointer-events: none;
    background: none !important;   /* reset dark navy from login-register.css */
}
.form-container-2 .circle-one {
    width: 120px; height: 120px;
    background: radial-gradient(circle, rgba(212,168,67,0.18), transparent 70%) !important;
    top: -40px; right: -40px;
    left: auto !important; z-index: -1 !important;
}
.form-container-2 .circle-two {
    width: 80px; height: 80px;
    background: radial-gradient(circle, rgba(28,37,96,0.12), transparent 70%) !important;
    bottom: -30px; left: -30px;
}

/* Form labels */
.form-container-2 label,
.form-container-2 .form-group label {
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    color: #555 !important;
    margin-bottom: 6px;
    letter-spacing: 0.3px;
    display: block;
}
/* Form inputs — override any dark/glass input styles */
.form-container-2 .form-control,
div.main .form-control {
    border: 1.5px solid #e0dac8 !important;
    border-radius: 10px !important;
    padding: 11px 15px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 0.9rem !important;
    color: var(--mg-dark, #1a180e) !important;
    background: #fdfcf8 !important;
    transition: border-color 0.24s ease, box-shadow 0.24s ease !important;
    box-shadow: none !important;
    backdrop-filter: none !important;
}
.form-container-2 .form-control:focus,
div.main .form-control:focus {
    border-color: var(--mg-accent, #d4a843) !important;
    box-shadow: 0 0 0 3px rgba(212,168,67,0.20) !important;
    background: #fff !important;
    outline: none !important;
}
.form-container-2 textarea.form-control { resize: vertical; min-height: 90px; }
.form-container-2 select.form-control {
    appearance: none;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='6'%3E%3Cpath d='M0 0l5 6 5-6z' fill='%23888'/%3E%3C/svg%3E") !important;
    background-repeat: no-repeat !important;
    background-position: right 14px center !important;
    padding-right: 36px !important;
    background-color: #fdfcf8 !important;
}

/* Register / submit button — override login-register.css dark navy */
.register-btn,
input[type="submit"].register-btn {
    display: inline-flex !important;
    align-items: center !important;
    justify-content: center !important;
    width: 100% !important;
    padding: 13px 28px !important;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038)) !important;
    background-color: transparent !important;
    color: #fff !important;
    border: none !important;
    border-radius: 999px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 0.95rem !important;
    font-weight: 700 !important;
    letter-spacing: 0.5px;
    cursor: pointer;
    transition: all 0.26s cubic-bezier(0.4,0,0.2,1) !important;
    box-shadow: 0 4px 18px rgba(154,139,82,0.35) !important;
    margin-top: 6px;
    text-shadow: none;
}
.register-btn:hover,
input[type="submit"].register-btn:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 8px 28px rgba(154,139,82,0.50) !important;
    background: linear-gradient(135deg,#d4a843,#9a8b52) !important;
    color: #fff !important;
}

/* Forgot password link */
.register-forget {
    display: block;
    margin-top: 14px;
    text-align: center;
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    color: var(--mg-primary, #9a8b52);
    text-decoration: none;
    transition: color 0.2s;
}
.register-forget:hover { color: var(--mg-accent, #d4a843); text-decoration: underline; }

/* Error / success messages */
.form-container-2 .error,
div.error {
    padding: 12px 16px !important;
    background: #fff4f4 !important;
    border-left: 4px solid #e74c3c;
    border-radius: 8px;
    color: #c0392b;
    font-family: 'Poppins', sans-serif;
    font-size: 0.85rem;
    margin-bottom: 18px !important;
}
.form-container-2 .success,
div.success {
    padding: 12px 16px !important;
    background: #f0faf4 !important;
    border-left: 4px solid #27ae60;
    border-radius: 8px;
    color: #1e8c49;
    font-family: 'Poppins', sans-serif;
    font-size: 0.85rem;
    margin-bottom: 18px !important;
}

/* vide spacer col used in login.php — hide, handled by centering */
.vide { display: none; }


/* ============================================================
   9. CART PAGE
   ============================================================ */
/* Cart table wrapper */
div.cart {
    background: #fff;
    border-radius: 18px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
    overflow: hidden;
    margin-bottom: 30px;
}
div.cart .table {
    margin-bottom: 0;
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
}
div.cart .table thead tr th,
div.cart .table tr th {
    background: linear-gradient(90deg, var(--mg-dark,#1a180e), var(--mg-secondary,#1c2560));
    color: #fff;
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    letter-spacing: 0.5px;
    padding: 14px 16px;
    border: none;
    text-transform: uppercase;
}
div.cart .table tr td {
    padding: 14px 16px;
    vertical-align: middle;
    border-color: #f0ece0;
    color: #444;
}
div.cart .table tr:hover td {
    background: #fdfcf8;
}
div.cart .table tr td img {
    width: 60px; height: 60px;
    object-fit: cover;
    border-radius: 10px;
    box-shadow: 0 2px 8px rgba(0,0,0,0.10);
}
/* Quantity input */
div.cart input.qty {
    width: 70px;
    text-align: center;
    border: 1.5px solid #e0dac8;
    border-radius: 8px;
    padding: 7px 10px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.9rem;
    transition: border-color 0.22s;
}
div.cart input.qty:focus {
    border-color: var(--mg-accent, #d4a843);
    box-shadow: 0 0 0 3px rgba(212,168,67,0.18);
    outline: none;
}

/* Cart summary totals row */
div.cart .table .total-text,
div.cart .table .total-amount {
    background: #fdfcf8;
    font-family: 'Poppins', sans-serif;
    font-weight: 700;
    font-size: 1rem;
    color: var(--mg-dark, #1a180e);
    border-top: 2px solid #e0dac8;
    padding: 16px 16px;
}
div.cart .table .total-amount {
    color: var(--mg-primary, #9a8b52);
    font-size: 1.15rem;
}

/* Cart action buttons (Update, Checkout) */
.cart-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-top: 20px;
}

/* Update cart + checkout buttons — target common submit/link patterns */
.page input[type="submit"],
.page a.btn-checkout,
.page .btn-update-cart {
    padding: 11px 28px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038));
    color: #fff;
    border: none;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
    font-weight: 600;
    cursor: pointer;
    transition: all 0.26s;
    box-shadow: 0 3px 14px rgba(154,139,82,0.30);
    text-decoration: none;
    display: inline-block;
}
.page input[type="submit"]:hover,
.page a.btn-checkout:hover,
.page .btn-update-cart:hover {
    transform: translateY(-2px);
    box-shadow: 0 7px 22px rgba(154,139,82,0.45);
    background: linear-gradient(135deg,#d4a843,#9a8b52);
    color: #fff;
}

/* WhatsApp help box */
.whatsapp-help-box {
    background: linear-gradient(135deg, #e8f5e9, #f1f8e9);
    border: 2px solid #4caf50;
    border-radius: 16px;
    padding: 28px 32px;
    text-align: center;
    margin: 30px auto;
    max-width: 480px;
    box-shadow: 0 4px 20px rgba(76,175,80,0.12);
}
.whatsapp-help-box h4 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.05rem;
    font-weight: 700;
    color: #2e7d32;
    margin-bottom: 10px;
}
.whatsapp-help-box h4 i { margin-right: 8px; }
.whatsapp-help-box p {
    color: #555;
    font-size: 0.9rem;
    margin-bottom: 20px;
}
.whatsapp-direct-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 12px 26px;
    background: #25d366;
    color: #fff;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-weight: 600;
    font-size: 0.92rem;
    text-decoration: none;
    transition: all 0.26s;
    box-shadow: 0 4px 16px rgba(37,211,102,0.35);
}
.whatsapp-direct-link:hover {
    background: #128c7e;
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(37,211,102,0.50);
    color: #fff;
    text-decoration: none;
}
.whatsapp-direct-link i { font-size: 1.2rem; }


/* ============================================================
   10. CHECKOUT PAGE
   ============================================================ */
.billing-address {
    margin-top: 36px;
    background: #fff;
    border-radius: 18px;
    padding: 32px 36px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
}
.billing-address h3.special {
    font-family: 'Poppins', sans-serif;
    font-size: 1.1rem;
    font-weight: 700;
    color: var(--mg-dark, #1a180e);
    margin-bottom: 16px;
    padding-bottom: 10px;
    border-bottom: 2px solid #e0dac8;
}
.billing-address h3.special::before {
    content: '● ';
    color: var(--mg-accent, #d4a843);
}
.bill-address {
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
    border-radius: 10px;
    overflow: hidden;
    margin-bottom: 20px;
}
.bill-address tr td {
    padding: 10px 14px;
    border-color: #f0ece0;
    color: #555;
}
.bill-address tr td:first-child {
    font-weight: 600;
    color: #333;
    background: #fdfcf8;
    width: 40%;
}


/* ============================================================
   11. PRODUCT DETAIL PAGE
   ============================================================ */
/* Product detail wrapper */
.page .product {
    background: #fff;
    border-radius: 18px;
    padding: 32px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
    margin-bottom: 30px;
}

/* Product title */
.page .product h1,
.page .product .product-title {
    font-family: 'Poppins', sans-serif;
    font-size: 1.7rem;
    font-weight: 700;
    color: var(--mg-dark, #1a180e);
    margin-bottom: 12px;
}
/* Price block */
.page .product .price-block h4,
.page .product h4.price {
    font-family: 'Poppins', sans-serif;
    font-size: 1.4rem;
    font-weight: 800;
    color: var(--mg-primary, #9a8b52);
}
.page .product h4.price del {
    font-size: 1rem;
    font-weight: 400;
    color: #aaa;
    margin-left: 8px;
}

/* Add to cart button on product detail */
.page .product input[type="submit"].btn-cart,
.page .product .btn.btn-cart,
.page .product .add-to-cart-btn {
    padding: 13px 32px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038));
    color: #fff;
    border: none;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    cursor: pointer;
    transition: all 0.26s;
    box-shadow: 0 4px 18px rgba(154,139,82,0.35);
}
.page .product input[type="submit"].btn-cart:hover,
.page .product .btn.btn-cart:hover,
.page .product .add-to-cart-btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(154,139,82,0.50);
    background: linear-gradient(135deg,#d4a843,#9a8b52);
}

/* Product tabs */
.page .product .nav-tabs {
    border-bottom: 2px solid #e0dac8;
    margin-bottom: 20px;
}
.page .product .nav-tabs > li > a {
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
    font-weight: 600;
    color: #888;
    border: none;
    border-radius: 0;
    padding: 10px 20px;
    transition: color 0.22s;
}
.page .product .nav-tabs > li.active > a,
.page .product .nav-tabs > li > a:hover {
    color: var(--mg-accent, #d4a843);
    background: none;
    border: none;
    border-bottom: 2px solid var(--mg-accent, #d4a843);
}
.page .product .tab-content {
    font-family: 'Poppins', sans-serif;
    font-size: 0.92rem;
    color: #555;
    line-height: 1.8;
}

/* Review section */
.page .product .review-form label {
    font-family: 'Poppins', sans-serif;
    font-size: 0.82rem;
    font-weight: 600;
    color: #555;
}
.page .product .review-form .form-control {
    border: 1.5px solid #e0dac8;
    border-radius: 10px;
    font-family: 'Poppins', sans-serif;
    transition: border-color 0.24s, box-shadow 0.24s;
}
.page .product .review-form .form-control:focus {
    border-color: var(--mg-accent, #d4a843);
    box-shadow: 0 0 0 3px rgba(212,168,67,0.18);
    outline: none;
}


/* ============================================================
   12. CUSTOMER DASHBOARD & SIDEBAR
   ============================================================ */
/* Sidebar wrapper */
.user-sidebar {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
    padding: 28px 20px;
    margin-bottom: 28px;
}
.user-sidebar ul {
    list-style: none;
    padding: 0;
    margin: 0;
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}
/* Sidebar navigation buttons */
.user-sidebar a button.btn.btn-danger,
.user-sidebar a .btn-danger {
    background: none !important;
    background-image: none !important;
    border: 2px solid var(--mg-primary, #9a8b52) !important;
    color: var(--mg-primary, #9a8b52) !important;
    border-radius: 999px !important;
    padding: 9px 20px !important;
    font-family: 'Poppins', sans-serif !important;
    font-size: 0.82rem !important;
    font-weight: 600 !important;
    letter-spacing: 0.3px;
    transition: all 0.24s !important;
    box-shadow: none !important;
    text-shadow: none !important;
}
.user-sidebar a:hover button.btn.btn-danger,
.user-sidebar a:hover .btn-danger,
.user-sidebar a:focus button.btn.btn-danger {
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#6b6038)) !important;
    color: #fff !important;
    border-color: transparent !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 5px 16px rgba(154,139,82,0.35) !important;
}

/* User content area */
.user-content {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
    padding: 36px 32px;
}
.user-content h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 1.2rem;
    font-weight: 700;
    color: var(--mg-dark, #1a180e);
    margin-bottom: 20px;
    position: relative;
    display: inline-block;
}
.user-content h3::after {
    content: '';
    display: block;
    width: 40px;
    height: 3px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#d4a843));
    border-radius: 2px;
    margin: 6px auto 0;
}

/* Tables inside user-content (order table, etc.) */
.user-content .table,
.customer-order-table {
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
    border-radius: 10px;
    overflow: hidden;
}
.user-content .table thead tr th,
.customer-order-table thead tr th {
    background: linear-gradient(90deg, var(--mg-dark,#1a180e), var(--mg-secondary,#1c2560));
    color: #fff;
    font-weight: 600;
    font-size: 0.82rem;
    letter-spacing: 0.4px;
    padding: 12px 16px;
    border: none;
    text-transform: uppercase;
}
.user-content .table tr td,
.customer-order-table tr td {
    padding: 12px 16px;
    vertical-align: middle;
    border-color: #f0ece0;
    color: #555;
}
.user-content .table tr:hover td { background: #fdfcf8; }

/* Status badges */
.badge-pending { background: #fff3cd; color: #856404; border-radius: 999px; padding: 3px 12px; font-size: 0.75rem; font-weight: 600; }
.badge-confirmed { background: #d1e7dd; color: #0f5132; border-radius: 999px; padding: 3px 12px; font-size: 0.75rem; font-weight: 600; }
.badge-shipped { background: #cfe2ff; color: #084298; border-radius: 999px; padding: 3px 12px; font-size: 0.75rem; font-weight: 600; }
.badge-delivered { background: #d1e7dd; color: #0a3622; border-radius: 999px; padding: 3px 12px; font-size: 0.75rem; font-weight: 600; }


/* ============================================================
   13. CATALOGUE PAGE
   ============================================================ */
/* Catalogue download button */
.service .headline a.btn.btn-primary,
.service a[download].btn {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 13px 32px;
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#d4a843));
    color: #fff !important;
    border: none;
    border-radius: 999px;
    font-family: 'Poppins', sans-serif;
    font-size: 0.95rem;
    font-weight: 700;
    text-decoration: none;
    transition: all 0.26s;
    box-shadow: 0 4px 18px rgba(154,139,82,0.35);
    margin-top: 18px;
}
.service .headline a.btn.btn-primary:hover,
.service a[download].btn:hover {
    transform: translateY(-2px);
    box-shadow: 0 8px 28px rgba(154,139,82,0.50);
    background: linear-gradient(135deg,#d4a843,#9a8b52);
}

/* Catalogue slideshow */
.slideshow-container {
    position: relative;
    max-width: 860px;
    margin: 0 auto;
}
.mySlides {
    display: none;
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 8px 36px rgba(26,24,14,0.18);
}
.mySlides.fade { animation: sp-fade-in 0.6s ease; }
@keyframes sp-fade-in {
    from { opacity: 0; transform: scale(0.97); }
    to   { opacity: 1; transform: scale(1); }
}
.mySlides img {
    width: 100%;
    height: auto;
    display: block;
    border-radius: 14px;
}
/* Slideshow navigation buttons */
.prev-btn, .next-btn,
button.prev, button.next {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    background: rgba(26,24,14,0.68);
    backdrop-filter: blur(6px);
    color: #fff;
    border: none;
    border-radius: 50%;
    width: 44px; height: 44px;
    font-size: 1.2rem;
    cursor: pointer;
    z-index: 10;
    transition: background 0.24s, transform 0.24s;
    display: flex;
    align-items: center;
    justify-content: center;
}
.prev-btn, button.prev { left: 12px; }
.next-btn, button.next { right: 12px; }
.prev-btn:hover, .next-btn:hover,
button.prev:hover, button.next:hover {
    background: var(--mg-accent, #d4a843);
    transform: translateY(-50%) scale(1.1);
}
/* Dots */
.dots-container {
    text-align: center;
    padding: 16px 0 4px;
}
.dot {
    display: inline-block;
    width: 10px; height: 10px;
    background: #ccc;
    border-radius: 50%;
    margin: 0 4px;
    cursor: pointer;
    transition: background 0.22s, transform 0.22s;
}
.dot.active, .dot:hover {
    background: var(--mg-accent, #d4a843);
    transform: scale(1.3);
}


/* ============================================================
   14. SEARCH RESULTS
   ============================================================ */
.product.product-cat .row {
    display: flex;
    flex-wrap: wrap;
}


/* ============================================================
   15. GENERAL TABLES (checkout, billing, order details)
   ============================================================ */
.table.table-bordered.table-hover,
.table.table-responsive.table-hover.table-bordered {
    font-family: 'Poppins', sans-serif;
    border-radius: 12px;
    overflow: hidden;
    border: none;
    box-shadow: 0 2px 12px rgba(107,96,56,0.08);
}
.table.table-bordered thead tr th {
    background: linear-gradient(90deg, var(--mg-dark,#1a180e), var(--mg-secondary,#1c2560));
    color: #fff;
    font-weight: 600;
    font-size: 0.82rem;
    letter-spacing: 0.4px;
    padding: 13px 16px;
    border: none;
    text-transform: uppercase;
}
.table.table-bordered tr td {
    padding: 12px 16px;
    vertical-align: middle;
    border-color: #f0ece0;
}
.table.table-bordered tr:hover td { background: #fdfcf8; }
.table.table-striped tbody tr:nth-of-type(odd) { background: #fdfcf8; }


/* ============================================================
   16. FORGOT / RESET PASSWORD
   ============================================================ */
/* Inherits .form-container-2 and .section-bg styles from auth section above */
.forget-intro {
    font-family: 'Poppins', sans-serif;
    font-size: 0.92rem;
    color: #666;
    text-align: center;
    margin-bottom: 24px;
}


/* ============================================================
   17. INDEX HOMEPAGE SLIDER
   ============================================================ */
/* Bootstrap touch slider enhancements */
.bt-slider-section .carousel-caption,
.slider-caption {
    font-family: 'Poppins', sans-serif;
}
.bt-slider-section .carousel-caption h2,
.slider-caption h2 {
    font-size: clamp(1.5rem, 4vw, 3rem);
    font-weight: 800;
    text-shadow: 0 2px 20px rgba(0,0,0,0.5);
}
.bt-slider-section .carousel-caption p {
    font-size: clamp(0.9rem, 2vw, 1.1rem);
    text-shadow: 0 1px 12px rgba(0,0,0,0.4);
}
/* Bootstrap carousel overlay for better text contrast */
.bootstrap-touch-slider .item::after {
    content: '';
    position: absolute;
    inset: 0;
    background: linear-gradient(180deg,
        rgba(0,0,0,0.10) 0%,
        rgba(26,24,14,0.45) 100%);
    pointer-events: none;
}


/* ============================================================
   18. SIDEBAR CATEGORY (product-category sidebar)
   ============================================================ */
.sidebar-category {
    background: #fff;
    border-radius: 16px;
    box-shadow: 0 4px 24px rgba(107,96,56,0.10);
    padding: 24px 20px;
    margin-bottom: 28px;
}
.sidebar-category h3 {
    font-family: 'Poppins', sans-serif;
    font-size: 1rem;
    font-weight: 700;
    color: var(--mg-dark, #1a180e);
    border-bottom: 2px solid #e0dac8;
    padding-bottom: 10px;
    margin-bottom: 14px;
}
.sidebar-category ul {
    list-style: none;
    padding: 0;
    margin: 0;
}
.sidebar-category ul li a {
    display: block;
    padding: 8px 12px;
    color: #555;
    font-family: 'Poppins', sans-serif;
    font-size: 0.88rem;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.22s;
}
.sidebar-category ul li a:hover {
    background: #fdf8ec;
    color: var(--mg-accent, #d4a843);
    padding-left: 18px;
}
.sidebar-category ul li.active > a {
    background: var(--mg-grad-primary, linear-gradient(135deg,#b09e60,#d4a843));
    color: #fff;
}


/* ============================================================
   19. SCROLL REVEAL — IntersectionObserver trigger
   ============================================================ */
/* Already defined above in section 0 — this block adds page-specific entries */


/* ============================================================
   20. RESPONSIVE ADJUSTMENTS
   ============================================================ */
@media (max-width: 991px) {
    .page { padding: 40px 0; }
    .billing-address { padding: 22px 20px; }
    .form-container-2 { padding: 32px 22px; }
    .user-content { padding: 24px 16px; }
    .page .product { padding: 20px; }
}
@media (max-width: 767px) {
    .page-banner { min-height: 200px; }
    .page-banner h1,
    .page-banner .inner h1,
    .page-banner .page-banner-inner h1 { font-size: 1.5rem; }
    .page { padding: 30px 0; }
    .form-container-2 { padding: 24px 16px; }
    .user-sidebar ul { flex-direction: column; }
    .user-sidebar a button.btn { width: 100%; text-align: left; }
    .headline h2 { font-size: 1.4rem; }
    div.cart { border-radius: 10px; }
    .billing-address { padding: 18px 14px; }
}
@media (max-width: 480px) {
    .page-banner .inner,
    .page-banner .page-banner-inner { padding: 40px 14px; }
    .register-btn,
    input[type="submit"].register-btn { font-size: 0.88rem; }
    .product .item .thumb { height: 180px; }
}
