:root{
    /* base = black */
    --bg:#0a0a0a;
    --bg-2:#131312;
    --bg-3:#1c1c1a;
    --fg:#f1efe9;
    --fg-soft:#c2bfb7;
    --fg-mute:#6f6d66;
    --line:rgba(241,239,233,.14);
    --line-strong:rgba(241,239,233,.32);
    --accent:#ee5728;
    --grad-fill:linear-gradient(180deg, #f6f4ed 0%, #d8d4c9 100%);
    --grad-fill-inv:linear-gradient(180deg, #1c1c1a 0%, #0a0a0a 100%);
    --pad:clamp(20px, 4vw, 64px);
    --gap-y:clamp(96px, 12vw, 180px);
    --maxw:1680px;
    --photo-filter:grayscale(1) contrast(1.04) brightness(.94);
  }
  *,*::before,*::after{box-sizing:border-box}
  html,body{margin:0;padding:0}
  html{background:var(--bg);scroll-behavior:smooth}
  /* offset for sticky nav when jumping to anchors like #week */
  [id]{scroll-margin-top:80px}
  body{
    background:var(--bg);
    color:var(--fg);
    font-family:"Inter",ui-sans-serif,system-ui,-apple-system,Segoe UI,Helvetica,Arial,sans-serif;
    font-size:16px;
    line-height:1.5;
    -webkit-font-smoothing:antialiased;
    text-rendering:optimizeLegibility;
    overflow-x:hidden;
  }
  body.light{
    --bg:#f1eee7;
    --bg-2:#e9e5dc;
    --bg-3:#dfdbd0;
    --fg:#0a0a0a;
    --fg-soft:#3a3a36;
    --fg-mute:#7a766c;
    --line:rgba(10,10,10,.14);
    --line-strong:rgba(10,10,10,.32);
    --grad-fill:linear-gradient(180deg, #1c1c1a 0%, #0a0a0a 100%);
    --grad-fill-inv:linear-gradient(180deg, #f6f4ed 0%, #d8d4c9 100%);
  }
  body.color  { --photo-filter:contrast(1.04) saturate(.92) brightness(1); }
  body.compact{ --gap-y:clamp(64px, 8vw, 120px); }
  body.comfy  { --gap-y:clamp(128px, 16vw, 240px); }

  /* type */
  .display{
    font-family:"Inter Tight","Inter",ui-sans-serif,system-ui,sans-serif;
    font-weight:800;
    letter-spacing:-.025em;
    line-height:.92;
  }
  .display-x{ letter-spacing:-.035em; font-weight:900; }
  .mono{
    font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;
    font-size:11px;letter-spacing:.08em;text-transform:uppercase;
    font-weight:500;
  }
  .label{
    font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;
    font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--fg-mute); font-weight:500;
  }
  .num{font-family:"JetBrains Mono",ui-monospace,Menlo,monospace;font-feature-settings:"tnum"}

  a{color:inherit;text-decoration:none}
  button{font:inherit;color:inherit;background:none;border:0;cursor:pointer}
  img{display:block;max-width:100%}

  /* layout */
  .wrap{max-width:var(--maxw);margin:0 auto;padding-left:var(--pad);padding-right:var(--pad)}
  hr.rule{border:0;border-top:1px solid var(--line);margin:0}

  /* shared section */
  .sec{padding-top:var(--gap-y); padding-bottom:0}
  .sec-head{
    display:grid; grid-template-columns:140px 1fr 1fr; gap:32px;
    align-items:end; margin-bottom:56px;
    padding-bottom:24px; border-bottom:1px solid var(--fg);
  }
  .sec-head .idx{ padding-bottom:6px; color:var(--fg) }
  .sec-head h2{
    font-family:"Inter Tight",sans-serif; font-weight:800;
    font-size:clamp(48px, 7.4vw, 124px);
    line-height:.92; letter-spacing:-.04em;
    margin:0;
  }
  .sec-head .lede{font-size:16px;color:var(--fg-soft);max-width:42ch;line-height:1.5;padding-bottom:10px}

  /* nav */
  .nav{
    position:sticky; top:0; z-index:50;
    background:color-mix(in oklab, var(--bg) 88%, transparent);
    -webkit-backdrop-filter:saturate(140%) blur(14px);
    backdrop-filter:saturate(140%) blur(14px);
    border-bottom:1px solid var(--line);
  }
  .nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
  .brand{display:flex;align-items:center;gap:12px;font-family:"Inter Tight";font-weight:800;font-size:18px;letter-spacing:-.02em}
  .brand .brand-logo{
    height:28px; width:auto; display:block;
    /* Logo is white-on-black PNG — invert when site is in light mode */
  }
  body.light .brand .brand-logo{ filter:invert(1) }
  .brand .mark{
    width:26px;height:26px;border:1.25px solid var(--fg);border-radius:50%;
    display:grid;place-items:center;font-family:"Inter Tight";font-size:11px;letter-spacing:-.02em;
    transform:translateY(-1px);font-weight:800;
  }
  .nav-links{display:flex;gap:28px}
  .nav-links a{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-soft);font-weight:500}
  .nav-links a:hover{color:var(--fg)}
  .cta{
    display:inline-flex;align-items:center;gap:10px;
    background:var(--fg);color:var(--bg);
    padding:11px 18px;border-radius:999px;
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;font-weight:500;
    transition:transform .2s ease, background .2s ease, color .2s ease;
  }
  .cta:hover{transform:translateY(-1px)}
  .cta .arrow{display:inline-block;transition:transform .2s ease}
  .cta:hover .arrow{transform:translateX(3px)}
  .cta.accent{background:var(--grad-fill);color:var(--bg)}
  body.accent .cta.accent{background:var(--accent);color:#fff}
  .cta.ghost{background:transparent;color:var(--fg);border:1px solid var(--line-strong);padding:10px 17px}

  /* hero — editorial column grid */
  .hero{
    padding-top:24px; padding-bottom:24px;
  }

  /* brand-forward hero — calmer, editorial */
  .hero-brand{padding-bottom:0}
  .hero-brand-stack{
    padding:clamp(48px,8vw,120px) 0 clamp(40px,6vw,88px);
    display:grid;
    grid-template-columns: 1fr auto;
    gap:0 clamp(32px,5vw,80px);
    align-items:end;
    border-bottom:1px solid var(--line);
    position:relative;
  }
  .hero-brand-topline{
    grid-column:1 / -1;
    display:flex;justify-content:space-between;align-items:flex-start;
    padding-bottom:24px;
    color:var(--fg-mute);
  }

  .hero-wordmark{
    margin:0;
    font-family:"Inter Tight";font-weight:900; font-style:italic;
    line-height:.86;letter-spacing:-.055em;text-transform:uppercase;
    font-size:clamp(80px, 14vw, 240px);
    display:flex;align-items:baseline;gap:.08em;
    color:var(--fg);
  }
  .hero-wordmark .line-1{display:inline-block}
  .hero-wordmark .line-2{
    display:inline-flex;align-items:baseline;
    font-size:.92em;
  }
  .hero-wordmark .line-2 .dot{color:var(--fg-mute);font-style:normal;margin-left:.05em}
  body.accent .hero-wordmark .line-2 .dot{color:var(--accent)}

  /* vertical year on the right — atmospheric mark */
  .hero-year{
    align-self:end;
    display:flex;flex-direction:column;align-items:flex-end;gap:14px;
    padding-bottom:14px;
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--fg-mute);text-align:right;
  }
  .hero-year .y{
    font-family:"Inter Tight";font-weight:700;font-style:italic;
    font-size:clamp(36px,4vw,64px);letter-spacing:-.03em;line-height:1;
    color:var(--fg);
  }

  .hero-tag{
    grid-column:1 / -1;
    display:flex;align-items:center;gap:18px;flex-wrap:wrap;
    margin-top:28px;
    padding:16px 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line);
    font-family:"Inter Tight";font-weight:600;font-size:clamp(14px,1.5vw,20px);
    letter-spacing:-.005em;line-height:1;
    color:var(--fg-soft);text-transform:uppercase;
  }
  .hero-tag b{color:var(--fg);font-weight:700;letter-spacing:-.005em}
  .hero-tag .sep{color:var(--line-strong);font-weight:400}

  .hero-brand-foot{
    grid-column:1 / -1;
    display:grid;grid-template-columns:1.4fr 1fr;gap:32px;align-items:end;
    margin-top:24px;
  }
  .hero-brand-foot .lede{
    margin:0;max-width:54ch;font-size:16px;line-height:1.55;color:var(--fg-soft);
  }
  .hero-brand-foot .ctas{
    display:flex;gap:12px;flex-wrap:wrap;justify-content:flex-end;
  }

  @media (max-width:980px){
    .hero-brand-stack{grid-template-columns:1fr;gap:18px}
    .hero-year{align-items:flex-start;text-align:left;padding-bottom:0}
    .hero-brand-foot{grid-template-columns:1fr;align-items:start}
    .hero-brand-foot .ctas{justify-content:flex-start}
  }

  .hero-top{
    display:grid; grid-template-columns:1.6fr 1fr 1fr 1fr; gap:0;
    border-top:1px solid var(--fg); border-bottom:1px solid var(--line);
    padding:14px 0;
  }
  .hero-top > div{padding:0 22px;border-left:1px solid var(--line)}
  .hero-top > div:first-child{padding-left:0;border-left:0}
  .hero-top .l{display:block;color:var(--fg-mute);font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:4px}
  .hero-top .v{display:block;color:var(--fg);font-family:"Inter";font-size:13.5px;line-height:1.35}

  .hero-grid{
    display:grid;
    grid-template-columns:1fr 1fr 1fr 1fr;
    gap:0;
    align-items:stretch;
    min-height:clamp(420px, 56vw, 660px);
    border-bottom:1px solid var(--line);
  }
  /* simpler hero: drop the photo column, expand main */
  .hero-grid.hero-simple{
    grid-template-columns:3fr 1fr;
    min-height:clamp(360px, 44vw, 540px);
  }
  .hero-grid.hero-simple .hero-main{grid-column:span 1}
  .hero-col{
    border-left:1px solid var(--line);
    padding:24px 22px;
    display:flex; flex-direction:column;
    min-height:0;
  }
  .hero-col:first-child{border-left:0;padding-left:0}
  .hero-col.accent-fill{
    background:var(--grad-fill); color:var(--bg);
    border-left-color:transparent;padding:24px 22px;position:relative;overflow:hidden;
  }
  body.accent .hero-col.accent-fill{background:linear-gradient(180deg, #ee5728 0%, #c43d12 100%); color:#fff}
  .hero-col.accent-fill .stamp{
    font-family:"Inter Tight";font-weight:900;font-size:clamp(80px,12vw,180px);line-height:.84;
    letter-spacing:-.05em; color:inherit;
    margin-top:auto;
  }
  .hero-col.accent-fill .stamp-small{font-family:"JetBrains Mono";font-size:10px;letter-spacing:.2em;text-transform:uppercase;margin-bottom:auto;opacity:.78}

  .hero-photo{
    border-left:1px solid var(--line);
    position:relative; overflow:hidden; background:#000;
  }
  .hero-photo > img{
    position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
    filter:var(--photo-filter);
  }
  .hero-photo .pmeta{
    position:absolute; left:14px; bottom:12px;
    font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;color:#f1efe9;
    text-shadow:0 1px 8px rgba(0,0,0,.5);text-transform:uppercase;z-index:2;
  }

  .hero-main{
    display:flex;flex-direction:column;justify-content:space-between;gap:24px;
    grid-column:span 2;
  }
  .hero-main .topline{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;color:var(--fg-mute)}
  .hero-main h1{
    margin:0;
    font-family:"Inter Tight";font-weight:800;
    font-size:clamp(64px, 8.6vw, 168px);
    line-height:.86;
    letter-spacing:-.045em;
  }
  .hero-main h1 .dot{color:var(--fg-mute)}
  body.accent .hero-main h1 .dot{color:var(--accent)}
  .hero-main .lede{font-size:17px;line-height:1.45;max-width:42ch;color:var(--fg-soft)}
  .hero-main .ctas{display:flex;gap:12px;flex-wrap:wrap}

  /* hero bottom strip */
  .hero-bottom{
    display:grid;grid-template-columns:repeat(4, 1fr); gap:0;
    border-top:1px solid var(--line); border-bottom:1px solid var(--fg);
    padding:18px 0;
  }
  .hero-bottom > div{padding:0 22px; border-left:1px solid var(--line)}
  .hero-bottom > div:first-child{padding-left:0;border-left:0}
  .hero-bottom .l{display:block;color:var(--fg-mute);font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;margin-bottom:6px}
  .hero-bottom .v{display:block;color:var(--fg);font-family:"Inter Tight";font-weight:700;font-size:22px;letter-spacing:-.02em;line-height:1.05}
  .hero-bottom .v small{font-family:"Inter";font-weight:500;font-size:11px;color:var(--fg-mute);margin-left:4px;letter-spacing:0}

  /* ticker */
  .ticker{overflow:hidden; padding:18px 0; border-bottom:1px solid var(--line)}
  .ticker-track{
    display:flex;gap:48px;white-space:nowrap;
    font-family:"Inter Tight";font-weight:800;
    font-size:clamp(36px,5.6vw,76px); line-height:1;
    letter-spacing:-.03em; text-transform:uppercase;
    animation:tick 48s linear infinite; will-change:transform;
  }
  .ticker-track > span{display:inline-flex;align-items:center;gap:48px;color:var(--fg)}
  .ticker-track .dot{display:inline-block;width:12px;height:12px;border-radius:50%;background:var(--fg)}
  .ticker-track .red{color:var(--fg-mute)}
  body.accent .ticker-track .red{color:var(--accent)}
  @keyframes tick{from{transform:translateX(0)} to{transform:translateX(-50%)}}

  /* the family — full-bleed group photo */
  .thefamily{
    padding-top:var(--gap-y);
    padding-bottom:0;
  }
  .tf-meta{
    max-width:var(--maxw);margin:0 auto;
    padding:0 var(--pad);
    display:flex;justify-content:space-between;
    padding-bottom:14px;
    border-bottom:1px solid var(--fg);
    margin-bottom:0;
  }
  .tf-label{
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;
    color:var(--fg);
  }
  .tf-figure{
    margin:0;
    position:relative;
    overflow:hidden;
    background:#0a0a0a;
    /* full-bleed — break out of the wrap padding */
    width:100%;
    aspect-ratio: 16 / 7;
    max-height:80vh;
  }
  .tf-figure > img{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover; object-position:center 50%;
    filter:var(--photo-filter, grayscale(1) contrast(1.06) brightness(.95));
    transition:transform 1.2s cubic-bezier(.2,.7,.2,1);
  }
  .reveal.in .tf-figure > img{ transform:scale(1.0); }
  .reveal:not(.in) .tf-figure > img{ transform:scale(1.04); }
  .tf-figure:hover > img{ transform:scale(1.01); }
  body.color .tf-figure > img{
    filter:contrast(1.06) saturate(.9) brightness(.95);
  }

  .tf-scrim{
    position:absolute;inset:0;
    background:linear-gradient(180deg,
      rgba(0,0,0,.38) 0%,
      rgba(0,0,0,0) 22%,
      rgba(0,0,0,0) 58%,
      rgba(0,0,0,.55) 100%);
    pointer-events:none;
  }
  .tf-tag{
    position:absolute;
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;
    color:#f1efe9; text-shadow:0 1px 8px rgba(0,0,0,.55);
    z-index:2;
  }
  .tf-tag.tl{top:16px;left:22px}
  .tf-tag.tr{top:16px;right:22px;text-align:right}
  .tf-tag.bl{bottom:16px;left:22px}
  .tf-tag.br{bottom:16px;right:22px;text-align:right}

  .tf-caption{
    position:absolute; left:0; right:0;
    bottom:clamp(28px, 6vw, 64px);
    text-align:center; color:#f1efe9;
    z-index:2; pointer-events:none;
  }
  .tf-caption .tf-q{
    display:block;
    font-family:"Inter Tight";font-weight:900;font-style:italic;
    font-size:clamp(28px, 4vw, 64px);
    letter-spacing:-.025em;line-height:1;
    text-shadow:0 2px 16px rgba(0,0,0,.4);
  }
  .tf-caption .tf-s{
    display:block;margin-top:10px;
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.2em;text-transform:uppercase;
    color:rgba(241,239,233,.85);
  }

  @media (max-width:980px){
    .tf-figure{aspect-ratio:4 / 5;max-height:none}
    .tf-caption .tf-q{font-size:32px}
    .tf-tag{font-size:9.5px;letter-spacing:.14em}
  }

  /* ecosystem trio */
  .eco{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:0;
    border-top:1px solid var(--fg); border-bottom:1px solid var(--fg);
  }
  .eco.eco-4{ grid-template-columns:repeat(4, 1fr); }
  .eco-col{
    border-left:1px solid var(--line);
    padding:32px 28px 36px;
    display:flex; flex-direction:column; gap:18px;
    background:var(--bg);
    transition:background .25s ease;
    min-height:380px;
  }
  .eco-col:first-child{border-left:0}
  .eco-col:hover{background:var(--bg-2)}
  .eco-num{display:flex;justify-content:space-between;align-items:center;color:var(--fg-mute)}
  .eco-photo{
    aspect-ratio:4/5; position:relative; overflow:hidden; background:#000;
  }
  .eco-photo > img{width:100%;height:100%;object-fit:cover;filter:var(--photo-filter);transition:transform .8s cubic-bezier(.2,.7,.2,1)}
  .eco-col:hover .eco-photo > img{transform:scale(1.03)}
  .eco-photo .tag{position:absolute;top:12px;left:14px;font-family:"JetBrains Mono";font-size:10px;letter-spacing:.16em;color:#f1efe9;text-shadow:0 1px 6px rgba(0,0,0,.55);text-transform:uppercase;font-weight:500}
  .eco-name{
    font-family:"Inter Tight";font-weight:800;
    font-size:clamp(34px,3.2vw,52px); line-height:.92; letter-spacing:-.04em;
    margin:0;
  }
  .eco-kind{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);margin-top:-8px}
  .eco-blurb{margin:0;font-size:15px;line-height:1.55;color:var(--fg-soft);max-width:32ch}
  .eco-foot{margin-top:auto;display:flex;justify-content:space-between;align-items:center;padding-top:18px;border-top:1px solid var(--line);font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg)}
  .eco-foot .arrow{transition:transform .2s ease}
  .eco-col:hover .eco-foot .arrow{transform:translateX(4px)}

  .eco-col.featured{background:var(--grad-fill);color:var(--bg)}
  body.accent .eco-col.featured{background:linear-gradient(180deg, #ee5728 0%, #c43d12 100%);color:#fff}
  .eco-col.featured .eco-num,
  .eco-col.featured .eco-kind,
  .eco-col.featured .eco-foot{color:color-mix(in oklab, var(--bg) 60%, transparent)}
  body.accent .eco-col.featured .eco-num,
  body.accent .eco-col.featured .eco-kind,
  body.accent .eco-col.featured .eco-foot{color:rgba(255,255,255,.72)}
  .eco-col.featured .eco-blurb{color:color-mix(in oklab, var(--bg) 85%, transparent)}
  body.accent .eco-col.featured .eco-blurb{color:rgba(255,255,255,.92)}
  .eco-col.featured .eco-foot{border-top-color:color-mix(in oklab, var(--bg) 30%, transparent)}
  body.accent .eco-col.featured .eco-foot{border-top-color:rgba(255,255,255,.28)}
  .eco-col.featured:hover{filter:brightness(.96)}

  /* the week */
  .week{
    display:grid; grid-template-columns:1fr 1fr; gap:0;
    border-top:1px solid var(--fg); border-bottom:1px solid var(--fg);
  }
  .week-list{display:flex;flex-direction:column}
  .week-row{
    display:grid;grid-template-columns:40px 1fr 110px 80px;gap:18px;align-items:center;
    padding:22px 24px;
    border-bottom:1px solid var(--line);
    transition:background .2s ease, padding .2s ease;
    color:inherit;
  }
  .week-row:last-child{border-bottom:0}
  .week-row:hover{background:var(--bg-2);padding-left:32px}
  .week-row .idx{font-family:"JetBrains Mono";font-size:11px;color:var(--fg-mute);letter-spacing:.12em}
  .week-row .name{font-family:"Inter Tight";font-weight:700;font-size:clamp(22px,2vw,32px);letter-spacing:-.025em;line-height:1}
  .week-row .min{font-family:"JetBrains Mono";font-size:11px;color:var(--fg-soft);letter-spacing:.1em;text-transform:uppercase}
  .week-row .arrow{justify-self:end;color:var(--fg);transition:transform .2s ease;font-family:"Inter Tight";font-weight:700;font-size:22px}
  .week-row:hover .arrow{transform:translateX(4px);color:var(--fg)}

  .week-feature{position:relative;overflow:hidden;background:#000;border-left:1px solid var(--line);min-height:520px}
  .week-feature > img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;filter:var(--photo-filter)}
  .week-feature .meta{position:absolute;left:18px;bottom:16px;color:#f1efe9;font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.55)}
  .week-feature .stamp{position:absolute;right:18px;top:18px;color:#f1efe9;font-family:"JetBrains Mono";font-size:10px;letter-spacing:.18em;text-transform:uppercase;text-shadow:0 1px 6px rgba(0,0,0,.55);text-align:right}

  /* timetable */
  .tt-legend{
    display:grid; grid-template-columns:repeat(3, 1fr); gap:14px 32px;
    margin-bottom:24px;
    padding:18px 0;
    border-bottom:1px solid var(--line);
  }
  .tt-legend > div{
    display:flex;align-items:center;gap:12px;
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;
    color:var(--fg-soft);
  }
  .tt-legend .swatch{
    width:18px;height:18px;flex:0 0 auto;border-radius:0;
  }
  .swatch.t-upper { background:var(--grad-fill) }
  .swatch.t-lower { background:transparent; border:1px solid var(--fg) }
  .swatch.t-engine{ background:var(--bg-3); border:1px solid var(--line-strong) }
  .swatch.t-full  { background:var(--fg) }
  .swatch.t-run   { background:transparent; border:1px dashed var(--fg) }
  .swatch.t-boxing{ background:var(--bg-2); border:1px solid var(--fg) }

  /* unified grid — every cell aligns to a time column */
  .timetable{
    display:grid;
    border:1px solid var(--line);
    background:var(--bg);
    /* grid-template-columns is set inline so the count can change with the data */
  }

  /* mobile: switch to a stacked day-by-day list — no horizontal scroll */
  @media (max-width:760px){
    .timetable{
      display:block;
      border:0;
    }
    .tt-corner,
    .tt-head{ display:none }
    .tt-day{
      grid-column:1 / -1;
      display:flex !important;
      align-items:baseline;justify-content:space-between;
      padding:14px 18px;
      background:var(--bg-2);
      border:1px solid var(--line);
      border-bottom:0;
      font-family:"Inter Tight";font-weight:800;font-size:15px;letter-spacing:.04em;
      text-transform:uppercase;
    }
    .tt-day::after{
      content:attr(data-day-count);
      font-family:"JetBrains Mono";font-size:10px;letter-spacing:.16em;color:var(--fg-mute);
      font-weight:500;
    }
    .tt-cell{
      display:flex;align-items:center;gap:14px;
      border:1px solid var(--line);
      border-top:0;
      padding:12px 18px;
      min-height:auto;
      justify-content:flex-start;
    }
    .tt-cell.empty{display:none}
    .tt-cell::before{
      content:attr(data-time);
      font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;color:var(--fg-soft);
      min-width:54px;
    }
    .tt-chip{padding:5px 9px;font-size:10px}
  }

  .tt-corner,
  .tt-head{
    background:var(--bg-2);
    padding:14px 12px;
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;
    color:var(--fg-mute); font-weight:500;
    font-variant-numeric:tabular-nums;
    text-align:center;
    border-bottom:1px solid var(--line-strong);
    border-left:1px solid var(--line);
    display:flex;align-items:center;justify-content:center;
  }
  .tt-corner{
    border-left:0; text-align:left; justify-content:flex-start;
    padding-left:24px; color:var(--fg);
  }

  .tt-day{
    background:var(--bg-2);
    padding:18px 24px;
    font-family:"Inter Tight";font-weight:800;font-size:16px;letter-spacing:-.02em;
    color:var(--fg);
    text-transform:uppercase;
    display:flex; align-items:center;
    border-top:1px solid var(--line);
    border-right:1px solid var(--line);
  }

  .tt-cell{
    border-left:1px solid var(--line);
    border-top:1px solid var(--line);
    display:flex; align-items:center; justify-content:center;
    padding:10px;
    min-height:64px;
    transition:background .15s ease;
  }
  .tt-cell.empty{background:transparent}

  .tt-book{
    display:inline-flex;align-items:center;gap:12px;
    padding:10px 16px;
    background:var(--grad-fill); color:var(--bg);
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;
    font-weight:600;
    transition:transform .2s ease, filter .2s ease;
    border:0; cursor:pointer;
  }
  body.accent .tt-book{background:linear-gradient(180deg, #ee5728 0%, #c43d12 100%);color:#fff}
  .tt-book:hover{transform:translateY(-1px);filter:brightness(.96)}
  .tt-book b{font-family:"Inter Tight";font-weight:800;font-size:16px;letter-spacing:-.02em}
  .tt-book .arrow{transition:transform .2s ease}
  .tt-book:hover .arrow{transform:translateX(3px)}

  /* booking modal */
  .book-modal{
    position:fixed; inset:0; z-index:9000;
    display:grid; place-items:center;
    padding:clamp(16px, 3vw, 36px);
  }
  .book-modal-scrim{
    position:absolute; inset:0;
    background:color-mix(in oklab, var(--bg) 70%, transparent);
    -webkit-backdrop-filter:blur(8px); backdrop-filter:blur(8px);
    cursor:pointer;
    animation:bmFade .25s ease;
  }
  .book-modal-card{
    position:relative; z-index:1;
    width:min(100%, 1100px); max-height:calc(100vh - 48px);
    background:var(--bg);
    border:1px solid var(--line-strong);
    display:flex; flex-direction:column;
    animation:bmRise .35s cubic-bezier(.2,.7,.2,1);
    box-shadow:0 30px 80px rgba(0,0,0,.5);
  }
  @keyframes bmFade{ from{opacity:0} to{opacity:1} }
  @keyframes bmRise{ from{opacity:0;transform:translateY(12px)} to{opacity:1;transform:none} }
  .book-modal-head{
    display:flex;justify-content:space-between;align-items:flex-start;
    padding:24px 28px; border-bottom:1px solid var(--line);
  }
  .book-modal-title{
    font-family:"Inter Tight";font-weight:800;font-size:clamp(28px, 3.4vw, 44px);
    letter-spacing:-.03em;line-height:1; margin-top:8px;
  }
  .book-modal-close{
    width:36px;height:36px;display:grid;place-items:center;
    border:1px solid var(--line-strong);background:transparent;color:var(--fg);
    cursor:pointer;transition:background .2s ease, transform .2s ease;
  }
  .book-modal-close:hover{background:var(--bg-2);transform:rotate(90deg)}
  .book-modal-body{
    flex:1 1 auto; overflow:auto;
    padding:20px 28px;
    min-height:380px;
  }
  .book-modal-body #ribbon-schedule{ color:var(--fg) }
  .book-modal-foot{
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
    padding:18px 28px; border-top:1px solid var(--line);
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;
    color:var(--fg-mute);
  }
  .book-modal-foot b{color:var(--fg);font-weight:500;letter-spacing:.14em}

  @media (max-width:980px){
    .book-modal{padding:8px}
    .book-modal-card{max-height:calc(100vh - 16px)}
    .book-modal-head{padding:18px 18px}
    .book-modal-body{padding:14px 18px}
    .book-modal-foot{padding:14px 18px;font-size:10px}
  }

  .tt-chip{
    display:inline-flex;align-items:center;justify-content:center;
    padding:7px 10px; width:100%;
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.06em;
    font-weight:600;text-transform:uppercase;
    white-space:nowrap;
    transition:transform .15s ease;
  }
  .tt-cell:hover .tt-chip{transform:scale(1.03)}
  .tt-chip.t-upper { background:var(--grad-fill); color:var(--bg) }
  .tt-chip.t-lower { background:transparent; color:var(--fg); border:1px solid var(--fg) }
  .tt-chip.t-engine{ background:var(--bg-3); color:var(--fg); border:1px solid var(--line-strong) }
  .tt-chip.t-full  { background:var(--fg); color:var(--bg) }
  .tt-chip.t-run   { background:transparent; color:var(--fg); border:1px dashed var(--fg) }
  .tt-chip.t-boxing{ background:var(--bg-2); color:var(--fg); border:1px solid var(--fg) }

  .tt-foot{
    display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:14px;
    padding:18px 0 0;
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--fg-mute);
  }
  .tt-foot b{color:var(--fg);font-weight:500;letter-spacing:.16em}

  /* receipts */
  .receipts{
    display:grid;grid-template-columns:repeat(3, 1fr);gap:0;
    border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  }
  .receipt{
    padding:32px 28px 28px;
    display:flex;flex-direction:column;gap:22px;
    border-left:1px solid var(--line);
    min-height:340px;
  }
  .receipt:first-child{border-left:0}
  .receipt-head{display:flex;justify-content:space-between;align-items:center}
  .stars{font-size:15px;letter-spacing:.18em;color:var(--fg)}
  body.accent .stars{color:var(--accent)}
  .rid{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;color:var(--fg-mute);text-transform:uppercase}
  .rquote{
    margin:0;font-family:"Inter";font-size:17px;line-height:1.5;color:var(--fg);flex:1;
    font-weight:400; letter-spacing:-.005em;
  }
  .rfoot{display:flex;justify-content:space-between;align-items:flex-end;border-top:1px solid var(--line);padding-top:16px;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase}
  .rfoot .rname{font-family:"Inter Tight";font-weight:700;font-size:14px;letter-spacing:-.01em;text-transform:none}
  .rfoot .rmeta{color:var(--fg-mute);margin-top:3px;font-size:10.5px}

  /* visit / join */
  .visit{
    margin-top:var(--gap-y);
    border-top:1px solid var(--fg);
    background:var(--bg);
    padding:clamp(48px,7vw,96px) 0 0;
  }
  .visit-inner{
    display:grid; grid-template-columns:1.3fr 1fr; gap:0;
    border-bottom:1px solid var(--fg);
  }
  .visit-left{padding:0 var(--pad) 64px;display:flex;flex-direction:column;gap:24px}
  .visit-left h2{
    font-family:"Inter Tight";font-weight:800;
    font-size:clamp(72px,11vw,200px);
    line-height:.86;letter-spacing:-.045em;
    margin:0;
  }
  .visit-left h2 .em{color:var(--fg-mute)}
  body.accent .visit-left h2 .em{color:var(--accent)}
  .visit-left p{max-width:46ch;font-size:17px;line-height:1.5;color:var(--fg-soft);margin:0}
  .visit-left .ctas{display:flex;gap:12px;flex-wrap:wrap;margin-top:8px}

  .visit-right{
    padding:32px var(--pad) 32px 32px;
    border-left:1px solid var(--fg);
    display:flex;flex-direction:column;gap:0;
  }
  .v-row{padding:18px 0;border-bottom:1px solid var(--line);display:flex;flex-direction:column;gap:8px}
  .v-row:first-child{padding-top:0}
  .v-row:last-child{border-bottom:0}
  .v-row .v-l{display:flex;align-items:baseline;justify-content:space-between}
  .v-row .v-label{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute)}
  .v-row .v-val{font-family:"Inter Tight";font-weight:600;font-size:18px;line-height:1.35;letter-spacing:-.01em}
  .hours{display:grid;grid-template-columns:1fr 1fr;gap:8px}
  .hours div{display:flex;justify-content:space-between;font-family:"JetBrains Mono";font-size:11px;color:var(--fg-soft);letter-spacing:.05em;text-transform:uppercase}
  .hours div b{color:var(--fg);font-weight:500}

  /* footer */
  footer{padding:56px var(--pad) 28px; background:var(--bg)}
  footer .foot-inner{max-width:var(--maxw);margin:0 auto;display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:24px;align-items:start}
  footer .mark{font-family:"Inter Tight";font-weight:900;font-size:clamp(96px,14vw,200px);line-height:.84;letter-spacing:-.05em;margin:0}
  footer .foot-logo{
    width:clamp(140px, 22vw, 280px); height:auto; display:block;
  }
  body.light footer .foot-logo{ filter:invert(1) }
  footer .mark .dot{color:var(--fg-mute)}
  body.accent footer .mark .dot{color:var(--accent)}
  footer .col h4{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--fg-mute);margin:0 0 14px;font-weight:500}
  footer .col ul{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
  footer .col li{font-size:14px;color:var(--fg-soft);font-family:"Inter"}
  footer .col li a:hover{color:var(--fg)}
  footer .foot-bot{max-width:var(--maxw);margin:36px auto 0;display:flex;justify-content:space-between;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);border-top:1px solid var(--line);padding-top:18px;font-weight:500}

  /* twogether — event cards */
  .two-events{
    display:grid;grid-template-columns:repeat(2,1fr);gap:0;
    border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  }
  .two-event{
    padding:32px 32px 28px;
    border-left:1px solid var(--line);
    border-top:1px solid var(--line);
    display:flex;flex-direction:column;gap:14px;
    transition:background .2s ease;
  }
  .two-event:nth-child(odd){border-left:0}
  .two-event:nth-child(1),
  .two-event:nth-child(2){border-top:0}
  .two-event:hover{background:var(--bg-2)}
  .two-event-meta{
    display:flex;align-items:baseline;gap:18px;
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;
    color:var(--fg-mute);
    padding-bottom:6px;border-bottom:1px solid var(--line);
  }
  .two-event-num{color:var(--fg-mute)}
  .two-event-date{color:var(--fg)}
  .two-event-time{margin-left:auto;color:var(--fg-soft)}
  .two-event-title{
    font-family:"Inter Tight";font-weight:800;font-size:clamp(32px,3vw,48px);
    line-height:.95;letter-spacing:-.035em;margin:0;
  }
  .two-event-desc{margin:0;font-size:15px;line-height:1.5;color:var(--fg-soft);max-width:42ch}
  .two-event-foot{
    display:flex;justify-content:space-between;align-items:center;gap:14px;flex-wrap:wrap;
    margin-top:auto;padding-top:14px;border-top:1px solid var(--line);
  }
  .two-event-tags{display:flex;gap:6px;flex-wrap:wrap}
  .two-event-tag{
    display:inline-flex;align-items:center;padding:4px 10px;
    border:1px solid var(--line-strong);
    font-family:"JetBrains Mono";font-size:10px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-soft);
  }
  .two-event-where{
    font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute);
  }
  .two-event-cta{
    align-self:flex-start;
    display:inline-flex;align-items:center;gap:10px;
    margin-top:4px;
    font-family:"JetBrains Mono";font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg);
    padding-bottom:4px;border-bottom:1px solid var(--fg);
    transition:gap .2s ease;
  }
  .two-event-cta:hover{gap:14px}

  /* reset — recovery lounge tiles */
  .reset-lounge{
    display:grid;grid-template-columns:repeat(3,1fr);gap:0;
    border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  }
  .reset-tile{
    padding:32px 28px 36px;border-left:1px solid var(--line);
    display:flex;flex-direction:column;gap:18px;min-height:420px;
    transition:background .2s ease;
  }
  .reset-tile:first-child{border-left:0}
  .reset-tile:hover{background:var(--bg-2)}
  .reset-tile .rnum{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.18em;text-transform:uppercase;color:var(--fg-mute);display:flex;justify-content:space-between}
  .reset-tile .icon{
    width:100%;aspect-ratio:5/3;display:grid;place-items:center;
    background:var(--bg-2);border:1px solid var(--line);
    color:var(--fg);
  }
  .reset-tile .icon svg{width:60%;height:60%}
  .reset-tile h3{font-family:"Inter Tight";font-weight:800;font-size:clamp(40px,4vw,60px);letter-spacing:-.04em;line-height:.92;margin:0}
  .reset-tile .temp{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;text-transform:uppercase;color:var(--fg-mute);margin-top:-8px}
  .reset-tile p{margin:0;font-size:14.5px;line-height:1.55;color:var(--fg-soft);max-width:32ch}
  .reset-tile ul{list-style:none;padding:0;margin:auto 0 0;display:flex;flex-direction:column;gap:6px}
  .reset-tile ul li{display:flex;justify-content:space-between;font-family:"JetBrains Mono";font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--fg-soft);border-top:1px dashed var(--line);padding-top:8px}

  /* reset — workshops list */
  .workshops{
    border-top:1px solid var(--fg);border-bottom:1px solid var(--fg);
  }
  .workshop-row{
    display:grid;grid-template-columns:60px 1.4fr 1fr 120px;gap:18px;align-items:center;
    padding:24px;
    border-bottom:1px solid var(--line);
    transition:background .2s ease, padding .2s ease;
  }
  .workshop-row:last-child{border-bottom:0}
  .workshop-row:hover{background:var(--bg-2);padding-left:36px}
  .workshop-row .wnum{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.14em;color:var(--fg-mute);text-transform:uppercase}
  .workshop-row .wname{font-family:"Inter Tight";font-weight:800;font-size:clamp(22px,2.2vw,32px);letter-spacing:-.025em;line-height:1.05}
  .workshop-row .wkind{font-family:"JetBrains Mono";font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg-mute);margin-top:4px}
  .workshop-row .wdesc{font-family:"Inter";font-size:14px;color:var(--fg-soft);line-height:1.5}
  .workshop-row .wdate{font-family:"JetBrains Mono";font-size:11px;letter-spacing:.12em;text-transform:uppercase;color:var(--fg);justify-self:end;text-align:right}

  @media (max-width:980px){
    .two-events{grid-template-columns:1fr}
    .two-event{border-left:0;border-top:1px solid var(--line)}
    .two-event:nth-child(1){border-top:0}
    .two-event:nth-child(2){border-top:1px solid var(--line)}
    .reset-lounge{grid-template-columns:1fr}
    .reset-tile{border-left:0;border-top:1px solid var(--line);min-height:auto}
    .reset-tile:first-child{border-top:0}
    .workshop-row{grid-template-columns:1fr;gap:6px}
    .workshop-row .wdate{justify-self:start;text-align:left}
  }

  /* reveal */
  .reveal{opacity:0;transform:translateY(12px);transition:opacity .7s ease, transform .7s ease}
  .reveal.in{opacity:1;transform:none}

  /* small */
  @media (max-width:980px){
    .nav-links{display:none}
    .hero-top, .hero-bottom{grid-template-columns:1fr 1fr}
    .hero-top > div, .hero-bottom > div{border-left:0;border-top:1px solid var(--line);padding:8px 0}
    .hero-top > div:first-child, .hero-bottom > div:first-child{border-top:0}
    .hero-grid{grid-template-columns:1fr;min-height:auto}
    .hero-col{border-left:0;border-top:1px solid var(--line);padding:24px 0}
    .hero-col:first-child{border-top:0}
    .hero-main{grid-column:auto}
    .hero-photo{min-height:380px;border-left:0;border-top:1px solid var(--line)}
    .sec-head{grid-template-columns:1fr;gap:14px;align-items:start}
    .eco{grid-template-columns:1fr}
    .eco.eco-4{grid-template-columns:1fr}
    .eco-col{border-left:0;border-top:1px solid var(--line);min-height:auto}
    .eco-col:first-child{border-top:0}
    .week{grid-template-columns:1fr}
    .week-feature{border-left:0;border-top:1px solid var(--line);min-height:360px}
    .timetable{display:block;overflow-x:auto;-webkit-overflow-scrolling:touch}
    .timetable .tt-corner,
    .timetable .tt-head,
    .timetable .tt-day,
    .timetable .tt-cell{min-width:88px}
    .tt-legend{grid-template-columns:1fr 1fr;gap:10px 18px}
    .receipts{grid-template-columns:1fr}
    .receipt{border-left:0;border-top:1px solid var(--line);min-height:auto}
    .receipt:first-child{border-top:0}
    .visit-inner{grid-template-columns:1fr}
    .visit-right{border-left:0;border-top:1px solid var(--fg);padding-left:var(--pad)}
    footer .foot-inner{grid-template-columns:1fr 1fr}
  }