:root{
  --paper:#EBEEF2; --surface:#FFFFFF; --ink:#1C2430; --muted:#6A7380; --faint:#9AA2AD;
  --brass:#A87A33; --brass-2:#8C631F; --brass-bg:#F4ECDC; --line:#E4E8EE; --line-2:#EEF1F4;
  --mk:#6E56CF; --ok:#2E7BD6; --otk:#1E9E86; --vh:#5B6470;
  --paid:#1E8E5A; --paid-bg:#E7F3EC; --part:#B5790F; --part-bg:#FAF0DC; --unpaid:#C0392B; --unpaid-bg:#FBEAE8;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Golos Text',system-ui,sans-serif;color:var(--ink);background:var(--paper);
  -webkit-font-smoothing:antialiased;line-height:1.45}
button{font-family:inherit;cursor:pointer}
.num{font-variant-numeric:tabular-nums}
.rub{font-weight:400;color:var(--muted)}
.hidden{display:none!important}

/* ===== LOGIN ===== */
.login{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}
.loginbox{width:340px;background:var(--surface);border:1px solid var(--line);border-radius:18px;padding:26px 24px}
.loginbox .mk{width:44px;height:44px;border-radius:12px;background:var(--brass);color:#fff;display:flex;align-items:center;justify-content:center;font-size:24px;margin-bottom:14px}
.loginbox h1{font-family:'Onest';font-weight:600;font-size:20px;margin-bottom:4px}
.loginbox p{color:var(--muted);font-size:13px;margin-bottom:18px}
.loginbox label{font-size:13px;color:var(--muted);display:block;margin-bottom:6px}
.loginbox input{width:100%;border:1px solid var(--line);border-radius:11px;padding:11px 13px;font-size:15px;font-family:inherit;margin-bottom:14px}
.loginbox input:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px var(--brass-bg)}
.loginbox .hint{font-size:12px;color:var(--faint);margin-top:12px;text-align:center}
.btn-primary{width:100%;background:var(--brass);border:1px solid var(--brass);color:#fff;border-radius:11px;padding:12px;font-size:15px;font-weight:600}

/* ===== APP SHELL ===== */
.app{display:grid;grid-template-columns:236px 1fr;min-height:100vh}
.side{border-right:1px solid var(--line);padding:18px 14px;display:flex;flex-direction:column;background:#FCFCFD;position:sticky;top:0;height:100vh}
.brand{display:flex;align-items:center;gap:9px;padding:4px 8px 16px}
.brand .mk{width:30px;height:30px;border-radius:9px;background:var(--brass);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px}
.brand b{font-family:'Onest';font-weight:600;font-size:15px}
.nav{display:flex;flex-direction:column;gap:2px}
.item{display:flex;align-items:center;gap:11px;padding:10px 11px;border-radius:11px;color:var(--muted);font-size:14px;font-weight:500;text-decoration:none}
.item i{font-size:20px}
.item.on{background:var(--brass-bg);color:var(--brass-2)}
.me{margin-top:auto;display:flex;align-items:center;gap:10px;padding:10px 8px 2px;border-top:1px solid var(--line)}
.me .av{width:34px;height:34px;border-radius:50%;background:#E9E3D4;color:var(--brass-2);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:13px}
.me .nm{font-size:13.5px;font-weight:500} .me .ro{font-size:12px;color:var(--muted)}
.me .out{margin-left:auto;color:var(--faint);font-size:18px;background:none;border:none}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:14px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:var(--paper);z-index:5}
.topbar .ttl{font-family:'Onest';font-weight:600;font-size:20px;letter-spacing:-.01em}
.search{margin-left:8px;flex:1;max-width:420px;display:flex;align-items:center;gap:8px;background:#F4F6F8;border:1px solid var(--line);border-radius:11px;padding:0 12px;color:var(--muted)}
.search i{font-size:18px}
.search input{flex:1;border:none;background:none;padding:9px 0;font-size:13.5px;font-family:inherit;color:var(--ink)}
.search input:focus{outline:none}
.grow{flex:1}
.tbtn{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:600;color:#fff;background:var(--brass);border:none;border-radius:11px;padding:9px 14px}
.content{padding:20px 22px 26px;min-width:0}
.tabbar{display:none}

/* ===== SHARED ===== */
.label{font-size:12px;font-weight:600;color:var(--faint);text-transform:uppercase;letter-spacing:.06em;margin:2px 2px 10px}
.stats{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap}
.stat{flex:1;min-width:120px;background:#F5F7F9;border-radius:14px;padding:12px 14px}
.stat .n{font-family:'Onest';font-weight:600;font-size:24px;letter-spacing:-.02em}
.stat .l{font-size:12px;color:var(--muted);margin-top:1px}
.row{position:relative;background:var(--surface);border:1px solid var(--line);border-radius:13px;padding:11px 12px 11px 18px;display:flex;align-items:center;gap:10px;margin-bottom:8px;cursor:pointer;text-align:left;width:100%;font-family:inherit}
.row.sel{border-color:var(--brass);background:#FCF8EF}
.spine{position:absolute;left:0;top:9px;bottom:9px;width:4px;border-radius:4px}
.row .m{flex:1;min-width:0}
.row .t{font-size:14px;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--ink)}
.row .s{font-size:12.5px;color:var(--muted);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.row .meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px;font-size:12.5px;color:var(--muted)}
.chev{color:var(--faint);font-size:18px}
.pill{display:inline-flex;align-items:center;gap:4px;font-weight:600;font-size:12px;padding:3px 9px;border-radius:999px;white-space:nowrap}
.pill .g{font-size:13px;line-height:1}
.paid{color:var(--paid);background:var(--paid-bg)} .part{color:var(--part);background:var(--part-bg)} .unpaid{color:var(--unpaid);background:var(--unpaid-bg)}
.dot{width:9px;height:9px;border-radius:50%;display:inline-block;flex:none}
.dchip{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;padding:5px 11px;border-radius:999px;background:#F2F4F7}
.filters{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:13px}
.fchip{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;padding:6px 11px;border-radius:999px;border:1px solid var(--line);background:#fff;color:var(--muted)}
.fchip.on{background:var(--ink);color:#fff;border-color:var(--ink)} .fchip.off{opacity:.5}
.orphan{display:flex;align-items:center;gap:10px;background:#FBF3E4;border:1px solid #EAD9B3;color:var(--brass-2);border-radius:12px;padding:10px 13px;font-size:13.5px;font-weight:500;margin-bottom:12px;cursor:pointer}
.orphan .b{margin-left:auto;font-size:12px;background:var(--brass);color:#fff;padding:4px 10px;border-radius:999px;font-weight:600}
.empty{color:var(--faint);font-size:14px;text-align:center;padding:40px 10px}

/* ===== ORDERS SPLIT ===== */
.orders{display:grid;grid-template-columns:380px 1fr;gap:18px;align-items:start}
.listcol{min-width:0}
.detailcol{min-width:0}
.placeholder{border:1px dashed var(--line);border-radius:16px;padding:60px 20px;text-align:center;color:var(--faint);font-size:14px}
.detail{border:1px solid var(--line);border-radius:16px;padding:18px}
.backbtn{display:none;align-items:center;gap:6px;font-size:13.5px;color:var(--muted);background:none;border:none;margin-bottom:12px}
.ordhead{display:flex;align-items:center;gap:12px;margin-bottom:16px;flex-wrap:wrap}
.ordhead .h{font-family:'Onest';font-weight:600;font-size:20px}
.ordhead .sp{flex:1}
.ghost{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;color:var(--ink);border:1px solid var(--line);background:#fff;border-radius:10px;padding:7px 11px}
.ordgrid{display:grid;grid-template-columns:1.15fr 1fr;gap:16px;margin-bottom:16px}
.money{background:#F7F8FA;border:1px solid var(--line);border-radius:16px;padding:16px}
.money .mrow{display:flex;justify-content:space-between;align-items:baseline;font-size:14px;margin-bottom:7px}
.money .mrow .k{color:var(--muted)} .money .mrow .v{font-weight:500}
.money .ost{display:flex;justify-content:space-between;align-items:center;margin:12px 0 4px}
.money .ost .k{color:var(--muted);font-size:13px}
.money .big{font-family:'Onest';font-weight:700;font-size:32px;letter-spacing:-.02em}
.bar{height:6px;border-radius:999px;background:#E6E9EE;overflow:hidden;margin-top:12px}
.bar > i{display:block;height:100%;background:var(--brass)}
.pct{font-size:11.5px;color:var(--muted);margin-top:6px}
.sidecol{display:flex;flex-direction:column;gap:12px}
.stat2{display:flex;gap:10px}
.scell{flex:1;border:1px solid var(--line);border-radius:12px;padding:10px 12px}
.scell .l{font-size:11.5px;color:var(--muted)} .scell .v{font-size:13.5px;font-weight:600;margin-top:3px;display:flex;align-items:center;gap:6px}
.ok-i{color:var(--paid)} .wn-i{color:var(--part)} .no-i{color:var(--muted)}
.kv{border:1px solid var(--line);border-radius:13px;padding:2px 14px}
.kv .r{display:flex;justify-content:space-between;align-items:center;padding:9px 0;font-size:13.5px;border-bottom:1px solid var(--line)}
.kv .r:last-child{border-bottom:0} .kv .k{color:var(--muted)} .kv .v{font-weight:500;text-align:right}
.touches{border-top:1px solid var(--line);padding-top:14px;margin-bottom:16px}
.tch{display:flex;gap:10px;align-items:flex-start;font-size:13px;padding:6px 0}
.tch i{font-size:17px;color:var(--faint);margin-top:1px}
.tch .x{color:var(--muted)} .tch .dt{margin-left:auto;color:var(--faint);font-size:12px;white-space:nowrap}
.btns{display:flex;gap:10px;flex-wrap:wrap}
.btn{border-radius:12px;padding:12px 16px;font-size:14px;font-weight:600;border:1px solid var(--line);background:#fff;color:var(--ink);display:inline-flex;align-items:center;justify-content:center;gap:7px}
.btn.primary{background:var(--brass);border-color:var(--brass);color:#fff}

/* ===== MONEY DASHBOARD ===== */
.metrics{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px}
.mcard{background:#F5F7F9;border-radius:14px;padding:14px 16px}
.mcard .l{font-size:12.5px;color:var(--muted);display:flex;align-items:center;gap:6px}
.mcard .n{font-family:'Onest';font-weight:600;font-size:24px;margin-top:6px;letter-spacing:-.01em}
.mcard.warn{background:#FBF3E4} .mcard.warn .l{color:var(--brass-2)}
.mcard.bad{background:#FBEDEC} .mcard.bad .l{color:var(--unpaid)}
.dash{display:grid;grid-template-columns:1.9fr 1fr;gap:18px;align-items:start}
.panel{border:1px solid var(--line);border-radius:16px;overflow:hidden}
.panel .ph{padding:13px 16px;border-bottom:1px solid var(--line);font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px}
.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
.tbl th{text-align:left;color:var(--muted);font-weight:500;font-size:11.5px;text-transform:uppercase;letter-spacing:.04em;padding:10px 14px;border-bottom:1px solid var(--line)}
.tbl td{padding:11px 14px;border-bottom:1px solid var(--line-2)}
.tbl tr:last-child td{border-bottom:0}
.tbl .r{text-align:right;font-variant-numeric:tabular-nums}
.aside{display:flex;flex-direction:column;gap:18px}
.fun{padding:6px 16px 14px}
.fline{display:flex;align-items:center;gap:10px;padding:8px 0;font-size:13px}
.fline .lab{width:104px;color:var(--muted)} .fline .track{flex:1;height:8px;background:#EEF1F4;border-radius:999px;overflow:hidden}
.fline .track > i{display:block;height:100%;background:var(--brass);border-radius:999px}
.fline .c{width:26px;text-align:right;font-weight:600;font-variant-numeric:tabular-nums}
.src{padding:4px 16px 12px;font-size:13.5px}
.src .r{display:flex;justify-content:space-between;padding:9px 0;border-bottom:1px solid var(--line-2)} .src .r:last-child{border-bottom:0}
.src .k{color:var(--muted)} .src .v{font-weight:600;font-variant-numeric:tabular-nums}

/* ===== TOAST ===== */
.toast{position:fixed;left:50%;bottom:24px;transform:translateX(-50%);background:var(--ink);color:#fff;padding:11px 18px;border-radius:12px;font-size:13.5px;z-index:50;max-width:90vw;text-align:center}

/* ===== ADAPTIVE: phone ===== */
@media (max-width:980px){
  .app{grid-template-columns:1fr}
  .side{display:none}
  .topbar{padding:13px 16px}
  .content{padding:16px 16px 84px}
  .orders{grid-template-columns:1fr}
  .ordgrid{grid-template-columns:1fr}
  .metrics{grid-template-columns:repeat(2,1fr)}
  .dash{grid-template-columns:1fr}
  .search{max-width:none}
  .detailcol{display:none}
  .orders.has-detail .detailcol{display:block}
  .orders.has-detail .listcol{display:none}
  .backbtn{display:inline-flex}
  .tabbar{display:flex;position:fixed;left:0;right:0;bottom:0;background:var(--surface);border-top:1px solid var(--line);padding:8px 6px env(safe-area-inset-bottom);z-index:20}
  .tab{flex:1;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;color:var(--faint);text-decoration:none}
  .tab i{font-size:22px} .tab.on{color:var(--brass)}
}

/* ===== modal form ===== */
.modal-overlay{position:fixed;inset:0;background:rgba(20,25,35,.45);display:flex;align-items:center;justify-content:center;padding:20px;z-index:60}
.modal{width:380px;max-width:100%;background:var(--surface);border-radius:18px;overflow:hidden}
.modal-h{font-family:'Onest';font-weight:600;font-size:17px;padding:18px 20px 4px}
.modal-b{padding:8px 20px 4px}
.modal-f{display:flex;gap:10px;padding:14px 20px 18px}
.modal-f .btn{flex:1}
.field{margin-bottom:12px}
.field label{display:block;font-size:13px;color:var(--muted);margin-bottom:5px}
.field input,.field select{width:100%;border:1px solid var(--line);border-radius:11px;padding:10px 12px;font-size:15px;font-family:inherit;background:#fff;color:var(--ink)}
.field input:focus,.field select:focus{outline:none;border-color:var(--brass);box-shadow:0 0 0 3px var(--brass-bg)}
.readv{font-size:15px;font-weight:500;padding:6px 0}

/* ===== avatars ===== */
.av{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;background:#E9E3D4;color:var(--brass-2);font-weight:600;flex:none}
.av.sm{width:34px;height:34px;font-size:13px}
.av.lg{width:52px;height:52px;font-size:18px}
.avrow{padding-left:12px}

/* ===== deal flags ===== */
.fl{display:inline-flex;color:var(--brass-2);font-size:14px;margin-left:4px;vertical-align:-2px}
.flagrow{display:flex;gap:8px;flex-wrap:wrap}
.flagchip{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:500;padding:8px 12px;border-radius:11px;border:1px solid var(--line);background:#fff;color:var(--muted)}
.flagchip.on{background:var(--brass-bg);border-color:#E3D2AE;color:var(--brass-2)}

/* ===== client list / contact card ===== */
.clientsearch{display:flex;align-items:center;gap:8px;background:#F4F6F8;border:1px solid var(--line);border-radius:11px;padding:0 12px;margin-bottom:12px}
.clientsearch i{font-size:18px;color:var(--muted)}
.clientsearch input{flex:1;border:none;background:none;padding:10px 0;font-size:14px;font-family:inherit;color:var(--ink)}
.clientsearch input:focus{outline:none}
.contacthead{display:flex;align-items:center;gap:12px;margin-bottom:14px}
.contacthead .sp{flex:1}
.cname{font-family:'Onest';font-weight:600;font-size:19px}
.cphone{font-size:13.5px;color:var(--muted)}
.chans{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}
.chan{display:inline-flex;align-items:center;gap:6px;font-size:13px;color:var(--muted);background:#F2F4F7;padding:5px 10px;border-radius:999px}
.muted{color:var(--faint)}

/* ===== settings ===== */
.ph .addbtn{margin-left:auto;display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:600;color:var(--brass-2);background:var(--brass-bg);border:none;border-radius:9px;padding:5px 10px}
.setlist{padding:6px 12px 10px}
.setrow{display:flex;align-items:center;gap:10px;padding:9px 4px;border-bottom:1px solid var(--line-2)}
.setrow:last-child{border-bottom:0}
.setrow .m{flex:1;min-width:0}
.setrow .t{font-size:14px;font-weight:500} .setrow .s{font-size:12.5px;color:var(--muted)}
.setrow .ghost{padding:6px 9px;background:none}

/* ===== просрочка ===== */
.od{color:var(--unpaid);font-weight:600}
.stat.bad{background:#FBEDEC}
.stat.bad .n{color:var(--unpaid)}
