:root{
  --ink:#0F1813;          /* фон — тёмная ель */
  --surface:#17231C;
  --surface2:#1E2C24;
  --line:#2A3B31;
  --text:#E8EDE9;
  --muted:#8FA396;
  --gold:#D9B36C;         /* тенге-золото */
  --green:#6FCF8F;        /* закрыто */
  --amber:#E0A458;        /* скоро срок */
  --red:#E07A6B;          /* просрочено */
  --mono:'IBM Plex Mono',ui-monospace,monospace;
  --sans:'Manrope',system-ui,sans-serif;
}
*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
html{height:100%}
body{
  font-family:var(--sans);background:var(--ink);color:var(--text);
  min-height:100%;padding-bottom:calc(76px + env(safe-area-inset-bottom));
}
.num{font-family:var(--mono);font-variant-numeric:tabular-nums}

/* ---------- шапка ---------- */
.top{
  display:flex;justify-content:space-between;align-items:center;
  padding:calc(14px + env(safe-area-inset-top)) 18px 10px;
}
.eyebrow{font-size:12px;letter-spacing:.14em;text-transform:uppercase;color:var(--gold)}
.brand{font-weight:800;font-size:20px}
.top-actions{display:flex;align-items:center;gap:10px}
.icon-btn{
  width:36px;height:36px;border-radius:10px;border:1px solid var(--line);
  background:var(--surface);color:var(--text);font-size:18px;cursor:pointer;
}
.sync-dot{width:8px;height:8px;border-radius:50%;background:var(--muted);transition:background .3s}
.sync-dot.ok{background:var(--green)}
.sync-dot.pending{background:var(--amber)}
.sync-dot.err{background:var(--red)}

/* ---------- экраны ---------- */
main{padding:6px 14px 0}
.view{display:none}
.view.active{display:block}
.card{
  background:var(--surface);border:1px solid var(--line);
  border-radius:16px;padding:16px;margin-bottom:12px;
}
.label{font-size:12px;letter-spacing:.1em;text-transform:uppercase;color:var(--muted)}
.big{font-family:var(--mono);font-size:34px;font-weight:600;display:block;margin-top:4px}
.big.gold{color:var(--gold)}
.sub{font-size:13px;color:var(--muted);display:block;margin-top:4px}

/* ---------- герой: леджер-бар ---------- */
.hero-remaining .big{font-size:38px}
.ledger-bar{
  display:flex;gap:2px;height:30px;margin:16px 0 10px;
  border-radius:8px;overflow:hidden;
}
.ledger-bar .seg{
  background:var(--surface2);min-width:3px;position:relative;
  transition:background .35s;
}
.ledger-bar .seg.closed{background:var(--green)}
.ledger-bar .seg.overdue{background:var(--red);opacity:.55}
.hero-meta{
  display:flex;justify-content:space-between;
  font-family:var(--mono);font-size:13px;color:var(--muted);
}
.hero-meta span:first-child{color:var(--green)}

/* ---------- список платежей ---------- */
.pay-list{list-style:none}
.pay-list li{
  display:flex;align-items:center;gap:12px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:13px 14px;margin-bottom:8px;
}
.pay-list li.closed{opacity:.45}
.check{
  width:26px;height:26px;border-radius:50%;flex:none;
  border:2px solid var(--muted);background:transparent;cursor:pointer;
  display:flex;align-items:center;justify-content:center;
  color:transparent;font-size:15px;transition:all .2s;
}
li.closed .check{border-color:var(--green);background:var(--green);color:var(--ink)}
li.overdue .check{border-color:var(--red)}
.pay-info{flex:1;min-width:0}
.pay-name{font-weight:700;font-size:15px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.pay-due{font-size:12px;color:var(--muted);margin-top:2px}
.pay-due.overdue{color:var(--red)}
.pay-due.soon{color:var(--amber)}
.pay-amt{font-family:var(--mono);font-size:15px;font-weight:600;white-space:nowrap}
.edit-btn{
  border:none;background:none;color:var(--muted);font-size:15px;
  padding:6px;cursor:pointer;flex:none;
}
.tag{
  font-size:10px;letter-spacing:.08em;text-transform:uppercase;
  color:var(--gold);border:1px solid var(--line);border-radius:6px;
  padding:1px 5px;margin-left:6px;vertical-align:middle;
}

/* ---------- долги ---------- */
.freedom{text-align:center;padding:22px 16px}
.credit-card{margin-bottom:10px}
.credit-head{display:flex;justify-content:space-between;align-items:baseline}
.credit-name{font-weight:700}
.credit-monthly{font-family:var(--mono);font-size:14px;color:var(--muted)}
.credit-bar{height:8px;background:var(--surface2);border-radius:4px;margin:10px 0 8px;overflow:hidden}
.credit-bar i{display:block;height:100%;background:var(--gold);border-radius:4px}
.credit-meta{display:flex;justify-content:space-between;font-size:12px;color:var(--muted)}
.credit-meta .num{color:var(--text)}

.ladder-step{
  display:flex;justify-content:space-between;align-items:center;
  padding:9px 0;border-bottom:1px dashed var(--line);
  font-size:14px;
}
.ladder-step:last-child{border-bottom:none}
.ladder-step .num{font-size:15px}
.ladder-step .drop{color:var(--green);font-size:12px;margin-left:8px}

/* ---------- история ---------- */
.hist-row{
  display:flex;align-items:center;gap:12px;
  background:var(--surface);border:1px solid var(--line);
  border-radius:14px;padding:13px 14px;margin-bottom:8px;
}
.hist-month{font-weight:700;width:90px;text-transform:capitalize}
.hist-bar{flex:1;height:8px;background:var(--surface2);border-radius:4px;overflow:hidden}
.hist-bar i{display:block;height:100%;background:var(--green)}
.hist-pct{font-family:var(--mono);font-size:13px;width:44px;text-align:right}

/* ---------- табы ---------- */
.tabs{
  position:fixed;left:0;right:0;bottom:0;display:flex;
  background:rgba(15,24,19,.92);backdrop-filter:blur(12px);
  border-top:1px solid var(--line);
  padding:8px 10px calc(8px + env(safe-area-inset-bottom));
}
.tab{
  flex:1;border:none;background:none;color:var(--muted);
  font-family:var(--sans);font-weight:700;font-size:13px;
  padding:10px 0;border-radius:10px;cursor:pointer;
}
.tab.active{color:var(--gold);background:var(--surface)}

/* ---------- диалоги ---------- */
.dlg{
  border:1px solid var(--line);border-radius:18px;background:var(--surface);
  color:var(--text);padding:20px;width:min(92vw,400px);
  margin:auto;
}
.dlg::backdrop{background:rgba(0,0,0,.6)}
.dlg h3{margin-bottom:14px;font-size:17px}
.dlg label{display:block;font-size:13px;color:var(--muted);margin-bottom:10px}
.dlg input,.dlg select{
  width:100%;margin-top:4px;padding:11px 12px;font-size:16px;
  background:var(--ink);border:1px solid var(--line);border-radius:10px;
  color:var(--text);font-family:var(--mono);
}
.dlg .hint{font-size:12px;color:var(--muted);margin-bottom:10px}
.dlg-row{display:flex;gap:8px;justify-content:flex-end;margin-top:14px}
.btn{
  border:none;border-radius:10px;padding:11px 16px;font-weight:700;
  font-family:var(--sans);font-size:14px;cursor:pointer;
  background:var(--gold);color:var(--ink);
}
.btn.ghost{background:var(--surface2);color:var(--text)}
.btn.danger{background:var(--red);color:var(--ink);margin-right:auto}

.toast{
  position:fixed;bottom:90px;left:50%;transform:translateX(-50%);
  background:var(--surface2);border:1px solid var(--line);
  padding:10px 16px;border-radius:12px;font-size:13px;z-index:50;
}
@media (prefers-reduced-motion:reduce){*{transition:none!important}}
