/* ─────────────────────────────────────────────────────────
   Boya Linen — global stylesheet
   Replaces the legacy static/style.css
   ───────────────────────────────────────────────────────── */

/* Dev-mode email-verification banner (shown when SMTP not configured) */
.dev-code-banner {
    background: linear-gradient(180deg, #fff8e6 0%, #fff2cc 100%);
    border: 1px dashed #c8a96e;
    border-left: 4px solid #c8a96e;
    padding: 1rem 1.2rem;
    margin: 1.2rem 0 1.5rem;
    text-align: center;
    border-radius: 2px;
}
.dev-code-banner .dev-code-label {
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #8a6d2e;
    font-weight: 600;
    margin: 0 0 .35rem;
}
.dev-code-banner .dev-code-hint {
    font-size: .85rem;
    color: #6b5727;
    margin: 0 0 .55rem;
}
.dev-code-banner .dev-code-value {
    font-family: 'Courier New', monospace;
    font-size: 1.9rem;
    font-weight: 700;
    letter-spacing: .35em;
    color: #0a1628;
    padding: .4rem 0 .5rem;
    padding-left: .35em; /* compensates letter-spacing on the right */
    margin: 0;
    user-select: all;
}
.dev-code-banner .dev-code-foot {
    font-size: .72rem;
    color: #8a6d2e;
    margin: .35rem 0 0;
}
.dev-code-banner code {
    background: rgba(10,22,40,0.07);
    padding: 1px 5px;
    border-radius: 2px;
    font-size: .75rem;
}


:root {
    --navy: #0a1628;
    --deep: #0d1f3c;
    --blue: #1a3a6b;
    --accent: #c8a96e;
    --accent-light: #e8cfa0;
    --white: #f8f5f0;
    --mist: #d6cfc4;
    --text: #2c2c2c;
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
    font-family: 'DM Sans', sans-serif;
    background: var(--white);
    color: var(--text);
    overflow-x: hidden;
}

/* ── NAV ── */
nav {
    position: fixed; top: 0; left: 0; right: 0; z-index: 100;
    display: flex; justify-content: space-between; align-items: center;
    padding: 1.4rem 5vw;
    background: rgba(10, 22, 40, 0.55);
    backdrop-filter: blur(10px);
    -webkit-backdrop-filter: blur(10px);
    border-bottom: 1px solid rgba(200,169,110,0.18);
    transition: background .35s ease;
}
/* After scroll: stronger fill for legibility on light content */
nav.scrolled {
    background: rgba(10, 22, 40, 0.92);
}

.logo {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.45rem; font-weight: 600;
    color: var(--accent-light);
    letter-spacing: 0.04em;
    text-decoration: none;
}
.logo span { color: var(--accent); }

nav ul {
    list-style: none; display: flex; gap: 1.8rem;
    align-items: center;
}
nav ul a {
    text-decoration: none;
    font-size: 0.78rem; font-weight: 500; letter-spacing: 0.14em;
    text-transform: uppercase;
    color: var(--mist);
    transition: color .25s;
    position: relative;
    padding-bottom: 4px;
}
nav ul a:hover { color: var(--accent); }
nav ul a.active { color: var(--white); }
nav ul a.active::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -2px;
    height: 1px; background: var(--accent);
}

.nav-cta {
    background: var(--accent);
    color: var(--navy) !important;
    padding: .55rem 1.4rem;
    border-radius: 2px;
}
.nav-cta:hover { background: var(--accent-light); color: var(--navy) !important; }

/* ── NAV ACCOUNT (Connexion pill button) ── */
.nav-account { margin-left: .6rem; }
.nav-account-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .45rem;
    height: 36px;
    padding: 0 1rem 0 .85rem !important;
    border: 1px solid rgba(200,169,110,0.50);
    border-radius: 999px;
    color: var(--accent-light) !important;
    background: transparent;
    font-family: 'DM Sans', sans-serif;
    font-size: .76rem !important;
    font-weight: 600 !important;
    letter-spacing: .12em !important;
    text-transform: uppercase;
    transition: color .25s, border-color .25s, background .25s, transform .25s, box-shadow .25s;
}
.nav-account-btn svg {
    width: 16px; height: 16px;
    display: block; flex-shrink: 0;
    stroke: currentColor;
}
.nav-account-btn span {
    line-height: 1;
}
.nav-account-btn:hover {
    color: var(--navy) !important;
    background: var(--accent);
    border-color: var(--accent);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px rgba(200,169,110,0.25);
}
.nav-account-btn.active {
    color: var(--navy) !important;
    background: var(--accent);
    border-color: var(--accent);
}
.nav-account-btn.active::after { display: none !important; }
nav ul a.nav-account-btn::after { display: none !important; }

/* Logged-in variant: navy fill with gold text to differentiate */
.nav-account-btn--logged {
    background: rgba(200,169,110,0.12);
    border-color: rgba(200,169,110,0.55);
    color: var(--accent) !important;
}
.nav-account-btn--logged:hover {
    background: var(--accent);
    color: var(--navy) !important;
}
.nav-account-btn--logged.active {
    background: var(--accent);
    color: var(--navy) !important;
}

/* ── HERO ─────────────────────────────────────────────────
   Layer stack (bottom → top):
     1. .hero-image     real photo background
     2. .hero-mask      horizontal navy gradient (readable left, natural right)
     3. .hero-glow      soft gold wash to bridge mask & brand palette
     4. .hero-top-shade subtle top darkening for the navbar area only
     5. .hero-content   text + CTAs (z-index 3)
     6. .hero-trust     feature row at bottom
   ───────────────────────────────────────────────────────── */
.hero {
    position: relative;
    /* Leave room for the gold marquee (~52px) so it's visible on first load */
    min-height: calc(100vh - 50px);
    display: flex; align-items: center;
    overflow: hidden;
    background: var(--navy);
    isolation: isolate;
}

.hero-image {
    position: absolute; inset: 0;
    /* Audit § 4.4 — WebP first (≈3% of the PNG size), PNG fallback for
       any browser that doesn't grok image-set(). Modern browsers (>97%
       of African mobile traffic) take the WebP automatically. */
    background-image: url('/static/images/hero.png');
    background-image: image-set(
        url('/static/images/hero.webp') type('image/webp'),
        url('/static/images/hero.png') type('image/png')
    );
    background-size: 102%;
    background-position: 70% 15%;
    background-repeat: no-repeat;
    z-index: 0;
}

.hero-mask {
    position: absolute; inset: 0;
    background:
        linear-gradient(
            90deg,
            rgba(10, 22, 40, 0.96) 0%,
            rgba(10, 22, 40, 0.92) 22%,
            rgba(13, 31, 60, 0.70) 42%,
            rgba(13, 31, 60, 0.30) 60%,
            rgba(13, 31, 60, 0.05) 78%,
            rgba(13, 31, 60, 0.00) 100%
        );
    z-index: 1;
}

.hero-top-shade {
    position: absolute; top: 0; left: 0; right: 0;
    height: 180px;
    background: linear-gradient(
        180deg,
        rgba(10, 22, 40, 0.55) 0%,
        rgba(10, 22, 40, 0.18) 55%,
        rgba(10, 22, 40, 0.00) 100%
    );
    z-index: 2;
    pointer-events: none;
}

.hero-glow {
    position: absolute;
    left: -10%; top: 30%;
    width: 50%; height: 60%;
    background: radial-gradient(ellipse at center,
        rgba(200,169,110,0.10) 0%,
        transparent 70%);
    z-index: 1;
    pointer-events: none;
}

.hero-content {
    position: relative; z-index: 3;
    padding: 0 5vw;
    max-width: 920px;
    animation: fadeUp .9s ease both;
}
@keyframes fadeUp {
    from { opacity: 0; transform: translateY(24px); }
    to   { opacity: 1; transform: translateY(0); }
}

.hero-eyebrow {
    display: inline-flex; align-items: center; gap: .8rem;
    font-size: .75rem; font-weight: 500; letter-spacing: .22em;
    text-transform: uppercase; color: var(--accent);
    margin-bottom: 1.6rem;
}
.hero-eyebrow::before {
    content: ''; display: block;
    width: 42px; height: 1px; background: var(--accent);
}

.hero h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 4.6vw, 4.4rem);
    font-weight: 300; line-height: 1.15;
    color: var(--white);
    margin-bottom: 1.6rem;
    text-shadow: 0 2px 24px rgba(0,0,0,0.25);
}
.hero h1 .hero-line {
    display: block;
    white-space: nowrap;
}
.hero h1 em {
    font-style: italic; color: var(--accent);
    font-weight: 400;
}

.hero-divider {
    width: 64px; height: 1px;
    background: var(--accent);
    margin: 0 0 1.8rem 0;
    opacity: .8;
}

.hero p {
    font-size: 1.02rem; line-height: 1.75;
    color: var(--mist);
    max-width: 480px;
    margin-bottom: 2.6rem;
    text-shadow: 0 1px 12px rgba(0,0,0,0.35);
}

.hero-actions { display: flex; gap: 1.2rem; flex-wrap: wrap; }

.btn-primary {
    background: var(--accent);
    color: var(--navy);
    padding: .95rem 2.4rem;
    font-size: .82rem; font-weight: 500; letter-spacing: .14em;
    text-transform: uppercase; text-decoration: none;
    border-radius: 2px;
    transition: background .25s, transform .2s;
    display: inline-flex; align-items: center; gap: .7rem;
}
.btn-primary:hover { background: var(--accent-light); transform: translateY(-2px); }
.btn-primary::after { content: '→'; font-size: 1rem; }

.btn-outline {
    border: 1px solid rgba(232,207,160,0.55);
    color: var(--accent-light);
    padding: .95rem 2.4rem;
    font-size: .82rem; font-weight: 500; letter-spacing: .14em;
    text-transform: uppercase; text-decoration: none;
    border-radius: 2px;
    transition: border-color .25s, color .25s, background .25s;
    display: inline-block;
    background: rgba(10, 22, 40, 0.25);
}
.btn-outline:hover { border-color: var(--accent); color: var(--accent); background: rgba(10, 22, 40, 0.4); }

/* Trust strip — replaces the old numeric stat bar */
.hero-trust {
    position: absolute; bottom: 1.8rem; left: 0;
    z-index: 3;
    padding: 0 5vw;
    display: flex; gap: 2.8rem; flex-wrap: wrap;
    animation: fadeUp 1.2s .4s ease both;
}
.trust-item {
    display: flex; align-items: center; gap: .9rem;
    color: var(--mist);
}
.trust-item svg {
    width: 26px; height: 26px;
    stroke: var(--accent);
    flex-shrink: 0;
}
.trust-title {
    font-size: .85rem; color: var(--white);
    font-weight: 500; letter-spacing: .02em;
    line-height: 1.2;
    display: block;
}
.trust-sub {
    font-size: .72rem; letter-spacing: .08em;
    color: var(--mist);
    display: block;
    margin-top: .15rem;
}

/* ── MARQUEE ── */
.marquee-wrap {
    background: var(--accent);
    overflow: hidden; padding: .9rem 0;
}
.marquee-track {
    display: flex; gap: 3rem;
    white-space: nowrap;
    animation: marquee 22s linear infinite;
}
.marquee-track span {
    font-size: .78rem; font-weight: 500; letter-spacing: .14em;
    text-transform: uppercase; color: var(--navy);
    flex-shrink: 0;
}
.marquee-track span::after { content: ' ✦ '; margin-left: 3rem; }
@keyframes marquee { to { transform: translateX(-50%); } }

/* ── SERVICES ── */
.services {
    padding: 7rem 5vw;
    background: var(--white);
}

.section-header {
    display: flex; justify-content: space-between; align-items: flex-end;
    margin-bottom: 4rem;
    flex-wrap: wrap; gap: 1.5rem;
}

.section-label {
    font-size: .72rem; letter-spacing: .18em; text-transform: uppercase;
    color: var(--accent); font-weight: 500;
    margin-bottom: .8rem;
}

.section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 4vw, 3.4rem);
    font-weight: 400; line-height: 1.15;
    color: var(--navy);
}
.section-title em { font-style: italic; color: var(--blue); }

.section-desc {
    max-width: 360px; font-size: .9rem;
    line-height: 1.75; color: #555;
}

.services-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(250px, 1fr));
    gap: 1.5px;
    background: var(--mist);
}

.service-card {
    background: var(--white);
    padding: 2.8rem 2.4rem;
    transition: background .3s;
    position: relative; overflow: hidden;
}
.service-card::before {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0;
    height: 3px; background: var(--accent);
    transform: scaleX(0); transform-origin: left;
    transition: transform .35s ease;
}
.service-card:hover::before { transform: scaleX(1); }
.service-card:hover { background: #fdfaf5; }

.service-icon {
    font-size: 2.2rem; margin-bottom: 1.4rem;
    display: block;
}

.service-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.45rem; font-weight: 600;
    color: var(--navy); margin-bottom: .8rem;
}

.service-card p {
    font-size: .88rem; line-height: 1.7; color: #666;
}

.services-cta {
    margin-top: 3.5rem;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: .8rem;
}
.services-cta-hint {
    font-size: .75rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #888;
    margin: 0;
}

/* ── PROCESS ── */
.process {
    padding: 7rem 5vw;
    background: var(--navy);
    position: relative; overflow: hidden;
}
.process::before {
    content: '';
    position: absolute; top: -2px; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

.process .section-title,
.process .section-label { color: var(--accent); }
.process .section-title { color: var(--white); }
.process .section-title em { color: var(--accent-light); }

.steps {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
    gap: 2rem; margin-top: 4rem;
    counter-reset: step;
}

.step { position: relative; }
.step-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 5rem; font-weight: 300;
    color: rgba(200,169,110,0.12);
    line-height: 1;
    margin-bottom: .5rem;
}
.step h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; font-weight: 600;
    color: var(--white); margin-bottom: .6rem;
}
.step p { font-size: .85rem; line-height: 1.7; color: var(--mist); }

/* ── CTA ── */
.cta-band {
    padding: 6rem 5vw;
    background: var(--accent);
    display: flex; align-items: center;
    justify-content: space-between; flex-wrap: wrap; gap: 2rem;
}
.cta-band h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.5vw, 3rem);
    font-weight: 400; color: var(--navy);
    max-width: 560px; line-height: 1.2;
}
.btn-dark {
    background: var(--navy); color: var(--accent-light);
    padding: 1rem 2.6rem;
    font-size: .85rem; font-weight: 500; letter-spacing: .08em;
    text-transform: uppercase; text-decoration: none;
    border-radius: 2px;
    transition: background .25s;
    white-space: nowrap;
}
.btn-dark:hover { background: var(--deep); }

/* ── FOOTER ── */
footer {
    background: var(--deep);
    padding: 4rem 5vw 2rem;
    border-top: 1px solid rgba(200,169,110,0.15);
}
.footer-grid {
    display: grid;
    grid-template-columns: 2fr 1fr 1fr;
    gap: 3rem; margin-bottom: 3rem;
}
.footer-logo {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem; font-weight: 600;
    color: var(--accent-light); margin-bottom: 1rem;
}
.footer-desc { font-size: .85rem; line-height: 1.75; color: var(--mist); }

footer h5 {
    font-size: .72rem; letter-spacing: .15em; text-transform: uppercase;
    color: var(--accent); margin-bottom: 1.2rem;
}
footer ul { list-style: none; }
footer ul li { margin-bottom: .6rem; }
footer ul a {
    text-decoration: none; font-size: .87rem;
    color: var(--mist); transition: color .2s;
}
footer ul a:hover { color: var(--accent-light); }
.footer-icon {
    width: 1em; height: 1em;
    margin-right: .55em;
    vertical-align: -.15em;
    color: var(--accent);
    flex-shrink: 0;
}

.footer-bottom {
    border-top: 1px solid rgba(200,169,110,0.1);
    padding-top: 1.8rem;
    display: flex; justify-content: space-between;
    flex-wrap: wrap; gap: 1rem;
    font-size: .78rem; color: rgba(214,207,196,0.5);
}

/* ── À PROPOS ── */
.about {
    padding: 7rem 5vw;
    background: var(--white);
    position: relative;
}
.about-grid {
    display: grid;
    grid-template-columns: 1.2fr 1fr;
    gap: 5rem;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
}
.about-text .section-title {
    margin-bottom: 1.8rem;
}
.about-lead {
    font-size: 1.05rem;
    line-height: 1.75;
    color: var(--text);
    margin-bottom: 1.4rem;
}
.about-lead strong {
    color: var(--navy);
    font-weight: 600;
}
.about-body {
    font-size: .92rem;
    line-height: 1.8;
    color: #555;
    margin-bottom: 2.2rem;
}
.btn-ghost {
    display: inline-block;
    color: var(--navy);
    border-bottom: 1px solid var(--accent);
    padding: .3rem 0;
    font-size: .78rem; font-weight: 500;
    letter-spacing: .14em; text-transform: uppercase;
    text-decoration: none;
    transition: color .25s, border-color .25s;
}
.btn-ghost:hover { color: var(--accent); border-color: var(--navy); }

.about-stats {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.5px;
    background: var(--mist);
    border: 1px solid var(--mist);
}
.stat-card {
    background: var(--white);
    padding: 2.2rem 1.8rem;
    text-align: center;
}
.stat-num {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.6rem;
    font-weight: 600;
    color: var(--accent);
    line-height: 1.1;
    margin-bottom: .4rem;
}
.stat-cap {
    display: block;
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #6a6a6a;
}

/* ── ÉQUIPEMENTS ── */
.equipements {
    padding: 7rem 5vw;
    background: #f3ede2;
    position: relative;
}
.equipement-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin-top: 1rem;
}
.equipement-card {
    background: var(--white);
    padding: 2.5rem 2rem 2.2rem;
    border: 1px solid rgba(200,169,110,0.25);
    position: relative;
    transition: transform .3s, box-shadow .3s, border-color .3s;
}
.equipement-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 18px 40px rgba(10,22,40,0.08);
    border-color: var(--accent);
}
.equipement-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1rem;
    font-weight: 500;
    color: var(--accent);
    letter-spacing: .2em;
    display: block;
    margin-bottom: 1.4rem;
}
.equipement-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--navy);
    line-height: 1.25;
    margin-bottom: .8rem;
}
.equipement-card p {
    font-size: .88rem;
    line-height: 1.7;
    color: #5f5f5f;
}

/* ── ENGAGEMENT ── */
.engagement {
    padding: 7rem 5vw;
    background: var(--white);
}
.engagement-intro {
    max-width: 760px;
    margin-bottom: 4rem;
}
.engagement-intro .section-title {
    margin-bottom: 1.2rem;
}
.engagement-intro .section-desc {
    max-width: none;
    font-size: 1rem;
}
.pillars {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
    gap: 1px;
    background: var(--mist);
    border: 1px solid var(--mist);
}
.pillar {
    background: var(--white);
    padding: 2.6rem 2rem;
    transition: background .3s;
}
.pillar:hover { background: #fdfaf5; }
.pillar-icon {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 52px; height: 52px;
    border: 1px solid rgba(200,169,110,0.4);
    border-radius: 50%;
    margin-bottom: 1.6rem;
}
.pillar-icon svg {
    width: 24px; height: 24px;
    stroke: var(--accent);
}
.pillar h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: .7rem;
}
.pillar p {
    font-size: .88rem;
    line-height: 1.7;
    color: #5f5f5f;
}

/* ── RESPONSIVE ── */
@media (max-width: 1024px) {
    .hero-image { background-position: 70% center; }
    .hero-mask {
        background:
            linear-gradient(
                90deg,
                rgba(10, 22, 40, 0.95) 0%,
                rgba(10, 22, 40, 0.85) 40%,
                rgba(13, 31, 60, 0.55) 70%,
                rgba(13, 31, 60, 0.25) 100%
            );
    }
}

/* ═════════════════════════════════════════════════════════
   SERVICES PAGE — styles dedicated to /services
   ═════════════════════════════════════════════════════════ */

/* ── PAGE HEADER (compact hero for inner pages) ── */
.page-header {
    position: relative;
    padding: 11rem 5vw 6rem;
    background:
        linear-gradient(180deg, #08111e 0%, #0a1628 55%, #0d1f3c 100%);
    overflow: hidden;
    isolation: isolate;
}
.page-header::before {
    content: '';
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 18% 30%, rgba(200,169,110,0.10) 0%, transparent 40%),
        radial-gradient(circle at 82% 70%, rgba(26,58,107,0.55) 0%, transparent 50%);
    z-index: 0;
}
.page-header::after {
    content: '';
    position: absolute; bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.page-header-glow {
    position: absolute;
    top: -120px; right: -120px;
    width: 460px; height: 460px;
    background: radial-gradient(circle, rgba(200,169,110,0.16) 0%, transparent 65%);
    z-index: 0;
    pointer-events: none;
}
.page-header-content {
    position: relative; z-index: 2;
    max-width: 920px;
}
.page-header h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 4.4vw, 3.8rem);
    font-weight: 300; line-height: 1.18;
    color: var(--white);
    margin-bottom: 1.6rem;
}
.page-header h1 em {
    font-style: italic; color: var(--accent);
    font-weight: 400;
}
.page-header-desc {
    font-size: 1.02rem; line-height: 1.8;
    color: var(--mist);
    max-width: 620px;
}

/* Breadcrumb */
.breadcrumb {
    display: flex; align-items: center; gap: .6rem;
    font-size: .74rem; letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(214,207,196,0.55);
    margin-bottom: 2rem;
    position: relative;
    padding: 0; background: transparent; border: none;
}
.breadcrumb a {
    color: rgba(214,207,196,0.7);
    text-decoration: none;
    transition: color .2s;
    padding: 0;
}
.breadcrumb a:hover { color: var(--accent); }
.breadcrumb .sep { color: rgba(200,169,110,0.45); }
.breadcrumb .current { color: var(--accent); }

/* ── SERVICES OVERVIEW ── */
.services-overview {
    padding: 6rem 5vw;
    background: var(--white);
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.overview-grid {
    display: grid;
    grid-template-columns: 1fr 1.3fr;
    gap: 4rem;
    max-width: 1280px;
    margin: 0 auto;
    align-items: start;
}
.overview-body p {
    font-size: 1rem;
    line-height: 1.85;
    color: #4a4a4a;
    margin-bottom: 2.4rem;
}
.overview-meta {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
    border-top: 1px solid rgba(200,169,110,0.25);
    padding-top: 2rem;
}
.overview-meta > div {
    border-left: 2px solid var(--accent);
    padding-left: 1rem;
}
.meta-num {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem;
    font-weight: 600;
    color: var(--navy);
    line-height: 1.1;
    margin-bottom: .3rem;
}
.meta-cap {
    display: block;
    font-size: .7rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: #777;
}

/* ── SERVICE DETAILS (alternating blocks) ── */
.service-details {
    padding: 5rem 5vw 6rem;
    background: var(--white);
}
.service-detail {
    display: grid;
    grid-template-columns: 1.15fr 1fr;
    gap: 5rem;
    align-items: center;
    max-width: 1280px;
    margin: 0 auto;
    padding: 4rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.service-detail:last-child { border-bottom: none; }
.service-detail.reverse .service-detail-text { order: 2; }
.service-detail.reverse .service-detail-visual { order: 1; }

.service-detail-num {
    display: inline-block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 3.4rem;
    font-weight: 300;
    color: var(--accent);
    line-height: 1;
    margin-bottom: 1rem;
    opacity: .55;
}
.service-detail-text h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    font-weight: 400; line-height: 1.2;
    color: var(--navy);
    margin: .4rem 0 1.4rem;
}
.service-detail-text h3 em {
    font-style: italic; color: var(--blue);
}
.service-detail-lead {
    font-size: .98rem;
    line-height: 1.8;
    color: #555;
    margin-bottom: 2rem;
}

.feature-list {
    list-style: none;
    margin-bottom: 2rem;
    border-top: 1px solid rgba(200,169,110,0.2);
}
.feature-list li {
    padding: .95rem 0;
    font-size: .92rem;
    line-height: 1.5;
    color: #444;
    border-bottom: 1px solid rgba(200,169,110,0.15);
    position: relative;
    padding-left: 1.6rem;
}
.feature-list li::before {
    content: '';
    position: absolute;
    left: 0; top: 1.35rem;
    width: 8px; height: 1px;
    background: var(--accent);
}
.feature-list li strong {
    color: var(--navy);
    font-weight: 600;
}

.service-detail-tags {
    display: flex; flex-wrap: wrap; gap: .6rem;
}
.service-detail-tags span {
    display: inline-block;
    padding: .4rem .9rem;
    font-size: .72rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--blue);
    background: rgba(200,169,110,0.10);
    border: 1px solid rgba(200,169,110,0.3);
    border-radius: 2px;
}

/* Visual card placeholder (since no real images yet) */
.service-detail-visual {
    display: flex;
    align-items: center;
    justify-content: center;
}
.visual-card {
    width: 100%;
    aspect-ratio: 4 / 5;
    background:
        linear-gradient(135deg, #f3ede2 0%, #faf6ec 100%);
    border: 1px solid rgba(200,169,110,0.35);
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    text-align: center;
    padding: 2rem;
    position: relative;
    overflow: hidden;
    transition: transform .35s ease, box-shadow .35s ease;
}
.visual-card::before {
    content: '';
    position: absolute;
    top: 18px; left: 18px; right: 18px; bottom: 18px;
    border: 1px solid rgba(200,169,110,0.4);
    pointer-events: none;
}
.visual-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 24px 50px rgba(10,22,40,0.10);
}
.visual-card .visual-icon {
    font-size: 4.2rem;
    margin-bottom: 1.4rem;
    filter: drop-shadow(0 4px 12px rgba(10,22,40,0.15));
}
.visual-card .visual-label {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: .5rem;
}
.visual-card .visual-detail {
    font-size: .75rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent);
}
.visual-card-dark {
    background: linear-gradient(135deg, #0d1f3c 0%, #0a1628 100%);
}
.visual-card-dark::before { border-color: rgba(200,169,110,0.35); }
.visual-card-dark .visual-label { color: var(--accent-light); }
.visual-card-dark .visual-detail { color: var(--accent); }

/* Photo variant: --card-bg passes the image (text/icon removed in HTML).
   Native aspect ratio 2/3 to match 1024×1536 source images — no cropping. */
/* Photo variant — clean image card, inherits the .visual-card 4/5 aspect
   to match the sibling Médical / Industries cards. No text overlay. */
.visual-card--photo {
    padding: 0;
    background:
        var(--card-bg) center / cover no-repeat,
        linear-gradient(135deg, #0d1f3c 0%, #0a1628 100%);
    border-color: rgba(200,169,110,0.45);
}
.visual-card--photo::before {
    border-color: rgba(200,169,110,0.35);
    z-index: 1;
}

/* ── TIERS ── */
.tiers {
    padding: 7rem 5vw;
    background: #f3ede2;
}
.tier-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
    margin-top: 1rem;
    max-width: 1280px;
    margin-left: auto; margin-right: auto;
}
.tier-card {
    background: var(--white);
    padding: 2.6rem 2.2rem 2.4rem;
    border: 1px solid rgba(200,169,110,0.3);
    position: relative;
    transition: transform .3s, box-shadow .3s, border-color .3s;
    display: flex; flex-direction: column;
}
.tier-card:hover {
    transform: translateY(-4px);
    box-shadow: 0 20px 44px rgba(10,22,40,0.08);
    border-color: var(--accent);
}
.tier-featured {
    background: var(--navy);
    border-color: var(--accent);
    transform: translateY(-12px);
    box-shadow: 0 28px 50px rgba(10,22,40,0.18);
}
.tier-featured:hover {
    transform: translateY(-16px);
    box-shadow: 0 36px 60px rgba(10,22,40,0.22);
}

.tier-tag {
    font-size: .68rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 1rem;
    font-weight: 500;
}
.tier-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: .6rem;
    line-height: 1.1;
}
.tier-featured h3 { color: var(--accent-light); }
.tier-lead {
    font-size: .9rem;
    line-height: 1.65;
    color: #555;
    margin-bottom: 1.8rem;
    min-height: 2.8em;
}
.tier-featured .tier-lead { color: var(--mist); }

.tier-features {
    list-style: none;
    margin-bottom: 2rem;
    flex-grow: 1;
}
.tier-features li {
    padding: .7rem 0;
    font-size: .88rem;
    color: #444;
    border-bottom: 1px solid rgba(200,169,110,0.18);
    position: relative;
    padding-left: 1.4rem;
}
.tier-features li:last-child { border-bottom: none; }
.tier-features li::before {
    content: '✦';
    position: absolute;
    left: 0; top: .7rem;
    color: var(--accent);
    font-size: .7rem;
}
.tier-features li strong {
    color: var(--navy);
    font-weight: 600;
}
.tier-featured .tier-features li {
    color: var(--mist);
    border-color: rgba(200,169,110,0.22);
}
.tier-featured .tier-features li strong { color: var(--accent-light); }

.btn-primary-light {
    display: inline-block;
    background: var(--accent);
    color: var(--navy);
    padding: .85rem 1.8rem;
    font-size: .78rem; font-weight: 500;
    letter-spacing: .14em; text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    text-align: center;
    transition: background .25s, transform .2s;
}
.btn-primary-light:hover {
    background: var(--accent-light);
    transform: translateY(-2px);
}

/* ── SECTORS ── */
.sectors {
    padding: 7rem 5vw;
    background: var(--white);
}
.sectors-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5px;
    background: var(--mist);
    border: 1px solid var(--mist);
    max-width: 1280px;
    margin: 0 auto;
}
.sector {
    background: var(--white);
    padding: 2.4rem 1.8rem;
    text-align: left;
    transition: background .3s, transform .3s;
    position: relative;
}
.sector::before {
    content: '';
    position: absolute; top: 0; left: 0;
    width: 0; height: 2px;
    background: var(--accent);
    transition: width .35s ease;
}
.sector:hover { background: #fdfaf5; }
.sector:hover::before { width: 100%; }
.sector-icon {
    display: block;
    font-size: 2rem;
    margin-bottom: 1rem;
}
.sector h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: .5rem;
}
.sector p {
    font-size: .82rem;
    line-height: 1.6;
    color: #666;
}

/* ── PROBLEM / SOLUTION INTRO (services page) ── */
.tech-intro {
    padding: 6rem 5vw;
    background: var(--white);
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.tech-intro-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 5rem;
    max-width: 1280px;
    margin: 0 auto;
    align-items: start;
}
.tech-col h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.7rem, 2.8vw, 2.4rem);
    font-weight: 400;
    line-height: 1.25;
    color: var(--navy);
    margin: .6rem 0 2rem;
}
.tech-col h2 em { font-style: italic; color: var(--blue); }

/* Problem column */
.problem-list {
    list-style: none;
    display: flex;
    flex-direction: column;
    gap: 1.8rem;
    margin-bottom: 2rem;
}
.problem-list li {
    display: flex;
    gap: 1.1rem;
    align-items: flex-start;
}
.problem-icon {
    flex: 0 0 auto;
    width: 2rem; height: 2rem;
    border-radius: 50%;
    background: rgba(180,50,30,0.1);
    border: 1px solid rgba(180,50,30,0.25);
    color: #b43220;
    font-size: .85rem;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin-top: .15rem;
}
.problem-list li div strong {
    display: block;
    font-size: .95rem;
    color: var(--navy);
    margin-bottom: .3rem;
}
.problem-list li div p {
    font-size: .875rem;
    line-height: 1.7;
    color: #555;
    margin: 0;
}
.problem-cause {
    font-size: .82rem;
    line-height: 1.6;
    color: #777;
    border-left: 3px solid rgba(180,50,30,0.35);
    padding-left: .9rem;
}
.problem-cause strong { color: #b43220; }

/* Solution column */
.tech-col--solution {
    background: #f0ede8;
    border: 1px solid rgba(200,169,110,0.3);
    border-radius: 3px;
    padding: 2.8rem 2.4rem;
}
.solution-label { color: var(--accent) !important; }
.tech-intro-lead {
    font-size: .95rem;
    line-height: 1.8;
    color: #4a4a4a;
    margin-bottom: 2rem;
}
.solution-pillars {
    display: flex;
    flex-direction: column;
    gap: 1.1rem;
}
.solution-pillar {
    display: flex;
    gap: 1rem;
    align-items: flex-start;
    padding: .9rem 1.1rem;
    background: var(--white);
    border-left: 3px solid var(--accent);
    border-radius: 2px;
}
.pillar-num {
    flex: 0 0 auto;
    width: 1.8rem; height: 1.8rem;
    border-radius: 50%;
    background: var(--navy);
    color: var(--accent);
    font-size: .78rem;
    font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    margin-top: .1rem;
}
.solution-pillar div strong {
    display: block;
    font-size: .9rem;
    color: var(--navy);
    margin-bottom: .15rem;
}
.solution-pillar div span {
    font-size: .8rem;
    color: #666;
}

/* ── METHOD COMPARISON TABLE (services page) ── */
.method-comparison {
    padding: 6rem 5vw;
    background: var(--navy);
    position: relative;
}
.method-comparison::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.method-comparison-inner {
    max-width: 1280px;
    margin: 0 auto;
}
.method-comparison-header {
    text-align: center;
    margin-bottom: 3.5rem;
}
.method-comparison-header .section-label { color: var(--accent); }
.method-comparison-header .section-title { color: var(--white); margin: .8rem 0 1.4rem; }
.method-comparison-header .section-title em { color: var(--accent-light); }
.method-comparison-header .section-desc {
    color: var(--mist);
    font-size: .95rem;
    line-height: 1.75;
    max-width: 680px;
    margin: 0 auto;
}

.method-table-wrap {
    overflow-x: auto;
    border-radius: 4px;
    border: 1px solid rgba(200,169,110,0.2);
}
.method-table {
    width: 100%;
    border-collapse: collapse;
    font-size: .9rem;
    background: var(--deep);
}
.method-table thead tr {
    border-bottom: 2px solid rgba(200,169,110,0.3);
}
.method-table th {
    padding: 1.2rem 1.4rem;
    text-align: left;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    line-height: 1.4;
}
.method-table th.col-criterion { color: var(--mist); width: 18%; }
.method-table th.col-trad { color: #e07060; width: 28%; background: rgba(180,50,30,0.1); }
.method-table th.col-ours { color: var(--accent); width: 28%; background: rgba(200,169,110,0.1); }
.method-table th.col-result { color: #7ab87a; width: 26%; }
.col-ours-badge {
    display: inline-block;
    margin-top: .3rem;
    padding: .15rem .55rem;
    background: rgba(200,169,110,0.2);
    border: 1px solid rgba(200,169,110,0.35);
    border-radius: 2px;
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .08em;
    color: var(--accent-light);
    text-transform: uppercase;
}
.method-table tbody tr {
    border-bottom: 1px solid rgba(200,169,110,0.1);
}
.method-table tbody tr:last-child { border-bottom: none; }
.method-table td {
    padding: 1rem 1.4rem;
    line-height: 1.55;
    color: var(--mist);
    vertical-align: middle;
}
.method-table td:first-child { color: #c8c0b4; font-weight: 500; }
.method-table td.col-trad { color: #e8a090; background: rgba(180,50,30,0.06); }
.method-table td.col-ours { color: var(--accent-light); background: rgba(200,169,110,0.06); }
.method-table td.col-result { color: #9fcc9f; }
.method-table-highlight td { background: rgba(200,169,110,0.12) !important; }
.method-table-highlight td.col-trad { background: rgba(180,50,30,0.12) !important; }

.method-comparison-note {
    margin-top: 2rem;
    text-align: center;
    font-size: .85rem;
    color: var(--mist);
}
.method-comparison-note a {
    color: var(--accent);
    text-decoration: underline;
    text-underline-offset: 3px;
}
.method-comparison-note a:hover { color: var(--accent-light); }

/* ── WASH PROCESS TIMELINE (services page) ── */
.wash-process {
    padding: 7rem 5vw;
    background: var(--navy);
    position: relative;
    overflow: hidden;
}
.wash-process::before {
    content: '';
    position: absolute; top: 0; left: 0; right: 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.wash-process::after {
    content: '';
    position: absolute;
    top: 40%; left: -20%;
    width: 60%; height: 60%;
    background: radial-gradient(circle, rgba(200,169,110,0.10) 0%, transparent 65%);
    pointer-events: none;
}

.wash-process-header {
    max-width: 760px;
    margin: 0 auto 4.5rem;
    text-align: center;
    position: relative;
    z-index: 1;
}
.wash-process-header .section-label { color: var(--accent); }
.wash-process-header .section-title { color: var(--white); margin: .8rem 0 1.6rem; }
.wash-process-header .section-title em { color: var(--accent-light); }
.wash-process-header .section-desc {
    color: var(--mist);
    font-size: .98rem;
    line-height: 1.85;
    margin: 0 auto;
}

.wash-timeline {
    list-style: none;
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1.4rem;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
    z-index: 1;
}
.wash-step {
    background: rgba(255,255,255,0.03);
    border: 1px solid rgba(200,169,110,0.15);
    border-radius: 3px;
    padding: 2.2rem 1.6rem 1.8rem;
    position: relative;
    transition: background .3s, border-color .3s, transform .3s;
}
.wash-step:hover {
    background: rgba(200,169,110,0.07);
    border-color: rgba(200,169,110,0.4);
    transform: translateY(-4px);
}
.wash-step-num {
    position: absolute;
    top: .8rem; right: 1.2rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.6rem;
    font-weight: 300;
    color: rgba(200,169,110,0.22);
    line-height: 1;
    letter-spacing: -1px;
}
.wash-step-icon {
    display: block;
    font-size: 1.8rem;
    margin-bottom: 1rem;
    filter: drop-shadow(0 2px 6px rgba(0,0,0,0.4));
}
.wash-step h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 600;
    color: var(--white);
    margin-bottom: .65rem;
    letter-spacing: .01em;
}
.wash-step p {
    font-size: .85rem;
    line-height: 1.75;
    color: var(--mist);
}
.wash-step p em {
    color: var(--accent-light);
    font-style: italic;
}

.wash-process-foot {
    max-width: 880px;
    margin: 3.5rem auto 0;
    padding: 1.8rem 2rem;
    background: rgba(200,169,110,0.08);
    border-left: 3px solid var(--accent);
    border-radius: 2px;
    position: relative;
    z-index: 1;
    display: flex;
    align-items: flex-start;
    gap: 1.4rem;
    flex-wrap: wrap;
}
.wash-foot-tag {
    flex: 0 0 auto;
    font-size: .68rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--navy);
    background: var(--accent);
    padding: .35rem .8rem;
    border-radius: 2px;
    font-weight: 600;
    margin-top: .15rem;
}
.wash-process-foot p {
    flex: 1 1 320px;
    color: var(--mist);
    font-size: .92rem;
    line-height: 1.75;
    margin: 0;
}
.wash-process-foot p strong { color: var(--accent-light); font-weight: 600; }


/* ── BEFORE / AFTER COMPARISON (services page) ── */
.comparison {
    padding: 7rem 5vw;
    background: var(--white);
    position: relative;
}
.comparison .section-header {
    max-width: 1280px;
    margin: 0 auto 3.5rem;
}

.comparison-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 2rem;
    max-width: 1280px;
    margin: 0 auto;
}

.comparison-card {
    background: #fff;
    border: 1px solid var(--mist);
    border-radius: 3px;
    overflow: hidden;
    transition: box-shadow .35s, transform .35s, border-color .35s;
}
.comparison-card:hover {
    box-shadow: 0 18px 40px -22px rgba(10,22,40,0.35);
    border-color: rgba(200,169,110,0.4);
    transform: translateY(-4px);
}

.comparison-pair {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1px;
    background: var(--mist);
    aspect-ratio: 2 / 1;
}
.comparison-side {
    position: relative;
    overflow: hidden;
    background: var(--navy);
    margin: 0;
}
.comparison-side img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .6s ease;
}
.comparison-card:hover .comparison-side img { transform: scale(1.04); }

.comparison-side figcaption {
    position: absolute;
    top: .9rem; left: .9rem;
    font-size: .68rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    font-weight: 600;
    padding: .4rem .85rem;
    border-radius: 2px;
    z-index: 2;
}
.comparison-side--before figcaption {
    background: rgba(255,255,255,0.92);
    color: #8a6d2e;
    border: 1px solid rgba(138,109,46,0.25);
}
.comparison-side--after figcaption {
    background: var(--accent);
    color: var(--navy);
}

/* Subtle tonal hint so before/after read different even with the same placeholder */
.comparison-side--before::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(180,150,80,0.18), rgba(80,60,30,0.22));
    pointer-events: none;
    mix-blend-mode: multiply;
}
.comparison-side--after::after {
    content: '';
    position: absolute; inset: 0;
    background: linear-gradient(135deg, rgba(255,255,255,0.10), rgba(232,207,160,0.10));
    pointer-events: none;
}

.comparison-body {
    padding: 1.6rem 1.8rem 2rem;
}
.comparison-body h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--navy);
    margin-bottom: .6rem;
}
.comparison-body p {
    font-size: .9rem;
    line-height: 1.7;
    color: #555;
    margin: 0;
}

.comparison-cta {
    max-width: 1280px;
    margin: 3.5rem auto 0;
    padding: 2rem 2.4rem;
    background: var(--navy);
    border-radius: 3px;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 2rem;
    flex-wrap: wrap;
}
.comparison-cta p {
    flex: 1 1 360px;
    color: var(--mist);
    font-size: .95rem;
    line-height: 1.7;
    margin: 0;
}
.comparison-cta p strong {
    color: var(--accent-light);
    font-weight: 600;
}
.comparison-cta .btn-primary {
    flex: 0 0 auto;
    white-space: nowrap;
}


/* ═════════════════════════════════════════════════════════
   SERVICES PAGE — Responsive
   ═════════════════════════════════════════════════════════ */
@media (max-width: 1100px) {
    .wash-timeline { grid-template-columns: repeat(2, 1fr); }
    .comparison-grid { grid-template-columns: repeat(2, 1fr); }
    .comparison-grid > .comparison-card:nth-child(3) {
        grid-column: 1 / -1;
        max-width: 560px;
        margin: 0 auto;
        width: 100%;
    }
}

@media (max-width: 900px) {
    .tech-intro-inner { grid-template-columns: 1fr; gap: 2.5rem; }
    .tech-col--solution { padding: 2rem 1.6rem; }
    .method-comparison { padding: 4rem 5vw; }
    .method-comparison-header { margin-bottom: 2.5rem; }

    .tier-featured { transform: none; }
    .tier-featured:hover { transform: translateY(-4px); }

    .wash-process { padding: 5rem 5vw; }
    .wash-process-header { margin-bottom: 3rem; }
    .wash-process-foot { flex-direction: column; gap: .9rem; padding: 1.6rem 1.4rem; }
    .comparison { padding: 5rem 5vw; }
    .comparison-cta { flex-direction: column; text-align: center; padding: 1.8rem 1.6rem; }
    .comparison-cta .btn-primary { width: 100%; max-width: 320px; }
}

@media (max-width: 768px) {
    nav ul { display: none; }
    .section-header { flex-direction: column; }
    .footer-grid { grid-template-columns: 1fr; }
    .cta-band { flex-direction: column; text-align: center; }

    .hero { min-height: calc(92vh - 60px); }
    .hero-image { background-position: 75% center; }
    /* allow title to wrap on narrow screens so it never overflows */
    .hero h1 .hero-line { white-space: normal; }
    .hero h1 { font-size: clamp(2rem, 8vw, 3rem); }
    /* On mobile, switch to a vertical wash so text stays readable */
    .hero-mask {
        background:
            linear-gradient(
                180deg,
                rgba(10, 22, 40, 0.55) 0%,
                rgba(10, 22, 40, 0.85) 45%,
                rgba(10, 22, 40, 0.95) 100%
            );
    }
    .hero-content { max-width: 100%; }
    .hero-trust { gap: 1.4rem; bottom: 1.2rem; }
    .trust-item { flex: 0 0 100%; }

    .about-grid { grid-template-columns: 1fr; gap: 3rem; }
    .about-stats { grid-template-columns: 1fr 1fr; }
    .engagement-intro { margin-bottom: 2.5rem; }

    /* Services page tweaks */
    .page-header { padding: 9rem 5vw 4rem; }
    .page-header h1 { font-size: clamp(1.8rem, 7vw, 2.6rem); }
    .tech-intro { padding: 4rem 5vw; }
    .tech-col h2 { font-size: 1.6rem; }
    .method-table th, .method-table td { padding: .85rem .9rem; font-size: .82rem; }
    .tiers, .sectors, .services-overview { padding: 4.5rem 5vw; }
    .sectors-grid { grid-template-columns: 1fr 1fr; }

    .wash-timeline { grid-template-columns: 1fr; gap: 1rem; }
    .wash-step { padding: 1.8rem 1.4rem 1.5rem; }
    .comparison-grid { grid-template-columns: 1fr; gap: 1.6rem; }
    .comparison-grid > .comparison-card:nth-child(3) { grid-column: auto; }
    .comparison-pair { aspect-ratio: 2 / 1; }
    .comparison-body { padding: 1.3rem 1.4rem 1.6rem; }
}

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

/* ═════════════════════════════════════════════════════════
   ORDER / DEVIS PAGE — instant contact + pricing + form
   ═════════════════════════════════════════════════════════ */

.instant-contact {
    padding: 5.5rem 5vw;
    background: var(--white);
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.instant-contact-inner { max-width: 1280px; margin: 0 auto; }
.instant-header { text-align: center; margin-bottom: 3rem; }
.instant-header h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.4vw, 2.6rem);
    font-weight: 400; line-height: 1.2;
    color: var(--navy);
    margin: .4rem 0 1rem;
}
.instant-header h2 em { font-style: italic; color: var(--blue); }
.instant-sub {
    font-size: .95rem; line-height: 1.7;
    color: #5a5a5a; max-width: 560px;
    margin: 0 auto;
}

.contact-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.2rem;
}
.contact-card {
    display: flex; align-items: center; gap: 1.3rem;
    padding: 1.8rem; text-decoration: none;
    border: 1px solid rgba(200,169,110,0.3);
    background: var(--white);
    transition: transform .3s, box-shadow .3s, border-color .3s, background .3s;
}
.contact-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 18px 36px rgba(10,22,40,0.10);
    border-color: var(--accent);
}
.contact-card-whatsapp {
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    border-color: #128C7E;
    color: #fff;
}
.contact-card-whatsapp:hover {
    background: linear-gradient(135deg, #2ee06f 0%, #149a8b 100%);
    border-color: #fff;
}
.contact-card-phone {
    background: var(--navy);
    border-color: var(--accent);
    color: var(--accent-light);
}
.contact-card-phone:hover { background: var(--deep); }

.contact-icon {
    width: 52px; height: 52px; flex-shrink: 0;
    display: flex; align-items: center; justify-content: center;
    background: rgba(255,255,255,0.18);
    border-radius: 50%;
}
.contact-card-phone .contact-icon { background: rgba(200,169,110,0.18); }
.contact-icon svg { width: 26px; height: 26px; }

.contact-info { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.contact-channel {
    font-size: .68rem; letter-spacing: .18em;
    text-transform: uppercase; opacity: .85;
}
.contact-number {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem; font-weight: 600;
    letter-spacing: .02em; line-height: 1.1;
    margin: .15rem 0;
}
.contact-action {
    font-size: .72rem; letter-spacing: .14em;
    text-transform: uppercase; opacity: .9; font-weight: 500;
}

/* ── PRICING ── */
.pricing { padding: 7rem 5vw; background: #f3ede2; }
.pricing .section-header,
.quote-form-section .section-header,
.success-next .section-header {
    max-width: 1280px; margin-left: auto; margin-right: auto;
}

.pricing-categories {
    display: grid; grid-template-columns: repeat(2, 1fr);
    gap: 2rem; max-width: 1280px; margin: 0 auto;
}
.pricing-cat {
    background: var(--white);
    padding: 2.4rem 2rem 2rem;
    border: 1px solid rgba(200,169,110,0.25);
    transition: border-color .3s, box-shadow .3s;
}
.pricing-cat:hover {
    border-color: var(--accent);
    box-shadow: 0 16px 36px rgba(10,22,40,0.06);
}
.pricing-cat-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; font-weight: 600;
    color: var(--navy);
    display: flex; align-items: center; gap: .7rem;
    padding-bottom: 1rem; margin-bottom: 1.2rem;
    border-bottom: 1px solid rgba(200,169,110,0.3);
}
.pricing-cat-icon { font-size: 1.4rem; line-height: 1; }
.pricing-cat-cn {
    font-family: 'DM Sans', sans-serif;
    font-size: .82rem; letter-spacing: .1em;
    color: var(--accent); font-weight: 500;
    margin-left: auto;
}

.pricing-table { display: flex; flex-direction: column; }
.pricing-row {
    display: grid; grid-template-columns: 1.6fr 1fr;
    align-items: center;
    padding: .75rem .2rem;
    font-size: .9rem; color: #444;
    border-bottom: 1px solid rgba(200,169,110,0.12);
}
.pricing-row:last-child { border-bottom: none; }
.pricing-row.pricing-head {
    font-size: .68rem; letter-spacing: .14em;
    text-transform: uppercase; color: #888;
    font-weight: 500;
    border-bottom: 1px solid rgba(200,169,110,0.28);
    padding-bottom: .55rem; margin-bottom: .3rem;
}
.pricing-row.pricing-head > span:not(:first-child) {
    text-align: right;
}

/* Tiered tables: 4 columns (name + 3 tier prices) */
.pricing-table-tiered .pricing-row {
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    gap: .4rem;
}
.pricing-table-tiered .pricing-row.pricing-row-flat {
    grid-template-columns: 1.4fr 3fr;
}
.pricing-table-tiered .pricing-row.pricing-head {
    color: #888;
}

.pricing-price {
    text-align: right;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem; font-weight: 600;
    color: var(--navy);
}
.pricing-table-tiered .pricing-price {
    font-size: 1.02rem;
}
.pricing-price em {
    font-style: normal;
    font-family: 'DM Sans', sans-serif;
    font-size: .65rem; letter-spacing: .12em;
    color: var(--accent); font-weight: 500;
    margin-left: .2rem;
}
.pricing-price-flat {
    text-align: right;
    font-family: 'DM Sans', sans-serif;
    font-size: .88rem; color: #666;
    font-style: italic;
}
.pricing-price-flat em {
    font-style: normal;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.02rem; font-weight: 600;
    color: var(--navy); margin-right: .35rem;
}
.tier-mark {
    color: var(--accent); font-weight: 600;
    margin-left: .25rem; font-size: .8em;
}

/* Volume tier legend */
.tier-legend {
    max-width: 1280px;
    margin: 0 auto 2.5rem;
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1rem;
}
.tier-legend-item {
    background: var(--white);
    border: 1px solid rgba(200,169,110,0.25);
    border-left: 3px solid var(--accent);
    padding: 1rem 1.2rem;
    display: flex; flex-direction: column; gap: .35rem;
}
.tier-badge {
    font-family: 'DM Sans', sans-serif;
    font-size: .72rem; letter-spacing: .14em;
    text-transform: uppercase; font-weight: 600;
    color: var(--navy);
}
.tier-badge-1 { color: var(--accent); }
.tier-badge-2 { color: var(--accent); }
.tier-badge-3 { color: var(--accent); }
.tier-legend-desc {
    font-size: .85rem; color: #555;
    font-family: 'DM Sans', sans-serif;
}

.pricing-note {
    max-width: 1000px; margin: 3rem auto 0;
    background: var(--white);
    border-left: 3px solid var(--accent);
    padding: 1.3rem 1.6rem;
    display: flex; align-items: flex-start; gap: 1rem;
}
.pricing-note svg {
    width: 22px; height: 22px;
    color: var(--accent); flex-shrink: 0;
    margin-top: .15rem;
}
.pricing-note p { font-size: .9rem; line-height: 1.75; color: #4a4a4a; }
.pricing-note strong { color: var(--navy); font-weight: 600; }

/* ── QUOTE FORM ── */
.quote-form-section { padding: 7rem 5vw; background: var(--white); }
.quote-grid {
    display: grid; grid-template-columns: 1.7fr 1fr;
    gap: 4rem; max-width: 1280px; margin: 0 auto;
    align-items: start;
}
.quote-form-wrap .section-title { margin-bottom: 1.2rem; }
.quote-form-intro {
    font-size: 1rem; line-height: 1.8;
    color: #555; margin-bottom: 3rem; max-width: 620px;
}
.quote-form-intro strong { color: var(--navy); font-weight: 600; }

.form-step {
    border: none; padding: 0 0 2.4rem;
    margin-bottom: 2.4rem;
    border-bottom: 1px solid rgba(200,169,110,0.2);
}
.form-step:last-of-type {
    border-bottom: none; margin-bottom: 1.4rem;
}
.form-step legend {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem; font-weight: 600;
    color: var(--navy);
    display: flex; align-items: center; gap: .8rem;
    margin-bottom: 1.5rem; padding: 0;
}
.step-badge {
    display: inline-flex; align-items: center; justify-content: center;
    width: 30px; height: 30px;
    background: var(--accent); color: var(--navy);
    font-family: 'DM Sans', sans-serif;
    font-size: .7rem; font-weight: 600;
    letter-spacing: .05em;
    border-radius: 50%;
}
.legend-hint {
    font-family: 'DM Sans', sans-serif;
    font-size: .72rem; letter-spacing: .12em;
    text-transform: uppercase;
    color: #888; font-weight: 400;
    margin-left: .3rem;
}

.form-row {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 1.5rem; margin-bottom: 1.2rem;
}
.form-row:last-child { margin-bottom: 0; }
.form-field { display: flex; flex-direction: column; }
.form-field label {
    font-size: .72rem; letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--navy); font-weight: 500;
    margin-bottom: .5rem;
}
.form-field .req { color: var(--accent); }

.form-field input,
.form-field select,
.form-field textarea {
    font-family: 'DM Sans', sans-serif;
    font-size: .95rem; color: var(--text);
    padding: .9rem 1rem;
    border: 1px solid rgba(200,169,110,0.35);
    background: var(--white);
    border-radius: 2px; outline: none;
    transition: border-color .25s, box-shadow .25s, background .25s;
}
.form-field input::placeholder,
.form-field textarea::placeholder { color: #b0a89e; }
.form-field input:focus,
.form-field select:focus,
.form-field textarea:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,169,110,0.15);
    background: #fdfaf5;
}
.form-field textarea {
    resize: vertical; min-height: 120px;
    font-family: inherit; line-height: 1.6;
}
.form-field select {
    appearance: none;
    background-image: url("data:image/svg+xml;charset=UTF-8,%3csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23c8a96e' stroke-width='1.8' stroke-linecap='round' stroke-linejoin='round'%3e%3cpath d='M6 9l6 6 6-6'/%3e%3c/svg%3e");
    background-repeat: no-repeat;
    background-position: right 1rem center;
    background-size: 16px;
    padding-right: 2.5rem; cursor: pointer;
}

.radio-cards {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
    gap: .8rem;
}
.radio-card {
    position: relative;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: .5rem;
    padding: 1.4rem .8rem;
    border: 1px solid rgba(200,169,110,0.3);
    background: var(--white);
    cursor: pointer;
    transition: all .25s;
}
.radio-card input {
    position: absolute; opacity: 0;
    pointer-events: none;
}
.radio-card-icon { font-size: 1.7rem; line-height: 1; }
.radio-card-label {
    font-size: .82rem; color: var(--navy);
    font-weight: 500; letter-spacing: .02em;
}
.radio-card:hover { border-color: var(--accent); background: #fdfaf5; }
.radio-card:has(input:checked) {
    border-color: var(--accent);
    background: var(--navy);
    box-shadow: 0 6px 18px rgba(10,22,40,0.18);
}
.radio-card:has(input:checked) .radio-card-label {
    color: var(--accent-light);
}

.check-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
    gap: .7rem;
}
.check-item {
    display: flex; align-items: center; gap: .7rem;
    padding: .85rem 1rem;
    border: 1px solid rgba(200,169,110,0.3);
    background: var(--white);
    cursor: pointer;
    font-size: .88rem; color: #444;
    transition: all .25s;
}
.check-item input[type="checkbox"] {
    width: 18px; height: 18px;
    accent-color: var(--accent);
    cursor: pointer; flex-shrink: 0;
}
.check-item:hover { border-color: var(--accent); background: #fdfaf5; }
.check-item:has(input:checked) {
    background: rgba(200,169,110,0.08);
    border-color: var(--accent);
}
.check-item:has(input:checked) span {
    color: var(--navy); font-weight: 500;
}

.form-submit {
    margin-top: 2rem;
    display: flex; flex-direction: column;
    align-items: flex-start; gap: 1rem;
}
.btn-primary-form {
    border: none; cursor: pointer;
    font-family: inherit; font-size: .82rem;
    padding: 1.1rem 2.6rem;
}
.btn-primary-form:hover { transform: translateY(-2px); }
.form-disclaimer {
    font-size: .75rem; line-height: 1.6;
    color: #777; max-width: 480px;
}

.quote-sidebar {
    position: sticky; top: 100px;
    display: flex; flex-direction: column;
    gap: 1.2rem;
}
.sidebar-card {
    background: var(--white);
    border: 1px solid rgba(200,169,110,0.3);
    padding: 1.8rem 1.6rem;
}
.sidebar-card-dark {
    background: var(--navy);
    border-color: var(--accent);
    color: var(--mist);
}
.sidebar-card-dark .section-label { color: var(--accent); }
.sidebar-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.45rem; font-weight: 600;
    color: var(--white); line-height: 1.25;
    margin: .3rem 0 1.4rem;
}
.sidebar-card h3 em { font-style: italic; color: var(--accent-light); }
.sidebar-card h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; font-weight: 600;
    color: var(--navy); margin-bottom: 1.1rem;
}

.next-steps { list-style: none; }
.next-steps li {
    display: flex; gap: 1rem; padding: .9rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.next-steps li:last-child { border-bottom: none; }
.next-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; font-weight: 600;
    color: var(--accent); line-height: 1;
    flex-shrink: 0; width: 38px;
}
.next-steps li strong {
    display: block; color: var(--white);
    font-size: .92rem; margin-bottom: .25rem;
    font-weight: 500;
}
.next-steps li p {
    font-size: .82rem; line-height: 1.6;
    color: var(--mist);
}

.sidebar-contact { list-style: none; }
.sidebar-contact li {
    padding: .9rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
    display: grid;
    grid-template-columns: auto 1fr;
    gap: .25rem .8rem;
    align-items: center;
}
.sidebar-contact li:last-child { border-bottom: none; }
.sb-icon { grid-row: 1 / 3; font-size: 1.3rem; }
.sidebar-contact a {
    font-size: .9rem; font-weight: 500;
    color: var(--navy); text-decoration: none;
    transition: color .2s;
}
.sidebar-contact a:hover { color: var(--accent); }
.sidebar-contact em {
    font-style: normal;
    font-size: .7rem; letter-spacing: .1em;
    text-transform: uppercase; color: #888;
}

.sidebar-trust {
    background: #f3ede2;
    padding: 1.6rem;
    display: flex; flex-direction: column; gap: 1rem;
}
.trust-row { display: flex; align-items: center; gap: .9rem; }
.trust-emoji { font-size: 1.6rem; line-height: 1; }
.trust-row strong {
    display: block; font-size: .88rem;
    color: var(--navy); font-weight: 500;
}
.trust-row small {
    display: block; font-size: .72rem;
    color: #777; margin-top: .15rem;
}

/* ═════════════════════════════════════════════════════════
   ORDER SUCCESS PAGE
   ═════════════════════════════════════════════════════════ */
.success-hero {
    position: relative;
    padding: 12rem 5vw 7rem;
    background: linear-gradient(180deg, #08111e 0%, #0a1628 55%, #0d1f3c 100%);
    overflow: hidden; isolation: isolate;
    text-align: center;
}
.success-hero::before {
    content: ''; position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 30% 20%, rgba(200,169,110,0.12) 0%, transparent 50%),
        radial-gradient(circle at 70% 80%, rgba(26,58,107,0.5) 0%, transparent 50%);
    z-index: 0;
}
.success-hero::after {
    content: ''; position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.success-hero-glow {
    position: absolute;
    top: 50%; left: 50%;
    transform: translate(-50%, -50%);
    width: 600px; height: 600px;
    background: radial-gradient(circle, rgba(200,169,110,0.15) 0%, transparent 65%);
    z-index: 0;
}
.success-hero-content {
    position: relative; z-index: 2;
    max-width: 760px; margin: 0 auto;
}
.success-check {
    width: 96px; height: 96px;
    margin: 0 auto 2rem;
    color: var(--accent);
    animation: successPop .6s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
.success-check svg { width: 100%; height: 100%; }
@keyframes successPop {
    from { opacity: 0; transform: scale(0.4); }
    to   { opacity: 1; transform: scale(1); }
}

.success-hero .hero-eyebrow {
    margin-bottom: 1.4rem; justify-content: center;
}
.success-hero .hero-eyebrow::before { display: none; }
.success-hero h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 4.2vw, 3.4rem);
    font-weight: 300; line-height: 1.18;
    color: var(--white); margin-bottom: 1.6rem;
}
.success-hero h1 em { font-style: italic; color: var(--accent); font-weight: 400; }
.success-hero .hero-divider { margin-left: auto; margin-right: auto; }
.success-lead {
    font-size: 1.05rem; line-height: 1.8;
    color: var(--mist); max-width: 560px;
    margin: 0 auto 2.6rem;
}
.success-lead strong { color: var(--accent-light); font-weight: 600; }
.success-ref {
    display: inline-block;
    padding: 1rem 2rem;
    border: 1px solid var(--accent);
    background: rgba(200,169,110,0.08);
}
.ref-label {
    display: block; font-size: .68rem;
    letter-spacing: .18em; text-transform: uppercase;
    color: var(--mist); margin-bottom: .25rem;
}
.ref-num {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem; font-weight: 600;
    color: var(--accent); letter-spacing: .08em;
}

.success-next { padding: 7rem 5vw; background: var(--white); }
.success-timeline {
    list-style: none; max-width: 880px;
    margin: 0 auto; counter-reset: success-step;
}
.success-timeline li {
    display: grid; grid-template-columns: 60px 1fr;
    gap: 1.6rem; padding: 1.8rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.2);
    position: relative;
}
.success-timeline li:last-child { border-bottom: none; }
.timeline-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.4rem; font-weight: 300;
    color: var(--accent); line-height: 1; opacity: .65;
}
.timeline-body h4 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; font-weight: 600;
    color: var(--navy); margin-bottom: .5rem;
}
.timeline-body p {
    font-size: .92rem; line-height: 1.7;
    color: #555; margin-bottom: .6rem;
}
.timeline-body p strong { color: var(--navy); font-weight: 600; }
.timeline-when {
    display: inline-block; font-size: .7rem;
    letter-spacing: .14em; text-transform: uppercase;
    color: var(--accent);
    background: rgba(200,169,110,0.1);
    padding: .35rem .8rem;
    border-radius: 2px;
}

.success-summary { padding: 6rem 5vw; background: #f3ede2; }
.summary-wrap { max-width: 1080px; margin: 0 auto; }
.summary-wrap .section-title { margin-bottom: 2.5rem; }
.summary-grid {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
    gap: 1.5px;
    background: rgba(200,169,110,0.3);
    border: 1px solid rgba(200,169,110,0.3);
    margin-bottom: 2rem;
}
.summary-item {
    background: var(--white);
    padding: 1.3rem 1.4rem;
    display: flex; flex-direction: column; gap: .35rem;
}
.summary-key {
    font-size: .7rem; letter-spacing: .14em;
    text-transform: uppercase; color: #888;
}
.summary-val {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem; font-weight: 600;
    color: var(--navy); word-break: break-word;
}
.summary-services {
    background: var(--white);
    padding: 1.5rem 1.4rem;
    border: 1px solid rgba(200,169,110,0.3);
    margin-bottom: 1.5rem;
}
.summary-services .summary-key {
    margin-bottom: .8rem; display: block;
}
.summary-tags {
    display: flex; flex-wrap: wrap; gap: .5rem;
}
.summary-tag {
    display: inline-block;
    padding: .4rem .9rem;
    font-size: .78rem; color: var(--blue);
    background: rgba(200,169,110,0.12);
    border: 1px solid rgba(200,169,110,0.3);
    border-radius: 2px;
}
.summary-message {
    background: var(--white);
    border-left: 3px solid var(--accent);
    padding: 1.5rem 1.6rem;
}
.summary-message .summary-key {
    display: block; margin-bottom: .6rem;
}
.summary-message p {
    font-size: .95rem; line-height: 1.75;
    color: #444; white-space: pre-wrap;
}

.success-urgent { padding: 5rem 5vw; background: var(--accent); }
.urgent-inner {
    max-width: 1080px; margin: 0 auto;
    display: flex; justify-content: space-between;
    align-items: center; gap: 2.5rem;
    flex-wrap: wrap;
}
.urgent-text h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.7rem, 3vw, 2.4rem);
    font-weight: 500; color: var(--navy);
    line-height: 1.2; margin: .4rem 0 .6rem;
}
.urgent-text .section-label { color: var(--navy); }
.urgent-sub { font-size: .9rem; color: rgba(10,22,40,0.75); }
.urgent-actions {
    display: flex; gap: .8rem; flex-wrap: wrap;
}
.urgent-actions .btn-primary {
    background: var(--navy); color: var(--accent-light);
}
.urgent-actions .btn-primary:hover { background: var(--deep); }
.urgent-actions .btn-outline {
    border-color: var(--navy); color: var(--navy);
    background: transparent;
}
.urgent-actions .btn-outline:hover {
    background: var(--navy); color: var(--accent-light);
}

.success-back {
    padding: 3rem 5vw 5rem;
    background: var(--white);
    display: flex; justify-content: space-between;
    flex-wrap: wrap; gap: 1rem;
    max-width: 1080px; margin: 0 auto;
}

/* Responsive */
@media (max-width: 1024px) {
    .contact-cards { grid-template-columns: 1fr; }
    .pricing-categories { grid-template-columns: 1fr; }
    .quote-grid { grid-template-columns: 1fr; gap: 3rem; }
    .quote-sidebar { position: static; }
}

@media (max-width: 768px) {
    .instant-contact { padding: 4rem 5vw; }
    .pricing, .quote-form-section { padding: 4.5rem 5vw; }
    .pricing-cat { padding: 1.8rem 1.4rem; }
    .pricing-row { grid-template-columns: 1.6fr 1fr; padding: .65rem .1rem; font-size: .85rem; }
    .pricing-table-tiered .pricing-row {
        grid-template-columns: 1fr;
        gap: .15rem;
        padding: .85rem .1rem;
    }
    .pricing-table-tiered .pricing-row > span:first-child {
        font-weight: 600; color: var(--navy);
        font-size: .92rem;
    }
    .pricing-table-tiered .pricing-price {
        text-align: left;
        font-size: .92rem;
        display: flex; justify-content: space-between;
        padding-left: .5rem;
    }
    .pricing-table-tiered .pricing-price::before {
        content: attr(data-tier);
    }
    .pricing-table-tiered .pricing-row.pricing-head { display: none; }
    .pricing-table-tiered .pricing-row.pricing-row-flat {
        grid-template-columns: 1fr;
    }
    .pricing-table-tiered .pricing-row.pricing-row-flat .pricing-price-flat {
        text-align: left; padding-left: .5rem;
    }
    .tier-legend { grid-template-columns: 1fr; gap: .6rem; }
    .contact-card { padding: 1.4rem; gap: 1rem; }
    .contact-icon { width: 44px; height: 44px; }
    .contact-number { font-size: 1.15rem; }
    .form-row { grid-template-columns: 1fr; gap: 1rem; }
    .radio-cards { grid-template-columns: repeat(2, 1fr); }
    .check-grid { grid-template-columns: 1fr 1fr; }
    .success-hero { padding: 9rem 5vw 5rem; }
    .success-check { width: 72px; height: 72px; margin-bottom: 1.4rem; }
    .success-next, .success-summary, .success-urgent { padding: 4rem 5vw; }
    .success-timeline li { grid-template-columns: 1fr; gap: .4rem; }
    .urgent-inner { flex-direction: column; text-align: center; }
    .urgent-actions { justify-content: center; }
    .success-back { flex-direction: column; align-items: stretch; text-align: center; }
}

@media (max-width: 480px) {
    .radio-cards { grid-template-columns: 1fr 1fr; }
    .check-grid { grid-template-columns: 1fr; }
}

/* ═════════════════════════════════════════════════════════
   WHATSAPP FLOATING WIDGET — site-wide chat button + panel
   ═════════════════════════════════════════════════════════ */
.wa-widget {
    position: fixed;
    bottom: 24px;
    right: 24px;
    z-index: 9999;
    font-family: 'DM Sans', sans-serif;
}

/* ── Toggle button (floating circle) ── */
.wa-toggle {
    position: relative;
    width: 62px; height: 62px;
    border-radius: 50%;
    border: none;
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    color: #fff;
    cursor: pointer;
    box-shadow: 0 12px 30px rgba(18, 140, 126, 0.4), 0 4px 12px rgba(0,0,0,0.15);
    display: flex; align-items: center; justify-content: center;
    transition: transform .25s, box-shadow .25s;
    outline: none;
}
.wa-toggle:hover {
    transform: translateY(-3px) scale(1.04);
    box-shadow: 0 18px 38px rgba(18, 140, 126, 0.5), 0 6px 16px rgba(0,0,0,0.2);
}
.wa-toggle:focus-visible {
    box-shadow: 0 0 0 4px rgba(200,169,110,0.45), 0 12px 30px rgba(18,140,126,0.4);
}

.wa-toggle-icon {
    position: absolute;
    width: 30px; height: 30px;
    transition: opacity .25s, transform .3s;
}
.wa-toggle-icon svg { width: 100%; height: 100%; }
.wa-toggle-icon.wa-toggle-close { opacity: 0; transform: rotate(-90deg) scale(.6); }
.wa-widget.wa-open .wa-toggle-icon.wa-toggle-open  { opacity: 0; transform: rotate(90deg) scale(.6); }
.wa-widget.wa-open .wa-toggle-icon.wa-toggle-close { opacity: 1; transform: rotate(0) scale(1); }

/* Subtle pulse ring */
.wa-pulse {
    position: absolute;
    inset: 0;
    border-radius: 50%;
    background: rgba(37, 211, 102, 0.45);
    z-index: -1;
    animation: waPulse 2.6s ease-out infinite;
}
@keyframes waPulse {
    0%   { transform: scale(1);    opacity: .65; }
    70%  { transform: scale(1.6);  opacity: 0; }
    100% { transform: scale(1.6);  opacity: 0; }
}
.wa-widget.wa-open .wa-pulse { display: none; }

/* Stronger attention pulse triggered by JS */
.wa-toggle.wa-hint {
    animation: waHint 1.2s ease-in-out 2;
}
@keyframes waHint {
    0%, 100% { transform: scale(1); }
    50%      { transform: scale(1.12); }
}

/* ── Chat panel ── */
.wa-panel {
    position: absolute;
    bottom: calc(100% + 14px);
    right: 0;
    width: 340px;
    max-width: calc(100vw - 32px);
    background: var(--white);
    border-radius: 14px;
    box-shadow: 0 20px 50px rgba(10, 22, 40, 0.28), 0 6px 16px rgba(0,0,0,0.08);
    overflow: hidden;
    transform: translateY(20px) scale(0.96);
    opacity: 0;
    pointer-events: none;
    transition: transform .3s cubic-bezier(0.34, 1.56, 0.64, 1), opacity .25s;
    transform-origin: bottom right;
}
.wa-widget.wa-open .wa-panel {
    transform: translateY(0) scale(1);
    opacity: 1;
    pointer-events: auto;
}

.wa-panel-header {
    background: linear-gradient(135deg, #0a1628 0%, #1a3a6b 100%);
    padding: 1rem 1.1rem;
    display: flex;
    align-items: center;
    gap: .8rem;
    color: #fff;
    position: relative;
}
.wa-panel-header::after {
    content: '';
    position: absolute;
    bottom: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.wa-brand {
    display: flex; align-items: center; gap: .8rem;
    flex: 1; min-width: 0;
}
.wa-brand-logo {
    width: 40px; height: 40px;
    border-radius: 50%;
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
    color: #fff;
    box-shadow: 0 2px 8px rgba(0,0,0,0.2);
}
.wa-brand-logo svg { width: 22px; height: 22px; }

.wa-brand-text {
    display: flex; flex-direction: column; gap: .15rem;
    min-width: 0;
}
.wa-brand-text strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--accent-light);
    line-height: 1.1;
}
.wa-status {
    display: inline-flex; align-items: center; gap: .35rem;
    font-size: .7rem;
    color: var(--mist);
    letter-spacing: .02em;
}
.wa-dot {
    width: 7px; height: 7px;
    background: #25D366;
    border-radius: 50%;
    box-shadow: 0 0 0 2px rgba(37,211,102,0.25);
    animation: waDotPulse 2s ease-in-out infinite;
}
@keyframes waDotPulse {
    0%, 100% { opacity: 1; }
    50%      { opacity: .5; }
}

.wa-close {
    background: rgba(255,255,255,0.1);
    border: none;
    color: var(--mist);
    width: 28px; height: 28px;
    border-radius: 50%;
    font-size: 1.2rem;
    line-height: 1;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    transition: background .2s, color .2s;
    flex-shrink: 0;
}
.wa-close:hover {
    background: rgba(255,255,255,0.2);
    color: var(--white);
}

.wa-panel-body {
    padding: 1.1rem;
    background:
        radial-gradient(circle at 30% 10%, rgba(200,169,110,0.05) 0%, transparent 60%),
        var(--white);
}
.wa-greeting {
    font-size: .85rem;
    line-height: 1.55;
    color: #555;
    margin-bottom: 1rem;
    padding-bottom: .9rem;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}

.wa-agent {
    display: flex;
    align-items: center;
    gap: .85rem;
    padding: .8rem .9rem;
    border: 1px solid rgba(200,169,110,0.25);
    border-radius: 10px;
    text-decoration: none;
    color: var(--navy);
    margin-bottom: .55rem;
    transition: all .25s;
    background: var(--white);
}
.wa-agent:last-child { margin-bottom: 0; }
.wa-agent:hover {
    border-color: #25D366;
    background: rgba(37, 211, 102, 0.05);
    transform: translateX(2px);
    box-shadow: 0 4px 12px rgba(37,211,102,0.12);
}
.wa-agent-avatar {
    width: 38px; height: 38px;
    border-radius: 50%;
    background: linear-gradient(135deg, #25D366 0%, #128C7E 100%);
    color: #fff;
    display: flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    font-weight: 600;
    flex-shrink: 0;
    box-shadow: 0 3px 8px rgba(18,140,126,0.25);
}
.wa-agent-info {
    display: flex; flex-direction: column; gap: .15rem;
    flex: 1; min-width: 0;
}
.wa-agent-info strong {
    font-size: .82rem;
    color: var(--navy);
    font-weight: 600;
    letter-spacing: .01em;
}
.wa-agent-info em {
    font-style: normal;
    font-size: .72rem;
    letter-spacing: .04em;
    color: #777;
}
.wa-agent-arrow {
    color: var(--accent);
    font-size: 1.1rem;
    transition: transform .25s;
    flex-shrink: 0;
}
.wa-agent:hover .wa-agent-arrow {
    transform: translateX(3px);
    color: #25D366;
}

.wa-panel-footer {
    padding: .7rem 1.1rem;
    background: #f3ede2;
    font-size: .72rem;
    letter-spacing: .08em;
    text-transform: uppercase;
    color: #888;
    text-align: center;
    border-top: 1px solid rgba(200,169,110,0.18);
}

/* Mobile adjustments */
@media (max-width: 480px) {
    .wa-widget { bottom: 16px; right: 16px; }
    .wa-toggle { width: 56px; height: 56px; }
    .wa-toggle-icon { width: 26px; height: 26px; }
    .wa-panel { width: calc(100vw - 32px); right: 0; }
}

/* ═════════════════════════════════════════════════════════
   PAGE-HEADER PHOTO VARIANT (services page)
   Same layered structure as the homepage hero.
   ═════════════════════════════════════════════════════════ */
.page-header--photo {
    background: var(--navy);
    /* Fixed height so the background image is identical on every photo
       header (services / pressing / broderie / location / boutique /
       order / about). 560px clears the tallest header content (broderie,
       which carries an extra CTA button) without clipping. */
    height: 560px;
    /* Vertically centre the text block within the fixed height. The
       inherited 11rem top padding would otherwise push content too high;
       zero it on desktop and let align-items handle spacing. Mobile
       restores its own padding inside the max-width:768px block below. */
    display: flex;
    align-items: center;
    padding-top: 0;
    padding-bottom: 0;
}
/* Hide default radial gradients when photo is present */
.page-header--photo::before {
    display: none;
}

/* Layer 1: photo on the right
   Image URL is set per-page via the --header-bg CSS variable.
   Falls back to services1.webp if not overridden.
   Audit § 4.4 — defaults use WebP with PNG fallback via image-set(). */
.page-header-image {
    position: absolute;
    inset: 0;
    background-image: var(--header-bg, url('/static/images/services1.png'));
    background-image: var(--header-bg, image-set(
        url('/static/images/services1.webp') type('image/webp'),
        url('/static/images/services1.png') type('image/png')
    ));
    background-size: cover;
    background-position: right 22%;
    background-repeat: no-repeat;
    z-index: 0;
}

/* Layer 2: horizontal navy gradient mask
   (opaque on the left for text legibility, transparent on the right) */
.page-header--photo .page-header-mask {
    position: absolute;
    inset: 0;
    background: linear-gradient(
        90deg,
        rgba(10, 22, 40, 0.96) 0%,
        rgba(10, 22, 40, 0.92) 22%,
        rgba(13, 31, 60, 0.70) 42%,
        rgba(13, 31, 60, 0.30) 60%,
        rgba(13, 31, 60, 0.05) 78%,
        rgba(13, 31, 60, 0.00) 100%
    );
    z-index: 1;
}

/* Tablet — shift photo slightly + soften the mask */
@media (max-width: 1024px) {
    .page-header--photo .page-header-image {
        background-position: 70% 22%;
    }
    .page-header--photo .page-header-mask {
        background: linear-gradient(
            90deg,
            rgba(10, 22, 40, 0.95) 0%,
            rgba(10, 22, 40, 0.85) 40%,
            rgba(13, 31, 60, 0.55) 70%,
            rgba(13, 31, 60, 0.25) 100%
        );
    }
}

/* Mobile — switch to a vertical wash so the photo becomes ambience */
@media (max-width: 768px) {
    /* Drop the fixed height on mobile — narrow text wraps to more lines,
       so let the content drive the height to avoid clipping. Restore the
       vertical padding (zeroed for desktop centering) so the header isn't
       flush against the navbar. */
    .page-header--photo {
        height: auto;
        padding-top: 9rem;
        padding-bottom: 4rem;
    }
    .page-header--photo .page-header-image {
        background-position: 75% 22%;
    }
    .page-header--photo .page-header-mask {
        background: linear-gradient(
            180deg,
            rgba(10, 22, 40, 0.55) 0%,
            rgba(10, 22, 40, 0.85) 45%,
            rgba(10, 22, 40, 0.95) 100%
        );
    }
}

/* ═════════════════════════════════════════════════════════
   AUTH (LOGIN / REGISTER) PAGE
   ═════════════════════════════════════════════════════════ */
.auth-section {
    position: relative;
    background:
        linear-gradient(180deg, #08111e 0%, #0a1628 55%, #0d1f3c 100%);
    padding: 9rem 5vw 6rem;
    overflow: hidden;
    isolation: isolate;
    min-height: calc(100vh - 80px);
    display: flex; align-items: center;
}
.auth-section::before {
    content: '';
    position: absolute; inset: 0;
    background-image:
        radial-gradient(circle at 15% 25%, rgba(200,169,110,0.10) 0%, transparent 45%),
        radial-gradient(circle at 85% 75%, rgba(26,58,107,0.55) 0%, transparent 50%);
    z-index: 0;
}
.auth-bg-glow {
    position: absolute;
    top: -160px; right: -120px;
    width: 520px; height: 520px;
    background: radial-gradient(circle, rgba(200,169,110,0.16) 0%, transparent 65%);
    z-index: 0; pointer-events: none;
}

.auth-grid {
    position: relative; z-index: 2;
    width: 100%;
    max-width: 1200px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.05fr;
    gap: 4rem;
    align-items: stretch;
}

/* Left aside */
.auth-aside {
    color: var(--mist);
    padding: 1rem 0;
}
.auth-aside .section-label { color: var(--accent); }
.auth-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 3.4vw, 2.8rem);
    font-weight: 300; line-height: 1.18;
    color: var(--white);
    margin: .6rem 0 1.4rem;
}
.auth-title em {
    font-style: italic;
    color: var(--accent);
    font-weight: 400;
}
.auth-lead {
    font-size: 1rem; line-height: 1.75;
    color: rgba(214,207,196,0.85);
    margin-bottom: 2rem;
    max-width: 460px;
}
.auth-benefits {
    list-style: none;
    display: flex; flex-direction: column;
    gap: .9rem;
    max-width: 460px;
}
.auth-benefits li {
    display: flex; align-items: center; gap: .9rem;
    font-size: .92rem; color: rgba(214,207,196,0.85);
}
.auth-benefits svg {
    width: 22px; height: 22px;
    color: var(--accent);
    flex-shrink: 0;
}

/* Right panel */
.auth-panel {
    background: var(--white);
    padding: 2.6rem 2.4rem;
    border: 1px solid rgba(200,169,110,0.28);
    box-shadow: 0 20px 50px rgba(8, 17, 30, 0.35);
    position: relative;
}
.auth-panel::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 3px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}

/* Tabs */
.auth-tabs {
    display: grid; grid-template-columns: 1fr 1fr;
    gap: 0;
    border-bottom: 1px solid rgba(200,169,110,0.28);
    margin-bottom: 1.8rem;
}
.auth-tab {
    background: transparent;
    border: none;
    font-family: 'DM Sans', sans-serif;
    font-size: .78rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    color: #888;
    padding: .9rem .4rem;
    cursor: pointer;
    position: relative;
    transition: color .25s;
}
.auth-tab:hover { color: var(--navy); }
.auth-tab.active { color: var(--navy); }
.auth-tab.active::after {
    content: '';
    position: absolute;
    left: 20%; right: 20%; bottom: -1px;
    height: 2px; background: var(--accent);
}

/* Forms */
.auth-form {
    display: flex; flex-direction: column;
    gap: 1.1rem;
}
.auth-form .form-row { margin-bottom: 0; gap: 1rem; }
.auth-form .form-field input,
.auth-form .form-field select {
    padding: .8rem .95rem;
}
.auth-form--hidden { display: none; }

.auth-row {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem;
    margin: .2rem 0 .5rem;
    font-size: .85rem;
}
.auth-check {
    display: inline-flex; align-items: center; gap: .55rem;
    cursor: pointer; color: #555;
    font-size: .85rem;
}
.auth-check input[type="checkbox"] {
    width: 16px; height: 16px;
    accent-color: var(--accent);
    cursor: pointer;
}
.auth-check-wide {
    line-height: 1.55;
    align-items: flex-start;
    margin: .4rem 0 .2rem;
}
.auth-check-wide input { margin-top: 3px; }
.auth-link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
    transition: color .25s;
}
.auth-link:hover { color: var(--navy); text-decoration: underline; }
.auth-link-inline { font-weight: 500; }

.auth-submit {
    width: 100%;
    justify-content: center;
    margin-top: .4rem;
    padding: 1rem 1.4rem;
}
.auth-switch {
    text-align: center;
    font-size: .88rem;
    color: #666;
    margin-top: .4rem;
}
.auth-switch a {
    color: var(--accent);
    text-decoration: none;
    font-weight: 600;
    margin-left: .3rem;
}
.auth-switch a:hover { color: var(--navy); text-decoration: underline; }

/* Flash message */
.auth-flash {
    display: flex; align-items: flex-start; gap: .7rem;
    background: rgba(200,169,110,0.10);
    border-left: 3px solid var(--accent);
    padding: .9rem 1.1rem;
    margin-bottom: 1.4rem;
    color: var(--navy);
    font-size: .9rem; line-height: 1.55;
}
.auth-flash svg {
    width: 20px; height: 20px;
    color: var(--accent); flex-shrink: 0;
    margin-top: 2px;
}
.auth-flash-info {
    background: rgba(26, 58, 107, 0.06);
    border-left-color: #1a3a6b;
    color: #1a3a6b;
}
.auth-flash-info svg { color: #1a3a6b; }

.auth-flash-error {
    background: rgba(192, 57, 43, 0.08);
    border-left-color: #c0392b;
    color: #8e2a1f;
}
.auth-flash-error svg { color: #c0392b; }

/* OAuth (Google) button */
.oauth-btn {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .7rem;
    width: 100%;
    padding: .85rem 1.2rem;
    background: var(--white);
    border: 1px solid #dadce0;
    border-radius: 4px;
    color: #3c4043;
    font-family: 'DM Sans', sans-serif;
    font-size: .92rem; font-weight: 500;
    text-decoration: none;
    transition: background .2s, border-color .2s, box-shadow .2s, transform .15s;
    cursor: pointer;
}
.oauth-btn svg {
    width: 20px; height: 20px;
    flex-shrink: 0;
}
.oauth-btn:hover {
    background: #f8f9fa;
    border-color: #c4c7c9;
    box-shadow: 0 1px 2px rgba(60,64,67,0.08), 0 1px 3px 1px rgba(60,64,67,0.05);
    transform: translateY(-1px);
}
.oauth-btn:active {
    background: #f1f3f4;
    transform: translateY(0);
}

/* Divider between OAuth and email form */
.oauth-divider {
    display: flex; align-items: center;
    gap: .9rem;
    margin: .2rem 0 .1rem;
    color: #999;
    font-size: .76rem;
    letter-spacing: .06em;
    text-transform: uppercase;
}
.oauth-divider::before,
.oauth-divider::after {
    content: '';
    flex: 1;
    height: 1px;
    background: rgba(200,169,110,0.28);
}

/* ── Password input with eye toggle ── */
.pw-wrap {
    position: relative;
    display: flex; align-items: stretch;
}
.pw-wrap input {
    width: 100%;
    padding-right: 3.4rem !important;
}
/* Larger variant — for register / new-password fields */
.pw-wrap--lg input {
    padding: 1.15rem 3.4rem 1.15rem 1.1rem !important;
    font-size: 1.02rem !important;
    min-height: 56px;
    letter-spacing: .04em;
}
.pw-toggle {
    position: absolute;
    right: .7rem; top: 50%;
    transform: translateY(-50%);
    width: 36px; height: 36px;
    background: transparent;
    border: none;
    color: #5a5a5a;
    cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    padding: 0;
    transition: color .2s, background .2s;
    border-radius: 50%;
}
.pw-toggle:hover { color: var(--navy); background: rgba(10,22,40,0.06); }
.pw-toggle svg { width: 22px; height: 22px; display: block; }
/* Default = password hidden → show the CLOSED eye (with slash) */
.pw-toggle .pw-eye-open   { display: none; }
.pw-toggle .pw-eye-closed { display: block; }
/* When .pw-showing = password visible → show the OPEN eye */
.pw-toggle.pw-showing .pw-eye-open   { display: block; }
.pw-toggle.pw-showing .pw-eye-closed { display: none; }
.pw-toggle.pw-showing { color: var(--accent); }

/* Info tooltip next to "Password" label */
.pw-label {
    display: flex; align-items: center;
    gap: .35rem;
}
.pw-info {
    position: relative;
    display: inline-flex; align-items: center;
    color: #999;
    cursor: help;
    line-height: 0;
}
.pw-info svg { width: 14px; height: 14px; }
.pw-info:hover, .pw-info:focus-within {
    color: var(--navy);
    outline: none;
}
.pw-tooltip {
    position: absolute;
    bottom: calc(100% + 10px);
    left: -8px;
    width: 280px;
    background: #2c2c2c;
    color: #f5f5f5;
    padding: .9rem 1rem;
    font-size: .8rem;
    line-height: 1.6;
    letter-spacing: 0;
    text-transform: none;
    font-weight: 400;
    border-radius: 4px;
    box-shadow: 0 8px 20px rgba(0,0,0,0.18);
    opacity: 0; visibility: hidden;
    transition: opacity .2s, visibility .2s, transform .2s;
    transform: translateY(4px);
    pointer-events: none;
    z-index: 10;
}
.pw-tooltip::after {
    content: '';
    position: absolute;
    bottom: -6px; left: 14px;
    width: 0; height: 0;
    border-left: 6px solid transparent;
    border-right: 6px solid transparent;
    border-top: 6px solid #2c2c2c;
}
.pw-info:hover .pw-tooltip,
.pw-info:focus-within .pw-tooltip {
    opacity: 1; visibility: visible;
    transform: translateY(0);
}

/* ── Password strength meter ── */
.pw-strength {
    display: grid;
    grid-template-columns: repeat(4, 1fr) auto;
    gap: .3rem;
    align-items: center;
    margin-top: .55rem;
    font-family: 'DM Sans', sans-serif;
}
.pw-bar {
    height: 4px;
    background: rgba(200,169,110,0.18);
    border-radius: 2px;
    transition: background .25s;
}
.pw-strength-label {
    grid-column: 1 / -1;
    font-style: normal;
    font-size: .72rem;
    color: #888;
    letter-spacing: .06em;
    margin-top: .15rem;
}
/* states */
.pw-strength-1 .pw-bar.on { background: #e74c3c; }
.pw-strength-1 .pw-strength-label { color: #e74c3c; }
.pw-strength-2 .pw-bar.on { background: #f39c12; }
.pw-strength-2 .pw-strength-label { color: #d68910; }
.pw-strength-3 .pw-bar.on { background: #c8a96e; }
.pw-strength-3 .pw-strength-label { color: var(--accent); }
.pw-strength-4 .pw-bar.on { background: #27ae60; }
.pw-strength-4 .pw-strength-label { color: #1e8449; }

/* Confirm-password match hint */
.pw-match-hint {
    font-size: .78rem;
    margin-top: .4rem;
    display: block;
    min-height: 1em;
    font-family: 'DM Sans', sans-serif;
}
.pw-match-ok  { color: #1e8449; }
.pw-match-err { color: #c0392b; }

/* ── OTP verify code input ── */
.verify-wrap {
    position: relative; z-index: 2;
    width: 100%;
    max-width: 560px;
    margin: 0 auto;
}
.verify-panel {
    text-align: center;
    padding: 3rem 2.6rem 2.4rem;
}
.verify-icon {
    width: 64px; height: 64px;
    margin: 0 auto 1.4rem;
    border: 1px solid rgba(200,169,110,0.5);
    border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    color: var(--accent);
    background: rgba(200,169,110,0.08);
}
.verify-icon svg { width: 30px; height: 30px; }
.verify-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.6rem, 2.6vw, 2.1rem);
    font-weight: 300; line-height: 1.2;
    color: var(--navy);
    margin: .4rem 0 .9rem;
}
.verify-title em {
    font-style: italic;
    color: var(--accent);
    font-weight: 400;
}
.verify-lead {
    font-size: .95rem; line-height: 1.7;
    color: #555;
    margin-bottom: 1.6rem;
}
.verify-lead strong { color: var(--navy); }
.verify-form { margin: 1.4rem 0 .5rem; }

.otp-input {
    display: flex; justify-content: center;
    gap: .55rem;
    margin: .8rem 0 1.6rem;
}
.otp-box {
    width: 52px; height: 60px;
    text-align: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.85rem; font-weight: 600;
    color: var(--navy);
    border: 1px solid rgba(200,169,110,0.4);
    background: var(--white);
    border-radius: 4px;
    outline: none;
    transition: border-color .2s, box-shadow .2s, background .2s;
}
.otp-box:focus {
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,169,110,0.18);
    background: #fdfaf5;
}
.otp-box:not(:placeholder-shown),
.otp-box[value]:not([value=""]) {
    background: #fdfaf5;
}

.verify-resend {
    margin-top: 1.4rem;
    font-size: .88rem;
    color: #777;
    display: flex; align-items: center;
    justify-content: center;
    gap: .4rem;
    flex-wrap: wrap;
}
.verify-resend-form {
    display: inline; margin: 0; padding: 0;
}
.verify-resend-form button {
    background: none; border: none;
    color: var(--accent);
    font-weight: 600;
    cursor: pointer;
    padding: 0;
    font-size: .88rem;
    font-family: inherit;
}
.verify-resend-form button:hover {
    color: var(--navy);
    text-decoration: underline;
}
.verify-back {
    margin-top: 1rem;
    font-size: .85rem;
    text-align: center;
}

/* Email verified badge on account page */
.badge-verified {
    display: inline-block;
    margin-left: .4rem;
    padding: .15rem .5rem;
    background: rgba(39, 174, 96, 0.12);
    color: #1e8449;
    font-size: .68rem; font-weight: 600;
    letter-spacing: .08em;
    text-transform: uppercase;
    border-radius: 99px;
    vertical-align: middle;
}

@media (max-width: 560px) {
    .otp-box { width: 42px; height: 52px; font-size: 1.5rem; }
    .otp-input { gap: .35rem; }
    .verify-panel { padding: 2.4rem 1.4rem 2rem; }
}

/* ═════════════════════════════════════════════════════════
   LEGAL PAGES (Terms of Use / Privacy Policy)
   ═════════════════════════════════════════════════════════ */
.legal-updated {
    margin-top: 1.4rem;
    font-size: .82rem;
    color: rgba(214,207,196,0.65);
    letter-spacing: .06em;
}
.legal-updated strong {
    color: var(--accent);
    font-weight: 500;
}

.legal-section {
    background: var(--white);
    padding: 5rem 5vw 6rem;
}
.legal-grid {
    max-width: 1180px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: 260px 1fr;
    gap: 4rem;
    align-items: start;
}

/* Sidebar TOC */
.legal-toc {
    position: sticky;
    top: 110px;
    padding: 1.6rem 1.3rem;
    background: #f7f2e9;
    border-left: 3px solid var(--accent);
    align-self: start;
    max-height: calc(100vh - 140px);
    overflow-y: auto;
}
.legal-toc-title {
    font-family: 'DM Sans', sans-serif;
    font-size: .72rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent);
    font-weight: 600;
    margin: 0 0 1rem;
}
.legal-toc ol {
    list-style: none;
    padding: 0; margin: 0;
    display: flex; flex-direction: column;
    gap: .55rem;
}
.legal-toc a {
    display: block;
    font-size: .85rem;
    color: #555;
    text-decoration: none;
    line-height: 1.45;
    padding: .25rem 0;
    border-left: 2px solid transparent;
    padding-left: .55rem;
    margin-left: -.55rem;
    transition: color .2s, border-color .2s, background .2s;
}
.legal-toc a:hover {
    color: var(--navy);
    border-color: var(--accent);
    background: rgba(200,169,110,0.08);
}

/* Article content */
.legal-content {
    max-width: 760px;
}
.legal-content section {
    margin-bottom: 3rem;
    scroll-margin-top: 100px;
}
.legal-content section:last-child {
    margin-bottom: 0;
}
.legal-content h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem;
    font-weight: 600;
    color: var(--navy);
    margin: 0 0 1.1rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid rgba(200,169,110,0.28);
    line-height: 1.25;
}
.legal-content h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: 1rem;
    font-weight: 600;
    color: var(--navy);
    margin: 1.8rem 0 .7rem;
    letter-spacing: .01em;
}
.legal-content p {
    font-size: .95rem;
    line-height: 1.8;
    color: #3d3d3d;
    margin: 0 0 1rem;
}
.legal-content p:last-child {
    margin-bottom: 0;
}
.legal-content strong {
    color: var(--navy);
    font-weight: 600;
}
.legal-content em {
    font-style: italic;
    color: #5a5a5a;
}
.legal-content a {
    color: var(--accent);
    text-decoration: none;
    border-bottom: 1px solid rgba(200,169,110,0.4);
    transition: color .2s, border-color .2s;
}
.legal-content a:hover {
    color: var(--navy);
    border-bottom-color: var(--navy);
}
.legal-content ul {
    margin: .4rem 0 1.2rem;
    padding-left: 1.4rem;
    list-style: none;
}
.legal-content ul li {
    position: relative;
    font-size: .94rem;
    line-height: 1.75;
    color: #3d3d3d;
    margin-bottom: .55rem;
    padding-left: 1.1rem;
}
.legal-content ul li::before {
    content: '';
    position: absolute;
    left: 0; top: .75rem;
    width: 6px; height: 1px;
    background: var(--accent);
}

/* Definition lists (e.g., legal info, retention periods) */
.legal-info-list {
    display: grid;
    grid-template-columns: 200px 1fr;
    gap: .8rem 1.5rem;
    margin: 1rem 0 1.4rem;
    padding: 1.2rem 1.4rem;
    background: #f9f5ec;
    border-left: 2px solid var(--accent);
}
.legal-info-list dt {
    font-family: 'DM Sans', sans-serif;
    font-size: .76rem;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: #777;
    font-weight: 500;
    padding-top: .15rem;
}
.legal-info-list dd {
    font-size: .94rem;
    color: var(--navy);
    margin: 0;
    line-height: 1.55;
}
.legal-info-list dd a {
    color: var(--accent);
    border-bottom-color: rgba(200,169,110,0.4);
}

/* Callout box (e.g., "We don't collect sensitive data") */
.legal-callout {
    background: rgba(200,169,110,0.08);
    border-left: 3px solid var(--accent);
    padding: 1rem 1.2rem !important;
    margin: 1.2rem 0 !important;
    font-size: .92rem !important;
    color: #4a4a4a !important;
}

/* Contact list at bottom */
.legal-contact-list {
    list-style: none !important;
    padding: 1rem 1.4rem !important;
    background: #f9f5ec;
    border-left: 2px solid var(--accent);
    margin: 1rem 0 !important;
}
.legal-contact-list li {
    padding-left: 0 !important;
    margin-bottom: .35rem !important;
}
.legal-contact-list li::before {
    display: none !important;
}

/* Footer bottom — legal links */
.footer-bottom a {
    color: rgba(214,207,196,0.7);
    text-decoration: none;
    transition: color .2s;
}
.footer-bottom a:hover {
    color: var(--accent);
}

/* Responsive */
@media (max-width: 968px) {
    .legal-grid {
        grid-template-columns: 1fr;
        gap: 2rem;
    }
    .legal-toc {
        position: static;
        max-height: none;
        order: 0;
    }
    .legal-toc ol {
        display: grid;
        grid-template-columns: 1fr 1fr;
        gap: .35rem .8rem;
    }
}
@media (max-width: 600px) {
    .legal-section { padding: 3.5rem 5vw 4rem; }
    .legal-info-list {
        grid-template-columns: 1fr;
        gap: .15rem 0;
    }
    .legal-info-list dt {
        margin-top: .8rem;
    }
    .legal-info-list dt:first-child {
        margin-top: 0;
    }
    .legal-content h2 { font-size: 1.4rem; }
    .legal-toc ol { grid-template-columns: 1fr; }
}

/* Responsive */
@media (max-width: 1024px) {
    .auth-grid { grid-template-columns: 1fr; gap: 2.5rem; }
    .auth-aside { text-align: center; }
    .auth-lead, .auth-benefits { margin-left: auto; margin-right: auto; }
    .auth-benefits li { justify-content: flex-start; max-width: 380px; margin: 0 auto; }
}
@media (max-width: 768px) {
    .auth-section { padding: 8rem 5vw 4rem; }
    .auth-panel { padding: 2rem 1.4rem; }
    .auth-form .form-row { grid-template-columns: 1fr; }
    .auth-row { flex-direction: column; align-items: flex-start; gap: .6rem; }
}

/* ═════════════════════════════════════════════════════════
   ACCOUNT (USER DASHBOARD) PAGE
   ═════════════════════════════════════════════════════════ */
.account-section {
    position: relative;
    background: #f7f2e9;
    padding: 8rem 5vw 5rem;
    min-height: calc(100vh - 80px);
    isolation: isolate;
}
.account-bg-glow {
    position: absolute;
    top: 0; right: 0;
    width: 520px; height: 520px;
    background: radial-gradient(circle, rgba(200,169,110,0.18) 0%, transparent 65%);
    z-index: 0; pointer-events: none;
}
.account-wrap {
    position: relative; z-index: 1;
    max-width: 1200px;
    margin: 0 auto;
}

.account-header {
    margin-bottom: 2.5rem;
    padding-bottom: 1.8rem;
    border-bottom: 1px solid rgba(200,169,110,0.30);
}
.account-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2rem, 3.4vw, 2.8rem);
    font-weight: 300; line-height: 1.18;
    color: var(--navy);
    margin: .4rem 0 .8rem;
}
.account-title em {
    font-style: italic;
    color: var(--accent);
    font-weight: 400;
}
.account-subtitle {
    font-size: 1rem; line-height: 1.7;
    color: #555;
    max-width: 620px;
}

.account-grid {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 2rem;
    margin-bottom: 2rem;
}

.account-card {
    background: var(--white);
    padding: 2rem 2rem 1.8rem;
    border: 1px solid rgba(200,169,110,0.28);
    position: relative;
}
.account-card::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.account-card-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem; font-weight: 600;
    color: var(--navy);
    display: flex; align-items: center; gap: .7rem;
    padding-bottom: 1rem; margin-bottom: 1.4rem;
    border-bottom: 1px solid rgba(200,169,110,0.22);
}
.account-card-title svg {
    width: 22px; height: 22px;
    color: var(--accent);
    flex-shrink: 0;
}

/* Profile info list */
.account-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.2rem 2rem;
}
.account-info > div {
    display: flex; flex-direction: column;
    gap: .3rem;
}
.account-info dt {
    font-size: .68rem; letter-spacing: .14em;
    text-transform: uppercase;
    color: #888; font-weight: 500;
}
.account-info dd {
    font-size: .98rem;
    color: var(--navy);
    font-weight: 500;
    word-break: break-word;
}
.account-info dd.capitalize { text-transform: capitalize; }

/* Side column */
.account-side {
    display: flex; flex-direction: column;
    gap: 1.2rem;
}

.account-card-accent {
    background: linear-gradient(180deg, #0a1628 0%, #0d1f3c 100%);
    color: var(--mist);
    border-color: var(--navy);
}
.account-card-accent::before {
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
    opacity: .8;
}
.account-card-accent .account-card-title {
    color: var(--white);
    border-bottom-color: rgba(200,169,110,0.22);
}

.account-action {
    display: flex; align-items: center;
    gap: 1rem;
    padding: .9rem .2rem;
    border-bottom: 1px solid rgba(200,169,110,0.15);
    text-decoration: none;
    color: var(--mist);
    transition: transform .2s, color .2s;
}
.account-action:last-child { border-bottom: none; }
.account-action:hover {
    color: var(--white);
    transform: translateX(3px);
}
.account-action-icon {
    font-size: 1.4rem; line-height: 1;
    flex-shrink: 0;
}
.account-action-text {
    flex: 1;
    display: flex; flex-direction: column; gap: .15rem;
}
.account-action-text strong {
    font-size: .92rem; font-weight: 600;
    color: var(--white);
    letter-spacing: .02em;
}
.account-action-text em {
    font-style: normal;
    font-size: .76rem;
    color: rgba(214,207,196,0.65);
}
.account-action-arrow {
    color: var(--accent);
    font-size: 1.1rem;
    transition: transform .2s;
}
.account-action:hover .account-action-arrow {
    transform: translateX(3px);
}

/* Logout button */
.btn-logout {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .6rem;
    padding: .85rem 1.3rem;
    background: var(--white);
    border: 1px solid rgba(192, 57, 43, 0.3);
    color: #c0392b;
    font-family: 'DM Sans', sans-serif;
    font-size: .78rem; font-weight: 600;
    letter-spacing: .14em; text-transform: uppercase;
    text-decoration: none;
    transition: background .25s, color .25s, border-color .25s;
}
.btn-logout svg {
    width: 16px; height: 16px;
}
.btn-logout:hover {
    background: #c0392b;
    color: var(--white);
    border-color: #c0392b;
}

/* Empty state for orders */
.account-card-empty .account-empty-state {
    display: flex; flex-direction: column;
    align-items: center; gap: 1.4rem;
    padding: 2rem 1rem;
    text-align: center;
}
.account-card-empty .account-empty-state p {
    color: #777;
    font-size: 1rem;
}

@media (max-width: 1024px) {
    .account-grid { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .account-section { padding: 7rem 5vw 4rem; }
    .account-card { padding: 1.5rem 1.3rem; }
    .account-info { grid-template-columns: 1fr; gap: 1rem; }
}

/* ═════════════════════════════════════════════════════════
   SHOP / CATALOG / CART / CHECKOUT / DASHBOARD EXTENSIONS
   ═════════════════════════════════════════════════════════ */

.visually-hidden {
    position: absolute !important;
    width: 1px; height: 1px;
    margin: -1px; padding: 0; overflow: hidden;
    clip: rect(0 0 0 0); border: 0;
}

/* Modifier: small primary button */
.btn-primary--sm {
    padding: .65rem 1.3rem;
    font-size: .72rem;
    letter-spacing: .12em;
}
.btn-primary[disabled],
.btn-primary--sm[disabled] {
    background: #c7bfb1;
    color: #fff;
    cursor: not-allowed;
    transform: none;
    pointer-events: none;
}

/* Generic alert blocks for account pages */
.account-alert {
    padding: .95rem 1.2rem;
    margin: 0 0 1.4rem;
    border-left: 3px solid var(--accent);
    background: #fff;
    font-size: .92rem;
    color: var(--text);
}
.account-alert-error  { border-left-color: #c0392b; color: #8b271c; background: #fdf3f1; }
.account-alert-info   { border-left-color: #2e7d32; color: #1b5e20; background: #f1f8f3; }
.account-alert-cancel { border-left-color: #9e9e9e; color: #555; background: #f5f5f5; }

/* Soft link arrow */
.link-arrow {
    display: inline-block;
    font-size: .82rem; font-weight: 600;
    letter-spacing: .04em;
    color: var(--navy);
    text-decoration: none;
    padding: .3rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.4);
    transition: color .2s, border-color .2s;
}
.link-arrow:hover { color: var(--accent); border-color: var(--accent); }

/* Link-style button (used inside forms) */
.link-btn {
    background: none; border: 0; padding: 0;
    font: inherit;
    font-size: .82rem; font-weight: 600;
    color: var(--navy);
    cursor: pointer;
    text-decoration: none;
    letter-spacing: .02em;
    border-bottom: 1px solid rgba(200,169,110,0.4);
    transition: color .2s, border-color .2s;
}
.link-btn:hover { color: var(--accent); border-color: var(--accent); }
.link-btn--danger { color: #c0392b; border-bottom-color: rgba(192,57,43,0.3); }
.link-btn--danger:hover { color: #a02619; border-bottom-color: #a02619; }
.inline-form { display: inline; }

/* Badges */
.badge-default {
    display: inline-block;
    font-size: .65rem; letter-spacing: .14em; text-transform: uppercase;
    color: var(--navy);
    background: var(--accent-light);
    padding: .2rem .55rem;
    border-radius: 2px;
    font-weight: 600;
}
.badge-free {
    display: inline-block;
    font-size: .72rem; letter-spacing: .08em; text-transform: uppercase;
    color: #1b5e20;
    background: #d8efde;
    padding: .15rem .6rem;
    border-radius: 2px;
    font-weight: 600;
}

/* Card link action (top-right of card title) */
.account-card-title {
    flex-wrap: wrap;
}
.card-link-action {
    margin-left: auto;
    font-family: 'DM Sans', sans-serif;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    color: var(--accent);
    text-decoration: none;
    transition: color .2s;
    padding-bottom: 0;
    border: 0;
}
.card-link-action:hover { color: var(--navy); }

/* Step bullet for checkout titles */
.step-bullet {
    display: inline-flex;
    align-items: center; justify-content: center;
    width: 26px; height: 26px;
    border-radius: 50%;
    background: var(--accent);
    color: var(--navy);
    font-family: 'DM Sans', sans-serif;
    font-size: .85rem; font-weight: 700;
    margin-right: .15rem;
}

/* ─── Account sub-nav ─── */
.account-subnav {
    display: flex;
    flex-wrap: wrap;
    gap: .35rem;
    margin: 0 0 2rem;
    padding: .35rem;
    background: #fff;
    border: 1px solid rgba(200,169,110,0.28);
    border-radius: 2px;
}
.account-subnav a {
    flex: 1 1 auto;
    text-align: center;
    text-decoration: none;
    font-size: .72rem; font-weight: 600;
    letter-spacing: .12em; text-transform: uppercase;
    color: #777;
    padding: .75rem .9rem;
    transition: background .2s, color .2s;
    white-space: nowrap;
}
.account-subnav a:hover { color: var(--navy); }
.account-subnav a.is-active {
    background: var(--navy);
    color: var(--accent-light);
}

/* ─── Dashboard quick stats ─── */
.dash-stats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
    margin: 0 0 2rem;
}
.dash-stat {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.28);
    text-decoration: none;
    color: var(--navy);
    padding: 1.3rem 1.2rem;
    display: flex; flex-direction: column;
    gap: .25rem;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    position: relative;
    overflow: hidden;
}
.dash-stat::before {
    content: ''; position: absolute;
    top: 0; left: 0; right: 0; height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.dash-stat:hover {
    transform: translateY(-2px);
    border-color: var(--accent);
    box-shadow: 0 6px 20px -8px rgba(10,22,40,0.18);
}
.dash-stat-ico { font-size: 1.6rem; line-height: 1; }
.dash-stat-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 2.2rem; font-weight: 600;
    color: var(--navy); line-height: 1;
}
.dash-stat-lbl {
    font-size: .7rem; letter-spacing: .14em;
    text-transform: uppercase; color: #888;
    font-weight: 500;
}

/* Grids: narrow & equal */
.account-grid--narrow { grid-template-columns: minmax(0, 720px) 1fr; }
.account-grid--equal  { grid-template-columns: 1fr 1fr; }
@media (max-width: 1024px) {
    .account-grid--narrow,
    .account-grid--equal { grid-template-columns: 1fr; }
}

/* ─── Forms inside account ─── */
.account-form { padding-bottom: 2rem; }
.account-form .form-row {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.1rem;
}
@media (max-width: 600px) {
    .account-form .form-row { grid-template-columns: 1fr; }
}
.acc-field {
    display: flex; flex-direction: column;
    gap: .4rem;
    margin: 0 0 1rem;
}
.acc-field > span {
    font-size: .7rem; letter-spacing: .14em;
    text-transform: uppercase;
    color: #777; font-weight: 500;
}
.acc-field input[type="text"],
.acc-field input[type="email"],
.acc-field input[type="tel"],
.acc-field input[type="password"],
.acc-field input[type="number"] {
    font: inherit;
    font-size: .95rem;
    padding: .75rem .9rem;
    border: 1px solid rgba(200,169,110,0.45);
    border-radius: 2px;
    background: #fff;
    color: var(--navy);
    transition: border-color .2s, box-shadow .2s;
}
.acc-field input:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,169,110,0.18);
}
.acc-field input[disabled] { background: #f7f2e9; color: #888; }
.acc-hint { font-size: .75rem; color: #888; margin-top: .15rem; }

.acc-checkbox {
    display: inline-flex; align-items: center;
    gap: .55rem;
    cursor: pointer;
    margin: .3rem 0 1rem;
    font-size: .9rem;
    color: var(--navy);
}
.acc-checkbox input { accent-color: var(--accent); }

.form-actions {
    display: flex; justify-content: space-between; align-items: center;
    gap: 1rem;
    margin-top: 1.4rem;
    flex-wrap: wrap;
}

.account-card-soft {
    background: #fff;
    border: 1px dashed rgba(200,169,110,0.45);
    padding: 1.5rem 1.4rem;
}
.soft-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem;
    color: var(--navy);
    margin: 0 0 .5rem;
}
.account-card-soft p { font-size: .92rem; color: #666; margin-bottom: .8rem; }

/* ─── Shop / catalog ─── */
.shop-section { background: #f7f2e9; padding: 5rem 5vw 5rem; position: relative; }
.shop-wrap   { max-width: 1280px; margin: 0 auto; }
.shop-header {
    display: flex; justify-content: space-between; align-items: flex-end;
    flex-wrap: wrap; gap: 1.5rem;
    margin-bottom: 2rem;
}
.shop-search {
    display: flex; align-items: center;
    background: #fff; border: 1px solid rgba(200,169,110,0.45);
    border-radius: 2px;
    overflow: hidden;
    min-width: 280px;
}
.shop-search input {
    flex: 1; border: 0; padding: .75rem 1rem;
    font: inherit; font-size: .9rem;
    color: var(--navy); background: transparent;
}
.shop-search input:focus { outline: none; }
.shop-search button {
    background: var(--navy); color: var(--accent-light);
    border: 0; padding: 0 1rem; cursor: pointer;
    height: 42px; display: inline-flex; align-items: center;
    transition: background .2s;
}
.shop-search button:hover { background: var(--deep); }
.shop-search button svg { width: 18px; height: 18px; }

/* ─── Shop layout: sidebar (categories) + main (grid) ─── */
.shop-layout {
    display: grid;
    grid-template-columns: 240px minmax(0, 1fr);
    gap: 2.5rem;
    align-items: flex-start;
    margin-top: 2.5rem;
}

/* Sidebar */
.shop-sidebar {
    position: sticky;
    top: 100px;
    align-self: flex-start;
}
.shop-sidebar-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 600;
    color: var(--navy);
    margin: 0 0 1rem;
    padding-bottom: .8rem;
    border-bottom: 1px solid rgba(200,169,110,0.35);
}
.shop-cat-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.8rem;
    display: flex;
    flex-direction: column;
}
.shop-cat-link {
    display: flex; align-items: center;
    gap: .7rem;
    padding: .65rem .3rem;
    text-decoration: none;
    color: #5b5b5b;
    font-size: .9rem;
    border-bottom: 1px solid rgba(200,169,110,0.16);
    transition: color .2s, padding-left .2s, background .2s;
    position: relative;
}
.shop-cat-link:last-child { border-bottom: 0; }
.shop-cat-link:hover {
    color: var(--navy);
    padding-left: .55rem;
}
.shop-cat-link::before {
    content: '';
    position: absolute;
    left: 0; top: 50%;
    width: 2px; height: 0;
    background: var(--accent);
    transform: translateY(-50%);
    transition: height .25s ease;
}
.shop-cat-link.is-active {
    color: var(--navy);
    font-weight: 600;
    padding-left: .85rem;
}
.shop-cat-link.is-active::before { height: 60%; }
.shop-cat-ico {
    font-size: 1.05rem;
    width: 1.4rem;
    text-align: center;
    flex-shrink: 0;
}
.shop-cat-name { flex: 1; }
.shop-cat-count {
    font-size: .75rem;
    color: #999;
    background: rgba(200,169,110,0.12);
    padding: .12rem .5rem;
    border-radius: 999px;
    letter-spacing: .04em;
}
.shop-cat-link.is-active .shop-cat-count {
    background: var(--accent);
    color: var(--navy);
    font-weight: 600;
}

/* Sidebar aside card (B2B quote callout) */
.shop-sidebar-aside {
    background: linear-gradient(180deg, var(--navy) 0%, var(--deep) 100%);
    color: var(--mist);
    padding: 1.4rem 1.3rem;
    position: relative;
}
.shop-sidebar-aside::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 2px;
    background: linear-gradient(90deg, transparent, var(--accent), transparent);
}
.sidebar-aside-eyebrow {
    margin: 0 0 .4rem;
    font-size: .62rem;
    letter-spacing: .2em;
    text-transform: uppercase;
    color: var(--accent);
    font-weight: 600;
}
.sidebar-aside-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    font-weight: 400;
    line-height: 1.2;
    color: var(--white);
    margin: 0 0 .6rem;
}
.sidebar-aside-text {
    font-size: .82rem;
    line-height: 1.55;
    color: rgba(214,207,196,0.75);
    margin: 0 0 1rem;
}
.sidebar-aside-cta {
    display: inline-block;
    color: var(--accent-light);
    text-decoration: none;
    font-size: .8rem;
    letter-spacing: .1em;
    font-weight: 600;
    border-bottom: 1px solid rgba(200,169,110,0.5);
    padding-bottom: 2px;
    transition: color .2s, border-color .2s;
}
.sidebar-aside-cta:hover { color: var(--white); border-color: var(--accent); }

/* Main column toolbar */
.shop-main { min-width: 0; }
.shop-toolbar {
    display: flex; justify-content: space-between; align-items: center;
    flex-wrap: wrap; gap: 1rem;
    padding: 1rem 0 1.2rem;
    border-bottom: 1px solid rgba(200,169,110,0.22);
    margin-bottom: 1.6rem;
}
.shop-toolbar-info { display: flex; flex-direction: column; gap: .2rem; }
.shop-active-cat {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    color: var(--navy);
    margin: 0;
    font-weight: 600;
}

/* Inside-shop grid: tighter columns since sidebar takes 240px */
.product-grid--in-shop {
    grid-template-columns: repeat(auto-fill, minmax(230px, 1fr));
    gap: 1.3rem;
}

/* Mobile: collapse sidebar to horizontal scroll above products */
@media (max-width: 900px) {
    .shop-layout {
        grid-template-columns: 1fr;
        gap: 1.2rem;
        margin-top: 1.5rem;
    }
    .shop-sidebar {
        position: static;
        top: auto;
    }
    .shop-sidebar-title {
        font-size: 1.1rem;
        margin-bottom: .6rem;
        padding-bottom: .5rem;
    }
    .shop-cat-list {
        flex-direction: row;
        overflow-x: auto;
        gap: .5rem;
        margin-bottom: 1rem;
        scrollbar-width: thin;
        -webkit-overflow-scrolling: touch;
        padding-bottom: .5rem;
    }
    .shop-cat-list li { flex-shrink: 0; }
    .shop-cat-link {
        flex-shrink: 0;
        white-space: nowrap;
        border: 1px solid rgba(200,169,110,0.4);
        border-bottom: 1px solid rgba(200,169,110,0.4);
        border-radius: 999px;
        padding: .5rem 1rem;
    }
    .shop-cat-link::before { display: none; }
    .shop-cat-link.is-active {
        background: var(--navy);
        color: var(--accent-light);
        border-color: var(--navy);
        padding-left: 1rem;
    }
    .shop-cat-link.is-active .shop-cat-name { color: var(--accent-light); }
    .shop-cat-count { display: none; }
    .shop-sidebar-aside { display: none; }
}
.shop-count {
    font-size: .8rem; letter-spacing: .08em;
    color: #666; text-transform: uppercase;
    font-weight: 500;
}
.shop-sort { display: flex; align-items: center; gap: .6rem; }
.shop-sort label { font-size: .78rem; color: #777; letter-spacing: .06em; }
.shop-sort select {
    font: inherit;
    border: 1px solid rgba(200,169,110,0.45);
    padding: .45rem .8rem;
    background: #fff;
    color: var(--navy);
    border-radius: 2px;
    font-size: .85rem;
}

/* Product grid */
.product-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
    gap: 1.5rem;
}
.product-card {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.25);
    display: flex; flex-direction: column;
    transition: transform .2s, border-color .2s, box-shadow .2s;
    position: relative; overflow: hidden;
}
.product-card:hover {
    transform: translateY(-3px);
    border-color: var(--accent);
    box-shadow: 0 8px 24px -10px rgba(10,22,40,0.2);
}
.product-thumb {
    position: relative;
    background: linear-gradient(180deg, #f7f2e9 0%, #efe6d4 100%);
    height: 160px;
    display: flex; align-items: center; justify-content: center;
    border-bottom: 1px solid rgba(200,169,110,0.25);
}
.product-icon { font-size: 4.5rem; line-height: 1; filter: drop-shadow(0 4px 6px rgba(10,22,40,0.1)); }
.product-photo {
    position: absolute; inset: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
}
.product-cat-tag {
    position: absolute;
    top: .7rem; left: .7rem;
    font-size: .62rem; letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--navy);
    background: rgba(255,255,255,0.85);
    padding: .25rem .55rem;
    font-weight: 600;
}
.product-fav-form {
    position: absolute;
    top: .55rem; right: .55rem;
}
.product-fav {
    background: rgba(255,255,255,0.92);
    border: 0;
    width: 36px; height: 36px;
    border-radius: 50%;
    display: inline-flex; align-items: center; justify-content: center;
    cursor: pointer;
    color: #c0392b;
    transition: background .2s, transform .2s, color .2s;
}
.product-fav:hover { background: #fff; transform: scale(1.08); }
.product-fav.is-active { color: #c0392b; }
.product-fav svg { width: 18px; height: 18px; }

.product-body {
    padding: 1.1rem 1.1rem 1.2rem;
    display: flex; flex-direction: column;
    gap: .55rem;
    flex: 1;
}
.product-name {
    font-family: 'DM Sans', sans-serif;
    font-size: 1rem; font-weight: 600;
    color: var(--navy);
    line-height: 1.3;
    margin: 0;
}
.product-desc {
    font-size: .82rem; line-height: 1.55;
    color: #666;
    flex: 1;
}
.product-price-row {
    display: flex; align-items: baseline;
    gap: .35rem;
    margin: .2rem 0;
}
.product-price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; font-weight: 600;
    color: var(--accent);
    letter-spacing: .01em;
}
.product-unit { font-size: .8rem; color: #888; }

.product-add {
    display: flex; align-items: stretch; gap: .55rem;
    margin-top: .3rem;
}
.product-login-cta { width: 100%; justify-content: center; }

.qty-input {
    display: inline-flex; align-items: stretch;
    border: 1px solid rgba(200,169,110,0.45);
    border-radius: 2px;
    background: #fff;
    overflow: hidden;
}
.qty-input input {
    width: 44px; text-align: center;
    border: 0; background: transparent;
    font: inherit;
    color: var(--navy);
    -moz-appearance: textfield;
}
.qty-input input::-webkit-outer-spin-button,
.qty-input input::-webkit-inner-spin-button {
    -webkit-appearance: none; margin: 0;
}
.qty-btn {
    width: 32px;
    background: transparent;
    border: 0;
    font-size: 1.1rem; line-height: 1;
    color: var(--navy);
    cursor: pointer;
    transition: background .15s;
}
.qty-btn:hover { background: rgba(200,169,110,0.2); }

/* ─── Compact product card variant (square image, name, price + cart icon) ─── */
.product-thumb--square {
    height: auto;
    aspect-ratio: 1 / 1;
}
.product-body--compact {
    padding: .85rem .9rem 1rem;
    gap: .4rem;
}
.product-body--compact .product-name {
    font-size: .95rem;
    /* Keep name to two lines max so card heights stay uniform */
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    min-height: 2.5em;
}
.product-body--compact .product-price-row {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: .6rem;
    margin: .25rem 0 0;
}
.product-body--compact .product-price {
    display: inline-flex;
    align-items: baseline;
    gap: .3rem;
    line-height: 1.1;
}
.product-body--compact .product-unit {
    font-size: .72rem;
    color: #999;
}

.product-cart-form { margin: 0; }
.product-cart-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px; height: 38px;
    border: 1px solid var(--accent);
    background: var(--accent);
    color: #fff;
    cursor: pointer;
    border-radius: 2px;
    transition: background .18s, transform .18s, border-color .18s, color .18s;
    text-decoration: none;
    padding: 0;
}
.product-cart-btn svg { width: 18px; height: 18px; }
.product-cart-btn:hover {
    background: var(--navy);
    border-color: var(--navy);
    transform: translateY(-1px);
}
.product-cart-btn--locked {
    background: #fff;
    color: var(--accent);
}
.product-cart-btn--locked:hover {
    background: var(--accent);
    color: #fff;
}

.shop-empty {
    background: #fff;
    border: 1px dashed rgba(200,169,110,0.5);
    padding: 4rem 2rem;
    text-align: center;
    color: #666;
}
.shop-empty p { margin: 0 0 1.5rem; font-size: 1.05rem; }

/* ─── Cart ─── */
.cart-layout {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 2rem;
    align-items: flex-start;
}
@media (max-width: 1024px) {
    .cart-layout { grid-template-columns: 1fr; }
}
.cart-list { list-style: none; padding: 0; margin: 0; }
.cart-row {
    display: grid;
    grid-template-columns: 70px 1fr auto auto 30px;
    align-items: center;
    gap: 1.1rem;
    padding: 1.1rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.cart-row:last-child { border-bottom: 0; }
.cart-row-icon {
    width: 64px; height: 64px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(180deg, #f7f2e9 0%, #efe6d4 100%);
    font-size: 2.4rem;
    border: 1px solid rgba(200,169,110,0.25);
}
.cart-row-info h3 {
    font-family: 'DM Sans', sans-serif;
    font-size: .98rem; font-weight: 600;
    color: var(--navy);
    line-height: 1.3;
    margin: 0 0 .25rem;
}
.cart-row-cat { font-size: .72rem; letter-spacing: .12em; text-transform: uppercase; color: #999; margin: 0 0 .15rem; }
.cart-row-unit { font-size: .82rem; color: #888; margin: 0; }
.cart-row-unit span { color: #aaa; }
.cart-row-qty { display: inline-flex; align-items: stretch; border: 1px solid rgba(200,169,110,0.45); background: #fff; }
.cart-row-qty button {
    width: 32px;
    background: transparent;
    border: 0;
    font-size: 1.1rem;
    color: var(--navy);
    cursor: pointer;
}
.cart-row-qty button:hover { background: rgba(200,169,110,0.18); }
.cart-row-qty input {
    width: 44px; text-align: center;
    border: 0;
    font: inherit;
    color: var(--navy);
    background: transparent;
    -moz-appearance: textfield;
}
.cart-row-qty input::-webkit-outer-spin-button,
.cart-row-qty input::-webkit-inner-spin-button {
    -webkit-appearance: none; margin: 0;
}
.cart-row-qty-ro {
    font-size: .92rem;
    color: var(--navy);
    font-weight: 500;
    text-align: center;
    min-width: 50px;
}
.cart-row-total {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem; font-weight: 600;
    color: var(--navy);
    text-align: right;
    min-width: 100px;
}
.cart-row-remove button {
    background: transparent; border: 0;
    color: #aaa;
    cursor: pointer;
    transition: color .2s;
    padding: .3rem;
}
.cart-row-remove button:hover { color: #c0392b; }
.cart-row-remove svg { width: 18px; height: 18px; }
.cart-row--readonly { grid-template-columns: 70px 1fr auto auto; }

.cart-actions {
    padding-top: 1.4rem;
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 1rem;
}

/* Summary card */
.cart-summary-card { position: sticky; top: 100px; }
.summary-list {
    list-style: none; padding: 0; margin: 0 0 1.5rem;
}
.summary-list > div {
    display: flex; justify-content: space-between; align-items: baseline;
    padding: .7rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.summary-list > div:last-child { border-bottom: 0; }
.summary-list dt { color: #666; font-size: .92rem; }
.summary-list dd {
    font-size: 1rem; font-weight: 600;
    color: var(--navy);
    margin: 0;
}
.summary-total dt { font-weight: 600; color: var(--navy); }
.summary-total dd {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem;
    font-weight: 600;
    color: var(--accent);
}
.summary-list--tight > div { padding: .45rem 0; }
.cart-checkout-btn { width: 100%; justify-content: center; }
.cart-summary-note {
    font-size: .76rem;
    color: #888;
    line-height: 1.55;
    margin-top: 1rem;
    text-align: center;
}

.empty-illu {
    font-size: 4rem;
    line-height: 1;
    margin-bottom: .5rem;
    color: var(--accent);
}
.empty-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.6rem;
    font-weight: 400;
    color: var(--navy);
    margin: 0;
}

/* ─── Checkout ─── */
.checkout-layout {
    display: grid;
    grid-template-columns: 1.6fr 1fr;
    gap: 2rem;
    align-items: flex-start;
}
@media (max-width: 1024px) {
    .checkout-layout { grid-template-columns: 1fr; }
}
.checkout-main { display: flex; flex-direction: column; gap: 1.5rem; }
.checkout-summary { position: sticky; top: 100px; }

.addr-radio-list,
.pay-radio-list {
    display: flex; flex-direction: column;
    gap: .8rem;
    margin-bottom: 1rem;
}
.addr-radio,
.pay-radio {
    display: flex;
    gap: .9rem;
    padding: 1.1rem 1.2rem;
    border: 1px solid rgba(200,169,110,0.4);
    background: #fff;
    cursor: pointer;
    transition: border-color .2s, box-shadow .2s;
}
.addr-radio input,
.pay-radio input { margin-top: .25rem; accent-color: var(--accent); }
.addr-radio:hover,
.pay-radio:hover { border-color: var(--accent); }
.addr-radio:has(input:checked),
.pay-radio:has(input:checked) {
    border-color: var(--navy);
    box-shadow: 0 0 0 3px rgba(200,169,110,0.18);
}
.addr-radio-body,
.pay-radio-body { flex: 1; }
.addr-radio-head,
.pay-radio-head {
    display: flex; align-items: center; gap: .5rem;
    margin-bottom: .3rem;
    color: var(--navy);
}
.pay-icon { font-size: 1.3rem; }
.pay-radio-body p { font-size: .85rem; color: #777; line-height: 1.5; margin: 0; }

.addr-line { font-size: .92rem; color: var(--navy); margin: 0; line-height: 1.5; }
.addr-line-meta { color: #888; font-size: .85rem; }

.checkout-textarea {
    width: 100%;
    border: 1px solid rgba(200,169,110,0.45);
    border-radius: 2px;
    padding: .8rem 1rem;
    font: inherit; font-size: .92rem;
    background: #fff;
    color: var(--navy);
    resize: vertical;
    min-height: 80px;
}
.checkout-textarea:focus {
    outline: none;
    border-color: var(--accent);
    box-shadow: 0 0 0 3px rgba(200,169,110,0.18);
}

.checkout-empty {
    padding: 1.5rem;
    text-align: center;
    background: #f7f2e9;
    border: 1px dashed rgba(200,169,110,0.45);
}
.checkout-empty p { margin-bottom: 1rem; color: #666; }

.checkout-mini-list {
    list-style: none; padding: 0; margin: 0 0 1rem;
    border-bottom: 1px solid rgba(200,169,110,0.18);
    padding-bottom: 1rem;
}
.checkout-mini-list li {
    display: grid;
    grid-template-columns: 32px 1fr auto;
    gap: .6rem;
    align-items: baseline;
    padding: .35rem 0;
    font-size: .88rem;
}
.mini-ico { font-size: 1.2rem; }
.mini-name { color: var(--navy); }
.mini-name em {
    font-style: normal;
    color: #888; margin-left: .35rem;
    font-size: .8rem;
}
.mini-price {
    color: var(--navy); font-weight: 600;
    text-align: right;
    font-size: .9rem;
}
.mini-more {
    grid-column: 1 / -1;
    font-size: .82rem; color: #888; padding-top: .3rem;
}
.checkout-hint {
    font-size: .76rem;
    color: #888;
    margin: -.4rem 0 .8rem;
    text-align: center;
}

/* ─── Order list / cards / status ─── */
.order-list { list-style: none; padding: 0; margin: 0; }
.order-list-row {
    display: grid;
    grid-template-columns: 1.6fr auto auto auto;
    align-items: center;
    gap: 1rem;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.order-list-row:last-child { border-bottom: 0; }
.order-ref {
    font-family: 'DM Sans', sans-serif;
    font-size: .92rem; font-weight: 600;
    color: var(--navy);
    margin: 0 0 .2rem;
    letter-spacing: .02em;
}
.order-meta { font-size: .78rem; color: #888; margin: 0; }
.order-list-amount {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; font-weight: 600;
    color: var(--navy);
}
.order-list-link {
    font-size: .8rem; letter-spacing: .08em;
    text-transform: uppercase; color: var(--accent);
    text-decoration: none;
    white-space: nowrap;
}
.order-list-link:hover { color: var(--navy); }
.order-status {
    display: inline-flex; align-items: center;
    padding: .3rem .8rem;
    font-size: .7rem; letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 600;
    color: var(--status-color, var(--accent));
    background: color-mix(in srgb, var(--status-color, var(--accent)) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--status-color, var(--accent)) 35%, transparent);
    border-radius: 999px;
    white-space: nowrap;
}
.order-status--inline {
    margin-left: .3rem;
    transform: translateY(-1px);
}

@media (max-width: 768px) {
    .order-list-row { grid-template-columns: 1fr auto; }
    .order-list-amount, .order-list-link { grid-column: span 2; text-align: left; }
}

/* Order filter chips */
.order-filter { display: flex; flex-wrap: wrap; gap: .5rem; margin-bottom: 1.5rem; }
.order-filter-chip {
    display: inline-flex; align-items: center;
    padding: .45rem 1rem;
    font-size: .72rem; letter-spacing: .14em;
    text-transform: uppercase;
    font-weight: 600;
    color: #777;
    background: #fff;
    border: 1px solid rgba(200,169,110,0.4);
    border-radius: 999px;
    text-decoration: none;
    transition: color .2s, border-color .2s, background .2s;
}
.order-filter-chip:hover { border-color: var(--accent); color: var(--navy); }
.order-filter-chip.is-active {
    background: var(--navy);
    color: var(--accent-light);
    border-color: var(--navy);
}

/* Order cards (for listing) */
.order-cards { display: flex; flex-direction: column; gap: 1.2rem; }
.order-card { padding: 1.4rem 1.6rem; }
.order-card-head {
    display: flex; justify-content: space-between; align-items: flex-start;
    flex-wrap: wrap;
    gap: 1rem;
    margin-bottom: 1rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.order-card-items { list-style: none; padding: 0; margin: 0 0 1rem; }
.order-card-items li {
    display: flex; align-items: center;
    gap: .55rem;
    padding: .3rem 0;
    font-size: .88rem;
}
.order-card-items .mini-ico { font-size: 1.2rem; }
.order-card-foot {
    display: flex; justify-content: space-between; align-items: center;
    gap: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(200,169,110,0.18);
}
.order-card-pay { font-size: .82rem; color: #777; margin: 0 0 .2rem; }
.order-card-total {
    margin: 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.4rem;
    color: var(--navy);
}

/* Status timeline */
.timeline-card { margin-bottom: 1.5rem; }
.status-timeline {
    list-style: none; padding: 0; margin: 0;
    display: grid;
    grid-template-columns: repeat(5, 1fr);
    gap: .5rem;
    position: relative;
}
.status-timeline::before {
    content: ''; position: absolute;
    top: 13px; left: 5%; right: 5%;
    height: 2px;
    background: rgba(200,169,110,0.3);
    z-index: 0;
}
.ts-step {
    display: flex; flex-direction: column; align-items: center;
    gap: .55rem;
    position: relative;
    z-index: 1;
    text-align: center;
}
.ts-dot {
    width: 26px; height: 26px;
    border-radius: 50%;
    background: #fff;
    border: 2px solid rgba(200,169,110,0.45);
    transition: background .2s, border-color .2s;
}
.ts-label {
    font-size: .72rem; letter-spacing: .12em;
    text-transform: uppercase;
    color: #999;
    font-weight: 500;
}
.ts-step.is-done .ts-dot { background: var(--accent); border-color: var(--accent); }
.ts-step.is-done .ts-label { color: #888; }
.ts-step.is-current .ts-dot {
    background: var(--navy);
    border-color: var(--navy);
    box-shadow: 0 0 0 4px rgba(200,169,110,0.25);
}
.ts-step.is-current .ts-label { color: var(--navy); font-weight: 600; }
@media (max-width: 768px) {
    .status-timeline { grid-template-columns: repeat(5, 1fr); gap: .25rem; }
    .ts-label { font-size: .6rem; letter-spacing: .06em; }
}

.order-note {
    font-size: .92rem; line-height: 1.6;
    color: #555;
    padding: .8rem 1rem;
    background: #f7f2e9;
    border-left: 3px solid var(--accent);
    margin: 0;
}

/* ─── Addresses ─── */
.addr-toolbar {
    display: flex; justify-content: space-between; align-items: center;
    gap: 1rem; margin-bottom: 1.5rem;
    flex-wrap: wrap;
}
.addr-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
    gap: 1.5rem;
}
.addr-card { padding: 1.4rem 1.5rem 1.2rem; display: flex; flex-direction: column; gap: .3rem; }
.addr-card.is-default { border-color: var(--accent); box-shadow: 0 0 0 3px rgba(200,169,110,0.12); }
.addr-card-head {
    display: flex; justify-content: space-between; align-items: center;
    gap: .8rem;
    margin-bottom: .5rem;
    padding-bottom: .5rem;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.addr-card-head h3 {
    margin: 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem; font-weight: 600;
    color: var(--navy);
}
.addr-card-foot {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px solid rgba(200,169,110,0.18);
    display: flex; gap: 1rem; flex-wrap: wrap; align-items: center;
}

/* Dashboard mini-lists */
.addr-mini-list,
.fav-mini-list { list-style: none; padding: 0; margin: 0; }
.addr-mini-list li {
    padding: .8rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
    font-size: .9rem;
}
.addr-mini-list li:last-child { border-bottom: 0; }
.addr-mini-head {
    display: flex; align-items: center; gap: .6rem;
    margin-bottom: .25rem;
    color: var(--navy);
}
.addr-mini-list p { margin: 0; color: #555; font-size: .85rem; }

.fav-mini-list li {
    display: flex; align-items: center;
    gap: .8rem;
    padding: .75rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.fav-mini-list li:last-child { border-bottom: 0; }
.fav-mini-ico {
    width: 42px; height: 42px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(180deg, #f7f2e9 0%, #efe6d4 100%);
    font-size: 1.4rem;
    flex-shrink: 0;
    border: 1px solid rgba(200,169,110,0.25);
}
.fav-mini-info { flex: 1; min-width: 0; }
.fav-mini-name {
    font-size: .9rem; font-weight: 500;
    color: var(--navy);
    margin: 0 0 .15rem;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
.fav-mini-price {
    font-size: .82rem;
    color: var(--accent);
    margin: 0;
    font-weight: 600;
}
.fav-mini-price span { color: #aaa; font-weight: 400; }

/* Success page footer */
.success-actions {
    display: flex; justify-content: center; gap: 1rem;
    flex-wrap: wrap;
    margin-top: 2rem;
}

/* Nav: cart icon */
.nav-cart {
    margin-left: .4rem;
    position: relative;
}
.nav-cart-btn {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: 999px;
    border: 1px solid rgba(200,169,110,0.5);
    color: var(--accent-light) !important;
    background: transparent;
    text-decoration: none;
    transition: color .2s, border-color .2s, background .2s;
    position: relative;
    padding: 0 !important;
}
.nav-cart-btn:hover {
    color: var(--white) !important;
    border-color: var(--accent);
    background: rgba(200,169,110,0.15);
}
.nav-cart-btn svg { width: 18px; height: 18px; }
.nav-cart-badge {
    position: absolute;
    top: -4px; right: -4px;
    min-width: 18px; height: 18px;
    padding: 0 5px;
    border-radius: 999px;
    background: var(--accent);
    color: var(--navy);
    font-size: .65rem;
    font-weight: 700;
    line-height: 18px;
    text-align: center;
    letter-spacing: 0;
    border: 2px solid var(--navy);
    box-sizing: content-box;
}

/* Responsive niceties */
@media (max-width: 768px) {
    .dash-stats { grid-template-columns: repeat(2, 1fr); }
    .cart-row {
        grid-template-columns: 56px 1fr auto;
        grid-template-areas:
            "icon info info"
            "icon qty  total"
            "icon remove remove";
        row-gap: .6rem;
    }
    .cart-row-icon  { grid-area: icon; }
    .cart-row-info  { grid-area: info; }
    .cart-row-qty   { grid-area: qty; justify-self: start; }
    .cart-row-total { grid-area: total; text-align: right; }
    .cart-row-remove{ grid-area: remove; }
    .cart-row--readonly {
        grid-template-areas: "icon info info" "icon qty total";
    }
    .shop-header { flex-direction: column; align-items: stretch; }
}

/* ═══════════════════════════════════════════════════════════════════════════
   NAV ACCOUNT DROPDOWN — anchored, scroll-aware, never floats orphaned.
   Trigger lives inside .nav-account-wrap (position:relative) and the menu
   uses position:absolute so it is structurally bound to the button. The
   JS controller in _nav.html closes it on scroll / resize / outside-click.
   ═══════════════════════════════════════════════════════════════════════ */
.nav-account-wrap {
    position: relative;
    display: inline-flex;
    align-items: center;
}
.nav-account-caret {
    width: 12px; height: 12px;
    margin-left: .15rem;
    opacity: .8;
    transition: transform .25s ease, opacity .25s ease;
}
.nav-account-wrap.is-open .nav-account-caret {
    transform: rotate(180deg);
    opacity: 1;
}
.nav-account-menu {
    position: absolute;
    top: calc(100% + 14px);
    right: 0;
    min-width: 280px;
    max-width: min(320px, calc(100vw - 32px));
    background: #ffffff;
    color: var(--navy);
    border: 1px solid rgba(200,169,110,0.35);
    border-radius: 10px;
    box-shadow:
        0 1px 2px rgba(10,22,40,0.06),
        0 12px 32px -8px rgba(10,22,40,0.20),
        0 24px 64px -16px rgba(10,22,40,0.18);
    padding: .5rem;
    z-index: 1000;
    opacity: 0;
    visibility: hidden;
    transform: translateY(-6px);
    pointer-events: none;
    transition:
        opacity .18s ease,
        transform .22s cubic-bezier(.2,.7,.3,1),
        visibility 0s linear .18s;
}
.nav-account-wrap.is-open .nav-account-menu {
    opacity: 1;
    visibility: visible;
    transform: translateY(0);
    pointer-events: auto;
    transition:
        opacity .18s ease,
        transform .22s cubic-bezier(.2,.7,.3,1),
        visibility 0s;
}
.nav-account-menu::before {
    content: '';
    position: absolute;
    top: -6px; right: 22px;
    width: 12px; height: 12px;
    background: #fff;
    border-left: 1px solid rgba(200,169,110,0.35);
    border-top: 1px solid rgba(200,169,110,0.35);
    transform: rotate(45deg);
    border-top-left-radius: 2px;
}
.nav-account-menu-head {
    display: flex; flex-direction: column;
    gap: .15rem;
    padding: .85rem 1rem .9rem;
    margin-bottom: .25rem;
    border-bottom: 1px solid rgba(200,169,110,0.22);
}
.nav-account-menu-head strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    font-weight: 600;
    color: var(--navy);
    letter-spacing: .01em;
}
.nav-account-menu-head span {
    font-size: .76rem;
    color: #8a8478;
    word-break: break-all;
}
.nav-account-menu a {
    display: flex; align-items: center;
    gap: .7rem;
    padding: .65rem .9rem;
    border-radius: 6px;
    text-decoration: none;
    color: var(--navy) !important;
    font-size: .85rem !important;
    font-weight: 500 !important;
    letter-spacing: .01em !important;
    text-transform: none !important;
    transition: background .15s ease, color .15s ease;
    line-height: 1.2;
}
.nav-account-menu a::after { display: none !important; }
.nav-account-menu a svg {
    width: 16px; height: 16px;
    flex-shrink: 0;
    color: #8a8478;
    transition: color .15s ease;
}
.nav-account-menu a:hover {
    background: rgba(200,169,110,0.12);
    color: var(--navy) !important;
}
.nav-account-menu a:hover svg { color: var(--accent); }
.nav-account-menu-admin {
    color: var(--accent) !important;
}
.nav-account-menu-admin svg { color: var(--accent) !important; }
.nav-account-menu-switch,
.nav-account-menu-logout {
    margin-top: .25rem;
    border-top: 1px solid rgba(200,169,110,0.22);
    padding-top: .8rem !important;
    border-radius: 0 0 6px 6px;
}
.nav-account-menu-logout {
    color: #b94a4a !important;
    margin-top: 0;
    border-top: 0;
    padding-top: .65rem !important;
}
.nav-account-menu-logout svg { color: #b94a4a !important; }
.nav-account-menu-logout:hover {
    background: rgba(185,74,74,0.08);
}

/* Hide the dropdown entirely on mobile — the hamburger drawer handles nav there. */
@media (max-width: 768px) {
    .nav-account-wrap .nav-account-menu { display: none !important; }
}


/* ═══════════════════════════════════════════════════════════════════════════
   ESPACE CLIENT — true desktop dashboard (Stripe / Shopify / Apple spacing).
   Layout switches at 1024px: below that, the sidebar collapses to a horizontal
   chip rail and the cards stack as a single column. Above 1024px, a fixed
   240px sidebar sits next to a fluid main area capped at 1400px overall.
   ═══════════════════════════════════════════════════════════════════════ */
.ec-account {
    background: #f4ede0;
    min-height: 100vh;
    padding: 110px 0 4rem;
    color: var(--navy);
    position: relative;
}
.ec-account::before {
    content: '';
    position: absolute;
    top: 0; left: 0; right: 0;
    height: 280px;
    background:
        radial-gradient(ellipse at 20% 0%, rgba(200,169,110,0.18), transparent 60%),
        linear-gradient(180deg, rgba(10,22,40,0.04) 0%, transparent 100%);
    pointer-events: none;
    z-index: 0;
}
.ec-account-wrap {
    position: relative;
    z-index: 1;
    max-width: 1400px;
    margin: 0 auto;
    padding: 0 2.5rem;
    display: grid;
    grid-template-columns: 260px minmax(0, 1fr);
    gap: 2.5rem;
    align-items: flex-start;
}

/* ── SIDEBAR ─────────────────────────────────────────────────────────── */
.ec-side {
    position: sticky;
    top: 100px;
    align-self: flex-start;
    display: flex;
    flex-direction: column;
    gap: 1rem;
    max-height: calc(100vh - 120px);
}
.ec-side-card {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.28);
    border-radius: 12px;
    padding: 1.4rem 1.3rem;
    box-shadow: 0 1px 2px rgba(10,22,40,0.04);
}
.ec-side-profile {
    display: flex; align-items: center; gap: .9rem;
}
.ec-side-avatar {
    width: 48px; height: 48px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--navy) 0%, #1a3a6b 100%);
    color: var(--accent-light);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.2rem; font-weight: 600;
    letter-spacing: .02em;
    flex-shrink: 0;
    box-shadow: 0 4px 12px -4px rgba(10,22,40,0.4);
}
.ec-side-id { display: flex; flex-direction: column; gap: .15rem; min-width: 0; }
.ec-side-id strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    color: var(--navy);
    letter-spacing: .01em;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ec-side-id span {
    font-size: .73rem;
    color: #888;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ec-side-verified {
    color: #2f9e6b !important;
    font-size: .68rem !important;
    font-weight: 600;
    letter-spacing: .06em;
    text-transform: uppercase;
    margin-top: .1rem;
}
.ec-side-nav {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.28);
    border-radius: 12px;
    padding: .55rem;
    display: flex; flex-direction: column; gap: 2px;
    box-shadow: 0 1px 2px rgba(10,22,40,0.04);
}
.ec-side-nav a {
    display: flex; align-items: center; gap: .75rem;
    padding: .7rem .85rem;
    text-decoration: none;
    color: #4a4a4a;
    font-size: .85rem;
    font-weight: 500;
    border-radius: 8px;
    position: relative;
    transition: background .18s ease, color .18s ease, transform .18s ease;
}
.ec-side-nav a svg {
    width: 18px; height: 18px;
    color: #9b9388;
    flex-shrink: 0;
    transition: color .18s ease;
}
.ec-side-nav a:hover {
    background: rgba(200,169,110,0.10);
    color: var(--navy);
}
.ec-side-nav a:hover svg { color: var(--accent); }
.ec-side-nav a.is-active {
    background: var(--navy);
    color: var(--accent-light);
}
.ec-side-nav a.is-active svg { color: var(--accent); }
.ec-side-count {
    margin-left: auto;
    background: rgba(200,169,110,0.18);
    color: var(--navy);
    font-size: .68rem;
    font-weight: 700;
    padding: .15rem .55rem;
    border-radius: 999px;
    letter-spacing: .02em;
    min-width: 22px;
    text-align: center;
}
.ec-side-nav a.is-active .ec-side-count {
    background: rgba(200,169,110,0.30);
    color: var(--accent-light);
}
.ec-side-count--accent {
    background: var(--accent);
    color: var(--navy);
}
.ec-side-sep {
    height: 1px;
    background: rgba(200,169,110,0.20);
    margin: .4rem .5rem;
}
.ec-side-admin { color: var(--accent) !important; }
.ec-side-admin svg { color: var(--accent) !important; }
.ec-side-logout { color: #b94a4a !important; }
.ec-side-logout svg { color: #b94a4a !important; }
.ec-side-logout:hover { background: rgba(185,74,74,0.08) !important; }

/* ── MAIN AREA ───────────────────────────────────────────────────────── */
.ec-main {
    min-width: 0;
    display: flex;
    flex-direction: column;
    gap: 2rem;
}

/* Hero / welcome header */
.ec-hero {
    background: linear-gradient(135deg, var(--navy) 0%, #14274a 60%, #1a3a6b 100%);
    color: #fff;
    border-radius: 14px;
    padding: 2.2rem 2.4rem;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 2rem;
    align-items: center;
    position: relative;
    overflow: hidden;
    box-shadow: 0 10px 30px -12px rgba(10,22,40,0.30);
}
.ec-hero::before {
    content: '';
    position: absolute;
    inset: 0;
    background:
        radial-gradient(circle at 95% 10%, rgba(200,169,110,0.25), transparent 45%),
        radial-gradient(circle at 5% 110%, rgba(200,169,110,0.15), transparent 50%);
    pointer-events: none;
}
.ec-hero > * { position: relative; z-index: 1; }
.ec-hero-eyebrow {
    font-size: .7rem;
    letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 .55rem;
    font-weight: 500;
}
.ec-hero-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.7rem, 2.6vw, 2.5rem);
    font-weight: 400;
    line-height: 1.15;
    margin: 0 0 .55rem;
    color: #fff;
}
.ec-hero-title em {
    font-style: italic;
    color: var(--accent);
    font-weight: 500;
}
.ec-hero-sub {
    font-size: .92rem;
    color: rgba(248,245,240,0.75);
    line-height: 1.6;
    max-width: 480px;
    margin: 0;
}
.ec-hero-stats {
    display: flex;
    gap: 1.6rem;
    padding-left: 1.6rem;
    border-left: 1px solid rgba(200,169,110,0.30);
}
.ec-hero-stats > div {
    display: flex;
    flex-direction: column;
    gap: .15rem;
    text-align: right;
    min-width: 70px;
}
.ec-hero-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem;
    font-weight: 600;
    color: var(--accent-light);
    line-height: 1;
}
.ec-hero-lbl {
    font-size: .65rem;
    letter-spacing: .16em;
    text-transform: uppercase;
    color: rgba(214,207,196,0.75);
    font-weight: 500;
}

/* Status filter cards — horizontal KPI row */
.ec-status-grid {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1rem;
}
.ec-status-card {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.25);
    border-radius: 12px;
    padding: 1.2rem 1.3rem;
    text-decoration: none;
    color: var(--navy);
    display: grid;
    grid-template-columns: auto 1fr;
    grid-template-rows: auto auto;
    column-gap: 1rem;
    row-gap: .15rem;
    align-items: center;
    position: relative;
    overflow: hidden;
    transition:
        transform .25s cubic-bezier(.2,.7,.3,1),
        border-color .25s ease,
        box-shadow .25s ease;
}
.ec-status-card::after {
    content: '';
    position: absolute;
    inset: 0;
    border-radius: inherit;
    box-shadow: 0 1px 2px rgba(10,22,40,0.04);
    pointer-events: none;
    transition: box-shadow .25s ease;
}
.ec-status-card:hover {
    transform: translateY(-3px);
    border-color: var(--accent);
}
.ec-status-card:hover::after {
    box-shadow: 0 16px 32px -16px rgba(10,22,40,0.30);
}
.ec-status-icon {
    grid-row: 1 / span 2;
    width: 42px; height: 42px;
    display: inline-flex; align-items: center; justify-content: center;
    border-radius: 10px;
    background: rgba(200,169,110,0.14);
    color: var(--navy);
}
.ec-status-icon svg { width: 22px; height: 22px; }
.ec-status-icon[data-st="pending"]   { background: rgba(214,156,52,0.16);  color: #b6781b; }
.ec-status-icon[data-st="preparing"] { background: rgba(38,135,228,0.14);  color: #1e6fb5; }
.ec-status-icon[data-st="shipped"]   { background: rgba(120,90,200,0.14);  color: #6a4ec3; }
.ec-status-icon[data-st="delivered"] { background: rgba(47,158,107,0.14);  color: #1f7a52; }
.ec-status-count {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem;
    font-weight: 600;
    line-height: 1;
}
.ec-status-label {
    font-size: .72rem;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: #8a8478;
    font-weight: 500;
}

/* Section blocks (white cards) */
.ec-block {
    background: #fff;
    border: 1px solid rgba(200,169,110,0.22);
    border-radius: 14px;
    padding: 1.7rem 1.8rem 1.8rem;
    box-shadow: 0 1px 2px rgba(10,22,40,0.04);
}
.ec-block-head {
    display: flex; align-items: center; justify-content: space-between;
    gap: 1rem;
    margin-bottom: 1.2rem;
    padding-bottom: .9rem;
    border-bottom: 1px solid rgba(200,169,110,0.18);
}
.ec-block-head h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.45rem;
    font-weight: 600;
    margin: 0;
    color: var(--navy);
    letter-spacing: .01em;
}
.ec-block-link {
    font-size: .76rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent);
    text-decoration: none;
    font-weight: 600;
    transition: color .2s ease, transform .2s ease;
}
.ec-block-link:hover { color: var(--navy); transform: translateX(2px); }

/* Recent orders list */
.ec-orders { list-style: none; padding: 0; margin: 0; }
.ec-order-row {
    display: grid;
    grid-template-columns: auto 1fr auto auto;
    gap: 1.25rem;
    align-items: center;
    padding: 1rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.16);
}
.ec-order-row:last-child { border-bottom: 0; padding-bottom: 0; }
.ec-order-row:first-child { padding-top: 0; }
.ec-order-thumbs {
    display: flex;
    align-items: center;
}
.ec-order-thumb,
.ec-order-thumb-more {
    width: 44px; height: 44px;
    border-radius: 10px;
    background: linear-gradient(180deg, #f7f2e9 0%, #efe6d4 100%);
    border: 1px solid rgba(200,169,110,0.30);
    display: inline-flex; align-items: center; justify-content: center;
    font-size: 1.2rem;
    margin-left: -10px;
    overflow: hidden;
}
.ec-order-thumb:first-child,
.ec-order-thumb-more:first-child { margin-left: 0; }
.ec-order-thumb img { width: 100%; height: 100%; object-fit: cover; }
.ec-order-thumb-more {
    font-size: .72rem;
    font-weight: 700;
    color: var(--navy);
    background: rgba(200,169,110,0.20);
    letter-spacing: .02em;
}
.ec-order-info { min-width: 0; }
.ec-order-ref {
    display: flex; align-items: center; gap: .6rem;
    margin: 0 0 .25rem;
    font-size: .85rem;
}
.ec-order-ref strong {
    color: var(--navy);
    font-weight: 600;
    letter-spacing: .01em;
}
.ec-order-status {
    display: inline-flex;
    padding: .22rem .65rem;
    font-size: .65rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--st, var(--accent));
    background: color-mix(in srgb, var(--st, var(--accent)) 12%, transparent);
    border: 1px solid color-mix(in srgb, var(--st, var(--accent)) 30%, transparent);
    border-radius: 999px;
}
.ec-order-meta {
    margin: 0;
    font-size: .76rem;
    color: #8a8478;
}
.ec-order-total {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.25rem;
    font-weight: 600;
    color: var(--navy);
    white-space: nowrap;
}
.ec-order-actions {
    display: flex; gap: .5rem; flex-shrink: 0;
}

/* Two-column grid for address + favorites */
.ec-grid-2 {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.4rem;
}

/* Address card content */
.ec-address {
    display: flex; flex-direction: column; gap: .4rem;
}
.ec-address-head {
    display: flex; align-items: center; gap: .6rem;
    margin-bottom: .2rem;
}
.ec-address-head strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem;
    color: var(--navy);
    font-weight: 600;
}
.ec-badge-default {
    display: inline-flex;
    padding: .15rem .55rem;
    background: rgba(47,158,107,0.14);
    color: #1f7a52;
    font-size: .62rem;
    font-weight: 700;
    letter-spacing: .1em;
    text-transform: uppercase;
    border-radius: 999px;
}
.ec-address-name {
    margin: 0;
    font-size: .9rem;
    color: var(--navy);
    font-weight: 500;
}
.ec-address-line {
    margin: 0;
    font-size: .88rem;
    color: #555;
    line-height: 1.55;
}
.ec-address-meta {
    margin: 0;
    font-size: .8rem;
    color: #8a8478;
}
.ec-address-other {
    margin: .9rem 0 0;
    font-size: .78rem;
    color: #8a8478;
    padding-top: .8rem;
    border-top: 1px dashed rgba(200,169,110,0.30);
}

/* Favorites mini-list */
.ec-fav-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: .25rem; }
.ec-fav-list li {
    display: flex; align-items: center; gap: .9rem;
    padding: .65rem 0;
    border-bottom: 1px solid rgba(200,169,110,0.14);
}
.ec-fav-list li:last-child { border-bottom: 0; padding-bottom: 0; }
.ec-fav-list li:first-child { padding-top: 0; }
.ec-fav-ico {
    width: 42px; height: 42px;
    border-radius: 10px;
    display: inline-flex; align-items: center; justify-content: center;
    background: linear-gradient(180deg, #f7f2e9 0%, #efe6d4 100%);
    font-size: 1.4rem;
    border: 1px solid rgba(200,169,110,0.25);
    flex-shrink: 0;
}
.ec-fav-info { flex: 1; min-width: 0; }
.ec-fav-name {
    margin: 0 0 .15rem;
    font-size: .9rem;
    color: var(--navy);
    font-weight: 500;
    overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.ec-fav-price {
    margin: 0;
    font-size: .82rem;
    color: var(--accent);
    font-weight: 700;
}
.ec-fav-price span { color: #aaa; font-weight: 400; margin-left: .2rem; }
.ec-fav-add {
    width: 32px; height: 32px;
    border-radius: 50%;
    border: 1px solid rgba(200,169,110,0.40);
    display: inline-flex; align-items: center; justify-content: center;
    color: var(--navy);
    text-decoration: none;
    transition: background .2s ease, color .2s ease, transform .2s ease;
    flex-shrink: 0;
    font-size: 1rem;
}
.ec-fav-add:hover {
    background: var(--accent);
    color: var(--navy);
    transform: translateX(2px);
}

/* Buttons (account-scoped) */
.ec-btn-primary,
.ec-btn-ghost,
.ec-btn-wa {
    display: inline-flex; align-items: center; justify-content: center;
    gap: .45rem;
    padding: .55rem 1.1rem;
    font-size: .74rem;
    font-weight: 600;
    letter-spacing: .12em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 6px;
    border: 1px solid transparent;
    cursor: pointer;
    transition: background .2s ease, color .2s ease, transform .2s ease, box-shadow .2s ease, border-color .2s ease;
    white-space: nowrap;
    line-height: 1;
}
.ec-btn-primary {
    background: var(--navy);
    color: var(--accent-light);
}
.ec-btn-primary:hover {
    background: var(--deep);
    transform: translateY(-1px);
    box-shadow: 0 6px 16px -6px rgba(10,22,40,0.40);
}
.ec-btn-ghost {
    background: #fff;
    color: var(--navy);
    border-color: rgba(200,169,110,0.45);
}
.ec-btn-ghost:hover {
    border-color: var(--accent);
    background: rgba(200,169,110,0.08);
}
.ec-btn-wa {
    background: #25D366;
    color: #fff;
}
.ec-btn-wa:hover { background: #1ebe57; transform: translateY(-1px); }
.ec-btn-wa svg { width: 14px; height: 14px; }

/* Empty states */
.ec-empty {
    text-align: center;
    padding: 2.5rem 1rem;
    color: #8a8478;
}
.ec-empty p { margin: 0 0 1.2rem; font-size: .92rem; }
.ec-empty-actions {
    display: flex; gap: .6rem; flex-wrap: wrap; justify-content: center;
}
.ec-empty--inline { padding: 1.2rem 0; text-align: left; }
.ec-empty--inline p { margin: 0 0 .8rem; }

/* Help / support strip */
.ec-help {
    background: linear-gradient(135deg, #fff 0%, #fbf6ed 100%);
    border: 1px solid rgba(200,169,110,0.30);
    border-radius: 14px;
    padding: 1.6rem 1.8rem;
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 1.5rem;
    align-items: center;
    box-shadow: 0 1px 2px rgba(10,22,40,0.04);
}
.ec-help-eyebrow {
    font-size: .7rem;
    letter-spacing: .18em;
    text-transform: uppercase;
    color: var(--accent);
    margin: 0 0 .4rem;
    font-weight: 600;
}
.ec-help h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.3rem;
    font-weight: 500;
    color: var(--navy);
    margin: 0;
    line-height: 1.3;
}
.ec-help-actions {
    display: flex; gap: .6rem; flex-wrap: wrap; justify-content: flex-end;
}

/* ── TABLET (≤1024px): sidebar becomes a chip rail above the main area ── */
@media (max-width: 1024px) {
    .ec-account-wrap {
        grid-template-columns: 1fr;
        gap: 1.5rem;
        padding: 0 1.5rem;
    }
    .ec-side {
        position: static;
        max-height: none;
        flex-direction: row;
        gap: .9rem;
        overflow-x: auto;
        scrollbar-width: thin;
        padding-bottom: .25rem;
    }
    .ec-side-card { flex-shrink: 0; min-width: 240px; }
    .ec-side-nav {
        flex-direction: row;
        flex-shrink: 0;
        gap: 4px;
        padding: .4rem;
    }
    .ec-side-nav a {
        white-space: nowrap;
        padding: .55rem .8rem;
        font-size: .8rem;
    }
    .ec-side-nav .ec-side-count { display: none; }
    .ec-side-sep { display: none; }
    .ec-grid-2 { grid-template-columns: 1fr; }
}

/* ── MOBILE (≤768px): true card-stack layout, hide sidebar profile card ── */
@media (max-width: 768px) {
    .ec-account { padding: 90px 0 6rem; }
    .ec-account-wrap { padding: 0 1rem; gap: 1.2rem; }

    /* Hide the sidebar entirely — the hamburger drawer covers nav on mobile.
       The page becomes a pure card stack the way the brief requested. */
    .ec-side { display: none; }

    .ec-hero {
        grid-template-columns: 1fr;
        padding: 1.6rem 1.4rem;
        gap: 1.1rem;
    }
    .ec-hero-stats {
        padding-left: 0;
        border-left: 0;
        padding-top: 1.1rem;
        border-top: 1px solid rgba(200,169,110,0.25);
        justify-content: space-between;
        gap: .8rem;
    }
    .ec-hero-stats > div { text-align: left; min-width: 0; }
    .ec-hero-num { font-size: 1.4rem; }

    .ec-status-grid {
        grid-template-columns: repeat(2, 1fr);
        gap: .7rem;
    }
    .ec-status-card { padding: 1rem; column-gap: .7rem; }
    .ec-status-icon { width: 36px; height: 36px; }
    .ec-status-icon svg { width: 18px; height: 18px; }
    .ec-status-count { font-size: 1.4rem; }

    .ec-block { padding: 1.3rem 1.2rem; border-radius: 12px; }
    .ec-block-head h2 { font-size: 1.2rem; }

    .ec-order-row {
        grid-template-columns: auto 1fr;
        grid-template-areas:
            "thumbs info"
            "total  total"
            "actions actions";
        row-gap: .6rem;
        column-gap: .9rem;
    }
    .ec-order-thumbs   { grid-area: thumbs; }
    .ec-order-info     { grid-area: info; }
    .ec-order-total    { grid-area: total; }
    .ec-order-actions  { grid-area: actions; }
    .ec-order-actions .ec-btn-primary,
    .ec-order-actions .ec-btn-ghost { flex: 1; }

    .ec-help {
        grid-template-columns: 1fr;
        padding: 1.4rem 1.3rem;
    }
    .ec-help-actions { justify-content: flex-start; }

    /* Sticky bottom CTA rail — primary action always reachable on mobile.
       Sits above the mobile-actions partial; if that is present (~58px),
       this rail lifts above it. */
    .ec-help-actions .ec-btn-primary { width: 100%; }
}

/* Carried over from the original mobile @media that got split when the new
   account-dashboard CSS was inserted above. Keeps shop & order layouts intact. */
@media (max-width: 768px) {
    .shop-search { width: 100%; }
    .order-card-head, .order-card-foot { flex-direction: column; align-items: flex-start; }
}

/* ═════════════════════════════════════════════════════════════════════
   v2 PREMIUM UPGRADE LAYER — 2026
   Additive only. Preserves every existing rule above.
   Adds: mobile drawer, sticky bottom CTA, testimonials, scroll reveal,
         pricing-teaser, dual CTA band, micro-interactions, focus rings.
   ═════════════════════════════════════════════════════════════════════ */

/* ── Accessibility focus ring ── */
a:focus-visible, button:focus-visible, .btn-primary:focus-visible,
.btn-outline:focus-visible, .btn-dark:focus-visible, .btn-ghost:focus-visible {
    outline: 2px solid var(--accent);
    outline-offset: 3px;
    border-radius: 2px;
}

/* ── Improved hero CTA: WhatsApp variant ── */
.btn-whatsapp {
    background: #25D366;
    color: #fff !important;
    padding: .95rem 2.2rem;
    font-size: .82rem; font-weight: 600; letter-spacing: .12em;
    text-transform: uppercase; text-decoration: none;
    border-radius: 2px;
    transition: background .25s, transform .2s, box-shadow .25s;
    display: inline-flex; align-items: center; gap: .65rem;
    border: 1px solid #25D366;
    box-shadow: 0 8px 22px rgba(37,211,102,0.28);
}
.btn-whatsapp:hover {
    background: #1faa53;
    border-color: #1faa53;
    transform: translateY(-2px);
    box-shadow: 0 12px 28px rgba(37,211,102,0.38);
}
.btn-whatsapp svg { width: 18px; height: 18px; fill: currentColor; }

/* ── Hero secondary line: phone + hours micro-trust ── */
.hero-microtrust {
    margin-top: 1.6rem;
    display: flex; flex-wrap: wrap; gap: 1.4rem;
    font-size: .76rem; letter-spacing: .12em;
    text-transform: uppercase;
    color: rgba(214,207,196,0.72);
}
.hero-microtrust span {
    display: inline-flex; align-items: center; gap: .45rem;
}
.hero-microtrust span::before {
    content: ''; display: block;
    width: 6px; height: 6px; border-radius: 50%;
    background: #25D366;
    box-shadow: 0 0 0 3px rgba(37,211,102,0.18);
}
.hero-microtrust a { color: inherit; text-decoration: none; }
.hero-microtrust a:hover { color: var(--accent); }

/* ════════════════════════════════
   MOBILE HAMBURGER + DRAWER
   ════════════════════════════════ */
.nav-hamburger {
    display: none;
    background: transparent;
    border: 1px solid rgba(200,169,110,0.50);
    width: 42px; height: 42px;
    border-radius: 999px;
    cursor: pointer;
    align-items: center; justify-content: center;
    transition: background .25s, border-color .25s;
    margin-left: .6rem;
    flex-shrink: 0;
}
.nav-hamburger:hover { background: rgba(200,169,110,0.12); border-color: var(--accent); }
.nav-hamburger span {
    display: block; position: relative;
    width: 18px; height: 2px;
    background: var(--accent-light);
    transition: transform .3s, opacity .25s, top .3s;
}
.nav-hamburger span::before,
.nav-hamburger span::after {
    content: ''; position: absolute; left: 0;
    width: 18px; height: 2px;
    background: var(--accent-light);
    transition: transform .3s, top .3s;
}
.nav-hamburger span::before { top: -6px; }
.nav-hamburger span::after  { top:  6px; }
.nav-hamburger.is-open span { background: transparent; }
.nav-hamburger.is-open span::before { top: 0; transform: rotate(45deg); }
.nav-hamburger.is-open span::after  { top: 0; transform: rotate(-45deg); }

/* Drawer container */
.mobile-drawer {
    position: fixed;
    top: 0; right: 0; bottom: 0;
    width: min(86vw, 360px);
    background: linear-gradient(180deg, #0a1628 0%, #0d1f3c 100%);
    z-index: 200;
    padding: 5.5rem 1.8rem 6.5rem;
    transform: translateX(100%);
    transition: transform .35s cubic-bezier(.22,.61,.36,1);
    box-shadow: -20px 0 60px rgba(0,0,0,0.35);
    overflow-y: auto;
    -webkit-overflow-scrolling: touch;
    display: flex; flex-direction: column;
}
.mobile-drawer.is-open { transform: translateX(0); }
.mobile-drawer-backdrop {
    position: fixed; inset: 0;
    background: rgba(10,22,40,0.55);
    backdrop-filter: blur(4px);
    -webkit-backdrop-filter: blur(4px);
    opacity: 0; visibility: hidden;
    transition: opacity .3s, visibility .3s;
    z-index: 199;
}
.mobile-drawer-backdrop.is-open { opacity: 1; visibility: visible; }

.mobile-drawer-eyebrow {
    font-size: .68rem; letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 1.2rem;
}
.mobile-drawer ul {
    list-style: none;
    display: flex; flex-direction: column;
    gap: 0;
    margin: 0; padding: 0;
}
.mobile-drawer ul li {
    border-bottom: 1px solid rgba(200,169,110,0.12);
}
.mobile-drawer ul a {
    display: flex; align-items: center; justify-content: space-between;
    padding: 1.1rem 0;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.35rem; font-weight: 500;
    color: var(--white);
    text-decoration: none;
    letter-spacing: .01em;
    transition: color .2s, padding-left .25s;
}
.mobile-drawer ul a::after {
    content: '→';
    font-family: 'DM Sans', sans-serif;
    font-size: .9rem;
    color: var(--accent);
    opacity: .55;
    transition: transform .25s, opacity .25s;
}
.mobile-drawer ul a:hover,
.mobile-drawer ul a.active {
    color: var(--accent-light);
    padding-left: .35rem;
}
.mobile-drawer ul a:hover::after,
.mobile-drawer ul a.active::after { opacity: 1; transform: translateX(4px); }

.mobile-drawer-foot {
    margin-top: auto;
    padding-top: 1.6rem;
    border-top: 1px solid rgba(200,169,110,0.18);
}
.mobile-drawer-foot a.btn-whatsapp {
    width: 100%;
    justify-content: center;
    margin-bottom: .9rem;
}
.mobile-drawer-foot .mdf-phone {
    display: block;
    color: var(--accent-light);
    text-decoration: none;
    text-align: center;
    font-size: .82rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    padding: .65rem 0;
    border: 1px solid rgba(200,169,110,0.45);
    border-radius: 2px;
    transition: background .25s, color .25s;
}
.mobile-drawer-foot .mdf-phone:hover {
    background: var(--accent);
    color: var(--navy);
}
.mobile-drawer-foot .mdf-hours {
    display: block;
    font-size: .7rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: rgba(214,207,196,0.55);
    text-align: center;
    margin-top: 1rem;
}

/* Lock body scroll when drawer is open */
body.is-drawer-open { overflow: hidden; }

/* ════════════════════════════════
   STICKY MOBILE BOTTOM ACTION BAR
   ════════════════════════════════ */
.mobile-action-bar {
    display: none;
    position: fixed;
    left: 0; right: 0; bottom: 0;
    z-index: 90;
    background: rgba(10,22,40,0.96);
    backdrop-filter: blur(12px);
    -webkit-backdrop-filter: blur(12px);
    border-top: 1px solid rgba(200,169,110,0.25);
    padding: .55rem .8rem calc(.55rem + env(safe-area-inset-bottom, 0px));
    gap: .55rem;
    box-shadow: 0 -8px 24px rgba(0,0,0,0.18);
}
.mobile-action-bar a {
    flex: 1;
    display: inline-flex; align-items: center; justify-content: center;
    gap: .5rem;
    padding: .85rem .4rem;
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: .1em;
    text-transform: uppercase;
    text-decoration: none;
    border-radius: 2px;
    line-height: 1;
}
.mab-call { background: rgba(200,169,110,0.12); color: var(--accent-light); border: 1px solid rgba(200,169,110,0.4); }
.mab-call:active { background: rgba(200,169,110,0.22); }
.mab-wa { background: #25D366; color: #fff; }
.mab-wa:active { background: #1faa53; }
.mab-quote { background: var(--accent); color: var(--navy); }
.mab-quote:active { background: var(--accent-light); }
.mobile-action-bar svg { width: 16px; height: 16px; flex-shrink: 0; }

/* ════════════════════════════════
   PRICING TEASER (home page)
   ════════════════════════════════ */
.pricing-teaser {
    padding: 5.5rem 5vw;
    background: var(--white);
    border-top: 1px solid rgba(200,169,110,0.15);
    border-bottom: 1px solid rgba(200,169,110,0.15);
}
.pricing-teaser-inner {
    max-width: 1280px; margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1.4fr;
    gap: 4rem;
    align-items: center;
}
.pricing-teaser-text .section-label { margin-bottom: .8rem; }
.pricing-teaser-text h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.4vw, 2.8rem);
    font-weight: 400; line-height: 1.18;
    color: var(--navy);
    margin-bottom: 1.2rem;
}
.pricing-teaser-text h2 em { font-style: italic; color: var(--blue); }
.pricing-teaser-text p {
    font-size: .95rem; line-height: 1.8; color: #555;
    margin-bottom: 2rem; max-width: 460px;
}
.pricing-teaser-actions { display: flex; gap: .9rem; flex-wrap: wrap; }

.pricing-teaser-grid {
    display: grid;
    grid-template-columns: repeat(2, 1fr);
    gap: 1px;
    background: var(--mist);
    border: 1px solid var(--mist);
}
.pt-card {
    background: var(--white);
    padding: 1.7rem 1.5rem;
    display: flex; flex-direction: column;
    gap: .35rem;
    transition: background .3s;
}
.pt-card:hover { background: #fdfaf5; }
.pt-card-label {
    font-size: .7rem; letter-spacing: .14em;
    text-transform: uppercase; color: #888;
}
.pt-card-price {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem; font-weight: 600;
    color: var(--navy); line-height: 1.05;
}
.pt-card-price small {
    font-family: 'DM Sans', sans-serif;
    font-size: .7rem; font-weight: 500;
    color: var(--accent); letter-spacing: .14em;
    text-transform: uppercase; margin-left: .3rem;
}
.pt-card-sub {
    font-size: .8rem; color: #666;
    line-height: 1.5;
}

/* ════════════════════════════════
   TESTIMONIALS / SOCIAL PROOF
   ════════════════════════════════ */
.testimonials {
    padding: 7rem 5vw;
    background: #f3ede2;
    position: relative;
}
.testimonials .section-header { max-width: 1280px; margin-left: auto; margin-right: auto; margin-bottom: 3.5rem; }
.testimonials-grid {
    max-width: 1280px;
    margin: 0 auto;
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
    gap: 1.5rem;
}
.testimonial-card {
    background: var(--white);
    border: 1px solid rgba(200,169,110,0.28);
    padding: 2.4rem 2rem 2rem;
    position: relative;
    transition: transform .3s, box-shadow .3s, border-color .3s;
    display: flex; flex-direction: column;
}
.testimonial-card:hover {
    transform: translateY(-4px);
    border-color: var(--accent);
    box-shadow: 0 22px 44px rgba(10,22,40,0.10);
}
.testimonial-card::before {
    content: '“';
    position: absolute;
    top: .4rem; left: 1.4rem;
    font-family: 'Cormorant Garamond', serif;
    font-size: 4.5rem;
    color: var(--accent);
    opacity: .22;
    line-height: 1;
}
.testimonial-stars {
    color: var(--accent);
    font-size: .95rem;
    letter-spacing: .15em;
    margin-bottom: 1.1rem;
}
.testimonial-card p {
    font-size: .95rem; line-height: 1.75;
    color: #444;
    margin-bottom: 1.6rem;
    flex-grow: 1;
    font-style: italic;
}
.testimonial-author {
    display: flex; align-items: center; gap: .9rem;
    border-top: 1px solid rgba(200,169,110,0.2);
    padding-top: 1.1rem;
}
.testimonial-avatar {
    width: 44px; height: 44px;
    border-radius: 50%;
    background: linear-gradient(135deg, var(--accent) 0%, var(--accent-light) 100%);
    color: var(--navy);
    display: inline-flex; align-items: center; justify-content: center;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.15rem; font-weight: 700;
    flex-shrink: 0;
}
.testimonial-meta strong {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    color: var(--navy);
    font-weight: 600;
    line-height: 1.2;
}
.testimonial-meta span {
    display: block;
    font-size: .72rem; letter-spacing: .12em;
    text-transform: uppercase;
    color: #888;
    margin-top: .2rem;
}

/* Trust logo strip */
.trust-strip {
    background: var(--white);
    padding: 2.6rem 5vw;
    border-top: 1px solid rgba(200,169,110,0.15);
    border-bottom: 1px solid rgba(200,169,110,0.15);
}
.trust-strip-inner {
    max-width: 1280px; margin: 0 auto;
    display: flex; flex-wrap: wrap;
    align-items: center; justify-content: space-between;
    gap: 1.6rem;
}
.trust-strip-label {
    font-size: .68rem; letter-spacing: .22em;
    text-transform: uppercase;
    color: #999;
    font-weight: 500;
    flex-shrink: 0;
}
.trust-strip-items {
    display: flex; flex-wrap: wrap; gap: 2.2rem;
    align-items: center;
}
.trust-strip-items span {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.05rem;
    font-weight: 500;
    color: var(--navy);
    opacity: .55;
    letter-spacing: .03em;
    white-space: nowrap;
    transition: opacity .25s, color .25s;
}
.trust-strip-items span:hover { opacity: 1; color: var(--accent); }

/* ════════════════════════════════
   DUAL CTA BAND (Devis + WhatsApp)
   ════════════════════════════════ */
.cta-band-v2 {
    padding: 5.5rem 5vw;
    background:
        linear-gradient(135deg, rgba(10,22,40,0.96) 0%, rgba(13,31,60,0.92) 100%),
        radial-gradient(circle at 80% 30%, rgba(200,169,110,0.2), transparent 50%);
    color: var(--white);
    text-align: center;
    position: relative;
    overflow: hidden;
    isolation: isolate;
}
.cta-band-v2::before {
    content: '';
    position: absolute; inset: 0;
    background:
        radial-gradient(circle at 15% 80%, rgba(200,169,110,0.12), transparent 45%),
        radial-gradient(circle at 85% 20%, rgba(26,58,107,0.6), transparent 55%);
    z-index: -1;
}
.cta-band-v2 .cta-eyebrow {
    font-size: .72rem; letter-spacing: .22em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: 1rem;
}
.cta-band-v2 h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.9rem, 3.6vw, 3rem);
    font-weight: 300;
    color: var(--white);
    line-height: 1.2;
    max-width: 720px;
    margin: 0 auto 1rem;
}
.cta-band-v2 h2 em { font-style: italic; color: var(--accent); font-weight: 400; }
.cta-band-v2 p {
    font-size: 1rem; line-height: 1.7;
    color: var(--mist);
    max-width: 580px;
    margin: 0 auto 2.4rem;
}
.cta-band-v2-actions {
    display: flex; gap: 1rem;
    justify-content: center; flex-wrap: wrap;
}

/* ════════════════════════════════
   SCROLL REVEAL
   ════════════════════════════════ */
[data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity .8s cubic-bezier(.22,.61,.36,1), transform .8s cubic-bezier(.22,.61,.36,1);
    will-change: opacity, transform;
}
[data-reveal].is-visible {
    opacity: 1;
    transform: translateY(0);
}
[data-reveal="fade"] { transform: none; }
[data-reveal-delay="1"] { transition-delay: .08s; }
[data-reveal-delay="2"] { transition-delay: .16s; }
[data-reveal-delay="3"] { transition-delay: .24s; }
[data-reveal-delay="4"] { transition-delay: .32s; }
[data-reveal-delay="5"] { transition-delay: .40s; }

@media (prefers-reduced-motion: reduce) {
    [data-reveal] { opacity: 1 !important; transform: none !important; transition: none !important; }
    .marquee-track { animation: none !important; }
}

/* ════════════════════════════════
   MICRO-INTERACTIONS
   ════════════════════════════════ */
.service-card,
.equipement-card,
.pillar,
.testimonial-card,
.tier-card,
.pt-card {
    will-change: transform;
}
.service-card:hover { transform: translateY(-3px); }
.btn-primary, .btn-dark, .btn-whatsapp, .btn-outline, .btn-primary-light {
    position: relative;
    overflow: hidden;
}
.btn-primary::before, .btn-dark::before, .btn-whatsapp::before, .btn-primary-light::before {
    content: '';
    position: absolute;
    top: 0; left: -120%;
    width: 60%; height: 100%;
    background: linear-gradient(120deg, transparent 0%, rgba(255,255,255,0.22) 50%, transparent 100%);
    transition: left .55s ease;
    pointer-events: none;
}
.btn-primary:hover::before, .btn-dark:hover::before,
.btn-whatsapp:hover::before, .btn-primary-light:hover::before {
    left: 130%;
}

/* ════════════════════════════════
   MOBILE OVERRIDES
   ════════════════════════════════ */
@media (max-width: 900px) {
    .pricing-teaser-inner { grid-template-columns: 1fr; gap: 2rem; }
    .pricing-teaser-text p { max-width: none; }
}

@media (max-width: 768px) {
    /* Show hamburger, hide horizontal list */
    .nav-hamburger { display: inline-flex; }
    nav ul.nav-main { display: none; }

    /* Compact nav padding so mobile feels less crowded */
    nav { padding: 1rem 5vw; }
    .logo { font-size: 1.2rem; }

    /* Show sticky mobile action bar */
    .mobile-action-bar { display: flex; }

    /* Add bottom padding so content / WhatsApp widget clears the action bar */
    body { padding-bottom: 68px; }
    .wa-widget { bottom: 78px !important; }

    /* CTA v2 */
    .cta-band-v2 { padding: 4rem 5vw; }
    .cta-band-v2-actions .btn-primary,
    .cta-band-v2-actions .btn-whatsapp,
    .cta-band-v2-actions .btn-outline { width: 100%; justify-content: center; }

    /* Hero action stack on mobile */
    .hero-actions { flex-direction: column; align-items: stretch; gap: .8rem; width: 100%; }
    .hero-actions .btn-primary,
    .hero-actions .btn-outline,
    .hero-actions .btn-whatsapp { width: 100%; justify-content: center; text-align: center; }
    .hero-microtrust { gap: 1rem; font-size: .68rem; }

    /* Testimonials tighter */
    .testimonials { padding: 4.5rem 5vw; }
    .testimonials-grid { gap: 1rem; }

    /* Pricing teaser */
    .pricing-teaser { padding: 3.8rem 5vw; }
    .pricing-teaser-grid { grid-template-columns: 1fr 1fr; }
    .pt-card { padding: 1.3rem 1.1rem; }
    .pt-card-price { font-size: 1.55rem; }

    /* Footer columns */
    .footer-grid { gap: 2rem; }

    /* Trust strip stack */
    .trust-strip-inner { justify-content: center; text-align: center; }
    .trust-strip-items { gap: 1.4rem; justify-content: center; }
    .trust-strip-items span { font-size: .92rem; }
}

@media (max-width: 480px) {
    .pricing-teaser-grid { grid-template-columns: 1fr; }
    .testimonial-card { padding: 2rem 1.5rem 1.6rem; }
    .mobile-action-bar a { font-size: .65rem; padding: .8rem .25rem; }
    .mab-call svg, .mab-wa svg, .mab-quote svg { width: 14px; height: 14px; }
    .hero p { font-size: .94rem; }
}

/* ════════════════════════════════════════
   LOGIN — SWITCH-ACCOUNT BANNER
   Shown when an already-authenticated user visits /login
   ════════════════════════════════════════ */
.auth-flash-switch {
    background: linear-gradient(180deg, #fff8e6 0%, #fff2cc 100%);
    border-left: 3px solid var(--accent);
    color: var(--navy);
    align-items: flex-start;
}
.auth-flash-switch svg {
    color: var(--accent);
    margin-top: 4px;
}
.auth-switch-text {
    display: flex; flex-direction: column;
    gap: .25rem;
    line-height: 1.5;
}
.auth-switch-text strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.02rem;
    font-weight: 600;
    color: var(--navy);
}
.auth-switch-text span {
    font-size: .85rem;
    color: #5a5a5a;
}
.auth-switch-text a {
    color: #c0392b;
    text-decoration: underline;
    font-weight: 600;
    transition: color .2s;
}
.auth-switch-text a:hover {
    color: #a83323;
}




/* ===========================================================================
   HARDENING LAYER (must come last so it wins the cascade)
   - Restores mobile-drawer-admin / -switch / -logout helpers that lived
     in the stale ACCOUNT DROPDOWN block we deleted.
   - Re-asserts the desktop dashboard grid with high-specificity selectors
     so no legacy/cached rule can collapse the layout.
   - Forces the nav account dropdown above every layout child via a max
     z-index so it can never be obscured.
   =========================================================================== */

/* Mobile drawer link variants (restored) */
.mobile-drawer ul a.mobile-drawer-admin  { color: var(--accent)  !important; }
.mobile-drawer ul a.mobile-drawer-switch { color: #cfe2ff        !important; }
.mobile-drawer ul a.mobile-drawer-logout { color: #f5b7b1        !important; }
.mobile-drawer ul a.mobile-drawer-admin::after  { content: '\2699'; color: var(--accent); opacity: 1; margin-left: .35rem; }
.mobile-drawer ul a.mobile-drawer-switch::after { content: '\21BB'; color: #cfe2ff; opacity: 1; margin-left: .35rem; }
.mobile-drawer ul a.mobile-drawer-logout::after { content: '\21AA'; color: #f5b7b1; opacity: 1; margin-left: .35rem; }

/* Dropdown z-index — last line of defence */
nav .nav-account-wrap .nav-account-menu { z-index: 2147483000 !important; }

/* Re-assert the desktop dashboard grid so no stale rule can collapse it. */
section.ec-account .ec-account-wrap {
    display: grid !important;
    grid-template-columns: 240px minmax(0, 1fr) !important;
    gap: 2rem !important;
    max-width: 1400px !important;
    margin: 0 auto !important;
    padding: 0 2rem !important;
    align-items: start !important;
}
section.ec-account .ec-side {
    position: sticky;
    top: 100px;
    align-self: start;
    z-index: 5;
}
section.ec-account .ec-main { min-width: 0; z-index: 5; position: relative; }

/* <=1023.98px : sidebar becomes a horizontal chip rail above the main area. */
@media (max-width: 1023.98px) {
    section.ec-account .ec-account-wrap {
        grid-template-columns: 1fr !important;
        gap: 1.25rem !important;
        padding: 0 1.25rem !important;
    }
    section.ec-account .ec-side {
        position: static !important;
        flex-direction: row;
        gap: .8rem;
        overflow-x: auto;
        padding-bottom: .25rem;
        max-height: none;
    }
    section.ec-account .ec-side .ec-side-card { flex-shrink: 0; min-width: 240px; }
    section.ec-account .ec-side .ec-side-nav {
        flex-direction: row;
        flex-shrink: 0;
        gap: 4px;
        padding: .4rem;
    }
    section.ec-account .ec-side .ec-side-nav a {
        white-space: nowrap;
        padding: .55rem .8rem;
        font-size: .8rem;
    }
    section.ec-account .ec-side .ec-side-nav .ec-side-count { display: none; }
    section.ec-account .ec-side .ec-side-sep { display: none; }
}

/* <=767.98px : hide sidebar entirely (drawer handles nav on mobile). */
@media (max-width: 767.98px) {
    section.ec-account { padding: 90px 0 6rem !important; }
    section.ec-account .ec-side { display: none !important; }
    section.ec-account .ec-account-wrap { padding: 0 1rem !important; }
}



/* ─────────────────────────────────────────────────────────────────────
 * Error pages (404 / 403 / 429 / 500). Added by audit § 1.8.
 * Visually quiet, branded, prominently offers a WhatsApp escape hatch.
 * ───────────────────────────────────────────────────────────────────── */
.error-section{
    min-height: calc(100vh - 200px);
    display: flex;
    align-items: center;
    justify-content: center;
    padding: 4rem 1.5rem;
    background: linear-gradient(180deg, #f9f5ec 0%, #f3ece0 100%);
}
.error-card{
    max-width: 560px;
    width: 100%;
    text-align: center;
    background: #fff;
    border: 1px solid rgba(200, 169, 110, 0.25);
    border-radius: 18px;
    padding: 3rem 2rem;
    box-shadow: 0 12px 40px rgba(20, 33, 61, 0.08);
}
.error-code{
    font-family: 'Cormorant Garamond', serif;
    font-size: 5rem;
    font-weight: 300;
    color: #c8a96e;
    line-height: 1;
    margin-bottom: 1rem;
    letter-spacing: 0.04em;
}
.error-title{
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem;
    font-weight: 600;
    color: #14213d;
    margin: 0 0 1rem;
}
.error-message{
    color: #555;
    font-size: 1rem;
    line-height: 1.65;
    margin: 0 0 1.5rem;
}
.error-meta{
    font-size: 0.85rem;
    color: #888;
    margin: 0 0 1.5rem;
}
.error-meta code{
    background: #f4f0e6;
    padding: 2px 8px;
    border-radius: 4px;
    font-family: 'DM Mono', 'Courier New', monospace;
    color: #c8a96e;
}
.error-actions{
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    align-items: center;
}
.error-actions a{
    display: inline-block;
    padding: 0.85rem 1.75rem;
    border-radius: 8px;
    font-weight: 500;
    text-decoration: none;
    transition: all 0.2s;
    min-width: 260px;
}
.error-actions .btn-primary{
    background: #c8a96e;
    color: #fff;
}
.error-actions .btn-primary:hover{
    background: #b89858;
    transform: translateY(-1px);
}
.error-actions .btn-ghost{
    background: transparent;
    color: #14213d;
    border: 1px solid rgba(20, 33, 61, 0.2);
}
.error-actions .btn-ghost:hover{
    background: #14213d;
    color: #fff;
}
@media (max-width: 600px){
    .error-card{ padding: 2rem 1.25rem; }
    .error-code{ font-size: 3.5rem; }
    .error-title{ font-size: 1.5rem; }
}

/* ─────────────────────────────────────────────────────────────────────
 * Quote form error banner — audit § 3.1. Shown when server-side
 * validation rejects the submission (missing required fields).
 * ───────────────────────────────────────────────────────────────────── */
.form-error-banner{
    background: #fdecea;
    border-left: 3px solid #c0392b;
    color: #8b1e0f;
    padding: 14px 18px;
    margin: 0 0 18px;
    border-radius: 4px;
    font-size: 14px;
    line-height: 1.5;
}

/* ─────────────────────────────────────────────────────────
   HOME REDESIGN — Boya Linen · May 2026
   B2B hotel linen supply chain narrative.
   All new classes are namespaced `.home-*` to avoid colliding
   with legacy `.hero`, `.service-card`, etc. used elsewhere.
   ───────────────────────────────────────────────────────── */

/* ── Hero (slim, B2B supply-chain narrative) ── */
.home-hero {
    position: relative;
    min-height: 64vh;
    display: flex; align-items: center;
    padding: 7rem 5vw 3.5rem;
    color: var(--white);
    overflow: hidden;
}
.home-hero-bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    z-index: 0;
}
/* .home-hero-bg::after removed — this was a navy gradient overlay that
   darkened the ENTIRE hero photo by 45–94% (it never dropped below 0.45
   opacity, so even the right edge was veiled). The homepage hero is
   styled by home.css, which keeps the photo at full brightness; text
   legibility is handled by text-shadow, not by darkening the image. */
.home-hero-content {
    position: relative; z-index: 1;
    max-width: 760px;
}
.home-hero-eyebrow {
    color: var(--accent);
    font-size: .72rem; font-weight: 600;
    letter-spacing: .28em; text-transform: uppercase;
    margin-bottom: 1.2rem;
}
.home-hero h1 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(2.2rem, 4.4vw, 3.6rem);
    font-weight: 500; line-height: 1.1;
    margin-bottom: 1.2rem;
    color: var(--white);
}
.home-hero h1 em { color: var(--accent-light); font-style: italic; }
.home-hero-divider {
    width: 60px; height: 2px; background: var(--accent);
    margin: 1rem 0 1.4rem;
}
.home-hero-sub {
    font-size: 1.02rem; line-height: 1.7;
    color: var(--mist);
    max-width: 620px;
    margin-bottom: 1.8rem;
}
.home-hero-actions { display: flex; gap: .8rem; flex-wrap: wrap; }
.home-hero-microtrust {
    margin-top: 1.6rem;
    display: flex; gap: 1.6rem; flex-wrap: wrap;
    font-size: .82rem; color: var(--mist);
}
.home-hero-microtrust span::before {
    content: "✓ "; color: var(--accent); margin-right: 4px;
}
.home-hero-microtrust a { color: var(--mist); text-decoration: none; }
.home-hero-microtrust a:hover { color: var(--accent); }

/* ── Section title ── */
.home-section-eyebrow {
    color: var(--accent);
    font-size: .72rem; font-weight: 600;
    letter-spacing: .28em; text-transform: uppercase;
    margin-bottom: .8rem;
}
.home-section-title {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3.2vw, 2.6rem);
    font-weight: 500; line-height: 1.15;
    color: var(--navy);
    margin-bottom: 2.2rem;
}
.home-section-title em { color: var(--blue); font-style: italic; }

/* ── Trust bar (slim) ── */
.home-trust-bar {
    background: var(--navy);
    color: var(--mist);
    padding: 1.6rem 5vw;
    display: flex; justify-content: space-around; align-items: center;
    gap: 2rem; flex-wrap: wrap;
}
.home-trust-item {
    display: flex; align-items: baseline; gap: .55rem;
    font-size: .9rem;
}
.home-trust-item strong {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.7rem; font-weight: 600;
    color: var(--accent);
    letter-spacing: .02em;
}

/* ── Supply-chain timeline (THE CENTREPIECE) ── */
.home-chain-section {
    padding: 5rem 5vw 4rem;
    background: var(--white);
}
.home-chain-head {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 3rem;
    align-items: end;
    margin-bottom: 3rem;
}
.home-chain-head .lead {
    font-size: 1rem;
    color: #555;
    line-height: 1.7;
    max-width: 460px;
    margin-left: auto;
}
.home-chain-grid {
    display: grid;
    grid-template-columns: 1fr;
    gap: 0;
    counter-reset: chain;
}
.home-chain-row {
    display: grid;
    grid-template-columns: 110px 1fr 1fr;
    gap: 2.4rem;
    padding: 2rem 0;
    border-top: 1px solid rgba(10,22,40,0.10);
    align-items: start;
}
.home-chain-row:last-child {
    border-bottom: 1px solid rgba(10,22,40,0.10);
}
.home-chain-num {
    font-family: 'Cormorant Garamond', serif;
    font-size: 3.2rem;
    font-weight: 500;
    color: var(--accent);
    line-height: 1;
    letter-spacing: .04em;
}
.home-chain-body h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem;
    font-weight: 600;
    color: var(--navy);
    margin: .2rem 0 .5rem;
    line-height: 1.2;
}
.home-chain-body .zh {
    display: block;
    font-size: .82rem;
    color: var(--accent);
    letter-spacing: .14em;
    margin-bottom: .4rem;
    font-weight: 500;
}
.home-chain-body p {
    font-size: .95rem;
    color: #555;
    line-height: 1.7;
    max-width: 360px;
}
.home-chain-aside {
    background: #f6f1e9;
    border-left: 3px solid var(--accent);
    padding: 1.2rem 1.4rem;
    border-radius: 0 4px 4px 0;
}
.home-chain-aside strong {
    display: block;
    font-size: .82rem;
    letter-spacing: .14em;
    text-transform: uppercase;
    color: var(--accent);
    margin-bottom: .35rem;
    font-weight: 600;
}
.home-chain-aside span {
    font-size: .92rem;
    color: #444;
    line-height: 1.6;
}

/* ── B2B offer block (single, dominant) ── */
.home-b2b-feature {
    background:
        linear-gradient(135deg, rgba(13,31,60,0.92) 0%, rgba(26,58,107,0.92) 100%),
        var(--deep);
    color: var(--white);
    padding: 4.5rem 5vw;
}
.home-b2b-feature-inner {
    display: grid;
    grid-template-columns: 1fr 1.2fr;
    gap: 3rem;
    align-items: center;
}
.home-b2b-feature h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    font-weight: 500; line-height: 1.15;
    margin-bottom: 1rem;
    color: var(--white);
}
.home-b2b-feature h2 em { color: var(--accent-light); font-style: italic; }
.home-b2b-feature .lead {
    color: var(--mist);
    line-height: 1.7;
    margin-bottom: 1.4rem;
    max-width: 520px;
}
.home-b2b-feature ul {
    list-style: none;
    padding: 0;
    margin: 0 0 1.6rem;
    display: grid;
    gap: .55rem;
}
.home-b2b-feature ul li {
    color: var(--mist);
    font-size: .94rem;
    padding-left: 1.3rem;
    position: relative;
}
.home-b2b-feature ul li::before {
    content: "→";
    position: absolute;
    left: 0; top: 0;
    color: var(--accent);
    font-weight: 600;
}
.home-b2b-stats-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1rem;
}
.home-b2b-stat {
    background: rgba(200,169,110,0.08);
    border: 1px solid rgba(200,169,110,0.25);
    padding: 1.4rem 1.2rem;
    border-radius: 4px;
}
.home-b2b-stat strong {
    display: block;
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.9rem; font-weight: 600;
    color: var(--accent);
    margin-bottom: .25rem;
}
.home-b2b-stat span {
    font-size: .82rem; color: var(--mist);
    letter-spacing: .04em;
}

/* ── B2C strip (secondary line — pressing + boutique) ── */
.home-b2c-strip {
    padding: 4rem 5vw 4.5rem;
    background: var(--white);
}
.home-b2c-head {
    text-align: center;
    margin-bottom: 2.5rem;
}
.home-b2c-head .home-section-title {
    margin-bottom: .8rem;
}
.home-b2c-head .lead {
    color: #5b5b5b;
    line-height: 1.7;
    max-width: 620px;
    margin: 0 auto;
}
.home-b2c-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
    max-width: 900px;
    margin: 0 auto;
}
.home-b2c-card {
    position: relative;
    background: var(--navy);
    border-radius: 4px;
    overflow: hidden;
    text-decoration: none;
    min-height: 260px;
    display: flex; flex-direction: column; justify-content: flex-end;
    padding: 1.6rem;
    border: 1px solid rgba(200,169,110,0.12);
    transition: transform .3s ease, box-shadow .3s ease;
}
.home-b2c-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 12px 30px rgba(10,22,40,0.16);
}
.home-b2c-card-img {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    opacity: .55;
}
.home-b2c-card::after {
    content: "";
    position: absolute; inset: 0;
    background: linear-gradient(180deg,
        rgba(10,22,40,0.10) 0%,
        rgba(10,22,40,0.88) 100%);
}
.home-b2c-card > *:not(.home-b2c-card-img) { position: relative; z-index: 2; }
.home-b2c-card .label {
    font-size: .68rem; font-weight: 600;
    letter-spacing: .26em; text-transform: uppercase;
    color: var(--accent);
    margin-bottom: .5rem;
}
.home-b2c-card h3 {
    font-family: 'Cormorant Garamond', serif;
    font-size: 1.5rem; font-weight: 600;
    color: var(--white);
    margin-bottom: .35rem;
}
.home-b2c-card p {
    font-size: .88rem;
    color: var(--mist);
    margin-bottom: .8rem;
}
.home-b2c-card .cta {
    display: inline-flex; align-items: center; gap: .4rem;
    font-size: .74rem; font-weight: 600;
    letter-spacing: .18em; text-transform: uppercase;
    color: var(--accent-light);
}
.home-b2c-card .cta::after { content: "→"; transition: transform .25s; }
.home-b2c-card:hover .cta::after { transform: translateX(4px); }

/* ── Testimonials (compact, 2 cards) ── */
.home-testi-section {
    padding: 4rem 5vw;
    background: #f6f1e9;
}
.home-testi-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 18px;
}
.home-testi-card {
    background: var(--white);
    border: 1px solid rgba(10,22,40,0.08);
    border-left: 3px solid var(--accent);
    padding: 1.6rem;
    border-radius: 0 4px 4px 0;
}
.home-testi-card .stars {
    color: var(--accent);
    letter-spacing: .15em;
    font-size: .82rem;
    margin-bottom: .7rem;
}
.home-testi-card .quote {
    font-family: 'Cormorant Garamond', serif;
    font-style: italic;
    font-size: 1.05rem; line-height: 1.6;
    color: var(--navy);
    margin-bottom: 1rem;
}
.home-testi-author { display: flex; align-items: center; gap: .8rem; }
.home-testi-avatar {
    width: 40px; height: 40px; border-radius: 50%;
    background: var(--navy); color: var(--accent);
    display: flex; align-items: center; justify-content: center;
    font-weight: 600;
    font-family: 'Cormorant Garamond', serif;
}
.home-testi-meta strong {
    display: block;
    font-size: .9rem; color: var(--navy);
}
.home-testi-meta span {
    font-size: .78rem; color: #6b6b6b;
}

/* ── Final CTA band ── */
.home-final-cta {
    background: var(--navy);
    color: var(--white);
    padding: 4rem 5vw;
    text-align: center;
}
.home-final-cta .home-section-eyebrow {
    margin-bottom: .8rem;
}
.home-final-cta h2 {
    font-family: 'Cormorant Garamond', serif;
    font-size: clamp(1.8rem, 3vw, 2.4rem);
    font-weight: 500; line-height: 1.2;
    margin-bottom: 1rem;
    color: var(--white);
}
.home-final-cta h2 em { color: var(--accent-light); font-style: italic; }
.home-final-cta p { color: var(--mist); margin-bottom: 1.6rem; }
.home-final-cta-actions {
    display: flex; justify-content: center; gap: .8rem; flex-wrap: wrap;
}
.home-final-cta-secondary {
    margin-top: 1.4rem;
    font-size: .85rem;
    color: var(--mist);
}
.home-final-cta-secondary a {
    color: var(--accent-light);
    text-decoration: underline;
}

/* ── Responsive ── */
@media (max-width: 920px) {
    .home-chain-head { grid-template-columns: 1fr; gap: 1rem; }
    .home-chain-head .lead { margin-left: 0; max-width: none; }
    .home-chain-row {
        grid-template-columns: 60px 1fr;
        gap: 1.2rem;
        padding: 1.6rem 0;
    }
    .home-chain-num { font-size: 2.2rem; }
    .home-chain-aside {
        grid-column: 1 / -1;
        margin-top: .5rem;
    }
    .home-b2b-feature-inner { grid-template-columns: 1fr; }
    .home-b2c-grid { grid-template-columns: 1fr; }
    .home-testi-grid { grid-template-columns: 1fr; }
    .home-trust-bar { gap: 1.2rem; padding: 1.4rem 5vw; }
    .home-trust-item strong { font-size: 1.4rem; }
}

@media (max-width: 560px) {
    .home-b2b-stats-grid { grid-template-columns: 1fr; }
    .home-hero { min-height: 56vh; padding-top: 6rem; }
}
