/* =========================================================================
   ЕГАИС-коннектор — Design System (single source of truth)
   Чистый CSS, без зависимостей. Эти токены и компоненты — основа продакшн-стилей
   для Go server-rendered ЛК. Цвета берём только из переменных, не из хардкода.
   ========================================================================= */
:root{
  /* surfaces */
  --bg:#F5F6F8; --surface:#FFFFFF; --surface-soft:#FAFBFC;
  --border:#E8EAEF; --border-strong:#DADDE4;
  /* text */
  --ink:#0E1116; --text:#383F4A; --muted:#6B7280; --faint:#9CA3AF;
  /* brand + accents */
  --primary:#4F46E5; --primary-hover:#4338CA; --primary-tint:#EEF0FE; --primary-tint-2:#E2E5FC;
  --ring:rgba(79,70,229,.30);
  --success:#0E9F6E; --success-tint:#E6F6EF; --success-ink:#0A7D57;
  --warning:#B45309; --warning-tint:#FBF1E3; --warning-ink:#92400E;
  --danger:#DC2626;  --danger-tint:#FCECEC;  --danger-ink:#B91C1C;
  --info:#0369A1;    --info-tint:#E6F1F8;    --info-ink:#075985;
  /* elevation */
  --shadow-xs:0 1px 2px rgba(15,23,42,.05);
  --shadow-sm:0 1px 3px rgba(15,23,42,.06),0 1px 2px rgba(15,23,42,.04);
  --shadow-md:0 10px 30px -12px rgba(15,23,42,.18),0 2px 6px -2px rgba(15,23,42,.06);
  --shadow-lg:0 30px 60px -20px rgba(15,23,42,.25);
  /* radius */
  --r-sm:8px; --r-md:10px; --r-lg:14px; --r-xl:18px; --r-pill:999px;
  /* motion */
  --ease:cubic-bezier(.2,.6,.2,1); --dur:180ms;
}
*{box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility}
body{
  margin:0;background:var(--bg);color:var(--text);
  font-family:"Inter",system-ui,-apple-system,"Segoe UI",sans-serif;
  font-size:15px;line-height:1.55;letter-spacing:-0.006em;
}
h1,h2,h3,h4{font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI","Inter",sans-serif;color:var(--ink);letter-spacing:-0.02em;margin:0;line-height:1.2}
a{color:var(--primary);text-decoration:none}
.tnum{font-variant-numeric:tabular-nums}
@media (prefers-reduced-motion:reduce){*{transition:none!important;animation:none!important}}

/* ---------- doc layout (this guideline page chrome) ---------- */
.doc{max-width:1200px;margin:0 auto;padding:0 24px 120px}
.doc-top{position:sticky;top:0;z-index:50;background:rgba(245,246,248,.82);backdrop-filter:saturate(160%) blur(12px);border-bottom:1px solid var(--border);margin:0 -24px 0;padding:14px 24px;display:flex;align-items:center;gap:18px;flex-wrap:wrap}
.doc-top .brand{display:flex;align-items:center;gap:10px;font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI";font-weight:700;color:var(--ink);font-size:16px;letter-spacing:-.02em}
.doc-nav{display:flex;gap:4px;flex-wrap:wrap;margin-left:auto}
.doc-nav a{font-size:13px;font-weight:500;color:var(--muted);padding:6px 11px;border-radius:var(--r-pill);transition:all var(--dur) var(--ease)}
.doc-nav a:hover{color:var(--ink);background:var(--surface);box-shadow:var(--shadow-xs)}
.hero{padding:56px 0 12px}
.hero .eyebrow{font-size:13px;font-weight:600;color:var(--primary);text-transform:uppercase;letter-spacing:.08em}
.hero h1{font-size:42px;margin:10px 0 14px;max-width:18ch}
.hero p{font-size:17px;color:var(--muted);max-width:62ch;margin:0}
.sec{padding:56px 0 0}
.sec > .sec-head{margin-bottom:24px}
.sec-head .kicker{font-size:12px;font-weight:600;letter-spacing:.09em;text-transform:uppercase;color:var(--faint)}
.sec-head h2{font-size:28px;margin:6px 0 6px}
.sec-head p{margin:0;color:var(--muted);max-width:70ch}
.subhead{font-size:13px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--faint);margin:34px 0 14px}
.divider{height:1px;background:var(--border);margin:64px 0 0}

/* panel = generic white card used to showcase components */
.panel{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}
.panel.pad{padding:24px}
.grid{display:grid;gap:18px}
.cols-2{grid-template-columns:repeat(2,1fr)}
.cols-3{grid-template-columns:repeat(3,1fr)}
.cols-4{grid-template-columns:repeat(4,1fr)}
@media(max-width:860px){.cols-2,.cols-3,.cols-4{grid-template-columns:1fr}}

/* ---------- SVG icons ---------- */
.ic{width:20px;height:20px;flex:none;stroke:currentColor;stroke-width:1.75;fill:none;stroke-linecap:round;stroke-linejoin:round}
.ic-sm{width:16px;height:16px}
.ic-lg{width:24px;height:24px}

/* =========================================================================
   COMPONENTS
   ========================================================================= */
/* buttons */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;font:inherit;font-weight:600;font-size:14px;line-height:1;
  padding:0 16px;height:40px;border-radius:var(--r-md);border:1px solid transparent;cursor:pointer;white-space:nowrap;
  transition:background var(--dur) var(--ease),border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease);user-select:none}
.btn:active{transform:translateY(.5px)}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--ring)}
.btn-primary{background:var(--primary);color:#fff;box-shadow:var(--shadow-xs)}
.btn-primary:hover{background:var(--primary-hover)}
.btn-secondary{background:var(--surface);color:var(--ink);border-color:var(--border-strong);box-shadow:var(--shadow-xs)}
.btn-secondary:hover{background:var(--surface-soft);border-color:#CBD0D9}
.btn-ghost{background:transparent;color:var(--text)}
.btn-ghost:hover{background:var(--surface-soft)}
.btn-danger{background:var(--danger);color:#fff}
.btn-danger:hover{background:var(--danger-ink)}
.btn-danger-soft{background:var(--danger-tint);color:var(--danger-ink)}
.btn-danger-soft:hover{background:#F9DEDE}
.btn[disabled],.btn.is-disabled{opacity:.45;cursor:not-allowed;box-shadow:none}
.btn-sm{height:32px;padding:0 12px;font-size:13px;border-radius:var(--r-sm)}
.btn-lg{height:46px;padding:0 22px;font-size:15px}
.btn-icon{width:40px;padding:0}
.btn .ic{width:18px;height:18px}
.btn .spin{width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin .7s linear infinite}
.btn-secondary .spin{border-color:rgba(0,0,0,.15);border-top-color:var(--primary)}
@keyframes spin{to{transform:rotate(360deg)}}

/* inputs */
.field{display:flex;flex-direction:column;gap:7px}
.field > label{font-size:13px;font-weight:600;color:var(--ink)}
.field .req{color:var(--danger);margin-left:2px}
.input,.select,.textarea{font:inherit;font-size:14.5px;color:var(--ink);background:var(--surface);
  border:1px solid var(--border-strong);border-radius:var(--r-md);padding:0 13px;height:42px;width:100%;
  transition:border-color var(--dur) var(--ease),box-shadow var(--dur) var(--ease)}
.textarea{height:auto;padding:11px 13px;resize:vertical;min-height:90px}
.input::placeholder{color:var(--faint)}
.input:hover,.select:hover{border-color:#CBD0D9}
.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}
.input.has-error{border-color:var(--danger)}
.input.has-error:focus{box-shadow:0 0 0 3px rgba(220,38,38,.22)}
.field .help{font-size:12.5px;color:var(--muted)}
.field .err{font-size:12.5px;color:var(--danger-ink);font-weight:500;display:flex;align-items:center;gap:5px}
.input-group{position:relative;display:flex;align-items:center}
.input-group .ic{position:absolute;left:12px;color:var(--faint);pointer-events:none}
.input-group .input{padding-left:38px}

/* status pills / badges */
.badge{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;line-height:1;
  padding:5px 10px;border-radius:var(--r-pill);border:1px solid transparent}
.badge .dot{width:7px;height:7px;border-radius:50%;background:currentColor;flex:none}
.badge-success{background:var(--success-tint);color:var(--success-ink)}
.badge-warning{background:var(--warning-tint);color:var(--warning-ink)}
.badge-danger{background:var(--danger-tint);color:var(--danger-ink)}
.badge-info{background:var(--info-tint);color:var(--info-ink)}
.badge-neutral{background:#EFF1F4;color:#4B5563}
.badge.solid-success{background:var(--success);color:#fff}
.badge .dot.live{box-shadow:0 0 0 0 currentColor;animation:pulse 1.8s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(14,159,110,.5)}70%{box-shadow:0 0 0 6px rgba(14,159,110,0)}100%{box-shadow:0 0 0 0 rgba(14,159,110,0)}}

/* alert / banner */
.alert{display:flex;gap:12px;padding:14px 16px;border-radius:var(--r-md);border:1px solid;font-size:14px}
.alert .ic{margin-top:1px}
.alert .a-body{flex:1}
.alert .a-title{font-weight:600;color:var(--ink);margin-bottom:2px}
.alert-info{background:var(--info-tint);border-color:#CBE3F1;color:var(--info-ink)}
.alert-success{background:var(--success-tint);border-color:#BFE7D5;color:var(--success-ink)}
.alert-warning{background:var(--warning-tint);border-color:#EBD7B0;color:var(--warning-ink)}
.alert-danger{background:var(--danger-tint);border-color:#F3CFCF;color:var(--danger-ink)}

/* toast */
.toast{display:flex;gap:12px;align-items:flex-start;background:var(--ink);color:#fff;border-radius:var(--r-md);
  padding:13px 14px;box-shadow:var(--shadow-lg);max-width:380px;font-size:14px}
.toast .ic{margin-top:1px}
.toast .t-title{font-weight:600;margin-bottom:1px}
.toast .t-msg{color:rgba(255,255,255,.72)}
.toast .t-close{margin-left:6px;color:rgba(255,255,255,.55);cursor:pointer}
.toast.ok .ic{color:#34D399}.toast.err .ic{color:#F87171}.toast.warn .ic{color:#FBBF24}

/* table */
.table-wrap{border:1px solid var(--border);border-radius:var(--r-lg);overflow:hidden;background:var(--surface)}
table.tbl{width:100%;border-collapse:collapse;font-size:14px}
.tbl thead th{font-size:12px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--faint);
  text-align:left;padding:12px 16px;background:var(--surface-soft);border-bottom:1px solid var(--border);white-space:nowrap}
.tbl thead th.num,.tbl td.num{text-align:right}
.tbl tbody td{padding:14px 16px;border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}
.tbl tbody tr:last-child td{border-bottom:none}
.tbl tbody tr{transition:background var(--dur) var(--ease)}
.tbl tbody tr:hover{background:var(--surface-soft)}
.tbl .prim{color:var(--ink);font-weight:600}
.tbl .sub{color:var(--muted);font-size:12.5px}
.tbl td.num{font-variant-numeric:tabular-nums;font-weight:600;color:var(--ink)}
.th-sort{display:inline-flex;align-items:center;gap:5px;cursor:pointer}
.th-sort .ic{width:13px;height:13px;color:var(--primary)}

/* cards / stat */
.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);padding:18px 20px;box-shadow:var(--shadow-xs)}
.stat .s-label{font-size:13px;color:var(--muted);display:flex;align-items:center;gap:8px}
.stat .s-label .ic{width:16px;height:16px;color:var(--faint)}
.stat .s-value{font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI";font-weight:700;font-size:26px;color:var(--ink);margin-top:10px;letter-spacing:-.02em}
.stat .s-foot{font-size:12.5px;color:var(--muted);margin-top:4px}

/* empty state */
.empty{text-align:center;padding:54px 24px}
.empty .e-ic{width:54px;height:54px;border-radius:var(--r-lg);background:var(--primary-tint);color:var(--primary);
  display:grid;place-items:center;margin:0 auto 16px}
.empty .e-ic .ic{width:26px;height:26px}
.empty h3{font-size:18px;margin-bottom:6px}
.empty p{color:var(--muted);max-width:42ch;margin:0 auto 18px}

/* skeleton */
.sk{background:linear-gradient(90deg,#EDEFF2 25%,#F4F5F7 37%,#EDEFF2 63%);background-size:400% 100%;
  animation:shimmer 1.4s ease infinite;border-radius:6px;height:14px}
@keyframes shimmer{0%{background-position:100% 0}100%{background-position:-100% 0}}

/* swatches & type specimens (guideline only) */
.swatch{border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;background:var(--surface)}
.swatch .chip{height:64px}
.swatch .meta{padding:9px 11px;font-size:12px}
.swatch .meta b{display:block;color:var(--ink);font-size:13px;font-weight:600}
.swatch .meta span{color:var(--faint);font-variant-numeric:tabular-nums}
.spec-row{display:flex;align-items:baseline;gap:16px;padding:12px 0;border-bottom:1px dashed var(--border)}
.spec-row .tag{font-size:11px;color:var(--faint);width:120px;flex:none;font-variant-numeric:tabular-nums}
.token-row{display:flex;align-items:center;gap:14px;padding:11px 0;border-bottom:1px dashed var(--border);font-size:13px}
.token-row code{font-family:ui-monospace,Menlo,Consolas,monospace;font-size:12.5px;background:#F1F2F5;padding:2px 7px;border-radius:6px;color:var(--ink)}
.shadow-demo{height:84px;border-radius:var(--r-lg);background:#fff;display:grid;place-items:center;font-size:12px;color:var(--muted)}

/* =========================================================================
   APP SHELL (real ЛК chrome) — used inside screen mockups
   ========================================================================= */
.mock{margin:22px 0 0;border-radius:16px;overflow:hidden;border:1px solid var(--border-strong);box-shadow:var(--shadow-md);background:var(--surface)}
.mock-bar{display:flex;align-items:center;gap:8px;padding:11px 14px;background:#EEF0F3;border-bottom:1px solid var(--border-strong)}
.mock-bar .dots{display:flex;gap:6px}
.mock-bar .dots i{width:11px;height:11px;border-radius:50%;background:#CFD4DC}
.mock-url{margin-left:8px;flex:1;max-width:420px;background:#fff;border:1px solid var(--border);border-radius:var(--r-pill);
  font-size:12px;color:var(--muted);padding:5px 12px;display:flex;align-items:center;gap:7px}
.mock-url .ic{width:13px;height:13px;color:var(--success)}
.mock-cap{font-size:12px;color:var(--faint);margin-left:auto;font-weight:500}
.app{display:grid;grid-template-columns:248px 1fr;min-height:560px;background:var(--bg)}
@media(max-width:860px){.app{grid-template-columns:1fr}.sidebar{display:none}}

.sidebar{background:var(--surface);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:16px 14px}
.s-brand{display:flex;align-items:center;gap:10px;padding:6px 8px 16px}
.s-logo{width:34px;height:34px;border-radius:10px;background:linear-gradient(135deg,#5B54F0,#4338CA);display:grid;place-items:center;color:#fff;box-shadow:var(--shadow-xs)}
.s-logo .ic{width:19px;height:19px;stroke-width:2}
.s-brand .nm{font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI";font-weight:700;color:var(--ink);font-size:15.5px;letter-spacing:-.02em;line-height:1.1}
.s-brand .nm small{display:block;font-family:"Inter";font-weight:500;font-size:11px;color:var(--faint);letter-spacing:.02em}
.s-group{font-size:11px;font-weight:600;letter-spacing:.07em;text-transform:uppercase;color:var(--faint);padding:14px 10px 6px}
.nav-i{display:flex;align-items:center;gap:11px;padding:9px 11px;border-radius:var(--r-md);font-size:14px;font-weight:500;color:var(--text);cursor:pointer;transition:all var(--dur) var(--ease);margin-bottom:2px}
.nav-i .ic{width:19px;height:19px;color:var(--faint)}
.nav-i:hover{background:var(--surface-soft);color:var(--ink)}
.nav-i.active{background:var(--primary-tint);color:var(--primary-hover);font-weight:600}
.nav-i.active .ic{color:var(--primary)}
.nav-i .count{margin-left:auto;font-size:11.5px;font-weight:600;color:var(--muted);background:#EFF1F4;padding:1px 7px;border-radius:var(--r-pill)}
.s-foot{margin-top:auto;border-top:1px solid var(--border);padding-top:12px}
.agent-chip{display:flex;align-items:center;gap:10px;padding:9px 10px;border-radius:var(--r-md);background:var(--surface-soft);border:1px solid var(--border)}
.agent-chip .ava{width:30px;height:30px;border-radius:8px;background:var(--primary-tint);color:var(--primary);display:grid;place-items:center;flex:none}
.agent-chip .ava .ic{width:16px;height:16px}
.agent-chip .who{font-size:12.5px;line-height:1.3;overflow:hidden}
.agent-chip .who b{display:block;color:var(--ink);font-weight:600;white-space:nowrap;text-overflow:ellipsis;overflow:hidden;max-width:120px}
.agent-chip .who span{color:var(--muted)}

.main{display:flex;flex-direction:column;min-width:0}
.topbar{display:flex;align-items:center;gap:14px;padding:16px 26px;border-bottom:1px solid var(--border);background:rgba(255,255,255,.7);backdrop-filter:blur(8px)}
.topbar h1{font-size:20px}
.topbar .crumb{font-size:12.5px;color:var(--faint);margin-bottom:3px}
.topbar .actions{margin-left:auto;display:flex;align-items:center;gap:10px}
.content{padding:26px;overflow:auto}
.page-intro{color:var(--muted);font-size:14px;margin:-4px 0 22px;max-width:74ch}

/* auth screen */
.auth{min-height:560px;display:grid;grid-template-columns:1.05fr .95fr}
@media(max-width:860px){.auth{grid-template-columns:1fr}.auth .auth-aside{display:none}}
.auth-aside{background:linear-gradient(155deg,#171A5C 0%,#3730A3 52%,#4F46E5 100%);color:#fff;padding:44px;display:flex;flex-direction:column;position:relative;overflow:hidden}
.auth-aside::after{content:"";position:absolute;inset:auto -80px -120px auto;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.18),transparent 60%)}
.auth-aside .s-logo{background:rgba(255,255,255,.14)}
.auth-aside .nm{color:#fff}
.auth-aside h2{color:#fff;font-size:30px;margin:auto 0 14px;max-width:16ch;line-height:1.18}
.auth-aside p{color:rgba(255,255,255,.78);max-width:34ch;font-size:14.5px}
.auth-aside .feat{display:flex;gap:11px;align-items:center;margin-top:14px;font-size:13.5px;color:rgba(255,255,255,.9)}
.auth-aside .feat .ic{width:18px;height:18px;color:#A5B4FC}
.auth-main{background:var(--surface);display:grid;place-items:center;padding:40px}
.auth-card{width:100%;max-width:360px}
.auth-card h3{font-size:24px;margin-bottom:6px}
.auth-card .sub{color:var(--muted);margin-bottom:26px;font-size:14px}
.auth-card .field{margin-bottom:16px}
.auth-card .row-between{display:flex;justify-content:space-between;align-items:center;font-size:13px}

/* one-time code display */
.code-display{display:flex;gap:10px;justify-content:center;margin:6px 0}
.code-display .c{width:46px;height:58px;border:1px solid var(--border-strong);border-radius:var(--r-md);background:var(--surface-soft);
  display:grid;place-items:center;font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI";font-weight:700;font-size:26px;color:var(--ink);font-variant-numeric:tabular-nums}
.code-display .c.on{border-color:var(--primary);background:var(--primary-tint);color:var(--primary-hover)}

/* checklist (binding) */
.checklist{display:flex;flex-direction:column;gap:2px}
.check-i{display:flex;align-items:center;gap:13px;padding:14px 4px;border-bottom:1px solid var(--border)}
.check-i:last-child{border-bottom:none}
.check-i .ci{width:26px;height:26px;border-radius:50%;display:grid;place-items:center;flex:none}
.check-i.ok .ci{background:var(--success-tint);color:var(--success-ink)}
.check-i.bad .ci{background:var(--danger-tint);color:var(--danger-ink)}
.check-i.wait .ci{background:#EFF1F4;color:var(--muted)}
.check-i .ci .ic{width:15px;height:15px}
.check-i .ct{flex:1}
.check-i .ct b{display:block;color:var(--ink);font-weight:600;font-size:14px}
.check-i .ct span{font-size:13px;color:var(--muted)}
.check-i.bad .ct span{color:var(--danger-ink)}

/* steps */
.steps{display:flex;gap:0;margin-bottom:6px}
.step{flex:1;text-align:center;position:relative;font-size:12.5px;color:var(--muted)}
.step .n{width:28px;height:28px;border-radius:50%;background:var(--surface);border:1px solid var(--border-strong);display:grid;place-items:center;margin:0 auto 7px;font-weight:600;font-size:13px;color:var(--muted);position:relative;z-index:1}
.step.done .n{background:var(--success);border-color:var(--success);color:#fff}
.step.active .n{background:var(--primary);border-color:var(--primary);color:#fff;box-shadow:0 0 0 4px var(--primary-tint)}
.step.active b{color:var(--ink)}
.step::before{content:"";position:absolute;top:14px;left:-50%;width:100%;height:2px;background:var(--border)}
.step:first-child::before{display:none}
.step.done::before,.step.active::before{background:var(--success)}

/* modal mock */
.modal-scrim{background:rgba(14,17,22,.5);border-radius:14px;padding:40px;display:grid;place-items:center;backdrop-filter:blur(2px)}
.modal{width:100%;max-width:440px;background:var(--surface);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);overflow:hidden}
.modal .m-head{padding:22px 24px 0;display:flex;gap:14px}
.modal .m-ic{width:42px;height:42px;border-radius:50%;display:grid;place-items:center;flex:none}
.modal .m-ic.danger{background:var(--danger-tint);color:var(--danger)}
.modal h3{font-size:18px}
.modal .m-body{padding:8px 24px 0 80px;color:var(--muted);font-size:14px}
.modal .m-foot{padding:22px 24px;display:flex;gap:10px;justify-content:flex-end}

/* agent desktop window */
.win{width:100%;max-width:460px;margin:0 auto;border-radius:12px;overflow:hidden;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);background:var(--surface)}
.win-bar{background:#F2F3F6;border-bottom:1px solid var(--border-strong);padding:9px 13px;display:flex;align-items:center;gap:9px;font-size:12.5px;color:var(--muted)}
.win-bar .ctrl{margin-left:auto;display:flex;gap:8px;color:var(--faint)}
.win-bar .ctrl .ic{width:14px;height:14px}
.win-body{padding:22px}
.win-hero{display:flex;align-items:center;gap:13px;margin-bottom:18px}
.win-hero .wl{width:44px;height:44px;border-radius:11px;background:linear-gradient(135deg,#5B54F0,#4338CA);display:grid;place-items:center;color:#fff}
.win-hero .wt b{display:block;font-family:"Inter Tight",system-ui,-apple-system,"Segoe UI";font-weight:700;color:var(--ink);font-size:16px}
.win-hero .wt span{font-size:12.5px;color:var(--muted)}
.win-status{display:flex;flex-direction:column;gap:1px;border:1px solid var(--border);border-radius:var(--r-md);overflow:hidden;margin-bottom:18px}
.win-status .wr{display:flex;align-items:center;gap:11px;padding:12px 14px;background:var(--surface);border-bottom:1px solid var(--border);font-size:13.5px}
.win-status .wr:last-child{border-bottom:none}
.win-status .wr .ic{width:17px;height:17px;color:var(--faint)}
.win-status .wr .lab{color:var(--text)}
.win-status .wr .val{margin-left:auto;font-weight:600;color:var(--ink);font-variant-numeric:tabular-nums}

/* installer */
.installer{width:100%;max-width:520px;margin:0 auto;border-radius:12px;overflow:hidden;border:1px solid var(--border-strong);box-shadow:var(--shadow-lg)}
.inst-head{background:linear-gradient(120deg,#1E1B4B,#3730A3);color:#fff;padding:26px 28px}
.inst-head h3{color:#fff;font-size:20px}
.inst-head p{color:rgba(255,255,255,.75);font-size:13.5px;margin-top:4px}
.inst-body{background:var(--surface);padding:26px 28px}
.inst-body .pbar{height:8px;border-radius:var(--r-pill);background:#EAECF0;overflow:hidden;margin:8px 0 6px}
.inst-body .pbar i{display:block;height:100%;width:68%;background:var(--primary);border-radius:var(--r-pill)}
.inst-foot{padding:18px 28px;background:var(--surface-soft);border-top:1px solid var(--border);display:flex;gap:10px;justify-content:flex-end}

/* misc utility */
.toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.toolbar .grow{flex:1}
.muted{color:var(--muted)}
.note{font-size:13px;color:var(--muted);background:var(--surface-soft);border:1px solid var(--border);border-left:3px solid var(--primary);border-radius:var(--r-sm);padding:11px 14px}
.kbd{font-family:ui-monospace,monospace;font-size:12px;background:#fff;border:1px solid var(--border-strong);border-bottom-width:2px;border-radius:6px;padding:2px 7px;color:var(--ink)}
.pagination{display:flex;align-items:center;gap:4px}
.pagination .pg{min-width:34px;height:34px;display:grid;place-items:center;border-radius:var(--r-sm);font-size:13.5px;font-weight:500;color:var(--text);cursor:pointer;border:1px solid transparent}
.pagination .pg:hover{background:var(--surface-soft)}
.pagination .pg.active{background:var(--primary);color:#fff}
.legend{font-size:12px;color:var(--faint);margin-top:8px}
