/* ============================================================================
   Project Oracle — дизайн-система служебной панели (Cybersupremacy).
   Токены и компоненты перенесены из дизайн-прототипа claude.ai/design
   (Project Oracle.html + js/*.jsx) в обычный CSS под Thymeleaf-шаблоны.
   ========================================================================== */

@font-face {
    font-family: 'Ubuntu';
    src: url('/fonts/Ubuntu-Regular.ttf') format('truetype');
    font-weight: 400;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Ubuntu';
    src: url('/fonts/Ubuntu-Italic.ttf') format('truetype');
    font-weight: 400;
    font-style: italic;
    font-display: swap;
}
@font-face {
    font-family: 'Ubuntu';
    src: url('/fonts/Ubuntu-Medium.ttf') format('truetype');
    /* 500–600: у Ubuntu нет 600 (semibold) — Medium закрывает оба, чтобы браузер не «жирнил» синтетикой */
    font-weight: 500 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Ubuntu';
    src: url('/fonts/Ubuntu-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Ubuntu Mono';
    src: url('/fonts/UbuntuMono-Regular.ttf') format('truetype');
    font-weight: 400 600;
    font-style: normal;
    font-display: swap;
}
@font-face {
    font-family: 'Ubuntu Mono';
    src: url('/fonts/UbuntuMono-Bold.ttf') format('truetype');
    font-weight: 700;
    font-style: normal;
    font-display: swap;
}

:root {
    --cs-ink-900: #080A0D; --cs-ink-800: #11141A; --cs-ink-700: #1B1F27; --cs-ink-600: #272B35;
    --cs-ink-500: #3A3F4B; --cs-ink-400: #53586A; --cs-ink-300: #6B6C7A; --cs-ink-200: #A5A7B3;
    --cs-ink-100: #D2D4DB; --cs-ink-50: #E7E8EC; --cs-ink-25: #F3F3F5; --cs-white: #FFFFFF;
    --cs-teal-50: #E4FBF4; --cs-teal-100: #BFF4E3; --cs-teal-200: #7FE8C8; --cs-teal-300: #3FDBAC;
    --cs-teal-400: #11D4AA; --cs-teal-500: #0FBE99; --cs-teal-600: #0C9B7C; --cs-teal-700: #0A7860;
    --cs-teal-800: #075A48; --cs-teal-900: #04332A;
    --cs-orange-50: #FFEEE4; --cs-orange-100: #FFD6BF; --cs-orange-200: #FFB189; --cs-orange-300: #FE9461;
    --cs-orange-400: #FD7A40; --cs-orange-500: #E66629; --cs-orange-600: #BF5220; --cs-orange-700: #913D17;
    --cs-orange-800: #63290E; --cs-orange-900: #3A1808;

    --bg-subtle: var(--cs-ink-25); --bg-muted: var(--cs-ink-50);
    --surface: var(--cs-white); --border: var(--cs-ink-50); --border-strong: var(--cs-ink-100);
    --fg-1: var(--cs-ink-900); --fg-2: var(--cs-ink-400); --fg-3: var(--cs-ink-300);
    --accent: var(--cs-teal-400); --accent-hover: var(--cs-teal-500); --accent-fg: var(--cs-ink-900);
    --warn: var(--cs-orange-400); --warn-hover: var(--cs-orange-500);
    --danger: #E5484D; --info: #4A8CFF; --info-deep: #2C66D6;

    --font-sans: 'Ubuntu', ui-sans-serif, system-ui, -apple-system, 'Segoe UI', Roboto, sans-serif;
    --font-mono: 'Ubuntu Mono', ui-monospace, 'JetBrains Mono', Menlo, Consolas, monospace;

    --r-xs: 4px; --r-sm: 6px; --r-md: 10px; --r-lg: 14px; --r-xl: 20px; --r-pill: 999px;
    --shadow-sm: 0 1px 2px rgba(8,10,13,0.06), 0 1px 3px rgba(8,10,13,0.04);
    --shadow-md: 0 4px 12px rgba(8,10,13,0.06), 0 2px 4px rgba(8,10,13,0.04);
    --shadow-lg: 0 12px 28px rgba(8,10,13,0.08), 0 4px 10px rgba(8,10,13,0.04);
    --ease-standard: cubic-bezier(0.2, 0.6, 0.2, 1);
    --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
    --dur-fast: 120ms; --dur-base: 200ms; --dur-slow: 360ms;
}

* { box-sizing: border-box; }
html, body {
    margin: 0; min-height: 100vh;
    background: var(--cs-ink-25);
    font-family: var(--font-sans);
    color: var(--fg-1);
    font-size: 14px;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
}
button, input, select, textarea { font-family: inherit; }
.mono { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-feature-settings: "tnum", "zero"; }
::-webkit-scrollbar { width: 10px; height: 10px; }
::-webkit-scrollbar-thumb { background: var(--cs-ink-100); border-radius: 999px; border: 2px solid var(--cs-ink-25); }
::-webkit-scrollbar-thumb:hover { background: var(--cs-ink-200); }
input::placeholder, textarea::placeholder { color: var(--cs-ink-200); }

@keyframes oFadeUp { from { transform: translateY(7px); } to { transform: none; } }
@keyframes oPulse { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
@keyframes oSpin { to { transform: rotate(360deg); } }
.o-fade { animation: oFadeUp var(--dur-slow) var(--ease-out); }

/* ---- Иконки (SVG-спрайт /assets/icons.svg) ---- */
.ic { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; flex-shrink: 0; vertical-align: middle; display: inline-block; }
.ic-14 { width: 14px; height: 14px; } .ic-15 { width: 15px; height: 15px; } .ic-16 { width: 16px; height: 16px; }
.ic-12 { width: 12px; height: 12px; } .ic-20 { width: 20px; height: 20px; } .ic-28 { width: 28px; height: 28px; }
.ic-bold { stroke-width: 3; }
.spin { animation: oSpin 0.9s linear infinite; }

/* ============================== Оболочка ============================== */
.shell { display: flex; min-height: 100vh; }

/* ---- Сайдбар ---- */
.sidebar { width: 248px; background: var(--cs-ink-900); color: #fff; display: flex; flex-direction: column; position: sticky; top: 0; height: 100vh; flex-shrink: 0; }
.sb-brand { display: flex; align-items: center; gap: 10px; padding: 20px 20px 16px; color: #fff; text-decoration: none; }
.sb-brand img { display: block; width: 28px; height: 28px; }
.sb-brand span { font-size: 16px; font-weight: 700; letter-spacing: -0.01em; }
.sb-line { margin: 0 14px 14px; background: var(--cs-ink-800); border-radius: var(--r-md); padding: 10px 12px; display: flex; align-items: center; gap: 10px; }
.sb-line-badge { width: 30px; height: 30px; border-radius: 7px; background: var(--cs-teal-400); color: var(--cs-ink-900); display: grid; place-items: center; font-weight: 700; font-size: 12px; flex-shrink: 0; }
.sb-line-info { flex: 1; min-width: 0; }
.sb-line-name { font-size: 12.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-line-sub { font-family: var(--font-mono); font-size: 10.5px; color: var(--cs-ink-200); }
.sb-nav { flex: 1; overflow: auto; padding: 0 12px; }
.sb-group { font-size: 10px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; color: var(--cs-ink-300); padding: 12px 10px 6px; }
.sb-item { display: flex; align-items: center; gap: 11px; padding: 9px 10px; border-radius: var(--r-sm); width: 100%; text-align: left; cursor: pointer; font-size: 13.5px; font-weight: 500; background: transparent; color: var(--cs-ink-200); text-decoration: none; transition: all var(--dur-fast); margin-bottom: 1px; }
.sb-item .ic { width: 17px; height: 17px; color: var(--cs-ink-300); }
.sb-item:hover { background: var(--cs-ink-800); color: #fff; }
.sb-item.active { background: var(--cs-ink-700); color: #fff; font-weight: 600; }
.sb-item.active .ic { color: var(--cs-teal-400); }
.sb-user { padding: 14px; border-top: 1px solid var(--cs-ink-700); display: flex; align-items: center; gap: 10px; }
.sb-avatar { width: 32px; height: 32px; border-radius: 50%; background: var(--cs-ink-600); color: #fff; display: grid; place-items: center; font-size: 12px; font-weight: 600; text-transform: uppercase; flex-shrink: 0; }
.sb-user-info { flex: 1; min-width: 0; }
.sb-user-name { font-size: 12.5px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.sb-user-role { font-size: 11px; color: var(--cs-ink-300); }
.sb-logout { background: none; border: 0; cursor: pointer; color: var(--cs-ink-300); display: grid; place-items: center; padding: 4px; }
.sb-logout:hover { color: #fff; }

/* ---- Контент + топбар ---- */
.main { flex: 1; min-width: 0; display: flex; flex-direction: column; }
.topbar { display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 14px 28px; background: rgba(255,255,255,0.85); backdrop-filter: blur(12px); border-bottom: 1px solid var(--border); position: sticky; top: 0; z-index: 20; }
.tb-crumb { font-family: var(--font-mono); font-size: 11px; color: var(--fg-2); letter-spacing: 0.04em; }
.tb-title { font-size: 20px; font-weight: 600; letter-spacing: -0.01em; margin-top: 2px; white-space: nowrap; }
.tb-right { display: flex; align-items: center; gap: 14px; flex-shrink: 0; }
.tb-live { display: flex; align-items: center; gap: 8px; background: var(--cs-teal-50); padding: 7px 12px; border-radius: var(--r-md); font-size: 12.5px; color: var(--cs-teal-700); font-weight: 600; white-space: nowrap; }
.tb-live.down { background: var(--cs-orange-50); color: var(--cs-orange-700); }
.tb-live.unknown { background: var(--cs-ink-50); color: var(--fg-2); }
.page { padding: 28px; flex: 1; display: flex; flex-direction: column; gap: 18px; align-items: stretch; }

/* ---- Глобальный поиск ---- */
.gsearch { position: relative; width: 320px; }
.gsearch-drop { position: absolute; top: calc(100% + 6px); left: 0; right: 0; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-md); box-shadow: var(--shadow-lg); z-index: 30; overflow: hidden; }
.gsearch-row { display: flex; align-items: center; gap: 10px; width: 100%; padding: 10px 14px; border: 0; background: none; cursor: pointer; text-align: left; border-bottom: 1px solid var(--border); text-decoration: none; color: var(--fg-1); }
.gsearch-row:hover { background: var(--cs-ink-25); }
.gsearch-row .gs-name { font-size: 13px; font-weight: 600; }
.gsearch-row .gs-id { font-family: var(--font-mono); font-size: 10.5px; color: var(--fg-2); }
.gsearch-empty { padding: 16px; font-size: 13px; color: var(--fg-3); text-align: center; }

/* ============================== Компоненты ============================== */

/* ---- Карточка ---- */
.card { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 24px; box-shadow: var(--shadow-sm); }
.card.p0 { padding: 0; overflow: hidden; }
.card.p16 { padding: 16px; }
.card.p18 { padding: 18px; }
.card.p22 { padding: 22px; }
.card-head { padding: 18px 22px; border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 14px; flex-wrap: wrap; }
.card.hoverable { transition: all var(--dur-base) var(--ease-standard); }
.card.hoverable:hover { box-shadow: var(--shadow-md); transform: translateY(-1px); }
.card.tint-teal { background: var(--cs-teal-50); border-color: var(--cs-teal-200); }
.card.tint-orange { background: var(--cs-orange-50); border-color: var(--cs-orange-200); }

/* ---- Eyebrow / заголовки секций ---- */
.eyebrow { font-size: 11px; letter-spacing: 0.08em; text-transform: uppercase; font-weight: 600; color: var(--fg-2); display: inline-flex; align-items: center; gap: 7px; }
.eyebrow .edot { width: 6px; height: 6px; border-radius: 50%; background: var(--cs-teal-500); flex-shrink: 0; }
.eyebrow .edot.orange { background: var(--cs-orange-500); }
.eyebrow .edot.red { background: var(--danger); }
.eyebrow .edot.slate { background: var(--cs-ink-300); }
.sec-head .eyebrow { margin-bottom: 8px; }
.sec-title-row { display: flex; align-items: baseline; gap: 10px; flex-wrap: wrap; }
.sec-title { margin: 0; font-size: 19px; font-weight: 600; letter-spacing: -0.01em; color: var(--fg-1); }
.sec-sub { font-size: 13px; color: var(--fg-2); font-weight: 400; }

/* ---- Бейджи ---- */
.badge { font-size: 11px; font-weight: 600; padding: 3px 8px; border-radius: var(--r-pill); display: inline-flex; align-items: center; gap: 5px; white-space: nowrap; line-height: 1.4; background: var(--cs-ink-50); color: var(--cs-ink-500); border: none; }
.badge.teal { background: var(--cs-teal-50); color: var(--cs-teal-700); }
.badge.orange { background: var(--cs-orange-50); color: var(--cs-orange-700); }
.badge.ink { background: var(--cs-ink-900); color: #fff; }
.badge.red { background: #FDECEC; color: var(--danger); }
.badge.blue { background: #EAF1FF; color: var(--info-deep); }
.badge.ghost { background: transparent; color: var(--fg-2); border: 1px solid var(--border-strong); }

/* ---- Кнопки ---- */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: 7px; padding: 9px 16px; font-size: 13.5px; font-weight: 600; border-radius: var(--r-md); cursor: pointer; transition: all var(--dur-fast) var(--ease-standard); border: 1px solid transparent; white-space: nowrap; line-height: 1.2; text-decoration: none; background: var(--accent); color: var(--accent-fg); }
.btn:hover { background: var(--accent-hover); transform: translateY(-1px); }
.btn .ic { width: 16px; height: 16px; }
.btn.sm { padding: 6px 12px; font-size: 12.5px; gap: 6px; }
.btn.sm .ic { width: 14px; height: 14px; }
.btn.lg { padding: 12px 22px; font-size: 15px; gap: 8px; }
.btn.lg .ic { width: 18px; height: 18px; }
.btn.dark { background: var(--cs-ink-900); color: #fff; }
.btn.dark:hover { background: var(--cs-ink-700); }
.btn.ghost { background: transparent; color: var(--fg-1); border-color: var(--border-strong); }
.btn.ghost:hover { background: var(--bg-muted); }
.btn.subtle { background: var(--bg-subtle); color: var(--fg-1); }
.btn.subtle:hover { background: var(--bg-muted); }
.btn.danger { background: transparent; color: var(--danger); border-color: var(--border-strong); }
.btn.danger:hover { background: #FDECEC; border-color: var(--danger); transform: none; }
.btn.warn { background: var(--warn); color: #fff; }
.btn.warn:hover { background: var(--warn-hover); }
.btn:disabled { opacity: 0.5; cursor: not-allowed; transform: none; }

/* ---- Таблицы ---- */
.o-table { width: 100%; border-collapse: collapse; font-size: 13.5px; }
.o-table th { text-align: left; padding: 11px 22px; font-size: 11px; color: var(--fg-2); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; white-space: nowrap; background: var(--cs-ink-25); }
.o-table td { padding: 13px 22px; border-top: 1px solid var(--border); vertical-align: middle; }
.o-table th.r, .o-table td.r { text-align: right; }
.o-table td.nowrap { white-space: nowrap; }
.o-table td.dt { font-family: var(--font-mono); color: var(--fg-2); font-size: 12px; white-space: nowrap; }
.o-table td.num { font-family: var(--font-mono); font-variant-numeric: tabular-nums; white-space: nowrap; }
.o-table tr.rowlink { cursor: pointer; }
.o-table tr.rowlink:hover td { background: var(--cs-ink-25); }
.o-table tr.empty td { color: var(--fg-3); text-align: center; padding: 40px 24px; font-size: 14px; }
.o-table tr.voided td { opacity: 0.6; }
.o-table tr.voided td.stake { text-decoration: line-through; }
.o-table .cell-title { font-weight: 600; color: var(--fg-1); }
.o-table .cell-title a { color: inherit; text-decoration: none; }
.o-table .cell-title a:hover { text-decoration: underline; }
.o-table .cell-sub { font-family: var(--font-mono); font-size: 11.5px; color: var(--fg-2); margin-top: 3px; word-break: break-all; }
.table-scroll { overflow-x: auto; }
.ev-sep { color: var(--fg-3); font-weight: 400; }

/* ---- Spec (ключ-значение) ---- */
.spec { display: flex; flex-direction: column; }
.spec-row { display: flex; align-items: baseline; gap: 14px; padding: 7px 0; }
.spec-row + .spec-row { border-top: 1px solid var(--border); }
.spec-k { width: 150px; flex-shrink: 0; font-size: 13px; color: var(--fg-2); }
.spec-k.w130 { width: 130px; }
.spec-v { font-size: 13.5px; color: var(--fg-1); word-break: break-all; }
.spec-v.strong { font-weight: 600; }
.spec-v.dim { color: var(--fg-2); }

/* ---- MiniStat ---- */
.stats-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 16px; }
.stat { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 18px; box-shadow: var(--shadow-sm); }
.stat-top { display: flex; align-items: center; justify-content: space-between; }
.stat-ic { width: 30px; height: 30px; border-radius: 8px; background: var(--cs-ink-25); display: grid; place-items: center; color: var(--fg-2); }
.stat.teal .stat-ic { background: var(--cs-teal-50); color: var(--cs-teal-600); }
.stat.orange .stat-ic { background: var(--cs-orange-50); color: var(--cs-orange-600); }
.stat-ic .ic { width: 16px; height: 16px; }
.stat-value { font-size: 24px; font-weight: 600; color: var(--fg-1); margin-top: 12px; letter-spacing: -0.01em; }
.stat-value.mono { font-weight: 500; }
.stat.teal .stat-value { color: var(--cs-teal-600); }
.stat.orange .stat-value { color: var(--cs-orange-600); }
.stat-value .suffix { font-size: 13px; color: var(--fg-3); margin-left: 5px; font-weight: 500; }

/* ---- KPI ---- */
.kpi-grid { display: grid; grid-template-columns: repeat(7, 1fr); gap: 12px; }
.kpi { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); padding: 16px; text-align: center; box-shadow: var(--shadow-sm); }
.kpi-val { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 24px; font-weight: 500; color: var(--fg-1); letter-spacing: -0.01em; line-height: 1.1; }
.kpi-val.big { font-size: 28px; }
.kpi-val.teal { color: var(--cs-teal-600); }
.kpi-val.orange { color: var(--cs-orange-600); }
.kpi-val.red { color: var(--danger); }
.kpi-val .kpi-unit { font-size: 14px; }
.kpi-label { font-size: 12px; color: var(--fg-2); margin-top: 8px; font-weight: 500; }
.kpi-sub { font-family: var(--font-mono); font-size: 11px; color: var(--fg-3); margin-top: 4px; }

/* ---- Балансовые плитки ---- */
.balance-tile { border: 1px solid var(--border); border-radius: var(--r-lg); padding: 20px; display: flex; flex-direction: column; justify-content: center; background: var(--surface); box-shadow: var(--shadow-sm); }
.balance-tile.pos { background: var(--cs-teal-50); border-color: var(--cs-teal-200); }
.balance-tile.pos .eyebrow { color: var(--cs-teal-700); }
.balance-tile.neg { background: var(--cs-orange-50); border-color: var(--cs-orange-200); }
.balance-tile.neg .eyebrow { color: var(--cs-orange-700); }
.balance-tile-val { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-size: 30px; font-weight: 500; letter-spacing: -0.01em; margin-top: 8px; color: var(--fg-1); }
.balance-tile.pos .balance-tile-val { color: var(--cs-teal-700); }
.balance-tile.neg .balance-tile-val { color: var(--cs-orange-700); }
.balance-tile-val .cur { font-size: 14px; color: var(--fg-3); }

/* ---- Деньги ---- */
.money { font-family: var(--font-mono); font-variant-numeric: tabular-nums; font-weight: 600; white-space: nowrap; }
.money.pos { color: var(--cs-teal-600); }
.money.neg { color: var(--danger); }
.money .cur { color: var(--fg-3); font-weight: 500; font-size: 0.82em; }

/* ---- Статус-точка ---- */
.dot { width: 9px; height: 9px; border-radius: 50%; background: var(--cs-teal-500); display: inline-block; flex-shrink: 0; box-shadow: 0 0 0 3px rgba(15,190,153,0.13); }
.dot.orange { background: var(--cs-orange-500); box-shadow: 0 0 0 3px rgba(230,102,41,0.13); }
.dot.red { background: var(--danger); box-shadow: 0 0 0 3px rgba(229,72,77,0.13); }
.dot.slate { background: var(--cs-ink-300); box-shadow: 0 0 0 3px rgba(107,108,122,0.13); }
.dot.pulse { animation: oPulse 1.8s ease-in-out infinite; }

/* ---- Формы ---- */
.lbl { display: block; font-size: 12px; font-weight: 600; color: var(--fg-2); margin-bottom: 6px; letter-spacing: 0.01em; }
.lbl .lbl-hint { font-weight: 400; color: var(--fg-3); margin-left: 6px; }
.in, select.in, textarea.in { width: 100%; padding: 9px 12px; font-size: 14px; color: var(--fg-1); background: var(--surface); border: 1px solid var(--border-strong); border-radius: var(--r-md); outline: none; transition: all var(--dur-fast); }
.in:focus { border-color: var(--accent); box-shadow: 0 0 0 3px var(--cs-teal-50); }
.in:disabled { background: var(--bg-subtle); }
.in.mono { font-family: var(--font-mono); }
select.in { appearance: none; padding-right: 34px; cursor: pointer; background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='15' height='15' viewBox='0 0 24 24' fill='none' stroke='%236B6C7A' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); background-repeat: no-repeat; background-position: right 11px center; }
textarea.in { resize: vertical; min-height: 70px; }
.in-icon-wrap { position: relative; display: flex; align-items: center; }
.in-icon-wrap .ic { position: absolute; left: 11px; pointer-events: none; color: var(--fg-3); width: 15px; height: 15px; }
.in-icon-wrap .in { padding-left: 34px; }
.fields { display: grid; gap: 12px 16px; align-items: end; }
.fields.c2 { grid-template-columns: 1fr 1fr; }
.fields.c3 { grid-template-columns: 1fr 1fr 1fr; }
.fields.c5 { grid-template-columns: repeat(5, 1fr); }

/* чекбокс */
.check { display: inline-flex; align-items: flex-start; gap: 9px; cursor: pointer; font-size: 13.5px; color: var(--fg-1); line-height: 1.4; }
.check input { appearance: none; width: 18px; height: 18px; border-radius: 5px; border: 1.5px solid var(--border-strong); background: var(--surface); margin: 1px 0 0; cursor: pointer; flex-shrink: 0; display: grid; place-items: center; transition: all var(--dur-fast); }
.check input:checked { background: var(--accent); border-color: var(--accent); }
.check input:checked::after { content: ""; width: 10px; height: 6px; border-left: 2.5px solid var(--cs-ink-900); border-bottom: 2.5px solid var(--cs-ink-900); transform: rotate(-45deg) translate(0.5px, -1px); }

/* тумблер (checkbox-switch; авто-submit формы из JS) */
.switch { position: relative; display: inline-flex; align-items: center; cursor: pointer; }
.switch input { appearance: none; width: 38px; height: 22px; border-radius: 999px; background: var(--cs-ink-100); cursor: pointer; transition: all var(--dur-base); margin: 0; }
.switch input:checked { background: var(--accent); }
.switch input::after { content: ""; position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%; background: #fff; box-shadow: var(--shadow-sm); transition: all var(--dur-base) var(--ease-standard); }
.switch input:checked::after { left: 18px; }

/* fieldset с «плавающей» легендой */
.ofs { border: 1px solid var(--border); border-radius: var(--r-md); padding: 20px 18px 18px; margin: 0 0 18px; position: relative; }
.ofs legend { padding: 0 8px; margin-left: 6px; font-size: 11px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-2); }

/* ---- Фильтры-пилюли ---- */
.pf { padding: 6px 12px; border-radius: var(--r-md); border: 1px solid var(--border-strong); background: transparent; color: var(--fg-2); font-size: 12px; font-weight: 600; cursor: pointer; transition: all var(--dur-fast); text-decoration: none; display: inline-flex; align-items: center; gap: 6px; }
.pf:hover { color: var(--fg-1); }
.pf.active { border-color: var(--cs-ink-900); background: var(--cs-ink-900); color: #fff; }

/* ---- Вкладки ---- */
.tabs { display: flex; gap: 4px; padding: 14px 22px 0; border-bottom: 1px solid var(--border); }
.tab { padding: 10px 14px; background: none; border: 0; border-bottom: 2px solid transparent; color: var(--fg-2); font-size: 13.5px; font-weight: 600; cursor: pointer; margin-bottom: -1px; }
.tab.active { border-bottom-color: var(--cs-ink-900); color: var(--fg-1); }
.tab-panel.hidden { display: none; }

/* ---- Match-pill (сверка) ---- */
.mpill { display: inline-flex; align-items: center; gap: 5px; padding: 3px 9px; border-radius: 999px; font-size: 11px; font-weight: 600; background: var(--cs-ink-50); color: var(--fg-3); white-space: nowrap; }
.mpill.ok { background: var(--cs-teal-50); color: var(--cs-teal-700); }
.mpill.bad { background: #FDECEC; color: var(--danger); }

/* ---- Карточка сверки (клиент → система → оператор) ---- */
.recon { background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-lg); box-shadow: var(--shadow-sm); overflow: hidden; }
.recon-head { padding: 12px 20px; background: var(--cs-ink-25); border-bottom: 1px solid var(--border); display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.recon-ts { font-family: var(--font-mono); font-size: 12.5px; color: var(--fg-2); }
.recon-pills { display: flex; gap: 7px; flex-wrap: wrap; align-items: center; }
.recon-cols { display: flex; align-items: stretch; }
.recon-col { flex: 1; padding: 18px 20px; min-width: 0; }
.recon-div { width: 1px; background: var(--border); flex-shrink: 0; }
.recon-col-head { display: flex; align-items: center; gap: 8px; margin-bottom: 16px; font-size: 11px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--fg-2); }
.recon-col-head.teal { color: var(--cs-teal-600); }
.recon-col-head .ic { width: 15px; height: 15px; }
.recon-kv { display: grid; grid-template-columns: 92px 1fr; gap: 12px; padding: 7px 0; align-items: baseline; }
.recon-kv + .recon-kv { border-top: 1px solid var(--border); }
.recon-kv .k { font-size: 12.5px; color: var(--fg-2); }
.recon-kv .v { font-size: 13.5px; color: var(--fg-1); line-height: 1.4; word-break: break-word; }
.recon-kv .v.dim { color: var(--fg-3); }
.recon-kv .v.strong { font-weight: 600; }
.recon-decision { margin-top: 14px; padding: 12px; background: var(--cs-teal-50); border-radius: var(--r-md); border: 1px solid var(--cs-teal-100); }
.recon-decision-label { font-size: 11px; font-weight: 600; color: var(--cs-teal-700); text-transform: uppercase; letter-spacing: 0.05em; margin-bottom: 6px; }
.recon-decision-text { font-size: 13px; color: var(--fg-1); line-height: 1.45; }
@media (max-width: 980px) { .recon-cols { flex-direction: column; } .recon-div { width: auto; height: 1px; } }

/* ---- Алерты ---- */
.alert { padding: 12px 16px; border-radius: var(--r-md); font-size: 13.5px; border: 1px solid transparent; display: flex; align-items: center; gap: 10px; }
.alert.ok { background: var(--cs-teal-50); color: var(--cs-teal-800); border-color: var(--cs-teal-200); }
.alert.error { background: #FDECEC; color: var(--danger); border-color: #F6C6C8; }
.alert.warn { background: var(--cs-orange-50); color: var(--cs-orange-800); border-color: var(--cs-orange-200); }

/* ---- Пустое состояние ---- */
.empty-state { padding: 48px 24px; text-align: center; color: var(--fg-3); }
.empty-state .ic { width: 28px; height: 28px; color: var(--cs-ink-100); }
.empty-state div { margin-top: 10px; font-size: 14px; }

/* ---- Confidence-бар ---- */
.conf { display: inline-flex; align-items: center; gap: 8px; }
.conf-track { width: 56px; height: 5px; background: var(--cs-ink-50); border-radius: 3px; overflow: hidden; }
.conf-fill { height: 100%; background: var(--cs-teal-500); }
.conf-fill.mid { background: var(--cs-teal-300); }
.conf-fill.low { background: var(--cs-orange-400); }
.conf-num { font-family: var(--font-mono); font-size: 12.5px; font-weight: 600; }

/* ---- Разное ---- */
.back-link { display: inline-flex; align-items: center; gap: 7px; background: none; border: 0; color: var(--fg-2); font-size: 13.5px; font-weight: 500; cursor: pointer; padding: 0; width: fit-content; text-decoration: none; }
.back-link:hover { color: var(--fg-1); }
.hint { font-size: 12.5px; color: var(--fg-3); font-weight: 400; line-height: 1.5; }
.muted { color: var(--fg-2); }
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.grid-13-1 { display: grid; grid-template-columns: 1.3fr 1fr; gap: 18px; }
.grid-115-1 { display: grid; grid-template-columns: 1.15fr 1fr; gap: 18px; }
.grid-12-1 { display: grid; grid-template-columns: 1.2fr 1fr; gap: 18px; }
.col-gap { display: flex; flex-direction: column; gap: 18px; }
.row { display: flex; align-items: center; gap: 12px; flex-wrap: wrap; }
.row-actions { display: flex; gap: 6px; flex-wrap: wrap; align-items: center; }
.row-actions form { margin: 0; display: inline-flex; }
.explain { font-family: var(--font-mono); font-size: 12px; word-break: break-word; }
code { font-family: var(--font-mono); background: var(--cs-ink-50); padding: 1px 5px; border-radius: 4px; font-size: 0.92em; }
a { color: var(--info-deep); }
h2.client-title { margin: 0; font-size: 24px; font-weight: 600; letter-spacing: -0.01em; }
.photos { margin-top: 8px; display: flex; gap: 10px; flex-wrap: wrap; }
@media (max-width: 1100px) { .stats-grid { grid-template-columns: 1fr 1fr; } .kpi-grid { grid-template-columns: repeat(4, 1fr); } }
@media (max-width: 900px) { .grid-2, .grid-13-1, .grid-115-1, .grid-12-1 { grid-template-columns: 1fr; } }

/* ============================== Логин ============================== */
.login-wrap { min-height: 100vh; display: grid; place-items: center; background: var(--cs-ink-25); background-image: radial-gradient(var(--cs-ink-50) 1px, transparent 1px); background-size: 20px 20px; }
.login-card { width: 380px; background: var(--surface); border: 1px solid var(--border); border-radius: var(--r-xl); box-shadow: var(--shadow-lg); padding: 36px; }
.login-brand { display: flex; flex-direction: column; align-items: center; margin-bottom: 28px; }
.login-brand-row { display: flex; align-items: center; gap: 10px; }
.login-brand-row img { display: block; width: 34px; height: 34px; }
.login-brand-row span { font-size: 22px; font-weight: 700; letter-spacing: -0.02em; }
.login-sub { font-size: 13.5px; color: var(--fg-2); margin-top: 8px; }
.login-form { display: flex; flex-direction: column; gap: 16px; }
.login-foot { font-family: var(--font-mono); text-align: center; font-size: 11px; color: var(--fg-3); margin-top: 22px; }
