/* ============================================================
   2026 TRAINING CAMP · Trailblazer Football
   Design language: dirtyshoulders deck family
   ============================================================ */

:root {
  --ink: #0A0A0A;
  --ink-2: #141414;
  --ink-3: #1E1E1E;
  --ink-4: #262626;
  --paper: #F5F0E8;
  --paper-dim: #B8B0A2;
  --paper-ghost: rgba(245, 240, 232, 0.4);
  --rule: #2A2622;
  --rule-bright: #3A3530;

  --red: #C8372D;
  --red-deep: #8F1D15;
  --red-bright: #E04336;
  --red-glow: rgba(200, 55, 45, 0.18);

  --gold: #C9A961;
  --gold-deep: #9B7F3F;

  --display: 'Big Shoulders Display', 'Impact', sans-serif;
  --label: 'Staatliches', 'Impact', sans-serif;
  --body: 'Fraunces', 'Georgia', serif;
  --mono: 'JetBrains Mono', 'Courier New', monospace;

  --s-grain: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='160' height='160'><filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='2' seed='3'/><feColorMatrix values='0 0 0 0 0.96 0 0 0 0 0.94 0 0 0 0 0.91 0 0 0 0.08 0'/></filter><rect width='100%25' height='100%25' filter='url(%23n)'/></svg>");
}

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

html, body {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--body);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  scroll-behavior: smooth;
}
body { overflow-x: hidden; }

a { color: inherit; text-decoration: none; }
button { font-family: inherit; cursor: pointer; }

img { display: block; max-width: 100%; height: auto; }

::selection { background: var(--red); color: var(--paper); }

/* ============================================================
   TOP META BAR
   ============================================================ */
.page-meta {
  position: sticky; top: 0; z-index: 50;
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 24px;
  background: rgba(10, 10, 10, 0.88);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  border-bottom: 1px solid var(--rule);
  font-family: var(--label);
  font-size: 12px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
}
.page-meta .brand { color: var(--paper); display: flex; align-items: center; gap: 10px; }
.page-meta .brand .dot { width: 7px; height: 7px; background: var(--red); border-radius: 50%; animation: pulse 2.6s ease-in-out infinite; }
.page-meta .brand .sep { color: var(--rule-bright); }
.page-meta .brand .year { color: var(--red); }
.page-meta .right { display: flex; align-items: center; gap: 18px; color: var(--paper-dim); }
.page-meta .version-pill {
  font-family: var(--mono);
  font-size: 10px; letter-spacing: 0.2em;
  padding: 3px 8px;
  border: 1px solid var(--gold);
  color: var(--gold);
  text-transform: uppercase;
}
.page-meta .top-action {
  font-family: var(--label); font-size: 11px; letter-spacing: 0.3em;
  background: transparent; color: var(--paper-dim); border: 1px solid var(--rule-bright);
  padding: 6px 12px; text-transform: uppercase; transition: 0.18s;
}
.page-meta .top-action:hover { color: var(--red); border-color: var(--red); }

@media (max-width: 640px) {
  .page-meta { padding: 12px 16px; font-size: 10.5px; letter-spacing: 0.32em; }
  .page-meta .brand .sep, .page-meta .right .label-print { display: none; }
}

/* ============================================================
   HERO
   ============================================================ */
.hero {
  position: relative;
  min-height: clamp(560px, 82vh, 820px);
  display: grid;
  grid-template-columns: 1fr;
  align-content: end;
  padding: 80px 8vw 60px;
  overflow: hidden;
  isolation: isolate;
}
.hero .bg {
  position: absolute; inset: 0; z-index: -2;
  background-image: url(public/images/team-lineup.jpg);
  background-size: cover; background-position: center 30%;
  filter: saturate(1.05) contrast(1.05);
}
.hero .bg-tint {
  position: absolute; inset: 0; z-index: -1;
  background:
    radial-gradient(circle at 75% 40%, rgba(200, 55, 45, 0.18) 0%, rgba(10, 10, 10, 0) 55%),
    linear-gradient(180deg, rgba(10, 10, 10, 0.45) 0%, rgba(10, 10, 10, 0.10) 30%, rgba(10, 10, 10, 0.78) 78%, rgba(10, 10, 10, 0.96) 100%);
}
.hero .grain {
  position: absolute; inset: 0; z-index: -1;
  background-image: var(--s-grain); mix-blend-mode: overlay; opacity: 0.4;
  pointer-events: none;
}

.hero .kicker {
  font-family: var(--label);
  font-size: clamp(12px, 1.2vw, 15px);
  letter-spacing: 0.55em;
  color: var(--red);
  border-left: 3px solid var(--red);
  padding-left: 14px;
  text-transform: uppercase;
  margin-bottom: 24px;
}

.hero h1 {
  font-family: var(--display);
  font-weight: 900;
  font-size: clamp(72px, 13vw, 220px);
  line-height: 0.82;
  letter-spacing: -0.035em;
  text-transform: uppercase;
  color: var(--paper);
  margin-bottom: 8px;
}
.hero h1 .year {
  display: block;
  font-size: clamp(96px, 17vw, 280px);
  line-height: 0.78;
  color: var(--red);
  letter-spacing: -0.055em;
  margin-top: -6px;
}

.hero .tag {
  font-family: var(--body);
  font-style: italic;
  font-size: clamp(18px, 1.9vw, 26px);
  color: var(--paper-dim);
  line-height: 1.45;
  max-width: 640px;
  margin-top: 26px;
  margin-bottom: 38px;
}
.hero .tag .em { color: var(--paper); font-style: normal; font-weight: 500; }

.hero .hero-row {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  justify-content: space-between;
  gap: 36px;
}

.hero .hero-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
}
.btn {
  display: inline-flex; align-items: center; gap: 10px;
  font-family: var(--label);
  font-size: 13px;
  letter-spacing: 0.4em;
  text-transform: uppercase;
  padding: 14px 22px;
  border: 1px solid var(--rule-bright);
  background: transparent;
  color: var(--paper);
  transition: all 0.18s ease;
}
.btn:hover { border-color: var(--red); color: var(--red); transform: translateY(-1px); }
.btn.primary { background: var(--red); border-color: var(--red); }
.btn.primary:hover { background: var(--red-deep); border-color: var(--red-deep); color: var(--paper); }
.btn .arrow { font-family: var(--mono); transition: transform 0.2s; }
.btn:hover .arrow { transform: translateX(3px); }

.countdown {
  display: flex; flex-direction: column;
  padding: 22px 26px;
  border: 1px solid var(--red);
  background: rgba(10, 10, 10, 0.62);
  backdrop-filter: blur(6px);
  min-width: 270px;
}
.countdown .ck-label {
  font-family: var(--mono);
  font-size: 10.5px;
  letter-spacing: 0.4em;
  color: var(--red);
  text-transform: uppercase;
  margin-bottom: 6px;
}
.countdown .ck-value {
  font-family: var(--display);
  font-weight: 900;
  font-size: 78px;
  line-height: 0.86;
  color: var(--paper);
  letter-spacing: -0.025em;
}
.countdown .ck-value .unit {
  font-family: var(--mono);
  font-weight: 500;
  font-size: 13px;
  letter-spacing: 0.3em;
  color: var(--paper-dim);
  margin-left: 6px;
  vertical-align: middle;
  text-transform: uppercase;
}
.countdown .ck-opp {
  font-family: var(--label);
  font-size: 13px;
  letter-spacing: 0.32em;
  color: var(--gold);
  margin-top: 10px;
  text-transform: uppercase;
}
.countdown .ck-when {
  font-family: var(--mono);
  font-size: 11px;
  letter-spacing: 0.18em;
  color: var(--paper-dim);
  margin-top: 4px;
}

/* ============================================================
   VITALS STRIP
   ============================================================ */
.vitals {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
  background: var(--ink-2);
}
.vitals .stat {
  padding: 28px 26px;
  border-right: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 6px;
}
.vitals .stat:last-child { border-right: none; }
.vitals .stat .k {
  font-family: var(--mono); font-size: 10.5px; letter-spacing: 0.35em;
  color: var(--paper-dim); text-transform: uppercase;
}
.vitals .stat .v {
  font-family: var(--display); font-weight: 900; font-size: 44px; line-height: 0.92;
  color: var(--paper); letter-spacing: -0.02em;
}
.vitals .stat .v .red { color: var(--red); }
.vitals .stat .sub {
  font-family: var(--label); font-size: 11.5px; letter-spacing: 0.28em;
  color: var(--gold); text-transform: uppercase;
}
@media (max-width: 760px) {
  .vitals { grid-template-columns: repeat(2, 1fr); }
  .vitals .stat:nth-child(2n) { border-right: none; }
  .vitals .stat:nth-child(-n+2) { border-bottom: 1px solid var(--rule); }
  .vitals .stat .v { font-size: 36px; }
}

/* ============================================================
   DAY-TAB STRIP (sticky horizontal scroller)
   ============================================================ */
.day-tabs {
  position: sticky;
  top: 49px;  /* under top meta bar */
  z-index: 40;
  background: rgba(10, 10, 10, 0.94);
  backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--rule);
}
.day-tabs .scroller {
  display: flex;
  overflow-x: auto;
  scroll-behavior: smooth;
  scrollbar-width: none;
  -ms-overflow-style: none;
  padding: 0 24px;
}
.day-tabs .scroller::-webkit-scrollbar { display: none; }
.day-tabs .tab {
  flex: 0 0 auto;
  padding: 14px 16px;
  display: flex; flex-direction: column; align-items: center; gap: 4px;
  border-right: 1px solid var(--rule);
  text-decoration: none;
  transition: background 0.16s, color 0.16s;
  position: relative;
}
.day-tabs .tab:first-child { border-left: 1px solid var(--rule); }
.day-tabs .tab .wd {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.28em;
  color: var(--paper-dim); text-transform: uppercase;
}
.day-tabs .tab .dt {
  font-family: var(--display); font-weight: 900; font-size: 22px; line-height: 1;
  color: var(--paper);
}
.day-tabs .tab:hover { background: var(--ink-3); }
.day-tabs .tab.is-today {
  background: var(--ink-3);
}
.day-tabs .tab.is-today::after {
  content: ""; position: absolute; left: 14px; right: 14px; bottom: 0;
  height: 2px; background: var(--red);
}
.day-tabs .tab.is-active .dt { color: var(--red); }

/* ============================================================
   SCHEDULE
   ============================================================ */
.schedule {
  max-width: 1400px;
  margin: 0 auto;
  padding: 64px 24px 96px;
}

.week { margin-bottom: 72px; }
.week-divider {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 22px;
  margin-bottom: 36px;
}
.week-divider .label {
  font-family: var(--label); font-size: 14px; letter-spacing: 0.45em;
  color: var(--red); text-transform: uppercase;
}
.week-divider .rule { height: 1px; background: linear-gradient(90deg, var(--red) 0%, var(--rule) 100%); }
.week-divider .num {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.3em;
  color: var(--paper-dim);
}

.day-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 22px;
}
@media (min-width: 900px) {
  .day-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (min-width: 1200px) {
  .day-grid { grid-template-columns: repeat(3, 1fr); }
}

.day-card {
  background: var(--ink-2);
  border: 1px solid var(--rule);
  padding: 26px 26px 22px;
  display: flex; flex-direction: column;
  scroll-margin-top: 130px;
  position: relative;
  transition: border-color 0.22s, transform 0.22s;
}
.day-card:hover { border-color: var(--rule-bright); }
.day-card.is-today {
  border-color: var(--red);
  box-shadow: 0 0 0 1px var(--red), 0 8px 32px var(--red-glow);
}
.day-card.is-today::before {
  content: "TODAY"; position: absolute; top: -10px; left: 22px;
  background: var(--red); color: var(--paper); padding: 3px 10px;
  font-family: var(--label); font-size: 11px; letter-spacing: 0.4em; text-transform: uppercase;
}

.day-card .day-head {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 18px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--rule);
  margin-bottom: 18px;
}
.day-card .day-head .left { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.day-card .wd {
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.32em;
  color: var(--paper-dim); text-transform: uppercase;
}
.day-card .dt {
  font-family: var(--display); font-weight: 900; font-size: 42px; line-height: 0.9;
  color: var(--paper); letter-spacing: -0.025em;
  text-transform: uppercase;
}
.day-card .dt .mo { color: var(--paper-dim); font-weight: 700; }
.day-card .day-tag {
  font-family: var(--label); font-size: 10.5px; letter-spacing: 0.32em;
  padding: 5px 9px; text-transform: uppercase;
  white-space: nowrap;
  border: 1px solid var(--rule-bright);
  color: var(--paper-dim);
  flex-shrink: 0;
}
.day-tag.tag-helmets   { color: var(--paper-dim); border-color: var(--paper-dim); }
.day-tag.tag-shells    { color: var(--gold);      border-color: var(--gold); }
.day-tag.tag-full      { color: var(--paper);     border-color: var(--red); background: var(--red); }
.day-tag.tag-walkthrough{ color: var(--paper-dim); border-color: var(--rule-bright); }
.day-tag.tag-headshots { color: var(--gold);      border-color: var(--gold); border-style: dashed; }
.day-tag.tag-checkin   { color: var(--paper-dim); border-color: var(--rule-bright); }
.day-tag.tag-picture   { color: var(--gold);      border-color: var(--gold); }

.day-card .timeline {
  list-style: none;
  display: flex; flex-direction: column;
}
.day-card .t-item {
  display: grid;
  grid-template-columns: 84px 14px 1fr;
  gap: 14px;
  align-items: baseline;
  padding: 10px 0;
  border-bottom: 1px dashed var(--rule);
  position: relative;
}
.day-card .t-item:last-child { border-bottom: none; }
.day-card .t-time {
  font-family: var(--mono);
  font-size: 12px;
  letter-spacing: 0.05em;
  color: var(--paper-dim);
  white-space: nowrap;
  text-transform: lowercase;
}
.day-card .t-dot {
  align-self: center;
  width: 8px; height: 8px;
  background: var(--paper-dim);
  border-radius: 50%;
  margin-top: 2px;
  flex-shrink: 0;
}
.day-card .t-title {
  font-family: var(--body);
  font-size: 16px;
  font-weight: 500;
  color: var(--paper);
  line-height: 1.35;
}
.day-card .t-title .sub {
  display: block;
  font-family: var(--mono);
  font-size: 10.5px;
  font-weight: 400;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--paper-dim);
  margin-top: 3px;
}

.cat-practice  .t-dot { background: var(--red); box-shadow: 0 0 8px var(--red-glow); }
.cat-practice  .t-title { font-family: var(--display); font-weight: 800; font-size: 22px; letter-spacing: -0.005em; text-transform: uppercase; }
.cat-lift      .t-dot { background: var(--gold); }
.cat-film      .t-dot { background: var(--gold-deep); }
.cat-meeting   .t-dot { background: var(--paper); }
.cat-meal      .t-dot { background: var(--rule-bright); }
.cat-meal      .t-title { color: var(--paper-dim); font-style: italic; }
.cat-install   .t-dot { background: var(--red-deep); }
.cat-walk      .t-dot { background: var(--gold-deep); border-radius: 0; transform: rotate(45deg); width: 6px; height: 6px; }
.cat-special   .t-dot { background: var(--gold); transform: scale(1.4); box-shadow: 0 0 8px var(--gold); }
.cat-special   .t-title { color: var(--gold); }

.day-card .notes {
  margin-top: 18px; padding-top: 14px;
  border-top: 1px solid var(--rule);
  display: flex; flex-direction: column; gap: 6px;
}
.day-card .notes .nkey {
  font-family: var(--mono); font-size: 10px; letter-spacing: 0.34em;
  color: var(--gold); text-transform: uppercase;
}
.day-card .notes .nitem {
  font-family: var(--body); font-style: italic; font-size: 14px;
  color: var(--paper-dim); line-height: 1.4;
}
.day-card .empty {
  font-family: var(--body); font-style: italic; font-size: 14px;
  color: var(--paper-ghost);
  padding: 8px 0;
}

/* ============================================================
   KEY / LEGEND
   ============================================================ */
.legend {
  max-width: 1400px;
  margin: 0 auto;
  padding: 0 24px 48px;
}
.legend .legend-card {
  background: var(--ink-2);
  border: 1px solid var(--rule);
  padding: 28px 28px 24px;
}
.legend h2 {
  font-family: var(--label); font-size: 14px; letter-spacing: 0.45em;
  color: var(--red); text-transform: uppercase;
  margin-bottom: 18px;
}
.legend .legend-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 18px;
}
.legend .item {
  display: flex; align-items: center; gap: 12px;
}
.legend .item .swatch {
  width: 12px; height: 12px; border-radius: 50%; flex-shrink: 0;
}
.legend .item .lbl {
  font-family: var(--label); font-size: 12px; letter-spacing: 0.28em;
  color: var(--paper); text-transform: uppercase;
}
.legend .item .lbl .sub {
  display: block;
  font-family: var(--body); font-style: italic; font-size: 12px;
  color: var(--paper-dim); letter-spacing: 0;
  text-transform: none;
  margin-top: 2px;
}
.legend .gear-row {
  display: flex; flex-wrap: wrap; gap: 10px;
  margin-top: 20px; padding-top: 18px; border-top: 1px solid var(--rule);
}
.legend .gear-row .day-tag { font-size: 10px; padding: 4px 8px; }

/* ============================================================
   PASSBACK
   ============================================================ */
.passback {
  position: relative;
  padding: 90px 8vw;
  background:
    linear-gradient(180deg, rgba(10,10,10,0.92) 0%, rgba(10,10,10,0.75) 100%),
    url(public/images/locker-room.jpg) center/cover no-repeat;
  text-align: center;
  border-top: 1px solid var(--rule);
  border-bottom: 1px solid var(--rule);
}
.passback .grain {
  position: absolute; inset: 0;
  background-image: var(--s-grain); mix-blend-mode: overlay; opacity: 0.35;
  pointer-events: none;
}
.passback .q {
  position: relative; z-index: 1;
  font-family: var(--body); font-style: italic;
  font-size: clamp(18px, 1.7vw, 22px);
  color: var(--paper-dim);
  letter-spacing: 0.08em;
  margin-bottom: 18px;
}
.passback .a {
  position: relative; z-index: 1;
  font-family: var(--display); font-weight: 900;
  font-size: clamp(72px, 14vw, 200px);
  line-height: 0.86;
  letter-spacing: -0.04em;
  color: var(--paper);
  text-transform: uppercase;
}
.passback .a .red { color: var(--red); }
.passback .creed {
  position: relative; z-index: 1;
  font-family: var(--label); font-size: 13px; letter-spacing: 0.5em;
  color: var(--gold); text-transform: uppercase; margin-top: 22px;
}

/* ============================================================
   FOOTER
   ============================================================ */
.page-footer {
  padding: 36px 24px 60px;
  border-top: 1px solid var(--rule);
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 24px;
  align-items: center;
  max-width: 1400px;
  margin: 0 auto;
  font-family: var(--mono); font-size: 11px; letter-spacing: 0.22em;
  color: var(--paper-dim); text-transform: uppercase;
}
.page-footer .right { display: flex; align-items: center; gap: 18px; }
.page-footer .right .gold { color: var(--gold); }
.page-footer .right .red { color: var(--red); }
.page-footer .fox {
  width: 26px; height: 26px;
  display: inline-flex; align-items: center; justify-content: center;
}
.page-footer .fox svg { width: 100%; height: 100%; fill: var(--red); }

/* ============================================================
   ANIMATIONS
   ============================================================ */
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.55; transform: scale(0.85); }
}

.fade-in {
  opacity: 0;
  transform: translateY(18px);
  transition: opacity 0.55s ease, transform 0.55s ease;
}
.fade-in.in {
  opacity: 1;
  transform: translateY(0);
}

@media (prefers-reduced-motion: reduce) {
  .fade-in { transition: none; opacity: 1; transform: none; }
  .page-meta .brand .dot { animation: none; }
  html { scroll-behavior: auto; }
}

/* ============================================================
   PRINT
   ============================================================ */
@media print {
  html, body { background: white; color: black; }
  .page-meta, .day-tabs, .hero .hero-actions, .passback, .page-footer, .legend { display: none !important; }
  .hero { min-height: 0; padding: 12mm 10mm 8mm; background: none; }
  .hero .bg, .hero .bg-tint, .hero .grain { display: none; }
  .hero h1 { color: black; font-size: 56pt; }
  .hero h1 .year { color: #C8372D; font-size: 70pt; }
  .hero .tag { color: #333; }
  .hero .kicker { color: #C8372D; }
  .countdown { border-color: #C8372D; color: black; background: white; min-width: 0; padding: 10pt 14pt; }
  .countdown .ck-value { color: black; font-size: 28pt; }
  .countdown .ck-label, .countdown .ck-opp { color: #C8372D; }
  .countdown .ck-when { color: #333; }
  .vitals { background: white; border-color: #ccc; }
  .vitals .stat { padding: 10pt 12pt; border-color: #ccc; }
  .vitals .stat .k { color: #555; }
  .vitals .stat .v { color: black; font-size: 24pt; }
  .vitals .stat .sub { color: #C8372D; }
  .schedule { padding: 8mm 10mm; max-width: none; }
  .week { page-break-inside: avoid; margin-bottom: 18pt; }
  .week-divider .label { color: #C8372D; }
  .week-divider .rule { background: #ccc; }
  .week-divider .num { color: #555; }
  .day-grid { grid-template-columns: repeat(2, 1fr); gap: 10pt; }
  .day-card { background: white; border: 1px solid #ccc; color: black; padding: 10pt; page-break-inside: avoid; }
  .day-card .wd { color: #555; }
  .day-card .dt { color: black; font-size: 22pt; }
  .day-card .dt .mo { color: #555; }
  .day-card .day-tag { border-color: #C8372D; color: #C8372D; background: white !important; }
  .day-card .t-item { border-color: #eee; padding: 4pt 0; }
  .day-card .t-time { color: #555; font-size: 9pt; }
  .day-card .t-title { color: black; font-size: 11pt; }
  .day-card .t-title .sub { color: #555; }
  .day-card .cat-practice .t-title { color: #C8372D; font-size: 13pt; }
  .day-card .notes { border-color: #eee; }
  .day-card .notes .nkey { color: #C8372D; }
  .day-card .notes .nitem { color: #333; }
  .day-card.is-today { border-color: #C8372D; box-shadow: none; }
  .day-card.is-today::before { background: #C8372D; color: white; }
}
