/* Invorica — target B2B fintech interface system */

@font-face {
  font-family: "Gilroy";
  src: url("assets/webfonts/Gilroy-Regular.woff2") format("woff2"),
       url("assets/webfonts/Gilroy-Regular.woff") format("woff");
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("assets/webfonts/Gilroy-Regular.woff2") format("woff2"),
       url("assets/webfonts/Gilroy-Regular.woff") format("woff");
  font-weight: 500;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("assets/webfonts/Gilroy-Bold.woff2") format("woff2"),
       url("assets/webfonts/Gilroy-Bold.woff") format("woff");
  font-weight: 600;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("assets/webfonts/Gilroy-Bold.woff2") format("woff2"),
       url("assets/webfonts/Gilroy-Bold.woff") format("woff");
  font-weight: 700;
  font-style: normal;
  font-display: swap;
}
@font-face {
  font-family: "Gilroy";
  src: url("assets/webfonts/Gilroy-Bold.woff2") format("woff2"),
       url("assets/webfonts/Gilroy-Bold.woff") format("woff");
  font-weight: 800;
  font-style: normal;
  font-display: swap;
}

:root {
  /* Brand — target fintech system */
  --rich-black: #101828;
  --ink: #101828;

  /* Primary brand: magenta */
  --brand: #C72A6C;
  --brand-soft: #FCE7F0;
  --brand-deep: #B42365;

  /* Secondary brand: purple (gradient end) */
  --brand-purple: #9C649E;
  --brand-purple-soft: #F4EAF4;
  --brand-purple-deep: #7A477D;

  /* Signature gradient used on CTAs, active nav, hero accents */
  --brand-gradient: linear-gradient(90deg, #C72A6C 0%, #9C649E 100%);
  --brand-gradient-diag: linear-gradient(135deg, #C72A6C 0%, #9C649E 100%);

  /* Legacy aliases (existing screens read --azure / --royal) */
  --azure: var(--brand);
  --azure-soft: var(--brand-soft);
  --azure-deep: var(--brand-deep);
  --royal: var(--brand-purple);
  --royal-soft: var(--brand-purple-soft);

  /* Supporting accents (from logo) */
  --teal: #2563EB;
  --teal-soft: #EFF6FF;
  --teal-deep: #1D4ED8;
  --orange: #F79009;
  --orange-soft: #FFFAEB;
  --orange-deep: #B54708;
  --pink: #C72A6C;
  --pink-soft: #FCE7F0;
  --pink-deep: #B42365;
  --green: #039855;
  --green-soft: #ECFDF3;
  --green-deep: #027A48;
  --purple: #9C649E;
  --purple-soft: #F1E8F2;
  --purple-deep: #79487B;
  --violet: var(--purple);
  --violet-soft: var(--purple-soft);
  --gray: #98A2B3;

  /* Neutrals */
  --n-0: #FFFFFF;
  --n-25: #FCFCFD;
  --n-50: #F9FAFB;
  --n-100: #F2F4F7;
  --n-150: #EAECF0;
  --n-200: #D0D5DD;
  --n-300: #B8C0CC;
  --n-400: #98A2B3;
  --n-500: #667085;
  --n-600: #475467;
  --n-700: #344054;
  --n-800: #1D2939;
  --n-900: #101828;

  /* Status */
  --ok: #039855;
  --ok-soft: #ECFDF3;
  --warn: #F79009;
  --warn-soft: #FFFAEB;
  --bad: #D92D20;
  --bad-soft: #FEF3F2;
  --info: #2563EB;
  --info-soft: #EFF6FF;

  /* Surface */
  --bg: #F5F6F8;
  --surface: var(--n-0);
  --surface-2: var(--n-50);
  --border: var(--n-150);
  --border-strong: var(--n-200);
  --text: var(--n-900);
  --text-2: var(--n-600);
  --text-3: var(--n-400);

  /* Radius */
  --r-sm: 6px;
  --r-md: 8px;
  --r-lg: 8px;
  --r-xl: 12px;
  --r-pill: 999px;

  /* Shadow */
  --shadow-xs: 0 1px 1px rgba(16, 24, 40, 0.03);
  --shadow-sm: 0 1px 2px rgba(16, 24, 40, 0.05);
  --shadow-md: 0 8px 24px rgba(16, 24, 40, 0.08);
  --shadow-lg: 0 18px 48px rgba(16, 24, 40, 0.12);
  --shadow-azure: 0 8px 18px rgba(199, 42, 108, 0.14);
  --shadow-royal: 0 8px 18px rgba(156, 100, 158, 0.12);

  --sidebar-bg: #EEF0F4;
  --sidebar-border: #D9DEE7;

  --sidebar-w: 248px;
  --topbar-h: 60px;

  /* Type — Gilroy from the Style Guide */
  --font: "Gilroy", "Manrope", -apple-system, BlinkMacSystemFont, "SF Pro Text", system-ui, sans-serif;
  --font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;
}

* { box-sizing: border-box; }
html, body, #app { height: 100%; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: var(--font);
  font-feature-settings: "ss01", "cv11";
  color: var(--text);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-size: 14px;
  line-height: 1.45;
  letter-spacing: 0;
}

button { font-family: inherit; cursor: pointer; }
input, textarea, select { font-family: inherit; }

.tabular { font-variant-numeric: tabular-nums; }
.mono { font-family: var(--font-mono); font-size: 12.5px; letter-spacing: 0; }

/* -------- App shell -------- */
.app {
  display: grid;
  grid-template-columns: var(--sidebar-w) 1fr;
  grid-template-rows: var(--topbar-h) 1fr;
  grid-template-areas: "side topbar" "side main";
  min-height: 100vh;
}
.app.collapsed { --sidebar-w: 72px; }

/* -------- Sidebar -------- */
.sidebar {
  grid-area: side;
  background: var(--sidebar-bg);
  color: var(--n-600);
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--sidebar-border);
  position: sticky; top: 0; height: 100vh;
  overflow: hidden;
}
.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  font-weight: 700;
  font-size: 16px;
  letter-spacing: 0;
  color: var(--text);
  border-bottom: 1px solid var(--sidebar-border);
  height: var(--topbar-h);
}
.sidebar-brand .mark {
  width: 32px; height: 32px;
  display: grid; place-items: center;
  flex-shrink: 0;
  position: relative;
}
.sidebar-brand .mark img {
  width: 100%; height: 100%;
  object-fit: contain;
  display: block;
}
.sidebar-brand .name {
  font-family: var(--font);
  font-weight: 700;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  font-size: 14px;
}
.sidebar-section {
  padding: 16px 16px 7px;
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--n-500);
}
.collapsed .sidebar-section, .collapsed .sidebar-brand .name, .collapsed .nav-item .label, .collapsed .nav-item .chev, .collapsed .nav-item .nav-badge { display: none; }
.collapsed .sidebar-brand { justify-content: center; padding: 18px 12px; }

.nav-list { display: flex; flex-direction: column; gap: 2px; padding: 0 10px; }
.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 11px;
  border-radius: var(--r-md);
  color: var(--n-600);
  text-decoration: none;
  font-size: 13.5px;
  font-weight: 500;
  cursor: pointer;
  transition: background .16s ease, color .16s ease, box-shadow .16s ease, transform .16s ease;
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
}
.nav-item:hover { background: rgba(255,255,255,0.72); color: var(--text); transform: translateX(1px); }
.nav-item.active {
  background: #FFFFFF;
  color: var(--text);
  box-shadow: inset 3px 0 0 var(--brand), 0 1px 2px rgba(16,24,40,0.04);
}
.nav-item .icon { width: 18px; height: 18px; flex-shrink: 0; opacity: .85; }
.nav-item.active .icon { opacity: 1; color: var(--brand); }
.nav-item .label { flex: 1; }
.nav-item .nav-badge {
  font-size: 10.5px;
  background: var(--brand-soft);
  color: var(--brand-deep);
  padding: 1px 7px;
  border-radius: var(--r-pill);
  font-weight: 700;
}
.nav-item .chev { color: var(--n-500); }
.sidebar-footer {
  margin-top: auto;
  padding: 14px 16px;
  border-top: 1px solid var(--sidebar-border);
  display: flex; align-items: center; gap: 10px;
  background: rgba(255,255,255,0.34);
}
.sidebar-footer .avatar {
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--brand-gradient-diag);
  display: grid; place-items: center;
  color: white; font-weight: 700; font-size: 12px;
}
.sidebar-footer .who { font-size: 13px; color: var(--text); font-weight: 600; }
.sidebar-footer .role { font-size: 11px; color: var(--n-500); }
.collapsed .sidebar-footer .meta { display: none; }
.collapsed .sidebar-footer { justify-content: center; }

/* -------- Topbar -------- */
.topbar {
  grid-area: topbar;
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  padding: 0 28px;
  gap: 14px;
  position: sticky; top: 0; z-index: 30;
}
.topbar .crumb {
  font-size: 13px;
  color: var(--text-2);
  display: flex; align-items: center; gap: 8px;
}
.topbar .crumb .here { color: var(--text); font-weight: 600; }
.topbar .search {
  flex: 1;
  max-width: 560px;
  margin-left: 18px;
  position: relative;
}
.topbar .search input {
  width: 100%;
  height: 38px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: #F6F7F9;
  padding: 0 12px 0 36px;
  font-size: 13px;
  color: var(--text);
  outline: none;
}
.topbar .search input:focus { border-color: var(--brand); background: white; box-shadow: 0 0 0 4px rgba(199,42,108,.10); }
.topbar .search .ic { position: absolute; left: 11px; top: 50%; transform: translateY(-50%); color: var(--text-3); }
.topbar .right { margin-left: auto; display: flex; align-items: center; gap: 10px; }
.icon-btn {
  width: 36px; height: 36px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: white;
  display: grid; place-items: center;
  color: var(--text-2);
  position: relative;
  transition: background .16s ease, border-color .16s ease, color .16s ease, transform .16s ease;
}
.icon-btn:hover { color: var(--text); border-color: var(--border-strong); background: var(--n-50); transform: translateY(-1px); }
.icon-btn .dot {
  position: absolute; top: 7px; right: 7px;
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--azure); border: 2px solid white;
}
.profile-health {
  width: 178px;
  height: 38px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  padding: 6px 10px;
  color: var(--text);
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.profile-health:hover {
  border-color: rgba(199,42,108,.35);
  box-shadow: 0 0 0 4px rgba(199,42,108,.08);
  transform: translateY(-1px);
}
.profile-health-copy {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  line-height: 1;
}
.profile-health-label {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 600;
}
.profile-health-copy strong {
  color: var(--brand-deep);
  font-size: 12px;
}
.profile-health-meter {
  height: 4px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--n-100);
}
.profile-health-meter i {
  display: block;
  height: 100%;
  border-radius: 99px;
  background: var(--brand);
}
.user-menu {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 4px 10px 4px 4px;
  gap: 8px;
  height: 38px;
  cursor: pointer;
  transition: background .16s ease, border-color .16s ease, transform .16s ease;
}
.user-menu:hover {
  background: var(--n-50);
  border-color: var(--border-strong);
  transform: translateY(-1px);
}

/* -------- Main -------- */
.main {
  grid-area: main;
  padding: 26px 28px 80px;
  max-width: 100%;
  overflow-x: hidden;
  background:
    linear-gradient(180deg, rgba(255,255,255,.72) 0, rgba(255,255,255,0) 260px),
    var(--bg);
}
.page-header {
  display: flex; align-items: flex-end; justify-content: space-between;
  gap: 24px; margin-bottom: 20px;
}
.page-title { font-size: 24px; font-weight: 800; letter-spacing: 0; line-height: 1.15; }
.page-sub { color: var(--text-2); font-size: 13px; margin-top: 2px; }
.page-actions { display: flex; gap: 10px; align-items: center; }
.dashboard-page-actions { align-items: stretch; flex-wrap: wrap; justify-content: flex-end; }
.period-filter-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-width: 0;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow-xs);
}
.period-filter-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.period-filter-label {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-3);
}
.period-filter-helper {
  font-size: 12.5px;
  font-weight: 700;
  color: var(--text);
  white-space: nowrap;
}
.period-filter-controls {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.period-filter-select {
  position: relative;
  display: inline-flex;
  align-items: center;
  min-width: 176px;
}
.period-filter-select-icon {
  position: absolute;
  left: 12px;
  color: var(--text-2);
  pointer-events: none;
}
.period-select-input {
  min-width: 176px;
  width: auto;
  padding-left: 34px;
  padding-right: 34px;
  font-weight: 600;
  appearance: none;
  -webkit-appearance: none;
  -moz-appearance: none;
  background-image: none;
}

/* -------- Buttons -------- */
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  height: 36px;
  padding: 0 14px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: white;
  color: var(--text);
  font-weight: 600;
  font-size: 13px;
  letter-spacing: 0;
  white-space: nowrap;
  transition: background .16s ease, border-color .16s ease, color .16s ease, box-shadow .16s ease, transform .16s ease;
  cursor: pointer;
}
.btn:hover { border-color: var(--border-strong); background: var(--n-50); transform: translateY(-1px); }
.btn:active, .icon-btn:active, .nav-item:active, .user-menu:active, .profile-health:active { transform: translateY(0); }
.btn.primary {
  background: var(--rich-black);
  color: white; border-color: var(--rich-black);
}
.btn.primary:hover { background: var(--n-800); border-color: var(--n-800); }
.btn.azure {
  background: var(--brand); color: white; border-color: var(--brand);
  box-shadow: var(--shadow-azure);
}
.btn.azure:hover { background: var(--brand-deep); border-color: var(--brand-deep); }
.btn.royal { background: var(--brand-gradient); color: white; border-color: transparent; box-shadow: var(--shadow-royal); }
.btn.ghost { background: transparent; border-color: transparent; color: var(--text-2); }
.btn.ghost:hover { background: var(--n-100); color: var(--text); }
.btn.sm { height: 30px; padding: 0 10px; font-size: 12.5px; }
.btn.lg { height: 44px; padding: 0 18px; font-size: 14px; }
.btn.icon-only { padding: 0; width: 36px; justify-content: center; }
.btn:disabled { opacity: .5; cursor: not-allowed; }

/* -------- Card -------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.card-head {
  padding: 15px 18px;
  border-bottom: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.card-title { font-weight: 700; font-size: 14px; letter-spacing: 0; }
.card-sub { color: var(--text-3); font-size: 12px; }
.card-body { padding: 18px; }
.card-foot {
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  display: flex; align-items: center; justify-content: space-between;
  font-size: 12.5px; color: var(--text-2);
}

/* -------- Badge -------- */
.badge {
  display: inline-flex; align-items: center; gap: 5px;
  height: 22px;
  padding: 0 8px;
  border-radius: var(--r-pill);
  font-size: 11.5px;
  font-weight: 600;
  letter-spacing: 0;
  background: var(--n-100);
  color: var(--text-2);
  white-space: nowrap;
  border: 1px solid transparent;
}
.badge .pip { width: 6px; height: 6px; border-radius: 50%; background: currentColor; }
.badge.ok { background: var(--ok-soft); color: var(--ok); }
.badge.warn { background: var(--warn-soft); color: var(--warn); }
.badge.bad { background: var(--bad-soft); color: var(--bad); }
.badge.info { background: var(--azure-soft); color: var(--azure-deep); }
.badge.royal { background: var(--royal-soft); color: var(--royal); }
.badge.violet { background: var(--violet-soft); color: var(--violet); }
.badge.outline { background: white; border-color: var(--border); color: var(--text-2); }

/* -------- Table -------- */
.table-wrap { overflow-x: auto; }
.table {
  width: 100%;
  border-collapse: separate;
  border-spacing: 0;
  font-size: 13px;
}
.table th {
  text-align: left;
  font-weight: 600;
  color: var(--text-3);
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 12px 14px;
  border-bottom: 1px solid var(--border);
  background: var(--n-50);
  position: sticky; top: 0;
}
.table td {
  padding: 13px 14px;
  border-bottom: 1px solid var(--border);
  vertical-align: middle;
  color: var(--text);
}
.table tr:last-child td { border-bottom: none; }
.table tbody tr { transition: background .1s; }
.table tbody tr:hover { background: var(--n-50); }
.table tbody tr.selected { background: var(--azure-soft); }
.table .num { text-align: right; font-variant-numeric: tabular-nums; }
.table .muted { color: var(--text-3); }

/* -------- Form -------- */
.field { display: flex; flex-direction: column; gap: 6px; }
.field label { font-size: 12px; font-weight: 600; color: var(--text-2); }
.form-grid {
  display: grid;
  gap: 12px;
}
.form-grid.two {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
@media (max-width: 760px) {
  .form-grid.two {
    grid-template-columns: 1fr;
  }
}
.input, select.input, textarea.input {
  height: 40px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: white;
  padding: 0 12px;
  font-size: 13.5px;
  color: var(--text);
  outline: none;
  transition: border-color .14s ease, box-shadow .14s ease, background .14s ease;
  width: 100%;
}
textarea.input { padding: 10px 12px; height: auto; min-height: 80px; line-height: 1.5; }
.input:focus { border-color: var(--brand); box-shadow: 0 0 0 4px rgba(199,42,108,.10); }
.input::placeholder { color: var(--text-3); }

.check { display: inline-flex; align-items: center; gap: 8px; cursor: pointer; font-size: 13px; }
.check input { accent-color: var(--azure); width: 16px; height: 16px; }

/* Подсветка незаполненных обязательных полей анкеты */
.field--required > label::after {
  content: " *";
  color: var(--bad);
  font-weight: 800;
}
.field--required > .input:placeholder-shown,
.field--required > textarea.input:placeholder-shown,
.field--required > select.input.is-empty {
  border-color: var(--bad);
  background: var(--bad-soft);
}
.field--required > .input:placeholder-shown:focus,
.field--required > textarea.input:placeholder-shown:focus {
  border-color: var(--bad);
  box-shadow: 0 0 0 4px var(--bad-soft);
}
.required-notice {
  display: flex; align-items: center; gap: 8px;
  background: var(--bad-soft);
  color: #8B1A2A;
  border: 1px solid #F2B8C2;
  padding: 8px 12px;
  border-radius: 8px;
  font-size: 12px;
  font-weight: 600;
  margin-bottom: 14px;
}

/* -------- Stats -------- */
.stat-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 18px 16px;
  display: flex; flex-direction: column; gap: 8px;
  position: relative; overflow: hidden;
  transition: background .15s, border-color .15s, color .15s, box-shadow .15s, transform .15s;
}
.stat:hover {
  background: white;
  border-color: var(--border-strong);
  color: var(--text);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.stat:hover .label,
.stat:hover .delta,
.stat:hover .value .unit { color: var(--text-2); }
.stat:hover .delta.up { color: var(--ok); }
.stat:hover .delta.down { color: var(--bad); }
.stat .label { font-size: 12px; color: var(--text-2); font-weight: 600; display: flex; align-items: center; gap: 6px; }
.stat .value {
  font-size: 26px; font-weight: 800; letter-spacing: 0;
  font-variant-numeric: tabular-nums;
  display: flex; align-items: baseline; gap: 6px;
}
.stat .value .unit { font-size: 14px; color: var(--text-3); font-weight: 600; }
.stat .delta { font-size: 12px; font-weight: 600; display: inline-flex; align-items: center; gap: 4px; }
.stat .delta.up { color: var(--ok); }
.stat .delta.down { color: var(--bad); }
.stat.feature {
  background: linear-gradient(135deg, var(--rich-black) 0%, #2a2730 100%);
  border-color: transparent;
  color: white;
}
.stat.feature .label, .stat.feature .value .unit { color: rgba(255,255,255,0.65); }
.stat.feature::after {
  content: ""; position: absolute; right: -40px; top: -40px;
  width: 160px; height: 160px; border-radius: 50%;
  background: radial-gradient(circle, rgba(206,85,131,0.55), transparent 70%);
}
.stat.feature.royal { background: linear-gradient(135deg, var(--brand-deep) 0%, var(--brand-purple-deep) 100%); }
.stat.feature.royal::after { background: radial-gradient(circle, rgba(156,100,158,0.55), transparent 70%); }

/* -------- Tabs -------- */
.tabs {
  display: inline-flex;
  background: var(--n-100);
  border-radius: var(--r-md);
  padding: 3px;
  gap: 2px;
  border: 1px solid var(--border);
}
.tab {
  height: 30px;
  padding: 0 14px;
  border-radius: 7px;
  background: transparent;
  border: none;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  white-space: nowrap;
  display: inline-flex; align-items: center; gap: 6px;
}
.tab.active {
  background: white; color: var(--text);
  box-shadow: var(--shadow-xs);
}
.tab:hover:not(.active) { color: var(--text); }

@media (max-width: 1180px) {
  .page-header {
    align-items: flex-start;
    flex-direction: column;
  }
  .dashboard-page-actions {
    width: 100%;
    justify-content: flex-start;
  }
}

@media (max-width: 760px) {

  .period-filter-card {
    width: 100%;
  }
  .period-filter-head,
  .period-filter-controls {
    align-items: flex-start;
    flex-direction: column;
  }
  .period-filter-helper,
  .period-filter-select,
  .period-select-input {
    width: 100%;
  }
}

.tabs-underline {
  display: flex; gap: 4px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 18px;
}
.tab-u {
  background: none; border: none;
  padding: 12px 14px;
  font-size: 13px; font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  display: inline-flex; align-items: center; gap: 8px;
}
.tab-u.active { color: var(--azure-deep); border-bottom-color: var(--azure); }
.tab-u .count { font-size: 11px; background: var(--n-100); color: var(--text-2); padding: 1px 7px; border-radius: var(--r-pill); }
.tab-u.active .count { background: var(--azure-soft); color: var(--azure-deep); }

/* -------- Progress -------- */
.progress {
  height: 6px;
  background: #EEF0F3;
  border-radius: var(--r-pill);
  overflow: hidden;
}
.progress > i {
  display: block; height: 100%;
  background: var(--brand);
  border-radius: var(--r-pill);
  transition: width .4s;
}
.progress.ok > i { background: var(--ok); }
.progress.warn > i { background: var(--warn); }
.progress.bad > i { background: var(--bad); }

/* -------- AI insight callout -------- */
.ai-card {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px 18px;
  background:
    linear-gradient(135deg, rgba(199,42,108,0.07) 0%, rgba(16,24,40,0.02) 100%),
    white;
  position: relative;
  overflow: hidden;
}
.ai-card .ai-tag {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.08em;
  color: var(--azure-deep);
  background: var(--azure-soft);
  padding: 3px 8px;
  border-radius: var(--r-pill);
}
.ai-card h4 { margin: 8px 0 4px; font-size: 14.5px; letter-spacing: 0; }
.ai-card p { margin: 0; color: var(--text-2); font-size: 13px; line-height: 1.55; }
.ai-spark {
  width: 22px; height: 22px; flex-shrink: 0;
  background: linear-gradient(135deg, var(--azure), var(--violet));
  border-radius: 6px;
  display: grid; place-items: center;
  color: white;
}

/* -------- Financing offers workspace -------- */
.financing-offers-screen {
  max-width: 100%;
}
.financing-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 18px;
}
.financing-kpi {
  display: flex;
  align-items: center;
  gap: 14px;
  min-width: 0;
  min-height: 92px;
  padding: 18px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
}
.financing-kpi-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-deep);
  background: var(--brand-soft);
}
.financing-kpi-icon.is-green {
  color: var(--ok);
  background: var(--ok-soft);
}
.financing-kpi-icon.is-purple {
  color: var(--brand-purple-deep);
  background: var(--brand-purple-soft);
}
.financing-kpi-icon.is-orange {
  color: var(--orange-deep);
  background: var(--orange-soft);
}
.financing-kpi span {
  display: block;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.financing-kpi strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 20px;
  line-height: 1.1;
  font-weight: 800;
}
.financing-kpi small {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.financing-tabs {
  display: flex;
  align-items: center;
  gap: 22px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
}
.financing-tabs button {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  height: 40px;
  padding: 0;
  background: transparent;
  border: 0;
  border-bottom: 2px solid transparent;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 800;
  transition: color .16s ease, border-color .16s ease;
}
.financing-tabs button.active {
  color: var(--brand-deep);
  border-bottom-color: var(--brand);
}
.financing-tabs button span {
  min-width: 20px;
  height: 20px;
  padding: 0 7px;
  border-radius: 10px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: var(--n-100);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
}
.financing-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(310px, 350px);
  gap: 16px;
  align-items: flex-start;
}
.financing-notice {
  display: flex;
  align-items: center;
  gap: 9px;
  margin-bottom: 12px;
  padding: 11px 14px;
  border: 1px solid #FEDF89;
  border-radius: var(--r-lg);
  background: var(--warn-soft);
  color: #7A4B12;
  font-size: 12.5px;
  font-weight: 650;
}
.financing-notice svg {
  flex-shrink: 0;
  color: var(--warn);
}
.financing-debtor-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.financing-debtor-row {
  display: grid;
  grid-template-columns: 22px minmax(190px, .8fr) minmax(360px, 1.25fr) 112px;
  gap: 14px;
  align-items: center;
  padding: 16px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.financing-debtor-row.is-selected {
  border-color: var(--border);
  box-shadow: inset 3px 0 0 var(--brand), var(--shadow-xs);
}
.financing-row-check {
  display: flex;
  align-items: center;
  justify-content: center;
}
.financing-row-check input {
  width: 15px;
  height: 15px;
  accent-color: var(--brand);
}
.financing-debtor-main {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}
.financing-debtor-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-deep);
  background: var(--brand-soft);
}
.financing-debtor-icon.is-2 {
  color: var(--ok);
  background: var(--ok-soft);
}
.financing-debtor-icon.is-3 {
  color: var(--brand-purple-deep);
  background: var(--brand-purple-soft);
}
.financing-debtor-title {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.2;
  font-weight: 800;
}
.financing-debtor-sub {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.4;
}
.financing-terms,
.financing-total-grid,
.financing-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1px;
  background: var(--border);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  overflow: hidden;
}
.financing-term {
  min-width: 0;
  padding: 10px 12px;
  background: #FAFBFC;
}
.financing-term span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.financing-term strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.2;
  font-weight: 800;
}
.financing-row-actions {
  display: flex;
  flex-direction: column;
  gap: 8px;
  align-items: stretch;
}
.financing-row-actions .btn {
  justify-content: center;
}
.financing-total-card {
  box-shadow: none;
}
.financing-total-card .card-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.financing-legal-note,
.financing-footnote {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.financing-legal-note {
  padding: 12px 13px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.financing-footnote {
  margin-top: 12px;
  padding: 0 2px;
  color: var(--text-3);
}
.financing-summary {
  position: sticky;
  top: calc(var(--topbar-h) + 92px);
  padding: 18px;
  box-shadow: none;
}
.financing-summary-head {
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.financing-summary-icon {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  color: var(--brand-purple-deep);
  background: var(--brand-purple-soft);
}
.financing-summary-title {
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
}
.financing-summary-sub {
  margin-top: 2px;
  color: var(--text-2);
  font-size: 12px;
}
.financing-summary-grid {
  grid-template-columns: repeat(2, 1fr);
  margin-top: 16px;
}
.financing-summary-money {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
  padding: 14px;
  border: 1px solid rgba(199,42,108,.22);
  border-radius: var(--r-md);
  background: linear-gradient(180deg, #FFFFFF 0%, var(--brand-soft) 100%);
}
.financing-summary-money div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.financing-summary-money span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.financing-summary-money strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  text-align: right;
}
.financing-summary-terms {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 14px 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.financing-summary-terms div {
  display: flex;
  gap: 7px;
  align-items: flex-start;
}
.financing-summary-terms svg,
.financing-footnote svg,
.financing-legal-note svg {
  flex-shrink: 0;
  color: var(--brand-deep);
}
.financing-summary .btn {
  width: 100%;
  justify-content: center;
  margin-top: 8px;
}

.financing-detail-modal {
  width: min(940px, calc(100vw - 48px));
}
.financing-detail-head {
  grid-template-columns: minmax(0, 1fr) auto 34px;
}
.financing-detail-badges .badge {
  height: 28px;
  padding: 0 10px;
  font-size: 12px;
  font-weight: 750;
}
.financing-detail-body {
  grid-template-columns: minmax(0, 1fr) minmax(340px, 390px);
  align-items: stretch;
}
.financing-detail-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.financing-detail-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--border);
}
.financing-detail-metric {
  min-width: 0;
  min-height: 74px;
  padding: 13px 14px;
  background: #FAFBFC;
}
.financing-detail-metric span,
.financing-detail-selected span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  line-height: 1.2;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.financing-detail-metric strong {
  display: block;
  margin-top: 7px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 800;
}
.financing-detail-steps {
  display: grid;
  gap: 8px;
}
.financing-detail-step {
  min-height: 46px;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #fff;
}
.financing-detail-step span {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 50%;
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.financing-detail-step strong {
  min-width: 0;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
  font-weight: 750;
}
.financing-detail-result {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(145deg, rgba(199,42,108,.08), rgba(255,255,255,0) 42%), #F8FAFC;
}
.financing-detail-result-top {
  padding: 16px;
  border: 1px solid rgba(199,42,108,.18);
  border-radius: var(--r-md);
  background: #fff;
}
.financing-detail-result-top span,
.financing-detail-result-top small {
  display: block;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 750;
}
.financing-detail-result-top strong {
  display: block;
  margin-top: 8px;
  color: var(--brand-deep);
  font-size: 28px;
  line-height: 1;
  font-weight: 800;
}
.financing-detail-result-top small {
  margin-top: 8px;
  color: var(--text-3);
  line-height: 1.35;
}
.financing-detail-result .deal-calc-lines {
  margin-top: 0;
}
.financing-detail-selected {
  padding: 12px 13px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #fff;
}
.financing-detail-selected strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
  font-weight: 800;
}
.financing-detail-note {
  margin-top: auto;
}
.financing-detail-modal .deal-calc-actions .btn {
  white-space: nowrap;
}

@media (max-width: 980px) {
  .financing-detail-modal {
    width: min(940px, calc(100vw - 24px));
  }
  .financing-detail-head {
    grid-template-columns: minmax(0, 1fr) 34px;
  }
  .financing-detail-badges {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .financing-detail-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .financing-detail-metrics {
    grid-template-columns: 1fr;
  }
  .financing-detail-modal .deal-calc-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .financing-detail-modal .deal-calc-actions {
    width: 100%;
    flex-wrap: wrap;
  }
}

.financing-page-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.financing-export-action {
  align-items: flex-end;
}
.financing-export-action > .btn {
  white-space: nowrap;
}
.financing-export-menu {
  left: auto;
  right: 0;
  width: min(390px, calc(100vw - 56px));
  padding: 14px;
  z-index: 70;
}
.financing-export-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.financing-export-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.financing-export-sub {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.financing-export-section {
  margin-top: 13px;
}
.financing-export-label {
  margin-bottom: 7px;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.financing-export-segment {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}
.financing-export-segment button,
.financing-export-format button {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: #fff;
  color: var(--text);
  text-align: left;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.financing-export-segment button {
  padding: 10px 11px;
}
.financing-export-segment button span,
.financing-export-format button strong {
  display: block;
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.2;
}
.financing-export-segment button small,
.financing-export-format button span {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.25;
}
.financing-export-segment button.active,
.financing-export-format button.active {
  border-color: rgba(199,42,108,.34);
  background: var(--brand-soft);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,.08);
}
.financing-export-segment button:disabled {
  cursor: not-allowed;
  opacity: .55;
  background: var(--n-50);
}
.financing-export-format {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}
.financing-export-format button {
  padding: 9px 10px;
}
.financing-export-summary {
  display: grid;
  gap: 9px;
  margin-top: 13px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 8px;
  background: var(--n-50);
}
.financing-export-summary div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}
.financing-export-summary span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.financing-export-summary strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
  text-align: right;
}
.financing-export-actions {
  display: flex;
  justify-content: flex-end;
  gap: 9px;
  margin-top: 13px;
}
.financing-export-actions .btn {
  justify-content: center;
}

@media (max-width: 760px) {
  .financing-page-actions { width: 100%; }
  .financing-page-actions > .btn,
  .financing-export-action,
  .financing-export-action > .btn { width: 100%; }
  .financing-export-action > .btn { justify-content: center; }
  .financing-export-menu { width: calc(100vw - 32px); max-width: calc(100vw - 32px); }
  .financing-export-segment,
  .financing-export-format { grid-template-columns: 1fr; }
  .financing-export-actions { flex-direction: column; }
  .financing-export-actions .btn { width: 100%; }
}

/* -------- Status dot -------- */
.dot { width: 8px; height: 8px; border-radius: 50%; display: inline-block; }
.dot.ok { background: var(--ok); }
.dot.warn { background: var(--warn); }
.dot.bad { background: var(--bad); }
.dot.info { background: var(--azure); }
.dot.draft { background: var(--n-400); }

/* -------- Pills (for status text) -------- */
.status-pill {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 600;
}

/* -------- Avatar group -------- */
.avg { display: inline-flex; }
.avg .av {
  width: 24px; height: 24px; border-radius: 50%;
  border: 2px solid white;
  display: grid; place-items: center;
  font-size: 10px; font-weight: 700; color: white;
  margin-left: -6px;
}
.avg .av:first-child { margin-left: 0; }

/* -------- Auth screens -------- */
.auth-shell {
  min-height: 100vh;
  display: grid;
  grid-template-columns: 1fr 1.1fr;
  background: white;
}
.auth-left {
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 40px 56px;
}
.auth-form-wrap { max-width: 380px; width: 100%; margin: auto 0; }
.auth-form-wrap h1 { font-size: 28px; letter-spacing: 0; margin: 0 0 8px; font-weight: 800; }
.auth-form-wrap .sub { color: var(--text-2); font-size: 14px; margin-bottom: 28px; }
.auth-error {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: var(--bad);
  background: #FEF3F2;
  border: 1px solid #FECDCA;
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 12.5px;
  font-weight: 600;
  line-height: 1.35;
}
.auth-error.locked {
  color: var(--text-1);
  background: var(--n-100);
  border-color: var(--border);
}
.auth-right {
  background: linear-gradient(160deg, var(--rich-black) 0%, #2a2024 45%, var(--brand-deep) 95%, var(--brand-purple) 130%);
  position: relative; overflow: hidden;
  color: white;
  display: flex; flex-direction: column; justify-content: space-between;
  padding: 40px 56px;
}
.auth-right .glow {
  position: absolute; width: 600px; height: 600px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(206,85,131,0.50), transparent 70%);
  top: -200px; right: -200px;
  filter: blur(20px);
}
.auth-right .glow.b {
  background: radial-gradient(circle, rgba(156,100,158,0.45), transparent 70%);
  bottom: -200px; left: -100px; top: auto; right: auto;
}

/* -------- Onboarding -------- */
.ob-shell {
  min-height: 100vh;
  background: var(--bg);
}
.ob-top {
  background: white;
  border-bottom: 1px solid var(--border);
  padding: 16px 28px;
  display: flex; align-items: center; gap: 28px;
}
.ob-steps { display: flex; align-items: center; gap: 0; flex: 1; max-width: 880px; margin: 0 auto; }
.ob-step { display: flex; align-items: center; gap: 10px; flex: 1; position: relative; }
.ob-step .num {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--n-100); color: var(--text-2);
  display: grid; place-items: center; font-weight: 700; font-size: 12.5px;
  flex-shrink: 0;
  border: 1px solid var(--border);
}
.ob-step.done .num { background: var(--azure); color: white; border-color: var(--azure); }
.ob-step.active .num { background: var(--rich-black); color: white; border-color: var(--rich-black); }
.ob-step .text { font-size: 12.5px; font-weight: 600; color: var(--text-2); }
.ob-step.active .text { color: var(--text); }
.ob-step.done .text { color: var(--text); }
.ob-step + .ob-step::before {
  content: ""; position: absolute; left: -8px; right: calc(100% - 8px - 28px);
  height: 1px; background: var(--border);
  top: 50%;
}
.ob-step.done + .ob-step::before { background: var(--azure); }

.ob-body {
  max-width: 960px; margin: 32px auto;
  padding: 0 28px;
}

/* -------- Compare screen -------- */
.compare-screen {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.compare-screen .page-header {
  margin-bottom: 2px;
}
.compare-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 5px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 600;
  transition: color .16s ease, transform .16s ease;
}
.compare-back:hover {
  color: var(--brand-deep);
  transform: translateX(-1px);
}
.compare-decision {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .95fr) minmax(270px, .72fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--border);
  box-shadow: var(--shadow-xs);
}
.compare-decision > * {
  background: white;
}
.compare-decision-main {
  padding: 18px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 18px;
  box-shadow: inset 4px 0 0 var(--brand);
}
.compare-decision-bank {
  display: flex;
  align-items: flex-start;
  gap: 13px;
}
.compare-eyebrow {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.compare-decision h3 {
  margin: 3px 0 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.15;
}
.compare-decision-sub {
  margin-top: 5px;
  max-width: 580px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.45;
}
.compare-decision-proof {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.compare-decision-proof span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 28px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.compare-decision-proof svg {
  color: var(--brand-deep);
}
.compare-decision-money {
  display: grid;
  grid-template-columns: 1fr;
}
.compare-decision-money div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 58px;
  padding: 12px 16px;
  border-right: 0;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.compare-decision-money div:last-child {
  border-bottom: 0;
}
.compare-decision-money span,
.compare-kpi-card span {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 800;
  line-height: 1.25;
}
.compare-decision-money strong {
  display: block;
  margin-top: 0;
  color: var(--text);
  font-size: 18px;
  line-height: 1.1;
  font-weight: 800;
  text-align: right;
  white-space: nowrap;
}
.compare-accept {
  padding: 16px;
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: space-between;
}
.compare-accept-note {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid rgba(199,42,108,.18);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: #7A2C4E;
  font-size: 12px;
  line-height: 1.45;
  font-weight: 650;
}
.compare-accept-note svg {
  flex-shrink: 0;
  margin-top: 1px;
}
.compare-kpis {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.compare-kpi-card {
  min-height: 92px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-xs);
}
.compare-kpi-card strong {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-size: 22px;
  line-height: 1.05;
  font-weight: 800;
}
.compare-kpi-card small {
  display: block;
  margin-top: 7px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.compare-card {
  overflow: hidden;
  margin-bottom: 2px;
}
.compare-table-scroll {
  overflow-x: auto;
  background: white;
}
.compare-grid {
  display: grid;
  min-width: 100%;
  gap: 0;
}
.compare-grid .cell,
.compare-grid .head {
  border-right: 1px solid var(--border);
}
.compare-grid .cell.is-last-col,
.compare-grid .head.is-last-col {
  border-right: 0;
}
.compare-grid .cell {
  min-height: 52px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--border);
  background: white;
  font-size: 13.5px;
  line-height: 1.35;
}
.compare-grid .cell.label {
  position: sticky;
  left: 0;
  z-index: 4;
  background: #F7F8FA;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 750;
  box-shadow: 1px 0 0 var(--border);
}
.compare-grid .cell.label strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 14px;
}
.compare-grid .compare-corner {
  top: 0;
  z-index: 8;
}
.compare-grid .head {
  position: sticky;
  top: 0;
  z-index: 5;
  min-height: 96px;
  padding: 18px 16px 14px;
  border-bottom: 1px solid var(--border);
  background: #F7F8FA;
  font-weight: 700;
}
.compare-grid .head.best {
  background:
    linear-gradient(180deg, rgba(252,231,240,.86) 0%, rgba(255,255,255,.98) 100%);
  border-bottom-color: var(--brand);
  box-shadow: inset 0 3px 0 var(--brand);
}
.compare-grid .head.best::before {
  content: "Лучший мэтч";
  position: absolute;
  top: 8px;
  right: 12px;
  height: 20px;
  display: inline-flex;
  align-items: center;
  background: var(--brand);
  color: white;
  font-size: 10.5px;
  font-weight: 800;
  padding: 0 8px;
  border-radius: var(--r-pill);
}
.compare-head-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 12px;
}
.compare-head-copy {
  min-width: 0;
}
.compare-head-copy > div {
  margin-bottom: 3px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.15;
  font-weight: 800;
}
.compare-head-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-top: 10px;
}
.compare-head-meta span {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border-radius: var(--r-pill);
  background: white;
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 750;
}
.compare-head-meta span.is-strong {
  border-color: rgba(199,42,108,.28);
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.compare-grid .cell.is-best-col {
  background: linear-gradient(90deg, rgba(252,231,240,.42), rgba(255,255,255,.98));
}
.compare-best-value {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  width: fit-content;
  max-width: 100%;
  padding: 0 2px 1px;
  margin: 0 -2px -1px;
  border-radius: 0;
  background:
    linear-gradient(180deg, transparent 48%, rgba(199,42,108,.13) 48%, rgba(199,42,108,.13) 88%, transparent 88%);
  box-shadow: none;
  color: var(--text);
  font-weight: 800;
}
.compare-best-value svg {
  color: var(--brand-deep);
}
.compare-strong {
  font-weight: 700;
}
.compare-cost {
  color: var(--brand-purple-deep);
  font-weight: 700;
}
.compare-invorica-fee {
  color: #7A2C4E;
  font-weight: 700;
}
.compare-invorica-fee span {
  margin-left: 4px;
  color: currentColor;
  font-weight: 500;
  opacity: .72;
}
.compare-action-label {
  display: flex;
  align-items: center;
}
.compare-match {
  display: flex;
  align-items: center;
  gap: 10px;
}
.compare-match div {
  flex: 1;
  height: 7px;
  overflow: hidden;
  border-radius: var(--r-pill);
  background: var(--n-100);
}
.compare-match i {
  display: block;
  height: 100%;
  border-radius: var(--r-pill);
  background: var(--brand-gradient);
}
.compare-match .compare-score {
  width: 28px;
  text-align: right;
  color: var(--text);
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.compare-match .compare-score.compare-best-value {
  justify-content: center;
  min-width: 28px;
  width: auto;
  color: var(--brand-deep);
}
.compare-number {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.compare-number.is-medium {
  font-size: 18px;
}
.compare-money {
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.compare-status {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--text);
  font-weight: 750;
}
.compare-status svg {
  color: var(--brand);
}
.compare-link {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 0 0 2px;
  border: 0;
  border-bottom: 1px dashed var(--brand);
  background: transparent;
  color: var(--brand);
  font-size: 13px;
  font-weight: 750;
}
.compare-link:hover {
  color: var(--brand-deep);
  border-bottom-color: var(--brand-deep);
}
.compare-perks {
  display: flex;
  flex-direction: column;
  gap: 5px;
}
.compare-perks span {
  display: inline-flex;
  align-items: flex-start;
  gap: 6px;
  color: var(--text-2);
  font-size: 12.5px;
}
.compare-perks svg {
  flex-shrink: 0;
  margin-top: 2px;
  color: var(--ok);
}

/* -------- Deal calculator modal -------- */
.deal-calc-overlay {
  position: fixed;
  inset: 0;
  z-index: 1000;
  display: grid;
  place-items: center;
  padding: 24px;
  background: rgba(16, 24, 40, .58);
  backdrop-filter: blur(5px);
}
.deal-calc-modal {
  width: min(980px, 100%);
  max-height: min(92vh, 860px);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  border: 1px solid rgba(255,255,255,.62);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: 0 28px 80px rgba(16, 24, 40, .26);
}
.deal-calc-head {
  min-height: 86px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  background:
    linear-gradient(135deg, rgba(199,42,108,.065), rgba(255,255,255,0) 42%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto 34px;
  align-items: center;
  gap: 16px;
}
.deal-calc-bank {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 13px;
}
.deal-calc-bank h3 {
  margin: 2px 0 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.15;
  font-weight: 800;
}
.deal-calc-kicker {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.deal-calc-sub {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 600;
}
.deal-calc-badges {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 7px;
}
.deal-calc-badges span {
  display: inline-flex;
  align-items: center;
  height: 28px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  background: white;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 750;
  white-space: nowrap;
}
.deal-calc-close {
  width: 34px;
  height: 34px;
  border: 1px solid transparent;
  border-radius: var(--r-md);
  background: transparent;
  color: var(--text-2);
  display: grid;
  place-items: center;
  transition: background .14s ease, border-color .14s ease, color .14s ease;
}
.deal-calc-close:hover {
  border-color: var(--border);
  background: white;
  color: var(--text);
}
.deal-calc-body {
  min-height: 0;
  padding: 22px;
  overflow-y: auto;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 430px);
  gap: 18px;
}
.deal-calc-inputs {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.deal-calc-section-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.deal-calc-control {
  padding: 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: #FCFCFD;
}
.deal-calc-control label {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 13px;
}
.deal-calc-control label span {
  color: var(--text-2);
  font-size: 13px;
  font-weight: 800;
}
.deal-calc-control label strong {
  color: var(--brand-deep);
  font-size: 14px;
  font-weight: 800;
  white-space: nowrap;
}
.deal-calc-range {
  width: 100%;
  height: 24px;
  margin: 0;
  background: transparent;
  accent-color: var(--brand);
  -webkit-appearance: none;
  appearance: none;
}
.deal-calc-range::-webkit-slider-runnable-track {
  height: 6px;
  border-radius: var(--r-pill);
  background: var(--n-150);
}
.deal-calc-range::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 20px;
  height: 20px;
  margin-top: -7px;
  border: 3px solid white;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 4px 10px rgba(199,42,108,.24);
}
.deal-calc-range::-moz-range-track {
  height: 6px;
  border-radius: var(--r-pill);
  background: var(--n-150);
}
.deal-calc-range::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border: 3px solid white;
  border-radius: 50%;
  background: var(--brand);
  box-shadow: 0 4px 10px rgba(199,42,108,.24);
}
.deal-calc-scale {
  display: flex;
  justify-content: space-between;
  margin-top: 3px;
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 650;
}
.deal-calc-note {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 12px 13px;
  border: 1px solid rgba(156,100,158,.20);
  border-radius: var(--r-md);
  background: var(--brand-purple-soft);
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
  font-weight: 650;
}
.deal-calc-note svg {
  flex-shrink: 0;
  margin-top: 1px;
  color: var(--brand-purple-deep);
}
.deal-calc-result {
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background:
    linear-gradient(145deg, rgba(199,42,108,.08), rgba(255,255,255,0) 42%),
    #F8FAFC;
}
.deal-calc-result-top {
  padding: 16px;
  border: 1px solid rgba(199,42,108,.18);
  border-radius: var(--r-md);
  background: white;
}
.deal-calc-result-top span {
  display: block;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}
.deal-calc-result-top strong {
  display: block;
  margin-top: 8px;
  color: var(--brand-deep);
  font-size: 30px;
  line-height: 1;
  font-weight: 800;
}
.deal-calc-result-top small {
  display: block;
  margin-top: 8px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.deal-calc-lines {
  margin-top: 12px;
  border-top: 1px solid var(--border);
}
.deal-calc-line {
  min-height: 52px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  border-bottom: 1px solid var(--border);
}
.deal-calc-line span {
  color: var(--text-2);
  font-size: 13px;
  font-weight: 650;
}
.deal-calc-line strong {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
  text-align: right;
  white-space: nowrap;
}
.deal-calc-line.is-negative strong {
  color: var(--text);
}
.deal-calc-line.is-total strong {
  color: var(--text);
  font-size: 15px;
}
.deal-calc-line.is-rate strong {
  color: var(--brand-purple-deep);
}
.deal-calc-foot {
  padding: 14px 22px;
  border-top: 1px solid var(--border);
  background: #FCFCFD;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
}
.deal-calc-footnote {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.deal-calc-footnote svg {
  color: var(--brand-deep);
}
.deal-calc-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

@media (max-width: 1280px) {
  .compare-decision {
    grid-template-columns: 1fr;
  }
  .compare-decision-money {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .compare-kpis {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .deal-calc-head {
    grid-template-columns: minmax(0, 1fr) 34px;
  }
  .deal-calc-badges {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .deal-calc-body {
    grid-template-columns: 1fr;
  }
  .deal-calc-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .deal-calc-actions {
    justify-content: flex-end;
  }
}

/* -------- Analytics screen -------- */
.analytics-screen {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.analytics-screen .page-header {
  margin-bottom: 0;
}
.analytics-brief {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(360px, .85fr) minmax(270px, .62fr);
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--border);
  box-shadow: var(--shadow-xs);
}
.analytics-brief > * {
  background: white;
}
.analytics-brief-main {
  padding: 18px;
  box-shadow: inset 4px 0 0 var(--brand);
}
.analytics-brief-main h3 {
  max-width: 760px;
  margin: 4px 0 0;
  color: var(--text);
  font-size: 20px;
  line-height: 1.2;
  font-weight: 800;
}
.analytics-brief-main p {
  max-width: 760px;
  margin: 8px 0 0;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.5;
}
.analytics-brief-metrics {
  display: grid;
  grid-template-columns: 1fr;
}
.analytics-brief-metrics div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 56px;
  padding: 11px 16px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.analytics-brief-metrics div:last-child {
  border-bottom: 0;
}
.analytics-brief-metrics span,
.analytics-kpi span {
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.25;
  font-weight: 800;
}
.analytics-brief-metrics strong {
  color: var(--text);
  font-size: 17px;
  line-height: 1;
  font-weight: 800;
  text-align: right;
  white-space: nowrap;
}
.analytics-brief-action {
  padding: 16px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 12px;
}
.analytics-brief-action > div {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 11px 12px;
  border: 1px solid rgba(199,42,108,.18);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: #7A2C4E;
  font-size: 12px;
  line-height: 1.45;
  font-weight: 650;
}
.analytics-brief-action svg {
  flex-shrink: 0;
  margin-top: 1px;
}
.analytics-kpi-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
}
.analytics-kpi {
  min-height: 116px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-xs);
}
.analytics-kpi.is-brand {
  background:
    linear-gradient(180deg, rgba(252,231,240,.72), rgba(255,255,255,.96) 54%),
    white;
  border-color: rgba(199,42,108,.25);
}
.analytics-kpi strong {
  display: block;
  margin-top: 9px;
  color: var(--text);
  font-size: 25px;
  line-height: 1.05;
  font-weight: 800;
}
.analytics-kpi small {
  display: block;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.analytics-kpi div {
  margin-top: 10px;
  padding-top: 9px;
  border-top: 1px solid var(--border);
  color: var(--brand-deep);
  font-size: 12px;
  font-weight: 750;
}
.analytics-main-grid {
  display: grid;
  grid-template-columns: minmax(0, 2.05fr) minmax(330px, 1fr);
  gap: 16px;
}
.analytics-rate-card,
.analytics-concentration-card,
.analytics-bank-card,
.analytics-status-card,
.analytics-volume-card {
  box-shadow: none;
}
.analytics-card-tag {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 9px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.analytics-rate-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 235px;
  gap: 1px;
  background: var(--border);
}
.analytics-chart-area {
  min-width: 0;
  padding: 14px 18px 16px;
  background: white;
}
.analytics-legend {
  display: flex;
  flex-wrap: wrap;
  gap: 18px;
  padding-left: 44px;
  color: var(--text-2);
  font-size: 12.5px;
}
.analytics-legend span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
}
.analytics-legend i {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}
.analytics-rate-aside {
  padding: 16px;
  background: #FAFBFC;
}
.analytics-aside-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.analytics-factor {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
}
.analytics-factor span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.analytics-factor strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  text-align: right;
}
.analytics-note {
  margin-top: 14px;
  padding: 11px 12px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: white;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.analytics-concentration-body {
  padding: 18px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
}
.analytics-exposure-list {
  width: 100%;
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.analytics-exposure-row,
.analytics-status-row {
  display: grid;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-size: 12.5px;
}
.analytics-exposure-row {
  grid-template-columns: 10px minmax(0, 1fr) auto 46px;
}
.analytics-exposure-row span:nth-child(2) {
  overflow: hidden;
  color: var(--text);
  font-weight: 700;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.analytics-exposure-row strong {
  color: var(--text-2);
  font-weight: 650;
}
.analytics-exposure-row b {
  color: var(--text);
  font-weight: 800;
  text-align: right;
}
.analytics-color-dot {
  width: 10px;
  height: 10px;
  border-radius: 3px;
}
.analytics-warning {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  width: 100%;
  padding: 11px 12px;
  border: 1px solid #FEDF89;
  border-radius: var(--r-md);
  background: var(--warn-soft);
  color: #7A4B12;
  font-size: 12px;
  line-height: 1.45;
  font-weight: 650;
}
.analytics-warning svg {
  flex-shrink: 0;
  color: var(--warn);
  margin-top: 1px;
}
.analytics-lower-grid {
  display: grid;
  grid-template-columns: minmax(330px, 1fr) minmax(330px, 1fr) minmax(330px, 1fr);
  gap: 16px;
}
.analytics-bank-list {
  padding: 4px 0;
}
.analytics-bank-row {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr) 58px 50px;
  grid-template-areas:
    "logo name spark rate"
    "logo delta spark rate";
  column-gap: 10px;
  row-gap: 2px;
  align-items: center;
  padding: 10px 18px;
  border-top: 1px solid var(--border);
}
.analytics-bank-row:first-child {
  border-top: 0;
}
.analytics-bank-row.is-best {
  background: linear-gradient(90deg, rgba(252,231,240,.62), rgba(255,255,255,.96));
}
.analytics-bank-row > div:first-child {
  grid-area: logo;
}
.analytics-bank-row > span {
  grid-area: name;
  overflow: hidden;
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.analytics-bank-row small {
  grid-area: delta;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-align: left;
}
.analytics-bank-row > svg {
  grid-area: spark;
}
.analytics-bank-row strong {
  grid-area: rate;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  text-align: right;
}
.analytics-status-body {
  padding: 18px;
  display: grid;
  grid-template-columns: 150px minmax(0, 1fr);
  gap: 18px;
  align-items: center;
}
.analytics-status-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.analytics-status-row {
  grid-template-columns: 10px minmax(0, 1fr) auto;
}
.analytics-status-row span:nth-child(2) {
  color: var(--text-2);
}
.analytics-status-row strong {
  color: var(--text);
  font-weight: 800;
}
.analytics-volume-body {
  padding: 18px;
}
.analytics-volume-summary {
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-top: 10px;
  color: var(--text-2);
  font-size: 12.5px;
}
.analytics-volume-summary strong {
  color: var(--text);
  font-weight: 800;
}

@media (max-width: 1280px) {
  .analytics-brief,
  .analytics-main-grid {
    grid-template-columns: 1fr;
  }
  .analytics-brief-metrics {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .analytics-brief-metrics div {
    border-right: 1px solid var(--border);
    border-bottom: 0;
  }
  .analytics-brief-metrics div:last-child {
    border-right: 0;
  }
  .analytics-kpi-grid,
  .analytics-lower-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

/* -------- Notifications row -------- */
.notifications-page-shell {
  position: relative;
}
.notif-mark-all-btn.is-done {
  color: var(--ok);
  border-color: rgba(3, 152, 85, .18);
  background: var(--ok-soft);
  box-shadow: none;
}
.notif-mark-all-btn:disabled {
  opacity: 1;
  cursor: default;
}
.notif-settings-btn.is-active {
  color: var(--text);
  border-color: rgba(199, 42, 108, .18);
  background: linear-gradient(180deg, #FFF8FB 0%, #FFFFFF 100%);
}
.notif-settings-overlay {
  position: fixed;
  inset: 0;
  z-index: 40;
  border: 0;
  background: rgba(16, 24, 40, .14);
  backdrop-filter: blur(2px);
}
.notif-settings-drawer {
  position: fixed;
  top: 76px;
  right: 22px;
  bottom: 22px;
  z-index: 41;
  width: min(540px, calc(100vw - 32px));
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(16,24,40,.08);
  border-radius: 22px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,252,253,.98) 100%),
    radial-gradient(circle at top right, rgba(199,42,108,.07), transparent 30%);
  box-shadow: 0 24px 64px rgba(16,24,40,.18);
  overflow: auto;
}
.notif-settings-drawer-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
}
.notif-settings-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.notif-settings-drawer-head h3 {
  margin: 12px 0 0;
  color: var(--text);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 800;
}
.notif-settings-drawer-head p {
  margin: 9px 0 0;
  max-width: 48ch;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.notif-settings-drawer-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.notif-settings-stat {
  min-height: 106px;
  padding: 14px;
  border: 1px solid rgba(16,24,40,.06);
  border-radius: 16px;
  background: rgba(255,255,255,.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.92);
}
.notif-settings-stat span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.notif-settings-stat strong {
  display: block;
  margin-top: 16px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.notif-settings-stat small {
  display: block;
  margin-top: 8px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
  font-weight: 600;
}
.notif-settings-mini-head,
.notif-settings-mini-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 72px 72px 72px;
  gap: 10px;
  align-items: center;
}
.notif-settings-mini-head {
  padding: 0 4px;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.notif-settings-mini-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.notif-settings-mini-row {
  min-height: 96px;
  padding: 14px;
  border: 1px solid rgba(16,24,40,.06);
  border-radius: 18px;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,252,253,.96) 100%);
  box-shadow: var(--shadow-xs);
}
.notif-settings-mini-event {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
}
.notif-settings-mini-copy {
  min-width: 0;
}
.notif-settings-mini-copy-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.notif-settings-mini-copy-top strong {
  color: var(--text);
  font-size: 14px;
  line-height: 1.3;
  font-weight: 800;
}
.notif-settings-mini-copy-top span {
  display: inline-flex;
  align-items: center;
  min-height: 22px;
  padding: 0 8px;
  border-radius: 999px;
  background: var(--n-50);
  color: var(--text-2);
  font-size: 10.5px;
  font-weight: 700;
}
.notif-settings-mini-copy p {
  margin: 7px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.52;
}
.notif-settings-mini-switch {
  display: grid;
  justify-items: center;
  gap: 6px;
}
.notif-settings-mini-switch-label {
  display: none;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.notif-settings-drawer-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  margin-top: auto;
  padding-top: 6px;
}
.notif-settings-helper {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.notif-settings-helper svg {
  color: var(--brand);
  flex: 0 0 auto;
}
.notif-settings-drawer-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
@media (max-width: 980px) {
  .notif-settings-drawer {
    top: 68px;
    right: 12px;
    left: 12px;
    bottom: 12px;
    width: auto;
    padding: 16px;
  }
  .notif-settings-drawer-stats {
    grid-template-columns: 1fr;
  }
  .notif-settings-mini-head {
    display: none;
  }
  .notif-settings-mini-row {
    grid-template-columns: 1fr;
    gap: 14px;
  }
  .notif-settings-mini-switch {
    justify-items: start;
  }
  .notif-settings-mini-switch-label {
    display: inline-flex;
  }
  .notif-settings-drawer-foot {
    flex-direction: column;
    align-items: stretch;
  }
  .notif-settings-drawer-actions {
    justify-content: flex-end;
  }
}
.notif-row {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
}
.notif-row:hover { background: var(--n-50); }
.notif-row .ico {
  width: 34px; height: 34px;
  border-radius: var(--r-md);
  display: grid; place-items: center;
  flex-shrink: 0;
}
.notif-row.unread { background: linear-gradient(90deg, var(--azure-soft) 0%, transparent 60%); }
.notif-row .body { flex: 1; }
.notif-row .body p { margin: 0; font-size: 13.5px; color: var(--text); }
.notif-row .body p .em { font-weight: 700; }
.notif-row .when { font-size: 12px; color: var(--text-3); white-space: nowrap; }
.notif-row.unread::before {
  content: ""; width: 6px; height: 6px; border-radius: 50%;
  background: var(--azure); margin-top: 14px; flex-shrink: 0;
}

/* -------- Document upload -------- */
.dz {
  border: 1.5px dashed var(--border-strong);
  border-radius: var(--r-lg);
  padding: 28px;
  text-align: center;
  background: var(--n-25);
  transition: all .15s;
  cursor: pointer;
}
.dz:hover { border-color: var(--azure); background: var(--azure-soft); }
.dz .ic {
  width: 44px; height: 44px;
  border-radius: var(--r-md);
  background: white;
  border: 1px solid var(--border);
  display: inline-grid; place-items: center;
  margin-bottom: 12px;
  color: var(--azure-deep);
}

.doc-item {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
}
.doc-item + .doc-item { margin-top: 8px; }
.doc-item .doc-ic {
  width: 32px; height: 32px; border-radius: 7px;
  display: grid; place-items: center;
  background: var(--azure-soft); color: var(--azure-deep);
  font-weight: 700; font-size: 11px;
}
.doc-item .doc-name { font-weight: 600; font-size: 13px; }
.doc-item .doc-meta { font-size: 11.5px; color: var(--text-3); }

/* -------- Debtors workspace -------- */
.debtors-screen {
  max-width: 100%;
}
.debtors-overview {
  margin-bottom: 16px;
  padding: 18px;
}
.debtors-overview-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 22px;
  align-items: center;
}
.debtors-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtors-overview-title {
  color: var(--text);
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
}
.debtors-overview-copy {
  max-width: 760px;
  margin-top: 7px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.debtors-overview-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.debtors-meter-label {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.debtors-meter-label strong {
  color: var(--brand-deep);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.debtors-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.debtors-metric {
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
}
.debtors-metric span {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.debtors-metric strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.debtors-metric small {
  display: block;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtors-list-card {
  box-shadow: none;
}
.debtors-list-head {
  display: grid;
  grid-template-columns: minmax(220px, 300px) auto minmax(210px, 1fr);
  align-items: center;
}
.debtors-search {
  position: relative;
}
.debtors-search svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  pointer-events: none;
}
.debtors-search .input {
  height: 34px;
  padding-left: 32px;
  background: white;
}
.debtors-toolbar-actions {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}
.debtors-selected {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
}
.debtors-filter-wrap {
  position: relative;
}
.debtors-filter-wrap .btn span {
  margin-left: 2px;
  color: inherit;
  font-size: 11px;
  font-weight: 800;
}
.debtors-filter-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 8;
  width: 340px;
  padding: 14px;
  border: 1px solid rgba(208, 213, 221, .92);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(16, 24, 40, .12);
}
.debtors-filter-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.debtors-filter-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.debtors-filter-panel-head small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.debtors-filter-section + .debtors-filter-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.debtors-filter-label {
  display: block;
  margin-bottom: 8px;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.debtors-filter-status-note {
  padding: 10px 11px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fafbfc;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.debtors-filter-checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.debtors-filter-check {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 600;
}
.debtors-filter-check input {
  margin: 0;
}
.debtors-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.debtors-filter-range-values,
.debtors-filter-range-scale {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.debtors-filter-range-values strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.debtors-filter-range input[type="range"] {
  width: 100%;
  margin: 8px 0 0;
  accent-color: var(--brand-deep);
}
.debtors-filter-range-scale {
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
}
.debtors-filter-panel-foot {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.debtors-export-wrap {
  position: relative;
}
.debtors-export-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 8;
  width: 340px;
  padding: 14px;
  border: 1px solid rgba(208, 213, 221, .92);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(16, 24, 40, .12);
}
.debtors-export-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.debtors-export-panel-head small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.debtors-export-section + .debtors-export-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.debtors-export-scope {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.debtors-export-scope button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 700;
  transition: border-color .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease;
}
.debtors-export-scope button span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
}
.debtors-export-scope button.active {
  border-color: rgba(199, 42, 108, .2);
  background: rgba(199, 42, 108, .06);
  color: var(--brand-deep);
  box-shadow: inset 0 0 0 1px rgba(199, 42, 108, .06);
}
.debtors-export-scope button:disabled {
  opacity: .54;
  cursor: not-allowed;
}
.debtors-export-format {
  width: fit-content;
}
.debtors-export-note {
  margin-top: 10px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.debtors-export-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.debtor-list-table {
  overflow-x: auto;
}
.debtor-row {
  display: grid;
  grid-template-columns: 32px minmax(190px, 1.35fr) 100px 58px 152px 96px 104px 94px 108px 20px;
  gap: 14px;
  align-items: center;
  min-width: 1080px;
  padding: 13px 18px;
  border-top: 1px solid var(--border);
  background: white;
  cursor: pointer;
  transition: background .16s ease;
}
.debtor-row:hover {
  background: #FAFBFC;
}
.debtor-row-head {
  cursor: default;
  background: #F8F9FB;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-row-head:hover {
  background: #F8F9FB;
}
.debtor-check {
  display: flex;
  align-items: center;
  justify-content: center;
}
.debtor-check input {
  width: 14px;
  height: 14px;
  accent-color: var(--brand);
  cursor: pointer;
}
.debtor-main-cell {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}
.debtor-avatar {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-deep);
  background: var(--brand-soft);
  border: 1px solid rgba(199,42,108,.16);
  font-size: 12px;
  font-weight: 800;
}
.debtor-name {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.debtor-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-sector {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.debtor-history {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 800;
}
.debtor-history.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.debtor-history.is-muted {
  color: var(--text-3);
  background: var(--n-100);
  border-color: var(--border);
}
.debtor-limit-cell {
  min-width: 0;
}
.debtor-limit-line {
  display: flex;
  align-items: center;
  gap: 5px;
  color: var(--text-3);
  font-size: 12.5px;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}
.debtor-limit-line strong {
  color: var(--text);
  font-weight: 800;
}
.debtor-limit-line .approved {
  color: var(--ok);
}
.debtor-limit-line .muted {
  color: var(--text-3);
}
.debtor-limit-bar {
  height: 4px;
  margin-top: 6px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--n-100);
}
.debtor-limit-bar i {
  display: block;
  height: 100%;
  border-radius: 99px;
  background: var(--brand);
}
.debtor-money {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 750;
}
.debtor-payment-cell,
.debtor-trend-cell {
  display: flex;
  align-items: center;
  gap: 8px;
}
.debtor-payment-cell span {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
  white-space: nowrap;
}
.debtor-status {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  height: 24px;
  padding: 0 9px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 800;
  white-space: nowrap;
}
.debtor-status.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.debtor-status.is-attention {
  color: #B54708;
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.20);
}
.debtor-status.is-draft {
  color: var(--text-2);
  background: var(--n-100);
  border-color: var(--border);
}
.debtor-status.is-bad {
  color: var(--bad);
  background: var(--bad-soft);
  border-color: rgba(217,45,32,.18);
}

/* -------- Debtor CSV import -------- */
.btn.is-active {
  border-color: rgba(199,42,108,.26);
  background: var(--brand-soft);
  color: var(--brand-deep);
  box-shadow: 0 0 0 4px rgba(199,42,108,.07);
}
.debtor-import-toast {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 30px;
  gap: 11px;
  align-items: center;
  margin: -2px 0 14px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
  box-shadow: 0 14px 38px rgba(16, 24, 40, .08);
}
.debtor-import-toast > span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  color: var(--ok);
  background: var(--ok-soft);
}
.debtor-import-toast.is-attention > span {
  color: var(--warn);
  background: var(--warn-soft);
}
.debtor-import-toast strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-import-toast small {
  display: block;
  margin-top: 2px;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.debtor-import-toast .btn {
  width: 30px;
  padding: 0;
  justify-content: center;
}
.debtor-import-modal {
  width: min(940px, 100%);
}
.debtor-import-head {
  grid-template-columns: minmax(0, 1fr) 34px;
}
.debtor-import-body {
  min-height: 0;
  padding: 20px 22px 22px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.debtor-import-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(300px, .9fr);
  gap: 16px;
  align-items: stretch;
}
.debtor-import-upload-col {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.debtor-import-dropzone {
  min-height: 206px;
  width: 100%;
  padding: 22px;
  border: 1.5px dashed var(--border-strong);
  border-radius: var(--r-lg);
  background: #FAFBFC;
  color: var(--text);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  text-align: center;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}
.debtor-import-dropzone:hover,
.debtor-import-dropzone.is-dragging {
  border-color: rgba(199,42,108,.42);
  background: white;
  box-shadow: 0 0 0 4px rgba(199,42,108,.07);
  transform: translateY(-1px);
}
.debtor-import-upload-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.debtor-import-dropzone strong {
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
}
.debtor-import-dropzone small {
  color: var(--brand-deep);
  font-size: 12.5px;
  font-weight: 750;
}
.debtor-import-file-chip,
.debtor-import-message {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
}
.debtor-import-file-chip svg {
  color: var(--brand-deep);
  flex-shrink: 0;
}
.debtor-import-message.is-error {
  border-color: rgba(217,45,32,.18);
  background: var(--bad-soft);
  color: var(--bad);
}
.debtor-import-message svg {
  flex-shrink: 0;
}
.debtor-import-format-card {
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(145deg, rgba(199,42,108,.06), rgba(255,255,255,0) 48%), #FCFCFD;
}
.debtor-import-format-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
}
.debtor-import-format-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.debtor-import-format-head p {
  max-width: 280px;
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
  font-weight: 650;
}
.debtor-import-field-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 14px;
}
.debtor-import-field-row {
  display: grid;
  grid-template-columns: 26px minmax(0, 1fr) auto;
  gap: 9px;
  align-items: center;
  min-height: 36px;
  padding: 8px 9px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
}
.debtor-import-field-row > span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  border-radius: 7px;
  color: var(--brand-deep);
  background: var(--brand-soft);
}
.debtor-import-field-row strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-import-field-row small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.debtor-import-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.debtor-import-summary.is-four {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.debtor-import-summary div {
  min-width: 0;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
}
.debtor-import-summary span {
  display: block;
  color: var(--text);
  font-size: 21px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.debtor-import-summary small {
  display: block;
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.debtor-import-preview-card {
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
}
.debtor-import-preview-head {
  padding: 13px 15px;
  border-bottom: 1px solid var(--border);
  background: #FCFCFD;
}
.debtor-import-preview-head strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.debtor-import-preview-head span {
  display: block;
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 650;
}
.debtor-import-preview-table {
  overflow-x: auto;
  max-height: 260px;
}
.debtor-import-preview-row {
  display: grid;
  grid-template-columns: minmax(230px, 1.35fr) 116px 116px 122px;
  gap: 12px;
  align-items: center;
  min-width: 620px;
  padding: 11px 15px;
  border-top: 1px solid var(--border);
}
.debtor-import-preview-row:first-child {
  border-top: 0;
}
.debtor-import-preview-row.is-head {
  background: #F8F9FB;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.debtor-import-preview-row:not(.is-head).is-duplicate,
.debtor-import-preview-row:not(.is-head).is-attention {
  background: linear-gradient(90deg, rgba(255,250,235,.72), rgba(255,255,255,1));
}
.debtor-import-preview-name {
  min-width: 0;
}
.debtor-import-preview-name strong {
  display: block;
  overflow: hidden;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.debtor-import-preview-name small {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 650;
}
.debtor-import-preview-row > .tabular {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 750;
}
.debtor-import-status-cell {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 4px;
}
.debtor-import-status {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border: 1px solid transparent;
  border-radius: 6px;
  font-size: 11.5px;
  font-weight: 800;
  white-space: nowrap;
}
.debtor-import-status.is-ready {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.debtor-import-status.is-duplicate,
.debtor-import-status.is-attention {
  color: #B54708;
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.20);
}
.debtor-import-status-cell small {
  color: var(--bad);
  font-size: 11px;
  font-weight: 800;
}
.debtor-import-empty {
  min-height: 132px;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 22px;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
  text-align: center;
}
.debtor-import-empty svg {
  color: var(--text-3);
  flex-shrink: 0;
}
.debtor-import-foot .btn.azure {
  min-width: 142px;
  justify-content: center;
}

@media (max-width: 980px) {
  .debtor-import-grid,
  .debtor-import-summary {
    grid-template-columns: 1fr;
  }
  .debtor-import-format-head,
  .debtor-import-foot,
  .debtor-import-foot .deal-calc-actions {
    align-items: stretch;
    flex-direction: column;
  }
  .debtor-import-foot .btn {
    justify-content: center;
  }
}

/* -------- Debtor detail -------- */
.debtor-detail {
  max-width: 1560px;
  margin: 0 auto;
}
.debtor-back {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin: 0 0 12px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
  transition: color .16s ease, transform .16s ease;
}
.debtor-back:hover {
  color: var(--brand-deep);
  transform: translateX(-1px);
}
.debtor-hero {
  margin-bottom: 16px;
  padding: 22px 24px 24px;
  overflow: hidden;
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,.11), transparent 34%),
    linear-gradient(180deg, #FFFFFF 0%, #FBFCFE 100%);
}
.debtor-hero-top {
  display: flex;
  gap: 18px;
  align-items: flex-start;
  justify-content: space-between;
}
.debtor-hero-main {
  display: flex;
  gap: 16px;
  align-items: flex-start;
  min-width: 0;
}
.debtor-identity-mark {
  width: 58px;
  height: 58px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  background: linear-gradient(135deg, #D92D20 0%, var(--brand) 100%);
  color: white;
  font-size: 20px;
  font-weight: 800;
  box-shadow: 0 12px 24px rgba(199,42,108,.18);
}
.debtor-title-block {
  min-width: 0;
}
.debtor-title-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}
.debtor-title-row h1 {
  margin: 0;
  font-size: 24px;
  line-height: 1.15;
  font-weight: 800;
  letter-spacing: 0;
}
.debtor-rating {
  height: 24px;
  font-size: 12px;
}
.debtor-hero-meta,
.debtor-hero-badges {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 8px;
}
.debtor-hero-meta {
  color: var(--text-2);
  font-size: 12.8px;
}
.debtor-hero-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.debtor-hero-actions {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-shrink: 0;
}
.debtor-kpi-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 12px;
  margin-top: 22px;
}
.debtor-metric-card {
  position: relative;
  min-width: 0;
  min-height: 112px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.78);
  box-shadow: 0 1px 1px rgba(16,24,40,.02);
  overflow: hidden;
}
.debtor-metric-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--border-strong);
}
.debtor-metric-card.is-ok::before { background: var(--ok); }
.debtor-metric-card.is-warn::before { background: var(--warn); }
.debtor-metric-card.is-bad::before { background: var(--bad); }
.debtor-metric-label {
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-metric-value {
  margin-top: 8px;
  color: var(--text);
  font-size: 22px;
  line-height: 1;
  font-weight: 800;
}
.debtor-metric-card.is-ok .debtor-metric-value { color: var(--ok); }
.debtor-metric-card.is-warn .debtor-metric-value { color: var(--warn); }
.debtor-metric-card.is-bad .debtor-metric-value { color: var(--bad); }
.debtor-metric-sub {
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
}
.debtor-tabs-card {
  overflow: visible;
}
.debtor-tabs-wrap {
  padding: 0 20px;
  background: white;
  border-radius: var(--r-lg) var(--r-lg) 0 0;
}
.debtor-tabs-wrap .tabs-underline {
  margin-bottom: 0;
  overflow-x: auto;
}
.debtor-overview-tab {
  padding: 18px 24px 24px;
}
.debtor-action-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
  padding: 16px 18px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-lg);
  background:
    linear-gradient(90deg, rgba(252,231,240,.74), rgba(255,255,255,.88) 42%),
    #fff;
}
.debtor-action-copy span {
  display: block;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.debtor-action-copy strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 15px;
}
.debtor-action-copy p {
  max-width: 760px;
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.8px;
}
.debtor-chart-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 18px;
}
.debtor-chart-card,
.debtor-panel {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-xs);
}
.debtor-chart-card {
  padding: 18px;
}
.debtor-chart-head,
.debtor-panel-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 14px;
}
.debtor-chart-head h3,
.debtor-panel-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
  line-height: 1.2;
  font-weight: 800;
}
.debtor-chart-head p,
.debtor-panel-head p {
  margin: 3px 0 0;
  color: var(--text-3);
  font-size: 12px;
}
.chart-legend {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  justify-content: flex-end;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.chart-legend span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.chart-legend i {
  width: 8px;
  height: 8px;
  border-radius: 50%;
}
.debtor-chart-summary {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  margin-top: 10px;
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-chart-summary strong {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.debtor-info-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .96fr);
  gap: 18px;
  margin-top: 18px;
}
.debtor-panel {
  overflow: hidden;
}
.debtor-panel-head {
  margin: 0;
  padding: 15px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF, #FCFCFD);
}
.debtor-panel-head.compact {
  padding-bottom: 12px;
}
.debtor-kv-list {
  padding: 10px 18px 14px;
}
.debtor-side-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.recent-invoice-list {
  padding: 4px 0;
}
.recent-invoice-row {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr) auto auto;
  gap: 12px;
  align-items: center;
  padding: 11px 18px;
  border-top: 1px solid var(--border);
}
.recent-invoice-row:first-child {
  border-top: none;
}
.recent-invoice-main {
  display: flex;
  flex-direction: column;
  min-width: 0;
}
.recent-invoice-main .mono {
  color: var(--text);
  font-weight: 700;
}
.recent-invoice-main small {
  color: var(--text-3);
  font-size: 11px;
}
.recent-invoice-row > .tabular {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}

/* -------- Debtor secondary tabs -------- */
.debtor-tab-panel {
  padding: 18px 24px 24px;
}
.debtor-tab-summary {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.debtor-tab-metric {
  min-width: 0;
  padding: 14px 15px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: #FAFBFC;
}
.debtor-tab-metric span {
  display: block;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-tab-metric strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.15;
  font-weight: 800;
}
.debtor-tab-metric small {
  display: block;
  margin-top: 5px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-tab-metric.is-ok strong { color: var(--ok); }
.debtor-tab-metric.is-warn strong { color: var(--warn); }
.debtor-tab-metric.is-bad strong { color: var(--bad); }
.debtor-work-card {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.debtor-work-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 15px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF, #FCFCFD);
}
.debtor-work-head h3 {
  margin: 0;
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
  line-height: 1.2;
}
.debtor-work-head p {
  max-width: 680px;
  margin: 3px 0 0;
  color: var(--text-3);
  font-size: 12px;
}
.debtor-work-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.debtor-invoice-table {
  overflow-x: auto;
}
.debtor-invoice-row {
  display: grid;
  grid-template-columns: minmax(170px, 1.25fr) 120px 140px 140px 140px 150px;
  gap: 14px;
  align-items: center;
  min-width: 920px;
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-invoice-row:first-child {
  border-top: none;
}
.debtor-invoice-row.head {
  min-height: 40px;
  background: var(--n-50);
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-invoice-row strong {
  color: var(--text);
  font-weight: 800;
}
.debtor-invoice-row small {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11px;
}
.invoice-due {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}
.debtor-invoice-modal {
  width: min(1040px, calc(100vw - 40px));
  max-height: min(90vh, 860px);
  padding: 0;
  overflow: hidden;
  border: 1px solid rgba(208,213,221,.88);
  border-radius: 18px;
  background: linear-gradient(180deg, #fff, #fcfcfd);
  box-shadow: 0 30px 80px rgba(16,24,40,.16);
}
.debtor-invoice-modal-head {
  display: grid;
  grid-template-columns: minmax(0,1fr) auto 34px;
  align-items: start;
  gap: 14px;
  padding: 18px 22px;
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(252,231,240,.88), rgba(255,255,255,0) 34%),
    linear-gradient(180deg, #fff, #fcfcfd);
}
.debtor-invoice-modal-head .deal-calc-bank {
  min-width: 0;
}
.debtor-invoice-modal-head .deal-calc-bank h3 {
  margin: 2px 0 0;
  font-size: 17px;
  line-height: 1.15;
}
.debtor-invoice-modal-head .deal-calc-sub {
  margin-top: 4px;
  max-width: 620px;
  font-size: 12.5px;
  line-height: 1.45;
}
.debtor-invoice-modal-head .deal-calc-badges {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: flex-end;
  padding-top: 2px;
}
.debtor-invoice-modal-head .deal-calc-badges span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: rgba(255,255,255,.9);
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
  white-space: nowrap;
}
.debtor-invoice-modal-body {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) 320px;
  gap: 18px;
  padding: 18px 22px 20px;
  overflow: auto;
}
.debtor-invoice-form-card,
.debtor-invoice-side-card {
  min-width: 0;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: #fff;
  box-shadow: var(--shadow-xs);
}
.debtor-invoice-form-card {
  padding: 18px;
}
.debtor-invoice-form-intro {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
  margin-bottom: 18px;
}
.debtor-invoice-form-intro strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  line-height: 1.2;
  font-weight: 800;
}
.debtor-invoice-form-intro p {
  margin: 5px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.debtor-invoice-completion {
  width: 220px;
  flex-shrink: 0;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: linear-gradient(180deg, var(--n-50), #fff);
}
.debtor-invoice-completion > div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 8px;
}
.debtor-invoice-completion span {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.debtor-invoice-completion strong {
  color: var(--text);
  font-size: 16px;
  font-weight: 800;
}
.debtor-invoice-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px 16px;
}
.debtor-invoice-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-width: 0;
}
.debtor-invoice-field > span {
  color: var(--text-2);
  font-size: 10.8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.debtor-invoice-field small {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
}
.debtor-invoice-field .input {
  height: 42px;
  border-radius: 12px;
  background: #fff;
}
.debtor-invoice-field textarea.input {
  min-height: 112px;
  padding-top: 11px;
  resize: vertical;
}
.debtor-invoice-field--full {
  grid-column: 1 / -1;
}
.debtor-invoice-field.is-missing .input,
.debtor-invoice-field.is-missing textarea.input {
  border-color: rgba(217,45,32,.28);
  background: rgba(254,243,242,.42);
  box-shadow: 0 0 0 3px rgba(217,45,32,.06);
}
.debtor-invoice-upload-card {
  display: grid;
  grid-template-columns: 42px minmax(0,1fr) auto;
  align-items: center;
  gap: 14px;
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px dashed rgba(199,42,108,.24);
  border-radius: 15px;
  background: linear-gradient(135deg, rgba(252,231,240,.48), rgba(255,255,255,.98));
}
.debtor-invoice-upload-card strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-invoice-upload-card p {
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.4;
}
.debtor-invoice-side-card {
  padding: 18px;
  background:
    radial-gradient(circle at top left, rgba(252,231,240,.9), rgba(255,255,255,0) 34%),
    linear-gradient(180deg, #fff, #fcfcfd);
}
.debtor-invoice-side-kicker {
  color: var(--brand-deep);
  font-size: 10.8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.debtor-invoice-side-card h4 {
  margin: 8px 0 0;
  color: var(--text);
  font-size: 18px;
  line-height: 1.25;
  font-weight: 800;
}
.debtor-invoice-side-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}
.debtor-invoice-side-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,.88);
}
.debtor-invoice-side-item > span {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 9px;
  background: var(--n-50);
  color: var(--text-3);
}
.debtor-invoice-side-item.is-ok {
  border-color: rgba(3,152,85,.18);
  background: linear-gradient(180deg, rgba(236,253,243,.92), rgba(255,255,255,.96));
}
.debtor-invoice-side-item.is-ok > span {
  background: var(--ok-soft);
  color: var(--ok);
}
.debtor-invoice-side-item strong {
  display: block;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-invoice-side-item small {
  display: block;
  margin-top: 3px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
}
.debtor-invoice-side-summary {
  display: grid;
  gap: 10px;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}
.debtor-invoice-side-summary div {
  padding: 11px 12px;
  border: 1px solid rgba(208,213,221,.76);
  border-radius: 12px;
  background: rgba(255,255,255,.94);
}
.debtor-invoice-side-summary span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.debtor-invoice-side-summary strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.3;
  font-weight: 800;
}
.debtor-offer-banner {
  display: flex;
  justify-content: space-between;
  gap: 18px;
  align-items: center;
  margin-bottom: 16px;
  padding: 16px 18px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-lg);
  background:
    linear-gradient(90deg, rgba(252,231,240,.78), rgba(255,255,255,.92) 42%),
    white;
}
.debtor-offer-banner span {
  display: block;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.debtor-offer-banner strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 15px;
}
.debtor-offer-banner p {
  max-width: 760px;
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.8px;
}
.debtor-offer-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 14px;
}
.debtor-offer-card {
  min-width: 0;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  box-shadow: var(--shadow-xs);
}
.debtor-offer-card.is-best {
  border-color: rgba(3,152,85,.24);
  box-shadow: 0 10px 28px rgba(3,152,85,.08);
}
.debtor-offer-top {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  min-width: 0;
}
.debtor-hidden-partner {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  background: var(--royal-soft);
  color: var(--royal);
  font-weight: 800;
}
.debtor-offer-top > div:nth-child(2) {
  flex: 1;
  min-width: 0;
}
.debtor-offer-top h3 {
  margin: 0;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.debtor-offer-top p {
  margin: 2px 0 0;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-offer-rate {
  margin-top: 16px;
  color: var(--text);
  font-size: 30px;
  line-height: 1;
  font-weight: 800;
}
.debtor-offer-rate span {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 650;
}
.debtor-offer-terms {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 9px;
  margin-top: 15px;
}
.debtor-offer-terms div {
  padding: 9px 10px;
  border-radius: var(--r-md);
  background: var(--n-50);
}
.debtor-offer-terms span,
.debtor-offer-match span {
  display: block;
  color: var(--text-3);
  font-size: 10.8px;
  font-weight: 700;
}
.debtor-offer-terms strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-offer-match {
  margin: 14px 0;
}
.debtor-offer-match > div {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 7px;
}
.debtor-offer-match strong {
  color: var(--brand-deep);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-history-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.1fr) minmax(360px, .9fr);
  gap: 16px;
}
.debtor-payment-table {
  padding: 5px 0;
}
.debtor-payment-row {
  display: grid;
  grid-template-columns: minmax(120px, 1fr) 110px 70px 70px;
  gap: 12px;
  align-items: center;
  padding: 10px 18px;
  border-top: 1px solid var(--border);
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-payment-row:first-child {
  border-top: none;
}
.debtor-payment-row strong {
  color: var(--text);
  font-weight: 800;
}
.debtor-payment-row small {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11px;
}
.debtor-payment-row .ok {
  color: var(--ok);
  font-weight: 800;
}
.debtor-payment-row .warn {
  color: var(--warn);
  font-weight: 800;
}
.debtor-doc-summary {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px auto;
  gap: 16px;
  align-items: center;
  margin-bottom: 16px;
  padding: 16px 18px;
  border: 1px solid rgba(3,152,85,.18);
  border-radius: var(--r-lg);
  background:
    linear-gradient(90deg, rgba(236,253,243,.78), rgba(255,255,255,.94) 46%),
    white;
}
.debtor-doc-summary span {
  color: var(--ok);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.debtor-doc-summary strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
}
.debtor-doc-summary p {
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-doc-upload-note {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background: rgba(3,152,85,.05);
}
.debtor-doc-upload-note strong {
  color: var(--ok);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-doc-upload-note span {
  color: var(--text-2);
  font-size: 12px;
}
.debtor-doc-meter strong {
  color: var(--ok);
  font-size: 18px;
}
.debtor-doc-list {
  padding: 0;
}
.debtor-doc-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 110px 140px auto;
  gap: 14px;
  align-items: center;
  padding: 13px 18px;
  border-top: 1px solid var(--border);
}
.debtor-doc-row:first-child {
  border-top: none;
}
.debtor-doc-status {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--n-100);
  color: var(--text-2);
}
.debtor-doc-row.is-done .debtor-doc-status {
  background: var(--ok-soft);
  color: var(--ok);
}
.debtor-doc-row.is-review .debtor-doc-status,
.debtor-doc-row.is-attention .debtor-doc-status {
  background: var(--warn-soft);
  color: var(--warn);
}
.debtor-doc-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-doc-row p {
  margin: 2px 0 0;
  color: var(--text-3);
  font-size: 11.8px;
}
.debtor-doc-inline-note {
  display: block;
  margin-top: 4px;
  color: var(--brand-deep);
  font-size: 11.5px;
  font-weight: 700;
}
.debtor-doc-date {
  color: var(--text-2);
  font-size: 12px;
  white-space: nowrap;
}
.debtor-timeline-card {
  max-width: 100%;
}
.debtor-timeline-list {
  padding: 8px 18px 14px;
}
.debtor-timeline-row {
  position: relative;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 150px;
  gap: 14px;
  align-items: start;
  padding: 11px 0;
}
.debtor-timeline-icon {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  z-index: 1;
  background: var(--n-50);
  border: 1px solid var(--border);
  color: var(--text-2);
}
.debtor-timeline-row.is-ok .debtor-timeline-icon {
  background: var(--ok-soft);
  color: var(--ok);
}
.debtor-timeline-row.is-brand .debtor-timeline-icon {
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.debtor-timeline-row.is-info .debtor-timeline-icon {
  background: var(--info-soft);
  color: var(--info);
}
.debtor-timeline-line {
  position: absolute;
  left: 15px;
  top: 43px;
  bottom: -10px;
  width: 1px;
  background: var(--border);
}
.debtor-timeline-main {
  min-width: 0;
}
.debtor-timeline-title {
  display: flex;
  align-items: center;
  gap: 9px;
  flex-wrap: wrap;
}
.debtor-timeline-tag {
  padding: 3px 7px;
  border-radius: 6px;
  background: var(--n-100);
  color: var(--text-2);
  font-size: 10.5px;
  font-weight: 800;
}
.debtor-timeline-title strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-timeline-main p {
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-timeline-row time {
  color: var(--text-3);
  font-size: 11.5px;
  text-align: right;
}

/* -------- Debtor questionnaire -------- */
.debtor-form {
  padding: 18px 24px 26px;
}
.debtor-form-intro {
  display: flex;
  align-items: center;
  gap: 15px;
  margin-bottom: 18px;
  padding: 15px 18px;
  border: 1px solid rgba(199,42,108,.14);
  border-radius: var(--r-lg);
  background:
    linear-gradient(135deg, rgba(252,231,240,.86), rgba(255,255,255,.96) 52%),
    white;
}
.debtor-form-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  background: var(--brand);
  color: white;
  box-shadow: 0 10px 20px rgba(199,42,108,.16);
}
.debtor-form-intro-copy {
  flex: 1;
  min-width: 0;
}
.debtor-form-intro-copy h2 {
  margin: 0;
  color: var(--text);
  font-size: 16px;
  line-height: 1.25;
  font-weight: 800;
}
.debtor-form-intro-copy p {
  max-width: 760px;
  margin: 4px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
}
.debtor-form-intro-side {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.debtor-form-completion {
  width: 190px;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
}
.debtor-form-completion > div {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 7px;
}
.debtor-form-completion span {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.debtor-form-completion strong {
  color: var(--brand-deep);
  font-size: 12.5px;
  font-variant-numeric: tabular-nums;
}
.debtor-form-layout {
  display: grid;
  grid-template-columns: 260px minmax(0, 1fr);
  gap: 18px;
  align-items: start;
}
.debtor-form-rail {
  position: sticky;
  top: calc(var(--topbar-h) + 18px);
}
.debtor-form-rail-card {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: #FAFBFC;
  overflow: hidden;
}
.debtor-form-rail-title {
  padding: 14px 15px;
  border-bottom: 1px solid var(--border);
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-form-rail-list {
  padding: 6px;
}
.debtor-form-rail-row {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  gap: 8px;
  align-items: center;
  padding: 8px;
  border-radius: var(--r-md);
  text-decoration: none;
  color: var(--text-2);
  transition: background .16s ease, color .16s ease;
}
.debtor-form-rail-row:hover {
  background: white;
  color: var(--text);
}
.debtor-form-rail-row span {
  width: 24px;
  height: 24px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: var(--ok-soft);
  color: var(--ok);
  font-size: 11px;
  font-weight: 800;
}
.debtor-form-rail-row.is-attention span {
  background: var(--warn-soft);
  color: var(--warn);
}
.debtor-form-rail-row strong {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  font-size: 12.5px;
}
.debtor-form-rail-row small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.debtor-form-rail-alert {
  display: flex;
  gap: 9px;
  margin: 8px;
  padding: 11px;
  border-radius: var(--r-md);
  border: 1px solid rgba(247,144,9,.22);
  background: var(--warn-soft);
  color: #B54708;
}
.debtor-form-rail-alert strong {
  display: block;
  color: #93370D;
  font-size: 12px;
}
.debtor-form-rail-alert p {
  margin: 2px 0 0;
  font-size: 11.5px;
  line-height: 1.4;
}
.debtor-form-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  min-width: 0;
}
.debtor-form-section {
  scroll-margin-top: calc(var(--topbar-h) + 20px);
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: white;
  padding: 17px;
}
.debtor-form-section-head {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 15px;
}
.debtor-form-section-num {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: white;
  background: var(--brand);
  font-size: 12px;
  font-weight: 800;
}
.debtor-form-section-num.is-ok {
  background: var(--brand);
}
.debtor-form-section-num.is-attention {
  background: var(--warn);
}
.debtor-form-section-head h3 {
  margin: 0;
  color: var(--brand-deep);
  font-size: 13px;
  line-height: 1.25;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.1em;
}
.debtor-form-section-head p {
  margin: 3px 0 0;
  color: var(--text-3);
  font-size: 12px;
}
.debtor-form-grid {
  display: grid;
  gap: 13px 14px;
}
.debtor-form-grid.cols-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.debtor-form-grid.cols-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.debtor-form-grid.cols-bank { grid-template-columns: minmax(0, 2fr) minmax(180px, .8fr); }
.debtor-form-grid.cols-contact { grid-template-columns: minmax(240px, 1.35fr) minmax(190px, .9fr) minmax(190px, .9fr); }
.debtor-form-grid.cols-sign { grid-template-columns: minmax(260px, 1.4fr) minmax(180px, .8fr) minmax(170px, .7fr) minmax(170px, .7fr); }
.debtor-form-field.span-full {
  grid-column: 1 / -1;
}
.debtor-form-field label {
  display: flex;
  align-items: center;
  gap: 6px;
}
.debtor-form-field label span {
  color: var(--warn);
  font-size: 10.5px;
  font-weight: 800;
}
.debtor-form-field.is-missing .input {
  border-color: rgba(247,144,9,.7);
  background: #FFFDF5;
}
.debtor-form-field.is-missing .input:focus {
  border-color: var(--warn);
  box-shadow: 0 0 0 4px rgba(247,144,9,.12);
}
.debtor-contact-group + .debtor-contact-group {
  margin-top: 14px;
}
.debtor-contact-role {
  margin: 0 0 8px;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-radio-pair {
  height: 40px;
}
.debtor-form textarea.input {
  min-height: 98px;
  resize: vertical;
}
.signature-state {
  height: 40px;
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 0 12px;
  border: 1px solid rgba(3,152,85,.18);
  border-radius: var(--r-md);
  background: var(--ok-soft);
  color: var(--ok);
  font-size: 12.5px;
  font-weight: 800;
}
.debtor-form-note {
  padding: 13px 16px;
  border-radius: var(--r-lg);
  background: var(--n-50);
  color: var(--text-2);
  font-size: 11.8px;
  line-height: 1.55;
}

@media (max-width: 1280px) {
  .debtor-form-intro {
    flex-direction: column;
    align-items: stretch;
  }
  .debtor-form-intro-side {
    justify-content: flex-start;
  }
  .debtor-kpi-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
  .debtor-chart-grid,
  .debtor-info-grid,
  .debtor-history-grid {
    grid-template-columns: 1fr;
  }
  .debtor-tab-summary,
  .debtor-offer-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .debtor-doc-summary {
    grid-template-columns: minmax(0, 1fr);
    align-items: stretch;
  }
  .debtor-form-grid.cols-3,
  .debtor-form-grid.cols-contact,
  .debtor-form-grid.cols-sign {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 1100px) {
  .debtor-hero-top {
    flex-direction: column;
    align-items: stretch;
  }
  .debtor-hero-actions {
    justify-content: flex-start;
  }
  .debtor-form-layout {
    grid-template-columns: 1fr;
  }
  .debtor-form-rail {
    position: static;
  }
  .debtor-form-rail-list {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .debtor-hero,
  .debtor-overview-tab,
  .debtor-tab-panel,
  .debtor-form {
    padding-left: 16px;
    padding-right: 16px;
  }
  .debtor-kpi-grid,
  .debtor-tab-summary,
  .debtor-offer-grid,
  .debtor-form-grid.cols-2,
  .debtor-form-grid.cols-3,
  .debtor-form-grid.cols-bank,
  .debtor-form-grid.cols-contact,
  .debtor-form-grid.cols-sign,
  .debtor-form-rail-list {
    grid-template-columns: 1fr;
  }
  .debtor-action-note,
  .debtor-offer-banner,
  .debtor-work-head,
  .debtor-chart-summary,
  .recent-invoice-row {
    grid-template-columns: 1fr;
  }
  .debtor-action-note,
  .debtor-offer-banner,
  .debtor-work-head {
    flex-direction: column;
    align-items: flex-start;
  }
  .debtor-doc-row {
    grid-template-columns: 30px minmax(0, 1fr);
  }
  .debtor-doc-date,
  .debtor-doc-row .document-status-badge,
  .debtor-doc-row .btn {
    grid-column: 2;
    justify-self: start;
  }
  .debtor-timeline-row {
    grid-template-columns: 34px minmax(0, 1fr);
  }
  .debtor-timeline-row time {
    grid-column: 2;
    text-align: left;
  }
  .recent-invoice-row {
    display: flex;
    flex-wrap: wrap;
  }
}

/* -------- Suppliers workspace -------- */
.suppliers-screen {
  max-width: 100%;
}
.suppliers-overview {
  margin-bottom: 16px;
  padding: 18px;
  box-shadow: none;
}
.suppliers-overview-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 280px;
  gap: 22px;
  align-items: center;
}
.suppliers-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.suppliers-overview-title {
  color: var(--text);
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
}
.suppliers-overview-copy {
  max-width: 780px;
  margin-top: 7px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.suppliers-overview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.suppliers-overview-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.suppliers-meter-label {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.suppliers-meter-label strong {
  color: var(--brand-deep);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.suppliers-meter-note {
  color: var(--text-3);
  font-size: 12px;
}
.suppliers-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.suppliers-metric {
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}
.suppliers-metric:hover {
  background: white;
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.suppliers-metric.active {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--brand-soft) 100%);
  border-color: rgba(199,42,108,.32);
  box-shadow: 0 0 0 4px rgba(199,42,108,.06);
}
.suppliers-metric span {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.suppliers-metric strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.suppliers-metric small {
  display: block;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 11.5px;
}
.suppliers-add-card {
  margin-bottom: 16px;
  border-color: rgba(199,42,108,.38);
  box-shadow: 0 0 0 4px rgba(199,42,108,.06);
}
.suppliers-form-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 12px;
  align-items: end;
}
.suppliers-form-grid.is-compact {
  grid-template-columns: repeat(4, minmax(0, 1fr));
}
.suppliers-form-actions {
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  grid-column: span 4;
}
.suppliers-form-error {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--bad-soft);
  color: var(--bad);
  font-size: 12.5px;
  font-weight: 700;
  grid-column: 1 / -1;
}
.suppliers-list-card {
  box-shadow: none;
  overflow: visible;
}
.suppliers-list-head {
  display: grid;
  grid-template-columns: minmax(240px, 330px) auto minmax(240px, 1fr);
  align-items: center;
}
.suppliers-search {
  position: relative;
}
.suppliers-search svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  pointer-events: none;
}
.suppliers-search .input {
  height: 34px;
  padding-left: 32px;
  background: white;
}
.suppliers-toolbar-actions {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}
.suppliers-toolbar-actions > span {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
  white-space: nowrap;
}
.suppliers-filter-wrap {
  position: relative;
}
.suppliers-filter-wrap .btn span {
  margin-left: 2px;
  color: inherit;
  font-size: 11px;
  font-weight: 800;
}
.suppliers-filter-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 12;
  width: 360px;
  max-height: min(720px, calc(100vh - 130px));
  overflow-y: auto;
  padding: 14px;
  border: 1px solid rgba(208, 213, 221, .92);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(16, 24, 40, .12);
  scrollbar-gutter: stable;
}
.suppliers-filter-panel-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  align-items: flex-start;
}
.suppliers-filter-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.suppliers-filter-panel-head small {
  display: block;
  max-width: 220px;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.suppliers-filter-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.suppliers-filter-label {
  display: block;
  margin-bottom: 8px;
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .06em;
}
.suppliers-filter-checks {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.suppliers-filter-check {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
  min-height: 36px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 600;
}
.suppliers-filter-check input {
  flex-shrink: 0;
  margin: 0;
  accent-color: var(--brand-deep);
}
.suppliers-filter-check span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.suppliers-filter-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.suppliers-filter-range-values,
.suppliers-filter-range-scale {
  display: flex;
  justify-content: space-between;
  gap: 12px;
}
.suppliers-filter-range-values strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.suppliers-filter-range input[type="range"] {
  width: 100%;
  margin: 8px 0 0;
  accent-color: var(--brand-deep);
}
.suppliers-filter-range-scale {
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
}
.suppliers-filter-panel-foot {
  position: sticky;
  bottom: -14px;
  z-index: 1;
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  margin: 16px -14px -14px;
  padding: 12px 14px;
  border-top: 1px solid var(--border);
  border-radius: 0 0 12px 12px;
  background: linear-gradient(180deg, rgba(255, 255, 255, .94) 0%, #fff 34%);
}
.suppliers-export-wrap {
  position: relative;
}
.suppliers-export-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 12;
  width: 340px;
  padding: 14px;
  border: 1px solid rgba(208, 213, 221, .92);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(16, 24, 40, .12);
}
.suppliers-export-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.suppliers-export-panel-head small {
  display: block;
  max-width: 285px;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.suppliers-export-section {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.suppliers-export-scope {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.suppliers-export-scope button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  min-width: 0;
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 700;
  transition: border-color .16s ease, background .16s ease, color .16s ease, box-shadow .16s ease;
}
.suppliers-export-scope button span {
  min-width: 0;
  overflow: hidden;
  color: inherit;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.suppliers-export-scope button strong {
  flex-shrink: 0;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.suppliers-export-scope button.active {
  border-color: rgba(199, 42, 108, .2);
  background: rgba(199, 42, 108, .06);
  color: var(--brand-deep);
  box-shadow: inset 0 0 0 1px rgba(199, 42, 108, .06);
}
.suppliers-export-scope button:disabled {
  opacity: .54;
  cursor: not-allowed;
}
.suppliers-export-format {
  width: fit-content;
}
.suppliers-export-note {
  margin-top: 10px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.suppliers-export-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.suppliers-export-panel-foot > span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}
.supplier-list-table {
  overflow-x: auto;
}
.supplier-row {
  display: grid;
  grid-template-columns: 28px minmax(204px, 1.4fr) 88px 82px 124px 52px 84px 138px 50px;
  gap: 10px;
  align-items: center;
  min-width: 900px;
  padding: 13px 18px;
  border-top: 1px solid var(--border);
  background: white;
  transition: background .16s ease, box-shadow .16s ease;
}
.supplier-row:hover {
  background: #FAFBFC;
}
.supplier-row.is-selected {
  background: linear-gradient(180deg, rgba(252,231,240,.65) 0%, rgba(255,255,255,.96) 100%);
  box-shadow: inset 3px 0 0 var(--brand);
}
.supplier-row.is-editing {
  background: #FCFCFD;
}
.supplier-row-head {
  background: #F8F9FB;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.supplier-row-head:hover {
  background: #F8F9FB;
}
.supplier-select-cell {
  display: grid;
  place-items: center;
}
.supplier-select-cell input {
  width: 15px;
  height: 15px;
  margin: 0;
  accent-color: var(--brand-deep);
}
.supplier-main-cell {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}
.supplier-avatar {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-deep);
  background: var(--brand-soft);
  border: 1px solid rgba(199,42,108,.16);
  font-size: 12px;
  font-weight: 800;
}
.supplier-name {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.supplier-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}
.supplier-category {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.supplier-delay-cell {
  display: flex;
  align-items: baseline;
  gap: 5px;
  color: var(--text-3);
}
.supplier-delay-cell strong {
  color: var(--text);
  font-size: 18px;
  line-height: 1;
  font-weight: 800;
}
.supplier-delay-cell span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.supplier-limit-cell {
  min-width: 0;
}
.supplier-limit-line {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
  color: var(--text-3);
  font-size: 11.5px;
  white-space: nowrap;
}
.supplier-limit-line strong {
  color: var(--text);
  font-weight: 800;
}
.supplier-limit-bar {
  height: 4px;
  margin-top: 6px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--n-100);
}
.supplier-limit-bar i {
  display: block;
  height: 100%;
  border-radius: 99px;
  background: var(--brand);
}
.supplier-history {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 800;
}
.supplier-history.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.supplier-history.is-muted {
  color: var(--text-3);
  background: var(--n-100);
  border-color: var(--border);
}
.supplier-last-cell strong {
  display: block;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.supplier-last-cell span {
  display: block;
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}
.supplier-status {
  display: inline-flex;
  width: fit-content;
  max-width: 100%;
  align-items: center;
  gap: 5px;
  height: 24px;
  padding: 0 9px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 800;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.supplier-status svg {
  flex-shrink: 0;
}
.supplier-status.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.supplier-status.is-attention {
  color: #B54708;
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.20);
}
.supplier-status.is-draft {
  color: var(--text-2);
  background: var(--n-100);
  border-color: var(--border);
}
.supplier-status.is-neutral {
  color: var(--brand-deep);
  background: var(--brand-soft);
  border-color: rgba(199,42,108,.16);
}
.supplier-actions {
  display: flex;
  gap: 4px;
  justify-content: flex-end;
  position: relative;
}
.supplier-row-menu {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 14;
  width: 220px;
  display: grid;
  gap: 4px;
  padding: 8px;
  border: 1px solid rgba(208,213,221,.92);
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 18px 40px rgba(16,24,40,.12);
}
.supplier-row-menu button {
  display: flex;
  align-items: center;
  gap: 8px;
  width: 100%;
  min-height: 34px;
  padding: 0 10px;
  border: 0;
  border-radius: 8px;
  background: transparent;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 700;
  text-align: left;
}
.supplier-row-menu button:hover {
  background: var(--surface-2);
}
.supplier-edit-row {
  padding: 0 18px 16px 18px;
  border-top: 1px dashed rgba(199,42,108,.18);
  background: #FCFCFD;
}
.supplier-edit-card {
  margin-left: 38px;
  padding: 14px;
  border: 1px solid rgba(199,42,108,.24);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,231,240,.45) 100%);
}
.supplier-edit-head {
  display: flex;
  justify-content: space-between;
  gap: 16px;
  align-items: flex-start;
  margin-bottom: 12px;
}
.supplier-edit-head strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.supplier-edit-head small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.supplier-request-drawer {
  width: min(560px, calc(100vw - 28px));
}
.supplier-request-pill {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.supplier-request-docs {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}
.supplier-request-check {
  display: flex;
  align-items: center;
  gap: 8px;
  min-height: 40px;
  padding: 0 12px;
  border: 1px solid var(--border);
  border-radius: 10px;
  background: #fff;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 700;
}
.supplier-request-check input {
  width: 15px;
  height: 15px;
  margin: 0;
  accent-color: var(--brand-deep);
}
.supplier-request-list {
  display: grid;
  gap: 10px;
  margin-top: 14px;
}
.supplier-request-row {
  display: grid;
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,.84);
}
.supplier-request-row strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.supplier-request-row small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
}
.supplier-request-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.supplier-request-tags span {
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.supplier-request-channel-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
  margin-top: 14px;
}
.supplier-request-channel {
  min-height: 64px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #fff;
  text-align: left;
}
.supplier-request-channel.is-active {
  border-color: rgba(199,42,108,.26);
  background: rgba(199,42,108,.05);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,.06);
}
.supplier-request-channel strong {
  display: block;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.supplier-request-channel small {
  display: block;
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.4;
}
.supplier-request-form-grid {
  display: grid;
  gap: 12px;
  margin-top: 14px;
}
.supplier-request-textarea {
  min-height: 108px;
  resize: vertical;
}

/* -------- Debtor limits workspace -------- */
.debtor-limits-screen {
  max-width: 100%;
}
.debtor-limits-overview {
  margin-bottom: 16px;
  padding: 18px;
  box-shadow: none;
}
.debtor-limits-overview-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 300px;
  gap: 22px;
  align-items: center;
}
.debtor-limits-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-limits-title {
  color: var(--text);
  font-size: 24px;
  line-height: 1.1;
  font-weight: 800;
}
.debtor-limits-copy {
  max-width: 780px;
  margin-top: 7px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.debtor-limits-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.debtor-limits-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.debtor-limits-meter-label {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.debtor-limits-meter-label strong {
  color: var(--brand-deep);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.debtor-limits-meter-note {
  color: var(--text-3);
  font-size: 12px;
}
.debtor-limits-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.debtor-limits-metric {
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}
.debtor-limits-metric:hover {
  background: white;
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.debtor-limits-metric.active {
  background: linear-gradient(180deg, #FFFFFF 0%, var(--ok-soft) 100%);
  border-color: rgba(3,152,85,.24);
  box-shadow: 0 0 0 4px rgba(3,152,85,.05);
}
.debtor-limits-metric span {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.debtor-limits-metric strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.debtor-limits-metric strong small {
  color: var(--text-2);
  font-size: 13px;
  font-weight: 800;
}
.debtor-limits-metric small {
  display: block;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-limits-list-card {
  box-shadow: none;
}
.debtor-limits-list-head {
  display: grid;
  grid-template-columns: minmax(260px, 360px) auto minmax(150px, 1fr);
  align-items: center;
}
.debtor-limits-search {
  position: relative;
}
.debtor-limits-search svg {
  position: absolute;
  left: 10px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  pointer-events: none;
}
.debtor-limits-search .input {
  height: 34px;
  padding-left: 32px;
  background: white;
}
.debtor-limits-toolbar-actions {
  justify-self: end;
  display: flex;
  align-items: center;
  gap: 8px;
}
.debtor-limits-toolbar-actions > span {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
  white-space: nowrap;
}
.debtor-limit-list-table {
  overflow-x: auto;
}
.debtor-limit-row {
  display: grid;
  grid-template-columns: minmax(230px, 1.25fr) 108px 76px 214px minmax(176px, .9fr) 58px 18px;
  gap: 14px;
  align-items: center;
  min-width: 1080px;
  padding: 13px 18px;
  border-top: 1px solid var(--border);
  background: white;
  cursor: pointer;
  transition: background .16s ease;
}
.debtor-limit-row:hover {
  background: #FAFBFC;
}
.debtor-limit-row-head {
  cursor: default;
  background: #F8F9FB;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.debtor-limit-row-head:hover {
  background: #F8F9FB;
}
.debtor-limit-main {
  display: flex;
  align-items: center;
  gap: 11px;
  min-width: 0;
}
.debtor-limit-avatar {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-deep);
  background: var(--brand-soft);
  border: 1px solid rgba(199,42,108,.16);
  font-size: 12px;
  font-weight: 800;
}
.debtor-limit-name {
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
  font-weight: 800;
}
.debtor-limit-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-limit-sector {
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.debtor-limit-rating {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  height: 24px;
  padding: 0 8px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 800;
}
.debtor-limit-rating.is-strong {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.debtor-limit-rating.is-medium {
  color: var(--brand-deep);
  background: var(--brand-soft);
  border-color: rgba(199,42,108,.16);
}
.debtor-limit-rating.is-watch {
  color: #B54708;
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.20);
}
.debtor-limit-rating.is-risk {
  color: var(--bad);
  background: var(--bad-soft);
  border-color: rgba(217,45,32,.20);
}
.debtor-limit-usage {
  min-width: 0;
}
.debtor-limit-usage-top {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 8px;
}
.debtor-limit-usage-top strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-limit-usage-top span {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.debtor-limit-bar {
  height: 4px;
  margin-top: 6px;
  border-radius: 99px;
  overflow: hidden;
  background: var(--n-100);
}
.debtor-limit-bar i {
  display: block;
  height: 100%;
  border-radius: 99px;
  background: var(--brand);
}
.debtor-limit-free {
  margin-top: 5px;
  color: var(--text-3);
  font-size: 11.5px;
}
.debtor-limit-banks {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 5px;
}
.debtor-limit-bank-chip,
.debtor-limit-bank-pending {
  display: inline-flex;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border: 1px solid var(--border);
  border-radius: 6px;
  background: white;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 750;
}
.debtor-limit-bank-pending {
  color: var(--text-3);
  background: var(--n-50);
}
.debtor-limit-dpd {
  display: inline-flex;
  width: fit-content;
  height: 24px;
  align-items: center;
  padding: 0 8px;
  border-radius: 6px;
  font-size: 11.5px;
  font-weight: 800;
  white-space: nowrap;
}
.debtor-limit-dpd.is-ok {
  color: var(--ok);
  background: var(--ok-soft);
}
.debtor-limit-dpd.is-warn {
  color: #B54708;
  background: var(--warn-soft);
}

/* -------- Documents workspace -------- */
.documents-screen {
  max-width: 100%;
}
.documents-overview {
  margin-bottom: 16px;
  padding: 18px;
}
.documents-readiness {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 220px;
  gap: 20px;
  align-items: center;
}
.documents-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.documents-ready-title {
  font-size: 20px;
  line-height: 1.2;
  font-weight: 800;
}
.documents-ready-copy {
  max-width: 720px;
  margin-top: 5px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.documents-readiness-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.documents-readiness-meter strong {
  color: var(--brand-deep);
  font-size: 22px;
  line-height: 1;
  font-weight: 800;
  text-align: right;
}
.documents-summary-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.documents-summary {
  min-width: 0;
  padding: 12px 13px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
  text-align: left;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease, transform .16s ease;
}
.documents-summary:hover {
  background: white;
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.documents-summary.active {
  background: linear-gradient(180deg, #FFFFFF, var(--brand-soft));
  border-color: rgba(199,42,108,.32);
  box-shadow: 0 0 0 4px rgba(199,42,108,.07);
}
.documents-summary-label {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.documents-summary strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.documents-summary span:last-child {
  display: block;
  margin-top: 5px;
  color: var(--text-3);
  font-size: 12px;
}
.documents-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.55fr) minmax(360px, .95fr);
  gap: 16px;
  align-items: flex-start;
}
.documents-list-card,
.documents-upload-card,
.documents-action-card,
.credit-doc-card {
  box-shadow: none;
}
.documents-list-head {
  align-items: flex-end;
}

.documents-archive-action {
  position: relative;
  display: inline-flex;
  align-items: center;
}
.documents-download-all {
  min-width: 128px;
  white-space: nowrap;
}
.documents-archive-action.is-exporting .documents-download-all {
  color: var(--brand-deep);
  border-color: rgba(199,42,108,.24);
  background: linear-gradient(135deg, rgba(252,231,240,.72), #fff);
  box-shadow: 0 0 0 4px rgba(199,42,108,.07);
  cursor: wait;
}
.documents-archive-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  z-index: 55;
  width: 306px;
  padding: 12px;
  border: 1px solid rgba(208,213,221,.9);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.98);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(14px);
}
.documents-archive-panel:before {
  content: "";
  position: absolute;
  top: -6px;
  right: 34px;
  width: 10px;
  height: 10px;
  border-left: 1px solid rgba(208,213,221,.9);
  border-top: 1px solid rgba(208,213,221,.9);
  background: rgba(255,255,255,.98);
  transform: rotate(45deg);
}
.documents-archive-title {
  padding: 1px 2px 9px;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.documents-archive-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.documents-archive-item {
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 9px;
  align-items: flex-start;
  padding: 8px;
  border-radius: var(--r-md);
  background: #FAFBFC;
  border: 1px solid transparent;
}
.documents-archive-item:first-child {
  background: var(--brand-soft);
  border-color: rgba(199,42,108,.12);
}
.documents-archive-item > span {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: white;
  color: var(--brand-deep);
  border: 1px solid rgba(199,42,108,.12);
}
.documents-archive-item strong,
.documents-archive-item small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.documents-archive-item strong {
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.25;
  font-weight: 800;
}
.documents-archive-item small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.25;
}
.documents-archive-toast {
  position: fixed;
  top: 78px;
  right: 24px;
  z-index: 92;
  width: min(420px, calc(100vw - 48px));
  display: grid;
  grid-template-columns: auto minmax(0, 1fr) auto;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 14px 13px 12px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-xl);
  background: rgba(255,255,255,.97);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(16px);
}
.documents-archive-toast.is-success {
  border-color: rgba(3,152,85,.18);
}
.documents-archive-toast.is-error {
  border-color: rgba(247,144,9,.24);
}
.documents-archive-toast-icon {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  display: grid;
  place-items: center;
  color: var(--brand-deep);
  background: var(--brand-soft);
}
.documents-archive-toast.is-success .documents-archive-toast-icon {
  color: var(--ok);
  background: var(--ok-soft);
}
.documents-archive-toast.is-error .documents-archive-toast-icon {
  color: var(--warn);
  background: var(--warn-soft);
}
.documents-archive-toast-main {
  min-width: 0;
}
.documents-archive-toast-title {
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.25;
  font-weight: 800;
}
.documents-archive-toast-copy {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12.5px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.documents-archive-toast-progress {
  height: 6px;
  margin-top: 10px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(152,162,179,.18);
}
.documents-archive-toast-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-gradient);
  transition: width .22s ease;
}
.documents-archive-toast.is-error .documents-archive-toast-progress i {
  background: var(--warn);
}
.documents-archive-toast-close {
  width: 26px;
  min-width: 26px;
  padding: 0;
  justify-content: center;
}
.doc-tabs {
  display: flex;
  gap: 4px;
  padding: 3px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-100);
}
.doc-tabs button {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 30px;
  padding: 0 10px;
  border: 0;
  border-radius: 6px;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
  transition: background .16s ease, color .16s ease, box-shadow .16s ease;
}
.doc-tabs button.active {
  background: white;
  color: var(--brand-deep);
  box-shadow: var(--shadow-xs);
}
.doc-tabs button span {
  color: var(--text-3);
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.documents-list {
  display: flex;
  flex-direction: column;
}
.document-row {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr) auto 32px;
  gap: 14px;
  align-items: center;
  padding: 13px 18px;
  border-top: 1px solid var(--border);
  background: white;
  transition: background .16s ease;
}
.document-row:first-child { border-top: 0; }
.document-row:hover { background: #FAFBFC; }
.document-status-mark {
  width: 28px;
  height: 28px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  border: 1px solid transparent;
}
.document-row.is-done .document-status-mark {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.18);
}
.document-row.is-review .document-status-mark {
  color: var(--text-2);
  background: var(--n-100);
  border-color: var(--border);
}
.document-row.is-attention .document-status-mark {
  color: var(--warn);
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.24);
}
.document-row.is-missing .document-status-mark {
  color: var(--bad);
  background: var(--bad-soft);
  border-color: rgba(217,45,32,.22);
}
.document-main {
  min-width: 0;
}
.document-name {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 700;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.document-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}
.document-status-badge {
  justify-self: end;
  display: inline-flex;
  align-items: center;
  height: 24px;
  padding: 0 9px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 700;
  white-space: nowrap;
}
.document-status-badge.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.document-status-badge.is-review {
  color: var(--text-2);
  background: var(--n-100);
  border-color: var(--border);
}
.document-status-badge.is-attention {
  color: #B54708;
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.20);
}
.document-status-badge.is-missing {
  color: var(--bad);
  background: var(--bad-soft);
  border-color: rgba(217,45,32,.18);
}
.document-more {
  width: 30px;
  padding: 0;
  justify-content: center;
}
.documents-rail {
  position: sticky;
  top: calc(var(--topbar-h) + 96px);
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.documents-upload-zone {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  padding: 16px;
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: #FAFBFC;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, box-shadow .16s ease;
}
.documents-upload-zone:hover {
  border-color: rgba(199,42,108,.38);
  background: white;
  box-shadow: 0 0 0 4px rgba(199,42,108,.06);
}
.documents-upload-icon {
  width: 38px;
  height: 38px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: var(--brand-soft);
  color: var(--brand-deep);
  flex-shrink: 0;
}
.documents-upload-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.documents-upload-copy {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.documents-uploaded {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
}
.upload-file {
  margin: 0;
}
.upload-file-main {
  flex: 1;
  min-width: 0;
}
.upload-progress {
  flex: 0 0 96px;
}
.upload-percent {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}
.doc-item .doc-ic.pdf {
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.doc-item .doc-ic.xml {
  background: var(--ok-soft);
  color: var(--ok);
}
.documents-action-card {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 12px;
  padding: 16px;
  background: linear-gradient(135deg, var(--warn-soft), white 72%);
}
.documents-action-mark {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  background: white;
  color: var(--warn);
  border: 1px solid rgba(247,144,9,.22);
}
.documents-action-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.documents-action-copy {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.credit-doc-status {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 0 10px;
}
.credit-doc-status span:first-of-type {
  flex: 1;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}
.credit-doc-kv {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  font-size: 13px;
}
.credit-doc-kv + .credit-doc-kv {
  margin-top: 7px;
}
.credit-doc-kv span {
  color: var(--text-2);
}

/* -------- Credit load workspace -------- */
.credit-screen {
  max-width: 100%;
}
.credit-overview {
  margin-bottom: 16px;
  padding: 18px;
}
.credit-overview-main {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 22px;
  align-items: center;
}
.credit-kicker {
  display: inline-flex;
  width: fit-content;
  margin-bottom: 8px;
  padding: 4px 8px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.credit-overview-title {
  color: var(--text);
  font-size: 28px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.credit-overview-copy {
  max-width: 760px;
  margin-top: 8px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.credit-overview-meter {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.credit-meter-label {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.credit-meter-label strong {
  color: var(--brand-deep);
  font-size: 13px;
  font-variant-numeric: tabular-nums;
}
.credit-metric-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
  margin-top: 16px;
}
.credit-metric {
  min-width: 0;
  padding: 13px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
}
.credit-metric span {
  display: block;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.credit-metric strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.credit-metric small {
  display: block;
  margin-top: 6px;
  color: var(--text-3);
  font-size: 11.5px;
}
.credit-layout {
  display: grid;
  gap: 16px;
}
.credit-contracts-card,
.credit-action-card,
.credit-policy-card {
  box-shadow: none;
}
.credit-contracts-head {
  align-items: flex-end;
}
.credit-contract-list {
  display: flex;
  flex-direction: column;
}
.credit-contract-row {
  display: grid;
  grid-template-columns: minmax(150px, 1.05fr) minmax(145px, 1fr) 96px 96px 128px 72px 90px minmax(120px, .9fr) 30px;
  gap: 12px;
  align-items: center;
  padding: 14px 18px;
  border-top: 1px solid var(--border);
  background: white;
  transition: background .16s ease;
}
.credit-contract-row:hover {
  background: #FAFBFC;
}
.credit-contract-row.is-selected {
  background: linear-gradient(90deg, rgba(199,42,108,.08), rgba(255,255,255,.98) 26%);
  box-shadow: inset 3px 0 0 var(--brand);
}
.credit-contract-row:first-child {
  border-top: 0;
}
.credit-contract-title {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.credit-contract-meta {
  margin-top: 3px;
  color: var(--text-3);
  font-size: 10.5px;
}
.credit-contract-purpose div {
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}
.credit-contract-purpose span,
.credit-contract-money span,
.credit-contract-rate span,
.credit-util-head span {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 650;
}
.credit-contract-money strong,
.credit-contract-rate strong {
  display: block;
  margin-top: 3px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.credit-util-head {
  display: flex;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 6px;
}
.credit-util-head strong {
  color: var(--text-2);
  font-size: 11.5px;
}
.credit-contract-term {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.45;
}
.credit-contract-term strong {
  display: block;
  color: var(--text-2);
  font-weight: 700;
}
.credit-contract-collateral {
  display: flex;
  flex-direction: column;
  gap: 6px;
  min-width: 0;
}
.credit-contract-collateral small {
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.35;
}
.credit-status {
  display: inline-flex;
  width: fit-content;
  align-items: center;
  height: 22px;
  padding: 0 8px;
  border-radius: 6px;
  border: 1px solid transparent;
  font-size: 11.5px;
  font-weight: 700;
  white-space: nowrap;
}
.credit-status.is-done {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.16);
}
.credit-status.is-closed {
  color: var(--text-2);
  background: var(--n-100);
  border-color: var(--border);
}
.credit-contract-more {
  width: 30px;
  padding: 0;
  justify-content: center;
}
.credit-detail-overlay {
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(16,24,40,.22);
}
.credit-detail-drawer {
  position: absolute;
  top: 76px;
  right: 22px;
  bottom: 22px;
  width: min(520px, calc(100vw - 28px));
  display: flex;
  flex-direction: column;
  border: 1px solid rgba(16,24,40,.08);
  border-radius: 20px;
  background:
    linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,252,253,.98) 100%),
    radial-gradient(circle at top right, rgba(199,42,108,.08), transparent 28%);
  box-shadow: 0 24px 64px rgba(16,24,40,.18);
  overflow: hidden;
}
.credit-detail-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 20px 20px 18px;
  border-bottom: 1px solid var(--border);
}
.credit-detail-bank {
  min-width: 0;
  display: flex;
  align-items: flex-start;
  gap: 12px;
}
.credit-detail-kicker {
  color: var(--brand-deep);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
}
.credit-detail-bank h3 {
  margin: 6px 0 0;
  color: var(--text);
  font-size: 22px;
  line-height: 1.15;
  font-weight: 800;
}
.credit-detail-sub {
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.credit-detail-head-meta {
  display: flex;
  align-items: center;
  gap: 10px;
}
.credit-detail-body {
  flex: 1;
  overflow: auto;
  padding: 18px 20px 20px;
}
.credit-detail-metrics {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.credit-detail-metric {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,.82);
}
.credit-detail-metric span,
.credit-detail-field span,
.credit-detail-section-head span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 750;
}
.credit-detail-metric strong {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-size: 19px;
  line-height: 1.1;
  font-weight: 800;
}
.credit-detail-section {
  margin-top: 16px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,.78);
}
.credit-detail-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 12px;
}
.credit-detail-section-head h4 {
  margin: 0;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.credit-detail-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}
.credit-detail-field strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.45;
  font-weight: 700;
}
.credit-detail-progress {
  margin-top: 14px;
}
.credit-detail-note {
  margin-top: 14px;
  padding: 14px;
  border-radius: 12px;
  background: var(--ok-soft);
}
.credit-detail-note.is-muted {
  background: var(--surface-2);
}
.credit-detail-note strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.credit-detail-note p {
  margin: 7px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.55;
}
.credit-detail-foot {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  padding: 16px 20px 20px;
  border-top: 1px solid var(--border);
  background: rgba(255,255,255,.94);
}
body.drawer-open {
  overflow: hidden;
}
@media (max-width: 1180px) {
  .credit-detail-drawer {
    top: 68px;
    right: 12px;
    bottom: 12px;
    width: min(480px, calc(100vw - 24px));
  }
}
@media (max-width: 760px) {
  .credit-detail-drawer {
    top: auto;
    left: 8px;
    right: 8px;
    bottom: 8px;
    width: auto;
    border-radius: 18px;
  }
  .credit-detail-head,
  .credit-detail-foot {
    padding-left: 16px;
    padding-right: 16px;
  }
  .credit-detail-body {
    padding: 16px;
  }
  .credit-detail-metrics,
  .credit-detail-grid {
    grid-template-columns: 1fr;
  }
  .credit-detail-head {
    flex-direction: column;
  }
  .credit-detail-head-meta {
    width: 100%;
    justify-content: space-between;
  }
}
.credit-rail {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}
.credit-action-card {
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 16px;
  background: white;
}
.credit-action-card .btn {
  grid-column: 2;
  width: fit-content;
}
.credit-action-card.is-warning {
  background: linear-gradient(135deg, var(--warn-soft), white 76%);
}
.credit-action-mark {
  width: 30px;
  height: 30px;
  border-radius: 7px;
  display: grid;
  place-items: center;
  color: var(--brand-deep);
  background: var(--brand-soft);
  border: 1px solid rgba(199,42,108,.16);
}
.credit-action-card.is-warning .credit-action-mark {
  color: var(--warn);
  background: white;
  border-color: rgba(247,144,9,.22);
}
.credit-action-title {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.credit-action-copy {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.credit-policy-row {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 13px;
}
.credit-policy-row + .credit-policy-row {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.credit-policy-row strong {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}

/* -------- Signing flow -------- */
.sign-screen {
  max-width: 100%;
}
.sign-back {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  margin-bottom: 12px;
  padding: 0;
  border: 0;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 650;
}
.sign-back:hover {
  color: var(--brand-deep);
}
.sign-header {
  align-items: flex-start;
}
.sign-stepper-card {
  margin-bottom: 18px;
  box-shadow: none;
}
.sign-stepper {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
  padding: 18px 28px;
}
.sign-step {
  position: relative;
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
  border: 0;
  background: transparent;
  text-align: left;
  color: var(--text-3);
}
.sign-step::before {
  content: "";
  position: absolute;
  top: 18px;
  left: 38px;
  right: 0;
  height: 2px;
  background: var(--n-150);
  transform: translateX(22px);
}
.sign-step:last-child::before {
  display: none;
}
.sign-step.is-done::before {
  background: var(--ok);
}
.sign-step-dot {
  position: relative;
  z-index: 1;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--text-3);
  background: var(--n-100);
  border: 3px solid white;
  font-weight: 800;
  box-shadow: 0 0 0 1px var(--border);
}
.sign-step.is-done .sign-step-dot {
  background: var(--ok);
  color: white;
  box-shadow: 0 0 0 1px rgba(3,152,85,.22);
}
.sign-step.is-active .sign-step-dot {
  background: var(--brand);
  color: white;
  box-shadow: 0 0 0 5px rgba(199,42,108,.12);
}
.sign-step-copy {
  display: flex;
  min-width: 0;
  flex-direction: column;
  gap: 2px;
}
.sign-step-copy strong {
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.2;
  font-weight: 800;
}
.sign-step.is-active .sign-step-copy strong,
.sign-step.is-done .sign-step-copy strong {
  color: var(--text);
}
.sign-step-copy small {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.25;
}
.sign-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 390px);
  gap: 16px;
  align-items: flex-start;
}
.sign-stage-card,
.sign-params-card,
.sign-next-card {
  box-shadow: none;
}
.sign-card-head {
  background: white;
}
.sign-review-body {
  display: flex;
  flex-direction: column;
}
.sign-contract {
  max-height: 510px;
  overflow-y: auto;
  padding: 24px 28px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.72;
}
.sign-contract h3 {
  margin: 22px 0 8px;
  color: var(--text);
  font-size: 14.5px;
  line-height: 1.25;
  font-weight: 800;
}
.sign-contract h3:first-child {
  margin-top: 0;
}
.sign-contract p {
  margin: 0;
}
.sign-contract strong {
  color: var(--text);
}
.sign-accept-box {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 14px 18px;
  border-top: 1px solid var(--border);
  background: #FCFCFD;
}
.sign-signature-body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.sign-person-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
}
.sign-person-card span,
.sign-cert-grid span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.sign-person-card strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
}
.sign-person-card small {
  display: block;
  margin-top: 2px;
  color: var(--text-2);
  font-size: 12px;
}
.sign-cert-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.sign-cert-grid div {
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
}
.sign-cert-grid strong {
  display: block;
  margin-top: 5px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.sign-signature-pad {
  height: 132px;
  border: 1.5px dashed var(--border-strong);
  border-radius: var(--r-lg);
  display: grid;
  place-items: center;
  background: white;
  color: var(--brand-purple);
  font-family: "Caveat", cursive;
  font-size: 42px;
}
.sign-state-panel {
  min-height: 420px;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 52px;
  text-align: center;
}
.sign-state-icon {
  width: 82px;
  height: 82px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  margin-bottom: 22px;
}
.sign-state-icon.is-waiting {
  color: var(--brand-deep);
  background: var(--brand-soft);
}
.sign-state-icon.is-funded {
  color: white;
  background: var(--ok);
  box-shadow: 0 14px 36px rgba(3,152,85,.18);
}
.sign-state-panel h3 {
  margin: 0;
  max-width: 620px;
  color: var(--text);
  font-size: 24px;
  line-height: 1.2;
  font-weight: 800;
}
.sign-state-panel p {
  max-width: 510px;
  margin: 12px auto 22px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.6;
}
.sign-state-panel p strong {
  color: var(--text);
}
.sign-timeline {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  width: min(100%, 560px);
  gap: 10px;
  margin-bottom: 22px;
}
.sign-timeline div {
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FAFBFC;
}
.sign-timeline span {
  display: block;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}
.sign-timeline strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.sign-funded-actions {
  display: flex;
  justify-content: center;
  gap: 10px;
}
.sign-side {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.sign-params-card {
  position: sticky;
  top: calc(var(--topbar-h) + 92px);
}
.sign-partner-row {
  display: flex;
  align-items: center;
  gap: 11px;
  margin-bottom: 14px;
}
.sign-hidden-partner {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  color: var(--brand-purple-deep);
  background: var(--brand-purple-soft);
  font-weight: 800;
}
.sign-partner-name {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.sign-partner-sub {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 12px;
}
.sign-payout .v {
  color: var(--brand-deep);
  font-size: 16px;
  font-weight: 800;
}
.sign-next-card {
  padding: 16px 18px;
  border-color: rgba(199,42,108,.16);
  background:
    linear-gradient(135deg, rgba(199,42,108,.06), rgba(255,255,255,0) 70%),
    white;
}
.sign-next-label {
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.sign-next-title {
  margin-top: 6px;
  color: var(--text);
  font-size: 16px;
  font-weight: 800;
}
.sign-next-card p {
  margin: 6px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}

/* -------- Settings -------- */
.settings-screen {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.settings-overview {
  padding: 20px;
  display: grid;
  grid-template-columns: minmax(0, 1.12fr) minmax(540px, .92fr);
  gap: 22px;
  align-items: stretch;
  background:
    linear-gradient(135deg, rgba(199,42,108,.075), rgba(156,100,158,.045) 44%, rgba(255,255,255,0) 72%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  border-color: rgba(199,42,108,.10);
}
.settings-overview-main {
  min-height: 142px;
  padding: 8px 4px 6px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.settings-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  width: fit-content;
  height: 24px;
  padding: 0 9px;
  border-radius: var(--r-pill);
  color: var(--brand-deep);
  background: var(--brand-soft);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-overview-title {
  margin-top: 12px;
  color: var(--text);
  font-size: 24px;
  line-height: 1.15;
  font-weight: 800;
}
.settings-overview-copy {
  max-width: 620px;
  margin-top: 7px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.55;
}
.settings-overview-context {
  max-width: 640px;
  margin-top: 16px;
  padding: 14px 16px;
  border: 1px solid rgba(199,42,108,.10);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.72);
  box-shadow: var(--shadow-xs);
  backdrop-filter: blur(10px);
}
.settings-overview-context strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-overview-context span {
  display: block;
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.settings-overview-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 16px;
}
.settings-overview-pill {
  min-height: 28px;
  padding: 0 11px;
  border: 1px solid rgba(16,24,40,.08);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.78);
  color: var(--text-2);
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-size: 11.5px;
  font-weight: 700;
  backdrop-filter: blur(10px);
}
.settings-overview-pill.is-brand {
  border-color: rgba(199,42,108,.18);
  color: var(--brand-deep);
  background: rgba(255,247,250,.92);
}
.settings-overview-pill.is-ok {
  border-color: rgba(3,152,85,.18);
  color: var(--ok);
  background: rgba(243,255,248,.96);
}
.settings-overview-flow {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.settings-overview-flow span {
  height: 26px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  background: rgba(255,255,255,.72);
  color: var(--text-2);
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  font-weight: 800;
}
.settings-overview-flow span.is-done {
  border-color: rgba(3,152,85,.18);
  background: var(--ok-soft);
  color: var(--ok);
}
.settings-summary-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 10px;
}
.settings-summary {
  min-height: 126px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
  box-shadow: var(--shadow-xs);
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.settings-summary:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.settings-summary span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.settings-summary strong {
  margin-top: 8px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-summary small {
  margin-top: 8px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
}
.settings-summary.is-brand {
  border-color: rgba(199,42,108,.20);
  background: linear-gradient(180deg, #FFF7FA 0%, #FFFFFF 75%);
}
.settings-summary.is-brand strong { color: var(--brand-deep); }
.settings-summary.is-ok {
  border-color: rgba(3,152,85,.18);
  background: linear-gradient(180deg, #F3FFF8 0%, #FFFFFF 75%);
}
.settings-summary.is-ok strong { color: var(--ok); }
.settings-summary.is-purple strong { color: var(--brand-purple-deep); }
.settings-layout {
  display: grid;
  grid-template-columns: 248px minmax(0, 1fr);
  gap: 16px;
  align-items: start;
}
.settings-nav-card {
  position: sticky;
  top: calc(var(--topbar-h) + 76px);
  padding: 8px;
  box-shadow: var(--shadow-xs);
}
.settings-nav-meta {
  margin: 2px 2px 10px;
  padding: 13px 13px 14px;
  border-radius: calc(var(--r-md) + 2px);
  background:
    linear-gradient(145deg, rgba(199,42,108,.09), rgba(255,255,255,0) 62%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  border: 1px solid rgba(199,42,108,.10);
}
.settings-nav-meta span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.settings-nav-meta strong {
  display: block;
  margin-top: 7px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.15;
  font-weight: 800;
}
.settings-nav-meta small {
  display: block;
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 600;
}
.settings-nav-item {
  width: 100%;
  border: none;
  border-left: 3px solid transparent;
  border-radius: var(--r-md);
  background: transparent;
  color: var(--text-2);
  padding: 11px 11px 11px 12px;
  display: grid;
  grid-template-columns: 32px minmax(0, 1fr);
  gap: 11px;
  align-items: center;
  text-align: left;
  transition: background .14s ease, color .14s ease, transform .14s ease, border-color .14s ease;
}
.settings-nav-item:hover {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  color: var(--text);
}
.settings-nav-item:active { transform: translateY(1px); }
.settings-nav-item.active {
  border-left-color: var(--brand);
  background: linear-gradient(180deg, rgba(255,247,250,.96) 0%, rgba(255,251,253,.92) 100%);
  color: var(--brand-deep);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,.08);
}
.settings-nav-icon {
  width: 32px;
  height: 32px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #F8FAFC 0%, #F2F4F7 100%);
  color: var(--text-2);
  border: 1px solid rgba(16,24,40,.05);
}
.settings-nav-item.active .settings-nav-icon {
  background: white;
  color: var(--brand-deep);
  border-color: rgba(199,42,108,.10);
}
.settings-nav-text strong {
  display: block;
  color: inherit;
  font-size: 13.5px;
  line-height: 1.1;
  font-weight: 800;
}
.settings-nav-text small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.1;
  font-weight: 600;
}
.settings-nav-item.active .settings-nav-text small { color: rgba(180,35,101,.68); }
.settings-content {
  min-width: 0;
}
.settings-panel-card {
  box-shadow: var(--shadow-xs);
}
.settings-panel-head {
  min-height: 62px;
}
.settings-head-actions {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.settings-save-status {
  min-height: 28px;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: 999px;
  background: var(--n-25);
  color: var(--text-2);
  font-size: 12px;
  line-height: 1;
  font-weight: 800;
  white-space: nowrap;
}
.settings-save-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: currentColor;
  box-shadow: 0 0 0 3px rgba(199,42,108,.10);
}
.settings-save-status.is-dirty {
  border-color: rgba(199,42,108,.20);
  background: rgba(199,42,108,.07);
  color: var(--brand-deep);
}
.settings-save-status.is-saved {
  border-color: rgba(3,152,85,.18);
  background: var(--ok-soft);
  color: var(--ok);
}
.settings-save-status.is-error {
  border-color: rgba(217,45,32,.22);
  background: var(--bad-soft);
  color: var(--bad);
}
.settings-save-status.is-neutral {
  border-color: var(--border);
  background: var(--n-50);
  color: var(--text-2);
}
.settings-save-btn.is-attention {
  box-shadow: 0 10px 22px rgba(199,42,108,.18);
}
.settings-profile-feedback {
  display: flex;
  align-items: center;
  gap: 9px;
  min-height: 38px;
  margin-bottom: 14px;
  padding: 10px 12px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: rgba(199,42,108,.06);
  color: var(--brand-deep);
  font-size: 12.5px;
  line-height: 1.35;
  font-weight: 700;
}
.settings-profile-feedback svg {
  flex: 0 0 auto;
}
.settings-profile-feedback.is-saved {
  border-color: rgba(3,152,85,.18);
  background: var(--ok-soft);
  color: var(--ok);
}
.settings-profile-feedback.is-error {
  border-color: rgba(217,45,32,.22);
  background: var(--bad-soft);
  color: var(--bad);
}
.settings-profile-feedback.is-neutral {
  border-color: var(--border);
  background: var(--n-50);
  color: var(--text-2);
}
.settings-field-error > .input,
.settings-field-error > select.input,
.settings-field-error > textarea.input {
  border-color: var(--bad);
  background: var(--bad-soft);
}
.settings-field-error > .input:focus,
.settings-field-error > select.input:focus,
.settings-field-error > textarea.input:focus {
  border-color: var(--bad);
  box-shadow: 0 0 0 4px var(--bad-soft);
}
.settings-profile-body {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 292px;
  gap: 22px;
  align-items: start;
}
.settings-profile-main {
  min-width: 0;
}
.settings-profile-intro {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
  margin-bottom: 16px;
}
.settings-profile-stat {
  min-height: 116px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background:
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
}
.settings-profile-stat span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-profile-stat strong {
  display: block;
  margin-top: 14px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.2;
  font-weight: 800;
}
.settings-profile-stat small {
  display: block;
  margin-top: 7px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.settings-form-section {
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
}
.settings-form-section + .settings-form-section {
  margin-top: 14px;
}
.settings-section-heading {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}
.settings-section-heading p {
  max-width: 560px;
  margin: 6px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.settings-section-label {
  margin-bottom: 12px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-form-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.settings-wide {
  grid-column: 1 / -1;
}
.settings-profile-rail {
  display: flex;
  flex-direction: column;
  gap: 12px;
  position: sticky;
  top: calc(var(--topbar-h) + 76px);
}
.settings-readiness,
.settings-next-box,
.settings-checklist {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FCFCFD;
}
.settings-readiness {
  padding: 14px;
}
.settings-readiness > div {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 10px;
}
.settings-readiness span,
.settings-next-box > span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-readiness strong {
  color: var(--brand-deep);
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-readiness small {
  display: block;
  margin-top: 10px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.settings-checklist {
  overflow: hidden;
}
.settings-checklist > div {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  column-gap: 9px;
  row-gap: 2px;
  align-items: start;
  padding: 12px 14px;
  border-top: 1px solid var(--border);
}
.settings-checklist > div:first-child {
  border-top: none;
}
.settings-checklist svg {
  margin-top: 1px;
}
.settings-checklist .is-ok svg { color: var(--ok); }
.settings-checklist .is-warn svg { color: var(--warn); }
.settings-checklist span {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.settings-checklist small {
  grid-column: 2;
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 600;
}
.settings-next-box {
  padding: 14px;
  background:
    linear-gradient(135deg, rgba(199,42,108,.07), rgba(255,255,255,0) 64%),
    #FFFFFF;
}
.settings-next-box strong {
  display: block;
  margin: 7px 0 12px;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-next-box .btn {
  width: 100%;
  justify-content: center;
}
.settings-table th {
  background: #F8FAFC;
}
.settings-table {
  min-width: 820px;
}
.settings-table td,
.settings-table th {
  padding-left: 16px;
  padding-right: 16px;
}
.settings-audit-card {
  overflow: hidden;
}
.settings-audit-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.25fr) minmax(320px, .95fr);
  gap: 16px;
  padding: 18px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(199,42,108,.09), transparent 38%),
    linear-gradient(135deg, rgba(199,42,108,.05), rgba(156,100,158,.035) 48%, rgba(255,255,255,.96) 100%);
}
.settings-audit-hero-copy {
  max-width: 760px;
}
.settings-audit-kicker {
  display: inline-flex;
  align-items: center;
  padding: 6px 10px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(199,42,108,.12);
  background: rgba(255,255,255,.76);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-audit-hero-copy strong {
  display: block;
  margin-top: 12px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.32;
  font-weight: 800;
}
.settings-audit-hero-copy p {
  margin: 8px 0 0;
  color: var(--text-2);
  font-size: 12.75px;
  line-height: 1.6;
}
.settings-audit-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  align-self: stretch;
}
.settings-audit-stat {
  min-height: 112px;
  padding: 14px 14px 15px;
  border: 1px solid rgba(208,213,221,.92);
  border-radius: var(--r-lg);
  background: rgba(255,255,255,.92);
  box-shadow: var(--shadow-xs);
}
.settings-audit-stat span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-audit-stat strong {
  display: block;
  margin-top: 18px;
  color: var(--text);
  font-size: 22px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-audit-stat small {
  display: block;
  margin-top: 10px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.settings-audit-export-wrap {
  position: relative;
}
.settings-audit-export-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 12;
  width: 352px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #FFFFFF;
  box-shadow: var(--shadow-lg);
}
.settings-audit-export-head strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.settings-audit-export-head small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.settings-audit-export-section + .settings-audit-export-section {
  margin-top: 14px;
}
.settings-audit-export-scope {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.settings-audit-export-scope button {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 11px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #FCFCFD;
  color: var(--text-2);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, transform .16s ease;
}
.settings-audit-export-scope button:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.18);
  background: #FFFFFF;
}
.settings-audit-export-scope button strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
  line-height: 1.1;
}
.settings-audit-export-scope button span {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.settings-audit-export-scope button small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
}
.settings-audit-export-scope button.active {
  border-color: rgba(199,42,108,.24);
  background: rgba(255,247,250,.94);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,.08);
}
.settings-audit-export-format {
  margin-top: 2px;
}
.settings-audit-export-note {
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.45;
}
.settings-audit-export-summary {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
  padding: 12px;
  border: 1px solid rgba(208,213,221,.92);
  border-radius: 12px;
  background: linear-gradient(180deg, #FCFCFD 0%, #FFFFFF 100%);
}
.settings-audit-export-summary span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-audit-export-summary strong {
  display: block;
  margin-top: 8px;
  color: var(--text);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 800;
}
.settings-audit-export-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.settings-audit-export-panel-foot > span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.settings-audit-table-wrap {
  background: linear-gradient(180deg, rgba(252,252,253,.92) 0%, #FFFFFF 100%);
}
.settings-audit-table {
  min-width: 980px;
}
.settings-audit-table thead th {
  background: rgba(248,250,252,.9);
}
.settings-audit-table tbody tr {
  background: rgba(255,255,255,.82);
}
.settings-audit-table tbody tr:hover {
  background: linear-gradient(90deg, rgba(252,231,240,.38) 0%, rgba(255,255,255,.98) 100%);
}
.settings-audit-time {
  display: inline-flex;
  flex-direction: column;
  gap: 4px;
}
.settings-audit-time strong {
  color: var(--text);
  font-size: 13px;
}
.settings-audit-time span {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: .05em;
}
.settings-audit-user {
  display: flex;
  align-items: center;
  gap: 10px;
}
.settings-audit-user-copy strong,
.settings-audit-target strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  line-height: 1.35;
  font-weight: 700;
}
.settings-audit-user-copy span,
.settings-audit-target span {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-audit-action {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.settings-audit-action small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.settings-audit-action-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  min-height: 34px;
  padding: 0 12px;
  border-radius: var(--r-pill);
  border: 1px solid transparent;
  font-size: 12px;
  font-weight: 800;
  line-height: 1;
  white-space: nowrap;
}
.settings-audit-action-badge.is-ok {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3,152,85,.12);
}
.settings-audit-action-badge.is-brand {
  color: var(--brand-deep);
  background: var(--brand-soft);
  border-color: rgba(199,42,108,.12);
}
.settings-audit-action-badge.is-violet {
  color: var(--violet);
  background: var(--violet-soft);
  border-color: rgba(121,72,123,.12);
}
.settings-audit-action-badge.is-warn {
  color: var(--warn);
  background: var(--warn-soft);
  border-color: rgba(247,144,9,.12);
}
.settings-audit-action-badge.is-info {
  color: var(--info);
  background: var(--info-soft);
  border-color: rgba(37,99,235,.12);
}
.settings-audit-ip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 112px;
  min-height: 34px;
  padding: 0 10px;
  border-radius: var(--r-pill);
  border: 1px solid var(--border);
  background: #FFFFFF;
  color: var(--text-2);
  font-family: var(--font-mono);
  font-size: 12px;
  letter-spacing: 0;
}
.settings-audit-ip.is-empty {
  color: var(--text-3);
  background: var(--n-50);
}


@media (max-width: 1180px) {
  .settings-audit-hero {
    grid-template-columns: 1fr;
  }
}
@media (max-width: 860px) {
  .settings-audit-stats {
    grid-template-columns: 1fr;
  }
}
.settings-team-card {
  overflow: hidden;
}
.settings-team-hero {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  gap: 16px;
  padding: 18px;
  border-bottom: 1px solid var(--border);
  background:
    linear-gradient(135deg, rgba(199,42,108,.065), rgba(156,100,158,.035) 38%, rgba(255,255,255,0) 72%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-team-hero-copy {
  max-width: 760px;
}
.settings-team-hero-copy strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-team-hero-copy p {
  margin: 7px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.55;
}
.settings-team-hero-meta {
  display: flex;
  flex-wrap: wrap;
  justify-content: flex-end;
  gap: 8px;
}
.settings-team-strip {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-team-strip div {
  position: relative;
  padding: 14px 14px 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.settings-team-strip div::after {
  content: "";
  position: absolute;
  left: 12px;
  right: 12px;
  bottom: 0;
  height: 3px;
  border-radius: 99px 99px 0 0;
  background: var(--brand);
  opacity: .18;
}
.settings-strip-icon {
  float: right;
  width: 28px;
  height: 28px;
  margin: -2px 0 4px 8px;
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: var(--brand-deep) !important;
  display: grid !important;
  place-items: center;
}
.settings-team-strip strong {
  display: block;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-team-strip span {
  display: block;
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
}
.settings-team-strip small {
  display: block;
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 600;
}
.settings-team-toolbar {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 18px;
  border-bottom: 1px solid var(--border);
  background: white;
}
.settings-team-toolbar-actions {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  margin-left: auto;
}
.settings-team-toolbar-note {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 32px;
  padding: 0 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  background: var(--n-50);
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
  white-space: nowrap;
}
.settings-team-search {
  position: relative;
  flex: 1;
  min-width: 220px;
}
.settings-team-search svg {
  position: absolute;
  left: 11px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  pointer-events: none;
}
.settings-team-search input {
  width: 100%;
  height: 32px;
  padding: 0 12px 0 34px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
  color: var(--text);
  outline: none;
  font-size: 12.5px;
  transition: background .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.settings-team-search input:focus {
  background: white;
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(199,42,108,.10);
}
.settings-team-filter-wrap,
.settings-team-export-wrap {
  position: relative;
}
.settings-team-filter-panel,
.settings-team-export-panel {
  position: absolute;
  top: calc(100% + 8px);
  right: 0;
  z-index: 12;
  width: 308px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: #FFFFFF;
  box-shadow: var(--shadow-lg);
}
.settings-team-filter-head strong,
.settings-team-export-panel-head strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.settings-team-filter-head small,
.settings-team-export-panel-head small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
}
.settings-team-filter-list {
  display: grid;
  gap: 8px;
  margin-top: 12px;
}
.settings-team-filter-list button {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  width: 100%;
  padding: 10px 11px;
  border: 1px solid var(--border);
  border-radius: 11px;
  background: #FCFCFD;
  color: var(--text);
  font: inherit;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, transform .16s ease, box-shadow .16s ease;
}
.settings-team-filter-list button:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.20);
  background: #FFFFFF;
}
.settings-team-filter-list button.is-selected {
  border-color: rgba(199,42,108,.24);
  background: rgba(255,247,250,.94);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,.08);
}
.settings-team-filter-list button span {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-size: 12.5px;
  font-weight: 700;
}
.settings-team-filter-list button small {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 700;
}
.settings-team-export-section + .settings-team-export-section {
  margin-top: 14px;
}
.settings-team-panel-label {
  display: inline-flex;
  margin-bottom: 8px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-team-export-scope {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 8px;
}
.settings-team-export-scope button {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 11px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #FCFCFD;
  color: var(--text-2);
  font: inherit;
  text-align: left;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, transform .16s ease;
}
.settings-team-export-scope button strong {
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
  line-height: 1;
}
.settings-team-export-scope button.active {
  border-color: rgba(199,42,108,.24);
  background: rgba(255,247,250,.94);
}
.settings-team-export-format {
  margin-top: 2px;
}
.settings-team-export-note {
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.45;
}
.settings-team-export-panel-foot {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.settings-team-export-panel-foot > span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
}
.settings-team-toolbar-meta {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 10px 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-team-toolbar-meta span {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 700;
}
.settings-person {
  display: flex;
  align-items: center;
  gap: 10px;
}
.settings-person-name {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.settings-person-mail {
  font-size: 11.5px;
}
.settings-team-table-wrap {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-team-table tbody tr.is-attention {
  background: linear-gradient(90deg, rgba(247,144,9,.06), rgba(255,255,255,0) 70%);
}
.settings-team-table tbody tr.is-attention:hover {
  background: linear-gradient(90deg, rgba(247,144,9,.10), rgba(255,255,255,0) 78%);
}
.settings-role-chip {
  display: inline-flex;
  flex-direction: column;
  gap: 2px;
  min-width: 148px;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: #FFFFFF;
}
.settings-role-chip strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
  line-height: 1.2;
}
.settings-role-chip small {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 600;
  line-height: 1.2;
}
.settings-role-chip.is-brand {
  border-color: rgba(199,42,108,.16);
  background: rgba(255,247,250,.92);
}
.settings-role-chip.is-violet {
  border-color: rgba(156,100,158,.18);
  background: rgba(249,246,251,.95);
}
.settings-role-chip.is-warn {
  border-color: rgba(247,144,9,.20);
  background: rgba(255,250,240,.98);
}
.settings-role-chip.is-neutral {
  background: #FCFCFD;
}
.settings-access-text {
  color: var(--text-2);
  font-weight: 600;
}
.settings-role-matrix {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 1px;
  border-top: 1px solid var(--border);
  background: var(--border);
}
.settings-role-card {
  padding: 16px 16px 18px;
  background: #FCFCFD;
}
.settings-role-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 14px;
}
.settings-role-card-top span {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.settings-role-card-top small {
  display: inline-flex;
  color: var(--brand-deep);
  font-size: 11.5px;
  font-weight: 800;
}
.settings-role-card strong {
  display: block;
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
}
.settings-role-card p {
  min-height: 38px;
  margin: 7px 0 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.settings-role-card.is-violet .settings-role-card-top small {
  color: var(--brand-purple-deep);
}
.settings-role-card.is-warn .settings-role-card-top small {
  color: #C67608;
}
.settings-role-card.is-neutral .settings-role-card-top small {
  color: var(--brand-deep);
}
.settings-team-empty {
  display: grid;
  gap: 6px;
  padding: 32px 16px;
  text-align: center;
}
.settings-team-empty strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.settings-team-empty span {
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.5;
}

.settings-invite-overlay {
  place-items: start center;
  padding-top: 96px;
  background: rgba(16, 24, 40, .44);
}
.settings-invite-modal {
  width: min(560px, 100%);
  max-height: min(92vh, 720px);
  border-color: rgba(255,255,255,.72);
}
.settings-invite-form {
  min-height: 0;
  display: flex;
  flex: 1;
  flex-direction: column;
}
.settings-invite-head {
  min-height: 88px;
  grid-template-columns: minmax(0, 1fr) auto 34px;
  padding: 18px 20px;
}
.settings-invite-icon {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.settings-invite-badges span {
  border-color: rgba(199,42,108,.14);
  background: rgba(252,231,240,.72);
  color: var(--brand-deep);
}
.settings-invite-body {
  display: flex;
  flex-direction: column;
  grid-template-columns: 1fr;
  gap: 14px;
  padding: 18px 20px;
}
.settings-invite-field {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.settings-invite-field label {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}
.settings-invite-role-preview {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  min-height: 42px;
  padding: 9px 11px;
  border: 1px solid rgba(156,100,158,.16);
  border-radius: var(--r-md);
  background: rgba(249,246,251,.86);
}
.settings-invite-role-preview strong {
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-invite-role-preview span {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
  text-align: right;
}
.settings-invite-role-preview.is-brand {
  border-color: rgba(199,42,108,.16);
  background: rgba(255,247,250,.94);
}
.settings-invite-role-preview.is-neutral {
  border-color: var(--border);
  background: var(--n-50);
}
.settings-invite-access {
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FCFCFD;
}
.settings-invite-access.is-error {
  border-color: rgba(217,45,32,.28);
  background: var(--bad-soft);
}
.settings-invite-section-head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 10px;
}
.settings-invite-section-head span {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.settings-invite-section-head small {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 650;
}
.settings-invite-access-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.settings-invite-access-option {
  min-height: 82px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  color: var(--text-2);
  text-align: left;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, box-shadow .14s ease, transform .14s ease;
}
.settings-invite-access-option:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.18);
  box-shadow: var(--shadow-xs);
}
.settings-invite-access-option.is-selected {
  border-color: rgba(199,42,108,.22);
  background: rgba(252,231,240,.64);
  color: var(--brand-deep);
}
.settings-invite-access-option span {
  display: flex;
  align-items: center;
  gap: 7px;
  color: inherit;
  font-size: 12.5px;
  font-weight: 800;
}
.settings-invite-access-option small {
  display: block;
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-invite-switch-row {
  width: 100%;
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  text-align: left;
  cursor: pointer;
}
.settings-invite-switch-row > span:first-child {
  min-width: 0;
}
.settings-invite-switch-row strong {
  display: block;
  color: var(--text);
  font-size: 12.75px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-invite-switch-row small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-invite-switch {
  position: relative;
  width: 36px;
  height: 22px;
  flex: 0 0 auto;
  border-radius: var(--r-pill);
  background: var(--n-200);
  transition: background .14s ease;
}
.settings-invite-switch i {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #FFFFFF;
  box-shadow: 0 1px 3px rgba(16,24,40,.20);
  transition: left .14s ease;
}
.settings-invite-switch-row.is-on {
  border-color: rgba(199,42,108,.18);
  background: rgba(252,231,240,.34);
}
.settings-invite-switch-row.is-on .settings-invite-switch {
  background: var(--brand);
}
.settings-invite-switch-row.is-on .settings-invite-switch i {
  left: 17px;
}
.settings-invite-note {
  margin-top: 0;
}
.settings-invite-error {
  display: block;
  margin-top: 2px;
  color: var(--bad);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 750;
}
.settings-invite-foot {
  padding: 14px 20px;
}

@media (max-width: 760px) {
  .settings-invite-overlay {
    place-items: end center;
    padding: 16px;
  }
  .settings-invite-head {
    grid-template-columns: minmax(0, 1fr) 34px;
  }
  .settings-invite-badges {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .settings-invite-access-grid {
    grid-template-columns: 1fr;
  }
  .settings-invite-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .settings-invite-foot .deal-calc-actions {
    flex-direction: column-reverse;
  }
  .settings-invite-foot .btn {
    width: 100%;
    justify-content: center;
  }
}
.settings-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.settings-setting-list {
  display: flex;
  flex-direction: column;
  gap: 0;
  padding-top: 4px;
  padding-bottom: 4px;
}
.settings-setting-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 18px;
  row-gap: 10px;
  padding: 16px 0;
  border-bottom: 1px solid var(--border);
}
.settings-setting-row:last-child {
  border-bottom: none;
}
.settings-setting-copy {
  min-width: 0;
}
.settings-setting-copy div {
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.3;
  font-weight: 800;
  text-wrap: balance;
}
.settings-setting-copy span {
  display: block;
  max-width: 62ch;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
  text-wrap: pretty;
}
.settings-setting-control {
  display: flex;
  justify-content: flex-end;
  align-items: center;
  min-width: 148px;
}
.settings-setting-control > .btn,
.settings-setting-control > .input,
.settings-setting-control > .badge {
  max-width: 100%;
}
.settings-select-sm {
  width: 164px;
}
.settings-security-control {
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 8px;
  max-width: 100%;
}
.settings-security-overlay {
  place-items: start center;
  padding-top: 82px;
  background: rgba(16, 24, 40, .44);
}
.settings-security-modal {
  width: min(760px, 100%);
  max-height: min(92vh, 760px);
  border-color: rgba(255,255,255,.72);
}
.settings-sessions-modal {
  width: min(560px, calc(100vw - 32px));
  max-height: min(82vh, 640px);
}
.settings-security-head {
  min-height: 88px;
  grid-template-columns: minmax(0, 1fr) auto 34px;
  padding: 18px 20px;
}
.settings-security-icon {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.settings-security-badges span {
  border-color: rgba(199,42,108,.14);
  background: rgba(252,231,240,.72);
  color: var(--brand-deep);
}
.settings-sessions-badges span {
  border-color: rgba(247,144,9,.18);
  background: var(--warn-soft);
  color: #b54708;
}
.settings-security-body {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 286px;
  gap: 14px;
  padding: 18px 20px;
  overflow: auto;
}
.settings-security-panel {
  min-width: 0;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FCFCFD;
}
.settings-security-form-panel {
  background: #FFFFFF;
}
.settings-security-section-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 12px;
}
.settings-security-section-head strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-security-section-head span {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-security-key-list,
.settings-security-fields {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.settings-security-key-row {
  display: grid;
  grid-template-columns: 36px minmax(0, 1fr) auto;
  align-items: center;
  gap: 11px;
  padding: 11px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
}
.settings-security-key-icon {
  width: 36px;
  height: 36px;
  border: 1px solid rgba(199,42,108,.14);
  border-radius: var(--r-md);
  background: rgba(252,231,240,.62);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
}
.settings-security-key-copy {
  min-width: 0;
}
.settings-security-key-copy div {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  color: var(--text);
  font-size: 13px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-security-key-copy > span,
.settings-security-key-copy > small {
  display: block;
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-security-key-copy > small {
  color: var(--text-3);
}
.settings-security-empty {
  min-height: 138px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 7px;
  padding: 18px;
  border: 1px dashed var(--border-strong);
  border-radius: var(--r-md);
  background: #FFFFFF;
  color: var(--text-3);
  text-align: center;
}
.settings-security-empty strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.settings-security-empty span {
  max-width: 260px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.4;
  font-weight: 650;
}
.settings-security-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.settings-security-field > span {
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}
.settings-security-field small {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-security-field.is-missing .input {
  border-color: rgba(217,45,32,.42);
  background: var(--bad-soft);
}
.settings-security-field.is-missing small {
  color: var(--bad);
  font-weight: 750;
}
.settings-security-toggle {
  width: 100%;
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  color: var(--text);
  text-align: left;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease;
}
.settings-security-toggle strong {
  display: block;
  font-size: 12.5px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-security-toggle small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-security-toggle.is-on {
  border-color: rgba(199,42,108,.18);
  background: rgba(252,231,240,.34);
}
.settings-security-toggle.is-on .settings-invite-switch {
  background: var(--brand);
}
.settings-security-toggle.is-on .settings-invite-switch i {
  left: 17px;
}
.settings-security-add-btn {
  width: 100%;
  justify-content: center;
}
.settings-security-foot {
  padding: 14px 20px;
}
@media (max-width: 760px) {
  .settings-security-overlay {
    place-items: end center;
    padding: 16px;
  }
  .settings-security-head {
    grid-template-columns: minmax(0, 1fr) 34px;
  }
  .settings-security-badges {
    grid-column: 1 / -1;
    justify-content: flex-start;
  }
  .settings-security-body {
    grid-template-columns: 1fr;
    padding: 16px;
  }
  .settings-security-key-row {
    grid-template-columns: 36px minmax(0, 1fr);
  }
  .settings-security-key-row .btn {
    grid-column: 2;
    justify-self: flex-start;
  }
  .settings-security-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .settings-security-foot .deal-calc-actions {
    flex-direction: column-reverse;
  }
  .settings-security-foot .btn {
    width: 100%;
    justify-content: center;
  }
}

.settings-session-list {
  display: flex;
  flex-direction: column;
}
.settings-session-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  align-items: center;
  column-gap: 14px;
  row-gap: 10px;
  padding: 16px 18px;
  border-top: 1px solid var(--border);
}
.settings-session-row:first-child {
  border-top: none;
}
.settings-session-row.is-current {
  background: linear-gradient(90deg, rgba(3,152,85,.04), rgba(255,255,255,0) 58%);
}
.settings-session-icon {
  width: 34px;
  height: 34px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
  color: var(--text-2);
  display: grid;
  place-items: center;
}
.settings-session-copy {
  min-width: 0;
}
.settings-session-copy div {
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.3;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 7px;
  flex-wrap: wrap;
  text-wrap: balance;
}
.settings-session-copy span {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 12px;
  line-height: 1.45;
  text-wrap: pretty;
}
.settings-session-actions {
  display: flex;
  justify-content: flex-end;
}
.settings-sessions-head {
  min-height: 84px;
}
.settings-sessions-icon {
  border-color: rgba(247,144,9,.18);
  background: var(--warn-soft);
  color: #b54708;
}
.settings-sessions-modal-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 20px 8px;
}
.settings-sessions-summary {
  display: grid;
  grid-template-columns: 40px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: linear-gradient(135deg, rgba(199,42,108,.04), rgba(255,255,255,0) 68%), #fcfcfd;
}
.settings-sessions-summary-icon {
  width: 40px;
  height: 40px;
  border: 1px solid rgba(199,42,108,.14);
  border-radius: var(--r-md);
  background: rgba(252,231,240,.72);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
}
.settings-sessions-summary strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.35;
  font-weight: 800;
}
.settings-sessions-summary p {
  margin: 5px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
  font-weight: 600;
}
.settings-sessions-impact {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.settings-sessions-impact div {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
  font-weight: 700;
}
.settings-sessions-impact div:first-child svg {
  color: var(--ok);
}
.settings-sessions-impact div:last-child svg {
  color: #b54708;
}
.settings-code {
  display: inline-flex;
  width: fit-content;
  min-height: 24px;
  align-items: center;
  padding: 2px 7px;
  border: 1px solid var(--border);
  border-radius: var(--r-sm);
  background: var(--n-50);
}
.settings-api-card {
  overflow: hidden;
}
.settings-api-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
  gap: 18px;
  padding: 18px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(circle at top left, rgba(199,42,108,.10), rgba(255,255,255,0) 34%),
    linear-gradient(135deg, rgba(199,42,108,.06), rgba(156,100,158,.03) 42%, rgba(255,255,255,0) 76%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-api-hero.is-compact {
  align-items: start;
}
.settings-api-hero-copy strong {
  display: block;
  max-width: 760px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.28;
  font-weight: 800;
}
.settings-api-hero-copy p {
  max-width: 720px;
  margin: 8px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.6;
}
.settings-api-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 26px;
  margin-bottom: 12px;
  padding: 0 10px;
  border: 1px solid rgba(199,42,108,.14);
  border-radius: var(--r-pill);
  background: rgba(255,247,250,.92);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.settings-api-metrics {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.settings-api-metrics.is-compact {
  align-self: stretch;
}
.settings-api-metric {
  min-height: 122px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: rgba(255,255,255,.88);
  box-shadow: var(--shadow-xs);
}
.settings-api-metric span,
.settings-api-row-title span,
.settings-api-row-meta span,
.settings-api-footer-card span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-api-metric strong {
  display: block;
  margin-top: 16px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
}
.settings-api-metric small {
  display: block;
  margin-top: 10px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-api-metric.is-brand {
  border-color: rgba(199,42,108,.18);
  background: linear-gradient(180deg, rgba(255,247,250,.96) 0%, rgba(255,255,255,.94) 100%);
}
.settings-api-metric.is-brand strong {
  color: var(--brand-deep);
}
.settings-api-metric.is-ok {
  border-color: rgba(3,152,85,.20);
  background: linear-gradient(180deg, rgba(243,255,248,.96) 0%, rgba(255,255,255,.94) 100%);
}
.settings-api-metric.is-ok strong {
  color: var(--ok);
  text-transform: lowercase;
}
.settings-api-body {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.settings-api-body.is-compact {
  padding-top: 16px;
}
.settings-api-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.settings-api-row-card {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 16px;
  align-items: center;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
}
.settings-api-row-card.is-brand {
  border-color: rgba(199,42,108,.18);
  background: linear-gradient(180deg, rgba(255,247,250,.92) 0%, #FFFFFF 100%);
}
.settings-api-row-main {
  min-width: 0;
}
.settings-api-row-title strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 17px;
  font-weight: 800;
}
.settings-api-row-title small {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-api-key-code {
  display: block;
  width: 100%;
  margin-top: 12px;
  padding: 12px 13px;
  border: 1px solid rgba(16,24,40,.07);
  border-radius: 10px;
  background: rgba(248,250,252,.96);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 13px;
  overflow: hidden;
  text-overflow: ellipsis;
}
.settings-api-row-meta {
  display: grid;
  grid-template-columns: repeat(2, minmax(84px, auto));
  gap: 12px 16px;
  align-items: center;
  justify-items: end;
}
.settings-api-row-meta strong {
  display: block;
  margin-top: 6px;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
  text-align: right;
}
.settings-api-row-meta .btn {
  grid-column: 1 / -1;
}
.settings-api-footer {
  display: grid;
  grid-template-columns: minmax(0, .92fr) minmax(0, 1.08fr);
  gap: 12px;
}
.settings-api-footer-card {
  display: block;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
  text-decoration: none;
}
.settings-api-footer-card strong {
  display: block;
  margin-top: 10px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-api-footer-card small {
  display: block;
  margin-top: 8px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-api-footer-card:is(a) {
  color: inherit;
}
.settings-api-footer-card:is(a):hover strong {
  color: var(--brand-deep);
}
.settings-api-footer-card.is-code {
  background:
    linear-gradient(145deg, rgba(199,42,108,.06), rgba(255,255,255,0) 48%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-api-footer-card code {
  display: block;
  margin-top: 10px;
  padding: 10px 12px;
  border-radius: 10px;
  background: var(--n-100);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  overflow-wrap: anywhere;
}
.settings-api-overlay {
  background: rgba(16, 24, 40, .52);
}
.settings-api-modal {
  width: min(760px, 100%);
  max-height: min(92vh, 780px);
}
.settings-api-modal-head {
  min-height: 88px;
  padding: 18px 20px;
}
.settings-api-modal-badges span {
  border-color: rgba(199,42,108,.14);
  background: rgba(252,231,240,.64);
  color: var(--brand-deep);
}
.settings-api-modal-icon {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.settings-api-modal-body,
.settings-api-modal-success {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 250px;
  gap: 14px;
  padding: 18px 20px;
  overflow-y: auto;
  background: #FFFFFF;
}
.settings-api-form-card,
.settings-api-side-card,
.settings-api-success-card {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
}
.settings-api-form-card,
.settings-api-success-card {
  padding: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-api-form-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  align-items: start;
  gap: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.settings-api-form-intro strong,
.settings-api-success-banner strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-api-form-intro p,
.settings-api-success-banner small,
.settings-api-copy-row small {
  margin: 5px 0 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-api-completion {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.settings-api-completion > div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.settings-api-completion span,
.settings-api-field > span,
.settings-api-secret-block > span,
.settings-api-side-kicker {
  color: var(--text-3);
  font-size: 10.8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.settings-api-completion strong {
  color: var(--brand-deep);
  font-size: 12.5px;
  font-weight: 800;
  white-space: nowrap;
}
.settings-api-create-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}
.settings-api-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-width: 0;
}
.settings-api-field small,
.settings-api-side-item small {
  color: var(--text-3);
  font-size: 11.2px;
  line-height: 1.35;
  font-weight: 600;
}
.settings-api-field .input {
  height: 42px;
  border-radius: var(--r-md);
  background: #FFFFFF;
}
.settings-api-field.is-missing .input {
  border-color: rgba(217,45,32,.28);
  background: rgba(254,243,242,.42);
  box-shadow: 0 0 0 3px rgba(217,45,32,.06);
}
.settings-api-field.is-missing > small {
  color: var(--bad);
  font-weight: 750;
}
.settings-api-field--full {
  grid-column: 1 / -1;
}
.settings-api-segmented {
  height: 42px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 3px;
  padding: 3px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.settings-api-segmented button,
.settings-api-toggle {
  font-family: inherit;
}
.settings-api-segmented button {
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, color .14s ease, box-shadow .14s ease;
}
.settings-api-segmented button.is-active {
  border-color: rgba(199,42,108,.18);
  background: #FFFFFF;
  color: var(--brand-deep);
  box-shadow: var(--shadow-xs);
}
.settings-api-toggle {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 12px 13px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  text-align: left;
  cursor: pointer;
  transition: border-color .14s ease, box-shadow .14s ease, background .14s ease, transform .14s ease;
}
.settings-api-toggle:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.18);
  box-shadow: var(--shadow-xs);
}
.settings-api-toggle.is-on {
  border-color: rgba(199,42,108,.20);
  background: rgba(252,231,240,.54);
}
.settings-api-toggle strong,
.settings-api-side-item strong,
.settings-api-side-card h4 {
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-api-side-card {
  padding: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-api-side-card h4 {
  margin: 7px 0 0;
}
.settings-api-side-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}
.settings-api-side-item {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
}
.settings-api-side-item > span {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  border: 1px solid rgba(16,24,40,.08);
  background: var(--n-50);
  color: var(--text-2);
  display: grid;
  place-items: center;
}
.settings-api-side-item.is-ok > span {
  border-color: rgba(3,152,85,.16);
  background: rgba(236,253,243,.9);
  color: var(--ok);
}
.settings-api-success-banner {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.settings-api-secret-block {
  margin-top: 16px;
}
.settings-api-secret-block code {
  display: block;
  margin-top: 8px;
  padding: 14px;
  border: 1px solid rgba(199,42,108,.12);
  border-radius: 10px;
  background: rgba(255,247,250,.82);
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 13px;
  line-height: 1.5;
  overflow-wrap: anywhere;
}
.settings-api-copy-row {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
  margin-top: 14px;
}
.settings-api-modal-foot {
  position: relative;
  z-index: 1;
}
@media (max-width: 980px) {
  .settings-api-modal-body,
  .settings-api-modal-success {
    grid-template-columns: 1fr;
  }
}
.settings-billing-intro {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(280px, .85fr);
  gap: 14px;
  margin-bottom: 16px;
}
.settings-billing-copy,
.settings-billing-stats {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
}
.settings-billing-copy {
  padding: 20px 22px;
}
.settings-billing-copy > span {
  display: inline-flex;
  margin-bottom: 10px;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-billing-copy strong {
  display: block;
  max-width: 640px;
  color: var(--text);
  font-size: 24px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-billing-copy p {
  max-width: 620px;
  margin: 10px 0 0;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.settings-billing-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  overflow: hidden;
}
.settings-billing-stat {
  padding: 18px 16px;
  min-height: 118px;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  gap: 10px;
  background: linear-gradient(180deg, rgba(252,231,240,.42) 0%, rgba(255,255,255,.96) 100%);
}
.settings-billing-stat + .settings-billing-stat {
  border-left: 1px solid var(--border);
}
.settings-billing-stat strong {
  color: var(--text);
  font-size: 26px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-billing-stat span {
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
}
.settings-plan-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.settings-plan {
  position: relative;
  min-height: 560px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 22px;
  background:
    radial-gradient(circle at top left, rgba(242,244,247,.85), rgba(255,255,255,0) 38%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  display: flex;
  flex-direction: column;
  gap: 16px;
  box-shadow: var(--shadow-xs);
}
.settings-plan.is-current {
  border-color: rgba(3,152,85,.18);
}
.settings-plan.is-featured {
  border-color: rgba(199,42,108,.34);
  background:
    radial-gradient(circle at top right, rgba(252,231,240,.9), rgba(255,255,255,0) 36%),
    linear-gradient(180deg, #FFFFFF 0%, #FFF8FB 100%);
  box-shadow: 0 18px 44px rgba(180,35,101,.08);
}
.settings-plan-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
}
.settings-plan-top div {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-plan.is-featured .settings-plan-top div {
  color: var(--brand-deep);
}
.settings-plan-headline {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.settings-plan-headline > span {
  display: inline-flex;
  align-self: flex-start;
  padding: 5px 10px;
  border-radius: 999px;
  background: var(--n-50);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 700;
}
.settings-plan.is-featured .settings-plan-headline > span {
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.settings-plan-name {
  color: var(--text);
  font-size: 28px;
  line-height: 1.05;
  font-weight: 800;
}
.settings-plan-headline p {
  margin: 0;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}
.settings-plan-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.settings-plan-meta span {
  display: inline-flex;
  align-items: center;
  min-height: 30px;
  padding: 0 11px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.86);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 600;
}
.settings-plan-features {
  list-style: none;
  padding: 16px 0 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 11px;
  flex: 1;
  border-top: 1px solid rgba(208,213,221,.72);
}
.settings-plan-features li {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: var(--text);
  font-size: 13px;
  line-height: 1.48;
}
.settings-plan-features li > span:first-child {
  width: 18px;
  height: 18px;
  margin-top: 1px;
  border-radius: 50%;
  background: var(--ok);
  color: white;
  display: grid;
  place-items: center;
  flex-shrink: 0;
}
.settings-plan.is-featured .settings-plan-features li > span:first-child {
  background: var(--brand);
}
.settings-plan-price {
  padding-top: 15px;
  border-top: 1px solid var(--border);
  display: flex;
  align-items: baseline;
  gap: 8px;
}
.settings-plan-price strong {
  color: var(--text);
  font-size: 34px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-plan.is-featured .settings-plan-price strong {
  color: var(--brand-deep);
}
.settings-plan-price span {
  color: var(--text-2);
  font-size: 12.5px;
}
.settings-plan-note {
  min-height: 38px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.5;
}
.settings-plan .btn {
  justify-content: center;
}
.settings-muted-btn {
  background: var(--n-50);
}
.settings-notif-card {
  background:
    radial-gradient(circle at top left, rgba(199,42,108,.06), transparent 34%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-notif-list {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding-top: 12px;
}
.settings-notif-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(300px, .8fr);
  gap: 16px;
  padding: 18px;
  border: 1px solid rgba(199,42,108,.09);
  border-radius: calc(var(--r-lg) + 2px);
  background:
    linear-gradient(135deg, rgba(199,42,108,.07), rgba(156,100,158,.02) 46%, rgba(255,255,255,.9) 100%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.85);
}
.settings-notif-hero-copy span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  letter-spacing: .05em;
  text-transform: uppercase;
}
.settings-notif-hero-copy strong {
  display: block;
  max-width: 560px;
  margin-top: 12px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.28;
  font-weight: 800;
  text-wrap: balance;
}
.settings-notif-hero-copy p {
  max-width: 560px;
  margin: 8px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.6;
}
.settings-notif-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.settings-notif-stat {
  min-height: 118px;
  padding: 14px 14px 13px;
  border-radius: 16px;
  border: 1px solid rgba(16,24,40,.06);
  background: rgba(255,255,255,.78);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.92);
}
.settings-notif-stat span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.settings-notif-stat strong {
  display: block;
  margin-top: 18px;
  color: var(--text);
  font-size: 24px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-notif-stat small {
  display: block;
  margin-top: 8px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-notif-head,
.settings-notif-row {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 98px 98px;
  gap: 12px;
  align-items: center;
}
.settings-notif-head {
  padding: 0 4px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.settings-notif-grid {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.settings-notif-row {
  min-height: 88px;
  padding: 16px 16px 16px 14px;
  border: 1px solid rgba(16,24,40,.06);
  border-radius: calc(var(--r-lg) + 2px);
  background: linear-gradient(180deg, rgba(255,255,255,.98) 0%, rgba(252,252,253,.96) 100%);
  box-shadow: var(--shadow-xs);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease;
}
.settings-notif-row:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.14);
  box-shadow: 0 12px 28px rgba(16,24,40,.06);
}
.settings-notif-event {
  display: grid;
  grid-template-columns: 44px minmax(0, 1fr);
  gap: 13px;
  align-items: start;
}
.settings-notif-icon {
  width: 44px;
  height: 44px;
  border-radius: 14px;
  display: grid;
  place-items: center;
  border: 1px solid transparent;
}
.settings-notif-icon.is-brand {
  color: var(--brand-deep);
  background: linear-gradient(180deg, #FFF0F6 0%, #FFF8FB 100%);
  border-color: rgba(199,42,108,.12);
}
.settings-notif-icon.is-warn {
  color: #B54708;
  background: linear-gradient(180deg, #FFF6ED 0%, #FFFBF6 100%);
  border-color: rgba(245,158,11,.16);
}
.settings-notif-icon.is-ok {
  color: var(--ok);
  background: linear-gradient(180deg, #F1FFF7 0%, #F9FFFC 100%);
  border-color: rgba(3,152,85,.14);
}
.settings-notif-icon.is-neutral,
.settings-notif-icon.is-soft {
  color: var(--text-2);
  background: linear-gradient(180deg, #F8FAFC 0%, #F3F5F8 100%);
  border-color: rgba(16,24,40,.06);
}
.settings-notif-copy {
  min-width: 0;
}
.settings-notif-copy-top {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
}
.settings-notif-copy-top strong {
  color: var(--text);
  font-size: 14px;
  line-height: 1.3;
  font-weight: 800;
}
.settings-notif-copy-top span {
  display: inline-flex;
  align-items: center;
  min-height: 24px;
  padding: 0 9px;
  border-radius: 999px;
  background: var(--n-50);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 700;
}
.settings-notif-copy p {
  max-width: 62ch;
  margin: 7px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.58;
}
.settings-notif-switch-col {
  display: grid;
  justify-items: center;
  gap: 9px;
}
.settings-notif-channel-label {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  letter-spacing: .06em;
  text-transform: uppercase;
}
.settings-bank-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.15fr) minmax(320px, .85fr);
  gap: 16px;
  padding: 18px;
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  background:
    linear-gradient(135deg, rgba(199,42,108,.065), rgba(156,100,158,.03) 40%, rgba(255,255,255,0) 74%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-bank-hero-copy strong {
  display: block;
  color: var(--text);
  font-size: 16px;
  line-height: 1.32;
  font-weight: 800;
}
.settings-bank-hero-copy p {
  margin: 8px 0 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.55;
}
.settings-bank-hero-stats {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.settings-bank-hero-stats div {
  min-height: 112px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: rgba(255,255,255,.9);
  box-shadow: var(--shadow-xs);
}
.settings-bank-hero-stats span {
  display: block;
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-bank-hero-stats strong {
  display: block;
  margin-top: 14px;
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.settings-bank-hero-stats small {
  display: block;
  margin-top: 8px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.4;
  font-weight: 600;
}
.settings-bank-list {
  display: flex;
  flex-direction: column;
}
.settings-bank-row {
  display: grid;
  grid-template-columns: auto minmax(0, 1.2fr) minmax(180px, .72fr) auto auto;
  align-items: center;
  gap: 16px;
  padding: 16px 18px;
  border-top: 1px solid var(--border);
  background: white;
}
.settings-bank-row:first-child {
  border-top: none;
}
.settings-bank-row:hover {
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-bank-mark {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  display: grid;
  place-items: center;
  background: linear-gradient(180deg, #F8FAFC 0%, #F2F4F7 100%);
  border: 1px solid rgba(16,24,40,.06);
}
.settings-bank-copy {
  min-width: 0;
}
.settings-bank-copy > div {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.settings-bank-copy > span {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
}
.settings-bank-meta {
  min-width: 0;
}
.settings-bank-meta span {
  display: block;
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.settings-bank-meta small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.4;
}
.settings-bank-share {
  min-width: 86px;
  text-align: right;
}
.settings-bank-share strong {
  display: block;
  color: var(--text);
  font-size: 18px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.settings-bank-share span {
  color: var(--text-2);
  font-size: 12px;
}

.settings-account-overlay {
  background: rgba(16, 24, 40, .50);
}
.settings-account-modal {
  width: min(760px, 100%);
  max-height: min(92vh, 760px);
}
.settings-account-head {
  min-height: 88px;
  padding: 18px 20px;
}
.settings-account-head .deal-calc-badges span {
  border-color: rgba(199,42,108,.14);
  background: rgba(252,231,240,.64);
  color: var(--brand-deep);
}
.settings-account-icon {
  width: 38px;
  height: 38px;
  border: 1px solid rgba(199,42,108,.16);
  border-radius: var(--r-md);
  background: var(--brand-soft);
  color: var(--brand-deep);
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.settings-account-body {
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) 260px;
  gap: 14px;
  padding: 18px 20px;
  overflow-y: auto;
  background: #FFFFFF;
}
.settings-account-form-card,
.settings-account-side-card {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
}
.settings-account-form-card {
  padding: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-account-form-intro {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 132px;
  align-items: start;
  gap: 14px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.settings-account-form-intro strong {
  display: block;
  color: var(--text);
  font-size: 13.5px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-account-form-intro p {
  margin: 5px 0 0;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.45;
  font-weight: 600;
}
.settings-account-completion {
  display: flex;
  flex-direction: column;
  gap: 8px;
  min-width: 0;
}
.settings-account-completion > div {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 10px;
}
.settings-account-completion span {
  color: var(--text-3);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.settings-account-completion strong {
  color: var(--brand-deep);
  font-size: 12.5px;
  font-weight: 800;
  white-space: nowrap;
}
.settings-account-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
  margin-top: 14px;
}
.settings-account-field {
  display: flex;
  flex-direction: column;
  gap: 7px;
  min-width: 0;
}
.settings-account-field > span {
  color: var(--text-2);
  font-size: 10.8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .07em;
}
.settings-account-field small {
  color: var(--text-3);
  font-size: 11.2px;
  line-height: 1.35;
  font-weight: 600;
}
.settings-account-field .input {
  height: 42px;
  border-radius: var(--r-md);
  background: #FFFFFF;
}
.settings-account-field.is-missing .input {
  border-color: rgba(217,45,32,.28);
  background: rgba(254,243,242,.42);
  box-shadow: 0 0 0 3px rgba(217,45,32,.06);
}
.settings-account-field.is-missing > small {
  color: var(--bad);
  font-weight: 750;
}
.settings-account-field--full {
  grid-column: 1 / -1;
}
.settings-account-segmented {
  height: 42px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 3px;
  padding: 3px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.settings-account-segmented button,
.settings-account-option,
.settings-account-toggle {
  font-family: inherit;
}
.settings-account-segmented button {
  border: 1px solid transparent;
  border-radius: 6px;
  background: transparent;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 800;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, color .14s ease, box-shadow .14s ease;
}
.settings-account-segmented button.is-active {
  border-color: rgba(199,42,108,.18);
  background: #FFFFFF;
  color: var(--brand-deep);
  box-shadow: var(--shadow-xs);
}
.settings-account-option-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.settings-account-option {
  min-height: 74px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  text-align: left;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, box-shadow .14s ease, transform .14s ease;
}
.settings-account-option:hover {
  transform: translateY(-1px);
  border-color: rgba(199,42,108,.18);
  box-shadow: var(--shadow-xs);
}
.settings-account-option.is-selected {
  border-color: rgba(199,42,108,.22);
  background: rgba(252,231,240,.64);
}
.settings-account-option strong {
  display: block;
  color: var(--text);
  font-size: 12.3px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-account-option.is-selected strong {
  color: var(--brand-deep);
}
.settings-account-option small {
  display: block;
  margin-top: 7px;
  color: var(--text-3);
  font-size: 10.8px;
  line-height: 1.3;
  font-weight: 650;
}
.settings-account-toggle {
  min-height: 58px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #FFFFFF;
  text-align: left;
  cursor: pointer;
  transition: background .14s ease, border-color .14s ease, box-shadow .14s ease;
}
.settings-account-toggle:hover {
  border-color: rgba(199,42,108,.18);
  box-shadow: var(--shadow-xs);
}
.settings-account-toggle.is-on {
  border-color: rgba(199,42,108,.18);
  background: rgba(252,231,240,.34);
}
.settings-account-toggle strong {
  display: block;
  color: var(--text);
  font-size: 12.75px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-account-toggle small {
  display: block;
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-account-switch {
  position: relative;
  width: 36px;
  height: 22px;
  flex: 0 0 auto;
  border-radius: var(--r-pill);
  background: var(--n-200);
  transition: background .14s ease;
}
.settings-account-switch i {
  position: absolute;
  top: 3px;
  left: 3px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #FFFFFF;
  box-shadow: 0 1px 3px rgba(16,24,40,.20);
  transition: left .14s ease;
}
.settings-account-toggle.is-on .settings-account-switch {
  background: var(--brand);
}
.settings-account-toggle.is-on .settings-account-switch i {
  left: 17px;
}
.settings-account-side-card {
  padding: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.settings-account-side-kicker {
  color: var(--brand-deep);
  font-size: 10.8px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.settings-account-side-card h4 {
  margin: 8px 0 0;
  color: var(--text);
  font-size: 16px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-account-side-list {
  display: flex;
  flex-direction: column;
  gap: 9px;
  margin-top: 14px;
}
.settings-account-side-item {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: rgba(255,255,255,.88);
}
.settings-account-side-item > span {
  width: 26px;
  height: 26px;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
  border-radius: 8px;
  background: var(--n-100);
  color: var(--text-3);
}
.settings-account-side-item.is-ok > span {
  background: var(--ok-soft);
  color: var(--ok);
}
.settings-account-side-item strong {
  display: block;
  color: var(--text);
  font-size: 12.2px;
  line-height: 1.25;
  font-weight: 800;
}
.settings-account-side-item small {
  display: block;
  margin-top: 3px;
  color: var(--text-3);
  font-size: 11px;
  line-height: 1.35;
  font-weight: 650;
}
.settings-account-side-summary {
  display: grid;
  gap: 8px;
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}
.settings-account-side-summary div {
  display: flex;
  justify-content: space-between;
  gap: 10px;
}
.settings-account-side-summary span {
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 700;
}
.settings-account-side-summary strong {
  min-width: 0;
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
  text-align: right;
  word-break: break-word;
}

@media (max-width: 900px) {
  .settings-account-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 760px) {
  .settings-account-overlay {
    place-items: end center;
    padding: 16px;
  }
  .settings-account-modal {
    max-height: 94vh;
  }
  .settings-account-form-intro,
  .settings-account-grid,
  .settings-account-option-grid {
    grid-template-columns: 1fr;
  }
  .settings-account-foot {
    align-items: stretch;
    flex-direction: column;
  }
  .settings-account-foot .deal-calc-actions {
    flex-direction: column-reverse;
  }
  .settings-account-foot .btn {
    width: 100%;
    justify-content: center;
  }
}

@media (max-width: 1280px) {
  .settings-summary-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
  .settings-layout {
    grid-template-columns: 220px minmax(0, 1fr);
  }
  .settings-profile-body {
    grid-template-columns: 1fr;
  }
  .settings-profile-intro {
    grid-template-columns: 1fr;
  }
  .settings-profile-rail {
    display: grid;
    grid-template-columns: repeat(3, minmax(0, 1fr));
    align-items: stretch;
    position: static;
  }
  .settings-billing-intro,
  .settings-plan-grid {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 1100px) {
  .settings-overview,
  .settings-bank-hero,
  .settings-bank-hero-stats,
  .settings-api-hero,
  .settings-api-footer {
    grid-template-columns: 1fr;
  }
  .settings-api-metrics {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 900px) {
  .settings-layout,
  .settings-form-grid,
  .settings-team-strip,
  .settings-role-matrix,
  .settings-profile-rail,
  .settings-summary-grid,
  .settings-billing-stats {
    grid-template-columns: 1fr;
  }
  .settings-billing-stat + .settings-billing-stat {
    border-left: 0;
    border-top: 1px solid var(--border);
  }
  .settings-api-row-card {
    grid-template-columns: 1fr;
  }
  .settings-api-row-meta {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-items: start;
  }
  .settings-api-row-meta strong {
    text-align: left;
  }
  .settings-nav-card {
    position: static;
  }
  .settings-section-heading {
    flex-direction: column;
  }
  .settings-notif-hero {
    grid-template-columns: 1fr;
  }
  .settings-notif-hero-stats {
    grid-template-columns: 1fr;
  }
  .settings-notif-head,
  .settings-notif-row {
    grid-template-columns: minmax(0, 1fr) 72px 72px;
  }
  .settings-notif-row {
    padding: 14px 12px;
  }
  .settings-notif-event {
    grid-template-columns: 38px minmax(0, 1fr);
    gap: 10px;
  }
  .settings-notif-icon {
    width: 38px;
    height: 38px;
    border-radius: 12px;
  }
  .settings-notif-copy-top {
    flex-direction: column;
    align-items: flex-start;
  }
  .settings-bank-row {
    grid-template-columns: 1fr;
  }
  .settings-bank-share {
    text-align: left;
  }
  .settings-team-hero {
    flex-direction: column;
    align-items: flex-start;
  }
  .settings-team-toolbar {
    flex-wrap: wrap;
  }
  .settings-team-toolbar-actions {
    width: 100%;
    justify-content: flex-start;
    margin-left: 0;
  }
  .settings-team-search {
    flex-basis: 100%;
  }
  .settings-team-toolbar-meta {
    flex-wrap: wrap;
  }
  .settings-team-filter-panel,
  .settings-team-export-panel,
  .settings-audit-export-panel {
    left: 0;
    right: auto;
    width: min(352px, calc(100vw - 48px));
  }
  .settings-audit-export-summary,
  .settings-audit-export-scope {
    grid-template-columns: 1fr;
  }
  .settings-audit-export-panel-foot {
    flex-direction: column;
    align-items: stretch;
  }
  .settings-audit-export-panel-foot .btn {
    width: 100%;
    justify-content: center;
  }
  .settings-setting-row,
  .settings-session-row {
    grid-template-columns: 1fr;
  }
  .settings-session-actions {
    justify-content: flex-start;
  }
  .settings-setting-control {
    justify-content: flex-start;
    min-width: 0;
  }
  .settings-security-control {
    justify-content: flex-start;
    flex-wrap: wrap;
  }
}

/* -------- Misc -------- */
.divider { height: 1px; background: var(--border); margin: 12px 0; }
.kv { display: flex; justify-content: space-between; padding: 8px 0; font-size: 13px; }
.kv + .kv { border-top: 1px solid var(--border); }
.kv .k { color: var(--text-2); }
.kv .v { font-weight: 600; }

.grid { display: grid; gap: 16px; }
.g-2 { grid-template-columns: 1fr 1fr; }
.g-3 { grid-template-columns: repeat(3, 1fr); }
.g-4 { grid-template-columns: repeat(4, 1fr); }
.g-2-1 { grid-template-columns: 2fr 1fr; }
.g-1-2 { grid-template-columns: 1fr 2fr; }

.row { display: flex; align-items: center; gap: 10px; }
.spacer { flex: 1; }

.scroll-y { max-height: 100%; overflow-y: auto; }

/* -------- Target redesign helpers -------- */
.decision-panel {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-xs);
  padding: 20px;
  display: grid;
  grid-template-columns: 1.45fr 1fr;
  gap: 18px;
  align-items: stretch;
}
.decision-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 9px;
  border-radius: var(--r-sm);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}
.decision-title {
  font-size: 21px;
  line-height: 1.25;
  font-weight: 800;
  margin: 12px 0 6px;
}
.decision-copy {
  max-width: 720px;
  margin: 0;
  color: var(--text-2);
  font-size: 13.5px;
}
.decision-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 16px;
}
.decision-metrics {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 10px;
}
.decision-metric {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: #FAFBFC;
  padding: 13px 14px;
}
.decision-metric .label {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.decision-metric .value {
  margin-top: 5px;
  color: var(--text);
  font-size: 18px;
  font-weight: 800;
}
.worklist {
  display: flex;
  flex-direction: column;
}
.work-row {
  display: grid;
  grid-template-columns: 1.2fr .9fr .8fr .9fr 120px;
  gap: 14px;
  align-items: center;
  padding: 14px 18px;
  border-top: 1px solid var(--border);
}
.work-row:first-child { border-top: none; }
.work-label {
  font-size: 11px;
  color: var(--text-3);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.work-value {
  margin-top: 3px;
  font-size: 13.5px;
  font-weight: 700;
}
.profile-task-row {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 12px 0;
  border-top: 1px solid var(--border);
}
.profile-task-row:first-child { border-top: none; padding-top: 0; }
.profile-task-dot {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  margin-top: 1px;
}
.company-overview {
  margin-bottom: 16px;
  padding: 0;
  background:
    linear-gradient(90deg, rgba(199,42,108,.035), rgba(255,255,255,0) 34%),
    white;
}
.company-overview-grid {
  display: grid;
  grid-template-columns: 1.35fr 1fr;
  gap: 18px;
  align-items: stretch;
  padding: 18px;
}
.company-identity {
  display: flex;
  gap: 14px;
  align-items: flex-start;
}
.company-avatar {
  width: 58px;
  height: 58px;
  border-radius: 10px;
  background: linear-gradient(135deg, var(--brand) 0%, var(--brand-purple) 100%);
  color: white;
  display: grid;
  place-items: center;
  font-size: 22px;
  font-weight: 800;
  flex-shrink: 0;
}
.company-facts {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 9px;
  margin-top: 18px;
}
.company-fact {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 11px 12px;
  background: #FAFBFC;
}
.company-fact .k {
  color: var(--text-3);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.company-fact .v {
  margin-top: 4px;
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.readiness-panel {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 16px;
  background: #FAFBFC;
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.readiness-head {
  display: flex;
  justify-content: space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.readiness-title {
  font-weight: 800;
  font-size: 14px;
}
.readiness-copy {
  color: var(--text-2);
  font-size: 12.5px;
  margin-top: 2px;
  max-width: 420px;
}
.readiness-value {
  font-weight: 800;
  color: var(--brand-deep);
  font-size: 18px;
  font-variant-numeric: tabular-nums;
}
.company-layout {
  grid-template-columns: minmax(300px, 380px) minmax(0, 1fr);
}
.section-nav-card,
.blockers-card,
.questionnaire-card {
  box-shadow: none;
}
.section-nav-card .card-head,
.blockers-card .card-head,
.questionnaire-card .card-head {
  background: white;
}
.section-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 14px;
  cursor: pointer;
  border-left: 3px solid transparent;
  border-top: 0;
  border-right: 0;
  border-bottom: 0;
  background: transparent;
  width: 100%;
  text-align: left;
  color: var(--text-2);
  transition: background .16s ease, color .16s ease;
}
.section-item:hover {
  background: var(--n-50);
}
.section-item.active {
  background: linear-gradient(90deg, var(--brand-soft), rgba(252,231,240,.28));
  border-left-color: var(--brand);
}
.section-name {
  flex: 1;
  min-width: 0;
  font-size: 12.5px;
  font-weight: 650;
  color: var(--text-2);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.section-item.active .section-name {
  color: var(--brand-deep);
  font-weight: 800;
}
.section-index {
  width: 22px;
  height: 22px;
  border-radius: 6px;
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 800;
  flex-shrink: 0;
  border: 1px solid transparent;
  font-variant-numeric: tabular-nums;
}
.section-item.is-done .section-index {
  color: var(--ok);
  background: var(--ok-soft);
  border-color: rgba(3, 152, 85, .18);
}
.section-item.is-attention .section-index {
  color: var(--warn);
  background: var(--warn-soft);
  border-color: rgba(247, 144, 9, .24);
}
.section-state {
  flex-shrink: 0;
  max-width: 118px;
  padding: 3px 7px;
  border-radius: 6px;
  background: var(--warn-soft);
  color: #B54708;
  border: 1px solid rgba(247, 144, 9, .20);
  font-size: 10.5px;
  line-height: 1.1;
  font-weight: 700;
  white-space: nowrap;
}
.needs-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.needs-item {
  display: flex;
  gap: 8px;
  align-items: flex-start;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.pdf-action {
  position: relative;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}
.pdf-action-menu {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  min-width: 244px;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: rgba(255,255,255,.98);
  box-shadow: var(--shadow-md);
  backdrop-filter: blur(14px);
  z-index: 40;
}
.pdf-action-menu-title {
  padding: 4px 8px 8px;
  color: var(--text-3);
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .08em;
}
.dashboard-export-action {
  min-width: 0;
}
.dashboard-export-menu {
  left: auto;
  right: 0;
  width: min(620px, calc(100vw - 56px));
  min-width: 0;
  max-width: calc(100vw - 56px);
  padding: 12px;
}
.dashboard-export-menu-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 2px 4px 10px;
}
.dashboard-export-menu-sub {
  padding: 0 8px;
  color: var(--text-2);
  font-size: 12px;
}
.dashboard-export-progress-badge {
  flex-shrink: 0;
  padding: 7px 10px;
  border-radius: 999px;
  background: linear-gradient(135deg, rgba(252, 231, 240, .95), rgba(255, 255, 255, .95));
  border: 1px solid rgba(199, 42, 108, .14);
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.dashboard-export-grid {
  display: grid;
  grid-template-columns: minmax(0, 1.3fr) minmax(220px, .8fr);
  gap: 12px;
  align-items: start;
}
.dashboard-export-options {
  display: grid;
  gap: 8px;
}
.dashboard-export-option {
  width: 100%;
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) 14px;
  align-items: center;
  gap: 12px;
  padding: 12px;
  border: 1px solid rgba(234, 236, 240, .95);
  border-radius: 12px;
  background: #fff;
  text-align: left;
  transition: border-color .18s ease, background .18s ease, transform .18s ease, box-shadow .18s ease;
}
.dashboard-export-option:hover {
  border-color: rgba(199, 42, 108, .18);
  background: linear-gradient(90deg, rgba(252, 231, 240, .55), rgba(255, 255, 255, .98));
}
.dashboard-export-option.active {
  border-color: rgba(199, 42, 108, .28);
  background: linear-gradient(135deg, rgba(252, 231, 240, .72), rgba(255, 255, 255, .98));
  box-shadow: var(--shadow-xs);
}
.dashboard-export-option-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: rgba(248, 250, 252, .95);
  border: 1px solid rgba(234, 236, 240, .9);
}
.dashboard-export-option.active .dashboard-export-option-icon {
  background: rgba(255, 255, 255, .94);
  border-color: rgba(199, 42, 108, .16);
}
.dashboard-export-option-copy {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 4px;
}
.dashboard-export-option-copy strong {
  font-size: 13px;
  font-weight: 750;
  color: var(--text);
}
.dashboard-export-option-copy span {
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.4;
}
.dashboard-export-summary {
  min-width: 0;
}
.dashboard-export-summary-card {
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: linear-gradient(180deg, rgba(248, 250, 252, .85), rgba(255, 255, 255, .98));
}
.dashboard-export-summary-title {
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
  color: var(--text-3);
}
.dashboard-export-summary-list {
  display: grid;
  gap: 10px;
  margin-top: 12px;
}
.dashboard-export-summary-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 12.5px;
  color: var(--text-2);
}
.dashboard-export-summary-row strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 750;
  text-align: right;
}
.dashboard-export-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.dashboard-export-actions {
  display: flex;
  justify-content: flex-end;
  gap: 10px;
  margin-top: 12px;
}
.pdf-action-option {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 11px 10px;
  border: 0;
  border-radius: 10px;
  background: transparent;
  color: var(--text);
  font-size: 13px;
  font-weight: 650;
  text-align: left;
}
.pdf-action-option:hover {
  background: linear-gradient(90deg, var(--brand-soft), rgba(252,231,240,.24));
  color: var(--brand-deep);
}
.pdf-progress-chip {
  min-width: 244px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border: 1px solid rgba(199,42,108,.14);
  border-radius: 12px;
  background: linear-gradient(135deg, rgba(252,231,240,.78), rgba(255,255,255,.96));
  box-shadow: var(--shadow-xs);
}
.pdf-progress-label {
  color: var(--brand-deep);
  font-size: 12px;
  font-weight: 700;
  white-space: nowrap;
}
.pdf-progress-track {
  height: 6px;
  overflow: hidden;
  border-radius: 999px;
  background: rgba(152,162,179,.18);
}
.pdf-progress-track i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-gradient);
  transition: width .22s ease;
}
.pdf-progress-chip strong {
  color: var(--brand-deep);
  font-size: 12px;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.pdf-toast {
  position: fixed;
  top: 78px;
  right: 24px;
  z-index: 90;
  min-width: 320px;
  max-width: 420px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: flex-start;
  padding: 14px 14px 14px 12px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: rgba(255,255,255,.96);
  box-shadow: var(--shadow-lg);
  backdrop-filter: blur(16px);
}
.pdf-toast.is-success {
  border-color: rgba(3,152,85,.16);
}
.pdf-toast.is-error {
  border-color: rgba(247,144,9,.2);
}
.pdf-toast-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--n-50);
}
.pdf-toast.is-success .pdf-toast-icon {
  background: var(--ok-soft);
}
.pdf-toast.is-error .pdf-toast-icon {
  background: var(--warn-soft);
}
.pdf-toast-title {
  color: var(--text);
  font-size: 13.5px;
  font-weight: 800;
}
.pdf-toast-copy {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.pdf-toast-close {
  margin-top: -2px;
  padding: 0;
  width: 26px;
  min-width: 26px;
  justify-content: center;
}

.bank-export-modal {
  width: min(1120px, 100%);
}
.bank-export-head {
  min-height: 94px;
}
.bank-export-icon {
  background: linear-gradient(135deg, rgba(199,42,108,.14), rgba(156,100,158,.18));
  color: var(--brand-deep);
}
.bank-export-body {
  grid-template-columns: minmax(0, 1.18fr) minmax(320px, 400px);
  gap: 20px;
}
.bank-export-config {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.bank-export-block,
.bank-export-summary-card,
.bank-export-files-card {
  border: 1px solid var(--border);
  border-radius: 16px;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: var(--shadow-xs);
}
.bank-export-block {
  padding: 18px;
}
.bank-export-package-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}
.bank-export-package {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  padding: 15px 16px;
  border: 1px solid var(--border);
  border-radius: 14px;
  background: var(--n-25);
  text-align: left;
  transition: border-color .16s ease, box-shadow .16s ease, background .16s ease, transform .16s ease;
}
.bank-export-package:hover {
  border-color: rgba(199,42,108,.24);
  background: linear-gradient(90deg, rgba(252,231,240,.55), rgba(255,255,255,.96));
  transform: translateY(-1px);
}
.bank-export-package.active {
  border-color: rgba(199,42,108,.28);
  background: linear-gradient(135deg, rgba(252,231,240,.8), rgba(255,255,255,.96));
  box-shadow: var(--shadow-xs);
}
.bank-export-package strong {
  display: block;
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.bank-export-package span {
  display: block;
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.bank-export-package i {
  font-style: normal;
  color: var(--brand-deep);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
}
.bank-export-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
}
.bank-export-field label {
  display: block;
  margin-bottom: 8px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.bank-export-select-wrap {
  position: relative;
}
.bank-export-select-wrap select {
  appearance: none;
  padding-right: 38px;
}
.bank-export-select-icon {
  position: absolute;
  top: 50%;
  right: 12px;
  transform: translateY(-50%);
  pointer-events: none;
}
.bank-export-format-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.bank-export-format-chip {
  min-width: 74px;
  height: 40px;
  padding: 0 14px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: white;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 800;
}
.bank-export-format-chip.active {
  border-color: rgba(199,42,108,.24);
  background: linear-gradient(135deg, rgba(252,231,240,.88), rgba(255,255,255,.96));
  color: var(--brand-deep);
}
.bank-export-includes {
  background: linear-gradient(180deg, rgba(249,250,251,.78), rgba(255,255,255,.98));
}
.bank-export-include-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
  margin-top: 14px;
}
.bank-export-include-item {
  display: flex;
  align-items: center;
  gap: 10px;
  min-height: 46px;
  padding: 10px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: white;
  color: var(--text);
  font-size: 13px;
  font-weight: 700;
}
.bank-export-include-icon {
  width: 24px;
  height: 24px;
  border-radius: 999px;
  display: grid;
  place-items: center;
  background: var(--ok-soft);
  flex-shrink: 0;
}
.bank-export-summary {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.bank-export-summary-card,
.bank-export-files-card {
  padding: 18px;
}
.bank-export-summary-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.bank-export-summary-head strong {
  color: var(--brand-deep);
  font-size: 30px;
  line-height: 1;
  font-weight: 800;
}
.bank-export-summary-copy {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.bank-export-progress {
  height: 7px;
  margin-top: 14px;
  border-radius: 999px;
  overflow: hidden;
  background: rgba(152,162,179,.18);
}
.bank-export-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-gradient);
}
.bank-export-warning-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 16px;
}
.bank-export-warning-item {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
}
.bank-export-warning-item svg {
  flex-shrink: 0;
  margin-top: 2px;
}
.bank-export-file-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: 14px;
}
.bank-export-file-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: 12px;
  background: white;
}
.bank-export-file-icon {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: linear-gradient(135deg, rgba(252,231,240,.8), rgba(255,255,255,.98));
  flex-shrink: 0;
}
.bank-export-file-item strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.bank-export-file-item span {
  display: block;
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12px;
}
.bank-export-foot {
  gap: 18px;
}
.bank-export-footnote {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.bank-export-progress-chip {
  min-width: 280px;
}

@media (max-width: 1100px) {
  .dashboard-export-menu {
    min-width: min(100vw - 48px, 620px);
  }
  .dashboard-export-grid {
    grid-template-columns: 1fr;
  }
  .dashboard-export-actions {
    flex-wrap: wrap;
  }
  .dashboard-export-actions .btn {
    flex: 1 1 180px;
    justify-content: center;
  }
  .bank-export-body {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 720px) {
  .bank-export-grid,
  .bank-export-include-list {
    grid-template-columns: minmax(0, 1fr);
  }
}

@media (max-width: 1280px) {
  .stat-grid { grid-template-columns: repeat(2, 1fr); }
  .g-2-1, .g-1-2 { grid-template-columns: 1fr; }
  .decision-panel, .company-overview-grid { grid-template-columns: 1fr; }
  .documents-layout, .documents-readiness, .debtors-overview-main, .debtors-metric-grid, .debtors-list-head { grid-template-columns: 1fr; }
  .debtor-limits-overview-main, .debtor-limits-metric-grid, .debtor-limits-list-head { grid-template-columns: 1fr; }
  .credit-overview-main, .credit-metric-grid, .credit-rail { grid-template-columns: 1fr; }
  .credit-contract-row { grid-template-columns: 1fr 1fr; }
  .financing-kpi-grid { grid-template-columns: repeat(2, 1fr); }
  .financing-layout { grid-template-columns: 1fr; }

  .financing-page-actions { width: 100%; justify-content: flex-start; }
  .financing-export-action { align-items: flex-start; }
  .financing-export-menu { left: 0; right: auto; }
  .financing-summary { position: static; }
  .sign-layout { grid-template-columns: 1fr; }
  .sign-params-card { position: static; }
  .sign-stepper { grid-template-columns: repeat(2, 1fr); row-gap: 18px; }
  .sign-step:nth-child(2)::before { display: none; }
  .documents-rail { position: static; }
  .documents-archive-panel { right: auto; left: 0; }
  .work-row { grid-template-columns: 1fr 1fr; }
  .company-facts { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 900px) {
  .app { grid-template-columns: 1fr; grid-template-areas: "topbar" "main"; }
  .sidebar { display: none; }
}

/* Avoid native focus rings, use our own */
button:focus-visible, .input:focus-visible, .nav-item:focus-visible {
  outline: 2px solid var(--azure);
  outline-offset: 2px;
}
button:focus:not(:focus-visible) { outline: none; }

.metric-cell:last-child { border-right: none !important; }
.display-num {
  font-weight: 800;
  letter-spacing: 0;
  font-variant-numeric: tabular-nums;
}

/* ============================================================
   Factor / bank cabinet homepage
   ============================================================ */
.nav-item:disabled,
.nav-item.is-disabled {
  cursor: default;
  opacity: .68;
}
.nav-item.is-disabled:hover {
  background: transparent;
  color: var(--n-600);
  transform: none;
  box-shadow: none;
}
.nav-item.is-disabled .nav-badge {
  background: rgba(255,255,255,.58);
  color: var(--n-500);
  border: 1px solid rgba(208,213,221,.72);
}
.topbar-filter {
  height: 38px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 0 12px;
  border-radius: var(--r-md);
  border: 1px solid var(--border);
  background: white;
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
  white-space: nowrap;
  transition: background .16s ease, border-color .16s ease, transform .16s ease;
}
.topbar-filter:hover {
  background: var(--n-50);
  border-color: var(--border-strong);
  transform: translateY(-1px);
}
.factor-dashboard {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.factor-page-header {
  margin-bottom: 2px;
}
.factor-page-actions {
  flex-wrap: wrap;
  justify-content: flex-end;
}
.factor-dashboard .btn:disabled {
  background: var(--n-50);
  border-color: var(--border);
  color: var(--text-3);
  box-shadow: none;
  opacity: 1;
}
.factor-access-notice {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr);
  gap: 12px;
  align-items: center;
  padding: 13px 16px;
  border: 1px solid rgba(208,213,221,.86);
  border-radius: var(--r-lg);
  background:
    linear-gradient(90deg, rgba(252,231,240,.72), rgba(255,255,255,.86) 34%, rgba(249,250,251,.92)),
    #fff;
  box-shadow: var(--shadow-xs);
}
.factor-access-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.factor-access-notice strong,
.factor-access-notice span {
  display: block;
}
.factor-access-notice strong {
  color: var(--text);
  font-size: 14px;
  font-weight: 800;
}
.factor-access-notice span {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12.8px;
  line-height: 1.45;
}
.factor-kpi-grid {
  display: grid;
  grid-template-columns: repeat(7, minmax(118px, 1fr));
  gap: 12px;
}
.factor-kpi-card {
  min-height: 136px;
  display: flex;
  flex-direction: column;
  gap: 7px;
  padding: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-xs);
  transition: border-color .16s ease, box-shadow .16s ease, transform .16s ease;
}
.factor-kpi-card:hover {
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
  transform: translateY(-1px);
}
.factor-kpi-card.is-feature {
  color: white;
  border-color: transparent;
  background: linear-gradient(135deg, var(--n-900), #2d2531);
  box-shadow: 0 12px 30px rgba(16,24,40,.13);
}
.factor-kpi-icon {
  width: 31px;
  height: 31px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--n-100);
  color: var(--text-2);
}
.factor-kpi-icon.is-info { background: var(--info-soft); color: var(--info); }
.factor-kpi-icon.is-warn { background: var(--warn-soft); color: var(--warn); }
.factor-kpi-icon.is-ok { background: var(--ok-soft); color: var(--ok); }
.factor-kpi-icon.is-royal { background: var(--brand-purple-soft); color: var(--brand-purple-deep); }
.factor-kpi-icon.is-bad { background: var(--bad-soft); color: var(--bad); }
.factor-kpi-card.is-feature .factor-kpi-icon {
  color: white;
  background: rgba(255,255,255,.14);
}
.factor-kpi-label {
  min-height: 34px;
  color: var(--text-2);
  font-size: 11.8px;
  line-height: 1.35;
  font-weight: 700;
}
.factor-kpi-card.is-feature .factor-kpi-label,
.factor-kpi-card.is-feature .factor-kpi-sub {
  color: rgba(255,255,255,.72);
}
.factor-kpi-value {
  margin-top: auto;
  color: var(--text);
  font-size: 28px;
  line-height: 1;
  font-weight: 800;
}
.factor-kpi-card.is-feature .factor-kpi-value {
  color: white;
}
.factor-kpi-sub {
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.25;
}
.factor-home-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 370px);
  align-items: start;
  gap: 16px;
}
.factor-home-main,
.factor-home-rail {
  display: flex;
  flex-direction: column;
  gap: 16px;
  min-width: 0;
}
.factor-home-rail {
  position: sticky;
  top: calc(var(--topbar-h) + 18px);
}
.factor-card-head-wrap {
  align-items: flex-start;
  flex-wrap: wrap;
}
.factor-card-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.factor-pipeline {
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 10px;
}
.factor-pipeline-step {
  position: relative;
  display: grid;
  grid-template-columns: 28px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  min-height: 112px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: linear-gradient(180deg, #fff, var(--n-50));
}
.factor-pipeline-index {
  width: 28px;
  height: 28px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--n-100);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
}
.factor-pipeline-step.is-info .factor-pipeline-index { background: var(--info-soft); color: var(--info); }
.factor-pipeline-step.is-warn .factor-pipeline-index { background: var(--warn-soft); color: var(--warn); }
.factor-pipeline-step.is-ok .factor-pipeline-index { background: var(--ok-soft); color: var(--ok); }
.factor-pipeline-step.is-royal .factor-pipeline-index { background: var(--brand-purple-soft); color: var(--brand-purple-deep); }
.factor-pipeline-copy strong,
.factor-pipeline-copy span,
.factor-pipeline-copy small {
  display: block;
}
.factor-pipeline-copy strong {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.factor-pipeline-copy span {
  margin-top: 6px;
  color: var(--text);
  font-size: 12.5px;
  line-height: 1.25;
  font-weight: 800;
}
.factor-pipeline-copy small {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.35;
}
.factor-applications-table td {
  white-space: nowrap;
}
.factor-applications-table td:nth-child(2),
.factor-applications-table td:nth-child(3),
.factor-applications-table td:nth-child(5),
.factor-applications-table td:nth-child(6) {
  white-space: normal;
}
.factor-client-cell strong,
.factor-client-cell span {
  display: block;
}
.factor-client-cell span {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12.5px;
}
.factor-table-muted,
.factor-reaction {
  margin-top: 4px;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.25;
}
.factor-access-pill {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  min-height: 24px;
  padding: 0 8px;
  border: 1px solid rgba(208,213,221,.76);
  border-radius: var(--r-pill);
  background: white;
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.factor-access-pill.is-locked {
  background: var(--n-50);
  color: var(--text-3);
}
.factor-split-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(0, 1fr);
  gap: 16px;
}
.factor-reaction-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 10px;
}
.factor-reaction-grid div {
  min-height: 92px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.factor-reaction-grid strong,
.factor-reaction-grid span {
  display: block;
}
.factor-reaction-grid strong {
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.factor-reaction-grid span {
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.38;
}
.factor-accepted-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.factor-package-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #fff;
}
.factor-package-icon {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 9px;
}
.factor-package-icon.is-warn { background: var(--warn-soft); color: var(--warn); }
.factor-package-icon.is-ok { background: var(--ok-soft); color: var(--ok); }
.factor-package-row strong,
.factor-package-row small {
  display: block;
}
.factor-package-row strong {
  font-size: 13px;
  font-weight: 800;
}
.factor-package-row small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12px;
  line-height: 1.35;
}
.factor-onboarding-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 16px;
}
.factor-onboarding-row {
  display: grid;
  grid-template-columns: 30px minmax(0, 1fr);
  gap: 10px;
  align-items: start;
  padding: 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: white;
}
.factor-onboarding-icon {
  width: 30px;
  height: 30px;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--n-100);
  color: var(--text-2);
}
.factor-onboarding-row.is-done .factor-onboarding-icon { background: var(--ok-soft); color: var(--ok); }
.factor-onboarding-row.is-attention .factor-onboarding-icon { background: var(--warn-soft); color: var(--warn); }
.factor-onboarding-row.is-locked .factor-onboarding-icon { background: var(--n-100); color: var(--text-3); }
.factor-onboarding-copy strong,
.factor-onboarding-copy small {
  display: block;
}
.factor-onboarding-copy strong {
  color: var(--text);
  font-size: 12.8px;
  font-weight: 800;
}
.factor-onboarding-copy small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.6px;
  line-height: 1.35;
}
.factor-action-list,
.factor-audit-list {
  display: flex;
  flex-direction: column;
}
.factor-action-row {
  display: grid;
  grid-template-columns: 34px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 13px 14px;
  border-top: 1px solid var(--border);
}
.factor-action-row:first-child,
.factor-audit-row:first-child {
  border-top: none;
}
.factor-action-icon {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: var(--n-100);
  color: var(--text-2);
}
.factor-action-row.is-warn .factor-action-icon { background: var(--warn-soft); color: var(--warn); }
.factor-action-row.is-info .factor-action-icon { background: var(--info-soft); color: var(--info); }
.factor-action-row.is-bad .factor-action-icon { background: var(--bad-soft); color: var(--bad); }
.factor-action-copy strong,
.factor-action-copy small {
  display: block;
}
.factor-action-copy strong {
  color: var(--text);
  font-size: 12.8px;
  font-weight: 800;
}
.factor-action-copy small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.8px;
  line-height: 1.35;
}
.factor-risk-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 8px;
}
.factor-risk-metric {
  min-width: 0;
  padding: 11px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--n-50);
}
.factor-risk-metric span,
.factor-risk-metric strong,
.factor-risk-metric small {
  display: block;
}
.factor-risk-metric span {
  color: var(--text-3);
  font-size: 10.8px;
  line-height: 1.25;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.factor-risk-metric strong {
  margin-top: 7px;
  color: var(--text);
  font-size: 18px;
  line-height: 1;
  font-weight: 800;
}
.factor-risk-metric small {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.4px;
  line-height: 1.25;
}
.factor-risk-note {
  display: grid;
  grid-template-columns: 18px minmax(0, 1fr);
  gap: 8px;
  margin-top: 12px;
  padding: 10px 11px;
  border: 1px solid rgba(37,99,235,.18);
  border-radius: var(--r-md);
  background: var(--info-soft);
  color: var(--info);
  font-size: 12px;
  line-height: 1.4;
  font-weight: 700;
}
.factor-audit-row {
  display: grid;
  grid-template-columns: 54px minmax(0, 1fr);
  gap: 10px;
  padding: 12px 14px;
  border-top: 1px solid var(--border);
}
.factor-audit-time {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
}
.factor-audit-row strong,
.factor-audit-row small {
  display: block;
}
.factor-audit-row strong {
  color: var(--text);
  font-size: 12.5px;
  font-weight: 800;
}
.factor-audit-row small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.8px;
  line-height: 1.35;
}

@media (max-width: 1440px) {
  .factor-pipeline {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }
}
@media (max-width: 1180px) {
  .factor-kpi-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
  .factor-home-layout,
  .factor-split-grid {
    grid-template-columns: 1fr;
  }
  .factor-home-rail {
    position: static;
  }
  .factor-page-actions {
    width: 100%;
    justify-content: flex-start;
  }
}
@media (max-width: 760px) {
  .factor-kpi-grid,
  .factor-pipeline,
  .factor-reaction-grid,
  .factor-risk-grid {
    grid-template-columns: 1fr;
  }
  .factor-access-notice,
  .factor-package-row,
  .factor-action-row {
    grid-template-columns: 1fr;
  }
}

/* Subtle stripe for chart bg */
.chart-stripes {
  background-image: repeating-linear-gradient(180deg, transparent 0 39px, var(--n-100) 39px 40px);
}


/* ============================================================
   JourneyBar — deal-tracking stepper (CJM v1.0)
   ============================================================ */
.journey-bar {
  position: sticky;
  top: var(--topbar-h);
  z-index: 25;
  background: #FFFFFF;
  border-bottom: 1px solid var(--border);
  box-shadow: 0 1px 0 rgba(16,24,40,0.02);
}
.journey-bar-inner {
  display: flex;
  align-items: center;
  gap: 18px;
  padding: 10px 28px 12px;
  max-width: 100%;
}
.journey-status {
  display: flex;
  flex-direction: column;
  gap: 4px;
  flex-shrink: 0;
  min-width: 220px;
  max-width: 300px;
}
.journey-status-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 3px 9px;
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  width: fit-content;
}
.journey-status-chip .dot {
  width: 6px; height: 6px; border-radius: 50%;
}
.journey-status-chip.potential {
  background: #FFF3E0;
  color: #B0610B;
}
.journey-status-chip.potential .dot { background: #E08828; }
.journey-status-chip.working {
  background: var(--ok-soft);
  color: var(--ok);
}
.journey-status-chip.working .dot { background: var(--ok); }
.journey-status-meta {
  font-size: 11.5px;
  color: var(--text-3);
  display: flex; gap: 5px;
}
.journey-status-meta span:nth-child(3),
.journey-status-meta span:nth-child(5) { color: var(--text-3); }

.journey-track {
  flex: 1;
  min-width: 0;
  position: relative;
  padding: 7px 4px 3px;
}
.journey-line {
  position: absolute;
  left: 14px;
  right: 14px;
  top: 21px;
  height: 2px;
  background: #ECEFF3;
  border-radius: 99px;
  z-index: 0;
}
.journey-line-fill {
  height: 100%;
  background: var(--brand);
  border-radius: 99px;
  transition: width .3s ease;
}
.journey-steps {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  position: relative;
  z-index: 1;
}
.journey-step {
  background: transparent;
  border: none;
  padding: 0 6px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 7px;
  cursor: pointer;
  flex: 1;
  min-width: 0;
  max-width: 96px;
  position: relative;
}
.journey-dot {
  width: 24px; height: 24px;
  border-radius: 50%;
  background: white;
  border: 2px solid var(--n-200);
  color: var(--text-3);
  display: grid; place-items: center;
  font-size: 11px; font-weight: 700;
  transition: all .18s;
  flex-shrink: 0;
}
.journey-step.done .journey-dot {
  background: var(--brand);
  border-color: var(--brand);
  color: white;
}
.journey-step.active .journey-dot {
  background: white;
  border-color: var(--brand);
  color: var(--brand);
  box-shadow: 0 0 0 4px rgba(199,42,108,.13);
}
.journey-step.active .num { color: var(--brand); }
.journey-label {
  text-align: center;
  line-height: 1.2;
  max-width: 96px;
}
.journey-label-main {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--text-2);
  letter-spacing: 0;
  white-space: nowrap;
}
.journey-step.active .journey-label-main,
.journey-step.done .journey-label-main {
  color: var(--text);
}
.journey-label-sub {
  display: none;
  font-size: 10.5px;
  color: var(--text-3);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 96px;
}
.journey-step:hover .journey-dot {
  transform: scale(1.05);
}

.journey-actions {
  display: flex;
  gap: 4px;
  align-items: center;
  flex-shrink: 0;
}
.journey-actions .btn span { display: none; }

.factor-onboarding-bar {
  border-bottom-color: var(--border);
}
.factor-onboarding-bar-inner {
  min-height: 78px;
}
.factor-onboarding-status {
  min-width: 214px;
  max-width: 250px;
}
.factor-onboarding-meta {
  flex-wrap: wrap;
  line-height: 1.25;
}
.factor-onboarding-track {
  padding-top: 8px;
}
.factor-onboarding-steps {
  gap: 6px;
}
.factor-onboarding-step {
  max-width: 118px;
}
.factor-onboarding-dot .num {
  font-size: 16px;
  line-height: 1;
  color: var(--bad);
}
.factor-onboarding-step.todo .factor-onboarding-dot {
  border-color: var(--bad);
  background: var(--bad-soft);
  color: var(--bad);
}
.factor-onboarding-step.todo .journey-label-main {
  color: var(--text);
}
.factor-onboarding-step.todo .journey-label-sub {
  display: block;
  max-width: 118px;
}
.factor-onboarding-gate {
  display: flex;
  align-items: center;
  gap: 9px;
  min-width: 210px;
  padding: 9px 11px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: var(--warn-soft);
  color: var(--text-2);
}
.factor-onboarding-gate-icon {
  width: 26px;
  height: 26px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  background: white;
  color: var(--warn);
  flex-shrink: 0;
}
.factor-onboarding-gate strong,
.factor-onboarding-gate small {
  display: block;
  line-height: 1.2;
}
.factor-onboarding-gate strong {
  color: var(--text);
  font-size: 12.5px;
}
.factor-onboarding-gate small {
  margin-top: 2px;
  font-size: 11.5px;
}

@media (max-width: 1180px) {
  .factor-onboarding-bar-inner {
    align-items: flex-start;
    flex-wrap: wrap;
  }
  .factor-onboarding-track {
    order: 3;
    width: 100%;
    flex-basis: 100%;
  }
  .factor-onboarding-gate {
    margin-left: auto;
  }
}

@media (max-width: 760px) {
  .factor-onboarding-bar-inner {
    padding: 10px 16px 12px;
  }
  .factor-onboarding-status,
  .factor-onboarding-gate {
    min-width: 0;
    width: 100%;
  }
  .factor-onboarding-gate {
    margin-left: 0;
  }
  .factor-onboarding-steps {
    overflow-x: auto;
    justify-content: flex-start;
    padding-bottom: 2px;
  }
  .factor-onboarding-step {
    min-width: 92px;
  }
}

/* ============================================================
   Material Detail Landing (per CJM §4)
   ============================================================ */
.material-detail {
  display: grid;
  grid-template-columns: 280px 1fr 280px;
  gap: 18px;
  align-items: flex-start;
}
.material-side {
  position: sticky;
  top: calc(var(--topbar-h) + 80px);
  display: flex;
  flex-direction: column;
  gap: 2px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 8px;
  box-shadow: var(--shadow-sm);
}
.material-side .grp {
  font-size: 10.5px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--text-3);
  padding: 12px 12px 6px;
}
.material-side-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 9px 10px;
  border-radius: var(--r-md);
  cursor: pointer;
  font-size: 13px;
  font-weight: 500;
  color: var(--text-2);
  border: none;
  background: transparent;
  width: 100%;
  text-align: left;
  transition: background .12s, color .12s;
}
.material-side-item:hover { background: var(--n-50); color: var(--text); }
.material-side-item.active {
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-weight: 700;
}
.material-side-item .ic {
  width: 22px; height: 22px;
  border-radius: 6px;
  background: var(--n-50);
  display: grid; place-items: center;
  flex-shrink: 0;
  color: var(--text-3);
}
.material-side-item.active .ic {
  background: var(--brand);
  color: white;
}
.material-side-item.sub {
  padding: 6px 10px 6px 36px;
  font-size: 12.5px;
}
.material-side-item.sub.active {
  background: transparent;
  color: var(--brand);
}

.material-main {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 28px 32px;
  box-shadow: var(--shadow-sm);
  min-height: 600px;
}
.material-main h2 {
  margin: 0 0 6px;
  font-size: 22px;
  letter-spacing: 0;
  color: var(--brand-deep);
  font-weight: 800;
}
.material-main .lede {
  font-size: 13.5px;
  color: var(--text-2);
  line-height: 1.55;
  font-style: italic;
  margin: 0 0 22px;
}

.material-section {
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  margin-bottom: 8px;
  overflow: hidden;
  background: white;
  transition: border-color .15s;
}
.material-section.open {
  border-color: var(--brand);
  box-shadow: 0 4px 14px rgba(199,42,108,0.06);
}
.material-section-head {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  cursor: pointer;
  user-select: none;
  font-weight: 600;
  font-size: 13.5px;
  color: var(--text);
}
.material-section.open .material-section-head {
  color: var(--brand-deep);
  background: var(--brand-soft);
  border-bottom: 1px solid var(--brand);
}
.material-section-head .chev {
  width: 14px; height: 14px;
  display: grid; place-items: center;
  color: var(--text-3);
  flex-shrink: 0;
  transition: transform .15s;
}
.material-section.open .material-section-head .chev {
  transform: rotate(90deg);
  color: var(--brand);
}
.material-section-body {
  padding: 14px 18px 18px;
  font-size: 13px;
  color: var(--text-2);
  line-height: 1.6;
}
.material-section-body p { margin: 0 0 10px; }
.material-section-body p:last-child { margin-bottom: 0; }
.material-section-body ul {
  margin: 6px 0 8px;
  padding-left: 18px;
}
.material-section-body li { margin-bottom: 4px; }
.material-section-body code,
.material-section-body .tag {
  background: var(--n-50);
  border: 1px solid var(--border);
  padding: 1px 6px;
  border-radius: 4px;
  font-family: var(--font-mono);
  font-size: 11.5px;
  color: var(--text);
}

.material-aside {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.material-aside-card {
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 18px;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.material-aside-card .eyebrow {
  font-size: 11.5px;
  font-weight: 700;
  color: var(--brand-deep);
  letter-spacing: 0;
}
.material-aside-card .eyebrow .num {
  color: var(--ok);
}
.material-aside-card .ic {
  width: 56px; height: 56px;
  margin: 12px auto;
  border-radius: 14px;
  display: grid; place-items: center;
  background: var(--brand-soft);
  color: var(--brand);
}
.material-aside-card .note {
  font-size: 11.5px;
  color: var(--text-2);
  line-height: 1.4;
  margin-top: 8px;
}

.feedback-block {
  margin-top: 20px;
  padding: 36px 24px;
  text-align: center;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  box-shadow: var(--shadow-sm);
}
.feedback-block h3 {
  margin: 0 0 18px;
  font-size: 22px;
  font-weight: 700;
  color: var(--brand-deep);
  letter-spacing: 0;
}
.feedback-actions {
  display: flex;
  gap: 12px;
  justify-content: center;
}
.feedback-btn {
  padding: 10px 26px;
  border-radius: var(--r-md);
  font-weight: 700;
  font-size: 13px;
  border: none;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}
.feedback-btn.yes {
  background: var(--ok);
  color: white;
}
.feedback-btn.no {
  background: var(--n-200);
  color: var(--text-2);
}


.support-screen {
  display: flex;
  flex-direction: column;
  gap: 18px;
}
.support-hero {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(280px, .9fr);
  gap: 16px;
  padding: 22px;
  border: 1px solid rgba(199, 42, 108, 0.14);
  border-radius: 16px;
  background:
    radial-gradient(circle at top right, rgba(156, 100, 158, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(252,231,240,0.78) 100%);
  box-shadow: var(--shadow-sm);
}
.support-hero-main {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.support-hero-eyebrow {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-deep);
}
.support-hero-title {
  max-width: 620px;
  font-size: 28px;
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: -0.02em;
  color: var(--text);
}
.support-hero-sub {
  max-width: 660px;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.6;
}
.support-hero-person {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  width: fit-content;
  padding: 10px 14px;
  border-radius: 14px;
  background: rgba(255,255,255,0.76);
  border: 1px solid rgba(255,255,255,0.9);
  box-shadow: 0 12px 24px rgba(16, 24, 40, 0.05);
}
.support-hero-person-meta {
  display: flex;
  flex-direction: column;
  gap: 3px;
}
.support-hero-person-meta strong {
  font-size: 14px;
}
.support-hero-person-meta span {
  font-size: 12px;
  color: var(--ok);
}
.support-hero-tags {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.support-hero-stats {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.support-stat {
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  min-height: 98px;
  padding: 16px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: rgba(255,255,255,0.84);
}
.support-stat span {
  font-size: 11.5px;
  color: var(--text-2);
}
.support-stat strong {
  font-size: 28px;
  line-height: 1;
  letter-spacing: -0.03em;
}
.support-stat-brand {
  border-color: rgba(199, 42, 108, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(252,231,240,0.92));
}
.support-stat-brand strong { color: var(--brand-deep); }
.support-stat-ok {
  border-color: rgba(3, 152, 85, 0.14);
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(236,253,243,0.92));
}
.support-stat-ok strong { color: var(--ok); }
.support-stat-royal {
  border-color: rgba(156, 100, 158, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.92), rgba(244,234,244,0.92));
}
.support-stat-royal strong { color: var(--royal); }
.support-layout {
  display: grid;
  grid-template-columns: minmax(0, 1.35fr) minmax(320px, .9fr);
  gap: 16px;
  align-items: stretch;
}
.support-chat-card {
  display: flex;
  flex-direction: column;
  min-height: 620px;
}
.support-chat-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
  padding: 18px;
  border-bottom: 1px solid var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.support-chat-person,
.support-chat-head-side,
.support-ticket-top,
.support-ticket-bottom,
.support-knowledge-card {
  display: flex;
  align-items: center;
}
.support-chat-person {
  gap: 12px;
}
.support-chat-name {
  font-size: 14px;
  font-weight: 700;
}
.support-chat-status,
.support-chat-sla {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11.5px;
  color: var(--text-2);
}
.support-chat-status { color: var(--ok); }
.support-online-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--ok);
  box-shadow: 0 0 0 4px rgba(3, 152, 85, 0.12);
}
.support-chat-head-side {
  gap: 8px;
  justify-content: flex-end;
  flex-wrap: wrap;
}
.support-chat-sla {
  padding: 0 10px;
  height: 24px;
  border-radius: 999px;
  background: var(--n-50);
  border: 1px solid var(--border);
}
.support-thread {
  position: relative;
  flex: 1;
  overflow: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 20px 18px 24px;
  background:
    linear-gradient(180deg, rgba(252,231,240,0.22) 0%, rgba(255,255,255,0) 26%),
    linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
}
.support-thread-day {
  align-self: center;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,0.92);
  border: 1px solid var(--border);
  font-size: 11px;
  font-weight: 700;
  color: var(--text-2);
  box-shadow: var(--shadow-xs);
}
.support-bubble-row {
  display: flex;
  gap: 10px;
  max-width: min(76%, 720px);
}
.support-bubble-row.is-me {
  align-self: flex-end;
}
.support-bubble-stack {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.support-bubble {
  padding: 12px 14px;
  border-radius: 14px;
  font-size: 13.5px;
  line-height: 1.58;
  box-shadow: var(--shadow-xs);
}
.support-bubble.is-them {
  border-top-left-radius: 6px;
  background: white;
  border: 1px solid rgba(208, 213, 221, 0.9);
  color: var(--text);
}
.support-bubble.is-me {
  border-top-right-radius: 6px;
  background: var(--brand-gradient-diag);
  color: white;
}
.support-bubble-time {
  font-size: 11px;
  color: var(--text-3);
}
.support-bubble-row.is-me .support-bubble-time {
  align-self: flex-end;
}
.support-composer {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px;
  border-top: 1px solid var(--border);
  background: white;
}
.support-composer-field {
  flex: 1;
}
.support-composer-field .input {
  margin-bottom: 5px;
}
.support-composer-field span {
  display: block;
  font-size: 11.5px;
  color: var(--text-3);
}
.support-side {
  display: flex;
  flex-direction: column;
  gap: 16px;
}
.support-tickets-card {
  overflow: hidden;
}
.support-ticket-list {
  display: flex;
  flex-direction: column;
}
.support-ticket-row {
  display: flex;
  flex-direction: column;
  gap: 10px;
  width: 100%;
  padding: 16px 18px;
  border-top: 1px solid var(--border);
  border-left: 0;
  border-right: 0;
  border-bottom: 0;
  background: white;
  transition: background .16s ease, transform .16s ease;
  cursor: pointer;
  text-align: left;
  font: inherit;
}
.support-ticket-row:hover {
  background: #FCFCFD;
}
.support-ticket-row.is-active {
  background: linear-gradient(90deg, rgba(252,231,240,0.66) 0%, rgba(255,255,255,0) 92%);
}
.support-ticket-row:focus-visible,
.support-kb-filter:focus-visible,
.support-kb-item .btn:focus-visible {
  outline: none;
  box-shadow: 0 0 0 4px rgba(199, 42, 108, 0.14);
  position: relative;
  z-index: 1;
}
.support-ticket-top,
.support-ticket-bottom {
  justify-content: space-between;
  gap: 10px;
}
.support-ticket-id,
.support-ticket-when,
.support-ticket-meta {
  color: var(--text-3);
}
.support-ticket-when,
.support-ticket-meta {
  font-size: 11.5px;
}
.support-ticket-title {
  font-size: 14px;
  line-height: 1.45;
  font-weight: 700;
  color: var(--text);
}
.support-knowledge-card {
  gap: 14px;
  padding: 18px;
  justify-content: space-between;
}
.support-knowledge-icon {
  width: 42px;
  height: 42px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--brand-soft), rgba(255,255,255,0.9));
  color: var(--brand-deep);
}
.support-knowledge-copy {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 4px;
}
.support-knowledge-copy strong {
  font-size: 14px;
}
.support-knowledge-copy span {
  font-size: 12.5px;
  color: var(--text-2);
  line-height: 1.5;
}
.support-kb-overlay {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  justify-content: flex-end;
  background: rgba(16, 24, 40, 0.22);
  backdrop-filter: blur(6px);
}
.support-kb-drawer {
  width: min(1120px, calc(100vw - 28px));
  height: 100vh;
  overflow: auto;
  background: linear-gradient(180deg, #FFFFFF 0%, #FCFCFD 100%);
  box-shadow: -24px 0 48px rgba(16, 24, 40, 0.12);
  display: flex;
  flex-direction: column;
}
.support-kb-head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 18px;
  padding: 24px 24px 18px;
  border-bottom: 1px solid var(--border);
  background:
    radial-gradient(circle at top right, rgba(156, 100, 158, 0.18), transparent 34%),
    linear-gradient(135deg, rgba(255,255,255,0.98) 0%, rgba(252,231,240,0.72) 100%);
}
.support-kb-head h3 {
  margin: 2px 0 6px;
  font-size: 24px;
  line-height: 1.15;
}
.support-kb-toolbar {
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  background: rgba(255,255,255,0.92);
}
.support-kb-search {
  position: relative;
  display: block;
}
.support-kb-search > svg {
  position: absolute;
  top: 13px;
  left: 12px;
  color: var(--text-3);
}
.support-kb-search .input {
  padding-left: 36px;
  margin: 0;
}
.support-kb-filters {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.support-kb-filter {
  height: 32px;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: white;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: border-color .16s ease, background .16s ease, color .16s ease, transform .16s ease;
}
.support-kb-filter:hover {
  transform: translateY(-1px);
  border-color: var(--border-strong);
}
.support-kb-filter.is-active {
  background: var(--brand-soft);
  border-color: rgba(199, 42, 108, 0.24);
  color: var(--brand-deep);
}
.support-kb-body {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(280px, .8fr);
  gap: 18px;
  padding: 18px 24px 28px;
}
.support-kb-list {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.support-kb-item {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  align-items: flex-start;
  gap: 14px;
  padding: 16px;
  border: 1px solid var(--border);
  border-radius: 16px;
  background: white;
  box-shadow: var(--shadow-xs);
}
.support-kb-item-icon {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--brand-soft), rgba(255,255,255,0.92));
  color: var(--brand-deep);
}
.support-kb-item-copy {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.support-kb-item-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
}
.support-kb-item-top strong {
  font-size: 14px;
  line-height: 1.45;
}
.support-kb-item-meta {
  font-size: 11.5px;
  color: var(--text-3);
}
.support-kb-item-copy p {
  margin: 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.55;
}
.support-kb-empty {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding: 28px;
  border: 1px dashed var(--border-strong);
  border-radius: 16px;
  background: white;
  color: var(--text-2);
}
.support-kb-side {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.support-kb-summary {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px;
  border-radius: 16px;
  border: 1px solid rgba(199, 42, 108, 0.12);
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(252,231,240,0.76));
  box-shadow: var(--shadow-xs);
}
.support-kb-summary-soft {
  border-color: var(--border);
  background: linear-gradient(180deg, #FFFFFF 0%, #F9FAFB 100%);
}
.support-kb-summary-kicker {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--brand-deep);
}
.support-kb-summary strong {
  font-size: 15px;
}
.support-kb-summary p,
.support-ticket-aside-card p,
.support-ticket-aside-note {
  margin: 0;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.6;
}
.support-kb-summary-pills,
.support-ticket-aside-pills {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.support-ticket-overlay {
  z-index: 82;
}
.support-ticket-modal {
  width: min(980px, calc(100vw - 32px));
  border: 1px solid rgba(199, 42, 108, 0.12);
}
.support-ticket-head-icon {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: linear-gradient(180deg, var(--brand-soft), rgba(255,255,255,0.96));
  color: var(--brand-deep);
}
.support-ticket-badges span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.support-ticket-body {
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) minmax(240px, .75fr);
  gap: 18px;
  padding: 22px;
}
.support-ticket-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
}
.support-ticket-grid .field {
  margin: 0;
}
.support-ticket-field-wide {
  grid-column: 1 / -1;
}
.support-ticket-aside {
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.support-ticket-aside-card {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 18px;
  border-radius: 16px;
  border: 1px solid rgba(156, 100, 158, 0.16);
  background: linear-gradient(180deg, rgba(255,255,255,0.96), rgba(244,234,244,0.86));
}
.support-ticket-aside-kicker {
  font-size: 11px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  color: var(--royal);
}
.support-ticket-aside-card strong {
  font-size: 15px;
  line-height: 1.35;
}
.support-ticket-aside-note {
  padding: 14px 16px;
  border-radius: 14px;
  background: var(--n-50);
  border: 1px solid var(--border);
}
.support-ticket-foot {
  align-items: center;
}
.support-ticket-foot > span {
  color: var(--text-2);
  font-size: 12.5px;
}

@media (max-width: 1180px) {
  .support-hero,
  .support-layout {
    grid-template-columns: 1fr;
  }

  .support-hero-stats {
    grid-template-columns: repeat(3, minmax(0, 1fr));
  }

  .support-kb-body,
  .support-ticket-body {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 820px) {
  .support-hero {
    padding: 18px;
  }

  .support-hero-title {
    font-size: 23px;
  }

  .support-hero-stats {
    grid-template-columns: 1fr;
  }

  .support-chat-head,
  .support-knowledge-card,
  .support-ticket-bottom,
  .support-chat-head-side {
    align-items: flex-start;
  }

  .support-chat-head,
  .support-knowledge-card,
  .support-ticket-bottom {
    flex-direction: column;
  }

  .support-bubble-row {
    max-width: 92%;
  }

  .support-composer {
    align-items: stretch;
  }

  .support-kb-drawer {
    width: 100%;
  }

  .support-kb-head,
  .support-kb-toolbar,
  .support-kb-body,
  .support-ticket-body {
    padding-left: 18px;
    padding-right: 18px;
  }

  .support-kb-item,
  .support-ticket-grid {
    grid-template-columns: 1fr;
  }

  .support-kb-item {
    grid-template-columns: 42px minmax(0, 1fr);
  }

  .support-kb-item .btn {
    grid-column: 2;
    justify-self: flex-start;
  }

  .support-ticket-modal {
    width: min(100vw - 16px, 980px);
  }

  .support-ticket-foot {
    align-items: flex-start;
  }
}

.ticket-block {
  margin-top: 16px;
  background: white;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  padding: 32px;
  text-align: center;
  box-shadow: var(--shadow-sm);
}
.ticket-block h3 {
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 0;
}
.ticket-block p {
  margin: 0 0 18px;
  color: var(--text-2);
  font-size: 13px;
  line-height: 1.55;
}

/* Anketa — section header inside long form */
.section-head {
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.12em;
  color: var(--brand-deep);
  padding: 16px 0 12px;
  border-top: 1px solid var(--border);
  margin: 12px 0 4px;
  display: flex;
  align-items: center;
  gap: 10px;
}
.section-head:first-of-type { border-top: none; margin-top: 0; padding-top: 4px; }
.section-head .num {
  width: 22px; height: 22px;
  border-radius: 7px;
  background: var(--brand);
  color: white;
  display: grid; place-items: center;
  font-size: 11px;
  font-weight: 800;
}

.radio-pair {
  display: flex;
  gap: 6px;
  background: var(--n-50);
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  padding: 4px;
  height: 40px;
  align-items: center;
}
.radio-pair label {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12.5px;
  font-weight: 600;
  color: var(--text-2);
  cursor: pointer;
  padding: 5px 10px;
  border-radius: 6px;
  transition: background .12s;
}
.radio-pair input { display: none; }
.radio-pair input:checked + span {
  background: white;
  color: var(--text);
  box-shadow: 0 1px 3px rgba(0,0,0,0.08);
  padding: 5px 10px;
  border-radius: 6px;
}

@media (max-width: 1280px) {
  .material-detail { grid-template-columns: 240px 1fr; }
  .material-aside { grid-column: 1 / -1; flex-direction: row; }
  .material-aside-card { flex: 1; }
}

/* -------- Materials Library -------- */
.materials-page {
  --materials-glow: rgba(199, 42, 108, 0.12);
}
.materials-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(420px, 520px);
  gap: 18px;
  align-items: stretch;
  margin-bottom: 18px;
  padding: 22px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 12% 0%, rgba(199,42,108,0.10), transparent 34%),
    radial-gradient(circle at 92% 18%, rgba(156,100,158,0.12), transparent 30%),
    linear-gradient(135deg, #FFFFFF 0%, #FAFBFC 100%);
  box-shadow: 0 14px 38px rgba(16, 24, 40, 0.06);
  overflow: hidden;
  position: relative;
}
.materials-hero::after {
  content: "";
  position: absolute;
  inset: auto -90px -150px auto;
  width: 280px;
  height: 280px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(37,99,235,0.10), transparent 68%);
  pointer-events: none;
}
.materials-hero-main,
.materials-hero-panel {
  position: relative;
  z-index: 1;
}
.materials-kicker {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  height: 24px;
  padding: 0 9px;
  border-radius: var(--r-pill);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11.5px;
  font-weight: 800;
  margin-bottom: 12px;
}
.materials-title {
  font-size: 30px;
  line-height: 1.05;
  text-wrap: balance;
}
.materials-sub {
  max-width: 620px;
  margin-top: 7px;
  font-size: 13.5px;
  line-height: 1.55;
}
.materials-stat-row {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 170px));
  gap: 10px;
  margin-top: 20px;
}
.materials-stat {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 12px;
  border: 1px solid rgba(208, 213, 221, 0.82);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.76);
  box-shadow: var(--shadow-xs);
}
.materials-stat-icon {
  width: 32px;
  height: 32px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: 9px;
  background: linear-gradient(180deg, var(--brand-soft), white);
  color: var(--brand-deep);
}
.materials-stat strong,
.materials-stat small {
  display: block;
}
.materials-stat strong {
  color: var(--text);
  font-size: 18px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.materials-stat small {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.2;
  white-space: nowrap;
}
.materials-hero-panel {
  display: flex;
  flex-direction: column;
  gap: 12px;
  justify-content: flex-end;
}
.materials-search {
  position: relative;
}
.materials-search svg {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--text-3);
  z-index: 1;
}
.materials-search .input {
  height: 40px;
  padding-left: 36px;
  background: rgba(255,255,255,0.88);
}
.materials-recommend {
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) auto;
  gap: 12px;
  align-items: center;
  padding: 13px;
  border: 1px solid rgba(199,42,108,0.16);
  border-radius: var(--r-lg);
  background: linear-gradient(135deg, rgba(252,231,240,0.68), rgba(255,255,255,0.88));
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.75), var(--shadow-xs);
}
.materials-recommend-mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 10px;
  background: var(--brand-gradient-diag);
  color: white;
  box-shadow: var(--shadow-azure);
}
.materials-recommend span,
.materials-recommend strong,
.materials-recommend small {
  display: block;
}
.materials-recommend span {
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.materials-recommend strong {
  margin-top: 2px;
  font-size: 14px;
  line-height: 1.2;
}
.materials-recommend small {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 11.5px;
}
.materials-page .tabs-underline {
  gap: 12px;
  overflow-x: auto;
  scrollbar-width: thin;
}
.materials-page .tab-u {
  padding-inline: 0;
}
.materials-grid {
  display: grid;
  gap: 14px;
}
.materials-products-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}
.materials-guides-grid {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.materials-guide-strip {
  display: grid;
  grid-template-columns: minmax(260px, 1.2fr) repeat(3, minmax(160px, .72fr));
  gap: 1px;
  margin-bottom: 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--border);
  overflow: hidden;
  box-shadow: var(--shadow-xs);
}
.materials-guide-strip > div {
  min-width: 0;
  padding: 14px 16px;
  background: rgba(255,255,255,0.94);
}
.materials-guide-strip > div:first-child {
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,0.13), transparent 46%),
    linear-gradient(135deg, #FFFFFF, #FCFCFD);
}
.materials-guide-strip span {
  display: block;
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.materials-guide-strip strong {
  display: block;
  margin-top: 4px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.25;
  font-weight: 800;
}
.materials-guide-step {
  display: flex;
  flex-direction: column;
  justify-content: center;
}
.materials-guide-step span {
  color: var(--text-3);
  font-family: var(--font-mono);
  font-size: 11px;
}
.materials-guide-step strong {
  font-size: 12.5px;
  color: var(--text-2);
}
.material-card {
  position: relative;
  display: flex;
  gap: 16px;
  min-height: 172px;
  padding: 18px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.92), rgba(255,255,255,1)),
    var(--surface);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.material-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: transparent;
  transition: background .18s ease;
}
.material-card:hover {
  transform: translateY(-2px);
  border-color: var(--border-strong);
  box-shadow: 0 14px 34px rgba(16,24,40,0.09);
}
.material-card:hover::before {
  background: var(--brand-gradient-diag);
}
.material-card.is-featured {
  background:
    radial-gradient(circle at 0% 0%, rgba(199,42,108,0.10), transparent 38%),
    linear-gradient(180deg, #FFFFFF, #FFFFFF);
}
.material-guide-card {
  min-height: 184px;
  flex-direction: column;
  gap: 0;
}
.material-guide-card::after {
  content: "";
  position: absolute;
  right: -42px;
  top: -42px;
  width: 116px;
  height: 116px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(199,42,108,0.08), transparent 68%);
  pointer-events: none;
}
.material-guide-top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  min-width: 0;
}
.material-guide-progress {
  height: 4px;
  margin-top: 16px;
  border-radius: var(--r-pill);
  background: var(--n-100);
  overflow: hidden;
}
.material-guide-progress i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-gradient);
}
.material-guide-card .btn.ghost {
  color: var(--brand-deep);
  font-weight: 800;
}
.material-guide-card .btn.ghost:hover {
  background: var(--brand-soft);
}
.material-doc-thumb {
  width: 64px;
  height: 80px;
  border-radius: 7px;
  flex-shrink: 0;
  background: linear-gradient(145deg, var(--doc-color), color-mix(in srgb, var(--doc-color), #101828 12%));
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 8px;
  box-shadow: 0 11px 22px color-mix(in srgb, var(--doc-color), transparent 78%);
  overflow: visible;
}
.material-doc-thumb::after {
  content: "";
  position: absolute;
  left: 8px;
  right: 8px;
  top: 10px;
  height: 2px;
  border-radius: 2px;
  background: rgba(255,255,255,0.28);
  box-shadow: 0 8px 0 rgba(255,255,255,0.18), 0 16px 0 rgba(255,255,255,0.14);
}
.material-doc-fold {
  position: absolute;
  top: 8px;
  right: -5px;
  width: 18px;
  height: 22px;
  background: rgba(255,255,255,0.86);
  clip-path: polygon(0 0, 100% 0, 100% 100%, 50% 80%, 0 100%);
  box-shadow: -2px 2px 8px rgba(16,24,40,0.10);
}
.material-doc-thumb > span:last-child {
  color: white;
  font-size: 11px;
  font-weight: 800;
  line-height: 1;
}
.material-preview-tile {
  width: 64px;
  height: 64px;
  border-radius: 12px;
  flex-shrink: 0;
  background: linear-gradient(145deg, var(--tile-color), color-mix(in srgb, var(--tile-color), #101828 14%));
  color: white;
  display: grid;
  place-items: center;
  box-shadow: 0 10px 22px color-mix(in srgb, var(--tile-color), transparent 82%);
}
.material-card-copy {
  min-width: 0;
  flex: 1;
  display: flex;
  flex-direction: column;
}
.material-card-meta {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
  color: var(--text-3);
  font-size: 11.5px;
}
.material-kind {
  min-height: 22px;
  display: inline-flex;
  align-items: center;
  padding: 0 8px;
  border-radius: var(--r-pill);
  background: color-mix(in srgb, var(--kind-color), transparent 86%);
  color: color-mix(in srgb, var(--kind-color), #101828 10%);
  font-size: 10.5px;
  font-weight: 800;
}
.material-card-title {
  color: var(--text);
  font-size: 15.5px;
  line-height: 1.25;
  font-weight: 800;
  text-wrap: pretty;
}
.material-card-desc {
  margin-top: 7px;
  color: var(--text-2);
  font-size: 12.7px;
  line-height: 1.55;
  text-wrap: pretty;
}
.material-card-foot {
  display: flex;
  align-items: center;
  gap: 13px;
  margin-top: auto;
  padding-top: 14px;
  color: var(--text-3);
  font-size: 11.5px;
}
.material-card-foot > span:not(.material-card-spacer) {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  white-space: nowrap;
}
.material-card-spacer {
  flex: 1;
}
.material-product-card .btn.ghost,
.materials-row-actions .btn.ghost {
  min-width: 30px;
  justify-content: center;
}
.materials-video-lead {
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  gap: 18px;
  align-items: stretch;
  margin-bottom: 14px;
  padding: 16px 18px;
  border: 1px solid rgba(208,213,221,0.78);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,0.10), transparent 38%),
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(249,250,251,0.96));
  box-shadow: var(--shadow-xs);
}
.materials-video-lead-copy span,
.materials-video-lead-copy strong,
.materials-video-lead-copy small {
  display: block;
}
.materials-video-lead-copy span {
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.materials-video-lead-copy strong {
  margin-top: 4px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.2;
  font-weight: 800;
}
.materials-video-lead-copy small {
  max-width: 620px;
  margin-top: 6px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.materials-video-lead-stats {
  display: grid;
  grid-template-columns: repeat(2, minmax(110px, 1fr));
  gap: 10px;
}
.materials-video-lead-stat {
  min-width: 0;
  padding: 14px 16px;
  border-radius: 12px;
  background: rgba(255,255,255,0.82);
  border: 1px solid rgba(208,213,221,0.74);
}
.materials-video-lead-stat strong,
.materials-video-lead-stat span {
  display: block;
}
.materials-video-lead-stat strong {
  color: var(--text);
  font-size: 20px;
  line-height: 1;
  font-weight: 800;
}
.materials-video-lead-stat span {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.5px;
}
.materials-video-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.materials-video-card {
  cursor: pointer;
  border-radius: var(--r-lg);
  padding: 10px;
  background: linear-gradient(180deg, rgba(255,255,255,0.94), #fff);
  border: 1px solid rgba(208,213,221,0.82);
  box-shadow: var(--shadow-xs);
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease, background .18s ease;
}
.materials-video-card:hover {
  transform: translateY(-2px);
  border-color: rgba(199,42,108,0.24);
  box-shadow: 0 14px 34px rgba(16,24,40,0.09);
}
.materials-video-thumb {
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 8px;
  background:
    radial-gradient(circle at 25% 36%, rgba(199,42,108,0.34), transparent 38%),
    radial-gradient(circle at 78% 70%, rgba(37,99,235,0.22), transparent 40%),
    linear-gradient(135deg, #26252c 0%, #162f34 100%);
  position: relative;
  overflow: hidden;
  border: 1px solid rgba(16,24,40,0.16);
}
.materials-video-thumb::before {
  content: "";
  position: absolute;
  inset: 0;
  background-image:
    linear-gradient(120deg, rgba(255,255,255,0.10), transparent 34%),
    repeating-linear-gradient(90deg, rgba(255,255,255,0.035) 0 1px, transparent 1px 84px);
  opacity: .7;
}
.materials-video-sheen {
  position: absolute;
  inset: auto 0 0;
  height: 42%;
  background: linear-gradient(180deg, transparent, rgba(7,12,18,0.48));
}
.materials-video-play-wrap {
  position: absolute;
  inset: 0;
  display: grid;
  place-items: center;
}
.materials-video-play {
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: rgba(255,255,255,0.96);
  color: var(--ink);
  display: grid;
  place-items: center;
  box-shadow: 0 12px 28px rgba(0,0,0,0.28);
  transition: transform .18s ease, background .18s ease;
}
.materials-video-card:hover .materials-video-play {
  transform: scale(1.06);
  background: #fff;
}
.materials-video-duration {
  position: absolute;
  right: 8px;
  bottom: 8px;
  background: rgba(16,24,40,0.82);
  color: #fff;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
  padding: 5px 7px;
  border-radius: 5px;
}
.materials-video-copy {
  padding: 12px 4px 4px;
}
.materials-video-kicker {
  color: var(--brand-deep);
  font-size: 10.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.materials-video-title {
  margin-top: 5px;
  color: var(--text);
  font-size: 15px;
  line-height: 1.35;
  font-weight: 800;
  text-wrap: pretty;
}
.materials-video-meta {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-top: 8px;
  color: var(--text-3);
  font-size: 11.5px;
}
.materials-video-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.materials-video-meta span + span::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
  opacity: .55;
}
.materials-template-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, .78fr);
  gap: 16px;
  align-items: flex-start;
}
.materials-doc-card,
.materials-edo-card,
.materials-bank-card {
  border-color: rgba(208,213,221,0.78);
  box-shadow: 0 10px 28px rgba(16,24,40,0.045);
}
.materials-doc-card .card-head,
.materials-edo-card .card-head,
.materials-bank-card .card-head {
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,0.08), transparent 34%),
    linear-gradient(180deg, #fff, #fcfcfd);
}
.materials-doc-row,
.materials-legal-row,
.materials-bank-doc-row {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 15px 18px;
  border-top: 1px solid var(--border);
  transition: background .16s ease;
}
.materials-doc-row.is-first,
.materials-legal-row.is-first,
.materials-bank-doc-row.is-first {
  border-top: none;
}
.materials-doc-row,
.materials-legal-row {
  cursor: pointer;
}
.materials-doc-row:hover,
.materials-legal-row:hover,
.materials-bank-doc-row:hover {
  background: linear-gradient(90deg, rgba(252,231,240,0.42), rgba(255,255,255,0));
}
.materials-doc-row-icon {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  background: var(--brand-soft);
  color: var(--brand-deep);
  flex-shrink: 0;
}
.materials-doc-row-copy,
.materials-legal-copy,
.materials-bank-doc-copy,
.materials-bank-notice-copy {
  min-width: 0;
  flex: 1;
}
.materials-doc-row-title,
.materials-bank-notice-title {
  color: var(--text);
  font-weight: 800;
  font-size: 14px;
}
.materials-doc-row-desc,
.materials-bank-notice-desc {
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
  text-wrap: pretty;
}
.materials-edo-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.materials-edo-note {
  margin: 0;
}
.materials-template-head {
  align-items: flex-start;
  gap: 16px;
}
.materials-template-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.materials-template-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
  padding: 14px 18px 16px;
  border-top: 1px solid rgba(208,213,221,0.62);
  background:
    linear-gradient(180deg, rgba(255,255,255,0.88), rgba(249,250,251,0.72));
}
.materials-template-summary-item {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 12px;
  border: 1px solid rgba(208,213,221,0.76);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--shadow-xs);
}
.materials-template-summary-icon {
  width: 30px;
  height: 30px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: 8px;
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.materials-template-summary-item strong,
.materials-template-summary-item small {
  display: block;
}
.materials-template-summary-item strong {
  color: var(--text);
  font-size: 15.5px;
  line-height: 1;
  font-weight: 800;
}
.materials-template-summary-item small {
  margin-top: 4px;
  color: var(--text-2);
  font-size: 11.3px;
  line-height: 1.25;
}
.materials-doc-list {
  border-top: 1px solid var(--border);
}
.materials-template-row {
  position: relative;
  min-height: 72px;
  padding: 17px 18px;
  background: linear-gradient(90deg, rgba(255,255,255,0.98), rgba(255,255,255,0.92));
}
.materials-template-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: transparent;
  transition: background .16s ease;
}
.materials-template-row:hover::before {
  background: var(--brand-gradient);
}
.materials-template-row-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  box-shadow: inset 0 0 0 1px rgba(199,42,108,0.06);
}
.materials-template-row.tone-edo .materials-template-row-icon {
  background: rgba(156,100,158,0.12);
  color: var(--purple);
}
.materials-template-row.tone-docs .materials-template-row-icon {
  background: rgba(3,152,85,0.10);
  color: var(--green);
}
.materials-template-row.tone-banks .materials-template-row-icon {
  background: rgba(37,99,235,0.09);
  color: #2563EB;
}
.materials-template-row-top {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
}
.materials-template-row-top > span {
  flex-shrink: 0;
  color: var(--text-3);
  font-size: 11.5px;
  line-height: 1.4;
  white-space: nowrap;
}
.materials-template-row-action {
  min-width: 84px;
  display: inline-flex;
  align-items: center;
  justify-content: flex-end;
  gap: 6px;
  color: var(--text-3);
  font-size: 12px;
  font-weight: 800;
  transition: color .16s ease, transform .16s ease;
}
.materials-template-row:hover .materials-template-row-action {
  color: var(--brand-deep);
  transform: translateX(2px);
}
.materials-template-side {
  position: sticky;
  top: 76px;
  overflow: hidden;
}
.materials-edo-live {
  height: 24px;
  display: inline-flex;
  align-items: center;
  padding: 0 9px;
  border-radius: var(--r-pill);
  background: var(--n-100);
  color: var(--text-2);
  font-size: 11px;
  font-weight: 800;
}
.materials-edo-progress {
  padding: 14px;
  border: 1px solid rgba(199,42,108,0.14);
  border-radius: var(--r-md);
  background:
    radial-gradient(circle at 100% 0, rgba(199,42,108,0.10), transparent 42%),
    linear-gradient(135deg, rgba(252,231,240,0.46), rgba(255,255,255,0.94));
}
.materials-edo-progress strong,
.materials-edo-progress span {
  display: block;
}
.materials-edo-progress strong {
  color: var(--text);
  font-size: 18px;
  line-height: 1;
  font-weight: 800;
}
.materials-edo-progress span {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 12px;
}
.materials-edo-progress-bar {
  height: 5px;
  margin-top: 13px;
  border-radius: var(--r-pill);
  background: rgba(199,42,108,0.12);
  overflow: hidden;
}
.materials-edo-progress-bar i {
  display: block;
  height: 100%;
  border-radius: inherit;
  background: var(--brand-gradient);
}
.materials-edo-step {
  display: grid;
  grid-template-columns: 24px minmax(0, 1fr) auto;
  gap: 10px;
  align-items: center;
  padding: 11px 0;
  border-bottom: 1px solid var(--border);
  color: var(--text-2);
  font-size: 12.5px;
}
.materials-edo-step:last-of-type {
  border-bottom: none;
}
.materials-edo-step-mark {
  width: 24px;
  height: 24px;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--n-100);
  color: var(--text-3);
}
.materials-edo-step.done .materials-edo-step-mark {
  background: rgba(3,152,85,0.12);
  color: var(--green);
}
.materials-edo-step.active .materials-edo-step-mark {
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.materials-edo-step span:nth-child(2) {
  min-width: 0;
}
.materials-edo-step strong {
  color: var(--text);
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}
.materials-head-actions,
.materials-row-actions,
.materials-bank-head {
  gap: 8px;
}
.materials-row-actions {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.materials-legal-row {
  gap: 16px;
}
.materials-legal-title-line {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 5px;
  flex-wrap: wrap;
}
.materials-legal-title {
  color: var(--text);
  font-weight: 800;
  font-size: 14px;
}
.materials-version {
  font-size: 10.5px;
}
.materials-legal-desc {
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.45;
  margin-bottom: 6px;
  text-wrap: pretty;
}
.materials-legal-meta {
  gap: 14px;
  color: var(--text-3);
  font-size: 11.5px;
}
.materials-legal-meta span {
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.materials-platform-wrap {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.materials-platform-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, 460px);
  gap: 16px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid rgba(208,213,221,0.82);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 8% 12%, rgba(199,42,108,0.13), transparent 34%),
    radial-gradient(circle at 96% 0%, rgba(156,100,158,0.13), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(249,250,251,0.94));
  box-shadow: 0 14px 34px rgba(16,24,40,0.055);
  overflow: hidden;
}
.materials-platform-hero-copy {
  min-width: 0;
  padding: 4px 2px;
}
.materials-platform-kicker {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 26px;
  padding: 0 10px;
  border-radius: var(--r-pill);
  background: rgba(252,231,240,0.92);
  color: var(--brand-deep);
  font-size: 11.5px;
  font-weight: 800;
}
.materials-platform-hero h2 {
  max-width: 680px;
  margin: 14px 0 0;
  color: var(--text);
  font-size: 25px;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: 0;
  text-wrap: balance;
}
.materials-platform-hero p {
  max-width: 660px;
  margin: 9px 0 0;
  color: var(--text-2);
  font-size: 13.2px;
  line-height: 1.58;
  text-wrap: pretty;
}
.materials-platform-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.materials-platform-feature {
  position: relative;
  min-width: 0;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 16px;
  padding: 16px;
  border: 1px solid rgba(199,42,108,0.16);
  border-radius: var(--r-lg);
  background:
    linear-gradient(135deg, rgba(255,255,255,0.92), rgba(252,231,240,0.58)),
    #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.82), var(--shadow-xs);
  cursor: pointer;
  transition: transform .18s ease, box-shadow .18s ease, border-color .18s ease;
}
.materials-platform-feature:hover {
  transform: translateY(-2px);
  border-color: rgba(199,42,108,0.26);
  box-shadow: 0 16px 34px rgba(199,42,108,0.11);
}
.materials-platform-feature-top {
  display: flex;
  gap: 14px;
  align-items: flex-start;
  min-width: 0;
}
.materials-platform-feature-top span,
.materials-platform-feature-top strong,
.materials-platform-feature-top small {
  display: block;
}
.materials-platform-feature-top span {
  color: var(--brand-deep);
  font-size: 11px;
  font-weight: 800;
}
.materials-platform-feature-top strong {
  margin-top: 5px;
  color: var(--text);
  font-size: 16px;
  line-height: 1.25;
  font-weight: 800;
  text-wrap: pretty;
}
.materials-platform-feature-top small {
  margin-top: 7px;
  color: var(--text-2);
  font-size: 12.3px;
  line-height: 1.45;
}
.materials-platform-feature-meta {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 7px;
}
.materials-platform-feature-meta span {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 9px;
  border-radius: var(--r-pill);
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(208,213,221,0.68);
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.materials-platform-summary {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}
.materials-platform-summary-item {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 11px;
  padding: 13px 14px;
  border: 1px solid rgba(208,213,221,0.78);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.88);
  box-shadow: var(--shadow-xs);
}
.materials-platform-summary-item > span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 9px;
  background: linear-gradient(180deg, var(--brand-soft), #fff);
  color: var(--brand-deep);
}
.materials-platform-summary-item strong,
.materials-platform-summary-item small {
  display: block;
}
.materials-platform-summary-item strong {
  color: var(--text);
  font-size: 16px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.materials-platform-summary-item small {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.25;
}
.materials-platform-card {
  overflow: hidden;
}
.materials-platform-list {
  background:
    linear-gradient(90deg, rgba(252,231,240,0.14), transparent 22%),
    #fff;
}
.materials-platform-row {
  position: relative;
  display: grid;
  grid-template-columns: 42px minmax(0, 1fr) minmax(100px, 128px) auto;
  align-items: center;
  gap: 14px;
  padding: 16px 18px;
}
.materials-platform-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: transparent;
  transition: background .16s ease;
}
.materials-platform-row:hover::before {
  background: var(--brand-gradient);
}
.materials-platform-row.is-active,
.materials-bank-doc-row.is-active {
  background: linear-gradient(90deg, rgba(252,231,240,0.6), rgba(255,255,255,0.98));
}
.materials-platform-row.is-active::before {
  background: var(--brand-gradient);
}
.materials-docs-shell,
.materials-bank-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(320px, 380px);
  gap: 16px;
  align-items: start;
}
.materials-bank-main {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.materials-preview-rail {
  position: sticky;
  top: 76px;
  border-color: rgba(208,213,221,0.78);
  box-shadow: 0 14px 34px rgba(16,24,40,0.055);
  overflow: hidden;
}
.materials-preview-card .card-head {
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,0.08), transparent 34%),
    linear-gradient(180deg, #fff, #fcfcfd);
}
.materials-preview-head {
  align-items: flex-start;
  gap: 12px;
}
.materials-preview-body {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.materials-preview-sheet {
  position: relative;
  overflow: hidden;
  padding: 16px;
  border: 1px solid rgba(208,213,221,0.78);
  border-radius: 14px;
  background:
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(249,250,251,0.92));
  box-shadow: var(--shadow-xs);
}
.materials-preview-sheet::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--preview-accent, var(--brand));
}
.materials-preview-sheet-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  color: var(--text-3);
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: 0.04em;
}
.materials-preview-sheet-top strong {
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 800;
  text-transform: none;
  letter-spacing: 0;
}
.materials-preview-sheet-title {
  margin-top: 12px;
  color: var(--text);
  font-size: 18px;
  line-height: 1.3;
  font-weight: 800;
  text-wrap: pretty;
}
.materials-preview-sheet-desc {
  margin-top: 8px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.55;
  text-wrap: pretty;
}
.materials-preview-sheet-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 14px;
}
.materials-preview-sheet-meta span {
  min-height: 26px;
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 9px;
  border-radius: var(--r-pill);
  border: 1px solid rgba(208,213,221,0.76);
  background: rgba(255,255,255,0.9);
  color: var(--text-2);
  font-size: 11.5px;
  font-weight: 700;
}
.materials-preview-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.materials-preview-points {
  display: grid;
  gap: 10px;
}
.materials-preview-point {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.5;
}
.materials-preview-point > span {
  width: 22px;
  height: 22px;
  flex-shrink: 0;
  display: grid;
  place-items: center;
  border-radius: 50%;
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.materials-pdf-action {
  align-items: flex-end;
}
.materials-pdf-menu {
  left: auto;
  right: 0;
  min-width: 228px;
}
.materials-bank-doc-row {
  position: relative;
  cursor: pointer;
}
.materials-bank-doc-row::before {
  content: "";
  position: absolute;
  left: 0;
  top: 12px;
  bottom: 12px;
  width: 3px;
  border-radius: 0 3px 3px 0;
  background: transparent;
  transition: background .16s ease;
}
.materials-bank-doc-row:hover::before,
.materials-bank-doc-row.is-active::before {
  background: linear-gradient(180deg, var(--brand), var(--brand-purple));
}
@media (max-width: 1360px) {
  .materials-docs-shell,
  .materials-bank-layout {
    grid-template-columns: 1fr;
  }
  .materials-preview-rail {
    position: static;
  }
}

.materials-platform-row-mark {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 11px;
  background: var(--brand-soft);
  color: var(--brand-deep);
  box-shadow: inset 0 0 0 1px rgba(199,42,108,0.08);
}
.materials-bank-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.materials-bank-notice {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 18px;
  border: 1px solid rgba(199,42,108,0.16);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 0 0, rgba(199,42,108,0.11), transparent 42%),
    linear-gradient(135deg, rgba(252,231,240,0.82), #fff);
  box-shadow: var(--shadow-xs);
}
.materials-bank-notice-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  background: var(--brand);
  color: #fff;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  box-shadow: var(--shadow-azure);
}
.materials-bank-logo {
  width: 36px;
  height: 36px;
  border-radius: 8px;
  background: var(--bank-color);
  color: #191C1E;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 15px;
  flex-shrink: 0;
  box-shadow: inset 0 0 0 1px rgba(16,24,40,0.08);
}
.materials-bank-doc-type {
  width: 32px;
  height: 32px;
  border-radius: 7px;
  background: var(--pink-soft);
  color: var(--pink-deep);
  display: grid;
  place-items: center;
  font-size: 10px;
  font-weight: 800;
  flex-shrink: 0;
}
.materials-bank-doc-title {
  color: var(--text);
  font-weight: 700;
  font-size: 13.5px;
  line-height: 1.35;
}
.materials-bank-doc-meta {
  margin-top: 2px;
  color: var(--text-3);
  font-size: 11.5px;
}

.materials-bank-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(300px, 410px);
  gap: 16px;
  align-items: stretch;
  padding: 18px;
  border: 1px solid rgba(208,213,221,0.82);
  border-radius: var(--r-lg);
  background:
    radial-gradient(circle at 8% 0%, rgba(199,42,108,0.12), transparent 34%),
    radial-gradient(circle at 94% 22%, rgba(37,99,235,0.10), transparent 32%),
    linear-gradient(135deg, rgba(255,255,255,0.96), rgba(249,250,251,0.94));
  box-shadow: 0 14px 34px rgba(16,24,40,0.055);
  overflow: hidden;
}
.materials-bank-hero-copy {
  min-width: 0;
  padding: 2px;
}
.materials-bank-hero h2 {
  max-width: 760px;
  margin: 14px 0 0;
  color: var(--text);
  font-size: 25px;
  line-height: 1.12;
  font-weight: 800;
  letter-spacing: 0;
  text-wrap: balance;
}
.materials-bank-hero p {
  max-width: 730px;
  margin: 9px 0 0;
  color: var(--text-2);
  font-size: 13.2px;
  line-height: 1.58;
  text-wrap: pretty;
}
.materials-bank-hero-actions {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 18px;
}
.materials-bank-hero-panel {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
.materials-bank-stat {
  min-width: 0;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 13px 14px;
  border: 1px solid rgba(208,213,221,0.76);
  border-radius: var(--r-md);
  background: rgba(255,255,255,0.82);
  box-shadow: var(--shadow-xs);
}
.materials-bank-stat > span {
  width: 34px;
  height: 34px;
  display: grid;
  place-items: center;
  flex-shrink: 0;
  border-radius: 9px;
  background: linear-gradient(180deg, var(--brand-soft), #fff);
  color: var(--brand-deep);
}
.materials-bank-stat strong,
.materials-bank-stat small {
  display: block;
}
.materials-bank-stat strong {
  color: var(--text);
  font-size: 17px;
  line-height: 1;
  font-weight: 800;
  font-variant-numeric: tabular-nums;
}
.materials-bank-stat small {
  margin-top: 5px;
  color: var(--text-2);
  font-size: 11.5px;
  line-height: 1.25;
}
.materials-bank-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.materials-bank-card {
  position: relative;
  overflow: hidden;
}
.materials-bank-card::before {
  content: "";
  position: absolute;
  inset: 0 auto 0 0;
  width: 3px;
  background: var(--bank-color);
  opacity: .88;
}
.materials-bank-card .card-head {
  min-height: 68px;
  padding-left: 18px;
  background:
    radial-gradient(circle at 0 0, color-mix(in srgb, var(--bank-color), transparent 88%), transparent 44%),
    linear-gradient(180deg, #fff, #fcfcfd);
}
.materials-bank-head {
  min-width: 0;
}
.materials-bank-head-actions {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
}
.materials-bank-card-body {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--bank-color), transparent 96%), transparent 38%),
    #fff;
}
.materials-bank-doc-row {
  position: relative;
  display: grid;
  grid-template-columns: 38px minmax(0, 1fr) auto;
  min-height: 74px;
  padding: 14px 16px 14px 18px;
  transition: background .16s ease, transform .16s ease;
}
.materials-bank-doc-row:hover {
  background:
    linear-gradient(90deg, color-mix(in srgb, var(--bank-color), transparent 92%), rgba(255,255,255,0));
}
.materials-bank-doc-type {
  width: 34px;
  height: 34px;
  border-radius: 9px;
  background: color-mix(in srgb, var(--bank-color), #fff 86%);
  color: color-mix(in srgb, var(--bank-color), #101828 22%);
  box-shadow: inset 0 0 0 1px color-mix(in srgb, var(--bank-color), transparent 82%);
}
.materials-bank-doc-kicker {
  margin-bottom: 3px;
  color: color-mix(in srgb, var(--bank-color), #101828 30%);
  font-family: var(--font-mono);
  font-size: 10.5px;
  line-height: 1;
  font-weight: 700;
}
.materials-bank-doc-title {
  font-weight: 800;
  font-size: 13.8px;
}
.materials-bank-doc-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.materials-bank-doc-meta span {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}
.materials-bank-doc-meta span + span::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: currentColor;
  opacity: .55;
}
.materials-bank-notice-copy {
  display: flex;
  align-items: center;
  gap: 14px;
  justify-content: space-between;
}
.materials-bank-notice-copy .badge {
  flex-shrink: 0;
}

@media (max-width: 1180px) {
  .materials-hero,
  .materials-products-grid,
  .materials-guides-grid,
  .materials-guide-strip,
  .materials-video-grid,
  .materials-template-layout,
  .materials-video-lead,
  .materials-bank-hero,
  .materials-bank-grid {
    grid-template-columns: 1fr;
  }
  .materials-hero-panel {
    max-width: none;
  }
}

@media (max-width: 760px) {
  .materials-hero {
    padding: 18px;
  }
  .materials-title {
    font-size: 25px;
  }
  .materials-stat-row,
  .materials-recommend {
    grid-template-columns: 1fr;
  }
  .materials-stat small {
    white-space: normal;
  }
  .material-card,
  .materials-recommend {
    align-items: flex-start;
  }
  .materials-doc-row,
  .materials-legal-row,
  .materials-bank-doc-row,
  .materials-bank-notice,
  .materials-doc-card .card-head,
  .materials-bank-card .card-head,
  .materials-video-lead {
    align-items: flex-start;
    flex-direction: column;
  }
  .materials-template-summary {
    grid-template-columns: 1fr;
  }
  .materials-template-actions,
  .materials-template-row-top {
    width: 100%;
    flex-wrap: wrap;
  }
  .materials-template-row-action {
    width: 100%;
    justify-content: flex-start;
  }
  .materials-template-side {
    position: static;
  }
  .materials-doc-row,
  .materials-legal-row,
  .materials-bank-doc-row {
    gap: 10px;
  }
  .materials-row-actions,
  .materials-head-actions {
    width: 100%;
    flex-wrap: wrap;
  }
  .materials-row-actions .btn:first-child {
    flex: 1;
    justify-content: center;
  }
  .materials-video-lead-stats,
  .materials-video-meta {
    width: 100%;
    grid-template-columns: 1fr;
    flex-wrap: wrap;
  }
  .materials-platform-hero,
  .materials-platform-summary,
  .materials-platform-row,
  .materials-bank-hero-panel {
    grid-template-columns: 1fr;
  }
  .materials-platform-feature-top {
    flex-direction: column;
  }
  .materials-bank-hero h2 {
    font-size: 21px;
  }
  .materials-bank-notice-copy,
  .materials-bank-head-actions {
    width: 100%;
    flex-wrap: wrap;
  }
  .materials-bank-doc-row {
    grid-template-columns: 34px minmax(0, 1fr);
  }
  .materials-bank-doc-row .materials-row-actions {
    grid-column: 1 / -1;
    padding-left: 44px;
  }
  .material-card-foot {
    flex-wrap: wrap;
  }
  .material-card-spacer {
    flex-basis: 100%;
  }
}


@media(max-width:980px) {
  .debtor-invoice-modal-body {
    grid-template-columns: 1fr;
  }
}
@media(max-width:760px) {
  .debtor-invoice-form-intro {
    flex-direction: column;
    align-items: stretch;
  }
  .debtor-invoice-upload-card {
    grid-template-columns: 1fr;
  }
  .debtor-invoice-grid {
    grid-template-columns: 1fr;
  }
  .debtor-invoice-modal {
    width: min(calc(100vw - 16px), 1120px);
  }
}


.debtor-upload-modal .documents-upload-zone {
  margin: 0;
}
.debtor-upload-file {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin-top: 12px;
  padding: 12px 14px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: #fff;
}
.debtor-upload-file strong {
  display: block;
  color: var(--text);
  font-size: 13px;
  font-weight: 800;
}
.debtor-upload-file span {
  display: block;
  margin-top: 3px;
  color: var(--text-2);
  font-size: 12px;
}
.debtor-upload-error {
  margin-top: 10px;
  color: var(--danger);
  font-size: 12px;
  font-weight: 700;
}

/* -------- Protected public landing -------- */
.public-landing {
  min-height: 100vh;
  background:
    linear-gradient(180deg, rgba(252, 231, 240, 0.42) 0%, rgba(245, 246, 248, 0) 360px),
    var(--bg);
  color: var(--text);
  overflow-x: hidden;
}
.public-landing main { display: block; }
.landing-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 255, 255, 0.94);
  border-bottom: 1px solid var(--border);
  backdrop-filter: blur(16px);
}
.landing-header__inner {
  width: min(1180px, calc(100% - 40px));
  height: 64px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 18px;
}
.landing-header__brand {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  border: 0;
  background: transparent;
  padding: 0;
  color: var(--text);
  font-size: 15px;
  font-weight: 800;
  letter-spacing: .02em;
}
.landing-header__mark {
  width: 31px;
  height: 31px;
  display: inline-grid;
  place-items: center;
  border-radius: var(--r-md);
  background: white;
  border: 1px solid var(--border);
  box-shadow: var(--shadow-xs);
  overflow: hidden;
}
.landing-header__mark img {
  width: 22px;
  height: 22px;
  object-fit: contain;
}
.landing-header__nav {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 4px;
  flex: 1;
}
.landing-header__nav button,
.landing-header__mobile button:not(.btn) {
  height: 34px;
  border: 1px solid transparent;
  border-radius: var(--r-md);
  background: transparent;
  padding: 0 11px;
  color: var(--text-2);
  font-size: 13px;
  font-weight: 700;
  transition: background .16s ease, color .16s ease, border-color .16s ease, transform .16s ease;
}
.landing-header__nav button:hover,
.landing-header__mobile button:not(.btn):hover {
  background: var(--n-50);
  color: var(--text);
  border-color: var(--border);
  transform: translateY(-1px);
}
.landing-header__actions {
  display: flex;
  align-items: center;
  gap: 8px;
}
.landing-header__menu { display: none; }
.landing-header__mobile {
  display: none;
  width: min(1180px, calc(100% - 32px));
  margin: 0 auto;
  padding: 10px 0 14px;
  border-top: 1px solid var(--border);
}

.landing-hero {
  min-height: calc(100dvh - 64px);
  display: flex;
  align-items: center;
  padding: 46px 0 56px;
}
.landing-hero__inner,
.landing-ecosystem__inner,
.landing-workflow__inner,
.landing-lead__inner {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}
.landing-hero__inner {
  display: grid;
  grid-template-columns: minmax(0, .95fr) minmax(360px, .75fr);
  gap: 34px;
  align-items: center;
}
.landing-hero__copy {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 18px;
  min-width: 0;
}
.landing-hero__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  height: 28px;
  padding: 0 10px;
  border-radius: var(--r-pill);
  background: var(--brand-soft);
  color: var(--brand-deep);
  font-size: 11.5px;
  font-weight: 800;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.landing-hero__title {
  max-width: 720px;
  margin: 0;
  font-size: clamp(42px, 5vw, 68px);
  line-height: 1.02;
  font-weight: 800;
  letter-spacing: 0;
  color: var(--text);
}
.landing-hero__body {
  max-width: 560px;
  margin: 0;
  color: var(--text-2);
  font-size: 17px;
  line-height: 1.5;
}
.landing-hero__actions {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 2px;
}
.landing-hero__facts {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
  padding-top: 8px;
}
.landing-hero__facts span {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  min-height: 34px;
  padding: 7px 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  background: rgba(255, 255, 255, .76);
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
}
.landing-prognosis {
  display: flex;
  flex-direction: column;
  gap: 16px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: var(--r-xl);
  background: rgba(255, 255, 255, .96);
  box-shadow: var(--shadow-md);
}
.landing-prognosis__head {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 14px;
}
.landing-prognosis__head h2 {
  margin: 0 0 4px;
  font-size: 18px;
  line-height: 1.2;
}
.landing-prognosis__head p,
.landing-prognosis__footnote {
  margin: 0;
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.45;
}
.landing-prognosis__controls {
  display: grid;
  gap: 13px;
}
.landing-prognosis__control {
  display: grid;
  gap: 8px;
}
.landing-prognosis__control > span {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}
.landing-prognosis__control b {
  color: var(--text);
  font-variant-numeric: tabular-nums;
}
.landing-prognosis__control small {
  color: var(--bad);
  font-size: 12px;
  font-weight: 700;
}
.landing-prognosis__control.is-invalid .input {
  border-color: var(--bad);
  background: var(--bad-soft);
}
.landing-prognosis__range {
  width: 100%;
  accent-color: var(--brand);
}
.landing-prognosis__result {
  display: grid;
  gap: 1px;
  overflow: hidden;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--border);
}
.landing-prognosis__line {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  min-height: 42px;
  padding: 9px 12px;
  background: var(--surface);
  color: var(--text-2);
  font-size: 12.5px;
  font-weight: 700;
}
.landing-prognosis__line strong {
  color: var(--text);
  font-size: 14px;
  white-space: nowrap;
}
.landing-prognosis__line.is-total {
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.landing-prognosis__line.is-total strong {
  color: var(--brand-deep);
  font-size: 18px;
  font-weight: 800;
}
.landing-prognosis .btn {
  justify-content: center;
  width: 100%;
}

.landing-ecosystem,
.landing-workflow,
.landing-compare,
.landing-lead {
  padding: 74px 0;
  scroll-margin-top: 78px;
}
.landing-ecosystem {
  background: var(--surface);
  border-top: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
}
.landing-ecosystem__header,
.landing-workflow__header,
.landing-compare__head {
  max-width: 710px;
  margin: 0 auto 28px;
  text-align: center;
}
.landing-ecosystem__title,
.landing-workflow__title,
.landing-compare__head h2,
.landing-lead__context h2 {
  margin: 0;
  color: var(--text);
  font-size: clamp(30px, 3.7vw, 46px);
  line-height: 1.08;
  font-weight: 800;
  letter-spacing: 0;
}
.landing-ecosystem__lead,
.landing-workflow__copy,
.landing-compare__copy,
.landing-lead__context p {
  margin: 12px 0 0;
  color: var(--text-2);
  font-size: 16px;
  line-height: 1.5;
}
.landing-ecosystem__map {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
  align-items: stretch;
}
.landing-ecosystem__center,
.landing-ecosystem__node {
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-xs);
  transition: transform .16s ease, border-color .16s ease, box-shadow .16s ease, background .16s ease;
}
.landing-ecosystem__center:hover,
.landing-ecosystem__node:hover {
  transform: translateY(-1px);
  border-color: var(--border-strong);
  box-shadow: var(--shadow-sm);
}
.landing-ecosystem__center {
  grid-column: 1 / -1;
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 16px;
  align-items: center;
  padding: 20px;
  background: linear-gradient(180deg, var(--surface) 0%, var(--surface-2) 100%);
}
.landing-ecosystem__center-mark {
  width: 44px;
  height: 44px;
  border-radius: var(--r-xl);
  display: grid;
  place-items: center;
  background: var(--brand-gradient);
  color: white;
  font-size: 16px;
  font-weight: 800;
  box-shadow: var(--shadow-azure);
}
.landing-ecosystem__center strong {
  display: block;
  margin-bottom: 4px;
  font-size: 18px;
  font-weight: 800;
}
.landing-ecosystem__center p,
.landing-ecosystem__node-copy {
  margin: 0;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.5;
}
.landing-ecosystem__node { padding: 18px; }
.landing-ecosystem__node > span {
  width: 38px;
  height: 38px;
  display: grid;
  place-items: center;
  margin-bottom: 14px;
  border-radius: var(--r-lg);
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.landing-ecosystem__node-title {
  margin-bottom: 6px;
  font-size: 15px;
  font-weight: 800;
}
.landing-ecosystem__proof {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 18px;
}
.landing-ecosystem__chip {
  display: inline-flex;
  align-items: center;
  min-height: 28px;
  padding: 5px 10px;
  border: 1px solid var(--border);
  border-radius: var(--r-pill);
  background: var(--surface-2);
  color: var(--text-2);
  font-size: 12px;
  font-weight: 800;
}

.landing-workflow__grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 16px;
}
.landing-workflow__item {
  position: relative;
  min-height: 260px;
  padding: 20px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface);
  box-shadow: var(--shadow-xs);
  transition: transform .16s ease, border-color .16s ease, background .16s ease;
}
.landing-workflow__item:hover {
  transform: translateY(-1px);
  border-color: var(--border-strong);
  background: var(--n-25);
}
.landing-workflow__item--active {
  border-left: 3px solid var(--brand);
  background: linear-gradient(180deg, var(--surface) 0%, rgba(252, 231, 240, .42) 100%);
}
.landing-workflow__icon {
  width: 40px;
  height: 40px;
  display: grid;
  place-items: center;
  border-radius: var(--r-lg);
  background: var(--brand-soft);
  color: var(--brand-deep);
}
.landing-workflow__connector {
  position: absolute;
  top: 39px;
  left: calc(100% - 8px);
  width: 16px;
  height: 1px;
  background: var(--border-strong);
}
.landing-workflow__item-title {
  margin: 18px 0 8px;
  font-size: 18px;
  line-height: 1.2;
}
.landing-workflow__item-body,
.landing-workflow__item-detail {
  margin: 0;
  color: var(--text-2);
  font-size: 13.5px;
  line-height: 1.5;
}
.landing-workflow__item-detail {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
  color: var(--text);
  font-weight: 700;
}

.landing-compare {
  width: min(1180px, calc(100% - 40px));
  margin: 0 auto;
}
.landing-compare__note {
  margin: 12px 0 0;
  color: var(--text-3);
  font-size: 12.5px;
  line-height: 1.5;
}
.landing-compare__table-wrap { overflow-x: auto; }
.landing-compare__grid {
  display: grid;
  grid-template-columns: 220px repeat(3, minmax(210px, 1fr));
  min-width: 850px;
}
.landing-compare__cell {
  min-height: 48px;
  padding: 13px 16px;
  border-right: 1px solid var(--border);
  border-bottom: 1px solid var(--border);
  display: flex;
  align-items: center;
  color: var(--text);
  font-size: 13px;
}
.landing-compare__cell:nth-child(4n) { border-right: 0; }
.landing-compare__grid > .landing-compare__cell:nth-last-child(-n+4) { border-bottom: 0; }
.landing-compare__label {
  background: var(--surface-2);
  color: var(--text-2);
  font-weight: 800;
}
.landing-compare__offer-head {
  align-items: flex-start;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  border-top: 0;
  border-left: 0;
  border-bottom: 1px solid var(--border);
  border-radius: 0;
  background: var(--surface);
  text-align: left;
  transition: transform .16s ease, background .16s ease;
}
.landing-compare__offer-head:hover {
  background: var(--n-50);
  transform: translateY(-1px);
}
.landing-compare__offer-head strong {
  font-size: 14px;
  font-weight: 800;
}
.landing-compare__offer-head span {
  color: var(--text-3);
  font-size: 12px;
  font-weight: 700;
}
.landing-compare__offer-head--recommended {
  box-shadow: inset 0 3px 0 var(--brand);
  background: var(--brand-soft);
}
.landing-compare__best {
  display: inline;
  padding-bottom: 2px;
  box-shadow: inset 0 -5px 0 var(--brand-soft);
  font-weight: 800;
}
.landing-compare__cards { display: none; }
.landing-compare__actions {
  display: flex;
  justify-content: center;
  margin-top: 18px;
}

.landing-lead {
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.landing-lead__inner {
  display: grid;
  grid-template-columns: minmax(280px, .68fr) minmax(0, 1fr);
  gap: 26px;
  align-items: start;
}
.landing-lead__context {
  position: sticky;
  top: 88px;
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 16px;
}
.landing-lead__assurances {
  display: grid;
  gap: 10px;
  width: 100%;
  margin-top: 8px;
}
.landing-lead__assurances > div {
  display: grid;
  grid-template-columns: auto minmax(0, 1fr);
  gap: 10px;
  padding: 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-lg);
  background: var(--surface-2);
}
.landing-lead__assurances svg { color: var(--ok); }
.landing-lead__assurances strong,
.landing-lead__assurances span { display: block; }
.landing-lead__assurances strong {
  font-size: 13px;
  margin-bottom: 2px;
}
.landing-lead__assurances span {
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.4;
}
.landing-lead__grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}
.landing-lead__field { min-width: 0; }
.landing-lead__field > span {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-2);
}
.landing-lead__field:has(textarea) { grid-column: 1 / -1; }
.landing-lead__field.is-invalid .input,
.landing-lead__consent.is-invalid {
  border-color: var(--bad);
  background: var(--bad-soft);
}
.landing-lead__error {
  color: var(--bad);
  font-size: 12px;
  font-style: normal;
  font-weight: 700;
}
.landing-lead__consent {
  display: flex;
  align-items: flex-start;
  gap: 9px;
  margin-top: 14px;
  padding: 11px 12px;
  border: 1px solid var(--border);
  border-radius: var(--r-md);
  color: var(--text-2);
  font-size: 12.5px;
  line-height: 1.4;
}
.landing-lead__consent input {
  flex: 0 0 auto;
  margin-top: 1px;
  accent-color: var(--brand);
}
.landing-lead__notice {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 12px;
  padding: 10px 12px;
  border: 1px solid rgba(217, 45, 32, .18);
  border-radius: var(--r-md);
  background: var(--bad-soft);
  color: var(--bad);
  font-size: 12.5px;
  font-weight: 700;
}
.landing-lead__actions {
  display: flex;
  justify-content: flex-end;
  margin-top: 16px;
}
.landing-lead__success {
  display: grid;
  place-items: center;
  gap: 12px;
  min-height: 360px;
  padding: 32px;
  text-align: center;
}
.landing-lead__success > span {
  width: 50px;
  height: 50px;
  display: grid;
  place-items: center;
  border-radius: var(--r-xl);
  background: var(--ok-soft);
  color: var(--ok);
}
.landing-lead__success h3 {
  margin: 0;
  font-size: 22px;
}
.landing-lead__success p {
  max-width: 420px;
  margin: 0;
  color: var(--text-2);
}
.landing-header__brand:focus-visible,
.landing-header__nav button:focus-visible,
.landing-header__mobile button:focus-visible,
.landing-compare__offer-head:focus-visible,
.landing-lead__consent:focus-within {
  outline: none;
  box-shadow: 0 0 0 4px rgba(199, 42, 108, .10);
}

@media (max-width: 980px) {
  .landing-header__nav { display: none; }
  .landing-header__actions > .btn { display: none; }
  .landing-header__menu { display: inline-flex; }
  .landing-header__mobile {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 8px;
  }
  .landing-hero {
    min-height: auto;
    padding: 42px 0 58px;
  }
  .landing-hero__inner,
  .landing-ecosystem__map,
  .landing-workflow__grid,
  .landing-lead__inner {
    grid-template-columns: 1fr;
  }
  .landing-workflow__connector { display: none; }
  .landing-workflow__item { min-height: 0; }
  .landing-lead__context { position: static; }
}

@media (max-width: 760px) {
  .landing-header__inner {
    width: calc(100% - 28px);
    height: 56px;
  }
  .landing-header__mobile {
    width: calc(100% - 28px);
    grid-template-columns: 1fr;
  }
  .landing-header__brand { font-size: 14px; }
  .landing-hero { padding: 30px 0 44px; }
  .landing-hero__inner,
  .landing-ecosystem__inner,
  .landing-workflow__inner,
  .landing-lead__inner,
  .landing-compare {
    width: calc(100% - 32px);
  }
  .landing-hero__title {
    font-size: clamp(34px, 11vw, 42px);
    line-height: 1.08;
  }
  .landing-hero__body { font-size: 15px; }
  .landing-hero__actions,
  .landing-hero__actions .btn {
    width: 100%;
  }
  .landing-hero__actions .btn,
  .landing-compare__actions .btn,
  .landing-lead__actions .btn {
    justify-content: center;
    width: 100%;
  }
  .landing-prognosis { padding: 16px; }
  .landing-prognosis__head {
    flex-direction: column;
    align-items: flex-start;
  }
  .landing-prognosis__line {
    flex-direction: column;
    align-items: flex-start;
    gap: 4px;
  }
  .landing-ecosystem,
  .landing-workflow,
  .landing-compare,
  .landing-lead {
    padding: 52px 0;
    scroll-margin-top: 68px;
  }
  .landing-ecosystem__header,
  .landing-workflow__header,
  .landing-compare__head {
    text-align: left;
  }
  .landing-ecosystem__center { grid-template-columns: 1fr; }
  .landing-compare__table-wrap { display: none; }
  .landing-compare__cards {
    display: grid;
    gap: 12px;
  }
  .landing-compare__offer-card {
    border: 1px solid var(--border);
    border-radius: var(--r-lg);
    background: var(--surface);
    box-shadow: var(--shadow-xs);
    overflow: hidden;
  }
  .landing-compare__offer-card .landing-compare__offer-head {
    display: flex;
    flex-direction: row;
    align-items: flex-start;
    justify-content: space-between;
    gap: 12px;
    padding: 14px;
    background: var(--surface-2);
    border-bottom: 1px solid var(--border);
  }
  .landing-compare__mobile-row {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 16px;
    padding: 11px 14px;
    border-bottom: 1px solid var(--border);
    font-size: 12.5px;
  }
  .landing-compare__mobile-row:last-child { border-bottom: 0; }
  .landing-compare__mobile-row span {
    color: var(--text-2);
    font-weight: 700;
  }
  .landing-compare__mobile-row strong { text-align: right; }
  .landing-lead__grid { grid-template-columns: 1fr; }
  .landing-lead__field:has(textarea) { grid-column: auto; }
  .landing-lead__success {
    min-height: 300px;
    padding: 24px 10px;
  }
}

@media (prefers-reduced-motion: reduce) {
  .landing-header__nav button,
  .landing-header__mobile button,
  .landing-ecosystem__center,
  .landing-ecosystem__node,
  .landing-workflow__item,
  .landing-compare__offer-head {
    transition: none;
  }
}
