/*
Theme Name: Zinc
Theme URI: https://zinc.gersi.co.il
Author: Claude (for Gersi)
Description: Custom hand-coded theme for the Zinc restaurant brochure site. Premium Italian-American fine-dining, Hebrew / RTL + EN/RU. No page builders.
Version: 0.4.1
Requires at least: 6.0
Requires PHP: 7.4
Text Domain: zinc
*/

/* =========================================================================
   ZINC — design tokens. Implemented verbatim from work/brand-language.md (v1).
   Components reference tokens, never raw hex.
   ========================================================================= */
:root {
  /* ---- Black background layers (darkest -> raised) ---- */
  --zinc-black:        #000000;
  --zinc-surface:      #0A0A0A;
  --zinc-raised:       #111111;
  --zinc-card:         #161616;
  --zinc-hairline:     #2A2A28;

  /* ---- Champagne gold (brand) ---- */
  --zinc-gold:         #E8E0A8;
  --zinc-gold-rich:    #D9C77E;
  --zinc-gold-deep:    #C9A227;
  --zinc-gold-soft:    #F2E6B8;

  /* ---- Foreground text on black ---- */
  --zinc-fg:           #F5F1E8;
  --zinc-fg-strong:    #FFFFFF;
  --zinc-muted:        #B8B4AC;
  --zinc-muted-2:      #9A968E;

  /* ---- State colors ---- */
  --zinc-error:        #F2555A;
  --zinc-error-bg:     #1C0F10;
  --zinc-success:      #5FD39E;
  --zinc-success-bg:   #0E1A14;
  --zinc-focus:        #E8E0A8;

  /* ---- Semantic aliases (components reference THESE) ---- */
  --bg:                var(--zinc-surface);
  --bg-elevated:       var(--zinc-card);
  --text:              var(--zinc-fg);
  --text-muted:        var(--zinc-muted);
  --accent:            var(--zinc-gold);
  --accent-cta:        var(--zinc-gold-rich);
  --border:            var(--zinc-hairline);

  /* ---- Typography: per-script families (self-hosted, owner-chosen) ----
     Display = Playfair Display (Latin/Cyrillic) + Frank Ruhl Libre (Hebrew).
     Body    = Inter (Latin/Cyrillic) + Assistant (Hebrew).
     Browser picks the right face per glyph via @font-face unicode-range. */
  --font-display: "Playfair Display", "Frank Ruhl Libre", Georgia, "Times New Roman", serif;
  --font-body: "Inter", "Assistant", system-ui, -apple-system, "Segoe UI", Arial, sans-serif;

  /* ---- Type scale (fluid) ---- */
  --t-display: clamp(2.75rem, 6vw, 5.5rem);
  --t-h1:      clamp(2.25rem, 4.5vw, 3.5rem);
  --t-h2:      clamp(1.75rem, 3vw, 2.5rem);
  --t-h3:      clamp(1.35rem, 2vw, 1.75rem);
  --t-eyebrow: 0.8125rem;
  --t-lead:    clamp(1.0625rem, 1.6vw, 1.25rem);
  --t-body:    1rem;
  --t-small:   0.875rem;
  --t-fine:    0.8125rem;
  --t-button:  0.9375rem;

  /* ---- Spacing (8pt) ---- */
  --sp-0: 0;      --sp-1: 0.25rem; --sp-2: 0.5rem;
  --sp-3: 0.75rem;--sp-4: 1rem;    --sp-5: 1.5rem;
  --sp-6: 2rem;   --sp-7: 3rem;    --sp-8: 4rem;
  --sp-9: 6rem;   --sp-10: 8rem;   --sp-11: 10rem;

  /* ---- Widths & rhythm ---- */
  --content-max: 1200px;
  --content-narrow: 720px;
  --content-wide: 1440px;
  --gutter: clamp(1.25rem, 5vw, 4rem);
  --section-y: clamp(4rem, 10vw, 8rem);
  --radius-sm: 2px;
  --radius-md: 4px;
  --radius-pill: 999px;

  /* ---- Motion ---- */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --ease-inout: cubic-bezier(0.65, 0, 0.35, 1);
  --dur-fast: 180ms;
  --dur-mid: 420ms;
  --dur-slow: 800ms;

  --header-h: 5rem;
}

/* Hebrew documents bias the Hebrew face first for correct shaping. */
:root[lang="he"] {
  --font-display: "Frank Ruhl Libre", "Playfair Display", Georgia, serif;
  --font-body: "Assistant", "Inter", system-ui, sans-serif;
}
:root[lang="en"], :root[lang="ru"] {
  --font-display: "Playfair Display", "Frank Ruhl Libre", Georgia, serif;
  --font-body: "Inter", "Assistant", system-ui, sans-serif;
}

/* =========================================================================
   Reset
   ========================================================================= */
*, *::before, *::after { box-sizing: border-box; }
html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }
body, h1, h2, h3, h4, p, figure, blockquote, dl, dd, ul, ol { margin: 0; }
ul[class], ol[class] { list-style: none; padding: 0; }
img, picture, svg { max-width: 100%; display: block; }
button, input, select, textarea { font: inherit; color: inherit; }
a { color: inherit; text-decoration: none; }
:focus-visible {
  outline: 2px solid var(--zinc-focus);
  outline-offset: 2px;
}

/* =========================================================================
   Base typography & layout
   ========================================================================= */
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-body);
  font-size: var(--t-body);
  line-height: 1.7;
  font-weight: 400;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

h1, h2, h3 { font-family: var(--font-display); font-weight: 700; line-height: 1.12; }

.zinc-display { font-family: var(--font-display); font-size: var(--t-display); line-height: 1.05; letter-spacing: -0.01em; }
.zinc-h1 { font-size: var(--t-h1); letter-spacing: -0.005em; }
.zinc-h2 { font-size: var(--t-h2); font-weight: 600; line-height: 1.18; }
.zinc-h3 { font-size: var(--t-h3); font-weight: 600; line-height: 1.25; }

.zinc-eyebrow {
  display: inline-block;
  font-family: var(--font-body);
  font-size: var(--t-eyebrow);
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--accent);
  margin-block-end: var(--sp-4);
}
.zinc-lead { font-size: var(--t-lead); line-height: 1.7; color: var(--text); }
.zinc-small { font-size: var(--t-small); color: var(--text-muted); }
.zinc-fine { font-size: var(--t-fine); line-height: 1.55; color: var(--zinc-muted-2); }

/* Hebrew: no tracking / no uppercase (no casing in Hebrew). */
:root[lang="he"] .zinc-eyebrow { letter-spacing: 0; text-transform: none; }
:root[lang="he"] .zinc-display,
:root[lang="he"] .zinc-h1 { letter-spacing: 0; }

/* Numerals / phone / latin tokens render LTR inside RTL. */
bdi, .zinc-ltr { unicode-bidi: isolate; direction: ltr; }

/* =========================================================================
   Layout helpers
   ========================================================================= */
.zinc-container { max-inline-size: var(--content-max); margin-inline: auto; padding-inline: var(--gutter); }
.zinc-narrow { max-inline-size: var(--content-narrow); }
.zinc-wide { max-inline-size: var(--content-wide); }
.zinc-section { padding-block: var(--section-y); }
.zinc-center { text-align: center; }

.zinc-grid { display: grid; gap: var(--sp-5); }
@media (min-width: 768px) {
  .zinc-grid-2 { grid-template-columns: repeat(2, 1fr); }
  .zinc-grid-3 { grid-template-columns: repeat(3, 1fr); }
}

/* Placeholder image blocks (no real photos yet). */
.zinc-ph {
  position: relative;
  background:
    repeating-linear-gradient(135deg, var(--zinc-card) 0 18px, var(--zinc-raised) 18px 36px);
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  color: var(--zinc-muted-2);
  font-size: var(--t-small);
  letter-spacing: 0.08em;
  aspect-ratio: 4 / 3;
}
.zinc-ph--tall { aspect-ratio: 3 / 4; }
.zinc-ph--wide { aspect-ratio: 16 / 9; }

/* =========================================================================
   Buttons / CTA
   ========================================================================= */
.zinc-btn {
  display: inline-flex;
  align-items: center;
  gap: var(--sp-2);
  font-family: var(--font-body);
  font-size: var(--t-button);
  font-weight: 600;
  letter-spacing: 0.06em;
  line-height: 1;
  padding: var(--sp-3) var(--sp-6);
  border-radius: var(--radius-sm);
  border: 1px solid transparent;
  cursor: pointer;
  transition: background-color var(--dur-fast) var(--ease-out),
              color var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
  white-space: nowrap;
}
:root[lang="he"] .zinc-btn { letter-spacing: 0.02em; }

/* Primary gold CTA: black label on gold fill. */
.zinc-btn--primary { background: var(--accent-cta); color: var(--zinc-surface); border-color: var(--accent-cta); }
.zinc-btn--primary:hover { background: var(--zinc-gold); border-color: var(--zinc-gold); }

/* Secondary / ghost. */
.zinc-btn--ghost { background: transparent; color: var(--accent); border-color: var(--accent); }
.zinc-btn--ghost:hover { background: rgba(232, 224, 168, 0.08); }

/* =========================================================================
   Header / nav
   ========================================================================= */
.zinc-header {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 100;
  block-size: var(--header-h);
  display: flex;
  align-items: center;
  background: transparent;
  transition: background-color var(--dur-mid) var(--ease-inout),
              border-color var(--dur-mid) var(--ease-inout);
  border-block-end: 1px solid transparent;
}
.zinc-header.is-scrolled {
  background: var(--zinc-raised);
  border-block-end-color: var(--border);
}
.zinc-header__inner {
  inline-size: 100%;
  max-inline-size: var(--content-wide);
  margin-inline: auto;
  padding-inline: var(--gutter);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--sp-5);
}
/* Wordmark at inline-start (logo right in RTL is automatic via logical props). */
.zinc-brand {
  font-family: var(--font-display);
  font-weight: 700;
  font-size: 1.5rem;
  letter-spacing: 0.18em;
  color: var(--accent);
  text-transform: uppercase;
}
.zinc-brand img { block-size: 2.25rem; inline-size: auto; }

.zinc-nav { display: flex; align-items: center; gap: var(--sp-6); }
.zinc-nav__links { display: flex; align-items: center; gap: var(--sp-6); }
.zinc-nav__links a {
  position: relative;
  font-size: var(--t-small);
  color: var(--text);
  letter-spacing: 0.04em;
  padding-block: var(--sp-2);
}
.zinc-nav__links a::after {
  content: "";
  position: absolute;
  inset-block-end: 0;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 1px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: inline-start;
  transition: transform var(--dur-fast) var(--ease-out);
}
.zinc-nav__links a:hover::after,
.zinc-nav__links a[aria-current="page"]::after { transform: scaleX(1); }

.zinc-actions { display: flex; align-items: center; gap: var(--sp-4); }

/* Language switch (pill, gold active). */
.zinc-lang { display: inline-flex; align-items: center; gap: var(--sp-1); border: 1px solid var(--border); border-radius: var(--radius-pill); padding: var(--sp-1); }
.zinc-lang__btn {
  background: transparent;
  border: 0;
  color: var(--text-muted);
  font-size: var(--t-fine);
  font-weight: 600;
  letter-spacing: 0.08em;
  padding: var(--sp-1) var(--sp-3);
  border-radius: var(--radius-pill);
  cursor: pointer;
  transition: color var(--dur-fast) var(--ease-out), background-color var(--dur-fast) var(--ease-out);
}
.zinc-lang__btn:hover { color: var(--text); }
.zinc-lang__btn[aria-pressed="true"] { color: var(--zinc-surface); background: var(--accent); }

/* Mobile menu toggle. */
.zinc-burger {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  inline-size: 2.5rem;
  block-size: 2.5rem;
  background: transparent;
  border: 0;
  cursor: pointer;
}
.zinc-burger span { display: block; block-size: 1.5px; inline-size: 1.5rem; background: var(--accent); margin-inline: auto; transition: transform var(--dur-fast) var(--ease-out), opacity var(--dur-fast); }
.zinc-burger[aria-expanded="true"] span:nth-child(1) { transform: translateY(6.5px) rotate(45deg); }
.zinc-burger[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.zinc-burger[aria-expanded="true"] span:nth-child(3) { transform: translateY(-6.5px) rotate(-45deg); }

/* Mobile overlay menu. */
.zinc-mobile {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: var(--zinc-black);
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  gap: var(--sp-6);
  padding: var(--gutter);
  opacity: 0;
  visibility: hidden;
  transition: opacity var(--dur-mid) var(--ease-out), visibility var(--dur-mid);
}
.zinc-mobile.is-open { opacity: 1; visibility: visible; }
.zinc-mobile a { font-family: var(--font-display); font-size: var(--t-h2); color: var(--text); }
.zinc-mobile a:hover { color: var(--accent); }

@media (max-width: 900px) {
  .zinc-nav__links, .zinc-header .zinc-lang, .zinc-header .zinc-btn--primary { display: none; }
  .zinc-burger { display: flex; }
}

/* =========================================================================
   Hero
   ========================================================================= */
.zinc-hero {
  position: relative;
  min-block-size: 100vh;
  display: grid;
  place-items: center;
  text-align: center;
  padding-block-start: var(--header-h);
  padding-inline: var(--gutter);
  background: var(--zinc-black);
  overflow: hidden;
}
.zinc-hero__bg {
  position: absolute;
  inset: 0;
  z-index: 0;
  background:
    radial-gradient(120% 80% at 50% 0%, rgba(217, 199, 126, 0.10), transparent 60%),
    var(--zinc-black);
}
.zinc-hero__inner { position: relative; z-index: 1; max-inline-size: 56rem; }
.zinc-hero__title { color: var(--accent); margin-block: var(--sp-4) var(--sp-5); }
.zinc-hero__lead { color: var(--text-muted); margin-block-end: var(--sp-7); }
.zinc-hero__cta { display: inline-flex; flex-wrap: wrap; gap: var(--sp-4); justify-content: center; }

/* =========================================================================
   Bands / sections
   ========================================================================= */
.zinc-band { background: var(--zinc-surface); }
.zinc-band--black { background: var(--zinc-black); }
.zinc-band--card { background: var(--zinc-card); }

.zinc-deal {
  border-block: 1px solid var(--border);
  background: var(--zinc-card);
  text-align: center;
  padding-block: var(--sp-7);
}
.zinc-deal__amount { color: var(--accent); font-family: var(--font-display); font-size: var(--t-h2); display: block; margin-block-end: var(--sp-2); }

/* Order-channel cards. */
.zinc-channel {
  background: var(--zinc-card);
  border: 1px solid var(--border);
  padding: var(--sp-7) var(--sp-6);
  text-align: center;
  display: flex;
  flex-direction: column;
  gap: var(--sp-4);
  align-items: center;
  transition: border-color var(--dur-fast) var(--ease-out);
}
.zinc-channel:hover { border-color: var(--accent); }
.zinc-channel__title { color: var(--accent); }

/* =========================================================================
   Menu tabs (for /menus)
   ========================================================================= */
.zinc-tabs {
  display: flex;
  gap: var(--sp-6);
  border-block-end: 1px solid var(--border);
  overflow-x: auto;
  margin-block-end: var(--sp-8);
}
.zinc-tab {
  position: relative;
  background: transparent;
  border: 0;
  color: var(--text-muted);
  font-family: var(--font-body);
  font-weight: 600;
  font-size: var(--t-small);
  padding: var(--sp-3) var(--sp-1);
  cursor: pointer;
  white-space: nowrap;
  transition: color var(--dur-fast) var(--ease-out);
}
.zinc-tab:hover { color: var(--text); }
.zinc-tab::after {
  content: "";
  position: absolute;
  inset-block-end: -1px;
  inset-inline-start: 0;
  inline-size: 100%;
  block-size: 2px;
  background: var(--accent);
  transform: scaleX(0);
  transform-origin: inline-start;
  transition: transform var(--dur-fast) var(--ease-out);
}
.zinc-tab[aria-selected="true"] { color: var(--accent); }
.zinc-tab[aria-selected="true"]::after { transform: scaleX(1); }
.zinc-tab:focus-visible { outline: 2px solid var(--zinc-focus); outline-offset: 4px; border-radius: var(--radius-sm); }
.zinc-tabpanel[hidden] { display: none; }
.zinc-tabpanel:focus-visible { outline: none; }

/* Scrollable category strip: many categories, so the tablist scrolls.
   Edge fade hints there's more to scroll; scroll-snap keeps tabs tidy.
   Logical props keep it correct in RTL. */
.zinc-tabs--scroll {
  scroll-snap-type: inline proximity;
  scrollbar-width: thin;
  -webkit-overflow-scrolling: touch;
  -webkit-mask-image: linear-gradient(to right, transparent 0, #000 1.25rem, #000 calc(100% - 1.25rem), transparent 100%);
          mask-image: linear-gradient(to right, transparent 0, #000 1.25rem, #000 calc(100% - 1.25rem), transparent 100%);
}
.zinc-tabs--scroll .zinc-tab { scroll-snap-align: center; padding-inline: var(--sp-2); }
.zinc-tabs--scroll::-webkit-scrollbar { block-size: 4px; height: 4px; }
.zinc-tabs--scroll::-webkit-scrollbar-thumb { background: var(--border); border-radius: var(--radius-pill); }

/* Dish list inside a panel. No prices, no images - name + description only. */
.zinc-dishes {
  list-style: none;
  margin: 0;
  padding: 0;
  display: grid;
  gap: var(--sp-6);
}
@media (min-width: 768px) {
  .zinc-dishes { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: var(--sp-6) var(--sp-8); }
}
.zinc-dish { padding-block-end: var(--sp-5); border-block-end: 1px solid var(--border); }
.zinc-dish__name {
  color: var(--accent);
  font-family: var(--font-display);
  font-size: var(--t-h3);
  font-weight: 600;
  line-height: 1.25;
  margin-block: 0 var(--sp-2);
}
.zinc-dish__desc {
  color: var(--text-muted);
  font-size: var(--t-small);
  line-height: 1.7;
  margin: 0;
}

/* =========================================================================
   Footer
   ========================================================================= */
.zinc-footer {
  background: var(--zinc-black);
  border-block-start: 1px solid var(--border);
  padding-block: var(--section-y);
  color: var(--text-muted);
}
.zinc-footer__grid { display: grid; gap: var(--sp-7); }
@media (min-width: 768px) { .zinc-footer__grid { grid-template-columns: repeat(4, 1fr); } }
.zinc-footer h3 { color: var(--accent); font-size: var(--t-h3); margin-block-end: var(--sp-4); }
.zinc-footer a:hover { color: var(--accent); }
.zinc-footer__social { display: flex; gap: var(--sp-4); }
.zinc-footer__social a { color: var(--accent); }
.zinc-footer__bottom {
  margin-block-start: var(--sp-8);
  padding-block-start: var(--sp-5);
  border-block-start: 1px solid var(--border);
  display: flex;
  flex-wrap: wrap;
  gap: var(--sp-5);
  justify-content: space-between;
  align-items: center;
}
.zinc-footer__legal { display: flex; gap: var(--sp-5); flex-wrap: wrap; }

/* Directional icons mirror in RTL; logo & social glyphs do not. */
:root[dir="rtl"] .icon-chevron { transform: scaleX(-1); }

/* =========================================================================
   Gallery (ambiance grid) — varied tiles, swap-ready for real <img>.
   ========================================================================= */
.zinc-gallery {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-4);
}
@media (min-width: 600px) {
  .zinc-gallery { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 960px) {
  .zinc-gallery { grid-template-columns: repeat(3, 1fr); }
}
.zinc-gallery__tile { margin: 0; overflow: hidden; }
.zinc-gallery__ph { inline-size: 100%; block-size: 100%; }
.zinc-gallery__tile--tall .zinc-gallery__ph { aspect-ratio: 3 / 4; }
.zinc-gallery__tile--wide .zinc-gallery__ph { aspect-ratio: 4 / 3; }
/* Eventual real images sit edge-to-edge with a quiet hover lift. */
.zinc-gallery__tile img {
  inline-size: 100%;
  block-size: 100%;
  object-fit: cover;
  transition: transform var(--dur-mid) var(--ease-out);
}
.zinc-gallery__tile:hover img { transform: scale(1.03); }

/* =========================================================================
   Contact page — detail columns + map frame.
   ========================================================================= */
.zinc-contact-cols { display: grid; gap: var(--sp-7); }
@media (min-width: 540px) {
  .zinc-contact-cols { grid-template-columns: repeat(2, 1fr); }
}
.zinc-contact-block h2 { margin-block-end: var(--sp-2); }
.zinc-map {
  position: relative;
  inline-size: 100%;
  aspect-ratio: 4 / 3;
  border: 1px solid var(--border);
  background: var(--zinc-card);
  overflow: hidden;
  margin-block-start: var(--sp-4);
}
.zinc-map iframe {
  position: absolute;
  inset: 0;
  inline-size: 100%;
  block-size: 100%;
  border: 0;
  /* Subtle de-saturation so the bright Google map sits in the dark palette. */
  filter: grayscale(0.4) contrast(0.95);
}

/* =========================================================================
   Event-booking form.
   ========================================================================= */
.zinc-form-wrap { max-inline-size: var(--content-narrow); margin-inline: auto; }
.zinc-form {
  display: grid;
  grid-template-columns: 1fr;
  gap: var(--sp-5);
}
@media (min-width: 600px) {
  .zinc-form { grid-template-columns: repeat(2, 1fr); }
  .zinc-field--full { grid-column: 1 / -1; }
}
.zinc-field { display: flex; flex-direction: column; gap: var(--sp-2); }
.zinc-label {
  font-size: var(--t-small);
  font-weight: 600;
  color: var(--text);
  display: inline-flex;
  align-items: baseline;
  gap: var(--sp-1);
}
.zinc-req { color: var(--accent); }
.zinc-input {
  background: var(--zinc-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  padding: var(--sp-3) var(--sp-4);
  font-family: var(--font-body);
  font-size: var(--t-body);
  line-height: 1.5;
  inline-size: 100%;
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow var(--dur-fast) var(--ease-out);
}
.zinc-input::placeholder { color: var(--zinc-muted-2); }
.zinc-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 2px var(--zinc-focus);
}
.zinc-input[aria-invalid="true"] {
  border-color: var(--zinc-error);
  background: var(--zinc-error-bg);
}
.zinc-textarea { resize: vertical; min-block-size: 6rem; }
/* date/number controls keep the dark palette where the UA allows it. */
.zinc-input[type="date"]::-webkit-calendar-picker-indicator { filter: invert(0.8); cursor: pointer; }

.zinc-err {
  color: var(--zinc-error);
  font-size: var(--t-fine);
  line-height: 1.4;
}
.zinc-form__actions { display: flex; justify-content: flex-start; }
.zinc-btn:disabled,
.zinc-btn[aria-disabled="true"] { opacity: 0.6; cursor: progress; }

/* Honeypot — kept in the DOM for bots, removed from view + a11y tree. */
.zinc-hp {
  position: absolute !important;
  inline-size: 1px;
  block-size: 1px;
  overflow: hidden;
  clip: rect(0 0 0 0);
  clip-path: inset(50%);
  white-space: nowrap;
}

/* Alerts (success / error banners). */
.zinc-alert {
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: var(--sp-4) var(--sp-5);
  margin-block-end: var(--sp-6);
  display: flex;
  flex-direction: column;
  gap: var(--sp-1);
}
.zinc-alert strong { font-weight: 700; }
.zinc-alert--success { border-color: var(--zinc-success); background: var(--zinc-success-bg); }
.zinc-alert--success strong { color: var(--zinc-success); }
.zinc-alert--error { border-color: var(--zinc-error); background: var(--zinc-error-bg); }
.zinc-alert--error strong { color: var(--zinc-error); }

/* =========================================================================
   Reveal-on-scroll (JS adds .is-in). Default visible if JS disabled.
   ========================================================================= */
.zinc-reveal { opacity: 1; }
.js .zinc-reveal { opacity: 0; transform: translateY(16px); transition: opacity var(--dur-mid) var(--ease-out), transform var(--dur-mid) var(--ease-out); }
.js .zinc-reveal.is-in { opacity: 1; transform: none; }

/* =========================================================================
   Reduced motion — transforms off, opacity-only, fast.
   ========================================================================= */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    transition-duration: 120ms !important;
    scroll-behavior: auto !important;
  }
  .js .zinc-reveal { transform: none; }
  .zinc-channel:hover, .zinc-nav__links a:hover::after { /* keep */ }
}

/* Skip link (a11y). */
.zinc-skip {
  position: absolute;
  inset-block-start: -100%;
  inset-inline-start: var(--sp-4);
  background: var(--accent);
  color: var(--zinc-surface);
  padding: var(--sp-2) var(--sp-4);
  border-radius: var(--radius-sm);
  z-index: 200;
}
.zinc-skip:focus { inset-block-start: var(--sp-2); }

/* =========================================================================
   HOMEPAGE — art-directed fine-dining elevation (v0.3).
   Original visual language inspired by the Laurent design feel (full-bleed
   cinematic hero, gradient mesh, grain, thin gold frame, layered serif).
   Logical properties only (RTL-safe). Supersedes the minimal hero rules above.
   ========================================================================= */

.zinc-hero__mesh {
  position: absolute; inset: 0; z-index: 0; display: block;
  background:
    radial-gradient(60% 50% at 50% -8%,  rgba(217,199,126,0.16), transparent 62%),
    radial-gradient(48% 42% at 12% 18%,  rgba(201,162,39,0.10),  transparent 60%),
    radial-gradient(52% 48% at 88% 30%,  rgba(232,224,168,0.07), transparent 64%),
    radial-gradient(80% 60% at 50% 116%, rgba(217,199,126,0.10), transparent 60%),
    linear-gradient(180deg, #000 0%, #050505 40%, #000 100%);
}
.zinc-hero__mesh--alt {
  background:
    radial-gradient(50% 60% at 18% 50%, rgba(217,199,126,0.12), transparent 60%),
    radial-gradient(50% 60% at 82% 50%, rgba(201,162,39,0.09),  transparent 60%),
    linear-gradient(180deg, var(--zinc-black), var(--zinc-surface));
}
.zinc-hero__vignette {
  position: absolute; inset: 0; z-index: 1; display: block; pointer-events: none;
  background: radial-gradient(120% 90% at 50% 42%, transparent 52%, rgba(0,0,0,0.72) 100%);
}
.zinc-grain {
  position: absolute; inset: 0; z-index: 2; display: block; pointer-events: none;
  opacity: 0.05; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='160' height='160'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-size: 160px 160px;
}

.zinc-hero {
  position: relative;
  min-block-size: 100vh; min-block-size: 100svh;
  display: grid; place-items: center; text-align: center;
  padding-block: calc(var(--header-h) + var(--sp-7)) var(--sp-10);
  padding-inline: var(--gutter);
  background: var(--zinc-black); overflow: hidden; isolation: isolate;
}
.zinc-hero__bg { position: absolute; inset: 0; z-index: 0; }
.zinc-hero__frame {
  position: absolute; z-index: 3; pointer-events: none;
  inset: clamp(0.75rem, 2.2vw, 1.75rem);
  border: 1px solid rgba(232,224,168,0.22);
}
.zinc-hero__frame::before, .zinc-hero__frame::after {
  content: ""; position: absolute; inline-size: 12px; block-size: 12px;
  border: 1px solid var(--zinc-gold); opacity: 0.85;
}
.zinc-hero__frame::before { inset-block-start: -1px; inset-inline-start: -1px; border-inline-end: 0; border-block-end: 0; }
.zinc-hero__frame::after  { inset-block-end: -1px; inset-inline-end: -1px; border-inline-start: 0; border-block-start: 0; }

.zinc-hero__inner { position: relative; z-index: 4; max-inline-size: 60rem; }

.js .zinc-hero__eyebrow, .js .zinc-hero__title, .js .zinc-hero__lead,
.js .zinc-hero__cta, .js .zinc-hero__scroll {
  opacity: 0; transform: translateY(14px);
  animation: zinc-rise var(--dur-slow) var(--ease-out) forwards;
}
.js .zinc-hero__eyebrow { animation-delay: 80ms; }
.js .zinc-hero__title   { animation-delay: 200ms; }
.js .zinc-hero__lead    { animation-delay: 460ms; }
.js .zinc-hero__cta     { animation-delay: 620ms; }
.js .zinc-hero__scroll  { animation-delay: 820ms; }
@keyframes zinc-rise { to { opacity: 1; transform: none; } }

.zinc-hero__eyebrow { color: var(--zinc-gold); margin-block-end: var(--sp-5); }
.zinc-hero__title { margin: 0; display: grid; gap: var(--sp-3); }
.zinc-hero__wordmark {
  display: block; font-family: var(--font-display); font-weight: 700;
  font-size: clamp(4rem, 13vw, 11rem); line-height: 0.92; letter-spacing: 0.04em;
  color: var(--zinc-gold);
  text-shadow: 0 1px 0 rgba(255,255,255,0.08), 0 0 48px rgba(217,199,126,0.18);
}
:root[lang="he"] .zinc-hero__wordmark { letter-spacing: 0; }
.zinc-hero__kicker {
  display: flex; align-items: center; justify-content: center; gap: var(--sp-4);
  font-family: var(--font-body); font-size: var(--t-eyebrow); font-weight: 600;
  letter-spacing: 0.42em; text-transform: uppercase; color: var(--zinc-muted);
}
:root[lang="he"] .zinc-hero__kicker { letter-spacing: 0.12em; text-transform: none; }
.zinc-hero__kicker::before, .zinc-hero__kicker::after {
  content: ""; inline-size: clamp(1.5rem, 6vw, 4rem); block-size: 1px;
  background: linear-gradient(90deg, transparent, var(--zinc-gold-deep));
}
.zinc-hero__kicker::after { background: linear-gradient(270deg, transparent, var(--zinc-gold-deep)); }
.zinc-hero__lead { color: var(--zinc-muted); max-inline-size: 38rem; margin-inline: auto; margin-block: var(--sp-6) var(--sp-7); }
.zinc-hero__cta { display: inline-flex; flex-wrap: wrap; gap: var(--sp-4); justify-content: center; }

.zinc-hero__scroll {
  position: absolute; z-index: 4; inset-block-end: clamp(1.5rem, 4vw, 3rem);
  inset-inline-start: 50%; transform: translateX(-50%);
  display: inline-flex; flex-direction: column; align-items: center; gap: var(--sp-3);
  color: var(--zinc-muted);
}
.zinc-hero__scroll-label { font-size: var(--t-fine); font-weight: 600; letter-spacing: 0.24em; text-transform: uppercase; }
:root[lang="he"] .zinc-hero__scroll-label { letter-spacing: 0.08em; text-transform: none; }
.zinc-hero__scroll-line { inline-size: 1px; block-size: 3rem; overflow: hidden; position: relative; background: rgba(232,224,168,0.18); }
.zinc-hero__scroll-line::after {
  content: ""; position: absolute; inset-inline: 0; inset-block-start: -40%; block-size: 40%;
  background: var(--zinc-gold); animation: zinc-scroll 2.2s var(--ease-inout) infinite;
}
@keyframes zinc-scroll { 0% { transform: translateY(-100%);} 60%,100% { transform: translateY(330%);} }
.zinc-hero__scroll:hover { color: var(--zinc-gold); }

.zinc-eyebrow--center { display: block; margin-inline: auto; }
.zinc-rule { display: block; inline-size: 3rem; block-size: 2px; background: var(--zinc-gold-deep); margin-block: var(--sp-4) var(--sp-5); }
.zinc-rule--center { margin-inline: auto; }
.zinc-section__cta { margin-block-start: var(--sp-7); }
.zinc-section__head { margin-block-end: var(--sp-8); }
.zinc-section__head .zinc-rule { margin-block-end: 0; }

.zinc-split { display: grid; gap: var(--sp-7); align-items: center; }
@media (min-width: 880px) {
  .zinc-split { grid-template-columns: minmax(0, 0.9fr) minmax(0, 1.1fr); gap: var(--sp-9); }
  .zinc-split--reverse { grid-template-columns: minmax(0, 1.1fr) minmax(0, 0.9fr); }
  .zinc-split--reverse .zinc-split__body { order: -1; }
}
.zinc-split__body { max-inline-size: 34rem; }
.zinc-split__cta { margin-block-start: var(--sp-6); }

.zinc-frame {
  position: relative; margin: 0; overflow: hidden; display: grid; place-items: center;
  color: var(--zinc-gold);
  background:
    radial-gradient(120% 80% at 30% 20%, rgba(217,199,126,0.10), transparent 60%),
    linear-gradient(150deg, #14130f 0%, #0c0b09 55%, #050505 100%);
  border: 1px solid var(--border);
  box-shadow: inset 0 0 0 1px rgba(232,224,168,0.05);
  isolation: isolate;
}
.zinc-frame::before {
  content: ""; position: absolute; inset: 0; z-index: 0; pointer-events: none;
  opacity: 0.06; mix-blend-mode: overlay;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='140' height='140'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}
.zinc-frame::after { content: ""; position: absolute; inset: var(--sp-3); z-index: 1; pointer-events: none; border: 1px solid rgba(232,224,168,0.16); }
.zinc-frame--tall { aspect-ratio: 4 / 5; }
.zinc-frame--wide { aspect-ratio: 4 / 3; }
.zinc-monogram { position: relative; z-index: 2; inline-size: clamp(4.5rem, 12vw, 7rem); block-size: auto; color: var(--zinc-gold); opacity: 0.7; }
.zinc-frame__cap {
  position: absolute; z-index: 2; inset-block-end: var(--sp-5); inset-inline: 0; text-align: center;
  font-size: var(--t-fine); font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--zinc-muted);
}
:root[lang="he"] .zinc-frame__cap { letter-spacing: 0.06em; text-transform: none; }

.zinc-pillars { list-style: none; margin: var(--sp-7) 0 0; padding: 0; display: flex; flex-wrap: wrap; justify-content: center; gap: var(--sp-3) var(--sp-5); }
.zinc-pillar { display: inline-flex; align-items: center; gap: var(--sp-5); }
.zinc-pillar + .zinc-pillar::before { content: ""; inline-size: 4px; block-size: 4px; border-radius: 50%; background: var(--zinc-gold-deep); margin-inline-end: var(--sp-5); }
.zinc-pillar__word { font-family: var(--font-display); font-style: italic; font-size: var(--t-h3); color: var(--zinc-fg); }

.zinc-deal {
  position: relative; border-block: 1px solid var(--border);
  background: radial-gradient(80% 120% at 50% 0%, rgba(217,199,126,0.06), transparent 70%), var(--zinc-card);
  text-align: center; padding-block: var(--sp-8);
}
.zinc-deal__amount {
  color: var(--zinc-gold); font-family: var(--font-display);
  font-size: clamp(2.5rem, 6vw, 4rem); line-height: 1; display: block;
  margin-block: var(--sp-3) var(--sp-3); text-shadow: 0 0 32px rgba(217,199,126,0.16);
}
.zinc-deal__line { color: var(--zinc-fg); font-size: var(--t-lead); margin-block-end: var(--sp-2); }

.zinc-strip { position: relative; overflow: hidden; isolation: isolate; padding-block: clamp(5rem, 12vw, 9rem); padding-inline: var(--gutter); background: var(--zinc-black); }
.zinc-strip__bg { position: absolute; inset: 0; z-index: 0; }
.zinc-strip__bg::after { content: ""; position: absolute; inset: 0; background: radial-gradient(120% 100% at 50% 50%, transparent 45%, rgba(0,0,0,0.7) 100%); }
.zinc-strip__inner { position: relative; z-index: 1; }
.zinc-strip__quote { font-family: var(--font-display); font-style: italic; font-size: clamp(1.6rem, 3.4vw, 2.6rem); line-height: 1.3; color: var(--zinc-fg); margin-block: var(--sp-5) 0; }
.zinc-strip__cta { margin-block-start: var(--sp-7); }

.zinc-channel {
  position: relative;
  background: linear-gradient(160deg, rgba(232,224,168,0.04), transparent 60%), var(--zinc-card);
  border: 1px solid var(--border); padding: var(--sp-8) var(--sp-6) var(--sp-7);
  text-align: center; display: flex; flex-direction: column; gap: var(--sp-4); align-items: center;
  transition: border-color var(--dur-mid) var(--ease-out), transform var(--dur-mid) var(--ease-out), background-color var(--dur-mid) var(--ease-out);
}
.zinc-channel:hover { border-color: var(--zinc-gold); transform: translateY(-4px); }
.zinc-channel__num { font-family: var(--font-display); font-size: var(--t-small); letter-spacing: 0.2em; color: var(--zinc-gold-deep); }
.zinc-channel__title { color: var(--zinc-gold); margin-block-start: var(--sp-1); }
.zinc-channel .zinc-btn { margin-block-start: var(--sp-3); }

.zinc-visit { margin: var(--sp-5) 0 0; display: grid; gap: var(--sp-5); }
.zinc-visit__row { display: grid; gap: var(--sp-1); }
.zinc-visit__label { font-size: var(--t-eyebrow); font-weight: 600; letter-spacing: 0.18em; text-transform: uppercase; color: var(--zinc-gold); }
:root[lang="he"] .zinc-visit__label { letter-spacing: 0; text-transform: none; }
.zinc-visit__val { margin: 0; color: var(--zinc-fg); line-height: 1.7; }
.zinc-visit__val a:hover { color: var(--zinc-gold); }

@media (prefers-reduced-motion: reduce) {
  .js .zinc-hero__eyebrow, .js .zinc-hero__title, .js .zinc-hero__lead,
  .js .zinc-hero__cta, .js .zinc-hero__scroll { animation: none; opacity: 1; transform: none; }
  .zinc-hero__scroll-line::after { animation: none; }
  .zinc-channel:hover { transform: none; }
}

/* =========================================================================
   PHOTOGRAPHIC ELEVATION (v0.4) - real imagery layer.
   Full-bleed photographic hero with slow Ken-Burns zoom + dark scrim;
   editorial photo frames; serif dish grid; parallax book-a-table band;
   ambiance strip. Logical properties only (RTL-safe). Builds on v0.3 tokens.
   ========================================================================= */

/* ---- Hero: photographic ------------------------------------------------- */
.zinc-hero--photo { background: var(--zinc-black); }
.zinc-hero__media { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.zinc-hero__img {
  position: absolute; inset: 0; inline-size: 100%; block-size: 100%;
  object-fit: cover; object-position: center;
  transform: scale(1.06);
  animation: zinc-kenburns 22s var(--ease-inout) forwards;
  will-change: transform;
}
@keyframes zinc-kenburns { to { transform: scale(1.0); } }
.zinc-hero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(120% 95% at 50% 38%, rgba(0,0,0,0.30) 0%, rgba(0,0,0,0.62) 62%, rgba(0,0,0,0.86) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.30) 30%, rgba(0,0,0,0.45) 70%, rgba(0,0,0,0.88) 100%);
}
.zinc-hero--photo .zinc-grain { z-index: 2; opacity: 0.06; }
.zinc-hero--photo .zinc-hero__frame { z-index: 3; }
.zinc-hero--photo .zinc-hero__inner { z-index: 4; }
.zinc-hero--photo .zinc-hero__scroll { z-index: 4; }
.zinc-hero--photo .zinc-hero__wordmark { text-shadow: 0 2px 24px rgba(0,0,0,0.6), 0 0 60px rgba(217,199,126,0.22); }
.zinc-hero--photo .zinc-hero__lead { color: var(--zinc-fg); text-shadow: 0 1px 12px rgba(0,0,0,0.7); }

@media (prefers-reduced-motion: reduce) {
  .zinc-hero__img { animation: none; transform: none; }
}

/* ---- Editorial photo frame (intro + visit) ------------------------------ */
.zinc-photo {
  position: relative; margin: 0; overflow: hidden; isolation: isolate;
  border: 1px solid var(--border);
  box-shadow: inset 0 0 0 1px rgba(232,224,168,0.05), 0 30px 60px -30px rgba(0,0,0,0.8);
  background: var(--zinc-card);
}
.zinc-photo__img {
  position: absolute; inset: 0; z-index: 0;
  inline-size: 100%; block-size: 100%; object-fit: cover; display: block;
  transition: transform var(--dur-slow) var(--ease-out);
}
.zinc-photo:hover .zinc-photo__img { transform: scale(1.04); }
.zinc-photo::after {
  content: ""; position: absolute; inset: var(--sp-3); z-index: 2; pointer-events: none;
  border: 1px solid rgba(232,224,168,0.18);
}
.zinc-photo::before {
  content: ""; position: absolute; inset-inline: 0; inset-block-end: 0; z-index: 1;
  block-size: 45%; pointer-events: none;
  background: linear-gradient(180deg, transparent, rgba(0,0,0,0.72));
}
.zinc-photo--tall { aspect-ratio: 4 / 5; min-block-size: 22rem; }
.zinc-photo--wide { aspect-ratio: 4 / 3; min-block-size: 18rem; }
.zinc-photo__cap {
  position: absolute; z-index: 3; inset-block-end: var(--sp-5); inset-inline: 0; text-align: center;
  font-size: var(--t-fine); font-weight: 600; letter-spacing: 0.22em; text-transform: uppercase; color: var(--zinc-gold);
}
:root[lang="he"] .zinc-photo__cap { letter-spacing: 0.06em; text-transform: none; }

/* ---- Signature dish grid ------------------------------------------------ */
.zinc-dishgrid {
  list-style: none; margin: 0; padding: 0;
  display: grid; gap: var(--sp-5); grid-template-columns: 1fr;
}
@media (min-width: 720px) { .zinc-dishgrid { grid-template-columns: repeat(3, 1fr); gap: var(--sp-6); } }
.zinc-dishcard { margin: 0; }
.zinc-dishcard__link { display: block; color: inherit; }
.zinc-dishcard__media {
  display: block; position: relative; overflow: hidden; aspect-ratio: 4 / 5;
  border: 1px solid var(--border); background: var(--zinc-card);
}
.zinc-dishcard__img {
  inline-size: 100%; block-size: 100%; object-fit: cover; display: block;
  transition: transform var(--dur-slow) var(--ease-out), filter var(--dur-mid) var(--ease-out);
  filter: saturate(0.96) brightness(0.94);
}
.zinc-dishcard__link:hover .zinc-dishcard__img { transform: scale(1.05); filter: saturate(1.02) brightness(1); }
.zinc-dishcard__media::after {
  content: ""; position: absolute; inset: 0; pointer-events: none;
  box-shadow: inset 0 0 0 1px rgba(232,224,168,0.06);
  background: linear-gradient(180deg, transparent 55%, rgba(0,0,0,0.5));
}
.zinc-dishcard__body { display: block; text-align: center; padding-block-start: var(--sp-4); }
.zinc-dishcard__title {
  display: block; font-family: var(--font-display); font-size: var(--t-h3);
  font-weight: 600; color: var(--zinc-gold);
  transition: color var(--dur-fast) var(--ease-out);
}
.zinc-dishcard__link:hover .zinc-dishcard__title { color: var(--zinc-gold-soft); }
.zinc-dishcard__rule {
  display: block; inline-size: 2rem; block-size: 2px; margin: var(--sp-3) auto 0;
  background: var(--zinc-gold-deep); transform: scaleX(0.6); transform-origin: center;
  transition: transform var(--dur-mid) var(--ease-out);
}
.zinc-dishcard__link:hover .zinc-dishcard__rule { transform: scaleX(1); }

/* ---- Parallax book-a-table band ---------------------------------------- */
.zinc-bookband {
  position: relative; overflow: hidden; isolation: isolate;
  padding-block: clamp(6rem, 16vw, 12rem); padding-inline: var(--gutter);
  background-color: var(--zinc-black);
  background-size: cover; background-position: center;
  background-repeat: no-repeat; background-attachment: fixed;
}
.zinc-bookband__scrim {
  position: absolute; inset: 0; z-index: 0; pointer-events: none;
  background:
    radial-gradient(130% 110% at 50% 45%, rgba(0,0,0,0.18) 0%, rgba(0,0,0,0.52) 62%, rgba(0,0,0,0.82) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.40), rgba(0,0,0,0.40));
}
.zinc-bookband__inner { position: relative; z-index: 1; }
.zinc-bookband__quote {
  font-family: var(--font-display); font-style: italic;
  font-size: clamp(1.7rem, 3.6vw, 2.8rem); line-height: 1.3; color: var(--zinc-fg);
  margin-block: var(--sp-5) 0; text-shadow: 0 1px 16px rgba(0,0,0,0.6);
}
.zinc-bookband__cta { margin-block-start: var(--sp-7); }
@media (max-width: 900px), (hover: none) {
  .zinc-bookband { background-attachment: scroll; }
}
@media (prefers-reduced-motion: reduce) {
  .zinc-bookband { background-attachment: scroll; }
}

/* ---- Ambiance strip grid ----------------------------------------------- */
.zinc-strip-grid {
  display: grid; gap: var(--sp-3); grid-template-columns: repeat(2, 1fr);
  grid-auto-rows: 1fr;
}
@media (min-width: 760px) {
  .zinc-strip-grid {
    grid-template-columns: repeat(4, 1fr);
    grid-template-rows: repeat(2, 1fr);
    block-size: clamp(22rem, 40vw, 34rem);
  }
  .zinc-strip-grid__tile--a { grid-column: 1; grid-row: 1 / span 2; }
  .zinc-strip-grid__tile--b { grid-column: 2 / span 2; grid-row: 1; }
  .zinc-strip-grid__tile--c { grid-column: 2; grid-row: 2; }
  .zinc-strip-grid__tile--d { grid-column: 3 / span 2; grid-row: 2; }
}
.zinc-strip-grid__tile {
  position: relative; overflow: hidden; min-block-size: 9rem;
  border: 1px solid var(--border); background: var(--zinc-card);
}
.zinc-strip-grid__img {
  inline-size: 100%; block-size: 100%; object-fit: cover; display: block;
  filter: brightness(0.9) saturate(0.96);
  transition: transform var(--dur-slow) var(--ease-out), filter var(--dur-mid) var(--ease-out);
}
.zinc-strip-grid:hover .zinc-strip-grid__img { filter: brightness(0.78) saturate(0.96); }
.zinc-strip-grid__tile:hover .zinc-strip-grid__img { transform: scale(1.05); filter: brightness(1) saturate(1.02); }
.zinc-strip-grid:focus-visible { outline: 2px solid var(--zinc-focus); outline-offset: 4px; }

@media (min-width: 880px) {
  .zinc-split .zinc-photo { max-block-size: 36rem; }
}

/* ---- Interior page hero (photographic banner) -------------------------- */
.zinc-pagehero {
  position: relative; overflow: hidden; isolation: isolate;
  min-block-size: clamp(26rem, 56vh, 40rem);
  display: grid; place-items: center; text-align: center;
  padding-block: calc(var(--header-h) + var(--sp-8)) var(--sp-8);
  padding-inline: var(--gutter);
  background: var(--zinc-black);
}
.zinc-pagehero__media { position: absolute; inset: 0; z-index: 0; overflow: hidden; }
.zinc-pagehero__img {
  position: absolute; inset: 0; inline-size: 100%; block-size: 100%;
  object-fit: cover; object-position: center;
  transform: scale(1.04);
  animation: zinc-kenburns 24s var(--ease-inout) forwards;
}
.zinc-pagehero__scrim {
  position: absolute; inset: 0; z-index: 1; pointer-events: none;
  background:
    radial-gradient(120% 100% at 50% 40%, rgba(0,0,0,0.32) 0%, rgba(0,0,0,0.62) 60%, rgba(0,0,0,0.88) 100%),
    linear-gradient(180deg, rgba(0,0,0,0.55) 0%, rgba(0,0,0,0.32) 40%, rgba(0,0,0,0.78) 100%);
}
.zinc-pagehero .zinc-grain { z-index: 2; opacity: 0.06; }
.zinc-pagehero__inner { position: relative; z-index: 3; }
.zinc-pagehero__title { color: var(--zinc-gold); margin-block: var(--sp-2) 0; text-shadow: 0 2px 22px rgba(0,0,0,0.6); }
.zinc-pagehero__lead { color: var(--zinc-fg); margin-block-start: var(--sp-5); text-shadow: 0 1px 12px rgba(0,0,0,0.7); }
@media (prefers-reduced-motion: reduce) {
  .zinc-pagehero__img { animation: none; transform: none; }
}

/* ---- Gallery: real images sit edge-to-edge in the existing tile grid ---- */
.zinc-gallery__tile { position: relative; background: var(--zinc-card); border: 1px solid var(--border); }
.zinc-gallery__tile img { filter: brightness(0.92) saturate(0.97); }
.zinc-gallery__tile:hover img { filter: brightness(1) saturate(1.02); }
.zinc-gallery__tile--tall img { aspect-ratio: 3 / 4; }
.zinc-gallery__tile--wide img { aspect-ratio: 4 / 3; }
