/* =========================================================
   Page extras — components used by branch / program pages.
   Layered on top of design-system.css. Editorial-Bold (Var A).
   ========================================================= */

/* Full-bleed photo break — used to give long pages visual rest */
.media-break{position:relative;margin:0;background:#000;overflow:hidden}
.media-break picture,.media-break img{
  width:100%;height:auto;display:block;
  aspect-ratio:21/9;object-fit:cover;object-position:center 30%;
  filter:contrast(1.04) saturate(.95);
  transition:transform 8s var(--ease);
}
.media-break:hover img{transform:scale(1.04)}
@media (max-width:780px){.media-break img{aspect-ratio:4/3;object-position:center 35%}}

/* Optional overlay caption — short, editorial */
.media-break__cap{
  position:absolute;left:var(--gutter);bottom:24px;right:var(--gutter);
  color:var(--c-paper);
  font-family:var(--f-display);font-size:clamp(18px,2vw,28px);
  text-transform:uppercase;line-height:1;letter-spacing:.01em;
  text-shadow:0 2px 16px rgba(0,0,0,.5);
}
.media-break__cap .accent{background:var(--c-accent);color:var(--c-ink);padding:.04em .14em}

/* =========================================================
   Booking form — re-used on inline booking sections + dedicated /book.
   Built with explicit box-sizing, unified heights, and consistent
   widths so 2-column grids align cleanly even with wrapping labels.
   ========================================================= */
.trial-form{
  background:#161616;
  border:1px solid rgba(255,255,255,.08);
  padding:28px;
  color:#fff;
}
/* Inner grid lives inside the form's <div class="grid"> */
.trial-form .grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media (max-width:560px){.trial-form .grid{grid-template-columns:1fr}}

.field{
  display:flex;flex-direction:column;gap:8px;
  min-width:0;                              /* prevents grid blowout */
  font-family:var(--f-mono);
  font-size:12px;font-weight:500;
  letter-spacing:.12em;text-transform:uppercase;
  color:rgba(255,255,255,.72);
}
.field > span{
  display:block;min-height:14px;line-height:1.3;
}

/* Unified input/select baseline */
.field input,
.field select,
.field textarea{
  box-sizing:border-box;
  width:100%;
  height:48px;                              /* unified row height */
  padding:0 14px;
  margin:0;
  font-family:var(--f-body);
  font-size:15px;
  font-weight:400;
  letter-spacing:0;text-transform:none;
  color:#fff;
  background:#0A0A0A;
  border:1px solid rgba(255,255,255,.16);
  border-radius:0;
  outline:none;
  appearance:none;-webkit-appearance:none;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease);
}
.field textarea{
  height:auto;min-height:88px;
  padding:12px 14px;
  resize:vertical;
  line-height:1.5;
}

/* Placeholder + readonly state */
.field input::placeholder,
.field textarea::placeholder{color:rgba(255,255,255,.38)}
.field input:hover,
.field select:hover,
.field textarea:hover{border-color:rgba(255,255,255,.32)}
.field input:focus,
.field select:focus,
.field textarea:focus{
  border-color:var(--c-accent);
  box-shadow:inset 0 0 0 1px var(--c-accent);
}

/* Select arrow — consistently positioned, more visible */
.field select{
  padding-right:38px;cursor:pointer;
  background-image:
    linear-gradient(45deg, transparent 50%, rgba(255,255,255,.85) 50%),
    linear-gradient(135deg, rgba(255,255,255,.85) 50%, transparent 50%);
  background-position: calc(100% - 18px) calc(50% + 1px), calc(100% - 12px) calc(50% + 1px);
  background-size: 7px 7px;
  background-repeat: no-repeat;
}
/* Select option text on dark background */
.field select option{background:#0A0A0A;color:#fff;font-family:var(--f-body)}

/* Submit button — block-level, doesn't fight the grid above it */
.trial-form button[type="submit"]{
  width:100%;margin-top:18px;
  display:flex;align-items:center;justify-content:center;
}
.trial-form .muted{margin-top:10px}

/* Page hero (shared by branch + program pages) — dark backdrop + photo */
.page-hero{
  position:relative;padding:120px var(--gutter) 56px;
  border-bottom:1px solid rgba(255,255,255,.08);
  overflow:hidden;
  background:#0b0b0c;
  color:var(--c-paper);
  isolation:isolate;
}
.page-hero::before{
  content:"";position:absolute;inset:0;z-index:0;
  background-image:url('../img/photos/classroom-01.webp');
  background-size:cover;background-position:center 35%;
  opacity:.55;
}
.page-hero::after{
  content:"";position:absolute;inset:0;z-index:1;
  background:
    linear-gradient(180deg, rgba(11,11,12,.55) 0%, rgba(11,11,12,.45) 35%, rgba(11,11,12,.92) 100%),
    linear-gradient(90deg,  rgba(11,11,12,.65) 0%, rgba(11,11,12,.20) 60%, rgba(11,11,12,.40) 100%);
}
.page-hero__inner{max-width:var(--container);margin:0 auto;position:relative;z-index:2}
.page-hero__crumb{
  font-family:var(--f-mono);font-size:13px;letter-spacing:.18em;text-transform:uppercase;color:rgba(255,255,255,.65);
  margin-bottom:18px;
}
.page-hero__crumb a{color:rgba(255,255,255,.85)}
.page-hero__crumb a:hover{color:var(--c-paper)}
.page-hero__crumb .sep{margin:0 12px;color:rgba(255,255,255,.25)}
.page-hero__title{font-family:var(--f-display);font-size:clamp(40px,6.5vw,96px);line-height:.92;text-transform:uppercase;letter-spacing:-.018em;color:var(--c-paper)}
.page-hero__sub{margin-top:16px;max-width:54ch;font-size:var(--fs-m);line-height:1.45;color:rgba(255,255,255,.85)}
.page-hero__meta{
  margin-top:24px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px;
  padding-top:18px;border-top:1px solid rgba(255,255,255,.18);
}
.page-hero__meta div{display:flex;flex-direction:column;gap:6px}
.page-hero__meta .k{font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:rgba(255,255,255,.6)}
.page-hero__meta .v{font-family:var(--f-display);font-size:var(--fs-m);text-transform:uppercase;line-height:1;color:var(--c-paper)}
@media (max-width:780px){.page-hero{padding-top:100px;padding-bottom:44px}.page-hero__meta{grid-template-columns:1fr 1fr}}

/* Two-up content row */
.two-up{display:grid;grid-template-columns:1.05fr .95fr;gap:clamp(24px,3.5vw,56px);align-items:center}
.two-up.flip{grid-template-columns:.95fr 1.05fr;direction:rtl}
.two-up.flip > *{direction:ltr}
.two-up__media{aspect-ratio:5/4;background:#000 center/cover no-repeat}
@media (max-width:780px){.two-up,.two-up.flip{grid-template-columns:1fr;direction:ltr;gap:24px}}

/* Three-column split — for pages that want denser layouts */
.three-up{display:grid;grid-template-columns:1fr 1fr 1fr;gap:clamp(20px,2.5vw,32px)}
@media (max-width:880px){.three-up{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.three-up{grid-template-columns:1fr}}

/* Side-by-side: heading column + content column (alternative to section-head full-width) */
.side-head{display:grid;grid-template-columns:1fr 2fr;gap:clamp(24px,3.5vw,56px);align-items:start}
.side-head__head h2{font-size:var(--fs-l)}
@media (max-width:780px){.side-head{grid-template-columns:1fr;gap:18px}}

/* Schedule table (branch page) — Term timetable, grouped by level + subject */
.schedule{
  border-top:1px solid var(--c-line);
  display:grid;grid-template-columns:1fr 150px 150px;
  font-size:15px;
}
.schedule__learn{font-family:var(--f-mono);font-size:12px;letter-spacing:.04em}
.schedule__learn .btn-sm{display:inline-flex;width:100%;justify-content:center}
.schedule > div{
  padding:12px 12px;
  border-bottom:1px solid var(--c-line);
  display:flex;align-items:center;
  /* Cells now stretch to the row track height (no align-self:center), so the
     bottom border sits at a single y-position across every column in a row. */
}
.schedule__action{justify-content:flex-end}
.schedule > .schedule__h{display:none}  /* header row hidden — group heads + row content are self-explanatory */
.schedule__group-head{
  grid-column:1/-1;
  font-family:var(--f-display);font-size:18px;letter-spacing:.04em;text-transform:uppercase;
  background:var(--c-ink);color:var(--c-paper);
  padding:14px 16px !important;
  border-bottom:1px solid var(--c-ink);
}
.schedule__when{font-family:var(--f-mono);font-size:13.5px;color:var(--c-ink)}
.schedule__when .day{
  display:inline-block;min-width:36px;
  font-family:var(--f-display);font-size:12px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--c-ink);background:var(--c-paper-2);padding:3px 8px;border-radius:4px;
  margin-right:6px;
}
.schedule__room{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;color:var(--c-mute);text-transform:uppercase}
.schedule__action{text-align:right}

/* Status pill (text-only, color-coded) */
.status{
  display:inline-block;padding:5px 10px;border-radius:999px;
  font-family:var(--f-mono);font-size:10.5px;letter-spacing:.10em;text-transform:uppercase;font-weight:500;
  white-space:nowrap;max-width:100%;
  overflow:hidden;text-overflow:ellipsis;
}
.status--available{background:#ecfdf5;color:#166534;border:1px solid #bbf7d0}
.status--filling{background:#fff7ed;color:#9a3412;border:1px solid #fed7aa}
.status--full{background:#fef2f2;color:#991b1b;border:1px solid #fecaca}

/* Compact inline buttons inside the schedule */
.btn-sm{
  display:inline-flex;align-items:center;gap:4px;
  padding:7px 12px;border-radius:999px;
  font-family:var(--f-display);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  white-space:nowrap;border:1px solid transparent;
  transition:background var(--dur) var(--ease),color var(--dur) var(--ease),border-color var(--dur) var(--ease);
}
.btn--accent-sm{background:var(--c-accent);color:var(--c-accent-ink);border-color:var(--c-accent)}
.btn--accent-sm:hover{background:var(--c-ink);color:var(--c-paper);border-color:var(--c-ink)}
.btn--ghost-sm{background:transparent;color:var(--c-ink);border-color:var(--c-line)}
.btn--ghost-sm:hover{background:var(--c-ink);color:var(--c-paper);border-color:var(--c-ink)}

/* Capacity summary cards (3 buckets: available / filling fast / full) */
.capacity-cards{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;
  margin-bottom:24px;
}
.cap-card{
  padding:18px 20px;border-radius:12px;
  border:1px solid var(--c-line);
  background:var(--c-paper-2);
  display:flex;flex-direction:column;gap:6px;
}
.cap-card__num{font-family:var(--f-display);font-size:42px;line-height:1;letter-spacing:-.02em}
.cap-card__label{font-family:var(--f-mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--c-mute)}
.cap-card--available{background:#ecfdf5;border-color:#bbf7d0;color:#166534}
.cap-card--available .cap-card__label{color:#166534;opacity:.7}
.cap-card--filling{background:#fff7ed;border-color:#fed7aa;color:#9a3412}
.cap-card--filling .cap-card__label{color:#9a3412;opacity:.7}
.cap-card--full{background:#fef2f2;border-color:#fecaca;color:#991b1b}
.cap-card--full .cap-card__label{color:#991b1b;opacity:.7}

@media (max-width:980px){
  .capacity-cards{grid-template-columns:1fr 1fr 1fr;gap:10px}
  .cap-card{padding:14px 16px}
  .cap-card__num{font-size:32px}
}
@media (max-width:780px){
  /* Tablet & phone: drop the per-row Free-trial column. The Learn-more pill
     is the row's primary CTA, sticky-CTA at the bottom handles trial conversion.
     Schedule reduces to When · Learn more — clean at every width. */
  .schedule{grid-template-columns:1fr 150px;font-size:13.5px}
  .schedule > .schedule__h{display:none}
  .schedule > .schedule__action{display:none}
  .schedule__when .day{min-width:auto;padding:2px 6px;font-size:11px}
}
@media (max-width:560px){
  /* Stack capacity cards vertically — each card uses horizontal num + label so
     "FILLING FAST" and "FULL / WAITLIST" labels never crop. */
  .capacity-cards{grid-template-columns:1fr;gap:8px}
  .cap-card{
    flex-direction:row;align-items:baseline;gap:16px;
    padding:14px 18px;
  }
  .cap-card__num{font-size:30px;line-height:1}
  .cap-card__label{font-size:11px;letter-spacing:.12em}
  .schedule{grid-template-columns:1fr 130px}
}
@media (max-width:480px){
  .schedule{grid-template-columns:1fr 115px;font-size:12.5px}
  .schedule > div{padding:10px 8px}
  .status{padding:4px 8px;font-size:10px;letter-spacing:.08em}
}

/* Map block */
.map{
  display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  align-items:stretch;
}
.map__embed{
  background:#eee center/cover no-repeat;
  min-height:420px;
  position:relative;
  display:flex;
}
.map__embed iframe{flex:1 1 auto;width:100%;height:100%;display:block}
.map__addr{
  padding:32px 36px;
  display:flex;flex-direction:column;gap:10px;
  background:var(--c-paper-2);
  justify-content:center;
}
.map__addr .head{font-family:var(--f-display);font-size:var(--fs-l);text-transform:uppercase;line-height:.95;margin-bottom:6px}
.map__addr .row{display:flex;justify-content:space-between;gap:18px;border-bottom:1px solid var(--c-line);padding:10px 0;align-items:flex-start}
.map__addr .row:last-of-type{border-bottom:0}
.map__addr .k{font-family:var(--f-mono);font-size:12px;letter-spacing:.16em;text-transform:uppercase;color:var(--c-mute);flex:0 0 auto}
.map__addr .row > span:last-child{text-align:right;min-width:0}
@media (max-width:780px){
  .map{grid-template-columns:1fr}
  .map__addr{padding:24px;justify-content:flex-start}
  .map__embed{min-height:280px}
}

/* Subject-list grid (program index pages) */
.subj-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:0;border-top:1px solid var(--c-line)}
.subj{
  padding:26px 24px;border-right:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  display:flex;flex-direction:column;gap:12px;min-height:200px;
  background:var(--c-paper);transition:background var(--dur) var(--ease),color var(--dur) var(--ease);
}
.subj:hover{background:var(--c-ink);color:var(--c-paper)}
.subj:hover .subj__arrow{background:var(--c-accent);color:var(--c-ink)}
.subj__lvl{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-mute)}
.subj:hover .subj__lvl{color:var(--c-paper);opacity:.7}
.subj__title{font-family:var(--f-display);font-size:var(--fs-l);text-transform:uppercase;line-height:.94}
.subj__meta{margin-top:auto;display:flex;justify-content:space-between;align-items:center;font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase}
.subj__arrow{width:40px;height:40px;border-radius:50%;background:var(--c-paper-2);color:var(--c-ink);display:inline-flex;align-items:center;justify-content:center;transition:background var(--dur) var(--ease),color var(--dur) var(--ease)}
@media (max-width:880px){.subj-grid{grid-template-columns:1fr 1fr}}
@media (max-width:560px){.subj-grid{grid-template-columns:1fr}}

/* Curriculum / topic list */
.topics{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--c-line)}
.topic{padding:18px 0;display:grid;grid-template-columns:48px 1fr;gap:16px;border-bottom:1px solid var(--c-line)}
.topic .num{font-family:var(--f-mono);font-size:14px;letter-spacing:.16em;color:var(--c-mute)}
.topic .h{font-family:var(--f-display);font-size:var(--fs-m);text-transform:uppercase;line-height:1}
.topic .b{margin-top:6px;color:var(--c-ink-2);font-size:15px;line-height:1.55}
.topics .topic{padding-left:20px;padding-right:20px;border-right:1px solid var(--c-line)}
.topics .topic:nth-child(2n){border-right:0}
@media (max-width:780px){.topics{grid-template-columns:1fr}.topics .topic{border-right:0}}

/* FAQ */
.faq{border-top:1px solid var(--c-line)}
.faq details{border-bottom:1px solid var(--c-line);padding:14px 0}
.faq summary{
  cursor:pointer;display:flex;justify-content:space-between;align-items:center;
  font-family:var(--f-display);font-size:var(--fs-m);text-transform:uppercase;letter-spacing:-.005em;line-height:1.05;
  list-style:none;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{content:"+";font-size:24px;font-weight:400;font-family:var(--f-body);color:var(--c-accent);transition:transform var(--dur) var(--ease)}
.faq details[open] summary::after{transform:rotate(45deg)}
.faq .a{padding:14px 0 0;color:var(--c-ink-2);max-width:80ch;line-height:1.6}
.faq .a a{
  color:var(--c-accent);
  font-weight:600;
  text-decoration:underline;
  text-decoration-thickness:2px;
  text-underline-offset:3px;
  transition:color var(--dur) var(--ease);
}
.faq .a a:hover{color:var(--c-ink);text-decoration-color:var(--c-ink)}

/* Inline mini-CTA card */
.mini-cta{
  background:var(--c-ink);color:var(--c-paper);
  padding:32px;display:flex;justify-content:space-between;align-items:center;gap:24px;flex-wrap:wrap;
}
.mini-cta__h{font-family:var(--f-display);font-size:var(--fs-l);text-transform:uppercase;line-height:.95;margin:0}

/* Pull quote */
.pull{
  padding:36px 0;border-top:1px solid var(--c-line);border-bottom:1px solid var(--c-line);
  display:grid;grid-template-columns:120px 1fr;gap:24px;align-items:start;
}
.pull .lbl{font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--c-mute)}
.pull .body{font-family:var(--f-display);font-size:var(--fs-l);line-height:1.05;text-transform:uppercase;letter-spacing:-.005em}
.pull .attr{margin-top:18px;font-family:var(--f-mono);font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--c-mute)}
@media (max-width:780px){.pull{grid-template-columns:1fr}}

/* =====================================================
   Fees: Single + Bundle 2-card pattern
   ===================================================== */

/* Hero row above the cards: eyebrow + serif italic headline + green trust pill */
.fees-hero{
  display:flex;justify-content:space-between;align-items:flex-end;
  gap:24px;flex-wrap:wrap;margin-bottom:28px;
}
.fees-hero__lhs{flex:1 1 auto;min-width:280px}
.fees-headline{
  font-family:var(--f-display);
  font-weight:900;
  font-size:clamp(32px,4.4vw,56px);
  line-height:.92;letter-spacing:-.01em;
  text-transform:uppercase;
  color:var(--c-ink);
  margin-top:8px;
}
.fees-headline em{
  font-family:var(--f-display);
  font-style:normal;
  font-weight:900;
  color:var(--c-accent);
}
.fees-pill{
  display:inline-flex;align-items:center;gap:8px;
  background:#1f4d3a;color:#fff;
  padding:11px 20px;border-radius:var(--radius-pill);
  font-family:var(--f-mono);font-size:11px;letter-spacing:.14em;text-transform:uppercase;
  font-weight:500;white-space:nowrap;
  flex:0 0 auto;
}

/* Per-level header — only used when a single page lists multiple levels */
.fees-level-head{
  font-family:var(--f-mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
  color:var(--c-mute);margin:24px 0 10px;
}
.fees-level-head:first-child{margin-top:0}

/* The 2-card stack */
.fees-cards{display:grid;gap:14px;margin-bottom:32px}
.fees-cards:last-child{margin-bottom:0}
.fees-card{
  position:relative;
  background:var(--c-paper-2);
  padding:28px 32px;
  display:grid;
  grid-template-columns:1.6fr 1.1fr 1fr auto;
  gap:24px;align-items:center;
  border-radius:8px;
}
.fees-card--bundle{
  background:#f3ece1;
  border:2px solid var(--c-accent);
}
.fees-card__ribbon{
  position:absolute;top:-12px;left:24px;
  background:var(--c-accent);color:#fff;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.12em;text-transform:uppercase;
  padding:6px 12px;border-radius:4px;
  font-weight:600;
}
.fees-card__title{
  font-family:var(--f-display);
  font-size:18px;font-weight:900;color:var(--c-ink);line-height:1.05;
  text-transform:uppercase;letter-spacing:-.005em;
}
.fees-card__sub{
  margin-top:10px;
  font-family:var(--f-body);
  font-size:13.5px;line-height:1.55;color:var(--c-mute);
}
.fees-card__price{
  font-family:var(--f-display);
  font-size:32px;font-weight:900;color:var(--c-ink);line-height:1;
  letter-spacing:-.01em;
}
.fees-card__price-sub{
  margin-top:6px;
  font-family:var(--f-mono);
  font-size:12px;letter-spacing:.04em;color:var(--c-mute);
}
.fees-card__session{
  font-family:var(--f-display);
  font-weight:900;
  font-size:24px;color:var(--c-accent);line-height:1;
  letter-spacing:-.005em;
}
.fees-card__session-label{
  margin-top:6px;
  font-family:var(--f-mono);font-size:11px;letter-spacing:.16em;text-transform:uppercase;
  color:var(--c-mute);
}
.fees-card__cta{
  display:inline-flex;align-items:center;justify-content:center;
  background:var(--c-ink);color:#fff;
  font-family:var(--f-display);font-size:13px;letter-spacing:.08em;text-transform:uppercase;
  padding:14px 22px;border-radius:var(--radius-pill);
  white-space:nowrap;
  transition:transform var(--dur) var(--ease),background var(--dur) var(--ease);
}
.fees-card__cta:hover{transform:translateY(-2px)}
.fees-card--bundle .fees-card__cta{background:var(--c-accent);color:#fff}
.fees-card--bundle .fees-card__cta:hover{background:#d76830}

/* Fineprint paragraph below the cards */
.fees-fineprint{
  margin-top:18px;font-size:13px;line-height:1.6;color:var(--c-mute);
  max-width:80ch;
}

/* Mobile — stack each card's 4 columns into a single column */
@media (max-width:880px){
  .fees-card{
    grid-template-columns:1fr 1fr;
    gap:18px 24px;
    padding:26px 24px;
  }
  .fees-card > :first-child{grid-column:1 / -1}
  .fees-card__cta{grid-column:1 / -1;width:100%;text-align:center}
}
@media (max-width:560px){
  .fees-card{grid-template-columns:1fr;padding:22px 20px;gap:14px}
  .fees-card > :first-child{grid-column:auto}
  .fees-card__price{font-size:28px}
  .fees-card__session{font-size:20px}
  .fees-headline{font-size:30px}
  .fees-pill{font-size:10px;padding:9px 14px;letter-spacing:.1em}
}

/* Util tweaks */
@media (max-width:880px){
  .cta-panel .grid{grid-template-columns:1fr !important;gap:32px !important}
}
@media (max-width:880px){
  /* Inline `grid-column:span 2` on some fields breaks single-col mobile grid; force auto */
  .trial-form .grid > .field[style*="grid-column"]{grid-column:auto !important}
}
@media (max-width:560px){
  .cta-panel .grid{gap:24px !important}
  .trial-form{padding:20px;min-width:0}
  .trial-form .grid{gap:14px !important}
  .trial-form button[type="submit"]{padding:16px 18px;font-size:15px}
  .field input,.field select,.field textarea{font-size:16px}  /* iOS won't auto-zoom on focus when ≥16px */
}
