*{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}
:root{
  --bg:#0f1117;--bg2:#181c27;--bg3:#1e2336;--bg4:#252b3b;
  --txt:#e8eaf6;--txt2:#8892b0;--txt3:#4a5568;
  --accent:#6c8aff;--accent2:#4a6cf7;
  --green:#22c55e;--red:#ef4444;--yellow:#f59e0b;--purple:#818cf8;
  --border:#2a3050;--card:#1a1f33;
  --r:10px;--rl:16px;
}
html,body{height:100%;background:var(--bg);color:var(--txt);font-family:'Segoe UI',system-ui,sans-serif;overflow-x:hidden}
.app{max-width:480px;margin:0 auto;min-height:100vh;padding-bottom:70px;position:relative}

/* ── NAV ── */
.nav{position:fixed;bottom:0;left:50%;transform:translateX(-50%);width:100%;max-width:480px;background:var(--bg2);border-top:1px solid var(--border);display:flex;z-index:200}
.nav-btn{flex:1;padding:10px 4px 8px;background:none;border:none;color:var(--txt2);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:10px;transition:.2s}
.nav-btn.active{color:var(--accent)}
.nav-btn svg{width:20px;height:20px;flex-shrink:0}

/* ── HEADER ── */
.page-header{background:var(--bg2);padding:14px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}
.page-header-row{display:flex;align-items:center;justify-content:space-between}
.page-title{font-size:18px;font-weight:700}
.page-sub{font-size:12px;color:var(--txt2);margin-top:2px}

/* ── BACK HEADER ── */
.back-header{background:var(--bg2);padding:12px 16px;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;display:flex;align-items:center;gap:10px}
.back-btn{background:none;border:none;color:var(--accent);cursor:pointer;display:flex;align-items:center;gap:4px;font-size:14px;padding:4px 0}
.back-btn svg{width:18px;height:18px}

/* ── STATS ── */
.stats-row{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;padding:12px 16px}
.stat-box{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px}
.stat-val{font-size:20px;font-weight:700;line-height:1}
.stat-lbl{font-size:10px;color:var(--txt2);margin-top:4px}
.stat-green .stat-val{color:var(--green)}
.stat-red   .stat-val{color:var(--red)}
.stat-yellow .stat-val{color:var(--yellow)}

/* ── FILTER TABS ── */
.filter-row{display:flex;gap:6px;padding:0 16px 12px;overflow-x:auto;scrollbar-width:none}
.filter-row::-webkit-scrollbar{display:none}
.ftab{flex-shrink:0;padding:5px 12px;border-radius:20px;border:1px solid var(--border);background:none;color:var(--txt2);font-size:12px;cursor:pointer;transition:.2s;white-space:nowrap}
.ftab.active{background:var(--accent2);border-color:var(--accent2);color:#fff}

/* ── SEARCH ── */
.search-wrap{padding:0 16px 12px}
.search-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:9px 12px;color:var(--txt);font-size:14px;outline:none}
.search-input:focus{border-color:var(--accent)}
.search-input::placeholder{color:var(--txt3)}

/* ── APT LIST ── */
.apt-list{padding:0 16px}
.apt-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;margin-bottom:8px;cursor:pointer;transition:.15s;display:flex;align-items:center;gap:12px}
.apt-card:active{transform:scale(.98)}
.apt-num{width:44px;height:44px;border-radius:8px;background:var(--bg3);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:15px;flex-shrink:0}
.apt-num.c-green{background:rgba(34,197,94,.15);color:var(--green)}
.apt-num.c-red{background:rgba(239,68,68,.15);color:var(--red)}
.apt-num.c-yellow{background:rgba(245,158,11,.15);color:var(--yellow)}
.apt-num.c-purple{background:rgba(129,140,248,.15);color:var(--purple)}
.apt-info{flex:1;min-width:0}
.apt-name{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.apt-meta{font-size:11px;color:var(--txt2);margin-top:2px}
.apt-right{text-align:right;flex-shrink:0}
.apt-debt-val{font-size:13px;font-weight:600}
.badge{font-size:10px;margin-top:3px;padding:2px 7px;border-radius:10px;font-weight:500;display:inline-block}
.badge-paid   {background:rgba(34,197,94,.15);color:var(--green)}
.badge-debt   {background:rgba(239,68,68,.15);color:var(--red)}
.badge-partial{background:rgba(245,158,11,.15);color:var(--yellow)}
.badge-over   {background:rgba(129,140,248,.15);color:var(--purple)}

/* ── DETAIL ── */
.info-card{background:var(--card);border:1px solid var(--border);border-radius:var(--r);padding:14px;margin:0 16px 12px}
.info-row{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px}
.info-row:last-child{margin-bottom:0}
.info-key{font-size:12px;color:var(--txt2)}
.info-val{font-size:13px;font-weight:500}

/* ── Переплата-бейдж ── */
.over-banner{background:rgba(129,140,248,.12);border:1px solid rgba(129,140,248,.3);border-radius:var(--r);padding:10px 14px;margin:0 16px 12px;display:flex;align-items:center;gap:10px}
.over-banner-icon{font-size:20px;flex-shrink:0}
.over-banner-text{font-size:13px;font-weight:500;color:var(--purple)}
.over-banner-sub{font-size:11px;color:var(--txt2);margin-top:2px}

.section-hdr{font-size:12px;font-weight:600;color:var(--txt2);text-transform:uppercase;letter-spacing:.5px;padding:0 16px;margin:14px 0 8px;display:flex;align-items:center;justify-content:space-between}
.btn-sm{background:var(--accent2);border:none;color:#fff;padding:4px 12px;border-radius:16px;font-size:11px;cursor:pointer}
.btn-sm:active{opacity:.8}

.months-wrap{margin:0 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.months-table{width:100%;border-collapse:collapse;font-size:13px}
.months-table th{text-align:left;color:var(--txt2);font-weight:500;padding:8px 12px;border-bottom:1px solid var(--border);font-size:11px}
.months-table td{padding:9px 12px;border-bottom:1px solid var(--bg3)}
.months-table tr:last-child td{border-bottom:none}
.months-table tr.closed-month td{opacity:.4}

/* ── PAYMENTS LIST ── */
.pay-list{margin:0 16px;background:var(--card);border:1px solid var(--border);border-radius:var(--r);overflow:hidden}
.pay-row{padding:10px 14px;border-bottom:1px solid var(--bg3)}
.pay-row:last-child{border-bottom:none}
.pay-main{display:flex;align-items:center;gap:10px}
.pay-dot{width:8px;height:8px;border-radius:50%;background:var(--green);flex-shrink:0}
.pay-meta{flex:1}
.pay-amount{font-size:14px;font-weight:600;color:var(--green)}
.pay-date{font-size:11px;color:var(--txt2)}

/* Тип платежа */
.pay-type-badge{display:inline-flex;align-items:center;gap:3px;font-size:10px;padding:1px 6px;border-radius:8px;background:var(--bg4);color:var(--txt2);margin-left:4px}

/* Аллокации в истории */
.pay-allocs{margin-top:8px;padding:8px 10px;background:var(--bg3);border-radius:8px}
.pay-alloc-row{display:flex;justify-content:space-between;font-size:11px;padding:2px 0;color:var(--txt2)}
.pay-alloc-row.is-over{color:var(--purple);font-weight:500}
.pay-alloc-row.is-covered{color:var(--green)}
.pay-alloc-over-label{font-size:10px;color:var(--purple);margin-top:4px;display:flex;align-items:center;gap:4px}

.notes-wrap{margin:0 16px}
.notes-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;color:var(--txt);font-size:13px;outline:none;resize:none;height:72px;font-family:inherit}
.notes-textarea:focus{border-color:var(--accent)}
.btn-outline{background:none;border:1px solid var(--border);color:var(--txt2);padding:6px 14px;border-radius:8px;font-size:12px;cursor:pointer;margin-top:6px}
.btn-outline:hover{border-color:var(--accent);color:var(--txt)}

/* ── FORM ── */
.form-body{padding:16px}
.form-group{margin-bottom:14px}
.form-label{font-size:12px;color:var(--txt2);margin-bottom:5px;display:block}
.form-input,.form-select,.form-textarea{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:10px 12px;color:var(--txt);font-size:14px;outline:none;font-family:inherit;-webkit-appearance:none}
.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--accent)}
.form-select option{background:var(--bg3)}
.form-textarea{resize:none;height:70px}
.btn-primary{width:100%;padding:13px;background:var(--accent2);border:none;border-radius:var(--r);color:#fff;font-size:15px;font-weight:600;cursor:pointer;margin-top:6px;transition:.15s}
.btn-primary:active{transform:scale(.98);opacity:.9}

/* ── Тип платежа — сегментированный контрол ── */
.pay-type-group{display:grid;grid-template-columns:repeat(3,1fr);gap:6px}
.pay-type-btn{padding:9px 6px;border-radius:var(--r);border:1px solid var(--border);background:var(--bg3);color:var(--txt2);font-size:12px;cursor:pointer;text-align:center;transition:.15s;display:flex;flex-direction:column;align-items:center;gap:3px}
.pay-type-btn .pt-icon{font-size:18px}
.pay-type-btn.selected{border-color:var(--accent2);background:rgba(74,108,247,.15);color:var(--txt)}

.alloc-box{background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:12px;margin:10px 0}
.alloc-title{font-size:11px;font-weight:600;color:var(--txt2);margin-bottom:6px}
.alloc-row{display:flex;justify-content:space-between;font-size:12px;padding:3px 0}
.alloc-covered{color:var(--green)}
.alloc-partial{color:var(--yellow)}
.alloc-over{color:var(--purple)}

/* ── REPORTS ── */
.report-card{background:var(--card);border:1px solid var(--border);border-radius:var(--rl);padding:16px;margin:0 16px 12px}
.report-title{font-size:14px;font-weight:600;margin-bottom:12px}
.big-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}
.big-item{background:var(--bg3);border-radius:8px;padding:10px 12px}
.big-val{font-size:20px;font-weight:700}
.big-lbl{font-size:11px;color:var(--txt2);margin-top:3px}
.paytype-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-top:12px}
.paytype-item{background:var(--bg3);border-radius:8px;padding:10px 8px;text-align:center}
.paytype-val{font-size:15px;font-weight:700}
.paytype-lbl{font-size:11px;color:var(--txt2);margin-top:3px}
.progress-track{height:6px;background:var(--bg3);border-radius:3px;overflow:hidden;margin:8px 0}
.progress-fill{height:100%;background:var(--green);border-radius:3px;transition:width .5s}
.debtor-list{display:flex;flex-direction:column;gap:6px}
.debtor-row{display:grid;grid-template-columns:54px 1fr auto auto;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--bg3)}
.debtor-row:last-child{border-bottom:none}
.debtor-apt{font-size:12px;font-weight:700;color:var(--txt2)}
.debtor-main{min-width:0}
.debtor-name{font-size:13px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.debtor-meta{font-size:11px;color:var(--txt2)}
.debtor-months{font-size:11px;color:var(--yellow);white-space:nowrap}
.debtor-debt{font-size:13px;font-weight:600;color:var(--red);white-space:nowrap}
.month-bar{margin-bottom:10px}
.month-bar-hdr{display:flex;justify-content:space-between;font-size:12px;margin-bottom:3px}
.month-bar-sub{color:var(--txt2)}

/* ── LOGIN ── */
.login-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;padding:32px}
.login-icon{font-size:56px;margin-bottom:16px}
.login-title{font-size:22px;font-weight:700;margin-bottom:8px}
.login-sub{font-size:14px;color:var(--txt2);text-align:center;margin-bottom:32px;line-height:1.5}
.login-input{width:100%;background:var(--bg3);border:1px solid var(--border);border-radius:var(--r);padding:12px 14px;color:var(--txt);font-size:15px;outline:none;margin-bottom:10px}
.login-input:focus{border-color:var(--accent)}
.login-btn{width:100%;padding:14px;background:var(--accent2);border:none;border-radius:var(--r);color:#fff;font-size:15px;font-weight:600;cursor:pointer}

/* ── LOADING ── */
.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--txt2);font-size:14px}
.spinner{width:24px;height:24px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .6s linear infinite;margin-right:10px}
@keyframes spin{to{transform:rotate(360deg)}}

/* ── EMPTY ── */
.empty{text-align:center;padding:48px 20px;color:var(--txt2);font-size:14px}

/* ── TOAST ── */
.toast{position:fixed;bottom:85px;left:50%;transform:translateX(-50%) translateY(10px);padding:9px 20px;border-radius:20px;font-size:13px;font-weight:500;opacity:0;transition:.25s;z-index:999;pointer-events:none;white-space:nowrap}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.toast-ok{background:var(--green);color:#fff}
.toast-err{background:var(--red);color:#fff}

/* ── VIEWS ── */
.view{display:none}
.view.active{display:block}
