:root {
  --bg:#080a10; --surface:#111318; --surface2:#181c26; --surface3:#1f2435;
  --border:rgba(255,255,255,0.07); --border2:rgba(255,255,255,0.14);
  --text:#eef0f8; --muted:#525870; --muted2:#7e88a8;
  --accent:#00e5a0; --accent-dim:rgba(0,229,160,0.1);
  --blue:#3d7aff; --blue-dim:rgba(61,122,255,0.1);
  --warn:#ff9f0a; --warn-dim:rgba(255,159,10,0.1);
  --danger:#ff4d6a; --danger-dim:rgba(255,77,106,0.1);
  --gold:#f5c842; --gold-dim:rgba(245,200,66,0.1);
  --kalshi:#09c285; --kalshi-dim:rgba(9,194,133,0.08);
  --r:14px; --r-sm:9px;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{font-size:16px}
body{background:var(--bg);color:var(--text);font-family:'DM Sans',-apple-system,sans-serif;min-height:100vh;overflow-x:hidden;-webkit-font-smoothing:antialiased}

/* TZ MODAL */
.tz-backdrop{position:fixed;inset:0;background:rgba(0,0,0,0.92);z-index:2000;display:flex;align-items:center;justify-content:center;padding:20px}
.tz-modal{background:var(--surface);border-radius:20px;border:1px solid var(--border2);width:100%;max-width:420px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}
.tz-icon{font-size:48px;text-align:center;padding:24px 0 8px}
.tz-title{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:2px;text-align:center;color:var(--accent)}
.tz-sub{font-size:13px;color:var(--muted2);text-align:center;padding:6px 20px 14px;line-height:1.5}
.tz-list{overflow-y:auto;flex:1;border-top:1px solid var(--border)}
.tz-item{display:flex;align-items:center;justify-content:space-between;padding:13px 20px;border-bottom:1px solid var(--border);cursor:pointer;transition:background 0.15s}
.tz-item:active,.tz-item:hover{background:var(--surface2)}
.tz-item-label{font-size:13px;font-weight:500}
.tz-item-time{font-size:12px;font-family:'JetBrains Mono',monospace;color:var(--accent)}
.tz-auto-btn{margin:12px;padding:13px;background:var(--blue);color:#fff;border:none;border-radius:var(--r);font-size:14px;font-weight:700;cursor:pointer;flex-shrink:0}
.tz-auto-btn:active{transform:scale(0.97)}
.tz-display{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--accent);cursor:pointer;padding:2px 6px;border-radius:4px;border:1px solid var(--accent-dim)}

/* ALERT BANNER */
.alert-banner{position:fixed;top:52px;left:0;right:0;z-index:900;background:var(--surface2);border-bottom:2px solid var(--warn);box-shadow:0 4px 20px rgba(0,0,0,0.5);animation:slideDown 0.3s ease}
@keyframes slideDown{from{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}
.alert-banner-inner{display:flex;align-items:center;gap:12px;padding:12px 16px}
.alert-banner-icon{font-size:22px;flex-shrink:0}
.alert-banner-text{flex:1}
.alert-banner-title{font-size:13px;font-weight:700}
.alert-banner-sub{font-size:11px;color:var(--muted2);margin-top:2px}
.alert-banner-close{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px;flex-shrink:0}
.alert-banner-bar{height:3px;background:var(--surface3)}
.alert-banner-progress{height:100%;background:var(--warn);transition:width 5s linear}

/* HEADER */
.header{position:sticky;top:0;z-index:100;height:52px;display:flex;align-items:center;justify-content:space-between;padding:0 14px;background:var(--bg);border-bottom:1px solid var(--border);backdrop-filter:blur(20px)}
.header-left,.header-right{display:flex;align-items:center;gap:8px}
.logo{font-family:'Bebas Neue',sans-serif;font-size:24px;letter-spacing:1.5px;line-height:1}
.logo span{color:var(--accent)}
.kalshi-badge{background:var(--kalshi);color:#000;font-size:9px;font-weight:900;padding:2px 6px;border-radius:4px;letter-spacing:.5px}
.icon-btn{background:none;border:none;cursor:pointer;font-size:18px;padding:5px;border-radius:8px}
.slip-toggle{display:flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border2);border-radius:20px;padding:6px 14px;font-size:13px;font-weight:600;color:var(--text);cursor:pointer}
.slip-toggle:active{transform:scale(0.96)}
.slip-count{background:var(--accent);color:#000;font-size:11px;font-weight:700;min-width:18px;height:18px;border-radius:9px;padding:0 4px;display:flex;align-items:center;justify-content:center}

/* TICKER */
.ticker-wrap{background:var(--surface);border-bottom:1px solid var(--border);overflow:hidden;height:28px;display:flex;align-items:center}
.ticker-track{display:flex;white-space:nowrap;animation:ticker 55s linear infinite}
@keyframes ticker{0%{transform:translateX(0)}100%{transform:translateX(-50%)}}
.tick-item{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--muted2);padding:0 18px;border-right:1px solid var(--border);flex-shrink:0}

/* SPORT NAV */
.sport-nav{display:flex;gap:8px;overflow-x:auto;padding:10px 14px;scrollbar-width:none;background:var(--bg);border-bottom:1px solid var(--border)}
.sport-nav::-webkit-scrollbar{display:none}
.sport-pill{flex-shrink:0;padding:7px 16px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:13px;font-weight:500;color:var(--muted2);cursor:pointer;white-space:nowrap;transition:all .2s}
.sport-pill.active{background:var(--accent);color:#000;border-color:var(--accent);font-weight:700}
.sport-pill:active{transform:scale(.95)}

/* LEAGUE NAV */
.league-nav{display:none;gap:8px;overflow-x:auto;padding:8px 14px;scrollbar-width:none;background:var(--bg);border-bottom:1px solid var(--border)}
.league-nav.visible{display:flex}
.league-nav::-webkit-scrollbar{display:none}
.league-pill{flex-shrink:0;padding:5px 13px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--muted2);cursor:pointer;white-space:nowrap;transition:all .2s}
.league-pill.active{background:var(--blue-dim);border-color:var(--blue);color:#7fa0ff;font-weight:600}
.league-pill:active{transform:scale(.95)}

/* DAY TABS */
.day-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border)}
.day-tab{flex:1;padding:10px 8px;background:transparent;border:none;border-bottom:2px solid transparent;font-size:12px;font-weight:600;color:var(--muted2);cursor:pointer;transition:all .2s;white-space:nowrap}
.day-tab.active{color:var(--accent);border-bottom-color:var(--accent)}

/* FILTER ROW */
.filter-row{display:flex;gap:8px;padding:8px 14px;overflow-x:auto;scrollbar-width:none;background:var(--bg)}
.filter-row::-webkit-scrollbar{display:none}
.filter-chip{flex-shrink:0;padding:5px 13px;background:transparent;border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--muted2);cursor:pointer;white-space:nowrap;transition:all .2s}
.filter-chip.active{border-color:var(--blue);color:#7fa0ff;background:var(--blue-dim)}
.combo-chip.active{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}

/* UPDATE BAR */
.update-bar{display:flex;align-items:center;gap:8px;padding:5px 14px;background:var(--surface);border-bottom:1px solid var(--border)}
.live-dot-wrap{display:flex;align-items:center;gap:6px;flex:1}
.live-dot{width:6px;height:6px;background:var(--warn);border-radius:50%;animation:pulse 1.4s ease-in-out infinite;flex-shrink:0}
@keyframes pulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(1.6)}}
.update-time{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--kalshi)}
.refresh-btn{font-size:14px;font-weight:700;color:var(--muted2);background:none;border:none;cursor:pointer;padding:2px 8px;flex-shrink:0}

/* SHELL */
.app-shell{padding:14px 14px 100px}
.sec-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.sec-title{font-size:15px;font-weight:600}
.game-count{font-size:12px;color:var(--muted);font-family:'JetBrains Mono',monospace}
.games-list{display:flex;flex-direction:column;gap:14px}

/* LOADING / ERROR */
.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}
.loading-spinner{width:40px;height:40px;border:3px solid var(--border2);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.loading-text{font-size:14px;color:var(--muted2)}
.error-state{text-align:center;padding:48px 20px;color:var(--muted2)}
.error-title{font-size:16px;font-weight:600;color:var(--text);margin-bottom:6px}
.error-sub{font-size:13px;line-height:1.5;margin-bottom:16px}
.retry-btn{background:var(--blue);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:600;cursor:pointer}

/* GAME CARD */
.game-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden;position:relative}
.game-card::before{content:'';position:absolute;left:0;top:0;bottom:0;width:3px;background:transparent;transition:background .2s}
.game-card.has-pick{border-color:rgba(0,229,160,.3)}
.game-card.has-pick::before{background:var(--accent)}
.game-card.is-live::before{background:var(--danger)}
.card-top{padding:12px 14px 10px}
.card-meta{display:flex;align-items:center;gap:6px;margin-bottom:10px;flex-wrap:wrap}
.meta-time{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--muted);background:var(--surface2);padding:2px 7px;border-radius:4px}
.meta-date{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--accent);font-weight:600}
.meta-league{font-size:10px;font-weight:600;letter-spacing:.8px;padding:2px 7px;border-radius:20px;background:var(--surface3);color:var(--muted2)}
.meta-live{font-size:10px;font-weight:700;letter-spacing:.8px;padding:2px 7px;border-radius:20px;background:var(--danger-dim);color:var(--danger);animation:livePulse 2s ease-in-out infinite}
@keyframes livePulse{0%,100%{opacity:1}50%{opacity:.6}}
.meta-final{font-size:10px;font-weight:600;padding:2px 7px;border-radius:20px;background:var(--surface3);color:var(--muted)}
.meta-top{margin-left:auto;font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace}
.c-high{color:var(--accent)}.c-mid{color:var(--warn)}.c-low{color:var(--danger)}

/* MATCHUP */
.matchup{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:8px;margin-bottom:10px}
.team-block{display:flex;flex-direction:column;gap:2px;cursor:pointer;-webkit-tap-highlight-color:transparent}
.team-block:active{opacity:.75}
.team-block.away{text-align:right}
.team-emoji{font-size:22px}
.team-name{font-size:14px;font-weight:700;text-decoration:underline;text-decoration-style:dotted;text-underline-offset:3px;color:var(--text)}
.team-record{font-size:11px;color:var(--muted)}
.team-tap{font-size:9px;color:var(--blue);margin-top:1px;font-weight:600}
.vs-block{text-align:center}
.vs-text{font-family:'Bebas Neue',sans-serif;font-size:22px;color:var(--muted)}
.live-score-big{font-family:'Bebas Neue',sans-serif;font-size:28px;color:var(--danger);line-height:1}
.live-clock{font-size:10px;color:var(--danger);font-weight:700;letter-spacing:.5px;margin-top:1px}
.final-score-big{font-family:'Bebas Neue',sans-serif;font-size:24px;color:var(--muted);line-height:1}

/* WIN BAR */
.win-bar-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}
.win-pct{font-size:11px;font-weight:700;font-family:'JetBrains Mono',monospace;min-width:30px}
.win-pct.right{text-align:right}
.win-bar-track{flex:1;height:4px;background:var(--surface3);border-radius:2px;overflow:hidden}
.win-bar-fill{height:100%;border-radius:2px;transition:width .6s}

/* KALSHI MARKETS */
.kalshi-label{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--kalshi);text-transform:uppercase;padding:8px 14px 6px;display:flex;align-items:center;gap:6px;background:var(--kalshi-dim);border-top:1px solid rgba(9,194,133,.1)}
.kalshi-label::before{content:'K';background:var(--kalshi);color:#000;font-size:9px;font-weight:900;padding:1px 4px;border-radius:3px}
.markets-grid{display:grid;grid-template-columns:1fr 1fr;gap:0;border-top:1px solid var(--border)}
.mkt-tile{padding:10px;background:transparent;border:none;border-right:1px solid var(--border);border-bottom:1px solid var(--border);cursor:pointer;text-align:left;display:flex;flex-direction:column;gap:3px;transition:background .15s;position:relative}
.mkt-tile:nth-child(even){border-right:none}
.mkt-tile:nth-last-child(-n+2){border-bottom:none}
.mkt-tile:nth-last-child(1):nth-child(odd){grid-column:span 2}
.mkt-tile:active{background:var(--surface2)}
.mkt-tile.picked{background:var(--blue-dim)}
.mkt-tile.picked::after{content:'✓';position:absolute;top:6px;right:8px;font-size:10px;color:var(--blue);font-weight:700}
.mkt-tile.has-picker::after{content:'↕';position:absolute;top:6px;right:8px;font-size:11px;color:var(--accent);font-weight:700}
.mkt-tile.has-picker.picked::after{content:'✓ ↕'}
.mt-label{font-size:9px;color:var(--muted2);font-weight:600;text-transform:uppercase;letter-spacing:.3px}
.mt-q{font-size:11px;font-weight:700;color:var(--text);line-height:1.3}
.mt-price-row{display:flex;align-items:center;gap:5px;margin-top:2px}
.mt-yes{font-size:15px;font-weight:700;font-family:'JetBrains Mono',monospace}
.mt-chg{font-size:9px;font-family:'JetBrains Mono',monospace;padding:1px 4px;border-radius:3px}
.mt-chg.up{color:var(--accent);background:var(--accent-dim)}
.mt-chg.dn{color:var(--danger);background:var(--danger-dim)}
.mt-chg.st{color:var(--muted);background:var(--surface3)}
.more-btn{width:100%;padding:10px;background:transparent;border:none;border-top:1px solid var(--border);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;color:var(--blue);font-size:13px;font-weight:600}
.more-btn:active{background:var(--surface2)}
.synth-note{font-size:10px;color:var(--muted);padding:5px 14px;border-top:1px solid var(--border)}

/* ===================== LINE PICKER ===================== */
.sheet-overlay{position:fixed;inset:0;background:rgba(0,0,0,.75);z-index:400;backdrop-filter:blur(4px);display:none}
.sheet-overlay.open{display:block}
.bottom-sheet{position:fixed;bottom:0;left:0;right:0;z-index:500;background:var(--surface);border-radius:20px 20px 0 0;border-top:1px solid var(--border2);max-height:92vh;display:flex;flex-direction:column;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1)}
.bottom-sheet.open{transform:translateY(0)}
.sheet-handle{width:40px;height:4px;background:var(--border2);border-radius:2px;margin:12px auto 0;flex-shrink:0}
.sheet-header{display:flex;align-items:flex-start;justify-content:space-between;padding:14px 16px;border-bottom:1px solid var(--border);flex-shrink:0}
.sheet-title{font-size:16px;font-weight:700}
.sheet-sub{font-size:12px;color:var(--muted);margin-top:3px}
.close-x{background:var(--surface2);border:none;color:var(--muted2);width:28px;height:28px;border-radius:50%;font-size:14px;cursor:pointer;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-top:2px}
.sheet-tabs{display:flex;border-bottom:1px solid var(--border);flex-shrink:0}
.stab{flex:1;padding:10px 6px;background:transparent;border:none;border-bottom:2px solid transparent;font-size:12px;font-weight:500;color:var(--muted2);cursor:pointer;transition:all .2s;white-space:nowrap}
.stab.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:700}
.sheet-body{flex:1;overflow-y:auto;-webkit-overflow-scrolling:touch;padding:14px}

/* OVER/UNDER TOGGLE */
.lp-ou-row{display:flex;gap:0;margin:12px 16px 0;border-radius:var(--r);overflow:hidden;border:1px solid var(--border2)}
.lp-ou-btn{flex:1;padding:11px;background:transparent;border:none;font-size:14px;font-weight:700;color:var(--muted2);cursor:pointer;transition:all .2s}
.lp-ou-btn.active.over{background:rgba(0,229,160,.15);color:var(--accent)}
.lp-ou-btn.active.under{background:rgba(255,77,106,.15);color:var(--danger)}
.lp-ou-btn:first-child{border-right:1px solid var(--border2)}

/* DRUM ROLLER */
.lp-drum-wrap{position:relative;height:200px;overflow:hidden;margin:16px 0;cursor:grab}
.lp-drum-wrap:active{cursor:grabbing}
.lp-drum-overlay-top{position:absolute;top:0;left:0;right:0;height:72px;background:linear-gradient(to bottom,var(--surface) 0%,transparent 100%);z-index:2;pointer-events:none}
.lp-drum-overlay-bot{position:absolute;bottom:0;left:0;right:0;height:72px;background:linear-gradient(to top,var(--surface) 0%,transparent 100%);z-index:2;pointer-events:none}
.lp-drum-center-line{position:absolute;top:50%;left:16px;right:16px;height:1px;background:var(--accent);opacity:.4;z-index:3;pointer-events:none}
.lp-drum-center-line::before,.lp-drum-center-line::after{content:'';position:absolute;top:-20px;height:40px;width:1px;background:var(--accent);opacity:.3}
.lp-drum-center-line::before{left:0}
.lp-drum-center-line::after{right:0}
.lp-drum{display:flex;flex-direction:column;align-items:center;user-select:none;padding:80px 0;transition:transform .1s}
.lp-drum-item{height:44px;display:flex;align-items:center;justify-content:center;font-family:'JetBrains Mono',monospace;font-size:22px;font-weight:700;color:var(--muted);transition:all .15s;width:100%;flex-shrink:0}
.lp-drum-item.center{color:var(--text);font-size:28px;transform:scale(1.05)}
.lp-drum-item.near{color:var(--muted2);font-size:22px}
.lp-drum-item.far{color:var(--muted);font-size:18px;opacity:.5}

/* SELECTED DISPLAY */
.lp-selected-display{padding:16px;background:var(--surface2);margin:0 16px;border-radius:var(--r);border:1px solid var(--border)}
.lp-selected-line{font-family:'Bebas Neue',sans-serif;font-size:52px;line-height:1;color:var(--accent);text-align:center}
.lp-selected-pct{font-size:14px;font-weight:600;color:var(--muted2);text-align:center;margin-top:2px}
.lp-selected-bar-wrap{height:6px;background:var(--surface3);border-radius:3px;margin:10px 0;overflow:hidden}
.lp-selected-bar{height:100%;border-radius:3px;background:var(--accent);transition:width .4s}
.lp-selected-stat{font-size:12px;color:var(--muted2);text-align:center;line-height:1.5}
.lp-confirm-btn{width:calc(100% - 32px);margin:14px 16px;padding:15px;background:var(--accent);color:#000;border:none;border-radius:var(--r);font-size:15px;font-weight:700;cursor:pointer;font-family:'DM Sans',sans-serif;flex-shrink:0}
.lp-confirm-btn:active{transform:scale(.97)}

/* TEAM STATS */
.stat-grid-3{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:14px}
.stat-box{background:var(--surface2);border-radius:10px;padding:10px;text-align:center}
.stat-box-val{font-size:20px;font-weight:700;font-family:'JetBrains Mono',monospace}
.stat-box-label{font-size:9px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:3px}
.form-dots{display:flex;gap:8px;margin-bottom:14px}
.form-dot{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700}
.form-dot.W{background:var(--accent-dim);color:var(--accent)}
.form-dot.D{background:var(--warn-dim);color:var(--warn)}
.form-dot.L{background:var(--danger-dim);color:var(--danger)}
.inj-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--border)}
.inj-badge{font-size:10px;font-weight:700;padding:2px 7px;border-radius:20px}
.inj-out{background:var(--danger-dim);color:var(--danger)}
.inj-doubt{background:var(--warn-dim);color:var(--warn)}
.inj-fit{background:var(--accent-dim);color:var(--accent)}
.player-row{display:flex;align-items:center;gap:10px;padding:10px 0;border-bottom:1px solid var(--border)}
.player-num{width:28px;height:28px;border-radius:50%;background:var(--surface3);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:var(--muted2);flex-shrink:0}
.player-info{flex:1}
.player-name{font-size:13px;font-weight:600}
.player-pos{font-size:11px;color:var(--muted2)}
.player-stats{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--muted2);text-align:right}
.form-row{display:flex;align-items:center;gap:8px;padding:10px 0;border-bottom:1px solid var(--border)}
.form-res{font-size:12px;font-weight:700;min-width:18px}
.form-res.W{color:var(--accent)}.form-res.D{color:var(--warn)}.form-res.L{color:var(--danger)}
.form-score{font-family:'JetBrains Mono',monospace;font-size:13px;font-weight:700;min-width:46px}
.form-opp{font-size:12px;color:var(--muted2);flex:1}
.form-extra{font-size:11px;font-family:'JetBrains Mono',monospace;color:var(--muted)}
.lineup-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}
.lineup-slot{background:var(--surface2);border-radius:8px;padding:8px;text-align:center}
.lineup-name{font-size:11px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.lineup-pos{font-size:9px;color:var(--muted);text-transform:uppercase;margin-top:2px}
.section-label{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;margin:14px 0 8px}

/* COMBO BUILDER */
.combo-header{text-align:center;padding:16px 0 12px}
.combo-title{font-family:'Bebas Neue',sans-serif;font-size:28px;letter-spacing:2px;color:var(--accent)}
.combo-sub{font-size:13px;color:var(--muted2);margin-top:4px}
.combo-row-label{font-size:10px;font-weight:700;letter-spacing:1.5px;color:var(--muted);text-transform:uppercase;margin-bottom:8px;margin-top:4px}
.combo-leg-btns,.combo-type-btns{display:flex;gap:8px;flex-wrap:wrap}
.leg-size-btn{padding:8px 18px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:13px;font-weight:700;color:var(--muted2);cursor:pointer;transition:all .2s}
.leg-size-btn.active{background:var(--accent);color:#000;border-color:var(--accent)}
.leg-size-btn:active{transform:scale(.95)}
.ctype-btn{padding:7px 14px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:12px;font-weight:500;color:var(--muted2);cursor:pointer;white-space:nowrap;transition:all .2s}
.ctype-btn.active{background:var(--blue-dim);border-color:var(--blue);color:#7fa0ff}
.combo-type-desc{font-size:11px;color:var(--muted);margin-top:8px;line-height:1.4;padding:6px 10px;background:var(--surface2);border-radius:8px}
.combo-sport-checks{display:flex;gap:14px;flex-wrap:wrap;margin-top:4px}
.sport-check{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--muted2);cursor:pointer}
.sport-check input{accent-color:var(--accent);width:16px;height:16px}
.build-combo-btn{width:100%;padding:16px;background:var(--accent);color:#000;border:none;border-radius:var(--r);font-size:16px;font-weight:900;letter-spacing:1px;cursor:pointer;margin-top:16px;margin-bottom:20px;font-family:'DM Sans',sans-serif}
.build-combo-btn:active{transform:scale(.97)}
.build-combo-btn:disabled{opacity:.5;cursor:not-allowed}
.combo-results{display:flex;flex-direction:column;gap:14px}
.combo-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.combo-card-hdr{display:flex;align-items:flex-start;justify-content:space-between;padding:14px;background:linear-gradient(135deg,rgba(0,229,160,.06),transparent);border-bottom:1px solid var(--border)}
.combo-card-title{font-size:14px;font-weight:700}
.combo-card-sub{font-size:11px;color:var(--muted2);margin-top:3px}
.combo-card-pct{font-family:'Bebas Neue',sans-serif;font-size:32px;line-height:1}
.combo-pct-label{font-size:9px;color:var(--muted);text-align:right}
.combo-legs{padding:6px 0}
.combo-leg-row{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;border-bottom:1px solid var(--border)}
.combo-leg-row:last-child{border-bottom:none}
.combo-leg-num{width:20px;height:20px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;color:#fff;flex-shrink:0;margin-top:1px}
.combo-leg-info{flex:1;min-width:0}
.combo-leg-pick{font-size:12px;font-weight:700}
.combo-leg-reason{font-size:11px;color:var(--muted2);margin-top:2px;line-height:1.4}
.combo-leg-right{text-align:right;flex-shrink:0}
.combo-leg-price{font-size:15px;font-weight:700;font-family:'JetBrains Mono',monospace}
.combo-leg-chg{font-size:9px;font-family:'JetBrains Mono',monospace}
.combo-stats-btn{padding:4px 10px;background:var(--blue-dim);border:1px solid rgba(61,122,255,.3);border-radius:20px;font-size:11px;font-weight:600;color:var(--blue);cursor:pointer;margin-top:4px;white-space:nowrap}
.combo-stats-btn:active{transform:scale(.95)}
.combo-actions{display:grid;grid-template-columns:1fr auto;gap:0;border-top:1px solid var(--border)}
.combo-add-btn{padding:12px 14px;background:transparent;border:none;font-size:13px;font-weight:700;color:var(--blue);cursor:pointer;transition:background .15s;text-align:left}
.combo-add-btn:active{background:var(--surface2)}
.combo-add-btn.added{color:var(--accent)}

/* BET SLIP */
.slip-drawer{position:fixed;bottom:0;left:0;right:0;z-index:600;background:var(--surface);border-radius:20px 20px 0 0;border-top:1px solid var(--border2);max-height:90vh;overflow-y:auto;transform:translateY(100%);transition:transform .35s cubic-bezier(.32,.72,0,1);-webkit-overflow-scrolling:touch}
.slip-drawer.open{transform:translateY(0)}
.slip-header{display:flex;align-items:center;justify-content:space-between;padding:12px 18px;border-bottom:1px solid var(--border)}
.slip-title{font-size:16px;font-weight:700}
.clear-btn{background:none;border:none;color:var(--danger);font-size:13px;font-weight:600;cursor:pointer;padding:4px 8px}
.slip-empty{padding:48px 24px;text-align:center}
.slip-empty-title{font-size:17px;font-weight:600;margin-bottom:8px}
.slip-empty-sub{font-size:14px;color:var(--muted2);line-height:1.5}
.ks-summary{padding:16px 18px 12px;border-bottom:1px solid var(--border)}
.ks-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:10px}
.ks-cell{background:var(--surface2);border-radius:var(--r-sm);padding:10px;text-align:center}
.ks-label{font-size:10px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px}
.ks-big{font-size:18px;font-weight:700;font-family:'JetBrains Mono',monospace;color:var(--accent)}
.prob-bar-track{height:5px;background:var(--surface3);border-radius:2px;overflow:hidden}
.prob-bar-fill{height:100%;border-radius:2px;background:var(--accent);transition:width .5s}
.slip-sec-label{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--muted);text-transform:uppercase;padding:12px 18px 8px}
.legs-list{padding:0 14px;display:flex;flex-direction:column;gap:8px}
.leg-row{display:flex;align-items:center;gap:10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r-sm);padding:10px 12px}
.leg-num{width:22px;height:22px;border-radius:50%;background:var(--blue);display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;flex-shrink:0}
.leg-info{flex:1;min-width:0}
.leg-pick{font-size:12px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.leg-game{font-size:10px;color:var(--muted2);margin-top:2px}
.leg-price{font-size:14px;font-weight:700;font-family:'JetBrains Mono',monospace;flex-shrink:0;color:var(--kalshi)}
.leg-remove{background:none;border:none;color:var(--muted);font-size:18px;cursor:pointer;padding:4px;flex-shrink:0}
.payout-card{margin:10px 14px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);padding:14px}
.kalshi-note{font-size:11px;color:var(--kalshi);background:var(--kalshi-dim);border-radius:6px;padding:7px 10px;margin-bottom:12px;line-height:1.4}
.stake-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}
.stake-label{font-size:13px;color:var(--muted2);font-weight:500}
.stake-wrap{display:flex;align-items:center;gap:4px;background:var(--surface);border:1px solid var(--border2);border-radius:8px;padding:7px 12px}
.dollar{font-size:15px;font-weight:700;color:var(--muted2)}
.stake-input{background:none;border:none;color:var(--text);font-size:16px;font-weight:700;font-family:'JetBrains Mono',monospace;width:80px;outline:none;text-align:right}
.odds-grid{display:grid;grid-template-columns:1fr 1fr;gap:8px}
.odds-cell{background:var(--surface);border-radius:8px;padding:10px 12px}
.gold-cell{background:var(--gold-dim);border:1px solid rgba(245,200,66,.2)}
.odds-label{font-size:10px;color:var(--muted);font-weight:600;letter-spacing:.5px;margin-bottom:4px;text-transform:uppercase}
.odds-val{font-size:16px;font-weight:700;font-family:'JetBrains Mono',monospace}
.gold{color:var(--gold)}
.alert-card{margin:0 14px 10px;background:var(--surface2);border:1px solid rgba(255,159,10,.2);border-radius:var(--r);padding:14px}
.alert-card-title{font-size:13px;font-weight:700;margin-bottom:4px}
.alert-card-desc{font-size:12px;color:var(--muted2);margin-bottom:10px;line-height:1.4}
.alert-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}
.alert-select{background:var(--surface);border:1px solid var(--border2);border-radius:8px;padding:6px 10px;font-size:13px;color:var(--text);outline:none}
.alert-enable-btn{width:100%;padding:11px;background:var(--warn-dim);border:1px solid rgba(255,159,10,.3);border-radius:var(--r-sm);font-size:13px;font-weight:700;color:var(--warn);cursor:pointer}
.alert-enable-btn:active{transform:scale(.97)}
.best-single-card{margin:0 14px 10px;background:linear-gradient(135deg,rgba(245,200,66,.1),rgba(245,200,66,.04));border:1px solid rgba(245,200,66,.3);border-radius:var(--r);padding:12px 14px}
.best-single-label{font-size:10px;font-weight:700;letter-spacing:2px;color:var(--gold);margin-bottom:5px}
.best-single-pick{font-size:14px;font-weight:700}
.best-single-why{font-size:12px;color:var(--muted2);margin-top:3px;line-height:1.4}
.ai-panel{margin:0 14px 10px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.ai-panel-hdr{display:flex;align-items:center;justify-content:space-between;padding:11px 14px;border-bottom:1px solid var(--border)}
.ai-panel-title{display:flex;align-items:center;gap:8px;font-size:13px;font-weight:700}
.ai-badge{font-size:10px;font-weight:500;color:var(--muted2);background:var(--surface3);padding:2px 8px;border-radius:20px}
.ai-dots{display:flex;gap:4px;align-items:center}
.ai-dots span{width:6px;height:6px;background:var(--blue);border-radius:50%;animation:blink 1.2s ease-in-out infinite}
.ai-dots span:nth-child(2){animation-delay:.2s}
.ai-dots span:nth-child(3){animation-delay:.4s}
@keyframes blink{0%,100%{opacity:.2}50%{opacity:1}}
.ai-body{padding:12px 14px;font-size:13px;line-height:1.7;color:#b0bbdf}
.ai-placeholder{color:var(--muted2);font-style:italic}
.ai-body strong{color:var(--text);font-weight:600}
.ai-sources{padding:8px 14px;border-top:1px solid var(--border);display:flex;gap:6px;flex-wrap:wrap}
.ai-src{font-size:10px;font-family:'JetBrains Mono',monospace;background:var(--blue-dim);border:1px solid rgba(61,122,255,.2);border-radius:20px;padding:3px 9px;color:#7fa0ff}
.analyze-btn{display:flex;align-items:center;justify-content:center;gap:8px;width:calc(100% - 28px);margin:0 14px;padding:15px;background:var(--accent);color:#000;border:none;border-radius:var(--r);font-size:15px;font-weight:700;font-family:'DM Sans',sans-serif;cursor:pointer}
.analyze-btn:active{transform:scale(.97)}
.analyze-btn:disabled{opacity:.5;cursor:not-allowed}

/* SETTINGS */
.settings-modal{position:fixed;bottom:0;left:0;right:0;z-index:700;background:var(--surface);border-radius:20px 20px 0 0;border-top:1px solid var(--border2);max-height:85vh;overflow-y:auto;display:none}
.settings-modal.open{display:block}
.settings-body{padding:18px 18px 40px;display:flex;flex-direction:column;gap:20px}
.setting-group{display:flex;flex-direction:column;gap:8px}
.setting-group-title{font-size:13px;font-weight:700;color:var(--muted2);text-transform:uppercase;letter-spacing:1px}
.setting-desc{font-size:12px;color:var(--muted);line-height:1.5}
.setting-input{background:var(--surface2);border:1px solid var(--border2);border-radius:var(--r-sm);padding:12px 14px;font-size:14px;color:var(--text);outline:none;font-family:'JetBrains Mono',monospace;width:100%}
.setting-input:focus{border-color:var(--accent)}
.setting-tz-btn{padding:10px 14px;background:var(--blue-dim);border:1px solid rgba(61,122,255,.3);border-radius:var(--r-sm);font-size:13px;font-weight:600;color:var(--blue);cursor:pointer;text-align:left}
.toggle-row{display:flex;align-items:center;justify-content:space-between;padding:4px 0}
.toggle-label{font-size:13px;color:var(--muted2)}
.toggle{position:relative;display:inline-block;width:46px;height:26px}
.toggle input{opacity:0;width:0;height:0}
.toggle-slider{position:absolute;cursor:pointer;inset:0;background:var(--surface3);border-radius:13px;transition:.3s}
.toggle-slider::before{content:'';position:absolute;height:20px;width:20px;left:3px;bottom:3px;background:var(--muted);border-radius:50%;transition:.3s}
.toggle input:checked+.toggle-slider{background:var(--accent)}
.toggle input:checked+.toggle-slider::before{transform:translateX(20px);background:#000}
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(80px);background:var(--surface2);border:1px solid var(--border2);border-radius:12px;padding:12px 20px;font-size:13px;color:var(--text);z-index:999;transition:transform .3s ease;pointer-events:none;white-space:nowrap;box-shadow:0 8px 32px rgba(0,0,0,.5)}
.toast.show{transform:translateX(-50%) translateY(0)}
::-webkit-scrollbar{width:4px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border2);border-radius:4px}
@media(min-width:640px){
  .bottom-sheet,.slip-drawer{max-width:480px;left:50%;right:auto;transform:translateX(-50%) translateY(100%)}
  .bottom-sheet.open,.slip-drawer.open{transform:translateX(-50%) translateY(0)}
  .settings-modal{max-width:480px;left:50%;right:auto}
  .tz-modal{max-width:460px}
}
@media(min-width:1024px){
  .app-shell,.sport-nav,.league-nav,.day-tabs,.filter-row,.update-bar{max-width:720px;margin-left:auto;margin-right:auto}
}
