/* ════════════════════════════════════════════════
 Mystic John - The Racing Oracle
 Stylesheet (loaded after bootstrap-utilities)
 ════════════════════════════════════════════════ */

/* ── Reset & Variables ─────────────────────────── */
*{margin:0;padding:0;box-sizing:border-box}
:root{
 --bg:#0a0a1a;--surface:#1a1a2e;--card:#16162a;
 --primary:#7c3aed;--accent:#9d4edd;--gold:#f59e0b;
 /* --accent darkened to #9d4edd so white text on accent gradients meets AA (4.6:1). */
 /* --accent-text: AA-compliant (>=4.5:1 on card/surface) variant for text/icons; --accent stays for borders & gradients */
 --accent-text:#c084fc;
 --text:#e2e8f0;--muted:#94a3b8;
 /* --dim used only for decorative borders; --dim-text is the AA-compliant text variant */
 --dim:#475569;--dim-text:#7e90a6;
 --green:#22c55e;--red:#ef4444;
 --radius:14px;
}
html,body{height:100%;font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif;background:var(--bg);color:var(--text);overflow-x:hidden;-webkit-tap-highlight-color:transparent}
body{background:
 radial-gradient(circle at 20% 0%,rgba(124,58,237,.18),transparent 45%),
 radial-gradient(circle at 90% 10%,rgba(245,158,11,.10),transparent 40%),
 var(--bg);
 min-height:100vh}

.wrap{max-width:680px;margin:0 auto;padding:18px 16px 60px}

/* ── Accessibility: skip link + visible keyboard focus ── */
.skip-link{position:absolute;top:8px;left:8px;z-index:50;background:var(--card);color:var(--text);padding:10px 16px;border-radius:10px;border:1px solid var(--accent)}
.skip-link:not(:focus):not(:focus-within){position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
a:focus-visible,button:focus-visible,select:focus-visible,[tabindex]:focus-visible{outline:3px solid var(--gold);outline-offset:2px;border-radius:6px}

/* ── Title ─────────────────────────────────────── */
.title{text-align:center;position:relative}
/* Top-right action cluster: text-size + sound, always side by side */
.title-actions{position:absolute;top:0;right:0;display:flex;align-items:center;gap:8px}
.sound-toggle{position:relative;width:38px;height:38px;flex:none;border-radius:50%;background:var(--card);border:1px solid rgba(124,58,237,.2);color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .18s}
.sound-toggle:hover{color:var(--text);border-color:rgba(124,58,237,.4)}
.sound-toggle.on{color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));border-color:transparent;box-shadow:0 3px 12px rgba(124,58,237,.35)}
/* Text-size enlarger — same pill as sound */
.text-size-toggle{font-size:0;gap:1px}
.text-size-toggle .tsz-a{font-size:16px;font-weight:800;line-height:1;letter-spacing:-.5px}
.text-size-toggle .tsz-sign{font-size:11px;font-weight:900;line-height:1;letter-spacing:-1px;margin-left:1px}
.text-size-toggle .tsz-sign:empty{display:none;margin:0}
.text-size-toggle.shrinking .tsz-sign{color:var(--gold)}
.text-size-toggle.active{color:#fff;background:linear-gradient(135deg,var(--primary),var(--accent));border-color:transparent;box-shadow:0 3px 12px rgba(124,58,237,.35)}
.text-size-toggle[data-level="large"] .tsz-a{font-size:17px}
.text-size-toggle[data-level="xl"] .tsz-a{font-size:19px}
.title .logo{display:block;width:min(62vw,260px);height:auto;margin:0 auto 2px;filter:drop-shadow(0 4px 14px rgba(124,58,237,.4))}
.title .tagline{color:var(--muted);font-size:13px;font-style:italic}

/* ── Mystic John Stage (responsive circle) ─────── */
.stage{position:relative;display:flex;flex-direction:column;align-items:center;margin:6px 0 14px}

/* the orb sizes itself to the viewport but is capped */
.john-orb{position:relative;width:min(64vw,300px);aspect-ratio:1/1;border-radius:50%}

/* rotating conic ring */
.john-orb:before{content:'';position:absolute;inset:-6px;border-radius:50%;
 background:conic-gradient(from 0deg,var(--accent),var(--gold),var(--primary),var(--accent));
 filter:blur(6px);opacity:.55;animation:ringspin 9s linear infinite;z-index:0}
@keyframes ringspin{to{transform:rotate(360deg)}}

/* outer glow halo */
.john-orb:after{content:'';position:absolute;inset:-18%;border-radius:50%;
 background:radial-gradient(circle,rgba(124,58,237,.35) 0%,rgba(124,58,237,.10) 50%,transparent 72%);
 filter:blur(4px);animation:halo 4s ease-in-out infinite;pointer-events:none;z-index:0}
@keyframes halo{0%,100%{opacity:.7;transform:scale(1)}50%{opacity:1;transform:scale(1.06)}}

/* contact shadow under the ball so it sits like a real object */
.john-orb .ball-shadow{position:absolute;left:50%;bottom:-9%;transform:translateX(-50%);width:62%;height:8%;border-radius:50%;z-index:0;
 background:radial-gradient(ellipse at center,rgba(0,0,0,.55) 0%,rgba(0,0,0,.25) 55%,transparent 75%);filter:blur(3px)}

/* the clipped circular frame holding John (the glass interior) */
.john-stack{position:absolute;inset:0;border-radius:50%;overflow:hidden;z-index:1;
 background:radial-gradient(circle at 50% 38%,#2a2050 0%,#16143a 52%,#0a0a1a 100%);
 box-shadow:inset 0 0 40px rgba(124,58,237,.4),inset 0 -18px 40px rgba(0,0,0,.6),0 10px 34px rgba(0,0,0,.55)}
.john-stack img{position:absolute;left:50%;bottom:-1%;width:98%;height:98%;transform:translateX(-50%);object-fit:contain;object-position:bottom center;opacity:0;transition:opacity .45s ease;
 filter:saturate(.88) brightness(.97) contrast(1.02);
 -webkit-mask-image:linear-gradient(to bottom,#000 60%,rgba(0,0,0,.55) 78%,transparent 96%);
 mask-image:linear-gradient(to bottom,#000 60%,rgba(0,0,0,.55) 78%,transparent 96%)}

/* drifting inner fog inside the glass */
.john-stack .fog{position:absolute;inset:-20%;z-index:2;pointer-events:none;opacity:.5;mix-blend-mode:screen;
 background:radial-gradient(40% 30% at 30% 35%,rgba(168,85,247,.35),transparent 70%),
 radial-gradient(35% 25% at 70% 60%,rgba(124,58,237,.30),transparent 70%),
 radial-gradient(30% 22% at 55% 30%,rgba(245,158,11,.14),transparent 70%);
 animation:fogswirl 14s linear infinite}
@keyframes fogswirl{0%{transform:rotate(0) scale(1)}50%{transform:rotate(180deg) scale(1.1)}100%{transform:rotate(360deg) scale(1)}}

/* glass surface: rim light + refraction tint + specular highlight */
.john-orb .glass{position:absolute;inset:0;border-radius:50%;z-index:3;pointer-events:none;
 background:
 radial-gradient(circle at 50% 50%,transparent 60%,rgba(168,85,247,.25) 88%,rgba(220,200,255,.55) 97%,rgba(255,255,255,.15) 100%),
 radial-gradient(circle at 38% 32%,rgba(255,255,255,.10),transparent 45%);
 box-shadow:inset 0 0 22px rgba(180,150,255,.4),inset 0 6px 18px rgba(255,255,255,.10)}
/* the bright glossy specular highlight (top-left) */
.john-orb .glass:before{content:'';position:absolute;top:9%;left:14%;width:34%;height:24%;border-radius:50%;
 background:radial-gradient(circle at 40% 40%,rgba(255,255,255,.85),rgba(255,255,255,.25) 45%,transparent 72%);
 transform:rotate(-18deg);filter:blur(1px)}
/* small secondary glint bottom-right */
.john-orb .glass:after{content:'';position:absolute;bottom:16%;right:20%;width:12%;height:9%;border-radius:50%;
 background:radial-gradient(circle,rgba(255,255,255,.5),transparent 70%);filter:blur(1px)}
.john-stack img.show{opacity:1}
/* mist pooling at the base so the fade reads as fog, not a crop */
.john-stack:after{content:'';position:absolute;left:0;right:0;bottom:0;height:42%;z-index:2;pointer-events:none;
 background:linear-gradient(to top,#12122a 0%,rgba(18,18,42,.85) 28%,rgba(18,18,42,.35) 60%,transparent 100%)}
.john-stack.bob img.show{animation:bob 3.5s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translateX(-50%) translateY(0)}50%{transform:translateX(-50%) translateY(-6px)}}
.john-stack.thinking img.show{animation:think 1.6s ease-in-out infinite}
@keyframes think{0%,100%{transform:translateX(-50%) translateY(0) rotate(-1deg)}50%{transform:translateX(-50%) translateY(-4px) rotate(1.5deg)}}
/* Cheer is a celebratory burst, NOT an endless loop - it runs a few bounces
 then JS settles John into the calm bob (see reactToResult). */
.john-stack.cheer img.show{animation:cheer .5s ease-in-out 5}
@keyframes cheer{0%,100%{transform:translateX(-50%) translateY(0) scale(1.02)}50%{transform:translateX(-50%) translateY(-9px) scale(1.05)}}

/* speech bubble */
.bubble{position:relative;background:var(--card);border:1px solid rgba(124,58,237,.35);border-radius:16px;padding:12px 16px;max-width:520px;text-align:center;box-shadow:0 6px 20px rgba(0,0,0,.35)}
.bubble:before{content:'';position:absolute;top:-9px;left:50%;transform:translateX(-50%) rotate(45deg);width:16px;height:16px;background:var(--card);border-left:1px solid rgba(124,58,237,.35);border-top:1px solid rgba(124,58,237,.35)}
.bubble .say{font-size:14px;font-style:italic;color:var(--accent-text);min-height:18px}
.bubble .say.dots:after{content:'';animation:dots 1.4s steps(4,end) infinite}
@keyframes dots{0%{content:''}25%{content:'.'}50%{content:'..'}75%{content:'...'}}

/* ── Controls ──────────────────────────────────── */
.controls{display:flex;flex-direction:column;gap:10px;margin:8px 0 18px}
.ctrl{display:flex;flex-direction:column;gap:5px}
.ctrl label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--accent-text)}
.select-wrap{position:relative}
.select-wrap:after{content:'▼';position:absolute;right:14px;top:50%;transform:translateY(-50%);color:var(--muted);font-size:11px;pointer-events:none}
select{width:100%;appearance:none;-webkit-appearance:none;background:var(--card);color:var(--text);border:1px solid rgba(124,58,237,.3);border-radius:12px;padding:14px 38px 14px 14px;font-size:15px;cursor:pointer}
select:disabled{opacity:.5;cursor:not-allowed}
select:focus{outline:none;border-color:var(--accent)}

/* ── NAP banner ────────────────────────────────── */
.nap-banner{background:linear-gradient(135deg,var(--gold),#d97706);color:#0a0a1a;text-align:center;padding:10px;border-radius:12px;font-size:13px;font-weight:800;letter-spacing:2px;margin-bottom:14px;box-shadow:0 0 24px rgba(245,158,11,.35)}

/* ── Race Cards ────────────────────────────────── */
.race-card{background:var(--card);border:1px solid rgba(124,58,237,.15);border-radius:var(--radius);padding:18px;margin-bottom:16px;opacity:0;transform:translateY(16px);transition:opacity .45s,transform .45s}
.race-card.visible{opacity:1;transform:translateY(0)}
.race-card.nap-card{border-color:var(--gold);box-shadow:0 0 22px rgba(245,158,11,.15)}

/* ── NAP / Oracle's Chosen One: INVERTED GOLD treatment ──
 The chosen one glows golden against the dark purple UI - a light,
 premium card with dark ink, the visual opposite of every other card. */
.race-card.nap-card{
 background:linear-gradient(160deg,#fde68a 0%,#f8c54a 40%,#f0a818 100%);
 border:1px solid #b8860b;
 color:#2a1c00;
 box-shadow:0 0 40px rgba(245,158,11,.45),0 8px 28px rgba(0,0,0,.35);
 position:relative;
 overflow:hidden;
}
/* subtle shimmer sheen across the gold */
.race-card.nap-card::before{
 content:'';position:absolute;inset:0;pointer-events:none;
 background:linear-gradient(115deg,transparent 30%,rgba(255,255,255,.35) 48%,transparent 66%);
 background-size:250% 100%;
 animation:napSheen 5.5s ease-in-out infinite;
}
@keyframes napSheen{0%{background-position:140% 0}60%,100%{background-position:-40% 0}}
.race-card.nap-card > *{position:relative;z-index:1}

/* Inner banner sits on gold - invert to dark so it reads as a crest */
.race-card.nap-card .nap-banner{background:linear-gradient(135deg,#2a1c00,#4a3210);color:var(--gold);box-shadow:0 0 18px rgba(0,0,0,.25)}

/* Text + chips inside the gold card flip to dark ink */
.race-card.nap-card .race-name,
.race-card.nap-card .pick-horse,
.race-card.nap-card .pick-label,
.race-card.nap-card .mystic-phrase,
.race-card.nap-card .pick-num,
.race-card.nap-card .race-info,
.race-card.nap-card .gauge-label,
.race-card.nap-card .pick-details{color:#2a1c00}
.race-card.nap-card .pick-label,
.race-card.nap-card .mystic-phrase{color:#5a3d05}
.race-card.nap-card .race-time{background:#2a1c00;color:var(--gold)}
.race-card.nap-card .badge{background:rgba(42,28,0,.12);border-color:rgba(42,28,0,.3);color:#3d2a05}

/* The pick panel: warm cream so it lifts off the gold */
.race-card.nap-card .pick{background:rgba(255,255,255,.45);border:1px solid rgba(184,134,11,.4)}
.race-card.nap-card .pick-odds{background:#2a1c00;color:var(--gold)}
.race-card.nap-card .pick-details .bi{color:#7a5410}
.race-card.nap-card .crystals{color:#6b4e05}
.race-card.nap-card .crystals .bi{filter:none}
.race-card.nap-card .crystals .bi.dim{color:#6b4e05;opacity:.32}
.race-card.nap-card .crystals .bi{filter:drop-shadow(0 0 4px rgba(120,80,0,.45))}

/* Gauge inverted to dark track + gold fill on cream */
.race-card.nap-card .gauge{background:rgba(42,28,0,.18)}
.race-card.nap-card .gauge-fill{background:linear-gradient(90deg,#7c3aed,#b8860b,#2a1c00)}

/* Secondary + expanders on gold: cream panels, dark text */
.race-card.nap-card .secondary-pick{background:rgba(255,255,255,.4)}
.race-card.nap-card .secondary-pick .label{color:#5a3d05}
.race-card.nap-card .secondary-pick .name{color:#2a1c00}
.race-card.nap-card .secondary-pick .odds{color:#6b4a0a}
.race-card.nap-card .expand-btn{background:rgba(255,255,255,.4);border-color:rgba(184,134,11,.45);color:#2a1c00}
.race-card.nap-card .expand-content{color:#4a3210}
.race-card.nap-card .wisdom-picks{color:#7a5410}
.race-card.nap-card th{color:#5a3d05}
.race-card.nap-card td{border-bottom-color:rgba(184,134,11,.25)}

/* Keep the Back-bet button bold and contrasting (dark on gold) */
.race-card.nap-card .btn-bet{background:linear-gradient(135deg,#2a1c00,#4a3210);color:var(--gold);box-shadow:0 4px 16px rgba(0,0,0,.3)}
.race-header{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}
.race-time{background:var(--primary);color:#fff;padding:4px 10px;border-radius:8px;font-size:13px;font-weight:700}
.race-name{flex:1 1 100%;color:var(--text);font-size:14px;font-weight:600;margin-top:2px}
.race-info{color:var(--muted);font-size:12px}
.badge{display:inline-block;background:var(--surface);border:1px solid var(--dim);padding:2px 8px;border-radius:6px;font-size:11px;color:var(--muted)}

.pick{background:var(--surface);border-radius:12px;padding:16px;margin-bottom:12px}
.pick-label{font-size:11px;text-transform:uppercase;letter-spacing:2px;color:var(--accent-text);margin-bottom:8px}
.pick-horse{font-size:22px;font-weight:700;margin-bottom:4px}
.pick-num{color:var(--muted);font-size:13px}
.pick-odds{display:inline-block;background:var(--gold);color:#0a0a1a;padding:3px 10px;border-radius:6px;font-size:14px;font-weight:700;margin-right:8px}
.crystals{font-size:16px;margin:8px 0;color:var(--gold);display:flex;gap:4px;align-items:center}
.crystals .bi{filter:drop-shadow(0 0 6px rgba(245,158,11,.5))}
.crystals .bi.dim{opacity:.18}
.pick-details .bi,.secondary-pick .label .bi{color:var(--accent-text);margin-right:5px}
.bi-inline{margin-right:6px}
.mystic-phrase{font-style:italic;color:var(--accent-text);font-size:13px;margin:8px 0}
.pick-details{display:grid;grid-template-columns:1fr 1fr;gap:6px;font-size:12px;color:var(--muted);margin-top:10px}
.pick-details span{display:flex;align-items:center;gap:4px}

/* Form runes (Bootstrap-icon based, emoji-free) */
.rune-win{color:var(--gold)}
.rune-place{color:var(--accent-text)}
.rune-minor{color:var(--muted)}
.rune-dnf{color:#ef4444}
.rune-sep{color:var(--dim);margin:0 1px}

.gauge{height:6px;background:var(--bg);border-radius:3px;margin:10px 0 4px;overflow:hidden}
.gauge-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--primary),var(--accent),var(--gold));transition:width 1s ease;width:var(--gauge,5%)}
.gauge-label{font-size:11px;color:var(--muted);display:flex;justify-content:space-between}

.secondary{display:grid;grid-template-columns:1fr 1fr;gap:8px;margin-bottom:12px}
.secondary-pick{background:var(--surface);border-radius:10px;padding:10px;font-size:12px}
.secondary-pick .label{color:var(--accent-text);font-size:11px;margin-bottom:4px}
.secondary-pick .name{font-weight:600}
.secondary-pick .odds{color:var(--muted);margin-top:2px}

.expandable{margin-top:10px}
.expand-btn{width:100%;background:var(--surface);border:1px solid var(--dim);color:var(--text);padding:11px 14px;border-radius:10px;font-size:13px;text-align:left;cursor:pointer;display:flex;justify-content:space-between;align-items:center}
.expand-content{max-height:0;overflow:hidden;transition:max-height .35s ease;font-size:13px;color:var(--muted)}
.expand-content.open{max-height:1600px;padding-top:10px;overflow-y:auto}
.expand-content p{margin-bottom:6px}
.wisdom-picks{color:var(--gold)}
table{width:100%;border-collapse:collapse;font-size:12px}
th,td{padding:6px 4px;text-align:left;border-bottom:1px solid var(--surface)}
th{color:var(--accent-text);font-size:11px;text-transform:uppercase}
/* Power is the sort key — make that obvious */
.th-power{color:var(--gold)!important}
.th-power .bi{font-size:10px;margin-right:2px}
.td-power{font-weight:800;color:var(--gold)}
.td-rank{color:var(--muted);font-weight:700}
tbody tr:first-child .td-rank{color:var(--gold)}
tbody tr[hidden]{display:none!important}
/* Runner search + sort hint */
.runner-tools{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:8px;margin:2px 0 12px}
.runner-search{display:flex;align-items:center;gap:8px;flex:1 1 160px;background:var(--card);border:1px solid rgba(124,58,237,.3);border-radius:12px;padding:11px 14px}
.runner-search .bi{font-size:14px;color:var(--muted);flex:none}
.runner-filter{flex:1;min-width:0;background:transparent;border:none;outline:none;color:var(--text);font-family:inherit;font-size:15px}
.runner-filter::placeholder{color:var(--muted)}
.runner-filter::-webkit-search-cancel-button{-webkit-appearance:none;appearance:none}
.runner-search:focus-within{border-color:var(--accent)}
.runner-sortnote{font-size:11px;color:var(--muted);display:flex;align-items:center;gap:5px}
.runner-sortnote strong{color:var(--gold)}
.runner-sortnote .bi{font-size:12px}
.runner-noresult{padding:14px 4px;font-size:13px;color:var(--muted);text-align:center}

.btn-bet{display:flex;align-items:center;justify-content:center;gap:8px;margin-top:14px;width:100%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;text-decoration:none;padding:13px;border:none;border-radius:12px;font-weight:700;font-size:14px;cursor:pointer;font-family:inherit}
.btn-bet:hover{filter:brightness(1.08)}
.btn-bet .bi{font-size:15px}
.btn-bet .age{background:rgba(0,0,0,.3);padding:2px 6px;border-radius:5px;font-size:11px}

/* ── States ────────────────────────────────────── */
.empty,.loading{text-align:center;color:var(--muted);padding:30px 16px;font-style:italic}
.empty.inline{padding:20px}
.spinner{width:30px;height:30px;border:3px solid var(--surface);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 12px}
@keyframes spin{to{transform:rotate(360deg)}}

footer{text-align:center;color:var(--dim-text);font-size:11px;margin-top:24px;line-height:1.6}
footer a{color:var(--muted)}

/* ── How Mystic John Works ── */
.how-it-works{margin-top:36px;padding:0;background:var(--card);border:1px solid rgba(124,58,237,.18);border-radius:var(--radius);overflow:hidden}
.how-it-works>summary{list-style:none;cursor:pointer;display:flex;align-items:center;justify-content:space-between;gap:8px;padding:14px 20px;font-size:14px;font-weight:700;letter-spacing:.4px;color:var(--text);user-select:none}
.how-it-works>summary::-webkit-details-marker{display:none}
.hiw-summary-label{display:flex;align-items:center;gap:8px}
.hiw-summary-label .bi{color:var(--gold)}
.hiw-chevron{color:var(--muted);font-size:13px;transition:transform .25s ease}
.how-it-works[open]>summary .hiw-chevron{transform:rotate(180deg)}
.how-it-works>summary:hover{background:rgba(124,58,237,.06)}
.how-it-works>summary:focus-visible{outline:2px solid var(--accent-text);outline-offset:-2px}
.how-it-works>:not(summary){margin-left:20px;margin-right:20px}
.how-it-works>.hiw-note:last-child{margin-bottom:22px}
.hiw-lead{font-size:14px;line-height:1.7;color:var(--muted);margin-top:4px;margin-bottom:18px}
.hiw-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:18px}
.hiw-item{background:var(--surface);border:1px solid rgba(124,58,237,.12);border-radius:12px;padding:14px}
.hiw-item .bi{font-size:20px;color:var(--accent-text);margin-bottom:6px;display:block}
.hiw-item h3{font-size:13px;font-weight:700;margin-bottom:4px;color:var(--text)}
.hiw-item p{font-size:12px;line-height:1.5;color:var(--muted);margin:0}
.hiw-note{font-size:12.5px;line-height:1.7;color:var(--accent-text);background:var(--surface);border-left:3px solid var(--gold);border-radius:8px;padding:12px 14px;margin:0}
.hiw-note .bi{color:var(--gold)}
.tagline{font-size:13px;font-style:italic;color:#fff;}
.john-tagline{margin-top:-8px;}

/* ── View toggle (By Meeting / Golden NAPs) ── */
.view-toggle{display:flex;gap:6px;background:var(--card);border:1px solid rgba(124,58,237,.18);border-radius:14px;padding:5px;margin-bottom:16px}
/* ── Date picker bar ── */
.date-bar{display:flex;align-items:center;gap:8px;background:var(--card);border:1px solid rgba(124,58,237,.18);border-radius:14px;padding:6px 8px;margin-bottom:16px}
.date-bar .date-center{flex:1;display:flex;align-items:center;justify-content:center;gap:8px;min-width:0}
.date-bar .date-center>.bi{color:var(--accent-text);font-size:15px;flex-shrink:0}
.date-bar input[type="date"]{background:transparent;border:none;color:var(--text);font-size:15px;font-weight:700;cursor:pointer;padding:6px 4px;font-family:inherit;color-scheme:dark;min-width:0}
.date-bar input[type="date"]:focus{outline:none}
.date-bar input[type="date"]::-webkit-calendar-picker-indicator{filter:invert(.7);cursor:pointer}
.date-rel{font-size:12px;font-weight:700;color:var(--gold);background:#2a1c00;padding:4px 10px;border-radius:999px;white-space:nowrap;flex-shrink:0}
.date-nav{width:38px;height:38px;flex-shrink:0;border-radius:10px;background:var(--surface);border:1px solid rgba(124,58,237,.2);color:var(--accent-text);cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .15s}
.date-nav:hover{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border-color:transparent}
.date-today{flex-shrink:0;background:transparent;border:1px solid var(--gold);color:var(--gold);padding:8px 12px;border-radius:10px;font-size:12px;font-weight:700;cursor:pointer;transition:all .15s}
.date-today:hover{background:var(--gold);color:#0a0a1a}
@media(max-width:420px){.date-bar .date-center{gap:5px}.date-rel{font-size:11px;padding:3px 8px}.date-today{padding:7px 9px}}
/* Date-kind tints on the relative pill */
.date-rel.dk-past{color:#cbd5e1;background:rgba(148,163,184,.18)}
.date-rel.dk-future{color:#a5b4fc;background:rgba(99,102,241,.18)}
.date-rel.dk-today{color:var(--gold);background:#2a1c00}
/* Day-card status pill + stake note in the header */
.dcs-pill{display:inline-block;margin-left:8px;font-size:10px;font-weight:800;letter-spacing:1.5px;text-transform:uppercase;padding:3px 9px;border-radius:999px;vertical-align:middle}
.dcs-pill-today{background:#2a1c00;color:var(--gold)}
.dcs-pill-past{background:rgba(34,197,94,.16);color:#86efac}
.dcs-pill-future{background:rgba(99,102,241,.18);color:#a5b4fc}
.dcs-stake{float:right;font-size:12px;color:var(--muted);font-weight:600;margin-top:2px}
/* NAPs date context strip */
.naps-datestrip{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700;padding:9px 14px;border-radius:12px;margin-bottom:12px;background:var(--card);border:1px solid rgba(124,58,237,.18)}
.naps-datestrip.dk-past{color:#86efac;border-color:rgba(34,197,94,.25)}
.naps-datestrip.dk-future{color:#a5b4fc;border-color:rgba(99,102,241,.3)}
.vt-btn{flex:1;background:transparent;border:none;color:var(--muted);padding:11px 12px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:flex-start;justify-content:center;gap:7px;transition:all .18s;text-align:left}
.vt-btn .bi{font-size:15px;flex-shrink:0;line-height:1.25}
.vt-lab{display:block}
.vt-btn:hover{color:var(--text)}
.vt-btn.active{background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;box-shadow:0 4px 14px rgba(124,58,237,.35)}
.vt-btn#tab-naps.active{background:linear-gradient(135deg,var(--gold),#d97706);color:#2a1c00}

/* ── Bet recommendation block ── */
.bet-rec{margin-top:12px;background:rgba(124,58,237,.08);border:1px solid rgba(124,58,237,.25);border-radius:10px;padding:11px 13px}
.bet-rec.unavailable{color:var(--muted);font-size:12px;font-style:italic;text-align:center;background:transparent}
.bet-head{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.bet-type{font-size:13px;font-weight:800;letter-spacing:1px;color:var(--accent-text);display:inline-flex;align-items:center;gap:6px}
.bet-stake{font-size:12px;color:var(--text);font-weight:600}
.bet-stake .ew-split{color:var(--muted);font-weight:400}
.bet-flag{font-size:11px;color:#f59e0b;font-weight:700;text-transform:uppercase;letter-spacing:.5px;background:rgba(245,158,11,.12);padding:2px 7px;border-radius:6px;width:100%}
.bet-returns{display:flex;flex-direction:column;gap:5px}
.bet-line{display:flex;align-items:center;justify-content:space-between;font-size:13px;color:var(--text)}
.bet-line span{display:inline-flex;align-items:center;gap:6px;color:var(--muted)}
.bet-line span .bi{color:var(--gold)}
.bet-line strong{color:var(--text);font-weight:700}
.bet-terms{margin-top:8px;font-size:11px;color:var(--dim-text);text-align:right}

/* On the gold NAP card, recolour the bet block for contrast */
.nap-card .bet-rec{background:rgba(255,255,255,.4);border-color:rgba(184,134,11,.4)}
.nap-card .bet-type{color:#5a3d05}
.nap-card .bet-stake{color:#2a1c00}
.nap-card .bet-line{color:#2a1c00}
.nap-card .bet-line span{color:#6b4a0a}
.nap-card .bet-line span .bi{color:#b8860b}
.nap-card .bet-line strong{color:#2a1c00}
.nap-card .bet-terms{color:#7a5410}

/* ── Golden NAPs view ── */
.nod-banner{background:linear-gradient(135deg,var(--gold),#d97706);color:#2a1c00;text-align:center;padding:13px;border-radius:14px;font-size:14px;font-weight:800;letter-spacing:1px;margin-bottom:18px;box-shadow:0 0 30px rgba(245,158,11,.4);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.nod-banner .bi{color:#2a1c00}
.naps-grid{display:flex;flex-direction:column;gap:0}
.nap-tile{margin-bottom:16px!important}
.nap-tile.nap-of-day{outline:3px solid var(--gold);outline-offset:2px}
.nap-tile-race{margin-top:10px;font-size:12px;color:#5a3d05;display:flex;align-items:center;gap:6px}
.nap-tile-race .bi{color:#7a5410}

/* ── Today's Card (results + P&L) ── */
.daycard-summary{background:var(--card);border:1px solid rgba(124,58,237,.2);border-radius:16px;padding:16px;margin-bottom:16px}
.dcs-head{font-size:14px;font-weight:800;color:var(--text);display:flex;align-items:center;gap:8px;margin-bottom:14px}
.dcs-head .bi{color:var(--gold)}
.dcs-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}
.dcs-stat{background:var(--surface);border-radius:12px;padding:12px 10px;text-align:center;display:flex;flex-direction:column;gap:4px}
.dcs-num{font-size:19px;font-weight:800;color:var(--text);line-height:1}
.dcs-lab{font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.6px}
.dcs-stat.pos .dcs-num{color:#4ade80}
.dcs-stat.neg .dcs-num{color:#f87171}
.dcs-foot{margin-top:12px;font-size:12px;color:var(--muted);text-align:center}

.daycard-list{display:flex;flex-direction:column;gap:10px}
.card-row{background:var(--card);border:1px solid rgba(124,58,237,.16);border-radius:14px;padding:13px 14px}
.card-row.is-nap{border-color:var(--gold);box-shadow:0 0 16px rgba(245,158,11,.12)}
.card-row.st-pending{opacity:.92}
.cr-top{display:flex;align-items:center;gap:8px;margin-bottom:8px;flex-wrap:wrap}
.cr-time{background:var(--primary);color:#fff;padding:3px 9px;border-radius:7px;font-size:12px;font-weight:700}
.cr-meet{font-size:12px;color:var(--accent-text);font-weight:600}
.cr-spacer{flex:1}
.row-nap{font-size:10.5px;font-weight:800;color:var(--gold);letter-spacing:.5px;display:inline-flex;align-items:center;gap:4px}
.cr-horse{font-size:15px;color:var(--text);margin-bottom:10px;display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.cr-horse strong{font-weight:800}
.cr-odds{font-size:13px;color:var(--gold);font-weight:700}
.cr-pow{font-size:11px;color:var(--muted);background:var(--surface);padding:2px 7px;border-radius:6px}

.cr-bets{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.betopt{position:relative;background:var(--surface);border:1px solid rgba(124,58,237,.18);border-radius:10px;padding:10px 11px}
.betopt.none{grid-column:1/-1;text-align:center;color:var(--muted);font-size:12px;font-style:italic}
.betopt.rec{border-color:var(--gold);background:linear-gradient(135deg,rgba(245,158,11,.12),var(--surface))}
.rec-tag{position:absolute;top:-9px;right:9px;background:var(--gold);color:#2a1c00;font-size:10px;font-weight:800;letter-spacing:.5px;padding:2px 8px;border-radius:6px}
.betopt-head{font-size:12.5px;font-weight:700;color:var(--text);display:flex;align-items:center;gap:6px;margin-bottom:5px}
.betopt-head .bi{color:var(--accent-text)}
.betopt.rec .betopt-head .bi{color:var(--gold)}
.betopt-ret{font-size:13px;color:var(--text);font-weight:600}

/* Result badges */
.oc{font-size:12px;font-weight:700;display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:7px}
.oc .bi{font-size:13px}
.oc-won{color:#4ade80;background:rgba(74,222,128,.12)}
.oc-placed{color:#7dd3fc;background:rgba(125,211,252,.12)}
.oc-lost{color:#f87171;background:rgba(248,113,113,.1)}
.oc-pending{color:var(--muted);background:var(--surface)}
.oc-none{color:var(--muted);background:var(--surface)}
.oc-pos{font-weight:800;opacity:.75;margin-left:1px}
.row-pnl{font-size:14px;font-weight:800}
.row-pnl.pos{color:#4ade80}
.row-pnl.neg{color:#f87171}
.row-pnl.neu{color:var(--muted)}

@media(max-width:420px){.dcs-grid{grid-template-columns:repeat(2,1fr)}.cr-bets{grid-template-columns:1fr}}

/* ── Bookmaker Bet Sheet (bottom drawer) ── */
.sheet-overlay{position:fixed;inset:0;z-index:200;background:rgba(5,5,16,.66);backdrop-filter:blur(3px);display:flex;align-items:flex-end;justify-content:center;opacity:0;transition:opacity .26s ease}
.sheet-overlay[hidden]{display:none!important}
.sheet-overlay.open{opacity:1}
.bet-sheet{width:100%;max-width:520px;background:var(--card);border:1px solid rgba(124,58,237,.3);border-bottom:none;border-radius:22px 22px 0 0;padding:10px 18px max(22px,env(safe-area-inset-bottom)) 18px;box-shadow:0 -10px 40px rgba(0,0,0,.5);transform:translateY(100%);transition:transform .28s cubic-bezier(.16,1,.3,1);max-height:88vh;overflow-y:auto}
.sheet-overlay.open .bet-sheet{transform:translateY(0)}
.sheet-grip{display:block;width:44px;height:5px;border:none;border-radius:3px;background:var(--dim);margin:4px auto 14px;cursor:pointer;padding:0}
.sheet-grip:hover{background:var(--muted)}
.sheet-head{text-align:center;margin-bottom:16px}
.sheet-horse{font-size:20px;font-weight:800;color:var(--text);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap;line-height:1.2}
.sheet-horse .bi{color:var(--gold)}
.sheet-odds{color:var(--gold);font-size:17px}
.sheet-meta{margin-top:7px;font-size:13px;color:var(--muted);display:flex;align-items:center;justify-content:center;gap:8px;flex-wrap:wrap}
.sheet-meta .dot{color:var(--dim)}
.sheet-rec{margin-top:12px;display:inline-flex;align-items:center;gap:8px;background:var(--surface);border:1px solid rgba(124,58,237,.25);border-radius:10px;padding:7px 12px;font-size:13px}
.sheet-rec:empty{display:none}
.sr-tag{font-weight:800;color:var(--accent-text);display:inline-flex;align-items:center;gap:5px;letter-spacing:.5px}
.sr-stake{color:var(--text);font-weight:600}
.sheet-label{font-size:12px;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:1px;margin:18px 0 12px;display:flex;align-items:center;gap:7px}
.sheet-label .bi{color:var(--accent-text)}
.bookie-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}
.bookie-tile{display:flex;align-items:center;gap:11px;background:var(--surface);border:1px solid rgba(255,255,255,.07);border-left:4px solid var(--bk);border-radius:12px;padding:13px 13px;text-decoration:none;transition:transform .12s,background .18s;min-height:58px}
.bookie-tile:hover{background:#20203a;transform:translateY(-1px)}
.bookie-tile:active{transform:translateY(0)}
.bk-badge{flex:0 0 auto;width:38px;height:38px;border-radius:9px;background:var(--bk);color:#fff;display:flex;align-items:center;justify-content:center;font-weight:800;font-size:13px;text-transform:uppercase;letter-spacing:-.3px}
.bookie-tile.on-light .bk-badge{color:#1a1208}
.bk-name{flex:1;font-size:14px;font-weight:700;color:var(--text)}
.bk-go{color:var(--muted);font-size:14px}
.sheet-foot{margin-top:16px;font-size:11.5px;color:var(--dim-text);text-align:center;line-height:1.6;display:flex;align-items:flex-start;gap:6px;justify-content:center}
.sheet-foot .bi{color:var(--muted);margin-top:2px}

/* Back buttons */
.btn-bet-gold{background:linear-gradient(135deg,#2a1c00,#4a3210)!important;color:var(--gold)!important;box-shadow:0 4px 16px rgba(0,0,0,.3)}
.btn-bet-watch{background:transparent!important;color:var(--muted)!important;border:1px solid rgba(124,58,237,.3)!important;box-shadow:none!important;margin-top:8px!important;font-weight:600!important}
.btn-bet-watch:hover{filter:none;background:rgba(124,58,237,.08)!important;color:var(--text)!important;border-color:var(--accent)!important}
.btn-back-mini{margin-top:11px;width:100%;background:linear-gradient(135deg,var(--primary),var(--accent));color:#fff;border:none;padding:10px;border-radius:10px;font-size:13px;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:7px}
.btn-back-mini:hover{filter:brightness(1.08)}

@media(min-width:480px){.bookie-grid{grid-template-columns:1fr 1fr}}
@media(max-width:360px){.bookie-grid{grid-template-columns:1fr}}

/* ── Watching brief (read-only, no-value races) ──────────── */
.pick.watching{opacity:.92;border-left:3px solid var(--dim)}
.pick.watching .pick-label{color:var(--muted)}
.pick.watching .pick-horse{color:var(--text)}
.watch-note{display:flex;align-items:center;gap:8px;margin-top:14px;padding:11px 13px;background:rgba(148,163,184,.10);border:1px solid rgba(148,163,184,.22);border-radius:10px;color:var(--text);font-size:13px;line-height:1.4}
.watch-note .bi{color:var(--muted);flex-shrink:0}

/* ── Inline help "(i)" triggers + explainer popover ────── */
.help-i{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;min-width:22px;padding:0;margin-left:5px;vertical-align:middle;background:transparent;border:none;cursor:pointer;color:var(--accent-text);border-radius:50%;line-height:1;transition:background .15s,color .15s}
.help-i:hover,.help-i:focus-visible{background:rgba(192,132,252,.16);color:#d6b3ff}
.help-i:focus-visible{outline:2px solid var(--accent-text);outline-offset:1px}
.help-i .bi{font-size:14px}
/* keep the (i) readable on the gold NAP banner */
.nap-banner .help-i,.nod-banner .help-i{color:#2a1a00}
.nap-banner .help-i:hover,.nod-banner .help-i:hover{background:rgba(0,0,0,.15);color:#000}

.explain-overlay{position:fixed;inset:0;z-index:300;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(5,5,16,.72);backdrop-filter:blur(3px);opacity:0;transition:opacity .2s ease}
.explain-overlay[hidden]{display:none!important}
.explain-overlay.open{opacity:1}
.explain-pop{position:relative;max-width:380px;width:100%;background:var(--card);border:1px solid rgba(124,58,237,.35);border-radius:16px;padding:22px 20px 20px;box-shadow:0 18px 60px rgba(0,0,0,.5);transform:translateY(8px) scale(.98);transition:transform .2s ease}
.explain-overlay.open .explain-pop{transform:translateY(0) scale(1)}
.explain-title{font-size:17px;font-weight:800;color:var(--text);margin:0 36px 10px 0;display:flex;align-items:center;gap:8px}
.explain-body{font-size:14px;line-height:1.65;color:var(--muted)}
.explain-body p{margin:0 0 10px}
.explain-body p:last-child{margin-bottom:0}
.explain-body strong{color:var(--text)}
.explain-body em{color:var(--accent-text);font-style:italic}
.explain-body code{font-family:ui-monospace,SFMono-Regular,Menlo,monospace;font-size:.92em;font-weight:700;color:var(--gold);background:rgba(245,158,11,.12);border:1px solid rgba(245,158,11,.22);border-radius:5px;padding:1px 5px}
.explain-close{position:absolute;top:12px;right:12px;width:34px;height:34px;display:flex;align-items:center;justify-content:center;background:rgba(148,163,184,.12);border:1px solid rgba(148,163,184,.25);border-radius:50%;color:var(--text);cursor:pointer;font-size:15px}
.explain-close:hover{background:rgba(148,163,184,.22)}
.explain-close:focus-visible{outline:2px solid var(--accent-text);outline-offset:2px}

/* ── Respect reduced-motion: stop perpetual bouncing/spinning ── */
@media (prefers-reduced-motion: reduce){
 *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}
 .john-stack img.show{animation:none!important}
}

/* ── Track Record (verified rolling P&L) ────────────────── */
.tr-wrap{display:flex;flex-direction:column;gap:14px}
.tr-hero{background:var(--card);border:1px solid rgba(124,58,237,.22);border-radius:var(--radius);padding:20px;text-align:center}
.tr-hero.pos{border-color:rgba(52,211,153,.4)}
.tr-hero.neg{border-color:rgba(248,113,113,.4)}
.tr-hero-lab{font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--accent-text);display:flex;align-items:center;justify-content:center;gap:6px;margin-bottom:8px}
.tr-hero-pnl{font-size:40px;font-weight:800;line-height:1;color:var(--text)}
.tr-hero.pos .tr-hero-pnl{color:#34d399}
.tr-hero.neg .tr-hero-pnl{color:#f87171}
.tr-hero-sub{font-size:12px;color:var(--muted);margin-top:8px}
.tr-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:10px}
.tr-stat{background:var(--card);border:1px solid rgba(124,58,237,.15);border-radius:12px;padding:12px 8px;text-align:center}
.tr-num{display:block;font-size:18px;font-weight:800;color:var(--text);white-space:nowrap}
.tr-lab{display:block;font-size:11px;color:var(--muted);margin-top:3px}
.tr-graph{background:var(--card);border:1px solid rgba(124,58,237,.15);border-radius:12px;padding:14px}
.tr-spark{width:100%;height:auto;display:block}
.tr-spark .tr-line{stroke:var(--gold);stroke-width:2.5;stroke-linejoin:round;stroke-linecap:round}
.tr-spark .tr-bench{stroke:var(--dim-text);stroke-width:1.5;stroke-dasharray:4 3;opacity:.8}
.tr-spark .tr-zero{stroke:rgba(148,163,184,.3);stroke-width:1;stroke-dasharray:2 3}
.tr-legend{display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:11px;color:var(--muted);margin-top:10px;justify-content:center}
.tr-key{display:inline-block;width:16px;height:3px;border-radius:2px;vertical-align:middle}
.tr-key-line{background:var(--gold)}
.tr-key-bench{background:var(--dim-text)}
.tr-bench-note{display:flex;align-items:center;flex-wrap:wrap;gap:6px;background:var(--card);border:1px solid rgba(124,58,237,.15);border-radius:12px;padding:12px 14px;font-size:13px;color:var(--text)}
.tr-bench-note .bi{color:var(--accent-text)}
.tr-bench-note.pos strong{color:#34d399}
.tr-bench-note.neg strong{color:#f87171}
.tr-bench-sub{font-size:11px;color:var(--muted);width:100%}
.tr-days{background:var(--card);border:1px solid rgba(124,58,237,.15);border-radius:12px;padding:6px 14px 10px}
.tr-days-head{font-size:12px;text-transform:uppercase;letter-spacing:1px;color:var(--accent-text);padding:10px 0 6px;border-bottom:1px solid rgba(124,58,237,.12)}
.tr-day{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid rgba(148,163,184,.08);font-size:13px}
.tr-day:last-child{border-bottom:none}
.tr-day-date{color:var(--text);font-weight:600}
.tr-live{display:inline-block;margin-left:6px;font-size:9px;font-weight:800;letter-spacing:.5px;color:#0a0a1a;background:var(--gold);padding:1px 5px;border-radius:4px;vertical-align:middle}
.tr-day-rec{color:var(--muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tr-day-pnl{font-weight:800;flex-shrink:0;white-space:nowrap;margin-left:auto;text-align:right}
.tr-day-pnl.pos{color:#34d399}.tr-day-pnl.neg{color:#f87171}.tr-day-pnl.neu{color:var(--muted)}
.tr-disclaimer{display:flex;gap:8px;font-size:12px;line-height:1.55;color:var(--muted);background:rgba(148,163,184,.06);border:1px solid rgba(148,163,184,.16);border-radius:12px;padding:13px 14px}
.tr-disclaimer .bi{color:var(--muted);flex-shrink:0;margin-top:1px}
.tr-disclaimer em{color:var(--text);font-style:italic}
@media (max-width:520px){.tr-stats{grid-template-columns:repeat(2,1fr)}}
@media (max-width:420px){.tr-hero-pnl{font-size:34px}}
.tr-graph-empty{text-align:center;color:var(--muted);font-size:12.5px;line-height:1.5;padding:22px 14px}
.tr-graph-empty .bi{display:block;font-size:22px;color:var(--accent-text);margin-bottom:6px;opacity:.8}

/* ── Admin track-record management ── */
.tr-admin-lock{display:flex;justify-content:center;margin-top:4px}
.tr-lock-btn{background:transparent;border:1px solid rgba(148,163,184,.18);color:var(--muted);font-size:11px;font-weight:600;padding:6px 12px;border-radius:8px;cursor:pointer;display:inline-flex;align-items:center;gap:6px;opacity:.5;transition:opacity .18s}
.tr-lock-btn:hover{opacity:1;color:var(--text)}
.tr-admin{background:var(--card);border:1px solid rgba(248,113,113,.3);border-radius:12px;padding:14px;display:flex;flex-direction:column;gap:14px}
.tr-admin-head{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:800;text-transform:uppercase;letter-spacing:1px;color:#f87171}
.tr-admin-out{margin-left:auto;background:transparent;border:1px solid rgba(148,163,184,.25);color:var(--muted);font-size:10px;font-weight:700;text-transform:none;letter-spacing:0;padding:3px 9px;border-radius:6px;cursor:pointer}
.tr-admin-out:hover{color:var(--text)}
.tr-admin-row{display:flex;flex-direction:column;gap:7px}
.tr-admin-lab{font-size:12.5px;font-weight:700;color:var(--text)}
.tr-admin-lab span{font-weight:400;color:var(--muted)}
.tr-admin-ctl{display:flex;gap:8px;flex-wrap:wrap}
.tr-admin-ctl select{flex:1;min-width:140px;background:var(--surface);color:var(--text);border:1px solid rgba(148,163,184,.25);border-radius:9px;padding:9px 10px;font-size:13px}
.tr-admin-btn{flex-shrink:0;border:none;border-radius:9px;padding:9px 14px;font-size:13px;font-weight:700;cursor:pointer;display:inline-flex;align-items:center;gap:6px;color:#fff}
.tr-admin-btn.warn{background:#d97706}
.tr-admin-btn.warn:hover{background:#b45309}
.tr-admin-btn.danger{background:#dc2626;width:100%;justify-content:center}
.tr-admin-btn.danger:hover{background:#b91c1c}
.tr-admin-note{display:flex;gap:7px;font-size:11px;line-height:1.5;color:var(--muted);background:rgba(148,163,184,.06);border-radius:8px;padding:9px 11px}
.tr-admin-note .bi{flex-shrink:0;margin-top:1px;color:var(--accent-text)}

/* ── Danger confirm modal ── */
.confirm-overlay{position:fixed;inset:0;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;background:rgba(5,5,16,.66);backdrop-filter:blur(3px);opacity:0;transition:opacity .2s}
.confirm-overlay[hidden]{display:none!important}
.confirm-overlay.open{opacity:1}
.confirm-box{width:100%;max-width:380px;background:var(--card);border:1px solid rgba(248,113,113,.35);border-radius:16px;padding:22px 20px;text-align:center;transform:translateY(10px) scale(.98);transition:transform .2s;box-shadow:0 20px 60px rgba(0,0,0,.5)}
.confirm-overlay.open .confirm-box{transform:translateY(0) scale(1)}
.confirm-icon{width:52px;height:52px;margin:0 auto 12px;border-radius:50%;background:rgba(248,113,113,.14);display:flex;align-items:center;justify-content:center}
.confirm-icon .bi{font-size:26px;color:#f87171}
.confirm-title{margin:0 0 10px;font-size:18px;font-weight:800;color:var(--text)}
.confirm-body{font-size:13px;line-height:1.5;color:var(--muted);text-align:left;margin-bottom:18px}
.confirm-body .cf-line{display:block;margin-top:5px}
.confirm-body .cf-warn{display:block;margin-top:12px;color:#fbbf24;font-weight:600;font-size:12px}
.confirm-actions{display:flex;gap:10px}
.confirm-btn{flex:1;border:none;border-radius:10px;padding:12px;font-size:14px;font-weight:700;cursor:pointer}
.confirm-cancel{background:var(--surface);color:var(--text);border:1px solid rgba(148,163,184,.25)}
.confirm-cancel:hover{background:rgba(148,163,184,.12)}
.confirm-danger{background:#dc2626;color:#fff}
.confirm-danger:hover{background:#b91c1c}
