/* ============================================================
   UnionGlass — дизайн-система (светлая, мягкая, минималистичная).
   Перенесена из одобренного прототипа 1:1 + добавления для форм/логина.
   ============================================================ */
:root{
  --bg:#f4f8f8; --bg-2:#eef5f4; --surface:#ffffff; --surface-2:#f5faf9;
  --text:#22424a; --muted:#7e99a0; --faint:#aabfc3;
  --border:#eef3f3; --border-2:#e7efef;
  --primary:#2bab9b; --primary-strong:#1f9082; --primary-soft:#e7f5f1;
  --accent:#39c4af;
  --green:#41b78d; --green-soft:#e7f5ee; --green-ink:#2c9670;
  --rose:#ec9090; --rose-soft:#fbecec; --rose-ink:#cf6a64;
  --blue:#69b6df; --blue-soft:#e8f3fa; --blue-ink:#3f8fbf;
  --lav:#a99ce0; --lav-soft:#efecfa;
  --amber:#e0ab5e; --amber-soft:#faf0dc; --amber-ink:#b6822f;
  --shadow:0 1px 2px rgba(22,52,56,.03), 0 10px 28px rgba(22,52,56,.045);
  --shadow-soft:0 1px 2px rgba(22,52,56,.03), 0 16px 38px rgba(22,52,56,.05);
  --shadow-lift:0 2px 5px rgba(22,52,56,.05), 0 22px 46px rgba(22,52,56,.09);
  --radius:20px; --radius-sm:14px; --radius-xs:11px;
  --ease:cubic-bezier(.22,.61,.36,1);
}
*{box-sizing:border-box;}
html,body{margin:0;height:100%;}
body{
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Inter,Roboto,"Helvetica Neue",Arial,sans-serif;
  background:var(--bg); color:var(--text);
  -webkit-font-smoothing:antialiased; font-size:14px; line-height:1.5;
  overflow:hidden; letter-spacing:.1px;
}
a{color:inherit;text-decoration:none;}
::-webkit-scrollbar{width:10px;height:10px;}
::-webkit-scrollbar-thumb{background:#dde7e7;border-radius:20px;border:3px solid var(--bg);}
::-webkit-scrollbar-thumb:hover{background:#cddada;}
.ic{display:inline-flex;align-items:center;justify-content:center;}
.ic svg{width:1.2em;height:1.2em;display:block;}
.app{display:grid; grid-template-columns:64px 1fr; height:100vh;}

/* ===== Sidebar ===== */
.sidebar{background:var(--surface); border-right:1px solid var(--border); display:flex; flex-direction:column; padding:20px 10px;}
.brand{display:flex; align-items:center; gap:12px; padding:6px 8px 20px;}
.brand>div{min-width:0;}
.brand b{display:block;color:var(--text);font-size:18px;letter-spacing:.2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.brand span{display:block;color:var(--faint);font-size:12px;margin-top:2px;letter-spacing:.3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.nav{display:flex;flex-direction:column;gap:3px;margin-top:4px;flex:1;overflow:auto;}
.nav .group{color:var(--faint);font-size:10.5px;text-transform:uppercase;letter-spacing:1px;margin:16px 12px 7px;font-weight:600;}
.nav a{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:13px;color:var(--muted);font-size:13.5px;font-weight:550;cursor:pointer;transition:background .18s var(--ease),color .18s var(--ease);position:relative;}
.nav a .ic{font-size:18px;color:var(--faint);transition:color .18s;}
.nav a:hover{background:var(--surface-2);color:var(--text);}
.nav a:hover .ic{color:var(--muted);}
.nav a.active{background:var(--primary-soft);color:var(--primary-strong);font-weight:650;}
.nav a.active .ic{color:var(--primary);}
.nav a .soon{margin-left:auto;font-size:9.5px;background:var(--surface-2);color:var(--faint);padding:3px 7px;border-radius:20px;font-weight:600;letter-spacing:.3px;}
.nav a .dot{margin-left:auto;width:7px;height:7px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 4px var(--rose-soft);}
.side-foot{border-top:1px solid var(--border);padding-top:14px;margin-top:8px;display:flex;align-items:center;gap:11px;}
.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(140deg,#39c4af,#23a7cf);display:flex;align-items:center;justify-content:center;line-height:1;color:#fff;font-weight:700;font-size:13px;flex:none;margin-left:4px;box-shadow:0 6px 14px rgba(43,171,155,.28);}
.side-foot b{color:var(--text);font-size:13px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.side-foot span{color:var(--faint);font-size:11px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.side-foot a.logout{margin-left:auto;color:var(--faint);font-size:16px;}
.side-foot a.logout:hover{color:var(--rose-ink);}

/* ===== Main ===== */
.main{display:flex;flex-direction:column;min-width:0;height:100vh;}
.topbar{height:66px;flex:none;background:rgba(255,255,255,.8);backdrop-filter:blur(10px);border-bottom:1px solid var(--border);display:flex;align-items:center;gap:14px;padding:0 26px;}
.topbar h1{font-size:17px;margin:0;font-weight:700;letter-spacing:.2px;}
.topbar .sub{color:var(--muted);font-size:12.5px;margin-top:1px;}
.spacer{flex:1;}
.pill{display:inline-flex;align-items:center;gap:8px;height:40px;padding:0 15px;border-radius:13px;border:1px solid var(--border-2);background:var(--surface);color:var(--text);font-size:13px;font-weight:600;cursor:pointer;transition:background .18s,box-shadow .18s,transform .18s var(--ease);}
.pill:hover{background:var(--surface-2);box-shadow:var(--shadow);}
.pill:active{transform:translateY(1px);}
.pill .ic{font-size:17px;color:var(--muted);}
.pill.role{background:linear-gradient(140deg,var(--primary),#23a7cf);color:#fff;border:none;box-shadow:0 8px 18px rgba(43,171,155,.3);}
.pill.role .ic{color:#fff;}
.iconbtn{width:40px;height:40px;border-radius:13px;border:1px solid var(--border-2);background:var(--surface);display:grid;place-items:center;cursor:pointer;position:relative;color:var(--muted);font-size:18px;transition:background .18s,box-shadow .18s;}
.iconbtn:hover{background:var(--surface-2);color:var(--text);box-shadow:var(--shadow);}
.iconbtn .bell-dot{position:absolute;top:9px;right:10px;width:7px;height:7px;border-radius:50%;background:var(--rose);box-shadow:0 0 0 3px var(--surface);}

.scroll{overflow:auto;scrollbar-gutter:stable;padding:26px;flex:1;}
.panel{animation:fade .4s var(--ease);}
@keyframes fade{from{opacity:0;transform:translateY(10px);}to{opacity:1;transform:none;}}

.sec-head{display:flex;align-items:flex-end;gap:14px;margin-bottom:22px;flex-wrap:wrap;}
.sec-head h2{font-size:23px;margin:0;font-weight:740;letter-spacing:.1px;}
.sec-head p{margin:5px 0 0;color:var(--muted);font-size:13px;max-width:560px;}
.chips{display:inline-flex;background:var(--surface);border:1px solid var(--border-2);border-radius:13px;padding:4px;gap:3px;box-shadow:var(--shadow);}
.chips button{border:none;background:none;padding:8px 16px;border-radius:9px;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;transition:all .2s var(--ease);}
.chips button.on{background:var(--primary-soft);color:var(--primary-strong);}

.grid{display:grid;gap:18px;}
.g4{grid-template-columns:repeat(4,1fr);}
.g3{grid-template-columns:repeat(3,1fr);}
.g2{grid-template-columns:repeat(2,1fr);}
.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow);padding:20px;transition:box-shadow .25s var(--ease),transform .25s var(--ease);}
.card.hover{cursor:pointer;}
.card.hover:hover{box-shadow:var(--shadow-lift);transform:translateY(-3px);}
.card.tight{padding:17px;}
.card h3{margin:0 0 2px;font-size:13px;font-weight:600;color:var(--muted);display:flex;align-items:center;gap:8px;}
.card .big{font-size:28px;font-weight:760;letter-spacing:-.5px;margin-top:10px;font-variant-numeric:tabular-nums;}
.card .big.sm{font-size:23px;}
.kpi-ico{width:34px;height:34px;border-radius:11px;display:grid;place-items:center;flex:none;font-size:18px;}
.delta{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;font-weight:700;margin-top:11px;padding:4px 10px;border-radius:20px;}
.delta .ic{font-size:14px;}
.delta.up{color:var(--green-ink);background:var(--green-soft);}
.delta.down{color:var(--rose-ink);background:var(--rose-soft);}
.delta.flat{color:var(--muted);background:var(--surface-2);}
.muted{color:var(--muted);} .small{font-size:12px;}
.row-between{display:flex;align-items:center;justify-content:space-between;}

.status-ok{display:flex;gap:14px;align-items:center;background:linear-gradient(140deg,#2bb6a4,#26a6c6);color:#fff;border-radius:var(--radius);padding:20px;box-shadow:0 14px 32px rgba(38,166,198,.26);}
.status-ok.warn{background:linear-gradient(140deg,#e6a45a,#d98686);box-shadow:0 14px 32px rgba(217,134,134,.26);}
.status-ok .ico{width:50px;height:50px;border-radius:15px;background:rgba(255,255,255,.18);display:grid;place-items:center;flex:none;font-size:26px;}
.status-ok b{font-size:17px;display:block;}
.status-ok span{opacity:.9;font-size:12.5px;}

.chart{width:100%;height:240px;}
.chart.tall{height:280px;}

.lined{display:flex;flex-direction:column;}
.lined>div{display:flex;align-items:center;gap:12px;padding:12px 0;border-top:1px solid var(--border);}
.lined>div:first-child{border-top:none;}
.lined .nm{font-weight:600;} .lined .rt{margin-left:auto;text-align:right;font-variant-numeric:tabular-nums;}

/* Детализация ЧА — дерево на <details> */
.na-node{border-top:1px solid var(--border);}
.na-node:first-child{border-top:none;}
.na-row{display:flex;align-items:center;gap:12px;padding:14px 4px;cursor:pointer;list-style:none;user-select:none;}
.na-row::-webkit-details-marker{display:none;}
.na-row .car{width:14px;flex:none;color:var(--faint);display:inline-flex;transition:transform .18s var(--ease);}
.na-row .car::before{content:"";border:5px solid transparent;border-left-color:currentColor;margin-left:3px;}
details[open]>.na-row .car{transform:rotate(90deg);}
.na-ic{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;flex:none;font-size:17px;}
.na-row>.nm{font-weight:650;}
.na-row .rt{margin-left:auto;font-weight:760;font-variant-numeric:tabular-nums;font-size:15px;}
.na-kids{padding:2px 4px 14px 58px;}
.na-kids>div{display:flex;align-items:center;gap:12px;padding:8px 0;border-top:1px dashed var(--border);}
.na-kids>div:first-child{border-top:none;}
.na-kids .nm{font-weight:500;}
.na-kids .rt{margin-left:auto;font-variant-numeric:tabular-nums;color:var(--muted);}
.na-kids>div.muted .nm{color:var(--faint);}
.na-sum{display:flex;align-items:center;padding:16px 4px;border-top:2px solid var(--border);}
.na-sum .nm{font-weight:750;font-size:15px;}
.na-sum .rt{margin-left:auto;font-weight:820;font-variant-numeric:tabular-nums;font-size:17px;}
.na-sum.hl{background:var(--green-soft);border-radius:12px;margin-top:8px;padding:16px 14px;border-top:none;}
.na-sum.hl .rt{color:var(--green-ink);}

/* Контрагенты — итоговая строка «без привязки» */
.cp-foot td{padding:14px 16px;border-top:2px solid var(--border);background:var(--surface-2);vertical-align:middle;}
.cp-foot td:first-child{border-bottom-left-radius:12px;}
.cp-foot td:last-child{border-bottom-right-radius:12px;}
.badge{font-size:11px;font-weight:700;padding:4px 10px;border-radius:20px;display:inline-flex;align-items:center;gap:5px;}
.badge .ic{font-size:12px;}
.badge.gray{background:var(--surface-2);color:var(--muted);}
.badge.green{background:var(--green-soft);color:var(--green-ink);}
.badge.amber{background:var(--amber-soft);color:var(--amber-ink);}
.badge.rose{background:var(--rose-soft);color:var(--rose-ink);}
.badge.blue{background:var(--blue-soft);color:var(--blue-ink);}
.badge.lav{background:var(--lav-soft);color:var(--lav);}
.mini-rank{width:25px;height:25px;border-radius:8px;background:var(--surface-2);display:grid;place-items:center;font-size:12px;font-weight:700;color:var(--muted);flex:none;}

.check{display:flex;align-items:center;gap:12px;padding:11px 0;border-top:1px solid var(--border);font-size:13.5px;}
.check:first-child{border-top:none;}
.check .ci{width:24px;height:24px;border-radius:8px;display:grid;place-items:center;flex:none;font-size:15px;}
.check .ci.ok{background:var(--green-soft);color:var(--green-ink);}
.check .ci.warn{background:var(--amber-soft);color:var(--amber-ink);}
.check .r{margin-left:auto;color:var(--muted);font-weight:600;font-size:12.5px;}

.fund{padding:15px 0;border-top:1px solid var(--border);}
.fund:first-child{border-top:none;}
.fund .track{height:9px;border-radius:6px;background:var(--surface-2);overflow:hidden;margin-top:10px;}
.fund .fill{height:100%;border-radius:6px;transition:width .8s var(--ease);}

table{width:100%;border-collapse:collapse;font-size:13.5px;}
thead th{text-align:left;color:var(--muted);font-weight:600;font-size:12px;padding:4px 16px 13px;border-bottom:1px solid var(--border);white-space:nowrap;}
tbody td{padding:14px 16px;border-bottom:1px solid var(--border);vertical-align:middle;}
tbody tr:last-child td{border-bottom:none;}
tbody tr{transition:background .15s;}
tbody tr:hover{background:var(--surface-2);}
tbody tr.rowlink{cursor:pointer;}
td.num,th.num{text-align:right;font-variant-numeric:tabular-nums;}
.ctp{display:flex;align-items:center;gap:11px;}
.ctp .av{width:31px;height:31px;border-radius:9px;background:var(--primary-soft);display:flex;align-items:center;justify-content:center;line-height:1;font-size:11.5px;font-weight:700;color:var(--primary-strong);flex:none;}
.searchbar{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid #e5edee;border-radius:13px;padding:11px 15px;margin-bottom:14px;box-shadow:0 4px 16px rgba(20,40,60,.05);}
.searchbar .ic{width:18px;height:18px;color:var(--muted);flex:none;}
.searchbar input{flex:1;min-width:0;border:none;outline:none;background:none;font:inherit;font-size:14.5px;color:var(--text);}
.searchbar input::placeholder{color:#9fb3b8;}
.searchbar .js-search-count{flex:none;white-space:nowrap;}

.alert{display:flex;gap:15px;align-items:center;background:var(--rose-soft);border:1px solid #f4dada;border-radius:var(--radius);padding:18px 20px;}
.alert .ico{width:44px;height:44px;border-radius:13px;background:var(--rose);color:#fff;display:grid;place-items:center;flex:none;font-size:24px;}
.alert b{color:var(--rose-ink);font-size:15px;}
.alert button{margin-left:auto;align-self:center;}
.btn-rose{background:var(--rose);color:#fff;border:none;height:40px;padding:0 18px;border-radius:12px;font-weight:600;font-size:13px;cursor:pointer;white-space:nowrap;transition:filter .18s,transform .18s;}
.btn-rose:hover{filter:brightness(.97);} .btn-rose:active{transform:translateY(1px);}

.recon-top{display:grid;grid-template-columns:1fr auto 1fr auto 1fr;gap:18px;align-items:center;}
.recon-top .b{text-align:center;}
.recon-top .b .lab{color:var(--muted);font-size:12px;}
.recon-top .b .v{font-size:25px;font-weight:760;margin-top:5px;font-variant-numeric:tabular-nums;}
.recon-top .op{font-size:22px;color:var(--faint);}

.soon-box{display:grid;place-items:center;height:62vh;text-align:center;color:var(--muted);}
.soon-box .ico{width:66px;height:66px;border-radius:20px;background:var(--surface);border:1px solid var(--border);display:grid;place-items:center;margin-bottom:18px;color:var(--primary);box-shadow:var(--shadow-soft);font-size:30px;}
.soon-box b{color:var(--text);font-size:18px;}

/* ===== forms / buttons (добавлено для реального приложения) ===== */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;height:40px;padding:0 18px;border-radius:12px;border:none;background:linear-gradient(140deg,var(--primary),#23a7cf);color:#fff;font-size:13.5px;font-weight:650;cursor:pointer;box-shadow:0 8px 18px rgba(43,171,155,.28);transition:filter .18s,transform .18s;}
.btn:hover{filter:brightness(1.03);} .btn:active{transform:translateY(1px);}
.btn.ghost{background:var(--surface);color:var(--text);border:1px solid var(--border-2);box-shadow:none;}
.btn.ghost:hover{background:var(--surface-2);}
.btn.green{background:linear-gradient(140deg,#41b78d,#2c9670);box-shadow:0 8px 18px rgba(65,183,141,.28);}
/* ДДС — форма внесения движения */
.dds-add>summary{cursor:pointer;list-style:none;}
.dds-add>summary::-webkit-details-marker{display:none;}
.dds-form{display:flex;flex-wrap:wrap;gap:14px;align-items:flex-end;margin-top:16px;}
.dds-form .field{margin-bottom:0;min-width:150px;}
.dds-form .dds-submit{justify-content:flex-end;min-width:auto;}
.field{display:flex;flex-direction:column;gap:7px;margin-bottom:16px;}
.field label{font-size:12.5px;font-weight:600;color:var(--muted);}
.field input,.field select{height:44px;border:1px solid var(--border-2);border-radius:13px;padding:0 14px;font-size:14px;color:var(--text);background:var(--surface);outline:none;transition:border .18s,box-shadow .18s;font-family:inherit;}
.field input:focus,.field select:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft);}
.field select{-webkit-appearance:none;appearance:none;padding-right:42px;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='8' viewBox='0 0 12 8' fill='none'%3E%3Cpath d='M1 1.5L6 6.5L11 1.5' stroke='%2322424a' stroke-width='1.6' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center;}

/* ===== Login ===== */
.login-wrap{height:100vh;display:grid;place-items:center;background:radial-gradient(900px 500px at 30% -10%,#e7f5f1,var(--bg) 60%);}
.login-card{width:380px;background:var(--surface);border:1px solid var(--border);border-radius:24px;box-shadow:var(--shadow-soft);padding:34px 30px;}
.login-card h1{font-size:21px;margin:0 0 4px;font-weight:740;}
.login-card p{margin:0 0 22px;color:var(--muted);font-size:13px;}
.login-card .hint{margin-top:16px;font-size:11.5px;color:var(--faint);text-align:center;line-height:1.7;}
.login-card .err{background:var(--rose-soft);color:var(--rose-ink);border-radius:12px;padding:10px 13px;font-size:12.5px;font-weight:600;margin-bottom:16px;}
.login-card .btn{height:44px;}            /* вровень с полем (44px) для симметрии */

.htmx-indicator{opacity:0;transition:opacity .2s;}
.htmx-request .htmx-indicator{opacity:1;}

/* ===== TV mode (единственная тёмная поверхность — для офисного ТВ) ===== */
body.tv-open{overflow:hidden;}
#tv{position:fixed;inset:0;z-index:50;background:radial-gradient(1300px 700px at 18% -15%,#10434f,#072028 62%);color:#eaf6f4;display:none;flex-direction:column;padding:32px 44px;}
body.tv-open #tv{display:flex;animation:fade .5s var(--ease);}
.tv-head{display:flex;align-items:center;gap:16px;margin-bottom:24px;}
.tv-head b{font-size:22px;color:#fff;font-weight:700;}
.tv-head .date{margin-left:auto;color:#84b3bf;font-size:16px;}
.tv-close{background:rgba(255,255,255,.08);border:1px solid #1c4451;color:#cfe9ef;height:44px;padding:0 20px;border-radius:13px;font-weight:600;cursor:pointer;font-size:14px;transition:background .18s;}
.tv-close:hover{background:rgba(255,255,255,.14);}
.tv-grid{display:grid;grid-template-columns:1.1fr 1.1fr 1fr;grid-template-rows:auto 1fr;gap:22px;flex:1;min-height:0;}
.tv-card{background:rgba(11,42,52,.55);border:1px solid #164049;border-radius:22px;padding:26px 28px;display:flex;flex-direction:column;}
.tv-card .lab{color:#84b3bf;font-size:15px;font-weight:500;letter-spacing:.3px;}
.tv-card .num{font-size:50px;font-weight:800;letter-spacing:-1px;margin-top:8px;line-height:1;font-variant-numeric:tabular-nums;color:#fff;}
.tv-card .num.mid{font-size:40px;}
.tv-d{display:inline-flex;align-items:center;gap:7px;font-size:18px;font-weight:700;margin-top:16px;}
.tv-d.up{color:#5fd6ab;}
.tv-status{grid-column:3;grid-row:1;background:linear-gradient(140deg,#2bb6a4,#1f8fb0);border:none;}
.tv-status .lab{color:rgba(255,255,255,.85);}
.tv-chart-card{grid-column:1 / 3;grid-row:2;}
.tv-side{grid-column:3;grid-row:2;}
#tvchart{flex:1;min-height:0;}
.tv-flow div{margin-top:0;} .tv-flow .lab2{font-size:14px;color:#84b3bf;} .tv-flow .v2{font-size:27px;font-weight:800;margin-top:5px;}

@media(max-width:1180px){.g4{grid-template-columns:repeat(2,1fr);}.g3{grid-template-columns:1fr;}}

/* ── админка (Настройки) ── */
a.card.hover{text-decoration:none;color:inherit;display:block;}
.admin-hub .big{font-size:30px;}
.admin-cta{margin-top:16px;display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:700;color:var(--primary);}
.admin-cta .ic{width:16px;height:16px;}
.dds-form .field.grow{flex:1 1 220px;}
.cp-types-line{display:flex;justify-content:space-between;align-items:center;gap:16px 24px;flex-wrap:wrap;}
tbody tr[data-href]{cursor:pointer;}
tbody tr[data-href]:hover{background:var(--surface-2);}
.types-pick{display:flex;flex-wrap:wrap;gap:9px 18px;padding:2px 0 2px;}
.types-pick label{display:inline-flex;align-items:center;gap:7px;font-size:13.5px;font-weight:500;color:var(--text);cursor:pointer;}
input[type=checkbox]{appearance:none;-webkit-appearance:none;box-sizing:border-box;width:18px;height:18px;min-width:18px;margin:0;padding:0;border:1.6px solid var(--border-2);border-radius:5px;background:var(--surface);cursor:pointer;flex:none;position:relative;vertical-align:middle;transition:background .15s,border-color .15s;}
input[type=checkbox]:checked{border-color:var(--primary);background-color:var(--primary);background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 16 16' fill='none' stroke='%23fff' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M3.5 8.5l3 3 6-7'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:center;background-size:80%;}
input[type=checkbox]:focus-visible{outline:2px solid var(--primary-soft);outline-offset:2px;}
.admin-hint{display:flex;gap:11px;align-items:flex-start;background:var(--blue-soft);border:1px solid #cfe3ee;border-radius:14px;padding:13px 16px;margin-bottom:16px;font-size:13px;color:var(--blue-ink);}
.admin-hint .ic{width:17px;height:17px;flex:none;margin-top:1px;}
.pill.sm{height:34px;padding:0 13px;font-size:12.5px;border-radius:11px;}
/* submit-кнопка формы — ровно по высоте полей (44px), не «косит» вниз */
.dds-form .dds-submit .pill{height:44px;}

/* ── инлайн-редактирование строк таблицы (.erow) ── */
.erow .v-edit{display:none;}
.erow.editing .v-view{display:none;}
.erow.editing input.v-edit,.erow.editing select.v-edit{display:inline-block;}
.erow.editing span.v-edit{display:inline-flex;align-items:center;gap:8px;}
.erow.editing td{vertical-align:middle;}
.erow input.v-edit:not([type=checkbox]),.erow select.v-edit{height:38px;width:100%;max-width:210px;border:1px solid var(--border-2);border-radius:10px;padding:0 10px;font-size:13px;font-family:inherit;color:var(--text);background:var(--surface);}
.erow .v-edit:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--primary-soft);outline:none;}
.erow-actions{justify-content:flex-end;}
.erow-types{flex-wrap:wrap;gap:7px 13px!important;max-width:340px;}
.erow-types label{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:500;white-space:nowrap;cursor:pointer;color:var(--text);}
.cp-badges{display:inline-flex;flex-wrap:wrap;gap:4px;vertical-align:middle;}
.pill.danger{background:var(--rose-soft);color:var(--rose-ink);border-color:#f1d5d5;box-shadow:none;}
.pill.danger:hover{background:#f7e1e1;}
.pill.danger .ic{color:var(--rose-ink);}
.erow.inactive>td{opacity:.6;}
.erow.inactive.editing>td{opacity:1;}

/* ── модалка подтверждения удаления ── */
.modal-overlay{position:fixed;inset:0;z-index:200;background:rgba(18,38,48,.42);display:flex;align-items:center;justify-content:center;padding:20px;}
.modal-overlay[hidden]{display:none;}
.modal{background:var(--surface);border-radius:20px;box-shadow:0 26px 70px rgba(20,40,60,.32);padding:28px;max-width:430px;width:100%;text-align:center;animation:modal-pop .16s var(--ease);}
@keyframes modal-pop{from{transform:scale(.94);opacity:0;}to{transform:scale(1);opacity:1;}}
.modal-ico{width:54px;height:54px;border-radius:16px;background:var(--rose-soft);color:var(--rose-ink);display:grid;place-items:center;margin:0 auto 14px;}
.modal-ico .ic{width:26px;height:26px;}
.modal h3{margin:0 0 6px;font-size:18px;}
.modal>p{margin:0 0 18px;}
.modal form input{width:100%;height:46px;border:1px solid var(--border-2);border-radius:13px;padding:0 14px;font-size:14px;font-family:inherit;color:var(--text);background:var(--surface);margin-bottom:16px;text-align:center;}
.modal form input:focus{border-color:var(--primary);box-shadow:0 0 0 4px var(--primary-soft);outline:none;}
.modal-actions{display:flex;gap:10px;}
.modal-actions .pill{flex:1;justify-content:center;height:44px;}

/* ── сворачиваемый сайдбар: рельса с иконками, раскрывается по наведению ── */
.sidebar{position:relative;z-index:40;justify-self:start;width:64px;overflow:hidden;white-space:nowrap;transition:width .18s var(--ease),box-shadow .18s;}
.sidebar:hover{width:252px;box-shadow:8px 0 36px rgba(20,40,60,.12);}
.nav{overflow-x:hidden;}
.nav a{gap:0;font-size:0;padding:10px 0;}
.nav a .ic{width:44px;flex:none;}            /* фикс-слот: иконка по центру рельсы (64−2·10), не двигается при раскрытии */
.sidebar:hover .nav a{gap:12px;font-size:13.5px;padding:10px 14px 10px 0;}
.nav a .soon,.nav a .dot{display:none;}
.sidebar:hover .nav a .soon{display:inline-block;}
.sidebar:hover .nav a .dot{display:block;}
.brand,.nav .group{opacity:0;transition:opacity .12s;}
.sidebar:hover .brand,.sidebar:hover .nav .group{opacity:1;}
.side-foot>div:not(.avatar),.side-foot a.logout{display:none;}
.sidebar:hover .side-foot>div:not(.avatar),.sidebar:hover .side-foot a.logout{display:block;}
