/* =============================================================
   Лексора — Section styles
   ============================================================= */

/* =============================================================
   HERO
============================================================= */
.hero {
  position: relative;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding: clamp(120px, 14vh, 180px) var(--gutter) clamp(100px, 12vh, 140px);
  overflow: hidden;
  background: var(--paper);
}

.hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 78% 20%, rgba(31, 179, 166, 0.08), transparent 50%),
    radial-gradient(circle at 12% 88%, rgba(245, 184, 46, 0.10), transparent 55%);
  pointer-events: none;
  z-index: 0;
}
.hero > * { position: relative; z-index: 1; }

.hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--ink-soft);
  margin-bottom: clamp(28px, 3.5vw, 48px);
}
.hero__eyebrow::before {
  content: '';
  width: 28px; height: 1px;
  background: var(--ink-faint);
}

.hero__headline {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-hero);
  line-height: 0.98;
  letter-spacing: -0.025em;
  color: var(--ink);
}
.hero__line { display: block; }
.hero__period {
  color: var(--amber-warm);
  display: inline-block;
  margin-left: 0.02em;
}

.hero__ctas {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 14px;
  margin-top: clamp(36px, 4.5vw, 64px);
}

.hero__masthead {
  position: absolute;
  right: var(--gutter);
  bottom: clamp(36px, 4.5vh, 56px);
  text-align: right;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  line-height: 1.5;
  color: var(--ink-soft);
  letter-spacing: var(--track-wide);
}
.hero__masthead p + p { margin-top: 2px; }

.hero__scrollcue {
  position: absolute;
  left: var(--gutter);
  bottom: clamp(36px, 4.5vh, 56px);
  display: flex;
  align-items: center;
  gap: 14px;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.hero__scrollcue-line {
  display: inline-block;
  width: 40px; height: 1px;
  background: rgba(138, 145, 163, 0.3);
  position: relative;
  overflow: hidden;
}
.hero__scrollcue-line::after {
  content: '';
  position: absolute;
  left: 0; top: 0;
  width: 100%; height: 100%;
  background: var(--ink);
  animation: scrollcue 2.6s var(--ease-in-out) infinite;
}
@keyframes scrollcue {
  0%, 100% { transform: scaleX(0); transform-origin: left; }
  45%      { transform: scaleX(1); transform-origin: left; }
  45.01%   { transform: scaleX(1); transform-origin: right; }
  90%      { transform: scaleX(0); transform-origin: right; }
}

/* ---------- Hero character (the lightbulb, floating idle) ---------- */
.hero__char {
  position: absolute;
  top: 50%;
  right: clamp(48px, 10vw, 140px);
  width: clamp(140px, 22vw, 300px);
  height: auto;
  filter: drop-shadow(0 24px 60px rgba(245,184,46,0.22)) drop-shadow(0 8px 24px rgba(11,15,26,0.08));
  opacity: 0;
  animation:
    heroCharFade 900ms var(--ease-out) 500ms forwards,
    float 7s var(--ease-in-out) infinite;
  pointer-events: none;
}
@keyframes heroCharFade {
  to { opacity: 1; }
}
@keyframes float {
  0%, 100% { transform: translateY(calc(-50% - 0px)) rotate(-1.5deg); }
  50%      { transform: translateY(calc(-50% - 14px)) rotate(1.5deg); }
}

/* ---------- Hero load motion ---------- */
@keyframes rise {
  from { opacity: 0; transform: translate3d(0, 18px, 0); }
  to   { opacity: 1; transform: translate3d(0, 0, 0); }
}

.hero__eyebrow,
.hero__line,
.hero__masthead,
.hero__scrollcue {
  opacity: 0;
  animation: rise 700ms var(--ease-out) both;
}
.hero__eyebrow             { animation-delay:   0ms; }
.hero__line:nth-child(1)   { animation-delay: 140ms; }
.hero__line:nth-child(2)   { animation-delay: 260ms; }
.hero__line:nth-child(3)   { animation-delay: 380ms; }
.hero__masthead            { animation-delay: 640ms; }
.hero__scrollcue           { animation-delay: 820ms; }

.nav__brand, .nav__links, .nav__badge {
  opacity: 0;
  animation: rise 700ms var(--ease-out) 60ms both;
}
.nav__links { animation-delay: 160ms; }
.nav__badge { animation-delay: 260ms; }

@media (max-width: 880px) {
  .hero__char { opacity: 0.35; right: -10%; width: 70%; }
}
@media (max-width: 640px) {
  .hero {
    padding-top: clamp(100px, 22vh, 140px);
    padding-bottom: 48px;
    justify-content: flex-start;
  }
  .hero__ctas { flex-direction: column; align-items: stretch; gap: 10px; }
  .hero__ctas .btn { width: 100%; }
  .hero__masthead {
    position: static;
    text-align: left;
    margin-top: 40px;
  }
  .hero__scrollcue { display: none; }
  .hero__char { top: auto; bottom: -8%; right: -20%; transform: none; width: 80%; opacity: 0.18; animation: none; }
}

/* =============================================================
   ROUTER — "Вас интересует?"
   Owns the full viewport — next section only appears on scroll.
============================================================= */
.router {
  position: relative;
  min-height: 100dvh;
  padding: clamp(72px, 12vh, 140px) var(--gutter);
  background: var(--paper-warm);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: clamp(24px, 3vh, 48px);
}

.router::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 50% 20%, rgba(245,184,46,0.12), transparent 50%);
  pointer-events: none;
}
.router > * { position: relative; z-index: 1; }

.router__char-wrap {
  position: relative;
  width: clamp(100px, 10vw, 140px);
  height: clamp(100px, 10vw, 140px);
  display: grid;
  place-items: center;
}
.router__char-wrap::before,
.router__char-wrap::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  border: 1.5px solid var(--amber);
  opacity: 0;
  animation: pulseRing 2.8s var(--ease-out) infinite;
}
.router__char-wrap::after { animation-delay: 1.4s; }
@keyframes pulseRing {
  0%   { opacity: 0.6; transform: scale(0.9); }
  100% { opacity: 0; transform: scale(1.8); }
}
.router__char {
  width: 80%;
  height: 80%;
  object-fit: contain;
  filter: drop-shadow(0 10px 30px rgba(245,184,46,0.35));
  animation: float-small 5s var(--ease-in-out) infinite;
}
@keyframes float-small {
  0%, 100% { transform: translateY(0) rotate(-1deg); }
  50%      { transform: translateY(-8px) rotate(1deg); }
}

.router__question {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-5xl);
  line-height: 1.0;
  letter-spacing: -0.025em;
  color: var(--ink);
  text-align: center;
}
.router__question em {
  font-style: normal;
  color: var(--amber-warm);
}

.router__cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 1.6vw, 24px);
  width: 100%;
  max-width: 1120px;
}

.rcard {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
  padding: clamp(28px, 3vw, 40px);
  background: var(--paper);
  border: 1px solid rgba(11,15,26,0.08);
  border-radius: var(--radius-lg);
  text-align: left;
  color: var(--ink);
  cursor: pointer;
  overflow: hidden;
  transition: transform var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out);
}
.rcard::before {
  content: '';
  position: absolute;
  inset: 0;
  background: radial-gradient(circle at 100% 0%, var(--amber-glow), transparent 60%);
  opacity: 0;
  transition: opacity var(--dur-base) var(--ease-out);
}
.rcard > * { position: relative; }

.rcard:hover {
  transform: translateY(-4px);
  border-color: var(--amber-warm);
  box-shadow: var(--shadow-lg);
}
.rcard:hover::before { opacity: 1; }

.rcard__eyebrow {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-warm);
}
.rcard__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-2xl);
  line-height: 1.1;
  letter-spacing: var(--track-snug);
  color: var(--ink);
}
.rcard__desc {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 32ch;
}
.rcard__arrow {
  margin-top: auto;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  color: var(--ink);
  transition: transform var(--dur-base) var(--ease-out),
              color var(--dur-base) var(--ease-out);
}
.rcard:hover .rcard__arrow {
  transform: translateX(6px);
  color: var(--amber-warm);
}

.router__skip {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-faint);
  letter-spacing: var(--track-wide);
  padding-bottom: 2px;
  border-bottom: 1px solid var(--ink-ghost);
  transition: color var(--dur-fast), border-color var(--dur-fast);
}
.router__skip:hover {
  color: var(--ink);
  border-color: var(--ink);
}

/* ---------- Mobile: tighten composition so three cards + skip fit above fold ---------- */
@media (max-width: 640px) {
  .router {
    padding: clamp(72px, 14vh, 110px) var(--gutter) clamp(48px, 8vh, 72px);
    gap: clamp(18px, 3vh, 28px);
  }
  .router__char-wrap {
    width: 72px;
    height: 72px;
  }
  .router__question {
    font-size: clamp(36px, 10vw, 56px);
    line-height: 1.05;
  }
  .router__cards {
    gap: 10px;
  }
  /* Compact horizontal row layout */
  .rcard {
    flex-direction: row;
    align-items: center;
    gap: 14px;
    padding: 16px 18px;
    min-height: 0;
  }
  .rcard > * { flex-shrink: 0; }
  .rcard__eyebrow {
    width: 22px;
    font-size: 11px;
    opacity: 0.7;
  }
  .rcard__title {
    font-size: 18px;
    line-height: 1.2;
    flex: 1;
    min-width: 0;
  }
  /* Hide verbose description on mobile — tap is the commitment */
  .rcard__desc { display: none; }
  .rcard__arrow {
    margin-top: 0;
    font-size: 18px;
    color: var(--ink-faint);
  }
  .router__skip {
    margin-top: 4px;
    font-size: 13px;
  }
}

/* =============================================================
   WHY
============================================================= */
.why {
  padding: var(--section-pad-y) var(--gutter);
  background: var(--paper);
}
.why__inner {
  max-width: var(--container-wide);
  margin: 0 auto;
}
.why__head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-4xl);
  line-height: 1.02;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  max-width: 18ch;
  margin-bottom: clamp(48px, 6vw, 96px);
}

.why__pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(32px, 4vw, 64px);
}

.pillar {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.pillar__num {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-mega);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--ink);
}
.pillar__unit {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--amber-deep);
  font-weight: 500;
}
.pillar__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 38ch;
  margin-top: 12px;
}

/* =============================================================
   METHODOLOGY — pinned cinematic
============================================================= */
.metod {
  position: relative;
  background: var(--navy);
  color: var(--navy-ink);
  /* Total scroll distance = 4 stages × 100vh */
  height: 500vh;
}

.metod__sticky {
  position: sticky;
  top: 0;
  height: 100dvh;
  overflow: hidden;
  padding: clamp(96px, 12vh, 140px) var(--gutter) clamp(64px, 8vh, 96px);
  display: flex;
  flex-direction: column;
}

.metod__stage {
  position: relative;
  flex: 1;
  display: grid;
  place-items: center;
}

.stage {
  position: absolute;
  inset: 0;
  display: flex;
  flex-direction: column;
  justify-content: center;
  align-items: center;
  text-align: center;
  gap: clamp(16px, 2vw, 32px);
  opacity: 0;
  transform: translateY(24px);
  transition: opacity 600ms var(--ease-out), transform 600ms var(--ease-out);
  pointer-events: none;
}
.stage.is-active {
  opacity: 1;
  transform: translateY(0);
  pointer-events: auto;
}

.stage__head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-5xl);
  line-height: 1.04;
  letter-spacing: var(--track-snug);
  color: var(--navy-ink);
  max-width: 18ch;
}
.stage__head em {
  font-style: normal;
  color: var(--amber);
  font-weight: 600;
}
.stage__head-small {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-2xl);
  line-height: 1.2;
  letter-spacing: var(--track-snug);
  color: var(--navy-ink-soft);
  max-width: 30ch;
}
.stage__sub {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  color: var(--navy-ink-soft);
  max-width: 44ch;
}

/* Stage 1: split into two columns */
.stage--split {
  flex-direction: row;
  gap: clamp(32px, 6vw, 96px);
  justify-content: center;
  flex-wrap: wrap;
}
.stage__col {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
}
.stage__word {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: clamp(56px, 9vw, 160px);
  line-height: 0.9;
  letter-spacing: -0.04em;
  color: var(--navy-ink);
}
.stage__col:nth-child(1) .stage__word { color: var(--teal); }
.stage__col:nth-child(3) .stage__word { color: var(--amber); }

.stage__label {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--navy-ink);
  letter-spacing: var(--track-snug);
  margin-top: 8px;
}
.stage__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--navy-ink-faint);
  letter-spacing: var(--track-wide);
}
.stage__divider {
  width: 1px;
  align-self: stretch;
  background: rgba(240, 233, 221, 0.15);
}

/* Stage 2: four action cards */
.stage__four {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: clamp(14px, 1.6vw, 24px);
  max-width: 1000px;
  width: 100%;
}
.action-card {
  padding: clamp(20px, 2.4vw, 32px);
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(240, 233, 221, 0.12);
  border-radius: var(--radius-md);
  display: flex;
  flex-direction: column;
  gap: 10px;
  text-align: left;
  transition: border-color var(--dur-base), background var(--dur-base);
}
.action-card:hover {
  border-color: var(--amber);
  background: rgba(245,184,46,0.06);
}
.action-card__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--amber);
  letter-spacing: var(--track-wide);
}
.action-card__name {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--navy-ink);
  letter-spacing: var(--track-snug);
}
.action-card__ex {
  font-family: var(--font-mono, ui-monospace, Menlo, monospace);
  font-size: var(--text-sm);
  color: var(--teal);
  letter-spacing: 0.01em;
  margin-top: 4px;
}

.metod__progress {
  position: absolute;
  bottom: clamp(40px, 5vh, 64px);
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 2;
}
.metod__progress span {
  width: 28px; height: 2px;
  background: rgba(240, 233, 221, 0.18);
  border-radius: 2px;
  transition: background var(--dur-base) var(--ease-out);
}
.metod__progress span.is-active {
  background: var(--amber);
}

@media (max-width: 640px) {
  .stage__head { font-size: var(--text-3xl); }
  .stage__word { font-size: var(--text-4xl); }
  .stage--split { gap: 20px; flex-direction: column; }
  .stage__divider { display: none; }
}

/* =============================================================
   COURSES
============================================================= */
.courses {
  padding: var(--section-pad-y) var(--gutter);
  background: var(--paper);
}
.courses__inner {
  max-width: var(--container-wide);
  margin: 0 auto;
}
.courses__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(300px, 1fr));
  gap: clamp(16px, 1.8vw, 24px);
  margin-top: clamp(40px, 5vw, 72px);
}
.course {
  --c-bg:       var(--paper-warm);
  --c-ink:      var(--ink);
  --c-ink-soft: var(--ink-soft);
  --c-num:      var(--amber-deep);
  padding: clamp(24px, 2.8vw, 36px);
  background: var(--c-bg);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 10px;
  transition: transform var(--dur-base), background var(--dur-base), order var(--dur-base);
  position: relative;
  overflow: hidden;
  order: 5;
}
.course:hover {
  transform: translateY(-4px);
  --c-bg: var(--paper-deep);
}
.course__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  color: var(--c-num);
  letter-spacing: var(--track-wide);
}
.course__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--c-ink);
  letter-spacing: var(--track-snug);
}
.course__tagline {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--c-ink-soft);
  margin-top: 4px;
}
.course__price {
  margin-top: auto;
  padding-top: 16px;
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--c-ink);
  font-weight: 500;
}
.course__price small {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--c-ink-soft);
  font-weight: 400;
  margin-left: 4px;
}

/* Router choice promotes the first matching course to dark */
body[data-route="self"]    .course[data-audience~="self"]:first-of-type,
body[data-route="kid"]     .course[data-audience~="kid"]:first-of-type,
body[data-route="company"] .course[data-audience~="company"]:first-of-type {
  --c-bg:       var(--ink);
  --c-ink:      var(--paper);
  --c-ink-soft: rgba(250, 247, 242, 0.72);
  --c-num:      var(--amber);
  order: 1;
}
body[data-route="self"]    .course[data-audience~="self"],
body[data-route="kid"]     .course[data-audience~="kid"],
body[data-route="company"] .course[data-audience~="company"] { order: 2; }

body[data-route] .course:not([data-audience~="self"]):not([data-audience~="kid"]):not([data-audience~="company"]) { opacity: 0.7; }

/* =============================================================
   PRICING
============================================================= */
.pricing {
  padding: var(--section-pad-y) var(--gutter);
  background: var(--paper-warm);
}
.pricing__inner {
  max-width: var(--container);
  margin: 0 auto;
}
.pricing__grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(16px, 1.6vw, 20px);
  margin-top: clamp(40px, 5vw, 72px);
}
.price-card {
  padding: clamp(28px, 3vw, 40px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.price-card__name {
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 500;
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--ink-soft);
}
.price-card__amount {
  font-family: var(--font-display);
  font-size: var(--text-4xl);
  font-weight: 500;
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  margin-top: 12px;
}
.price-card__period {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-faint);
}
.price-card__detail {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-soft);
  line-height: var(--lead-normal);
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid rgba(11,15,26,0.08);
}
.pricing__note {
  margin-top: 32px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-faint);
}

/* =============================================================
   SPEAKING CLUB — amber warm moment
============================================================= */
.club {
  padding: var(--section-pad-y) var(--gutter);
  background: linear-gradient(180deg, var(--amber) 0%, #F0A810 100%);
  color: var(--ink);
  position: relative;
  overflow: hidden;
}
.club::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 80% 30%, rgba(255,255,255,0.25), transparent 40%),
    radial-gradient(circle at 20% 80%, rgba(11,15,26,0.08), transparent 50%);
  pointer-events: none;
}
.club__inner {
  position: relative;
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 28px;
}
.club__head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-5xl);
  line-height: 1.02;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  max-width: 22ch;
}
.club__text {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink);
  max-width: 52ch;
  opacity: 0.85;
}
.club__meta {
  display: flex;
  gap: 32px;
  flex-wrap: wrap;
  margin-top: 12px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink);
  letter-spacing: var(--track-wide);
}
.club__meta span strong {
  display: block;
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--ink);
  margin-bottom: 2px;
}

/* =============================================================
   PLACE — location / map
============================================================= */
.place {
  padding: var(--section-pad-y) var(--gutter);
  background: var(--paper);
}
.place__inner { max-width: var(--container-wide); margin: 0 auto; }
.place__grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: clamp(32px, 5vw, 80px);
  margin-top: clamp(40px, 5vw, 72px);
  align-items: center;
}
@media (max-width: 768px) {
  .place__grid { grid-template-columns: 1fr; }
}

.place__addr,
.place__hours {
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--ink-soft);
  line-height: var(--lead-normal);
  margin-top: 20px;
}
.place__hours { color: var(--ink); }
.place__phone {
  display: inline-block;
  margin-top: 24px;
  font-family: var(--font-display);
  font-size: var(--text-2xl);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  border-bottom: 1px solid var(--ink-ghost);
  padding-bottom: 4px;
  transition: color var(--dur-fast), border-color var(--dur-fast);
}
.place__phone:hover {
  color: var(--amber-deep);
  border-color: var(--amber-warm);
}

.place__map {
  position: relative;
  aspect-ratio: 4/3;
  border-radius: var(--radius-lg);
  overflow: hidden;
  background:
    linear-gradient(180deg, var(--paper-warm) 0%, var(--paper-deep) 100%);
}
.place__map-grid {
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(rgba(11,15,26,0.06) 1px, transparent 1px),
    linear-gradient(90deg, rgba(11,15,26,0.06) 1px, transparent 1px);
  background-size: 48px 48px;
}
.place__map-street {
  position: absolute;
  background: rgba(11,15,26,0.08);
}
.place__map-street--h { left: 0; right: 0; height: 14px; top: 62%; }
.place__map-street--v { top: 0; bottom: 0; width: 10px; left: 48%; }

.place__map-pin {
  position: absolute;
  left: 48%;
  top: 62%;
  transform: translate(-50%, -50%);
  z-index: 2;
  display: grid;
  place-items: center;
}
.place__map-pin-dot {
  width: 18px; height: 18px;
  background: var(--amber);
  border-radius: 50%;
  box-shadow: 0 0 0 4px var(--paper), 0 0 0 5px var(--amber-warm), var(--shadow-md);
  position: relative;
  z-index: 2;
}
.place__map-pin-pulse {
  position: absolute;
  inset: 0;
  width: 18px; height: 18px;
  margin: auto;
  border-radius: 50%;
  border: 2px solid var(--amber);
  animation: pinPulse 2s var(--ease-out) infinite;
}
@keyframes pinPulse {
  0%   { transform: scale(1); opacity: 0.8; }
  100% { transform: scale(4); opacity: 0; }
}
.place__map-label {
  position: absolute;
  top: 62%;
  left: calc(48% + 18px);
  margin-top: 12px;
  padding: 6px 10px;
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--track-wide);
  border-radius: var(--radius-sm);
  white-space: nowrap;
}

/* =============================================================
   TEST CTA
============================================================= */
.test-cta {
  padding: var(--section-pad-y) var(--gutter);
  background: var(--navy);
  color: var(--navy-ink);
  text-align: center;
  position: relative;
  overflow: hidden;
}
.test-cta::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 50% 100%, rgba(245,184,46,0.16), transparent 55%);
  pointer-events: none;
}
.test-cta__inner {
  position: relative;
  max-width: var(--container);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px;
}
.test-cta__head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-4xl);
  line-height: 1.02;
  letter-spacing: var(--track-snug);
  color: var(--navy-ink);
  max-width: 22ch;
}
.test-cta__text {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  color: var(--navy-ink-soft);
  max-width: 52ch;
}
.test-cta__char {
  width: clamp(80px, 10vw, 120px);
  filter: drop-shadow(0 16px 40px rgba(245,184,46,0.4));
  margin-bottom: 8px;
  animation: float-small 5s var(--ease-in-out) infinite;
}

/* =============================================================
   FOOTER
============================================================= */
.footer {
  padding: clamp(64px, 8vw, 120px) var(--gutter) 32px;
  background: var(--navy-deep);
  color: var(--navy-ink-soft);
}
.footer__inner { max-width: var(--container-wide); margin: 0 auto; }
.footer__grid {
  display: grid;
  grid-template-columns: 1.4fr 1fr 1fr 1fr;
  gap: clamp(32px, 4vw, 64px);
  padding-bottom: clamp(40px, 5vw, 72px);
  border-bottom: 1px solid rgba(240,233,221,0.12);
}
@media (max-width: 768px) {
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 480px) {
  .footer__grid { grid-template-columns: 1fr; }
}

.footer__brand {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-xl);
  letter-spacing: var(--track-snug);
  color: var(--navy-ink);
}
.footer__tagline {
  margin-top: 16px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--navy-ink-soft);
  max-width: 28ch;
}
.footer__col-head {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--navy-ink);
  margin-bottom: 16px;
}
.footer__col ul { list-style: none; display: flex; flex-direction: column; gap: 10px; }
.footer__col li {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--navy-ink-soft);
}
.footer__col a {
  transition: color var(--dur-fast) var(--ease-out);
}
.footer__col a:hover { color: var(--amber); }

.footer__bottom {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-top: 24px;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--navy-ink-faint);
  letter-spacing: var(--track-wide);
}
@media (max-width: 480px) {
  .footer__bottom { flex-direction: column; gap: 8px; align-items: flex-start; }
}

/* =============================================================
   ROUTER VIEW TOGGLE — cards ↔ sitemap
============================================================= */
.router__view {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: inherit;
  transition: opacity 400ms var(--ease-out);
}
.router__view[hidden] {
  display: none;
}
.router__view.is-entering {
  opacity: 0;
  animation: viewFadeIn 500ms var(--ease-out) forwards;
}
@keyframes viewFadeIn {
  to { opacity: 1; }
}

/* =============================================================
   SITEMAP — the "structure of the school" view
   A branching tree: one trunk → three audience branches,
   plus four standalone rooms below.
============================================================= */
.sitemap {
  width: 100%;
  max-width: 980px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: clamp(16px, 2vh, 28px);
  color: var(--ink-faint);  /* SVG uses currentColor */
}

/* Trunk: character + brand name at top */
.sitemap__trunk {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  margin-bottom: clamp(4px, 0.8vh, 12px);
}
.sitemap__char {
  width: clamp(64px, 6vw, 88px);
  height: auto;
  filter: drop-shadow(0 10px 24px rgba(245,184,46,0.32));
  animation: float-small 5s var(--ease-in-out) infinite;
}
.sitemap__trunk-name {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: var(--text-lg);
  color: var(--ink);
  letter-spacing: var(--track-snug);
}

/* SVG connecting lines between trunk and branches */
.sitemap__lines {
  width: 100%;
  max-width: 820px;
  height: clamp(40px, 6vh, 70px);
  color: var(--amber-warm);
  opacity: 0.5;
}

/* Three branch nodes (Для себя / ребёнка / компании) */
.sitemap__branches {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: clamp(10px, 1.2vw, 18px);
  width: 100%;
  max-width: 820px;
}
.sitemap__node--branch {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 6px;
  padding: clamp(14px, 1.8vw, 22px);
  background: var(--paper);
  border: 1px solid rgba(11,15,26,0.08);
  border-radius: var(--radius-md);
  color: var(--ink);
  text-align: left;
  transition: transform var(--dur-base) var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.sitemap__node--branch:hover {
  transform: translateY(-3px);
  border-color: var(--amber-warm);
  box-shadow: var(--shadow-md);
}
.sitemap__node-eyebrow {
  font-family: var(--font-display);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-warm);
}
.sitemap__node-title {
  font-family: var(--font-display);
  font-size: clamp(16px, 1.6vw, 20px);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.15;
}
.sitemap__node-desc {
  font-family: var(--font-body);
  font-size: 12px;
  color: var(--ink-soft);
  line-height: 1.35;
}

/* Divider label between branches and rooms */
.sitemap__aside {
  margin-top: clamp(14px, 2vh, 22px);
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.sitemap__aside::before,
.sitemap__aside::after {
  content: ' · ';
}

/* Four room nodes (О школе, Приложение, Тест, Контакты) */
.sitemap__rooms {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 8px;
  width: 100%;
  max-width: 820px;
}
.sitemap__room {
  padding: 10px 18px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
  background: var(--paper);
  border: 1px solid rgba(11,15,26,0.10);
  border-radius: var(--radius-pill);
  transition: background var(--dur-fast), border-color var(--dur-fast), color var(--dur-fast);
}
.sitemap__room:hover {
  background: var(--ink);
  border-color: var(--ink);
  color: var(--paper);
}

/* Mobile: stack branches, stack rooms, redraw SVG lines vertically */
@media (max-width: 640px) {
  .sitemap__lines { display: none; }
  .sitemap__branches {
    grid-template-columns: 1fr;
    max-width: 100%;
  }
  .sitemap__node--branch {
    padding: 14px 16px;
    flex-direction: row;
    align-items: center;
    gap: 12px;
  }
  .sitemap__node-eyebrow { width: 22px; opacity: 0.7; }
  .sitemap__node-desc { display: none; }
  .sitemap__rooms { flex-direction: column; align-items: stretch; max-width: 280px; }
  .sitemap__room { text-align: center; }
}

/* =============================================================
   PAGE HERO (audience + room pages)
============================================================= */
.page {
  padding-top: clamp(72px, 10vh, 100px);  /* nav clearance */
}

.page-hero {
  position: relative;
  padding: clamp(48px, 8vh, 96px) var(--gutter) clamp(64px, 8vh, 120px);
  background: var(--paper);
  overflow: hidden;
}
.page-hero::before {
  content: '';
  position: absolute;
  inset: 0;
  background-image:
    radial-gradient(circle at 90% 10%, rgba(245,184,46,0.08), transparent 45%);
  pointer-events: none;
}
.page-hero__inner { position: relative; }

.page-hero .section-eyebrow {
  margin-bottom: clamp(24px, 3vw, 36px);
}

.page-hero__head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-4xl);
  line-height: 1.02;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  max-width: 20ch;
  margin-bottom: clamp(20px, 2vw, 28px);
}
@media (max-width: 640px) {
  .page-hero__head {
    font-size: clamp(28px, 8.5vw, 36px);
    letter-spacing: -0.02em;
    word-break: normal;
    overflow-wrap: break-word;
    hyphens: auto;
  }
}
.page-hero__head em {
  font-style: normal;
  color: var(--amber-warm);
  font-weight: 500;
}

.page-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 58ch;
}

/* =============================================================
   PAGE SECTIONS (reusable content bands on inner pages)
============================================================= */
.page-section {
  padding: clamp(64px, 10vh, 120px) var(--gutter);
  background: var(--paper);
}
.page-section--alt {
  background: var(--paper-warm);
}
.page-section__inner,
.page-hero__inner {
  max-width: var(--container-wide);
  margin: 0 auto;
}

.page-section .section-eyebrow {
  margin-bottom: clamp(20px, 2.5vw, 32px);
}

.page-section .section-head {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-3xl);
  line-height: 1.04;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  max-width: 22ch;
  margin-bottom: clamp(20px, 3vw, 36px);
}
@media (max-width: 640px) {
  .page-section .section-head {
    font-size: clamp(26px, 7.5vw, 32px);
    letter-spacing: -0.02em;
    overflow-wrap: break-word;
    hyphens: auto;
  }
}
.page-section .section-head em {
  font-style: normal;
  color: var(--amber-warm);
  font-weight: 500;
}

.page-section__placeholder {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 64ch;
  padding: clamp(20px, 3vw, 32px);
  background: rgba(245, 184, 46, 0.06);
  border-left: 2px solid var(--amber-warm);
  border-radius: 0 var(--radius-md) var(--radius-md) 0;
}
.page-section__placeholder p + p {
  margin-top: 10px;
}
.page-section__placeholder a {
  color: var(--teal-deep);
  border-bottom: 1px solid currentColor;
  padding-bottom: 1px;
}
.page-section__placeholder strong {
  color: var(--ink);
  font-weight: 600;
}

.page-section__links {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-top: clamp(20px, 3vw, 32px);
}

/* =============================================================
   ABOUT PAGE COMPONENTS
============================================================= */

/* ---------- Page image (hero anchor, figure + caption) ---------- */
.page-image {
  padding: 0 var(--gutter) clamp(64px, 10vh, 120px);
  max-width: var(--container-wide);
  margin: 0 auto;
}
.page-image__frame {
  margin: 0;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--paper-warm);
}
.page-image__frame img {
  width: 100%;
  height: auto;
  display: block;
  max-height: 80vh;
  object-fit: cover;
}
.page-image__caption {
  position: absolute;
  left: clamp(20px, 3vw, 36px);
  bottom: clamp(20px, 3vw, 36px);
  right: clamp(20px, 3vw, 36px);
  max-width: 44ch;
  padding: 14px 18px;
  background: rgba(250, 247, 242, 0.92);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-radius: var(--radius-md);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink);
  box-shadow: var(--shadow-sm);
}

/* ---------- Prose blocks ---------- */
.page-prose {
  max-width: 62ch;
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-relaxed);
  color: var(--ink);
}
.page-prose p + p {
  margin-top: clamp(14px, 1.6vw, 20px);
}
.page-prose--muted {
  color: var(--ink-soft);
  font-size: var(--text-base);
}
.page-prose a {
  color: var(--teal-deep);
  border-bottom: 1px solid rgba(15, 127, 119, 0.35);
  padding-bottom: 1px;
  transition: border-color var(--dur-fast);
}
.page-prose a:hover {
  border-bottom-color: var(--teal-deep);
}

/* ---------- Three pillars (about page's "Чем отличаемся") ---------- */
.about-pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(20px, 2.4vw, 36px);
  margin-top: clamp(32px, 4vw, 48px);
}
.about-pillar {
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: clamp(24px, 2.8vw, 36px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.about-pillar__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-deep);
}
.about-pillar__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-2xl);
  line-height: 1.1;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  margin: 0;
}
.about-pillar__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}

/* ---------- Facts list (reqs, address, etc.) ---------- */
.page-facts {
  margin: 0;
  margin-top: clamp(24px, 3vw, 40px);
  max-width: 720px;
}
.page-facts__row {
  display: grid;
  grid-template-columns: minmax(120px, 200px) 1fr;
  gap: clamp(16px, 2vw, 32px);
  padding: clamp(14px, 1.8vw, 20px) 0;
  border-top: 1px solid rgba(11, 15, 26, 0.10);
}
.page-facts__row:last-child {
  border-bottom: 1px solid rgba(11, 15, 26, 0.10);
}
.page-facts dt {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--track-uppercase);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.page-facts dd {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink);
  margin: 0;
}
.page-facts dd a {
  color: var(--teal-deep);
  border-bottom: 1px solid rgba(15, 127, 119, 0.35);
  padding-bottom: 1px;
}
.page-facts dd a:hover {
  border-bottom-color: var(--teal-deep);
}
@media (max-width: 520px) {
  .page-facts__row {
    grid-template-columns: 1fr;
    gap: 4px;
  }
}


/* =============================================================
   CONTACTS PAGE
============================================================= */

/* A compact variant of page-section with less vertical padding */
.page-section--compact {
  padding-top: clamp(48px, 7vh, 96px);
  padding-bottom: clamp(48px, 7vh, 80px);
}
.page-section--compact .section-head {
  font-size: var(--text-3xl);
  max-width: 26ch;
}

/* Two-column split: students | companies */
.contacts-split {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(24px, 3vw, 48px);
  margin-top: clamp(28px, 3.5vw, 48px);
  max-width: var(--container-wide);
}
.contacts-col {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: clamp(24px, 2.6vw, 32px);
  background: var(--paper-warm);
  border: 1px solid rgba(11,15,26,0.06);
  border-radius: var(--radius-lg);
}
.contacts-col--corp {
  background: var(--ink);
  color: var(--paper);
  border-color: transparent;
}

.contacts-col__label {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--amber-deep);
  margin: 0;
}
.contacts-col--corp .contacts-col__label {
  color: var(--amber);
}

.contacts-col__lede {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0 0 8px;
  max-width: 34ch;
}
.contacts-col--corp .contacts-col__lede {
  color: rgba(250, 247, 242, 0.72);
}

/* Key/value list inside each column */
.contacts-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.contacts-list li {
  display: grid;
  grid-template-columns: 110px 1fr;
  align-items: baseline;
  gap: 12px;
  padding: 10px 0;
  border-top: 1px solid rgba(11, 15, 26, 0.08);
}
.contacts-list li:first-child {
  border-top: 0;
  padding-top: 0;
}
.contacts-col--corp .contacts-list li {
  border-top-color: rgba(250, 247, 242, 0.12);
}

.contacts-list__key {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.contacts-col--corp .contacts-list__key {
  color: rgba(250, 247, 242, 0.6);
}

.contacts-list__val {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.2;
  word-break: break-word;
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-fast), color var(--dur-fast);
}
.contacts-list__val:hover {
  border-bottom-color: var(--amber-warm);
  color: var(--amber-deep);
}
.contacts-col--corp .contacts-list__val {
  color: var(--paper);
}
.contacts-col--corp .contacts-list__val:hover {
  color: var(--amber);
  border-bottom-color: var(--amber);
}

/* Messenger row: inline pills */
.contacts-messengers {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.contacts-messengers a {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
  background: var(--paper);
  border: 1px solid rgba(11, 15, 26, 0.12);
  border-radius: var(--radius-pill);
  transition: background var(--dur-fast), color var(--dur-fast), border-color var(--dur-fast);
}
.contacts-messengers a:hover {
  background: var(--ink);
  color: var(--paper);
  border-color: var(--ink);
}

/* Schedule + address, inline below the split */
.contacts-meta {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: clamp(16px, 2vw, 32px);
  margin-top: clamp(28px, 3.5vw, 44px);
  padding-top: clamp(20px, 2.4vw, 28px);
  border-top: 1px solid rgba(11, 15, 26, 0.1);
}
.contacts-meta > div {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.contacts-meta__key {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
}
.contacts-meta__val {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
}

/* Map embed container */
.contacts-map {
  margin-top: clamp(24px, 3vw, 40px);
  position: relative;
  width: 100%;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--paper-warm);
  aspect-ratio: 16 / 9;
  max-height: 480px;
}
.contacts-map iframe {
  position: absolute;
  inset: 0;
  width: 100%;
  height: 100%;
  border: 0;
  display: block;
}

/* Mobile: stack the two columns, keep list tight */
@media (max-width: 720px) {
  .contacts-split {
    grid-template-columns: 1fr;
    gap: 16px;
  }
  .contacts-list li {
    grid-template-columns: 100px 1fr;
    gap: 10px;
  }
  /* Messenger row gets stacked on mobile — key above, pills below */
  .contacts-list__row {
    grid-template-columns: 1fr !important;
    gap: 8px !important;
  }
  .contacts-list__val {
    font-size: var(--text-base);
  }
  .contacts-meta {
    grid-template-columns: 1fr;
  }
  .contacts-map {
    aspect-ratio: 4 / 5;
    max-height: none;
  }
}

/* =============================================================
   /APP PAGE
============================================================= */

/* Hero: two-column on desktop, stacked on mobile */
.app-hero__inner {
  display: grid;
  grid-template-columns: 1.2fr 1fr;
  gap: clamp(32px, 4vw, 72px);
  align-items: center;
}
.app-hero__head {
  max-width: 16ch;
}
.app-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 40ch;
  margin: clamp(20px, 2.5vw, 32px) 0;
}
.app-hero__badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 8px 16px 8px 12px;
  background: var(--paper-warm);
  border: 1px solid rgba(11, 15, 26, 0.1);
  border-radius: var(--radius-pill);
  font-family: var(--font-body);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--ink);
}
.app-hero__badge-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--amber);
  box-shadow: 0 0 0 4px rgba(245, 184, 46, 0.22);
}

/* Phone mockup */
.app-hero__device {
  display: flex;
  justify-content: center;
  align-items: center;
}
.phone {
  width: 100%;
  max-width: 280px;
  height: auto;
  filter: drop-shadow(0 30px 60px rgba(11, 15, 26, 0.22))
          drop-shadow(0 10px 20px rgba(11, 15, 26, 0.12));
}

/* Feature cards */
.app-features {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(16px, 2vw, 24px);
  margin-top: clamp(28px, 3.5vw, 44px);
}
.app-feature {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(20px, 2.4vw, 28px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.app-feature__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-deep);
}
.app-feature__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-lg);
  line-height: 1.15;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  margin: 0;
}
.app-feature__text {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}

/* Store pills (disabled "soon" state) */
.app-stores__lede {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 58ch;
  margin: 0 0 clamp(24px, 3vw, 36px);
}
.app-stores {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.app-store {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 14px 24px;
  background: var(--paper-warm);
  border: 1px dashed rgba(11, 15, 26, 0.2);
  border-radius: var(--radius-lg);
  cursor: not-allowed;
  transition: none;
}
.app-store__tag {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--amber-deep);
  font-weight: 600;
}
.app-store__name {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
}

/* Mobile: stack hero */
@media (max-width: 800px) {
  .app-hero__inner {
    grid-template-columns: 1fr;
    gap: 32px;
  }
  .app-hero__device {
    order: -1;
  }
  .phone {
    max-width: 220px;
  }
}

/* =============================================================
   /TEST PAGE
============================================================= */

.test-hero__head {
  max-width: 18ch;
}
.test-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 54ch;
  margin: 0 0 clamp(28px, 3vw, 40px);
}

/* Stats row */
.test-stats {
  list-style: none;
  padding: 0;
  margin: 0 0 clamp(32px, 4vw, 48px);
  display: flex;
  flex-wrap: wrap;
  gap: clamp(24px, 3vw, 48px);
}
.test-stats li {
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.test-stat__num {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 6vw, 64px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
}
.test-stat__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
}

.test-hero__cta {
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
}
.test-hero__note {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-faint);
  max-width: 30ch;
}

/* Three steps */
.test-steps {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(240px, 1fr));
  gap: clamp(16px, 2vw, 24px);
  margin-top: clamp(28px, 3.5vw, 44px);
}
.test-step {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(20px, 2.4vw, 28px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
}
.test-step__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-deep);
}
.test-step__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-lg);
  line-height: 1.15;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  margin: 0;
}
.test-step__text {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}

/* CEFR levels */
.test-levels {
  margin: clamp(28px, 3.5vw, 44px) 0 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(320px, 1fr));
  gap: 0;
  border-top: 1px solid rgba(11, 15, 26, 0.1);
}
.test-level {
  display: grid;
  grid-template-columns: minmax(180px, 240px) 1fr;
  gap: clamp(16px, 2vw, 32px);
  padding: clamp(16px, 2vw, 24px) clamp(12px, 1.6vw, 20px);
  border-bottom: 1px solid rgba(11, 15, 26, 0.1);
  align-items: start;
}
.test-level dt {
  font-family: var(--font-display);
  font-size: var(--text-base);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  display: flex;
  align-items: center;
  gap: 12px;
}
.test-level__code {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 40px;
  padding: 4px 10px;
  background: var(--amber);
  color: var(--ink);
  border-radius: var(--radius-sm, 6px);
  font-family: var(--font-display);
  font-size: var(--text-sm);
  font-weight: 600;
  letter-spacing: 0;
}
.test-level dd {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}

/* Two-column layout on wider viewports */
@media (min-width: 900px) {
  .test-levels {
    grid-template-columns: 1fr 1fr;
    column-gap: clamp(32px, 4vw, 72px);
  }
}

/* Mobile stacking for levels */
@media (max-width: 520px) {
  .test-level {
    grid-template-columns: 1fr;
    gap: 6px;
  }
}

/* /test/start — inert "soon" page */
.test-soon {
  min-height: 60vh;
  display: flex;
  align-items: center;
}
.test-soon__head {
  max-width: 22ch;
}
.test-soon__lede {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 54ch;
  margin: clamp(16px, 2vw, 24px) 0;
}

/* =============================================================
   AUDIENCE PAGE (/for-self, /for-kid, /for-company)
============================================================= */

/* Thicker amber progress bar with a soft glow */
.scroll-progress {
  position: fixed;
  top: 0;
  left: 0;
  height: 3px;
  width: 0%;
  background: linear-gradient(90deg, var(--amber-warm), var(--amber));
  box-shadow: 0 0 10px rgba(245, 184, 46, 0.55),
              0 0 22px rgba(245, 184, 46, 0.3);
  z-index: 100;
  transition: width 60ms linear;
  pointer-events: none;
}

/* ============================================================
   AUDIENCE HERO — owns a full viewport, full-bleed background image
============================================================ */
.audience-hero {
  position: relative;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  justify-content: center;
  padding-top: clamp(96px, 14vh, 140px);
  padding-bottom: clamp(64px, 10vh, 96px);
  overflow: hidden;
  isolation: isolate;
}
.audience-hero .page-section__inner {
  width: 100%;
}

/* Full-bleed background image */
.audience-hero__bg {
  position: absolute;
  inset: 0;
  z-index: -2;
  pointer-events: none;
  display: block;
}
.audience-hero__bg img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  object-position: center center;
  display: block;
}

/* Gradient veil — warm paper on the left fading transparent on the right.
   Carefully tuned: strong on text side for legibility but not so opaque
   that the teal book spines (brand-matching) are completely hidden. */
.audience-hero__veil {
  position: absolute;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background:
    linear-gradient(
      to right,
      rgba(250, 247, 242, 0.96) 0%,
      rgba(250, 247, 242, 0.88) 30%,
      rgba(250, 247, 242, 0.55) 55%,
      rgba(250, 247, 242, 0.15) 80%,
      rgba(250, 247, 242, 0) 100%
    );
}

/* Hero headline */
.audience-hero__head {
  max-width: 18ch;
}
.audience-hero__sub {
  font-family: var(--font-body);
  font-size: var(--text-lg);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  max-width: 52ch;
  margin: 0 0 clamp(32px, 4vw, 56px);
}

/* Word-by-word reveal on headline (triggered by .is-ready on parent) */
.js .audience-hero__head .word {
  display: inline-block;
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 650ms var(--ease-out),
              transform 650ms var(--ease-out);
  transition-delay: calc(var(--i, 0) * 70ms);
}
.js .audience-hero.is-ready .audience-hero__head .word {
  opacity: 1;
  transform: translateY(0);
}
.js .audience-hero__sub {
  opacity: 0;
  transform: translateY(10px);
  transition: opacity 600ms var(--ease-out) 500ms,
              transform 600ms var(--ease-out) 500ms;
}
.js .audience-hero.is-ready .audience-hero__sub {
  opacity: 1;
  transform: translateY(0);
}

/* Mobile: image dominates the top, veil clears the text area below */
@media (max-width: 720px) {
  .audience-hero {
    padding-top: 0;
  }
  .audience-hero__bg img {
    object-position: center 85%;
  }
  .audience-hero__veil {
    background:
      linear-gradient(
        to bottom,
        rgba(250, 247, 242, 0) 0%,
        rgba(250, 247, 242, 0) 22%,
        rgba(250, 247, 242, 0.5) 32%,
        rgba(250, 247, 242, 0.92) 42%,
        rgba(250, 247, 242, 0.98) 55%,
        rgba(250, 247, 242, 1) 100%
      );
  }
  /* Push hero content down so image can breathe on top */
  .audience-hero .page-section__inner {
    padding-top: clamp(180px, 32vh, 280px);
  }
}

/* Shortcut cards — container */
.audience-shortcuts {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: clamp(12px, 1.5vw, 18px);
  margin-top: clamp(20px, 2.5vw, 32px);
  perspective: 1200px;
}

/* Each card — intro entrance (fans in from below-right with stagger) */
.ashortcut {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding: clamp(20px, 2.2vw, 28px);
  background: var(--paper-warm);
  border: 1px solid rgba(11, 15, 26, 0.08);
  border-radius: var(--radius-lg);
  color: var(--ink);
  will-change: transform;
  transition: transform 350ms var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
}
.js .ashortcut {
  opacity: 0;
  transform: translateY(28px) translateX(12px) rotate(1.5deg);
  transition: opacity 700ms var(--ease-out),
              transform 700ms var(--ease-out),
              border-color var(--dur-base) var(--ease-out),
              background var(--dur-base) var(--ease-out),
              box-shadow var(--dur-base) var(--ease-out);
  transition-delay: calc(var(--i, 0) * 100ms + 900ms);
}
.js .audience-hero.is-ready .ashortcut {
  opacity: 1;
  transform: translateY(0) translateX(0) rotate(0);
}

/* Hover tilt — a very small physical feel */
.ashortcut:hover {
  transform: translateY(-4px) rotate(-0.4deg);
  border-color: var(--amber-warm);
  background: var(--paper);
  box-shadow: 0 16px 32px -16px rgba(11, 15, 26, 0.22),
              0 4px 10px -6px rgba(11, 15, 26, 0.08);
}

/* Press pulse on click (short ring of amber that expands and fades) */
.ashortcut::after {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  box-shadow: 0 0 0 0 rgba(245, 184, 46, 0.4);
  pointer-events: none;
  transition: box-shadow 600ms var(--ease-out);
}
.ashortcut.is-pressed::after {
  box-shadow: 0 0 0 14px rgba(245, 184, 46, 0);
  transition: box-shadow 600ms var(--ease-out);
}

.ashortcut__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-deep);
}
.ashortcut__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.2;
  margin-top: 4px;
}
.ashortcut__desc {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-soft);
  margin-top: 6px;
}
.ashortcut__arrow {
  position: absolute;
  top: clamp(20px, 2.2vw, 28px);
  right: clamp(20px, 2.2vw, 28px);
  font-family: var(--font-display);
  font-size: var(--text-lg);
  color: var(--ink-faint);
  transition: transform var(--dur-base), color var(--dur-base);
}
.ashortcut:hover .ashortcut__arrow {
  transform: translateY(3px);
  color: var(--amber-warm);
}

/* Reduced-motion: skip all entrance animations, show content immediately */
@media (prefers-reduced-motion: reduce) {
  .js .audience-hero__head .word,
  .js .audience-hero__sub,
  .js .ashortcut {
    opacity: 1 !important;
    transform: none !important;
    transition: none !important;
  }
}

/* Offer section: 4 format cards */
.offer-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: clamp(16px, 2vw, 24px);
  margin-top: clamp(28px, 3.5vw, 44px);
}
.offer-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(22px, 2.4vw, 32px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  transition: transform var(--dur-base), box-shadow var(--dur-base);
}
.offer-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.offer-card__tag {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--amber-deep);
  margin: 0;
}
.offer-card__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.2;
  margin: 0;
}
.offer-card__text {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}
.offer-card__meta {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  color: var(--ink-faint);
  margin: 8px 0 0;
  padding-top: 10px;
  border-top: 1px dashed rgba(11, 15, 26, 0.1);
}

/* Course tables */
.course-block {
  margin-top: clamp(32px, 4vw, 52px);
}
.course-block__head {
  margin: 0 0 clamp(16px, 1.8vw, 24px);
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.course-block__name {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.2;
}
.course-block__lead {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-soft);
}

.course-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-body);
}
.course-table thead th {
  text-align: left;
  padding: 10px 12px;
  font-family: var(--font-body);
  font-size: var(--text-xs);
  font-weight: 500;
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
  border-bottom: 1px solid rgba(11, 15, 26, 0.12);
}
.course-table thead th:nth-child(2),
.course-table thead th:nth-child(3) {
  text-align: right;
}
.course-table tbody td {
  padding: clamp(12px, 1.4vw, 18px) 12px;
  font-family: var(--font-body);
  font-size: var(--text-base);
  color: var(--ink);
  border-bottom: 1px solid rgba(11, 15, 26, 0.08);
  vertical-align: middle;
}
.course-table tbody td:nth-child(2),
.course-table tbody td:nth-child(3) {
  text-align: right;
  font-family: var(--font-display);
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}
.course-table__per {
  color: var(--amber-deep);
}
.course-table tbody tr.is-recommended td {
  background: rgba(245, 184, 46, 0.08);
  font-weight: 500;
}
.course-table__tag {
  display: inline-block;
  margin-left: 10px;
  padding: 3px 10px;
  background: var(--amber);
  color: var(--ink);
  border-radius: var(--radius-pill);
  font-family: var(--font-display);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.5px;
  text-transform: uppercase;
  vertical-align: middle;
}
.course-table tbody tr.is-single td {
  color: var(--ink-soft);
  font-style: italic;
}

/* Exam note */
.course-note {
  margin-top: clamp(32px, 4vw, 56px);
  padding: clamp(20px, 2.4vw, 32px);
  background: var(--paper-warm);
  border-radius: var(--radius-lg);
  border-left: 3px solid var(--amber-warm);
}
.course-note__eyebrow {
  margin: 0 0 8px;
}

/* Commercial terms (freeze + refund) */
.course-terms {
  margin-top: clamp(40px, 5vw, 64px);
  padding: clamp(24px, 3vw, 40px);
  background: var(--ink);
  color: var(--paper);
  border-radius: var(--radius-lg);
}
.course-terms__head {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: 500;
  letter-spacing: var(--track-snug);
  margin: 0 0 clamp(16px, 2vw, 24px);
  color: var(--paper);
}
.course-terms__list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: clamp(12px, 1.5vw, 18px);
  counter-reset: terms;
}
.course-terms__list li {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: rgba(250, 247, 242, 0.82);
  padding-left: 28px;
  position: relative;
  counter-increment: terms;
}
.course-terms__list li::before {
  content: counter(terms, decimal-leading-zero);
  position: absolute;
  left: 0;
  top: 3px;
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber);
}
.course-terms__list strong {
  color: var(--paper);
  font-weight: 600;
}
.course-terms__more {
  margin: clamp(20px, 2.4vw, 28px) 0 0;
  padding-top: clamp(16px, 2vw, 20px);
  border-top: 1px solid rgba(250, 247, 242, 0.15);
  font-family: var(--font-body);
  font-size: var(--text-sm);
}
.course-terms__more a {
  color: var(--amber);
  border-bottom: 1px solid rgba(245, 184, 46, 0.3);
  padding-bottom: 1px;
  transition: border-color var(--dur-fast);
}
.course-terms__more a:hover {
  border-bottom-color: var(--amber);
}

/* Speaking club */
.club-panel {
  margin-top: clamp(28px, 3.5vw, 44px);
  display: grid;
  grid-template-columns: 1fr 280px;
  gap: clamp(24px, 3vw, 48px);
  padding: clamp(28px, 3.2vw, 48px);
  background: var(--paper);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  align-items: center;
}
.club-panel__body {
  max-width: 56ch;
}
.club-panel__body p {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-relaxed);
  color: var(--ink);
  margin: 0 0 14px;
}
.club-panel__body p:last-child { margin-bottom: 0; }
.club-panel__body em {
  font-style: normal;
  color: var(--amber-deep);
  font-weight: 500;
}
.club-panel__note {
  font-size: var(--text-sm) !important;
  color: var(--ink-soft) !important;
  padding-top: 14px;
  border-top: 1px dashed rgba(11, 15, 26, 0.12);
  margin-top: 16px !important;
}
.club-panel__side {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding-left: clamp(20px, 3vw, 40px);
  border-left: 1px solid rgba(11, 15, 26, 0.08);
}
.club-panel__fact {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.club-panel__num {
  font-family: var(--font-display);
  font-size: clamp(28px, 3.5vw, 40px);
  font-weight: 500;
  color: var(--amber-warm);
  letter-spacing: -0.02em;
  line-height: 1;
}
.club-panel__label {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
}

/* Why us — stats row */
.why-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: clamp(20px, 2.5vw, 40px);
  margin: clamp(32px, 4vw, 52px) 0 clamp(32px, 4vw, 56px);
  padding: clamp(24px, 3vw, 36px) 0;
  border-top: 1px solid rgba(11, 15, 26, 0.1);
  border-bottom: 1px solid rgba(11, 15, 26, 0.1);
}
.why-stat {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.why-stat__num {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: clamp(40px, 5vw, 64px);
  line-height: 1;
  letter-spacing: -0.03em;
  color: var(--ink);
  font-variant-numeric: tabular-nums;
}
.why-stat__label {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  color: var(--ink-soft);
  max-width: 20ch;
}

/* Why us — pillars grid */
.why-pillars {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: clamp(16px, 2vw, 28px);
}
.why-pillar {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: clamp(22px, 2.4vw, 32px);
  background: var(--paper-warm);
  border-radius: var(--radius-lg);
}
.why-pillar__num {
  font-family: var(--font-display);
  font-size: var(--text-xs);
  font-weight: 600;
  letter-spacing: var(--track-wide);
  color: var(--amber-deep);
}
.why-pillar__title {
  font-family: var(--font-display);
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--ink);
  letter-spacing: var(--track-snug);
  line-height: 1.2;
  margin: 0;
}
.why-pillar__text {
  font-family: var(--font-body);
  font-size: var(--text-sm);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}
.why-pillar__text a {
  color: var(--teal-deep);
  border-bottom: 1px solid rgba(15, 127, 119, 0.35);
  padding-bottom: 1px;
}
.why-pillar__text a:hover {
  border-bottom-color: var(--teal-deep);
}

/* Mobile: club panel stacks */
@media (max-width: 800px) {
  .club-panel {
    grid-template-columns: 1fr;
    gap: 24px;
  }
  .club-panel__side {
    padding-left: 0;
    border-left: 0;
    border-top: 1px solid rgba(11, 15, 26, 0.08);
    padding-top: 20px;
    flex-direction: row;
    flex-wrap: wrap;
    gap: clamp(16px, 4vw, 32px);
  }
}

/* Mobile: course tables turn into card-style blocks */
@media (max-width: 640px) {
  .course-table thead { display: none; }
  .course-table,
  .course-table tbody,
  .course-table tr,
  .course-table td {
    display: block;
    width: 100%;
  }
  .course-table tbody tr {
    padding: 14px 0;
    border-bottom: 1px solid rgba(11, 15, 26, 0.08);
    display: grid;
    grid-template-columns: 1fr auto;
    gap: 4px 12px;
    align-items: baseline;
  }
  .course-table tbody tr.is-recommended {
    padding: 14px 12px;
    background: rgba(245, 184, 46, 0.08);
    border-radius: var(--radius-md);
  }
  .course-table tbody td {
    padding: 0;
    border: 0;
    text-align: left !important;
  }
  .course-table tbody td:first-child {
    grid-column: 1 / 3;
    font-family: var(--font-display);
    font-weight: 500;
  }
  .course-table tbody td:nth-child(2) {
    grid-column: 1;
    color: var(--ink-soft);
    font-size: var(--text-sm);
  }
  .course-table tbody td:nth-child(2)::before {
    content: 'онлайн';
    color: var(--ink-faint);
    font-size: var(--text-xs);
    letter-spacing: var(--track-wide);
    text-transform: uppercase;
  }
  .course-table tbody td:nth-child(3) {
    grid-column: 2;
    text-align: right !important;
    font-size: var(--text-lg);
  }
}

/* Why us — hero row: [img_online] [text pillar] [img_offline] */
.why-hero {
  display: grid;
  grid-template-columns: 1fr 1.4fr 1fr;
  gap: clamp(16px, 2vw, 28px);
  margin: clamp(32px, 4vw, 52px) 0 clamp(24px, 3vw, 40px);
  align-items: stretch;
}
.why-hero__image {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.why-hero__image picture,
.why-hero__image img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  aspect-ratio: 4 / 5;
  border-radius: var(--radius-lg);
  box-shadow: 0 16px 40px -18px rgba(11, 15, 26, 0.22),
              0 4px 12px -6px rgba(11, 15, 26, 0.08);
}
.why-hero__image figcaption {
  font-family: var(--font-body);
  font-size: var(--text-xs);
  letter-spacing: var(--track-wide);
  text-transform: uppercase;
  color: var(--ink-faint);
  text-align: center;
}
.why-hero__pillar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: clamp(24px, 2.8vw, 36px);
  background: var(--paper-warm);
  border-radius: var(--radius-lg);
  align-self: center;
}
.why-hero__title {
  font-family: var(--font-display);
  font-weight: 500;
  font-size: var(--text-2xl);
  line-height: 1.15;
  letter-spacing: var(--track-snug);
  color: var(--ink);
  margin: 4px 0 0;
  max-width: 18ch;
}
.why-hero__title em {
  font-style: normal;
  color: var(--amber-deep);
  font-weight: 500;
}
.why-hero__text {
  font-family: var(--font-body);
  font-size: var(--text-base);
  line-height: var(--lead-normal);
  color: var(--ink-soft);
  margin: 0;
}

/* Tablet & smaller: stack into single column (img → pillar → img reading order) */
@media (max-width: 900px) {
  .why-hero {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .why-hero__image picture,
  .why-hero__image img {
    aspect-ratio: 16 / 10;
    max-height: 360px;
  }
  .why-hero__pillar {
    padding: clamp(20px, 4vw, 28px);
  }
}
