:root{
  --bg:#070b14;--bg2:#0c1422;--panel:#0e1828;--panel2:#111f33;--ink:#eaf1fb;--muted:#8093ab;
  --brand:#3ba0ff;--brand2:#22d3a6;--warn:#f7b955;--danger:#ff6b6b;--line:rgba(255,255,255,.08);
  --glass:rgba(255,255,255,.035);--radius:14px;
}
*{box-sizing:border-box;margin:0;padding:0}
body{font-family:'Inter',-apple-system,Segoe UI,Roboto,Arial,sans-serif;background:
  radial-gradient(60% 50% at 100% 0%,rgba(59,160,255,.10),transparent 60%),
  radial-gradient(50% 40% at 0% 100%,rgba(34,211,166,.07),transparent 60%),var(--bg);
  color:var(--ink);font-size:14px;-webkit-font-smoothing:antialiased;min-height:100vh}
a{color:inherit;text-decoration:none}
button{font-family:inherit}

/* ── ЛОГИН ── */
.login-body{display:flex;align-items:center;justify-content:center;min-height:100vh;padding:20px}
.login-card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);padding:36px;border-radius:22px;width:360px;display:flex;flex-direction:column;gap:14px;box-shadow:0 30px 80px rgba(0,0,0,.5);backdrop-filter:blur(10px)}
.login-logo{font-size:30px;font-weight:800;text-align:center;letter-spacing:.08em}
.login-logo span{background:linear-gradient(120deg,var(--brand),var(--brand2));-webkit-background-clip:text;background-clip:text;color:transparent}
.login-sub{text-align:center;color:var(--muted);margin-bottom:10px;font-size:13px}
.login-card input{padding:13px 15px;border:1px solid var(--line);border-radius:11px;font-size:15px;background:var(--glass);color:var(--ink)}
.login-card input:focus{outline:none;border-color:var(--brand)}
.login-card button{padding:14px;background:linear-gradient(135deg,var(--brand),#1f7fe0);color:#fff;border:0;border-radius:11px;font-size:15px;font-weight:700;cursor:pointer;box-shadow:0 12px 30px rgba(59,160,255,.3)}
.login-err{color:var(--danger);text-align:center;min-height:18px;font-size:13px}

/* ── КАРКАС: сайдбар + контент ── */
.layout{display:grid;grid-template-columns:248px 1fr;min-height:100vh}
.sidebar{background:rgba(8,13,22,.7);border-right:1px solid var(--line);backdrop-filter:blur(14px);display:flex;flex-direction:column;padding:22px 16px;position:sticky;top:0;height:100vh}
.side-logo{display:flex;align-items:center;gap:10px;padding:4px 8px 22px;border-bottom:1px solid var(--line);margin-bottom:14px}
.side-logo img{width:30px;height:30px;filter:invert(1) brightness(1.6) drop-shadow(0 0 8px rgba(59,160,255,.5))}
.side-logo b{font-size:19px;font-weight:800;letter-spacing:.06em}
.side-logo small{display:block;font-size:8.5px;color:var(--muted);letter-spacing:.16em}
.side-nav{display:flex;flex-direction:column;gap:3px;flex:1}
.side-nav button{display:flex;align-items:center;gap:12px;background:none;border:0;color:var(--muted);padding:11px 13px;border-radius:11px;cursor:pointer;font-size:14.5px;font-weight:500;text-align:left;transition:.15s}
.side-nav button .ico{font-size:17px;width:22px;text-align:center}
.side-nav button:hover{background:var(--glass);color:var(--ink)}
.side-nav button.active{background:linear-gradient(135deg,rgba(59,160,255,.2),rgba(34,211,166,.08));color:#fff;box-shadow:inset 0 0 0 1px rgba(59,160,255,.3)}
.nav-badge{margin-left:auto;background:#ff5d5d;color:#fff;font-size:11px;font-weight:700;min-width:20px;height:20px;border-radius:10px;display:inline-flex;align-items:center;justify-content:center;padding:0 6px}
.side-user{border-top:1px solid var(--line);padding-top:14px;font-size:13px}
.side-user .who{color:var(--ink);font-weight:600}
.side-user .role{color:var(--muted);font-size:11.5px;text-transform:uppercase;letter-spacing:.05em;margin:2px 0 10px}
.side-user button{width:100%;background:var(--glass);border:1px solid var(--line);color:var(--muted);padding:9px;border-radius:10px;cursor:pointer}
.side-user button:hover{color:var(--ink)}

.main{padding:26px 30px;max-width:1400px}
.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:22px;gap:16px;flex-wrap:wrap}
.page-head h1{font-size:26px;font-weight:800;letter-spacing:-.02em}

/* кнопки */
.btn{background:linear-gradient(135deg,var(--brand),#1f7fe0);color:#fff;border:0;border-radius:11px;padding:11px 18px;cursor:pointer;font-weight:600;font-size:14px;box-shadow:0 8px 22px rgba(59,160,255,.28);transition:transform .15s}
.btn:hover{transform:translateY(-2px)}
.btn-sm{padding:7px 13px;font-size:13px;border-radius:9px}
.btn-ghost{background:var(--glass);border:1px solid var(--line);color:var(--ink);border-radius:10px;padding:9px 14px;cursor:pointer;transition:.15s}
.btn-ghost:hover{background:rgba(255,255,255,.08)}
.btn-ghost:disabled{opacity:.4;cursor:default}

/* карточки дашборда */
.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:16px;margin-bottom:26px}
.card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--radius);padding:20px}
.card-val{font-size:30px;font-weight:800;background:linear-gradient(120deg,#fff,var(--brand));-webkit-background-clip:text;background-clip:text;color:transparent}
.card-label{color:var(--muted);margin-top:5px;font-size:13px}
.panel{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:var(--radius);padding:22px;margin-bottom:22px}
.panel h2{font-size:16px;margin-bottom:16px;font-weight:700}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:18px}
@media(max-width:900px){.two-col{grid-template-columns:1fr}}

/* бар-чарт (CSS) */
.bars{display:flex;flex-direction:column;gap:9px}
.bar-row{display:grid;grid-template-columns:120px 1fr 54px;align-items:center;gap:12px;font-size:13px}
.bar-row .bl{color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.bar-track{background:var(--glass);border-radius:6px;height:10px;overflow:hidden}
.bar-fill{height:100%;background:linear-gradient(90deg,var(--brand),var(--brand2));border-radius:6px}
.bar-row .bn{text-align:right;font-weight:600}

/* фильтры */
.filters{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:18px;align-items:center}
.filters input,.filters select{padding:10px 13px;border:1px solid var(--line);border-radius:10px;font-size:14px;background:var(--glass);color:var(--ink)}
.filters input:focus,.filters select:focus{outline:none;border-color:var(--brand)}
.filters .grow{flex:1;min-width:220px}
.count{color:var(--muted);font-size:13px;margin-bottom:10px}

/* таблицы */
.grid{width:100%;border-collapse:separate;border-spacing:0;background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}
.grid th{text-align:left;background:rgba(255,255,255,.03);padding:11px 13px;font-size:11px;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;white-space:nowrap}
.grid td{padding:11px 13px;border-top:1px solid var(--line);vertical-align:top}
.grid tbody tr:hover{background:rgba(59,160,255,.05)}
.grid tr.clickable{cursor:pointer}
.grid td.empty{text-align:center;color:var(--muted);padding:30px}
.pos{color:var(--brand2);font-weight:600}.neg{color:var(--danger)}
.pill{display:inline-block;padding:3px 9px;border-radius:7px;font-size:11px;font-weight:600}
.pill.open{background:rgba(34,211,166,.16);color:var(--brand2)}
.pill.closed{background:rgba(255,107,107,.14);color:var(--danger)}
.pager{display:flex;gap:12px;align-items:center;justify-content:center;margin:18px 0;color:var(--muted)}

/* биржа — карточки */
.offers{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.offer{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:16px;padding:18px;position:relative;overflow:hidden;transition:transform .2s,border-color .2s}
.offer:hover{transform:translateY(-4px);border-color:rgba(59,160,255,.35)}
.offer::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.offer.cargo::before{background:var(--brand)}.offer.truck::before{background:var(--brand2)}
.offer .route{font-size:17px;font-weight:700;margin-bottom:8px;display:flex;align-items:center;gap:8px}
.offer .route .arrow{color:var(--brand)}
.offer .meta{display:flex;flex-wrap:wrap;gap:6px;margin:10px 0}
.offer .tag{background:var(--glass);border:1px solid var(--line);padding:3px 9px;border-radius:7px;font-size:12px;color:var(--muted)}
.offer .who{color:var(--muted);font-size:13px;margin-top:6px}
.offer .foot{display:flex;justify-content:space-between;align-items:center;margin-top:12px;padding-top:12px;border-top:1px solid var(--line)}

/* модалка */
.modal{position:fixed;inset:0;background:rgba(4,8,15,.7);backdrop-filter:blur(4px);display:flex;align-items:flex-start;justify-content:center;padding:40px 16px;overflow-y:auto;z-index:100}
.modal.hidden{display:none}
.modal-card{background:linear-gradient(180deg,var(--panel),var(--bg2));border:1px solid var(--line);border-radius:20px;padding:26px;max-width:720px;width:100%;position:relative;box-shadow:0 30px 80px rgba(0,0,0,.6)}
.modal-close{position:absolute;top:14px;right:16px;border:0;background:var(--glass);width:34px;height:34px;border-radius:9px;font-size:20px;cursor:pointer;color:var(--muted)}
.modal-card h2{margin-bottom:18px;font-size:21px}
.kv{width:100%;border-collapse:collapse}
.kv td{padding:9px 10px;border-top:1px solid var(--line);font-size:14px}
.kv .kv-k{color:var(--muted);width:210px}
.doc-actions{display:flex;gap:10px;flex-wrap:wrap;margin:16px 0 4px}

/* формы */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:14px}
.form-grid .full{grid-column:1/-1}
.field label{display:block;font-size:12px;color:var(--muted);margin-bottom:5px;text-transform:uppercase;letter-spacing:.03em}
.field input,.field select,.field textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;background:var(--glass);color:var(--ink);font-size:14px;font-family:inherit}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand)}
.field textarea{resize:vertical;min-height:60px}
.checks{display:flex;flex-wrap:wrap;gap:14px}
.checks label{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--ink);text-transform:none;letter-spacing:0}
.checks input{width:auto}
.form-foot{display:flex;justify-content:flex-end;gap:10px;margin-top:20px}
.fieldset-title{grid-column:1/-1;font-size:13px;font-weight:700;color:var(--brand);text-transform:uppercase;letter-spacing:.05em;margin-top:6px;padding-top:10px;border-top:1px solid var(--line)}
@media(max-width:680px){.form-grid{grid-template-columns:1fr}.layout{grid-template-columns:1fr}.sidebar{position:static;height:auto;flex-direction:row;flex-wrap:wrap}.side-nav{flex-direction:row;flex-wrap:wrap}}
.toast{position:fixed;bottom:24px;right:24px;background:var(--panel2);border:1px solid var(--line);border-left:3px solid var(--brand2);padding:14px 18px;border-radius:12px;box-shadow:0 14px 40px rgba(0,0,0,.5);z-index:200;animation:slideup .3s}
@keyframes slideup{from{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}
