/* =========================================================
   YA-EVENT — design system (editorial + sand/moss palette)
   ========================================================= */

/* ---------- Reset ---------- */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-font-smoothing: antialiased; -moz-osx-font-smoothing: grayscale; }
body { margin: 0; }
img, svg { display: block; max-width: 100%; }
button { font: inherit; color: inherit; background: none; border: 0; cursor: pointer; padding: 0; }
a { color: inherit; text-decoration: none; }
input, select, textarea { font: inherit; color: inherit; }

/* ---------- Tokens ---------- */
:root {
    /* Sand + moss palette. Background is near-white with a faint sand tint. */
    --color-bg:        #fbf8f1;   /* almost white, hint of sand */
    --color-bg-alt:    #f6f1e6;   /* soft cream band */
    --color-bg-soft:   #efe9d9;
    --color-bg-dark:   #25251f;   /* warm near-black */
    --color-text:      #25251f;
    --color-text-mute: #6e6c64;
    --color-accent:    #4a5a3a;   /* deep moss */
    --color-accent-2:  #a8b58a;   /* light moss for inverse */
    --color-line:      #e0d9c4;
    --color-line-soft: #ece5d2;
    --color-white:     #ffffff;

    /* Photo color preset — applied to every background-image media block.
       Warm-film tone: a touch more saturation, softer contrast, gentle sepia. */
    --photo-preset: saturate(1.08) contrast(0.95) brightness(1.04) sepia(0.10);

    --radius-md: 12px;

    --container: 1280px;
    --gutter: clamp(20px, 4vw, 56px);

    --font-serif: 'Cormorant Garamond', 'Times New Roman', serif;
    --font-script: 'Marck Script', 'Cormorant Garamond', cursive;
    --font-sans:  'Inter', 'Open Sans', system-ui, -apple-system, sans-serif;

    --shadow-card: 0 24px 50px -28px rgba(37,37,31,0.25);
    --ease: cubic-bezier(.2,.7,.2,1);
}

/* ---------- Base ---------- */
body {
    background: var(--color-bg);
    color: var(--color-text);
    font-family: var(--font-sans);
    font-size: 16px;
    line-height: 1.5;
    font-weight: 400;
}

h1, h2, h3, h4 { margin: 0; font-weight: 500; letter-spacing: -0.01em; line-height: 1.05; }
p { margin: 0; }

.h-display {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(44px, 6.5vw, 96px);
    line-height: 0.98;
    letter-spacing: -0.02em;
}
.h-1 {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(32px, 4vw, 56px);
    line-height: 1.04;
    letter-spacing: -0.01em;
}
.h-2 {
    font-family: var(--font-serif);
    font-weight: 500;
    font-size: clamp(24px, 2.6vw, 36px);
    line-height: 1.1;
}
.eyebrow {
    display: inline-block;
    font-size: 11px;
    letter-spacing: 0.32em;
    text-transform: uppercase;
    color: var(--color-text-mute);
    font-weight: 500;
}

.lead {
    font-size: clamp(16px, 1.4vw, 19px);
    line-height: 1.55;
    color: var(--color-text-mute);
    max-width: 56ch;
}

.muted { color: var(--color-text-mute); }

/* Calligraphic accent for one-two words inside serif headings. */
.script {
    font-family: var(--font-script);
    font-style: normal;
    font-weight: 400;
    color: var(--color-accent);
    /* Marck Script reads small at the same size — bump it up. */
    font-size: 1.18em;
    line-height: 0.9;
    letter-spacing: 0;
    padding: 0 0.04em;
    display: inline-block;
    transform: translateY(0.04em);
}
.section--bg-dark .script,
.lead-form-section .script,
.hero .script {
    color: #d8e0bf;
    text-shadow: 0 2px 20px rgba(0,0,0,0.55);
}

/* ---------- Layout ---------- */
.container {
    width: 100%;
    max-width: var(--container);
    margin: 0 auto;
    padding: 0 var(--gutter);
}
.container--narrow { max-width: 880px; }

.section { padding: clamp(72px, 10vw, 130px) 0; }
.section--tight { padding: clamp(48px, 6vw, 80px) 0; }
.section--bg-cream { background: var(--color-bg-alt); }
.section--bg-dark  { background: var(--color-bg-dark); color: var(--color-bg); }
.section--bg-dark .eyebrow { color: rgba(236,230,216,0.6); }
.section--bg-dark .muted { color: rgba(236,230,216,0.65); }

/* ---------- Header ---------- */
.site-header {
    position: sticky;
    top: 0;
    z-index: 50;
    background: rgba(236,230,216,0.85);
    backdrop-filter: saturate(160%) blur(14px);
    -webkit-backdrop-filter: saturate(160%) blur(14px);
    border-bottom: 1px solid transparent;
    transition: background-color .35s var(--ease), border-color .35s var(--ease);
}
.site-header.is-scrolled {
    background: rgba(236,230,216,0.96);
    border-bottom-color: var(--color-line-soft);
}
.site-header__inner {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 32px;
    padding: 22px 0;
    transition: padding .35s var(--ease);
}
.site-header.is-scrolled .site-header__inner { padding: 12px 0; }
.site-header__logo { text-decoration: none; color: inherit; }
.site-header__wordmark {
    font-family: var(--font-serif);
    font-weight: 600;
    font-size: clamp(22px, 2.4vw, 28px);
    letter-spacing: 0.04em;
    line-height: 1;
    white-space: nowrap;
    color: var(--color-text);
    transition: font-size .35s var(--ease);
}
.site-header__wordmark small {
    font-weight: 400;
    font-size: 0.82em;
    letter-spacing: 0.12em;
}
.site-header.is-scrolled .site-header__wordmark { font-size: clamp(18px, 2vw, 22px); }

.site-nav { display: flex; gap: 28px; font-size: 14px; color: var(--color-text); }
.site-nav a { position: relative; padding-bottom: 4px; transition: color .25s var(--ease); }
.site-nav a::after {
    content: ""; position: absolute; left: 0; bottom: 0;
    height: 1px; width: 0; background: var(--color-text);
    transition: width .35s var(--ease);
}
.site-nav a:hover::after { width: 100%; }

.site-header__cta { display: flex; align-items: center; gap: 16px; }
.site-header__phone { font-size: 14px; font-weight: 500; }
.site-header__tg {
    display: inline-flex; align-items: center; justify-content: center;
    width: 36px; height: 36px;
    border-radius: 999px;
    border: 1px solid var(--color-line);
    transition: background .25s var(--ease), color .25s var(--ease), border-color .25s var(--ease);
}
.site-header__tg:hover { background: var(--color-accent); color: var(--color-bg); border-color: var(--color-accent); }
.site-header__tg svg { width: 16px; height: 16px; }

.site-header__burger { display: none; flex-direction: column; gap: 5px; padding: 8px; }
.site-header__burger span { display: block; width: 22px; height: 1px; background: var(--color-text); }

@media (max-width: 980px) {
    .site-nav { display: none; }
    .site-header__phone { display: none; }
    .site-header__burger { display: flex; }
}

/* ---------- Mobile drawer ---------- */
.site-drawer {
    position: fixed; inset: 0;
    background: var(--color-bg);
    z-index: 100;
    padding: 80px var(--gutter) 40px;
    transform: translateY(-100%);
    transition: transform .5s var(--ease);
    display: flex; flex-direction: column; gap: 36px;
}
.site-drawer.is-open { transform: translateY(0); }
.site-drawer__close {
    position: absolute; top: 22px; right: var(--gutter);
    font-size: 30px; line-height: 1; padding: 8px;
}
.site-drawer__nav { display: flex; flex-direction: column; gap: 18px; }
.site-drawer__nav a { font-family: var(--font-serif); font-size: 32px; }
.site-drawer__contacts { display: flex; flex-direction: column; gap: 12px; font-size: 16px; color: var(--color-text-mute); }
.site-drawer__contacts a { color: var(--color-text); }

/* ---------- Hero (editorial cover) ---------- */
.hero {
    position: relative;
    min-height: clamp(560px, 80vh, 780px);
    display: grid;
    align-items: end;
    color: var(--color-bg);
    overflow: hidden;
}
.hero::before {
    content: "";
    position: absolute; inset: 0;
    background:
        linear-gradient(180deg,
            rgba(20,18,16,0.55) 0%,
            rgba(20,18,16,0.30) 35%,
            rgba(20,18,16,0.55) 70%,
            rgba(20,18,16,0.85) 100%),
        linear-gradient(90deg,
            rgba(20,18,16,0.55) 0%,
            rgba(20,18,16,0.20) 55%,
            rgba(20,18,16,0.0) 100%);
    z-index: 1;
}
.hero__media {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    z-index: 0;
    transform: scale(1.10);
    animation: hero-zoom 18s var(--ease) forwards;
    filter: var(--photo-preset);
}
@keyframes hero-zoom { 0% { transform: scale(1.12); } 100% { transform: scale(1.0); } }
.hero__inner {
    position: relative;
    z-index: 2;
    padding: clamp(40px, 8vw, 100px) 0 clamp(40px, 6vw, 80px);
}
.hero__eyebrow { color: rgba(255,250,240,0.92); margin-bottom: 22px; text-shadow: 0 1px 12px rgba(0,0,0,0.5); }
.hero__title {
    color: #fbf8f0;
    max-width: 18ch;
    margin-bottom: 28px;
    text-shadow: 0 2px 24px rgba(0,0,0,0.55), 0 1px 3px rgba(0,0,0,0.35);
}
.hero__lead {
    color: rgba(251,248,240,0.95);
    font-size: clamp(16px, 1.5vw, 19px);
    line-height: 1.55;
    max-width: 52ch;
    text-shadow: 0 1px 14px rgba(0,0,0,0.55);
}
.hero__cta { display: flex; gap: 14px; margin-top: 32px; flex-wrap: wrap; }
.hero__facts {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: clamp(14px, 2vw, 36px);
    margin-top: clamp(40px, 6vw, 64px);
    padding-top: 32px;
    border-top: 1px solid rgba(236,230,216,0.2);
}
@media (max-width: 700px) { .hero__facts { grid-template-columns: 1fr 1fr; } }
.hero__fact-num {
    font-family: var(--font-serif);
    font-size: clamp(28px, 3vw, 40px);
    line-height: 1;
    color: #fbf8f0;
    font-weight: 500;
    letter-spacing: -0.01em;
    text-shadow: 0 1px 14px rgba(0,0,0,0.5);
}
.hero__fact-label { font-size: 12px; color: rgba(251,248,240,0.85); margin-top: 8px; line-height: 1.4; text-shadow: 0 1px 10px rgba(0,0,0,0.4); }

/* ---------- Buttons ---------- */
.btn {
    display: inline-flex; align-items: center; gap: 10px;
    padding: 15px 28px;
    border-radius: 999px;
    font-size: 14px;
    font-weight: 500;
    line-height: 1;
    border: 1px solid transparent;
    transition: background .3s var(--ease), color .3s var(--ease), border-color .3s var(--ease), transform .3s var(--ease);
}
.btn--primary { background: var(--color-text); color: var(--color-bg); }
.btn--primary:hover { background: var(--color-accent); transform: translateY(-1px); }
.btn--accent  { background: var(--color-accent); color: var(--color-bg); }
.btn--accent:hover  { background: var(--color-text); transform: translateY(-1px); }
.btn--ghost   { background: transparent; border-color: currentColor; color: inherit; }
.btn--ghost:hover { background: var(--color-text); color: var(--color-bg); border-color: var(--color-text); }

.btn-link {
    display: inline-flex; align-items: center; gap: 10px;
    font-size: 14px;
    font-weight: 500;
    padding-bottom: 4px;
    border-bottom: 1px solid currentColor;
    transition: gap .3s var(--ease), color .3s var(--ease);
}
.btn-link:hover { gap: 14px; color: var(--color-accent); }

/* ---------- Split (intro) ---------- */
.split {
    display: grid;
    grid-template-columns: 6fr 5fr;
    gap: clamp(40px, 6vw, 96px);
    align-items: center;
}
@media (max-width: 900px) { .split { grid-template-columns: 1fr; } }
.split__media {
    aspect-ratio: 4/5;
    background-size: cover; background-position: center;
    border-radius: var(--radius-md);
    overflow: hidden;
    filter: var(--photo-preset);
}

/* ---------- Formats ---------- */
.formats {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--color-line-soft);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius-md);
    overflow: hidden;
}
@media (max-width: 900px) { .formats { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .formats { grid-template-columns: 1fr; } }
.format {
    background: var(--color-white);
    padding: 36px 30px 32px;
    display: flex; flex-direction: column; gap: 14px;
    color: var(--color-text);
    transition: background .35s var(--ease);
    min-height: 240px;
}
.format:hover { background: var(--color-bg-alt); }
.format__num {
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 500;
}
.format h3 { font-family: var(--font-serif); font-size: 26px; line-height: 1.05; margin-top: auto; font-weight: 500; }
.format p { font-size: 14px; color: var(--color-text-mute); line-height: 1.55; }

/* ---------- Venues grid ---------- */
.venues {
    display: grid;
    grid-template-columns: repeat(12, 1fr);
    gap: 24px;
}
@media (max-width: 900px) { .venues { grid-template-columns: 1fr; gap: 18px; } }

.venue-card {
    grid-column: span 4;
    background: var(--color-white);
    border-radius: var(--radius-md);
    overflow: hidden;
    display: flex; flex-direction: column;
    text-decoration: none;
    color: inherit;
    border: 1px solid var(--color-line-soft);
    transition: transform .4s var(--ease), box-shadow .4s var(--ease), border-color .4s var(--ease);
}
.venue-card--wide { grid-column: span 8; }
.venue-card--full { grid-column: span 12; }
@media (max-width: 900px) {
    .venue-card, .venue-card--wide, .venue-card--full { grid-column: span 1; }
}
.venue-card:hover {
    transform: translateY(-6px);
    box-shadow: var(--shadow-card);
    border-color: var(--color-accent-2);
}
.venue-card__media {
    aspect-ratio: 4/3;
    background-size: cover; background-position: center;
    transition: transform 1s var(--ease);
    filter: var(--photo-preset);
}
.venue-card--wide .venue-card__media { aspect-ratio: 16/9; }
.venue-card:hover .venue-card__media { transform: scale(1.05); }
.venue-card__body {
    padding: 24px 26px 26px;
    display: flex; flex-direction: column; gap: 8px;
    flex: 1;
}
.venue-card__kicker {
    font-size: 11px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--color-text-mute);
    margin-bottom: 4px;
}
.venue-card__title {
    font-family: var(--font-serif);
    font-size: 28px;
    font-weight: 500;
    line-height: 1.05;
    letter-spacing: -0.01em;
}
.venue-card__meta {
    display: flex; flex-wrap: wrap; gap: 6px 14px;
    font-size: 13px; color: var(--color-text-mute);
    margin-top: 6px;
}
.venue-card__cta {
    margin-top: auto;
    padding-top: 16px;
    font-size: 13px; font-weight: 500;
    color: var(--color-text);
    display: inline-flex; align-items: center; gap: 8px;
    transition: gap .3s var(--ease), color .3s var(--ease);
}
.venue-card:hover .venue-card__cta { gap: 12px; color: var(--color-accent); }

/* ---------- Reasons (light cream variant) ---------- */
.reasons {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1px;
    background: var(--color-line-soft);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius-md);
    overflow: hidden;
}
@media (max-width: 900px) { .reasons { grid-template-columns: 1fr; } }
.reason {
    background: var(--color-white);
    padding: 36px 32px;
    display: flex; flex-direction: column; gap: 12px;
    transition: background .35s var(--ease);
}
.reason:hover { background: var(--color-bg-alt); }
.reason__num {
    font-size: 11px;
    letter-spacing: 0.28em;
    text-transform: uppercase;
    color: var(--color-accent);
    font-weight: 500;
}
.reason h3 {
    font-family: var(--font-serif);
    font-size: 24px;
    font-weight: 500;
    line-height: 1.1;
    margin: 0;
    color: var(--color-text);
}
.reason p { font-size: 14px; color: var(--color-text-mute); line-height: 1.55; margin: 0; }

/* ---------- Steps ---------- */
.steps {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 1px;
    background: var(--color-line-soft);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius-md);
    overflow: hidden;
    counter-reset: step;
}
@media (max-width: 900px) { .steps { grid-template-columns: 1fr 1fr; } }
@media (max-width: 560px) { .steps { grid-template-columns: 1fr; } }
.step {
    background: var(--color-white);
    padding: 36px 30px;
    display: flex; flex-direction: column; gap: 12px;
    counter-increment: step;
    position: relative;
}
.step::before {
    content: "0" counter(step);
    font-family: var(--font-serif);
    font-size: 36px;
    font-weight: 500;
    color: var(--color-accent);
    line-height: 1;
    margin-bottom: 8px;
}
.step h3 { font-family: var(--font-serif); font-size: 22px; font-weight: 500; }
.step p { font-size: 14px; color: var(--color-text-mute); line-height: 1.55; }

/* ---------- Quote band ---------- */
.quote-band {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: clamp(28px, 5vw, 80px);
    align-items: center;
    padding: clamp(36px, 5vw, 64px);
    background: var(--color-bg-alt);
    border-radius: var(--radius-md);
}
@media (max-width: 700px) { .quote-band { grid-template-columns: 1fr; } }
.quote-band__num {
    font-family: var(--font-serif);
    font-size: clamp(72px, 9vw, 140px);
    line-height: 0.9;
    color: var(--color-accent);
    font-weight: 500;
    letter-spacing: -0.02em;
}
.quote-band__num small {
    display: block;
    font-family: var(--font-sans);
    font-size: 12px;
    letter-spacing: 0.24em;
    text-transform: uppercase;
    color: var(--color-text-mute);
    margin-top: 14px;
    font-weight: 500;
    font-style: normal;
}

/* ---------- Lead form ---------- */
.lead-form-section {
    position: relative;
    overflow: hidden;
    background: var(--color-bg-dark);
    color: var(--color-bg);
}
.lead-form-section .container { position: relative; z-index: 2; }
.lead-form-section__bg {
    position: absolute; inset: 0;
    background-size: cover; background-position: center;
    opacity: 0.22;
    z-index: 0;
    transform: scale(1.06);
    animation: hero-zoom 22s var(--ease) forwards;
    filter: var(--photo-preset);
}
.lead-form-section::after {
    content: "";
    position: absolute; inset: 0;
    background: radial-gradient(ellipse at 30% 20%, transparent 0%, rgba(37,37,31,0.55) 70%);
    z-index: 1;
}
.lead-form {
    display: grid;
    grid-template-columns: 5fr 6fr;
    gap: clamp(32px, 6vw, 80px);
    align-items: stretch;
}
@media (max-width: 900px) { .lead-form { grid-template-columns: 1fr; } }
.lead-form__intro { align-self: center; }
.lead-form__intro .eyebrow { color: var(--color-accent-2); }
.lead-form__intro h2 { color: var(--color-bg); margin: 14px 0 16px; max-width: 18ch; }
.lead-form__intro p { color: rgba(236,230,216,0.78); font-size: 17px; line-height: 1.55; max-width: 38ch; }
.lead-form__intro ul {
    list-style: none; padding: 0;
    margin: 28px 0 0;
    display: grid; gap: 12px;
}
.lead-form__intro li {
    padding-left: 22px; position: relative;
    font-size: 14px;
    color: rgba(236,230,216,0.9);
    line-height: 1.5;
}
.lead-form__intro li::before {
    content: ""; position: absolute; left: 0; top: 10px;
    width: 12px; height: 1px; background: var(--color-accent-2);
}
.lead-form__intro a { color: var(--color-accent-2); border-bottom: 1px solid rgba(168,181,138,0.5); }

.form {
    background: var(--color-bg);
    color: var(--color-text);
    padding: clamp(28px, 4vw, 44px);
    border-radius: var(--radius-md);
    display: grid; gap: 18px;
    box-shadow: 0 30px 80px rgba(0,0,0,0.35);
}
.form__heading { font-family: var(--font-serif); font-size: 26px; font-weight: 500; line-height: 1.05; margin: 0; }
.form__sub { font-size: 13px; color: var(--color-text-mute); margin: -6px 0 4px; }
.form__row { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .form__row { grid-template-columns: 1fr; } }
.form__field { display: grid; gap: 8px; }
.form__field label {
    font-size: 11px;
    letter-spacing: 0.18em;
    text-transform: uppercase;
    font-weight: 500;
    color: var(--color-text-mute);
}
.form input, .form select, .form textarea {
    background: transparent;
    border: 0;
    border-bottom: 1px solid var(--color-line);
    padding: 8px 0 10px;
    font-size: 16px;
    color: var(--color-text);
    border-radius: 0;
    appearance: none;
    transition: border-color .3s var(--ease);
}
.form input::placeholder, .form textarea::placeholder { color: rgba(110,108,100,0.55); }
.form input:focus, .form select:focus, .form textarea:focus {
    outline: none;
    border-bottom-color: var(--color-accent);
}
.form select {
    background-image: linear-gradient(45deg, transparent 50%, var(--color-text) 50%), linear-gradient(135deg, var(--color-text) 50%, transparent 50%);
    background-position: calc(100% - 16px) calc(50% - 2px), calc(100% - 11px) calc(50% - 2px);
    background-size: 5px 5px, 5px 5px;
    background-repeat: no-repeat;
}
.form__consent { display: flex; gap: 12px; align-items: flex-start; font-size: 13px; color: var(--color-text-mute); line-height: 1.5; }
.form__consent input { width: 16px; height: 16px; margin-top: 2px; accent-color: var(--color-accent); flex-shrink: 0; }
.form__consent a { color: var(--color-text); border-bottom: 1px solid var(--color-line); }
.form__status { display: none; padding: 10px 14px; font-size: 14px; border-radius: 8px; margin: 0; }
.form__status.is-success { display: block; background: rgba(74,90,58,0.12); color: var(--color-accent); }
.form__status.is-error   { display: block; background: rgba(140,60,40,0.10); color: #8b3c28; }
.form button[type="submit"] { justify-self: start; }

/* ---------- FAQ ---------- */
.faq { display: flex; flex-direction: column; }
.faq__item { border-top: 1px solid var(--color-line); }
.faq__item:last-child { border-bottom: 1px solid var(--color-line); }
.faq__q {
    width: 100%;
    text-align: left;
    padding: 26px 0;
    display: flex; justify-content: space-between; align-items: center;
    gap: 16px;
    font-family: var(--font-serif);
    font-size: clamp(20px, 1.8vw, 24px);
    font-weight: 500;
    color: var(--color-text);
    transition: color .25s var(--ease);
}
.faq__q::after {
    content: "+";
    font-size: 26px; font-weight: 400;
    color: var(--color-accent);
    transition: transform .35s var(--ease);
    flex-shrink: 0;
}
.faq__item.is-open .faq__q::after { transform: rotate(45deg); }
.faq__q:hover { color: var(--color-accent); }
.faq__a {
    display: grid; grid-template-rows: 0fr;
    transition: grid-template-rows .45s var(--ease);
    color: var(--color-text-mute);
    font-size: 16px; line-height: 1.6;
}
.faq__a > div { overflow: hidden; }
.faq__a > div > p { padding-bottom: 26px; max-width: 64ch; margin: 0; }
.faq__item.is-open .faq__a { grid-template-rows: 1fr; }

/* ---------- Footer ---------- */
.site-footer {
    background: var(--color-bg-dark);
    color: var(--color-bg);
    padding: clamp(64px, 8vw, 100px) 0 36px;
}
.site-footer__top {
    display: grid;
    grid-template-columns: 2fr 2fr 1fr 1fr;
    gap: clamp(28px, 4vw, 64px);
    padding-bottom: 56px;
    border-bottom: 1px solid rgba(236,230,216,0.12);
}
@media (max-width: 800px) { .site-footer__top { grid-template-columns: 1fr 1fr; } .site-footer__brand { grid-column: span 2; } }
.site-footer__venues-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 24px; }
.site-footer__brand .site-footer__wordmark,
.site-footer__brand img { display: block; margin-bottom: 18px; }
.site-footer__wordmark {
    font-family: var(--font-serif);
    font-weight: 600;
    font-size: 26px;
    letter-spacing: 0.04em;
    color: rgba(236,230,216,0.92);
    text-decoration: none;
    line-height: 1;
}
.site-footer__wordmark small {
    font-weight: 400;
    font-size: 0.82em;
    letter-spacing: 0.12em;
}
.site-footer__brand p { font-size: 14px; color: rgba(236,230,216,0.65); max-width: 38ch; line-height: 1.55; }
.site-footer h4 { font-size: 11px; letter-spacing: 0.24em; text-transform: uppercase; color: rgba(236,230,216,0.5); margin-bottom: 18px; font-weight: 500; }
.site-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.site-footer ul a { font-size: 14px; color: var(--color-bg); transition: color .25s var(--ease); }
.site-footer ul a:hover { color: var(--color-accent-2); }
.site-footer__bottom {
    margin-top: 32px;
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 16px;
    font-size: 12px; color: rgba(236,230,216,0.5); letter-spacing: 0.04em;
}
.site-footer__bottom a:hover { color: var(--color-accent-2); }

/* ---------- Sticky mobile CTA ---------- */
.sticky-cta {
    position: fixed; left: 50%; bottom: 16px;
    transform: translateX(-50%);
    z-index: 40;
    display: none; gap: 8px;
    background: var(--color-bg-dark);
    color: var(--color-bg);
    padding: 6px;
    border-radius: 999px;
    box-shadow: 0 16px 40px -16px rgba(37,37,31,0.5);
}
.sticky-cta a {
    color: var(--color-bg);
    padding: 12px 20px;
    border-radius: 999px;
    font-size: 13px; font-weight: 500;
}
.sticky-cta a + a { background: var(--color-accent); }
@media (max-width: 900px) { .sticky-cta { display: inline-flex; } }

/* ---------- Reveal animations ---------- */
[data-reveal] {
    opacity: 0;
    transform: translateY(28px);
    transition: opacity 1s var(--ease), transform 1s var(--ease);
    will-change: opacity, transform;
}
[data-reveal].is-revealed { opacity: 1; transform: translateY(0); }
[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; }
[data-reveal-delay="6"] { transition-delay: .48s; }

@keyframes page-fade { from { opacity: 0; } to { opacity: 1; } }
body { animation: page-fade .7s var(--ease) both; }

/* ══════════════════════════════════════════════════════════════
   MOBILE OVERHAUL v2 — clean, airy, properly scaled
   ══════════════════════════════════════════════════════════════ */

/* ── Tablet (≤900px) ─────────────────────────────────────────── */
@media (max-width: 900px) {
    .section { padding: clamp(48px, 7vw, 80px) 0; }
    .section--tight { padding: clamp(36px, 5vw, 56px) 0; }

    .hero { min-height: clamp(380px, 56vh, 520px); }
    .hero__inner { padding: 24px 0 32px; }
    .hero__title { font-size: clamp(36px, 5.5vw, 56px); max-width: 15ch; }
    .hero__lead { font-size: 15px; max-width: 40ch; }
    .hero__cta { gap: 10px; }
    .hero__cta .btn { padding: 13px 22px; font-size: 14px; }
    .hero__facts { gap: 14px; margin-top: 24px; padding-top: 18px; }
    .hero__fact-num { font-size: clamp(20px, 2.5vw, 28px); }
    .hero__fact-label { font-size: 11px; margin-top: 3px; }

    .split { gap: 32px; }
    .split__media { aspect-ratio: 3 / 2; }

    .lead-form-section__bg { min-height: 200px; }
}

/* ── Phone (≤560px) ──────────────────────────────────────────── */
@media (max-width: 560px) {
    /* ── Global section spacing ── */
    .section { padding: 36px 0; }
    .section--tight { padding: 28px 0; }

    /* ── Header: compact ── */
    .site-header__wordmark { font-size: 18px; }
    .site-header.is-scrolled .site-header__wordmark { font-size: 16px; }
    .site-header__inner { gap: 10px; padding: 12px 0; }
    .site-header.is-scrolled .site-header__inner { padding: 8px 0; }

    /* ── Hero: short, clean, no clutter ── */
    .hero { min-height: 320px; max-height: 420px; align-items: end; }
    .hero__media { background-position: center 30%; }
    .hero__inner { padding: 0 0 24px; }
    .hero__eyebrow { font-size: 9px; letter-spacing: 0.22em; margin-bottom: 10px; }
    .hero__title { font-size: clamp(26px, 7.5vw, 34px); margin-bottom: 0; max-width: 14ch; line-height: 1.02; }
    .hero__lead { display: none; }
    .hero__cta { margin-top: 16px; gap: 8px; }
    .hero__cta .btn { padding: 12px 20px; font-size: 13px; }
    .hero__cta .btn--ghost { display: none; }
    .hero__facts { display: none; }

    /* ── Split intro ── */
    .split { gap: 20px; }
    .split__media { aspect-ratio: 16 / 9; border-radius: 8px; }

    /* ── Formats ── */
    .format { min-height: auto; padding: 24px 20px 22px; }
    .format h3 { font-size: 20px; }
    .format p { font-size: 13px; }

    /* ── Venue cards: clean, image-first ── */
    .venues { gap: 14px; }
    .venue-card__media { aspect-ratio: 16 / 9; }
    .venue-card--wide .venue-card__media { aspect-ratio: 16 / 9; }
    .venue-card__body { padding: 14px 16px 16px; gap: 4px; }
    .venue-card__kicker { font-size: 10px; margin-bottom: 2px; }
    .venue-card__title { font-size: 20px; }
    .venue-card__body > .muted { display: none; }
    .venue-card__meta { gap: 4px 10px; font-size: 12px; margin-top: 4px; }
    .venue-card__cta { padding-top: 10px; font-size: 12px; }

    /* ── Reasons ── */
    .reason { padding: 24px 20px; }
    .reason__num { font-size: 10px; }
    .reason h3 { font-size: 17px; }
    .reason p { font-size: 13px; line-height: 1.5; }

    /* ── Steps ── */
    .step { padding: 24px 20px; }
    .step::before { font-size: 28px; margin-bottom: 4px; }
    .step h3 { font-size: 18px; }
    .step p { font-size: 13px; }

    /* ── Quote band ── */
    .quote-band { padding: 24px 20px; gap: 20px; }
    .quote-band__num { font-size: clamp(48px, 12vw, 72px); }
    .quote-band__num small { font-size: 10px; margin-top: 8px; }
    .quote-band .lead { font-size: 14px; }
    .quote-band .btn-link { font-size: 13px; }

    /* ── Lead form ── */
    .lead-form { gap: 20px; }
    .lead-form__intro h2 { font-size: clamp(22px, 6vw, 28px); }
    .lead-form__intro p { font-size: 14px; }
    .lead-form__intro ul { margin-top: 18px; gap: 8px; }
    .lead-form__intro li { font-size: 13px; }
    .form { padding: 20px; gap: 14px; }
    .form__heading { font-size: 18px; }
    .form__sub { font-size: 12px; }
    .lead-form-section__bg { min-height: 140px; }

    /* ── FAQ ── */
    .faq__q { font-size: 16px; padding: 16px 0; }
    .faq__a { font-size: 14px; }

    /* ── Footer ── */
    .site-footer { padding: 40px 0 24px; }
    .site-footer__top { grid-template-columns: 1fr !important; gap: 20px; padding-bottom: 24px; }
    .site-footer__brand { grid-column: span 1 !important; }
    .site-footer__brand p { font-size: 13px; }
    .site-footer__wordmark { font-size: 20px; }
    .site-footer h4 { font-size: 10px; margin-bottom: 12px; }
    .site-footer ul { gap: 8px; }
    .site-footer ul a { font-size: 13px; }
    .site-footer__bottom { flex-direction: column; gap: 6px; text-align: center; font-size: 11px; }

    /* ── Sticky CTA ── */
    .sticky-cta { padding: 5px; border-radius: 999px; }
    .sticky-cta a { padding: 10px 16px; font-size: 12px; }

    /* ── Mobile drawer ── */
    .site-drawer { padding: 56px var(--gutter) 28px; gap: 28px; }
    .site-drawer__close { font-size: 26px; top: 16px; }
    .site-drawer__nav { gap: 12px; }
    .site-drawer__nav a { font-size: 20px; }
    .site-drawer__contacts { font-size: 14px; gap: 10px; }

    /* ── Contacts/transfer from info pages ── */
    .contacts-grid { grid-template-columns: 1fr !important; }
    .contacts-card__media { aspect-ratio: 16 / 9; }
    .transfer-grid { grid-template-columns: 1fr !important; }
    .transfer-card { padding: 16px; }

    /* ── CTA band (venue/service pages) ── */
    .v-cta-band h2 { font-size: clamp(20px, 5.5vw, 28px); }
    .v-cta-band p { font-size: 14px; }
    .v-cta-band__buttons { flex-direction: column; gap: 8px; }
    .v-cta-band__buttons .btn { width: 100%; text-align: center; }
}

@media (prefers-reduced-motion: reduce) {
    [data-reveal] { opacity: 1; transform: none; transition: none; }
    .hero__media, .lead-form-section__bg { animation: none; }
    body { animation: none; }
}

/* ---------- Nav dropdowns (desktop) ---------- */
.site-nav__group { position: relative; }
.site-nav__toggle {
    display: inline-flex; align-items: center; gap: 4px;
    padding: 0 0 4px;
    font: inherit; color: inherit; cursor: pointer;
    background: none; border: 0;
    transition: color .25s var(--ease);
}
.site-nav__chev {
    font-size: 9px; opacity: 0.6;
    transition: transform .25s var(--ease);
    display: inline-block;
}
.site-nav__group:hover .site-nav__chev,
.site-nav__group:focus-within .site-nav__chev { transform: translateY(2px); }

.site-nav__menu {
    position: absolute;
    top: calc(100% + 14px); left: 50%;
    transform: translate(-50%, 8px);
    min-width: 240px;
    background: var(--color-white);
    border: 1px solid var(--color-line-soft);
    border-radius: var(--radius-md);
    box-shadow: var(--shadow-card);
    padding: 12px;
    display: flex; flex-direction: column; gap: 2px;
    opacity: 0; visibility: hidden;
    transition: opacity .25s var(--ease), transform .25s var(--ease), visibility .25s;
    z-index: 50;
}
.site-nav__menu::before {
    content: ""; position: absolute;
    top: -10px; left: 0; right: 0; height: 14px;
    /* invisible bridge to prevent hover gap */
}
.site-nav__group:hover .site-nav__menu,
.site-nav__group:focus-within .site-nav__menu {
    opacity: 1; visibility: visible;
    transform: translate(-50%, 0);
}
.site-nav__menu a {
    display: block;
    padding: 10px 14px;
    font-size: 14px;
    border-radius: 8px;
    transition: background .2s var(--ease), color .2s var(--ease);
}
.site-nav__menu a::after { display: none; }
.site-nav__menu a:hover {
    background: var(--color-bg-alt);
    color: var(--color-accent);
}

/* ---------- Drawer groups (mobile) ---------- */
.site-drawer__group {
    display: flex; flex-direction: column; gap: 12px;
    padding: 16px 0;
    border-top: 1px solid var(--color-line-soft);
}
.site-drawer__group-title {
    font-family: var(--font-sans);
    font-size: 11px; font-weight: 500;
    letter-spacing: 0.28em; text-transform: uppercase;
    color: var(--color-text-mute);
    margin-bottom: 4px;
}
.site-drawer__group a {
    font-family: var(--font-serif);
    font-size: 24px; line-height: 1.2;
    color: var(--color-text);
}
