/* ============================================================
   THE CLOSING CODE — design system
   Built from the W Hotels communications guidelines:
   - black/white base, silver secondary, neon pink ONLY for
     achievement moments
   - the 23.8 degree angle is the spine of everything
   - headlines: condensed bold, ALL CAPS, tight tracking
   ============================================================ */

:root {
  /* core palette */
  --black: #0A0A0A;
  --white: #FFFFFF;
  --silver: #7B7977;
  --pink: #FF00FF;

  /* derived surfaces (kept near-black, never grey "cards") */
  --ink-2: #111111;
  --ink-3: #161616;
  --hair: #2A2A2A;          /* hairline borders */
  --silver-dim: #4A4948;    /* locked / inactive */

  /* the signature W angle */
  --angle: 23.8deg;
  --angle-neg: -23.8deg;

  /* type */
  --head: "Futura LT Condensed", "Futura Condensed", "Oswald", "Arial Narrow", Arial, sans-serif;
  --body: "Helvetica Neue", Helvetica, Arial, sans-serif;

  /* the one sanctioned gradient: -45deg, pink-led (W rule) */
  --grad-pink: linear-gradient(-45deg, #FF00FF 0%, #C400C4 55%, #2A0030 100%);
}

* { box-sizing: border-box; margin: 0; padding: 0; }

html, body { height: 100%; }

body {
  background: var(--black);
  color: var(--white);
  font-family: var(--body);
  font-size: 16px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  overflow-x: hidden;
}

/* faint 23.8deg pattern of intersecting lines (black-on-black) */
body::before {
  content: "";
  position: fixed;
  inset: -20%;
  z-index: 0;
  pointer-events: none;
  background-image:
    repeating-linear-gradient(66.2deg, transparent 0 64px, rgba(255,255,255,0.018) 64px 65px),
    repeating-linear-gradient(-23.8deg, transparent 0 90px, rgba(255,255,255,0.012) 90px 91px);
}

#app { position: relative; z-index: 1; }

/* ---------- typography ---------- */
.h, h1, h2, h3 {
  font-family: var(--head);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: -0.06em;
  line-height: 0.92;
}
.head-xl { font-size: clamp(2.6rem, 7vw, 5.5rem); letter-spacing: -0.08em; }
.head-lg { font-size: clamp(2rem, 5vw, 3.4rem);   letter-spacing: -0.07em; }
.head-md { font-size: clamp(1.4rem, 3vw, 2rem);   letter-spacing: -0.06em; }
.head-sm { font-size: 1.05rem; letter-spacing: -0.04em; }

.subhead {
  font-family: var(--body);
  font-weight: 700;
  font-size: 0.95rem;
  letter-spacing: 0.01em;
}
.kicker {
  font-family: var(--head);
  text-transform: uppercase;
  letter-spacing: 0.34em;
  font-size: 0.72rem;
  color: var(--silver);
  font-weight: 600;
}
/* pink "REMEMBER"-style label (section eyebrows) */
.kicker.hot { color: var(--pink); }

/* solid pink eyebrow flag — the "you-are-here" label, one per screen */
.eyebrow-flag {
  display: inline-flex; align-items: center;
  background: var(--pink); color: var(--white);
  font-family: var(--head); font-weight: 600; text-transform: uppercase;
  letter-spacing: 0.2em; font-size: 0.68rem;
  padding: 7px 18px 7px 13px;
  clip-path: polygon(0 0, 100% 0, calc(100% - 11px) 100%, 0 100%);
}

.body-copy { color: #CFCECD; font-size: 0.97rem; line-height: 1.6; }
.dim { color: var(--silver); }
.pink { color: var(--pink); }

/* ---------- layout shell ---------- */
.wrap { max-width: 1180px; margin: 0 auto; padding: 0 28px; }

/* ---------- command bar ---------- */
.cmdbar {
  position: sticky; top: 0; z-index: 40;
  display: flex; align-items: center; gap: 20px;
  padding: 16px 28px;
  background: rgba(10,10,10,0.86);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--hair);
}
/* the brand "flag": wordmark with the 23.8deg cut */
.flag {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--white); color: var(--black);
  padding: 9px 26px 9px 16px;
  clip-path: polygon(0 0, 100% 0, calc(100% - 18px) 100%, 0 100%);
  cursor: pointer;
}
.flag .mark {
  font-family: var(--head); font-weight: 700; font-size: 1.35rem;
  letter-spacing: -0.07em; line-height: 1; text-transform: uppercase;
}
.flag .mark small { display:block; font-size: 0.5rem; letter-spacing: 0.36em; color: var(--silver); }

.cmd-spacer { flex: 1; }

.nav-tabs { display: flex; gap: 4px; }
.nav-tabs button {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.06em;
  font-size: 0.8rem; font-weight: 600;
  background: none; border: none; color: var(--silver);
  padding: 8px 14px; cursor: pointer; position: relative;
}
.nav-tabs button.active { color: var(--white); }
.nav-tabs button.active::after {
  content: ""; position: absolute; left: 14px; right: 14px; bottom: 2px;
  height: 2px; background: var(--pink);
  clip-path: polygon(0 0, 100% 0, calc(100% - 6px) 100%, 0 100%);
}

/* athlete chip in the bar */
.athlete {
  display: flex; align-items: center; gap: 12px;
  padding-left: 18px; border-left: 1px solid var(--hair);
}
.athlete .who { text-align: right; line-height: 1.05; }
.athlete .who .name { font-weight: 700; font-size: 0.82rem; }
.athlete .who .rk { font-family: var(--head); font-size: 0.7rem; letter-spacing: 0.18em; color: var(--pink); }
.av {
  width: 38px; height: 38px; display: grid; place-items: center;
  background: var(--ink-3); border: 1px solid var(--hair);
  font-family: var(--head); font-weight: 700; font-size: 1rem; letter-spacing: -0.04em;
  clip-path: polygon(0 0, 100% 0, calc(100% - 9px) 100%, 0 100%);
}
/* member's Slack pic — clipped to the same angled shape as the initial */
.av.has-img, .big-av.has-img {
  background-size: cover; background-position: center; color: transparent;
}

/* avatar dropdown menu */
.athlete-menu { position: relative; }
.av-menu {
  position: absolute; top: calc(100% + 12px); right: 0; z-index: 60;
  min-width: 184px; display: flex; flex-direction: column;
  background: var(--ink-2); border: 1px solid var(--hair);
  box-shadow: 0 14px 44px rgba(0, 0, 0, 0.55);
}
.av-menu[hidden] { display: none; }
.av-item {
  background: none; border: 0; border-bottom: 1px solid var(--hair);
  padding: 13px 16px; text-align: left; cursor: pointer; color: var(--white);
  font-family: var(--head); font-weight: 700; font-size: 0.8rem;
  letter-spacing: 0.16em; text-transform: uppercase;
}
.av-item:last-child { border-bottom: 0; }
.av-item:hover { background: var(--ink-3); }
.av-logout { color: var(--silver); }
.av-logout:hover { color: var(--pink); background: var(--ink-3); }

/* small stat pills used in the bar */
.bar-stat { text-align: center; line-height: 1; }
.bar-stat .v { font-family: var(--head); font-size: 1.25rem; letter-spacing: -0.04em; }
.bar-stat .l { font-size: 0.56rem; letter-spacing: 0.22em; color: var(--silver); text-transform: uppercase; }
.bar-stat.live .v { color: var(--pink); }

/* ---------- views ---------- */
.view { display: none; padding: 40px 0 90px; }
.view.active { display: block; animation: rise .4s ease both; }
@keyframes rise { from { opacity: 0; transform: translateY(10px); } to { opacity: 1; transform: none; } }

/* ---------- dashboard: directive hero ---------- */
.directive {
  position: relative; overflow: hidden;
  border: 1px solid var(--hair);
  background: var(--ink-2);
  padding: 48px 44px;
  margin-bottom: 14px;
}
.directive::after {
  /* die-cut angle in the corner — black-on-near-black */
  content: ""; position: absolute; top: -10%; right: -6%;
  width: 360px; height: 150%;
  background: var(--black);
  transform: rotate(var(--angle));
  border-left: 1px solid var(--hair);
}
.directive .inner { position: relative; z-index: 2; max-width: 680px; }
.directive .go {
  margin-top: 26px; display: inline-flex; align-items: center; gap: 14px;
  background: var(--pink); color: var(--white);
  font-family: var(--head); font-weight: 700; text-transform: uppercase;
  letter-spacing: -0.02em; font-size: 1.1rem;
  padding: 14px 22px 14px 26px; border: none; cursor: pointer;
  clip-path: polygon(0 0, 100% 0, calc(100% - 14px) 100%, 0 100%);
  transition: transform .12s ease, background .12s ease;
}
.directive .go:hover { transform: translateX(4px); background: #e000e0; }
.directive .go .arr { font-family: var(--body); }

/* ---------- stat strip ---------- */
.strip { display: grid; grid-template-columns: repeat(4, 1fr); gap: 1px; background: var(--hair); border: 1px solid var(--hair); margin-bottom: 56px; }
.strip .cell { background: var(--black); padding: 20px 22px; }
.strip .cell .v { font-family: var(--head); font-size: 2.1rem; letter-spacing: -0.05em; line-height: 1; }
.strip .cell .l { font-size: 0.62rem; letter-spacing: 0.2em; color: var(--silver); text-transform: uppercase; margin-top: 7px; }
.strip .cell.live .v { color: var(--pink); }
.strip .cell.accent .v { color: var(--pink); }

/* ---------- THE CLIMB (module track) ---------- */
.section-head { display: flex; align-items: baseline; gap: 16px; margin-bottom: 26px; }
.section-head .kicker { white-space: nowrap; }
.section-head .rule { flex: 1; height: 1px; background: var(--hair); }

.climb { position: relative; }
/* the ascending 23.8deg guide line */
.climb::before {
  content: ""; position: absolute; left: 30px; right: 30px; bottom: 46px; top: 46px;
  background: linear-gradient(66.2deg, transparent 0 calc(50% - 1px), var(--silver-dim) 50%, transparent calc(50% + 1px) 100%);
  background-size: 100% 100%;
  pointer-events: none; opacity: 0.5;
  display: none; /* simplified: rely on the staggered flags themselves */
}
.track {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 14px;
  align-items: end;
}
/* each module is an angled flag; they step UP the climb */
.mod {
  position: relative; cursor: pointer; text-align: left;
  background: var(--ink-2); border: 1px solid var(--hair);
  padding: 18px 16px 20px;
  clip-path: polygon(0 0, 100% 0, 100% 100%, 0 100%);
  transition: transform .15s ease, border-color .15s ease, background .15s ease;
  min-height: 170px;
  display: flex; flex-direction: column; justify-content: flex-end;
}
.track .mod:nth-child(1) { margin-bottom: 0; }
.track .mod:nth-child(2) { margin-bottom: 22px; }
.track .mod:nth-child(3) { margin-bottom: 44px; }
.track .mod:nth-child(4) { margin-bottom: 66px; }
.track .mod:nth-child(5) { margin-bottom: 88px; }
.track .mod:nth-child(6) { margin-bottom: 110px; }
.track .mod:nth-child(7) { margin-bottom: 132px; }

.mod .num { font-family: var(--head); font-size: 0.78rem; letter-spacing: 0.14em; color: var(--silver); }
.mod .code { font-family: var(--head); font-weight: 700; font-size: 1.5rem; letter-spacing: -0.06em; margin-top: 8px; }
.mod .nm { font-size: 0.7rem; color: #BBBABA; margin-top: 4px; line-height: 1.15; min-height: 2.3em; }
.mod .tag {
  margin-top: 12px; font-family: var(--head); font-size: 0.6rem; letter-spacing: 0.18em;
  text-transform: uppercase; color: var(--silver);
}

.mod.current { border-color: var(--white); background: var(--ink-3); }
.mod.current .code { color: var(--white); }
.mod.current::before {
  content: ""; position: absolute; top: 0; left: 0; width: 4px; height: 100%;
  background: var(--white);
}
.mod.current .tag { color: var(--white); }
.mod.done .tag { color: var(--white); }
.mod.done .chk { color: var(--white); font-weight: 700; }

.mod:hover { transform: translateY(-4px); }

/* locked = die-cut, silver, no hover lift */
.mod.locked {
  background: #0D0D0D; border-color: #1c1c1c; cursor: not-allowed;
  color: var(--silver-dim);
}
.mod.locked .code, .mod.locked .num, .mod.locked .nm, .mod.locked .tag { color: var(--silver-dim); }
.mod.locked:hover { transform: none; }
.mod.locked::after {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(-23.8deg, transparent 0 9px, rgba(0,0,0,0.5) 9px 18px);
  pointer-events: none;
}
.lockico { position: absolute; top: 12px; right: 12px; opacity: 0.6; }

/* ---------- MODULE VIEW ---------- */
.mod-hero { display: flex; align-items: flex-end; gap: 24px; margin-bottom: 8px; flex-wrap: wrap; }
.mod-hero .idx {
  font-family: var(--head); font-weight: 700; font-size: clamp(3rem,9vw,7rem);
  letter-spacing: -0.08em; color: var(--hair); line-height: 0.8;
}
.back {
  background: none; border: 1px solid var(--hair); color: var(--silver);
  font-family: var(--head); letter-spacing: 0.12em; text-transform: uppercase;
  font-size: 0.72rem; padding: 8px 14px; cursor: pointer; margin-bottom: 24px;
}
.back:hover { color: var(--white); border-color: var(--silver); }

.mod-meta { display: flex; gap: 28px; align-items: center; margin: 22px 0 40px; flex-wrap: wrap; }
.reptracker { display: flex; align-items: center; gap: 14px; }
.reptracker .pips { display: flex; gap: 6px; }
.reptracker .pip {
  width: 34px; height: 10px; background: var(--ink-3); border: 1px solid var(--hair);
  clip-path: polygon(0 0, 100% 0, calc(100% - 5px) 100%, 0 100%);
}
.reptracker .pip.on { background: var(--white); border-color: var(--white); }
.reptracker .lab { font-family: var(--head); letter-spacing: 0.14em; font-size: 0.74rem; color: var(--silver); }

/* ---- lesson list (section overview: pick a drill) ---- */
.lesson-list { border-top: 1px solid var(--hair); }
.lesson-card {
  position: relative; width: 100%; text-align: left; cursor: pointer;
  display: grid; grid-template-columns: 54px 1fr auto; gap: 22px; align-items: center;
  background: none; border: none; border-bottom: 1px solid var(--hair);
  padding: 24px 8px; color: inherit;
  transition: background .15s ease, padding .15s ease;
  font-family: var(--body);
}
.lesson-card:hover { background: var(--ink-2); padding-left: 18px; }
.lc-marker {
  width: 44px; height: 44px; display: grid; place-items: center;
  border: 1px solid var(--hair); color: var(--silver);
  font-family: var(--head); font-size: 1.1rem; letter-spacing: -0.04em;
  clip-path: polygon(0 0, 100% 0, calc(100% - 9px) 100%, 0 100%);
}
.lesson-card.done .lc-marker { background: var(--white); color: var(--black); border-color: var(--white); }
.lc-title { font-family: var(--head); font-size: 1.45rem; letter-spacing: -0.05em; text-transform: uppercase; display: block; line-height: 1; }
.lc-note { color: var(--silver); font-size: 0.86rem; margin-top: 7px; display: block; max-width: 62ch; }
.lc-right { display: flex; flex-direction: column; align-items: flex-end; gap: 8px; white-space: nowrap; }
.lc-reps { font-family: var(--head); font-size: 0.74rem; letter-spacing: 0.1em; color: var(--silver); }
.lc-status { font-family: var(--head); font-size: 0.7rem; letter-spacing: 0.16em; color: var(--silver); }
.lesson-card.done .lc-status { color: var(--white); }
/* the suggested next rep is highlighted, not gated */
.lesson-card.next { background: var(--ink-3); }
.lesson-card.next::before {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--pink);
}
.lesson-card.next .lc-title { color: var(--white); }
.lesson-card.next .lc-status { color: var(--pink); }

/* ---- single lesson view ---- */
.lesson-body { max-width: 780px; margin-top: 30px; }
.lesson-body .player { margin-top: 0; }
.clear-gate {
  margin-top: 30px; margin-bottom: -8px;
  border-left: 2px solid var(--pink); background: var(--ink-2);
  padding: 12px 16px; color: var(--white); font-size: 0.9rem; line-height: 1.45;
}
.clear-gate[hidden] { display: none; }
.lesson-actions {
  margin-top: 30px; display: flex; align-items: center; justify-content: space-between;
  gap: 16px; flex-wrap: wrap;
}
.lesson-nav { display: flex; gap: 8px; }
.lesson-nav button {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.74rem;
  background: none; border: 1px solid var(--hair); color: var(--silver);
  padding: 11px 16px; cursor: pointer;
}
.lesson-nav button:hover:not(:disabled) { color: var(--white); border-color: var(--silver); }
.lesson-nav button:disabled { opacity: 0.28; cursor: default; }

/* ---- my notes (per drill, saved to the member's account) ---- */
.notes-box { margin-top: 26px; }
.notes-head { display: flex; align-items: baseline; justify-content: space-between; margin-bottom: 10px; }
.notes-status {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.16em;
  font-size: 0.64rem; color: var(--silver);
}
/* formatting toolbar */
.notes-tools {
  display: flex; align-items: stretch; gap: 4px;
  border: 1px solid var(--hair); border-bottom: none; background: var(--ink-2);
  padding: 6px;
}
.notes-tools button {
  min-width: 32px; height: 30px; padding: 0 8px;
  background: none; border: 1px solid transparent; color: var(--silver);
  font-family: var(--body); font-size: 0.92rem; line-height: 1; cursor: pointer;
}
.notes-tools button:hover { color: var(--white); border-color: var(--hair); }
.notes-tools button.active { color: var(--pink); border-color: var(--pink); }
.notes-tools .nt-div { width: 1px; background: var(--hair); margin: 2px 4px; }
/* the editor */
.notes-area {
  width: 100%; min-height: 120px; max-height: 420px; overflow: auto;
  background: var(--ink-2); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 0.97rem; line-height: 1.55;
  padding: 14px 16px; outline: none;
}
.notes-area:focus { border-color: var(--pink); }
.notes-area:empty::before {
  content: attr(data-placeholder); color: var(--silver-dim); pointer-events: none;
}
.notes-area ul { list-style: disc; padding-left: 22px; margin: 4px 0; }
.notes-area ol { list-style: decimal; padding-left: 22px; margin: 4px 0; }
.notes-area li { margin: 2px 0; }
.notes-area b, .notes-area strong { font-weight: 700; color: var(--white); }

/* drill rows ("reps") */
.reps { border-top: 1px solid var(--hair); }
.rep {
  display: grid; grid-template-columns: 54px 1fr auto; gap: 22px; align-items: start;
  padding: 26px 4px; border-bottom: 1px solid var(--hair);
  position: relative;
}
.rep .marker {
  width: 44px; height: 44px; display: grid; place-items: center;
  border: 1px solid var(--hair); color: var(--silver);
  font-family: var(--head); font-size: 1.1rem; letter-spacing: -0.04em;
  clip-path: polygon(0 0, 100% 0, calc(100% - 9px) 100%, 0 100%);
}
.rep.done .marker { background: var(--white); color: var(--black); border-color: var(--white); }
.rep .vid {
  width: 100%; aspect-ratio: 16/9; max-width: 0; /* placeholder lives in expand */
}
.rep .ttl { font-family: var(--head); font-size: 1.45rem; letter-spacing: -0.05em; text-transform: uppercase; }
.rep .note { margin-top: 8px; }
.drill-box {
  border: 1px solid var(--hair); background: var(--ink-2);
  padding: 14px 16px;
}
.drill-box .dl { font-family: var(--head); letter-spacing: 0.16em; font-size: 0.64rem; color: var(--silver); }
.drill-box .dt { font-size: 0.92rem; margin-top: 5px; color: #DAD9D8; }
/* lesson note: silver condensed-caps look, matching the drill (.dl) label */
#lessonNote {
  font-family: var(--head); text-transform: uppercase;
  letter-spacing: 0.16em; font-size: 0.78rem; line-height: 1.7;
  color: var(--silver);
}
.player {
  position: relative; overflow: hidden;
  aspect-ratio: 16/9; width: 100%;
  background:
    repeating-linear-gradient(-23.8deg, #0d0d0d 0 22px, #101010 22px 44px);
  border: 1px solid var(--hair);
  display: grid; place-items: center; color: var(--silver-dim);
}
.player iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }
.player .play {
  width: 0; height: 0; border-style: solid;
  border-width: 14px 0 14px 24px; border-color: transparent transparent transparent var(--silver);
}
/* per-user watermark — drifts over the video; deterrent, not DRM */
.wm {
  position: absolute; z-index: 5; pointer-events: none; user-select: none;
  font-family: var(--body); font-size: 0.82rem; letter-spacing: 0.04em;
  color: rgba(255, 255, 255, 0.22); text-shadow: 0 1px 3px rgba(0, 0, 0, 0.55);
  white-space: nowrap; transition: opacity 0.7s ease;
}
.rep .right { display: flex; flex-direction: column; align-items: flex-end; gap: 10px; }
.rep .repval { font-family: var(--head); font-size: 0.78rem; letter-spacing: 0.1em; color: var(--silver); }

.btn-clear {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.04em;
  font-size: 0.82rem; font-weight: 600;
  background: var(--pink); color: var(--white); border: none;
  padding: 11px 18px; cursor: pointer; white-space: nowrap;
  clip-path: polygon(0 0, 100% 0, calc(100% - 10px) 100%, 0 100%);
  transition: background .12s ease;
}
.btn-clear:hover { background: #e000e0; }
.btn-clear.is-done { background: none; color: var(--silver); border: 1px solid var(--hair); cursor: pointer; }
.btn-clear.is-done .cl-undo { display: none; }
.btn-clear.is-done:hover { background: none; color: var(--pink); border-color: var(--pink); }
.btn-clear.is-done:hover .cl-done { display: none; }
.btn-clear.is-done:hover .cl-undo { display: inline; }

/* gating banner */
.gate {
  margin-top: 44px; border: 1px solid var(--hair); background: var(--ink-2);
  padding: 26px 28px; display: flex; align-items: center; justify-content: space-between; gap: 20px; flex-wrap: wrap;
  position: relative; overflow: hidden;
}
.gate::after {
  content: ""; position: absolute; right: -40px; top: -20%; width: 200px; height: 140%;
  background: repeating-linear-gradient(-23.8deg, transparent 0 9px, rgba(255,255,255,0.03) 9px 18px);
}
.gate .g-next { font-family: var(--head); font-size: 1.6rem; letter-spacing: -0.05em; text-transform: uppercase; }
.gate.unlocked .g-next { color: var(--white); }

/* ---------- PROFILE / THE RECORD ---------- */
.athlete-card {
  border: 1px solid var(--hair); background: var(--ink-2);
  padding: 40px 40px 44px; margin-bottom: 56px; position: relative; overflow: hidden;
}
.athlete-card .big-av {
  width: 86px; height: 86px; display: grid; place-items: center;
  background: var(--black); border: 1px solid var(--hair);
  font-family: var(--head); font-weight: 700; font-size: 2.4rem; letter-spacing: -0.06em;
  clip-path: polygon(0 0, 100% 0, calc(100% - 16px) 100%, 0 100%);
}
.rank-line { display: flex; gap: 0; margin-top: 36px; border: 1px solid var(--hair); }
.rank-step {
  flex: 1; padding: 16px 18px; border-right: 1px solid var(--hair); position: relative;
}
.rank-step:last-child { border-right: none; }
.rank-step .rn { font-family: var(--head); font-size: 1.3rem; letter-spacing: -0.04em; color: var(--silver-dim); }
.rank-step .rr { font-size: 0.6rem; letter-spacing: 0.16em; color: var(--silver-dim); text-transform: uppercase; margin-top: 4px; }
.rank-step.reached .rn { color: var(--white); }
.rank-step.reached .rr { color: var(--silver); }
.rank-step.here { background: var(--pink); }
.rank-step.here .rn, .rank-step.here .rr { color: var(--white); }
.rank-step.here::after {
  content: "YOU"; position: absolute; top: 8px; right: 12px;
  font-family: var(--head); font-size: 0.56rem; letter-spacing: 0.2em; color: var(--white);
}

/* badges grid — the neon zone */
.badges { display: grid; grid-template-columns: repeat(auto-fill, minmax(170px,1fr)); gap: 14px; }
.badge {
  border: 1px solid var(--hair); background: var(--ink-2); padding: 22px 20px;
  position: relative; overflow: hidden;
}
.badge .bn { font-family: var(--head); font-size: 1.25rem; letter-spacing: -0.04em; text-transform: uppercase; color: var(--silver-dim); }
.badge .bd { font-size: 0.74rem; color: var(--silver); margin-top: 8px; }
.badge .lock { font-family: var(--head); font-size: 0.6rem; letter-spacing: 0.2em; color: var(--silver-dim); margin-top: 14px; }
/* earned badge: neon dominates here (sanctioned) */
.badge.earned { background: var(--grad-pink); border-color: var(--pink); }
.badge.earned .bn { color: var(--white); }
.badge.earned .bd { color: rgba(255,255,255,0.92); }
.badge.earned .got { font-family: var(--head); font-size: 0.6rem; letter-spacing: 0.2em; color: var(--white); margin-top: 14px; display: block; }

.mod-map { display: grid; grid-template-columns: repeat(7,1fr); gap: 8px; margin-top: 12px; }
.mod-map .mm {
  aspect-ratio: 1; border: 1px solid var(--hair); background: var(--ink-2);
  display: grid; place-items: center; font-family: var(--head); font-size: 0.78rem;
  color: var(--silver-dim); letter-spacing: 0.04em;
  clip-path: polygon(0 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.mod-map .mm.done { background: var(--white); color: var(--black); border-color: var(--white); }
.mod-map .mm.current { border-color: var(--white); color: var(--white); }

/* ---------- RANK-UP / BADGE OVERLAY (the neon moment) ---------- */
.overlay {
  position: fixed; inset: 0; z-index: 100; display: none;
  align-items: center; justify-content: center; padding: 24px;
  background: rgba(10,10,10,0.82); backdrop-filter: blur(6px);
}
.overlay.show { display: flex; animation: rise .35s ease both; }
.celebrate {
  position: relative; width: min(560px, 100%); text-align: center;
  background: var(--grad-pink); color: var(--white);
  padding: 60px 40px 50px;
  clip-path: polygon(0 0, 100% 0, 100% calc(100% - 26px), calc(100% - 26px) 100%, 0 100%);
  border: 1px solid var(--pink);
  overflow: hidden;
}
.celebrate::before {
  content: ""; position: absolute; inset: 0;
  background: repeating-linear-gradient(-23.8deg, transparent 0 20px, rgba(255,255,255,0.06) 20px 21px);
  pointer-events: none;
}
.celebrate .ck { font-family: var(--head); letter-spacing: 0.3em; font-size: 0.7rem; opacity: 0.9; }
.celebrate .big { font-family: var(--head); font-weight: 700; font-size: clamp(2.6rem,9vw,4.4rem); letter-spacing: -0.07em; margin: 12px 0 6px; line-height: 0.9; }
.celebrate .sub { font-size: 1rem; opacity: 0.95; max-width: 360px; margin: 0 auto; }
.celebrate .dismiss {
  margin-top: 30px; background: var(--white); color: var(--black); border: none;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.04em; font-size: 0.9rem;
  padding: 13px 26px; cursor: pointer;
  clip-path: polygon(0 0, 100% 0, calc(100% - 11px) 100%, 0 100%);
}

/* tiny reset link */
.footer { border-top: 1px solid var(--hair); margin-top: 70px; padding: 26px 0; display: flex; justify-content: space-between; color: var(--silver); font-size: 0.72rem; flex-wrap: wrap; gap: 10px; }
.footer button { background: none; border: none; color: var(--silver-dim); font-size: 0.72rem; cursor: pointer; text-decoration: underline; }
.footer button:hover { color: var(--silver); }

/* ---------- responsive ---------- */
@media (max-width: 860px) {
  .nav-tabs { display: none; }
  .track { grid-template-columns: repeat(2, 1fr); }
  .track .mod { margin-bottom: 0 !important; }
  .strip { grid-template-columns: repeat(2,1fr); }
  .athlete .who { display: none; }
  #barReps, #barStreak { display: none; }   /* mobile: drop stat chips, give space to search */
  .mod-map { grid-template-columns: repeat(4,1fr); }
  .rank-line { flex-wrap: wrap; }
  .rank-step { flex: 1 1 50%; border-bottom: 1px solid var(--hair); }
}
@media (max-width: 560px) {
  .wrap { padding: 0 18px; }
  .cmdbar { padding: 12px 16px; gap: 12px; }
  .directive { padding: 32px 24px; }
  .rep { grid-template-columns: 40px 1fr; }
  .rep .right { grid-column: 1 / -1; align-items: flex-start; flex-direction: row; }
  .track { grid-template-columns: 1fr; }
  .strip { grid-template-columns: 1fr 1fr; }
}

/* mobile bottom nav */
.mobnav { display: none; }
@media (max-width: 860px) {
  .mobnav {
    display: flex; position: fixed; bottom: 0; left: 0; right: 0; z-index: 50;
    background: rgba(10,10,10,0.94); backdrop-filter: blur(10px); border-top: 1px solid var(--hair);
  }
  .mobnav button {
    flex: 1; background: none; border: none; color: var(--silver);
    font-family: var(--head); letter-spacing: 0.1em; text-transform: uppercase; font-size: 0.7rem;
    padding: 14px 4px; cursor: pointer;
  }
  .mobnav button.active { color: var(--pink); }
  .view { padding-bottom: 120px; }
}

/* ---------- login wall ---------- */
.login[hidden] { display: none; }
.login {
  position: fixed; inset: 0; z-index: 200;
  display: flex; align-items: center; justify-content: center; padding: 28px;
  background: var(--black);
  background-image:
    repeating-linear-gradient(66.2deg, transparent 0 64px, rgba(255,255,255,0.02) 64px 65px),
    repeating-linear-gradient(-23.8deg, transparent 0 90px, rgba(255,255,255,0.014) 90px 91px);
}
.login-card { width: min(420px, 100%); }
.login-card .flag { display: inline-flex; }
.login-lab {
  display: block; margin: 22px 0 8px;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.22em;
  font-size: 0.64rem; color: var(--silver);
}
.login-input {
  width: 100%; background: var(--ink-2); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 1rem; padding: 14px 16px; outline: none;
}
.login-input:focus { border-color: var(--pink); }
.login-input::placeholder { color: var(--silver-dim); }
.login-go {
  width: 100%; margin-top: 26px; padding: 15px 18px; font-size: 0.95rem;
  justify-content: center; text-align: center;
}
.login-err {
  margin-top: 14px; min-height: 1.2em;
  color: var(--pink); font-size: 0.84rem; font-weight: 700;
}
.btn-slack {
  display: flex; align-items: center; justify-content: center; gap: 10px;
  margin-top: 26px;
}
.btn-slack svg { flex: none; }
.login-altlink {
  display: block; margin: 18px auto 0; padding: 4px;
  background: none; border: none; cursor: pointer;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.18em;
  font-size: 0.62rem; color: var(--silver);
  transition: color .12s ease;
}
.login-altlink:hover { color: var(--white); }

/* ---------- AI search ---------- */
.cmd-search {
  display: inline-flex; align-items: center; gap: 8px;
  background: none; border: 1px solid var(--hair); color: var(--silver);
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.14em; font-size: 0.7rem;
  padding: 9px 14px; cursor: pointer;
  clip-path: polygon(0 0, 100% 0, calc(100% - 8px) 100%, 0 100%);
}
.cmd-search:hover { color: var(--white); border-color: var(--pink); }
.cmd-search .cs-ico { font-size: 1.05rem; line-height: 1; }

.search-ov[hidden] { display: none; }
.search-ov {
  position: fixed; inset: 0; z-index: 150;
  background: rgba(8,8,8,0.82); backdrop-filter: blur(8px);
  display: flex; justify-content: center; align-items: flex-start;
  padding: 10vh 24px 24px;
}
.search-panel { width: min(720px, 100%); }
.search-head { display: flex; align-items: center; justify-content: space-between; margin-bottom: 16px; }
.search-close {
  background: none; border: none; color: var(--silver); cursor: pointer;
  font-family: var(--head); letter-spacing: 0.14em; font-size: 0.72rem; text-transform: uppercase;
}
.search-close:hover { color: var(--white); }
.search-input {
  width: 100%; background: var(--ink-2); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 1.15rem; padding: 18px 20px; outline: none;
}
.search-input:focus { border-color: var(--pink); }
.search-input::placeholder { color: var(--silver-dim); }
.search-results { margin-top: 14px; max-height: 60vh; overflow: auto; }
.search-hint { color: var(--silver); font-size: 0.92rem; padding: 18px 4px; line-height: 1.5; }
.search-result {
  width: 100%; text-align: left; cursor: pointer;
  display: grid; grid-template-columns: auto 1fr; gap: 16px; align-items: start;
  background: none; border: none; border-bottom: 1px solid var(--hair);
  padding: 18px 6px; color: inherit; font-family: var(--body);
  transition: background .15s ease, padding .15s ease;
}
.search-result:hover { background: var(--ink-2); padding-left: 12px; }
.sr-jump {
  font-family: var(--head); letter-spacing: 0.04em; font-size: 0.86rem; color: var(--pink);
  white-space: nowrap; padding-top: 2px;
}
.sr-title { display: block; font-family: var(--head); text-transform: uppercase; letter-spacing: -0.03em; font-size: 1.05rem; }
.sr-snip { display: block; color: var(--silver); font-size: 0.88rem; margin-top: 5px; line-height: 1.5; }

/* locked result — progression gate: visible but dimmed + non-clickable */
.search-result.locked { cursor: default; opacity: 0.45; }
.search-result.locked:hover { background: none; padding-left: 6px; }
.sr-jump.locked { color: var(--silver); }
.sr-jump.locked svg { display: block; }
.search-result.locked .sr-snip { font-family: var(--head); letter-spacing: 0.04em; text-transform: uppercase; }

@media (max-width: 860px) {
  .cmd-spacer { display: none; }             /* give the row's slack to search */
  .cmd-search {
    flex: 1;                                 /* stretch between logo and avatar */
    justify-content: flex-start;             /* icon + label read left-to-right */
    padding: 11px 14px;                      /* taller → reads as a tappable field */
  }
  /* .cs-tx label now shows (no longer hidden) → button reads "⌕ SEARCH" */
}

/* ---------- resources (member-side, on the lesson page) ---------- */
.resources[hidden] { display: none; }
.resources { margin-top: 24px; }
.res-link {
  display: inline-flex; align-items: center; gap: 8px;
  margin: 0 10px 10px 0; padding: 10px 15px;
  background: var(--ink-2); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 0.9rem; text-decoration: none;
}
.res-link:hover { border-color: var(--pink); color: var(--pink); }

/* ---------- transcript (collapsible "unravel" on the lesson page) ---------- */
.transcript[hidden] { display: none; }
.transcript { margin-top: 22px; border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.ts-toggle {
  display: flex; align-items: center; gap: 16px; width: 100%;
  background: none; border: none; padding: 16px 2px; cursor: pointer; text-align: left;
}
.ts-toggle .kicker.hot { margin: 0; }
.ts-rule { flex: 1; height: 1px; background: var(--hair); }
.ts-hint {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.16em;
  font-size: 0.62rem; color: var(--silver);
}
.ts-toggle:hover .ts-hint { color: var(--white); }
/* + that rotates into × when open */
.ts-icon { position: relative; width: 15px; height: 15px; flex: 0 0 15px; transition: transform 0.35s ease; }
.ts-icon::before, .ts-icon::after {
  content: ""; position: absolute; background: var(--pink); border-radius: 1px;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
}
.ts-icon::before { width: 15px; height: 2px; }
.ts-icon::after { width: 2px; height: 15px; }
.ts-toggle.open .ts-icon { transform: rotate(45deg); }

.ts-panel { max-height: 0; overflow: hidden; opacity: 0; transition: max-height 0.45s cubic-bezier(0.25, 1, 0.35, 1), opacity 0.35s ease; }
.ts-panel.open { max-height: 58vh; opacity: 1; }
.ts-inner {
  max-height: 58vh; overflow-y: auto; padding: 4px 16px 18px 16px;
  border-left: 2px solid var(--pink);     /* brand accent — "current/active" pink edge */
}
.ts-inner::-webkit-scrollbar { width: 8px; }
.ts-inner::-webkit-scrollbar-thumb { background: var(--hair); }
.ts-inner::-webkit-scrollbar-thumb:hover { background: var(--silver); }
.ts-tip {
  margin: 0 0 4px; padding: 8px 0 12px; border-bottom: 1px solid var(--hair);
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em;
  font-size: 0.62rem; color: var(--silver);
}
.ts-tip::first-letter { color: var(--pink); }   /* pink ▼ glyph — points down to the timestamps */
.ts-line { display: flex; gap: 16px; align-items: baseline; padding: 9px 0; border-bottom: 1px solid rgba(123,121,119,0.16); }
.ts-line:first-of-type { padding-top: 12px; }
.ts-line:last-child { border-bottom: none; }
.ts-time {
  flex: 0 0 46px; text-align: right; background: none; border: none; cursor: pointer; padding: 0;
  font-family: var(--head); font-size: 0.72rem; letter-spacing: 0.04em; color: var(--silver);
  white-space: nowrap; transition: color 0.15s ease;
}
.ts-time:hover { color: var(--pink); }
.ts-text { margin: 0; font-family: var(--body); font-size: 0.95rem; line-height: 1.65; color: #d2d0ce; }

/* ---------- call replays: YouTube library of past coaching calls (collapsible) ---------- */
/* reuses the transcript toggle/panel (.ts-toggle/.ts-panel/.ts-inner); only the band + rows are new */
.replays { margin-top: 28px; border-top: 1px solid var(--hair); border-bottom: 1px solid var(--hair); }
.rp-tip {
  margin: 0 0 4px; padding: 8px 0 12px; border-bottom: 1px solid var(--hair);
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em;
  font-size: 0.62rem; color: var(--silver);
}
.rp-tip::first-letter { color: var(--pink); }   /* pink ▶ glyph */
.rp-row {
  display: flex; align-items: baseline; gap: 16px; padding: 13px 2px;
  border-bottom: 1px solid rgba(123, 121, 119, 0.16); text-decoration: none;
}
.rp-row:last-child { border-bottom: none; }
.rp-date {
  flex: 0 0 60px; font-family: var(--head); text-transform: uppercase; letter-spacing: 0.06em;
  font-size: 0.72rem; color: var(--silver); white-space: nowrap;
}
.rp-title {
  flex: 1; font-family: var(--head); text-transform: uppercase; letter-spacing: 0.04em;
  font-size: 0.9rem; color: #d2d0ce; transition: color 0.15s ease;
}
.rp-watch {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em;
  font-size: 0.68rem; color: var(--pink); white-space: nowrap;
}
.rp-row:hover .rp-title { color: var(--white); }

/* ---------- quiz: per-drill knowledge check (member side, collapsible) ---------- */
.quiz[hidden] { display: none; }
.quiz { margin-top: 22px; border: 1px solid var(--hair); background: var(--ink-2); }
.quiz-toggle {
  display: flex; align-items: center; gap: 16px; width: 100%;
  background: none; border: none; padding: 16px 18px; cursor: pointer; text-align: left;
}
.quiz-toggle .kicker.hot { margin: 0; white-space: nowrap; }
.quiz-rule { flex: 1; height: 1px; background: var(--hair); }
.quiz-meta { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.64rem; color: var(--silver); white-space: nowrap; }
/* + that rotates into × when open (matches the transcript toggle) */
.quiz-icon { position: relative; width: 15px; height: 15px; flex: 0 0 15px; transition: transform 0.35s ease; }
.quiz-icon::before, .quiz-icon::after {
  content: ""; position: absolute; background: var(--pink); border-radius: 1px;
  top: 50%; left: 50%; transform: translate(-50%, -50%);
}
.quiz-icon::before { width: 15px; height: 2px; }
.quiz-icon::after { width: 2px; height: 15px; }
.quiz-toggle.open .quiz-icon { transform: rotate(45deg); }
.quiz-panel { max-height: 0; overflow: hidden; opacity: 0; transition: max-height 0.5s cubic-bezier(0.25, 1, 0.35, 1), opacity 0.35s ease; }
.quiz-panel.open { max-height: 4000px; opacity: 1; }
.quiz-panel-inner { padding: 2px 18px 18px; }
.quiz-loading { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.74rem; color: var(--silver); }
.quiz-q { margin-bottom: 18px; }
.quiz-q:last-child { margin-bottom: 0; }
.quiz-qn { font-family: var(--body); font-size: 0.96rem; font-weight: 700; color: var(--white); line-height: 1.45; margin-bottom: 10px; }
.quiz-opts { display: flex; flex-direction: column; gap: 8px; }
/* selectable option (form state) */
.quiz-opt {
  display: flex; align-items: center; gap: 12px; width: 100%; text-align: left;
  background: var(--black); border: 1px solid var(--hair); border-left: 3px solid transparent;
  color: #d2d0ce; font-family: var(--body); font-size: 0.92rem; padding: 12px 14px; cursor: pointer;
  transition: border-color 0.12s ease, color 0.12s ease;
}
.quiz-opt:hover { border-color: var(--silver); color: var(--white); }
.quiz-dot { flex: 0 0 14px; width: 14px; height: 14px; border-radius: 50%; border: 2px solid var(--silver); transition: all 0.12s ease; }
.quiz-opt.sel { border-color: var(--pink); border-left-color: var(--pink); color: var(--white); }
.quiz-opt.sel .quiz-dot { border-color: var(--pink); background: var(--pink); box-shadow: inset 0 0 0 2px var(--black); }
.quiz-otext { flex: 1; }
/* results (read-only, after submit) */
.quiz-opt.res { cursor: default; }
.quiz-opt.res:hover { border-color: var(--hair); color: #d2d0ce; }
.quiz-opt.res.correct { border-color: var(--pink); border-left-color: var(--pink); color: var(--white); background: rgba(255,0,255,0.06); }
.quiz-opt.res.wrong { border-left-color: var(--silver); color: var(--silver); text-decoration: line-through; }
.quiz-mark { flex: 0 0 14px; width: 14px; text-align: center; font-size: 0.9rem; font-weight: 700; }
.quiz-opt.res.correct .quiz-mark { color: var(--pink); }
.quiz-opt.res.wrong .quiz-mark { color: var(--silver); }
.quiz-foot { margin-top: 18px; display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.quiz-hint { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.62rem; color: var(--silver); }
.quiz-score { display: flex; align-items: baseline; gap: 16px; flex-wrap: wrap; }
.quiz-score .qs-frac { font-family: var(--head); font-size: 1.5rem; letter-spacing: 0.04em; color: var(--white); }
.quiz-score .qs-reps { font-family: var(--head); font-size: 0.9rem; letter-spacing: 0.06em; color: var(--pink); }
.quiz-score .qs-lock { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.62rem; color: var(--silver); }

/* ---------- quiz editor (admin side) ---------- */
.adm-quiz { border: 1px solid var(--hair); background: var(--black); padding: 12px; margin-bottom: 6px; }
.adm-quiz-head { align-items: center; justify-content: flex-start; gap: 20px; margin-bottom: 10px; }
.adm-check { display: inline-flex; align-items: center; gap: 7px; font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.68rem; color: var(--silver); cursor: pointer; }
.adm-check input { accent-color: var(--pink); width: 15px; height: 15px; }
.adm-quiz-reps { display: inline-flex; align-items: center; gap: 7px; font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.68rem; color: var(--silver); }
.adm-quiz-q { border-left: 3px solid var(--hair); background: var(--ink-2); padding: 10px 12px; margin: 10px 0; }
.adm-q-n { font-family: var(--head); font-size: 0.72rem; color: var(--silver); letter-spacing: 0.1em; }
.adm-quiz-opts { display: flex; flex-direction: column; gap: 6px; margin: 8px 0; }
.adm-quiz-opt { display: flex; align-items: center; gap: 8px; }
.adm-qopt-mark { flex: 0 0 auto; width: 26px; height: 26px; border: 1px solid var(--hair); background: var(--ink-3); color: var(--hair); font-size: 0.7rem; cursor: pointer; }
.adm-qopt-mark:hover { border-color: var(--silver); color: var(--silver); }
.adm-quiz-opt.correct .adm-qopt-mark { border-color: var(--pink); color: var(--pink); }

/* ---------- GAME TAPE (coaching call calendar) ---------- */
.gt-top { display: flex; align-items: flex-start; justify-content: space-between; gap: 18px; flex-wrap: wrap; margin-bottom: 28px; }
/* timezone control */
.tz-control { position: relative; }
.tz-btn {
  display: inline-flex; align-items: center; gap: 9px; background: var(--ink-2); border: 1px solid var(--hair);
  color: var(--white); padding: 10px 14px; cursor: pointer; font-family: var(--head);
  text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.7rem;
}
.tz-btn:hover { border-color: var(--silver); }
.tz-lab { color: var(--silver); }
.tz-name { color: var(--pink); }
.tz-caret { color: var(--silver); font-size: 0.7rem; }
.tz-pop {
  position: absolute; right: 0; top: calc(100% + 6px); z-index: 30; width: 300px; max-width: 84vw;
  background: var(--ink-2); border: 1px solid var(--hair); padding: 10px;
}
.tz-pop[hidden] { display: none; }
.tz-search { width: 100%; background: var(--ink-3); border: 1px solid var(--hair); color: var(--white); font-family: var(--body); font-size: 0.9rem; padding: 9px 11px; outline: none; }
.tz-search:focus { border-color: var(--pink); }
.tz-list { max-height: 280px; overflow-y: auto; margin-top: 8px; display: flex; flex-direction: column; }
.tz-item { text-align: left; background: none; border: none; color: #d2d0ce; font-family: var(--body); font-size: 0.86rem; padding: 8px 10px; cursor: pointer; }
.tz-item:hover { background: var(--ink-3); color: var(--white); }
.tz-item.on { color: var(--pink); }
.tz-empty { color: var(--silver); font-family: var(--body); font-size: 0.86rem; padding: 10px; }

/* agenda */
.gt-day { margin-bottom: 22px; }
.gt-day-head {
  display: flex; align-items: center; gap: 12px; margin-bottom: 12px;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.12em; font-size: 0.78rem; color: var(--white);
}
.gt-day-head::before { content: ""; width: 16px; height: 12px; background: var(--pink); clip-path: polygon(22% 0, 100% 0, 78% 100%, 0 100%); flex: 0 0 auto; }
.gt-card {
  display: flex; align-items: center; justify-content: space-between; gap: 16px; flex-wrap: wrap;
  background: var(--black); border: 1px solid var(--hair); border-left: 3px solid var(--hair);
  padding: 14px 16px; margin-bottom: 8px;
}
.gt-card.mine { border-left-color: var(--pink); }
.gt-card.cancelled { opacity: 0.6; }
.gt-card-main { display: flex; flex-direction: column; gap: 3px; min-width: 180px; }
.gt-time { font-family: var(--head); font-size: 1rem; letter-spacing: 0.03em; color: var(--white); }
.gt-title { font-family: var(--body); font-size: 0.9rem; color: var(--silver); }
.gt-card-side { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }
.gt-pill { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.6rem; padding: 4px 9px; border: 1px solid var(--hair); color: var(--silver); }
.gt-pill.in { color: var(--pink); border-color: var(--pink); }
.gt-pill.open { color: var(--white); border-color: var(--silver); }
.gt-pill.cancelled { color: var(--silver); text-decoration: line-through; }
.gt-going { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.62rem; color: var(--silver); }
.gt-actions { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.gt-reg { font-size: 0.74rem; padding: 9px 16px; }
.gt-cal { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.64rem; color: var(--white); border: 1px solid var(--hair); padding: 7px 11px; cursor: pointer; text-decoration: none; background: none; }
.gt-cal:hover { border-color: var(--pink); color: var(--pink); }
.gt-unreg { background: none; border: none; color: var(--silver); font-family: var(--body); font-size: 0.8rem; cursor: pointer; text-decoration: underline; }
.gt-unreg:hover { color: var(--pink); }
.gt-on { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.64rem; color: var(--pink); }
.gt-note { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.62rem; color: var(--silver); }

/* calendar toolbar */
.gt-toolbar { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin: 6px 0 16px; flex-wrap: wrap; }
.gt-tb-left { display: flex; align-items: center; gap: 12px; }
.gt-today { background: none; border: 1px solid var(--hair); color: var(--white); font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.66rem; padding: 8px 14px; cursor: pointer; }
.gt-today:hover { border-color: var(--pink); color: var(--pink); }
.gt-nav { background: none; border: 1px solid var(--hair); color: var(--silver); width: 32px; height: 32px; cursor: pointer; font-size: 1rem; line-height: 1; }
.gt-nav:hover { border-color: var(--silver); color: var(--white); }
.gt-month { text-align: center; min-width: 150px; display: flex; flex-direction: column; gap: 1px; }
.gt-month-lab { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.95rem; color: var(--white); }
.gt-month-sub { font-family: var(--body); font-size: 0.72rem; color: var(--silver); }
.gt-tb-right { display: flex; }
.gt-vtoggle { background: var(--ink-2); border: 1px solid var(--hair); color: var(--silver); width: 36px; height: 34px; cursor: pointer; font-size: 0.95rem; }
.gt-vtoggle + .gt-vtoggle { border-left: none; }
.gt-vtoggle.active { color: var(--pink); border-color: var(--pink); position: relative; z-index: 1; }

/* month grid */
.gt-grid-head, .gt-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 1px; background: var(--hair); }
.gt-grid-head { border: 1px solid var(--hair); border-bottom: 0; }
.gt-grid { border: 1px solid var(--hair); }
.gt-gh { background: var(--ink-2); padding: 9px 6px; text-align: center; font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em; font-size: 0.6rem; color: var(--silver); }
.gt-cell { background: var(--black); min-height: 106px; padding: 7px 7px 9px; display: flex; flex-direction: column; gap: 5px; }
.gt-cell.out { background: #060606; }
.gt-cell.out .gt-cell-day { color: #383838; }
.gt-cell-day { font-family: var(--head); font-size: 0.8rem; color: var(--silver); width: 24px; height: 24px; display: flex; align-items: center; }
.gt-cell.today .gt-cell-day { background: var(--pink); color: var(--white); border-radius: 50%; justify-content: center; }
.gt-cell-events { display: flex; flex-direction: column; gap: 4px; }
.gt-chip { text-align: left; width: 100%; background: var(--ink-2); border: none; border-left: 2px solid var(--silver); color: #d2d0ce; font-family: var(--body); font-size: 0.7rem; padding: 4px 7px; cursor: pointer; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.gt-chip:hover { color: var(--white); background: var(--ink-3); }
.gt-chip .gt-chip-t { font-family: var(--head); letter-spacing: 0.03em; color: var(--silver); }
.gt-chip.mine { border-left-color: var(--pink); color: var(--white); }
.gt-chip.mine .gt-chip-t { color: var(--pink); }
.gt-chip.cancelled { opacity: 0.42; text-decoration: line-through; }

/* event detail modal */
.gt-modal { position: fixed; inset: 0; z-index: 200; background: rgba(0,0,0,0.82); backdrop-filter: blur(3px); display: flex; align-items: center; justify-content: center; padding: 24px; }
.gt-modal[hidden] { display: none; }
.gt-modal-card {
  position: relative; width: 560px; max-width: 100%; background: var(--ink-2);
  border: 1px solid var(--hair); border-top: 4px solid var(--pink); padding: 44px 44px 40px;
  animation: gtModalIn .22s ease both;
}
@keyframes gtModalIn { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
.gt-modal-x { position: absolute; top: 18px; right: 20px; background: none; border: none; color: var(--silver); font-size: 1.15rem; cursor: pointer; line-height: 1; }
.gt-modal-x:hover { color: var(--pink); }
.gt-modal-card .kicker.hot { font-size: 0.72rem; }
.gt-modal-title { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.01em; font-size: 2.1rem; color: var(--white); margin: 12px 0 8px; line-height: 1.04; }
.gt-modal-time { font-family: var(--head); font-size: 1.25rem; color: var(--silver); letter-spacing: 0.03em; }
.gt-modal-meta { display: flex; align-items: center; gap: 14px; margin: 24px 0 0; }
.gt-modal-action { display: flex; align-items: center; gap: 16px; flex-wrap: wrap; margin-top: 28px; }
.gt-modal-action .gt-reg { font-size: 0.82rem; padding: 13px 26px; }
.gt-zoom { color: var(--pink); font-family: var(--body); font-size: 0.9rem; text-decoration: none; }
.gt-zoom:hover { text-decoration: underline; }

@media (max-width: 640px) {
  .gt-cell { min-height: 58px; padding: 4px 3px; gap: 3px; }
  .gt-gh { font-size: 0.5rem; padding: 6px 1px; letter-spacing: 0.03em; }
  .gt-cell-day { font-size: 0.66rem; width: 20px; height: 20px; }
  .gt-chip { font-size: 0; padding: 3px 4px; border-left-width: 3px; }
  .gt-chip .gt-chip-t { font-size: 0.56rem; }
  .gt-month { min-width: 110px; }
  .gt-month-lab { font-size: 0.82rem; }
}

/* admin: schedule manager + rosters */
.gt-admin { margin-top: 36px; border-top: 1px solid var(--hair); padding-top: 22px; }
.gt-admin[hidden] { display: none; }
.gt-admin-head { margin-bottom: 14px; }
.gt-slots { display: flex; flex-direction: column; gap: 8px; margin-bottom: 12px; }
.gt-slot { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; background: var(--ink-2); border: 1px solid var(--hair); padding: 10px; }
.gt-roster-row { display: flex; gap: 14px; align-items: baseline; padding: 7px 0; border-bottom: 1px solid rgba(123,121,119,0.16); font-family: var(--body); font-size: 0.86rem; color: #d2d0ce; }
.gt-roster-when { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.66rem; color: var(--silver); flex: 0 0 110px; }
.gt-roster-n { color: var(--pink); font-family: var(--head); flex: 0 0 24px; }
.gt-roster-who { color: var(--silver); }

@media (max-width: 640px) {
  .gt-card { flex-direction: column; align-items: flex-start; }
  .gt-card-side { width: 100%; justify-content: space-between; }
}

/* ---------- admin: nav tab + control room ---------- */
.adm-tab[hidden] { display: none; }
.adm-tab { color: var(--pink) !important; }
.admin-status {
  min-height: 1.2em; margin: 16px 0;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em;
  font-size: 0.74rem; color: var(--silver);
}
.admin-status.err { color: var(--pink); }

/* admin preview-mode toggle (unlock all modules for authoring) */
.adm-preview {
  display: flex; gap: 14px; align-items: flex-start;
  margin: 24px 0 4px; padding: 16px 18px; max-width: 660px;
  background: var(--ink-2); border: 1px solid var(--hair); border-left: 3px solid var(--pink);
  cursor: pointer;
}
.adm-preview input { flex: none; margin-top: 2px; width: 18px; height: 18px; accent-color: var(--pink); cursor: pointer; }
.adm-preview-tx { display: flex; flex-direction: column; gap: 6px; }
.adm-preview-t { font-family: var(--head); text-transform: uppercase; letter-spacing: 0.03em; font-size: 1rem; }
.adm-preview-d { color: var(--silver); font-size: 0.86rem; line-height: 1.55; }
.adm-preview-d strong { color: var(--white); }

/* command-bar "preview is on" chip — only shown to an admin while preview mode is active */
.cmd-preview {
  display: inline-flex; align-items: center; gap: 6px; margin-right: 6px;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem;
  color: var(--pink); background: none; border: 1px solid var(--pink); border-radius: 2px;
  padding: 6px 10px; white-space: nowrap; cursor: pointer;
}
.cmd-preview:hover { background: var(--pink); color: var(--black); }
.cmd-preview[hidden] { display: none; }   /* explicit display above would otherwise beat [hidden] */
@media (max-width: 860px) { .cmd-preview .cp-tx { display: none; } }

/* module switcher — one tab per module, edit one at a time (no endless scroll) */
.adm-modtabs {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: stretch;
  margin: 18px 0 24px; padding-bottom: 18px; border-bottom: 1px solid var(--hair);
}
.adm-modtab {
  display: flex; flex-direction: column; gap: 3px; text-align: left;
  background: var(--ink-2); border: 1px solid var(--hair); border-bottom: 2px solid transparent;
  color: var(--silver); padding: 10px 14px; cursor: pointer; min-width: 120px;
}
.adm-modtab:hover { border-color: var(--silver); color: var(--white); }
.adm-modtab.active { border-color: var(--hair); border-bottom-color: var(--pink); color: var(--white); }
.adm-modtab-code {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.1em;
  font-size: 0.66rem; color: var(--pink);
}
.adm-modtab.active .adm-modtab-code { color: var(--pink); }
.adm-modtab-title {
  font-family: var(--body); font-size: 0.82rem; max-width: 180px;
  overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.adm-modtab.add {
  justify-content: center; align-items: center; min-width: 0; border-style: dashed;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem;
}

/* drill order ▲/▼ controls */
.adm-order { display: flex; flex-direction: column; align-items: center; gap: 2px; }
.adm-order-row { flex-direction: row; gap: 4px; }   /* horizontal ◀/▶ for module reorder in the header */
.adm-ord-btn {
  background: var(--ink-3); border: 1px solid var(--hair); color: var(--silver);
  width: 30px; line-height: 18px; padding: 1px 0; cursor: pointer; font-size: 0.7rem;
}
.adm-ord-btn:hover:not(:disabled) { color: var(--pink); border-color: var(--pink); }
.adm-ord-btn:disabled { opacity: 0.3; cursor: default; }
.adm-ord-num { font-family: var(--head); font-size: 0.72rem; color: var(--white); letter-spacing: 0.06em; }

.adm-mod { border: 1px solid var(--hair); background: var(--ink-2); padding: 18px; margin: 0 0 24px; }
.adm-mod-head, .adm-row { display: flex; gap: 8px; align-items: center; flex-wrap: wrap; }
.adm-grow { flex: 1; min-width: 160px; }
.adm-in {
  background: var(--ink-3); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 0.92rem; padding: 9px 11px; outline: none;
}
.adm-in:focus { border-color: var(--pink); }
.adm-ta {
  width: 100%; resize: vertical; min-height: 46px; margin-bottom: 4px;
  background: var(--ink-3); border: 1px solid var(--hair); color: var(--white);
  font-family: var(--body); font-size: 0.92rem; line-height: 1.5; padding: 9px 11px; outline: none;
}
.adm-ta:focus { border-color: var(--pink); }
.adm-lab {
  display: block; margin: 12px 0 5px;
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.16em;
  font-size: 0.6rem; color: var(--silver);
}
.adm-drills { margin-top: 14px; }
.adm-drill { background: var(--black); border: 1px solid var(--hair); border-left: 3px solid var(--pink); padding: 14px; margin: 12px 0; }
.adm-res { display: grid; gap: 6px; }
.adm-res-row { display: flex; gap: 6px; align-items: center; }
.adm-btn {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.08em; font-size: 0.72rem;
  background: none; border: 1px solid var(--hair); color: var(--silver); padding: 9px 14px; cursor: pointer;
}
.adm-btn:hover { color: var(--white); border-color: var(--silver); }
.adm-btn.save { background: var(--pink); color: var(--white); border-color: var(--pink); }
.adm-btn.save:hover { background: #e000e0; }
.adm-btn.del:hover { color: var(--pink); border-color: var(--pink); }
.adm-btn.ghost { border-style: dashed; margin-top: 10px; }
.adm-btn.sm { padding: 7px 10px; font-size: 0.66rem; }
.adm-btn.add-mod { margin: 20px 0 40px; }

/* admin transcript uploader */
.adm-tx { align-items: center; }
.adm-file { color: var(--silver); font-family: var(--body); font-size: 0.82rem; max-width: 260px; }
.adm-file::file-selector-button {
  font-family: var(--head); text-transform: uppercase; letter-spacing: 0.06em; font-size: 0.66rem;
  background: var(--ink-3); border: 1px solid var(--hair); color: var(--silver);
  padding: 7px 10px; margin-right: 10px; cursor: pointer;
}
.adm-file::file-selector-button:hover { color: var(--white); border-color: var(--silver); }
.adm-tx-status { font-family: var(--body); font-size: 0.82rem; color: var(--silver); }
/* per-drill "is the transcript indexed?" badge, sits in the TRANSCRIPT label */
.adm-tx-badge {
  margin-left: 10px; letter-spacing: 0.08em; color: var(--silver);
  font-size: 0.58rem; font-weight: 400;
}
.adm-tx-badge.on { color: var(--pink); }
