/* =====================================================================
   FracMO Sports — sportsbook template (vanilla, zero-dependency)
   A bet365-genre demo sportsbook built by NetWebMedia / fracmo.ai.
   Original UI — no third-party CSS or assets. Odds & events are
   SIMULATED play-money demo data (see the demo ribbon + footer).
   Self-contained: no build, no framework. Swap data.js for real feeds.
   ===================================================================== */

:root{
  --green:#0b8457;        /* brand sportsbook green */
  --green-d:#086a45;
  --green-dd:#054c31;
  --green-h:#0e9a66;      /* hover / live accent */
  --green-soft:#e7f4ee;   /* tinted surfaces */
  --green-line:#cfe6db;
  --amber:#FF671F;        /* fracmo orange — Join / accents */
  --amber-d:#e4561a;
  --odd:#ffe07a;          /* yellow odds button */
  --odd-h:#ffd24a;
  --odd-line:#e6c84b;
  --up:#15924f;           /* odds drifting up (green flash) */
  --down:#d13b3b;         /* odds drifting down (red flash) */
  --live:#e23636;         /* LIVE red */
  --page:#cfd6dd;         /* grey app background */
  --card:#ffffff;
  --ink:#15181c;          /* primary text */
  --ink-2:#3a424c;
  --muted:#6b7480;
  --muted-2:#9aa3ad;
  --line:#e3e7ec;
  --line-2:#d2d8df;
  --dark:#101720;         /* dark in-play surfaces */
  --dark-2:#17202b;
  --dark-3:#1f2a37;
  --display:'Poppins',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --sans:'Inter',system-ui,-apple-system,'Segoe UI',Roboto,sans-serif;
  --shell:1340px;
  --rail-l:220px;
  --rail-r:330px;
  --radius:10px;
  --radius-sm:7px;
  --shadow:0 6px 22px -10px rgba(16,24,32,.28);
  --shadow-lg:0 22px 50px -22px rgba(16,24,32,.45);
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  font-family:var(--sans);
  color:var(--ink);
  background:var(--page);
  line-height:1.5;
  font-size:14px;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img,svg{display:block;max-width:100%}
ul{list-style:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
input,select,textarea{font-family:inherit;font-size:14px}
h1,h2,h3,h4{font-family:var(--display);line-height:1.18;letter-spacing:-.01em}
.muted{color:var(--muted)}
.nowrap{white-space:nowrap}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;
  font-family:var(--display);font-weight:600;font-size:.85rem;
  padding:.5rem .9rem;border-radius:var(--radius-sm);border:1.5px solid transparent;
  transition:transform .12s,background .12s,color .12s,border-color .12s,box-shadow .12s;
  white-space:nowrap}
.btn:hover{transform:translateY(-1px)}
.btn:active{transform:translateY(0)}
.btn-green{background:var(--green);color:#fff}
.btn-green:hover{background:var(--green-d)}
.btn-amber{background:var(--amber);color:#fff;box-shadow:0 6px 16px -8px rgba(255,103,31,.6)}
.btn-amber:hover{background:var(--amber-d)}
.btn-line{background:transparent;color:#fff;border-color:rgba(255,255,255,.5)}
.btn-line:hover{background:rgba(255,255,255,.12);border-color:#fff}
.btn-ghost{background:#fff;color:var(--ink);border-color:var(--line-2)}
.btn-ghost:hover{border-color:var(--green);color:var(--green)}
.btn-dark{background:var(--dark-2);color:#fff}
.btn-lg{padding:.8rem 1.3rem;font-size:.98rem}
.btn-sm{padding:.4rem .7rem;font-size:.78rem}
.btn-wide{width:100%}

/* ---------- Keyboard focus (a11y) ---------- */
.btn:focus-visible,.oddsfmt:focus-visible,.hdr-burger:focus-visible,.bs-tab:focus-visible,
.hdr-nav a:focus-visible,.rail-list a:focus-visible,.bs-fab .go:focus-visible,.x:focus-visible,
.quick button:focus-visible,.seg button:focus-visible{outline:2px solid var(--amber);outline-offset:2px;border-radius:inherit}
.odd:focus-visible,.bs-place:focus-visible{outline:2px solid var(--green-d);outline-offset:2px;position:relative;z-index:2}
.bs-stake:focus-within,.field input:focus,.field select:focus{outline:2px solid transparent}
.bs-stake:focus-within{border-color:var(--green)}
a:focus-visible{outline:2px solid var(--amber);outline-offset:2px}

/* ---------- Demo ribbon ---------- */
.demo-ribbon{background:#101720;color:#cfe6db;font-size:.78rem;text-align:center;
  padding:.45rem 1rem;border-bottom:2px solid var(--amber)}
.demo-ribbon b{color:#fff}
.demo-ribbon a{color:var(--amber);font-weight:600}

/* ---------- Header ---------- */
.hdr{position:sticky;top:0;z-index:80;background:linear-gradient(180deg,var(--green) 0%,var(--green-d) 100%);
  color:#fff;box-shadow:0 2px 10px -2px rgba(0,0,0,.3)}
.hdr-in{max-width:var(--shell);margin:0 auto;display:flex;align-items:center;gap:1rem;
  height:54px;padding:0 14px}
.hdr-burger{display:none;color:#fff;padding:.35rem;border-radius:6px}
.hdr-burger:hover{background:rgba(255,255,255,.12)}
.brand{display:flex;align-items:center;gap:.5rem;font-family:var(--display);font-weight:800;
  font-size:1.32rem;letter-spacing:-.02em;color:#fff}
.brand .logo{width:30px;height:30px;flex:none}
.brand span{color:var(--odd)}
.hdr-nav{display:flex;gap:.2rem;margin-left:.6rem}
.hdr-nav a{display:inline-flex;align-items:center;gap:.35rem;padding:.45rem .7rem;border-radius:6px;
  font-weight:600;font-size:.86rem;color:rgba(255,255,255,.92);transition:background .12s}
.hdr-nav a:hover,.hdr-nav a.active{background:rgba(255,255,255,.15);color:#fff}
.hdr-right{margin-left:auto;display:flex;align-items:center;gap:.5rem}
.balance{display:flex;flex-direction:column;align-items:flex-end;line-height:1.05;
  font-weight:700;font-size:.92rem;padding-right:.3rem}
.balance small{font-weight:500;font-size:.62rem;color:rgba(255,255,255,.88);text-transform:uppercase;letter-spacing:.06em}
.oddsfmt{font-family:var(--display);font-weight:700;font-size:.7rem;letter-spacing:.04em;
  background:rgba(0,0,0,.18);color:#fff;padding:.4rem .55rem;border-radius:6px;border:1px solid rgba(255,255,255,.18)}
.oddsfmt:hover{background:rgba(0,0,0,.32)}
.livedot{width:7px;height:7px;border-radius:50%;background:var(--odd);box-shadow:0 0 0 0 rgba(255,224,122,.7);
  animation:pulse 1.6s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(255,224,122,.6)}70%{box-shadow:0 0 0 7px rgba(255,224,122,0)}100%{box-shadow:0 0 0 0 rgba(255,224,122,0)}}

/* ---------- Sport quick strip ---------- */
.sportstrip{background:var(--green-dd);overflow-x:auto;scrollbar-width:none}
.sportstrip::-webkit-scrollbar{display:none}
.sportstrip-in{max-width:var(--shell);margin:0 auto;display:flex;gap:.1rem;padding:0 8px}
.sportstrip a{display:inline-flex;align-items:center;gap:.4rem;white-space:nowrap;
  padding:.55rem .8rem;font-size:.8rem;font-weight:600;color:rgba(255,255,255,.85);
  border-bottom:3px solid transparent;transition:color .12s,border-color .12s}
.sportstrip a svg{width:16px;height:16px}
.sportstrip a:hover{color:#fff}
.sportstrip a.active{color:#fff;border-bottom-color:var(--odd)}

/* ---------- Shell layout ---------- */
.shell{max-width:var(--shell);margin:0 auto;display:grid;
  grid-template-columns:var(--rail-l) minmax(0,1fr) var(--rail-r);
  gap:12px;padding:12px 14px 40px}
.col-main{min-width:0;display:flex;flex-direction:column;gap:12px}

/* ---------- Left rail (A-Z sports) ---------- */
.rail-left{align-self:start;position:sticky;top:66px}
.rail-card{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.rail-head{background:var(--green-soft);color:var(--green-d);font-family:var(--display);font-weight:700;
  font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;padding:.6rem .85rem;border-bottom:1px solid var(--green-line)}
.rail-list a{display:flex;align-items:center;gap:.6rem;padding:.55rem .85rem;font-size:.84rem;font-weight:500;
  border-bottom:1px solid var(--line);transition:background .12s}
.rail-list a:last-child{border-bottom:0}
.rail-list a:hover{background:var(--green-soft)}
.rail-list a.active{background:var(--green-soft);color:var(--green-d);font-weight:700;box-shadow:inset 3px 0 0 var(--green)}
.rail-list a svg{width:18px;height:18px;color:var(--green);flex:none}
.rail-list a .ct{margin-left:auto;background:#eef1f4;color:var(--muted);font-size:.7rem;font-weight:700;
  border-radius:20px;padding:.05rem .45rem;min-width:22px;text-align:center}
.rail-list a.live-row .ct{background:#fde7e7;color:var(--live)}

/* ---------- Section / card headers ---------- */
.panel{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.panel-head{display:flex;align-items:center;gap:.6rem;padding:.7rem .95rem;border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#fff,#fafbfc)}
.panel-head h2,.panel-head h3{font-size:.96rem;font-weight:700;color:var(--ink)}
.panel-head .sub{font-size:.76rem;color:var(--muted);font-weight:500}
.panel-head .more{margin-left:auto;font-size:.78rem;font-weight:600;color:var(--green-d)}
.panel-head .ic{width:22px;height:22px;color:var(--green)}
.panel-head .pill-live{background:var(--live);color:#fff;font-size:.66rem;font-weight:700;letter-spacing:.05em;
  padding:.12rem .45rem;border-radius:4px;text-transform:uppercase}

/* ---------- Coupon / event rows ---------- */
.coupon-cols{display:flex;align-items:center;padding:.4rem .95rem;border-bottom:1px solid var(--line);
  background:#f7f9fa;font-size:.7rem;font-weight:700;color:var(--muted);text-transform:uppercase;letter-spacing:.04em}
.coupon-cols .c-pick{margin-left:auto;display:flex;gap:6px}
.coupon-cols .c-pick span{width:62px;text-align:center}

.ev{display:flex;align-items:stretch;gap:.6rem;padding:.6rem .95rem;border-bottom:1px solid var(--line);
  transition:background .1s}
.ev:last-child{border-bottom:0}
.ev:hover{background:#f7fbf9}
.ev-time{flex:none;width:50px;display:flex;flex-direction:column;justify-content:center;align-items:center;
  font-size:.72rem;color:var(--muted);text-align:center;line-height:1.15}
.ev-time .d{font-weight:700;color:var(--ink-2)}
.ev-time.live{color:var(--live);font-weight:700}
.ev-time .min{font-size:.82rem;font-weight:800;color:var(--live)}
.ev-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:.2rem;justify-content:center}
.ev-teams{display:flex;flex-direction:column;gap:.18rem}
.ev-team{display:flex;align-items:center;gap:.5rem;font-size:.88rem;font-weight:600;min-width:0}
.ev-team .crest{width:20px;height:20px;flex:none;border-radius:4px}
.ev-team .nm{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.ev-team .sc{margin-left:auto;font-weight:800;font-size:.92rem;color:var(--green-d);min-width:18px;text-align:right}
.ev-meta{display:flex;align-items:center;gap:.5rem;font-size:.72rem;color:var(--muted)}
.ev-meta a{color:var(--green-d);font-weight:600}
.ev-meta .lg{display:flex;align-items:center;gap:.3rem}
.ev-picks{flex:none;display:flex;align-items:center;gap:6px}
.ev-more{flex:none;align-self:center;display:flex;align-items:center;gap:.25rem;font-size:.74rem;
  font-weight:700;color:var(--green-d);padding-left:.4rem}
.ev-more .n{background:var(--green-soft);border-radius:5px;padding:.18rem .4rem}

/* ---------- Odds buttons ---------- */
.odd{position:relative;width:62px;height:44px;display:flex;flex-direction:column;align-items:center;justify-content:center;
  background:var(--odd);border:1px solid #ecc94b;border-radius:6px;font-family:var(--display);
  font-weight:700;font-size:.86rem;color:#1a1d22;line-height:1;transition:background .12s,border-color .12s,transform .08s;
  overflow:hidden}
.odd:hover{background:var(--odd-h);border-color:#d8b73a}
.odd:active{transform:scale(.96)}
.odd .lbl{font-size:.6rem;font-weight:600;color:#6a5a16;margin-bottom:2px}
.odd.empty{background:#f1f3f5;border-color:var(--line-2);color:var(--muted-2);cursor:default}
.odd.empty:hover{background:#f1f3f5;transform:none}
.odd.selected{background:var(--green);border-color:var(--green-d);color:#fff}
.odd.selected .lbl{color:rgba(255,255,255,.8)}
.odd.up{animation:flashUp .9s ease}
.odd.down{animation:flashDown .9s ease}
.odd .arr{position:absolute;top:2px;right:3px;font-size:.6rem;font-weight:800}
.odd.up .arr{color:var(--up)}
.odd.down .arr{color:var(--down)}
@keyframes flashUp{0%{background:#bff0d2;border-color:var(--up)}100%{}}
@keyframes flashDown{0%{background:#fbd2d2;border-color:var(--down)}100%{}}
.odd-wide{width:100%;flex-direction:row;gap:.5rem;height:44px;justify-content:space-between;padding:0 .8rem}
.odd-wide .lbl{margin:0;font-size:.8rem;color:#403613;font-weight:600}
.odd-wide.selected .lbl{color:rgba(255,255,255,.85)}

/* ---------- Hero / promo strip ---------- */
.hero-strip{background:linear-gradient(110deg,var(--green-dd),var(--green) 70%);color:#fff;border-radius:var(--radius);
  padding:1.1rem 1.2rem;display:flex;align-items:center;gap:1rem;flex-wrap:wrap;position:relative;overflow:hidden}
.hero-strip::after{content:"";position:absolute;right:-40px;top:-40px;width:200px;height:200px;
  background:radial-gradient(circle,rgba(255,224,122,.25),transparent 70%)}
.hero-strip .ht{position:relative;z-index:1}
.hero-strip h1{font-size:1.4rem;font-weight:800}
.hero-strip p{font-size:.86rem;color:rgba(255,255,255,.85);max-width:520px;margin-top:.2rem}
.hero-strip .hactions{position:relative;z-index:1;margin-left:auto;display:flex;gap:.5rem;flex-wrap:wrap}

/* ---------- Promo cards ---------- */
.promo-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:12px}
.promo{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden;
  display:flex;flex-direction:column;box-shadow:var(--shadow)}
.promo .pbanner{height:96px;background:linear-gradient(120deg,var(--green),var(--green-h));position:relative;
  display:flex;align-items:flex-end;padding:.7rem;color:#fff}
.promo .pbanner.alt{background:linear-gradient(120deg,#102433,#1f3a4d)}
.promo .pbanner.amber{background:linear-gradient(120deg,var(--amber),#ff8a4c)}
.promo .ptag{position:absolute;top:.6rem;left:.6rem;background:rgba(0,0,0,.28);color:#fff;font-size:.64rem;
  font-weight:700;text-transform:uppercase;letter-spacing:.05em;padding:.2rem .5rem;border-radius:5px}
.promo .pbody{padding:.85rem;display:flex;flex-direction:column;gap:.4rem;flex:1}
.promo .pbody h3{font-size:.96rem}
.promo .pbody p{font-size:.82rem;color:var(--muted);flex:1}
.promo .pbody .fine{font-size:.68rem;color:var(--muted-2)}

/* ---------- Bet slip ---------- */
.rail-right{align-self:start}
.betslip{position:sticky;top:66px;background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  overflow:hidden;box-shadow:var(--shadow)}
.bs-head{background:var(--dark);color:#fff;display:flex;align-items:center;gap:.5rem;padding:.7rem .9rem}
.bs-head .ttl{font-family:var(--display);font-weight:700;font-size:.92rem}
.bs-head .cnt{background:var(--amber);color:#fff;font-size:.72rem;font-weight:800;border-radius:20px;
  min-width:20px;height:20px;display:inline-flex;align-items:center;justify-content:center;padding:0 .3rem}
.bs-head .clr{margin-left:auto;font-size:.74rem;color:rgba(255,255,255,.7)}
.bs-head .clr:hover{color:#fff}
.bs-tabs{display:flex;border-bottom:1px solid var(--line)}
.bs-tab{flex:1;padding:.6rem;font-weight:700;font-size:.8rem;color:var(--muted);background:#f7f9fa;
  border-bottom:3px solid transparent}
.bs-tab.active{color:var(--green-d);background:#fff;border-bottom-color:var(--green)}
.bs-tab:disabled{opacity:.45;cursor:not-allowed}
.bs-empty{padding:2rem 1.1rem;text-align:center;color:var(--muted)}
.bs-empty svg{width:46px;height:46px;color:var(--line-2);margin:0 auto .7rem}
.bs-empty h4{font-size:.92rem;color:var(--ink-2);margin-bottom:.25rem}
.bs-empty p{font-size:.8rem}
.bs-list{max-height:none}
.bs-item{padding:.7rem .9rem;border-bottom:1px solid var(--line);position:relative}
.bs-item .x{position:absolute;top:.55rem;right:.7rem;color:var(--muted-2);font-size:1rem;line-height:1}
.bs-item .x:hover{color:var(--down)}
.bs-item .sel{font-weight:700;font-size:.84rem;padding-right:1rem}
.bs-item .mk{font-size:.74rem;color:var(--muted);margin-top:.1rem}
.bs-item .evn{font-size:.74rem;color:var(--muted);margin-top:.05rem}
.bs-item .pr{display:inline-flex;align-items:center;gap:.3rem;margin-top:.35rem;font-weight:800;color:var(--green-d)}
.bs-item .stake-row{display:flex;align-items:center;gap:.5rem;margin-top:.45rem}
.bs-item .stake-row label{font-size:.72rem;color:var(--muted)}
.bs-stake{flex:1;display:flex;align-items:center;border:1.5px solid var(--line-2);border-radius:6px;overflow:hidden}
.bs-stake .cur{padding:0 .45rem;color:var(--muted);font-weight:700;background:#f3f5f7;align-self:stretch;display:flex;align-items:center}
.bs-stake input{flex:1;border:0;padding:.4rem .5rem;width:100%;outline:none;font-weight:700}
.bs-stake input:focus{background:#fffdf5}
.bs-ret{font-size:.74rem;color:var(--muted);margin-top:.3rem;display:flex;justify-content:space-between}
.bs-ret b{color:var(--ink)}
.bs-multi{padding:.8rem .9rem;border-bottom:1px solid var(--line);background:var(--green-soft)}
.bs-multi .row{display:flex;justify-content:space-between;align-items:center;font-size:.82rem;margin-bottom:.4rem}
.bs-multi .row b{font-weight:800}
.bs-foot{padding:.9rem;background:#fafbfc}
.bs-foot .tot{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:.2rem;font-size:.84rem}
.bs-foot .tot.big b{font-size:1.15rem;color:var(--green-d)}
.bs-foot .quick{display:flex;gap:6px;margin:.5rem 0}
.bs-foot .quick button{flex:1;background:#fff;border:1px solid var(--line-2);border-radius:6px;padding:.35rem;
  font-weight:700;font-size:.76rem;color:var(--ink-2)}
.bs-foot .quick button:hover{border-color:var(--green);color:var(--green-d)}
.bs-place{width:100%;background:var(--green);color:#fff;font-family:var(--display);font-weight:800;
  font-size:.96rem;padding:.8rem;border-radius:7px;margin-top:.3rem;transition:background .12s}
.bs-place:hover{background:var(--green-d)}
.bs-place:disabled{background:#b7c2bd;cursor:not-allowed}
.bs-note{font-size:.66rem;color:var(--muted-2);text-align:center;margin-top:.5rem;line-height:1.35}

/* mobile bet slip launcher */
.bs-fab{display:none;position:fixed;left:0;right:0;bottom:0;z-index:90;background:var(--dark);color:#fff;
  align-items:center;gap:.7rem;padding:.7rem 1rem;box-shadow:0 -6px 20px -8px rgba(0,0,0,.5)}
.bs-fab .cnt{background:var(--amber);color:#fff;font-weight:800;border-radius:20px;min-width:22px;height:22px;
  display:inline-flex;align-items:center;justify-content:center;padding:0 .35rem;font-size:.78rem}
.bs-fab .go{margin-left:auto;background:var(--green);color:#fff;font-weight:800;padding:.5rem 1.1rem;border-radius:6px}

/* ---------- Tables (my bets, account) ---------- */
.tbl{width:100%;border-collapse:collapse;font-size:.84rem}
.tbl th{text-align:left;padding:.55rem .85rem;background:#f7f9fa;color:var(--muted);font-weight:700;
  font-size:.72rem;text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--line)}
.tbl td{padding:.65rem .85rem;border-bottom:1px solid var(--line);vertical-align:top}
.tbl tr:last-child td{border-bottom:0}
.tag{display:inline-flex;align-items:center;gap:.25rem;font-size:.7rem;font-weight:700;border-radius:5px;
  padding:.12rem .45rem;text-transform:uppercase;letter-spacing:.03em}
.tag.open{background:#e7f0ff;color:#2563c9}
.tag.won{background:var(--green-soft);color:var(--green-d)}
.tag.lost{background:#fde7e7;color:var(--down)}
.tag.void{background:#eef1f4;color:var(--muted)}

/* ---------- Forms / account ---------- */
.formbox{max-width:430px;margin:0 auto}
.field{margin-bottom:.85rem}
.field label{display:block;font-size:.78rem;font-weight:600;color:var(--ink-2);margin-bottom:.3rem}
.field input,.field select{width:100%;border:1.5px solid var(--line-2);border-radius:7px;padding:.6rem .7rem;
  background:#fff;outline:none;transition:border-color .12s}
.field input:focus,.field select:focus{border-color:var(--green)}
.seg{display:flex;background:#eef1f4;border-radius:8px;padding:3px;margin-bottom:1.1rem}
.seg button{flex:1;padding:.5rem;border-radius:6px;font-weight:700;font-size:.84rem;color:var(--muted)}
.seg button.active{background:#fff;color:var(--green-d);box-shadow:var(--shadow)}

/* ---------- Content blocks (RG / static) ---------- */
.prose{background:var(--card);border:1px solid var(--line);border-radius:var(--radius);padding:1.4rem 1.5rem}
.prose h1{font-size:1.5rem;margin-bottom:.5rem}
.prose h2{font-size:1.1rem;margin:1.3rem 0 .5rem}
.prose p{margin-bottom:.7rem;color:var(--ink-2)}
.prose ul.bullets{margin:.3rem 0 .9rem 1.1rem;list-style:disc}
.prose ul.bullets li{margin-bottom:.35rem;color:var(--ink-2)}
.callout{display:flex;gap:.8rem;background:var(--green-soft);border:1px solid var(--green-line);
  border-radius:var(--radius);padding:1rem 1.1rem;margin:1rem 0}
.callout svg{width:26px;height:26px;color:var(--green-d);flex:none}
.callout.warn{background:#fff6e9;border-color:#f3dcb0}
.callout.warn svg{color:var(--amber-d)}
.limit-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:12px;margin:1rem 0}
.limit-card{border:1px solid var(--line);border-radius:var(--radius);padding:1rem}
.limit-card h3{font-size:.9rem;margin-bottom:.4rem}
.limit-card .row{display:flex;gap:.5rem;align-items:center;margin-top:.5rem}

/* ---------- Toast ---------- */
.toast{position:fixed;left:50%;bottom:26px;transform:translateX(-50%) translateY(20px);background:var(--dark);
  color:#fff;padding:.7rem 1.1rem;border-radius:9px;font-size:.86rem;font-weight:600;z-index:120;opacity:0;
  pointer-events:none;transition:opacity .2s,transform .2s;box-shadow:var(--shadow-lg);max-width:90vw;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast.win{background:var(--green-d)}

/* ---------- Empty states ---------- */
.empty{padding:2.4rem 1rem;text-align:center;color:var(--muted)}
.empty h3{color:var(--ink-2);margin-bottom:.3rem}

/* ---------- Footer ---------- */
.ftr{background:var(--dark);color:#aeb8c2;margin-top:auto}
.ftr-in{max-width:var(--shell);margin:0 auto;padding:1.8rem 16px 1rem;
  display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:1.4rem}
.ftr h4{color:#fff;font-size:.82rem;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.7rem}
.ftr a{display:block;color:#aeb8c2;font-size:.82rem;padding:.18rem 0;transition:color .12s}
.ftr a:hover{color:#fff}
.ftr-brand .brand{font-size:1.2rem;margin-bottom:.5rem}
.ftr-brand p{font-size:.82rem;max-width:320px;line-height:1.5}
.age-badge{display:inline-flex;align-items:center;gap:.5rem;margin-top:.9rem;background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.14);border-radius:8px;padding:.5rem .7rem;font-size:.78rem}
.age-badge .ring{width:30px;height:30px;border:2px solid var(--amber);border-radius:50%;display:flex;
  align-items:center;justify-content:center;font-weight:800;color:#fff;font-size:.78rem;flex:none}
.ftr-bottom{max-width:var(--shell);margin:0 auto;padding:1rem 16px 1.6rem;border-top:1px solid rgba(255,255,255,.08);
  display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;font-size:.76rem}
.ftr-bottom a{color:var(--amber);font-weight:600}
.ftr-disc{max-width:var(--shell);margin:0 auto;padding:0 16px 1.4rem;font-size:.72rem;color:#7e8893;line-height:1.5}

/* ---------- Mobile drawer ---------- */
.drawer-back{display:none;position:fixed;inset:0;background:rgba(8,12,16,.5);z-index:95}
.drawer-back.open{display:block}

/* ---------- Responsive ---------- */
@media(max-width:1080px){
  :root{--rail-r:300px}
  .shell{grid-template-columns:var(--rail-l) minmax(0,1fr);}
  .rail-right{position:fixed;top:0;right:0;bottom:0;width:320px;max-width:88vw;z-index:96;
    background:var(--card);transform:translateX(105%);transition:transform .25s;overflow-y:auto;
    box-shadow:var(--shadow-lg)}
  .rail-right.open{transform:translateX(0)}
  .betslip{position:static;border:0;border-radius:0;box-shadow:none;min-height:100%}
  .bs-fab{display:flex}
}
@media(max-width:820px){
  .hdr-nav{display:none}
  .hdr-burger{display:inline-flex}
  .balance small{display:none}
  .shell{grid-template-columns:minmax(0,1fr);padding:10px 10px 80px}
  .rail-left{position:fixed;top:0;left:0;bottom:0;width:260px;max-width:84vw;z-index:97;
    background:var(--card);transform:translateX(-105%);transition:transform .25s;overflow-y:auto;border-radius:0}
  .rail-left.open{transform:translateX(0)}
  .ftr-in{grid-template-columns:1fr 1fr}
  .hero-strip h1{font-size:1.18rem}
  .ev-picks .odd{width:54px}
  .coupon-cols .c-pick span{width:54px}
}
@media(max-width:480px){
  .ftr-in{grid-template-columns:1fr}
  .ev-more{display:none}
  .hero-strip .hactions{width:100%}
}
