/* MATIER DASHBOARD — shared styles */

:root{
  --bg:#080604; --panel:#0d0a07; --panel-2:#11100c; --panel-3:#16140e;
  --line:rgba(245,245,240,.07); --line-2:rgba(245,245,240,.14); --line-3:rgba(245,245,240,.22);
  --gold:#C4973B; --gold-bright:#D9AC4D; --gold-deep:#8C6A24; --gold-soft:rgba(196,151,59,.12);
  --cream:#F5F5F0;
  --sub:rgba(245,245,240,.55); --mute:rgba(245,245,240,.32); --whisper:rgba(245,245,240,.18);
  --mon:#E8915C; --tue:#5C9CE8; --wed:#7CC890; --thu:#B889E8; --fri:#E85C7C; --sat:#F5F5F0; --sun:#3D3937;
  --sans:'Space Grotesk',system-ui,sans-serif; --serif:'Shrikhand',serif;
  --r:6px; --r-l:10px;
  --pad-s:14px; --pad:22px; --pad-l:32px;
  --grid-gap:14px;
  --side:88px;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html,body{background:var(--bg);color:var(--cream);font-family:var(--sans);font-size:14px;line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}

/* === SHELL — sidebar + main === */
.shell{display:grid;grid-template-columns:var(--side) 1fr;min-height:100vh}

/* === SIDEBAR === */
.side{position:sticky;top:0;height:100vh;background:var(--panel);border-right:1px solid var(--line);display:flex;flex-direction:column;align-items:center;padding:24px 0;gap:8px;z-index:20}
.side-logo{font-family:var(--serif);font-size:30px;color:var(--gold);line-height:1;letter-spacing:-1px;writing-mode:vertical-rl;transform:rotate(180deg);margin-bottom:auto;padding-top:8px}
.side-nav{display:flex;flex-direction:column;gap:4px;width:100%;align-items:center}
.side-link{width:48px;height:48px;border-radius:var(--r);display:flex;align-items:center;justify-content:center;color:var(--mute);transition:all .15s;position:relative}
.side-link:hover{color:var(--cream);background:var(--panel-2)}
.side-link.active{color:var(--gold);background:var(--gold-soft)}
.side-link.active::before{content:"";position:absolute;left:-1px;top:8px;bottom:8px;width:2px;background:var(--gold);border-radius:2px}
.side-link svg{width:20px;height:20px}
.side-foot{font-size:9px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;padding:8px 0}

/* === MAIN === */
.main{padding:32px 40px 60px;max-width:1640px;margin:0;width:100%}

/* === TOP BAR === */
.top{display:flex;justify-content:space-between;align-items:center;padding-bottom:24px;border-bottom:1px solid var(--line);margin-bottom:32px}
.top-l{display:flex;align-items:baseline;gap:16px}
.top-title{font-family:var(--serif);font-size:32px;color:var(--cream);letter-spacing:-.5px;line-height:1}
.top-sub{font-size:11px;color:var(--mute);letter-spacing:5px;text-transform:uppercase}
.top-r{display:flex;align-items:center;gap:24px;font-size:11px;color:var(--mute);letter-spacing:2px;text-transform:uppercase}
.live{display:flex;align-items:center;gap:8px;color:var(--gold-bright)}
.live::before{content:"";width:6px;height:6px;background:var(--gold-bright);border-radius:50%;animation:p 2s infinite}
@keyframes p{0%,100%{opacity:1}50%{opacity:.3}}

/* === DASHBOARD GRID (homepage) === */
.grid-home{display:grid;grid-template-columns:repeat(12,1fr);gap:var(--grid-gap)}
.grid-home > *{min-width:0}
.span-12{grid-column:span 12}
.span-8{grid-column:span 8}
.span-7{grid-column:span 7}
.span-6{grid-column:span 6}
.span-5{grid-column:span 5}
.span-4{grid-column:span 4}
.span-3{grid-column:span 3}

/* === CARD === */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-l);padding:var(--pad);position:relative;overflow:hidden;transition:border-color .15s}
.card:hover{border-color:var(--line-2)}
.card-eyebrow{font-size:9px;letter-spacing:4px;text-transform:uppercase;color:var(--mute);font-weight:600;margin-bottom:14px;display:flex;align-items:center;gap:10px}
.card-eyebrow::before{content:"";width:3px;height:3px;background:var(--gold);border-radius:50%}

/* === TODAY CARD (big hero) === */
.today-card{background:linear-gradient(135deg,var(--panel) 0%,var(--panel-2) 100%);border:1px solid var(--line-2);min-height:280px;padding:var(--pad-l);display:flex;flex-direction:column;justify-content:space-between}
.today-card::before{content:"";position:absolute;inset:0;background:radial-gradient(circle at 80% 20%,rgba(196,151,59,.08),transparent 60%);pointer-events:none}
.today-meta{font-size:10px;color:var(--mute);letter-spacing:5px;text-transform:uppercase;font-weight:700;margin-bottom:8px}
.today-day{font-family:var(--serif);font-size:84px;color:var(--cream);line-height:.92;letter-spacing:-2px;margin-bottom:4px}
.today-domain{font-family:var(--sans);font-weight:700;font-size:22px;color:var(--gold-bright);letter-spacing:6px;text-transform:uppercase;margin-bottom:18px}
.today-coach{display:flex;align-items:center;gap:12px;font-size:13px;color:var(--sub)}
.coach-dot{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:18px;color:var(--bg)}
.today-status{margin-top:auto;display:flex;justify-content:space-between;align-items:flex-end;padding-top:24px}
.today-cta{padding:10px 20px;background:var(--gold);color:var(--bg);font-weight:700;font-size:12px;letter-spacing:2px;text-transform:uppercase;border-radius:var(--r);transition:all .15s}
.today-cta:hover{background:var(--gold-bright);transform:translateY(-1px)}
.today-foot{font-size:10px;color:var(--mute);letter-spacing:2px;font-family:var(--sans)}

/* === STREAK CARD === */
.streak-card{display:flex;flex-direction:column;justify-content:center;align-items:center;text-align:center;min-height:140px}
.streak-num{font-family:var(--serif);font-size:96px;color:var(--gold);line-height:1;letter-spacing:-3px}
.streak-lab{font-size:9px;color:var(--mute);letter-spacing:5px;text-transform:uppercase;margin-top:6px}

/* === STAT CARDS === */
.stat-card{display:flex;flex-direction:column;gap:6px;padding:18px 20px;min-height:0}
.stat-num{font-family:var(--serif);font-size:42px;color:var(--cream);line-height:1;letter-spacing:-1px}
.stat-num.gold{color:var(--gold)}
.stat-lab{font-size:9px;color:var(--mute);letter-spacing:4px;text-transform:uppercase}

/* === WEEK STRIP === */
.week-strip{display:grid;grid-template-columns:repeat(7,1fr);gap:8px}
.day-cell{aspect-ratio:1.4/1;background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);padding:14px;display:flex;flex-direction:column;justify-content:space-between;position:relative;transition:all .15s}
.day-cell:hover{border-color:var(--line-2);transform:translateY(-1px)}
.day-cell.past{background:var(--panel-3);border-color:var(--line-2)}
.day-cell.past .day-letter{color:var(--gold)}
.day-cell.past::after{content:"✓";position:absolute;top:10px;right:12px;color:var(--gold);font-size:14px;font-weight:700}
.day-cell.today{background:linear-gradient(135deg,var(--panel-2),var(--gold-soft));border-color:var(--gold);box-shadow:0 0 0 1px var(--gold)}
.day-cell.today .day-letter{color:var(--gold)}
.day-cell.today::after{content:"●";position:absolute;top:8px;right:12px;color:var(--gold-bright);font-size:14px;animation:p 2s infinite}
.day-cell.future .day-letter{color:var(--whisper)}
.day-cell.off{background:transparent;border-style:dashed;border-color:var(--line)}
.day-cell.off .day-letter{color:var(--whisper)}
.day-cell.off .day-domain{color:var(--whisper)}
.day-letter{font-family:var(--serif);font-size:36px;line-height:1;letter-spacing:-1px}
.day-domain{font-size:9px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;font-weight:600}

/* === COACH GRID === */
.coach-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.coach-card-mini{background:var(--panel-2);border:1px solid var(--line);border-radius:var(--r);padding:14px 10px;text-align:center;display:flex;flex-direction:column;align-items:center;gap:6px;transition:all .15s;cursor:pointer;min-width:0}
.coach-card-mini:hover{border-color:var(--line-2);transform:translateY(-2px)}
.coach-mono{width:42px;height:42px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:20px;color:var(--bg);line-height:1}
.coach-name{font-size:11px;color:var(--cream);letter-spacing:1px;text-transform:uppercase;font-weight:700;margin-top:6px}
.coach-day{font-size:9px;color:var(--mute);letter-spacing:2px;text-transform:uppercase}

/* === FEED === */
.feed{display:flex;flex-direction:column;gap:0}
.feed-item{display:grid;grid-template-columns:minmax(60px,auto) 1fr auto;gap:14px;padding:12px 0;border-bottom:1px solid var(--line);align-items:baseline}
.feed-item:last-child{border:none}
.feed-time{font-size:9px;color:var(--gold);font-family:var(--sans);letter-spacing:2px;text-transform:uppercase;font-weight:700;white-space:nowrap;max-width:90px;overflow:hidden;text-overflow:ellipsis}
.feed-text{font-size:13px;color:var(--cream)}
.feed-text small{color:var(--sub);display:block;margin-top:2px;font-size:11px}
.feed-tag{font-size:9px;letter-spacing:2px;text-transform:uppercase;padding:3px 8px;background:var(--gold-soft);color:var(--gold-bright);border-radius:3px}

/* === EMPTY STATES === */
.empty-block{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--mute);padding:40px 20px;gap:8px}
.empty-block b{font-family:var(--serif);font-size:22px;color:var(--cream);font-weight:normal;letter-spacing:-.5px}
.empty-block span{font-size:12px;letter-spacing:2px;text-transform:uppercase}

/* === DETAIL PAGE (today.html) === */
.brief-detail{max-width:920px;margin:0 auto;padding:8px 0 40px}
.brief-h{padding:32px 0 24px;border-bottom:1px solid var(--line);margin-bottom:28px;display:flex;justify-content:space-between;align-items:flex-end;gap:24px}
.brief-h-l{flex:1}
.brief-day-row{font-size:11px;color:var(--gold);letter-spacing:5px;text-transform:uppercase;font-weight:700;margin-bottom:8px}
.brief-title{font-family:var(--serif);font-size:48px;color:var(--cream);line-height:1.05;letter-spacing:-1px}
.brief-source{margin-top:14px;font-size:13px;color:var(--sub)}
.brief-source a{color:var(--gold-bright);border-bottom:1px solid rgba(217,172,77,.4)}

.audit-block{margin:24px 0 32px;padding:20px 24px;background:var(--panel-2);border-left:2px solid var(--gold);border-radius:0 var(--r) var(--r) 0}
.audit-block h4{font-size:10px;color:var(--mute);letter-spacing:4px;text-transform:uppercase;margin-bottom:12px;font-weight:700}
.audit-row{display:flex;gap:10px;padding:5px 0;font-size:13px;color:var(--sub)}
.audit-row::before{content:"";width:5px;height:5px;border-radius:50%;flex-shrink:0;margin-top:8px}
.audit-row.have::before{background:var(--gold)}
.audit-row.gap::before{background:var(--cream)}

.rules-block{counter-reset:r;margin:32px 0}
.rules-block h4{font-size:10px;color:var(--mute);letter-spacing:4px;text-transform:uppercase;margin-bottom:18px;font-weight:700}
.rule-item{counter-increment:r;display:grid;grid-template-columns:50px 1fr;gap:18px;padding:18px 0;border-top:1px solid var(--line)}
.rule-item:last-child{border-bottom:1px solid var(--line)}
.rule-item::before{content:counter(r,decimal-leading-zero);font-family:var(--serif);font-size:32px;color:var(--gold);line-height:1}
.rule-text{color:var(--cream);font-size:15px;font-weight:500;line-height:1.5}
.rule-where{font-size:10px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;margin-top:6px;font-family:var(--sans)}

.experiment-block{margin:32px 0;padding:24px 28px;background:var(--gold-soft);border-left:2px solid var(--gold-bright);border-radius:0 var(--r) var(--r) 0}
.experiment-block h4{font-size:10px;color:var(--gold-bright);letter-spacing:4px;text-transform:uppercase;margin-bottom:8px;font-weight:700}
.experiment-text{font-size:15px;color:var(--cream);font-weight:500}

.brief-foot{font-size:10px;color:var(--mute);letter-spacing:2px;font-family:var(--sans);padding-top:24px;border-top:1px solid var(--line);margin-top:32px}

/* === ARCHIVE GRID === */
.arch-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px}
.arch-card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-l);padding:22px;cursor:pointer;transition:all .15s;min-height:160px;display:flex;flex-direction:column;justify-content:space-between;position:relative;overflow:hidden}
.arch-card:hover{border-color:var(--line-2);transform:translateY(-2px)}
.arch-card::before{content:"";position:absolute;top:0;left:0;width:3px;height:100%;background:var(--gold);opacity:.5}
.arch-meta{display:flex;justify-content:space-between;font-size:10px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;margin-bottom:12px}
.arch-meta .domain{color:var(--gold)}
.arch-title{font-family:var(--serif);font-size:22px;color:var(--cream);line-height:1.15;letter-spacing:-.5px}
.arch-source{font-size:11px;color:var(--sub);margin-top:14px}

/* === COACHES PAGE === */
.coaches-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:14px}
.coach-card-full{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-l);padding:24px;display:flex;flex-direction:column;gap:14px;min-height:220px;position:relative;overflow:hidden}
.coach-card-full::before{content:"";position:absolute;top:0;left:0;width:100%;height:3px}
.coach-card-full[data-day="Mon"]::before{background:var(--mon)}
.coach-card-full[data-day="Tue"]::before{background:var(--tue)}
.coach-card-full[data-day="Wed"]::before{background:var(--wed)}
.coach-card-full[data-day="Thu"]::before{background:var(--thu)}
.coach-card-full[data-day="Fri"]::before{background:var(--fri)}
.coach-card-full[data-day="Sat"]::before{background:var(--sat)}
.coach-h{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}
.coach-h-l .coach-day-name{font-size:10px;color:var(--mute);letter-spacing:4px;text-transform:uppercase;font-weight:700}
.coach-h-l .coach-h-name{font-family:var(--serif);font-size:28px;color:var(--cream);line-height:1;letter-spacing:-.5px;margin-top:4px}
.coach-mono-l{width:54px;height:54px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:var(--serif);font-size:24px;color:var(--bg)}
.coach-bio{font-size:12px;color:var(--sub);line-height:1.6;flex:1}
.coach-state{display:flex;justify-content:space-between;font-size:10px;color:var(--mute);letter-spacing:2px;text-transform:uppercase;padding-top:12px;border-top:1px solid var(--line)}
.coach-state b{color:var(--gold);font-weight:600}

/* === RESPONSIVE === */
@media(max-width:1100px){
  .span-8,.span-7,.span-6,.span-5,.span-4,.span-3{grid-column:span 12}
  .week-strip{grid-template-columns:repeat(7,minmax(60px,1fr))}
  .coach-grid{grid-template-columns:repeat(3,1fr)}
}
@media(max-width:720px){
  :root{--side:60px}
  .main{padding:20px}
  .today-day{font-size:60px}
  .brief-title{font-size:32px}
  .week-strip{grid-template-columns:repeat(7,minmax(40px,1fr));gap:4px}
  .day-cell{padding:8px}
  .day-letter{font-size:22px}
  .day-domain{display:none}
  .coach-grid{grid-template-columns:repeat(2,1fr)}
}
