/* ===========================================================================
   SL TOTOMATOR — retro pixel / CRT arcade theme
   =========================================================================== */
:root{
  --bg:#070710; --bg2:#0d0d1c; --panel:#0a0a18;
  --grid:#15152c;
  --green:#39ff14; --amber:#ffb000; --magenta:#ff2e88;
  --cyan:#00e5ff; --red:#ff3b3b; --gold:#ffd23f;
  --ink:#c8f7d0; --dim:#5b6a78; --line:#243244;
}
*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0; background:var(--bg);
  color:var(--ink);
  font-family:'VT323',monospace;
  font-size:20px; line-height:1.05;
  image-rendering:pixelated;
  overflow:hidden;
}
/* faint pixel grid background */
.crt{
  height:100vh; display:flex; flex-direction:column;
  background:
    linear-gradient(transparent 0, transparent 23px, var(--grid) 24px) 0 0/24px 24px,
    linear-gradient(90deg, transparent 0, transparent 23px, var(--grid) 24px) 0 0/24px 24px,
    radial-gradient(120% 90% at 50% 0%, #11112a 0%, var(--bg) 70%);
  position:relative;
}
/* scanlines + flicker + vignette overlays */
.crt::before{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.28) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;
}
.crt::after{
  content:""; position:fixed; inset:0; z-index:9001; pointer-events:none;
  background:radial-gradient(130% 110% at 50% 50%, transparent 55%, rgba(0,0,0,.55) 100%);
  animation:flicker 6s infinite steps(60);
}
/* in fullscreen only the map renders, so re-add the scanlines onto it. NOTE: keep these
   as SEPARATE rules — grouping :fullscreen with :-webkit-full-screen makes Firefox treat
   the whole selector as invalid and drop it, so the scanlines vanish in fullscreen. */
#map-col:fullscreen::after{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.28) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;
}
#map-col:-webkit-full-screen::after{
  content:""; position:fixed; inset:0; z-index:9000; pointer-events:none;
  background:repeating-linear-gradient(0deg, rgba(0,0,0,.28) 0 1px, transparent 1px 3px);
  mix-blend-mode:multiply;
}
@keyframes flicker{ 0%,100%{opacity:.9} 47%{opacity:.84} 48%{opacity:1} 49%{opacity:.86} }

h2,.title,.badge,.stat-label,.panel-h,.pos,.route,.banner{
  font-family:'Press Start 2P',monospace;
}

/* ---------------------------------------------------------------- top bar */
#topbar{
  flex:0 0 auto; padding:10px 18px 8px;
  border-bottom:3px solid var(--line);
  background:linear-gradient(180deg,#13132c,#08081a);
  display:grid; grid-template-columns:1fr auto; grid-template-rows:auto auto;
  column-gap:16px; align-items:center;
}
.title{
  grid-row:1; grid-column:1;
  font-size:26px; letter-spacing:3px; color:var(--green);
  white-space:nowrap; word-spacing:-0.5em;   /* tighten the wide Press Start 2P space to ~half */
  /* glow in em so it scales with the font size (looks right on mobile too) */
  text-shadow:0 0 .22em var(--green),0 0 .6em rgba(57,255,20,.55),.12em .12em 0 #064d00;
}
.title .logo{color:var(--magenta);text-shadow:0 0 .3em var(--magenta)}
.subtitle{
  grid-row:2; grid-column:1; color:var(--cyan); font-size:15px; letter-spacing:1px;
  text-shadow:0 0 6px rgba(0,229,255,.5); margin-top:6px;
}
.status{grid-row:1/3; grid-column:2; display:flex; align-items:center; gap:12px}
.badge{
  font-size:11px; padding:7px 10px; border:2px solid currentColor; border-radius:2px;
  display:inline-flex; align-items:center; gap:.4em;
}
.badge .bdot{width:.62em;height:.62em;border-radius:50%;background:currentColor;flex:0 0 auto}
.badge.live{color:var(--red); text-shadow:0 0 8px var(--red); animation:blink 1.1s steps(2) infinite}
.badge.replay{color:var(--amber); text-shadow:0 0 8px var(--amber)}
@keyframes blink{50%{opacity:.25}}
.clock{font-size:30px;color:var(--amber);text-shadow:0 0 8px var(--amber);min-width:130px;text-align:right}
.poll{font-size:16px;color:var(--dim)}
.poll.ok{color:var(--green);text-shadow:0 0 6px var(--green)}
.poll.err{color:var(--red);text-shadow:0 0 6px var(--red)}

/* ---------------------------------------------------------------- menu / views */
#menu{flex:0 0 auto;display:flex;gap:8px;padding:8px 12px 0;border-bottom:3px solid var(--line);
  background:linear-gradient(180deg,#0c0c1c,#08081a)}
#menu button{font-family:'Press Start 2P';font-size:12px;color:var(--dim);cursor:pointer;
  background:#0a0a18;border:2px solid var(--line);border-bottom:none;padding:9px 14px 8px}
#menu button:hover{color:var(--ink)}
#menu button.active{color:var(--green);border-color:var(--green);text-shadow:0 0 7px rgba(57,255,20,.6);
  background:#0d160d}
#tote[hidden],#grid[hidden]{display:none!important}

/* ---------------------------------------------------------------- layout */
#grid{
  flex:1 1 auto; min-height:0;
  display:grid; grid-template-columns:minmax(360px,38%) 1fr; gap:12px;
  padding:12px;
}
.panel{
  background:linear-gradient(180deg,var(--panel),#06060f);
  border:3px solid var(--line);
  box-shadow:0 0 0 3px #000 inset, 0 0 18px rgba(0,0,0,.6);
  display:flex; flex-direction:column; min-height:0; position:relative;
}
.panel-h{
  flex:0 0 auto; margin:0; padding:9px 12px; font-size:13px; letter-spacing:1px;
  color:var(--dim);   /* base grey so any ellipsis is grey, not lime */
  border-bottom:2px solid var(--line);
  background:linear-gradient(180deg,#101028,#0a0a18);
}
.panel-h .pn{color:var(--green); text-shadow:0 0 .28em rgba(57,255,20,.55)}   /* the heading word */
.panel-h .dim{color:var(--dim);font-size:11px;text-shadow:none}   /* subtitle: no inherited glow */
#fs-btn{position:absolute;right:8px;top:6px;background:#0a0a18;color:var(--green);border:2px solid var(--line);
  font-size:13px;line-height:1;padding:3px 8px;cursor:pointer;z-index:2}
#fs-btn:hover{border-color:var(--green);text-shadow:0 0 6px var(--green)}
#map-col>.panel-h{position:relative;padding-right:42px}   /* room for the fullscreen button */
.dim{color:var(--dim)}

/* ---------------------------------------------------------------- left column */
#left-col{display:flex;flex-direction:column;gap:12px;min-height:0}
#paddock-col{flex:1 1 40%;min-height:0;overflow:hidden}
#races-col{flex:1 1 60%;min-height:0;overflow:hidden}
#paddock{flex:1 1 auto;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:8px}
#paddock::-webkit-scrollbar{width:10px}
#paddock::-webkit-scrollbar-thumb{background:var(--line);border:2px solid #000}
#races{flex:1 1 auto; overflow-y:auto; padding:10px; display:flex; flex-direction:column; gap:11px}
#races::-webkit-scrollbar{width:10px}
#races::-webkit-scrollbar-thumb{background:var(--line);border:2px solid #000}
.empty{padding:24px;text-align:center;color:var(--dim);font-size:22px}
.empty .dots{display:inline-block;width:1.6em;text-align:left}   /* reserve space so text doesn't shift */
.empty .dots::after{content:"";animation:dots 1.5s steps(4) infinite}
@keyframes dots{0%{content:""}25%{content:"."}50%{content:".."}75%{content:"..."}}

.race{
  border:2px solid var(--line); background:#08091a;
  box-shadow:3px 3px 0 #000; cursor:pointer;
}
.race:hover{border-color:#3a567a}
.race.selected{border-color:var(--green); box-shadow:3px 3px 0 #000,0 0 14px rgba(57,255,20,.45)}
.race.selected .banner{background:linear-gradient(90deg,#16331a,#0c0c22)}
.race.finished{border-color:var(--green); box-shadow:3px 3px 0 #000,0 0 12px rgba(57,255,20,.3)}
.race.winphoto{border-color:var(--gold)}
.winrow{padding:6px 9px;font-size:18px;color:var(--gold);text-shadow:0 0 8px rgba(255,210,63,.6);
  background:linear-gradient(90deg,#2a2208,#0c0c22);border-bottom:2px solid var(--line)}
.winrow b{color:#fff}
.winrow .ph{color:var(--red);text-shadow:0 0 8px var(--red)}
.runner.win{background:rgba(255,210,63,.08)}
.runner.win .rid{color:var(--gold);text-shadow:0 0 6px rgba(255,210,63,.6)}
.race .banner{
  display:flex; justify-content:space-between; align-items:center; gap:8px;
  padding:7px 9px; font-size:11px; letter-spacing:1px; overflow:hidden;
  background:linear-gradient(90deg,#1a1140,#0c0c22);
  border-bottom:2px solid var(--line); color:var(--cyan);
  text-shadow:0 0 6px rgba(0,229,255,.5);
}
/* card titles: one line, clip overflow (hub name truncates, status stays) */
.banner>span:first-child,.pbanner>span:first-child{min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--dim)}
.banner>span:last-child,.pbanner>span:last-child{white-space:nowrap;flex:0 0 auto}
.panel-h{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.race .pill{font-size:9px; padding:4px 6px; border:2px solid currentColor;
  display:inline-flex; align-items:center; gap:3px}
.race .pill .fg{font-size:11px; line-height:1}
.race .pin{font-size:9px;color:var(--gold);text-shadow:0 0 6px rgba(255,210,63,.6)}
.follow{color:var(--green);text-shadow:0 0 6px var(--green)}
.banner .follow,.pbanner .follow{font-size:inherit}   /* same size as the title */
.pill.live{color:var(--green)}
.pill.photo{color:var(--red); text-shadow:0 0 8px var(--red)}
.pill.done{color:var(--gold); text-shadow:0 0 7px rgba(255,210,63,.5)}
.pill.settled{color:var(--dim)}
.race .field{padding:6px 8px; display:flex; flex-direction:column; gap:4px}

.runner{
  display:grid; grid-template-columns:46px 1fr 78px 56px; align-items:center;
  gap:7px; padding:3px 4px; font-size:19px; position:relative;
}
.runner .pos{
  font-size:11px; text-align:center; color:var(--dim);
}
.runner.p1 .pos{color:var(--ink)}
.runner .route{
  font-size:9px; color:#001; border:2px solid #000; line-height:1;  /* bg set inline */
  align-self:stretch; display:flex; align-items:center; justify-content:center; margin-right:5px;
}
.runner .route.fav{box-shadow:0 0 0 2px #fff,0 0 7px rgba(255,255,255,.6)}
.runner .name{display:flex;flex-direction:column;min-width:0}
.runner .rid{color:var(--ink);letter-spacing:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.runner.fin .rid{color:var(--green)}
.runner.dq{opacity:.62}
.runner.dq .rid{text-decoration:line-through;color:#ff8a8a}
.brow.dq{opacity:.62}
.brow.dq .bid{text-decoration:line-through;color:#ff8a8a}
.runner .bar{
  height:9px; margin-top:3px; background:#05050d; border:1px solid var(--line);
  position:relative; overflow:hidden;
}
.runner .bar .fill{
  position:absolute; right:0; top:0; bottom:0;
  background:repeating-linear-gradient(90deg,var(--cyan) 0 6px, #0a3a44 6px 8px);
  transition:width .9s linear; box-shadow:0 0 8px rgba(0,229,255,.6);
}
.runner.fin .bar .fill{width:100%!important;background:var(--green);box-shadow:0 0 8px var(--green)}
.runner .eta{font-variant-numeric:tabular-nums;text-align:right;color:var(--amber);text-shadow:0 0 6px rgba(255,176,0,.5)}
.runner.fin .eta{color:var(--green);text-shadow:0 0 6px var(--green)}
.runner .odds{text-align:right;color:var(--magenta);text-shadow:0 0 6px rgba(255,46,136,.5);font-size:16px}
.runner .gps{position:absolute;left:-2px;top:2px;font-size:9px}

/* paddock (upcoming / betting) cards */
.pad{border:2px solid var(--line);background:#0a0a1c;box-shadow:3px 3px 0 #000;cursor:pointer}
.pad:hover{border-color:#3a567a}
.pad.selected{border-color:var(--green);box-shadow:3px 3px 0 #000,0 0 13px rgba(57,255,20,.45)}
.pad .pbanner{display:flex;justify-content:space-between;align-items:center;gap:8px;overflow:hidden;padding:7px 9px;font-size:18px;
  letter-spacing:.5px;background:linear-gradient(90deg,#241640,#0c0c22);border-bottom:2px solid var(--line)}
.pad .off{color:var(--gold);text-shadow:0 0 7px rgba(255,210,63,.6);font-size:19px;display:inline-flex;align-items:center;gap:.3em}
#map-sel b{font-weight:inherit}
#map-sel .t-off{color:var(--amber)} #map-sel .t-run{color:var(--green)} #map-sel .t-fin{color:var(--gold)}
/* checkered finish flag via an SVG checkerboard (conic-gradient fails on some Firefox) */
.pill .fg.flag{width:.95em;height:.72em;border:1px solid currentColor;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='2' height='2' fill='%23000'/%3E%3Crect x='2' y='2' width='2' height='2' fill='%23000'/%3E%3C/svg%3E") 0/4px 4px}
.pad .off.atpost{color:var(--red);text-shadow:0 0 8px var(--red);animation:blink 1s steps(2) infinite}
.pad .pfield{padding:6px 8px;display:flex;flex-direction:column;gap:4px}
.brow{display:grid;grid-template-columns:46px 1fr 70px 52px;gap:8px;align-items:center;font-size:21px;padding:2px 0 2px 3px}
.brow .route{font-size:11px;text-align:center;padding:5px 0;color:#001;border:2px solid #000;line-height:1}
.brow .route.fav{box-shadow:0 0 0 2px #fff,0 0 7px rgba(255,255,255,.6)}
.brow .bid{color:var(--ink);letter-spacing:1px;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.brow .bodds{text-align:right;color:var(--magenta);text-shadow:0 0 7px rgba(255,46,136,.5);font-size:23px}
.brow .bwin{text-align:right;color:#8aa6b8;font-size:17px}

/* ---------------------------------------------------------------- map */
#map-col{overflow:hidden}
#map{flex:1 1 auto;min-height:0;background:#0a1020;position:relative}
/* 3..2..1..GO! overlay when the followed race starts */
#mapcount{display:none;position:absolute;top:8px;left:50%;transform:translateX(-50%);z-index:500;
  pointer-events:none;font-family:'Press Start 2P';font-size:13px;color:var(--amber);
  background:rgba(8,8,20,.7);border:2px solid var(--line);padding:6px 10px;
  text-shadow:0 0 7px rgba(255,176,0,.6)}
#gocount{display:none;position:absolute;inset:0;z-index:500;pointer-events:none;
  align-items:center;justify-content:center;font-family:'Press Start 2P';
  color:var(--amber);text-shadow:0 0 18px var(--amber),4px 4px 0 #000;}
#gocount.go-show{font-size:120px;animation:gopop .9s ease-out}
#gocount.go-go{color:var(--green);text-shadow:0 0 22px var(--green),4px 4px 0 #000;font-size:96px}
@keyframes gopop{0%{transform:scale(2.2);opacity:0}25%{opacity:1}100%{transform:scale(1);opacity:.95}}
.leaflet-container{background:#0a1020;font-family:'VT323',monospace}
/* single dark basemap, brightened + higher contrast so roads/edges and the
   street labels read clearly without crushing to black */
.leaflet-tile{filter:brightness(2.25) contrast(1.55) saturate(1.4) hue-rotate(-6deg)}
.leaflet-control-attribution{background:rgba(0,0,0,.5)!important;color:#456!important;font-size:10px}
.leaflet-control-attribution a{color:#69c!important}
.leaflet-bar a{background:#0a0a18;color:var(--green);border-color:var(--line)}

.legend{
  flex:0 0 auto; display:flex; gap:14px; flex-wrap:wrap; padding:6px 10px;
  font-size:14px; color:var(--dim); border-top:2px solid var(--line); background:#08081a;
}
.legend .sw{display:inline-block;width:11px;height:11px;margin-right:5px;vertical-align:-1px;border:1px solid #000}
.sw.hub{background:repeating-conic-gradient(#fff 0 25%, #000 0 50%) 0/8px 8px}
.sw.lead{background:var(--gold);box-shadow:0 0 6px var(--gold)}
.sw.run{background:var(--cyan)}
.sw.eta{background:transparent;border:1px dashed var(--cyan)}

/* map markers (DivIcons) */
.hub-marker{position:relative;transition:opacity .3s}
.hub-marker.dim{opacity:.32;filter:grayscale(.55)}
.hub-marker.dim .hub-ring{display:none}
.hub-flag{
  width:14px;height:14px;border:2px solid #fff;
  background:repeating-conic-gradient(#fff 0 25%, #000 0 50%) 0/7px 7px;
  box-shadow:0 0 0 2px #000,0 0 12px rgba(255,255,255,.5);
}
.hub-dot{width:11px;height:11px;border:2px solid #fff;border-radius:50%}
/* each route's own solid finish dot, in the runner's colour, at the end of its route */
.fin-dot{border:2px solid #000;border-radius:50%}
/* checkered finish flag at the top of the finish hull */
.fin-flag .pole{position:absolute;left:0;bottom:0;width:2px;height:22px;background:#fff;box-shadow:0 0 2px #000}
.fin-flag .cloth{position:absolute;left:2px;top:0;width:15px;height:11px;border:1px solid #000;
  background:#fff url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='4' height='4'%3E%3Crect width='2' height='2' fill='%23000'/%3E%3Crect x='2' y='2' width='2' height='2' fill='%23000'/%3E%3C/svg%3E") 0/5px 5px;box-shadow:0 0 6px rgba(0,0,0,.7)}
.hub-ring{
  position:absolute; left:50%; top:50%; width:16px;height:16px;
  border:3px solid var(--green); border-radius:50%;
  transform:translate(-50%,-50%); animation:ring 2s ease-out infinite; opacity:0;
  box-shadow:0 0 12px currentColor;
}
@keyframes ring{0%{width:16px;height:16px;opacity:1}70%{opacity:.45}100%{width:170px;height:170px;opacity:0}}
.hub-label{
  position:absolute; left:16px; top:-4px; white-space:nowrap;
  font-family:'Press Start 2P'; font-size:11px; color:#eaf2ff;
  text-shadow:1px 1px 0 #000,-1px 1px 0 #000,1px -1px 0 #000,-1px -1px 0 #000,0 0 6px rgba(0,0,0,.9);
}
/* a centred pill that grows to fit the line number (1-3 digits) */
.run-dot{position:absolute;left:12px;top:12px;transform:translate(-50%,-50%);
  min-width:22px;height:22px;padding:0 5px;border:2px solid #000;box-shadow:0 0 8px rgba(255,255,255,.4);
  display:flex;align-items:center;justify-content:center;border-radius:4px;white-space:nowrap}
.run-dot b{font-family:'Press Start 2P';font-size:11px;color:#001;line-height:1}
.run-dot.lead{min-width:26px;height:28px;border:2px solid #fff;box-shadow:0 0 11px rgba(255,255,255,.55)}
.run-dot.lead b{font-size:13px}
.run-dot.eta{border-style:dashed;border-color:#fff;opacity:.82}
.run-dot.fin{box-shadow:0 0 0 3px var(--green)}
/* disqualified (GPS down ≥20 s): dim, red-dashed, struck-through name — stays for the race */
.run-dot.dq{border-style:dashed;border-color:#ff5a5a;opacity:.5}
.run-marker .dot-label.dq{text-decoration:line-through;color:#ff8a8a;opacity:.7}
/* GPS-down warning tag (amber, seconds counting up) — pulses to flag the disqual risk */
.run-marker .gps-tag{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);
  white-space:nowrap;font-family:'VT323';font-size:13px;line-height:1;color:#001;
  background:#ffd24a;border:1px solid #000;padding:2px 5px;border-radius:3px;
  box-shadow:1px 1px 0 #000;pointer-events:none;letter-spacing:.02em;
  animation:gps-pulse 1s ease-in-out infinite}
@keyframes gps-pulse{0%,100%{opacity:1}50%{opacity:.55}}
/* the DISQUALIFIED stamp shown for 4 s when the break is called (red, steady) */
.run-marker .gps-tag.dq{background:#ff3b3b;color:#fff;font-weight:bold;animation:none;
  border-color:#000;box-shadow:1px 1px 0 #000,0 0 8px rgba(255,59,59,.7)}
.run-marker .dot-label{position:absolute;top:30px;left:50%;transform:translateX(-50%);
  white-space:nowrap;font-family:'VT323';font-size:14px;line-height:1;color:#dfe9f2;
  text-shadow:0 0 4px #000,1px 1px 0 #000,-1px 1px 0 #000,1px -1px 0 #000,-1px -1px 0 #000;
  pointer-events:none}
.run-tip{background:#0a0a18!important;border:2px solid var(--line)!important;color:var(--ink)!important;
  font-family:'VT323'!important;font-size:15px!important;box-shadow:2px 2px 0 #000!important;border-radius:0!important}
.run-tip::before{display:none!important}

/* ---------------------------------------------------------------- tote board (own page) */
#tote{flex:1 1 auto; min-height:0; margin:12px}
#tote-grid{
  flex:1 1 auto; display:grid;
  grid-template-columns:repeat(3,1fr); grid-auto-rows:minmax(130px,1fr);
  gap:12px; padding:12px; min-height:0;
}
.stat.wide{grid-column:1 / -1}   /* RECENT RESULTS spans the full width on its own row */
.stat{border:2px solid var(--line);background:#08091a;padding:8px;display:flex;flex-direction:column;min-height:0;box-shadow:2px 2px 0 #000}
.stat-label{font-size:9px;color:var(--cyan);letter-spacing:1px;margin-bottom:6px;text-shadow:0 0 6px rgba(0,229,255,.4)}
.stat-num{font-family:'Press Start 2P';font-size:32px;color:var(--green);text-shadow:0 0 10px var(--green);margin-top:2px}
.stat-num.sm{font-size:24px}
.stat-sub{font-size:15px;color:var(--dim);margin-top:auto}
.chart{display:flex;flex-direction:column;gap:3px;justify-content:center;flex:1}
.chart .row{display:grid;grid-template-columns:34px 1fr 30px;gap:6px;align-items:center;font-size:15px}
.chart .row .k{color:var(--amber);text-align:right}
.chart .row .b{height:13px;background:#05050d;border:1px solid var(--line);position:relative}
.chart .row .b i{position:absolute;left:0;top:0;bottom:0;background:repeating-linear-gradient(90deg,var(--magenta) 0 5px,#4a0d29 5px 7px);box-shadow:0 0 6px rgba(255,46,136,.5)}
.chart .row.hot .b i{background:repeating-linear-gradient(90deg,var(--gold) 0 5px,#5a4400 5px 7px)}
.chart .row .v{color:var(--dim);font-size:13px}
.recent{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:2px;font-size:16px}
.recent .r{display:grid;grid-template-columns:auto 1fr auto;gap:8px;border-bottom:1px dotted var(--line);padding:2px 0}
.recent .r .hub{color:var(--cyan)}
.recent .r .out{color:var(--gold)}
.recent .r .out.fav{color:var(--dim)}
.recent .r .g{color:var(--magenta);text-align:right}
.recent .r.flash{animation:rflash 1.2s steps(2) 2}
@keyframes rflash{50%{background:rgba(57,255,20,.18)}}

@media(max-width:1100px){
  /* stacked cards-over-map: minmax(0,…) lets the rows SHRINK to the viewport instead of
     overflowing it (plain 1fr keeps each row at its min-content height -> too tall). The
     map gets a slightly smaller share so the pair fits comfortably. */
  #grid{grid-template-columns:1fr; grid-template-rows:minmax(0,1fr) minmax(0,0.9fr); overflow:hidden}
  #tote-grid{grid-auto-rows:minmax(120px,auto)}
  #tote{height:auto}
}

/* ---- mobile: let the whole page scroll, stack the panels, give them real height */
@media(max-width:760px){
  body{overflow:auto}
  .crt{height:auto; min-height:100vh}
  #topbar{grid-template-columns:1fr; row-gap:4px}
  .title{font-size:20px} .subtitle{font-size:13px}
  .status{grid-row:auto; grid-column:1; justify-content:flex-start}
  #grid{display:block; padding:8px}
  #left-col{display:block}
  #paddock-col,#races-col,#map-col{overflow:visible; margin-bottom:10px}
  #paddock,#races{overflow:visible}
  #map-col{height:100vh;display:flex;flex-direction:column}
  #map{flex:1 1 auto;height:auto;min-height:0}
  .panel{display:block}
  #tote{margin:8px}
  #tote-grid{grid-template-columns:1fr; grid-auto-rows:auto}
  .stat{min-height:120px}
}
