:root{
  --bg:#0f1115; --surface:#171a21; --surface-2:#1f232c; --line:#2a2f3a;
  --text:#e8eaed; --muted:#9aa3b2; --accent:#5b8cff; --accent-ink:#0b1220;
  --green:#2ecc71; --green-bg:rgba(46,204,113,.12);
  --red:#ff5c6c; --red-bg:rgba(255,92,108,.12);
  --amber:#f4b740;
  --radius:14px; --shadow:0 8px 30px rgba(0,0,0,.35);
  font-synthesis:none;
}
*{box-sizing:border-box}
/* Атрибут hidden должен ВСЕГДА прятать — иначе display:flex у .screen/.summary
   перебивает [hidden]{display:none} и «скрытые» блоки остаются видимыми. */
[hidden]{display:none !important}
html,body{margin:0}
body{
  background:radial-gradient(1200px 600px at 50% -10%, #182033 0%, var(--bg) 55%);
  color:var(--text); min-height:100dvh;
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Inter,system-ui,sans-serif;
  -webkit-font-smoothing:antialiased;
}
.screen{min-height:100dvh;display:flex;flex-direction:column}
.dot{display:inline-block;width:9px;height:9px;border-radius:50%;
  background:var(--accent);box-shadow:0 0 12px var(--accent);vertical-align:middle}

/* ---------- Вход ---------- */
#login{align-items:center;justify-content:center;padding:24px}
.card.auth{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--line);
  border-radius:var(--radius);box-shadow:var(--shadow);padding:28px}
.brand{font-size:19px;font-weight:700;letter-spacing:.2px;margin-bottom:22px;display:flex;gap:10px;align-items:center}
.lbl{display:block;font-size:13px;color:var(--muted);margin:14px 0 7px}
.input{width:100%;background:var(--surface-2);border:1px solid var(--line);color:var(--text);
  border-radius:10px;padding:13px 14px;font-size:16px;outline:none;transition:border-color .15s}
.input:focus{border-color:var(--accent)}
select.input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8'%3E%3Cpath d='M1 1l5 5 5-5' stroke='%239aa3b2' stroke-width='1.6' fill='none' stroke-linecap='round'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:right 14px center;padding-right:36px}
.input.code{letter-spacing:10px;text-align:center;font-size:26px;font-variant-numeric:tabular-nums;font-weight:700}
.btn{width:100%;border:0;border-radius:10px;padding:13px 14px;font-size:15px;font-weight:600;
  cursor:pointer;margin-top:14px;transition:transform .05s, filter .15s}
.btn:active{transform:translateY(1px)}
.btn-primary{background:var(--accent);color:var(--accent-ink)}
.btn-primary:hover{filter:brightness(1.06)}
.btn-primary:disabled{opacity:.55;cursor:default}
.btn-ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.btn-ghost:hover{color:var(--text)}
.btn.sm{width:auto;padding:8px 14px;font-size:13px;margin:0}
.hint{color:var(--muted);font-size:12.5px;margin:12px 0 0;line-height:1.5}
.err{color:var(--red);font-size:13px;margin:14px 0 0;background:var(--red-bg);
  border:1px solid rgba(255,92,108,.25);border-radius:9px;padding:10px 12px}
.foot{color:var(--muted);opacity:.6;font-size:12px;margin:18px 0 0;text-align:center}

/* ---------- Топбар ---------- */
.topbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;justify-content:space-between;
  padding:14px 18px;background:rgba(15,17,21,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.topbar-l{display:flex;gap:10px;align-items:center;font-size:15px}
.wrap{max-width:760px;width:100%;margin:0 auto;padding:18px 16px 60px}

/* ---------- Сводка ---------- */
.summary{display:flex;gap:12px;margin-bottom:18px}
.sum-item{flex:1;background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:14px 16px}
.sum-item span{display:block;color:var(--muted);font-size:12.5px;margin-bottom:5px}
.sum-item b{font-size:22px;font-variant-numeric:tabular-nums}

/* ---------- Карточка смены ---------- */
.shifts{display:flex;flex-direction:column;gap:14px}
.shift{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.shift-head{display:flex;justify-content:space-between;align-items:center;padding:14px 16px;
  border-bottom:1px solid var(--line);background:var(--surface-2)}
.shift-head .date{font-weight:700;font-size:15px}
.shift-head .cashier{color:var(--muted);font-size:12.5px;margin-top:2px}
.rows{padding:8px 16px}
.row{display:flex;justify-content:space-between;align-items:baseline;padding:7px 0;font-size:14px;border-bottom:1px dashed var(--line)}
.row:last-child{border-bottom:0}
.row .k{color:var(--muted)}
.row .v{font-variant-numeric:tabular-nums;font-weight:600}
.row .note{color:var(--amber);font-size:11.5px;margin-left:8px}
.sub{padding:4px 16px 12px}
.sub h4{margin:12px 0 6px;font-size:12px;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}
.exp{display:flex;justify-content:space-between;gap:10px;background:var(--surface-2);
  border:1px solid var(--line);border-radius:10px;padding:9px 12px;margin-bottom:7px;font-size:13.5px}
.exp .cat{font-weight:600}
.exp .cm{color:var(--muted);font-size:12px;margin-top:2px}
.exp .amt{font-variant-numeric:tabular-nums;white-space:nowrap}
.shift-foot{display:flex;justify-content:space-between;align-items:center;padding:13px 16px;border-top:1px solid var(--line)}
.shift-foot .cash{font-size:15px}
.shift-foot .cash b{font-variant-numeric:tabular-nums}
.badge{font-size:12.5px;font-weight:700;padding:5px 11px;border-radius:999px}
.badge.ok{background:var(--green-bg);color:var(--green)}
.badge.short{background:var(--red-bg);color:var(--red)}
.empty{color:var(--muted);text-align:center;padding:40px 0;font-size:15px}

/* ---------- Редактируемый расход ---------- */
.exp{flex-direction:column;gap:8px}
.exp-top{display:flex;justify-content:space-between;gap:10px;align-items:center}
.exp-fields{display:none;flex-direction:column;gap:8px;margin-top:2px}
.exp.editing .exp-fields{display:flex}
.exp .edit-input{width:100%;background:var(--bg);border:1px solid var(--line);color:var(--text);
  border-radius:9px;padding:9px 11px;font-size:13.5px;outline:none}
.exp .edit-input:focus{border-color:var(--accent)}
.exp-actions{display:flex;gap:8px;justify-content:flex-end}
.mini{border:0;border-radius:8px;padding:6px 12px;font-size:12.5px;font-weight:600;cursor:pointer}
.mini.apply{background:var(--accent);color:var(--accent-ink)}
.mini.apply:disabled{opacity:.5;cursor:default}
.mini.del{background:var(--red-bg);color:var(--red)}
.mini.ghost{background:transparent;color:var(--muted);border:1px solid var(--line)}
.icon-btn{background:transparent;border:1px solid var(--line);color:var(--muted);border-radius:8px;
  padding:5px 9px;font-size:12px;cursor:pointer}
.icon-btn:hover{color:var(--text)}
.exp .edited{color:var(--green);font-size:11px;margin-left:6px}

/* ---------- Сверка с банком ---------- */
.bank{padding:2px 16px 10px}
.bank .mini.ghost{width:auto}
.bank-out{margin-top:8px;display:flex;flex-direction:column;gap:6px}
.bank-line{display:flex;justify-content:space-between;align-items:center;gap:10px;
  background:var(--surface-2);border:1px solid var(--line);border-radius:9px;padding:8px 11px;font-size:12.5px}
.bank-line span:first-child{color:var(--muted);font-variant-numeric:tabular-nums}
.bank-note{color:var(--muted);font-size:12.5px;padding:4px 2px}
.bank-note.bad{color:var(--red)}

/* ---------- Панель сдачи ---------- */
.wrap{padding-bottom:90px}
.handover-bar{position:sticky;bottom:0;display:flex;align-items:center;justify-content:space-between;
  gap:12px;padding:12px 16px;background:rgba(15,17,21,.92);backdrop-filter:blur(10px);
  border-top:1px solid var(--line);max-width:760px;margin:0 auto;width:100%}
.hb-info{font-size:14px}
.hb-info b{font-variant-numeric:tabular-nums;font-size:17px}
.hb-btn{width:auto;margin:0;padding:12px 18px}

/* ---------- Модалка ---------- */
.modal{position:fixed;inset:0;background:rgba(0,0,0,.6);display:flex;align-items:center;
  justify-content:center;padding:20px;z-index:50}
.modal-card{background:var(--surface);border:1px solid var(--line);border-radius:16px;
  box-shadow:var(--shadow);padding:22px;width:100%;max-width:420px}
.modal-card h3{margin:0 0 14px;font-size:17px}
.modal-body-text{color:var(--muted);font-size:14px;line-height:1.5;margin-bottom:12px}
.modal-card textarea,.modal-card input{width:100%;background:var(--surface-2);border:1px solid var(--line);
  color:var(--text);border-radius:10px;padding:11px 13px;font-size:15px;outline:none;font-family:inherit}
.modal-card textarea:focus,.modal-card input:focus{border-color:var(--accent)}
.modal-card textarea{min-height:80px;resize:vertical}
.modal-card .big-num{font-size:20px;font-weight:700;text-align:center;font-variant-numeric:tabular-nums}
.modal-actions{display:flex;gap:10px;margin-top:16px}
.modal-actions .btn{margin:0}

/* ---------- Тост ---------- */
.toast{position:fixed;bottom:76px;left:50%;transform:translateX(-50%);background:var(--surface-2);
  border:1px solid var(--line);color:var(--text);padding:11px 18px;border-radius:999px;font-size:13.5px;
  box-shadow:var(--shadow);z-index:60;max-width:90%}
.toast.ok{border-color:rgba(46,204,113,.4)}
.toast.bad{border-color:rgba(255,92,108,.4);color:var(--red)}

@media (max-width:480px){
  .card.auth{padding:22px}
  .summary{flex-direction:column}
  .handover-bar{flex-direction:column;gap:10px}
  .hb-btn{width:100%}
}
