/* ==========================================================================
   Caravan Cafe — Colors & Typography
   Warm, earthy palette drawn from Uzbek mosaic tilework, desert dunes,
   and the deep-teal wordmark of the Caravan Cafe logo.
   ========================================================================== */

/* ---------- Fonts ---------------------------------------------------------
   Display + script come from Google Fonts (Fraunces, Caveat).
   Body is Source Sans 3 — the brand font — self-hosted as a variable WOFF2.
   -------------------------------------------------------------------------- */
@import url("https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,500;0,9..144,600;0,9..144,700;0,9..144,800;1,9..144,500&family=Caveat:wght@500;600&display=swap");

@font-face {
    font-family: "Source Sans 3";
    src: url("../fonts/SourceSans3-VariableFont_wght.woff2")
        format("woff2-variations");
    font-weight: 200 900;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: "Source Sans 3";
    src: url("../fonts/SourceSans3-Italic-VariableFont_wght.woff2")
        format("woff2-variations");
    font-weight: 200 900;
    font-style: italic;
    font-display: swap;
}

:root {
    /* =========================================================================
     COLOR — Primary (brand core)
     ========================================================================= */
    /* Deep teal from the wordmark — our "ink" and primary brand color. */
    --cv-teal-900: #1e3d3a; /* wordmark ink */
    --cv-teal-700: #2e5754;
    --cv-teal-500: #3f7370;
    --cv-teal-300: #7aa3a0;
    --cv-teal-100: #d6e3e1;

    /* Warm amber/saffron — the sun, honey, saffron rice. */
    --cv-amber-900: #8b4e16;
    --cv-amber-700: #c27a2b;
    --cv-amber-500: #e4a24a; /* signature underline swoosh */
    --cv-amber-300: #f2c884;
    --cv-amber-100: #fbebcb;

    /* Terracotta / clay — dune shadow, warm accent. */
    --cv-clay-900: #5c2a15;
    --cv-clay-700: #8e4a2a;
    --cv-clay-500: #b6623a;
    --cv-clay-300: #d99472;
    --cv-clay-100: #f3dccb;

    /* Mosaic blues — from the tile pattern, used sparingly as deep accent. */
    --cv-lapis-900: #143a6b;
    --cv-lapis-700: #1e5a9a;
    --cv-lapis-500: #2f86c2;

    /* =========================================================================
     COLOR — Neutrals (warm, NOT cool gray)
     ========================================================================= */
    --cv-cream-50: #fbf6ec; /* page background */
    --cv-cream-100: #f6eedd; /* card / alt surface */
    --cv-cream-200: #ede1c7; /* subtle divider */
    --cv-sand-300: #d9c6a3;
    --cv-sand-500: #a68e66;
    --cv-stone-700: #6b5a45;
    --cv-stone-900: #3a2f22;

    /* =========================================================================
     COLOR — Semantic aliases
     ========================================================================= */
    --bg: var(--cv-cream-50);
    --bg-alt: var(--cv-cream-100);
    --surface: #fffdf7;
    --surface-sunk: var(--cv-cream-200);

    --fg: var(--cv-teal-900); /* primary ink */
    --fg-muted: var(--cv-stone-700);
    --fg-soft: var(--cv-sand-500);
    --fg-on-dark: var(--cv-cream-50);

    --accent: var(
        --cv-amber-500
    ); /* the sunset / underline swoosh */
    --accent-strong: var(--cv-amber-700);
    --accent-ink: var(--cv-clay-900); /* text on amber */

    --brand: var(--cv-teal-900);
    --brand-soft: var(--cv-teal-300);

    --border: var(--cv-cream-200);
    --border-strong: var(--cv-sand-300);

    --success: #4e7a3a;
    --error: #b0412c;

    /* =========================================================================
     TYPOGRAPHY — canonical scale. Pick one token per role; never hardcode.
     ========================================================================= */
    --font-display:
        "Fraunces", "Playfair Display", Georgia, serif;
    --font-body:
        "Source Sans 3", "Source Sans Pro", "Helvetica Neue", Arial,
        sans-serif;
    --font-accent: "Caveat", "Brush Script MT", cursive;
    --font-mono: ui-monospace, "SF Mono", Menlo, monospace;

    /* Type scale (10 sizes, distinct roles) */
    --fs-display: clamp(2.75rem, 5.5vw, 4.75rem); /* 44–76 hero */
    --fs-h1: clamp(2.5rem, 4.5vw, 3.5rem); /* 40–56 large section heads */
    --fs-h2: clamp(2rem, 3.5vw, 2.75rem); /* 32–44 small section heads */
    --fs-h3: 1.625rem; /* 26 subheads */
    --fs-h4: 1.25rem; /* 20 stat values */
    --fs-lead: 1.1875rem; /* 19 emphasised leads */
    --fs-lg: 1.125rem; /* 18 body lg */
    --fs-base: 1rem; /* 16 body */
    --fs-sm: 0.875rem; /* 14 UI / small body */
    --fs-xs: 0.8125rem; /* 13 meta */
    --fs-eyebrow: 0.75rem; /* 12 wide-tracked label */

    /* Weights (4 roles) */
    --fw-regular: 400;
    --fw-medium: 500;
    --fw-semibold: 600;
    --fw-bold: 700;

    /* Line heights */
    --lh-tight: 1.05;
    --lh-snug: 1.3;
    --lh-normal: 1.55;
    --lh-loose: 1.7;

    /* Tracking */
    --tracking-tight: -0.02em;
    --tracking-normal: 0;
    --tracking-wide: 0.04em;
    --tracking-eyebrow: 0.22em;

    /* =========================================================================
     SPACING — 4pt base
     ========================================================================= */
    --sp-1: 4px;
    --sp-2: 8px;
    --sp-3: 12px;
    --sp-4: 16px;
    --sp-5: 24px;
    --sp-6: 32px;
    --sp-7: 48px;
    --sp-8: 64px;
    --sp-9: 96px;
    --sp-10: 128px;

    /* =========================================================================
     RADII — soft, warm, never sharp
     ========================================================================= */
    --r-xs: 4px;
    --r-sm: 8px;
    --r-md: 14px;
    --r-lg: 20px;
    --r-xl: 28px;
    --r-pill: 999px;

    /* =========================================================================
     SHADOWS — soft, warm-tinted (never pure black)
     ========================================================================= */
    --sh-xs: 0 1px 2px rgba(92, 42, 21, 0.06);
    --sh-sm: 0 2px 6px rgba(92, 42, 21, 0.08);
    --sh-md:
        0 8px 20px rgba(92, 42, 21, 0.1),
        0 2px 4px rgba(92, 42, 21, 0.06);
    --sh-lg:
        0 20px 40px rgba(92, 42, 21, 0.14),
        0 4px 8px rgba(92, 42, 21, 0.08);
    --sh-inset-warm: inset 0 1px 0 rgba(255, 253, 247, 0.5);

    /* =========================================================================
     MOTION
     ========================================================================= */
    --ease-warm: cubic-bezier(
        0.33,
        0,
        0.2,
        1
    ); /* gentle ease, slightly loose */
    --ease-out: cubic-bezier(0.22, 0.61, 0.36, 1);
    --dur-quick: 160ms;
    --dur-base: 240ms;
    --dur-slow: 420ms;

    /* =========================================================================
     LAYOUT
     ========================================================================= */
    --container: 1200px;
    --container-sm: 880px;
}

/* ==========================================================================
   SEMANTIC TYPE STYLES — base element styles, all routed through tokens
   ========================================================================== */

body {
    font-family: var(--font-body);
    font-size: var(--fs-base);
    line-height: var(--lh-normal);
    color: var(--fg);
    background: var(--bg);
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
}

h1 {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--fg);
    font-variation-settings: "opsz" 96;
}

h2 {
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--fg);
    font-variation-settings: "opsz" 48;
}

h3 {
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    font-weight: var(--fw-semibold);
    line-height: var(--lh-snug);
    color: var(--fg);
}

h4 {
    font-family: var(--font-body);
    font-size: var(--fs-h4);
    font-weight: var(--fw-bold);
    line-height: var(--lh-snug);
    color: var(--fg);
}

.cv-eyebrow {
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    font-weight: var(--fw-bold);
    text-transform: uppercase;
    letter-spacing: var(--tracking-eyebrow);
    color: var(--accent-strong);
}

p {
    font-family: var(--font-body);
    font-size: var(--fs-base);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    text-wrap: pretty;
}

/* ==========================================================================
   COMPONENTS
   ========================================================================== */

* {
    box-sizing: border-box;
}
html,
body {
    margin: 0;
    padding: 0;
}
html {
    scroll-behavior: smooth;
    scroll-padding-top: 100px;
}
body {
    background: var(--bg);
    color: var(--fg);
    font-family: var(--font-body);
}
img {
    display: block;
    max-width: 100%;
}
a {
    color: inherit;
}

/* =============================== Nav ================================ */
.cv-nav-wrap {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(251, 246, 236, 0.88);
    backdrop-filter: blur(16px);
    -webkit-backdrop-filter: blur(16px);
    border-bottom: 1px solid var(--border);
    padding: 0 20px;
    transition: box-shadow 240ms var(--ease-warm);
}
.cv-nav-wrap.scrolled {
    box-shadow: var(--sh-sm);
}
.cv-nav {
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr auto 1fr;
    align-items: center;
    gap: 24px;
    padding: 16px 0;
}
.cv-nav-brand img {
    height: 36px;
}
.cv-nav-links {
    display: flex;
    gap: 32px;
    justify-content: center;
}
.cv-nav-links a {
    color: var(--fg);
    text-decoration: none;
    font-weight: var(--fw-medium);
    font-size: var(--fs-sm);
    position: relative;
    padding: 6px 2px;
    letter-spacing: var(--tracking-wide);
}
.cv-nav-links a::after {
    content: "";
    position: absolute;
    left: 0;
    right: 0;
    bottom: 0;
    height: 2px;
    background: var(--accent);
    border-radius: 999px;
    transform: scaleX(0);
    transform-origin: left;
    transition: transform 240ms var(--ease-warm);
}
.cv-nav-links a:hover::after,
.cv-nav-links a.active::after {
    transform: scaleX(1);
}
.cv-nav-cta {
    justify-self: end;
    display: inline-flex;
    align-items: initial;
    margin-top: 4px;
    gap: 8px;
    font-size: var(--fs-xs);
    color: var(--fg);
    text-decoration: none;
    font-weight: var(--fw-semibold);
    letter-spacing: var(--tracking-wide);
}
.cv-nav-cta img {
    width: 14px;
    height: 14px;
}
.cv-nav-cta:hover {
    color: var(--accent-strong);
}

/* =========================== Buttons =============================== */
.cv-btn {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 13px 24px;
    border-radius: 999px;
    font-family: var(--font-body);
    font-weight: var(--fw-semibold);
    font-size: var(--fs-sm);
    border: 1px solid transparent;
    cursor: pointer;
    text-decoration: none;
    transition: all 240ms var(--ease-warm);
    letter-spacing: var(--tracking-wide);
    white-space: nowrap;
}
.cv-btn img {
    width: 16px;
    height: 16px;
}
.cv-btn-accent {
    background: var(--cv-amber-500);
    color: var(--cv-clay-900);
    box-shadow: var(--sh-sm);
}
.cv-btn-accent:hover {
    background: var(--cv-amber-700);
    color: var(--cv-cream-50);
    box-shadow: var(--sh-md);
    transform: translateY(-1px);
}
.cv-btn-accent img {
    filter: brightness(0.3);
}
.cv-btn-accent:hover img {
    filter: brightness(0) invert(1);
}
.cv-btn-ghost {
    background: transparent;
    color: var(--cv-teal-900);
    border-color: var(--cv-teal-900);
}
.cv-btn-ghost:hover {
    background: var(--cv-teal-900);
    color: var(--cv-cream-50);
}

/* =========================== Hero ================================== */
.cv-hero {
    position: relative;
    padding: 48px 24px 72px;
}
.cv-hero-wrap {
    max-width: var(--container);
    margin: 0 auto;
}
.cv-hero-grid {
    display: grid;
    grid-template-columns: 7fr 5fr;
    gap: 56px;
    align-items: stretch;
}
.cv-hero-copy {
    display: flex;
    flex-direction: column;
    padding: 48px 0;
}
.cv-hero-copy .cv-eyebrow {
    margin-bottom: 28px;
}
.cv-hero-title {
    font-family: var(--font-display);
    font-weight: var(--fw-bold);
    font-size: var(--fs-display);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--fg);
    margin: 0 0 28px;
    font-variation-settings: "opsz" 120;
    text-wrap: balance;
}
.cv-hero-swoosh {
    position: relative;
    color: var(--accent-strong);
}
.cv-hero-swoosh::after {
    content: "";
    display: none;
}
.cv-hero-lead {
    font-size: var(--fs-lead);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    max-width: 540px;
    margin: 0 0 36px;
}
.cv-hero-actions {
    display: flex;
    gap: 14px;
    flex-wrap: wrap;
    margin-bottom: 0;
}

.cv-hero-art {
    position: relative;
    border-radius: var(--r-lg);
    overflow: hidden;
    box-shadow: var(--sh-lg);
    align-self: stretch;
    aspect-ratio: 768 / 1376;
    max-width: 100%;
    justify-self: center;
}
.cv-hero-art-img {
    position: absolute;
    inset: 0;
    width: 100%;
    height: 100%;
    object-fit: cover;
    display: block;
}

/* Strip under hero — three factlets */
.cv-strip {
    margin-top: auto;
    padding-top: 48px;
}
.cv-strip-inner {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 24px 32px;
    padding: 28px 0 0;
    border-top: 1px solid var(--border);
}
.cv-strip-cell {
    display: flex;
    flex-direction: column;
    gap: 4px;
}
.cv-strip-cell .k {
    font-family: var(--font-body);
    font-size: var(--fs-eyebrow);
    font-weight: var(--fw-bold);
    letter-spacing: var(--tracking-eyebrow);
    text-transform: uppercase;
    color: var(--accent-strong);
}
.cv-strip-cell .v {
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-weight: var(--fw-medium);
    color: var(--fg);
    line-height: var(--lh-snug);
    font-variation-settings: normal;
}
.cv-strip-cell .v a {
    text-decoration: none;
}
.cv-strip-cell .v a:hover {
    color: var(--accent-strong);
}

/* =========================== About ================================ */
.cv-about {
    max-width: none;
    padding: 0 24px;
    background: var(--cv-cream-100);
    border-top: 1px solid var(--border);
    border-bottom: 1px solid var(--border);
}
.cv-about-inner {
    max-width: var(--container);
    margin: 0 auto;
    padding: 96px 0;
    display: grid;
    grid-template-columns: 1fr 3fr;
    gap: 64px;
    align-items: start;
}
.cv-about-eyebrow {
    display: flex;
    flex-direction: column;
    gap: 18px;
    position: sticky;
    top: 120px;
}
.cv-about-eyebrow .swoosh {
    width: 56px;
    height: 4px;
    background: var(--accent);
    border-radius: 999px;
}
.cv-about-copy {
    max-width: 680px;
}
.cv-about-copy p {
    font-size: var(--fs-lg);
    line-height: var(--lh-loose);
    color: var(--fg);
    margin: 0 0 22px;
}
.cv-about-copy p:first-of-type {
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    font-weight: var(--fw-semibold);
    line-height: var(--lh-snug);
    letter-spacing: var(--tracking-tight);
    font-variation-settings: "opsz" 72;
}
.cv-about-sign {
    font-family: var(--font-accent);
    font-size: 2.375rem;
    color: var(--accent-strong);
    line-height: 1;
    margin-top: 14px;
    display: block;
}

/* =========================== Menu ================================== */
.cv-menu-section {
    padding: 112px 24px;
}
.cv-menu-head {
    max-width: var(--container);
    margin: 0 auto 72px;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 64px;
    align-items: end;
    padding-bottom: 32px;
    border-bottom: 2px solid var(--fg);
}
.cv-menu-head .label {
    font-size: var(--fs-eyebrow);
    letter-spacing: var(--tracking-eyebrow);
    text-transform: uppercase;
    color: var(--accent-strong);
    font-weight: var(--fw-bold);
}
.cv-menu-head h2 {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--fg);
    margin: 0 0 14px;
    text-wrap: balance;
}
.cv-menu-head .lead {
    font-size: var(--fs-lg);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    max-width: 520px;
    margin: 0;
}

.cv-menu-cats {
    max-width: var(--container);
    margin: 0 auto;
    display: flex;
    flex-direction: column;
    gap: 112px;
}
.cv-menu-cat {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 72px;
    align-items: center;
}
.cv-menu-cat:nth-child(even) .cv-menu-cat-text {
    order: 2;
}
.cv-menu-cat-image img {
    display: block;
    width: 100%;
    height: auto;
}
.cv-menu-cat-head {
    display: flex;
    justify-content: space-between;
    align-items: baseline;
    gap: 16px;
    border-bottom: 1px solid var(--border-strong);
    padding-bottom: 14px;
    margin-bottom: 24px;
}
.cv-menu-cat-name {
    margin: 0;
    font-family: var(--font-display);
    font-size: var(--fs-h3);
    font-weight: var(--fw-bold);
    color: var(--fg);
    letter-spacing: var(--tracking-tight);
}
.cv-menu-cat-idx {
    font-family: var(--font-display);
    font-style: italic;
    font-size: var(--fs-sm);
    color: var(--accent-strong);
    font-variant-numeric: tabular-nums;
    letter-spacing: var(--tracking-wide);
}
.cv-menu-items {
    display: flex;
    flex-direction: column;
    gap: 18px;
}
.cv-menu-item-row {
    display: flex;
    align-items: baseline;
    gap: 12px;
}
.cv-menu-item-name {
    font-family: var(--font-body);
    font-weight: var(--fw-medium);
    font-size: var(--fs-lg);
    color: var(--fg);
}
.cv-menu-cat-intro {
    font-size: var(--fs-base);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    margin: 0 0 24px;
    max-width: 520px;
}
.cv-menu-item-desc {
    font-size: var(--fs-sm);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    margin-top: 4px;
    max-width: 480px;
}
.cv-menu-item-note {
    font-size: var(--fs-sm);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    margin-top: 4px;
    font-style: italic;
}

/* =========================== FAQ ================================= */
.cv-faq {
    background: var(--cv-cream-100);
    border-top: 1px solid var(--border);
    padding: 96px 24px;
}
.cv-faq-inner {
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 2fr;
    gap: 64px;
    align-items: start;
}
.cv-faq-head h2 {
    font-family: var(--font-display);
    font-size: var(--fs-h2);
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--fg);
    margin: 14px 0 0;
    text-wrap: balance;
}
.cv-faq-list {
    display: flex;
    flex-direction: column;
    gap: 0;
    border-top: 1px solid var(--border-strong);
}
.cv-faq-item {
    border-bottom: 1px solid var(--border-strong);
    padding: 20px 0;
}
.cv-faq-item summary {
    cursor: pointer;
    list-style: none;
    font-family: var(--font-display);
    font-size: var(--fs-lead);
    font-weight: var(--fw-semibold);
    color: var(--fg);
    letter-spacing: var(--tracking-tight);
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
}
.cv-faq-item summary::-webkit-details-marker {
    display: none;
}
.cv-faq-item summary::after {
    content: "+";
    font-family: var(--font-display);
    font-weight: var(--fw-regular);
    font-size: 1.75rem;
    color: var(--accent-strong);
    line-height: 1;
    transition: transform 240ms var(--ease-warm);
}
.cv-faq-item[open] summary::after {
    transform: rotate(45deg);
}
.cv-faq-item p {
    margin: 12px 0 0;
    font-size: var(--fs-base);
    line-height: var(--lh-normal);
    color: var(--fg-muted);
    max-width: 620px;
}

/* =========================== Contact =============================== */
.cv-contact {
    background: var(--cv-teal-900);
    color: var(--cv-cream-50);
    padding: 112px 24px;
}
.cv-contact-inner {
    max-width: var(--container);
    margin: 0 auto;
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 80px;
    align-items: start;
}
.cv-contact-eyebrow {
    color: var(--cv-amber-300);
}
.cv-contact h2 {
    font-family: var(--font-display);
    font-size: var(--fs-h1);
    font-weight: var(--fw-bold);
    line-height: var(--lh-tight);
    letter-spacing: var(--tracking-tight);
    color: var(--cv-cream-50);
    margin: 18px 0 24px;
    text-wrap: balance;
}
.cv-contact .lead {
    font-size: var(--fs-lg);
    line-height: var(--lh-normal);
    color: rgba(251, 246, 236, 0.78);
    max-width: 520px;
    margin: 0 0 48px;
}

.cv-contact-rows {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-top: 1px solid rgba(251, 246, 236, 0.18);
}
.cv-contact-row {
    display: grid;
    grid-template-columns: 140px 1fr auto;
    gap: 24px;
    align-items: baseline;
    padding: 22px 0;
    border-bottom: 1px solid rgba(251, 246, 236, 0.14);
    transition: padding 240ms var(--ease-warm);
}
.cv-contact-row:hover {
    padding-left: 6px;
}
.cv-contact-row .k {
    font-size: var(--fs-eyebrow);
    font-weight: var(--fw-bold);
    letter-spacing: var(--tracking-eyebrow);
    text-transform: uppercase;
    color: var(--cv-amber-300);
}
.cv-contact-row .v {
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-weight: var(--fw-medium);
    color: var(--cv-cream-50);
    line-height: var(--lh-snug);
}
.cv-contact-row .v a {
    color: inherit;
    text-decoration: none;
}
.cv-contact-row .v a:hover {
    color: var(--cv-amber-300);
}
.cv-contact-row .v .sub {
    display: block;
    font-family: var(--font-body);
    font-size: var(--fs-sm);
    color: rgba(251, 246, 236, 0.6);
    margin-top: 4px;
    font-weight: var(--fw-regular);
    letter-spacing: var(--tracking-normal);
}
.cv-contact-row .arrow {
    opacity: 0;
    transition:
        opacity 200ms var(--ease-warm),
        transform 200ms var(--ease-warm);
    color: var(--cv-amber-300);
}
.cv-contact-row:hover .arrow {
    opacity: 1;
    transform: translateX(4px);
}
.cv-contact-row img {
    width: 18px;
    height: 18px;
    filter: invert(1);
    opacity: 0.6;
}

/* Map side */
.cv-map-card {
    border-radius: var(--r-lg);
    overflow: hidden;
    box-shadow: var(--sh-lg);
    background: var(--cv-cream-100);
    border: 1px solid rgba(251, 246, 236, 0.1);
}
.cv-map-iframe {
    width: 100%;
    height: 460px;
    border: 0;
    display: block;
    filter: saturate(0.9) contrast(0.95);
}
.cv-map-foot {
    padding: 22px 26px;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 16px;
    background: var(--cv-cream-50);
    color: var(--fg);
    font-size: var(--fs-sm);
}
.cv-map-foot strong {
    font-family: var(--font-display);
    font-weight: var(--fw-bold);
    font-size: var(--fs-lg);
}
.cv-map-foot a {
    color: var(--accent-strong);
    text-decoration: none;
    font-weight: var(--fw-bold);
    letter-spacing: var(--tracking-wide);
    font-size: var(--fs-xs);
    text-transform: uppercase;
}
.cv-map-foot a:hover {
    color: var(--cv-teal-900);
}

/* =========================== Footer ================================ */
.cv-footer {
    background: var(--cv-teal-900);
    color: var(--cv-cream-50);
    padding: 48px 24px 40px;
    border-top: 1px solid rgba(251, 246, 236, 0.12);
}
.cv-footer-inner {
    max-width: var(--container);
    margin: 0 auto;
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 32px;
    flex-wrap: wrap;
    font-size: var(--fs-xs);
    color: rgba(251, 246, 236, 0.6);
}
.cv-footer-mark {
    font-family: var(--font-display);
    font-size: var(--fs-h4);
    font-weight: var(--fw-bold);
    color: var(--cv-cream-50);
}
.cv-footer-mark .swoosh {
    position: relative;
    display: inline-block;
}
.cv-footer-mark .swoosh::after {
    content: "";
    position: absolute;
    left: 6%;
    right: 6%;
    bottom: -4px;
    height: 4px;
    background: var(--accent);
    border-radius: 50%;
    transform: scaleY(0.6);
}
.cv-footer-inner a {
    color: rgba(251, 246, 236, 0.75);
    text-decoration: none;
}
.cv-footer-inner a:hover {
    color: var(--cv-amber-300);
}

/* =========================== Responsive ============================ */
@media (max-width: 960px) {
    .cv-nav-links,
    .cv-nav-cta {
        display: none;
    }
    .cv-nav {
        grid-template-columns: 1fr auto;
    }
    .cv-hero-grid {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .cv-hero-art {
        min-height: 320px;
    }
    .cv-strip-inner {
        grid-template-columns: 1fr;
        gap: 18px;
    }
    .cv-about-inner,
    .cv-contact-inner,
    .cv-faq-inner {
        grid-template-columns: 1fr;
        gap: 40px;
        padding: 72px 20px;
    }
    .cv-about {
        padding: 0 20px;
    }
    .cv-about-inner {
        padding: 72px 0;
    }
    .cv-faq {
        padding: 0;
    }
    .cv-about-eyebrow {
        position: static;
    }
    .cv-menu-cats {
        gap: 72px;
    }
    .cv-menu-cat {
        grid-template-columns: 1fr;
        gap: 32px;
    }
    .cv-menu-cat-image {
        order: -1;
    }
    .cv-menu-cat:nth-child(even) .cv-menu-cat-text {
        order: 0;
    }
    .cv-menu-head {
        grid-template-columns: 1fr;
        gap: 20px;
    }
    .cv-menu-section {
        padding: 72px 20px;
    }
    .cv-contact-row {
        grid-template-columns: 1fr;
        gap: 4px;
        padding: 18px 0;
    }
    .cv-contact-row:hover {
        padding-left: 0;
    }
    .cv-contact-row .arrow {
        display: none;
    }
}
