/*
 * Prospectar Design System v4 — "Reimagine"
 * Inspiração: Linear, Resend, Vercel, Supabase (sem copiar)
 * Dark first com tons quentes e profundos + light opcional via [data-theme="light"]
 * Mantém 100% das classes v3 (drop-in replacement) e adiciona tokens semânticos +
 *   componentes novos (.card, switch, tooltip, segmented tabs, sidebar, theme-toggle).
 *
 * Estrutura:
 *   1.  Imports + reset
 *   2.  Tokens primitivos (cores brutas)
 *   3.  Tokens semânticos dark (default)
 *   4.  Tokens semânticos light ([data-theme="light"])
 *   5.  Spacing / type / radius / shadow / motion / z-index
 *   6.  Base (body, links, scrollbar, selection)
 *   7.  Layout (header, tabs, content, sidebar)
 *   8.  Theme toggle + skip-link
 *   9.  Stats
 *   10. Sections + cards (.section + novo .card)
 *   11. Forms (input/select/textarea/checkbox/radio/switch/search/prefix-suffix)
 *   12. Buttons (6 variants × 3 sizes + icon-only + loading)
 *   13. Tables
 *   14. Badges
 *   15. Modals
 *   16. Toasts
 *   17. Tabs (existing + segmented novo)
 *   18. Tooltip (CSS-only)
 *   19. Loading states (spinner, skeleton, progress)
 *   20. Empty state
 *   21. Charts / log / steps / query / details
 *   22. Auth
 *   23. Alerts
 *   24. Animations
 *   25. Responsive
 */

/* ===== 1. IMPORTS + RESET ===== */
@import url('https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap');
@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:ital,wght@0,400;0,500;0,600;1,400;1,500&display=swap');

*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;color-scheme:dark}
[data-theme="light"]{color-scheme:light}

/* ===== 2. TOKENS PRIMITIVOS ===== */
:root{
  /* Brand emerald (primary accent) */
  --emerald-300:#6ee7b7; --emerald-400:#34d399; --emerald-500:#10b981; --emerald-600:#059669; --emerald-700:#047857;
  /* Secondary brand: violet (interactive secondary, links com personalidade) */
  --violet-300:#c4b5fd; --violet-400:#a78bfa; --violet-500:#8b5cf6; --violet-600:#7c3aed;
  /* Status hues */
  --green-500:#22c55e; --amber-500:#f59e0b; --red-500:#ef4444; --blue-500:#3b82f6; --cyan-500:#06b6d4;
  /* Warm neutral scale (NÃO grayscale puro — leve viés azul-violet pra dar profundidade) */
  --warm-50:#fafafa;  --warm-100:#f4f4f5; --warm-200:#e4e4e7; --warm-300:#d4d4d8;
  --warm-400:#a1a1aa; --warm-500:#71717a; --warm-600:#52525b; --warm-700:#3f3f46;
  --warm-800:#27272a; --warm-900:#18181b; --warm-950:#0d0d10;
}

/* ===== 3. TOKENS SEMÂNTICOS — DARK (DEFAULT) ===== */
:root{
  /* Surfaces (warm dark, com profundidade tonal) */
  --bg:           #0b0b0f;
  --bg-subtle:    #101015;
  --surface-1:    #16161c;
  --surface-2:    #1c1c24;
  --surface-3:    #24242e;
  --elevated:     #1f1f28;
  --surface-card: var(--surface-1);
  --surface-overlay: rgba(11,11,15,.72);

  /* Borders */
  --border:        rgba(255,255,255,.06);
  --border-default:rgba(255,255,255,.08);
  --border-hover:  rgba(255,255,255,.12);
  --border-active: rgba(255,255,255,.18);
  --border-strong: rgba(255,255,255,.24);

  /* Text */
  --text-1: #fafafa;
  --text-2: #c7c7d1;
  --text-3: #8a8a96;
  --text-4: #56565f;
  --text-body:    var(--text-2);
  --text-heading: var(--text-1);
  --text-muted:   var(--text-3);
  --text-disabled:var(--text-4);

  /* Brand */
  --accent:       var(--emerald-500);
  --accent-hover: var(--emerald-600);
  --accent-soft:  rgba(16,185,129,.10);
  --accent-soft-2:rgba(16,185,129,.18);
  --accent-text:  var(--emerald-400);
  --accent-ring:  rgba(16,185,129,.40);

  /* Secondary brand (violet — links, hover de personalidade) */
  --accent-2:      var(--violet-500);
  --accent-2-hover:var(--violet-600);
  --accent-2-soft: rgba(139,92,246,.12);
  --accent-2-text: var(--violet-400);

  /* Status (mantém compat v3) */
  --green:      var(--green-500);
  --green-muted:rgba(34,197,94,.10);
  --amber:      var(--amber-500);
  --amber-muted:rgba(245,158,11,.10);
  --red:        var(--red-500);
  --red-muted:  rgba(239,68,68,.10);
  --blue:       var(--blue-500);
  --blue-muted: rgba(59,130,246,.10);

  /* Inputs */
  --input-bg:     rgba(255,255,255,.025);
  --input-border: rgba(255,255,255,.09);
  --input-border-hover:rgba(255,255,255,.14);
  --input-focus:  var(--accent-ring);
  --input-text:   var(--text-1);
  --input-placeholder: var(--text-4);

  /* Shadows com tinta sutil de cor (não preto puro) */
  --shadow-xs: 0 1px 2px rgba(0,0,0,.35);
  --shadow-sm: 0 1px 2px rgba(0,0,0,.4), 0 1px 1px rgba(0,0,0,.25);
  --shadow:    0 4px 12px rgba(0,0,0,.32), 0 2px 4px rgba(0,0,0,.22);
  --shadow-lg: 0 12px 32px rgba(0,0,0,.45), 0 4px 12px rgba(0,0,0,.28);
  --shadow-xl: 0 20px 48px rgba(0,0,0,.55), 0 8px 16px rgba(0,0,0,.32);
  --shadow-2xl:0 32px 80px rgba(0,0,0,.65), 0 12px 24px rgba(0,0,0,.4);
  --shadow-accent: 0 0 0 4px var(--accent-soft), 0 8px 24px rgba(16,185,129,.15);
}

/* ===== 4. TOKENS SEMÂNTICOS — LIGHT (warm editorial, Pórtico-aligned) ===== */
[data-theme="light"]{
  --bg:           #f5efe6;
  --bg-subtle:    #efe8dc;
  --surface-1:    #faf6f0;
  --surface-2:    #f0e9dd;
  --surface-3:    #e5dccc;
  --elevated:     #ffffff;
  --surface-card: #faf6f0;
  --surface-overlay: rgba(245,239,230,.85);

  --border:        #e5dccc;
  --border-default:#e5dccc;
  --border-hover:  #c9bca5;
  --border-active: #8a7c66;
  --border-strong: #4a4339;

  --text-1: #1a1816;
  --text-2: #4a4339;
  --text-3: #8a7c66;
  --text-4: #b8ab95;
  --text-body:    var(--text-2);
  --text-heading: var(--text-1);
  --text-muted:   var(--text-3);
  --text-disabled:var(--text-4);

  /* Editorial accent: terracotta (Pórtico-aligned) */
  --accent:       #9c5d3e;
  --accent-hover: #7d4530;
  --accent-soft:  rgba(156,93,62,.08);
  --accent-soft-2:rgba(156,93,62,.18);
  --accent-text:  #7d4530;
  --accent-ring:  rgba(156,93,62,.28);

  --accent-2:      #1a1816;
  --accent-2-hover:#000000;
  --accent-2-soft: rgba(26,24,22,.06);
  --accent-2-text: #1a1816;

  --green:      #5a8c3f; --green-muted:rgba(90,140,63,.10);
  --amber:      #b87a2c; --amber-muted:rgba(184,122,44,.10);
  --red:        #b04444; --red-muted:  rgba(176,68,68,.10);
  --blue:       #4a6b8c; --blue-muted: rgba(74,107,140,.10);

  --input-bg:     #ffffff;
  --input-border: #d9ccb3;
  --input-border-hover:#a89878;
  --input-placeholder: #b8ab95;

  --shadow-xs: 0 1px 2px rgba(74,67,57,.06);
  --shadow-sm: 0 1px 3px rgba(74,67,57,.08);
  --shadow:    0 4px 12px rgba(74,67,57,.10), 0 2px 4px rgba(74,67,57,.06);
  --shadow-lg: 0 12px 28px rgba(74,67,57,.12), 0 4px 10px rgba(74,67,57,.06);
  --shadow-xl: 0 20px 40px rgba(74,67,57,.14);
  --shadow-2xl:0 28px 64px rgba(74,67,57,.18);
}

/* ===== 5. SPACING / TYPE / RADIUS / MOTION / Z-INDEX ===== */
:root{
  /* Spacing (4px base) */
  --space-1:4px;  --space-2:8px;  --space-3:12px; --space-4:16px;
  --space-5:20px; --space-6:24px; --space-7:32px; --space-8:40px;
  --space-9:48px; --space-10:64px; --space-11:80px; --space-12:96px;

  /* Type scale */
  --fs-11:11px; --fs-12:12px; --fs-13:13px; --fs-14:14px;
  --fs-16:16px; --fs-18:18px; --fs-20:20px; --fs-24:24px;
  --fs-28:28px; --fs-32:32px; --fs-40:40px;
  --font-sans: 'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;
  --font-display:'Source Serif 4','Source Serif Pro',Georgia,serif;
  --font-mono: 'SF Mono','Cascadia Code','JetBrains Mono',Consolas,monospace;

  /* Radius (mantém v3 + 2 novos) */
  --radius-xs:4px; --radius-sm:6px; --radius:8px; --radius-md:10px;
  --radius-lg:12px; --radius-xl:14px; --radius-2xl:16px; --radius-3xl:24px;
  --radius-full:9999px;

  /* Motion */
  --ease:cubic-bezier(0.4,0,0.2,1);
  --ease-out:cubic-bezier(0.16,1,0.3,1);
  --motion-fast:120ms var(--ease);
  --motion-base:150ms var(--ease);
  --motion-slow:300ms var(--ease-out);

  /* Z-index scale */
  --z-base:1; --z-dropdown:50; --z-sticky:60; --z-fixed:80;
  --z-modal-bg:200; --z-modal:210; --z-toast:300; --z-tooltip:400;
}

/* ===== 6. BASE ===== */
body{
  font-family:var(--font-sans);
  background:var(--bg);
  color:var(--text-1);
  font-size:var(--fs-14);
  line-height:1.5;
  min-height:100vh;
  transition:background var(--motion-base), color var(--motion-base);
}
a{color:inherit;text-decoration:none}
::selection{background:var(--accent-soft-2);color:var(--accent-text)}

/* Scrollbar refinada */
::-webkit-scrollbar{width:10px;height:10px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:var(--border-hover);border-radius:var(--radius-full);border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--border-active);background-clip:padding-box;border:2px solid transparent}
html{scrollbar-color:var(--border-hover) transparent;scrollbar-width:thin}

/* Native select alignment with theme */
select{background-color:var(--surface-2);color:var(--text-1)}
select option{background:var(--surface-2);color:var(--text-1)}

/* Display headings (DM Serif) */
.display{font-family:var(--font-display);font-weight:400;letter-spacing:-.5px;line-height:1.1}

/* ===== 7. LAYOUT — HEADER / TABS / CONTENT / SIDEBAR ===== */
.header{
  height:56px;
  padding:0 var(--space-6);
  display:flex;align-items:center;justify-content:space-between;
  background:color-mix(in oklab,var(--bg) 80%,transparent);
  -webkit-backdrop-filter:saturate(180%) blur(12px);
  backdrop-filter:saturate(180%) blur(12px);
  border-bottom:1px solid var(--border);
  position:sticky;top:0;z-index:var(--z-sticky);
}
.header h1{font-size:var(--fs-14);font-weight:600;letter-spacing:-.3px;color:var(--text-2);display:flex;align-items:center;gap:var(--space-2)}
.header h1 span{color:var(--text-1)}
.header-right{display:flex;align-items:center;gap:var(--space-3)}
.plan-badge{font-size:11px;font-weight:500;padding:3px 9px;border-radius:6px;background:var(--surface-2);color:var(--text-3);text-transform:capitalize;letter-spacing:0;border:1px solid var(--border)}
.tenant-name{font-size:var(--fs-13);color:var(--text-3)}

.tabs{
  display:flex;gap:0;
  padding:0 var(--space-6);
  background:var(--bg);
  border-bottom:1px solid var(--border);
  overflow-x:auto;scrollbar-width:none;
}
.tabs::-webkit-scrollbar{display:none}
.tab{
  display:block;padding:12px var(--space-4);
  font-size:var(--fs-13);font-weight:500;color:var(--text-3);
  border-bottom:2px solid transparent;
  transition:color var(--motion-fast), border-color var(--motion-fast);
  white-space:nowrap;
}
.tab:hover{color:var(--text-2)}
.tab.active{color:var(--text-1);border-bottom-color:var(--accent)}
.tab:focus-visible{outline:2px solid var(--accent);outline-offset:-2px;border-radius:var(--radius-xs)}
.upgrade-tab{color:var(--accent-text);font-weight:600}

.content{padding:var(--space-6);max-width:1320px;margin:0 auto}
@media(min-width:1440px){.content{padding:var(--space-7) var(--space-8)}}

/* Sidebar (CSS pronto pra uso futuro — sem HTML obrigatório) */
.app-shell{display:grid;grid-template-columns:240px 1fr;min-height:calc(100vh - 56px)}
.sidebar{
  background:var(--bg-subtle);border-right:1px solid var(--border);
  padding:var(--space-4);display:flex;flex-direction:column;gap:var(--space-1);
  position:sticky;top:56px;height:calc(100vh - 56px);overflow-y:auto;
}
.sidebar-item{
  display:flex;align-items:center;gap:var(--space-3);
  padding:8px 10px;border-radius:var(--radius);
  font-size:var(--fs-13);color:var(--text-3);font-weight:500;
  transition:background var(--motion-fast), color var(--motion-fast);
}
.sidebar-item:hover{background:var(--surface-2);color:var(--text-1)}
.sidebar-item.active{background:var(--accent-soft);color:var(--accent-text)}
.sidebar-section{font-size:var(--fs-11);text-transform:uppercase;letter-spacing:.5px;color:var(--text-4);padding:var(--space-4) 10px var(--space-1);font-weight:600}

/* ===== 8. THEME TOGGLE + SKIP-LINK ===== */
.theme-toggle{
  width:34px;height:34px;border-radius:var(--radius-full);
  background:transparent;border:1px solid var(--border-default);
  color:var(--text-3);cursor:pointer;
  display:inline-flex;align-items:center;justify-content:center;
  transition:all var(--motion-fast);
}
.theme-toggle:hover{background:var(--surface-2);color:var(--text-1);border-color:var(--border-hover)}
.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.theme-toggle .icon-sun{display:none}
.theme-toggle .icon-moon{display:block}
[data-theme="light"] .theme-toggle .icon-sun{display:block}
[data-theme="light"] .theme-toggle .icon-moon{display:none}

.skip-link{position:absolute;top:-100px;left:8px;z-index:9999;padding:8px 16px;background:var(--accent);color:#fff;border-radius:var(--radius);font-size:var(--fs-13);font-weight:600;text-decoration:none;transition:top var(--motion-fast)}
.skip-link:focus{top:8px}

/* ===== 9. STATS ===== */
.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(170px,1fr));gap:1px;background:var(--border);border-radius:var(--radius-lg);overflow:hidden;margin-bottom:var(--space-6);box-shadow:var(--shadow-xs)}
.stat-card{background:var(--surface-1);padding:var(--space-4) var(--space-5)}
.stat-card:first-child{border-radius:var(--radius-lg) 0 0 var(--radius-lg)}
.stat-card:last-child{border-radius:0 var(--radius-lg) var(--radius-lg) 0}
.stat-label{font-size:var(--fs-11);color:var(--text-3);text-transform:uppercase;letter-spacing:.5px;font-weight:500;margin-bottom:6px}
.stat-value{font-size:var(--fs-24);font-weight:600;letter-spacing:-.5px;color:var(--text-1);font-variant-numeric:tabular-nums}
.stat-value.green{color:var(--green)}.stat-value.orange{color:var(--amber)}.stat-value.red{color:var(--red)}.stat-value.blue{color:var(--blue)}.stat-value.accent{color:var(--accent-text)}
.stat-sub{font-size:var(--fs-11);color:var(--text-4);margin-top:2px}

/* ===== 10. SECTIONS + CARDS ===== */
.section,.form-section{
  background:var(--surface-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:var(--space-5);
  margin-bottom:var(--space-4);
  transition:border-color var(--motion-fast);
}
.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}
.section-title,.form-section h3{font-size:var(--fs-13);font-weight:600;color:var(--text-1);margin-bottom:0}
.form-section h3{margin-bottom:var(--space-4)}
.section-subtitle{font-size:var(--fs-12);color:var(--text-3);margin-top:2px;line-height:1.5}

/* Novo: .card — alternativa mais flexível ao .section */
.card{
  background:var(--surface-card);border:1px solid var(--border);
  border-radius:var(--radius-lg);padding:var(--space-5);
  transition:border-color var(--motion-fast),transform var(--motion-fast),box-shadow var(--motion-fast);
}
.card-elevated{box-shadow:var(--shadow);background:var(--elevated)}
.card-interactive{cursor:pointer}
.card-interactive:hover{border-color:var(--border-hover);transform:translateY(-1px);box-shadow:var(--shadow)}
.card-interactive:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
.card-padded{padding:var(--space-6)}
.card-compact{padding:var(--space-4)}
.card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}
.card-title{font-size:var(--fs-14);font-weight:600;color:var(--text-1);letter-spacing:-.1px}
.card-desc{font-size:var(--fs-12);color:var(--text-3);margin-top:2px;line-height:1.5}

/* ===== 11. FORMS ===== */
.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:var(--space-3)}
.form-group{margin-bottom:var(--space-3)}
.form-group label,.form-label{display:block;font-size:var(--fs-12);font-weight:500;color:var(--text-2);margin-bottom:6px}
.form-help{font-size:var(--fs-11);color:var(--text-3);margin-top:6px;line-height:1.4}

.form-group input,.form-group select,.form-group textarea,
.input,.select,.textarea{
  width:100%;padding:9px 12px;
  background:var(--input-bg);border:1px solid var(--input-border);
  border-radius:var(--radius);color:var(--input-text);
  font-size:var(--fs-13);font-family:inherit;line-height:1.4;
  transition:border-color var(--motion-fast), box-shadow var(--motion-fast), background var(--motion-fast);
  outline:none;
}
.form-group input:hover,.form-group select:hover,.form-group textarea:hover,
.input:hover,.select:hover,.textarea:hover{border-color:var(--input-border-hover)}
.form-group input:focus,.form-group select:focus,.form-group textarea:focus,
.input:focus,.select:focus,.textarea:focus{
  border-color:var(--accent);
  box-shadow:0 0 0 3px var(--accent-ring);
}
.form-group input::placeholder,.form-group textarea::placeholder,
.input::placeholder,.textarea::placeholder{color:var(--input-placeholder)}
.form-group textarea,.textarea{min-height:72px;resize:vertical}
.form-group select,.select{cursor:pointer;padding-right:32px;background-image:url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%238a8a96' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><polyline points='6 9 12 15 18 9'/></svg>");background-repeat:no-repeat;background-position:right 10px center;-webkit-appearance:none;appearance:none}

/* Input com ícone embutido (search) */
.input-icon{position:relative}
.input-icon input{padding-left:34px}
.input-icon svg,.input-icon .icon{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-3);pointer-events:none;width:14px;height:14px}

/* Prefix/Suffix */
.input-group{display:flex;align-items:stretch;border:1px solid var(--input-border);border-radius:var(--radius);background:var(--input-bg);overflow:hidden;transition:border-color var(--motion-fast),box-shadow var(--motion-fast)}
.input-group:focus-within{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}
.input-group input{border:none;background:transparent;flex:1}
.input-group input:focus{box-shadow:none;border:none}
.input-prefix,.input-suffix{display:flex;align-items:center;padding:0 12px;font-size:var(--fs-13);color:var(--text-3);background:var(--surface-2);user-select:none}
.input-prefix{border-right:1px solid var(--border)}
.input-suffix{border-left:1px solid var(--border)}

/* Custom checkbox */
.checkbox{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--fs-13);color:var(--text-2);user-select:none}
.checkbox input[type="checkbox"]{position:absolute;opacity:0;pointer-events:none}
.checkbox-box{width:16px;height:16px;border:1.5px solid var(--input-border);border-radius:var(--radius-xs);background:var(--input-bg);display:inline-flex;align-items:center;justify-content:center;transition:all var(--motion-fast);flex-shrink:0}
.checkbox input:checked+.checkbox-box{background:var(--accent);border-color:var(--accent)}
.checkbox input:checked+.checkbox-box::after{content:'';width:4px;height:8px;border:solid #fff;border-width:0 2px 2px 0;transform:rotate(45deg) translate(-1px,-1px)}
.checkbox input:focus-visible+.checkbox-box{box-shadow:0 0 0 3px var(--accent-ring)}
.checkbox:hover .checkbox-box{border-color:var(--accent)}

/* Custom radio */
.radio{position:relative;display:inline-flex;align-items:center;gap:var(--space-2);cursor:pointer;font-size:var(--fs-13);color:var(--text-2);user-select:none}
.radio input[type="radio"]{position:absolute;opacity:0;pointer-events:none}
.radio-dot{width:16px;height:16px;border:1.5px solid var(--input-border);border-radius:50%;background:var(--input-bg);display:inline-flex;align-items:center;justify-content:center;transition:all var(--motion-fast);flex-shrink:0}
.radio input:checked+.radio-dot{border-color:var(--accent)}
.radio input:checked+.radio-dot::after{content:'';width:8px;height:8px;border-radius:50%;background:var(--accent)}
.radio input:focus-visible+.radio-dot{box-shadow:0 0 0 3px var(--accent-ring)}

/* Switch / Toggle (novo — pro theme toggle e settings) */
.switch{position:relative;display:inline-flex;align-items:center;gap:var(--space-3);cursor:pointer;user-select:none}
.switch input{position:absolute;opacity:0;pointer-events:none}
.switch-track{width:36px;height:20px;background:var(--surface-3);border-radius:var(--radius-full);position:relative;transition:background var(--motion-base);flex-shrink:0}
.switch-track::after{content:'';position:absolute;top:2px;left:2px;width:16px;height:16px;background:#fff;border-radius:50%;transition:transform var(--motion-base);box-shadow:var(--shadow-sm)}
.switch input:checked+.switch-track{background:var(--accent)}
.switch input:checked+.switch-track::after{transform:translateX(16px)}
.switch input:focus-visible+.switch-track{box-shadow:0 0 0 3px var(--accent-ring)}

/* Status select (compat v3) */
.status-select{background:var(--input-bg);color:var(--text-2);border:1px solid var(--input-border);border-radius:var(--radius-sm);padding:4px 8px;font-size:var(--fs-12);font-family:inherit;cursor:pointer;outline:none;transition:border-color var(--motion-fast)}
.status-select:focus{border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-ring)}

/* ===== 12. BUTTONS ===== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:6px;
  padding:8px 14px;font-size:var(--fs-13);font-weight:500;font-family:inherit;
  border:1px solid transparent;border-radius:var(--radius);
  cursor:pointer;white-space:nowrap;line-height:1.2;
  transition:background var(--motion-fast), border-color var(--motion-fast),
             color var(--motion-fast), transform var(--motion-fast), box-shadow var(--motion-fast);
  position:relative;
}
.btn:active:not(:disabled){transform:translateY(1px)}
.btn:disabled,.btn[aria-disabled="true"]{opacity:.45;cursor:not-allowed;pointer-events:none}
.btn:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}

/* Sizes */
.btn-xs{padding:4px 8px;font-size:var(--fs-11);gap:4px;border-radius:var(--radius-sm)}
.btn-sm{padding:6px 10px;font-size:var(--fs-12);gap:5px}
.btn-lg{padding:10px 18px;font-size:var(--fs-14)}
.btn-icon{padding:8px;width:34px;height:34px}
.btn-icon.btn-sm{padding:6px;width:28px;height:28px}
.btn-icon.btn-lg{padding:10px;width:40px;height:40px}

/* Variants */
.btn-primary{background:var(--text-1);color:#fff;border-color:var(--text-1);font-weight:500;font-size:13px;padding:10px 18px;border-radius:3px}
.btn-primary:hover:not(:disabled){background:#000;border-color:#000;box-shadow:var(--shadow-sm)}
.btn-primary:focus-visible{box-shadow:0 0 0 3px var(--accent-ring)}

.btn-secondary{background:var(--surface-3);color:var(--text-1);border-color:var(--border-hover)}
.btn-secondary:hover:not(:disabled){background:var(--elevated);border-color:var(--border-active)}

.btn-outline{background:transparent;color:var(--text-2);border-color:var(--border-hover)}
.btn-outline:hover:not(:disabled){border-color:var(--border-active);color:var(--text-1);background:var(--surface-2)}

.btn-ghost{background:transparent;color:var(--text-3);border:none;padding:7px 10px}
.btn-ghost:hover:not(:disabled){color:var(--text-1);background:var(--surface-2)}

.btn-danger{background:var(--red);color:#fff;border-color:var(--red)}
.btn-danger:hover:not(:disabled){background:#dc2626;border-color:#dc2626;box-shadow:var(--shadow-sm)}
.btn-danger:focus-visible{box-shadow:0 0 0 3px rgba(239,68,68,.4)}

.btn-danger-ghost{background:var(--red-muted);color:var(--red);border:none;padding:6px 10px;font-size:var(--fs-12);border-radius:var(--radius-sm);cursor:pointer;font-weight:500;font-family:inherit;transition:all var(--motion-fast)}
.btn-danger-ghost:hover:not(:disabled){background:rgba(239,68,68,.18)}
.btn-danger-ghost:focus-visible{outline:none;box-shadow:0 0 0 3px rgba(239,68,68,.3)}

.btn-delete{background:var(--red-muted);color:var(--red);padding:5px 10px;font-size:var(--fs-12);border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background var(--motion-fast)}
.btn-delete:hover{background:rgba(239,68,68,.18)}

/* Loading state — substitui texto por spinner mantendo width */
.btn.is-loading{color:transparent !important;pointer-events:none}
.btn.is-loading::after{
  content:'';position:absolute;left:50%;top:50%;
  width:14px;height:14px;margin:-7px 0 0 -7px;
  border:1.5px solid currentColor;border-right-color:transparent;
  border-radius:50%;animation:spin .55s linear infinite;
  color:inherit;opacity:.9;
}
.btn-primary.is-loading::after,.btn-danger.is-loading::after{border-color:#fff;border-right-color:transparent}

.btn-group{display:flex;gap:var(--space-2);margin-top:var(--space-4);flex-wrap:wrap;align-items:center}

/* ===== 13. TABLES ===== */
.table-wrap{overflow-x:auto;border-radius:var(--radius-lg);border:1px solid var(--border)}
table{width:100%;border-collapse:collapse;font-size:var(--fs-13)}
th{font-size:var(--fs-11);font-weight:600;color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;padding:10px 14px;text-align:left;border-bottom:1px solid var(--border);background:var(--bg-subtle)}
td{padding:11px 14px;border-bottom:1px solid var(--border);color:var(--text-2)}
tr:last-child td{border-bottom:none}
tr:hover td{background:var(--surface-2);color:var(--text-1)}
.status-badge:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring);border-radius:4px}

/* ===== 14. BADGES (neutral system, color via dot only) ===== */
.badge{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:6px;font-size:11px;font-weight:500;letter-spacing:0;border:1px solid var(--border);background:var(--surface-2);color:var(--text-2);line-height:1.4}
.badge::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--text-4);flex-shrink:0}
.badge-novo::before{background:var(--accent)}
.badge-contatado::before,.badge-enviado::before{background:#3b82f6}
.badge-respondeu::before,.badge-completed::before{background:#22c55e}
.badge-convertido::before{background:#f59e0b}
.badge-qualificado::before{background:#8b5cf6}
.badge-perdido::before{background:#9ca3af}
.badge-sem_interesse::before,.badge-error::before{background:#ef4444}
.badge-alta::before{background:#ef4444}
.badge-media::before{background:#f59e0b}
.badge-baixa::before{background:#22c55e}
.badge-pendente::before,.badge-pending::before{background:var(--text-4)}
.badge-running::before{background:#3b82f6}
.badge-trial::before,.badge-starter::before,.badge-essencial::before{background:var(--accent)}
.badge-free::before{background:var(--text-4)}
.badge-pro::before{background:#3b82f6}
.badge-business::before{background:#f59e0b}
.lead-score-dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:4px;vertical-align:middle}
.lead-score-dot.dot-alta{background:var(--green)}.lead-score-dot.dot-media{background:var(--amber)}.lead-score-dot.dot-baixa{background:#6b7280}

/* ===== 15. MODALS ===== */
.modal-overlay{
  position:fixed;inset:0;z-index:var(--z-modal-bg);
  background:rgba(5,5,8,.62);
  -webkit-backdrop-filter:blur(8px) saturate(140%);
  backdrop-filter:blur(8px) saturate(140%);
  display:flex;align-items:center;justify-content:center;padding:var(--space-6);
  animation:overlayIn .25s var(--ease-out);
}
[data-theme="light"] .modal-overlay{background:rgba(20,20,30,.42)}
.modal{
  background:var(--surface-2);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-6);width:100%;max-width:520px;
  max-height:90vh;overflow-y:auto;
  box-shadow:var(--shadow-2xl);
  z-index:var(--z-modal);
  animation:modalIn .3s var(--ease-out);
}
.modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3);margin-bottom:var(--space-4)}
.modal-title{font-size:var(--fs-16);font-weight:600;color:var(--text-1);letter-spacing:-.1px}
.modal-desc{font-size:var(--fs-13);color:var(--text-3);margin-top:4px;line-height:1.5}
.modal-close{
  width:30px;height:30px;border-radius:var(--radius);
  background:transparent;border:none;color:var(--text-3);
  cursor:pointer;display:inline-flex;align-items:center;justify-content:center;
  transition:all var(--motion-fast);font-size:18px;line-height:1;
}
.modal-close:hover{background:var(--surface-3);color:var(--text-1)}
.modal-close:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}
.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-5);padding-top:var(--space-4);border-top:1px solid var(--border)}
@keyframes overlayIn{from{opacity:0}to{opacity:1}}
@keyframes modalIn{from{opacity:0;transform:translateY(16px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}

/* ===== 16. TOASTS ===== */
#toast-stack{position:fixed;bottom:24px;right:24px;display:flex;flex-direction:column;gap:var(--space-2);z-index:var(--z-toast);pointer-events:none}
.toast{
  pointer-events:auto;
  display:inline-flex;align-items:flex-start;gap:var(--space-3);
  padding:12px 16px;
  background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius-lg);font-size:var(--fs-13);font-weight:500;color:var(--text-1);
  box-shadow:var(--shadow-lg);
  min-width:280px;max-width:420px;
  position:relative; /* old single toast compat (legacy bottom-right behavior) */
  bottom:auto;right:auto;
  transform:translateY(12px);opacity:0;
  transition:transform var(--motion-base), opacity var(--motion-base);
}
.toast.show{transform:translateY(0);opacity:1}
.toast-icon{flex-shrink:0;width:18px;height:18px;display:inline-flex;align-items:center;justify-content:center;margin-top:1px}
.toast-body{flex:1;line-height:1.45}
.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-3);cursor:pointer;padding:0 2px;font-size:16px;line-height:1;transition:color var(--motion-fast)}
.toast-close:hover{color:var(--text-1)}

.toast.success{border-left:3px solid var(--green)}
.toast.success .toast-icon{color:var(--green)}
.toast.error{border-left:3px solid var(--red)}
.toast.error .toast-icon{color:var(--red)}
.toast.warning{border-left:3px solid var(--amber)}
.toast.warning .toast-icon{color:var(--amber)}
.toast.info{border-left:3px solid var(--blue)}
.toast.info .toast-icon{color:var(--blue)}

/* Legacy single-toast compat (#toast in base.html) */
#toast{position:fixed;bottom:20px;right:20px;padding:10px 18px;border-radius:var(--radius);font-size:var(--fs-13);font-weight:500;z-index:var(--z-toast);transform:translateY(80px);opacity:0;transition:all .2s;box-shadow:var(--shadow-lg)}
#toast.show{transform:translateY(0);opacity:1}
#toast.success{background:var(--accent);color:#fff;border:none}
#toast.error{background:var(--red);color:#fff;border:none}

/* ===== 17. TABS — segmented (novo, formaliza pill style já usado em bulk email) ===== */
.tabs-segmented{
  display:inline-flex;padding:3px;
  background:var(--surface-2);border:1px solid var(--border);
  border-radius:var(--radius-full);gap:2px;
}
.tabs-segmented .tab-pill{
  padding:6px 14px;font-size:var(--fs-12);font-weight:500;
  color:var(--text-3);border-radius:var(--radius-full);
  border:none;background:transparent;cursor:pointer;
  transition:all var(--motion-fast);
}
.tabs-segmented .tab-pill:hover{color:var(--text-1)}
.tabs-segmented .tab-pill.active{background:var(--surface-3);color:var(--text-1);box-shadow:var(--shadow-xs)}
.tabs-segmented .tab-pill:focus-visible{outline:none;box-shadow:0 0 0 3px var(--accent-ring)}

/* ===== 18. TOOLTIP (CSS-only via [data-tooltip]) ===== */
[data-tooltip]{position:relative}
[data-tooltip]::before,[data-tooltip]::after{
  position:absolute;left:50%;bottom:calc(100% + 6px);transform:translateX(-50%);
  opacity:0;pointer-events:none;
  transition:opacity var(--motion-fast), transform var(--motion-fast);
  z-index:var(--z-tooltip);
}
[data-tooltip]::before{
  content:attr(data-tooltip);
  white-space:nowrap;
  padding:6px 10px;
  background:var(--surface-3);color:var(--text-1);
  border:1px solid var(--border);border-radius:var(--radius-sm);
  font-size:var(--fs-11);font-weight:500;
  box-shadow:var(--shadow);
}
[data-tooltip]::after{
  content:'';width:0;height:0;bottom:100%;
  border:4px solid transparent;border-top-color:var(--surface-3);
}
[data-tooltip]:hover::before,[data-tooltip]:hover::after,
[data-tooltip]:focus-visible::before,[data-tooltip]:focus-visible::after{
  opacity:1;transform:translateX(-50%) translateY(-2px);
}

/* ===== 19. LOADING STATES ===== */
.spinner{display:inline-block;width:14px;height:14px;border:1.5px solid var(--surface-3);border-top-color:var(--accent);border-radius:50%;animation:spin .55s linear infinite;vertical-align:middle}
.spinner-lg{width:24px;height:24px;border-width:2px}
.spinner-sm{width:11px;height:11px;border-width:1.2px}

/* Skeleton (padronizado — substitui inline em base.html) */
.skeleton{background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;border-radius:var(--radius-sm);height:16px;animation:skeleton-shimmer 1.6s ease-in-out infinite}
.skeleton-circle{border-radius:50%;width:40px;height:40px;background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.6s ease-in-out infinite}
.skeleton-card{border-radius:var(--radius-md);height:120px;background:linear-gradient(90deg,var(--surface-2) 0%,var(--surface-3) 50%,var(--surface-2) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.6s ease-in-out infinite}
.skeleton-text{height:13px;border-radius:var(--radius-xs)}
.skeleton-title{height:20px;width:60%;border-radius:var(--radius-sm)}
@keyframes skeleton-shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

.progress-bar{height:4px;background:var(--surface-3);border-radius:var(--radius-full);overflow:hidden}
.progress-fill{height:100%;border-radius:var(--radius-full);background:var(--accent);transition:width var(--motion-slow)}
.progress-fill.green{background:var(--green)}.progress-fill.blue{background:var(--blue)}
.progress-fill.amber{background:var(--amber)}.progress-fill.red{background:var(--red)}

/* ===== 20. EMPTY STATE ===== */
.empty-state{text-align:center;padding:var(--space-9) var(--space-5)}
.empty-state-icon{display:inline-flex;align-items:center;justify-content:center;width:56px;height:56px;border-radius:var(--radius-2xl);background:var(--surface-2);color:var(--text-3);margin-bottom:var(--space-4);font-size:24px}
.empty-state-icon svg{width:24px;height:24px}
.empty-state-title{font-size:var(--fs-14);font-weight:600;color:var(--text-1);margin-bottom:6px}
.empty-state-desc{font-size:var(--fs-12);color:var(--text-3);max-width:340px;margin:0 auto var(--space-4);line-height:1.55}
.empty-state .btn{margin-top:var(--space-2)}

/* ===== 21. CHARTS / LOG / STEPS / QUERY / DETAILS ===== */
.chart-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-5)}
.chart-container h3{font-size:var(--fs-11);font-weight:600;color:var(--text-3);margin-bottom:var(--space-4);text-transform:uppercase;letter-spacing:.4px}
.bar-chart{display:flex;align-items:flex-end;gap:6px;height:180px;padding-top:16px}
.bar-group{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}
.bar{width:100%;max-width:48px;border-radius:4px 4px 0 0;background:var(--accent)}
.bar-label{font-size:var(--fs-11);color:var(--text-4);text-align:center}
.bar-value{font-size:var(--fs-11);font-weight:600;color:var(--text-2)}

.log-container{background:var(--surface-1);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--space-4);max-height:280px;overflow-y:auto}
.log-entry{padding:6px 0;font-size:var(--fs-12);display:flex;gap:12px;border-bottom:1px solid var(--border)}
.log-entry:last-child{border-bottom:none}
.log-time{color:var(--text-4);font-size:var(--fs-11);white-space:nowrap;font-variant-numeric:tabular-nums}

.two-col{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}

.step-list{display:flex;flex-direction:column;gap:var(--space-3)}
.step-item{display:flex;gap:var(--space-3);align-items:flex-start}
.step-number{min-width:24px;height:24px;background:var(--surface-3);color:var(--text-2);border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--fs-11);flex-shrink:0}
.step-item.active .step-number{background:var(--accent);color:#fff}
.step-title{font-weight:500;font-size:var(--fs-13);margin-bottom:2px;color:var(--text-1)}
.step-desc{font-size:var(--fs-12);color:var(--text-3);line-height:1.5}

.query-preview{margin-top:var(--space-3);padding:10px 14px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius);font-family:var(--font-mono);font-size:var(--fs-12);color:var(--text-2)}

details summary{cursor:pointer;font-size:var(--fs-12);font-weight:500;color:var(--text-3);user-select:none;list-style:none;display:flex;align-items:center;gap:6px;transition:color var(--motion-fast)}
details summary:hover{color:var(--text-1)}
details summary::before{content:'›';font-size:14px;transition:transform var(--motion-fast);display:inline-block}
details[open] summary::before{transform:rotate(90deg)}
details summary::-webkit-details-marker{display:none}

/* ===== 22. AUTH ===== */
.auth-container{
  display:flex;align-items:center;justify-content:center;
  min-height:100vh;padding:var(--space-6);
  background:
    radial-gradient(ellipse 80% 50% at 50% -10%, var(--accent-soft) 0%, transparent 60%),
    radial-gradient(ellipse 60% 40% at 80% 110%, var(--accent-2-soft) 0%, transparent 55%),
    var(--bg);
  position:relative;overflow:hidden;
}
.auth-container::before{
  content:'';position:absolute;inset:0;
  background-image:
    linear-gradient(var(--border) 1px, transparent 1px),
    linear-gradient(90deg, var(--border) 1px, transparent 1px);
  background-size:48px 48px;
  mask-image:radial-gradient(ellipse 60% 50% at 50% 50%, #000 30%, transparent 70%);
  -webkit-mask-image:radial-gradient(ellipse 60% 50% at 50% 50%, #000 30%, transparent 70%);
  opacity:.5;pointer-events:none;
}
.auth-card{
  background:var(--surface-card);
  border:1px solid var(--border);
  border-radius:var(--radius-2xl);
  padding:var(--space-7) var(--space-6);
  width:100%;max-width:400px;
  box-shadow:var(--shadow-2xl);
  position:relative;z-index:1;
}
.auth-logo{display:flex;justify-content:center;margin-bottom:var(--space-5)}
.auth-logo img{width:48px;height:48px;border-radius:var(--radius-md)}
.auth-title{font-family:var(--font-display);font-size:var(--fs-28);font-weight:400;text-align:center;margin-bottom:6px;letter-spacing:-.5px;color:var(--text-1);line-height:1.1}
.auth-title span{color:var(--accent-text)}
.auth-subtitle{text-align:center;color:var(--text-3);font-size:var(--fs-13);margin-bottom:var(--space-6);line-height:1.5}
.auth-link{text-align:center;margin-top:var(--space-4);font-size:var(--fs-12);color:var(--text-3)}
.auth-link a{color:var(--accent-text);font-weight:500}
.auth-link a:hover{text-decoration:underline}
.auth-footer{margin-top:var(--space-6);text-align:center;display:flex;justify-content:center;gap:var(--space-4);font-size:var(--fs-11);color:var(--text-4);position:relative;z-index:1}
.auth-footer a{color:var(--text-3);transition:color var(--motion-fast)}
.auth-footer a:hover{color:var(--text-2)}

/* ===== 23. ALERTS ===== */
.alert{padding:11px 14px;border-radius:var(--radius);font-size:var(--fs-13);margin-bottom:var(--space-4);border:1px solid transparent;line-height:1.5;display:flex;align-items:flex-start;gap:var(--space-2)}
.alert-error{background:var(--red-muted);border-color:rgba(239,68,68,.2);color:var(--red)}
.alert-success{background:var(--green-muted);border-color:rgba(34,197,94,.2);color:var(--green)}
.alert-warning{background:var(--amber-muted);border-color:rgba(245,158,11,.2);color:var(--amber)}
.alert-info{background:var(--blue-muted);border-color:rgba(59,130,246,.2);color:var(--blue)}

/* ===== 24. ANIMATIONS ===== */
@keyframes spin{to{transform:rotate(360deg)}}
@keyframes pulse{0%,100%{opacity:1}50%{opacity:.4}}
@keyframes fadeIn{from{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}
@keyframes slideInUp{from{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}
.pulse{animation:pulse 2s infinite}
.animate-in{animation:fadeIn .25s var(--ease-out)}
.slide-in{animation:slideInUp .3s var(--ease-out)}

@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms !important;transition-duration:.01ms !important}
}

/* ===== 25. RESPONSIVE ===== */
@media(max-width:768px){
  .content{padding:var(--space-4)}
  .header{padding:0 var(--space-4);height:52px}
  .stats-grid{grid-template-columns:repeat(2,1fr);border-radius:var(--radius)}
  .stat-card:first-child{border-radius:var(--radius) 0 0 0}
  .stat-card:nth-child(2){border-radius:0 var(--radius) 0 0}
  .stat-card:last-child{border-radius:0 0 var(--radius) 0}
  .form-grid{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .tabs{padding:0 var(--space-4)}
  .tab{font-size:var(--fs-12);padding:10px 12px}
  .modal{padding:var(--space-5);margin:var(--space-3);border-radius:var(--radius-lg)}
  .auth-card{padding:var(--space-6) var(--space-5)}
  .app-shell{grid-template-columns:1fr}
  .sidebar{display:none}
}

/* ============================================================
 * PÓRTICO HERO PATTERN — global classes pra qualquer página
 * ============================================================ */
.page-hero{padding:24px 0 32px;border-bottom:1px solid var(--border);margin-bottom:32px}
.page-eyebrow{display:inline-flex;align-items:center;gap:10px;font-family:var(--font-sans);font-size:11px;text-transform:uppercase;letter-spacing:.18em;color:var(--text-3);font-weight:500;margin-bottom:18px}
.page-eyebrow::before{content:"";width:24px;height:1px;background:var(--text-3)}
.page-eyebrow .sec{color:var(--accent-text);font-family:var(--font-display);font-style:italic;font-size:14px;letter-spacing:0;text-transform:none;font-weight:500;line-height:1}
.page-display{font-family:var(--font-display);font-weight:400;font-size:40px;line-height:1.1;letter-spacing:-.01em;color:var(--text-1);margin:0}
.page-display em{font-style:italic;color:var(--accent-text);font-weight:400}
.page-display-sub{font-family:var(--font-display);font-weight:400;font-size:18px;color:var(--text-2);font-style:italic;margin-top:8px;line-height:1.4}
.page-display-sub em{font-style:normal;color:var(--text-1);font-weight:500}

.page-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:48px;margin:0 0 56px;padding:32px 0;border-top:1px solid var(--border);border-bottom:1px solid var(--border)}
@media(max-width:900px){.page-stats{gap:32px 48px;padding:24px 0;margin-bottom:40px}}
.page-stats .ps{display:flex;flex-direction:column;gap:8px}
.page-stats .ps-val{font-family:var(--font-display);font-weight:400;font-size:36px;line-height:1;color:var(--text-1);font-variant-numeric:tabular-nums;letter-spacing:-.01em}
.page-stats .ps-val em{font-style:italic;color:var(--accent-text);font-size:.7em;font-weight:500;margin-left:4px}
.page-stats .ps-lab{font-family:var(--font-sans);font-size:10px;text-transform:uppercase;letter-spacing:.16em;color:var(--text-3);font-weight:500}
.page-stats .ps-sub{font-family:var(--font-sans);font-size:11px;color:var(--text-3);margin-top:2px;line-height:1.4}
.page-stats .ps-sub em{font-style:normal;color:var(--text-2)}

/* Auth pages — hero compacto */
.auth-hero{text-align:left;margin-bottom:24px}
.auth-hero .page-eyebrow{justify-content:flex-start;margin-bottom:14px}
.auth-hero .page-display{font-size:32px}
.auth-hero .page-display-sub{font-size:16px;margin-top:6px}
