/* Delft Seaways sweepstake. Maritime "stadium-night" theme from the v5 mockup
   (docs/sweepstake-ui-mockup-v5.html). Shared by the dashboard and the TV view. */
:root{
  --sea-900:#070f1c;--sea-850:#0a1525;--sea-800:#0c1b30;--sea-700:#10233c;
  --brass:#d9b44a;--brass-bright:#f0d27a;--foam:#f3efe6;
  --steel:#88a0bd;--steel-dim:#56708f;--live:#54e08a;--yellow:#f2c44a;--rule:rgba(217,180,74,.22);
}
*{box-sizing:border-box}
body{margin:0;color:var(--foam);font-family:"Hanken Grotesk",system-ui,sans-serif;font-size:15px;line-height:1.5;padding:0 0 60px;
  background:radial-gradient(1200px 480px at 16% -8%,rgba(217,180,74,.10),transparent 60%),radial-gradient(1000px 560px at 92% 0%,rgba(84,224,138,.06),transparent 55%),linear-gradient(180deg,var(--sea-850),var(--sea-900))}
.wrap{max-width:1180px;margin:0 auto;padding:0 20px}
h2.section{font-family:"Oswald",sans-serif;font-weight:600;text-transform:uppercase;letter-spacing:.05em;font-size:20px;margin:0;color:var(--foam)}
.flag{width:30px;height:20px;border-radius:3px;flex:0 0 auto;display:inline-block;overflow:hidden;box-shadow:0 0 0 1px rgba(255,255,255,.16),0 2px 5px rgba(0,0,0,.4);background:var(--sea-700);vertical-align:middle}
.flag.sm{width:22px;height:15px;border-radius:2px}
.flag svg,.flag img{display:block;width:100%;height:100%}

.topbar{border-bottom:1px solid var(--rule);background:linear-gradient(180deg,rgba(10,21,37,.72),rgba(10,21,37,0));position:sticky;top:0;z-index:20;backdrop-filter:blur(2px)}
.topbar .wrap{display:flex;align-items:center;gap:16px;padding:13px 20px}
.brandmark{display:flex;align-items:center;gap:12px;min-width:0}
.ship{width:32px;height:32px;flex:0 0 auto;color:var(--brass)}
.brandtext{display:flex;flex-direction:column;line-height:1.05}
.brandtext .ttl{font-family:"Oswald",sans-serif;font-weight:700;letter-spacing:.06em;text-transform:uppercase;font-size:17px;white-space:nowrap}
.brandtext .sub{font-size:10.5px;letter-spacing:.22em;text-transform:uppercase;color:var(--brass);font-weight:600}
.spacer{flex:1}
.status{display:flex;align-items:center;gap:16px;flex:0 0 auto}
.potline{font-size:12px;color:var(--steel);text-align:right}.potline b{color:var(--brass-bright);font-weight:600;font-size:14px}
.livepill{display:inline-flex;align-items:center;gap:8px;border:1px solid rgba(84,224,138,.4);background:rgba(84,224,138,.08);color:var(--live);border-radius:999px;padding:5px 11px 5px 9px;font-family:"Oswald",sans-serif;font-size:12px;letter-spacing:.14em;text-transform:uppercase;font-weight:600}
.dot{width:8px;height:8px;border-radius:50%;background:var(--live);animation:pulse 1.9s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(84,224,138,.5)}70%{box-shadow:0 0 0 8px rgba(84,224,138,0)}100%{box-shadow:0 0 0 0 rgba(84,224,138,0)}}
.updated{font-size:12px;color:var(--steel);white-space:nowrap}.updated b{color:var(--foam);font-weight:600}
.sampletag{text-align:center;font-size:11px;letter-spacing:.16em;text-transform:uppercase;color:var(--steel-dim);padding:9px 20px 0}

.card{background:linear-gradient(180deg,var(--sea-700),var(--sea-800));border:1px solid var(--rule);border-radius:14px;padding:17px 17px 15px;position:relative;min-width:0}
.card .head{display:flex;align-items:center;justify-content:space-between;gap:12px;margin-bottom:13px}
.card .head .meta{font-size:12px;color:var(--steel)}
.grid{display:grid;gap:16px;margin-top:18px}
.two{grid-template-columns:1.34fr .76fr}
.split{grid-template-columns:1.5fr 1fr}
@media(max-width:900px){.two{grid-template-columns:1fr}}
@media(max-width:760px){.split{grid-template-columns:1fr}}

.empty{color:var(--steel);font-size:13px;padding:8px 2px}

.inplay{margin-top:18px}.inplay .head .count{font-family:"IBM Plex Mono",monospace;color:var(--live);font-weight:600}
.live-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(min(100%,290px),1fr));gap:13px}
.livecard{background:linear-gradient(180deg,rgba(84,224,138,.05),transparent 45%),var(--sea-800);border:1px solid rgba(84,224,138,.26);border-radius:11px;padding:12px 13px}
.lc-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:9px}
.lc-grp{font-family:"Oswald",sans-serif;font-size:11px;letter-spacing:.1em;text-transform:uppercase;color:var(--steel)}
.lc-min{font-family:"Oswald",sans-serif;font-size:12px;letter-spacing:.06em;color:var(--live);font-weight:600}
.lc-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px}
.lc-team{display:flex;align-items:center;gap:9px;min-width:0}.lc-team.away{flex-direction:row-reverse;text-align:right}
.lc-team>.tt{min-width:0}
.lc-team .nm{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.02em;font-weight:600;font-size:15px;line-height:1.08;white-space:normal;overflow-wrap:break-word;hyphens:auto}
.lc-team .ow{font-size:11px;color:var(--steel);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lc-score{display:flex;align-items:center;gap:4px}
.miniflap{background:linear-gradient(180deg,#0c1626,#060c16);border:1px solid rgba(217,180,74,.25);border-radius:5px;min-width:30px;height:38px;display:flex;align-items:center;justify-content:center;font-family:"IBM Plex Mono",monospace;font-weight:600;font-size:22px;color:var(--brass-bright)}
.miniflap.sep{border:0;background:none;color:var(--steel-dim);min-width:8px;font-size:16px}

/* crew standings: three columns on desktop, a swipe carousel on mobile */
.lb-swipe{display:flex;gap:26px}
.lb-page{flex:1;min-width:0}
.lb-hint{display:none}
.lrow{break-inside:avoid;display:grid;grid-template-columns:26px 50px 1fr auto;align-items:center;gap:9px;padding:7px 4px;border-bottom:1px solid rgba(217,180,74,.09);position:relative}
.lrow .rank{font-family:"IBM Plex Mono",monospace;color:var(--steel-dim);font-size:13px;text-align:center}
.lrow .flags{display:flex;gap:4px}
.lrow .name{font-weight:600;font-size:14px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lrow .amt{font-family:"IBM Plex Mono",monospace;font-weight:600;font-size:15px;color:var(--foam);text-align:right}
.lrow.lead{background:linear-gradient(90deg,rgba(217,180,74,.15),transparent 75%);border-radius:8px}
.lrow.lead .rank{color:var(--brass)}.lrow.lead .amt{color:var(--brass-bright)}
.lrow.lead::before{content:"";position:absolute;left:0;top:5px;bottom:5px;width:3px;border-radius:3px;background:var(--brass)}

.pool .bar{height:13px;border-radius:8px;background:var(--sea-850);border:1px solid var(--rule);overflow:hidden;margin-top:3px}
.pool .fill{height:100%;background:linear-gradient(90deg,var(--brass),var(--brass-bright));border-radius:8px 0 0 8px}
.pool .nums{display:flex;justify-content:space-between;margin-top:8px;font-size:12.5px;color:var(--steel)}
.pool .big{font-family:"IBM Plex Mono",monospace;color:var(--brass-bright);font-weight:600}
.ycard{display:flex;align-items:center;gap:14px;margin-top:14px;border-top:1px solid var(--rule);padding-top:13px}
.ysquare{width:30px;height:42px;border-radius:5px;background:linear-gradient(180deg,#f4cf57,#e0ad32);box-shadow:0 4px 12px rgba(242,196,74,.22);flex:0 0 auto}
.ycard .lead-team{display:flex;align-items:center;gap:9px;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.03em;font-weight:600;font-size:17px}
.ycard .count{font-family:"IBM Plex Mono",monospace;color:var(--yellow);font-weight:600}
.ycard .ow{font-size:11px;color:var(--steel);font-family:"Hanken Grotesk",sans-serif;text-transform:none;letter-spacing:0;font-weight:400}
.ycard .note{font-size:12px;color:var(--steel)}.ycard .note b{color:var(--brass-bright);font-weight:600}

/* aligned fixtures + results: time | home(right) | mid | away(left) | end(right) */
.feed .frow{display:grid;grid-template-columns:50px 1fr 46px 1fr 64px;align-items:center;gap:10px;padding:9px 2px;border-bottom:1px solid rgba(217,180,74,.09)}
.feed .frow:last-child{border-bottom:0}
.ftime{font-family:"IBM Plex Mono",monospace;font-size:14px;color:var(--brass-bright);font-weight:500;line-height:1.12}
.ftime small{display:block;font-size:9px;color:var(--steel-dim);letter-spacing:.07em}
.fteam{display:flex;align-items:center;gap:8px;min-width:0}
.fteam.home{justify-content:flex-end}.fteam.away{justify-content:flex-start}
.fteam .col{display:flex;flex-direction:column;line-height:1.14;min-width:0}
.fteam.home .col{text-align:right;align-items:flex-end}
.fteam .tn{font-size:13.5px;font-weight:600;white-space:nowrap}
.fteam .ow{font-size:10.5px;color:var(--steel);white-space:nowrap}
.fmid{font-family:"IBM Plex Mono",monospace;text-align:center}
.fmid.vs{color:var(--steel-dim);font-size:12px}
.fmid.sc{color:var(--foam);font-weight:600;font-size:15px}
.fend{text-align:right;justify-self:end}
.tag{font-family:"Oswald",sans-serif;font-size:10px;letter-spacing:.1em;text-transform:uppercase;padding:3px 7px;border-radius:5px;font-weight:600;white-space:nowrap;color:var(--steel);border:1px solid var(--rule)}
.payout{font-size:11px;color:var(--live);white-space:nowrap}.payout.draw{color:var(--steel)}

.bscroll{overflow-x:auto;padding-bottom:6px}
.bracket{display:flex;gap:26px;min-width:740px;align-items:stretch;padding:4px 2px}
.bcol{display:flex;flex-direction:column;justify-content:space-around;gap:12px;flex:1}
.bcol .ct{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.12em;font-size:10.5px;color:var(--brass);text-align:center;margin-bottom:2px}
.tie{background:var(--sea-800);border:1px solid var(--rule);border-radius:9px;overflow:hidden}
.tie .t{display:flex;align-items:center;gap:7px;padding:6px 8px;font-size:12.5px;border-bottom:1px solid rgba(217,180,74,.1)}
.tie .t:last-child{border-bottom:0}
.tie .t.win{color:var(--foam);font-weight:600}.tie .t.win .sc{color:var(--brass-bright)}
.tie .t.out{color:var(--steel-dim)}
.tie .t .nm{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tie .t .sc{font-family:"IBM Plex Mono",monospace;font-weight:600}
.tbd{color:var(--steel-dim);font-style:italic}
.champ{align-self:center;text-align:center;background:linear-gradient(180deg,rgba(217,180,74,.18),rgba(217,180,74,.04));border:1px solid rgba(217,180,74,.5);border-radius:11px;padding:15px 16px}
.champ .lbl{font-family:"Oswald",sans-serif;letter-spacing:.16em;text-transform:uppercase;font-size:10px;color:var(--brass)}
.champ .nm{font-family:"Oswald",sans-serif;text-transform:uppercase;font-weight:700;font-size:18px;margin-top:6px;display:flex;align-items:center;gap:8px;justify-content:center}
.champ .prize{font-family:"IBM Plex Mono",monospace;color:var(--brass-bright);margin-top:3px;font-weight:600;font-size:13px}

/* TV view: safe-area margins + cycling standings */
.tv-eyebrow{font-family:"Oswald",sans-serif;font-size:10px;letter-spacing:.18em;color:var(--brass);text-transform:uppercase;margin:0 0 5px}
.tvframe{width:805px;max-width:100%}
.tv-shell{width:805px;height:453px;border-radius:16px;border:1px solid var(--rule);background:linear-gradient(180deg,#0a1626,#060d18);box-shadow:0 22px 56px rgba(0,0,0,.5),inset 0 0 0 6px rgba(0,0,0,.35);overflow:hidden;position:relative;transform-origin:top left}
.tv-pad{position:absolute;inset:0;padding:18px 26px;display:flex;flex-direction:column;gap:9px}
.tv-top{display:flex;align-items:center;gap:14px;border-bottom:1px solid var(--rule);padding:2px 0 11px}
.tv-top .tv-ball{width:34px;height:34px;color:var(--brass);flex:none}
.tv-top .ttl{font-family:"Oswald",sans-serif;font-weight:700;letter-spacing:.07em;text-transform:uppercase;font-size:32px;line-height:1}
.tv-qr{display:flex;align-items:center;gap:10px;flex:none}
.tv-qr-txt{text-align:right;font-size:10px;line-height:1.3;text-transform:uppercase;letter-spacing:.08em;color:var(--steel)}
.tv-qr-txt b{display:block;color:var(--brass-bright);font-size:11.5px;letter-spacing:.04em}
.tv-qr-img{width:50px;height:50px;background:#fff;padding:4px;border-radius:6px;flex:none;display:block}
.tv-top .sub{font-size:9px;letter-spacing:.2em;color:var(--brass);text-transform:uppercase}
.tv-cap{font-family:"Oswald",sans-serif;font-size:9.5px;letter-spacing:.16em;color:var(--brass);text-transform:uppercase}
.tv-live-strip{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.tvl{border:1px solid rgba(84,224,138,.3);border-radius:9px;background:rgba(84,224,138,.05);padding:4px 9px}
.tvl-min{font-family:"Oswald",sans-serif;font-size:8.5px;letter-spacing:.12em;text-transform:uppercase;color:var(--live);font-weight:600;margin-bottom:3px}
.tvl-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:6px}
.tvl-row .s{display:flex;align-items:center;gap:6px}.tvl-row .s.r{flex-direction:row-reverse}
.tvl-row .ab{font-family:"Oswald",sans-serif;font-weight:600;font-size:13px;letter-spacing:.04em}
.tvl-row .sc{font-family:"IBM Plex Mono",monospace;font-weight:600;color:var(--brass-bright);font-size:15px}
.tvl .flag.sm{width:18px;height:12px}
.tv-mid{flex:1;min-height:0;display:flex;flex-direction:column}
.tv-cap-row{display:flex;align-items:center;justify-content:space-between}
.tv-dots{display:flex;gap:5px;align-items:center}
.tv-dots i{width:6px;height:6px;border-radius:50%;background:var(--steel-dim);display:block;transition:background .3s}
.tv-dots i.on{background:var(--brass)}
.tv-pages{position:relative;flex:1;margin-top:4px}
.tv-page{position:absolute;inset:0;column-count:2;column-gap:26px;opacity:0;transition:opacity .45s;pointer-events:none}
.tv-page.on{opacity:1}
.tv-page .lr{break-inside:avoid;display:grid;grid-template-columns:20px 46px 1fr auto;gap:8px;align-items:center;padding:2px 2px;font-size:13.5px;border-bottom:1px solid rgba(217,180,74,.08)}
.tv-page .lr .r{font-family:"IBM Plex Mono",monospace;color:var(--steel-dim);font-size:12px;text-align:center}
.tv-page .lr .fl{display:flex;gap:3px}
.tv-page .lr .fl .flag.sm{width:15px;height:10px}
.tv-page .lr .n{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.tv-page .lr .a{font-family:"IBM Plex Mono",monospace;font-weight:600;text-align:right}
.tv-page .lr.t1{background:linear-gradient(90deg,rgba(217,180,74,.14),transparent 80%);border-radius:7px}
.tv-page .lr.t1 .a{color:var(--brass-bright)}.tv-page .lr.t1 .r{color:var(--brass)}
.tv-foot{display:grid;grid-template-columns:1.5fr 1fr;gap:18px;border-top:1px solid var(--rule);padding-top:9px;align-items:start}
.tv-next{display:flex;gap:12px;align-items:flex-start}
.nxlist{display:flex;flex-direction:column;gap:5px;min-width:0}
.tv-next .nx{display:flex;align-items:center;gap:6px;font-size:11px}
.tv-next .nx .tm{font-family:"IBM Plex Mono",monospace;color:var(--brass-bright);min-width:38px;flex:none}
.tv-next .nx .nxt{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0}
.tv-next .nx .nxv{color:var(--steel-dim);flex:none}
.tv-next .nx .flag.sm{width:16px;height:11px;flex:none}
.tv-pool .bar{height:8px;border-radius:6px;background:#060d18;border:1px solid var(--rule);overflow:hidden}
.tv-pool .fill{height:100%;background:linear-gradient(90deg,var(--brass),var(--brass-bright))}
.tv-pool .lab{display:flex;justify-content:space-between;font-size:10px;color:var(--steel);margin-top:3px}
.px-note{font-size:12px;color:var(--steel);margin-top:9px}.px-note b{color:var(--foam)}
footer{margin-top:32px;text-align:center;color:var(--steel-dim);font-size:12px}
footer a{color:var(--brass);text-decoration:none;border-bottom:1px solid rgba(217,180,74,.4)}
footer a:hover{color:var(--brass-bright)}

/* Standings rows link to a crew's own page */
a.lrow{color:inherit;text-decoration:none;cursor:pointer;border-radius:8px}
a.lrow:hover{background:linear-gradient(90deg,rgba(217,180,74,.12),transparent 80%)}
a.lrow:hover .name{color:var(--brass-bright)}

/* Crew and audit pages */
.backlink{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:13px;font-weight:600;color:var(--brass);text-decoration:none}
.backlink:hover{color:var(--brass-bright)}
.stats{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}
@media(max-width:760px){.stats{grid-template-columns:repeat(3,1fr)}}
@media(max-width:440px){.stats{grid-template-columns:repeat(2,1fr)}}
.stat{border:1px solid var(--rule);border-radius:10px;padding:10px 12px;background:rgba(12,27,48,.5)}
.stat .k{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--steel)}
.stat .v{font-family:"Oswald",sans-serif;font-weight:700;font-size:22px;color:var(--foam);margin-top:2px}
.stat .v small{font-size:12px;font-weight:500;color:var(--steel-dim)}
table.audit{width:100%;border-collapse:collapse}
table.audit th{text-align:left;font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--steel);border-bottom:1px solid var(--rule);padding:5px 6px}
table.audit td{padding:7px 6px;border-bottom:1px solid rgba(217,180,74,.09);font-size:13.5px;vertical-align:baseline}
table.audit td.when{color:var(--steel-dim);font-size:12px;white-space:nowrap}
table.audit td.detail{color:var(--foam)}
table.audit td.who{white-space:nowrap}
table.audit td.amt{font-family:"IBM Plex Mono",monospace;font-weight:600;text-align:right;color:var(--brass-bright);white-space:nowrap}
table.audit td.amt.neg{color:#e0716f}
.crewlink{color:var(--foam);text-decoration:none;border-bottom:1px solid rgba(217,180,74,.3)}
.crewlink:hover{color:var(--brass-bright)}
.auditnote{font-size:12.5px;color:var(--steel);margin:0 0 12px;max-width:70ch}
@media (prefers-reduced-motion: reduce){.dot{animation:none}}
:focus-visible{outline:2px solid var(--brass-bright);outline-offset:2px;border-radius:4px}

/* Pot side column: pot box and yellow-card leaderboard stacked */
.sidecol{display:flex;flex-direction:column;gap:16px}
.grid.even{grid-template-columns:1fr 1fr}
@media(max-width:900px){.grid.even{grid-template-columns:1fr}}

/* Prize summary inside the pot box */
.prizes{margin-top:13px;border-top:1px solid var(--rule);padding-top:11px;display:grid;grid-template-columns:1fr 1fr;gap:4px 20px}
.prow{display:flex;justify-content:space-between;align-items:baseline;gap:8px;font-size:12.5px;color:var(--steel)}
.prow span:last-child{color:var(--brass-bright);font-family:"IBM Plex Mono",monospace;font-weight:600;white-space:nowrap}
.ruleslink{display:inline-block;margin-top:13px;font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.06em;font-size:12px;font-weight:600;color:var(--brass);text-decoration:none}
.ruleslink:hover{color:var(--brass-bright)}

/* Yellow-card leaderboard */
.clb{display:flex;flex-direction:column}
.clrow{display:grid;grid-template-columns:20px 28px 1fr auto;align-items:center;gap:9px;padding:7px 4px;border-bottom:1px solid rgba(217,180,74,.08);position:relative}
.clrow:last-child{border-bottom:0}
.clrow .rank{font-family:"IBM Plex Mono",monospace;color:var(--steel-dim);font-size:13px;text-align:center}
.clrow .name{font-size:13.5px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.clrow .name .ow{font-size:11px;color:var(--steel);font-weight:400;margin-left:6px}
.clrow .amt{font-family:"IBM Plex Mono",monospace;font-weight:600;color:var(--yellow);font-size:15px;text-align:right}
.clrow.lead{background:linear-gradient(90deg,rgba(242,196,74,.12),transparent 78%);border-radius:8px}
.clnote{font-size:11.5px;color:var(--steel-dim);margin-top:10px}

/* Rules page */
.rules{max-width:760px}
.rules p{font-size:14px;color:var(--foam);line-height:1.55;margin:0 0 12px;max-width:68ch}
.rules h3{font-family:"Oswald",sans-serif;text-transform:uppercase;letter-spacing:.05em;font-size:14px;color:var(--brass);margin:20px 0 8px}
.rules .muted-note{color:var(--steel);font-size:13px}
.rules a{color:var(--brass);text-decoration:none;border-bottom:1px solid rgba(217,180,74,.4)}
.rules a:hover{color:var(--brass-bright)}
table.rtable{width:100%;border-collapse:collapse;margin:0 0 6px}
table.rtable td{padding:8px 6px;border-bottom:1px solid rgba(217,180,74,.1);font-size:14px}
table.rtable td.amt{text-align:right;font-family:"IBM Plex Mono",monospace;font-weight:600;color:var(--brass-bright);white-space:nowrap}

/* Mobile: keep the dashboard usable on a phone */
@media(max-width:640px){
  body{font-size:14.5px;padding-bottom:48px}
  .wrap{padding:0 13px}
  .topbar .wrap{flex-wrap:wrap;gap:8px 12px;padding:11px 14px}
  .brandtext .ttl{font-size:15px}
  .status{gap:11px}
  .updated{display:none}
  h2.section{font-size:17px}
  .grid{gap:13px;margin-top:14px}
  .card{padding:15px 14px 13px;border-radius:12px}
  /* live card: stack the two teams, each full width, with the score to the side,
     so names wrap at spaces and never break mid-word */
  .lc-row{grid-template-columns:1fr auto;grid-template-areas:"home homescore" "away awayscore";gap:8px 12px}
  .lc-row>.lc-team{grid-area:home;min-width:0}
  .lc-row>.lc-team.away{grid-area:away;flex-direction:row;text-align:left}
  /* one goal per team row, aligned with that team, instead of a combined score */
  .lc-score{display:contents}
  .lc-score .miniflap.sep{display:none}
  .lc-score .miniflap:first-child{grid-area:homescore}
  .lc-score .miniflap:last-child{grid-area:awayscore}
  .lc-score .miniflap{align-self:center;min-width:36px;height:32px;font-size:19px}
  .lc-team .nm{overflow-wrap:normal;word-break:normal;hyphens:none}
  /* crew standings: one full-width page at a time, swipe horizontally (flags kept) */
  .lb-swipe{gap:0;width:100%;max-width:100%;overflow-x:auto;overscroll-behavior-x:contain;scroll-snap-type:x mandatory;-webkit-overflow-scrolling:touch}
  .lb-page{flex:0 0 100%;width:100%;min-width:0;scroll-snap-align:start}
  .lb-hint{display:block;text-align:center;font-size:11px;letter-spacing:.04em;color:var(--steel-dim);margin-top:10px}
  /* feeds: match on top, time and payout below, names ellipsised, no mid-word breaks */
  .feed .frow{grid-template-columns:1fr auto 1fr;grid-template-areas:"home score away" "meta meta end";gap:4px 8px;padding:9px 0;align-items:center}
  .feed .ftime{grid-area:meta;display:flex;gap:6px;align-items:baseline}
  .feed .ftime small{display:inline}
  .feed .fteam.home{grid-area:home}
  .feed .fmid{grid-area:score}
  .feed .fteam.away{grid-area:away}
  .feed .fend{grid-area:end}
  .fteam{min-width:0}
  .fteam .col{min-width:0}
  .fteam .tn{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%;font-size:13px}
  .fteam .ow{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}
  /* ledger tables reflow to blocks: headline row + full-width detail + timestamp,
     so the description is never squeezed into a narrow column */
  table.audit thead{display:none}
  table.audit tr{display:grid;grid-template-columns:1fr auto;align-items:baseline;column-gap:10px;row-gap:2px;padding:9px 0;border-bottom:1px solid rgba(217,180,74,.09)}
  table.audit td{border:0;padding:0;font-size:13px}
  table.audit td.detail{color:var(--foam)}
  table.audit td.when{color:var(--steel-dim);font-size:11px}
  table.audit td.amt{text-align:right;white-space:nowrap}
  /* audit page: crew + amount headline, then detail, then timestamp */
  table.audit.wide td:nth-child(1){grid-row:3;grid-column:1/-1}
  table.audit.wide td:nth-child(2){grid-row:1;grid-column:1;font-weight:600}
  table.audit.wide td:nth-child(3){grid-row:2;grid-column:1/-1}
  table.audit.wide td:nth-child(4){grid-row:1;grid-column:2}
  /* crew winnings: detail + amount headline, then timestamp */
  table.audit.winnings td:nth-child(1){grid-row:2;grid-column:1/-1}
  table.audit.winnings td:nth-child(2){grid-row:1;grid-column:1}
  table.audit.winnings td:nth-child(3){grid-row:1;grid-column:2}
  /* crew yellows: player + minute headline, then the match */
  table.audit.cards td:nth-child(1){grid-row:1;grid-column:1;font-weight:600}
  table.audit.cards td:nth-child(2){grid-row:2;grid-column:1/-1}
  table.audit.cards td:nth-child(3){grid-row:1;grid-column:2}
  .stat .v{font-size:19px}
}

/* TV page is a single fullscreen frame, not the scrolling dashboard */
/* Transparent outside the rounded shell, so Xibo shows only the rounded box.
   A transparent body propagates to the page canvas (html has no background). */
body.tv{padding:0;min-height:100vh;display:flex;align-items:center;justify-content:center;background:transparent}
body.tv .tv-shell{box-shadow:none;inset:0}
