/* =============================================================================
   NAVA · single-file stylesheet
   tokens → reset → type → utilities → sections → motion → responsive
   ========================================================================== */

/* ---------- Tokens ------------------------------------------------------- */

:root {
  /* Brand */
  --leaf:        oklch(34%   0.04  152);
  --leaf-deep:   oklch(24%   0.035 152);
  --leaf-soft:   oklch(50%   0.04  150);
  --gold:        oklch(72%   0.10   75);
  --gold-deep:   oklch(58%   0.09   70);

  /* Canvas */
  --canvas:      oklch(95%   0.014  88);
  --canvas-warm: oklch(91%   0.022  82);
  --canvas-cool: oklch(98%   0.008  92);

  /* Ink */
  --ink:         oklch(20%   0.018 155);
  --ink-muted:   oklch(40%   0.022 155);
  --ink-whisper: oklch(60%   0.018 150);
  --cream:       oklch(95%   0.014  88);
  --cream-muted: oklch(78%   0.022  85);
  --cream-soft:  oklch(85%   0.018  85);

  /* Functional */
  --hairline:        oklch(82% 0.014 88);
  --hairline-leaf:   oklch(44% 0.04 150);
  --scrim:           oklch(20% 0.03 152 / 0.4);
  --scrim-deep:      oklch(20% 0.03 152 / 0.7);

  /* Type */
  --font-display-ltr: "EB Garamond", "Times New Roman", Georgia, serif;
  --font-display-he:  "Rubik", "Heebo", "Assistant", system-ui, sans-serif;
  --font-body-ltr:    "Manrope", system-ui, sans-serif;
  --font-body-he:     "Rubik", "Heebo", "Assistant", system-ui, sans-serif;

  --font-display: var(--font-display-he);
  --font-body:    var(--font-body-he);

  /* Modular scale (ratio 1.333), clamped fluid */
  --fs-xs:  0.75rem;
  --fs-sm:  0.875rem;
  --fs-base: 1rem;
  --fs-lg:  1.25rem;
  --fs-xl:  clamp(1.4rem,  1.1rem  + 1.2vw,  1.667rem);
  --fs-2xl: clamp(1.75rem, 1.35rem + 2vw,    2.222rem);
  --fs-3xl: clamp(2.25rem, 1.6rem  + 3vw,    2.963rem);
  --fs-4xl: clamp(2.75rem, 1.7rem  + 4.6vw,  3.95rem);
  --fs-5xl: clamp(3.4rem,  1.8rem  + 6.8vw,  5.265rem);
  --fs-6xl: clamp(4.2rem,  1.6rem  + 11vw,   7.02rem);

  /* Spacing (4px base) */
  --s-1:   4px;
  --s-2:   8px;
  --s-3:   12px;
  --s-4:   16px;
  --s-5:   24px;
  --s-6:   32px;
  --s-7:   48px;
  --s-8:   64px;
  --s-9:   96px;
  --s-10: 128px;
  --s-11: 160px;
  --s-12: 224px;

  /* Layout */
  --maxw-image: 1280px;
  --maxw-text:  720px;
  --maxw-tight: 640px;

  /* Motion */
  --ease-out-quart: cubic-bezier(0.25, 1, 0.5, 1);
  --motion-fast:   180ms;
  --motion-base:   320ms;
  --motion-slow:   540ms;
  --motion-deep:   820ms;

  /* Radii */
  --r-sharp: 0;
  --r-btn:   2px;
  --r-card:  3px;
}

html[lang="ru"], html[lang="en"] {
  --font-display: var(--font-display-ltr);
  --font-body:    var(--font-body-ltr);
}

/* ---------- Reset ------------------------------------------------------- */

*, *::before, *::after { box-sizing: border-box; }

html { -webkit-text-size-adjust: 100%; scroll-behavior: smooth; }

body, h1, h2, h3, h4, p, figure, blockquote, dl, dd, ol, ul, fieldset, legend {
  margin: 0; padding: 0;
}
ol, ul { list-style: none; }
fieldset { border: 0; }
legend  { display: block; }

img, svg, video {
  display: block;
  max-width: 100%;
  height: auto;
}
img {
  background-color: var(--leaf);
  color: transparent;
}

a { color: inherit; text-decoration: none; }
button { background: none; border: 0; padding: 0; font: inherit; color: inherit; cursor: pointer; }
button, input, textarea, select { font-family: inherit; }
input, textarea { background: transparent; color: inherit; border: 0; outline: 0; }

::selection {
  background: var(--leaf);
  color: var(--cream);
}

iframe { border: 0; display: block; max-width: 100%; }

[hidden] { display: none !important; }

/* ---------- Base ------------------------------------------------------- */

body {
  background: var(--canvas);
  color: var(--ink);
  font-family: var(--font-body);
  font-size: var(--fs-base);
  line-height: 1.65;
  font-feature-settings: "tnum" 1, "lnum" 1, "kern" 1;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
}

.skip {
  position: absolute;
  inset-block-start: -100px;
  inset-inline-start: var(--s-4);
  background: var(--ink);
  color: var(--cream);
  padding: var(--s-3) var(--s-5);
  font-size: var(--fs-sm);
  z-index: 100;
  transition: inset-block-start var(--motion-base) var(--ease-out-quart);
}
.skip:focus { inset-block-start: var(--s-4); }

:where(a, button, input, textarea, label, [tabindex]):focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 4px;
}

/* ---------- Typography utilities --------------------------------------- */

.display {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--ink);
  line-height: 1.05;
  text-wrap: balance;
}
.display em {
  font-style: italic;
  font-weight: 500;
  color: var(--gold-deep);
}
/* Hebrew has no italic tradition; faked oblique looks cosmetic. Use weight contrast. */
html[lang="he"] .display em,
html[lang="he"] .phil__title em,
html[lang="he"] .story__title em,
html[lang="he"] .cta-strip__head em,
html[lang="he"] .intro__head em {
  font-style: normal;
  font-weight: 700;
}
.display--md { font-size: var(--fs-3xl); }
.display--lg { font-size: var(--fs-4xl); }
.display--xl { font-size: var(--fs-5xl); }

.eyebrow {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  font-weight: 500;
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--gold-deep);
  margin-block-end: var(--s-5);
  display: inline-block;
}
.eyebrow--cream { color: var(--gold); }
html[lang="he"] .eyebrow {
  text-transform: none;
  letter-spacing: 0.05em;
  font-weight: 600;
}

.prose {
  max-width: 60ch;
  font-size: var(--fs-base);
  line-height: 1.7;
  color: var(--ink-muted);
}

.link {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--leaf);
  border-block-end: 1px solid currentColor;
  padding-block-end: 1px;
  transition: color var(--motion-fast) var(--ease-out-quart);
}
.link:hover { color: var(--leaf-deep); }

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--s-2);
  padding: 14px 30px;
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  border-radius: var(--r-btn);
  cursor: pointer;
  transition: background-color var(--motion-fast) var(--ease-out-quart),
              color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart);
  white-space: nowrap;
  text-transform: uppercase;
}
html[lang="he"] .btn { text-transform: none; letter-spacing: 0.04em; }

.btn--lg { padding: 18px 40px; font-size: var(--fs-base); }

.btn--leaf  { background: var(--leaf);  color: var(--cream); }
.btn--leaf:hover  { background: var(--leaf-deep); }
.btn--cream { background: var(--cream); color: var(--leaf-deep); }
.btn--cream:hover { background: var(--canvas-warm); }
.btn--ghost-cream {
  background: transparent;
  color: var(--cream);
  border: 1px solid color-mix(in oklch, var(--cream), transparent 50%);
}
.btn--ghost-cream:hover {
  border-color: var(--cream);
  background: color-mix(in oklch, var(--cream), transparent 90%);
}
.btn--gold {
  background: var(--gold);
  color: var(--leaf-deep);
}
.btn--gold:hover { background: var(--gold-deep); color: var(--cream); }

/* ---------- Header / Nav ----------------------------------------------- */

.nav {
  position: fixed;
  inset-block-start: 0;
  inset-inline: 0;
  z-index: 50;
  padding-block: var(--s-4);
  transition: background-color var(--motion-base) var(--ease-out-quart),
              padding-block var(--motion-base) var(--ease-out-quart),
              border-color var(--motion-base) var(--ease-out-quart);
  border-block-end: 1px solid transparent;
}
/* At very top of page: transparent over hero, cream text. */
.nav[data-state="top"] { color: var(--cream); }

/* Scrolled within hero: dark translucent scrim so cream nav lifts off the
   green column and the photo without colliding with the headline. */
.nav[data-state="hero"] {
  color: var(--cream);
  background: color-mix(in oklch, var(--leaf-deep), transparent 18%);
  backdrop-filter: saturate(140%) blur(10px);
  -webkit-backdrop-filter: saturate(140%) blur(10px);
  padding-block: var(--s-3);
  border-block-end-color: color-mix(in oklch, var(--cream), transparent 82%);
}

/* Past hero, on cream sections: light scrim, ink text. */
.nav[data-state="scrolled"] {
  background: color-mix(in oklch, var(--canvas), transparent 6%);
  padding-block: var(--s-3);
  border-block-end-color: var(--hairline);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}

.nav__inner {
  max-width: var(--maxw-image);
  margin-inline: auto;
  padding-inline: var(--s-5);
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: var(--s-6);
}

.nav__brand {
  display: inline-flex;
  align-items: baseline;
  gap: var(--s-2);
  font-family: var(--font-display-ltr);
  font-size: var(--fs-lg);
  letter-spacing: 0.18em;
  color: inherit;
}
.nav__brand-mark {
  font-style: italic;
  font-size: var(--fs-xl);
  font-weight: 500;
  letter-spacing: 0;
  line-height: 0.9;
  color: var(--gold);
}
.nav[data-state="scrolled"] .nav__brand-mark { color: var(--gold-deep); }

.nav__links {
  justify-self: center;
  display: flex;
  gap: var(--s-7);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: inherit;
  font-family: var(--font-body);
}
.nav__links a {
  position: relative;
  padding-block: 4px;
  letter-spacing: 0.04em;
  transition: color var(--motion-fast) var(--ease-out-quart);
}
.nav__links a:hover { color: var(--gold); }
.nav[data-state="scrolled"] .nav__links a:hover { color: var(--gold-deep); }

.nav__lang {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--fs-sm);
  letter-spacing: 0.06em;
}
.nav__lang-btn {
  font-family: var(--font-body);
  font-weight: 500;
  color: color-mix(in oklch, currentColor, transparent 40%);
  padding: 4px 6px;
  transition: color var(--motion-fast) var(--ease-out-quart);
}
.nav__lang-btn[aria-pressed="true"] { color: var(--gold); }
.nav[data-state="scrolled"] .nav__lang-btn[aria-pressed="true"] { color: var(--gold-deep); }
.nav__lang-btn:hover { color: var(--gold); }
.nav__lang-sep { opacity: 0.5; }

@media (max-width: 980px) {
  .nav__links { display: none; }
  .nav__inner { grid-template-columns: auto 1fr; }
  .nav__lang { justify-self: end; }
}

/* ---------- Hero entrance choreography ----------------------------------
   One orchestrated page-load sequence. ~2.5s end-to-end. Brand voice asks
   for slow, deliberate pacing; ambitious first-load motion is on-register.
   prefers-reduced-motion collapses to a 200ms opacity-only fade.
   --------------------------------------------------------------------- */

@keyframes heroPhotoDrape {
  from { clip-path: inset(0 0 0 100%); }
  to   { clip-path: inset(0 0 0 0); }
}
@keyframes heroFadeUp {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes heroFadeUpLarge {
  from { opacity: 0; transform: translateY(40px); }
  to   { opacity: 1; transform: translateY(0); }
}
@keyframes heroLineReveal {
  from { clip-path: inset(0 0 110% 0); transform: translateY(12px); }
  to   { clip-path: inset(0 0 0 0); transform: translateY(0); }
}
@keyframes heroPillSettle {
  from { opacity: 0; transform: scale(0.88); }
  to   { opacity: 1; transform: scale(1); }
}

.hero__col-media {
  animation: heroPhotoDrape 1200ms var(--ease-out-quart) 0ms backwards;
}
.hero__mark {
  animation: heroFadeUpLarge 1100ms var(--ease-out-quart) 600ms backwards;
}
.hero__loc {
  animation: heroFadeUp 600ms var(--ease-out-quart) 800ms backwards;
}
.hero__head-line {
  animation: heroLineReveal 900ms var(--ease-out-quart) 950ms backwards;
}
.hero__head-em {
  animation: heroLineReveal 900ms var(--ease-out-quart) 1100ms backwards;
}
.hero-svc-tag:nth-child(1) { animation: heroFadeUp 600ms var(--ease-out-quart) 1300ms backwards; }
.hero-svc-tag:nth-child(2) { animation: heroFadeUp 600ms var(--ease-out-quart) 1390ms backwards; }
.hero-svc-tag:nth-child(3) { animation: heroFadeUp 600ms var(--ease-out-quart) 1480ms backwards; }
.hero-svc-tag:nth-child(4) { animation: heroFadeUp 600ms var(--ease-out-quart) 1570ms backwards; }
.hero__pills .pill--solid {
  animation: heroPillSettle 700ms var(--ease-out-quart) 1500ms backwards;
}
.hero__pills .pill--primary {
  animation: heroPillSettle 700ms var(--ease-out-quart) 1620ms backwards;
}
.hero__scroll {
  animation: heroFadeUp 600ms var(--ease-out-quart) 1900ms backwards,
             scrollNudge 2.4s var(--ease-out-quart) 2500ms infinite;
}

@media (prefers-reduced-motion: reduce) {
  .hero__col-media,
  .hero__mark,
  .hero__loc,
  .hero__head-line,
  .hero__head-em,
  .hero-svc-tag:nth-child(n),
  .hero__pills .pill--solid,
  .hero__pills .pill--primary,
  .hero__scroll {
    animation: heroFadeUp 200ms var(--ease-out-quart) 0ms backwards !important;
    clip-path: none !important;
  }
}

/* ---------- Hero (split: text column LEFT, photo column RIGHT — physical) -- */

.hero {
  /* Hero height: 2/3 viewport, with a floor for short laptops.
     `--hero-h` is reused below so the photo column derives a width
     matching the image's native aspect ratio at this height — the
     image stays fully visible (no crop) and bleeds to the right edge.
     Capped at 60% so it never dominates very tall, narrow viewports. */
  --hero-h: max(540px, 100vh);
  --hero-photo-w: min(calc(var(--hero-h) * 1136 / 1385), 60%);
  position: relative;
  height: var(--hero-h);
  background: var(--leaf);
  color: var(--cream);
  overflow: hidden;
  isolation: isolate;
}
@supports (height: 100dvh) {
  .hero { --hero-h: max(540px, 100dvh); }
}

/* Photo column — physical RIGHT, width = hero height × image aspect ratio.
   Image native size is 1136 × 1385 (ratio ~0.82). Setting the column to
   that aspect at the current height means object-fit: cover does not crop. */
.hero__col-media {
  position: absolute;
  inset-block: 0;
  right: 0;
  width: var(--hero-photo-w);
  margin: 0;
  overflow: hidden;
  background: var(--leaf-deep);
}
.hero__col-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center;
  display: block;
}

/* Text column — anchored at the photo seam (physical right edge), capped width.
   On wide viewports the green floods to the outer edge as brand bleed; the
   content does not stretch with the viewport. */
.hero__col-text {
  position: absolute;
  inset-block: 0;
  right: var(--hero-photo-w);
  width: min(720px, calc(100% - var(--hero-photo-w)));
  padding: clamp(88px, 10vh, 116px) clamp(32px, 4vw, 72px) clamp(20px, 3vh, 40px);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  z-index: 2;
  overflow: hidden;
}
.hero__col-text > * { position: relative; z-index: 1; }

/* Brand letter as a giant fond mark — typographic identity at scale.
   Sits behind the headline, low contrast so it reads as material, not slogan. */
.hero__mark {
  position: absolute;
  inset-block-end: -12%;
  left: -3%;            /* physical left always — same corner regardless of language */
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-weight: 500;
  font-size: clamp(280px, 56vh, 560px);
  line-height: 0.78;
  color: var(--leaf-deep);
  z-index: 0;
  pointer-events: none;
  user-select: none;
}

.hero__col-inner {
  display: grid;
  gap: clamp(20px, 2.4vh, 32px);
  max-width: 36rem;
  /* Push to physical right within the text column, hugging the photo seam.
     In LTR (Russian), this pulls content toward the photo so reading flows
     into the image. In RTL (Hebrew), it confirms the natural inline-start
     placement; the rightmost letter (reading start) sits at the seam. */
  margin-left: auto;
}

/* ---- Hero copy ---- */

.hero__loc {
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  letter-spacing: 0.22em;
  text-transform: uppercase;
  color: var(--cream);
  font-weight: 500;
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
}
html[lang="he"] .hero__loc { text-transform: none; letter-spacing: 0.04em; font-weight: 500; }
.hero__loc-sep { opacity: 0.4; font-weight: 400; }

.hero__head {
  font-family: var(--font-display);
  font-size: clamp(3rem, 1.6rem + 6.5vw, 7.2rem);
  font-weight: 500;
  line-height: 0.92;
  letter-spacing: -0.025em;
  color: var(--cream);
  max-width: 14ch;
  text-wrap: balance;
}
html[lang="he"] .hero__head { line-height: 0.98; font-weight: 500; letter-spacing: -0.015em; }
.hero__head-line { display: block; }
.hero__head-em {
  display: block;
  font-style: italic;
  font-weight: 500;
  margin-block-start: 0.04em;
  color: var(--gold);
}
/* Hebrew has no italic tradition; Rubik's italic is a synthesized oblique.
   Use weight contrast (700 vs 500) plus the gold color instead. */
html[lang="he"] .hero__head-em {
  font-style: normal;
  font-weight: 700;
}

/* ---- Service mini-tags row (4 across) ---- */

.hero__svc {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-2);
  margin-block-start: var(--s-3);
}
.hero-svc-tag a {
  display: grid;
  grid-template-columns: 1fr auto;
  grid-template-rows: auto auto;
  align-items: start;
  column-gap: var(--s-2);
  padding-block: var(--s-3);
  padding-inline-start: var(--s-4);
  padding-inline-end: var(--s-3);
  border-inline-start: 1px solid color-mix(in oklch, var(--cream), transparent 70%);
  font-family: var(--font-body);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--cream);
  line-height: 1.3;
  transition: color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart);
}
html[lang="he"] .hero-svc-tag a {
  text-transform: none;
  letter-spacing: 0.02em;
  font-weight: 500;
}
.hero-svc-tag a:hover {
  color: var(--gold);
  border-inline-start-color: var(--gold);
}
.hero-svc-tag__name { grid-column: 1; grid-row: 1; }
.hero-svc-tag__sub  { grid-column: 1; grid-row: 2; opacity: 0.85; }
.hero-svc-tag__plus {
  grid-column: 2;
  grid-row: 1 / span 2;
  align-self: center;
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-size: var(--fs-base);
  font-weight: 400;
  color: var(--gold);
  letter-spacing: 0;
  opacity: 0.8;
}

/* ---- Round CTA pills (3 circles) ---- */

.hero__pills {
  display: flex;
  align-items: center;
  gap: clamp(12px, 1.5vw, 24px);
  margin-block-start: var(--s-4);
}
.pill {
  display: inline-flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  font-family: var(--font-body);
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: background-color var(--motion-fast) var(--ease-out-quart),
              color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart),
              transform var(--motion-fast) var(--ease-out-quart);
  flex-shrink: 0;
}
html[lang="he"] .pill { font-weight: 500; }
.pill span { display: block; }

/* Primary CTA pill — dominantly larger to read as the singular action.
   Asymmetric scale jump is the bold move; secondary is ~70% of primary. */
.pill--primary {
  width: clamp(132px, 11vw, 168px);
  height: clamp(132px, 11vw, 168px);
  background: var(--gold);
  color: var(--leaf-deep);
  font-size: var(--fs-base);
  letter-spacing: 0.04em;
  line-height: 1.1;
  box-shadow: 0 1px 0 0 color-mix(in oklch, var(--leaf-deep), transparent 50%);
}
html[lang="he"] .pill--primary { letter-spacing: 0; }
.pill--primary:hover {
  background: var(--cream);
  color: var(--leaf-deep);
  transform: translateY(-3px);
}

.pill--solid {
  width: clamp(96px, 8vw, 116px);
  height: clamp(96px, 8vw, 116px);
  background: var(--cream);
  color: var(--leaf-deep);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  line-height: 1.2;
  padding: 4px;
}
html[lang="he"] .pill--solid { letter-spacing: 0; }
.pill--solid:hover { background: var(--gold); transform: translateY(-2px); }


/* ---- Scroll indicator at bottom ---- */

.hero__scroll {
  display: flex;
  align-self: center;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border: 1px solid color-mix(in oklch, var(--cream), transparent 65%);
  border-radius: 50%;
  color: var(--cream);
  margin-block-start: var(--s-4);
  transition: color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart),
              transform var(--motion-base) var(--ease-out-quart);
  /* nudge animation is composed with the hero entrance, see Hero entrance choreography */
}
.hero__scroll:hover {
  color: var(--gold);
  border-color: var(--gold);
}
@keyframes scrollNudge {
  0%, 100% { transform: translateY(0); }
  50%      { transform: translateY(6px); }
}

/* ---------- Hero responsive: stack on mobile, photo on top --------------- */

@media (max-width: 860px) {
  .hero {
    height: auto;
    min-height: 100vh;
    display: grid;
    grid-template-rows: auto auto;
    grid-template-columns: 1fr;
  }
  .hero__col-text,
  .hero__col-media {
    position: static;
    inset: auto;
    width: 100%;
  }
  .hero__col-media {
    aspect-ratio: 4 / 5;
    max-height: 65vh;
    order: 1;
  }
  .hero__col-text {
    order: 2;
    padding: var(--s-7) var(--s-5) var(--s-5);
    min-height: 0;
    gap: var(--s-5);
  }
  .hero__col-inner { gap: var(--s-3); max-width: 100%; }
  .hero__head { font-size: clamp(2.4rem, 1.4rem + 5.5vw, 3.6rem); max-width: 14ch; line-height: 0.96; }
  .hero__svc { grid-template-columns: repeat(2, 1fr); gap: var(--s-2); }
  .hero__pills { justify-content: flex-start; flex-wrap: wrap; gap: var(--s-3); }
  .pill--primary { width: 110px; height: 110px; font-size: var(--fs-sm); }
  .pill--solid   { width: 86px;  height: 86px;  font-size: var(--fs-xs); }
  .hero__scroll { display: none; }
  .hero__mark {
    font-size: clamp(220px, 50vw, 320px);
    inset-block-end: -8%;
    opacity: 0.7;
  }
}

/* ---------- Intro (centered, ornament) -------------------------------- */

.intro {
  background: var(--canvas);
  padding-block: clamp(96px, 14vw, 200px);
  padding-inline: var(--s-5);
}
.intro__inner {
  max-width: var(--maxw-tight);
  margin-inline: auto;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-4);
}
.ornament {
  display: inline-block;
  color: var(--gold-deep);
  width: 80px;
  margin-block-end: var(--s-4);
}
.ornament svg { width: 100%; height: auto; }

.intro__head {
  font-family: var(--font-display);
  font-size: var(--fs-4xl);
  font-weight: 400;
  line-height: 1.1;
  letter-spacing: -0.012em;
  color: var(--ink);
  max-width: 18ch;
  text-wrap: balance;
}
.intro__head em {
  font-style: italic;
  font-weight: 500;
  color: var(--gold-deep);
  display: inline-block;
  padding-inline: 0.18em;
}

.intro__body {
  font-size: var(--fs-lg);
  line-height: 1.55;
  color: var(--ink-muted);
  max-width: 52ch;
  margin-block-start: var(--s-3);
}
.intro__body--small {
  font-size: var(--fs-base);
  color: var(--ink-whisper);
  max-width: 48ch;
  margin-block-start: var(--s-2);
}

/* ---------- Philosophy (flooded, list + photo) ------------------------ */

.phil {
  background: var(--leaf);
  color: var(--cream);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
}
.phil__inner {
  max-width: var(--maxw-image);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1.05fr 0.95fr;
  gap: clamp(40px, 6vw, 96px);
  align-items: center;
}

.phil__title {
  color: var(--cream);
  margin-block-end: var(--s-7);
  max-width: 18ch;
}
.phil__title em { color: var(--gold); }

.phil__list {
  display: grid;
  gap: var(--s-5);
  counter-reset: phil;
}
.phil__item {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: var(--s-4);
  padding-block: var(--s-4);
  border-block-start: 1px solid color-mix(in oklch, var(--cream), transparent 80%);
  align-items: baseline;
}
.phil__item:last-child {
  border-block-end: 1px solid color-mix(in oklch, var(--cream), transparent 80%);
}
.phil__num {
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-size: var(--fs-xl);
  font-weight: 500;
  color: var(--gold);
  letter-spacing: 0.04em;
  min-width: 40px;
  line-height: 1;
}
.phil__item h3 {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--cream);
  margin-block-end: var(--s-2);
}
.phil__item p {
  font-size: var(--fs-base);
  line-height: 1.55;
  color: color-mix(in oklch, var(--cream), transparent 25%);
  max-width: 50ch;
}

.phil__col-media {
  position: relative;
  aspect-ratio: 4 / 5;
  overflow: hidden;
}
.phil__col-media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.75);
}

@media (max-width: 860px) {
  .phil__inner { grid-template-columns: 1fr; gap: var(--s-7); }
  .phil__col-media { aspect-ratio: 3 / 2; max-height: 480px; }
}

/* ---------- Services (cards grid) ------------------------------------- */

.srv {
  background: var(--canvas);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
}
.srv__head {
  max-width: var(--maxw-image);
  margin-inline: auto;
  margin-block-end: var(--s-9);
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-3);
}
.srv__head .display {
  max-width: 22ch;
  text-wrap: balance;
}
.srv__head .display em { display: inline-block; padding-inline-start: 0.2em; }
.srv__lead {
  max-width: 52ch;
  font-size: var(--fs-base);
  color: var(--ink-muted);
  line-height: 1.6;
}

.srv__grid {
  max-width: var(--maxw-image);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: var(--s-5);
}

.srv-card {
  background: var(--canvas-cool);
  display: grid;
  grid-template-rows: auto 1fr;
  transition: background-color var(--motion-base) var(--ease-out-quart),
              transform var(--motion-base) var(--ease-out-quart);
}
.srv-card:hover { background: var(--cream); transform: translateY(-3px); }
.srv-card__media {
  aspect-ratio: 4 / 3;
  overflow: hidden;
  background: var(--leaf);
}
.srv-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.8);
  transition: transform var(--motion-deep) var(--ease-out-quart);
}
.srv-card:hover .srv-card__media img { transform: scale(1.04); }

.srv-card__body {
  padding: var(--s-5) var(--s-5) var(--s-5);
  display: grid;
  gap: var(--s-3);
  align-content: start;
}
.srv-card__num {
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-weight: 500;
  font-size: var(--fs-base);
  color: var(--gold-deep);
  letter-spacing: 0.04em;
}
.srv-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--ink);
  line-height: 1.15;
}
.srv-card__desc {
  font-size: var(--fs-sm);
  line-height: 1.6;
  color: var(--ink-muted);
  flex: 1;
}
.srv-card__foot {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: var(--s-3);
  margin-block-start: var(--s-3);
  padding-block-start: var(--s-3);
  border-block-start: 1px solid var(--hairline);
}
.srv-card__price {
  font-family: var(--font-display-ltr);
  font-size: var(--fs-xl);
  font-weight: 500;
  color: var(--ink);
  font-feature-settings: "tnum" 1, "lnum" 1;
}
.srv-card__from {
  font-family: var(--font-body);
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  color: var(--ink-whisper);
  margin-inline-end: 4px;
}

@media (max-width: 1100px) {
  .srv__grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 560px) {
  .srv__grid { grid-template-columns: 1fr; }
}

/* ---------- Story (flooded photo + text) ------------------------------ */

.story {
  background: var(--leaf-deep);
  color: var(--cream);
  padding-block: 0;
  overflow: hidden;
}
.story__inner {
  max-width: 1480px;
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  align-items: stretch;
  min-height: 600px;
}
.story__media {
  position: relative;
  overflow: hidden;
  background: var(--leaf);
}
.story__media img {
  width: 100%;
  height: 100%;
  min-height: 480px;
  object-fit: cover;
  filter: saturate(0.7);
}
.story__text {
  padding: clamp(64px, 6vw, 120px) clamp(40px, 5vw, 96px);
  display: grid;
  align-content: center;
  gap: var(--s-4);
  max-width: 56ch;
}
.story__title {
  color: var(--cream);
  margin-block-end: var(--s-4);
  max-width: 22ch;
}
.story__title em { color: var(--gold); }
.story__body {
  font-size: var(--fs-base);
  line-height: 1.7;
  color: color-mix(in oklch, var(--cream), transparent 22%);
}
.story__sign {
  margin-block-start: var(--s-5);
  padding-block-start: var(--s-4);
  border-block-start: 1px solid color-mix(in oklch, var(--cream), transparent 78%);
  font-size: var(--fs-sm);
  letter-spacing: 0.04em;
  color: var(--gold);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  align-items: baseline;
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-weight: 500;
}
.story__sign-sep { opacity: 0.5; font-style: normal; }

@media (max-width: 860px) {
  .story__inner { grid-template-columns: 1fr; min-height: 0; }
  .story__media img { min-height: 360px; }
}

/* ---------- Booking + Gift -------------------------------------------- */

.book {
  background: var(--canvas);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
}
.book__head {
  max-width: var(--maxw-image);
  margin-inline: auto;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-3);
  margin-block-end: var(--s-9);
}
.book__head .display em { display: inline-block; padding-inline-start: 0.2em; }

.book__shell {
  max-width: var(--maxw-image);
  margin-inline: auto;
  background: var(--canvas-cool);
  padding: clamp(32px, 4vw, 64px);
  display: grid;
  gap: var(--s-7);
}

.book__tabs {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  border-block-end: 1px solid var(--hairline);
  margin-block-end: 0;
  align-self: start;
}
.book__tab {
  position: relative;
  padding: var(--s-3) var(--s-5);
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--ink-muted);
  font-family: var(--font-body);
  transition: color var(--motion-fast) var(--ease-out-quart);
}
html[lang="he"] .book__tab { text-transform: none; letter-spacing: 0.04em; }
.book__tab:hover { color: var(--ink); }
.book__tab[aria-selected="true"] { color: var(--leaf); }
.book__tab[aria-selected="true"]::after {
  content: "";
  position: absolute;
  inset-block-end: -1px;
  inset-inline: var(--s-5);
  height: 2px;
  background: var(--gold);
}

.book__panel { display: none; }
.book__panel[data-active="true"] { display: block; }

.book__steps {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
  max-width: 720px;
  margin-block-end: var(--s-7);
}
.book__step {
  display: grid;
  grid-template-columns: auto 1fr;
  align-items: baseline;
  gap: var(--s-3);
  padding-block-end: var(--s-3);
  border-block-end: 1px solid var(--hairline);
  color: var(--ink-whisper);
  transition: color var(--motion-base) var(--ease-out-quart),
              border-color var(--motion-base) var(--ease-out-quart);
}
.book__step span {
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-size: var(--fs-lg);
  font-weight: 500;
}
.book__step b {
  font-size: var(--fs-sm);
  font-weight: 500;
  letter-spacing: 0.04em;
}
.book__step.is-active { color: var(--leaf); border-color: var(--gold); }
.book__step.is-active span { color: var(--gold-deep); }
.book__step.is-done   { color: var(--ink-muted); border-color: var(--ink-muted); }

.book__pane {
  display: none;
  margin: 0;
}
.book__pane.is-active { display: block; animation: fadeIn var(--motion-base) var(--ease-out-quart); }
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(6px); }
  to   { opacity: 1; transform: none; }
}

.book__legend {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--ink);
  margin-block-end: var(--s-6);
}

.book__field { margin-block-end: var(--s-7); }
.book__label {
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-muted);
  margin-block-end: var(--s-3);
  font-weight: 500;
  font-family: var(--font-body);
}
html[lang="he"] .book__label { text-transform: none; letter-spacing: 0.05em; }

.book__radios {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: var(--s-3);
  margin-block-end: var(--s-7);
}
.book__radio {
  position: relative;
  display: grid;
  gap: 4px;
  padding: var(--s-5);
  background: var(--canvas);
  cursor: pointer;
  outline: 1px solid var(--hairline);
  outline-offset: -1px;
  transition: background-color var(--motion-fast) var(--ease-out-quart),
              outline-color var(--motion-fast) var(--ease-out-quart);
}
.book__radio:hover { outline-color: var(--ink-whisper); }
.book__radio:has(input:checked) {
  background: color-mix(in oklch, var(--canvas), var(--gold) 12%);
  outline-color: var(--gold-deep);
}
.book__radio input { position: absolute; opacity: 0; pointer-events: none; }
.book__radio-name {
  font-family: var(--font-display);
  font-size: var(--fs-xl);
  font-weight: 400;
  color: var(--ink);
}
.book__radio-desc { font-size: var(--fs-sm); color: var(--ink-muted); }

@media (max-width: 720px) {
  .book__radios { grid-template-columns: 1fr; }
}

/* Chips */
.book__chips { display: flex; flex-wrap: wrap; gap: var(--s-2); }
.book__chip { position: relative; cursor: pointer; }
.book__chip input { position: absolute; opacity: 0; pointer-events: none; }
.book__chip span {
  display: inline-flex;
  align-items: baseline;
  gap: 4px;
  padding: 10px 18px;
  border: 1px solid var(--hairline);
  font-size: var(--fs-sm);
  font-weight: 500;
  background: var(--canvas);
  color: var(--ink-muted);
  transition: background-color var(--motion-fast) var(--ease-out-quart),
              color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart);
}
.book__chip span i {
  font-style: normal;
  font-size: var(--fs-xs);
  opacity: 0.75;
  letter-spacing: 0.04em;
}
.book__chip:hover span { color: var(--ink); border-color: var(--ink-whisper); }
.book__chip:has(input:checked) span {
  background: var(--leaf);
  color: var(--cream);
  border-color: var(--leaf);
}

/* Therapists */
.book__therapists {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-3);
}
.book__therapist {
  position: relative;
  display: grid;
  gap: 4px;
  padding: var(--s-4) var(--s-5);
  background: var(--canvas);
  outline: 1px solid var(--hairline);
  outline-offset: -1px;
  cursor: pointer;
  transition: outline-color var(--motion-fast) var(--ease-out-quart),
              background-color var(--motion-fast) var(--ease-out-quart);
}
.book__therapist input { position: absolute; opacity: 0; pointer-events: none; }
.book__therapist-name {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-weight: 400;
  color: var(--ink);
}
.book__therapist-tag { font-size: var(--fs-xs); letter-spacing: 0.06em; color: var(--ink-muted); }
.book__therapist:hover { outline-color: var(--ink-whisper); }
.book__therapist:has(input:checked) {
  outline-color: var(--gold-deep);
  background: color-mix(in oklch, var(--canvas), var(--gold) 12%);
}
@media (max-width: 720px) {
  .book__therapists { grid-template-columns: 1fr; }
}

/* Calendar */
.book__cal {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: var(--s-2);
  margin-block-end: var(--s-6);
}
.book__day {
  position: relative;
  cursor: pointer;
  padding: var(--s-4) var(--s-2);
  background: var(--canvas);
  text-align: center;
  outline: 1px solid var(--hairline);
  outline-offset: -1px;
  transition: outline-color var(--motion-fast) var(--ease-out-quart),
              background-color var(--motion-fast) var(--ease-out-quart);
}
.book__day input { position: absolute; opacity: 0; pointer-events: none; }
.book__day-dow {
  display: block;
  font-size: var(--fs-xs);
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-muted);
}
html[lang="he"] .book__day-dow { text-transform: none; letter-spacing: 0.04em; }
.book__day-num {
  display: block;
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-size: var(--fs-xl);
  font-weight: 500;
  margin-block-start: 2px;
  color: var(--ink);
  font-feature-settings: "tnum" 1;
}
.book__day-mon {
  display: block;
  font-size: var(--fs-xs);
  letter-spacing: 0.05em;
  color: var(--ink-whisper);
  margin-block-start: 2px;
}
.book__day:hover { outline-color: var(--ink-whisper); }
.book__day:has(input:checked) {
  outline-color: var(--gold-deep);
  background: color-mix(in oklch, var(--canvas), var(--gold) 14%);
}
.book__day[data-disabled="true"] { opacity: 0.4; pointer-events: none; }

@media (max-width: 720px) {
  .book__cal { grid-template-columns: repeat(7, minmax(58px, 1fr)); overflow-x: auto; padding-block-end: var(--s-2); }
}

/* Slots */
.book__slots {
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  min-height: 60px;
  margin-block-end: var(--s-7);
}
.book__slots-empty { font-size: var(--fs-sm); color: var(--ink-whisper); font-style: italic; }
.book__slot { position: relative; cursor: pointer; font-feature-settings: "tnum" 1; }
.book__slot input { position: absolute; opacity: 0; pointer-events: none; }
.book__slot span {
  display: inline-flex;
  align-items: center;
  padding: 10px 16px;
  border: 1px solid var(--hairline);
  font-size: var(--fs-sm);
  font-weight: 500;
  color: var(--ink-muted);
  background: var(--canvas);
  transition: background-color var(--motion-fast) var(--ease-out-quart),
              color var(--motion-fast) var(--ease-out-quart),
              border-color var(--motion-fast) var(--ease-out-quart);
}
.book__slot:hover span { color: var(--ink); border-color: var(--ink-whisper); }
.book__slot:has(input:checked) span {
  background: var(--leaf);
  color: var(--cream);
  border-color: var(--leaf);
}

.book__nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-block-start: var(--s-7);
  gap: var(--s-3);
}
.book__nav .link { font-size: var(--fs-sm); color: var(--ink-muted); border-block-end-color: var(--ink-whisper); }
.book__nav .link:hover { color: var(--ink); border-block-end-color: var(--ink); }

.book__error {
  margin-block-start: var(--s-3);
  font-size: var(--fs-sm);
  color: var(--gold-deep);
  font-weight: 500;
}

.book__success {
  padding: var(--s-9) 0 var(--s-6);
  max-width: 56ch;
  display: grid;
  gap: var(--s-4);
}
.book__success .display { color: var(--ink); }
.book__success-id {
  margin-block-start: var(--s-5);
  font-size: var(--fs-base);
  color: var(--ink-muted);
}
.book__success-id b {
  font-family: var(--font-display-ltr);
  font-style: italic;
  color: var(--gold-deep);
  font-size: var(--fs-xl);
  margin-inline-start: var(--s-2);
  letter-spacing: 0.04em;
}
.book__success-recap {
  font-size: var(--fs-sm);
  color: var(--ink-muted);
  background: var(--canvas);
  padding: var(--s-4) var(--s-5);
  margin-block-start: var(--s-3);
  line-height: 1.6;
}

/* ---------- Gift ------------------------------------------------------- */

.gift {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--s-9);
  align-items: start;
}
.gift__form { display: grid; gap: var(--s-6); }
.gift__field { display: grid; gap: var(--s-3); }
.gift__amounts { gap: var(--s-2); }
.gift__custom {
  background: var(--canvas);
  border: 1px solid var(--hairline);
  padding: 12px 14px;
  font-size: var(--fs-base);
  font-feature-settings: "tnum" 1;
  margin-block-start: var(--s-2);
  width: 14ch;
  transition: border-color var(--motion-fast) var(--ease-out-quart);
}
.gift__custom:focus { border-color: var(--gold); outline: none; }

.gift__field input[type="text"], .gift__field textarea {
  background: var(--canvas);
  border: 1px solid var(--hairline);
  padding: 12px 14px;
  font-size: var(--fs-base);
  width: 100%;
  resize: vertical;
  transition: border-color var(--motion-fast) var(--ease-out-quart);
}
.gift__field input[type="text"]::placeholder,
.gift__field textarea::placeholder { color: var(--ink-whisper); }
.gift__field input[type="text"]:focus,
.gift__field textarea:focus { border-color: var(--gold); outline: none; }

.gift__nav { display: grid; gap: var(--s-3); margin-block-start: var(--s-3); }
.gift__nav .btn { justify-self: start; }
.gift__note {
  font-size: var(--fs-xs);
  color: var(--ink-whisper);
  letter-spacing: 0.04em;
  max-width: 38ch;
}

/* Gift card preview */
.gift__preview { position: sticky; inset-block-start: var(--s-9); }
.gift-card {
  background: var(--leaf-deep);
  color: var(--cream);
  padding: var(--s-7);
  aspect-ratio: 5 / 3;
  display: grid;
  grid-template-rows: auto 1fr auto;
  position: relative;
  overflow: hidden;
}
.gift-card::before {
  content: "";
  position: absolute;
  inset: var(--s-3);
  border: 1px solid color-mix(in oklch, var(--gold), transparent 55%);
  pointer-events: none;
}
.gift-card__head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--cream), transparent 30%);
  position: relative;
}
.gift-card__brand {
  font-family: var(--font-display-ltr);
  font-style: italic;
  font-size: var(--fs-xl);
  letter-spacing: 0;
  text-transform: none;
  color: var(--gold);
  font-weight: 500;
}
.gift-card__no { font-feature-settings: "tnum" 1; font-family: var(--font-body-ltr); }
.gift-card__body { display: grid; align-content: center; position: relative; }
.gift-card__line {
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: color-mix(in oklch, var(--cream), transparent 35%);
  margin-block-start: var(--s-3);
}
html[lang="he"] .gift-card__line { text-transform: none; letter-spacing: 0.04em; font-weight: 500; }
.gift-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-style: italic;
  font-weight: 500;
  color: var(--cream);
  margin-block-start: 4px;
  line-height: 1.1;
}
.gift-card__amt {
  font-family: var(--font-display-ltr);
  font-size: var(--fs-4xl);
  font-weight: 400;
  color: var(--gold);
  margin-block-start: 4px;
  font-feature-settings: "tnum" 1, "lnum" 1;
}
.gift-card__msg {
  margin-block-start: var(--s-4);
  font-style: italic;
  font-size: var(--fs-sm);
  color: color-mix(in oklch, var(--cream), transparent 18%);
  max-width: 30ch;
  line-height: 1.5;
}
.gift-card__foot {
  display: flex;
  justify-content: space-between;
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  color: color-mix(in oklch, var(--cream), transparent 35%);
  position: relative;
  gap: var(--s-3);
}
.gift-card__seal {
  position: absolute;
  inset-inline-end: var(--s-7);
  inset-block-end: 70px;
  width: 60px;
  color: var(--gold);
  opacity: 0.6;
  pointer-events: none;
}
.gift-card__seal svg { width: 100%; height: auto; }

.gift__success { padding: var(--s-9) 0; max-width: 56ch; display: grid; gap: var(--s-4); grid-column: 1 / -1; }

@media (max-width: 860px) {
  .gift { grid-template-columns: 1fr; gap: var(--s-7); }
  .gift__preview { position: static; }
}
.gift[data-state="success"] .gift__form,
.gift[data-state="success"] .gift__preview { display: none; }

/* ---------- Practitioners --------------------------------------------- */

.prac {
  background: var(--canvas);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
}
.prac__head {
  max-width: var(--maxw-image);
  margin-inline: auto;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-3);
  margin-block-end: var(--s-9);
}
.prac__head .display em { display: inline-block; padding-inline-start: 0.2em; }

.prac__list {
  max-width: var(--maxw-image);
  margin-inline: auto;
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--s-7);
}
.prac-card {
  display: grid;
  gap: var(--s-3);
  text-align: start;
}
.prac-card__media {
  aspect-ratio: 4 / 5;
  overflow: hidden;
  background: var(--leaf);
  margin-block-end: var(--s-3);
}
.prac-card__media img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.8);
  transition: transform var(--motion-deep) var(--ease-out-quart);
}
.prac-card:hover .prac-card__media img { transform: scale(1.025); }
.prac-card__role {
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold-deep);
  font-weight: 500;
  font-family: var(--font-body);
}
html[lang="he"] .prac-card__role { text-transform: none; letter-spacing: 0.04em; }
.prac-card__name {
  font-family: var(--font-display);
  font-size: var(--fs-2xl);
  font-weight: 400;
  letter-spacing: -0.012em;
  color: var(--ink);
  line-height: 1.1;
}
.prac-card__bio {
  font-size: var(--fs-base);
  line-height: 1.6;
  color: var(--ink-muted);
  max-width: 38ch;
}
.prac-card__lang {
  margin-block-start: var(--s-3);
  font-size: var(--fs-xs);
  letter-spacing: 0.06em;
  color: var(--ink-whisper);
  padding-block-start: var(--s-3);
  border-block-start: 1px solid var(--hairline);
}

@media (max-width: 980px) { .prac__list { grid-template-columns: repeat(2, 1fr); gap: var(--s-7) var(--s-5); } }
@media (max-width: 600px) { .prac__list { grid-template-columns: 1fr; gap: var(--s-8); } }

/* ---------- Reviews (2-col hairline grid) ----------------------------- */

.rev {
  background: var(--canvas-warm);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
}
.rev__head {
  max-width: var(--maxw-image);
  margin-inline: auto;
  text-align: center;
  display: grid;
  justify-items: center;
  gap: var(--s-3);
  margin-block-end: var(--s-9);
}
.rev__head .display em { display: inline-block; padding-inline-start: 0.2em; }

.rev__grid {
  max-width: var(--maxw-image);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0;
  border-block-start: 1px solid var(--hairline);
}
.rev-card {
  padding: var(--s-7) var(--s-6);
  border-block-end: 1px solid var(--hairline);
  border-inline-start: 1px solid transparent;
  position: relative;
}
.rev-card:nth-child(2n) { border-inline-start-color: var(--hairline); }

.rev-card__body {
  font-family: var(--font-display);
  font-size: var(--fs-lg);
  font-style: italic;
  font-weight: 400;
  line-height: 1.4;
  color: var(--ink);
  max-width: 36ch;
  margin-block-end: var(--s-5);
}
.rev-card__cite {
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--ink-whisper);
  display: flex;
  flex-wrap: wrap;
  gap: var(--s-2);
  font-family: var(--font-body);
}
html[lang="he"] .rev-card__cite { text-transform: none; letter-spacing: 0.04em; font-weight: 500; }
.rev-card__cite span:first-child { color: var(--gold-deep); font-weight: 600; letter-spacing: 0.06em; }
.rev-card__sep { opacity: 0.5; }

@media (max-width: 720px) {
  .rev__grid { grid-template-columns: 1fr; }
  .rev-card:nth-child(2n) { border-inline-start-color: transparent; }
}

/* ---------- CTA strip (flooded) --------------------------------------- */

.cta-strip {
  background: var(--leaf-deep);
  color: var(--cream);
  padding-block: clamp(96px, 12vw, 160px);
  padding-inline: var(--s-5);
  text-align: center;
}
.cta-strip__inner {
  max-width: var(--maxw-tight);
  margin-inline: auto;
  display: grid;
  justify-items: center;
  gap: var(--s-4);
}
.cta-strip__head {
  font-family: var(--font-display);
  font-size: var(--fs-5xl);
  font-weight: 400;
  line-height: 1.05;
  letter-spacing: -0.012em;
  color: var(--cream);
  max-width: 16ch;
}
.cta-strip__head em {
  font-style: italic;
  font-weight: 500;
  color: var(--gold);
  border-block-end: 2px solid var(--gold);
  padding-block-end: 0.05em;
  margin-inline-start: 0.2em;
  display: inline-block;
}
.cta-strip__sub {
  font-size: var(--fs-lg);
  color: color-mix(in oklch, var(--cream), transparent 25%);
  margin-block-end: var(--s-3);
  max-width: 42ch;
}

/* ---------- Footer ---------------------------------------------------- */

.foot {
  background: var(--leaf-deep);
  color: var(--cream);
}
.foot__top {
  display: grid;
  grid-template-columns: 1fr 1fr;
  height: clamp(280px, 36vw, 440px);
  border-block-end: 1px solid var(--hairline-leaf);
}
.foot__map {
  position: relative;
  overflow: hidden;
  background: var(--leaf);
}
.foot__map iframe {
  width: 100%;
  height: 100%;
  filter: saturate(0.6) hue-rotate(-10deg) brightness(0.95);
}
.foot__map-overlay {
  position: absolute;
  inset-block-end: var(--s-5);
  inset-inline-start: var(--s-5);
  background: var(--leaf-deep);
  color: var(--cream);
  padding: var(--s-3) var(--s-4);
  pointer-events: none;
}
.foot__map-pin {
  display: inline-flex;
  align-items: center;
  gap: var(--s-2);
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  font-weight: 500;
}
html[lang="he"] .foot__map-pin { text-transform: none; letter-spacing: 0.04em; }
.foot__map-pin-mark {
  display: inline-block;
  width: 8px;
  height: 8px;
  background: var(--gold);
  border-radius: 50%;
  font-size: 0;
}

.foot__photo {
  position: relative;
  overflow: hidden;
  background: var(--leaf);
  margin: 0;
}
.foot__photo img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  filter: saturate(0.6) brightness(0.7);
}

.foot__bottom { padding: clamp(48px, 6vw, 96px) var(--s-5) var(--s-7); }
.foot__inner {
  max-width: var(--maxw-image);
  margin-inline: auto;
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: var(--s-7);
}
.foot__col { display: grid; gap: var(--s-2); align-content: start; }
.foot__brand {
  font-family: var(--font-display-ltr);
  font-size: var(--fs-2xl);
  letter-spacing: 0.18em;
  color: var(--cream);
}
.foot__brand-sub {
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: var(--fs-base);
  letter-spacing: 0.02em;
  color: var(--gold);
  margin-block-start: 4px;
}
.foot__label {
  font-size: var(--fs-xs);
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--gold);
  margin-block-end: var(--s-3);
  font-weight: 500;
}
html[lang="he"] .foot__label { text-transform: none; letter-spacing: 0.04em; font-weight: 600; }
.foot__line {
  font-size: var(--fs-sm);
  color: color-mix(in oklch, var(--cream), transparent 35%);
}
.foot__line--strong { color: var(--cream); font-weight: 500; }
.foot__line--mute   { color: color-mix(in oklch, var(--cream), transparent 50%); font-size: var(--fs-xs); }
.foot__line a { transition: color var(--motion-fast) var(--ease-out-quart); }
.foot__line a:hover { color: var(--gold); }

.foot__legal {
  max-width: var(--maxw-image);
  margin-inline: auto;
  margin-block-start: var(--s-7);
  padding-block-start: var(--s-5);
  border-block-start: 1px solid var(--hairline-leaf);
  display: flex;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: var(--s-3);
  font-size: var(--fs-xs);
  letter-spacing: 0.04em;
  color: color-mix(in oklch, var(--cream), transparent 50%);
}

@media (max-width: 980px) {
  .foot__top { grid-template-columns: 1fr; height: auto; }
  .foot__map, .foot__photo { aspect-ratio: 16 / 10; }
  .foot__inner { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 600px) {
  .foot__inner { grid-template-columns: 1fr; gap: var(--s-5); }
  .foot__legal { flex-direction: column; gap: var(--s-2); }
}

/* ---------- Reveals (motion) ----------------------------------------- */

.reveal {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity var(--motion-deep) var(--ease-out-quart),
              transform var(--motion-deep) var(--ease-out-quart);
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal.is-in { opacity: 1; transform: none; }

.reveal-img {
  opacity: 0;
  transform: scale(1.04);
  transition: opacity var(--motion-deep) var(--ease-out-quart),
              transform 1.1s var(--ease-out-quart);
  transition-delay: var(--reveal-delay, 0ms);
}
.reveal-img.is-in { opacity: 1; transform: none; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 200ms !important;
    transition-delay: 0ms !important;
    scroll-behavior: auto !important;
  }
  .reveal, .reveal-img { transform: none !important; }
}

.is-hidden { display: none !important; }

/* ---------- RTL composition tweaks ----------------------------------- */

html[dir="rtl"] .nav__brand,
html[dir="rtl"] .nav__brand-mark,
html[dir="rtl"] .nav__brand-word,
html[dir="rtl"] .gift-card__brand,
html[dir="rtl"] .foot__brand {
  font-family: var(--font-display-ltr); /* keep wordmark Latin */
}
