/* ============================================================================
 * PLANQA · Application styles (premium UI)
 * ----------------------------------------------------------------------------
 * Mobile-first. 44+px touch targets. Тонкие 0.5-1px бордюры. Subtle shadows.
 * Inter + JetBrains Mono для tabular numbers. Rounded 10/12/16 по системе.
 * ============================================================================ */

html, body {
  height: 100%;
  margin: 0;
}

body {
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--color-surface);
  font-size: 15px;
  line-height: 1.5;
  overscroll-behavior-y: none;
  color: var(--color-text-primary);
}

img, svg { max-width: 100%; }

/* Безопасная обертка для всех interactive элементов */
button, [role="button"] { -webkit-tap-highlight-color: transparent; }

/* ============================================================================
 * LOADING SCREEN
 * ============================================================================ */

.loading-screen {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background:
    radial-gradient(ellipse at 40% 20%, rgba(13, 148, 136, 0.10), transparent 55%),
    radial-gradient(ellipse at 60% 80%, rgba(94, 234, 212, 0.08), transparent 50%),
    var(--color-surface);
  z-index: var(--z-loading);
  gap: 20px;
}

.loading-wordmark {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.01em;
  font-size: 22px;
  color: var(--teal-950);
  animation: loading-pulse 2s ease-in-out infinite;
}

@keyframes loading-pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.6; }
}

.loading-bar {
  width: 80px;
  height: 2px;
  background: var(--color-border);
  border-radius: 1px;
  overflow: hidden;
  position: relative;
}

.loading-bar::before {
  content: '';
  position: absolute;
  inset: 0;
  background: var(--color-primary);
  transform-origin: left;
  animation: loading-bar 1.4s var(--ease-soft) infinite;
}

@keyframes loading-bar {
  0%   { transform: scaleX(0);   transform-origin: left;  }
  50%  { transform: scaleX(1);   transform-origin: left;  }
  51%  { transform: scaleX(1);   transform-origin: right; }
  100% { transform: scaleX(0);   transform-origin: right; }
}

/* ============================================================================
 * AUTH SCREEN
 * ============================================================================ */

.auth-screen {
  position: fixed;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background:
    radial-gradient(ellipse 600px 400px at 20% 10%, rgba(13, 148, 136, 0.08), transparent),
    radial-gradient(ellipse 500px 500px at 80% 90%, rgba(94, 234, 212, 0.08), transparent),
    var(--color-surface);
  z-index: var(--z-auth);
}

.auth-card {
  width: 100%;
  max-width: 380px;
  background: var(--color-paper);
  border-radius: var(--radius-xl);
  border: 1px solid var(--color-border);
  padding: 36px 28px;
  box-shadow: var(--shadow-lg);
  animation: fade-up 400ms var(--ease-soft) both;
}

@keyframes fade-up {
  from { opacity: 0; transform: translateY(12px); }
  to   { opacity: 1; transform: translateY(0); }
}

.auth-monogram {
  display: flex;
  justify-content: center;
  margin-bottom: 24px;
  color: var(--color-primary);
}

.auth-title {
  font-family: var(--font-display);
  font-size: 28px;
  letter-spacing: 0.02em;
  text-align: center;
  color: var(--teal-950);
  margin: 0 0 6px;
}

.auth-subtitle {
  font-size: 13px;
  color: var(--color-text-secondary);
  text-align: center;
  margin: 0 0 28px;
}

.auth-gsi {
  display: flex;
  justify-content: center;
  margin-bottom: 14px;
  min-height: 44px;
}

.auth-error {
  background: var(--error-50);
  color: var(--error-700);
  border-radius: var(--radius-md);
  padding: 10px 12px;
  font-size: 13px;
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.auth-hint {
  font-size: 12px;
  color: var(--color-text-tertiary);
  text-align: center;
  margin-top: 16px;
  line-height: 1.5;
}

/* ============================================================================
 * APP LAYOUT · mobile-first
 * ============================================================================ */

.app {
  display: grid;
  grid-template-rows: auto 1fr auto;
  min-height: 100vh;
  min-height: 100dvh;
  background: var(--color-surface);
}

/* ---------- Topbar (mobile) ---------- */

.topbar {
  position: sticky;
  top: 0;
  z-index: var(--z-sticky);
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  padding-top: calc(12px + env(safe-area-inset-top));
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(160%) blur(12px);
  -webkit-backdrop-filter: saturate(160%) blur(12px);
  border-bottom: 1px solid var(--color-border);
  min-height: 56px;
}

.topbar-back {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  color: var(--color-text-primary);
  background: var(--color-surface);
  transition: background var(--duration-fast) var(--ease-soft);
}

.topbar-back:active { background: var(--teal-100); }

.topbar-title {
  flex: 1;
  min-width: 0;
}

.topbar-title-text {
  font-weight: 600;
  font-size: 17px;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  letter-spacing: -0.01em;
}

.topbar-subtitle {
  font-size: 11px;
  color: var(--color-text-secondary);
  margin-top: 1px;
  font-variant-numeric: tabular-nums;
}

.topbar-user {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
}

/* ---------- User avatar ---------- */

.user-initials {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--teal-600), var(--teal-800));
  color: #fff;
  font-size: 12px;
  font-weight: 600;
  letter-spacing: 0.02em;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.08);
}

/* ---------- Sidebar (desktop only) ---------- */

.sidebar { display: none; }

/* ---------- Main content ---------- */

.main {
  padding: 16px 16px;
  padding-bottom: calc(100px + env(safe-area-inset-bottom));
  max-width: 1200px;
  width: 100%;
  margin: 0 auto;
}

.page {
  animation: page-in 180ms var(--ease-soft) both;
}

@keyframes page-in {
  from { opacity: 0; transform: translateY(4px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ---------- Tabbar (mobile) ---------- */

.tabbar {
  position: fixed;
  bottom: 0;
  left: 0;
  right: 0;
  z-index: var(--z-tabbar);
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  padding: 8px 8px calc(8px + env(safe-area-inset-bottom));
  background: rgba(255, 255, 255, 0.92);
  backdrop-filter: saturate(180%) blur(20px);
  -webkit-backdrop-filter: saturate(180%) blur(20px);
  border-top: 1px solid var(--color-border);
}

.tab {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 4px;
  padding: 6px 4px;
  color: var(--color-text-tertiary);
  font-size: 10px;
  font-weight: 500;
  border-radius: var(--radius-md);
  transition: color var(--duration-fast) var(--ease-soft);
  letter-spacing: -0.01em;
  min-height: 48px;
}

.tab:active { transform: scale(0.95); }
.tab.active { color: var(--color-primary); }

/* Add-tab — «плавающая» кнопка */
.tab-primary {
  position: relative;
  color: #fff;
}
.tab-primary svg { position: relative; z-index: 1; }
.tab-primary::before {
  content: '';
  position: absolute;
  top: -12px;
  left: 50%;
  transform: translateX(-50%);
  width: 48px;
  height: 48px;
  background: linear-gradient(135deg, var(--teal-500), var(--teal-700));
  border-radius: 50%;
  box-shadow: 0 6px 20px rgba(13, 148, 136, 0.35);
  z-index: 0;
  transition: transform var(--duration-fast) var(--ease-soft);
}
.tab-primary:active::before { transform: translateX(-50%) scale(0.92); }
.tab-primary span { color: var(--color-text-tertiary); margin-top: 18px; }
.tab-primary.active span { color: var(--color-primary); }

/* ============================================================================
 * SIDEBAR (desktop)
 * ============================================================================ */

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 6px 24px;
  border-bottom: 1px solid var(--color-border);
  margin-bottom: 16px;
}

.sidebar-brand-mark {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  color: var(--color-primary);
}

.sidebar-brand-name {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.02em;
  font-size: 16px;
  color: var(--teal-950);
}

.sidebar-nav {
  flex: 1;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 1px;
}

.sidebar-nav-group + .sidebar-nav-group {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--color-border);
}

.sidebar-nav-group-title {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  padding: 0 10px 8px;
}

.sidebar-nav a {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 9px 10px;
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  font-size: 14px;
  font-weight: 500;
  transition: all var(--duration-fast) var(--ease-soft);
  position: relative;
}

.sidebar-nav a:hover {
  background: var(--color-surface);
  color: var(--color-text-primary);
}

.sidebar-nav a.active {
  background: var(--teal-950);
  color: #fff;
}

.sidebar-nav a.active::before {
  content: '';
  position: absolute;
  left: -16px;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 20px;
  background: var(--color-primary);
  border-radius: 0 2px 2px 0;
}

.sidebar-nav-icon {
  display: inline-flex;
  width: 18px;
  height: 18px;
  flex-shrink: 0;
}

.sidebar-footer {
  border-top: 1px solid var(--color-border);
  padding-top: 16px;
  margin-top: 16px;
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 6px;
  border-radius: var(--radius-md);
}

.sidebar-user-info {
  flex: 1;
  min-width: 0;
}

.sidebar-user-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-signout {
  font-size: 11px;
  color: var(--color-text-tertiary);
  display: inline-flex;
  align-items: center;
  gap: 4px;
  transition: color var(--duration-fast) var(--ease-soft);
}
.sidebar-user-signout:hover { color: var(--error-700); }

/* ============================================================================
 * TYPOGRAPHY
 * ============================================================================ */

.wordmark {
  font-family: var(--font-display);
  font-weight: 400;
  letter-spacing: 0.02em;
  color: var(--teal-950);
}

.mono, .num {
  font-family: var(--font-mono);
  font-variant-numeric: tabular-nums;
  font-feature-settings: 'tnum';
  letter-spacing: -0.01em;
}

/* ============================================================================
 * PAGE SECTIONS
 * ============================================================================ */

.section { margin-bottom: 28px; }
.section:last-child { margin-bottom: 0; }

.section-title-row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin: 0 4px 10px;
  gap: 12px;
}

.section-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
  margin: 0;
}

.page-hero {
  padding: 8px 4px 20px;
}

.page-hero-title {
  font-size: 24px;
  font-weight: 600;
  letter-spacing: -0.02em;
  line-height: 1.2;
  color: var(--color-text-primary);
  margin: 0 0 4px;
}

.page-hero-sub {
  font-size: 14px;
  color: var(--color-text-secondary);
  margin: 0;
}

/* ============================================================================
 * CARDS
 * ============================================================================ */

.card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 16px;
  transition: all var(--duration-fast) var(--ease-soft);
}

/* ============================================================================
 * MENU CARDS (home)
 * ============================================================================ */

.menu-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 8px;
}

.menu-card {
  display: grid;
  grid-template-columns: 40px 1fr auto;
  align-items: center;
  gap: 14px;
  padding: 14px 16px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: all var(--duration-fast) var(--ease-soft);
  color: var(--color-text-primary);
}

.menu-card:active {
  background: var(--color-surface);
  transform: scale(0.99);
}

.menu-card.soon {
  opacity: 0.55;
}

.menu-card-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--color-primary);
}

/* Цветная индивидуальность по типу раздела */
.menu-card-icon.ic-purple { background: #F5F3FF; color: #7C3AED; }
.menu-card-icon.ic-amber  { background: var(--ai-surface); color: var(--ai-bright); }
.menu-card-icon.ic-emerald{ background: var(--success-50); color: var(--success-700); }
.menu-card-icon.ic-rose   { background: var(--error-50);   color: var(--error-700); }
.menu-card-icon.ic-blue   { background: var(--info-50);    color: var(--info-700); }
.menu-card-icon.ic-slate  { background: var(--slate-100);  color: var(--slate-600); }
.menu-card-icon.ic-teal   { background: var(--color-surface); color: var(--color-primary); }

.menu-card-body { min-width: 0; }

.menu-card-title {
  font-weight: 500;
  font-size: 15px;
  color: var(--color-text-primary);
  margin-bottom: 2px;
  letter-spacing: -0.01em;
}

.menu-card-desc {
  font-size: 12px;
  color: var(--color-text-secondary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.menu-card-chevron {
  color: var(--color-text-tertiary);
  display: flex;
}

.menu-card-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 7px;
  margin-left: 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: 9px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
}

/* ============================================================================
 * KPI TILES
 * ============================================================================ */

.kpi-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
}

.kpi {
  padding: 16px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  position: relative;
  overflow: hidden;
}

.kpi-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-secondary);
  margin-bottom: 8px;
  line-height: 1.3;
}

.kpi-label-icon { display: inline-flex; color: var(--color-text-tertiary); }

.kpi-value {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
  line-height: 1.1;
  letter-spacing: -0.01em;
}

.kpi-value-display {
  font-size: 32px;
  font-weight: 600;
  letter-spacing: -0.02em;
}

.kpi-hint {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 11px;
  color: var(--color-text-tertiary);
  margin-top: 6px;
  font-variant-numeric: tabular-nums;
}

.kpi-trend {
  display: inline-flex;
  align-items: center;
  gap: 2px;
  padding: 1px 6px;
  border-radius: var(--radius-xs);
  font-size: 10px;
  font-weight: 600;
}
.kpi-trend.up   { background: var(--success-50); color: var(--success-700); }
.kpi-trend.down { background: var(--error-50);   color: var(--error-700); }

/* ============================================================================
 * BUTTONS
 * ============================================================================ */

.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 10px 16px;
  font-size: 14px;
  font-weight: 500;
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-soft);
  min-height: 40px;
  letter-spacing: -0.01em;
  white-space: nowrap;
}

.btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}

.btn-primary {
  background: var(--color-primary);
  color: #fff;
  box-shadow: 0 1px 2px rgba(13, 148, 136, 0.2);
}
.btn-primary:hover:not(:disabled) {
  background: var(--color-primary-hover);
  transform: translateY(-1px);
  box-shadow: var(--shadow-md);
}
.btn-primary:active:not(:disabled) {
  transform: translateY(0);
  background: var(--color-primary-pressed);
}

.btn-secondary {
  background: var(--color-paper);
  color: var(--color-text-primary);
  border: 1px solid var(--color-border-strong);
}
.btn-secondary:hover:not(:disabled) {
  background: var(--color-surface);
  border-color: var(--color-primary);
  color: var(--color-primary);
}

.btn-ghost {
  background: transparent;
  color: var(--color-text-primary);
}
.btn-ghost:hover:not(:disabled) { background: var(--color-surface); }

.btn-danger {
  background: var(--error-500);
  color: #fff;
  border: 1px solid var(--error-500);
}
.btn-danger:hover:not(:disabled) {
  background: var(--error-700);
  border-color: var(--error-700);
  transform: translateY(-1px);
  box-shadow: 0 4px 12px rgba(244, 63, 94, 0.25);
}
.btn-danger:active:not(:disabled) {
  transform: translateY(0);
  background: var(--error-700);
}

.btn-lg { padding: 14px 24px; font-size: 15px; min-height: 48px; }
.btn-block { width: 100%; }

.btn-icon {
  width: 40px;
  height: 40px;
  padding: 0;
  justify-content: center;
}

/* ============================================================================
 * FORM CONTROLS
 * ============================================================================ */

.field {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}

.field-label {
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-secondary);
}

.field-hint {
  font-size: 11px;
  color: var(--color-text-tertiary);
  margin-top: 2px;
}

.input, .textarea {
  width: 100%;
  padding: 11px 14px;
  font-size: 16px; /* 16+ чтобы iOS не зумил */
  background: var(--color-paper);
  color: var(--color-text-primary);
  border: 1px solid var(--color-border-strong);
  border-radius: var(--radius-md);
  outline: none;
  transition: border-color var(--duration-fast) var(--ease-soft),
              box-shadow var(--duration-fast) var(--ease-soft),
              background var(--duration-fast) var(--ease-soft);
  min-height: 44px;
  font-family: inherit;
  font-weight: 400;
  line-height: 1.4;
}

.input::placeholder { color: var(--color-text-tertiary); }

.input:focus, .textarea:focus {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
  background: var(--color-paper);
}

.textarea { min-height: 80px; resize: vertical; }

/* Большой input для сумм */
.input-amount {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  text-align: center;
  padding: 20px 16px;
  letter-spacing: -0.02em;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  min-height: 72px;
}
.input-amount:focus {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}

/* Input с search-иконкой */
.input-search {
  position: relative;
}
.input-search .input { padding-left: 40px; }
.input-search-icon {
  position: absolute;
  left: 12px;
  top: 50%;
  transform: translateY(-50%);
  color: var(--color-text-tertiary);
  pointer-events: none;
}

/* ============================================================================
 * WIZARD (step-by-step)
 * ============================================================================ */

.wizard {
  display: flex;
  flex-direction: column;
  min-height: calc(100vh - 56px - 100px);
  min-height: calc(100dvh - 56px - 100px);
}

.wizard-progress {
  display: flex;
  gap: 4px;
  padding: 2px 0 20px;
}

.wizard-progress-step {
  flex: 1;
  height: 3px;
  background: var(--color-border);
  border-radius: 2px;
  transition: background var(--duration-default) var(--ease-soft);
}

.wizard-progress-step.done    { background: var(--color-primary); }
.wizard-progress-step.current { background: var(--color-primary); }

.wizard-step {
  flex: 1;
  display: flex;
  flex-direction: column;
}

.wizard-step-label {
  display: flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: 0.08em;
  font-weight: 500;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  margin-bottom: 10px;
}

.wizard-step-question {
  font-size: 22px;
  font-weight: 600;
  color: var(--color-text-primary);
  line-height: 1.25;
  letter-spacing: -0.02em;
  margin: 0 0 20px;
}

.wizard-step-hint {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: -12px 0 16px;
  line-height: 1.5;
}

.wizard-step-body { flex: 1; }

.wizard-nav {
  display: flex;
  gap: 10px;
  padding: 20px 0 0;
  position: sticky;
  bottom: calc(82px + env(safe-area-inset-bottom));
  background:
    linear-gradient(to top, var(--color-surface) 0%, var(--color-surface) 70%, transparent);
  padding-top: 24px;
}

.wizard-nav .btn { flex: 1; }

/* ============================================================================
 * CHOICES (list of selectable items for wizard)
 * ============================================================================ */

.choice-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 6px;
}

.choice-grid.scroll {
  max-height: 50vh;
  overflow-y: auto;
  margin: 0 -4px;
  padding: 0 4px;
  -webkit-overflow-scrolling: touch;
}

.choice {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  text-align: left;
  font-size: 15px;
  color: var(--color-text-primary);
  min-height: 52px;
  width: 100%;
  transition: all var(--duration-fast) var(--ease-soft);
  letter-spacing: -0.01em;
  line-height: 1.3;
}

.choice:hover {
  border-color: var(--color-primary);
  background: var(--teal-50);
}
.choice:active { transform: scale(0.99); }

.choice.selected {
  border-color: var(--color-primary);
  background: var(--teal-50);
  color: var(--teal-900);
  font-weight: 500;
  box-shadow: inset 0 0 0 1px var(--color-primary);
}

.choice-icon {
  display: flex;
  flex-shrink: 0;
  color: var(--color-text-tertiary);
}

.choice.selected .choice-icon { color: var(--color-primary); }

.choice-check {
  margin-left: auto;
  display: flex;
  align-items: center;
  justify-content: center;
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: var(--color-primary);
  color: #fff;
  opacity: 0;
  transform: scale(0.8);
  transition: all var(--duration-fast) var(--ease-soft);
  flex-shrink: 0;
}

.choice.selected .choice-check { opacity: 1; transform: scale(1); }

.choice-body {
  flex: 1;
  min-width: 0;
}

.choice-title {
  font-weight: 500;
  line-height: 1.3;
}

.choice-sub {
  font-size: 12px;
  color: var(--color-text-tertiary);
  margin-top: 2px;
  line-height: 1.3;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* ============================================================================
 * CURRENCY TOGGLE
 * ============================================================================ */

.currency-toggle {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 6px;
  margin-top: 14px;
  padding: 4px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
}

.currency-toggle button {
  padding: 10px;
  background: transparent;
  border: none;
  border-radius: var(--radius-sm);
  font-size: 15px;
  font-weight: 500;
  color: var(--color-text-secondary);
  transition: all var(--duration-fast) var(--ease-soft);
  min-height: 40px;
  font-family: var(--font-mono);
}

.currency-toggle button.active {
  background: var(--color-paper);
  color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

/* ============================================================================
 * SUMMARY CARD (wizard last step)
 * ============================================================================ */

.summary-card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 16px;
}

.summary-hero {
  padding: 24px 20px 20px;
  text-align: center;
  background:
    radial-gradient(ellipse at top, rgba(13, 148, 136, 0.08), transparent 70%),
    var(--color-paper);
  border-bottom: 1px solid var(--color-border);
}

.summary-hero-value {
  font-family: var(--font-mono);
  font-size: 36px;
  font-weight: 600;
  color: var(--teal-900);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
  line-height: 1.1;
  margin-bottom: 2px;
}

.summary-hero-label {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
}

.summary-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  padding: 12px 20px;
  border-top: 1px solid var(--color-border);
  align-items: flex-start;
}

.summary-row:first-of-type { border-top: none; }

.summary-row-label {
  color: var(--color-text-secondary);
  font-size: 12px;
  line-height: 1.4;
}

.summary-row-value {
  color: var(--color-text-primary);
  text-align: right;
  font-weight: 500;
  font-size: 13px;
  word-break: break-word;
  line-height: 1.4;
}

/* ============================================================================
 * EXPENSE LIST ITEMS
 * ============================================================================ */

.expense-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  padding: 14px 16px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: 6px;
  align-items: center;
  transition: all var(--duration-fast) var(--ease-soft);
}

.expense-item:hover {
  border-color: var(--color-border-strong);
}

.expense-item-clickable {
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.expense-item-clickable:hover {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}
.expense-item-clickable:active {
  transform: scale(0.995);
}
.expense-item-clickable:focus-visible {
  outline: none;
  border-color: var(--color-primary);
  box-shadow: var(--shadow-focus);
}

.expense-item-date {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-width: 42px;
  padding: 6px 8px;
  background: var(--color-surface);
  border-radius: var(--radius-sm);
  color: var(--color-text-primary);
}

.expense-item-date-day {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 600;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.02em;
}

.expense-item-date-month {
  font-size: 9px;
  text-transform: uppercase;
  font-weight: 600;
  letter-spacing: 0.06em;
  color: var(--color-text-secondary);
  margin-top: 2px;
  font-family: var(--font-mono);
}

.expense-item-body { min-width: 0; }

.expense-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
  letter-spacing: -0.01em;
}

.expense-item-meta {
  display: flex;
  gap: 6px;
  align-items: center;
  font-size: 11px;
  color: var(--color-text-tertiary);
  overflow: hidden;
}

.expense-item-meta span {
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.expense-item-meta .dot {
  color: var(--color-border-strong);
}

.expense-item-amount {
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
  text-align: right;
  white-space: nowrap;
  letter-spacing: -0.01em;
}

.expense-item-amount-currency {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: 3px;
}

/* Группировка по датам в списке */
.expense-date-group {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 4px 6px;
}

.expense-date-group-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
}

.expense-date-group-sum {
  margin-left: auto;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-secondary);
  font-variant-numeric: tabular-nums;
}

/* ============================================================================
 * FILTER CHIPS
 * ============================================================================ */

.filter-bar {
  display: flex;
  gap: 6px;
  overflow-x: auto;
  padding: 2px 0 12px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}

.filter-bar::-webkit-scrollbar { display: none; }

.filter-chip {
  flex-shrink: 0;
  padding: 7px 12px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: 12px;
  font-weight: 500;
  color: var(--color-text-secondary);
  white-space: nowrap;
  transition: all var(--duration-fast) var(--ease-soft);
  letter-spacing: -0.01em;
}

.filter-chip:hover { border-color: var(--color-border-strong); color: var(--color-text-primary); }

.filter-chip.active {
  background: var(--teal-950);
  color: #fff;
  border-color: var(--teal-950);
}

/* ============================================================================
 * RECEIPT UPLOADER
 * ============================================================================ */

.receipt-uploader {
  margin-top: 8px;
}

.receipt-uploader-trigger {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: var(--color-paper);
  border: 1.5px dashed var(--color-border-strong);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
  min-height: 60px;
}

.receipt-uploader-trigger:hover {
  border-color: var(--color-primary);
  background: var(--teal-50);
}
.receipt-uploader-trigger:active { transform: scale(0.995); }

.receipt-uploader-icon {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-sm);
  background: var(--color-surface);
  color: var(--color-primary);
  flex-shrink: 0;
}

.receipt-uploader-label {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.receipt-uploader-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
}

.receipt-uploader-hint {
  font-size: 11px;
  color: var(--color-text-tertiary);
}

.receipt-uploader-preview {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  min-height: 60px;
}

.receipt-uploader-preview-thumb {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: var(--radius-sm);
  overflow: hidden;
  background: var(--color-surface);
  display: flex;
  align-items: center;
  justify-content: center;
}

.receipt-uploader-preview-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.receipt-uploader-preview-pdf {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 2px;
  color: var(--error-700);
  font-size: 9px;
  font-weight: 600;
  font-family: var(--font-mono);
  letter-spacing: 0.04em;
}

.receipt-uploader-preview-body {
  flex: 1;
  min-width: 0;
}

.receipt-uploader-preview-name {
  font-size: 13px;
  font-weight: 500;
  color: var(--color-text-primary);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.receipt-uploader-preview-size {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
}

.receipt-uploader-remove {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-sm);
  color: var(--color-text-tertiary);
  transition: all var(--duration-fast) var(--ease-soft);
  flex-shrink: 0;
}
.receipt-uploader-remove:hover {
  background: var(--error-50);
  color: var(--error-700);
}

.receipt-attached-badge {
  display: inline-flex;
  align-items: center;
  gap: 3px;
  padding: 2px 6px;
  border-radius: var(--radius-xs);
  background: var(--success-50);
  color: var(--success-700);
  font-size: 10px;
  font-weight: 500;
  letter-spacing: -0.01em;
}

/* ============================================================================
 * EMPTY STATES & LOADING
 * ============================================================================ */

.empty-state {
  text-align: center;
  padding: 48px 24px;
  color: var(--color-text-secondary);
  animation: fade-up 300ms var(--ease-soft) both;
}

.empty-state-illust {
  margin: 0 auto 20px;
  color: var(--color-primary);
}

.empty-state-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 6px;
  letter-spacing: -0.01em;
}

.empty-state-desc {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 0 auto;
  max-width: 320px;
  line-height: 1.5;
}

.empty-state-action {
  margin-top: 20px;
}

/* Skeleton loading */
.skeleton {
  background: linear-gradient(
    90deg,
    var(--color-surface) 0%,
    rgba(94, 234, 212, 0.1) 50%,
    var(--color-surface) 100%
  );
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.4s ease-in-out infinite;
  border-radius: var(--radius-sm);
}

@keyframes skeleton-shimmer {
  0%   { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

.skeleton-line {
  height: 12px;
  margin-bottom: 8px;
}
.skeleton-line.short { width: 60%; }
.skeleton-line.med { width: 80%; }
.skeleton-line.long { width: 100%; }

.skeleton-expense {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 14px;
  align-items: center;
  padding: 14px 16px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: 6px;
  min-height: 62px;
}

.skeleton-date { width: 42px; height: 40px; }
.skeleton-body { flex: 1; }
.skeleton-amount { width: 72px; height: 20px; }

/* Spinner */
.spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: currentColor;
  border-radius: 50%;
  animation: spin 700ms linear infinite;
}

@keyframes spin { to { transform: rotate(360deg); } }

/* ============================================================================
 * TOASTS
 * ============================================================================ */

.toasts {
  position: fixed;
  left: 50%;
  transform: translateX(-50%);
  bottom: calc(100px + env(safe-area-inset-bottom));
  z-index: var(--z-toast);
  display: flex;
  flex-direction: column;
  gap: 8px;
  pointer-events: none;
  max-width: calc(100vw - 24px);
}

.toast {
  pointer-events: auto;
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 12px 16px;
  background: var(--teal-950);
  color: #fff;
  border-radius: var(--radius-md);
  font-size: 14px;
  box-shadow: var(--shadow-lg);
  animation: toast-in 250ms var(--ease-sheet);
  max-width: 400px;
  line-height: 1.4;
  letter-spacing: -0.01em;
}

.toast-success { background: var(--success-700); }
.toast-error   { background: var(--error-700); }
.toast-warning { background: var(--warning-700); }
.toast-info    { background: var(--info-700); }

.toast-icon { display: flex; }

@keyframes toast-in {
  from { opacity: 0; transform: translateY(24px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* ============================================================================
 * BOTTOM SHEET (iOS-like modal)
 * ============================================================================ */

.sheet-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(4, 47, 46, 0.45);
  z-index: var(--z-overlay);
  animation: fade-in 200ms var(--ease-soft);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
}

@keyframes fade-in {
  from { opacity: 0; }
  to   { opacity: 1; }
}

.sheet {
  position: fixed;
  left: 0;
  right: 0;
  bottom: 0;
  z-index: var(--z-sheet);
  background: var(--color-paper);
  border-radius: var(--radius-2xl) var(--radius-2xl) 0 0;
  max-height: 85vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  animation: sheet-up 300ms var(--ease-sheet);
  padding-bottom: env(safe-area-inset-bottom);
  box-shadow: 0 -12px 40px rgba(4, 47, 46, 0.15);
}

@keyframes sheet-up {
  from { transform: translateY(100%); }
  to   { transform: translateY(0); }
}

.sheet-handle {
  width: 36px;
  height: 4px;
  background: var(--color-border-strong);
  border-radius: 2px;
  margin: 10px auto 0;
}

.sheet-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 20px;
  border-bottom: 1px solid var(--color-border);
}

.sheet-title {
  font-size: 17px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.sheet-body {
  padding: 16px 20px 20px;
  overflow-y: auto;
  flex: 1;
}

/* ============================================================================
 * ACCOUNTS (v7) · Карточки счетов
 * ============================================================================ */

.account-card {
  display: block;
  width: 100%;
  text-align: left;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
}

.account-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

.account-card:active {
  transform: scale(0.998);
}

.account-card:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-color: var(--color-primary);
}

.account-card-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
}

.account-card-title-block {
  min-width: 0;
}

.account-card-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-card-meta {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.account-card-balance {
  font-size: 18px;
  font-weight: 600;
  font-family: var(--font-mono);
  white-space: nowrap;
  letter-spacing: -0.01em;
}

.account-card-balance-currency {
  font-size: 0.65em;
  color: var(--color-text-tertiary);
  margin-left: 3px;
  font-weight: 500;
}

.account-card-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
}

.account-card-stat {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.account-card-stat-icon {
  display: inline-flex;
}

.account-card-stat-label {
  font-size: 11px;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.03em;
  font-weight: 500;
}

.account-card-stat-value {
  font-size: 13px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* Section-title-meta — счётчик у заголовка секции («3 счёта», «2 карты») */
.section-title-meta {
  font-size: 12px;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: auto;
}

/* Дополнительное оформление choice-sub (используется в wizard выбора счёта) */
.choice-sub {
  display: block;
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 3px;
  line-height: 1.3;
}

/* ============================================================================
 * RECURRING (v8) · Карточки регулярных платежей
 * ============================================================================ */

.recurring-card {
  display: block;
  width: 100%;
  text-align: left;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
}

.recurring-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

.recurring-card:active { transform: scale(0.998); }

.recurring-card:focus-visible {
  outline: none;
  box-shadow: var(--shadow-focus);
  border-color: var(--color-primary);
}

.recurring-card.overdue {
  border-color: rgba(244, 63, 94, 0.35);
  background: linear-gradient(90deg, var(--error-50) 0%, var(--color-paper) 40%);
}

.recurring-card.soon {
  border-color: rgba(245, 158, 11, 0.30);
  background: linear-gradient(90deg, var(--warning-50) 0%, var(--color-paper) 40%);
}

.recurring-card.paused   { opacity: 0.75; }
.recurring-card.archived { opacity: 0.55; }

.recurring-card-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 12px;
  align-items: center;
}

.recurring-card-title-block {
  min-width: 0;
}

.recurring-card-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  line-height: 1.3;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recurring-card-meta {
  font-size: 12px;
  color: var(--color-text-secondary);
  margin-top: 2px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.recurring-card-amount {
  font-size: 18px;
  font-weight: 600;
  font-family: var(--font-mono);
  white-space: nowrap;
  letter-spacing: -0.01em;
  color: var(--color-text-primary);
}

.recurring-card-amount-currency {
  font-size: 0.65em;
  color: var(--color-text-tertiary);
  margin-left: 3px;
  font-weight: 500;
}

.recurring-card-foot {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
  font-size: 12px;
}

.recurring-card-runs {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: var(--color-text-tertiary);
  margin-left: auto;
}

.due-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.01em;
  line-height: 1;
}

.due-badge-overdue  { background: var(--error-50);   color: var(--error-700);   }
.due-badge-soon     { background: var(--warning-50); color: var(--warning-700); }
.due-badge-normal   { background: var(--slate-100);  color: var(--slate-600);   }
.due-badge-paused   { background: var(--warning-50); color: var(--warning-700); }
.due-badge-archived { background: var(--slate-100);  color: var(--slate-500);   }

@media (min-width: 1024px) {
  .recurring-card { padding: 18px 22px; }
  .recurring-card-name { font-size: 16px; }
  .recurring-card-amount { font-size: 22px; }
}

/* ============================================================================
 * REPORTS (v9) — page /reports
 * ============================================================================ */

.report-switcher {
  margin-bottom: 8px;
}

.report-switcher .filter-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  font-size: 13px;
}

.report-toolbar {
  display: flex;
  align-items: flex-end;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 16px;
}

.report-toolbar-left {
  flex: 1;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.report-year-label {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.report-year-bar {
  padding-bottom: 0;
  padding-top: 0;
  margin: 0;
}

.report-year-bar .filter-chip {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 500;
  padding: 6px 12px;
}

.report-toolbar-right {
  display: flex;
  gap: 6px;
  flex-shrink: 0;
}

.btn-sm {
  padding: 8px 12px;
  font-size: 12px;
  min-height: 36px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  background: var(--color-paper);
  color: var(--color-text-primary);
  font-weight: 500;
  transition: all var(--duration-fast) var(--ease-soft);
}

.btn-sm:hover {
  border-color: var(--color-border-strong);
  background: var(--color-surface);
}

.report-summary {
  margin-bottom: 24px;
}

.report-content {
  margin-top: 8px;
}

/* ── График (большой bar-chart) ── */

.report-chart-card {
  padding: 16px 14px 10px;
}

.report-legend {
  display: flex;
  justify-content: center;
  align-items: center;
  gap: 18px;
  margin-top: 8px;
  font-size: 11px;
  color: var(--color-text-secondary);
  flex-wrap: wrap;
}

.report-legend-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

.report-legend-swatch {
  width: 10px;
  height: 10px;
  border-radius: 2px;
  display: inline-block;
}

.report-legend-meta {
  font-family: var(--font-mono);
  color: var(--color-text-tertiary);
  margin-left: 6px;
}

/* ── Таблица помесячной разбивки ── */

.report-table {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
}

.report-table-head,
.report-table-row {
  display: grid;
  grid-template-columns: minmax(0, 1.5fr) minmax(0, 1fr) minmax(0, 1fr) minmax(0, 1fr);
  gap: 10px;
  align-items: center;
  padding: 12px 16px;
}

.report-table-head {
  background: var(--color-surface);
  font-size: 11px;
  font-weight: 500;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-bottom: 1px solid var(--color-border);
}

.report-table-row {
  border-bottom: 1px solid var(--color-border);
  font-size: 14px;
  transition: background var(--duration-fast) var(--ease-soft);
}

.report-table-row:last-child {
  border-bottom: none;
}

.report-table-row:hover:not(.report-table-total) {
  background: var(--color-surface);
}

.report-table-cell-name {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.report-month-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 4px 10px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-sm);
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 600;
  color: var(--color-text-primary);
  min-width: 44px;
}

.report-table-total {
  background: var(--teal-50);
  border-top: 2px solid var(--color-border-strong);
}

.report-table-total .report-table-cell-name {
  color: var(--color-text-primary);
}

/* ── Карточки по кварталам ── */

.report-quarters-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.report-quarter-card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  transition: all var(--duration-fast) var(--ease-soft);
}

.report-quarter-card.current {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-md);
  background: linear-gradient(180deg, var(--teal-50) 0%, var(--color-paper) 70%);
}

.report-quarter-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  margin-bottom: 8px;
  gap: 8px;
}

.report-quarter-label {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
}

.report-quarter-months {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.report-quarter-netto {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  margin-bottom: 14px;
  font-variant-numeric: tabular-nums;
}

.report-quarter-netto-cur {
  font-size: 0.55em;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: 4px;
}

.report-quarter-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.report-quarter-stat {
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.report-quarter-stat-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
}

.report-quarter-stat-value {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

/* ── Категории ── */

.report-cat-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.report-cat-item {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  transition: all var(--duration-fast) var(--ease-soft);
}

.report-cat-item:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

.report-cat-item.expanded {
  border-color: var(--color-primary);
  box-shadow: var(--shadow-sm);
}

.report-cat-head {
  display: grid;
  grid-template-columns: auto 1fr auto auto;
  align-items: center;
  gap: 12px;
  width: 100%;
  padding: 14px 16px 10px;
  background: transparent;
  border: none;
  text-align: left;
  cursor: pointer;
  transition: background var(--duration-fast) var(--ease-soft);
}

.report-cat-head:hover {
  background: var(--color-surface);
}

.report-cat-body {
  display: flex;
  flex-direction: column;
  gap: 4px;
  min-width: 0;
}

.report-cat-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.report-cat-meta {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-tertiary);
}

.report-cat-meta .dot { color: var(--color-text-tertiary); opacity: 0.6; }

.report-cat-split {
  display: inline-flex;
  gap: 4px;
}

.report-split-badge {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  letter-spacing: 0.02em;
  white-space: nowrap;
  font-variant-numeric: tabular-nums;
}

.report-split-badge.ooo     { background: var(--teal-100);    color: var(--teal-800);      }
.report-split-badge.founder { background: #F5F3FF;            color: #6D28D9;               }
.report-split-badge.usn     { background: var(--warning-50);  color: var(--warning-700);    }

.report-cat-amounts {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 2px;
}

.report-cat-total {
  font-size: 16px;
  font-weight: 700;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
  letter-spacing: -0.01em;
}

.report-cat-total-cur {
  font-size: 0.7em;
  color: var(--color-text-tertiary);
  font-weight: 500;
}

.report-cat-share {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
}

.report-cat-chevron {
  display: inline-flex;
  color: var(--color-text-tertiary);
  transition: transform var(--duration-default) var(--ease-soft);
}

.report-cat-item.expanded .report-cat-chevron {
  transform: rotate(90deg);
  color: var(--color-primary);
}

.report-cat-bar {
  height: 3px;
  background: var(--color-surface);
  position: relative;
  margin: 0 16px 2px;
  border-radius: 999px;
  overflow: hidden;
}

.report-cat-bar-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: linear-gradient(90deg, var(--color-primary) 0%, var(--teal-400) 100%);
  border-radius: 999px;
  transition: width var(--duration-slow) var(--ease-soft);
}

.report-cat-bar-fill-income {
  background: linear-gradient(90deg, var(--success-700) 0%, var(--success-500) 100%);
}

.report-cat-subs {
  border-top: 1px solid var(--color-border);
  padding: 6px 0 8px;
  background: var(--color-surface-alt);
}

.report-cat-sub {
  display: grid;
  grid-template-columns: 1fr auto auto;
  align-items: center;
  gap: 10px;
  padding: 8px 16px 8px 62px;
  font-size: 13px;
}

.report-cat-sub + .report-cat-sub {
  border-top: 1px solid var(--color-border);
}

.report-cat-sub-name {
  color: var(--color-text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.report-cat-sub-meta {
  font-size: 11px;
}

.report-cat-sub-amount {
  font-variant-numeric: tabular-nums;
  font-weight: 500;
}

/* ============================================================================
 * TAXES (v10) — page /taxes
 * ============================================================================ */

.tax-periods-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
}

.tax-period-card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 18px 20px;
  transition: all var(--duration-fast) var(--ease-soft);
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.tax-period-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

.tax-period-overdue {
  background: linear-gradient(180deg, var(--error-50) 0%, var(--color-paper) 60%);
  border-color: var(--error-500);
}

.tax-period-urgent {
  background: linear-gradient(180deg, var(--warning-50) 0%, var(--color-paper) 60%);
  border-color: var(--warning-500);
}

.tax-period-soon {
  border-color: var(--warning-500);
}

.tax-period-paid {
  opacity: 0.75;
}

.tax-period-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 10px;
}

.tax-period-title-block {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  min-width: 0;
}

.tax-period-label {
  font-size: 17px;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
}

.tax-period-year {
  font-family: var(--font-mono);
  font-size: 13px;
  color: var(--color-text-tertiary);
  font-weight: 500;
}

.tax-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.01em;
  white-space: nowrap;
}

.tax-badge-paid      { background: var(--success-50); color: var(--success-700); }
.tax-badge-overdue   { background: var(--error-500);  color: #fff; }
.tax-badge-urgent    { background: var(--warning-700); color: #fff; }
.tax-badge-soon      { background: var(--warning-50); color: var(--warning-700); }
.tax-badge-upcoming  { background: var(--slate-100);  color: var(--slate-600); }

.tax-period-deadline {
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-size: 12px;
  color: var(--color-text-secondary);
  padding: 8px 12px;
  background: var(--color-surface-alt);
  border-radius: var(--radius-sm);
}

.tax-period-deadline-date {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-weight: 500;
}

.tax-period-deadline-days {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--color-text-tertiary);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.tax-period-overdue .tax-period-deadline {
  background: var(--error-50);
  color: var(--error-700);
}
.tax-period-overdue .tax-period-deadline-days { color: var(--error-700); }

.tax-period-urgent .tax-period-deadline {
  background: var(--warning-50);
  color: var(--warning-700);
}
.tax-period-urgent .tax-period-deadline-days { color: var(--warning-700); }

.tax-period-main {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.tax-period-amount-wrap {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.tax-period-amount-label {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.tax-period-amount {
  font-size: 28px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

.tax-period-amount-zero {
  color: var(--color-text-tertiary);
}

.tax-period-amount-cur {
  font-size: 0.55em;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: 4px;
}

.tax-period-pay {
  padding: 10px 18px;
  font-size: 13px;
  min-height: 40px;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex-shrink: 0;
}

.tax-period-paid-indicator {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 40px;
  height: 40px;
  border-radius: 999px;
  background: var(--success-50);
  color: var(--success-700);
  flex-shrink: 0;
}

.tax-period-breakdown {
  display: flex;
  flex-direction: column;
  gap: 6px;
  padding-top: 12px;
  border-top: 1px solid var(--color-border);
  font-size: 13px;
}

.tax-period-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 8px;
}

.tax-period-row-label {
  color: var(--color-text-secondary);
  display: inline-flex;
  align-items: center;
  gap: 5px;
}

.tax-period-row-value {
  color: var(--color-text-primary);
  font-weight: 500;
  font-variant-numeric: tabular-nums;
}

.tax-period-row-value.muted { color: var(--color-text-tertiary); }

.tax-period-payments {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 10px;
  border-top: 1px dashed var(--color-border);
}

.tax-period-payment {
  display: grid;
  grid-template-columns: auto 1fr auto;
  gap: 10px;
  align-items: center;
  font-size: 12px;
  padding: 6px 0;
}

.tax-period-payment-date {
  font-family: var(--font-mono);
  color: var(--color-text-tertiary);
  font-size: 11px;
  min-width: 46px;
}

.tax-period-payment-name {
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.tax-period-payment-amount {
  color: var(--success-700);
  font-weight: 600;
  font-variant-numeric: tabular-nums;
}

.tax-history-period-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 8px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: 10px;
  font-weight: 600;
  color: var(--color-text-primary);
  letter-spacing: 0.02em;
  white-space: nowrap;
}

.tax-info-card {
  display: grid;
  grid-template-columns: auto 1fr;
  gap: 12px;
  padding: 14px 16px;
  background: var(--info-50);
  border: 1px solid var(--info-500);
  border-radius: var(--radius-md);
  margin-top: 8px;
}

.tax-info-icon {
  color: var(--info-700);
  display: inline-flex;
  align-items: flex-start;
  padding-top: 2px;
}

.tax-info-body {
  min-width: 0;
}

.tax-info-title {
  font-size: 13px;
  font-weight: 600;
  color: var(--info-700);
  margin-bottom: 4px;
}

.tax-info-text {
  font-size: 12px;
  color: var(--color-text-secondary);
  line-height: 1.5;
}

.tax-info-text b {
  color: var(--color-text-primary);
  font-weight: 600;
}

/* ============================================================================
 * FOUNDERS (v11) — page /founders
 * ============================================================================ */

/* ── Уставный капитал — сводный блок ── */

.uk-summary {
  display: grid;
  grid-template-columns: 1fr;
  gap: 20px;
  padding-bottom: 18px;
  margin-bottom: 18px;
  border-bottom: 1px solid var(--color-border);
}

.uk-summary-main {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.uk-summary-label {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.uk-summary-value {
  font-size: 32px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

.uk-summary-value-cur {
  font-size: 0.55em;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: 4px;
}

.uk-summary-meta {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-secondary);
  flex-wrap: wrap;
}

.uk-summary-meta .dot { color: var(--color-text-tertiary); opacity: 0.6; }

.uk-deadline-overdue { color: var(--error-700); display: inline-flex; align-items: center; gap: 4px; font-weight: 600; }
.uk-deadline-soon    { color: var(--warning-700); display: inline-flex; align-items: center; gap: 4px; font-weight: 600; }
.uk-deadline-ok      { color: var(--color-text-secondary); display: inline-flex; align-items: center; gap: 4px; }
.uk-deadline-paid    { color: var(--success-700); display: inline-flex; align-items: center; gap: 4px; font-weight: 600; }

.uk-summary-progress {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

.uk-progress-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  font-size: 12px;
  color: var(--color-text-secondary);
  font-weight: 500;
}

.uk-progress-pct {
  font-size: 14px;
  font-weight: 700;
  color: var(--color-text-primary);
}

.uk-progress-bar {
  height: 10px;
  background: var(--color-surface);
  border-radius: 999px;
  overflow: hidden;
  position: relative;
}

.uk-progress-fill {
  position: absolute;
  left: 0;
  top: 0;
  bottom: 0;
  background: linear-gradient(90deg, var(--success-700) 0%, var(--success-500) 100%);
  border-radius: 999px;
  transition: width var(--duration-slow) var(--ease-soft);
}

.uk-progress-stats {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  font-size: 12px;
}

.uk-progress-stats .muted { color: var(--color-text-tertiary); }

/* ── УК: строки учредителей ── */

.uk-founders {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.uk-founder-row {
  display: grid;
  grid-template-columns: 1fr;
  gap: 12px;
  padding: 14px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
}

.uk-founder-identity {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 0;
}

.uk-founder-avatar {
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--teal-100);
  color: var(--teal-800);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 14px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
}

.uk-founder-body {
  min-width: 0;
}

.uk-founder-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  letter-spacing: -0.01em;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.uk-founder-meta {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-secondary);
}

.uk-founder-share {
  display: inline-flex;
  padding: 2px 8px;
  background: var(--teal-50);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--teal-800);
}

.uk-founder-stats {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.uk-founder-stat-label {
  font-size: 11px;
  color: var(--color-text-tertiary);
  margin-bottom: 2px;
}

.uk-founder-stat-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

.uk-founder-action {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 8px;
}

.uk-status-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.02em;
}

.uk-status-paid     { background: var(--success-50); color: var(--success-700); }
.uk-status-partial  { background: var(--warning-50); color: var(--warning-700); }
.uk-status-unpaid   { background: var(--slate-100);  color: var(--slate-600); }
.uk-status-overdue  { background: var(--error-500);  color: #fff; }

.uk-contribute-btn {
  white-space: nowrap;
}

/* ── Балансы и расчёты (2 карточки) ── */

.founders-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
}

.founder-card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
  transition: all var(--duration-fast) var(--ease-soft);
}

.founder-card:hover {
  border-color: var(--color-border-strong);
  box-shadow: var(--shadow-sm);
}

.founder-card-head {
  display: flex;
  align-items: center;
  gap: 14px;
}

.founder-avatar-lg {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--teal-100) 0%, var(--teal-300) 100%);
  color: var(--teal-900);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-weight: 700;
  font-size: 18px;
  letter-spacing: 0.02em;
  flex-shrink: 0;
  box-shadow: var(--shadow-sm);
}

.founder-card-title-block { min-width: 0; flex: 1; }

.founder-card-name {
  font-size: 17px;
  font-weight: 700;
  color: var(--color-text-primary);
  letter-spacing: -0.02em;
  margin-bottom: 4px;
}

.founder-card-meta {
  display: inline-flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 6px;
  font-size: 12px;
  color: var(--color-text-secondary);
}

.founder-card-meta .dot { opacity: 0.5; }

.founder-card-share {
  display: inline-flex;
  padding: 2px 8px;
  background: var(--teal-100);
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--teal-800);
  letter-spacing: 0.02em;
}

/* Балансовый блок */
.founder-balance-block {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 14px 16px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
}

.founder-balance-label {
  font-size: 11px;
  color: var(--color-text-tertiary);
  font-weight: 500;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

.founder-balance-value {
  font-size: 26px;
  font-weight: 700;
  line-height: 1.1;
  letter-spacing: -0.02em;
  font-variant-numeric: tabular-nums;
}

.founder-balance-cur {
  font-size: 0.55em;
  color: var(--color-text-tertiary);
  font-weight: 500;
  margin-left: 4px;
}

.founder-compensate-btn {
  align-self: flex-start;
  margin-top: 4px;
}

/* Статистика */
.founder-stats-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.founder-stat-label {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 11px;
  color: var(--color-text-tertiary);
  margin-bottom: 2px;
}

.founder-stat-value {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
}

/* Личные счета */
.founder-accounts {
  display: flex;
  flex-direction: column;
  gap: 4px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
}

.founder-account-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  font-size: 13px;
  transition: background var(--duration-fast) var(--ease-soft);
  text-decoration: none;
  color: inherit;
}

.founder-account-row:hover {
  background: var(--color-surface);
}

.founder-account-name {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  min-width: 0;
}

.founder-account-balance {
  font-weight: 600;
  color: var(--color-text-primary);
  font-variant-numeric: tabular-nums;
  white-space: nowrap;
}

.founder-account-balance.negative { color: var(--error-700); }

.founder-actions {
  display: flex;
  gap: 8px;
  padding-top: 10px;
  border-top: 1px solid var(--color-border);
}

/* ============================================================================
 * UTILS
 * ============================================================================ */

.muted      { color: var(--color-text-secondary); }
.dim        { color: var(--color-text-tertiary); }
.center     { text-align: center; }
.right      { text-align: right; }
.bold       { font-weight: 600; }
.mt-0 { margin-top: 0; }
.mt-2 { margin-top: 8px; }
.mt-4 { margin-top: 16px; }
.mt-6 { margin-top: 24px; }
.mb-2 { margin-bottom: 8px; }
.mb-4 { margin-bottom: 16px; }

.sr-only {
  position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0,0,0,0); border: 0;
}

/* ============================================================================
 * TABLET (≥ 768 px)
 * ============================================================================ */

@media (min-width: 768px) {
  body { font-size: 15px; }

  .main {
    padding: 24px;
    padding-bottom: calc(100px + env(safe-area-inset-bottom));
  }

  .menu-grid { grid-template-columns: repeat(2, 1fr); gap: 10px; }
  .kpi-grid { grid-template-columns: repeat(4, 1fr); }
  .choice-grid { grid-template-columns: repeat(2, 1fr); }

  .wizard { max-width: 600px; margin: 0 auto; }
  .wizard-step-question { font-size: 28px; }

  .report-quarters-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
  .report-table-head,
  .report-table-row { padding: 14px 20px; }

  .tax-periods-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }

  .founders-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
  .uk-founder-row { grid-template-columns: 1.5fr 1.5fr auto; align-items: center; }
  .uk-founder-action { flex-direction: row; align-items: center; gap: 10px; }
  .uk-summary { grid-template-columns: 1fr 1.3fr; gap: 32px; align-items: center; }
}

/* ============================================================================
 * DESKTOP (≥ 1024 px)
 * ============================================================================ */

@media (min-width: 1024px) {
  .app {
    grid-template-columns: 260px 1fr;
    grid-template-rows: 1fr;
    grid-template-areas: 'sidebar main';
  }

  .topbar { display: none; }
  .tabbar { display: none; }

  .sidebar {
    grid-area: sidebar;
    display: flex;
    flex-direction: column;
    background: var(--color-paper);
    border-right: 1px solid var(--color-border);
    padding: 24px 16px;
    height: 100vh;
    position: sticky;
    top: 0;
  }

  .main {
    grid-area: main;
    padding: 32px 40px;
    padding-bottom: 40px;
    max-width: none;
    overflow-y: auto;
  }

  .page-hero-title { font-size: 32px; }

  .menu-grid { grid-template-columns: repeat(3, 1fr); gap: 12px; }

  .menu-card {
    grid-template-columns: 40px 1fr;
    grid-template-rows: auto auto;
    padding: 18px 20px;
    gap: 10px 14px;
  }

  .menu-card-icon { grid-row: 1 / span 2; align-self: center; }
  .menu-card-chevron { display: none; }
  .menu-card-desc { white-space: normal; font-size: 13px; line-height: 1.4; }

  .wizard { max-width: 640px; }
  .wizard-nav { position: static; padding: 24px 0 0; background: none; }

  .choice-grid { grid-template-columns: 1fr 1fr; }

  .expense-item { padding: 14px 20px; }

  .account-card { padding: 18px 22px; }
  .account-card-name { font-size: 16px; }
  .account-card-balance { font-size: 22px; }

  .report-quarters-grid { grid-template-columns: repeat(2, 1fr); gap: 16px; }
}

/* ============================================================================
 * REFS (Справочники) — v12
 * ============================================================================ */

.refs-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 18px;
  padding: 4px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.refs-tab {
  flex: 1 1 auto;
  min-width: 0;
  padding: 8px 12px;
  border: none;
  background: transparent;
  color: var(--color-text-secondary);
  font-size: 13px;
  font-weight: 500;
  border-radius: calc(var(--radius-lg) - 4px);
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
  white-space: nowrap;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  justify-content: center;
}

.refs-tab:hover {
  color: var(--color-text-primary);
  background: var(--color-paper);
}

.refs-tab.active {
  background: var(--color-paper);
  color: var(--teal-950);
  box-shadow: 0 1px 2px rgba(0,0,0,0.04);
  font-weight: 600;
}

.refs-tab-count {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 400;
  color: var(--color-text-tertiary);
  padding: 1px 6px;
  background: var(--color-surface);
  border-radius: 999px;
}

.refs-tab.active .refs-tab-count {
  background: var(--teal-50);
  color: var(--teal-700);
}

.refs-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
  gap: 12px;
}

.refs-section-title {
  font-size: 17px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.3;
}

.refs-section-desc {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin: 2px 0 0;
  line-height: 1.4;
}

.refs-list {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}

.refs-item {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 12px 14px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  transition: all var(--duration-fast) var(--ease-soft);
  min-height: 44px;
}

.refs-item:hover {
  border-color: var(--color-border-strong);
}

.refs-item-handle {
  display: flex;
  align-items: center;
  color: var(--color-text-tertiary);
  cursor: grab;
  padding: 4px;
  border-radius: 4px;
}

.refs-item-handle:hover {
  color: var(--color-text-secondary);
  background: var(--color-surface);
}

.refs-item-handle:active {
  cursor: grabbing;
}

.refs-item-body {
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.refs-item-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.refs-item-meta {
  font-size: 12px;
  color: var(--color-text-tertiary);
  display: flex;
  align-items: center;
  gap: 6px;
}

.refs-item-meta .dot { opacity: 0.5; }

.refs-item-actions {
  display: flex;
  gap: 4px;
  opacity: 0;
  transition: opacity var(--duration-fast) var(--ease-soft);
}

.refs-item:hover .refs-item-actions,
.refs-item:focus-within .refs-item-actions,
.refs-item.touch-active .refs-item-actions {
  opacity: 1;
}

.refs-item-actions .btn-icon {
  width: 32px;
  height: 32px;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: var(--color-text-tertiary);
}

.refs-item-actions .btn-icon:hover {
  color: var(--color-text-primary);
  background: var(--color-surface);
}

.refs-item-actions .btn-icon.danger:hover {
  color: var(--error-700);
  background: var(--error-50);
}

.refs-item-editing {
  background: var(--teal-50);
  border-color: var(--teal-700);
}

.refs-item-editing .refs-item-actions { opacity: 1; }

.refs-item-input {
  width: 100%;
  padding: 6px 8px;
  border: 1px solid var(--color-border-strong);
  border-radius: 6px;
  background: var(--color-paper);
  font-size: 14px;
  font-family: inherit;
  color: var(--color-text-primary);
}

.refs-item-input:focus {
  outline: none;
  border-color: var(--teal-700);
  box-shadow: 0 0 0 3px var(--teal-50);
}

.refs-add-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  background: transparent;
  border: 1px dashed var(--color-border-strong);
  border-radius: var(--radius-md);
  color: var(--color-text-secondary);
  font-size: 14px;
  font-weight: 500;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
  width: 100%;
  justify-content: center;
}

.refs-add-btn:hover {
  border-color: var(--teal-700);
  color: var(--teal-700);
  background: var(--teal-50);
}

.refs-add-form {
  display: grid;
  grid-template-columns: 1fr auto auto;
  gap: 8px;
  align-items: center;
  padding: 10px;
  background: var(--teal-50);
  border: 1px solid var(--teal-700);
  border-radius: var(--radius-md);
  margin-bottom: 8px;
}

.refs-add-form-multi {
  grid-template-columns: 1fr;
  gap: 8px;
}

.refs-add-form-multi .refs-add-form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px;
}

.refs-add-form-multi .refs-add-form-actions {
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.refs-contractor-item {
  grid-template-columns: auto 1fr auto;
}

.refs-contractor-body {
  display: grid;
  grid-template-columns: 1fr auto;
  gap: 4px 10px;
  align-items: baseline;
  min-width: 0;
}

.refs-contractor-name {
  font-size: 14px;
  font-weight: 500;
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.refs-contractor-inn {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-text-tertiary);
  white-space: nowrap;
}

.refs-contractor-note {
  grid-column: 1 / -1;
  font-size: 12px;
  color: var(--color-text-secondary);
  line-height: 1.4;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.refs-usage-warning {
  margin-top: 10px;
  padding: 10px 12px;
  background: var(--warning-50);
  border: 1px solid var(--warning-500);
  border-radius: var(--radius-md);
  color: var(--warning-700);
  font-size: 13px;
  line-height: 1.4;
  display: flex;
  gap: 8px;
  align-items: flex-start;
}

.refs-usage-warning-icon {
  flex: 0 0 auto;
  margin-top: 1px;
}

.refs-category-block {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  margin-bottom: 12px;
  overflow: hidden;
}

.refs-category-head {
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid var(--color-border);
  background: var(--color-surface);
}

.refs-category-head-toggle {
  display: flex;
  align-items: center;
  color: var(--color-text-tertiary);
  cursor: pointer;
  padding: 4px;
  border-radius: 4px;
  transition: transform var(--duration-fast) var(--ease-soft);
}

.refs-category-block.collapsed .refs-category-head-toggle {
  transform: rotate(-90deg);
}

.refs-category-block.collapsed .refs-category-body {
  display: none;
}

.refs-category-name {
  font-size: 15px;
  font-weight: 600;
  color: var(--color-text-primary);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.refs-category-count {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-text-tertiary);
  padding: 2px 8px;
  background: var(--color-surface);
  border-radius: 999px;
  margin-left: 8px;
}

.refs-category-body {
  padding: 10px 12px;
}

.refs-category-actions {
  display: flex;
  gap: 4px;
  opacity: 0.7;
}

.refs-category-actions .btn-icon {
  width: 30px;
  height: 30px;
  background: transparent;
  border: none;
  border-radius: 6px;
  color: var(--color-text-tertiary);
}

.refs-category-actions .btn-icon:hover {
  color: var(--color-text-primary);
  background: var(--color-paper);
}

.refs-category-actions .btn-icon.danger:hover {
  color: var(--error-700);
  background: var(--error-50);
}

.refs-help-banner {
  background: var(--teal-50);
  border: 1px solid var(--teal-700);
  border-left-width: 3px;
  border-radius: var(--radius-md);
  padding: 12px 14px;
  margin-bottom: 16px;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: var(--teal-950);
}

.refs-help-banner-icon {
  flex: 0 0 auto;
  margin-top: 1px;
  color: var(--teal-700);
}

.refs-help-banner-body {
  font-size: 13px;
  line-height: 1.45;
}

.refs-help-banner-title {
  font-weight: 600;
  margin-bottom: 2px;
}

@media (max-width: 720px) {
  .refs-tabs { overflow-x: auto; flex-wrap: nowrap; }
  .refs-tab { flex: 0 0 auto; }
  .refs-item-actions { opacity: 1; }
  .refs-category-actions { opacity: 1; }
  .refs-add-form { grid-template-columns: 1fr; }
  .refs-add-form .btn { width: 100%; }
}

/* ============================================================================
 * 💱 Rates (v13)
 * ============================================================================ */

.rates-action-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.rates-fetch-btn {
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.rates-action-hint {
  font-size: 12px;
  color: var(--color-text-secondary);
}

.rates-action-hint a {
  color: var(--teal-700);
  border-bottom: 1px dotted var(--teal-400);
}

.rates-action-hint a:hover {
  color: var(--teal-900);
  border-bottom-color: var(--teal-700);
}

.rates-card {
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  margin-bottom: 24px;
}

.rates-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 8px 4px 12px;
  color: var(--color-text-primary);
}

.rates-section-header h3 {
  margin: 0;
  font-size: 15px;
  font-weight: 600;
  letter-spacing: -0.01em;
}

.rates-section-hint {
  margin-left: auto;
  font-size: 12px;
  font-weight: 400;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
}

.rates-table {
  display: flex;
  flex-direction: column;
}

.rates-row {
  display: grid;
  grid-template-columns: minmax(180px, 1.6fr) minmax(120px, 1fr) minmax(140px, 1fr) minmax(140px, 1.2fr);
  gap: 12px;
  padding: 12px 14px;
  align-items: center;
  border-bottom: 1px solid var(--color-border);
}

.rates-row:last-child {
  border-bottom: none;
}

.rates-row-head {
  font-size: 12px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--color-text-tertiary);
  background: var(--color-surface);
}

.rates-col-symbol {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 0;
}

.rates-symbol-badge {
  flex: 0 0 auto;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  background: var(--teal-50);
  color: var(--teal-800);
  font-weight: 600;
  font-size: 16px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-display);
}

.rates-symbol-badge-sm {
  width: 24px;
  height: 24px;
  font-size: 13px;
  border-radius: 6px;
}

.rates-name {
  font-size: 14px;
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rates-col-rate {
  text-align: right;
  font-family: var(--font-mono);
}

.rates-rate-value {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-mono);
  font-size: 15px;
  font-weight: 500;
  color: var(--color-text-primary);
  padding: 4px 8px;
  border-radius: var(--radius-sm);
}

.rates-rate-base {
  color: var(--color-text-tertiary);
  font-weight: 400;
}

.rates-rate-editable {
  background: transparent;
  border: 1px dashed transparent;
  cursor: pointer;
  transition: all var(--duration-fast) var(--ease-soft);
}

.rates-rate-editable:hover {
  background: var(--teal-50);
  border-color: var(--teal-300);
  color: var(--teal-900);
}

.rates-rate-edit-icon {
  opacity: 0;
  color: var(--teal-700);
  transition: opacity var(--duration-fast) var(--ease-soft);
}

.rates-rate-editable:hover .rates-rate-edit-icon {
  opacity: 1;
}

.rates-rate-editor {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  justify-content: flex-end;
}

.rates-rate-input {
  width: 110px;
  padding: 6px 8px;
  font-family: var(--font-mono);
  font-size: 14px;
  text-align: right;
  border: 1.5px solid var(--teal-500);
  border-radius: var(--radius-sm);
  background: var(--color-paper);
  color: var(--color-text-primary);
  outline: none;
}

.rates-rate-input:focus {
  box-shadow: var(--shadow-focus);
}

.rates-col-updated,
.rates-col-source {
  font-size: 13px;
  color: var(--color-text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── История ── */

.rates-history-table .rates-row {
  grid-template-columns: minmax(120px, 0.9fr) minmax(160px, 1.4fr) minmax(160px, 1.4fr) minmax(140px, 1.2fr);
}

.rates-hist-row:hover {
  background: var(--color-surface);
}

.rates-hist-date {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--color-text-secondary);
}

.rates-hist-currency {
  display: flex;
  align-items: center;
  gap: 8px;
  min-width: 0;
}

.rates-hist-currency-name {
  font-size: 13px;
  color: var(--color-text-primary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.rates-hist-change {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: var(--font-mono);
  font-size: 13px;
}

.rates-hist-old {
  color: var(--color-text-tertiary);
  text-decoration: line-through;
  text-decoration-color: var(--color-text-tertiary);
}

.rates-hist-new {
  color: var(--color-text-primary);
  font-weight: 500;
}

.rates-hist-arrow {
  font-weight: 600;
  font-size: 14px;
}

.rates-delta-up   { color: var(--success-700); }
.rates-delta-down { color: var(--error-700); }
.rates-delta-zero { color: var(--color-text-tertiary); }

.rates-hist-source {
  font-size: 12px;
  color: var(--color-text-secondary);
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Mobile ── */

@media (max-width: 720px) {
  .rates-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
    row-gap: 4px;
  }
  .rates-col-symbol {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
  }
  .rates-col-rate {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    text-align: right;
  }
  .rates-col-updated {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
    font-size: 11px;
    color: var(--color-text-tertiary);
  }
  .rates-col-source {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    text-align: right;
    font-size: 11px;
    color: var(--color-text-tertiary);
  }
  .rates-row-head { display: none; }

  .rates-history-table .rates-row {
    grid-template-columns: 1fr auto;
    grid-template-rows: auto auto;
  }
  .rates-hist-date {
    grid-column: 1 / 2;
    grid-row: 1 / 2;
  }
  .rates-hist-currency {
    grid-column: 1 / 2;
    grid-row: 2 / 3;
  }
  .rates-hist-change {
    grid-column: 2 / 3;
    grid-row: 1 / 2;
    justify-content: flex-end;
  }
  .rates-hist-source {
    grid-column: 2 / 3;
    grid-row: 2 / 3;
    text-align: right;
  }

  .rates-action-bar { flex-direction: column; align-items: stretch; }
  .rates-fetch-btn { width: 100%; justify-content: center; }
}

/* ============================================================================
 * 📖 HELP (v14) — страница «Инструкция»
 * ============================================================================ */

.help-page {
  /* Чтобы последняя секция могла оказаться под sticky TOC при scroll-spy */
  padding-bottom: 40px;
}

/* ── Оглавление (sticky) ─────────────────────────────────────────── */

.help-toc {
  position: sticky;
  /* На desktop topbar скрыт → top: 0 (прилипает к верху .main).
     На mobile topbar sticky 56px + safe-area → сдвигаем TOC ниже (см. media-query). */
  top: 0;
  z-index: var(--z-sticky);
  margin: -8px -4px 20px;
  padding: 10px 4px;
  background: var(--color-paper);
  backdrop-filter: saturate(1.2);
  border-bottom: 1px solid var(--color-border);
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  overflow-x: auto;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.help-toc::-webkit-scrollbar { display: none; }

.help-toc-item {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  flex: 0 0 auto;
  padding: 7px 12px;
  background: var(--color-surface);
  color: var(--color-text-secondary);
  font-size: 13px;
  font-weight: 500;
  border-radius: 999px;
  border: 1px solid transparent;
  white-space: nowrap;
  transition:
    color var(--duration-fast) var(--ease-soft),
    background var(--duration-fast) var(--ease-soft),
    border-color var(--duration-fast) var(--ease-soft);
  cursor: pointer;
}
.help-toc-item:hover {
  color: var(--color-text-primary);
  background: var(--teal-50);
}
.help-toc-item.active {
  color: var(--teal-950);
  background: var(--teal-100);
  border-color: var(--teal-300);
  font-weight: 600;
}

.help-toc-icon {
  display: inline-flex;
  opacity: 0.75;
}
.help-toc-item.active .help-toc-icon { opacity: 1; color: var(--teal-700); }

.help-toc-label {
  /* Лейбл чипа в TOC — наследует font-* от родителя */
  line-height: 1;
}

/* ── Основной контейнер секций ──────────────────────────────────── */

.help-main {
  display: flex;
  flex-direction: column;
  gap: 36px;
}

.help-section {
  scroll-margin-top: 120px; /* запас под topbar + TOC */
}

.help-section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--color-border);
}

.help-section-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--teal-700);
  flex: 0 0 auto;
}

.help-section-title {
  font-size: 20px;
  font-weight: 700;
  letter-spacing: -0.01em;
  color: var(--color-text-primary);
  margin: 0;
  line-height: 1.2;
}

.help-section-body {
  /* Равномерный ритм внутри секции */
}

/* ── Проза (короткие пояснения) ──────────────────────────────────── */

.help-prose {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--color-text-primary);
}
.help-prose p { margin: 0 0 12px; }
.help-prose p:last-child { margin-bottom: 0; }

.help-prose-intro {
  font-size: 14.5px;
  line-height: 1.6;
  color: var(--color-text-secondary);
  margin: 0 0 16px;
}

.help-list {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.help-list li {
  position: relative;
  padding-left: 22px;
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--color-text-primary);
}
.help-list li::before {
  content: "";
  position: absolute;
  left: 6px;
  top: 10px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--teal-500);
}

.help-inline-link {
  color: var(--teal-700);
  border-bottom: 1px solid var(--teal-300);
  transition: color var(--duration-fast) var(--ease-soft), border-color var(--duration-fast) var(--ease-soft);
}
.help-inline-link:hover {
  color: var(--teal-800);
  border-bottom-color: var(--teal-500);
}

.help-mono {
  font-family: var(--font-mono);
  font-size: 0.92em;
  padding: 1px 6px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xs);
  color: var(--teal-900);
  white-space: nowrap;
}

.help-chip {
  display: inline-flex;
  align-items: center;
  padding: 2px 10px;
  background: var(--teal-600);
  color: #fff;
  border-radius: 999px;
  font-size: 0.92em;
  font-weight: 500;
  white-space: nowrap;
}

.help-chip-inline {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  background: var(--color-surface);
  color: var(--teal-900);
  border: 1px solid var(--color-border);
  border-radius: 999px;
  font-size: 0.92em;
  font-weight: 500;
  white-space: nowrap;
}

.help-prose kbd,
.help-section-body kbd {
  display: inline-block;
  padding: 1px 6px;
  font-family: var(--font-mono);
  font-size: 0.85em;
  background: var(--slate-100);
  border: 1px solid var(--color-border-strong);
  border-bottom-width: 2px;
  border-radius: var(--radius-xs);
  color: var(--slate-700);
  white-space: nowrap;
}

/* ── Принципы / автоматизация — двухколоночная сетка карточек ───── */

.help-principles-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 10px;
}

.help-principle-card {
  display: flex;
  gap: 12px;
  padding: 14px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  transition: border-color var(--duration-fast) var(--ease-soft), box-shadow var(--duration-fast) var(--ease-soft);
}
.help-principle-card:hover {
  border-color: var(--teal-300);
  box-shadow: var(--shadow-sm);
}

.help-principle-icon {
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  border-radius: var(--radius-md);
  background: var(--color-surface);
  color: var(--teal-700);
  display: inline-flex;
  align-items: center;
  justify-content: center;
}

.help-principle-body { min-width: 0; }

.help-principle-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 4px;
  line-height: 1.3;
}

.help-principle-text {
  font-size: 13px;
  line-height: 1.5;
  color: var(--color-text-secondary);
}

/* ── Разделы приложения — переиспользуем menu-grid, добавляя заголовки групп ── */

.help-sections-group-title {
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--color-text-tertiary);
  font-family: var(--font-mono);
  margin: 20px 4px 8px;
}
.help-sections-group-title:first-child { margin-top: 8px; }

/* ── Шаги (нумерованный список с крупными номерами) ─────────────── */

.help-steps {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.help-step {
  display: flex;
  gap: 12px;
  padding: 14px 14px 14px 12px;
  background: var(--color-paper);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
}

.help-step-number {
  flex: 0 0 auto;
  width: 28px;
  height: 28px;
  border-radius: 999px;
  background: var(--teal-600);
  color: #fff;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 13px;
}

.help-step-body { min-width: 0; flex: 1 1 auto; }

.help-step-title {
  font-size: 14.5px;
  font-weight: 600;
  color: var(--color-text-primary);
  margin-bottom: 3px;
  line-height: 1.3;
}

.help-step-text {
  font-size: 13.5px;
  line-height: 1.55;
  color: var(--color-text-secondary);
}

/* ── CTA под шагами ──────────────────────────────────────────────── */

.help-cta {
  margin-top: 16px;
  padding: 14px;
  background: var(--color-surface);
  border: 1px dashed var(--teal-300);
  border-radius: var(--radius-lg);
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.help-cta-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  white-space: nowrap;
}

.help-cta-hint {
  font-size: 12.5px;
  color: var(--color-text-secondary);
  flex: 1 1 auto;
  min-width: 0;
}

/* ── Info-banner (для УК) ────────────────────────────────────────── */

.help-banner {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 12px 14px;
  border-radius: var(--radius-md);
  margin-bottom: 16px;
  font-size: 13.5px;
  line-height: 1.5;
}
.help-banner-icon { flex: 0 0 auto; margin-top: 1px; }
.help-banner-body { min-width: 0; }

.help-banner-info {
  background: var(--teal-50);
  border: 1px solid var(--teal-700);
  border-left-width: 3px;
  color: var(--teal-950);
}
.help-banner-info .help-banner-icon { color: var(--teal-700); }

/* ── Дерево папок Drive ──────────────────────────────────────────── */

.help-tree {
  font-family: var(--font-mono);
  font-size: 12.5px;
  line-height: 1.7;
  padding: 14px 16px;
  background: var(--slate-50);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-lg);
  color: var(--slate-700);
  overflow-x: auto;
  white-space: pre;
  margin: 0;
}

/* ── Чего не делать ──────────────────────────────────────────────── */

.help-donts {
  list-style: none;
  padding: 0;
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.help-dont {
  display: flex;
  gap: 12px;
  padding: 12px 14px;
  background: var(--error-50);
  border: 1px solid rgba(244, 63, 94, 0.25);
  border-left: 3px solid var(--error-500);
  border-radius: var(--radius-md);
}

.help-dont-icon {
  flex: 0 0 auto;
  color: var(--error-700);
  margin-top: 1px;
}

.help-dont-body { min-width: 0; }

.help-dont-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--error-700);
  margin-bottom: 2px;
  line-height: 1.3;
}

.help-dont-text {
  font-size: 13px;
  line-height: 1.5;
  color: var(--slate-700);
}

/* ── Заметка под автоматизацией ──────────────────────────────────── */

.help-note {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 14px;
  padding: 10px 12px;
  background: var(--color-surface);
  border-radius: var(--radius-md);
  font-size: 12.5px;
  color: var(--color-text-secondary);
}
.help-note svg { color: var(--teal-700); flex: 0 0 auto; }

/* ── Footer ─────────────────────────────────────────────────────── */

.help-footer {
  margin-top: 8px;
  padding: 24px 20px;
  background: var(--color-surface);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-xl);
  text-align: center;
}

.help-footer-title {
  font-size: 24px;
  letter-spacing: 0.08em;
  color: var(--teal-700);
  margin-bottom: 4px;
}

.help-footer-sub {
  font-size: 13px;
  color: var(--color-text-secondary);
  margin-bottom: 16px;
  line-height: 1.5;
}

.help-footer-actions {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
}
.help-footer-actions .btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
}

/* ── Mobile adaptations ──────────────────────────────────────────── */

/* На mobile и tablet (< 1024px) есть sticky topbar — TOC должен прилипать под ним */
@media (max-width: 1023px) {
  .help-toc {
    top: calc(56px + env(safe-area-inset-top));
  }
}

@media (max-width: 720px) {
  .help-toc {
    margin-left: -16px;
    margin-right: -16px;
    padding-left: 16px;
    padding-right: 16px;
    flex-wrap: nowrap;
    border-radius: 0;
  }

  .help-principles-grid {
    grid-template-columns: 1fr;
  }

  .help-section-title { font-size: 18px; }

  .help-footer { padding: 20px 16px; }
  .help-footer-title { font-size: 20px; }
  .help-footer-actions .btn { flex: 1 1 auto; justify-content: center; }

  .help-cta-hint { flex: 1 1 100%; order: 2; }
  .help-cta-btn { order: 1; }
}

/* ============================================================================
 * PRINT
 * ============================================================================ */

@media print {
  .topbar, .tabbar, .sidebar, .wizard-nav, .filter-bar { display: none !important; }
  .main { padding: 0; max-width: none; }
  .help-toc, .report-toolbar, .report-switcher { display: none !important; }
  .card, .kpi, table, .chart, .report-row { break-inside: avoid; page-break-inside: avoid; }
  .page-hero { margin-bottom: 8mm; }
  body { font-size: 11pt; color: #000; background: #fff; }
  a { color: #000; text-decoration: none; }
}
