/* Booking — Design Tokens (F4.W4)
 *
 * Канон: Stripe Sigma color scale, Linear --space-* scale, Tailwind shadow tokens.
 * Используются в calendar-v2/* и впоследствии расширятся на admin SPA + public page +
 * widget (W6 brand override через --brand-primary/--brand-accent CSS vars инъекцию).
 */

:root {
  /* — Color (semantic) ────────────────────────────────────── */
  --color-bg:           #ffffff;
  --color-bg-muted:     #f7f8fa;
  --color-bg-subtle:    #f0f2f5;
  --color-bg-hover:     #eef0f4;
  --color-border:       #e1e4ea;
  --color-border-strong:#c2c8d2;
  --color-text:         #1a1d23;
  --color-text-muted:   #6b7280;
  --color-text-subtle:  #9ca3af;
  --color-text-inverse: #ffffff;

  /* F580.W4 — drawer overlay (scrim под карточкой брони) + danger (текст ошибки).
     Theme-aware: dark-блоки ниже переопределяют. Используются drawer-shared.css /
     PackageDrawer.css без hex-fallback (premium-ui-style.md dark-theme правило). */
  --color-overlay:      rgba(15, 23, 42, 0.28);
  --color-danger:       #dc2626;

  /* F632.W5 — info-контейнер (B24 deal-link и подобные info-поверхности карточки брони).
     Theme-aware: светлый голубой в light, blue-tint поверх тёмного фона в dark (БЕЗ
     light-hex fallback — premium-ui-style.md dark-theme правило). */
  --color-info-bg:       #eff6ff;
  --color-info-border:   #bfdbfe;

  /* Status semantic (reservation status mapping) */
  --color-status-pending:    #f59e0b;  /* amber */
  --color-status-confirmed:  #10b981;  /* emerald */
  --color-status-checked-in: #3b82f6;  /* blue */
  --color-status-checked-out:#6b7280;  /* gray */
  --color-status-cancelled:  #ef4444;  /* red */
  --color-status-no-show:    #a855f7;  /* purple */

  /* F66 — Payment status semantic */
  --color-payment-not-paid:     #94a3b8;  /* slate-400 — нейтрально */
  --color-payment-deposit-paid: #3b82f6;  /* blue — задаток внесён */
  --color-payment-paid-in-full: #10b981;  /* emerald — оплачено полностью */

  /* F632.W5 — каналы происхождения брони (source-бейдж). Фиксированные насыщенные
     цвета канала (как --color-status-* — НЕ переопределяются по теме, белый текст
     читаем в обеих темах). */
  --color-source-telegram: #2ba5e0;  /* Telegram brand blue */
  --color-source-ota:      #475569;  /* slate — generic внешний блок (iCal/OTA) */

  /* Brand (F522 — цветовые РОЛИ, не один цвет. Канон Cal.com/Stripe/Linear.
     applyBranding пишет базовые --brand-primary/--brand-accent/--brand-cta из
     tenant.{primary,accent,cta}_color; hover/soft/deep деривируются через
     color-mix → следуют за брендом без JS. Смена бренда каскадирует всюду. */

  /* Роль 1 — основные действия */
  --brand-primary:       #2563eb;
  --brand-primary-hover: color-mix(in srgb, var(--brand-primary) 85%, #000);
  --brand-primary-soft:  color-mix(in srgb, var(--brand-primary) 42%, #fff);

  /* Роль 2 — вторичный/группы/AI/дерево (F522.W7 — свёрнут индиго #6366f1;
     tenant override через accent_color → перекрашивает всю вторичную семью). */
  --brand-accent:        #6366f1;
  --brand-accent-hover:  color-mix(in srgb, var(--brand-accent) 80%, #000);
  --brand-accent-deep:   color-mix(in srgb, var(--brand-accent) 66%, #000);
  --brand-accent-soft:   color-mix(in srgb, var(--brand-accent) 12%, #fff);

  /* Роль 3 — CTA продажа/покупка/оплата (F522.W7). Default наследует primary;
     tenant override через cta_color → выделяет sale/pay-кнопки отдельным цветом. */
  --brand-cta:           var(--brand-primary);
  --brand-on-cta:        #ffffff;

  /* — Spacing scale (4px base) ────────────────────────────── */
  --space-0:  0;
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;

  /* — Radius ──────────────────────────────────────────────── */
  --radius-sm: 4px;
  --radius-md: 6px;
  --radius-lg: 10px;
  --radius-xl: 16px;
  --radius-full: 9999px;

  /* — Shadow (Tailwind elevation scale) ───────────────────── */
  --shadow-sm:    0 1px 2px 0 rgba(0,0,0,.05);
  --shadow-md:    0 4px 6px -1px rgba(0,0,0,.10), 0 2px 4px -1px rgba(0,0,0,.06);
  --shadow-lg:    0 10px 15px -3px rgba(0,0,0,.10), 0 4px 6px -2px rgba(0,0,0,.05);
  /* F632.W7 — карточка брони. Многослойные ТОНИРОВАННЫЕ тени (slate hue поверхности
     вместо pure-black blur — design-excellence.md §3, канон Stripe). Один источник
     света. --shadow-drawer: левый край right-anchored drawer (hairline + мягкая глубина).
     --shadow-pop: малая hover-/overlay-элевация внутри карточки (2 слоя). */
  --shadow-drawer: -1px 0 0 0 rgba(15,23,42,.05),
                   -10px 0 24px -8px rgba(15,23,42,.18),
                   -3px 0 8px -5px rgba(50,50,93,.10);
  --shadow-pop:    0 2px 4px -1px rgba(15,23,42,.10),
                   0 8px 18px -6px rgba(15,23,42,.16);

  /* — Typography ──────────────────────────────────────────── */
  /* F523.W1 — Inter первым (self-hosted @font-face в p/fonts.css). Premium-канон
     Linear/Cal.com/Vercel. System-stack — fallback до загрузки woff2 (font-display:swap). */
  --font-sans: 'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto,
               "Helvetica Neue", Arial, sans-serif;
  --font-mono: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;

  --text-xs:   12px;
  --text-sm:   13px;
  --text-base: 14px;
  --text-md:   15px;
  --text-lg:   17px;
  --text-xl:   20px;
  --text-2xl:  24px;

  --leading-tight: 1.25;
  --leading-base:  1.5;

  /* F632.W7 — letter-spacing (трекинг). Канон Geist/design-excellence §5:
     отрицательный на крупном тексте, положительный «caps» только для
     uppercase-микролейблов секций. */
  --tracking-tight: -0.01em;  /* заголовки 17–24px */
  --tracking-caps:   0.04em;  /* uppercase section-title 12–13px */

  --font-normal:   400;
  --font-medium:   500;
  --font-semibold: 600;
  --font-bold:     700;

  /* — Animation ───────────────────────────────────────────── */
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-decelerate: cubic-bezier(0, 0, 0.2, 1);
  --dur-fast:    150ms;
  --dur-normal:  250ms;
  --dur-slow:    400ms;

  /* F632.W7 — единое кольцо фокуса (:focus-visible). Тонированное brand-primary,
     контраст ≥3:1 к соседнему (WCAG 2.2 SC 2.4.11). Заменяет браузерный outline.
     color-mix → следует за бренд-цветом тенанта (как brand-primary-hover). */
  --focus-ring: 0 0 0 3px color-mix(in srgb, var(--brand-primary) 32%, transparent);

  /* — Z-index layering ────────────────────────────────────── */
  --z-content:  1;
  --z-overlay:  100;
  --z-drawer:   200;
  --z-modal:    300;
  --z-toast:    400;
  /* F612.W10.1 — оверлей «Добавить ресурс» должен быть ПОВЕРХ drawer (drawer-shared.css
     z-index:1200), иначе модалка рендерится под карточкой («в тёмном месте»). */
  --z-promote:  1400;
}

/* — Dark mode (auto via prefers-color-scheme; W6 явный toggle через [data-theme=dark]) — */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --color-bg:           #0f1115;
    --color-bg-muted:     #16191f;
    --color-bg-subtle:    #1d2128;
    --color-bg-hover:     #252a33;
    --color-border:       #2a2f38;
    --color-border-strong:#3a414c;
    --color-text:         #e5e7eb;
    --color-text-muted:   #9ca3af;
    --color-text-subtle:  #6b7280;
    --color-text-inverse: #0f1115;
    --color-overlay:      rgba(0, 0, 0, 0.6);
    --color-danger:       #f87171;
    --color-info-bg:      rgba(59, 130, 246, 0.12);
    --color-info-border:  rgba(59, 130, 246, 0.32);
  }
}

[data-theme="dark"] {
  --color-bg:           #0f1115;
  --color-bg-muted:     #16191f;
  --color-bg-subtle:    #1d2128;
  --color-bg-hover:     #252a33;
  --color-border:       #2a2f38;
  --color-border-strong:#3a414c;
  --color-text:         #e5e7eb;
  --color-text-muted:   #9ca3af;
  --color-text-subtle:  #6b7280;
  --color-text-inverse: #0f1115;
  --color-overlay:      rgba(0, 0, 0, 0.6);
  --color-danger:       #f87171;
  --color-info-bg:      rgba(59, 130, 246, 0.12);
  --color-info-border:  rgba(59, 130, 246, 0.32);
}

/* — Utility примитивы (минимальный набор для calendar-v2) — */
.tk-card {
  background: var(--color-bg);
  border: 1px solid var(--color-border);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-sm);
}
.tk-text-muted { color: var(--color-text-muted); }
.tk-text-subtle { color: var(--color-text-subtle); }
.tk-text-xs { font-size: var(--text-xs); }
.tk-text-sm { font-size: var(--text-sm); }
.tk-flex { display: flex; }
.tk-flex-center { display: flex; align-items: center; justify-content: center; }
.tk-gap-1 { gap: var(--space-1); }
.tk-gap-2 { gap: var(--space-2); }
.tk-gap-3 { gap: var(--space-3); }
.tk-gap-4 { gap: var(--space-4); }
