/* ===== ItalyVisa CRM — Swiss Design System ===== */
:root{
  --ink:#0a0a0a; --ink-soft:#3a3a3a; --rule:#1a1a1a; --rule-soft:rgba(10,10,10,.12);
  --bg:#ffffff; --bg-soft:#f5f5f3; --red:#e63946; --green:#2c8c5f; --yellow:#e6a23a;
  --blue:#3a7bd5; --purple:#8a5cf6; --muted:#7a7a78;
  --mono:'JetBrains Mono',monospace;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{font-family:'Space Grotesk',system-ui,sans-serif;background:var(--bg);color:var(--ink);font-size:15px;line-height:1.45;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
button{font-family:inherit}
input:focus,select:focus,textarea:focus,button:focus-visible{outline:2px solid var(--ink);outline-offset:1px}
.mono{font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-weight:500}
.muted{color:var(--muted)}
.tnum{font-feature-settings:"tnum"}
.dot{color:var(--red)}            /* красная точка-тире после заголовков */

/* ===== Layout ===== */
.layout{display:flex;min-height:100vh}
.main{flex:1;min-width:0;display:flex;flex-direction:column}
.content{padding:32px;flex:1}

/* ===== Sidebar ===== */
.sidebar{width:240px;flex-shrink:0;border-right:1.5px solid var(--ink);background:var(--bg);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}
.side-logo{padding:20px 24px;border-bottom:1.5px solid var(--ink);display:flex;align-items:center;gap:10px}
.side-logo .lg-name{font-weight:700;font-size:13px;letter-spacing:-.01em}
.side-logo .lg-sub{font-family:var(--mono);font-size:9px;color:var(--muted);letter-spacing:.15em;margin-top:1px}
.side-nav{flex:1;padding:12px 0;overflow-y:auto}
.nav-sec{padding:14px 24px 6px}
.nav-item{width:100%;background:transparent;color:var(--ink);border:none;border-top:1px solid var(--rule-soft);cursor:pointer;padding:14px 24px;display:grid;grid-template-columns:24px 1fr auto;gap:12px;align-items:baseline;text-align:left;transition:background .15s}
.nav-item:hover{background:var(--bg-soft)}
.nav-item.active{background:var(--ink);color:var(--bg)}
.nav-item .n{font-family:var(--mono);font-size:10px;opacity:.5;letter-spacing:.1em}
.nav-item.active .n{opacity:.7}
.nav-item .l{font-size:14px;letter-spacing:-.01em}
.nav-item .nb{font-family:var(--mono);font-size:10px;padding:2px 6px;background:var(--ink);color:var(--bg);font-weight:700}
.nav-item.active .nb{background:var(--red)}
.side-user{padding:16px;border-top:1.5px solid var(--ink);display:flex;align-items:center;gap:10px}
.avatar{width:36px;height:36px;background:var(--ink);color:var(--bg);display:grid;place-items:center;font-size:13px;font-weight:700;flex-shrink:0}
.side-user .su-name{font-size:13px;font-weight:600;line-height:1.2}
.side-user .su-role{font-size:10px;color:var(--muted);font-family:var(--mono);letter-spacing:.1em;text-transform:uppercase;margin-top:2px}
.side-user .su-out{margin-left:auto;width:30px;height:30px;border:1px solid var(--rule-soft);background:transparent;cursor:pointer;display:grid;place-items:center;color:var(--ink)}
.side-user .su-out:hover{background:var(--red);color:var(--bg);border-color:var(--red)}

/* ===== Topbar ===== */
.topbar{border-bottom:1.5px solid var(--ink);background:var(--bg);position:sticky;top:0;z-index:10}
.tb-inner{display:grid;grid-template-columns:1fr auto;gap:24px;padding:20px 32px;align-items:center}
.tb-head{display:flex;align-items:baseline;gap:14px;flex-wrap:wrap}
.tb-num{font-family:var(--mono);font-size:12px;color:var(--muted)}
.tb-title{font-size:32px;margin:0;font-weight:400;letter-spacing:-.03em;line-height:1}
.tb-sub{font-size:13px;color:var(--muted)}
.tb-actions{display:flex;gap:12px;align-items:center}
.burger{display:none}

/* ===== Buttons ===== */
.btn{display:inline-flex;align-items:center;gap:8px;padding:12px 20px;font-size:13px;font-weight:500;letter-spacing:.02em;border:1.5px solid var(--ink);background:var(--bg-soft);color:var(--ink);cursor:pointer;transition:.15s;border-radius:0}
.btn:hover{background:#ebebe8}
.btn-primary{background:var(--ink);color:var(--bg);border-color:var(--ink)}
.btn-primary:hover{background:#000}
.btn-ghost{background:transparent;border-color:var(--ink)}
.btn-ghost:hover{background:var(--bg-soft)}
.btn-danger{background:transparent;border-color:var(--red);color:var(--red)}
.btn-danger:hover{background:var(--red);color:var(--bg)}
.btn-sm{padding:8px 14px;font-size:12px}
.btn-block{width:100%;justify-content:center}
form.inline{display:inline}

/* ===== KPI strip ===== */
.kpi-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1px;background:var(--rule);border:1.5px solid var(--ink);margin-bottom:32px}
.kpi{padding:24px;background:var(--bg)}
.kpi-head{display:flex;justify-content:space-between;align-items:baseline}
.kpi-diff{font-family:var(--mono);font-size:10px;font-weight:700;letter-spacing:.05em}
.kpi-diff.pos{color:var(--green)} .kpi-diff.neg{color:var(--red)}
.kpi-num{font-size:46px;line-height:.9;letter-spacing:-.04em;margin-top:20px;font-feature-settings:"tnum"}
.kpi-num .u{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.1em;margin-left:6px}
.kpi-sub{font-size:11px;color:var(--muted);margin-top:14px}
.kpi.invert{background:var(--ink);color:var(--bg)}
.kpi.invert .kpi-sub{color:#aaa}

/* ===== Panels / sections ===== */
.grid-2{display:grid;grid-template-columns:2fr 1fr;gap:32px}
.grid-even{display:grid;grid-template-columns:1fr 1fr;gap:32px}
.panel{margin-bottom:32px}
.panel-head{display:flex;justify-content:space-between;align-items:baseline;padding-bottom:14px;border-bottom:1.5px solid var(--ink);margin-bottom:4px}
.panel-head .ttl{display:flex;align-items:baseline;gap:12px}
.panel-head h2{font-size:24px;margin:0;font-weight:400;letter-spacing:-.02em}
.panel-head h3{font-size:20px;margin:0;font-weight:400;letter-spacing:-.02em}
.card{border:1.5px solid var(--ink);padding:20px;margin-bottom:24px}

/* ===== Tables ===== */
.table{width:100%;border-collapse:collapse}
.table thead th{text-align:left;font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase;color:var(--muted);font-weight:500;padding:12px 12px;border-bottom:1px solid var(--rule-soft)}
.table thead th.r,.table td.r{text-align:right}
.table tbody td{padding:16px 12px;border-bottom:1px solid var(--rule-soft);vertical-align:middle}
.table tbody tr.click{cursor:pointer;transition:background .12s}
.table tbody tr.click:hover{background:var(--bg-soft)}
.table .id{font-family:var(--mono);font-size:12px;color:var(--muted)}
.table .arrow{color:var(--red);font-family:var(--mono)}
.bignum{font-size:22px;line-height:1;letter-spacing:-.02em;font-feature-settings:"tnum"}

.mini{width:100%;border-collapse:collapse}
.mini td{padding:14px 0;border-bottom:1px solid var(--rule-soft);vertical-align:top}
.mini tr:last-child td{border-bottom:none}

/* ===== Status badges ===== */
.badge{display:inline-flex;align-items:center;gap:6px;padding:4px 9px;font-family:var(--mono);font-size:9px;letter-spacing:.15em;font-weight:600;text-transform:uppercase;border:1px solid;border-radius:0}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:currentColor;flex-shrink:0}
.badge.role{color:var(--ink-soft);background:var(--bg-soft);border-color:var(--rule-soft)}
.badge.role::before{display:none}
.s-new{color:var(--yellow);background:#fef5e0;border-color:#e6a23a55}
.s-collecting{color:var(--blue);background:#e6f0fb;border-color:#3a7bd555}
.s-submitted{color:var(--ink);background:var(--bg-soft);border-color:var(--rule-soft)}
.s-review{color:var(--purple);background:#f0ebfb;border-color:#8a5cf655}
.s-approved{color:var(--green);background:#e0f2e9;border-color:#2c8c5f55}
.s-rejected{color:var(--red);background:#fde6e8;border-color:#e6394655}
.tag-urgent{font-family:var(--mono);font-size:9px;padding:2px 6px;background:var(--red);color:var(--bg);letter-spacing:.1em;font-weight:700;margin-left:8px}

/* ===== Funnel / bars ===== */
.funnel-row{padding:12px 0;border-bottom:1px solid var(--rule-soft)}
.funnel-row .fr-top{display:flex;justify-content:space-between;margin-bottom:6px;font-size:13px}
.funnel-row .fr-val{font-family:var(--mono);font-size:12px}
.bar{height:6px;background:var(--rule-soft)}
.bar>span{display:block;height:100%;background:var(--ink)}
.bar>span.red{background:var(--red)}

/* ===== Key-value ===== */
.kv{display:grid;grid-template-columns:auto 1fr;gap:10px 16px;margin:0;font-size:13px;align-items:baseline}
.kv dt{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted)}
.kv dd{margin:0;font-weight:500;text-align:right}
.notes-block{margin-top:14px;padding-top:14px;border-top:1px solid var(--rule-soft);white-space:pre-wrap;color:var(--ink-soft);font-size:13px;line-height:1.5}

/* ===== Forms ===== */
.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}
.form label,.search-box label{display:flex;flex-direction:column;gap:7px;font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);font-weight:500}
.form label.wide{grid-column:1/-1}
.form label.check{flex-direction:row;align-items:center;gap:8px;text-transform:none;letter-spacing:0;font-family:inherit;font-size:14px;color:var(--ink)}
input,select,textarea{font-family:inherit;font-size:15px;padding:11px 13px;border:1.5px solid var(--ink);background:var(--bg);color:var(--ink);width:100%;border-radius:0}
textarea{resize:vertical}
.check input{width:auto}
.form-actions{margin-top:24px;display:flex;gap:10px}

/* search + filters */
.toolbar{display:flex;gap:12px;margin-bottom:24px;flex-wrap:wrap}
.search-box{display:flex;align-items:center;gap:8px;padding:0 14px;border:1.5px solid var(--ink);flex:1;max-width:420px}
.search-box input{border:none;padding:11px 0}
.search-box input:focus{outline:none}
.filters{display:flex;border-top:1.5px solid var(--ink);border-bottom:1.5px solid var(--ink);margin-bottom:24px;overflow-x:auto}
.chip{padding:14px 18px;background:transparent;color:var(--ink);border:none;border-right:1px solid var(--rule-soft);cursor:pointer;font-family:var(--mono);font-size:11px;letter-spacing:.1em;text-transform:uppercase;white-space:nowrap}
.chip:hover{background:var(--bg-soft)}
.chip.active{background:var(--ink);color:var(--bg)}

.empty{text-align:center;color:var(--muted);padding:56px;border:1.5px dashed var(--rule-soft)}
.empty a{color:var(--red);font-weight:600}
.alert{background:#fde6e8;color:var(--red);padding:11px 14px;border:1px solid #e6394655;margin-bottom:16px;font-size:13px}
.back{font-family:var(--mono);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--muted);display:inline-block;margin-bottom:8px}
.back:hover{color:var(--red)}
.inline-form{display:flex;gap:8px;flex-wrap:wrap;align-items:center;margin-top:16px;padding-top:16px;border-top:1px solid var(--rule-soft)}
.inline-form input,.inline-form select{width:auto;flex:1;min-width:90px}

/* ===== Login ===== */
.login-body{background:var(--ink);min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;font-family:'Space Grotesk',sans-serif}
.login-card{background:var(--bg);padding:40px 36px;width:100%;max-width:380px;display:flex;flex-direction:column;gap:16px;border:1.5px solid var(--ink)}
.login-logo{display:flex;justify-content:center;margin-bottom:4px}
.login-card h1{font-size:26px;margin:0;font-weight:400;letter-spacing:-.02em;text-align:center}
.login-card .sub{text-align:center;color:var(--muted);margin:0 0 8px;font-family:var(--mono);font-size:10px;letter-spacing:.15em;text-transform:uppercase}

/* ===== Responsive ===== */
@media(max-width:980px){
  .kpi-grid{grid-template-columns:1fr 1fr}
  .grid-2,.grid-even{grid-template-columns:1fr}
}
@media(max-width:760px){
  .sidebar{position:fixed;left:0;top:0;z-index:100;transform:translateX(-100%);transition:transform .2s;box-shadow:4px 0 24px rgba(0,0,0,.2)}
  .sidebar.open{transform:translateX(0)}
  .burger{display:grid;place-items:center;width:40px;height:40px;border:1.5px solid var(--ink);background:var(--bg);cursor:pointer;font-size:18px}
  .tb-inner{grid-template-columns:auto 1fr;padding:14px 18px;gap:14px}
  .tb-title{font-size:24px}
  .tb-sub{display:none}
  .content{padding:18px}
  .form-grid{grid-template-columns:1fr}
  .table thead{display:none}
  .table tbody td{display:block;padding:4px 0;border:none}
  .table tbody tr.click{display:block;padding:14px 0;border-bottom:1px solid var(--rule-soft)}
}
@media(max-width:480px){ .kpi-grid{grid-template-columns:1fr} }
