/* ============================================================
   парси — UI kit (дизайн-токены и базовые компоненты)
   B2B SaaS · navy #0A1730 + акцент #195AFE · Inter
   ============================================================ */

@font-face {
  font-family: "Comfortaa";
  src: url("../assets/fonts/Comfortaa.ttf") format("truetype");
  font-weight: 300 700;
  font-display: swap;
}

:root {
  /* Бренд / акцент */
  --blue: #195AFE;
  --blue-hover: #1247CB;
  --blue-300: #7FA6FF;
  --blue-100: #C9D9FF;

  /* Тёмный фон (сайт) */
  --navy: #0A1730;
  --navy-1: #0E1C3A;
  --navy-2: #122146;
  --navy-line: #21314F;

  /* Светлые фоны */
  --bg-1: #F7F9FC;
  --bg-2: #EEF3FF;
  --bg-3: #EAF0FF;
  --white: #FFFFFF;

  /* Текст на тёмном */
  --on-dark: #FFFFFF;
  --on-dark-2: #A9BAD8;   /* приглушённый голубовато-серый */
  --on-dark-3: #6E80A6;

  /* Текст на светлом */
  --ink: #101828;
  --ink-2: #667085;
  --ink-3: #98A2B3;

  /* Границы */
  --line: #E4E9F2;
  --line-2: #EDF1F7;

  /* Состояния */
  --success: #12B76A; --success-bg: #E7F8EF;
  --warning: #F79009; --warning-bg: #FEF3E2;
  --error:   #F04438; --error-bg:   #FDECEA;
  --info:    #195AFE; --info-bg:    #EEF3FF;

  /* Тарифы */
  --tier-free:  #667085;
  --tier-start: #195AFE;
  --tier-pro:   #6C3CE6;   /* премиальный фиолетово-синий акцент для ПРО */
  --tier-year:  #0E9384;

  /* Графики / метрики */
  --c1: #195AFE; --c2: #6C3CE6; --c3: #0E9384; --c4: #F79009; --c5: #F04438;

  /* Радиусы */
  --r-sm: 8px; --r-md: 12px; --r-lg: 16px; --r-xl: 22px; --r-pill: 999px;

  /* Тени (мягкие) */
  --sh-xs: 0 1px 2px rgba(16,24,40,.06);
  --sh-sm: 0 2px 8px rgba(16,24,40,.08);
  --sh-md: 0 8px 24px rgba(16,24,40,.10);
  --sh-lg: 0 20px 48px rgba(16,24,40,.16);
  --sh-dark: 0 24px 60px rgba(2,8,23,.45);
  --glow: 0 0 0 1px rgba(25,90,254,.18), 0 18px 60px rgba(25,90,254,.28);

  /* Раскладка */
  --container: 1600px;
  --gap: 24px;
  --font: "Comfortaa", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; font-family: var(--font); color: var(--ink); background: var(--white);
  -webkit-font-smoothing: antialiased; line-height: 1.55; zoom: 1.1; font-weight: 500; }
a { color: inherit; text-decoration: none; }
img { max-width: 100%; display: block; }

/* ---------- Типографика ---------- */
.h1 { font-size: clamp(34px, 4.4vw, 56px); line-height: 1.05; letter-spacing: -.02em; font-weight: 700; margin: 0; }
.h2 { font-size: clamp(26px, 3vw, 38px); line-height: 1.12; letter-spacing: -.02em; font-weight: 700; margin: 0; }
.h3 { font-size: 22px; line-height: 1.25; letter-spacing: -.01em; font-weight: 650; margin: 0; }
.h4 { font-size: 17px; line-height: 1.3; font-weight: 650; margin: 0; }
.body { font-size: 16px; line-height: 1.6; font-weight: 500; }
.lead { font-size: 19px; line-height: 1.55; color: var(--ink-2); font-weight: 400; }
.small { font-size: 14px; }
.caption { font-size: 13px; color: var(--ink-2); font-weight: 400; }
.label { font-size: 12px; font-weight: 600; letter-spacing: .04em; text-transform: uppercase; color: var(--ink-2); }
.price { font-size: 40px; font-weight: 700; letter-spacing: -.02em; }
.price small { font-size: 15px; font-weight: 500; color: var(--ink-2); }
.mono { font-variant-numeric: tabular-nums; }

/* На тёмном фоне */
.on-dark { color: var(--on-dark); }
.on-dark .lead, .text-dim { color: var(--on-dark-2); }

/* ---------- Контейнеры / секции ---------- */
.wrap { width: min(var(--container), 100% - 48px); margin: 0 auto; }
.section { padding: 88px 0; }
.section-sm { padding: 56px 0; }
.eyebrow { display:inline-flex; align-items:center; gap:8px; font-size:13px; font-weight:600;
  color: var(--blue); background: var(--bg-2); border:1px solid var(--blue-100);
  padding:6px 14px; border-radius: var(--r-pill); }
.sec-head { text-align:center; max-width:640px; margin:0 auto 48px; }
.sec-head .h2 { margin-bottom:12px; }
.sec-head p { color: var(--ink-2); font-size:17px; margin:0; }

/* ---------- Кнопки ---------- */
.btn { display:inline-flex; align-items:center; justify-content:center; gap:8px;
  font-family:inherit; font-size:15px; font-weight:600; line-height:1; cursor:pointer;
  padding:12px 20px; border-radius: var(--r-md); border:1px solid transparent; transition:.15s; white-space:nowrap; }
.btn-lg { padding:15px 26px; font-size:16px; border-radius: var(--r-md); }
.btn-sm { padding:9px 14px; font-size:14px; }
.btn-primary { background: var(--blue); color:#fff; box-shadow: 0 6px 18px rgba(25,90,254,.3); }
.btn-primary:hover { background: var(--blue-hover); }
.btn-secondary { background:#fff; color: var(--ink); border-color: var(--line); box-shadow: var(--sh-xs); }
.btn-secondary:hover { background: var(--bg-1); border-color:#D5DCEA; }
.btn-ghost { background:transparent; color: var(--ink); }
.btn-ghost:hover { background: var(--bg-1); }
.btn-danger { background: var(--error); color:#fff; }
.btn-danger:hover { filter:brightness(.94); }
.btn-block { width:100%; }
.btn:disabled, .btn.is-disabled { opacity:.5; cursor:not-allowed; box-shadow:none; }
/* кнопки на тёмном фоне */
.on-dark .btn-secondary { background: rgba(255,255,255,.06); color:#fff; border-color: rgba(255,255,255,.18); box-shadow:none; }
.on-dark .btn-secondary:hover { background: rgba(255,255,255,.12); }
.on-dark .btn-ghost { color:#fff; }
.on-dark .btn-ghost:hover { background: rgba(255,255,255,.08); }
/* те же варианты для секций .dark (шапка/герой/CTA/футер) */
.dark .btn-secondary { background: rgba(255,255,255,.08); color:#fff; border-color: rgba(255,255,255,.20); box-shadow:none; }
.dark .btn-secondary:hover { background: rgba(255,255,255,.14); }
.dark .btn-ghost { color:#fff; border-color: rgba(255,255,255,.22); }
.dark .btn-ghost:hover { background: rgba(255,255,255,.10); }

/* ---------- Поля ввода ---------- */
.field { display:block; margin-bottom:14px; }
.field > .label { display:block; margin-bottom:6px; text-transform:none; letter-spacing:0; font-size:13px; color: var(--ink); }
.input, .textarea, .select { width:100%; font-family:inherit; font-size:15px; color: var(--ink);
  background:#fff; border:1px solid var(--line); border-radius: var(--r-md); padding:11px 14px; transition:.15s; }
.input:hover, .textarea:hover, .select:hover { border-color:#CBD5E6; }
.input:focus, .textarea:focus, .select:focus { outline:none; border-color: var(--blue); box-shadow:0 0 0 4px rgba(25,90,254,.15); }
.textarea { min-height:104px; resize:vertical; }
.input::placeholder { color: var(--ink-3); }

/* checkbox / radio / toggle */
.check { display:inline-flex; align-items:center; gap:10px; font-size:14px; cursor:pointer; }
.check input { width:18px; height:18px; accent-color: var(--blue); }
.toggle { position:relative; width:42px; height:24px; flex:none; }
.toggle input { position:absolute; opacity:0; }
.toggle .track { position:absolute; inset:0; background:#CBD5E6; border-radius:999px; transition:.18s; }
.toggle .track::after { content:""; position:absolute; top:3px; left:3px; width:18px; height:18px; background:#fff; border-radius:50%; transition:.18s; box-shadow: var(--sh-xs); }
/* Фирменный градиент включённого тумблера — как в расширении парси */
.toggle input:checked + .track { background: linear-gradient(270deg, var(--blue) 0%, rgba(25,90,254,.35) 45%, var(--white) 100%); border:1px solid var(--blue-100); }
.toggle input:checked + .track::after { transform: translateX(18px); }

/* segmented / tabs */
.segmented { display:inline-flex; background: var(--bg-1); border:1px solid var(--line); border-radius: var(--r-md); padding:4px; gap:4px; }
.segmented button { border:none; background:transparent; font-family:inherit; font-size:14px; font-weight:600; color: var(--ink-2); padding:8px 16px; border-radius: var(--r-sm); cursor:pointer; transition:.15s; }
.segmented button.active { background:#fff; color: var(--ink); box-shadow: var(--sh-xs); }
.tabs { display:flex; gap:24px; border-bottom:1px solid var(--line); }
.tabs button { border:none; background:none; font-family:inherit; font-size:15px; font-weight:600; color: var(--ink-2); padding:12px 2px; cursor:pointer; border-bottom:2px solid transparent; margin-bottom:-1px; }
.tabs button.active { color: var(--blue); border-bottom-color: var(--blue); }

/* ---------- Бейджи / чипы ---------- */
.badge { display:inline-flex; align-items:center; gap:6px; font-size:12px; font-weight:600; padding:4px 10px; border-radius: var(--r-pill); }
.badge-blue { background: var(--info-bg); color: var(--blue); }
.badge-success { background: var(--success-bg); color: var(--success); }
.badge-warning { background: var(--warning-bg); color: var(--warning); }
.badge-error { background: var(--error-bg); color: var(--error); }
.badge-neutral { background: var(--bg-1); color: var(--ink-2); }
.badge .dot { width:6px; height:6px; border-radius:50%; background: currentColor; }
.chip { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:500; color: var(--ink-2);
  background: var(--bg-1); border:1px solid var(--line); padding:6px 12px; border-radius: var(--r-pill); }

/* ---------- Карточки ---------- */
.card { background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--sh-sm); padding:24px; }
.card-flat { background: var(--bg-1); border:1px solid var(--line-2); border-radius: var(--r-lg); padding:20px; }
.kpi { background:#fff; border:1px solid var(--line); border-radius: var(--r-lg); padding:18px 20px; box-shadow: var(--sh-xs); }
.kpi .label { display:block; margin-bottom:8px; }
.kpi .v { font-size:28px; font-weight:700; letter-spacing:-.02em; }
.kpi .delta { font-size:13px; font-weight:600; }
.kpi .delta.up { color: var(--success); } .kpi .delta.down { color: var(--error); }

/* ---------- Таблица ---------- */
.table { width:100%; border-collapse:collapse; font-size:14px; }
.table th { text-align:left; font-size:12px; font-weight:600; letter-spacing:.03em; text-transform:uppercase; color: var(--ink-2); padding:12px 16px; border-bottom:1px solid var(--line); }
.table td { padding:14px 16px; border-bottom:1px solid var(--line-2); color: var(--ink); }
.table tr:hover td { background: var(--bg-1); }

/* статусы данных */
.status { display:inline-flex; align-items:center; gap:6px; font-size:13px; font-weight:600; }
.status .dot { width:8px; height:8px; border-radius:50%; }
.status.done  { color: var(--success); } .status.done .dot  { background: var(--success); }
.status.run   { color: var(--blue); }    .status.run .dot   { background: var(--blue); }
.status.err   { color: var(--error); }   .status.err .dot   { background: var(--error); }
.status.limit { color: var(--warning); } .status.limit .dot { background: var(--warning); }

/* ---------- Tooltip / modal / dropdown / toast ---------- */
.tooltip { position:relative; }
.tooltip .tip { position:absolute; bottom:calc(100% + 8px); left:50%; transform:translateX(-50%);
  background: var(--ink); color:#fff; font-size:12px; padding:6px 10px; border-radius: var(--r-sm); white-space:nowrap; box-shadow: var(--sh-md); }
.overlay { background: rgba(10,23,48,.55); display:flex; align-items:center; justify-content:center; padding:24px; border-radius: var(--r-lg); }
.modal { background:#fff; border-radius: var(--r-xl); box-shadow: var(--sh-lg); padding:28px; width:min(460px,100%); }
.dropdown { background:#fff; border:1px solid var(--line); border-radius: var(--r-md); box-shadow: var(--sh-md); padding:6px; min-width:200px; }
.dropdown a { display:flex; align-items:center; gap:10px; padding:9px 12px; border-radius: var(--r-sm); font-size:14px; color: var(--ink); }
.dropdown a:hover { background: var(--bg-1); }
.toast { display:inline-flex; align-items:center; gap:10px; background: var(--ink); color:#fff; font-size:14px; padding:12px 16px; border-radius: var(--r-md); box-shadow: var(--sh-lg); }

/* ---------- Empty / progress / pagination ---------- */
.empty { text-align:center; padding:48px 24px; color: var(--ink-2); }
.empty .ic { width:56px; height:56px; border-radius: var(--r-lg); background: var(--bg-2); display:flex; align-items:center; justify-content:center; margin:0 auto 16px; color: var(--blue); }
.progress { height:8px; background: var(--bg-3); border-radius:999px; overflow:hidden; }
.progress > i { display:block; height:100%; background: var(--blue); border-radius:999px; }
.pagination { display:flex; gap:6px; }
.pagination a { min-width:36px; height:36px; display:inline-flex; align-items:center; justify-content:center; border:1px solid var(--line); border-radius: var(--r-sm); font-size:14px; color: var(--ink); }
.pagination a.active { background: var(--blue); color:#fff; border-color: var(--blue); }

/* ---------- Иконки (линейные, stroke 2) ---------- */
.ic-box { width:44px; height:44px; background: transparent; color: var(--blue);
  display:flex; align-items:center; justify-content:center; }
svg.ico { width:22px; height:22px; stroke: currentColor; fill:none; stroke-width:2; stroke-linecap:round; stroke-linejoin:round; }

/* ---------- Тёмные секции / свечение ---------- */
.dark { background:
    radial-gradient(60% 420px at 50% -80px, rgba(25,90,254,.45), rgba(25,90,254,0) 60%),
    var(--navy); color: var(--on-dark); }
.dark .h1, .dark .h2, .dark .h3, .dark .h4 { color:#fff; }
.dark .sec-head p { color: var(--on-dark-2); }
.glass { background: rgba(255,255,255,.05); border:1px solid rgba(255,255,255,.10); border-radius: var(--r-lg); backdrop-filter: blur(8px); }

.row { display:flex; align-items:center; flex-wrap:wrap; }
.grid { display:grid; gap: var(--gap); }
@media (max-width:900px){ .section{padding:64px 0;} }
