/* EL PALCO Tracker · OLED shell · shared */
:root{
  --bg:#000;--card:#141414;--surface:#0a0a0a;--border:#1c1c1e;--border2:#2c2c2e;
  --text:#fff;--muted:#636366;--pos:#30d158;--neg:#ff453a;--warn:#ffd60a;
  --mono:ui-monospace,'JetBrains Mono','SF Mono',Consolas,monospace;
  --sans:system-ui,-apple-system,'Segoe UI',sans-serif;
  --hero:30px;--nav-h:52px;--shell-max:640px;--shell-wide:1100px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--bg);color:var(--text);font-family:var(--sans);font-size:14px;line-height:1.45;
  min-height:100%;-webkit-font-smoothing:antialiased}
.mono{font-family:var(--mono);font-variant-numeric:tabular-nums}
.pos{color:var(--pos)}.neg{color:var(--neg)}.warn{color:var(--warn)}.muted{color:var(--muted)}
.shell{max-width:var(--shell-max);margin:0 auto;padding:0 20px calc(var(--nav-h) + 24px + env(safe-area-inset-bottom))}
.shell.wide{max-width:var(--shell-wide)}

header.app-hd{display:flex;align-items:center;justify-content:space-between;padding:16px 0 8px;border-bottom:1px solid var(--border);gap:10px}
.brand{font-size:11px;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--muted)}
.brand strong{color:var(--text);font-weight:700}
.live-dot{display:inline-flex;align-items:center;gap:6px;font-family:var(--mono);font-size:10px;font-weight:600;
  letter-spacing:.06em;text-transform:uppercase;color:var(--text)}
.live-dot .dot{width:7px;height:7px;border-radius:50%;background:var(--pos);flex:none}
.live-dot.off .dot{background:var(--muted)}
.live-dot.off{color:var(--muted)}
.hdr-btn,.btn-ghost{font-size:10px;letter-spacing:.06em;text-transform:uppercase;background:transparent;
  border:1px solid var(--border);color:var(--muted);padding:6px 10px;border-radius:6px;cursor:pointer;font-family:var(--mono);
  text-decoration:none;display:inline-flex;align-items:center}
.hdr-btn:hover,.btn-ghost:hover{color:var(--text);border-color:var(--border2)}
.link-back{font-size:10px;color:var(--muted);text-decoration:none;letter-spacing:.06em;text-transform:uppercase}
.link-back:hover{color:var(--text)}

.pure-label,.sec-label{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;
  margin-top:24px;margin-bottom:6px}
.pure-hero{font-family:var(--mono);font-size:var(--hero);font-weight:600;line-height:1.1;letter-spacing:-.02em}
.pure-hero .dec{font-size:14px;color:var(--muted);font-weight:400}
.row{display:flex;justify-content:space-between;align-items:baseline;padding:11px 0;border-top:1px solid var(--border);font-size:13px}
.row .l{color:var(--muted)}
.row .v{font-family:var(--mono);font-weight:500;color:var(--text)}
.row .v.pos{color:var(--pos)}
.row .v.neg{color:var(--neg)}

.card{border:1px solid var(--border);border-radius:10px;padding:14px;margin-bottom:10px;background:var(--bg)}
.card.click{cursor:pointer}
.card.click:hover{border-color:var(--border2)}
.card-hd{display:flex;justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:8px}
.card-title{font-size:14px;font-weight:600;line-height:1.3}
.card-sub{font-family:var(--mono);font-size:10px;color:var(--muted);margin-top:4px}
.card-meta{font-family:var(--mono);font-size:12px;text-align:right;white-space:nowrap}
.badge{font-family:var(--mono);font-size:8px;letter-spacing:.06em;text-transform:uppercase;padding:3px 7px;
  border:1px solid var(--border);border-radius:4px;color:var(--muted)}
.badge.paper{border-color:rgba(255,214,10,.35);color:var(--warn)}
.badge.live-s{border-color:rgba(48,209,88,.35);color:var(--pos)}
.badge.open{color:var(--text)}

.bar-track{height:6px;background:var(--border);border-radius:3px;overflow:hidden;margin:10px 0}
.bar-fill{height:100%;background:var(--text);border-radius:3px;transition:width .3s}
.bar-fill.warn{background:var(--warn)}
.bar-fill.over{background:var(--neg)}

.split{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--border);border-radius:10px;overflow:hidden;margin-bottom:16px}
@media(max-width:640px){.split{grid-template-columns:1fr}}
.split-left{padding:14px;border-right:1px solid var(--border)}
@media(max-width:640px){.split-left{border-right:0;border-bottom:1px solid var(--border)}}
.split-right{padding:14px;background:#050505}
.split-lbl{font-size:9px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:600;margin-bottom:4px}
.split-hero{font-family:var(--mono);font-size:28px;font-weight:600}

.form-group{margin-bottom:14px}
.form-group label{display:block;font-size:10px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);
  font-weight:600;margin-bottom:6px}
.form-group input,.form-group select,.form-group textarea{
  width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:11px 12px;
  border-radius:8px;font-size:14px;font-family:var(--sans)}
.form-group textarea{font-family:var(--mono);font-size:12px;min-height:72px;resize:vertical}
.form-group input.mono,.form-group select.mono{font-family:var(--mono)}
.form-row{display:grid;grid-template-columns:1fr 1fr;gap:10px}
@media(max-width:500px){.form-row{grid-template-columns:1fr}}
.form-hint{font-size:11px;color:var(--muted);margin-top:5px;line-height:1.4}
.chk-row{display:flex;align-items:flex-start;gap:10px;padding:12px;border:1px solid var(--border);border-radius:8px;
  margin:14px 0;cursor:pointer}
.chk-row input{margin-top:3px;accent-color:var(--pos)}
.chk-row .t{font-size:13px;font-weight:600}
.chk-row .d{font-size:11px;color:var(--muted);margin-top:4px}

.btn-primary{width:100%;padding:13px;border:1px solid var(--text);background:transparent;color:var(--text);
  border-radius:8px;font-size:11px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;cursor:pointer;
  font-family:var(--sans)}
.btn-primary:disabled{opacity:.35;cursor:not-allowed}
.btn-primary:hover:not(:disabled){background:rgba(255,255,255,.06)}
.btn-secondary{padding:10px 14px;border:1px solid var(--border);background:transparent;color:var(--muted);
  border-radius:8px;font-size:10px;text-transform:uppercase;letter-spacing:.06em;cursor:pointer}

.chips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}
.chip{font-size:10px;text-transform:uppercase;letter-spacing:.06em;padding:6px 11px;border:1px solid var(--border);
  border-radius:6px;background:transparent;color:var(--muted);cursor:pointer}
.chip.on{border-color:var(--text);color:var(--text)}

.empty{padding:28px 0;text-align:center;color:var(--muted);font-size:13px}
.note{font-size:12px;color:var(--muted);margin-top:8px;line-height:1.45}
.stub-pill{display:inline-block;font-family:var(--mono);font-size:9px;padding:4px 8px;border:1px dashed var(--border2);
  color:var(--muted);border-radius:4px;margin-bottom:12px}

footer.meta{margin-top:24px;padding-top:14px;border-top:1px solid var(--border);font-family:var(--mono);
  font-size:10px;color:var(--muted);display:flex;flex-wrap:wrap;gap:12px}

.nav{position:fixed;bottom:0;left:0;right:0;background:var(--border);border-top:1px solid var(--border2);
  padding-bottom:env(safe-area-inset-bottom);z-index:40}
.nav-in{max-width:var(--shell-max);margin:0 auto;display:flex;background:#000}
.nav-in.wide{max-width:var(--shell-wide)}
.nav a{flex:1;color:var(--muted);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;
  padding:14px 6px;text-align:center;text-decoration:none}
.nav a.on{color:var(--text);font-weight:700}

#gate{position:fixed;inset:0;background:rgba(0,0,0,.94);display:none;align-items:center;justify-content:center;z-index:200;
  pointer-events:auto}
#gate.on{display:flex!important}
.gate-box{background:var(--card);border:1px solid var(--border);border-radius:12px;padding:24px;width:min(360px,92vw);
  position:relative;z-index:201}
.gate-box h2{font-size:13px;font-weight:600;letter-spacing:.08em;text-transform:uppercase;margin-bottom:8px}
.gate-box input{width:100%;background:var(--bg);border:1px solid var(--border);color:var(--text);padding:12px;
  border-radius:8px;font-family:var(--mono);font-size:16px;margin:12px 0;-webkit-appearance:none;appearance:none}
.gate-box input:focus{outline:none;border-color:var(--border2)}
.gate-box .btn-primary{margin-top:4px}

table.tbl{width:100%;border-collapse:collapse;font-size:11px}
table.tbl th{font-size:9px;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);text-align:left;
  padding:7px 8px;background:var(--card);border-bottom:1px solid var(--border)}
table.tbl th.r,table.tbl td.r{text-align:right}
table.tbl td{padding:6px 8px;border-bottom:1px solid #111;vertical-align:top}
table.tbl tr.click:hover{background:var(--card);cursor:pointer}
table.tbl tr.data-row:hover{background:var(--card);cursor:pointer}

/* OddsJam · KPI strip */
.kpi-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:8px;margin:16px 0}
@media(max-width:520px){.kpi-strip{grid-template-columns:repeat(2,1fr)}}
.kpi-cell{border:1px solid var(--border);border-radius:8px;padding:10px 12px;background:var(--card)}
.kpi-lbl{font-size:8px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);font-weight:600}
.kpi-val{font-size:17px;font-weight:600;margin-top:4px;text-align:right}

/* Pikkit · period toggles */
.period-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}
.period-bar .tog{font-family:var(--mono);font-size:9px;padding:5px 10px;border:1px solid var(--border);
  border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;text-transform:uppercase;letter-spacing:.05em}
.period-bar .tog.on{border-color:var(--text);color:var(--text)}
.period-bar .tog.grp{margin-left:auto}

/* Pikkit · calendar */
.cal-hd{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:8px}
.cal-month{font-size:11px;font-weight:600;text-transform:capitalize}
.cal-month-pnl{font-size:13px;font-weight:600}
.cal-weekdays{display:grid;grid-template-columns:repeat(7,1fr);gap:4px;margin-bottom:4px}
.cal-weekdays span{font-size:8px;text-align:center;color:var(--muted);font-family:var(--mono)}
.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:4px}
.cal-cell{aspect-ratio:1;border:1px solid var(--border);border-radius:6px;background:var(--card);
  font-family:var(--mono);font-size:10px;color:var(--muted);cursor:pointer;padding:0}
.cal-cell.empty{border-color:transparent;background:transparent;cursor:default}
.cal-cell.win{background:rgba(48,209,88,.12);border-color:rgba(48,209,88,.3);color:var(--pos)}
.cal-cell.loss{background:rgba(255,69,58,.1);border-color:rgba(255,69,58,.25);color:var(--neg)}
.cal-cell.neu{color:var(--muted)}
.cal-cell.sel{outline:1px solid var(--text);outline-offset:1px}
.cal-cell:hover:not(.empty){border-color:var(--border2)}

/* PM · Polymarket + PredictFolio */
.pm-summary{display:flex;flex-wrap:wrap;gap:12px;font-size:12px;margin-bottom:10px;padding-bottom:10px;border-bottom:1px solid var(--border)}
.pm-table-wrap{max-height:320px;overflow:auto;border:1px solid var(--border);border-radius:8px}
table.pm-tbl{font-size:11px}
.pm-title{font-size:12px;font-weight:500;line-height:1.25}
.pm-outcome{font-size:9px;margin-top:2px}
.pm-pos-card{border:1px solid var(--border);border-radius:10px;padding:12px;margin-bottom:8px;background:var(--card)}
.pm-pos-card .m{font-size:13px;font-weight:500;line-height:1.3}
.pm-pos-card .nums{display:flex;justify-content:space-between;margin-top:8px;font-family:var(--mono);font-size:11px}

/* OddsJam · bet list */
.bet-name{font-size:12px;font-weight:500;line-height:1.25}
.bet-sub{font-size:9px;margin-top:2px}
.st-pill{font-family:var(--mono);font-size:8px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--muted)}
.st-pill.won{color:var(--pos)}.st-pill.lost{color:var(--neg)}.st-pill.cash{color:var(--warn)}.st-pill.open{color:var(--text)}
.align-pill{font-size:9px;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.align-pill.con{color:var(--pos)}.align-pill.contra{color:var(--neg)}.align-pill.na{color:var(--muted)}

/* Ledger shell */
.ledger-shell{display:grid;grid-template-rows:auto auto auto 1fr auto;min-height:100vh;padding-bottom:calc(var(--nav-h) + env(safe-area-inset-bottom))}
.lens-bar{display:flex;gap:6px;padding:10px 18px;border-bottom:1px solid var(--border);background:var(--bg);flex-wrap:wrap;overflow-x:auto}
.lens{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.07em;padding:8px 12px;border:1px solid var(--border);
  border-radius:6px;background:transparent;color:var(--muted);cursor:pointer;white-space:nowrap;font-family:var(--sans)}
.lens.on{border-color:var(--text);color:var(--text)}
.ledger-main{padding:14px 18px 24px;overflow:auto;max-width:1200px;width:100%;justify-self:center}
.view{display:none}.view.on{display:block}
.filter-bar{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px;align-items:center}
.filter-bar select,.filter-bar input{
  background:var(--bg);border:1px solid var(--border);color:var(--text);padding:7px 10px;border-radius:6px;
  font-size:11px;font-family:var(--mono)}
.filter-bar input{min-width:140px;flex:1}
.tbl-wrap{max-height:480px;overflow:auto;border:1px solid var(--border);border-radius:8px}
.grid2{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:14px}
@media(max-width:900px){.grid2{grid-template-columns:1fr}}
.panel{border:1px solid var(--border);border-radius:8px;padding:12px 14px;background:var(--bg)}
.panel-h{font-size:9px;text-transform:uppercase;letter-spacing:.1em;color:var(--muted);font-weight:600;margin-bottom:10px;display:flex;justify-content:space-between}
.chart-wrap{height:180px;position:relative}
canvas.chart-canvas{width:100%!important;height:100%!important}
.kpi-row{display:grid;grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:14px}
@media(max-width:1100px){.kpi-row{grid-template-columns:repeat(3,1fr)}}
.kpi{border:1px solid var(--border);border-radius:8px;padding:10px 12px;background:var(--bg)}
.kpi .lab{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-weight:600}
.kpi .val{font-family:var(--mono);font-size:18px;margin-top:4px;text-align:right}

/* Drawer */
.drawer{position:fixed;top:0;right:-100%;width:min(420px,100vw);height:100vh;background:var(--card);
  border-left:1px solid var(--border);z-index:50;transition:right .2s ease;overflow:auto;padding:16px}
.drawer.open{right:0}
.drawer .close{float:right;background:transparent;border:1px solid var(--border);color:var(--muted);padding:4px 10px;cursor:pointer;border-radius:6px;font-family:var(--mono);font-size:9px}
.drawer h3{font-size:11px;text-transform:uppercase;letter-spacing:.1em;margin-bottom:12px}
.detail-hero{font-size:32px;font-weight:600;margin-bottom:14px;text-align:right}
.detail-block{margin-bottom:14px;padding:12px;background:var(--surface);border:1px solid var(--border);border-radius:8px}
.detail-block h4{font-size:9px;text-transform:uppercase;letter-spacing:.08em;color:var(--muted);margin-bottom:8px}
.leg-line{font-size:11px;padding:4px 0;border-bottom:1px solid var(--border);display:flex;justify-content:space-between;gap:8px}

/* OddsJam · intention modal card */
.modal-card{border:1px solid var(--border);border-radius:12px;padding:18px;background:var(--card);margin-top:8px}
.modal-card .modal-hd{font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);margin-bottom:14px;font-weight:600}
.modal-actions{display:flex;gap:8px;margin-top:16px}
.modal-actions .btn-primary{flex:1}
.modal-actions .btn-secondary{flex:0}

/* Jornada day panel */
.day-hero{font-family:var(--mono);font-size:28px;font-weight:600;text-align:center;padding:16px 0}
.day-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}
.day-stat{border:1px solid var(--border);border-radius:8px;padding:10px;text-align:center}
.day-stat .l{font-size:8px;text-transform:uppercase;color:var(--muted);letter-spacing:.08em}
.day-stat .v{font-family:var(--mono);font-size:15px;font-weight:600;margin-top:4px}

footer.status{font-family:var(--mono);font-size:10px;color:var(--muted);padding:10px 18px;display:flex;gap:16px;
  align-items:center;border-top:1px solid var(--border);background:var(--bg)}