/* ============================================================
   Uplift Fitness Boutique — design "The Timetable" (D1)
   TOKEN-FIRST: reskins (palette/type/radius) happen HERE in the
   :root block and apply site-wide. Structural identity lives in
   the layout partials. See docs/migration-report.md § Theming.
   ============================================================ */

/* ---- self-hosted fonts (latin subset) ---- */
@font-face{
  font-family:"Anton";
  src:url("/assets/fonts/anton.woff2") format("woff2");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Archivo";
  src:url("/assets/fonts/archivo-var.woff2") format("woff2");
  font-weight:100 900;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Space Mono";
  src:url("/assets/fonts/space-mono-400.woff2") format("woff2");
  font-weight:400;font-style:normal;font-display:swap;
}
@font-face{
  font-family:"Space Mono";
  src:url("/assets/fonts/space-mono-700.woff2") format("woff2");
  font-weight:700;font-style:normal;font-display:swap;
}

/* ---- design tokens ---- */
:root{
  --ink:#14110F;
  --paper:#FBFAF7;
  --chalk:#E8E4DC;
  --chalk-line:#D8D2C7;
  --orange:#FF5A1F;        /* fills + decoration */
  --orange-deep:#C2390B;   /* orange as TEXT on paper — AA 5.2:1 */
  --muted:#6B655C;         /* AA 5.5:1 on paper */
  /* effort accents — the "few other colours"; borders/dots decorative,
     dark enough for AA when used as text on paper */
  --fx-gentle:#3E7A44;
  --fx-build:#8F6300;
  --fx-sweat:#C2390B;
  --fx-strong:#B02E24;
  --fx-open:#2E5FA3;
  --fx-kids:#7A4B94;
  --display:"Anton",Impact,"Arial Narrow",sans-serif;
  --body:"Archivo",system-ui,-apple-system,sans-serif;
  --mono:"Space Mono",ui-monospace,monospace;
  --radius:2px;
  --shadow:4px 4px 0 var(--ink);
}

/* ---- base ---- */
*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{background:var(--paper);color:var(--ink);font-family:var(--body);line-height:1.55;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;height:auto;display:block}
.wrap{max-width:1240px;margin:0 auto;padding:0 clamp(16px,4vw,48px)}
:focus-visible{outline:3px solid var(--orange);outline-offset:2px}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
.skip{position:absolute;left:-999px;top:8px;background:var(--ink);color:var(--paper);padding:10px 16px;z-index:100}
.skip:focus{left:12px}

/* ---- type helpers ---- */
.kicker{font-family:var(--mono);font-weight:700;font-size:13px;letter-spacing:.14em;text-transform:uppercase;color:var(--orange-deep)}
.mono{font-family:var(--mono)}

/* ---- header / nav ---- */
header{position:sticky;top:0;z-index:60;background:var(--paper);border-bottom:2px solid var(--ink)}
.nav{display:flex;align-items:center;justify-content:space-between;height:72px;gap:16px}
.logo img{width:110px;height:auto}
.nav .links{display:flex;gap:26px;list-style:none;font-weight:700;font-size:14px;text-transform:uppercase;letter-spacing:.07em}
.nav .links a:hover{color:var(--orange-deep)}
.nav .links a[aria-current="page"]{color:var(--orange-deep);border-bottom:2px solid var(--orange)}
.btn{display:inline-block;background:var(--orange);color:var(--ink);font-weight:800;text-transform:uppercase;letter-spacing:.05em;padding:12px 22px;font-size:15px;border:2px solid var(--ink);border-radius:var(--radius);box-shadow:3px 3px 0 var(--ink);transition:transform .08s,box-shadow .08s;cursor:pointer;font-family:var(--body)}
.btn:hover{transform:translate(-1px,-1px);box-shadow:var(--shadow)}
.btn.lg{font-size:17px;padding:16px 30px}
.btn.ghost{background:var(--paper)}
.btn.chalk{background:var(--chalk)}
.nav-actions{display:flex;align-items:center;gap:12px}
.menu-btn{display:none;background:var(--paper);border:2px solid var(--ink);border-radius:var(--radius);padding:9px 16px;font-weight:800;font-size:14px;text-transform:uppercase;letter-spacing:.05em;cursor:pointer;color:var(--ink);font-family:var(--body)}
.mobile-nav{display:none;border-top:2px solid var(--ink);background:var(--paper)}
.mobile-nav ul{list-style:none;padding:8px clamp(16px,4vw,48px) 16px}
.mobile-nav li{border-bottom:1px solid var(--chalk-line)}
.mobile-nav li.mobile-cta{border:0}
.mobile-nav a{display:block;padding:14px 4px;font-weight:800;font-size:16px;text-transform:uppercase;letter-spacing:.05em}
.mobile-nav .mobile-cta a{text-align:center;margin-top:14px}

/* ---- hero (home): typographic, timetable follows immediately ---- */
.hero{padding:clamp(30px,5vw,64px) 0 clamp(10px,2vw,18px)}
.hero h1{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(52px,9.5vw,124px);line-height:.95;letter-spacing:.005em;margin:10px 0 18px;max-width:12ch}
.hero .lede{font-size:18px;color:var(--muted);max-width:52ch;font-weight:500}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;align-items:center;margin-top:22px}
.hero-note{margin-top:14px;font-family:var(--mono);font-size:13px;color:var(--muted)}

/* ---- section scaffolding ---- */
section{padding:clamp(40px,6vw,80px) 0}
.rule-head{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:10px 20px;border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:22px}
.rule-head h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(26px,4vw,40px);line-height:1}
.rule-head .aside{font-family:var(--mono);font-size:13px;color:var(--muted);letter-spacing:.04em}
.rule-head .aside a{color:var(--orange-deep);font-weight:700}

/* ---- page head (interior) ---- */
.page-head{padding:clamp(30px,5vw,56px) 0 0;max-width:820px}
.page-head h1{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(40px,6.5vw,76px);line-height:.95;margin:10px 0 14px}
.page-head p{font-size:18px;color:var(--muted);font-weight:500}
.page-head a{color:var(--orange-deep);font-weight:700}

/* ---- effort labels: text carries meaning, colour is secondary ---- */
.effort{display:inline-block;font-family:var(--mono);font-weight:700;font-size:11px;letter-spacing:.08em;text-transform:uppercase;padding:3px 9px;border:1px solid currentColor;border-radius:var(--radius)}
.effort.gentle{color:var(--fx-gentle)} .effort.build{color:var(--fx-build)}
.effort.sweat{color:var(--fx-sweat)}  .effort.strong{color:var(--fx-strong)}
.effort.open{color:var(--fx-open)}    .effort.kids{color:var(--fx-kids)}
.legend{display:flex;gap:8px;flex-wrap:wrap}

/* ---- D1 timetable: day columns, mono times, tap-to-book ---- */
.tt-intro{display:flex;flex-wrap:wrap;align-items:baseline;justify-content:space-between;gap:8px 20px;border-bottom:2px solid var(--ink);padding-bottom:10px;margin-bottom:0}
.tt-intro h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(26px,4vw,40px);line-height:1}
.tt-intro .aside{font-family:var(--mono);font-size:13px;color:var(--muted);letter-spacing:.06em;text-transform:uppercase}
.tt-label{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(20px,3vw,28px);margin:28px 0 0;border-bottom:2px solid var(--ink);padding-bottom:8px}
.swipe-hint{display:none;font-family:var(--mono);font-size:12px;color:var(--muted);margin:10px 0 0}
.tt{border:2px solid var(--ink);border-top:0;background:#fff}
.tt-scroll{overflow-x:auto;scroll-snap-type:x proximity}
.tt-grid{display:grid;grid-template-columns:repeat(var(--cols),minmax(150px,1fr))}
.tt-day{border-right:1px solid var(--chalk-line);scroll-snap-align:start;display:flex;flex-direction:column}
.tt-day:last-child{border-right:0}
.tt-dayhead{background:var(--ink);color:var(--paper);padding:10px 12px;font-family:var(--mono);text-transform:uppercase}
.tt-dayhead b{display:block;font-size:15px;letter-spacing:.12em}
.tt-dayhead small{display:block;font-size:10px;letter-spacing:.06em;color:var(--chalk);margin-top:2px}
.tt-cell{display:block;padding:10px 12px 11px;border-bottom:1px solid var(--chalk-line);border-left:3px solid transparent}
.tt-cell:last-child{border-bottom:0}
.tt-cell .t{display:block;font-family:var(--mono);font-weight:700;font-size:12px;color:var(--muted)}
.tt-cell .n{display:block;font-weight:800;font-size:15px;text-transform:uppercase;letter-spacing:.01em;line-height:1.2;margin:2px 0 1px}
.tt-cell .s{display:block;font-family:var(--mono);font-size:10.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.tt-cell:hover{background:var(--chalk)}
.tt-cell:hover .n{color:var(--orange-deep)}
.tt-cell.fx-gentle{border-left-color:var(--fx-gentle)} .tt-cell.fx-build{border-left-color:var(--fx-build)}
.tt-cell.fx-sweat{border-left-color:var(--fx-sweat)}   .tt-cell.fx-strong{border-left-color:var(--fx-strong)}
.tt-cell.fx-open{border-left-color:var(--fx-open)}     .tt-cell.fx-kids{border-left-color:var(--fx-kids)}
.tt-foot{display:flex;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:14px 0 0}
.tt-foot p{font-family:var(--mono);font-size:12px;color:var(--muted)}

/* ---- class cards (photo-topped, numbered) ---- */
.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.card{background:#fff;border:2px solid var(--ink);border-radius:var(--radius);overflow:hidden;transition:transform .1s,box-shadow .1s}
.card:hover{transform:translate(-2px,-2px);box-shadow:var(--shadow)}
.card .photo{aspect-ratio:3/2;overflow:hidden;border-bottom:2px solid var(--ink);background:var(--chalk)}
.card .photo img{width:100%;height:100%;object-fit:cover}
.card .body{padding:18px 20px 20px}
.card .top{display:flex;justify-content:space-between;align-items:center;gap:10px;margin-bottom:4px}
.card h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:24px;line-height:1}
.card .meta{font-family:var(--mono);font-size:11.5px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;margin-bottom:10px}
.card p{color:#3a352f;font-size:14.5px}

/* ---- CTA band: ink poster ---- */
.band{background:var(--ink);color:var(--paper)}
.band-inner{max-width:1240px;margin:0 auto;display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:24px;padding:clamp(38px,6vw,68px) clamp(16px,4vw,48px)}
.band h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(34px,5.5vw,64px);line-height:.95;max-width:16ch}
.band h2 b{color:var(--orange);font-weight:400}
.band p{color:var(--chalk);font-size:16px;max-width:44ch;margin-top:12px}

/* ---- Instagram strip ---- */
.ig-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:14px}
.ig-tile{position:relative;display:block;border:2px solid var(--ink);border-radius:var(--radius);overflow:hidden;aspect-ratio:1/1;background:var(--chalk)}
.ig-tile img{width:100%;height:100%;object-fit:cover;transition:transform .15s}
.ig-tile:hover img{transform:scale(1.03)}
.ig-tile .ig-tag{position:absolute;left:0;bottom:0;background:var(--ink);color:var(--paper);font-family:var(--mono);font-size:11px;font-weight:700;letter-spacing:.06em;padding:5px 9px;text-transform:lowercase}

/* ---- kids block ---- */
.kids{display:grid;grid-template-columns:1fr 1fr;border:2px solid var(--ink);border-radius:var(--radius);overflow:hidden;background:#fff}
.kids .pic{min-height:280px;background:var(--chalk)}
.kids .pic img{width:100%;height:100%;object-fit:cover}
.kids .txt{padding:clamp(24px,4vw,44px)}
.kids .txt h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(28px,4vw,44px);line-height:.98;margin-bottom:12px}
.kids .txt p{color:#3a352f;max-width:44ch;margin-bottom:18px}
.kids .txt ul{margin:0 0 18px 20px;color:#3a352f}
.kids .txt li{margin-bottom:6px}
.kids .txt a.inline{color:var(--orange-deep);font-weight:700}

/* ---- prose (about / terms) ---- */
.prose{max-width:740px;padding-bottom:clamp(40px,6vw,80px)}
.prose h2{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:clamp(22px,3vw,30px);margin:34px 0 10px}
.prose h3{font-weight:800;font-size:17px;margin:24px 0 8px;text-transform:uppercase;letter-spacing:.03em}
.prose p{margin-bottom:14px;color:#3a352f}
.prose ul{margin:0 0 14px 22px;color:#3a352f}
.prose li{margin-bottom:6px}
.prose a{color:var(--orange-deep);font-weight:700}

/* ---- pillars / quotes / contact ---- */
.pillars{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:1px;background:var(--chalk-line);border:1px solid var(--chalk-line)}
.pillar{background:var(--paper);padding:24px}
.pillar h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:20px;margin-bottom:8px}
.pillar p{color:#3a352f;font-size:14.5px}
.quotes{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}
.quote{background:var(--chalk);border-radius:var(--radius);padding:24px;border:1px solid var(--chalk-line)}
.quote p{font-size:14.5px;color:#3a352f;margin-bottom:12px}
.quote footer{font-family:var(--mono);font-weight:700;font-size:13px;color:var(--ink);text-transform:uppercase;letter-spacing:.05em}
.contact-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1px;background:var(--chalk-line);border:1px solid var(--chalk-line);margin-bottom:clamp(40px,6vw,80px)}
.contact-card{background:var(--paper);padding:24px}
.contact-card h3{font-family:var(--display);font-weight:400;text-transform:uppercase;font-size:20px;margin-bottom:10px}
.contact-card a{display:block;color:var(--orange-deep);font-weight:700;margin-bottom:6px}
.contact-card p{color:#3a352f;font-size:14.5px}

/* ---- Zenbly embed ---- */
.embed-card{background:#fff;border:2px solid var(--ink);border-radius:var(--radius);overflow:hidden;margin-bottom:16px}
.embed-card iframe{display:block;width:100%;height:820px;border:0}
.embed-fallback{font-family:var(--mono);font-size:14px;color:var(--muted)}
.embed-fallback a{color:var(--orange-deep);font-weight:700}

/* ---- footer ---- */
footer{background:var(--chalk);border-top:2px solid var(--ink);margin-top:clamp(40px,6vw,80px)}
.foot{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:28px;padding:clamp(36px,5vw,60px) 0}
.foot h4{font-family:var(--mono);font-weight:700;font-size:12px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);margin-bottom:12px}
.foot p,.foot a{font-size:15px;display:block;margin-bottom:6px;color:#3a352f}
.foot a:hover{color:var(--orange-deep)}
.foot-blurb{max-width:26ch;margin-top:10px}
.foot-trial{color:var(--orange-deep)!important;font-weight:800}
.copyright{border-top:1px solid var(--chalk-line);padding:18px 0;font-family:var(--mono);font-size:12px;color:var(--muted);display:flex;flex-wrap:wrap;gap:8px 24px;justify-content:space-between}
.copyright a:hover{color:var(--orange-deep)}

/* ---- responsive ---- */
@media(max-width:880px){
  .nav .links{display:none}
  .nav-actions .btn{display:none}
  .menu-btn{display:inline-block}
  .mobile-nav.open{display:block}
  .kids{grid-template-columns:1fr}
  .kids .pic{min-height:200px}
  .swipe-hint{display:block}
  .band-inner{flex-direction:column;align-items:flex-start}
  .tt-grid{grid-template-columns:repeat(var(--cols),minmax(168px,1fr))}
}
