/* ============================================================
   Betaminic logs — styles
   Theme: "Cold instrument" — fresh, precise, analytical.
   Signature: tabular mono numerals for every financial figure.
   ============================================================ */

/* ---------- Tokens ---------- */
:root{
  /* surfaces */
  --canvas:#F4F7FB;
  --surface:#FFFFFF;
  --surface-2:#FBFCFE;
  --surface-3:#F1F5FA;
  --border:#E5EAF2;
  --border-strong:#D3DBE8;

  /* ink */
  --ink:#0C1524;
  --ink-2:#39465E;
  --muted:#7A879E;
  --faint:#A7B2C5;

  /* brand: cold electric blue */
  --brand:#1F5BF0;
  --brand-ink:#1647C2;
  --brand-soft:#E9F0FE;
  --brand-soft-2:#DCE8FE;

  /* money semantics */
  --profit:#0EA56B;
  --profit-soft:#E1F6ED;
  --loss:#E14B4F;
  --loss-soft:#FCEAEA;
  --warn:#C98A00;
  --warn-soft:#FBF1DC;

  /* effects */
  --radius:14px;
  --radius-sm:10px;
  --radius-xs:8px;
  --shadow-sm:0 1px 2px rgba(13,22,38,.06), 0 1px 3px rgba(13,22,38,.04);
  --shadow:0 2px 6px rgba(13,22,38,.06), 0 8px 24px rgba(13,22,38,.06);
  --shadow-lg:0 12px 40px rgba(13,22,38,.16);
  --ring:0 0 0 3px rgba(31,91,240,.22);

  --font-display:'Space Grotesk', system-ui, sans-serif;
  --font-body:'Inter', system-ui, sans-serif;
  /* numbers now use Inter with tabular figures: readable + aligned */
  --font-mono:'Inter', system-ui, sans-serif;

  --sidebar-w:236px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  font-family:var(--font-body);
  background:var(--canvas);
  color:var(--ink);
  font-size:14px;
  line-height:1.5;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
button{font-family:inherit;cursor:pointer}
a{color:inherit}
h1,h2,h3,h4{font-family:var(--font-display);font-weight:600;letter-spacing:-.01em;margin:0}
.num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}

::selection{background:var(--brand-soft-2)}

/* ---------- App shell ---------- */
.app{display:flex;min-height:100vh}

.sidebar{
  width:var(--sidebar-w);
  flex:0 0 var(--sidebar-w);
  background:var(--surface);
  border-right:1px solid var(--border);
  display:flex;flex-direction:column;
  position:sticky;top:0;height:100vh;
  padding:18px 14px;
  z-index:30;
}
.brand{display:flex;align-items:center;gap:11px;padding:6px 8px 16px}
.brand__mark{
  width:34px;height:34px;border-radius:9px;flex:0 0 auto;
  background:linear-gradient(150deg,var(--brand) 0%,#3B73FF 60%,#18B6E0 100%);
  display:grid;place-items:center;color:#fff;
  font-family:var(--font-mono);font-weight:700;font-size:15px;
  box-shadow:0 4px 12px rgba(31,91,240,.35);
}
.brand__name{font-family:var(--font-display);font-weight:600;font-size:15.5px;line-height:1.1}
.brand__name span{display:block;font-family:var(--font-mono);font-weight:500;font-size:10px;color:var(--muted);letter-spacing:.14em;text-transform:uppercase;margin-top:2px}

.nav{display:flex;flex-direction:column;gap:2px;margin-top:6px}
.nav__item{
  display:flex;align-items:center;gap:11px;
  padding:9px 11px;border-radius:var(--radius-sm);
  color:var(--ink-2);font-weight:500;font-size:13.5px;
  border:0;background:transparent;text-align:left;width:100%;
  transition:background .14s, color .14s;
}
.nav__item svg{width:18px;height:18px;flex:0 0 auto;stroke-width:1.9}
.nav__item:hover{background:var(--surface-3);color:var(--ink)}
.nav__item.is-active{background:var(--brand-soft);color:var(--brand-ink);font-weight:600}
.nav__item.is-active svg{color:var(--brand)}

.sidebar__foot{margin-top:auto;padding:10px 8px 2px;border-top:1px solid var(--border)}
.sidebar__foot .pill{margin-bottom:8px}
.sidebar__note{font-size:11px;color:var(--faint);line-height:1.45}

/* ---------- Main ---------- */
.main{flex:1 1 auto;min-width:0;display:flex;flex-direction:column}

.topbar{
  position:sticky;top:0;z-index:20;
  background:rgba(244,247,251,.82);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;gap:16px;
  padding:14px 24px;
}
.topbar__title h1{font-size:19px}
.topbar__title p{margin:1px 0 0;color:var(--muted);font-size:12.5px}
.topbar__spacer{flex:1}
.topbar__actions{display:flex;align-items:center;gap:8px}

.pill{
  display:inline-flex;align-items:center;gap:7px;
  padding:5px 11px;border-radius:999px;
  background:var(--surface);border:1px solid var(--border);
  font-size:12px;font-weight:500;color:var(--ink-2);
}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--profit);box-shadow:0 0 0 3px var(--profit-soft)}
.pill--live .dot{animation:pulse 2s infinite}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}

.btn{
  display:inline-flex;align-items:center;gap:7px;
  padding:8px 14px;border-radius:var(--radius-sm);
  font-weight:600;font-size:13px;border:1px solid var(--border-strong);
  background:var(--surface);color:var(--ink);
  transition:background .14s, border-color .14s, transform .05s;
}
.btn svg{width:16px;height:16px;stroke-width:2}
.btn:hover{background:var(--surface-3)}
.btn:active{transform:translateY(1px)}
.btn--primary{background:var(--brand);border-color:var(--brand);color:#fff}
.btn--primary:hover{background:var(--brand-ink)}
.btn--ghost{border-color:transparent;background:transparent}
.btn--ghost:hover{background:var(--surface-3)}
.btn--sm{padding:6px 10px;font-size:12px}
.btn:focus-visible,.nav__item:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:var(--ring)}

/* ---------- Views ---------- */
.view{display:none;padding:22px 24px 110px;max-width:1280px}
.view.is-active{display:block;animation:fade .25s ease}
@keyframes fade{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:none}}

.section-label{
  font-family:var(--font-mono);font-size:10.5px;letter-spacing:.16em;
  text-transform:uppercase;color:var(--muted);font-weight:600;
  margin:26px 2px 12px;display:flex;align-items:center;gap:10px;
}
.section-label::after{content:"";flex:1;height:1px;background:var(--border)}
.section-label:first-child{margin-top:4px}

/* ---------- Cards ---------- */
.card{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);box-shadow:var(--shadow-sm);
}
.card__head{display:flex;align-items:center;gap:12px;padding:16px 18px 0}
.card__head h3{font-size:14.5px}
.card__head .card__sub{color:var(--muted);font-size:12px;font-weight:400}
.card__head .spacer{flex:1}
.card__body{padding:16px 18px}

/* ---------- KPI grid ---------- */
.kpis{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}
.kpi{
  background:var(--surface);border:1px solid var(--border);
  border-radius:var(--radius);padding:15px 16px;box-shadow:var(--shadow-sm);
  position:relative;overflow:hidden;
}
.kpi__label{font-size:12px;color:var(--muted);font-weight:500;display:flex;align-items:center;gap:6px}
.kpi__label .hint{
  width:14px;height:14px;border-radius:50%;border:1px solid var(--border-strong);
  color:var(--faint);font-size:9px;display:grid;place-items:center;cursor:help;font-family:var(--font-body)
}
.kpi__value{font-family:var(--font-mono);font-variant-numeric:tabular-nums;font-weight:700;font-size:26px;letter-spacing:-.02em;margin-top:7px;line-height:1.05}
.kpi__sub{font-size:12px;color:var(--muted);margin-top:4px;font-family:var(--font-mono)}
.kpi.is-pos .kpi__value{color:var(--profit)}
.kpi.is-neg .kpi__value{color:var(--loss)}
.kpi__spark{position:absolute;right:12px;top:14px;width:54px;height:22px;opacity:.9}

/* ---------- Chart blocks ---------- */
.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.grid-3{display:grid;grid-template-columns:2fr 1fr;gap:14px}
.chart-wrap{position:relative;width:100%;height:300px}
.chart-wrap.sm{height:260px}
.chart-wrap canvas{position:absolute;inset:0;width:100%!important;height:100%!important}
.chart-tabs{display:inline-flex;background:var(--surface-3);border-radius:999px;padding:3px;gap:2px}
.chart-tab{border:0;background:transparent;padding:5px 12px;border-radius:999px;font-size:12px;font-weight:600;color:var(--ink-2)}
.chart-tab.is-active{background:var(--surface);color:var(--brand-ink);box-shadow:var(--shadow-sm)}

/* ---------- Tables ---------- */
.table-scroll{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}
table.tbl{width:100%;border-collapse:collapse;font-size:13px;min-width:680px}
table.tbl th{
  text-align:left;font-weight:600;color:var(--muted);
  font-size:11px;letter-spacing:.04em;text-transform:uppercase;
  padding:11px 12px;border-bottom:1px solid var(--border);white-space:nowrap;
  position:sticky;top:0;background:var(--surface);cursor:pointer;user-select:none;
}
table.tbl th.no-sort{cursor:default}
table.tbl th .arrow{opacity:.35;margin-left:4px;font-size:9px}
table.tbl th.sorted .arrow{opacity:1;color:var(--brand)}
table.tbl td{padding:11px 12px;border-bottom:1px solid var(--border);white-space:nowrap;color:var(--ink-2)}
table.tbl tbody tr:hover{background:var(--surface-2)}
table.tbl .t-num{font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right}
table.tbl .t-strong{color:var(--ink);font-weight:600}
.pos{color:var(--profit)!important}
.neg{color:var(--loss)!important}

.tag{
  display:inline-flex;align-items:center;padding:2px 9px;border-radius:999px;
  font-size:11px;font-weight:600;font-family:var(--font-body);
  background:var(--surface-3);color:var(--ink-2);border:1px solid var(--border);
}
.tag--win{background:var(--profit-soft);color:#0a7d50;border-color:transparent}
.tag--loss{background:var(--loss-soft);color:#b73438;border-color:transparent}
.tag--void{background:var(--surface-3);color:var(--muted)}
.tag--pending{background:var(--warn-soft);color:#9a6a00;border-color:transparent}

.row-actions{display:flex;gap:4px;justify-content:flex-end}
.icon-btn{
  width:28px;height:28px;border-radius:7px;border:1px solid transparent;
  background:transparent;display:grid;place-items:center;color:var(--muted);
}
.icon-btn:hover{background:var(--surface-3);color:var(--ink)}
.icon-btn svg{width:15px;height:15px;stroke-width:2}

/* ---------- Filter bar ---------- */
.filterbar{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px}
.field{display:flex;flex-direction:column;gap:4px}
.field label{font-size:11px;color:var(--muted);font-weight:600}
.input,select.input,textarea.input{
  font-family:var(--font-body);font-size:13px;color:var(--ink);
  background:var(--surface);border:1px solid var(--border-strong);
  border-radius:var(--radius-sm);padding:8px 11px;min-width:0;
  transition:border-color .14s;
}
.input::placeholder{color:var(--faint)}
.input:hover{border-color:var(--muted)}
.search{position:relative;flex:1;min-width:180px}
.search svg{position:absolute;left:11px;top:50%;transform:translateY(-50%);width:16px;height:16px;color:var(--faint)}
.search input{width:100%;padding-left:34px}

/* pagination */
.pager{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 4px 0;flex-wrap:wrap}
.pager__info{font-size:12px;color:var(--muted);font-family:var(--font-mono)}
.pager__btns{display:flex;gap:6px;align-items:center}

/* ---------- FAB ---------- */
.fab{
  position:fixed;right:26px;bottom:26px;z-index:40;
  width:56px;height:56px;border-radius:18px;border:0;
  background:var(--brand);color:#fff;
  display:grid;place-items:center;
  box-shadow:0 8px 24px rgba(31,91,240,.45);
  transition:transform .15s, box-shadow .15s, background .15s;
}
.fab svg{width:26px;height:26px;stroke-width:2.4}
.fab:hover{background:var(--brand-ink);transform:translateY(-2px) scale(1.03);box-shadow:0 12px 30px rgba(31,91,240,.5)}
.fab:active{transform:translateY(0) scale(.98)}

/* ---------- Modal ---------- */
.modal-backdrop{
  position:fixed;inset:0;z-index:50;background:rgba(12,21,36,.45);
  backdrop-filter:blur(3px);display:none;align-items:flex-start;justify-content:center;
  padding:40px 16px;overflow-y:auto;
}
.modal-backdrop.is-open{display:flex;animation:fade .18s ease}
.modal{
  background:var(--surface);border-radius:18px;box-shadow:var(--shadow-lg);
  width:100%;max-width:620px;border:1px solid var(--border);
  animation:pop .2s cubic-bezier(.2,.9,.3,1.2);
}
@keyframes pop{from{opacity:0;transform:translateY(10px) scale(.98)}to{opacity:1;transform:none}}
.modal__head{display:flex;align-items:center;gap:12px;padding:18px 20px;border-bottom:1px solid var(--border)}
.modal__head h2{font-size:17px}
.modal__head .spacer{flex:1}
.modal__body{padding:18px 20px;max-height:64vh;overflow-y:auto}
.modal__foot{display:flex;gap:10px;justify-content:flex-end;padding:16px 20px;border-top:1px solid var(--border);background:var(--surface-2);border-radius:0 0 18px 18px}
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.form-grid .full{grid-column:1/-1}
.form-grid .field{gap:5px}
.stake-preview{
  grid-column:1/-1;background:var(--brand-soft);border:1px solid var(--brand-soft-2);
  border-radius:var(--radius-sm);padding:11px 13px;font-size:12.5px;color:var(--brand-ink);
  display:flex;align-items:center;gap:9px;
}
.stake-preview .spi{width:16px;height:16px;flex:0 0 auto}
.stake-preview .num{font-weight:700}
.stake-preview .num{font-weight:700}
.segmented{display:inline-flex;background:var(--surface-3);border-radius:var(--radius-sm);padding:3px;gap:3px;width:100%}
.segmented button{flex:1;border:0;background:transparent;padding:7px;border-radius:7px;font-weight:600;font-size:12.5px;color:var(--ink-2)}
.segmented button.is-active{background:var(--surface);box-shadow:var(--shadow-sm);color:var(--ink)}
.segmented button[data-val="Win"].is-active{color:#0a7d50}
.segmented button[data-val="Loss"].is-active{color:#b73438}

/* ---------- Empty / misc ---------- */
.empty{padding:40px 20px;text-align:center;color:var(--muted)}
.empty svg{width:34px;height:34px;color:var(--faint);margin-bottom:8px}
.muted{color:var(--muted)}
.docs details{border:1px solid var(--border);border-radius:var(--radius-sm);margin-bottom:8px;background:var(--surface)}
.docs summary{padding:12px 14px;font-weight:600;cursor:pointer;font-size:13.5px}
.docs .docs__inner{padding:0 14px 14px;font-size:13px;color:var(--ink-2);line-height:1.6}
.docs code{background:var(--surface-3);padding:1px 6px;border-radius:5px;font-family:var(--font-mono);font-size:12px;color:var(--brand-ink)}
.docs ul{margin:6px 0;padding-left:18px}
.docs li{margin:3px 0}

.kgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px}
.setting-row{display:flex;justify-content:space-between;align-items:center;gap:14px;padding:13px 0;border-bottom:1px solid var(--border)}
.setting-row:last-child{border-bottom:0}
.setting-row__txt h4{font-size:13.5px}
.setting-row__txt p{margin:2px 0 0;font-size:12px;color:var(--muted)}

.toast-wrap{position:fixed;left:50%;bottom:26px;transform:translateX(-50%);z-index:60;display:flex;flex-direction:column;gap:8px;align-items:center}
.toast{
  background:var(--ink);color:#fff;padding:10px 16px;border-radius:10px;
  font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);
  animation:toastin .2s ease;display:flex;align-items:center;gap:9px;
}
.toast.is-pos{background:#0c8a59}.toast.is-neg{background:#c0383c}
@keyframes toastin{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}

/* ---------- Mobile bottom nav ---------- */
.bottombar{display:none}

/* ---------- Responsive ---------- */
@media (max-width:1080px){
  .kpis{grid-template-columns:repeat(2,1fr)}
  .grid-2,.grid-3{grid-template-columns:1fr}
  .kgrid{grid-template-columns:1fr}
}
@media (max-width:860px){
  .sidebar{display:none}
  .view{padding:18px 16px 96px}
  .topbar{padding:12px 16px}
  .topbar__title h1{font-size:17px}
  .topbar .btn--label{display:none}
  .form-grid{grid-template-columns:1fr}
  .bottombar{
    display:flex;position:fixed;bottom:0;left:0;right:0;z-index:35;
    background:var(--surface);border-top:1px solid var(--border);
    padding:7px 6px calc(7px + env(safe-area-inset-bottom));justify-content:space-around;
  }
  .bottombar a,.bottombar button{
    flex:1;border:0;background:transparent;display:flex;flex-direction:column;align-items:center;gap:3px;
    padding:5px;color:var(--muted);font-size:10.5px;font-weight:600;border-radius:10px;
  }
  .bottombar svg{width:21px;height:21px;stroke-width:1.9}
  .bottombar .is-active{color:var(--brand)}
  .fab{bottom:78px;right:18px;width:52px;height:52px}
  .toast-wrap{bottom:84px}
}
@media (max-width:420px){
  .kpis{grid-template-columns:1fr 1fr;gap:9px}
  .kpi__value{font-size:20px}
}
@media (prefers-reduced-motion:reduce){
  *{animation:none!important;transition:none!important}
}

/* ---------- v2 additions ---------- */
.tag--side{margin-left:6px;font-size:10px;padding:1px 7px;background:var(--surface-3);color:var(--ink-2);border:1px solid var(--border)}
.segmented button[data-val="Pending"].is-active{color:var(--warn)}
.segmented button[data-val="Void"].is-active{color:var(--muted)}
.seg--result button{font-size:12px;padding:7px 4px}

.icon-btn--win:hover{background:var(--profit-soft);color:#0a7d50}
.icon-btn--loss:hover{background:var(--loss-soft);color:#b73438}

.empty--big{padding:54px 24px;text-align:center}
.empty--big svg{width:40px;height:40px;color:var(--brand);opacity:.85;margin-bottom:10px}
.empty--big h3{font-size:18px;margin:4px 0 2px}
.empty--big p{max-width:380px;margin:0 auto}
.empty__actions{display:flex;gap:10px;justify-content:center;margin-top:18px;flex-wrap:wrap}

/* ---------- v3 additions ---------- */
/* page-level horizontal scroll guard (clip keeps sticky working) */
html,body{overflow-x:clip;max-width:100%}

/* prominent stake box in the modal */
.stake-box{grid-column:1/-1;background:linear-gradient(120deg,var(--brand-soft),#fff 90%);border:1px solid var(--brand-soft-2);border-radius:12px;padding:14px 16px}
.stake-box__row{display:flex;align-items:stretch;gap:16px}
.stake-box__col{flex:1;min-width:0;display:flex;flex-direction:column}
.stake-box__divider{width:1px;background:var(--brand-soft-2);align-self:stretch}
.stake-box__label{font-size:12px;font-weight:600;color:var(--brand-ink);display:flex;align-items:center;gap:7px}
.stake-box__tag{font-size:10px;font-weight:600;color:var(--brand);background:#fff;border:1px solid var(--brand-soft-2);padding:1px 8px;border-radius:999px;white-space:nowrap}
.stake-box__amt{font-size:28px;font-weight:700;color:var(--ink);letter-spacing:-.02em;margin-top:6px;line-height:1}
.stake-box__amt.pos{color:var(--profit)}
.stake-box__hint{font-size:11.5px;color:var(--muted);margin-top:9px}

/* fixed-layout bet log table (columns no longer jump) */
table.tbl--fixed{table-layout:fixed}
table.tbl--fixed th,table.tbl--fixed td{overflow:hidden}
.tbl .ell{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

/* calendar heatmap */
.cal__nav{display:flex;align-items:center;gap:4px}
.cal__month{font-size:12.5px;font-weight:600;min-width:118px;text-align:center;font-family:var(--font-display)}
.cal__grid{display:grid;grid-template-columns:repeat(7,1fr);gap:5px}
.cal__dows{margin-bottom:6px}
.cal__dow{font-size:9.5px;color:var(--muted);text-align:center;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.cal__cell{min-height:56px;border-radius:8px;background:var(--surface-3);display:flex;flex-direction:column;align-items:flex-start;justify-content:flex-start;padding:4px 6px;gap:1px;overflow:hidden}
.cal__cell--pad{background:transparent}
.cal__cell--bet{background:var(--surface);border:1px solid var(--border)}
.cal__d{font-size:10px;font-weight:600;color:var(--muted);align-self:flex-end;line-height:1}
.cal__d--muted{color:var(--faint)}
.cal__pl{font-size:12.5px;font-weight:700;line-height:1.15;margin-top:2px}
.cal__n{font-size:9px;color:var(--muted);font-weight:500}
.cal__foot{display:flex;justify-content:space-between;align-items:center;margin-top:13px;font-size:12px;flex-wrap:wrap;gap:8px}
.cal__legend{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--muted)}
.cal__legend .lg{width:12px;height:12px;border-radius:3px;display:inline-block;margin:0 1px}
.lg--pos{background:rgba(14,165,107,.8)} .lg--loss{background:rgba(225,75,79,.8)}

/* analytics insight cards + 6-up kpi grid */
.kpis--6{grid-template-columns:repeat(6,1fr)}
.insights{display:grid;grid-template-columns:repeat(auto-fit,minmax(155px,1fr));gap:12px}
.insight{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:14px;box-shadow:var(--shadow-sm)}
.insight__label{font-size:11.5px;color:var(--muted);font-weight:600}
.insight__val{font-size:19px;font-weight:700;margin-top:6px;letter-spacing:-.01em}
.insight__sub{font-size:11.5px;color:var(--muted);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}

@media (max-width:860px){
  .cal__month{min-width:96px;font-size:12px}
  .stake-box__amt{font-size:26px}
}

/* ---------- v4 additions ---------- */
/* keep the win/loss action buttons fully visible */
table.tbl--fixed td.col-actions, table.tbl--fixed th.col-actions{overflow:visible}
.row-actions{flex-wrap:nowrap}

/* calendar tighter on small screens */
@media (max-width:860px){
  .cal__cell{min-height:50px;padding:3px 4px}
  .cal__pl{font-size:11px}
  .cal__n{font-size:8.5px}
  .stake-box__amt{font-size:23px}
}
@media (max-width:430px){
  .stake-box__row{flex-direction:column;gap:10px}
  .stake-box__divider{display:none}
}

/* ---------- v5 additions ---------- */
/* Calendar: centered tiles, green for profit / red for loss */
.cal__cell{position:relative;min-height:58px;border-radius:8px;background:var(--surface-3);
  display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;gap:1px;padding:16px 5px 6px;overflow:hidden}
.cal__cell--pad{background:transparent}
.cal__cell--none{background:var(--surface-3)}
.cal__cell--flat{background:var(--surface-3)}
.cal__cell--win{background:var(--profit-soft);border:1px solid #BFE9D6}
.cal__cell--loss{background:var(--loss-soft);border:1px solid #F3C9CB}
.cal__d{position:absolute;top:4px;left:6px;font-size:10px;font-weight:600;color:var(--muted);line-height:1}
.cal__d--muted{color:var(--faint)}
.cal__pl{font-size:13px;font-weight:700;line-height:1.15}
.cal__cell--win .cal__pl{color:#0A7D50}
.cal__cell--loss .cal__pl{color:#B73438}
.cal__cell--flat .cal__pl{color:var(--muted)}
.cal__n{font-size:9px;color:var(--muted);font-weight:500}
@media (max-width:860px){ .cal__cell{min-height:52px;padding:14px 3px 4px} .cal__pl{font-size:11px} .cal__n{font-size:8px} }

/* Reliable KPI hover tooltip (custom, not native title) */
.kpi{overflow:visible}
.hint{position:relative}
.hint:hover::after,.hint:focus::after{content:attr(data-tip);position:absolute;left:50%;bottom:calc(100% + 9px);transform:translateX(-50%);
  background:var(--ink);color:#fff;padding:7px 10px;border-radius:8px;font-size:11px;font-weight:500;line-height:1.4;
  width:max-content;max-width:190px;text-align:center;white-space:normal;box-shadow:var(--shadow);z-index:30;pointer-events:none}
.hint:hover::before,.hint:focus::before{content:"";position:absolute;left:50%;bottom:calc(100% + 4px);transform:translateX(-50%);
  border:5px solid transparent;border-top-color:var(--ink);z-index:30;pointer-events:none}

/* Resizable bet-log columns */
table.tbl--fixed th{position:relative}
.col-resize{position:absolute;top:0;right:0;width:10px;height:100%;cursor:col-resize;touch-action:none;z-index:3;user-select:none}
.col-resize::after{content:"";position:absolute;top:24%;right:4px;width:2px;height:52%;border-radius:2px;background:var(--border-strong);opacity:0;transition:opacity .12s}
.col-resize:hover::after,.col-resize.is-active::after{opacity:1;background:var(--brand)}
body.is-colresizing{cursor:col-resize;user-select:none}
body.is-colresizing *{cursor:col-resize!important}

/* Return-per-month card fills its height (0% sits at the bottom) */
.card--fill{display:flex;flex-direction:column}
.card--fill .card__body{flex:1;display:flex;min-height:0}
.chart-wrap.fill{flex:1;height:auto;min-height:240px;position:relative}

/* ---------- v6: mobile polish ---------- */
/* Card head + chart toggle wrap to full width instead of overflowing */
@media (max-width:860px){
  .card__head{flex-wrap:wrap;row-gap:8px}
  .card__head .spacer{display:none}
  .chart-tabs{order:5;width:100%}
  .chart-tabs .chart-tab{flex:1;text-align:center;padding:7px 6px;font-size:12px}
}

/* Add-bet modal as a compact bottom sheet that fits one screen (no inner scroll) */
@media (max-width:860px){
  .modal-backdrop{padding:0;align-items:flex-end;overflow:hidden}
  .modal{max-width:none;width:100%;max-height:100dvh;border-radius:18px 18px 0 0;display:flex;flex-direction:column}
  .modal__head{padding:13px 16px}
  .modal__head h2{font-size:16px}
  .modal__body{max-height:none;overflow:visible;padding:14px 16px}
  .modal__foot{padding:12px 16px;border-radius:0}
  .form-grid{grid-template-columns:1fr 1fr;gap:10px}
  .form-grid > .field{grid-column:1/-1}              /* default: full width */
  .form-grid > .field:nth-child(2),
  .form-grid > .field:nth-child(3){grid-column:auto} /* Home + Away share a row */
  .form-grid .field{gap:4px}
  .field label{font-size:10.5px}
  .input{padding:9px 10px;font-size:14px}
  .segmented button{padding:6px 4px;font-size:12px}
  .stake-box{padding:10px 12px}
  .stake-box__label{font-size:11px}
  .stake-box__amt{font-size:20px}
}
/* keep stake figures side-by-side on the smallest screens (shorter modal) */
@media (max-width:430px){
  .stake-box__row{flex-direction:row;gap:12px}
  .stake-box__divider{display:block}
  .stake-box__amt{font-size:18px}
}

/* ---------- v7: KPI sizing ---------- */
/* Analytics 12-KPI strip: 6 per row on desktop, gracefully fewer on smaller screens */
.kpis--6{grid-template-columns:repeat(6,1fr)}
@media (max-width:1080px){ .kpis--6{grid-template-columns:repeat(3,1fr)} }
@media (max-width:560px){ .kpis--6{grid-template-columns:repeat(2,1fr)} }
/* a touch more presence on the smallest screens too */
@media (max-width:420px){ .kpi__value{font-size:22px} }

/* ---------- v8: deposits & withdrawals ---------- */
.cf-list{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}
.cf-row{display:grid;grid-template-columns:104px 120px 1fr auto;align-items:center;gap:10px;padding:8px 10px;background:var(--surface-3);border-radius:10px}
.cf-row__amt{font-weight:700}
.cf-row__note{font-size:12.5px}
.cf-add{display:flex;flex-wrap:wrap;align-items:center;gap:8px}
.cf-add #cfNote{flex:1;min-width:150px}
@media (max-width:560px){ .cf-row{grid-template-columns:1fr auto auto;gap:8px} .cf-row__note{display:none} }

/* ---------- v9: team autocomplete ---------- */
.ac{position:relative;display:block;width:100%}
.ac>.input{width:100%;display:block;box-sizing:border-box}
.ac__menu{position:absolute;left:0;right:0;top:calc(100% + 4px);z-index:40;background:var(--surface);border:1px solid var(--border);border-radius:10px;box-shadow:var(--shadow);max-height:252px;overflow-y:auto;padding:4px}
.ac__item{display:flex;align-items:center;justify-content:space-between;gap:8px;width:100%;text-align:left;border:0;background:transparent;padding:8px 10px;border-radius:7px;font:inherit;font-size:13.5px;color:var(--ink);cursor:pointer}
.ac__item:hover,.ac__item.is-active{background:var(--brand-soft)}
.ac__tag{font-size:10px;font-weight:600;color:var(--brand);background:var(--brand-soft);border:1px solid var(--brand-soft-2);padding:1px 7px;border-radius:999px;white-space:nowrap}
.ac__item:hover .ac__tag,.ac__item.is-active .ac__tag{background:#fff}
.ac__empty{padding:9px 10px;font-size:12.5px;color:var(--muted);line-height:1.4}

/* ---------- v10: teams management ---------- */
.card__intro{font-size:12.5px;color:var(--muted);line-height:1.5;margin:-2px 0 13px;max-width:64ch}
.empty-min{font-size:13px;color:var(--muted);padding:4px 0}
.teamgrid{display:flex;flex-wrap:wrap;gap:8px}
.teamchip{display:inline-flex;align-items:center;gap:7px;padding:5px 6px 5px 12px;background:var(--surface);border:1px solid var(--border);border-radius:999px;font-size:13px;color:var(--ink)}
.teamchip__name{font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:230px}
.teamchip__n{font-size:11px;font-weight:600;color:var(--muted);background:var(--canvas,#F4F7FB);border:1px solid var(--border);border-radius:999px;padding:1px 7px;min-width:22px;text-align:center}
.teamchip__edit{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;padding:0;border:0;background:transparent;color:var(--muted);border-radius:50%;cursor:pointer;flex:none}
.teamchip__edit:hover{background:var(--brand-soft);color:var(--brand)}
.teamchip__edit svg{width:14px;height:14px}

/* ---------- v11: cloud sync badge ---------- */
.sync{font-size:11.5px;font-weight:600;padding:4px 11px;border-radius:999px;white-space:nowrap;border:1px solid transparent}
.sync--ok{color:var(--profit);background:var(--profit-soft);border-color:var(--profit-soft)}
.sync--busy{color:var(--brand);background:var(--brand-soft);border-color:var(--brand-soft-2)}
.sync--err{color:var(--loss);background:var(--loss-soft);border-color:var(--loss-soft)}
