/* ==========================================================================
   AFRICAFRESH — Shared Design System
   Aesthetic: Desert Gold — warm editorial luxury
   ========================================================================== */

@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;0,9..144,600;0,9..144,700;1,9..144,300;1,9..144,400;1,9..144,600&family=Bricolage+Grotesque:opsz,wght@12..96,300;12..96,400;12..96,500;12..96,600&family=Amiri:ital,wght@0,400;0,700;1,400&family=Tajawal:wght@300;400;500;600&display=swap');

:root {
    --sand:   #F0E8D4;
    --cream:  #FAF6ED;
    --dark:   #1A150D;
    --terra:  #C24828;
    --green:  #1D4B2E;
    --gold:   #C8923C;
    --muted:  #8C7B65;
    --border: rgba(26,21,13,0.1);
    --ff-d: 'Fraunces', serif;
    --ff-b: 'Bricolage Grotesque', sans-serif;
}

/* ── RESET & BASE ── */
*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    background: var(--cream);
    color: var(--dark);
    font-family: var(--ff-b);
    font-size: 16px;
    line-height: 1.5;
    overflow-x: hidden;
}
img { display: block; max-width: 100%; }
a { color: inherit; }

/* Grain */
body::after {
    content: '';
    position: fixed; inset: 0;
    background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='200' height='200'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3CfeColorMatrix type='saturate' values='0'/%3E%3C/filter%3E%3Crect width='200' height='200' filter='url(%23n)' opacity='0.4'/%3E%3C/svg%3E");
    pointer-events: none;
    z-index: 9999;
    opacity: 0.03;
    mix-blend-mode: multiply;
}

/* ── NAV ── */
nav {
    position: fixed; top: 0; left: 0; right: 0;
    z-index: 100;
    padding: 1.2rem 3rem;
    display: flex; align-items: center; justify-content: space-between;
    transition: background 0.4s, box-shadow 0.4s;
}
nav.scrolled {
    background: rgba(250,246,237,0.93);
    backdrop-filter: blur(14px);
    box-shadow: 0 1px 0 var(--border);
}
.nav-logo {
    font-family: var(--ff-d);
    font-size: 1.35rem; font-weight: 600;
    letter-spacing: 0.1em;
    color: var(--dark); text-decoration: none;
}
.nav-logo span { color: var(--terra); }
.nav-links {
    display: flex; align-items: center;
    gap: 2rem; list-style: none;
}
.nav-links a {
    color: var(--dark); text-decoration: none;
    font-size: 0.85rem; font-weight: 500;
    letter-spacing: 0.02em;
    opacity: 0.6;
    transition: opacity 0.2s;
    position: relative;
}
.nav-links a::after {
    content: '';
    position: absolute; bottom: -3px; left: 0; right: 0;
    height: 1px; background: var(--terra);
    transform: scaleX(0); transform-origin: left;
    transition: transform 0.25s;
}
.nav-links a:hover { opacity: 1; }
.nav-links a:hover::after { transform: scaleX(1); }
.nav-links a.active { opacity: 1; }
.nav-links a.active::after { transform: scaleX(1); }
.nav-cta {
    background: var(--terra) !important; color: #fff !important;
    padding: 0.55rem 1.4rem !important;
    border-radius: 100px !important;
    opacity: 1 !important;
    transition: background 0.25s !important;
}
.nav-cta::after { display: none !important; }
.nav-cta:hover { background: var(--green) !important; }

/* ── BUTTONS ── */
.btn-primary {
    display: inline-block;
    background: var(--terra); color: #fff;
    padding: 0.85rem 2rem; border-radius: 4px;
    text-decoration: none; font-size: 0.875rem; font-weight: 600;
    letter-spacing: 0.02em;
    border: none; cursor: pointer;
    transition: background 0.25s, transform 0.2s;
}
.btn-primary:hover { background: var(--green); transform: translateY(-2px); }

.btn-ghost {
    display: inline-flex; align-items: center; gap: 0.5rem;
    color: var(--dark); text-decoration: none;
    font-size: 0.875rem; font-weight: 500;
    transition: gap 0.25s;
}
.btn-ghost::after { content: '→'; }
.btn-ghost:hover { gap: 0.9rem; }

.btn-sand {
    display: inline-block;
    background: var(--sand); color: var(--dark);
    padding: 0.9rem 2.25rem; border-radius: 4px;
    text-decoration: none; font-size: 0.875rem; font-weight: 600;
    letter-spacing: 0.02em; border: none; cursor: pointer;
    transition: background 0.2s, transform 0.2s;
}
.btn-sand:hover { background: #fff; transform: translateY(-2px); }

.btn-outline-sand {
    display: inline-block;
    border: 1px solid rgba(240,232,212,0.3); color: rgba(240,232,212,0.8);
    padding: 0.9rem 1.75rem; border-radius: 4px;
    text-decoration: none; font-size: 0.875rem; font-weight: 500;
    transition: border-color 0.2s, color 0.2s;
}
.btn-outline-sand:hover { border-color: var(--sand); color: var(--sand); }

.btn-outline {
    display: inline-block;
    border: 1px solid var(--border); color: var(--dark);
    padding: 0.8rem 1.75rem; border-radius: 4px;
    text-decoration: none; font-size: 0.875rem; font-weight: 500;
    transition: border-color 0.2s, background 0.2s;
}
.btn-outline:hover { border-color: var(--terra); background: rgba(194,72,40,0.04); }

/* ── SHARED TYPOGRAPHY ── */
.label {
    font-size: 0.68rem; font-weight: 600;
    letter-spacing: 0.2em; text-transform: uppercase;
    color: var(--terra); margin-bottom: 1.25rem;
    display: block;
}
.title {
    font-family: var(--ff-d);
    font-size: clamp(2rem, 3.5vw, 3.2rem);
    font-weight: 600; line-height: 1.12;
    letter-spacing: -0.02em;
}
.title em { font-style: italic; font-weight: 300; color: var(--terra); }

/* ── PAGE HERO (inner pages) ── */
.page-hero {
    padding: 10rem 3rem 7rem;
    background: var(--sand);
    position: relative; overflow: hidden;
}
.page-hero::before {
    content: '';
    position: absolute; top: -50%; right: -10%;
    width: 60%; height: 200%;
    background: radial-gradient(ellipse, rgba(200,146,60,0.14) 0%, transparent 60%);
    pointer-events: none;
}
.page-hero::after {
    content: '';
    position: absolute; bottom: -30%; left: -5%;
    width: 45%; height: 100%;
    background: radial-gradient(ellipse, rgba(194,72,40,0.07) 0%, transparent 60%);
    pointer-events: none;
}
.page-hero-inner {
    max-width: 1200px; margin: 0 auto;
    position: relative; z-index: 1;
}
.page-hero-title {
    font-family: var(--ff-d);
    font-size: clamp(2.8rem, 5vw, 5rem);
    font-weight: 600; line-height: 1.05;
    letter-spacing: -0.03em;
    max-width: 800px;
    margin-top: 1rem;
}
.page-hero-title em { font-style: italic; font-weight: 300; color: var(--terra); }
.page-hero-desc {
    font-size: 1.05rem; line-height: 1.75;
    color: var(--muted); max-width: 560px;
    margin-top: 1.5rem;
}

/* ── MARQUEE ── */
.marquee-wrap { background: var(--dark); padding: 1rem 0; overflow: hidden; }
.marquee-track { display: flex; animation: scroll 36s linear infinite; width: max-content; }
.marquee-item {
    display: inline-flex; align-items: center; gap: 1.5rem;
    padding: 0 1.5rem;
    font-size: 0.72rem; font-weight: 500;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: rgba(240,232,212,0.45); white-space: nowrap;
}
.marquee-sep {
    display: inline-block; width: 3px; height: 3px;
    border-radius: 50%; background: var(--terra); flex-shrink: 0;
}
.marquee-item.hl { color: var(--gold); }

/* ── SHARED CTA BLOCK ── */
.cta-block {
    padding: 8rem 3rem;
    background: var(--green);
    position: relative; overflow: hidden;
}
.cta-block::before {
    content: '';
    position: absolute; top: -30%; right: -5%;
    width: 50%; height: 160%;
    background: radial-gradient(ellipse, rgba(200,146,60,0.2) 0%, transparent 65%);
    pointer-events: none;
}
.cta-block-inner {
    max-width: 760px; margin: 0 auto;
    text-align: center; position: relative; z-index: 1;
}
.cta-eyebrow {
    font-size: 0.68rem; letter-spacing: 0.2em; text-transform: uppercase;
    color: rgba(240,232,212,0.5); margin-bottom: 1.5rem;
    display: block;
}
.cta-title {
    font-family: var(--ff-d);
    font-size: clamp(2.5rem, 5vw, 4.5rem);
    font-weight: 600; line-height: 1.08;
    letter-spacing: -0.025em;
    color: var(--sand); margin-bottom: 1.5rem;
}
.cta-title em { font-style: italic; font-weight: 300; color: var(--gold); }
.cta-sub {
    font-size: 1rem; color: rgba(240,232,212,0.6);
    line-height: 1.7; margin-bottom: 3rem;
}
.cta-btns { display: flex; gap: 1rem; justify-content: center; }

/* ── FOOTER ── */
footer { background: var(--dark); padding: 5.5rem 3rem 2.5rem; color: rgba(240,232,212,0.55); }
.footer-inner { max-width: 1200px; margin: 0 auto; }
.footer-grid {
    display: grid; grid-template-columns: 2fr 1fr 1fr 1fr;
    gap: 4rem;
    padding-bottom: 4rem;
    border-bottom: 1px solid rgba(240,232,212,0.08);
    margin-bottom: 2rem;
}
.footer-logo { font-family: var(--ff-d); font-size: 1.4rem; font-weight: 600; color: var(--sand); letter-spacing: 0.08em; margin-bottom: 1rem; }
.footer-logo span { color: var(--terra); }
.footer-tagline { font-size: 0.875rem; line-height: 1.7; max-width: 250px; margin-bottom: 1.5rem; }
.footer-social { display: flex; gap: 0.6rem; }
.soc-link {
    width: 2rem; height: 2rem;
    border: 1px solid rgba(240,232,212,0.12);
    border-radius: 4px;
    display: flex; align-items: center; justify-content: center;
    color: rgba(240,232,212,0.45); text-decoration: none;
    transition: border-color 0.2s, color 0.2s;
}
.soc-link:hover { border-color: var(--terra); color: var(--terra); }
.footer-col-h { font-size: 0.68rem; font-weight: 600; letter-spacing: 0.16em; text-transform: uppercase; color: var(--sand); margin-bottom: 1.5rem; }
.footer-links { list-style: none; display: flex; flex-direction: column; gap: 0.7rem; }
.footer-links li { font-size: 0.875rem; }
.footer-links a { color: rgba(240,232,212,0.5); text-decoration: none; transition: color 0.2s; }
.footer-links a:hover { color: var(--sand); }
.footer-bottom {
    display: flex; justify-content: space-between; align-items: center;
    font-size: 0.78rem;
}

/* ── REVEAL ── */
.reveal {
    opacity: 0; transform: translateY(26px);
    transition: opacity 0.7s ease, transform 0.7s ease;
}
.reveal.in { opacity: 1; transform: translateY(0); }

/* ── KEYFRAMES ── */
@keyframes fadeUp  { from { opacity:0; transform:translateY(22px); } to { opacity:1; transform:translateY(0); } }
@keyframes fadeIn  { from { opacity:0; } to { opacity:1; } }
@keyframes scroll  { from { transform:translateX(0); } to { transform:translateX(-50%); } }
@keyframes spin    { from { transform:rotate(0deg); } to { transform:rotate(360deg); } }
@keyframes spin-rev{ from { transform:rotate(0deg); } to { transform:rotate(-360deg); } }

/* ── LANGUAGE TOGGLE ── */
.lang-toggle {
    background: none; border: 1px solid var(--border);
    color: var(--dark); border-radius: 100px;
    padding: 0.38rem 0.9rem;
    font-family: var(--ff-b); font-size: 0.75rem; font-weight: 600;
    cursor: pointer; letter-spacing: 0.04em;
    transition: background 0.2s, border-color 0.2s, color 0.2s;
    white-space: nowrap;
}
.lang-toggle:hover { background: var(--terra); border-color: var(--terra); color: #fff; }

/* ── WHATSAPP FLOATING BUTTON ── */
.wa-float {
    position: fixed; bottom: 2rem; right: 2rem;
    width: 3.25rem; height: 3.25rem; border-radius: 50%;
    background: #25D366; color: #fff; text-decoration: none;
    display: flex; align-items: center; justify-content: center;
    box-shadow: 0 4px 20px rgba(37,211,102,0.4);
    z-index: 9998;
    transition: transform 0.25s, box-shadow 0.25s;
}
.wa-float:hover { transform: scale(1.1); box-shadow: 0 6px 28px rgba(37,211,102,0.55); }
.wa-tooltip {
    position: absolute; right: calc(100% + 0.75rem); top: 50%; transform: translateY(-50%) translateX(4px);
    background: var(--dark); color: var(--sand);
    padding: 0.4rem 0.9rem; border-radius: 4px;
    font-family: var(--ff-b); font-size: 0.75rem; font-weight: 500;
    white-space: nowrap; pointer-events: none;
    opacity: 0; transition: opacity 0.2s, transform 0.2s;
}
.wa-tooltip::after {
    content: ''; position: absolute; left: 100%; top: 50%; transform: translateY(-50%);
    border: 5px solid transparent; border-left-color: var(--dark);
}
.wa-float:hover .wa-tooltip { opacity: 1; transform: translateY(-50%) translateX(0); }

/* ── TRUST STRIP ── */
.trust-strip { background: var(--dark); padding: 1.35rem 3rem; }
.trust-strip-inner {
    max-width: 1200px; margin: 0 auto;
    display: flex; align-items: center; gap: 2.5rem; flex-wrap: wrap;
}
.trust-cert-label,
.trust-market-label {
    font-size: 0.62rem; font-weight: 600; letter-spacing: 0.14em;
    text-transform: uppercase; color: rgba(240,232,212,0.35);
    white-space: nowrap; flex-shrink: 0;
}
.trust-badge-list { display: flex; gap: 0.5rem; flex-wrap: wrap; align-items: center; }
.trust-badge {
    font-size: 0.63rem; font-weight: 700; letter-spacing: 0.05em;
    color: var(--gold); border: 1px solid rgba(200,146,60,0.35);
    padding: 0.2rem 0.65rem; border-radius: 100px; white-space: nowrap;
}
.trust-strip-sep { width: 1px; height: 1.75rem; background: rgba(240,232,212,0.1); flex-shrink: 0; }
.trust-strip-markets { display: flex; align-items: center; gap: 1rem; flex-wrap: wrap; }
.trust-flags { display: flex; align-items: center; gap: 0.3rem; font-size: 1.15rem; line-height: 1; }
.trust-flags span[title] { cursor: default; transition: transform 0.15s; display: inline-block; }
.trust-flags span[title]:hover { transform: scale(1.25); }
.trust-flag-more {
    font-size: 0.62rem; font-weight: 600; color: rgba(240,232,212,0.4);
    letter-spacing: 0.06em; margin-left: 0.2rem;
}

/* ── RTL (Arabic) ── */
html[dir="rtl"] { --ff-b: 'Tajawal', sans-serif; --ff-d: 'Amiri', serif; }
html[dir="rtl"] .hero-lbl::before { display: none; }
html[dir="rtl"] .hero-lbl { flex-direction: row-reverse; }
html[dir="rtl"] .btn-ghost::after { content: '\2190'; }
html[dir="rtl"] .wa-float { right: auto; left: 2rem; }
html[dir="rtl"] .wa-tooltip {
    right: auto; left: calc(100% + 0.75rem);
    transform: translateY(-50%) translateX(-4px);
}
html[dir="rtl"] .wa-tooltip::after { left: auto; right: 100%; border-left-color: transparent; border-right-color: var(--dark); }
html[dir="rtl"] .wa-float:hover .wa-tooltip { transform: translateY(-50%) translateX(0); }
html[dir="rtl"] .trust-flag-more { margin-left: 0; margin-right: 0.2rem; }
html[dir="rtl"] .nav-links a::after { transform-origin: right; }

/* ── HAMBURGER ── */
.nav-hamburger {
    display: none;
    flex-direction: column; gap: 5px;
    background: none; border: none; cursor: pointer;
    padding: 0.4rem; z-index: 101; margin-left: 1rem;
}
.nav-hamburger span {
    display: block; width: 22px; height: 1.5px;
    background: var(--dark);
    transition: transform 0.3s, opacity 0.3s;
}
nav.nav-open .nav-hamburger span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
nav.nav-open .nav-hamburger span:nth-child(2) { opacity: 0; }
nav.nav-open .nav-hamburger span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* ── RESPONSIVE — TABLET ── */
@media (max-width: 900px) {
    nav { padding: 1rem 1.5rem; }
    .nav-hamburger { display: flex; }
    .nav-links {
        position: fixed; top: 0; left: 0; right: 0;
        padding: 5rem 2rem 2.5rem;
        background: var(--cream);
        flex-direction: column; align-items: flex-start;
        gap: 0;
        transform: translateY(-105%);
        transition: transform 0.4s cubic-bezier(0.4,0,0.2,1);
        box-shadow: 0 12px 40px rgba(26,21,13,0.14);
        z-index: 100;
        list-style: none;
    }
    .nav-links li { width: 100%; border-bottom: 1px solid var(--border); }
    .nav-links a {
        display: block; padding: 1rem 0;
        font-size: 1rem; opacity: 1 !important;
    }
    .nav-cta {
        display: inline-block !important;
        margin-top: 1rem;
        border-radius: 4px !important;
    }
    nav.nav-open .nav-links { transform: translateY(0); }

    .footer-grid { grid-template-columns: 1fr 1fr; gap: 2.5rem; }
    .page-hero { padding: 8rem 1.5rem 5rem; }
    .cta-block { padding: 6rem 1.5rem; }
    .cta-btns { flex-direction: column; align-items: center; }
    .trust-strip { padding: 1.25rem 1.5rem; }
    .trust-strip-inner { gap: 1rem; }
    .trust-strip-sep { width: 100%; height: 1px; }
    .lang-toggle { margin-right: 0.25rem; }
    .wa-float { bottom: 1.5rem; right: 1.5rem; }
    html[dir="rtl"] .wa-float { left: 1.5rem; }
}

/* ── RESPONSIVE — MOBILE ── */
@media (max-width: 540px) {
    nav { padding: 0.9rem 1.25rem; }
    .footer-grid { grid-template-columns: 1fr; gap: 2rem; }
    .footer-bottom { flex-direction: column; gap: 0.75rem; text-align: center; }
    .page-hero { padding: 7rem 1.25rem 4rem; }
    .page-hero-title { letter-spacing: -0.02em; }
    .cta-block { padding: 4.5rem 1.25rem; }
}

/* ── CATALOG REQUEST MODAL ── */
#cat-modal-overlay {
    position: fixed; inset: 0; z-index: 10000;
    background: rgba(26,21,13,0.65);
    backdrop-filter: blur(4px);
    display: flex; align-items: center; justify-content: center;
    padding: 1.5rem;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s;
}
#cat-modal-overlay.cat-open { opacity: 1; pointer-events: auto; }
#cat-modal-overlay.cat-open .cat-modal-panel { transform: translateY(0); }

.cat-modal-panel {
    background: var(--cream); border-radius: 8px;
    width: 100%; max-width: 520px; max-height: 90vh; overflow-y: auto;
    padding: 2.5rem 2.5rem 2.5rem;
    position: relative;
    transform: translateY(20px);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
}

.cat-modal-close {
    position: absolute; top: 1.25rem; right: 1.25rem;
    background: none; border: none; cursor: pointer;
    color: var(--muted); padding: 0.25rem;
    transition: color 0.2s;
}
.cat-modal-close:hover { color: var(--dark); }

.cat-modal-eyebrow {
    display: block;
    font-family: var(--ff-b); font-size: 0.65rem; font-weight: 700;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--terra); margin-bottom: 0.6rem;
}
.cat-modal-title {
    font-family: var(--ff-d); font-size: clamp(1.5rem, 4vw, 2rem);
    font-weight: 400; color: var(--dark); margin-bottom: 0.6rem; line-height: 1.2;
}
.cat-product-chip {
    display: flex; align-items: center; gap: 0.6rem;
    background: rgba(194,72,40,0.07); border: 1px solid rgba(194,72,40,0.2);
    border-radius: 6px; padding: 0.6rem 0.9rem; margin-bottom: 1rem;
}
.cat-product-chip-label {
    font-family: var(--ff-b); font-size: 0.62rem; font-weight: 700;
    letter-spacing: 0.12em; text-transform: uppercase;
    color: var(--terra); flex-shrink: 0;
}
.cat-product-chip-name {
    font-family: var(--ff-d); font-size: 1rem; font-weight: 600;
    color: var(--dark);
}

.cat-modal-sub {
    font-size: 0.875rem; color: var(--muted); line-height: 1.6; margin-bottom: 1.75rem;
}

.cat-form-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 1rem 1.25rem; margin-bottom: 1.25rem;
}
.cat-fg { display: flex; flex-direction: column; gap: 0.4rem; }
.cat-fg-full { grid-column: 1 / -1; }
.cat-fg label {
    font-family: var(--ff-b); font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.04em; color: var(--dark);
}
.cat-fg input, .cat-fg select {
    padding: 0.65rem 0.875rem;
    border: 1px solid var(--border); border-radius: 4px;
    font-family: var(--ff-b); font-size: 0.875rem; color: var(--dark);
    background: #fff; outline: none;
    transition: border-color 0.2s;
}
.cat-fg input:focus, .cat-fg select:focus { border-color: var(--terra); }

.cat-submit {
    width: 100%; padding: 0.875rem 1.5rem;
    font-size: 0.9rem; letter-spacing: 0.04em;
    cursor: pointer;
}
.cat-submit:disabled { opacity: 0.6; cursor: not-allowed; }

.cat-error {
    font-size: 0.82rem; color: var(--terra);
    background: rgba(194,72,40,0.08); border: 1px solid rgba(194,72,40,0.25);
    border-radius: 4px; padding: 0.75rem 1rem; margin-top: 0.75rem;
}

/* Success state */
.cat-success {
    text-align: center; padding: 1rem 0;
}
.cat-success-title {
    font-family: var(--ff-d); font-size: 1.75rem; font-weight: 400;
    color: var(--dark); margin: 1rem 0 0.35rem;
}
.cat-success-sub {
    font-size: 0.85rem; color: var(--muted); margin-bottom: 1rem;
}
.cat-code-box {
    display: inline-block;
    font-family: 'Courier New', monospace; font-size: 1.5rem; font-weight: 700;
    color: var(--dark); letter-spacing: 0.18em;
    background: var(--sand); border: 2px dashed var(--terra);
    padding: 0.75rem 2rem; border-radius: 6px; margin-bottom: 1.25rem;
}
.cat-success-note {
    font-size: 0.8rem; color: var(--muted); line-height: 1.6;
    margin-bottom: 1.5rem; max-width: 360px; margin-left: auto; margin-right: auto;
}

@media (max-width: 540px) {
    .cat-modal-panel { padding: 2rem 1.5rem; }
    .cat-form-grid { grid-template-columns: 1fr; }
    .cat-fg-full { grid-column: auto; }
}

/* ── FREIGHT QUOTE MODAL ── */
#quote-modal-overlay {
    position: fixed; inset: 0; z-index: 10001;
    background: rgba(26,21,13,0.65);
    backdrop-filter: blur(4px);
    display: flex; align-items: flex-start; justify-content: center;
    padding: 2rem 1.5rem;
    overflow-y: auto;
    opacity: 0; pointer-events: none;
    transition: opacity 0.3s;
}
#quote-modal-overlay.qm-open { opacity: 1; pointer-events: auto; }
#quote-modal-overlay.qm-open .qmodal-panel { transform: translateY(0); }

.qmodal-panel {
    background: var(--cream); border-radius: 8px;
    width: 100%; max-width: 640px;
    padding: 2.5rem;
    position: relative;
    transform: translateY(20px);
    transition: transform 0.35s cubic-bezier(0.4,0,0.2,1);
    margin: auto;
}

.q-section-head {
    font-family: var(--ff-b); font-size: 0.62rem; font-weight: 700;
    letter-spacing: 0.14em; text-transform: uppercase;
    color: var(--terra); margin: 1.5rem 0 0.85rem;
    padding-bottom: 0.5rem; border-bottom: 1px solid var(--border);
}
.q-section-head:first-of-type { margin-top: 0.25rem; }

.qfg-grid {
    display: grid; grid-template-columns: 1fr 1fr; gap: 0.85rem 1.25rem;
}
.qfg { display: flex; flex-direction: column; gap: 0.35rem; }
.qfg-full { grid-column: 1 / -1; }
.qfg label {
    font-family: var(--ff-b); font-size: 0.7rem; font-weight: 600;
    letter-spacing: 0.04em; color: var(--dark);
}
.qfg input, .qfg select, .qfg textarea {
    padding: 0.6rem 0.8rem;
    border: 1px solid var(--border); border-radius: 4px;
    font-family: var(--ff-b); font-size: 0.85rem; color: var(--dark);
    background: #fff; outline: none; width: 100%; box-sizing: border-box;
    transition: border-color 0.2s;
}
.qfg input:focus, .qfg select:focus, .qfg textarea:focus { border-color: var(--terra); }
.qfg textarea { resize: vertical; min-height: 80px; }

.qfg-inline { display: flex; gap: 0.5rem; }
.qfg-inline input { flex: 1; min-width: 0; }
.qfg-inline select { flex: 1.4; min-width: 0; }

/* Certifications checkboxes */
.q-checks {
    display: grid; grid-template-columns: repeat(3, 1fr); gap: 0.5rem 1rem;
    margin-top: 0.5rem;
}
.q-check-item {
    display: flex; align-items: center; gap: 0.4rem;
    font-family: var(--ff-b); font-size: 0.8rem; color: var(--dark);
    cursor: pointer;
}
.q-check-item input[type="checkbox"] {
    width: 15px; height: 15px; flex-shrink: 0;
    accent-color: var(--terra); cursor: pointer; padding: 0; border: none;
}

@media (max-width: 600px) {
    .qmodal-panel { padding: 1.75rem 1.25rem; }
    .qfg-grid { grid-template-columns: 1fr; }
    .qfg-full { grid-column: auto; }
    .q-checks { grid-template-columns: 1fr 1fr; }
}

/* ── FREIGHT QUOTE MODAL — STEP UI ── */

/* Widen panel for multi-step layout */
.qmodal-panel { max-width: 700px; }

/* Step indicator bar */
.qstep-bar {
    display: flex; align-items: flex-start; justify-content: center;
    gap: 0; margin-bottom: 1.75rem;
}

/* Connector lines between dots */
.qstep-conn {
    flex: 1; height: 2px; margin-top: 1.1rem;
    background: var(--border);
    transition: background 0.3s;
}
.qstep-conn.done { background: var(--terra); }

/* Individual step dot */
.qstep-dot {
    display: flex; flex-direction: column; align-items: center; gap: 0.4rem;
    flex-shrink: 0; cursor: default;
}

/* Numbered circle */
.qstep-circle {
    width: 2.1rem; height: 2.1rem; border-radius: 50%;
    display: flex; align-items: center; justify-content: center;
    font-family: var(--ff-b); font-size: 0.78rem; font-weight: 700;
    background: var(--sand); color: var(--muted);
    border: 2px solid var(--border);
    transition: background 0.3s, border-color 0.3s, color 0.3s;
}
.qstep-dot.active .qstep-circle {
    background: var(--terra); color: #fff; border-color: var(--terra);
}
.qstep-dot.done .qstep-circle {
    background: var(--green); color: #fff; border-color: var(--green);
}

/* Step label under circle */
.qstep-lbl {
    font-family: var(--ff-b); font-size: 0.6rem; font-weight: 600;
    letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--muted); text-align: center; white-space: nowrap;
    transition: color 0.3s;
}
.qstep-dot.active .qstep-lbl { color: var(--terra); }
.qstep-dot.done .qstep-lbl { color: var(--green); }

/* Mobile progress text — hidden on desktop */
.qstep-mobile-prog {
    display: none;
    font-family: var(--ff-b); font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.06em; text-transform: uppercase;
    color: var(--terra); margin-bottom: 1.25rem; text-align: center;
}

/* Individual step panel — visibility controlled by JS inline style */
.qstep { display: block; }

/* Navigation row */
.qnav-row {
    display: flex; align-items: center; justify-content: space-between;
    margin-top: 1.5rem; gap: 0.75rem;
}

.qbtn-back, .qbtn-next, .qbtn-submit {
    font-family: var(--ff-b); font-size: 0.82rem; font-weight: 600;
    border-radius: 4px; cursor: pointer; padding: 0.65rem 1.5rem;
    transition: background 0.2s, color 0.2s, opacity 0.2s;
    border: none;
}
.qbtn-back {
    background: transparent; color: var(--muted);
    border: 1px solid var(--border);
}
.qbtn-back:hover { background: var(--sand); color: var(--dark); }

.qbtn-next {
    background: var(--terra); color: #fff; margin-left: auto;
}
.qbtn-next:hover { background: #a63a1c; }

.qbtn-submit {
    background: var(--green); color: #fff; margin-left: auto;
}
.qbtn-submit:hover { background: #163920; }

/* Validation error */
.qstep-error {
    font-family: var(--ff-b); font-size: 0.75rem; color: var(--terra);
    margin-top: 0.85rem; padding: 0.5rem 0.75rem;
    background: rgba(194,72,40,0.08); border-radius: 4px;
    border-left: 3px solid var(--terra);
}

/* ── Mobile overrides for step modal ── */
@media (max-width: 640px) {
    /* Full-screen panel on small screens */
    #quote-modal-overlay { align-items: flex-end; }
    .qmodal-panel {
        max-width: 100%; border-radius: 12px 12px 0 0;
        padding: 1.5rem 1.2rem 2rem;
        max-height: 92dvh; overflow-y: auto;
    }

    /* Hide full step bar, show compact text */
    .qstep-bar { display: none; }
    .qstep-mobile-prog { display: block; }

    /* Stack nav buttons vertically */
    .qnav-row { flex-direction: column-reverse; gap: 0.55rem; }
    .qbtn-back, .qbtn-next, .qbtn-submit {
        width: 100%; text-align: center; margin-left: 0;
    }

    /* Single-column grid already handled above; reinforce */
    .qfg-grid { grid-template-columns: 1fr; }
}

/* ── COOKIE BANNER ── */
#cookie-banner {
    position: fixed; bottom: 0; left: 0; right: 0; z-index: 9999;
    background: var(--dark); border-top: 1px solid rgba(240,232,212,0.1);
    padding: 1.25rem 1.5rem;
    transform: translateY(0);
    transition: transform 0.4s cubic-bezier(0.4,0,0.2,1), opacity 0.4s;
}
#cookie-banner.cookie-hide { transform: translateY(100%); opacity: 0; }
.cookie-inner {
    max-width: 1200px; margin: 0 auto;
    display: flex; align-items: center; gap: 2rem; flex-wrap: wrap;
}
.cookie-text {
    flex: 1; min-width: 0;
    font-size: 0.82rem; line-height: 1.6; color: rgba(240,232,212,0.75);
    margin: 0;
}
.cookie-link { color: var(--gold); text-decoration: underline; }
.cookie-link:hover { color: var(--sand); }
.cookie-btns { display: flex; gap: 0.65rem; flex-shrink: 0; }
.cookie-btn-primary {
    padding: 0.55rem 1.25rem;
    background: var(--terra); color: var(--sand);
    border: none; border-radius: 4px;
    font-family: var(--ff-b); font-size: 0.8rem; font-weight: 600;
    cursor: pointer; transition: background 0.2s;
}
.cookie-btn-primary:hover { background: #a63a1c; }
.cookie-btn-secondary {
    padding: 0.55rem 1.25rem;
    background: transparent; color: rgba(240,232,212,0.6);
    border: 1px solid rgba(240,232,212,0.2); border-radius: 4px;
    font-family: var(--ff-b); font-size: 0.8rem; font-weight: 500;
    cursor: pointer; transition: border-color 0.2s, color 0.2s;
}
.cookie-btn-secondary:hover { border-color: rgba(240,232,212,0.5); color: var(--sand); }
@media (max-width: 600px) {
    .cookie-inner { flex-direction: column; gap: 1rem; }
    .cookie-btns { width: 100%; }
    .cookie-btn-primary, .cookie-btn-secondary { flex: 1; text-align: center; }
}

/* ── BACK-TO-TOP ── */
#back-to-top {
    position: fixed; bottom: 6rem; right: 2rem; z-index: 900;
    width: 2.4rem; height: 2.4rem;
    background: var(--dark); color: var(--sand);
    border: 1px solid rgba(240,232,212,0.15);
    border-radius: 4px; cursor: pointer;
    display: flex; align-items: center; justify-content: center;
    opacity: 0; pointer-events: none;
    transition: opacity 0.25s, transform 0.25s, background 0.2s;
    transform: translateY(6px);
}
#back-to-top.btt-visible { opacity: 1; pointer-events: auto; transform: translateY(0); }
#back-to-top:hover { background: var(--terra); border-color: transparent; }
html[dir="rtl"] #back-to-top { right: auto; left: 2rem; }
@media (max-width: 900px) {
    #back-to-top { bottom: 5rem; right: 1.5rem; }
    html[dir="rtl"] #back-to-top { left: 1.5rem; }
}
