/* The Roar Deal — season sentiment, rendered as a podcast waveform.
   Direction: "broadcast booth meets audio desk" in Brisbane Lions heritage colours. */
:root{
  --pitch:#0a1430; --pitch-2:#0d1a3d; --card:#101f47; --card-2:#132552; --line:#243668;
  --claret:#6f1531; --claret-br:#c11f54; --royal:#1b3a8f; --royal-br:#2f5bd0;
  --gold:#f4b323; --gold-lite:#ffd873; --chalk:#eef1f8; --dim:#93a1c4;
  /* mood bands */
  --poor:#d64545; --ok:#e0863c; --avg:#e9c34a; --good:#3fb87c; --epic:#3f8cff;
  --maxw:1180px; --shadow:0 18px 50px rgba(0,0,0,.45);
  --mono:"IBM Plex Mono",ui-monospace,SFMono-Regular,Menlo,monospace;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;color:var(--chalk);
  font-family:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  background:
    radial-gradient(1100px 520px at 88% -8%, rgba(193,31,84,.30), transparent 58%),
    radial-gradient(1000px 520px at -5% 2%, rgba(27,58,143,.55), transparent 55%),
    linear-gradient(180deg,#070f26 0%, #0a1430 44%, #070d20 100%);
  background-attachment:fixed;line-height:1.55;-webkit-font-smoothing:antialiased;
}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px}
a{color:var(--gold-lite);text-underline-offset:3px}
.mono{font-family:var(--mono)}

/* ---------- hero ---------- */
.hero{position:relative;padding:88px 0 26px;text-align:center}
.eyebrow{font-family:var(--mono);letter-spacing:.34em;text-transform:uppercase;font-size:11.5px;
  color:var(--gold);margin:0 0 20px}
.hero h1{
  font-family:"Anton",Impact,sans-serif;font-weight:400;letter-spacing:.012em;line-height:.86;margin:0;
  font-size:clamp(58px,13vw,148px);text-transform:uppercase;
  background:linear-gradient(178deg,#fff 4%, var(--gold-lite) 58%, var(--gold) 100%);
  -webkit-background-clip:text;background-clip:text;color:transparent;
  filter:drop-shadow(0 6px 34px rgba(244,179,35,.16));
}
.hero .sub{color:var(--dim);font-size:clamp(15px,2.1vw,18px);margin:20px auto 0;max-width:600px}
.hero .meta{font-family:var(--mono);margin-top:14px;color:var(--gold-lite);font-size:12.5px;letter-spacing:.06em}

/* legend */
.legend{display:flex;gap:8px;flex-wrap:wrap;justify-content:center;margin:24px 0 4px}
.legend .chip{display:flex;align-items:center;gap:7px;font-family:var(--mono);font-size:11px;color:var(--dim);
  background:rgba(255,255,255,.03);border:1px solid var(--line);padding:5px 11px;border-radius:6px}
.bar-key{width:4px;height:13px;border-radius:2px}
.poorb{background:var(--poor)}.okb{background:var(--ok)}.avgb{background:var(--avg)}.goodb{background:var(--good)}.epicb{background:var(--epic)}

/* ---------- waveform hero ---------- */
.wave-card{position:relative;background:linear-gradient(180deg,var(--card),#0a1636);
  border:1px solid var(--line);border-radius:22px;padding:20px 8px 6px;margin:30px 0 6px;box-shadow:var(--shadow);overflow:hidden}
.wave-card .cap{display:flex;justify-content:space-between;align-items:baseline;padding:0 16px 10px}
.wave-card h2{margin:0;font-family:var(--mono);font-size:12px;letter-spacing:.18em;text-transform:uppercase;color:var(--gold)}
.wave-card .cap small{font-family:var(--mono);color:var(--dim);font-size:11px}
#wave{width:100%;height:264px;display:block}
.wave-x{display:flex;justify-content:space-between;padding:6px 16px 4px;color:var(--dim);font-family:var(--mono);font-size:11px}
.wave-note{margin:0;padding:0 16px 8px;color:var(--dim);font-size:12px}
.wfilter{display:flex;gap:6px;flex-wrap:wrap}
.wfilter button{font-family:var(--mono);font-size:11.5px;font-weight:600;color:var(--dim);cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--line);padding:5px 11px;border-radius:6px;transition:.14s}
.wfilter button:hover{border-color:var(--gold);color:var(--chalk)}
.wfilter button.on{background:var(--gold);color:#241100;border-color:var(--gold)}
.ic{vertical-align:-2px;margin-right:2px}
@media(prefers-reduced-motion:no-preference){
  .wline{stroke-dasharray:1;stroke-dashoffset:1;animation:draw 1.1s cubic-bezier(.4,0,.2,1) .1s forwards}
  .wpt{opacity:0;animation:pop .35s ease forwards}
}
@keyframes draw{to{stroke-dashoffset:0}}
@keyframes pop{to{opacity:1}}
.wbar{transition:opacity .15s, filter .15s;transform-origin:center center;cursor:pointer}
.wbar:hover{filter:brightness(1.35)}
@media(prefers-reduced-motion:no-preference){
  .wbar{animation:rise .5s cubic-bezier(.2,.7,.3,1) both}
  #playhead{animation:sweep 2.2s cubic-bezier(.4,0,.2,1) .1s both}
}
@keyframes rise{from{transform:scaleY(0)}to{transform:scaleY(1)}}
@keyframes sweep{from{transform:translateX(0);opacity:.9}80%{opacity:.9}to{transform:translateX(var(--sweep,1000px));opacity:0}}
.wave-tip{position:fixed;pointer-events:none;z-index:50;background:#0a1636;border:1px solid var(--gold);
  border-radius:12px;padding:9px 12px;max-width:260px;box-shadow:var(--shadow);font-size:12.5px;opacity:0;
  transition:opacity .12s;transform:translate(-50%,-118%)}
.wave-tip b{font-family:var(--mono);color:var(--gold-lite)}
.wave-tip .mk{color:var(--dim);font-size:11.5px}

/* ---------- season scrubber nav ---------- */
.filterbar{position:sticky;top:0;z-index:30;display:flex;gap:6px;justify-content:center;padding:12px 0;margin-top:6px;
  background:linear-gradient(180deg,#070f26 30%,rgba(7,15,38,.6) 78%,transparent);backdrop-filter:blur(7px)}
.filterbar button{font-family:var(--mono);font-size:13px;font-weight:600;color:var(--chalk);cursor:pointer;
  background:rgba(255,255,255,.04);border:1px solid var(--line);padding:7px 15px;border-radius:7px;transition:.15s}
.filterbar button:hover{border-color:var(--gold)}
.filterbar button.on{background:var(--gold);color:#241100;border-color:var(--gold)}

/* ---------- season block ---------- */
.season{padding:38px 0 12px;scroll-margin-top:60px}
.shead{display:flex;align-items:center;gap:20px;flex-wrap:wrap;border-bottom:1px solid var(--line);padding-bottom:16px;margin-bottom:24px}
.shead .yr{font-family:"Anton",sans-serif;font-size:clamp(52px,9vw,92px);line-height:.82;color:#fff;letter-spacing:.02em}
.shead .rec{font-family:var(--mono);font-weight:600;color:var(--gold-lite);font-size:17px}
.shead .rec small{color:var(--dim)}
.shead .medallion{margin-left:auto;display:flex;align-items:center;gap:10px;font-family:var(--mono);font-size:11.5px;
  font-weight:600;letter-spacing:.1em;text-transform:uppercase;padding:8px 15px;border-radius:999px;border:1px solid var(--line);color:var(--dim)}
.shead .medallion.premiers{background:linear-gradient(180deg,var(--gold-lite),var(--gold));color:#241100;border-color:var(--gold)}
.shead .medallion.gf{border-color:var(--gold);color:var(--gold-lite)}
.shead .medallion .cap{font-size:16px;display:inline-flex;align-items:center}
.story{flex-basis:100%;margin:6px 0 0;color:var(--dim);font-size:14.5px;max-width:760px}
.story b{color:var(--chalk);font-weight:600}
.cbgroup{margin-bottom:10px}
.cbgroup .lbl{font-family:var(--mono);font-size:10.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--dim);margin:4px 0 2px}

/* panels */
.panels{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:26px}
@media(max-width:780px){.panels{grid-template-columns:1fr}}
.panel{background:var(--card);border:1px solid var(--line);border-radius:16px;padding:16px 18px}
.panel h3{margin:0 0 12px;font-family:var(--mono);font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:8px}
.medalist{display:flex;align-items:center;gap:12px;margin-bottom:12px}
.medalist .cap{font-size:30px}
.medalist b{font-size:16px}
.medalist small{display:block;color:var(--dim);font-family:var(--mono);font-size:11px}
.ldr{display:flex;align-items:center;gap:10px;padding:6px 0;border-bottom:1px dashed rgba(255,255,255,.07)}
.ldr:last-child{border-bottom:0}
.ldr .rank{font-family:var(--mono);width:22px;color:var(--dim);font-weight:600;text-align:right}
.ldr .who{flex:1}
.ldr .votes{font-family:var(--mono);font-weight:700;color:var(--gold-lite)}
.ldr.top .who{color:#fff;font-weight:700}
.ldr .meter{height:4px;border-radius:2px;background:linear-gradient(90deg,var(--claret-br),var(--gold));margin-top:4px}
.cb{display:flex;gap:10px;padding:9px 0;border-bottom:1px dashed rgba(255,255,255,.07);font-size:13.5px}
.cb:last-child{border-bottom:0}
.verdict{flex:none;font-family:var(--mono);font-weight:700;font-size:10px;letter-spacing:.06em;padding:3px 7px;border-radius:5px;height:fit-content}
.verdict.hit{background:rgba(63,184,124,.16);color:#7fe0a8;border:1px solid #2f7a54}
.verdict.miss{background:rgba(214,69,69,.16);color:#f0938c;border:1px solid #8f3630}
.verdict.pending{background:rgba(147,161,196,.12);color:var(--dim);border:1px solid var(--line)}
.cb .txt small{color:var(--dim);font-family:var(--mono);font-size:11px}
.panel .empty{color:var(--dim);font-size:13px}

/* ---------- month cue cards ---------- */
.months{display:grid;grid-template-columns:1fr;gap:16px}
@media(min-width:820px){.months{grid-template-columns:1fr 1fr}}
.mcard{position:relative;background:linear-gradient(180deg,var(--card-2),var(--card));border:1px solid var(--line);
  border-radius:16px;padding:16px 16px 15px;overflow:hidden;transition:transform .18s,border-color .18s}
.mcard:hover{transform:translateY(-3px);border-color:var(--gold)}
.mcard .accent{position:absolute;left:0;top:0;bottom:0;width:5px}
.mtop{display:flex;align-items:center;gap:13px;margin-bottom:11px}
.score{width:56px;height:56px;flex:none;border-radius:14px;display:grid;place-items:center;
  font-family:"Anton",sans-serif;font-size:29px;color:#0b1020;line-height:1}
.mtop .mo{font-family:var(--mono);font-weight:600;font-size:14px;letter-spacing:.03em}
.mtop .band{font-family:var(--mono);font-size:10.5px;letter-spacing:.16em;text-transform:uppercase;color:var(--dim)}
.judge{margin-left:auto;font-family:var(--mono);font-size:10px;font-weight:600;color:var(--dim);
  border:1px solid var(--line);border-radius:6px;padding:3px 7px;display:flex;align-items:center;gap:4px}
.judge.ok{color:#7fe0a8;border-color:#2f7a54}
.judge.adj{color:var(--gold-lite);border-color:var(--gold)}
.markers{display:flex;flex-wrap:wrap;gap:6px;margin:2px 0 12px}
.marker{font-family:var(--mono);font-size:11px;color:var(--gold-lite);background:rgba(244,179,35,.09);
  border:1px solid rgba(244,179,35,.24);padding:3px 8px;border-radius:5px}
.split{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px;align-items:stretch}
.wnote{background:rgba(255,255,255,.03);border:1px solid var(--line);border-radius:10px;padding:8px 10px;
  min-height:104px;display:flex;flex-direction:column}
.wnote .n{font-family:var(--mono);font-size:10.5px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--gold);display:flex;align-items:center;gap:5px}
.wnote.mike .n{color:var(--claret-br)}
.wnote p{margin:5px 0 0;font-size:12.5px}
.gstrip{display:flex;flex-wrap:wrap;gap:5px;margin:2px 0 12px}
.pip{font-family:var(--mono);font-size:10.5px;font-weight:600;padding:3px 7px;border-radius:5px}
.pip.W{background:rgba(63,184,124,.18);color:#8fe6b3;border:1px solid #2f7a54}
.pip.L{background:rgba(214,69,69,.16);color:#f0938c;border:1px solid #8f3630}
.pip.D{background:rgba(233,195,74,.16);color:var(--gold-lite);border:1px solid #8a742a}
.disc{margin:0;padding-left:16px}
.disc li{font-size:12.6px;color:var(--dim);margin:3px 0}
.evidence{margin-top:11px;border-top:1px dashed rgba(255,255,255,.08);padding-top:10px}
.evidence p{margin:5px 0 0;font-size:12px;color:var(--chalk);font-style:italic;opacity:.9}
.evidence p::before{content:"“"}.evidence p::after{content:"”"}

footer{color:var(--dim);font-size:12.5px;text-align:center;padding:48px 0 64px;line-height:1.75}
footer .disc-note{max-width:640px;margin:12px auto 0;opacity:.75;font-family:var(--mono);font-size:11px}
