/* ============================================================================
   KIPS PDF — Enterprise Design System
   Single source of truth for design tokens, responsive engine, and primitives.
   Loaded on every page. ~9KB, zero dependencies, GPU-friendly.
   ----------------------------------------------------------------------------
   Architecture notes:
   - Tokens are CSS custom properties so themes/brands can be swapped at runtime.
   - Responsive uses fluid clamp() typography + container-aware spacing.
   - Honors prefers-reduced-motion, prefers-color-scheme, forced-colors.
   - data-perf="low|balanced|ultra" downgrades effects on weak devices.
   ========================================================================== */

/* ----------------------------------------------------------------------------
   1. DESIGN TOKENS
   -------------------------------------------------------------------------- */
:root {
  color-scheme: dark light;

  /* Brand */
  --kips-brand-400: #38bdf8;
  --kips-brand-500: #0ea5e9;
  --kips-brand-600: #0284c7;
  --kips-accent-400: #818cf8;
  --kips-accent-500: #6366f1;
  --kips-success: #22c55e;
  --kips-warning: #f59e0b;
  --kips-danger: #ef4444;

  /* Surfaces (dark default) */
  --kips-bg: #020617;
  --kips-bg-grad-top: #0f172a;
  --kips-surface-1: #0f172a;
  --kips-surface-2: #111b2e;
  --kips-surface-3: #1e293b;
  --kips-border: rgba(255, 255, 255, 0.08);
  --kips-border-strong: rgba(255, 255, 255, 0.14);

  /* Text */
  --kips-text: #f1f5f9;
  --kips-text-muted: #94a3b8;
  --kips-text-faint: #64748b;

  /* Gradients */
  --kips-grad-brand: linear-gradient(135deg, var(--kips-brand-400), var(--kips-accent-400));
  --kips-grad-surface: linear-gradient(145deg, #111b2e, #060b18);

  /* Radii */
  --kips-r-sm: 10px;
  --kips-r-md: 16px;
  --kips-r-lg: 22px;
  --kips-r-xl: 28px;
  --kips-r-pill: 999px;

  /* Shadows */
  --kips-shadow-sm: 0 2px 8px rgba(0, 0, 0, 0.3);
  --kips-shadow-md: 0 12px 32px rgba(0, 0, 0, 0.45);
  --kips-shadow-lg: 0 24px 60px rgba(0, 0, 0, 0.6);
  --kips-glow: 0 0 24px rgba(56, 189, 248, 0.35);

  /* Fluid spacing scale (responsive engine) */
  --kips-space-1: clamp(4px, 0.5vw, 6px);
  --kips-space-2: clamp(8px, 1vw, 12px);
  --kips-space-3: clamp(12px, 1.6vw, 18px);
  --kips-space-4: clamp(16px, 2.4vw, 28px);
  --kips-space-5: clamp(24px, 4vw, 48px);
  --kips-space-6: clamp(40px, 7vw, 96px);

  /* Fluid typography */
  --kips-font: 'Segoe UI', system-ui, -apple-system, Roboto, 'Helvetica Neue', Arial, sans-serif;
  --kips-fs-xs: clamp(11px, 1.4vw, 12px);
  --kips-fs-sm: clamp(13px, 1.6vw, 14px);
  --kips-fs-md: clamp(15px, 1.8vw, 16px);
  --kips-fs-lg: clamp(18px, 2.4vw, 22px);
  --kips-fs-xl: clamp(24px, 4vw, 34px);
  --kips-fs-2xl: clamp(32px, 7vw, 64px);

  /* Motion */
  --kips-ease-spring: cubic-bezier(0.175, 0.885, 0.32, 1.275);
  --kips-ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --kips-dur-fast: 0.18s;
  --kips-dur: 0.32s;
  --kips-dur-slow: 0.6s;

  /* Layout */
  --kips-container: 1180px;
  --kips-header-h: 64px;
  --kips-safe-top: env(safe-area-inset-top, 0px);
  --kips-safe-bottom: env(safe-area-inset-bottom, 0px);

  --kips-z-header: 900;
  --kips-z-overlay: 1000;
  --kips-z-toast: 1100;
}

/* Light theme — applied when user/system selects light */
[data-theme="light"] {
  color-scheme: light;
  --kips-bg: #f1f5f9;
  --kips-bg-grad-top: #ffffff;
  --kips-surface-1: #ffffff;
  --kips-surface-2: #f8fafc;
  --kips-surface-3: #e2e8f0;
  --kips-border: rgba(2, 6, 23, 0.10);
  --kips-border-strong: rgba(2, 6, 23, 0.16);
  --kips-text: #0f172a;
  --kips-text-muted: #475569;
  --kips-text-faint: #94a3b8;
  --kips-grad-surface: linear-gradient(145deg, #ffffff, #eef2f7);
  --kips-shadow-md: 0 12px 32px rgba(15, 23, 42, 0.12);
  --kips-shadow-lg: 0 24px 60px rgba(15, 23, 42, 0.16);
}

/* ----------------------------------------------------------------------------
   2. RESET & BASE
   -------------------------------------------------------------------------- */
*, *::before, *::after { box-sizing: border-box; }
* { margin: 0; padding: 0; }

html { -webkit-text-size-adjust: 100%; text-size-adjust: 100%; scroll-behavior: smooth; }

body.kips {
  font-family: var(--kips-font);
  font-size: var(--kips-fs-md);
  line-height: 1.6;
  color: var(--kips-text);
  background-color: var(--kips-bg);
  background-image: radial-gradient(circle at top, var(--kips-bg-grad-top), var(--kips-bg));
  background-attachment: fixed;
  min-height: 100%;
  overflow-x: hidden;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  padding-top: var(--kips-safe-top);
  padding-bottom: var(--kips-safe-bottom);
}

/* Element defaults are scoped to .kips so the design system can be safely
   loaded alongside legacy tool pages without altering their canvas/links. */
.kips img, .kips svg, .kips canvas { max-width: 100%; }
.kips img { display: block; }
.kips a { color: var(--kips-brand-400); text-decoration: none; }
.kips a:hover { text-decoration: underline; }

:focus-visible {
  outline: 3px solid var(--kips-brand-400);
  outline-offset: 2px;
  border-radius: 4px;
}

/* Accessible skip link */
.kips-skip {
  position: absolute;
  left: -9999px;
  top: 0;
  background: var(--kips-brand-500);
  color: #001018;
  padding: 10px 16px;
  border-radius: 0 0 var(--kips-r-sm) 0;
  font-weight: 800;
  z-index: var(--kips-z-toast);
}
.kips-skip:focus { left: 0; }

/* ----------------------------------------------------------------------------
   3. LAYOUT PRIMITIVES
   -------------------------------------------------------------------------- */
.kips-container {
  width: 100%;
  max-width: var(--kips-container);
  margin-inline: auto;
  padding-inline: var(--kips-space-4);
}

.kips-stack { display: flex; flex-direction: column; gap: var(--kips-space-3); }
.kips-row { display: flex; align-items: center; gap: var(--kips-space-2); flex-wrap: wrap; }
.kips-spacer { flex: 1 1 auto; }

.kips-grid {
  display: grid;
  gap: var(--kips-space-3);
  grid-template-columns: repeat(auto-fit, minmax(min(100%, 200px), 1fr));
}

/* ----------------------------------------------------------------------------
   4. APP HEADER (glassmorphism, sticky, responsive)
   -------------------------------------------------------------------------- */
.kips-header {
  position: sticky;
  top: 0;
  z-index: var(--kips-z-header);
  height: var(--kips-header-h);
  display: flex;
  align-items: center;
  gap: var(--kips-space-3);
  padding-inline: var(--kips-space-4);
  background: color-mix(in srgb, var(--kips-surface-1) 72%, transparent);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--kips-border);
}
.kips-header__brand { display: flex; align-items: center; gap: 10px; font-weight: 800; }
.kips-header__brand img { height: 30px; width: auto; }
.kips-header__nav { display: flex; gap: var(--kips-space-3); margin-left: auto; align-items: center; }
.kips-header__nav a { color: var(--kips-text-muted); font-weight: 600; font-size: var(--kips-fs-sm); }
.kips-header__nav a:hover { color: var(--kips-text); text-decoration: none; }
@media (max-width: 720px) {
  .kips-header__nav a:not(.kips-header__cta) { display: none; }
}

/* ----------------------------------------------------------------------------
   5. BUTTONS
   -------------------------------------------------------------------------- */
.kips-btn {
  --bg: var(--kips-surface-3);
  --fg: var(--kips-text);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 12px 20px;
  border: 1px solid var(--kips-border-strong);
  border-radius: var(--kips-r-sm);
  background: var(--bg);
  color: var(--fg);
  font: inherit;
  font-weight: 700;
  cursor: pointer;
  text-decoration: none;
  transition: transform var(--kips-dur-fast) var(--kips-ease-out),
              box-shadow var(--kips-dur-fast) var(--kips-ease-out),
              filter var(--kips-dur-fast) var(--kips-ease-out);
  will-change: transform;
}
.kips-btn:hover { transform: translateY(-2px); text-decoration: none; }
.kips-btn:active { transform: translateY(0); }
.kips-btn--primary {
  --bg: var(--kips-grad-brand);
  --fg: #021018;
  border-color: transparent;
  font-weight: 800;
  letter-spacing: 0.01em;
  box-shadow: 0 8px 22px rgba(14, 165, 233, 0.45), var(--kips-glow);
}
.kips-btn--primary:hover {
  filter: brightness(1.06) saturate(1.1);
  box-shadow: 0 12px 30px rgba(14, 165, 233, 0.6), var(--kips-glow);
}
/* Subtle attention pulse so the main call-to-action clearly stands out.
   Disabled on low-end devices and when reduced motion is requested. */
.kips-btn--primary.kips-btn--pulse {
  position: relative;
  animation: kips-cta-pulse 2.8s var(--kips-ease-out) infinite;
}
@keyframes kips-cta-pulse {
  0%, 100% { box-shadow: 0 8px 22px rgba(14, 165, 233, 0.45), 0 0 0 0 rgba(56, 189, 248, 0.5); }
  50%      { box-shadow: 0 10px 28px rgba(14, 165, 233, 0.55), 0 0 0 10px rgba(56, 189, 248, 0); }
}
[data-perf="low"] .kips-btn--primary.kips-btn--pulse { animation: none; }
@media (prefers-reduced-motion: reduce) { .kips-btn--primary.kips-btn--pulse { animation: none; } }
.kips-btn--ghost { --bg: transparent; }
.kips-btn--lg { padding: 16px 28px; font-size: var(--kips-fs-md); border-radius: var(--kips-r-md); }

/* ----------------------------------------------------------------------------
   6. CARDS / SURFACES
   -------------------------------------------------------------------------- */
.kips-surface {
  background: var(--kips-grad-surface);
  border: 1px solid var(--kips-border);
  border-top-color: var(--kips-border-strong);
  border-radius: var(--kips-r-lg);
  box-shadow: var(--kips-shadow-md);
}

.kips-card {
  background: var(--kips-grad-surface);
  border-top: 1.5px solid var(--kips-border-strong);
  border-left: 1px solid var(--kips-border);
  border-radius: var(--kips-r-lg);
  padding: var(--kips-space-4) var(--kips-space-3);
  text-align: center;
  color: var(--kips-text);
  text-decoration: none;
  font-weight: 700;
  font-size: var(--kips-fs-sm);
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: var(--kips-space-3);
  box-shadow: var(--kips-shadow-md);
  transition: transform var(--kips-dur) var(--kips-ease-spring),
              box-shadow var(--kips-dur) var(--kips-ease-out),
              border-color var(--kips-dur) var(--kips-ease-out);
  will-change: transform;
}
.kips-card:hover {
  transform: translateY(-8px) scale(1.03);
  border-color: var(--kips-brand-400);
  box-shadow: var(--kips-shadow-lg), var(--kips-glow);
  text-decoration: none;
}
.kips-card__icon {
  width: 46px; height: 46px;
  display: flex; align-items: center; justify-content: center;
  transition: transform var(--kips-dur) var(--kips-ease-out);
}
.kips-card__icon svg { width: 100%; height: 100%; stroke: url(#kips-icon-gradient); stroke-width: 1.6; fill: none; }
.kips-card:hover .kips-card__icon { transform: rotate(5deg) scale(1.12); }

/* ----------------------------------------------------------------------------
   7. PROSE (content/legal pages)
   -------------------------------------------------------------------------- */
.kips-prose { max-width: 820px; margin-inline: auto; }
.kips-prose h1 { font-size: var(--kips-fs-xl); color: var(--kips-brand-400); margin-bottom: var(--kips-space-3); }
.kips-prose h2 { font-size: var(--kips-fs-lg); margin: var(--kips-space-4) 0 var(--kips-space-2); }
.kips-prose p, .kips-prose li { color: var(--kips-text-muted); margin-bottom: var(--kips-space-2); }
.kips-prose ul, .kips-prose ol { padding-left: 1.4em; margin-bottom: var(--kips-space-3); }
.kips-prose a { font-weight: 600; }
.kips-prose .kips-updated { color: var(--kips-text-faint); font-size: var(--kips-fs-sm); margin-bottom: var(--kips-space-4); }

/* ----------------------------------------------------------------------------
   8. FOOTER
   -------------------------------------------------------------------------- */
.kips-footer {
  margin-top: var(--kips-space-6);
  border-top: 1px solid var(--kips-border);
  background: color-mix(in srgb, var(--kips-surface-1) 40%, transparent);
  padding: var(--kips-space-5) var(--kips-space-4) var(--kips-space-4);
}
.kips-footer__cols {
  max-width: var(--kips-container);
  margin-inline: auto;
  display: grid;
  gap: var(--kips-space-4);
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
}
.kips-footer h4 { color: var(--kips-text); font-size: var(--kips-fs-sm); text-transform: uppercase; letter-spacing: 0.08em; margin-bottom: var(--kips-space-2); }
.kips-footer a { display: block; color: var(--kips-text-muted); font-size: var(--kips-fs-sm); padding: 4px 0; }
.kips-footer a:hover { color: var(--kips-brand-400); text-decoration: none; }
.kips-footer__legal { max-width: var(--kips-container); margin: var(--kips-space-4) auto 0; padding-top: var(--kips-space-3); border-top: 1px solid var(--kips-border); color: var(--kips-text-faint); font-size: var(--kips-fs-xs); text-align: center; }

/* ----------------------------------------------------------------------------
   9. COOKIE CONSENT (Google Consent Mode v2 UI)
   -------------------------------------------------------------------------- */
.kips-consent {
  position: fixed;
  left: 50%;
  bottom: max(16px, var(--kips-safe-bottom));
  transform: translateX(-50%) translateY(150%);
  width: min(680px, calc(100% - 24px));
  z-index: var(--kips-z-toast);
  background: var(--kips-surface-2);
  border: 1px solid var(--kips-border-strong);
  border-radius: var(--kips-r-md);
  box-shadow: var(--kips-shadow-lg);
  padding: var(--kips-space-3) var(--kips-space-4);
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: var(--kips-space-3);
  transition: transform var(--kips-dur) var(--kips-ease-out);
}
.kips-consent[data-open="true"] { transform: translateX(-50%) translateY(0); }
.kips-consent p { color: var(--kips-text-muted); font-size: var(--kips-fs-sm); flex: 1 1 260px; margin: 0; }
.kips-consent__actions { display: flex; gap: var(--kips-space-2); margin-left: auto; }

/* ----------------------------------------------------------------------------
   10. UTILITIES & STATE
   -------------------------------------------------------------------------- */
.kips-visually-hidden {
  position: absolute !important;
  width: 1px; height: 1px;
  padding: 0; margin: -1px;
  overflow: hidden; clip: rect(0, 0, 0, 0);
  white-space: nowrap; border: 0;
}
.kips-hidden { display: none !important; }

.kips-to-top {
  position: fixed;
  right: 18px;
  bottom: max(18px, var(--kips-safe-bottom));
  width: 46px; height: 46px;
  border-radius: var(--kips-r-pill);
  display: grid; place-items: center;
  background: var(--kips-grad-brand);
  color: #021018;
  border: none; cursor: pointer;
  box-shadow: var(--kips-shadow-md);
  opacity: 0; pointer-events: none;
  transform: translateY(12px);
  transition: opacity var(--kips-dur) var(--kips-ease-out), transform var(--kips-dur) var(--kips-ease-out);
  z-index: var(--kips-z-overlay);
}
.kips-to-top[data-show="true"] { opacity: 1; pointer-events: auto; transform: translateY(0); }

/* Skeleton shimmer for perceived performance */
.kips-skeleton {
  background: linear-gradient(90deg, var(--kips-surface-2) 25%, var(--kips-surface-3) 37%, var(--kips-surface-2) 63%);
  background-size: 400% 100%;
  animation: kips-shimmer 1.4s ease infinite;
  border-radius: var(--kips-r-sm);
}
@keyframes kips-shimmer { 0% { background-position: 100% 0; } 100% { background-position: -100% 0; } }

/* ----------------------------------------------------------------------------
   11. RTL SUPPORT
   -------------------------------------------------------------------------- */
[dir="rtl"] .kips-header__nav { margin-left: 0; margin-right: auto; }
[dir="rtl"] .kips-consent__actions { margin-left: 0; margin-right: auto; }
[dir="rtl"] .kips-to-top { right: auto; left: 18px; }

/* ----------------------------------------------------------------------------
   12. ADAPTIVE PERFORMANCE — downgrade effects on weak devices / reduced motion
   -------------------------------------------------------------------------- */
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.001ms !important;
  }
}

/* Low-end tier (set by kips-platform.js): kill blur/heavy shadows/animations */
[data-perf="low"] .kips-header,
[data-perf="low"] .kips-consent { -webkit-backdrop-filter: none; backdrop-filter: none; }
[data-perf="low"] .kips-card,
[data-perf="low"] .kips-btn { transition: none; will-change: auto; }
[data-perf="low"] .kips-card:hover { transform: none; }
[data-perf="low"] .kips-skeleton { animation: none; }
[data-perf="low"] body.kips { background-attachment: scroll; }

/* High-contrast / forced colors accessibility */
@media (forced-colors: active) {
  .kips-card, .kips-surface, .kips-btn { border: 1px solid CanvasText; }
}


/* ============================================================================
   13. MOCK APP LAYER — auth, dashboard, assistant, pricing, teams
   (Local-first, dummy/simulated. Built on the same tokens for consistency.)
   ========================================================================== */
.kips-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 30px; height: 30px; border-radius: var(--kips-r-pill);
  background: var(--kips-grad-brand); color: #021018;
  font-size: 12px; font-weight: 800; flex: 0 0 auto;
}
.kips-badge-soft {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 10px; border-radius: var(--kips-r-pill);
  background: color-mix(in srgb, var(--kips-brand-400) 14%, transparent);
  border: 1px solid color-mix(in srgb, var(--kips-brand-400) 35%, transparent);
  color: var(--kips-brand-400); font-size: var(--kips-fs-xs); font-weight: 700;
}

/* Centered auth card */
.kips-auth {
  min-height: calc(100vh - var(--kips-header-h));
  display: grid; place-items: center; padding: var(--kips-space-5) var(--kips-space-4);
}
.kips-auth__card {
  width: 100%; max-width: 420px;
  background: var(--kips-grad-surface); border: 1px solid var(--kips-border);
  border-top-color: var(--kips-border-strong);
  border-radius: var(--kips-r-lg); box-shadow: var(--kips-shadow-lg);
  padding: var(--kips-space-5) var(--kips-space-4);
}
.kips-auth__card h1 { font-size: var(--kips-fs-xl); margin-bottom: 6px; }
.kips-auth__card p.sub { color: var(--kips-text-muted); font-size: var(--kips-fs-sm); margin-bottom: var(--kips-space-4); }

.kips-field { display: flex; flex-direction: column; gap: 6px; margin-bottom: var(--kips-space-3); text-align: left; }
.kips-field label { font-size: var(--kips-fs-sm); color: var(--kips-text-muted); font-weight: 600; }
.kips-input {
  width: 100%; padding: 13px 14px; min-height: 46px;
  background: var(--kips-surface-1); color: var(--kips-text);
  border: 1px solid var(--kips-border-strong); border-radius: var(--kips-r-sm);
  font: inherit; font-size: var(--kips-fs-md); outline: none;
  transition: border-color var(--kips-dur-fast), box-shadow var(--kips-dur-fast);
}
.kips-input:focus { border-color: var(--kips-brand-400); box-shadow: 0 0 0 3px color-mix(in srgb, var(--kips-brand-400) 25%, transparent); }
.kips-btn--block { width: 100%; }
.kips-error { color: var(--kips-danger); font-size: var(--kips-fs-sm); min-height: 1.2em; margin-bottom: var(--kips-space-2); text-align: left; }
.kips-divider { display:flex; align-items:center; gap:12px; color: var(--kips-text-faint); font-size: var(--kips-fs-xs); margin: var(--kips-space-3) 0; }
.kips-divider::before, .kips-divider::after { content:""; height:1px; flex:1; background: var(--kips-border); }
.kips-switch-auth { text-align:center; margin-top: var(--kips-space-3); font-size: var(--kips-fs-sm); color: var(--kips-text-muted); }

/* App shell (dashboard / teams) */
.kips-app-head {
  display:flex; align-items:center; gap: var(--kips-space-3); flex-wrap: wrap;
  margin-bottom: var(--kips-space-4);
}
.kips-app-head h1 { font-size: var(--kips-fs-xl); }
.kips-stat-grid { display:grid; gap: var(--kips-space-3); grid-template-columns: repeat(auto-fit, minmax(150px,1fr)); margin-bottom: var(--kips-space-4); }
.kips-stat { background: var(--kips-grad-surface); border:1px solid var(--kips-border); border-radius: var(--kips-r-md); padding: var(--kips-space-4); }
.kips-stat b { display:block; font-size: var(--kips-fs-xl); color: var(--kips-brand-400); line-height:1.1; }
.kips-stat span { color: var(--kips-text-muted); font-size: var(--kips-fs-sm); }

.kips-doc-row {
  display:flex; align-items:center; gap: var(--kips-space-3);
  padding: var(--kips-space-3); border:1px solid var(--kips-border);
  border-radius: var(--kips-r-md); background: var(--kips-surface-2);
  margin-bottom: 10px;
}
.kips-doc-row .doc-ic { width:38px; height:38px; border-radius: 9px; display:grid; place-items:center; background: color-mix(in srgb, var(--kips-brand-400) 16%, transparent); flex:0 0 auto; }
.kips-doc-row .doc-ic svg { width:20px; height:20px; stroke: var(--kips-brand-400); fill:none; stroke-width:1.8; }
.kips-doc-row .doc-meta { flex:1 1 auto; min-width:0; text-align:left; }
.kips-doc-row .doc-meta strong { display:block; font-size: var(--kips-fs-md); white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.kips-doc-row .doc-meta span { color: var(--kips-text-faint); font-size: var(--kips-fs-xs); }

/* Pricing */
.kips-price-grid { display:grid; gap: var(--kips-space-3); grid-template-columns: repeat(auto-fit, minmax(230px,1fr)); }
.kips-plan { display:flex; flex-direction:column; background: var(--kips-grad-surface); border:1px solid var(--kips-border); border-radius: var(--kips-r-lg); padding: var(--kips-space-4); }
.kips-plan--featured { border-color: var(--kips-brand-400); box-shadow: var(--kips-glow); }
.kips-plan h3 { font-size: var(--kips-fs-lg); margin-bottom: 4px; }
.kips-plan .price { font-size: var(--kips-fs-2xl); font-weight: 800; line-height:1; margin: 8px 0; }
.kips-plan .price small { font-size: var(--kips-fs-sm); color: var(--kips-text-faint); font-weight:600; }
.kips-plan ul { list-style:none; margin: var(--kips-space-3) 0; display:flex; flex-direction:column; gap:8px; flex:1 1 auto; }
.kips-plan li { display:flex; gap:8px; align-items:flex-start; color: var(--kips-text-muted); font-size: var(--kips-fs-sm); }
.kips-plan li::before { content:"✓"; color: var(--kips-success); font-weight:800; }

/* Assistant chat */
.kips-chat { display:flex; flex-direction:column; height: calc(100vh - var(--kips-header-h) - 2px); max-width: 860px; margin-inline:auto; }
.kips-chat__log { flex:1 1 auto; overflow-y:auto; padding: var(--kips-space-4); display:flex; flex-direction:column; gap: var(--kips-space-3); }
.kips-msg { display:flex; gap:10px; max-width: 90%; }
.kips-msg__b { padding: 12px 14px; border-radius: var(--kips-r-md); font-size: var(--kips-fs-md); line-height:1.55; white-space:pre-wrap; }
.kips-msg--user { align-self:flex-end; flex-direction: row-reverse; }
.kips-msg--user .kips-msg__b { background: var(--kips-grad-brand); color:#021018; border-bottom-right-radius: 4px; }
.kips-msg--ai .kips-msg__b { background: var(--kips-surface-3); color: var(--kips-text); border-bottom-left-radius:4px; border:1px solid var(--kips-border); }
.kips-chat__bar { display:flex; gap:10px; padding: var(--kips-space-3) var(--kips-space-4); border-top:1px solid var(--kips-border); background: color-mix(in srgb, var(--kips-surface-1) 60%, transparent); }
.kips-chat__suggest { display:flex; flex-wrap:wrap; gap:8px; padding: 0 var(--kips-space-4) var(--kips-space-3); }
.kips-chip { padding:8px 12px; border-radius: var(--kips-r-pill); border:1px solid var(--kips-border-strong); background: var(--kips-surface-2); color: var(--kips-text-muted); font-size: var(--kips-fs-sm); cursor:pointer; }
.kips-chip:hover { border-color: var(--kips-brand-400); color: var(--kips-text); }

.kips-section-title { display:flex; align-items:center; gap:10px; margin: var(--kips-space-4) 0 var(--kips-space-3); font-size: var(--kips-fs-lg); }
