/* ╔══════════════════════════════════════════════════════════╗
   ║  ARTISAN PREMIUM THEME — MODERN REDESIGN                 ║
   ║  Fonts: Cormorant Garamond + DM Sans                     ║
   ╚══════════════════════════════════════════════════════════╝ */

@import url('https://fonts.googleapis.com/css2?family=Cormorant+Garamond:ital,wght@0,300;0,400;0,600;0,700;1,400&family=DM+Sans:wght@300;400;500;600&display=swap');

/* ╔══════════════════════════════════════════════════════════╗
   ║  BRAND SYSTEM — FINAL CONSOLIDATED                       ║
   ║  ① REPLACE :root + [data-theme="dark"] in theme.css      ║
   ║  ② PASTE the overrides block at the very END of theme.css ║
   ║                                                          ║
   ║  Olive #5E6F3C → headers · icons · highlights            ║
   ║  Gold  #C9A64A → buttons · CTAs · links · hover          ║
   ╚══════════════════════════════════════════════════════════╝ */


/* ═══════════════════════════════════════════
   PART 1 — TOKENS
   Replace your existing :root and dark blocks
═══════════════════════════════════════════ */

:root {
    /* Surfaces */
    --bg:               #FAFAF8;
    --bg-alt:           #F3F0EA;
    --surface:          #FFFFFF;
    --surface-2:        #F7F5F0;

    /* Typography */
    --text:             #18150F;
    --text-muted:       #7A7064;

    /* ① Olive Green — headers, icons, highlights, decorative */
    --accent:           #5E6F3C;
    --accent-light:     #8A9E5A;
    --accent-dark:      #3D4828;

    /* ② Gold — buttons, CTAs, links, hover states */
    --gold:             #C9A64A;
    --gold-light:       #DFC070;
    --gold-dark:        #A07830;

    /* Structure */
    --brand-dark:       #1C1108;
    --border:           #E4DDD0;
    --shadow-sm:        0 2px 8px rgba(0,0,0,0.06);
    --shadow-md:        0 8px 32px rgba(0,0,0,0.09);
    --shadow-lg:        0 24px 64px rgba(0,0,0,0.13);
    --radius-sm:        8px;
    --radius-md:        16px;
    --radius-lg:        24px;
    --font-display:     'Cormorant Garamond', Georgia, serif;
    --font-body:        'DM Sans', sans-serif;
    --transition:       0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

[data-theme="dark"] {
    --bg:               #0D0B08;
    --bg-alt:           #161310;
    --surface:          #1E1A14;
    --surface-2:        #252018;
    --text:             #F0EDE6;
    --text-muted:       #9A9080;

    /* Olive brightens on dark for readability */
    --accent:           #7A9050;
    --accent-light:     #9AB068;
    --accent-dark:      #4E5C30;

    /* Gold stays warm on dark */
    --gold:             #D4A84A;
    --gold-light:       #E8C870;
    --gold-dark:        #B08530;

    --brand-dark:       #0A0805;
    --border:           #2E2820;
    --shadow-sm:        0 2px 8px rgba(0,0,0,0.25);
    --shadow-md:        0 8px 32px rgba(0,0,0,0.4);
    --shadow-lg:        0 24px 64px rgba(0,0,0,0.5);
}


/* ═══════════════════════════════════════════
   PART 2 — OVERRIDES
   Paste at the very END of theme.css
   (after all addon CSS files)
═══════════════════════════════════════════ */


/* ─────────────────────────────────────────
   ① OLIVE — Section Headers
───────────────────────────────────────── */

/* Light-background headings on all three pages */
.ab-mv-card h4,
.ab-why-sticky h2,
.ab-values-header h2,
.sv-section-title,
.sv-process-step-title,
.sv-card-title,
.ct-form-heading,
.ct-hours-heading,
.ct-social-heading,
.ct-map-header h2,
.ab-audience-card h6,
.why-title,
.step-title,
.service-title,
.product-name,
.about-heading,
.faq-main-title,
.newsletter-heading,
.section-title {
    color: var(--accent) !important;
}

/* Hero & CTA titles stay white — olive is too dark on brand-dark bg */
.ab-hero-title,
.ct-hero-title,
.sv-hero-title,
.ab-cta-inner h2,
.sv-cta-inner h2,
.cta-heading {
    color: #ffffff !important;
    transition: none !important;
}

/* Value cards sit on dark bg — keep white */
.ab-value-card h5 { color: #ffffff !important; transition: none !important; }

/* Hero italic emphasis → gold (readable on dark) */
.ab-hero-title em,
.ct-hero-title em,
.sv-hero-title em,
.ab-cta-inner h2 em,
.sv-cta-inner h2 em { color: var(--gold-light) !important; }

/* Generic .text-primary throughout old Bootstrap templates */
.text-primary { color: var(--accent) !important; }


/* ─────────────────────────────────────────
   ① OLIVE — Icons
───────────────────────────────────────── */

/* All icon wrapper tiles */
.ab-value-icon,
.sv-card-icon-wrap,
.why-icon-wrap,
.service-icon-wrap,
.step-icon-circle,
.ct-contact-icon,
.ct-hours-icon,
.newsletter-icon-wrap {
    color:        var(--accent);
    border-color: rgba(94,111,60,.22) !important;
    background:   linear-gradient(135deg,
                    rgba(94,111,60,.11),
                    rgba(94,111,60,.03)) !important;
}

/* Inline icon classes from Bootstrap templates */
.fas.text-primary,
.fa-solid.text-primary,
.fab.text-primary,
.far.text-primary,
.ct-hours-heading i,
.ab-why-item-icon { color: var(--accent) !important; }

/* Icon fill on card hover → gold for contrast pop */
.sv-card:hover            .sv-card-icon-wrap,
.service-card:hover       .service-icon-wrap,
.why-card:hover           .why-icon-wrap,
.how-step-card:hover      .step-icon-circle,
.ab-value-card:hover      .ab-value-icon {
    background:   var(--gold) !important;
    border-color: var(--gold) !important;
    color:        #ffffff    !important;
}


/* ─────────────────────────────────────────
   ① OLIVE — Highlights & Decorative
───────────────────────────────────────── */

/* Section label pills with flanking lines */
.section-label,
.ab-section-label,
.sv-section-label {
    color: var(--accent) !important;
}
.section-label::before,  .section-label::after,
.ab-section-label::before, .ab-section-label::after,
.sv-section-label::before, .sv-section-label::after {
    background: var(--accent) !important;
    opacity: .5;
}

/* Horizontal rule accents */
.section-rule,
.about-rule,
.why-border-line {
    background: linear-gradient(90deg, var(--accent), transparent) !important;
}

/* Card bottom rule (services) */
.sv-card-rule            { background: var(--accent) !important; }
.sv-card:hover .sv-card-rule { background: var(--gold) !important; }

/* Audience card hover border */
.ab-audience-card:hover  { border-color: var(--accent) !important; }

/* Step number badges */
.step-number-badge        { background: var(--accent) !important; }
.product-badge            { background: var(--accent) !important; }

/* Watermark numbers (faint, decorative) */
.ab-mv-card-num {
    color: var(--accent) !important;
    opacity: .1;
}
.sv-card-index {
    color: var(--accent) !important;
    opacity: .09;
}
.sv-card:hover .sv-card-index { opacity: .16 !important; }

/* Why-choose & process counters */
.ab-why-num              { color: var(--accent) !important; opacity: .45; }
.ab-why-item:hover .ab-why-num { opacity: 1 !important; }
.sv-process-num          { color: var(--accent) !important; }


/* ─────────────────────────────────────────
   ② GOLD — Buttons & CTAs
───────────────────────────────────────── */
.btn-hero-primary {
    background:   var(--gold);
    border-color: var(--gold);
    color: #fff;
}
.btn-hero-primary:hover {
    background:   transparent;
    color:        var(--gold);
    border-color: var(--gold);
    box-shadow:   0 8px 30px rgba(201,166,74,.28);
}

.btn-primary              { background: var(--gold) !important; border-color: var(--gold) !important; }
.btn-primary:hover        { background: var(--gold-dark) !important; border-color: var(--gold-dark) !important; }

.btn-outline-primary      { color: var(--gold) !important; border-color: var(--gold) !important; }
.btn-outline-primary:hover{ background: var(--gold) !important; border-color: var(--gold) !important; color: #fff !important; }

.btn-outline-elegant      { color: var(--gold); border-bottom-color: var(--gold); }
.btn-outline-elegant:hover{ color: var(--gold-dark); }

.ct-submit-btn            { background: var(--gold); border-color: var(--gold); }
.ct-submit-btn:hover      { background: transparent; color: var(--gold); border-color: var(--gold); box-shadow: 0 10px 32px rgba(201,166,74,.25); }

.newsletter-submit-btn    { background: var(--gold); }
.newsletter-submit-btn:hover { background: var(--gold-dark); box-shadow: 0 8px 24px rgba(201,166,74,.28); }

#scrollTopBtn             { background: var(--gold); box-shadow: 0 8px 24px rgba(201,166,74,.32); }
#scrollTopBtn:hover       { background: var(--gold-dark); }


/* ─────────────────────────────────────────
   ② GOLD — Links
───────────────────────────────────────── */
a                         { color: var(--gold); }
a:hover                   { color: var(--gold-dark); opacity: 1; }
.ct-contact-value:hover   { color: var(--gold-light) !important; }


/* ─────────────────────────────────────────
   ② GOLD — Hover states & active indicators
───────────────────────────────────────── */

/* Navbar underline */
.navbar-nav .nav-link::after  { background: var(--gold-light); }

/* Social buttons */
.ct-social-btn:hover          { background: var(--gold); border-color: var(--gold); color: #fff !important; }

/* FAQ active */
.faq-question:not(.collapsed) { color: var(--gold); }
.faq-question:not(.collapsed) .faq-icon-wrap { background: var(--gold); border-color: var(--gold); }

/* Card top-bar sweep (hover) */
.why-card::before,
.how-step-card::before,
.ab-mv-card::before,
.sv-card::before,
.ct-form-panel::before,
.ct-info-card::before {
    background: linear-gradient(90deg, var(--gold), var(--gold-light));
}

/* Process step circle hover */
.sv-process-step:hover .sv-process-num {
    background:   var(--gold) !important;
    border-color: var(--gold) !important;
    color:        #ffffff     !important;
    box-shadow:   0 8px 24px rgba(201,166,74,.28);
}

/* Form focus ring */
input:focus,
textarea:focus,
select:focus,
.ct-form-panel .form-control:focus,
.ct-form-panel .form-select:focus,
.ct-form-panel input:focus,
.ct-form-panel textarea:focus,
.newsletter-form input:focus {
    border-color: var(--gold)                  !important;
    box-shadow:   0 0 0 3px rgba(201,166,74,.12) !important;
}


/* ─────────────────────────────────────────
   ② GOLD — Hero dark-bg decorative elements
   (olive is illegible on brand-dark)
───────────────────────────────────────── */

/* Eyebrow pills on all three heroes */
.ab-eyebrow,
.ct-hero-eyebrow,
.sv-hero-eyebrow {
    background:   rgba(201,166,74,.1)  !important;
    border-color: rgba(201,166,74,.28) !important;
    color:        var(--gold-light)    !important;
    transition:   none                 !important;
}
.ab-eyebrow-dot,
.ct-hero-eyebrow-dot,
.sv-hero-eyebrow-dot { background: var(--gold); }

/* Hero scroll hint lines */
.ab-hero-scroll span          { background: var(--gold); }

/* Image corner accent + label */
.ab-image-accent              { border-color: var(--gold); }
.ab-image-label               { color: var(--gold-light); }

/* Value card bottom shimmer on dark bg */
.ab-value-card::after         { background: linear-gradient(90deg, transparent, var(--gold), transparent); }

/* Stat numbers on dark hero */
.stat-number,
.sv-stat-num                  { color: var(--gold) !important; }

/* Mission/Vision watermarks */
.ab-mv-card-num               { color: var(--gold) !important; opacity: .1; }

/* Hero orb glows */
.hero-orb-1                   { background: radial-gradient(circle, rgba(201,166,74,.18), transparent 70%); }
.hero-orb-2                   { background: radial-gradient(circle, rgba(201,166,74,.10), transparent 70%); }


/* ─────────────────────────────────────────
   DARK MODE ADJUSTMENTS
───────────────────────────────────────── */

/* Olive → accent-light on dark surfaces */
[data-theme="dark"] .text-primary,
[data-theme="dark"] .sv-card-title,
[data-theme="dark"] .sv-section-title,
[data-theme="dark"] .sv-process-step-title,
[data-theme="dark"] .ab-mv-card h4,
[data-theme="dark"] .ab-why-sticky h2,
[data-theme="dark"] .ct-form-heading,
[data-theme="dark"] .ct-hours-heading,
[data-theme="dark"] .ct-social-heading,
[data-theme="dark"] .section-title,
[data-theme="dark"] .why-title,
[data-theme="dark"] .step-title {
    color: var(--accent-light) !important;
}

[data-theme="dark"] .section-label,
[data-theme="dark"] .ab-section-label,
[data-theme="dark"] .sv-section-label {
    color: var(--accent-light) !important;
}
[data-theme="dark"] .section-label::before,  [data-theme="dark"] .section-label::after,
[data-theme="dark"] .ab-section-label::before,[data-theme="dark"] .ab-section-label::after,
[data-theme="dark"] .sv-section-label::before,[data-theme="dark"] .sv-section-label::after {
    background: var(--accent-light) !important;
}

[data-theme="dark"] .ab-value-icon,
[data-theme="dark"] .sv-card-icon-wrap,
[data-theme="dark"] .why-icon-wrap,
[data-theme="dark"] .ct-contact-icon,
[data-theme="dark"] .ct-hours-icon {
    color:        var(--accent-light)            !important;
    border-color: rgba(122,144,80,.28)           !important;
    background:   linear-gradient(135deg,
                    rgba(122,144,80,.12),
                    rgba(122,144,80,.03))        !important;
}

/* ─────────────────────────────────────────
   BASE
───────────────────────────────────────── */
*, *::before, *::after {
    box-sizing: border-box;
    transition: background-color var(--transition), color var(--transition), border-color var(--transition);
}

html, body { height: 100%; scroll-behavior: smooth; }

body {
    margin: 0;
    font-family: var(--font-body);
    font-size: 16px;
    font-weight: 400;
    background-color: var(--bg);
    color: var(--text);
    line-height: 1.7;
    -webkit-font-smoothing: antialiased;
}

h1, h2, h3, h4, h5 {
    font-family: var(--font-display);
    color: var(--text);
    line-height: 1.15;
    margin: 0;
}

p { color: var(--text); margin: 0; }

a {
    color: var(--accent);
    text-decoration: none;
    transition: opacity var(--transition);
}
a:hover { opacity: 0.8; }

img { max-width: 100%; }

/* ─────────────────────────────────────────
   UTILITY
───────────────────────────────────────── */
.section-padded { padding: 100px 0; }

.section-header {
    text-align: center;
    max-width: 680px;
    margin: 0 auto 64px;
}

.section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-body);
    font-size: 0.75rem;
    font-weight: 600;
    letter-spacing: 0.15em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 16px;
}
.section-label::before,
.section-label::after {
    content: '';
    display: block;
    width: 24px;
    height: 1px;
    background: var(--accent);
    opacity: 0.6;
}

.section-title {
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 600;
    color: var(--text);
    margin-bottom: 16px;
}

.section-rule {
    width: 48px;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), transparent);
    border-radius: 2px;
    margin: 16px auto 20px;
}

.section-desc {
    font-size: 1.05rem;
    color: var(--text-muted);
    line-height: 1.8;
    margin: 0;
}

/* ─────────────────────────────────────────
   NAVBAR (matches existing brown palette)
───────────────────────────────────────── */
.navbar {
    position: sticky;
    top: 0;
    z-index: 9999;
    background: linear-gradient(135deg, #6F4E37, #5c4033, #3d2b1f) !important;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
    box-shadow: 0 4px 30px rgba(0,0,0,0.3);
    padding: 0.9rem 0;
    transition: all var(--transition);
}
.navbar-brand {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 700;
    color: #fff !important;
    letter-spacing: 0.05em;
}
.navbar-nav .nav-link {
    font-family: var(--font-body);
    color: rgba(255,255,255,0.88) !important;
    font-size: 0.9rem;
    font-weight: 500;
    padding: 0.5rem 1rem;
    letter-spacing: 0.03em;
    position: relative;
    transition: all 0.3s;
}
.navbar-nav .nav-link::after {
    content: '';
    position: absolute;
    bottom: 0; left: 1rem;
    width: 0; height: 2px;
    background: var(--accent-light);
    transition: width 0.3s ease;
}
.navbar-nav .nav-link:hover { color: #fff !important; }
.navbar-nav .nav-link:hover::after { width: calc(100% - 2rem); }

/* Theme switch */
.theme-switch { display: flex; gap: 8px; align-items: center; }
.theme-btn {
    width: 28px; height: 28px;
    display: flex; align-items: center; justify-content: center;
    border-radius: 8px; font-size: 14px; border: 1px solid transparent;
    transition: all 0.3s;
}
.theme-btn.light { background: #f1f1f1; color: #333; }
.theme-btn.dark { background: #1a1a1a; color: #fff; }
.theme-btn:hover { transform: translateY(-2px); border-color: var(--accent-light); }
.active-theme { border: 2px solid var(--accent-light) !important; }

/* =========================
   NAV MENU ICON COLORS
========================= */

.custom-nav-link i {
    transition: all 0.3s ease;
}

/* Home */
.custom-nav-link .fa-house {
    color: #4dabf7;
}

/* About */
.custom-nav-link .fa-circle-info {
    color: #8b5cf6;
}

/* Services */
.custom-nav-link .fa-briefcase {
    color: #f59e0b;
}

/* Products */
.custom-nav-link .fa-box-open {
    color: #10b981;
}

/* Contact */
.custom-nav-link .fa-envelope {
    color: #ef4444;
}

/* Hover Animation */
.custom-nav-link:hover i {
    transform: translateY(-2px) scale(1.08);
    filter: brightness(1.1);
}

/* ─────────────────────────────────────────
   HERO SECTION
───────────────────────────────────────── */
.hero-section {
    position: relative;
    min-height: 92vh;
    display: flex;
    align-items: center;
}

.hero-bg {
    position: absolute;
    inset: 0;
    background-color: var(--brand-dark);
    background-size: cover;
    background-position: center;
    background-repeat: no-repeat;
}

.hero-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        135deg,
        rgba(12,8,3,0.85) 0%,
        rgba(28,17,8,0.75) 50%,
        rgba(28,17,8,0.6) 100%
    );
}

.hero-grain {
    position: absolute;
    inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.04'/%3E%3C/svg%3E");
    opacity: 0.4;
    pointer-events: none;
}

.hero-orb {
    position: absolute;
    border-radius: 50%;
    filter: blur(100px);
    pointer-events: none;
}
.hero-orb-1 {
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(200,136,42,0.18), transparent 70%);
    top: -100px; right: -100px;
    animation: orbFloat 12s ease-in-out infinite;
}
.hero-orb-2 {
    width: 400px; height: 400px;
    background: radial-gradient(circle, rgba(200,136,42,0.1), transparent 70%);
    bottom: 50px; left: -50px;
    animation: orbFloat 16s ease-in-out infinite reverse;
}
@keyframes orbFloat {
    0%, 100% { transform: translateY(0) scale(1); }
    50% { transform: translateY(-30px) scale(1.05); }
}

.hero-content {
    position: relative;
    z-index: 2;
    padding: 120px 0 80px;
}

.min-vh-90 { min-height: 80vh; }

/* Eyebrow */
.hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(200,136,42,0.12);
    border: 1px solid rgba(200,136,42,0.3);
    color: var(--accent-light);
    font-family: var(--font-body);
    font-size: 0.78rem;
    font-weight: 600;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    padding: 8px 18px;
    border-radius: 100px;
    margin-bottom: 24px;
}
.eyebrow-dot {
    width: 6px; height: 6px;
    background: var(--accent);
    border-radius: 50%;
    animation: pulse 2s infinite;
}
@keyframes pulse {
    0%, 100% { opacity: 1; transform: scale(1); }
    50% { opacity: 0.5; transform: scale(1.5); }
}

/* Hero heading */
.hero-heading {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 4rem);
    font-weight: 600;
    color: #FFFFFF;
    line-height: 1.1;
    letter-spacing: -0.02em;
    margin-bottom: 24px;
}

/* Subtext */
.hero-subtext {
    font-family: var(--font-body);
    font-size: clamp(1.05rem, 2vw, 1.25rem);
    color: rgba(255,255,255,0.72);
    max-width: 580px;
    line-height: 1.7;
    margin-bottom: 40px;
}

/* CTA group */
.hero-cta-group {
    display: flex;
    gap: 16px;
    flex-wrap: wrap;
    align-items: center;
    margin-bottom: 48px;
}

/* Primary button */
.btn-hero-primary {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: var(--accent);
    color: #fff;
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    padding: 14px 30px;
    border-radius: var(--radius-sm);
    border: 2px solid var(--accent);
    transition: all 0.3s ease;
    text-decoration: none;
    white-space: nowrap;
}
.btn-hero-primary:hover {
    background: transparent;
    color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 8px 30px rgba(200,136,42,0.3);
    opacity: 1;
}
.btn-hero-primary svg { transition: transform 0.3s; }
.btn-hero-primary:hover svg { transform: translateX(4px); }

.btn-hero-large { padding: 18px 42px; font-size: 1.05rem; }

/* Ghost button */
.btn-hero-ghost {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: rgba(255,255,255,0.8);
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 500;
    padding: 14px 24px;
    border-radius: var(--radius-sm);
    border: 1px solid rgba(255,255,255,0.25);
    transition: all 0.3s ease;
    text-decoration: none;
}
.btn-hero-ghost:hover {
    border-color: rgba(255,255,255,0.6);
    color: #fff;
    transform: translateY(-3px);
    opacity: 1;
}

/* Feature pills */
.hero-features {
    display: flex;
    flex-wrap: wrap;
    gap: 12px;
}
.hero-feature-pill {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.07);
    border: 1px solid rgba(255,255,255,0.12);
    color: rgba(255,255,255,0.75);
    font-size: 0.82rem;
    font-weight: 500;
    padding: 8px 16px;
    border-radius: 100px;
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
}
.hero-feature-pill i { color: var(--accent-light); }

/* Scroll indicator */
.scroll-indicator {
    position: absolute;
    bottom: 30px;
    left: 50%;
    transform: translateX(-50%);
    display: flex;
    flex-direction: column;
    align-items: center;
}
.scroll-line {
    width: 1px;
    height: 60px;
    background: linear-gradient(to bottom, rgba(255,255,255,0.5), transparent);
    animation: scrollAnim 2s ease-in-out infinite;
}
@keyframes scrollAnim {
    0% { transform: scaleY(0); transform-origin: top; }
    50% { transform: scaleY(1); transform-origin: top; }
    50.001% { transform-origin: bottom; }
    100% { transform: scaleY(0); transform-origin: bottom; }
}

/* Hero animations */
.animate-fade-up {
    opacity: 0;
    transform: translateY(30px);
    animation: fadeUp 0.8s cubic-bezier(0.4,0,0.2,1) forwards;
}
.animate-delay-1 { animation-delay: 0.2s; }
.animate-delay-2 { animation-delay: 0.4s; }
.animate-delay-3 { animation-delay: 0.6s; }
.animate-delay-4 { animation-delay: 0.8s; }
@keyframes fadeUp {
    to { opacity: 1; transform: translateY(0); }
}

/* ─────────────────────────────────────────
   STATS BAR
───────────────────────────────────────── */
.stats-bar {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    border-top: 1px solid var(--border);
    padding: 32px 0;
}
.stats-grid {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    flex-wrap: wrap;
}
.stat-item {
    display: flex;
    flex-direction: column;
    align-items: center;
    padding: 0 40px;
}
.stat-number {
    font-family: var(--font-display);
    font-size: 2.2rem;
    font-weight: 700;
    color: var(--accent);
    line-height: 1;
}
.stat-label {
    font-size: 0.8rem;
    font-weight: 500;
    color: var(--text-muted);
    letter-spacing: 0.05em;
    text-transform: uppercase;
    margin-top: 6px;
}
.stat-divider {
    width: 1px;
    height: 40px;
    background: var(--border);
}
@media (max-width: 576px) {
    .stat-item { padding: 16px 20px; }
    .stat-divider { display: none; }
}

/* ─────────────────────────────────────────
   WHY CHOOSE US
───────────────────────────────────────── */
.why-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 28px;
}

.why-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 36px 32px;
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
}
.why-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 0.4s ease;
}
.why-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: transparent;
}
.why-card:hover::before { transform: scaleX(1); }

.why-icon-wrap {
    width: 56px; height: 56px;
    background: linear-gradient(135deg, rgba(200,136,42,0.12), rgba(200,136,42,0.04));
    border: 1px solid rgba(200,136,42,0.2);
    border-radius: var(--radius-sm);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.4rem;
    color: var(--accent);
    margin-bottom: 20px;
}
.why-title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}
.why-text { font-size: 0.95rem; color: var(--text-muted); line-height: 1.7; }
.why-border-line {
    width: 32px; height: 2px;
    background: var(--accent);
    border-radius: 2px;
    margin-top: 20px;
    opacity: 0.4;
}

/* ─────────────────────────────────────────
   HOW IT WORKS
───────────────────────────────────────── */
.how-section { position: relative; overflow: hidden; }
.how-section-bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, var(--bg-alt) 0%, var(--bg) 100%);
}

.how-steps-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
    gap: 32px;
}

.how-step-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 40px 32px;
    position: relative;
    transition: all 0.4s ease;
    overflow: visible;
}
.how-step-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
}

.step-number-badge {
    position: absolute;
    top: -16px; right: 24px;
    width: 32px; height: 32px;
    background: var(--accent);
    color: #fff;
    font-family: var(--font-body);
    font-size: 0.8rem;
    font-weight: 700;
    border-radius: 8px;
    display: flex; align-items: center; justify-content: center;
}

.step-icon-circle {
    width: 72px; height: 72px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(200,136,42,0.1), rgba(200,136,42,0.02));
    border: 2px solid rgba(200,136,42,0.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem;
    color: var(--accent);
    margin-bottom: 24px;
    transition: all 0.3s;
}
.how-step-card:hover .step-icon-circle {
    background: linear-gradient(135deg, rgba(200,136,42,0.2), rgba(200,136,42,0.06));
    border-color: var(--accent);
    transform: rotate(-5deg);
}

.step-connector {
    display: none;
}

.step-title {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}
.step-desc { font-size: 0.93rem; color: var(--text-muted); line-height: 1.7; }

/* ─────────────────────────────────────────
   ABOUT SECTION
───────────────────────────────────────── */

.about-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: center;
}

@media (max-width: 768px) {
    .about-grid {
        grid-template-columns: 1fr;
        gap: 48px;
    }

    .about-visual {
        display: none;
    }
}

/* VISUAL PANEL */
.about-visual {
    position: relative;
}

.about-visual-inner {
    position: relative;
    height: 460px;

    overflow: hidden;
    border-radius: var(--radius-md);
}

/* IMAGE */
.about-main-image {
    position: absolute;
    inset: 0;

    width: 50%;
    height: 80%;

    object-fit: cover;
    object-position: center;

    display: block;

    border-radius: var(--radius-md);

    z-index: 1;
}

/* OPTIONAL OVERLAY */
.about-visual-inner::after {
    content: "";

    position: absolute;
    inset: 0;

    background:
        linear-gradient(
            to top,
            rgba(0,0,0,0.35),
            rgba(0,0,0,0.05)
        );

    z-index: 2;
}

/* Floating badge */
.about-badge-float {
    position: absolute;
    left: 24px;
    bottom: 24px;

    display: flex;
    align-items: center;
    gap: 10px;

    padding: 14px 18px;

    background: rgba(255,255,255,0.12);

    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);

    border: 1px solid rgba(255,255,255,0.2);

    border-radius: 16px;

    color: #fff;

    z-index: 5;
}

.about-badge-float i {
    color: #ffd166;
}

/* Geometric decorations */
.about-geometric-1 {
    position: absolute;

    width: 320px;
    height: 380px;

    background: linear-gradient(
        135deg,
        var(--bg-alt),
        var(--surface)
    );

    border: 1px solid var(--border);

    border-radius: var(--radius-md);

    top: 0;
    left: 30px;

    transform: rotate(-3deg);

    z-index: 0;
}

.about-geometric-2 {
    position: absolute;

    width: 280px;
    height: 340px;

    background: linear-gradient(
        135deg,
        rgba(200,136,42,0.08),
        rgba(200,136,42,0.02)
    );

    border: 1px solid rgba(200,136,42,0.2);

    border-radius: var(--radius-md);

    top: 40px;
    left: 10px;

    transform: rotate(2deg);

    z-index: 0;
}

.about-geometric-3 {
    position: absolute;

    width: 200px;
    height: 200px;

    background: linear-gradient(
        135deg,
        var(--accent),
        var(--accent-dark)
    );

    border-radius: var(--radius-md);

    bottom: 20px;
    right: 20px;

    opacity: 0.15;

    z-index: 0;
}

.about-badge-float {
    position: absolute;
    bottom: 60px; left: -10px;
    display: flex; align-items: center; gap: 10px;
    background: var(--surface);
    border: 1px solid var(--border);
    padding: 14px 20px;
    border-radius: var(--radius-sm);
    box-shadow: var(--shadow-md);
    z-index: 2;
    font-size: 0.9rem;
    font-weight: 600;
    color: var(--text);
}
.about-badge-float i { color: var(--accent); font-size: 1.1rem; }

.about-heading {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.8rem);
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}
.about-rule {
    width: 48px; height: 3px;
    background: linear-gradient(90deg, var(--accent), transparent);
    border-radius: 2px;
    margin-bottom: 24px;
}
.about-body {
    font-size: 1.05rem;
    color: var(--text-muted);
    line-height: 1.8;
    margin-bottom: 32px;
}

.btn-outline-elegant {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    color: var(--accent);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    letter-spacing: 0.03em;
    border-bottom: 2px solid var(--accent);
    padding-bottom: 4px;
    transition: all 0.3s;
    text-decoration: none;
}
.btn-outline-elegant:hover { gap: 14px; opacity: 1; color: var(--accent-dark); }
.btn-outline-elegant svg { transition: transform 0.3s; }
.btn-outline-elegant:hover svg { transform: translateX(4px); }

/* ─────────────────────────────────────────
   SERVICES
───────────────────────────────────────── */
.services-section { background: var(--bg-alt); }

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 24px;
}

.service-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 40px 32px;
    position: relative;
    overflow: hidden;
    transition: all 0.4s ease;
    cursor: pointer;
}
.service-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(200,136,42,0.3);
}
.service-glow {
    position: absolute;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(200,136,42,0.08), transparent 70%);
    top: -80px; right: -80px;
    transition: all 0.5s;
}
.service-card:hover .service-glow {
    transform: scale(1.5);
    opacity: 0.8;
}

.service-icon-wrap {
    width: 60px; height: 60px;
    background: linear-gradient(135deg, rgba(200,136,42,0.12), rgba(200,136,42,0.03));
    border: 1px solid rgba(200,136,42,0.2);
    border-radius: 14px;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.5rem;
    color: var(--accent);
    margin-bottom: 22px;
    transition: all 0.3s;
}
.service-card:hover .service-icon-wrap {
    background: var(--accent);
    color: #fff;
    border-color: var(--accent);
    transform: scale(1.1) rotate(-5deg);
}

.service-title {
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 600;
    margin-bottom: 12px;
    color: var(--text);
}
.service-text { font-size: 0.93rem; color: var(--text-muted); line-height: 1.7; }

.service-arrow {
    position: absolute;
    bottom: 24px; right: 24px;
    width: 36px; height: 36px;
    border: 1px solid var(--border);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--text-muted);
    opacity: 0;
    transform: translateX(-10px);
    transition: all 0.3s;
}
.service-card:hover .service-arrow {
    opacity: 1;
    transform: translateX(0);
    border-color: var(--accent);
    color: var(--accent);
}

.btn-pill-outline {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: transparent;
    color: var(--text);
    font-family: var(--font-body);
    font-size: 0.9rem;
    font-weight: 600;
    padding: 13px 30px;
    border: 2px solid var(--border);
    border-radius: 100px;
    transition: all 0.3s;
    text-decoration: none;
}
.btn-pill-outline:hover {
    border-color: var(--accent);
    color: var(--accent);
    transform: translateY(-3px);
    box-shadow: var(--shadow-md);
    opacity: 1;
}

/* ─────────────────────────────────────────
   PRODUCTS
───────────────────────────────────────── */
.products-section { position: relative; overflow: hidden; }
.products-section-bg {
    position: absolute;
    inset: 0;
    background: linear-gradient(160deg, var(--surface) 0%, var(--bg) 100%);
}

.products-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
    gap: 28px;
    margin-bottom: 60px;
}

.product-card-modern {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    overflow: hidden;
    transition: all 0.4s ease;
}
.product-card-modern:hover {
    transform: translateY(-10px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(200,136,42,0.25);
}

.product-img-wrap {
    position: relative;
    overflow: hidden;
    height: 260px;
}
.product-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.4,0,0.2,1);
}
.product-card-modern:hover .product-img { transform: scale(1.08); }

.product-img-overlay {
    position: absolute;
    inset: 0;
    background: rgba(12,8,3,0.5);
    display: flex; align-items: center; justify-content: center;
    opacity: 0;
    transition: opacity 0.3s;
}
.product-card-modern:hover .product-img-overlay { opacity: 1; }

/* Quick View Button */
.product-quick-view {
    display: inline-flex;
    align-items: center;
    gap: 8px;

    padding: 10px 20px;

    background: rgba(255,255,255,0.14);

    color: #ffffff;

    font-size: 0.85rem;
    font-weight: 700;

    border-radius: 999px;

    border: 1px solid rgba(255,255,255,0.18);

    text-decoration: none;

    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);

    box-shadow: 0 8px 24px rgba(0,0,0,0.22);

    transform: translateY(10px);

    transition:
        transform 0.3s ease,
        background 0.3s ease,
        color 0.3s ease;
}

.product-card-modern:hover .product-quick-view {
    transform: translateY(0);
}

/* Hover */
.product-quick-view:hover {
    background: rgba(255,255,255,0.22);
    color: #ffffff;
}

.product-badge {
    position: absolute;
    top: 16px; left: 16px;
    background: var(--accent);
    color: #fff;
    font-size: 0.72rem;
    font-weight: 700;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    padding: 4px 12px;
    border-radius: 4px;
}

.product-body { padding: 24px; }
.product-name {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 10px;
}
.product-desc-text { font-size: 0.9rem; color: var(--text-muted); line-height: 1.6; margin-bottom: 20px; }

.product-footer {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.product-price {
    font-family: var(--font-display);
    font-size: 1.4rem;
    font-weight: 700;
    color: var(--accent);
}
.product-cta-btn {
    background: var(--text);
    color: var(--bg);
    font-size: 0.82rem;
    font-weight: 600;
    padding: 9px 18px;
    border-radius: 8px;
    text-decoration: none;
    transition: all 0.3s;
    white-space: nowrap;
}
.product-cta-btn:hover {
    background: var(--accent);
    color: #fff;
    opacity: 1;
    transform: translateY(-2px);
}

/* Bottom CTA banner */
.products-cta-banner {
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 5px solid var(--accent);
    border-radius: var(--radius-md);
    padding: 40px 48px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    flex-wrap: wrap;
}
.products-cta-text h3 {
    font-family: var(--font-display);
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 8px;
}
.products-cta-text p { font-size: 0.95rem; color: var(--text-muted); }

/* ─────────────────────────────────────────
   TESTIMONIALS
───────────────────────────────────────── */
.testimonials-section { background: var(--bg-alt); }

.testimonials-carousel { max-width: 780px; margin: 0 auto; }

.testimonial-card-modern {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 52px 48px;
    text-align: center;
    box-shadow: var(--shadow-md);
}

.testimonial-quote-icon {
    color: var(--accent);
    opacity: 0.2;
    margin-bottom: 8px;
}
.testimonial-text-modern {
    font-family: var(--font-display);
    font-size: 1.35rem;
    font-style: italic;
    line-height: 1.7;
    color: var(--text);
    margin-bottom: 24px;
}
.testimonial-stars { color: var(--accent-light); font-size: 0.85rem; margin-bottom: 28px; letter-spacing: 3px; }

.testimonial-author {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
}
.testimonial-avatar {
    width: 48px; height: 48px;
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: #fff;
    font-family: var(--font-display);
    font-size: 1.2rem;
    font-weight: 700;
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.testimonial-name { display: block; font-size: 0.95rem; font-weight: 600; color: var(--text); }
.testimonial-company { display: block; font-size: 0.82rem; color: var(--text-muted); margin-top: 2px; }

.testimonial-controls {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 20px;
    margin-top: 36px;
}
.testimonial-ctrl-btn {
    width: 44px; height: 44px;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--text);
    cursor: pointer;
    transition: all 0.3s;
}
.testimonial-ctrl-btn:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    transform: scale(1.1);
}

.carousel-indicators-custom { display: flex; gap: 8px; align-items: center; }
.carousel-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    border: none;
    background: var(--border);
    padding: 0;
    cursor: pointer;
    transition: all 0.3s;
}
.carousel-dot.active {
    background: var(--accent);
    width: 24px;
    border-radius: 4px;
}

/* ─────────────────────────────────────────
   FAQ
───────────────────────────────────────── */
.faq-layout {
    display: grid;
    grid-template-columns: 320px 1fr;
    gap: 80px;
    align-items: start;
}
@media (max-width: 900px) {
    .faq-layout { grid-template-columns: 1fr; gap: 40px; }
}

.faq-main-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 3vw, 3rem);
    font-weight: 600;
    color: var(--text);
    line-height: 1.1;
    margin-bottom: 20px;
}
.faq-sidebar-text { font-size: 0.9rem; color: var(--text-muted); }
.faq-sidebar-text a { color: var(--accent); font-weight: 600; }

.faq-item-modern {
    border-bottom: 1px solid var(--border);
    transition: all 0.3s;
}
.faq-item-modern:first-child { border-top: 1px solid var(--border); }

.faq-question {
    width: 100%;
    background: transparent;
    border: none;
    padding: 22px 0;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    cursor: pointer;
    text-align: left;
    font-family: var(--font-body);
    font-size: 1rem;
    font-weight: 600;
    color: var(--text);
    transition: color 0.3s;
}
.faq-question:not(.collapsed) { color: var(--accent); }

.faq-icon-wrap {
    width: 32px; height: 32px;
    border: 1px solid var(--border);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: all 0.3s;
    color: var(--text-muted);
    position: relative;
}
.faq-question:not(.collapsed) .faq-icon-wrap {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.faq-plus { transition: opacity 0.3s; position: absolute; }
.faq-minus { transition: opacity 0.3s; position: absolute; opacity: 0; }
.faq-question:not(.collapsed) .faq-plus { opacity: 0; }
.faq-question:not(.collapsed) .faq-minus { opacity: 1; }

.faq-answer {
    padding: 0 0 22px;
    font-size: 0.95rem;
    color: var(--text-muted);
    line-height: 1.8;
}

/* ─────────────────────────────────────────
   NEWSLETTER
───────────────────────────────────────── */
.newsletter-section-modern {
    position: relative;
    overflow: hidden;
    background: var(--surface);
}
.newsletter-bg-effect {
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse at 50% 50%, rgba(200,136,42,0.06), transparent 70%);
    pointer-events: none;
}

.newsletter-card {
    max-width: 640px;
    margin: 0 auto;
    text-align: center;
}
.newsletter-icon-wrap {
    width: 72px; height: 72px;
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-size: 1.8rem;
    color: #fff;
    margin: 0 auto 24px;
    box-shadow: 0 12px 32px rgba(200,136,42,0.35);
}

.newsletter-heading {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 600;
    color: var(--text);
    margin-bottom: 12px;
}
.newsletter-sub { font-size: 1rem; color: var(--text-muted); margin-bottom: 36px; }

.newsletter-form {
    display: flex;
    gap: 12px;
    max-width: 520px;
    margin: 0 auto;
    flex-wrap: wrap;
}
.newsletter-input-wrap {
    flex: 1;
    min-width: 240px;
    position: relative;
}
.newsletter-input-icon {
    position: absolute;
    left: 16px;
    top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted);
    font-size: 0.9rem;
    pointer-events: none;
}
.newsletter-form input {
    width: 100%;
    background: var(--bg-alt);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 14px 14px 14px 44px;
    font-family: var(--font-body);
    font-size: 0.95rem;
    color: var(--text);
    transition: all 0.3s;
}
.newsletter-form input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,136,42,0.12);
}
.newsletter-form input::placeholder { color: var(--text-muted); }

.newsletter-submit-btn {
    background: var(--accent);
    color: #fff;
    font-family: var(--font-body);
    font-size: 0.95rem;
    font-weight: 600;
    padding: 14px 28px;
    border: none;
    border-radius: var(--radius-sm);
    cursor: pointer;
    white-space: nowrap;
    transition: all 0.3s;
}
.newsletter-submit-btn:hover {
    background: var(--accent-dark);
    transform: translateY(-2px);
    box-shadow: 0 8px 24px rgba(200,136,42,0.3);
}

/* Alert messages */
.newsletter-messages { margin-bottom: 20px; }
.alert-modern {
    display: flex; align-items: center; gap: 10px;
    background: var(--surface-2);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 12px 16px;
    font-size: 0.9rem;
    color: var(--text);
    text-align: left;
    margin-bottom: 8px;
}
.alert-modern.alert-success { border-left: 4px solid #22c55e; }
.alert-modern.alert-error, .alert-modern.alert-danger { border-left: 4px solid #ef4444; }
.alert-close { margin-left: auto; background: none; border: none; font-size: 1.2rem; cursor: pointer; color: var(--text-muted); }

/* ─────────────────────────────────────────
   FINAL CTA
───────────────────────────────────────── */
.cta-final {
    position: relative;
    overflow: hidden;
    background: var(--brand-dark);
}
.cta-final-bg {
    position: absolute;
    inset: 0;
    background: 
        radial-gradient(ellipse at 30% 50%, rgba(200,136,42,0.15), transparent 60%),
        radial-gradient(ellipse at 70% 50%, rgba(200,136,42,0.08), transparent 60%);
}

.cta-content-wrap {
    position: relative;
    max-width: 700px;
    margin: 0 auto;
    text-align: center;
}
.cta-heading {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.5rem);
    font-weight: 600;
    color: #fff;
    margin-bottom: 16px;
}
.cta-sub {
    font-size: 1.1rem;
    color: rgba(255,255,255,0.65);
    margin-bottom: 40px;
    line-height: 1.7;
}

/* ─────────────────────────────────────────
   FOOTER / OTHER GLOBALS
───────────────────────────────────────── */
.card {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-sm);
}

main.container {
    background: var(--surface);
    color: var(--text);
    border-radius: var(--radius-md);
    padding: 2rem;
    box-shadow: var(--shadow-sm);
}

input, textarea, select {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 10px 14px;
    font-family: var(--font-body);
}
input:focus, textarea:focus, select:focus {
    border-color: var(--accent);
    outline: none;
    box-shadow: 0 0 0 3px rgba(200,136,42,0.12);
}

table { width: 100%; color: var(--text); border-collapse: collapse; }
th, td { border: 1px solid var(--border); padding: 10px; }

.text-muted { color: var(--text-muted) !important; }
.text-primary { color: var(--accent) !important; }

.btn-primary, .btn-outline-primary {
    font-family: var(--font-body);
    font-size: 0.9rem;
}
.btn-primary {
    background: var(--accent);
    border-color: var(--accent);
}
.btn-primary:hover {
    background: var(--accent-dark);
    border-color: var(--accent-dark);
    transform: translateY(-2px);
}
.btn-outline-primary {
    color: var(--accent);
    border-color: var(--accent);
}
.btn-outline-primary:hover {
    background: var(--accent);
    border-color: var(--accent);
}

/* Scroll to top */
#scrollTopBtn {
    position: fixed;
    bottom: 32px; right: 32px;
    width: 48px; height: 48px;
    border-radius: 50%;
    border: none;
    background: var(--accent);
    color: #fff;
    font-size: 18px;
    display: none;
    box-shadow: 0 8px 24px rgba(200,136,42,0.35);
    cursor: pointer;
    transition: all 0.3s;
    z-index: 9000;
}
#scrollTopBtn:hover { transform: translateY(-4px); background: var(--accent-dark); }

/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 768px) {
    .section-padded { padding: 64px 0; }
    .hero-content { padding: 80px 0 60px; }
    .testimonial-card-modern { padding: 36px 24px; }
    .products-cta-banner { flex-direction: column; padding: 32px 24px; text-align: center; }
    .faq-accordion-wrap { border-top: 1px solid var(--border); }
    .newsletter-form { flex-direction: column; }
    .newsletter-input-wrap { min-width: unset; }
    .newsletter-submit-btn { width: 100%; }
}

@media (max-width: 576px) {
    .hero-cta-group { flex-direction: column; align-items: flex-start; }
    .btn-hero-primary, .btn-hero-ghost { width: 100%; justify-content: center; }
}

/* ╔══════════════════════════════════════════════════════════╗
   ║  BASE TEMPLATE STYLES — Append to theme.css              ║
   ║  Navbar + Footer + Scroll-to-top                         ║
   ╚══════════════════════════════════════════════════════════╝ */

/* ─────────────────────────────────────────
   NAVBAR
───────────────────────────────────────── */

/* Override Bootstrap's default .navbar background */
.custom-navbar {
    background: linear-gradient(135deg, #6F4E37 0%, #5c4033 55%, #3d2b1f 100%) !important;
    border-bottom: 1px solid rgba(255,255,255,0.07);
    box-shadow:
        0 1px 0 rgba(255,255,255,0.05) inset,
        0 6px 28px rgba(0,0,0,0.28);
    padding-top: 0;
    padding-bottom: 0;
    min-height: 66px;
    position: sticky;
    top: 0;
    z-index: 9999;
    transition: min-height 0.35s ease, box-shadow 0.35s ease;
}

/* Scrolled state */
.custom-navbar.nav-scrolled {
    min-height: 56px;
    box-shadow: 0 4px 32px rgba(0,0,0,0.38);
    -webkit-backdrop-filter: blur(12px);
    backdrop-filter: blur(12px);
}

/* ── Brand ── */
.custom-brand { text-decoration: none !important; }

.brand-icon-wrap {
    width: 36px; height: 36px;
    border-radius: 10px;
    background: rgba(255,255,255,0.1);
    border: 1px solid rgba(255,255,255,0.14);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    transition: background 0.3s;
}
.custom-brand:hover .brand-icon-wrap {
    background: rgba(255,255,255,0.18);
}
.brand-icon-wrap img { object-fit: contain; }

.brand-name {
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.03em;
    line-height: 1;
}

/* ── Mobile toggler ── */
.custom-toggler {
    background: transparent !important;
    border: 1px solid rgba(255,255,255,0.22) !important;
    border-radius: 8px !important;
    padding: 8px 10px !important;
    display: flex;
    flex-direction: column;
    gap: 5px;
    cursor: pointer;
    transition: border-color 0.3s, background 0.3s;
}
.custom-toggler:hover {
    background: rgba(255,255,255,0.08) !important;
    border-color: rgba(255,255,255,0.4) !important;
}
/* Hide Bootstrap's default toggler icon */
.custom-toggler .navbar-toggler-icon { display: none !important; }

.toggler-line {
    display: block;
    width: 20px; height: 2px;
    background: rgba(255,255,255,0.9);
    border-radius: 2px;
    transition: all 0.3s;
}

/* ── Nav links ── */

/* Override Bootstrap's .nav-link color inside our navbar */
.custom-navbar .nav-link,
.custom-navbar .custom-nav-link {
    font-family: var(--font-body) !important;
    font-size: 0.88rem !important;
    font-weight: 500 !important;
    color: rgba(255,255,255,0.82) !important;
    padding: 8px 14px !important;
    border-radius: 8px;
    letter-spacing: 0.025em;
    position: relative;
    transition: color 0.25s ease, background 0.25s ease !important;
    white-space: nowrap;
}

.custom-navbar .custom-nav-link::after {
    content: '';
    position: absolute;
    bottom: 4px; left: 14px;
    width: 0; height: 2px;
    background: rgba(232,200,122,0.85);
    border-radius: 2px;
    transition: width 0.3s ease;
}

.custom-navbar .custom-nav-link:hover {
    color: #fff !important;
    background: rgba(255,255,255,0.08) !important;
}
.custom-navbar .custom-nav-link:hover::after {
    width: calc(100% - 28px);
}

/* Active page highlight */
.custom-navbar .custom-nav-link.nav-link-active {
    color: #fff !important;
    background: rgba(255,255,255,0.1) !important;
}
.custom-navbar .custom-nav-link.nav-link-active::after {
    width: calc(100% - 28px);
}

/* Contact CTA pill */
.custom-navbar .custom-nav-cta {
    background: rgba(200,136,42,0.18) !important;
    border: 1px solid rgba(200,136,42,0.38) !important;
    color: rgba(232,200,122,1) !important;
    border-radius: 8px;
}
.custom-navbar .custom-nav-cta:hover {
    background: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
    transform: translateY(-2px);
    box-shadow: 0 6px 18px rgba(200,136,42,0.35);
}
.custom-navbar .custom-nav-cta::after { display: none !important; }

/* ── Theme toggle pill ── */
.theme-toggle-pill {
    display: inline-flex;
    align-items: center;
    gap: 2px;
    background: rgba(0,0,0,0.22);
    border: 1px solid rgba(255,255,255,0.12);
    border-radius: 100px;
    padding: 3px;
}

.theme-btn {
    width: 25px; height: 25px;
    border-radius: 40%;
    display: flex; align-items: center; justify-content: center;
    text-decoration: none !important;
    border: 1px solid transparent;
    color: rgba(255,255,255,0.55) !important;
    transition: all 0.3s ease;
    cursor: pointer;
}
.theme-btn:hover {
    color: #fff !important;
    background: rgba(255,255,255,0.1);
}
.theme-btn.active-theme {
    background: rgba(255,255,255,0.15) !important;
    border-color: rgba(255,255,255,0.28) !important;
    color: #fff !important;
}

/* ── Mobile collapsed menu ── */
@media (max-width: 991.98px) {
    /* The Bootstrap collapse panel */
    .custom-navbar .navbar-collapse {
        background: linear-gradient(160deg, #5c4033 0%, #3d2b1f 100%);
        border-top: 1px solid rgba(255,255,255,0.07);
        border-bottom: 1px solid rgba(255,255,255,0.04);
        box-shadow: 0 12px 32px rgba(0,0,0,0.35);
        padding: 8px 16px 16px;
        /* Overlap the page content */
        position: absolute;
        top: 100%; left: 0; right: 0;
        z-index: 9998;
    }

    .custom-navbar .custom-nav-link {
        display: block;
        padding: 11px 16px !important;
        border-radius: 10px;
    }
    .custom-navbar .custom-nav-link::after { display: none; }

    .custom-navbar .custom-nav-cta { margin-top: 4px; text-align: center; }

    .theme-toggle-pill { margin-left: 4px; }
}

/* ── Reading progress bar ── */
.nav-progress-bar {
    position: absolute;
    bottom: 0; left: 0;
    height: 2px; width: 0%;
    background: linear-gradient(90deg, var(--accent), var(--accent-light));
    border-radius: 0 2px 0 0;
    transition: width 0.1s linear;
    pointer-events: none;
}


/* ─────────────────────────────────────────
   FOOTER
───────────────────────────────────────── */
.site-footer {
    background: #0D0A06;
    color: rgba(255,255,255,0.7);
    font-family: var(--font-body);
}

.footer-top-divider {
    height: 3px;
    background: linear-gradient(
        90deg,
        transparent 0%,
        var(--accent) 30%,
        var(--accent-light, #E8C87A) 50%,
        var(--accent) 70%,
        transparent 100%
    );
}

/* Three-column grid */
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 56px;
    padding-bottom: 40px;
    border-bottom: 1px solid rgba(255,255,255,0.07);
}

@media (max-width: 900px) {
    .footer-grid { grid-template-columns: 1fr 1fr; gap: 36px; }
    .footer-brand-col { grid-column: 1 / -1; }
}
@media (max-width: 560px) {
    .footer-grid { grid-template-columns: 1fr; gap: 28px; }
}

/* Brand */
.footer-brand-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    text-decoration: none;
    margin-bottom: 14px;
}
.footer-brand-link img { border-radius: 8px; opacity: 0.88; }
.footer-brand-link span {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 700;
    color: #fff;
    letter-spacing: 0.03em;
}

.footer-tagline {
    font-size: 0.87rem;
    color: rgba(255,255,255,0.38);
    line-height: 1.7;
    max-width: 270px;
    margin-bottom: 22px;
}

/* Socials */
.footer-socials { display: flex; gap: 8px; flex-wrap: wrap; }

.footer-social-btn {
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.09);
    display: flex; align-items: center; justify-content: center;
    color: rgba(255,255,255,0.5);
    font-size: 0.8rem;
    text-decoration: none;
    transition: all 0.3s ease;
}
.footer-social-btn:hover {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    transform: translateY(-3px);
    box-shadow: 0 6px 16px rgba(200,136,42,0.35);
}

/* Column headings */
.footer-col-heading {
    font-family: var(--font-body);
    font-size: 0.7rem;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--accent-light, #E8C87A);
    margin-bottom: 18px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.footer-col-heading::after {
    content: '';
    flex: 1; height: 1px;
    background: rgba(255,255,255,0.07);
}

/* Links */
.footer-link-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 10px;
}
.footer-link-list a {
    font-size: 0.88rem;
    color: rgba(255,255,255,0.5);
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 6px;
    transition: all 0.25s ease;
}
.footer-link-list a::before {
    content: '';
    width: 0; height: 1px;
    background: var(--accent);
    transition: width 0.3s;
    display: block;
}
.footer-link-list a:hover { color: rgba(255,255,255,0.88); gap: 10px; }
.footer-link-list a:hover::before { width: 12px; }

/* Contact list */
.footer-contact-list {
    list-style: none;
    margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 14px;
}
.footer-contact-list li {
    display: flex; align-items: flex-start; gap: 12px;
    font-size: 0.87rem;
    color: rgba(255,255,255,0.45);
    line-height: 1.5;
}
.footer-contact-list i {
    color: var(--accent);
    font-size: 0.8rem;
    margin-top: 3px;
    flex-shrink: 0;
    width: 14px;
}
.footer-contact-list a {
    color: rgba(255,255,255,0.5);
    text-decoration: none;
    transition: color 0.3s;
}
.footer-contact-list a:hover { color: rgba(255,255,255,0.88); }

/* Bottom bar */
.footer-bottom {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding-top: 24px;
    flex-wrap: wrap;
}
.footer-copy {
    font-size: 0.82rem;
    color: rgba(255,255,255,0.3);
    margin: 0;
}
.footer-copy a {
    color: rgba(255,255,255,0.45);
    text-decoration: none;
    transition: color 0.3s;
}
.footer-copy a:hover { color: var(--accent-light); }

.footer-bottom-links { display: flex; align-items: center; gap: 12px; }
.footer-bottom-links a {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.28);
    text-decoration: none;
    transition: color 0.3s;
}
.footer-bottom-links a:hover { color: rgba(255,255,255,0.65); }

.footer-dot {
    width: 3px; height: 3px;
    border-radius: 50%;
    background: rgba(255,255,255,0.18);
    display: inline-block;
}

/* ─────────────────────────────────────────
   SCROLL TO TOP
───────────────────────────────────────── */
#scrollTopBtn {
    position: fixed;
    bottom: 32px; right: 32px;
    width: 48px; height: 48px;
    border-radius: 50%;
    border: 1px solid rgba(255,255,255,0.1);
    background: var(--accent);
    color: #fff;
    display: none;              /* JS sets to flex when visible */
    align-items: center;
    justify-content: center;
    box-shadow: 0 8px 28px rgba(200,136,42,0.42);
    cursor: pointer;
    transition: all 0.3s ease;
    z-index: 8000;
}
#scrollTopBtn:hover {
    background: var(--accent-dark);
    transform: translateY(-4px);
    box-shadow: 0 14px 36px rgba(200,136,42,0.48);
}

/* ─────────────────────────────────────────
   MAIN CONTENT
───────────────────────────────────────── */
#main-content { min-height: 60vh; }




/* ╔══════════════════════════════════════════════════════════╗
   ║  PRODUCT DETAIL PAGE — Append to theme.css               ║
   ╚══════════════════════════════════════════════════════════╝ */

/* ─────────────────────────────────────────
   BREADCRUMB BAR
───────────────────────────────────────── */
.pd-breadcrumb-bar {
    background: var(--surface);
    border-bottom: 1px solid var(--border);
    padding: 14px 0;
}
.pd-breadcrumb {
    display: flex;
    align-items: center;
    gap: 6px;
    font-size: 0.82rem;
    flex-wrap: wrap;
}
.pd-breadcrumb a {
    color: var(--text-muted);
    text-decoration: none;
    transition: color 0.2s;
}
.pd-breadcrumb a:hover { color: var(--accent); }
.pd-breadcrumb svg { color: var(--border); flex-shrink: 0; }
.pd-breadcrumb span { color: var(--accent); font-weight: 500; }


/* ─────────────────────────────────────────
   PRODUCT HERO
───────────────────────────────────────── */
.pd-hero-section {
    padding: 60px 0 80px;
    background: var(--bg);
}

.pd-hero-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}
@media (max-width: 900px) {
    .pd-hero-grid { grid-template-columns: 1fr; gap: 48px; }
}

/* ── Image panel ── */
.pd-image-panel { position: sticky; top: 90px; }

.pd-main-image-wrap {
    position: relative;
    border-radius: 24px;
    overflow: hidden;
    background: var(--surface);
    border: 1px solid var(--border);
    box-shadow: var(--shadow-lg);
    aspect-ratio: 4/3;
    display: flex;
    align-items: center;
    justify-content: center;
    cursor: zoom-in;
    margin-bottom: 20px;
}
.pd-main-image {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.6s cubic-bezier(0.4, 0, 0.2, 1);
}
.pd-main-image-wrap:hover .pd-main-image { transform: scale(1.06); }
.pd-main-image--placeholder { object-fit: contain; padding: 40px; }

/* Floating badge */
.pd-img-badge {
    position: absolute;
    top: 18px; left: 18px;
    display: flex; align-items: center; gap: 6px;
    font-size: 0.75rem; font-weight: 700;
    letter-spacing: 0.06em;
    padding: 6px 14px;
    border-radius: 100px;
}
.pd-img-badge--featured {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: #fff;
    box-shadow: 0 4px 14px rgba(200,136,42,0.4);
}

/* Zoom hint */
.pd-img-zoom-hint {
    position: absolute;
    bottom: 16px; right: 16px;
    width: 36px; height: 36px;
    border-radius: 50%;
    background: rgba(0,0,0,0.45);
    color: rgba(255,255,255,0.8);
    display: flex; align-items: center; justify-content: center;
    font-size: 0.8rem;
    opacity: 0;
    transition: opacity 0.3s;
}
.pd-main-image-wrap:hover .pd-img-zoom-hint { opacity: 1; }

/* Trust strip */
.pd-trust-strip {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 14px;
    padding: 16px;
}
.pd-trust-item {
    display: flex; align-items: center; gap: 8px;
    flex: 1; justify-content: center;
    font-size: 0.8rem; font-weight: 500;
    color: var(--text-muted);
}
.pd-trust-item i { color: var(--accent); font-size: 0.85rem; }
.pd-trust-divider {
    width: 1px; height: 28px;
    background: var(--border); flex-shrink: 0;
}

/* ── Details panel ── */
.pd-badge-row {
    display: flex; gap: 8px; flex-wrap: wrap;
    margin-bottom: 18px;
}
.pd-badge {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.72rem; font-weight: 700;
    letter-spacing: 0.08em; text-transform: uppercase;
    padding: 5px 14px; border-radius: 100px;
}
.pd-badge--category {
    background: rgba(13,110,253,0.1);
    color: #0d6efd;
    border: 1px solid rgba(13,110,253,0.2);
}
[data-theme="dark"] .pd-badge--category {
    background: rgba(77,171,247,0.12);
    color: #4dabf7;
    border-color: rgba(77,171,247,0.2);
}
.pd-badge--featured {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: #fff;
}

.pd-product-name {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3rem);
    font-weight: 700;
    color: var(--text);
    line-height: 1.1;
    margin-bottom: 16px;
    letter-spacing: -0.02em;
}

/* Rating */
.pd-rating-row {
    display: flex; align-items: center; gap: 10px;
    margin-bottom: 24px; flex-wrap: wrap;
}
.pd-stars { color: var(--accent); font-size: 0.9rem; letter-spacing: 2px; }
.pd-rating-text {
    font-size: 0.88rem; font-weight: 600; color: var(--text);
}
.pd-rating-sep { color: var(--border); }
.pd-rating-reviews { font-size: 0.84rem; color: var(--text-muted); }

/* Rule */
.pd-section-rule {
    height: 1px; background: var(--border); margin-bottom: 24px;
}

/* Description */
.pd-description {
    font-size: 1rem; color: var(--text-muted); line-height: 1.8;
    margin-bottom: 28px;
}

/* Price block */
.pd-price-block {
    background: var(--surface);
    border: 1px solid var(--border);
    border-left: 4px solid var(--accent);
    border-radius: 16px;
    padding: 24px 28px;
    margin-bottom: 28px;
}
.pd-price-label {
    font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em;
    text-transform: uppercase; color: var(--text-muted); margin-bottom: 6px;
}
.pd-price-value {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 2.8rem);
    font-weight: 700; color: var(--accent); line-height: 1;
    margin-bottom: 10px;
}
.pd-price-currency {
    font-size: 1.1rem; font-weight: 500; color: var(--text-muted);
    margin-left: 4px;
}
.pd-price-note {
    font-size: 0.8rem; color: var(--text-muted); margin: 0;
    display: flex; align-items: center; gap: 6px;
}
.pd-price-note i { color: #22c55e; }

/* Action buttons */
.pd-actions {
    display: flex; gap: 14px; flex-wrap: wrap; margin-bottom: 32px;
}
.pd-btn-primary {
    display: inline-flex; align-items: center; gap: 9px;
    background: var(--accent); color: #fff;
    font-family: var(--font-body); font-size: 0.95rem; font-weight: 600;
    padding: 14px 28px; border-radius: 10px;
    border: 2px solid var(--accent); text-decoration: none;
    transition: all 0.3s ease; white-space: nowrap;
}
.pd-btn-primary:hover {
    background: transparent; color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 8px 28px rgba(200,136,42,0.3);
    opacity: 1;
}
.pd-btn-ghost {
    display: inline-flex; align-items: center; gap: 9px;
    background: transparent; color: var(--text);
    font-family: var(--font-body); font-size: 0.95rem; font-weight: 500;
    padding: 14px 24px; border-radius: 10px;
    border: 1px solid var(--border); text-decoration: none;
    transition: all 0.3s ease; white-space: nowrap;
}
.pd-btn-ghost:hover {
    border-color: var(--accent); color: var(--accent);
    transform: translateY(-3px); opacity: 1;
}

/* Highlights */
.pd-highlights {
    display: flex; flex-direction: column; gap: 14px;
    padding: 24px;
    background: var(--surface-2, var(--bg-alt));
    border: 1px solid var(--border);
    border-radius: 16px;
}
.pd-highlight-item {
    display: flex; align-items: flex-start; gap: 14px;
}
.pd-highlight-icon {
    width: 38px; height: 38px; flex-shrink: 0;
    border-radius: 10px;
    background: linear-gradient(135deg, rgba(200,136,42,0.12), rgba(200,136,42,0.04));
    border: 1px solid rgba(200,136,42,0.18);
    display: flex; align-items: center; justify-content: center;
    color: var(--accent); font-size: 0.85rem;
}
.pd-highlight-item strong {
    display: block; font-size: 0.88rem; font-weight: 600; color: var(--text);
    margin-bottom: 2px;
}
.pd-highlight-item span {
    font-size: 0.8rem; color: var(--text-muted);
}


/* ─────────────────────────────────────────
   TABS SECTION
───────────────────────────────────────── */
.pd-tabs-section {
    padding: 0 0 80px;
    background: var(--bg);
}

.pd-tabs-nav {
    display: flex;
    gap: 0;
    border-bottom: 2px solid var(--border);
    margin-bottom: 40px;
    overflow-x: auto;
    -ms-overflow-style: none; /* IE and legacy Edge */
    overflow-y: auto;
}
.pd-tabs-nav::-webkit-scrollbar {
    display: none; /* Chrome, Safari, iOS, Samsung Internet */
    width: 0;
    height: 0;
}

.pd-tab-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: transparent; border: none;
    font-family: var(--font-body); font-size: 0.88rem; font-weight: 600;
    color: var(--text-muted); padding: 14px 24px;
    cursor: pointer; white-space: nowrap;
    position: relative; transition: color 0.3s;
}
.pd-tab-btn::after {
    content: '';
    position: absolute; bottom: -2px; left: 0; right: 0;
    height: 2px; background: var(--accent);
    transform: scaleX(0); transition: transform 0.3s ease;
}
.pd-tab-btn:hover { color: var(--text); }
.pd-tab-btn.active { color: var(--accent); }
.pd-tab-btn.active::after { transform: scaleX(1); }

/* Tab panels */
.pd-tab-panel { display: none; animation: fadeUp 0.4s ease; }
.pd-tab-panel.active { display: block; }

/* Overview grid */
.pd-overview-grid {
    display: grid; grid-template-columns: 1.5fr 1fr; gap: 60px;
}
@media (max-width: 768px) { .pd-overview-grid { grid-template-columns: 1fr; gap: 36px; } }

.pd-overview-text h3,
.pd-overview-specs h3 {
    font-family: var(--font-display);
    font-size: 1.3rem; font-weight: 600; color: var(--text);
    margin-bottom: 16px;
}
.pd-desc-full { font-size: 0.95rem; color: var(--text-muted); line-height: 1.8; }

/* Spec list */
.pd-spec-list {
    list-style: none; margin: 0; padding: 0;
    display: flex; flex-direction: column; gap: 0;
    border: 1px solid var(--border); border-radius: 14px; overflow: hidden;
}
.pd-spec-list li {
    display: flex; align-items: center;
    padding: 14px 18px;
    font-size: 0.88rem;
    border-bottom: 1px solid var(--border);
    transition: background 0.2s;
}
.pd-spec-list li:last-child { border-bottom: none; }
.pd-spec-list li:hover { background: var(--bg-alt); }
.spec-key {
    font-weight: 600; color: var(--text-muted);
    min-width: 120px; flex-shrink: 0;
}
.spec-val { color: var(--text); }
.spec-featured { color: var(--accent); font-weight: 600; }
.spec-available { color: #22c55e; font-weight: 600; }

/* Shipping grid */
.pd-shipping-grid {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px;
}
@media (max-width: 768px) { .pd-shipping-grid { grid-template-columns: 1fr; } }

.pd-shipping-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 16px; padding: 32px 24px;
    text-align: center;
    transition: all 0.3s;
}
.pd-shipping-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-md);
    border-color: rgba(200,136,42,0.25);
}
.shipping-icon {
    width: 58px; height: 58px;
    border-radius: 50%;
    background: linear-gradient(135deg, rgba(200,136,42,0.12), rgba(200,136,42,0.03));
    border: 1px solid rgba(200,136,42,0.18);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.3rem; color: var(--accent);
    margin: 0 auto 18px;
}
.pd-shipping-card h5 {
    font-family: var(--font-display);
    font-size: 1.1rem; font-weight: 600; margin-bottom: 10px; color: var(--text);
}
.pd-shipping-card p { font-size: 0.88rem; color: var(--text-muted); line-height: 1.7; margin: 0; }

/* FAQ list */
.pd-faq-list { display: flex; flex-direction: column; gap: 0; }
.pd-faq-item {
    padding: 24px 0;
    border-bottom: 1px solid var(--border);
}
.pd-faq-item:last-child { border-bottom: none; }
.pd-faq-q {
    font-family: var(--font-body);
    font-size: 1rem; font-weight: 600; color: var(--text);
    margin-bottom: 10px;
    display: flex; align-items: flex-start; gap: 10px;
}
.pd-faq-q::before {
    content: 'Q';
    display: inline-flex; align-items: center; justify-content: center;
    width: 24px; height: 24px; flex-shrink: 0;
    border-radius: 6px; background: var(--accent);
    color: #fff; font-size: 0.72rem; font-weight: 800;
}
.pd-faq-a {
    font-size: 0.93rem; color: var(--text-muted); line-height: 1.75;
    padding-left: 34px;
}


/* ─────────────────────────────────────────
   RELATED PRODUCTS
───────────────────────────────────────── */
.pd-related-section {
    padding: 80px 0;
    background: var(--bg-alt);
}

.pd-related-header {
    display: flex; align-items: flex-end;
    justify-content: space-between; gap: 20px;
    margin-bottom: 48px; flex-wrap: wrap;
}
.pd-related-title {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.5rem);
    font-weight: 600; color: var(--text); margin: 0;
}
.pd-related-view-all {
    display: inline-flex; align-items: center; gap: 6px;
    font-size: 0.85rem; font-weight: 600; color: var(--accent);
    text-decoration: none; white-space: nowrap;
    transition: gap 0.3s;
}
.pd-related-view-all:hover { gap: 10px; opacity: 0.8; }

/* Grid */
.pd-related-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(270px, 1fr));
    gap: 24px;
}

/* Card */
.pd-related-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 20px; overflow: hidden;
    transition: all 0.4s ease;
    animation: fadeUp 0.5s ease both;
    animation-delay: calc(var(--ri, 0) * 0.07s + 0.1s);
}
.pd-related-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(200,136,42,0.25);
}

/* Image */
.pd-related-img-wrap {
    position: relative; overflow: hidden; height: 220px;
}
.pd-related-img {
    width: 100%; height: 100%; object-fit: cover;
    transition: transform 0.5s cubic-bezier(0.4,0,0.2,1);
}
.pd-related-card:hover .pd-related-img { transform: scale(1.08); }

/* Related Product Overlay */
.pd-related-overlay {
    position: absolute;
    inset: 0;

    background: rgba(12, 8, 3, 0.5);

    display: flex;
    align-items: center;
    justify-content: center;

    opacity: 0;

    transition: opacity 0.3s ease;

    z-index: 2;
}

.pd-related-card:hover .pd-related-overlay {
    opacity: 1;
}

/* Quick View Button */
.pd-related-quick {
    display: inline-flex;
    align-items: center;
    gap: 8px;

    padding: 11px 20px;

    background: rgba(255,255,255,0.14);

    color: #ffffff;

    font-size: 0.85rem;
    font-weight: 700;

    border-radius: 999px;

    border: 1px solid rgba(255,255,255,0.18);

    text-decoration: none;

    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);

    box-shadow: 0 8px 24px rgba(0,0,0,0.22);

    transform: translateY(8px);

    transition:
        transform 0.3s ease,
        background 0.3s ease,
        color 0.3s ease;
}

.pd-related-card:hover .pd-related-quick {
    transform: translateY(0);
}

/* Hover */
.pd-related-quick:hover {
    background: rgba(255,255,255,0.22);
    color: #ffffff;
}

.pd-related-quick {
    background: #fff; color: var(--text);
    font-size: 0.83rem; font-weight: 600;
    padding: 9px 18px; border-radius: 100px;
    text-decoration: none;
    display: inline-flex; align-items: center; gap: 6px;
    transform: translateY(8px); transition: transform 0.3s;
}
.pd-related-card:hover .pd-related-quick { transform: translateY(0); }

/* Body */
.pd-related-body { padding: 22px; }
.pd-related-cat {
    display: inline-block;
    font-size: 0.7rem; font-weight: 700; letter-spacing: 0.1em;
    text-transform: uppercase; color: var(--accent);
    margin-bottom: 8px;
}
.pd-related-name {
    font-family: var(--font-display);
    font-size: 1.2rem; font-weight: 600; color: var(--text);
    margin-bottom: 8px; line-height: 1.2;
}
.pd-related-desc {
    font-size: 0.85rem; color: var(--text-muted);
    line-height: 1.6; margin-bottom: 18px;
}
.pd-related-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: 10px;
}
.pd-related-price {
    font-family: var(--font-display);
    font-size: 1.2rem; font-weight: 700; color: var(--accent);
}
.pd-related-btn {
    font-size: 0.8rem; font-weight: 600;
    background: var(--text); color: var(--bg);
    padding: 8px 16px; border-radius: 8px;
    text-decoration: none; transition: all 0.3s; white-space: nowrap;
}
.pd-related-btn:hover {
    background: var(--accent); color: #fff;
    transform: translateY(-2px); opacity: 1;
}

/* Empty */
.pd-related-empty {
    grid-column: 1 / -1;
    display: flex; flex-direction: column; align-items: center; gap: 12px;
    padding: 60px 20px; text-align: center;
    color: var(--text-muted);
}
.pd-related-empty i { font-size: 2rem; color: var(--border); }


/* ─────────────────────────────────────────
   CTA STRIP
───────────────────────────────────────── */
.pd-cta-strip {
    position: relative; overflow: hidden;
    padding: 60px 0;
    background: var(--brand-dark, #0D0A06);
}
.pd-cta-strip-bg {
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse at 20% 50%, rgba(200,136,42,0.14), transparent 55%),
        radial-gradient(ellipse at 80% 50%, rgba(200,136,42,0.08), transparent 55%);
    pointer-events: none;
}
.pd-cta-strip-inner {
    position: relative; z-index: 2;
    display: flex; align-items: center;
    justify-content: space-between; gap: 24px;
    flex-wrap: wrap;
}
.pd-cta-strip-text h3 {
    font-family: var(--font-display);
    font-size: clamp(1.5rem, 3vw, 2.2rem);
    font-weight: 600; color: #fff; margin-bottom: 8px;
}
.pd-cta-strip-text p {
    font-size: 0.95rem; color: rgba(255,255,255,0.55); margin: 0;
}

@media (max-width: 640px) {
    .pd-cta-strip-inner { flex-direction: column; text-align: center; }
    .pd-cta-strip-inner .btn-hero-primary { width: 100%; justify-content: center; }
    .pd-actions { flex-direction: column; }
    .pd-btn-primary, .pd-btn-ghost { justify-content: center; }
    .pd-image-panel { position: static; }
    .pd-trust-item span { display: none; }
}


/* ╔══════════════════════════════════════════════════════════╗
   ║  PRODUCTS LISTING PAGE — Append to theme.css             ║
   ╚══════════════════════════════════════════════════════════╝ */

/* ─────────────────────────────────────────
   HERO
───────────────────────────────────────── */
.pl-hero {
    position: relative;
    overflow: hidden;
    padding: 110px 0 80px;
    min-height: 44vh;
    display: flex;
    align-items: center;
}
.pl-hero-bg {
    position: absolute; inset: 0;
    background: linear-gradient(135deg, #0D0A06 0%, #1C1108 50%, #251808 100%);
}
.pl-hero-bg::after {
    content: '';
    position: absolute; inset: 0;
    background-image:
        linear-gradient(rgba(200,136,42,0.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(200,136,42,0.05) 1px, transparent 1px);
    background-size: 56px 56px;
    -webkit-mask-image: linear-gradient(to bottom, black, transparent);
    mask-image: linear-gradient(to bottom, black, transparent);
    -webkit-mask-image: radial-gradient(ellipse at 50% 100%, black 30%, transparent 75%);
    mask-image: radial-gradient(ellipse at 50% 100%, black 30%, transparent 75%);
}
.pl-hero-orb-1 {
    position: absolute;
    width: 600px; height: 600px; border-radius: 50%;
    background: radial-gradient(circle, rgba(200,136,42,0.13), transparent 65%);
    top: -200px; right: -100px;
    animation: orbFloat 14s ease-in-out infinite;
    pointer-events: none;
}
.pl-hero-orb-2 {
    position: absolute;
    width: 350px; height: 350px; border-radius: 50%;
    background: radial-gradient(circle, rgba(200,136,42,0.07), transparent 65%);
    bottom: -100px; left: -80px;
    animation: orbFloat 18s ease-in-out infinite reverse;
    pointer-events: none;
}
.pl-hero-content {
    position: relative; z-index: 2;
    max-width: 720px;
}

.pl-breadcrumb {
    display: inline-flex; align-items: center; gap: 7px;
    font-size: 0.8rem; font-weight: 500;
    color: rgba(255,255,255,0.45);
    margin-bottom: 24px;
}
.pl-breadcrumb a { color: rgba(255,255,255,0.5); text-decoration: none; transition: color 0.3s; }
.pl-breadcrumb a:hover { color: var(--accent-light); }
.pl-breadcrumb svg { opacity: 0.35; }
.pl-breadcrumb span { color: var(--accent-light); }

.pl-hero-eyebrow {
    display: inline-flex; align-items: center; gap: 10px;
    background: rgba(200,136,42,0.1);
    border: 1px solid rgba(200,136,42,0.25);
    color: var(--accent-light);
    font-size: 0.74rem; font-weight: 600;
    letter-spacing: 0.14em; text-transform: uppercase;
    padding: 7px 18px; border-radius: 100px;
    margin-bottom: 22px;
}
.pl-hero-heading {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 5vw, 4.2rem);
    font-weight: 600; color: #fff;
    line-height: 1.05; letter-spacing: -0.02em;
    margin-bottom: 20px;
    background: linear-gradient(135deg, #fff 55%, var(--accent-light) 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
}
.pl-hero-sub {
    font-size: clamp(0.95rem, 2vw, 1.1rem);
    color: rgba(255,255,255,0.58);
    max-width: 560px; line-height: 1.8; margin: 0;
}


/* ─────────────────────────────────────────
   FILTER BAR
───────────────────────────────────────── */
.pl-filter-bar-wrap {
    position: relative;

    z-index: 500;

    background: var(--surface);

    border-bottom: 1px solid var(--border);

    transition: box-shadow 0.3s ease;
}

/* Optional shadow effect */
.pl-filter-bar-wrap.pl-filter-bar--stuck {
    box-shadow: 0 4px 24px rgba(0,0,0,0.1);
}

.pl-filter-bar {
    display: flex;
    align-items: center;
    gap: 20px;
    padding: 14px 0;
    flex-wrap: wrap;
}

/* Search */
.pl-search-wrap {
    position: relative;
    flex: 0 0 280px;
    min-width: 200px;
}
.pl-search-icon {
    position: absolute; left: 14px; top: 50%;
    transform: translateY(-50%);
    color: var(--text-muted); font-size: 0.82rem;
    pointer-events: none;
}
.pl-search-input {
    width: 100%;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 10px 38px 10px 38px;
    font-family: var(--font-body);
    font-size: 0.88rem;
    color: var(--text);
    transition: border-color 0.3s, box-shadow 0.3s;
}
.pl-search-input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,136,42,0.12);
}
.pl-search-input::placeholder { color: var(--text-muted); }
.pl-search-clear {
    position: absolute; right: 10px; top: 50%;
    transform: translateY(-50%);
    width: 22px; height: 22px; border-radius: 50%;
    background: var(--border); border: none;
    display: flex; align-items: center; justify-content: center;
    font-size: 0.7rem; color: var(--text-muted);
    cursor: pointer; transition: all 0.2s;
}
.pl-search-clear:hover { background: var(--accent); color: #fff; }

/* Category pills */
.pl-category-pills {
    display: flex; gap: 8px;
    flex: 1; flex-wrap: wrap;
    overflow-x: auto;
    -ms-overflow-style: none;
}
.pl-category-pills::-webkit-scrollbar { display: none; }

.pl-cat-pill {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--bg);
    border: 1px solid var(--border);
    border-radius: 100px;
    font-family: var(--font-body);
    font-size: 0.8rem; font-weight: 600;
    color: var(--text-muted);
    padding: 7px 16px;
    cursor: pointer; white-space: nowrap;
    transition: all 0.25s ease;
}
.pl-cat-pill i { font-size: 0.72rem; }
.pl-cat-pill:hover {
    border-color: var(--accent);
    color: var(--accent);
    background: rgba(200,136,42,0.06);
}
.pl-cat-pill.active {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 4px 14px rgba(200,136,42,0.3);
}

/* Count */
.pl-results-count {
    font-size: 0.82rem;
    color: var(--text-muted);
    white-space: nowrap;
    flex-shrink: 0;
}
.pl-results-count span { font-weight: 700; color: var(--accent); }


/* ─────────────────────────────────────────
   MAIN SECTION
───────────────────────────────────────── */
.pl-main-section {
    padding: 60px 0 100px;
    background: var(--bg);
}


/* ─────────────────────────────────────────
   CATEGORY SECTION
───────────────────────────────────────── */
.pl-cat-section { margin-bottom: 72px; }

.pl-cat-heading {
    display: flex; align-items: center; gap: 20px;
    margin-bottom: 32px;
}
.pl-cat-heading-left {
    display: flex; align-items: center; gap: 16px;
    flex-shrink: 0;
}
.pl-cat-icon {
    width: 44px; height: 44px;
    border-radius: 12px;
    background: linear-gradient(135deg, rgba(200,136,42,0.14), rgba(200,136,42,0.04));
    border: 1px solid rgba(200,136,42,0.2);
    display: flex; align-items: center; justify-content: center;
    color: var(--accent); font-size: 0.9rem;
}
.pl-cat-name {
    font-family: var(--font-display);
    font-size: 1.6rem; font-weight: 600;
    color: var(--text); margin: 0; line-height: 1;
}
.pl-cat-count {
    display: inline-block;
    font-size: 0.75rem; font-weight: 700;
    color: var(--text-muted); letter-spacing: 0.05em;
    margin-top: 4px;
}
.pl-cat-rule {
    flex: 1; height: 1px;
    background: linear-gradient(90deg, var(--border), transparent);
}


/* ─────────────────────────────────────────
   PRODUCT GRID
───────────────────────────────────────── */
.pl-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}


/* ─────────────────────────────────────────
   PRODUCT CARD
───────────────────────────────────────── */
.pl-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 20px;
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: all 0.4s cubic-bezier(0.4,0,0.2,1);
    animation: fadeUp 0.5s ease both;
    animation-delay: calc(var(--ci, 0) * 0.06s + 0.1s);
}
.pl-card:hover {
    transform: translateY(-10px);
    box-shadow: 0 24px 60px rgba(0,0,0,0.12);
    border-color: rgba(200,136,42,0.28);
}

/* Image */
.pl-card-img-wrap {
    position: relative; overflow: hidden;
    height: 240px; cursor: pointer;
}
.pl-card-img {
    width: 100%; height: 100%;
    object-fit: cover;
    transition: transform 0.55s cubic-bezier(0.4,0,0.2,1);
}
.pl-card-img--placeholder { object-fit: contain; padding: 32px; }
.pl-card:hover .pl-card-img { transform: scale(1.08); }

/* Overlay */
.pl-card-img-overlay {
    position: absolute;
    inset: 0;

    background: rgba(12, 8, 3, 0.48);

    display: flex;
    align-items: center;
    justify-content: center;

    opacity: 0;

    transition: opacity 0.3s ease;

    z-index: 2;
}

.pl-card:hover .pl-card-img-overlay {
    opacity: 1;
}

/* Preview Button */
.pl-card-zoom-btn {
    background: rgba(255,255,255,0.14);

    color: #ffffff;

    font-size: 0.82rem;
    font-weight: 700;

    padding: 10px 18px;

    border-radius: 100px;

    display: inline-flex;
    align-items: center;
    gap: 8px;

    border: 1px solid rgba(255,255,255,0.18);

    -webkit-backdrop-filter: blur(10px);
    backdrop-filter: blur(10px);

    box-shadow: 0 8px 24px rgba(0,0,0,0.2);

    transform: translateY(8px);

    transition:
        transform 0.3s ease,
        background 0.3s ease;
}

.pl-card:hover .pl-card-zoom-btn {
    transform: translateY(0);
}

/* Hover effect */
.pl-card-zoom-btn:hover {
    background: rgba(255,255,255,0.22);
}

/* Badges */
.pl-card-badges {
    position: absolute;
    top: 14px; left: 14px;
    display: flex; flex-direction: column; gap: 6px;
}
.pl-card-badge {
    display: inline-flex; align-items: center; gap: 5px;
    font-size: 0.67rem; font-weight: 800;
    letter-spacing: 0.07em; text-transform: uppercase;
    padding: 4px 10px; border-radius: 6px;
    width: fit-content;
}
.pl-card-badge--featured {
    background: linear-gradient(135deg, var(--accent), var(--accent-dark));
    color: #fff;
    box-shadow: 0 3px 10px rgba(200,136,42,0.4);
}
.pl-card-badge--cat {
    background: rgba(0,0,0,0.55);
    color: rgba(255,255,255,0.9);
    border: 1px solid rgba(255,255,255,0.15);
    -webkit-backdrop-filter: blur(4px);
    backdrop-filter: blur(4px);
}

/* Body */
.pl-card-body {
    padding: 22px;
    display: flex; flex-direction: column;
    flex: 1;
}
.pl-card-name {
    font-family: var(--font-display);
    font-size: 1.2rem; font-weight: 600;
    color: var(--text); margin-bottom: 10px;
    line-height: 1.25;
}
.pl-card-desc {
    font-size: 0.87rem; color: var(--text-muted);
    line-height: 1.65; margin-bottom: 20px;
    flex: 1;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

/* Footer */
.pl-card-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: 12px;
    padding-top: 16px;
    border-top: 1px solid var(--border);
}
.pl-card-price {
    font-family: var(--font-display);
    font-size: 1.3rem; font-weight: 700; color: var(--accent);
    line-height: 1;
}
.pl-card-currency {
    font-size: 0.8rem; color: var(--text-muted);
    font-family: var(--font-body); font-weight: 400;
    margin-left: 2px;
}
.pl-card-btn {
    display: inline-flex; align-items: center; gap: 6px;
    background: var(--text); color: var(--bg);
    font-family: var(--font-body);
    font-size: 0.78rem; font-weight: 700;
    padding: 9px 16px; border-radius: 8px;
    text-decoration: none; white-space: nowrap;
    transition: all 0.3s;
}
.pl-card-btn svg { transition: transform 0.3s; }
.pl-card-btn:hover {
    background: var(--accent); color: #fff;
    transform: translateY(-2px);
    box-shadow: 0 6px 16px rgba(200,136,42,0.32);
    opacity: 1;
}
.pl-card-btn:hover svg { transform: translateX(3px); }


/* ─────────────────────────────────────────
   MODAL
───────────────────────────────────────── */
.pl-modal .modal-dialog { max-width: 700px; }

.pl-modal-content {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 24px;
    overflow: hidden;
    box-shadow: 0 40px 100px rgba(0,0,0,0.3);
}

.pl-modal-header {
    display: flex; align-items: flex-start;
    justify-content: space-between; gap: 16px;
    padding: 24px 28px 18px;
    border-bottom: 1px solid var(--border);
}
.pl-modal-cat {
    display: inline-block;
    font-size: 0.7rem; font-weight: 700;
    letter-spacing: 0.1em; text-transform: uppercase;
    color: var(--accent); margin-bottom: 6px;
}
.pl-modal-title {
    font-family: var(--font-display);
    font-size: 1.4rem; font-weight: 600;
    color: var(--text); margin: 0;
}
.pl-modal-close {
    width: 36px; height: 36px; flex-shrink: 0;
    background: var(--bg); border: 1px solid var(--border);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--text-muted); cursor: pointer;
    transition: all 0.25s;
}
.pl-modal-close:hover {
    background: var(--accent); border-color: var(--accent);
    color: #fff; transform: rotate(90deg);
}

.pl-modal-img-wrap {
    background: var(--bg-alt);
    display: flex; align-items: center; justify-content: center;
    max-height: 480px; overflow: hidden;
}
.pl-modal-img { width: 100%; max-height: 480px; object-fit: cover; }
.pl-modal-img--placeholder { object-fit: contain; padding: 48px; }

.pl-modal-footer {
    display: flex; align-items: center;
    justify-content: space-between; gap: 16px;
    padding: 20px 28px;
    border-top: 1px solid var(--border);
    flex-wrap: wrap;
}
.pl-modal-price {
    font-family: var(--font-display);
    font-size: 1.5rem; font-weight: 700; color: var(--accent);
}
.pl-modal-actions { display: flex; gap: 10px; }

.pl-modal-dismiss {
    background: transparent;
    border: 1px solid var(--border);
    color: var(--text-muted);
    font-family: var(--font-body); font-size: 0.85rem; font-weight: 500;
    padding: 9px 18px; border-radius: 8px;
    cursor: pointer; transition: all 0.25s;
}
.pl-modal-dismiss:hover { border-color: var(--text-muted); color: var(--text); }

.pl-modal-detail-btn {
    display: inline-flex; align-items: center; gap: 7px;
    background: var(--accent); color: #fff;
    font-family: var(--font-body); font-size: 0.85rem; font-weight: 700;
    padding: 9px 20px; border-radius: 8px;
    text-decoration: none; transition: all 0.25s;
}
.pl-modal-detail-btn:hover {
    background: var(--accent-dark); color: #fff;
    transform: translateY(-2px); opacity: 1;
}
.pl-modal-detail-btn svg { transition: transform 0.25s; }
.pl-modal-detail-btn:hover svg { transform: translateX(3px); }


/* ─────────────────────────────────────────
   NO RESULTS
───────────────────────────────────────── */
.pl-no-results {
    display: flex; flex-direction: column;
    align-items: center; gap: 16px;
    padding: 80px 20px; text-align: center;
}
.pl-no-results-icon {
    width: 80px; height: 80px; border-radius: 50%;
    background: var(--surface); border: 1px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    font-size: 2rem; color: var(--text-muted);
}
.pl-no-results h4 {
    font-family: var(--font-display); font-size: 1.5rem;
    font-weight: 600; color: var(--text); margin: 0;
}
.pl-no-results p { font-size: 0.95rem; color: var(--text-muted); margin: 0; }
.pl-no-results-reset {
    background: var(--accent); color: #fff;
    border: none; border-radius: 10px;
    font-family: var(--font-body); font-size: 0.9rem; font-weight: 600;
    padding: 12px 24px; cursor: pointer;
    transition: all 0.3s;
}
.pl-no-results-reset:hover { background: var(--accent-dark); transform: translateY(-2px); }


/* ─────────────────────────────────────────
   EMPTY STATE
───────────────────────────────────────── */
.pl-empty-state {
    display: flex; flex-direction: column;
    align-items: center; gap: 18px;
    text-align: center; padding: 100px 20px;
}
.pl-empty-icon {
    width: 96px; height: 96px; border-radius: 50%;
    background: linear-gradient(135deg, rgba(200,136,42,0.1), rgba(200,136,42,0.02));
    border: 2px dashed rgba(200,136,42,0.25);
    display: flex; align-items: center; justify-content: center;
    font-size: 2.5rem; color: var(--accent);
}
.pl-empty-state h3 {
    font-family: var(--font-display);
    font-size: 1.8rem; font-weight: 600; color: var(--text); margin: 0;
}
.pl-empty-state p { font-size: 1rem; color: var(--text-muted); max-width: 400px; }


/* ─────────────────────────────────────────
   PAGINATION
───────────────────────────────────────── */
.pl-pagination-wrap { padding-top: 48px; display: flex; justify-content: center; }

.pl-pagination {
    display: flex; align-items: center; gap: 6px;
    list-style: none; margin: 0; padding: 0;
}
.pl-page-btn {
    display: inline-flex; align-items: center; justify-content: center;
    min-width: 42px; height: 42px;
    background: var(--surface); border: 1px solid var(--border);
    border-radius: 10px; color: var(--text);
    font-family: var(--font-body); font-size: 0.88rem; font-weight: 600;
    text-decoration: none; padding: 0 10px;
    transition: all 0.25s;
}
.pl-page-btn:hover {
    border-color: var(--accent); color: var(--accent);
    background: rgba(200,136,42,0.05); opacity: 1;
}
.pl-page-btn--active {
    background: var(--accent) !important;
    border-color: var(--accent) !important;
    color: #fff !important;
    box-shadow: 0 4px 14px rgba(200,136,42,0.35);
}
.pl-page-btn--disabled {
    opacity: 0.35; cursor: not-allowed; pointer-events: none;
}


/* ─────────────────────────────────────────
   RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 768px) {
    .pl-hero { padding: 80px 0 60px; }
    .pl-filter-bar { flex-direction: column; align-items: stretch; }
    .pl-search-wrap { flex: unset; }
    .pl-grid { grid-template-columns: 1fr 1fr; }
    .pl-modal-footer { flex-direction: column; align-items: flex-start; }
}

@media (max-width: 500px) {
    .pl-grid { grid-template-columns: 1fr; }
}


/* ╔══════════════════════════════════════════════════════════╗
   ║  CONTACT PAGE — ADD BELOW about_page_addon.css           ║
   ║  All tokens inherited from theme.css                     ║
   ╚══════════════════════════════════════════════════════════╝ */


/* ─────────────────────────────────────────
   CONTACT · HERO BANNER
───────────────────────────────────────── */
.ct-hero {
    position: relative;
    background: var(--brand-dark) !important;
    color: #fff;
    padding: 90px 24px 80px;
    overflow: hidden;
    text-align: center;
}

.ct-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(200,136,42,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(200,136,42,.05) 1px, transparent 1px);
    background-size: 52px 52px;
    -webkit-mask-image: radial-gradient(ellipse 80% 100% at center, black 30%, transparent 100%);
    mask-image: radial-gradient(ellipse 80% 100% at center, black 30%, transparent 100%);
    pointer-events: none;
}

.ct-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 80% at 75% 30%, rgba(200,136,42,.12), transparent 65%),
        radial-gradient(ellipse 45% 60% at 15% 70%, rgba(200,136,42,.07), transparent 60%);
    pointer-events: none;
}

.ct-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 720px;
    margin: 0 auto;
}

.ct-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(200,136,42,.1);
    border: 1px solid rgba(200,136,42,.28);
    color: var(--accent-light) !important;
    font-family: var(--font-body);
    font-size: .73rem;
    font-weight: 600;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 6px 18px;
    border-radius: 100px;
    margin-bottom: 24px;
    opacity: 0;
    animation: fadeUp .7s cubic-bezier(.22,1,.36,1) .1s forwards;
    transition: none !important;
}

.ct-hero-eyebrow-dot {
    width: 5px; height: 5px;
    background: var(--accent);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.ct-hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.4rem, 5vw, 4rem);
    font-weight: 300;
    line-height: 1.1;
    letter-spacing: -.02em;
    color: #ffffff !important;
    margin: 0 0 20px;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .3s forwards;
    transition: none !important;
}

.ct-hero-title em {
    font-style: italic;
    color: var(--accent-light) !important;
}

.ct-hero-lead {
    font-size: 1rem;
    font-weight: 300;
    line-height: 1.8;
    color: rgba(255,255,255,.62) !important;
    max-width: 560px;
    margin: 0 auto;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .5s forwards;
    transition: none !important;
}


/* ─────────────────────────────────────────
   CONTACT · PAGE WRAPPER
───────────────────────────────────────── */
.ct-page {
    background: var(--bg);
    padding: 80px 24px 100px;
}

.ct-page-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 420px 1fr;
    gap: 48px;
    align-items: start;
}


/* ─────────────────────────────────────────
   CONTACT · INFO PANEL (left column)
───────────────────────────────────────── */
.ct-info-panel {
    display: flex;
    flex-direction: column;
    gap: 24px;
}

/* ── Main info card ── */
.ct-info-card {
    background: var(--brand-dark);
    border-radius: var(--radius-md);
    padding: 40px 36px;
    color: #fff;
    position: relative;
    overflow: hidden;
}

.ct-info-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light), transparent);
}

.ct-info-card::after {
    content: '';
    position: absolute;
    bottom: -60px; right: -60px;
    width: 200px; height: 200px;
    background: radial-gradient(circle, rgba(200,136,42,.12), transparent 70%);
    pointer-events: none;
}

.ct-info-heading {
    font-family: var(--font-display);
    font-size: 1.5rem;
    font-weight: 600;
    color: #fff !important;
    margin: 0 0 28px;
    position: relative; z-index: 1;
}

/* Individual contact rows */
.ct-contact-row {
    display: flex;
    align-items: flex-start;
    gap: 16px;
    margin-bottom: 22px;
    position: relative; z-index: 1;
}

.ct-contact-icon {
    width: 40px; height: 40px;
    border-radius: 10px;
    background: rgba(200,136,42,.15);
    border: 1px solid rgba(200,136,42,.25);
    display: flex; align-items: center; justify-content: center;
    font-size: .9rem;
    color: var(--accent-light);
    flex-shrink: 0;
    margin-top: 2px;
}

.ct-contact-label {
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.4);
    display: block;
    margin-bottom: 3px;
}

.ct-contact-value {
    font-size: .93rem;
    color: rgba(255,255,255,.85) !important;
    text-decoration: none !important;
    line-height: 1.5;
    transition: color var(--transition);
}

.ct-contact-value:hover {
    color: var(--accent-light) !important;
}

.ct-info-divider {
    border: none;
    border-top: 1px solid rgba(255,255,255,.1);
    margin: 24px 0;
    position: relative; z-index: 1;
}

/* ── Hours card ── */
.ct-hours-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 28px 30px;
}

.ct-hours-heading {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 20px;
    display: flex;
    align-items: center;
    gap: 10px;
}

.ct-hours-heading i { color: var(--accent); font-size: 1rem; }

.ct-hours-row {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 12px 0;
    border-bottom: 1px solid var(--border);
}

.ct-hours-row:last-child { border-bottom: none; padding-bottom: 0; }
.ct-hours-row:first-of-type { padding-top: 0; }

.ct-hours-icon {
    width: 34px; height: 34px;
    border-radius: 8px;
    background: linear-gradient(135deg, rgba(200,136,42,.1), rgba(200,136,42,.03));
    border: 1px solid rgba(200,136,42,.18);
    display: flex; align-items: center; justify-content: center;
    font-size: .8rem;
    color: var(--accent);
    flex-shrink: 0;
}

.ct-hours-day {
    font-size: .88rem;
    font-weight: 600;
    color: var(--text);
    display: block;
}

.ct-hours-time {
    font-size: .82rem;
    color: var(--text-muted);
}

/* ── Social card ── */
.ct-social-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 24px 30px;
}

.ct-social-heading {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 18px;
}

.ct-social-links {
    display: flex;
    flex-wrap: wrap;
    gap: 10px;
}

.ct-social-btn {
    width: 40px; height: 40px;
    border-radius: 10px;
    border: 1px solid var(--border);
    background: var(--bg-alt);
    display: flex; align-items: center; justify-content: center;
    font-size: .95rem;
    color: var(--text-muted);
    text-decoration: none !important;
    transition: all var(--transition);
}

.ct-social-btn:hover {
    border-color: var(--accent);
    background: var(--accent);
    color: #fff !important;
    transform: translateY(-3px);
    box-shadow: 0 6px 20px rgba(200,136,42,.28);
}


/* ─────────────────────────────────────────
   CONTACT · FORM PANEL (right column)
───────────────────────────────────────── */
.ct-form-panel {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-lg);
    padding: 48px 44px;
    position: relative;
    overflow: hidden;
}

.ct-form-panel::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light), transparent);
}

.ct-form-heading {
    font-family: var(--font-display);
    font-size: 1.8rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 8px;
}

.ct-form-sub {
    font-size: .93rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0 0 36px;
}

/* Form field groups */
.ct-field-group {
    margin-bottom: 20px;
}

.ct-field-label {
    display: block;
    font-size: .75rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--text-muted);
    margin-bottom: 7px;
}

/* Override base input styles with contact-specific polish */
.ct-form-panel .form-control,
.ct-form-panel .form-select,
.ct-form-panel select,
.ct-form-panel input[type="text"],
.ct-form-panel input[type="email"],
.ct-form-panel input[type="tel"],
.ct-form-panel textarea {
    width: 100%;
    background: var(--bg-alt) !important;
    border: 1.5px solid var(--border) !important;
    border-radius: var(--radius-sm) !important;
    padding: 13px 16px !important;
    font-family: var(--font-body) !important;
    font-size: .93rem !important;
    color: var(--text) !important;
    transition: border-color var(--transition), box-shadow var(--transition) !important;
    outline: none;
    -webkit-appearance: none;
    appearance: none;
}

.ct-form-panel .form-control:focus,
.ct-form-panel .form-select:focus,
.ct-form-panel select:focus,
.ct-form-panel input[type="text"]:focus,
.ct-form-panel input[type="email"]:focus,
.ct-form-panel input[type="tel"]:focus,
.ct-form-panel textarea:focus {
    border-color: var(--accent) !important;
    box-shadow: 0 0 0 3px rgba(200,136,42,.1) !important;
    background: var(--surface) !important;
}

.ct-form-panel textarea {
    resize: vertical;
    min-height: 130px;
}

.ct-form-panel .form-floating label {
    color: var(--text-muted) !important;
    font-size: .9rem !important;
}

/* Two-col field row */
.ct-field-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
}

/* Error text */
.ct-field-error {
    font-size: .78rem;
    color: #ef4444;
    margin-top: 5px;
    display: block;
}

/* Django messages */
.ct-alert {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    padding: 14px 16px;
    border-radius: var(--radius-sm);
    font-size: .88rem;
    margin-bottom: 8px;
    border: 1px solid var(--border);
    background: var(--surface-2);
    color: var(--text);
}

.ct-alert.success { border-left: 3px solid #22c55e; }
.ct-alert.error,
.ct-alert.danger  { border-left: 3px solid #ef4444; }
.ct-alert.warning { border-left: 3px solid #f59e0b; }

.ct-alert-icon { font-size: 1rem; margin-top: 1px; flex-shrink: 0; }
.ct-alert.success .ct-alert-icon { color: #22c55e; }
.ct-alert.error   .ct-alert-icon,
.ct-alert.danger  .ct-alert-icon { color: #ef4444; }
.ct-alert.warning .ct-alert-icon { color: #f59e0b; }

.ct-alert-close {
    margin-left: auto;
    background: none; border: none;
    font-size: 1rem; cursor: pointer;
    color: var(--text-muted);
    padding: 0; line-height: 1;
    flex-shrink: 0;
}

/* Submit button — extends btn-hero-primary from theme */
.ct-submit-btn {
    width: 100%;
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    background: var(--accent);
    color: #fff;
    font-family: var(--font-body);
    font-size: .95rem;
    font-weight: 600;
    padding: 16px 32px;
    border: 2px solid var(--accent);
    border-radius: var(--radius-sm);
    cursor: pointer;
    transition: all var(--transition);
    margin-top: 8px;
}

.ct-submit-btn:hover {
    background: transparent;
    color: var(--accent);
    transform: translateY(-3px);
    box-shadow: 0 10px 32px rgba(200,136,42,.28);
}

.ct-submit-btn svg {
    transition: transform var(--transition);
}

.ct-submit-btn:hover svg {
    transform: translateX(5px);
}


/* ─────────────────────────────────────────
   CONTACT · MAP SECTION
───────────────────────────────────────── */
.ct-map-section {
    background: var(--bg-alt);
    padding: 0 24px 80px;
}

.ct-map-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.ct-map-header {
    text-align: center;
    padding: 60px 0 36px;
}

.ct-map-header h2 {
    font-family: var(--font-display);
    font-size: clamp(1.6rem, 3vw, 2.4rem);
    font-weight: 400;
    color: var(--text);
    margin: 12px 0 0;
}

.ct-map-wrap {
    border-radius: var(--radius-md);
    overflow: hidden;
    box-shadow: var(--shadow-lg);
    border: 1px solid var(--border);
    height: 360px;
}

.ct-map-wrap iframe {
    width: 100%;
    height: 100%;
    border: 0;
    display: block;
}


/* ─────────────────────────────────────────
   CONTACT · SCROLL REVEAL
───────────────────────────────────────── */
.ct-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .65s cubic-bezier(.22,1,.36,1),
                transform .65s cubic-bezier(.22,1,.36,1);
}
.ct-reveal.visible { opacity: 1; transform: none; }
.ct-reveal-d1 { transition-delay: .08s; }
.ct-reveal-d2 { transition-delay: .16s; }
.ct-reveal-d3 { transition-delay: .24s; }


/* ─────────────────────────────────────────
   CONTACT · RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 1024px) {
    .ct-page-inner {
        grid-template-columns: 1fr;
        max-width: 720px;
    }
}

@media (max-width: 640px) {
    .ct-hero          { padding: 72px 20px 60px; }
    .ct-page          { padding: 48px 16px 72px; }
    .ct-form-panel    { padding: 32px 24px; }
    .ct-info-card     { padding: 32px 24px; }
    .ct-field-row     { grid-template-columns: 1fr; }
    .ct-map-wrap      { height: 260px; }
    .ct-map-section   { padding: 0 16px 60px; }
}



/* ╔══════════════════════════════════════════════════════════╗
   ║  SERVICES PAGE — ADD BELOW contact_page_addon.css        ║
   ║  All tokens inherited from theme.css                     ║
   ╚══════════════════════════════════════════════════════════╝ */


/* ─────────────────────────────────────────
   SERVICES · HERO
───────────────────────────────────────── */
.sv-hero {
    position: relative;
    background: var(--brand-dark) !important;
    color: #fff;
    padding: 110px 24px 100px;
    overflow: hidden;
    text-align: center;
}

/* Diagonal line grid */
.sv-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(200,136,42,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(200,136,42,.05) 1px, transparent 1px);
    background-size: 52px 52px;
    mask-image: radial-gradient(ellipse 90% 100% at center, black 20%, transparent 100%);
    -webkit-mask-image: radial-gradient(ellipse 90% 100% at center, black 20%, transparent 100%);
    pointer-events: none;
}

/* Dual gold orbs */
.sv-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 55% 80% at 80% 20%, rgba(200,136,42,.14), transparent 65%),
        radial-gradient(ellipse 40% 60% at 10% 80%, rgba(200,136,42,.08), transparent 60%);
    pointer-events: none;
}

.sv-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 780px;
    margin: 0 auto;
}

.sv-hero-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(200,136,42,.1);
    border: 1px solid rgba(200,136,42,.28);
    color: var(--accent-light) !important;
    font-family: var(--font-body);
    font-size: .73rem;
    font-weight: 600;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 6px 20px;
    border-radius: 100px;
    margin-bottom: 26px;
    opacity: 0;
    animation: fadeUp .7s cubic-bezier(.22,1,.36,1) .1s forwards;
    transition: none !important;
}

.sv-hero-eyebrow-dot {
    width: 5px; height: 5px;
    background: var(--accent);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.sv-hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 5.5vw, 4.4rem);
    font-weight: 300;
    line-height: 1.08;
    letter-spacing: -.02em;
    color: #ffffff !important;
    margin: 0 0 22px;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .3s forwards;
    transition: none !important;
}

.sv-hero-title em {
    font-style: italic;
    color: var(--accent-light) !important;
}

.sv-hero-lead {
    font-size: 1.03rem;
    font-weight: 300;
    line-height: 1.8;
    color: rgba(255,255,255,.62) !important;
    max-width: 600px;
    margin: 0 auto 0;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .5s forwards;
    transition: none !important;
}

/* Stat strip inside hero */
.sv-hero-stats {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 0;
    flex-wrap: wrap;
    margin-top: 56px;
    padding-top: 48px;
    border-top: 1px solid rgba(255,255,255,.08);
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .7s forwards;
    transition: none !important;
}

.sv-stat-item {
    padding: 0 36px;
    text-align: center;
}

.sv-stat-num {
    font-family: var(--font-display);
    font-size: 2.4rem;
    font-weight: 600;
    color: var(--accent-light) !important;
    line-height: 1;
    display: block;
}

.sv-stat-label {
    font-size: .72rem;
    font-weight: 500;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(255,255,255,.38) !important;
    margin-top: 6px;
    display: block;
}

.sv-stat-divider {
    width: 1px;
    height: 36px;
    background: rgba(255,255,255,.12);
}


/* ─────────────────────────────────────────
   SERVICES · MAIN GRID SECTION
───────────────────────────────────────── */
.sv-grid-section {
    background: var(--bg);
    padding: 96px 24px 80px;
}

.sv-grid-inner {
    max-width: 1200px;
    margin: 0 auto;
}

/* Section header */
.sv-section-header {
    max-width: 580px;
    margin-bottom: 64px;
}

.sv-section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-body);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 14px;
}
.sv-section-label::before,
.sv-section-label::after {
    content: '';
    display: block;
    width: 20px; height: 1px;
    background: var(--accent);
    opacity: .5;
}

.sv-section-title {
    font-family: var(--font-display);
    font-size: clamp(2rem, 3.5vw, 3rem);
    font-weight: 400;
    line-height: 1.15;
    color: var(--text);
    margin: 0 0 14px;
}

.sv-section-desc {
    font-size: .95rem;
    color: var(--text-muted);
    line-height: 1.8;
}


/* ─────────────────────────────────────────
   SERVICES · CARDS
───────────────────────────────────────── */
.sv-cards-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
    gap: 24px;
}

.sv-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 40px 32px 36px;
    position: relative;
    overflow: hidden;
    display: flex;
    flex-direction: column;
    transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
    cursor: default;
}

/* Animated gold top bar */
.sv-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform .4s cubic-bezier(.22,1,.36,1);
}

/* Subtle glow blob */
.sv-card::after {
    content: '';
    position: absolute;
    width: 180px; height: 180px;
    background: radial-gradient(circle, rgba(200,136,42,.07), transparent 70%);
    top: -80px; right: -60px;
    transition: transform .5s var(--transition), opacity .5s;
    opacity: 0;
    pointer-events: none;
}

.sv-card:hover {
    transform: translateY(-8px);
    box-shadow: var(--shadow-lg);
    border-color: rgba(200,136,42,.2);
}

.sv-card:hover::before { transform: scaleX(1); }
.sv-card:hover::after  { opacity: 1; transform: scale(1.4); }

/* Index number watermark */
.sv-card-index {
    position: absolute;
    top: 16px; right: 22px;
    font-family: var(--font-display);
    font-size: 2.8rem;
    font-weight: 300;
    color: var(--accent);
    opacity: .07;
    line-height: 1;
    pointer-events: none;
    transition: opacity var(--transition);
}
.sv-card:hover .sv-card-index { opacity: .14; }

/* Icon */
.sv-card-icon-wrap {
    width: 58px; height: 58px;
    border-radius: var(--radius-sm);
    background: linear-gradient(135deg, rgba(200,136,42,.12), rgba(200,136,42,.03));
    border: 1px solid rgba(200,136,42,.2);
    display: flex; align-items: center; justify-content: center;
    font-size: 1.45rem;
    color: var(--accent);
    margin-bottom: 24px;
    transition: background var(--transition), border-color var(--transition), color var(--transition), transform var(--transition);
    flex-shrink: 0;
}

.sv-card:hover .sv-card-icon-wrap {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    transform: rotate(-6deg) scale(1.08);
}

/* Title & description */
.sv-card-title {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 12px;
    line-height: 1.3;
}

.sv-card-text {
    font-size: .9rem;
    color: var(--text-muted);
    line-height: 1.75;
    margin: 0;
    flex: 1;
}

/* Bottom rule accent */
.sv-card-rule {
    width: 28px; height: 2px;
    background: var(--accent);
    border-radius: 2px;
    margin-top: 24px;
    opacity: .3;
    transition: width var(--transition), opacity var(--transition);
}
.sv-card:hover .sv-card-rule { width: 48px; opacity: .7; }

/* Empty state */
.sv-empty {
    grid-column: 1 / -1;
    text-align: center;
    padding: 64px 24px;
    color: var(--text-muted);
    font-size: .95rem;
}
.sv-empty i {
    display: block;
    font-size: 2.4rem;
    color: var(--accent);
    opacity: .3;
    margin-bottom: 16px;
}


/* ─────────────────────────────────────────
   SERVICES · PROCESS STRIP
   "How we work" — 4 horizontal steps
───────────────────────────────────────── */
.sv-process {
    background: var(--bg-alt);
    padding: 88px 24px;
    overflow: hidden;
}

.sv-process-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.sv-process-header {
    text-align: center;
    max-width: 560px;
    margin: 0 auto 64px;
}

.sv-process-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 32px;
    position: relative;
}

/* Connecting dashed line */
.sv-process-grid::before {
    content: '';
    position: absolute;
    top: 28px;
    left: calc(12.5% + 28px);
    right: calc(12.5% + 28px);
    height: 1px;
    background: repeating-linear-gradient(
        90deg,
        var(--accent) 0, var(--accent) 6px,
        transparent 6px, transparent 14px
    );
    opacity: .25;
    pointer-events: none;
}

.sv-process-step {
    text-align: center;
    position: relative;
}

.sv-process-num {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: var(--surface);
    border: 2px solid var(--border);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 24px;
    font-family: var(--font-display);
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--accent);
    position: relative; z-index: 1;
    transition: background var(--transition), border-color var(--transition), color var(--transition), box-shadow var(--transition);
}

.sv-process-step:hover .sv-process-num {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
    box-shadow: 0 8px 24px rgba(200,136,42,.3);
}

.sv-process-step-title {
    font-family: var(--font-display);
    font-size: 1.1rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 10px;
}

.sv-process-step-text {
    font-size: .85rem;
    color: var(--text-muted);
    line-height: 1.7;
    max-width: 200px;
    margin: 0 auto;
}


/* ─────────────────────────────────────────
   SERVICES · CTA BANNER
───────────────────────────────────────── */
.sv-cta {
    position: relative;
    background: var(--brand-dark);
    padding: 96px 24px;
    text-align: center;
    overflow: hidden;
}

.sv-cta::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 70% 80% at 30% 50%, rgba(200,136,42,.13), transparent 60%),
        radial-gradient(ellipse 50% 70% at 70% 50%, rgba(200,136,42,.07), transparent 60%);
    pointer-events: none;
}

.sv-cta-inner {
    position: relative; z-index: 1;
    max-width: 640px;
    margin: 0 auto;
}

.sv-cta-inner h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 400;
    color: #fff !important;
    line-height: 1.18;
    margin: 0 0 18px;
    transition: none !important;
}

.sv-cta-inner h2 em {
    font-style: italic;
    color: var(--accent-light) !important;
}

.sv-cta-inner p {
    font-size: .97rem;
    color: rgba(255,255,255,.5) !important;
    line-height: 1.75;
    margin: 0 0 40px;
    transition: none !important;
}

/* Reuses btn-hero-primary from theme */
.sv-cta .btn-hero-primary svg {
    transition: transform var(--transition);
}
.sv-cta .btn-hero-primary:hover svg {
    transform: translateX(5px);
}


/* ─────────────────────────────────────────
   SERVICES · SCROLL REVEAL
───────────────────────────────────────── */
.sv-reveal {
    opacity: 0;
    transform: translateY(24px);
    transition: opacity .65s cubic-bezier(.22,1,.36,1),
                transform .65s cubic-bezier(.22,1,.36,1);
}
.sv-reveal.visible { opacity: 1; transform: none; }
.sv-reveal-d1 { transition-delay: .07s; }
.sv-reveal-d2 { transition-delay: .14s; }
.sv-reveal-d3 { transition-delay: .21s; }
.sv-reveal-d4 { transition-delay: .28s; }
.sv-reveal-d5 { transition-delay: .35s; }
.sv-reveal-d6 { transition-delay: .42s; }


/* ─────────────────────────────────────────
   SERVICES · RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 900px) {
    .sv-process-grid         { grid-template-columns: 1fr 1fr; }
    .sv-process-grid::before { display: none; }
}

@media (max-width: 640px) {
    .sv-hero         { padding: 80px 20px 72px; }
    .sv-hero-stats   { gap: 0; }
    .sv-stat-item    { padding: 0 20px; }
    .sv-stat-divider { display: none; }
    .sv-grid-section { padding: 64px 16px; }
    .sv-process      { padding: 64px 16px; }
    .sv-cta          { padding: 72px 20px; }
    .sv-process-grid { grid-template-columns: 1fr; }
    .sv-cards-grid   { grid-template-columns: 1fr; }
}


/* ╔══════════════════════════════════════════════════════════╗
   ║  ABOUT PAGE — ADD BELOW theme.css                        ║
   ║  All tokens inherited from theme.css                     ║
   ╚══════════════════════════════════════════════════════════╝ */


/* ─────────────────────────────────────────
   ABOUT · HERO
───────────────────────────────────────── */
.ab-hero {
    position: relative;
    background: var(--brand-dark) !important;
    color: #ffffff;
    padding: 110px 24px 100px;
    overflow: hidden;
    text-align: center;
}

/* Dot-grid overlay */
.ab-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background-image:
        linear-gradient(rgba(200,136,42,.05) 1px, transparent 1px),
        linear-gradient(90deg, rgba(200,136,42,.05) 1px, transparent 1px);
    background-size: 52px 52px;
    mask-image: radial-gradient(ellipse 90% 100% at center, black 20%, transparent 100%);
    -webkit-mask-image: radial-gradient(ellipse 90% 100% at center, black 20%, transparent 100%);
    pointer-events: none;
}

/* Dual gold orbs */
.ab-hero::after {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(ellipse 60% 75% at 80% 30%, rgba(200,136,42,.14), transparent 65%),
        radial-gradient(ellipse 45% 60% at 12% 75%, rgba(200,136,42,.08), transparent 60%);
    pointer-events: none;
}

.ab-hero-inner {
    position: relative;
    z-index: 2;
    max-width: 820px;
    margin: 0 auto;
}

/* Eyebrow pill */
.ab-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    background: rgba(200,136,42,.1);
    border: 1px solid rgba(200,136,42,.28);
    color: var(--accent-light) !important;
    font-family: var(--font-body);
    font-size: .73rem;
    font-weight: 600;
    letter-spacing: .15em;
    text-transform: uppercase;
    padding: 6px 20px;
    border-radius: 100px;
    margin-bottom: 26px;
    opacity: 0;
    animation: fadeUp .7s cubic-bezier(.22,1,.36,1) .1s forwards;
    transition: none !important;
}

.ab-eyebrow-dot {
    width: 5px; height: 5px;
    background: var(--accent);
    border-radius: 50%;
    animation: pulse 2s infinite;
}

.ab-hero-title {
    font-family: var(--font-display);
    font-size: clamp(2.6rem, 5.5vw, 4.4rem);
    font-weight: 300;
    line-height: 1.08;
    letter-spacing: -.02em;
    color: #ffffff !important;
    margin: 0 0 22px;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .3s forwards;
    transition: none !important;
}

.ab-hero-title em {
    font-style: italic;
    color: var(--accent-light) !important;
}

.ab-hero-lead {
    font-size: 1.03rem;
    font-weight: 300;
    line-height: 1.8;
    color: rgba(255,255,255,.62) !important;
    max-width: 620px;
    margin: 0 auto 52px;
    opacity: 0;
    animation: fadeUp .85s cubic-bezier(.22,1,.36,1) .5s forwards;
    transition: none !important;
}

/* Scroll hint */
.ab-hero-scroll {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 14px;
    opacity: 0;
    animation: fadeUp .8s cubic-bezier(.22,1,.36,1) .75s forwards;
    transition: none !important;
}
.ab-hero-scroll span {
    display: block;
    width: 28px; height: 1px;
    background: var(--accent);
    opacity: .4;
}
.ab-hero-scroll p {
    font-size: .7rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: rgba(255,255,255,.3) !important;
    margin: 0;
    transition: none !important;
}


/* ─────────────────────────────────────────
   ABOUT · STORY SECTION
───────────────────────────────────────── */
.ab-story {
    background: var(--surface);
    padding: 96px 24px;
}

.ab-story-inner {
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: start;
}

/* ── Image column ── */
.ab-story-image-col { position: relative; }

.ab-story-image-col img {
    width: 100%;
    display: block;
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-lg);
}

.ab-image-accent {
    position: absolute;
    bottom: -18px; right: -18px;
    width: 130px; height: 130px;
    border: 1.5px solid var(--accent);
    border-radius: var(--radius-md);
    opacity: .2;
    pointer-events: none;
}

.ab-image-label {
    position: absolute;
    bottom: 20px; left: 20px;
    background: var(--brand-dark);
    color: var(--accent-light);
    font-family: var(--font-body);
    font-size: .7rem;
    font-weight: 600;
    letter-spacing: .16em;
    text-transform: uppercase;
    padding: 8px 16px;
    border-radius: var(--radius-sm);
}

/* Audience cards */
.ab-audience {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 14px;
    margin-top: 36px;
}

.ab-audience-card {
    background: var(--bg-alt);
    border: 1px solid var(--border);
    border-radius: var(--radius-sm);
    padding: 22px 20px;
    transition: border-color var(--transition), box-shadow var(--transition);
}

.ab-audience-card:hover {
    border-color: var(--accent);
    box-shadow: var(--shadow-md);
}

.ab-audience-card h6 {
    font-family: var(--font-display);
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 8px;
}

.ab-audience-card p {
    font-size: .87rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0;
}

/* ── Text column ── */
.ab-story-text { padding-top: 8px; }


/* ─────────────────────────────────────────
   ABOUT · SHARED SECTION LABEL
───────────────────────────────────────── */
.ab-section-label {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--font-body);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 20px;
}
.ab-section-label::before,
.ab-section-label::after {
    content: '';
    display: block;
    width: 20px; height: 1px;
    background: var(--accent);
    opacity: .5;
}


/* ─────────────────────────────────────────
   ABOUT · MISSION / VISION CARDS
───────────────────────────────────────── */
.ab-mv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    margin-bottom: 36px;
}

.ab-mv-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius-md);
    padding: 36px 30px;
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}

.ab-mv-card:hover {
    transform: translateY(-5px);
    box-shadow: var(--shadow-lg);
}

.ab-mv-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, var(--accent), var(--accent-light));
    transform: scaleX(0);
    transform-origin: left;
    transition: transform var(--transition);
}
.ab-mv-card:hover::before { transform: scaleX(1); }

.ab-mv-card-num {
    font-family: var(--font-display);
    font-size: 3rem;
    font-weight: 300;
    color: var(--accent);
    opacity: .1;
    position: absolute;
    top: 12px; right: 18px;
    line-height: 1;
    pointer-events: none;
}

.ab-mv-card h4 {
    font-family: var(--font-display);
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--text);
    margin: 0 0 12px;
}

.ab-mv-card p {
    font-size: .9rem;
    color: var(--text-muted);
    line-height: 1.75;
    margin: 0;
}


/* ─────────────────────────────────────────
   ABOUT · VALUES SECTION
───────────────────────────────────────── */
.ab-values-section {
    background: var(--bg-alt);
    padding: 88px 24px;
}

.ab-values-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.ab-values-header {
    text-align: center;
    max-width: 540px;
    margin: 0 auto 56px;
}

.ab-values-header h2 {
    font-family: var(--font-display);
    font-size: clamp(1.8rem, 3vw, 2.6rem);
    font-weight: 400;
    color: var(--text);
    margin: 0 0 12px;
    line-height: 1.2;
}

.ab-values-header p {
    font-size: .95rem;
    color: var(--text-muted);
    line-height: 1.8;
    margin: 0;
}

.ab-values-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

.ab-value-card {
    background: var(--brand-dark);
    border-radius: var(--radius-md);
    padding: 40px 28px;
    text-align: center;
    position: relative;
    overflow: hidden;
    transition: transform var(--transition), box-shadow var(--transition);
}

.ab-value-card:hover {
    transform: translateY(-7px);
    box-shadow: var(--shadow-lg);
}

.ab-value-card::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.ab-value-icon {
    width: 56px; height: 56px;
    border-radius: 50%;
    background: rgba(200,136,42,.14);
    border: 1px solid rgba(200,136,42,.28);
    display: flex; align-items: center; justify-content: center;
    margin: 0 auto 18px;
    font-size: 1.3rem;
    color: var(--accent);
    transition: background var(--transition), border-color var(--transition), color var(--transition);
}

.ab-value-card:hover .ab-value-icon {
    background: var(--accent);
    border-color: var(--accent);
    color: #fff;
}

.ab-value-card h5 {
    font-family: var(--font-display);
    font-size: 1.15rem;
    font-weight: 600;
    color: #fff !important;
    margin: 0 0 10px;
    transition: none !important;
}

.ab-value-card p {
    font-size: .85rem;
    color: rgba(255,255,255,.5) !important;
    line-height: 1.7;
    margin: 0;
    transition: none !important;
}


/* ─────────────────────────────────────────
   ABOUT · WHY CHOOSE US
───────────────────────────────────────── */
.ab-why {
    background: var(--surface);
    padding: 96px 24px;
}

.ab-why-inner {
    max-width: 1200px;
    margin: 0 auto;
}

.ab-why-layout {
    display: grid;
    grid-template-columns: 360px 1fr;
    gap: 80px;
    align-items: start;
}

.ab-why-sticky {
    position: sticky;
    top: 88px;
}

.ab-why-sticky h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 3vw, 2.8rem);
    font-weight: 400;
    color: var(--text);
    line-height: 1.15;
    margin: 0 0 18px;
}

.ab-why-sticky p {
    font-size: .93rem;
    color: var(--text-muted);
    line-height: 1.8;
}

.ab-why-items { display: flex; flex-direction: column; }

.ab-why-item {
    display: grid;
    grid-template-columns: 52px 1fr;
    gap: 20px;
    align-items: start;
    padding: 26px 0;
    border-bottom: 1px solid var(--border);
    transition: background var(--transition);
}
.ab-why-item:first-child { border-top: 1px solid var(--border); }

.ab-why-num {
    font-family: var(--font-display);
    font-size: 1.9rem;
    font-weight: 300;
    color: var(--accent);
    opacity: .4;
    line-height: 1;
    padding-top: 3px;
    transition: opacity var(--transition);
}
.ab-why-item:hover .ab-why-num { opacity: 1; }

.ab-why-content strong {
    display: block;
    font-size: .95rem;
    font-weight: 600;
    color: var(--text);
    margin-bottom: 5px;
}

.ab-why-content p {
    font-size: .875rem;
    color: var(--text-muted);
    line-height: 1.7;
    margin: 0;
}

.ab-why-item-icon {
    font-size: .82rem;
    color: var(--accent);
    margin-right: 6px;
}


/* ─────────────────────────────────────────
   ABOUT · CTA
───────────────────────────────────────── */
.ab-cta {
    position: relative;
    background: var(--brand-dark);
    padding: 96px 24px;
    text-align: center;
    overflow: hidden;
}

.ab-cta::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(ellipse 70% 80% at 30% 50%, rgba(200,136,42,.12), transparent 60%),
        radial-gradient(ellipse 50% 70% at 70% 50%, rgba(200,136,42,.07), transparent 60%);
    pointer-events: none;
}

.ab-cta-inner {
    position: relative; z-index: 1;
    max-width: 620px;
    margin: 0 auto;
}

.ab-cta-inner h2 {
    font-family: var(--font-display);
    font-size: clamp(2rem, 4vw, 3.2rem);
    font-weight: 400;
    color: #fff !important;
    line-height: 1.18;
    margin: 0 0 18px;
    transition: none !important;
}

.ab-cta-inner h2 em {
    font-style: italic;
    color: var(--accent-light) !important;
}

.ab-cta-inner p {
    font-size: .97rem;
    color: rgba(255,255,255,.5) !important;
    line-height: 1.75;
    margin: 0 0 40px;
    transition: none !important;
}

.ab-cta .btn-hero-primary svg { transition: transform var(--transition); }
.ab-cta .btn-hero-primary:hover svg { transform: translateX(5px); }


/* ─────────────────────────────────────────
   ABOUT · SCROLL REVEAL
───────────────────────────────────────── */
.ab-reveal {
    opacity: 0;
    transform: translateY(26px);
    transition: opacity .7s cubic-bezier(.22,1,.36,1),
                transform .7s cubic-bezier(.22,1,.36,1);
}
.ab-reveal.visible { opacity: 1; transform: none; }
.ab-reveal-d1 { transition-delay: .08s; }
.ab-reveal-d2 { transition-delay: .16s; }
.ab-reveal-d3 { transition-delay: .24s; }
.ab-reveal-d4 { transition-delay: .32s; }


/* ─────────────────────────────────────────
   ABOUT · RESPONSIVE
───────────────────────────────────────── */
@media (max-width: 992px) {
    .ab-story-inner  { grid-template-columns: 1fr; gap: 48px; }
    .ab-why-layout   { grid-template-columns: 1fr; gap: 40px; }
    .ab-why-sticky   { position: static; }
    .ab-mv-grid      { grid-template-columns: 1fr; }
    .ab-image-accent { display: none; }
}

@media (max-width: 768px) {
    .ab-hero          { padding: 84px 20px 72px; }
    .ab-story         { padding: 72px 20px; }
    .ab-values-section{ padding: 64px 20px; }
    .ab-why           { padding: 72px 20px; }
    .ab-cta           { padding: 72px 20px; }
    .ab-values-grid   { grid-template-columns: 1fr 1fr; }
    .ab-audience      { grid-template-columns: 1fr; }
}

@media (max-width: 480px) {
    .ab-values-grid { grid-template-columns: 1fr; }
}