/* ============================================================
   Сальдо — бухгалтер на автопилоте
   Дизайн-система: токены, типографика, базовые компоненты
   Светлая, дружелюбная финтех-эстетика
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Onest:wght@400;500;600;700;800&display=swap');

:root {
  /* — Палитра — */
  --bg:        #EEF1F4;
  --bg-warm:   #F4F2EE;
  --surface:   #FFFFFF;
  --surface-2: #F7F8FA;
  --surface-3: #EFF2F5;
  --line:      #E4E8ED;
  --line-2:    #D6DBE2;

  --ink:       #14181F;
  --ink-2:     #4A535F;
  --ink-3:     #7C8794;
  --ink-4:     #A6AFBA;

  /* Бренд — автопилот: свежий зелёный = "всё под контролем" */
  --brand:      #10A36A;
  --brand-600:  #0C8C5B;
  --brand-700:  #0A744C;
  --brand-soft: #E2F4EC;
  --brand-soft-2:#CDEBDE;

  /* ИИ-акцент — индиго */
  --ai:        #5A57E6;
  --ai-600:    #4A47D4;
  --ai-soft:   #ECECFD;
  --ai-soft-2: #DCDBFB;

  /* Семантика */
  --warn:      #E08600;
  --warn-soft: #FBEFD6;
  --danger:    #DE3B40;
  --danger-soft:#FBE4E5;
  --info:      #2E7CE4;
  --info-soft: #E2EEFB;

  /* Деньги */
  --money-in:  #10A36A;
  --money-out: #59636F;

  /* Радиусы */
  --r-xs: 7px;
  --r-sm: 10px;
  --r-md: 14px;
  --r-lg: 20px;
  --r-xl: 28px;
  --r-pill: 999px;

  /* Тени */
  --sh-xs: 0 1px 2px rgba(20,24,31,.05);
  --sh-sm: 0 2px 6px rgba(20,24,31,.06), 0 1px 2px rgba(20,24,31,.04);
  --sh-md: 0 8px 24px rgba(20,24,31,.08), 0 2px 6px rgba(20,24,31,.05);
  --sh-lg: 0 20px 48px rgba(20,24,31,.12), 0 6px 16px rgba(20,24,31,.06);
  --sh-brand: 0 8px 22px rgba(16,163,106,.28);
  --sh-ai: 0 8px 22px rgba(90,87,230,.26);

  /* Плотность (управляется Tweaks) */
  --density: 1;
  --pad-card: calc(22px * var(--density));

  --topbar-bg: rgba(255,255,255,.82);
  --maxw: 1280px;
}

/* ============================================================
   ТЁМНАЯ ТЕМА
   ============================================================ */
:root[data-theme="dark"] {
  --bg:        #0E1116;
  --bg-warm:   #14181F;
  --surface:   #181C23;
  --surface-2: #1F242D;
  --surface-3: #272D38;
  --line:      #2C333E;
  --line-2:    #3A4250;

  --ink:       #ECEFF3;
  --ink-2:     #B7C0CC;
  --ink-3:     #8A94A2;
  --ink-4:     #5C6675;

  --brand-soft:  rgba(16,163,106,.16);
  --brand-soft-2:rgba(16,163,106,.28);
  --ai-soft:   rgba(90,87,230,.20);
  --ai-soft-2: rgba(90,87,230,.30);
  --warn-soft: rgba(224,134,0,.20);
  --danger-soft:rgba(222,59,64,.20);
  --info-soft: rgba(46,124,228,.20);
  --money-out: #9AA4B0;

  --topbar-bg: rgba(20,24,31,.82);

  --sh-xs: 0 1px 2px rgba(0,0,0,.4);
  --sh-sm: 0 2px 6px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);
  --sh-md: 0 8px 24px rgba(0,0,0,.5), 0 2px 6px rgba(0,0,0,.3);
  --sh-lg: 0 20px 48px rgba(0,0,0,.55), 0 6px 16px rgba(0,0,0,.4);
}
:root[data-theme="dark"] ::selection { background: var(--brand-soft-2); }
:root[data-theme="dark"] .avatar { color: #fff; }

* { box-sizing: border-box; }

html, body {
  margin: 0;
  padding: 0;
  background: var(--bg);
  color: var(--ink);
  font-family: 'Onest', system-ui, sans-serif;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}

body { font-size: 15px; line-height: 1.5; }

h1,h2,h3,h4,h5 { margin: 0; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); }
p { margin: 0; }
button { font-family: inherit; cursor: pointer; border: none; background: none; }
input, textarea { font-family: inherit; }

.tnum { font-variant-numeric: tabular-nums; font-feature-settings: "tnum" 1; }

::selection { background: var(--brand-soft-2); }

/* — Скроллбары — */
::-webkit-scrollbar { width: 11px; height: 11px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: #C9D0D8; border-radius: 99px; border: 3px solid transparent; background-clip: content-box; }
::-webkit-scrollbar-thumb:hover { background: #AEB7C1; background-clip: content-box; }

/* ============================================================
   КОМПОНЕНТЫ
   ============================================================ */

/* Карточка */
.card {
  background: var(--surface);
  border: 1px solid var(--line);
  border-radius: var(--r-lg);
  box-shadow: var(--sh-sm);
}
.card-pad { padding: var(--pad-card); }

/* Кнопки */
.btn {
  display: inline-flex; align-items: center; gap: 8px; justify-content: center;
  height: 40px; padding: 0 16px;
  border-radius: var(--r-sm);
  font-size: 14.5px; font-weight: 600;
  color: var(--ink-2);
  background: var(--surface);
  border: 1px solid var(--line-2);
  transition: all .14s ease;
  white-space: nowrap;
}
.btn:hover { border-color: var(--ink-4); color: var(--ink); }
.btn:active { transform: translateY(1px); }
.btn svg { width: 18px; height: 18px; }

.btn-primary {
  background: var(--brand); color: #fff; border-color: var(--brand);
  box-shadow: var(--sh-brand);
}
.btn-primary:hover { background: var(--brand-600); border-color: var(--brand-600); color: #fff; }

.btn-ai {
  background: var(--ai); color: #fff; border-color: var(--ai);
  box-shadow: var(--sh-ai);
}
.btn-ai:hover { background: var(--ai-600); border-color: var(--ai-600); color:#fff; }

.btn-ghost { background: transparent; border-color: transparent; color: var(--ink-2); box-shadow:none; }
.btn-ghost:hover { background: var(--surface-3); color: var(--ink); border-color: transparent; }

.btn-sm { height: 32px; padding: 0 12px; font-size: 13.5px; border-radius: var(--r-xs); }
.btn-sm svg { width: 16px; height: 16px; }
.btn-lg { height: 48px; padding: 0 22px; font-size: 16px; border-radius: var(--r-md); }
.btn-icon { width: 40px; padding: 0; }
.btn-icon.btn-sm { width: 32px; }

/* Бейджи / чипы */
.badge {
  display: inline-flex; align-items: center; gap: 6px;
  height: 26px; padding: 0 10px;
  border-radius: var(--r-pill);
  font-size: 12.5px; font-weight: 600;
  background: var(--surface-3); color: var(--ink-2);
  white-space: nowrap;
}
.badge svg { width: 14px; height: 14px; }
.badge-brand { background: var(--brand-soft); color: var(--brand-700); }
.badge-ai { background: var(--ai-soft); color: var(--ai-600); }
.badge-warn { background: var(--warn-soft); color: var(--warn); }
.badge-danger { background: var(--danger-soft); color: var(--danger); }
.badge-info { background: var(--info-soft); color: var(--info); }
.badge-dot::before { content:''; width:6px; height:6px; border-radius:99px; background: currentColor; display:inline-block; }

/* Метка-капсула автопилота */
.pill-auto {
  display:inline-flex; align-items:center; gap:7px;
  height:28px; padding:0 12px 0 10px;
  border-radius: var(--r-pill);
  background: var(--brand-soft); color: var(--brand-700);
  font-size:12.5px; font-weight:700; letter-spacing:.01em;
}
.pill-auto svg { width:15px; height:15px; }

/* Аватары */
.avatar {
  width: 40px; height: 40px; border-radius: 50%;
  display: grid; place-items: center;
  font-weight: 700; font-size: 15px; color: #fff;
  background: var(--brand);
  flex: none;
}

/* Разделители / подписи */
.eyebrow {
  font-size: 11.5px; font-weight: 700; letter-spacing: .08em;
  text-transform: uppercase; color: var(--ink-3);
}
.muted { color: var(--ink-3); }
.divider { height:1px; background: var(--line); border:0; margin:0; }

/* Прогресс */
.bar { height: 8px; border-radius: 99px; background: var(--surface-3); overflow:hidden; }
.bar > i { display:block; height:100%; border-radius:99px; background: var(--brand); }

/* Тонкая ссылка-действие */
.link {
  color: var(--brand-700); font-weight:600; cursor:pointer;
  display:inline-flex; align-items:center; gap:4px;
}
.link:hover { color: var(--brand-600); }
.link svg { width:15px; height:15px; }

/* Утилиты раскладки */
.row { display:flex; align-items:center; }
.col { display:flex; flex-direction:column; }
.between { justify-content: space-between; }
.gap-2 { gap:8px; } .gap-3 { gap:12px; } .gap-4 { gap:16px; } .gap-5 { gap:20px; } .gap-6 { gap:24px; }
.grow { flex:1; }

/* Анимации */
@keyframes fadeUp { from { transform: translateY(10px); } to { transform: none; } }
@keyframes fadeIn { from { opacity:.001; } to { opacity:1; } }
@keyframes pop { 0%{transform:scale(.94);opacity:0} 60%{transform:scale(1.02)} 100%{transform:scale(1);opacity:1} }
@keyframes pulseRing { 0%{box-shadow:0 0 0 0 rgba(16,163,106,.35)} 70%{box-shadow:0 0 0 10px rgba(16,163,106,0)} 100%{box-shadow:0 0 0 0 rgba(16,163,106,0)} }
@keyframes shimmer { 0%{background-position:-400px 0} 100%{background-position:400px 0} }
@keyframes scanline { 0%{top:0} 100%{top:100%} }
@keyframes spin { to { transform: rotate(360deg); } }
.fade-up { animation: fadeUp .4s cubic-bezier(.2,.7,.3,1) both; }
.fade-in { animation: fadeIn .4s ease both; }

.spin { animation: spin 1s linear infinite; }

/* Ползунок калькулятора */
.calc-range { -webkit-appearance:none; appearance:none; height:6px; border-radius:99px; background:var(--surface-3); outline:none; }
.calc-range::-webkit-slider-thumb { -webkit-appearance:none; appearance:none; width:20px; height:20px; border-radius:50%; background:var(--brand); border:3px solid #fff; box-shadow:var(--sh-sm); cursor:pointer; }
.calc-range::-moz-range-thumb { width:18px; height:18px; border-radius:50%; background:var(--brand); border:3px solid #fff; box-shadow:var(--sh-sm); cursor:pointer; }
input[type=number]::-webkit-inner-spin-button, input[type=number]::-webkit-outer-spin-button { -webkit-appearance:none; margin:0; }
