/* ─── Дом «Река Культур» — общий стиль ───────────────────── */
:root{
  --bg:        #ffffff;
  --paper:     #f3f1ec;
  --ink:       #0a0a0a;
  --ink-soft:  #8a8782;
  --line:      #e6e3dc;
  --accent:    #0a0a0a;
  --link:      #1d4ea2;
  --serif:     "Onest", ui-sans-serif, system-ui, sans-serif;
  --sans:      "Onest", ui-sans-serif, system-ui, sans-serif;
  --mono:      "Onest", ui-monospace, monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--ink);font-family:var(--sans);-webkit-font-smoothing:antialiased}
body{font-size:14px;line-height:1.5}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* ── Layout ──────────────────────────────────────────────── */
.stage{display:grid;grid-template-columns:200px 1fr;min-height:100vh}

/* ── Sidebar nav (osetskayasalov style) ─────────────────── */
.nav{
  position:sticky;top:0;align-self:start;height:100vh;
  padding:32px 20px 28px 32px;
  display:flex;flex-direction:column;gap:40px;
  background:var(--bg);
  z-index:5;
  border-right:0;
}
.brand{display:flex;flex-direction:column;gap:6px}
.brand a{display:block}
.brand .mark{
  font-family:var(--sans);font-weight:600;font-style:normal;
  font-size:14px;line-height:1;letter-spacing:.12em;
  text-transform:uppercase;color:var(--ink);
  white-space:nowrap;
}
.brand .mark em{display:none}

.menu{display:flex;flex-direction:column;gap:0;margin-top:8px}
.menu a{
  display:block;padding:5px 0;font-size:11px;color:var(--link);
  font-weight:500;letter-spacing:.14em;text-transform:uppercase;
  border-bottom:0;transition:opacity .2s;
}
.menu a:hover{opacity:.55;border-color:transparent}
.menu a.active{color:var(--link);opacity:1}
.menu a.active::before{content:"• ";color:var(--link)}
.menu a .num{display:none}

.nav-foot{
  margin-top:auto;display:flex;flex-direction:column;gap:8px;
  font-size:11px;letter-spacing:.14em;color:var(--link);text-transform:uppercase;font-weight:500;
}
.nav-foot .lang{display:flex;gap:8px;align-items:center}
.nav-foot .lang span:first-child{color:var(--link)}
.nav-foot .lang span:nth-child(2){color:var(--ink-soft)}
.nav-foot div:not(.lang){color:var(--ink-soft);letter-spacing:.04em;text-transform:none;font-weight:400;font-size:11px}

/* ── Hamburger / peek toggle ───────────────────────────── */
.nav-toggle{
  position:fixed;top:18px;left:18px;z-index:120;
  display:flex;flex-direction:column;gap:5px;
  width:38px;height:38px;padding:0;cursor:pointer;
  background:var(--bg);border:1px solid var(--line);
  align-items:center;justify-content:center;
  opacity:0;pointer-events:none;
  transition:opacity .35s ease, background .2s, border-color .2s;
  font:inherit;
}
.nav-toggle:hover{background:var(--paper)}
.nav-toggle span{
  display:block;width:16px;height:1px;background:var(--ink);
  transition:transform .3s,opacity .3s;
}
body:has(.stage.nav-collapsed) .nav-toggle,
body:has(.stage.nav-peek) .nav-toggle{
  opacity:1;pointer-events:auto;
}
.nav-toggle.is-open span:nth-child(1){transform:translateY(3px) rotate(45deg)}
.nav-toggle.is-open span:nth-child(2){opacity:0;transform:translateX(-6px)}
.nav-toggle.is-open span:nth-child(3){transform:translateY(-3px) rotate(-45deg)}

/* Mobile back button — hidden on desktop */
.mobile-back{display:none}

/* Always hide <style> inside main (zagadki detail pages put styles in main) */
main > style{display:none !important}

/* Photo lightbox */
.photo-lightbox{position:fixed;inset:0;z-index:10001;display:flex;align-items:center;justify-content:center;opacity:0;visibility:hidden;transition:opacity .25s,visibility .25s}
.photo-lightbox.active{opacity:1;visibility:visible}
.photo-lightbox .lb-overlay{position:absolute;inset:0;background:rgba(0,0,0,.95)}
.photo-lightbox .lb-img{position:relative;max-width:94vw;max-height:88vh;object-fit:contain;z-index:1;user-select:none;-webkit-user-drag:none}
.photo-lightbox .lb-close{position:absolute;top:16px;right:16px;z-index:2;font-size:36px;color:#fff;background:none;border:none;cursor:pointer;opacity:.7;transition:opacity .2s;line-height:1}
.photo-lightbox .lb-close:hover{opacity:1}
.photo-lightbox .lb-prev,.photo-lightbox .lb-next{position:absolute;top:50%;transform:translateY(-50%);z-index:2;font-size:28px;color:#fff;background:rgba(255,255,255,.1);border:none;cursor:pointer;width:44px;height:56px;display:flex;align-items:center;justify-content:center;opacity:.6;transition:opacity .2s;border-radius:4px}
.photo-lightbox .lb-prev{left:12px}
.photo-lightbox .lb-next{right:12px}
.photo-lightbox .lb-prev:hover,.photo-lightbox .lb-next:hover{opacity:1;background:rgba(255,255,255,.2)}
.photo-lightbox .lb-counter{position:absolute;bottom:20px;left:50%;transform:translateX(-50%);z-index:2;color:rgba(255,255,255,.6);font-size:12px;letter-spacing:.1em;font-family:var(--sans)}

/* PEEK mode — nav floats over content; beats .nav-collapsed via !important */
.stage.nav-peek .nav{
  position:fixed !important;left:0 !important;top:0 !important;
  width:200px !important;height:100vh !important;
  opacity:1 !important;pointer-events:auto !important;
  padding:32px 20px 28px 32px !important;
  z-index:110;background:var(--bg);
  border-right:1px solid var(--line);
  box-shadow:24px 0 60px rgba(0,0,0,.06);
  transform:translateX(0) !important;
  transition:transform .35s cubic-bezier(.22,.84,.24,1), opacity .35s ease;
}

/* ── Sidebar collapse animation ───────────────────────── */
.stage{
  transition: grid-template-columns .55s cubic-bezier(.22,.84,.24,1);
}
.stage.nav-collapsed{
  grid-template-columns: 0 1fr;
}
.nav{
  overflow:hidden;
  transition: opacity .35s ease-out, padding .45s cubic-bezier(.22,.84,.24,1);
}
.stage.nav-collapsed .nav{
  opacity:0;
  padding-left:0;
  padding-right:0;
  pointer-events:none;
}

/* ─────────────────────────────────────────────────────────
   HPAGE — horizontal-scroll inner pages
   <body class="hpage"> turns the page sideways.
   ──────────────────────────────────────────────────────── */
body.hpage{height:100vh;overflow:hidden;margin:0}
body.hpage .stage{height:100vh;min-height:0;overflow:hidden}
body.hpage .nav{height:100vh;position:sticky;top:0;align-self:start}

body.hpage main{
  height:100vh;overflow-x:auto;overflow-y:hidden;
  display:flex;flex-direction:row;align-items:stretch;
  padding:0;max-width:none;
  scrollbar-width:thin;scrollbar-color:var(--ink) transparent;
}
body.hpage main::-webkit-scrollbar{height:6px}
body.hpage main::-webkit-scrollbar-track{background:transparent}
body.hpage main::-webkit-scrollbar-thumb{background:var(--ink);border-radius:3px}

body.hpage main > *{
  flex:0 0 auto;height:100vh;
  padding:32px 40px;box-sizing:border-box;
  border-right:1px solid var(--line);
  overflow:hidden;
  margin:0;
}
body.hpage main > *:last-child{border-right:0;padding-right:48px}

/* Hide non-last topbars (breadcrumbs); the trailing copyright topbar stays */
body.hpage main > .topbar:not(:last-child){display:none}

/* Combined hero+content panel — hero on TOP, next section pushed to BOTTOM */
body.hpage main > .hpanel-combo{
  flex:0 0 auto;height:100vh;
  padding:32px 40px;box-sizing:border-box;
  border-right:1px solid var(--line);
  display:flex;flex-direction:column;gap:20px;
  justify-content:space-between;
  width:min(82vw, 980px);min-width:640px;
  overflow:hidden;
}
body.hpage main > .hpanel-combo > *{
  width:100% !important;min-width:0 !important;
  height:auto !important;padding:0 !important;
  border:0 !important;background:transparent;margin:0;
}
body.hpage main > .hpanel-combo > .plain-hero,
body.hpage main > .hpanel-combo > .detail-hero,
body.hpage main > .hpanel-combo > .z-hero,
body.hpage main > .hpanel-combo > .zhero{
  display:flex;flex-direction:column;gap:14px;
  flex:0 0 auto;padding-top:24px !important;
}
body.hpage main > .hpanel-combo > .plain-hero h1,
body.hpage main > .hpanel-combo > .detail-hero h1,
body.hpage main > .hpanel-combo > .z-hero h1,
body.hpage main > .hpanel-combo > .zhero h1{font-size:clamp(36px, 4.2vw, 64px)}

/* Bottom content: stretch image, anchor text grids to bottom */
body.hpage main > .hpanel-combo > .hero-shot,
body.hpage main > .hpanel-combo > .z-bigshot{
  flex:1 1 auto;min-height:200px;height:auto !important;width:100% !important;
  border:1px solid var(--line);background:var(--paper);
  align-self:stretch;margin-top:auto;
}
body.hpage main > .hpanel-combo > .intro-cols,
body.hpage main > .hpanel-combo > .prose,
body.hpage main > .hpanel-combo > .contact-grid,
body.hpage main > .hpanel-combo > .related{
  align-self:end;flex:0 0 auto;margin-top:auto;padding-bottom:24px !important;
}
body.hpage main > .hpanel-combo > .intro-cols,
body.hpage main > .hpanel-combo > .prose{
  display:grid;grid-template-columns:80px 1fr 1fr;gap:20px;align-content:end;
}
body.hpage main > .hpanel-combo > .contact-grid{
  display:flex;flex-direction:row;gap:14px;
}
body.hpage main > .hpanel-combo > .contact-grid .contact-card{width:240px;flex:0 0 240px}

/* On Контакты page the SECOND combo holds intro-cols (where) + form (свободный вопрос).
   Stack them side-by-side inside the panel. */
body.hpage main > .hpanel-combo > .form{
  align-self:end;flex:0 0 auto;margin-top:auto;padding-bottom:24px !important;
  display:grid;grid-template-columns:80px 1fr;gap:20px;
}

/* Vertically-centred heroes ───────────────────────────── */
body.hpage main > .plain-hero,
body.hpage main > .zhero,
body.hpage main > .z-hero{
  display:flex;flex-direction:column;justify-content:center;gap:18px;
  width:min(72vw, 720px);min-width:480px;padding:48px 48px;
}
body.hpage main > .detail-hero{
  display:flex;flex-direction:column;justify-content:center;gap:18px;
  width:min(72vw, 760px);min-width:520px;
  padding:48px 48px;border-bottom:0;
}
body.hpage main > .detail-hero .rail-col{display:none}
body.hpage main > .detail-hero .eyebrow{flex-wrap:wrap;gap:6px 12px}
body.hpage main > .detail-hero h1,
body.hpage main > .plain-hero h1,
body.hpage main > .zhero h1,
body.hpage main > .z-hero h1{font-size:clamp(40px, 5vw, 76px)}

/* Big shots — narrower so empty placeholders aren't overwhelming */
body.hpage main > .hero-shot,
body.hpage main > .z-bigshot{
  width:min(58vw, 920px);height:min(60vh, 540px);
  padding:0;border:1px solid var(--line);
  align-self:center;margin:auto 16px;
  background:var(--paper);
}

/* Tri-/dual-column content panels ─────────────────────── */
body.hpage main > .intro-cols,
body.hpage main > .prose{
  display:grid;grid-template-columns:100px 1fr 1fr;gap:24px;
  width:min(72vw, 880px);min-width:640px;align-content:center;
  border-top:0;padding:48px 40px;
}
body.hpage main > .steps,
body.hpage main > .form{
  display:grid;grid-template-columns:100px 1fr;gap:24px;
  width:min(72vw, 820px);min-width:560px;align-content:center;
  border-top:0;padding:48px 40px;
}
body.hpage main > .z-body{
  display:grid;grid-template-columns:100px 1fr 1fr;gap:24px;
  width:min(72vw, 880px);min-width:640px;align-content:center;
  border-top:0;padding:48px 40px;
}

/* Steps: keep description in WIDE column (default auto-flow puts <p> under counter) */
.steps ol li{grid-template-areas:'n t' '. d'}
.steps ol li::before{grid-area:n}
.steps ol li h4{grid-area:t}
.steps ol li p{grid-area:d}

/* Contact cards — row of three ────────────────────────── */
body.hpage main > .contact-grid{
  display:flex;flex-direction:row;gap:16px;
  width:auto;min-width:680px;align-items:stretch;align-content:center;
  padding:48px 32px;
}
body.hpage main > .contact-grid .contact-card{width:240px;flex:0 0 240px;height:auto;align-self:center}

/* Galleries — flip to row-major ───────────────────────── */
body.hpage main > .gallery{
  width:auto;padding:48px 40px;justify-content:initial;
}
body.hpage main > .gallery .gallery-grid{
  display:grid;grid-template-rows:1fr 1fr;grid-auto-flow:column;
  grid-auto-columns:260px;grid-template-columns:none;
  gap:16px;height:80vh;
}
body.hpage main > .gallery .gallery-grid > .g-item{aspect-ratio:auto;width:auto;height:auto}
body.hpage main > .gallery .gallery-grid > .g-tall{grid-row:span 2;grid-column:auto}
body.hpage main > .gallery .gallery-grid > .g-wide{grid-row:auto;grid-column:span 2}
body.hpage main > .gallery .gallery-grid > .g-sq{grid-row:auto;grid-column:auto}

body.hpage main > .z-gallery{
  display:grid;grid-template-rows:1fr 1fr;grid-auto-flow:column;
  grid-auto-columns:260px;grid-template-columns:none;
  gap:16px;height:80vh;padding:48px 40px;
  border-top:0;
}
body.hpage main > .z-gallery > .g-item{aspect-ratio:auto;width:auto;height:auto}
body.hpage main > .z-gallery > .g-tall{grid-row:span 2;grid-column:auto}
body.hpage main > .z-gallery > .g-wide{grid-row:auto;grid-column:span 2}
body.hpage main > .z-gallery > .g-sq{grid-row:auto;grid-column:auto}

/* Zagadki main gallery — 3 rows, columns flow ─────────── */
body.hpage main > .zgrid{
  display:grid;grid-template-rows:repeat(3, 1fr);
  grid-auto-flow:column;grid-auto-columns:260px;
  grid-template-columns:none;
  gap:8px;height:82vh;padding:24px 40px;
}
body.hpage main > .zgrid .ztile{height:100%;width:100%}
body.hpage main > .zgrid .ztile-shot{aspect-ratio:auto;height:100%;width:100%}

/* Pull quote ──────────────────────────────────────────── */
body.hpage main > .pull{
  display:grid;grid-template-columns:80px 1fr 140px;gap:24px;
  width:min(72vw, 820px);min-width:560px;align-content:center;
  border-top:0;border-bottom:0;margin:0;padding:48px 40px;
}

/* Specs ───────────────────────────────────────────────── */
body.hpage main > .specs{
  display:grid;grid-template-columns:100px repeat(4, minmax(120px, 1fr));
  gap:24px;width:auto;min-width:560px;align-content:center;
  padding:48px 40px;
}

/* Booking strip ───────────────────────────────────────── */
body.hpage main > .booking{
  display:grid;grid-template-columns:1fr auto;gap:32px;
  width:auto;min-width:560px;align-content:center;
  margin:0;padding:40px;
}

/* Related cards row ───────────────────────────────────── */
body.hpage main > .related{
  width:auto;padding:48px 24px;align-content:center;
  border-top:0;margin:0;
}
body.hpage main > .related .grid{
  display:grid;grid-template-columns:repeat(4, 180px);gap:16px;
}

/* Pagers ──────────────────────────────────────────────── */
body.hpage main > .pager,
body.hpage main > .z-pager{
  display:flex;flex-direction:row;
  width:min(72vw, 760px);min-width:480px;align-items:stretch;
  justify-content:space-between;gap:24px;
  border-top:0;margin:0;padding:48px 40px;
}

/* Wordmark/manifest ───────────────────────────────────── */
body.hpage main > .wordmark{
  display:grid;grid-template-columns:100px 1fr auto;gap:24px;
  width:auto;min-width:560px;align-content:center;
  border-top:0;margin:0;padding:48px 40px;
}

/* Zagadki strip / "back" link ─────────────────────────── */
body.hpage main > .zmeta{
  display:flex;flex-direction:column;gap:14px;
  width:auto;min-width:260px;align-content:center;justify-content:center;
  border-top:0;border-bottom:0;margin:0;padding:48px 32px;
}
body.hpage main > .z-back{
  align-self:center;flex:0 0 auto;
  padding:32px 24px;border-right:1px solid var(--line);
  width:auto;min-width:160px;display:flex;align-items:center;
}

/* Zagadki main pagehead — hide entirely in hpage; nav already shows the page name */
body.hpage main > .pagehead{display:none}

/* Trailing copyright topbar — vertical mini-column */
body.hpage main > .topbar:last-child{
  display:flex !important;flex-direction:column;align-items:flex-start;justify-content:flex-start;
  gap:14px;width:auto;min-width:200px;padding:48px 24px;border-top:0 !important;margin:0;
}
body.hpage main > .topbar:last-child .meta{flex-direction:column;gap:6px}

/* Mobile fallback — fold back to vertical ─────────────── */
@media (max-width: 900px){
  body.hpage{height:auto;overflow-x:hidden;overflow-y:auto;width:100%}
  body.hpage .stage{height:auto;display:block;max-width:100vw;overflow-x:hidden}
  body.hpage .nav{
    /* Use same burger-style nav as 820px breakpoint */
    position:fixed;left:0;top:0;z-index:110;
    width:260px;height:100vh;
    transform:translateX(-100%);
    transition:transform .35s cubic-bezier(.22,.84,.24,1);
    border-right:1px solid var(--line);
    box-shadow:24px 0 60px rgba(0,0,0,.06);
    background:var(--bg);
    padding:32px 20px 28px 24px;
    overflow-y:auto;
  }
  body.hpage .stage.nav-peek .nav{
    transform:translateX(0) !important;
  }
  body.hpage .nav-toggle{
    opacity:1 !important;pointer-events:auto !important;
  }
  body.hpage .stage.nav-peek::before{
    content:"";position:fixed;inset:0;z-index:100;
    background:rgba(0,0,0,.55);
  }
  body.hpage main{
    flex-direction:column;height:auto;overflow-x:hidden;overflow-y:visible;
    padding:60px 16px 48px;max-width:100vw;display:block;
    overflow-wrap:break-word;word-wrap:break-word;
    touch-action:pan-y;-webkit-overflow-scrolling:touch;
  }
  body.hpage main > *{
    height:auto;width:auto !important;min-width:0 !important;
    border-right:0;border-bottom:1px solid var(--line);padding:24px 16px;
    display:block;
  }
  body.hpage main > style{display:none !important;padding:0;border:0}
  body.hpage main > .topbar{display:flex;padding-top:48px}
  body.hpage main > .hpanel-combo{
    display:flex;flex-direction:column;gap:16px;
    width:auto !important;min-width:0 !important;padding:24px 16px;
    height:auto !important;overflow:visible !important;
  }
  body.hpage main > .hpanel-combo > *{
    width:100% !important;min-width:0 !important;
    height:auto !important;padding:0 !important;
  }
  body.hpage main > .hpanel-combo > .hero-shot,
  body.hpage main > .hpanel-combo > .z-bigshot{
    aspect-ratio:16/10;min-height:0;
  }
  body.hpage main > .hpanel-combo > .intro-cols,
  body.hpage main > .hpanel-combo > .prose{
    display:block;
  }
  body.hpage main > .gallery .gallery-grid,
  body.hpage main > .z-gallery,
  body.hpage main > .zgrid{
    display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:none;
    grid-auto-flow:row;grid-auto-columns:auto;height:auto;
  }
  body.hpage main > .zgrid .ztile-shot{aspect-ratio:1/1}
  body.hpage main > .gallery .gallery-grid > .g-item{aspect-ratio:1/1}
  body.hpage main > .gallery .gallery-grid > .g-tall{grid-column:span 1;grid-row:auto;aspect-ratio:3/4}
  body.hpage main > .gallery .gallery-grid > .g-wide{grid-column:span 2;aspect-ratio:16/9}
  body.hpage main > .gallery .gallery-grid > .g-sq{aspect-ratio:1/1}
  body.hpage main > .z-gallery > .g-item{aspect-ratio:1/1}
  body.hpage main > .z-gallery > .g-tall{grid-column:span 1;grid-row:auto;aspect-ratio:3/4}
  body.hpage main > .z-gallery > .g-wide{grid-column:span 2;aspect-ratio:16/9}
  body.hpage main > .z-gallery > .g-sq{aspect-ratio:1/1}
  body.hpage main > .detail-hero{display:block}
  body.hpage main > .detail-hero .rail-col{display:none}
  body.hpage main > .detail-hero h1{font-size:clamp(28px, 8vw, 48px)}
  body.hpage main > .plain-hero h1,
  body.hpage main > .z-hero h1,
  body.hpage main > .zhero h1{font-size:clamp(28px, 8vw, 48px)}
  body.hpage main > .hpanel-combo > .plain-hero h1,
  body.hpage main > .hpanel-combo > .detail-hero h1,
  body.hpage main > .hpanel-combo > .z-hero h1,
  body.hpage main > .hpanel-combo > .zhero h1{font-size:clamp(28px, 8vw, 48px)}
  body.hpage main > .intro-cols,
  body.hpage main > .prose,
  body.hpage main > .steps,
  body.hpage main > .form,
  body.hpage main > .z-body,
  body.hpage main > .pull,
  body.hpage main > .specs,
  body.hpage main > .booking,
  body.hpage main > .wordmark{display:block}
  body.hpage main > .specs{display:grid;grid-template-columns:1fr 1fr;gap:16px}
  body.hpage main > .related,
  body.hpage main > .hpanel-combo > .related{display:block}
  body.hpage main > .related .grid,
  body.hpage main > .hpanel-combo > .related .grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}
  body.hpage main > .pager,
  body.hpage main > .z-pager{
    display:flex;flex-direction:column;width:auto !important;min-width:0 !important;
    padding:24px 16px;
  }
  body.hpage main > .pager a.next,
  body.hpage main > .z-pager a.next{text-align:left;align-items:flex-start}
  body.hpage main > .contact-grid{flex-direction:column;display:flex}
  body.hpage main > .contact-grid .contact-card{width:auto;flex:initial}
  body.hpage main > .booking{padding:24px 16px}
  body.hpage main > .z-back{padding:16px;width:auto;min-width:0;display:inline-flex}
  /* Zagadki detail page styles */
  .z-hero h1{font-size:clamp(28px, 8vw, 48px) !important}
  .z-body{display:block !important;grid-template-columns:1fr !important}
  .z-body .knum{margin-bottom:16px}
  .z-gallery{display:grid !important;grid-template-columns:repeat(2,1fr) !important;grid-template-rows:none !important;grid-auto-flow:row !important;height:auto !important}
  .z-gallery .g-tall{grid-column:span 1 !important;grid-row:auto !important;aspect-ratio:3/4}
  .z-gallery .g-wide{grid-column:span 2 !important}
  .z-pager{flex-direction:column !important}
  .z-pager a.next{text-align:left !important;align-items:flex-start !important}
}

/* ── Main column ─────────────────────────────────────────── */
main{padding:48px 56px 96px;max-width:1380px}

/* ── Topbar (crumbs) ─────────────────────────────────────── */
.topbar{
  display:flex;justify-content:space-between;align-items:flex-end;
  padding-bottom:24px;border-bottom:1px solid var(--line);
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
  gap:24px;flex-wrap:wrap;
}
.topbar .crumbs span{margin-right:14px}
.topbar .crumbs a:hover{color:var(--accent)}
.topbar .meta{display:flex;gap:22px;flex-wrap:wrap}

/* ── Hero (index) ────────────────────────────────────────── */
.hero{padding:80px 0 96px;position:relative}
.hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(40px, 5.4vw, 84px);line-height:1.04;
  letter-spacing:-.012em;margin:0;
  max-width:1100px;
  text-wrap:balance;
}
.hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.hero h1 .light{color:var(--ink-soft);font-weight:300}
.hero-foot{
  display:grid;grid-template-columns:1fr auto auto;align-items:end;gap:48px;
  margin-top:64px;padding-top:24px;border-top:1px solid var(--line);
}
.hero-foot p{
  max-width:520px;margin:0;color:var(--ink-soft);
  font-size:14.5px;line-height:1.55;
}
.hero-foot p strong{color:var(--ink);font-weight:500}
.hero-foot .scroll{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  display:flex;align-items:center;gap:10px;color:var(--ink);white-space:nowrap;
}
.hero-foot .scroll .dot{width:6px;height:6px;border-radius:50%;background:var(--accent);display:inline-block}
.hero-index{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--ink-soft);text-align:right;line-height:1.6;
}
.hero-index b{display:block;color:var(--ink);font-weight:500;font-size:11px}

/* ── Section ─────────────────────────────────────────────── */
.section{padding:64px 0 80px;border-top:1px solid var(--line)}
.sec-head{
  display:grid;grid-template-columns:160px 1fr auto;align-items:end;gap:32px;
  margin-bottom:36px;
}
.sec-num{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft);
}
.sec-title{
  font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:48px;line-height:1;letter-spacing:-.01em;margin:0;
}
.sec-meta{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
  text-align:right;
}
.sec-body{display:grid;grid-template-columns:160px 1fr;gap:32px;align-items:start}
.sec-rail{
  writing-mode:vertical-rl;transform:rotate(180deg);
  font-family:var(--mono);font-size:11px;letter-spacing:.32em;text-transform:uppercase;
  color:var(--ink);padding-top:4px;
  display:flex;align-items:center;gap:14px;
}
.sec-rail::before{content:"";width:1px;height:48px;background:var(--ink)}
.sec-lede{
  grid-column:2;max-width:680px;margin:0 0 28px;color:var(--ink-soft);
  font-size:14.5px;line-height:1.6;
}
.sec-lede em{font-family:var(--serif);font-style:italic;font-size:16.5px;color:var(--ink)}

/* ── Card grid (index) ───────────────────────────────────── */
.grid{display:grid;gap:20px}
.grid-5{grid-template-columns:repeat(5,1fr)}
.card{display:flex;flex-direction:column;gap:12px;cursor:pointer}
.card .slot-wrap{
  position:relative;aspect-ratio:4/5;overflow:hidden;background:var(--paper);
  border:1px solid var(--line);
}
.card image-slot{
  --slot-bg: var(--paper);
  --slot-border: transparent;
  --slot-color: var(--ink-soft);
  --slot-font: var(--mono);
  width:100%;height:100%;
}
.card .slot-wrap::after{
  content:"";position:absolute;inset:0;pointer-events:none;
  box-shadow:inset 0 0 0 1px rgba(28,26,23,.04);
  transition:box-shadow .25s;
}
.card:hover .slot-wrap::after{box-shadow:inset 0 0 0 1px var(--ink)}
.card .meta{display:flex;justify-content:space-between;align-items:baseline;gap:8px}
.card .name{
  font-family:var(--serif);font-weight:400;font-size:20px;line-height:1.1;
  letter-spacing:-.005em;transition:color .2s;
}
.card .num{
  font-family:var(--mono);font-size:10px;letter-spacing:.08em;color:var(--ink-soft);
  white-space:nowrap;
}
.card .ru{font-family:var(--sans);font-size:11.5px;color:var(--ink-soft);letter-spacing:.01em}
.card:hover .name{color:var(--accent)}

.arch-grid{grid-template-columns:repeat(5,1fr)}
.arch-grid .card .slot-wrap{aspect-ratio:1/1}
.pleasure-grid .card .slot-wrap{aspect-ratio:3/4}

/* ── Footer wordmark ─────────────────────────────────────── */
.wordmark{
  padding:80px 0 32px;border-top:1px solid var(--line);
  display:grid;grid-template-columns:160px 1fr auto;align-items:end;gap:32px;
  margin-top:24px;
}
.wordmark .big{
  font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:clamp(56px, 9vw, 132px);line-height:.95;letter-spacing:-.02em;
  margin:0;
}
.wordmark .big em{font-style:normal;color:var(--accent)}
.wordmark .big .q{color:var(--ink-soft)}
.wordmark .side{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
  text-align:right;line-height:1.7;
}
.wordmark .side b{display:block;color:var(--ink);font-weight:500}


/* ─── ВНУТРЕННЯЯ СТРАНИЦА ────────────────────────────────── */

.detail-hero{
  display:grid;grid-template-columns:160px 1fr;gap:32px;
  padding:56px 0 48px;border-bottom:1px solid var(--line);
}
.detail-hero .rail-col{display:flex}
.detail-hero .title-wrap{display:flex;flex-direction:column;gap:24px;max-width:980px}
.detail-hero .eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  display:flex;gap:14px;align-items:center;
}
.detail-hero .eyebrow .dot{width:5px;height:5px;border-radius:50%;background:var(--accent);display:inline-block}
.detail-hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px, 7.6vw, 132px);line-height:.94;letter-spacing:-.02em;
  margin:0;
  text-wrap:balance;
}
.detail-hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.detail-hero h1 .light{color:var(--ink-soft)}
.detail-hero .lede{
  font-family:var(--serif);font-size:24px;line-height:1.32;font-weight:300;color:var(--ink);
  max-width:780px;margin:0;font-style:italic;
}
.detail-hero .lede::before{content:"— ";color:var(--ink-soft);font-style:normal}

/* Main hero image — full bleed slot */
.hero-shot{
  position:relative;width:100%;aspect-ratio:21/9;overflow:hidden;
  background:var(--paper);border:1px solid var(--line);margin:32px 0 0;
}
.hero-shot image-slot{
  --slot-bg: var(--paper);
  --slot-border: transparent;
  --slot-color: var(--ink-soft);
  --slot-font: var(--mono);
  width:100%;height:100%;
}

/* Two-column intro */
.intro-cols{
  display:grid;grid-template-columns:160px 1fr 1fr;gap:32px;
  padding:64px 0 32px;
}
.intro-cols .num{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft);
}
.intro-cols h2{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:36px;
  line-height:1.1;margin:0 0 18px;letter-spacing:-.01em;
}
.intro-cols p{margin:0 0 14px;font-size:15px;line-height:1.65;color:var(--ink)}
.intro-cols p.muted{color:var(--ink-soft);font-size:14px}
.intro-cols ul{margin:0;padding-left:0;list-style:none}
.intro-cols li{
  display:flex;gap:14px;padding:10px 0;border-top:1px solid var(--line);
  font-size:14px;
}
.intro-cols li:last-child{border-bottom:1px solid var(--line)}
.intro-cols li .k{
  flex:0 0 110px;color:var(--ink-soft);font-family:var(--mono);font-size:11px;
  letter-spacing:.06em;text-transform:uppercase;padding-top:1px;
}
.intro-cols li .v{flex:1;color:var(--ink)}

/* Gallery */
.gallery{padding:32px 0 24px}
.gallery-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:20px}
.gallery-grid .g-item{
  position:relative;background:var(--paper);border:1px solid var(--line);
  overflow:hidden;
}
.gallery-grid .g-item image-slot{
  --slot-bg: var(--paper);
  --slot-border: transparent;
  --slot-color: var(--ink-soft);
  --slot-font: var(--mono);
  width:100%;height:100%;display:block;
}
.gallery-grid .g-tall{grid-column:span 2;grid-row:span 2;aspect-ratio:2/3}
.gallery-grid .g-wide{grid-column:span 4;aspect-ratio:16/9}
.gallery-grid .g-sq{grid-column:span 2;aspect-ratio:1/1}

/* Pull quote */
.pull{
  padding:80px 0 64px;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
  display:grid;grid-template-columns:160px 1fr 200px;gap:32px;align-items:start;
  margin:40px 0;
}
.pull blockquote{
  margin:0;font-family:var(--serif);font-style:italic;font-weight:300;
  font-size:clamp(28px, 3.4vw, 44px);line-height:1.2;letter-spacing:-.005em;
  max-width:880px;text-wrap:balance;
}
.pull blockquote em{font-style:normal;color:var(--accent)}
.pull .attr{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
  text-align:right;line-height:1.7;
}
.pull .attr b{color:var(--ink);display:block;font-weight:500}

/* Specs / details strip */
.specs{
  display:grid;grid-template-columns:160px repeat(4,1fr);gap:32px;
  padding:32px 0 64px;
}
.specs .label{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft);
}
.specs .spec{display:flex;flex-direction:column;gap:6px}
.specs .spec .k{
  font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft);
}
.specs .spec .v{
  font-family:var(--serif);font-size:28px;font-weight:300;line-height:1.1;
}

/* Booking CTA strip */
.booking{
  margin:24px 0 0;padding:48px;background:var(--ink);color:var(--bg);
  display:grid;grid-template-columns:1fr auto;gap:32px;align-items:center;
}
.booking h3{
  margin:0;font-family:var(--serif);font-weight:300;font-style:italic;
  font-size:40px;line-height:1.05;
}
.booking h3 em{font-style:normal;color:#f1a06b}
.booking .price{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;
  color:rgba(255,255,255,.55);margin-top:10px;
}
.booking .price b{color:var(--bg);font-family:var(--serif);font-size:32px;font-weight:300;display:inline-block;margin-right:8px;letter-spacing:-.005em}
.booking .cta{
  display:inline-flex;align-items:center;gap:14px;
  padding:18px 28px;border:1px solid rgba(255,255,255,.4);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  color:var(--bg);transition:background .2s,color .2s;
}
.booking .cta:hover{background:#f1a06b;color:var(--ink);border-color:#f1a06b}
.booking .cta .arrow{transition:transform .2s}
.booking .cta:hover .arrow{transform:translateX(4px)}

/* Related strip */
.related{padding:80px 0 32px;border-top:1px solid var(--line);margin-top:64px}
.related .sec-head{margin-bottom:28px}
.related .grid{grid-template-columns:repeat(4,1fr)}
.related .card .slot-wrap{aspect-ratio:4/5}

/* Pager */
.pager{
  display:flex;justify-content:space-between;align-items:stretch;gap:24px;
  padding:48px 0;border-top:1px solid var(--line);margin-top:24px;
}
.pager a{
  flex:1;display:flex;flex-direction:column;gap:8px;padding:24px 0;
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
  transition:color .2s;
}
.pager a:hover{color:var(--accent)}
.pager a .big{
  font-family:var(--serif);font-style:italic;font-size:32px;text-transform:none;letter-spacing:-.005em;color:var(--ink);
  margin-top:6px;font-weight:300;
}
.pager a:hover .big{color:var(--accent)}
.pager a.next{text-align:right;align-items:flex-end}

/* Plain page (Нравы, Хочу пожить, etc.) */
.plain-hero{padding:80px 0 64px}
.plain-hero .eyebrow{
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--ink-soft);
  margin-bottom:24px;
}
.plain-hero h1{
  font-family:var(--serif);font-weight:300;
  font-size:clamp(56px, 7vw, 120px);line-height:.96;letter-spacing:-.02em;margin:0;
  text-wrap:balance;
}
.plain-hero h1 em{font-style:italic;color:var(--accent);font-weight:400}
.plain-hero .lede{
  font-family:var(--serif);font-size:24px;line-height:1.4;font-weight:300;color:var(--ink-soft);
  max-width:780px;margin:32px 0 0;font-style:italic;
}

.prose{display:grid;grid-template-columns:160px 1fr 1fr;gap:32px;padding:48px 0;border-top:1px solid var(--line)}
.prose .num{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft)}
.prose h3{font-family:var(--serif);font-style:italic;font-weight:300;font-size:28px;margin:0 0 14px;letter-spacing:-.005em}
.prose p{margin:0 0 14px;font-size:15px;line-height:1.65}
.prose .col-mid p{color:var(--ink)}
.prose .col-r p{color:var(--ink-soft);font-size:14px}

/* Контакт-карточки */
.contact-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:32px;padding:48px 0 0}
.contact-card{
  padding:32px 28px;border:1px solid var(--line);background:var(--paper);
  display:flex;flex-direction:column;gap:14px;
}
.contact-card .ckey{
  font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--ink-soft);
}
.contact-card .cval{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:32px;line-height:1.1;letter-spacing:-.005em;
}
.contact-card .cval a:hover{color:var(--accent)}
.contact-card p{margin:0;font-size:13.5px;color:var(--ink-soft);line-height:1.55}

/* Form sketch */
.form{padding:48px 0;display:grid;grid-template-columns:160px 1fr;gap:32px;border-top:1px solid var(--line);margin-top:48px}
.form .label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft)}
.form-fields{display:grid;grid-template-columns:1fr 1fr;gap:24px 32px;max-width:780px}
.form-fields .field{display:flex;flex-direction:column;gap:6px}
.form-fields .field.full{grid-column:1/-1}
.form-fields label{font-family:var(--mono);font-size:10.5px;letter-spacing:.08em;text-transform:uppercase;color:var(--ink-soft)}
.form-fields input,.form-fields textarea{
  background:transparent;border:0;border-bottom:1px solid var(--line);
  padding:10px 0;font:inherit;color:var(--ink);outline:none;
  font-family:var(--serif);font-size:22px;font-weight:300;
}
.form-fields input::placeholder,.form-fields textarea::placeholder{color:var(--ink-soft);font-style:italic}
.form-fields input:focus,.form-fields textarea:focus{border-color:var(--accent)}
.form-fields textarea{min-height:80px;resize:vertical}
.form-fields button{
  margin-top:8px;justify-self:start;
  padding:18px 28px;border:1px solid var(--ink);background:var(--ink);color:var(--bg);
  font-family:var(--mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;cursor:pointer;
  transition:background .2s,color .2s;
}
.form-fields button:hover{background:var(--accent);border-color:var(--accent)}

/* Steps / numbered list */
.steps{display:grid;grid-template-columns:160px 1fr;gap:32px;padding:48px 0;border-top:1px solid var(--line)}
.steps .label{font-family:var(--mono);font-size:11px;letter-spacing:.1em;color:var(--ink-soft)}
.steps ol{margin:0;padding:0;list-style:none;counter-reset:s}
.steps ol li{
  counter-increment:s;display:grid;grid-template-columns:64px 1fr;gap:24px;
  padding:24px 0;border-top:1px solid var(--line);
}
.steps ol li:first-child{border-top:0;padding-top:0}
.steps ol li::before{
  content:counter(s,decimal-leading-zero);
  font-family:var(--mono);font-size:11px;letter-spacing:.08em;color:var(--ink-soft);padding-top:4px;
}
.steps ol li h4{
  font-family:var(--serif);font-style:italic;font-weight:300;font-size:24px;margin:0 0 6px;letter-spacing:-.005em;
}
.steps ol li p{margin:0;color:var(--ink-soft);font-size:14px;line-height:1.6;max-width:640px}

@media (max-width: 1100px){
  .grid-5{grid-template-columns:repeat(3,1fr)}
  .arch-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid{grid-template-columns:repeat(3,1fr)}
  .gallery-grid .g-tall{grid-column:span 1;grid-row:auto;aspect-ratio:2/3}
  .gallery-grid .g-wide{grid-column:span 3}
  .specs{grid-template-columns:160px repeat(2,1fr)}
}
@media (max-width: 820px){
  /* ── Base: prevent horizontal overflow ── */
  html{overflow-x:hidden;width:100%}
  body{overflow-x:hidden;-webkit-text-size-adjust:100%;width:100%}
  *{max-width:100vw;box-sizing:border-box}

  /* ── Layout: single column, no sidebar grid ── */
  .stage{grid-template-columns:1fr;display:block;max-width:100vw;overflow-x:hidden}

  /* ── Nav: hidden by default, shown via burger ── */
  .nav{
    position:fixed;left:0;top:0;z-index:110;
    width:260px;height:100vh;
    transform:translateX(-100%);
    transition:transform .35s cubic-bezier(.22,.84,.24,1);
    border-right:1px solid var(--line);
    box-shadow:24px 0 60px rgba(0,0,0,.06);
    background:var(--bg);
    padding:32px 20px 28px 24px;
    overflow-y:auto;
  }
  .stage.nav-peek .nav{
    transform:translateX(0) !important;
  }

  /* Burger always visible on mobile */
  .nav-toggle{
    opacity:1 !important;pointer-events:auto !important;
    position:fixed;top:12px;left:12px;z-index:120;
  }

  /* Overlay behind nav when open */
  .stage.nav-peek::before{
    content:"";position:fixed;inset:0;z-index:100;
    background:rgba(0,0,0,.55);
  }

  /* ── Main content ── */
  main{padding:60px 16px 48px;max-width:100vw;overflow-x:hidden;overflow-wrap:break-word;word-wrap:break-word;touch-action:pan-y;-webkit-overflow-scrolling:touch}

  /* ── Touch scroll: allow vertical scroll over images ── */
  image-slot,img,.ztile,.ztile-shot,.g-item,.card,.slot-wrap,.hcard,.shot{touch-action:pan-y !important}

  /* ── Typography: fit mobile screens ── */
  .hero h1{font-size:clamp(28px, 8vw, 48px)}
  .plain-hero h1{font-size:clamp(28px, 8vw, 48px)}
  .detail-hero h1{font-size:clamp(28px, 8vw, 48px)}
  .sec-title{font-size:clamp(28px, 7vw, 40px)}
  .detail-hero .lede{font-size:18px}
  .plain-hero .lede{font-size:18px;margin-top:16px}
  .booking h3{font-size:clamp(22px, 6vw, 32px)}
  .booking .price b{font-size:24px}
  .pull blockquote{font-size:clamp(20px, 5vw, 28px)}
  .wordmark .big{font-size:clamp(32px, 10vw, 64px)}
  .card .name{font-size:16px}
  .contact-card .cval{font-size:24px}
  .specs .spec .v{font-size:22px}
  .intro-cols h2{font-size:28px}
  .prose h3{font-size:22px}

  /* ── Grids: single/double column ── */
  .hero-foot,.sec-head,.sec-body,.detail-hero,.intro-cols,.pull,.specs,.prose,.steps,.form,.wordmark,.related .sec-head{grid-template-columns:1fr !important}
  .sec-rail{display:none}
  .detail-hero .rail-col{display:none}
  .grid-5{grid-template-columns:repeat(2,1fr)}
  .arch-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid{grid-template-columns:repeat(2,1fr)}
  .gallery-grid .g-tall{grid-column:span 1;grid-row:auto;aspect-ratio:3/4}
  .gallery-grid .g-wide{grid-column:span 2}
  .related .grid{grid-template-columns:repeat(2,1fr)}
  .contact-grid{grid-template-columns:1fr}
  .form-fields{grid-template-columns:1fr}
  .booking{grid-template-columns:1fr;padding:24px 16px}
  .pager{flex-direction:column}
  .pager a.next{text-align:left;align-items:flex-start}

  /* ── Specs: 2 cols on mobile ── */
  .specs{grid-template-columns:1fr 1fr !important;gap:16px}

  /* ── Hero: compact spacing ── */
  .hero{padding:48px 0 40px}
  .hero-foot{margin-top:32px;gap:20px;grid-template-columns:1fr}
  .hero-index{text-align:left}
  .plain-hero{padding:48px 0 32px}

  /* ── Sections: tighter padding ── */
  .section{padding:40px 0 48px}
  .intro-cols{padding:32px 0 24px;gap:20px}
  .pull{padding:40px 0 32px;margin:24px 0}
  .specs{padding:24px 0 40px}
  .steps{padding:32px 0;gap:20px}
  .steps ol li{grid-template-columns:40px 1fr;gap:12px}
  .related{padding:40px 0 24px;margin-top:32px}
  .prose{padding:32px 0;gap:20px}
  .form{padding:32px 0;gap:20px}

  /* ── Hero shot / image: full width ── */
  .hero-shot{aspect-ratio:16/10;margin:16px 0 0}

  /* ── Intro cols: key-value list fix ── */
  .intro-cols li .k{flex:0 0 90px;font-size:10px}

  /* ── Topbar: show breadcrumbs on mobile ── */
  body.hpage main > .topbar:not(:last-child){display:flex !important;padding-top:16px}
  .topbar{padding-top:16px;padding-bottom:16px;flex-direction:column;align-items:flex-start;gap:8px}
  .topbar .meta{flex-direction:column;gap:4px}
  .topbar .crumbs{word-break:break-word}

  /* ── Mobile back button ── */
  .mobile-back{
    position:fixed;top:18px;right:16px;z-index:120;
    display:inline-flex;align-items:center;gap:6px;
    padding:8px 14px;
    background:var(--bg);border:1px solid var(--line);
    font-family:var(--sans);font-size:12px;font-weight:500;
    letter-spacing:.06em;text-transform:uppercase;
    color:var(--ink);text-decoration:none;
    cursor:pointer;
    box-shadow:0 2px 8px rgba(0,0,0,.08);
    transition:background .2s,border-color .2s;
  }
  .mobile-back:hover,.mobile-back:active{background:var(--paper);border-color:var(--ink)}
  .mobile-back svg{width:14px;height:14px;flex-shrink:0}

  /* ── Overflow protection ── */
  h1,h2,h3,h4,p,blockquote{overflow-wrap:break-word;word-wrap:break-word;max-width:100%}
  .detail-hero,.plain-hero,.intro-cols,.prose,.pull,.specs,.steps,.form,.booking,.related,.wordmark,.pager{overflow-x:hidden;max-width:100%}
}

/* ── Extra small screens (phones) ── */
@media (max-width: 480px){
  main{padding:16px 12px 40px}
  .hero h1{font-size:clamp(24px, 9vw, 36px)}
  .plain-hero h1{font-size:clamp(24px, 9vw, 36px)}
  .detail-hero h1{font-size:clamp(24px, 9vw, 36px)}
  .grid-5{grid-template-columns:1fr 1fr}
  .arch-grid{grid-template-columns:1fr 1fr}
  .gallery-grid{grid-template-columns:1fr 1fr}
  .related .grid{grid-template-columns:1fr 1fr}
  .card .slot-wrap{aspect-ratio:1/1}
  .booking{padding:20px 12px}
  .booking .cta{padding:14px 20px;font-size:10px}
  .sec-head{gap:12px;margin-bottom:20px}
  .wordmark .big{font-size:clamp(28px, 12vw, 48px)}
  .contact-card{padding:20px 16px}
  .contact-card .cval{font-size:20px}
}
