/* =========================================================================
   LarCare — design system v2.3.0 — PREMIUM A+++
   Inspirado em Linear / Stripe / Vercel / Arc / Superhuman.
   Identidade preservada: sálvia (#3E6B5C) + dourado terroso (#D4A574).

   IMPORTANTE: Os tokens canonical usam prefixos (--color-*, --text-*).
   Aliases bare (sem prefixo) são MANTIDOS por retrocompatibilidade com
   o codebase existente. NÃO REMOVER aliases — quebra ~40 telas.
   ========================================================================= */

/* -------------------------------------------------------------------------
   1. Tokens v2 — Light mode (canonical + legacy aliases)
   ------------------------------------------------------------------------- */
:root {
  /* === SPACING — escala 4 absoluta === */
  --space-0: 0;
  --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: 56px;
  --space-11: 64px;
  --space-12: 80px;
  --space-13: 96px;
  --space-14: 128px;

  /* === TYPOGRAPHY === */
  --font-display: 'Fraunces', Georgia, 'Times New Roman', serif;
  --font-body: 'Inter', -apple-system, BlinkMacSystemFont, 'SF Pro Text', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', 'SF Mono', Menlo, Consolas, monospace;

  --text-2xs: 11px;
  --text-xs: 12px;
  --text-sm: 13px;
  --text-base: 14px;
  --text-md: 15px;
  --text-lg: 17px;
  --text-xl: 20px;
  --text-2xl: 24px;
  --text-3xl: 30px;
  --text-4xl: 36px;
  --text-5xl: 48px;
  --text-6xl: 60px;

  --leading-none: 1;
  --leading-tight: 1.15;
  --leading-snug: 1.3;
  --leading-normal: 1.5;
  --leading-relaxed: 1.65;

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

  --tracking-tighter: -0.03em;
  --tracking-tight: -0.015em;
  --tracking-normal: 0;
  --tracking-wide: 0.01em;
  --tracking-wider: 0.025em;

  /* === COLORS — canonical (prefixados) === */
  --color-bg: #FAF8F4;
  --color-bg-subtle: #F5F2EC;
  --color-surface: #FFFFFF;
  --color-surface-2: #FBFAF6;
  --color-surface-3: #F5F2EC;
  --color-surface-elevated: #FFFFFF;

  --color-primary: #3E6B5C;
  --color-primary-hover: #355C4E;
  --color-primary-active: #2D4F44;
  --color-primary-soft: #E8F0EC;
  --color-primary-softer: #F0F6F3;
  --color-primary-bg: rgba(62, 107, 92, 0.08);

  --color-accent: #D4A574;
  --color-accent-hover: #C49563;
  --color-accent-soft: #FAF1E4;
  --color-accent-bg: rgba(212, 165, 116, 0.1);

  --color-text-primary: #1A2E27;
  --color-text-secondary: #4A5D55;
  --color-text-tertiary: #7A8B83;
  --color-text-quaternary: #A8B5AE;
  --color-text-inverse: #FFFFFF;
  --color-text-link: #3E6B5C;

  --color-border: rgba(26, 46, 39, 0.08);
  --color-border-hover: rgba(26, 46, 39, 0.16);
  --color-border-strong: rgba(26, 46, 39, 0.24);
  --color-border-focus: #3E6B5C;

  --color-success: #4A8B6B;
  --color-success-bg: rgba(74, 139, 107, 0.1);
  --color-warning: #C8924A;
  --color-warning-bg: rgba(200, 146, 74, 0.1);
  --color-danger: #B85450;
  --color-danger-bg: rgba(184, 84, 80, 0.1);
  --color-info: #5A7D9A;
  --color-info-bg: rgba(90, 125, 154, 0.1);

  /* === SHADOWS — camadas físicas premium === */
  --shadow-xs: 0 1px 2px 0 rgba(26, 46, 39, 0.04);
  --shadow-sm: 0 1px 2px 0 rgba(26, 46, 39, 0.06), 0 1px 3px 0 rgba(26, 46, 39, 0.04);
  --shadow-md: 0 2px 4px -1px rgba(26, 46, 39, 0.06), 0 4px 8px -2px rgba(26, 46, 39, 0.04);
  --shadow-lg: 0 4px 8px -2px rgba(26, 46, 39, 0.08), 0 8px 16px -4px rgba(26, 46, 39, 0.06);
  --shadow-xl: 0 8px 16px -4px rgba(26, 46, 39, 0.1), 0 16px 32px -8px rgba(26, 46, 39, 0.08);
  --shadow-2xl: 0 24px 48px -12px rgba(26, 46, 39, 0.18);

  --ring-focus: 0 0 0 4px rgba(62, 107, 92, 0.15);
  --ring-focus-danger: 0 0 0 4px rgba(184, 84, 80, 0.15);

  /* === RADIUS === */
  --radius-xs: 6px;
  --radius-sm: 8px;
  --radius-md: 10px;
  --radius-lg: 12px;
  --radius-xl: 16px;
  --radius-2xl: 20px;
  --radius-3xl: 24px;
  --radius-full: 9999px;

  /* === TIMING === */
  --ease-standard: cubic-bezier(0.4, 0, 0.2, 1);
  --ease-out: cubic-bezier(0.16, 1, 0.3, 1);
  --ease-in-out: cubic-bezier(0.65, 0, 0.35, 1);
  --ease-bounce: cubic-bezier(0.34, 1.56, 0.64, 1);

  --duration-instant: 100ms;
  --duration-fast: 150ms;
  --duration-base: 200ms;
  --duration-slow: 300ms;
  --duration-slower: 500ms;

  /* === Z-INDEX === */
  --z-base: 0;
  --z-raised: 10;
  --z-sticky: 100;
  --z-fixed: 200;
  --z-dropdown: 1000;
  --z-overlay: 2000;
  --z-modal: 3000;
  --z-popover: 4000;
  --z-toast: 5000;

  /* === LAYOUT === */
  --header-height: 56px;
  --bottom-nav-height: 64px;
  --content-max: 480px;
  --content-max-wide: 720px;
  --content-max-xwide: 1080px;

  --safe-top: env(safe-area-inset-top, 0px);
  --safe-bottom: env(safe-area-inset-bottom, 0px);

  /* =========================================================================
     LEGACY ALIASES — apontam pros canonicais. NÃO REMOVER.
     Mantidos pra retrocompat com ~40 telas que ainda usam nomes bare.
     ========================================================================= */
  --bg: var(--color-bg);
  --surface: var(--color-surface);
  --surface-2: var(--color-surface-3);
  --primary: var(--color-primary);
  --primary-dark: var(--color-primary-hover);
  --primary-soft: var(--color-primary);
  --primary-tint: var(--color-primary-soft);
  --accent: var(--color-accent);
  --accent-soft: var(--color-accent-soft);
  --text: var(--color-text-primary);
  --text-dim: var(--color-text-secondary);
  --text-faint: var(--color-text-tertiary);
  --border: var(--color-border);
  --border-strong: var(--color-border-strong);
  --success: var(--color-success);
  --success-soft: var(--color-success-bg);
  --warning: var(--color-warning);
  --warning-soft: var(--color-warning-bg);
  --danger: var(--color-danger);
  --danger-soft: var(--color-danger-bg);

  --shadow-1: var(--shadow-xs);
  --shadow-2: var(--shadow-md);
  --shadow-3: var(--shadow-lg);
  --shadow-focus: var(--ring-focus);

  --radius-pill: var(--radius-full);

  --font-sans: var(--font-body);
  --font-serif: var(--font-display);
  --line-tight: var(--leading-tight);
  --line-normal: var(--leading-normal);

  --container: var(--content-max-xwide);
  --container-narrow: var(--content-max-wide);
  --header-h: 64px; /* legacy: muitos cálculos dependem disso, manter 64 */

  --ease: var(--ease-standard);
  --t-fast: var(--duration-fast);
  --t-base: var(--duration-base);
  --t-slow: var(--duration-slow);

  color-scheme: light;
}

/* -------------------------------------------------------------------------
   2. Tokens v2 — Dark mode (canonical refinado, aliases inherits)
   ------------------------------------------------------------------------- */
:root[data-theme="dark"] {
  --color-bg: #0E1411;
  --color-bg-subtle: #131A16;
  --color-surface: #1A2620;
  --color-surface-2: #1F2D26;
  --color-surface-3: #243530;
  --color-surface-elevated: #2D403A;

  --color-primary: #5DAB8E;
  --color-primary-hover: #6DBA9C;
  --color-primary-active: #7DC9AA;
  --color-primary-soft: rgba(93, 171, 142, 0.15);
  --color-primary-softer: rgba(93, 171, 142, 0.08);
  --color-primary-bg: rgba(93, 171, 142, 0.12);

  --color-accent: #E2BB90;
  --color-accent-hover: #EBC9A2;
  --color-accent-soft: rgba(226, 187, 144, 0.15);
  --color-accent-bg: rgba(226, 187, 144, 0.1);

  --color-text-primary: #ECF0EE;
  --color-text-secondary: #B8C5BF;
  --color-text-tertiary: #8A9B93;
  --color-text-quaternary: #5C6E66;
  --color-text-inverse: #0E1411;
  --color-text-link: #5DAB8E;

  --color-border: rgba(236, 240, 238, 0.08);
  --color-border-hover: rgba(236, 240, 238, 0.16);
  --color-border-strong: rgba(236, 240, 238, 0.24);
  --color-border-focus: #5DAB8E;

  --color-success: #6EB590;
  --color-success-bg: rgba(110, 181, 144, 0.12);
  --color-warning: #E0B260;
  --color-warning-bg: rgba(224, 178, 96, 0.12);
  --color-danger: #D87875;
  --color-danger-bg: rgba(216, 120, 117, 0.12);
  --color-info: #80A4C0;
  --color-info-bg: rgba(128, 164, 192, 0.12);

  --shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, 0.4);
  --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.5), 0 1px 3px 0 rgba(0, 0, 0, 0.4);
  --shadow-md: 0 2px 4px -1px rgba(0, 0, 0, 0.6), 0 4px 8px -2px rgba(0, 0, 0, 0.5);
  --shadow-lg: 0 4px 8px -2px rgba(0, 0, 0, 0.7), 0 8px 16px -4px rgba(0, 0, 0, 0.6);
  --shadow-xl: 0 8px 16px -4px rgba(0, 0, 0, 0.8), 0 16px 32px -8px rgba(0, 0, 0, 0.7);
  --shadow-2xl: 0 24px 48px -12px rgba(0, 0, 0, 0.9);

  --ring-focus: 0 0 0 4px rgba(93, 171, 142, 0.25);
  --ring-focus-danger: 0 0 0 4px rgba(216, 120, 117, 0.25);

  color-scheme: dark;
}

/* Auto-dark via prefers-color-scheme — só se usuário não setou explicitamente */
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]):not([data-theme]) {
    --color-bg: #0E1411;
    --color-bg-subtle: #131A16;
    --color-surface: #1A2620;
    --color-surface-2: #1F2D26;
    --color-surface-3: #243530;
    --color-primary: #5DAB8E;
    --color-primary-hover: #6DBA9C;
    --color-primary-active: #7DC9AA;
    --color-primary-soft: rgba(93, 171, 142, 0.15);
    --color-primary-bg: rgba(93, 171, 142, 0.12);
    --color-accent: #E2BB90;
    --color-accent-soft: rgba(226, 187, 144, 0.15);
    --color-text-primary: #ECF0EE;
    --color-text-secondary: #B8C5BF;
    --color-text-tertiary: #8A9B93;
    --color-text-quaternary: #5C6E66;
    --color-text-inverse: #0E1411;
    --color-border: rgba(236, 240, 238, 0.08);
    --color-border-hover: rgba(236, 240, 238, 0.16);
    --color-border-strong: rgba(236, 240, 238, 0.24);
    --color-border-focus: #5DAB8E;
    --color-success: #6EB590;
    --color-success-bg: rgba(110, 181, 144, 0.12);
    --color-warning: #E0B260;
    --color-warning-bg: rgba(224, 178, 96, 0.12);
    --color-danger: #D87875;
    --color-danger-bg: rgba(216, 120, 117, 0.12);
    color-scheme: dark;
  }
}

/* -------------------------------------------------------------------------
   3. Reset / base premium
   ------------------------------------------------------------------------- */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}
html, body { margin: 0; padding: 0; }
html {
  -webkit-text-size-adjust: 100%;
  -webkit-tap-highlight-color: transparent;
  scroll-behavior: smooth;
  text-rendering: optimizeLegibility;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  font-feature-settings: 'ss01', 'cv11';
}
body {
  font-family: var(--font-body);
  background: var(--color-bg);
  color: var(--color-text-primary);
  font-size: var(--text-base);
  font-weight: var(--font-regular);
  line-height: var(--leading-normal);
  letter-spacing: var(--tracking-normal);
  min-height: 100vh;
  min-height: 100dvh;
  display: flex;
  flex-direction: column;
  overflow-x: hidden;
  transition: background-color var(--duration-base) var(--ease-out),
              color var(--duration-base) var(--ease-out);
}
img, svg, video { display: block; max-width: 100%; height: auto; }
button, input, textarea, select {
  font-family: inherit;
  color: inherit;
}
button {
  background: none;
  border: 0;
  cursor: pointer;
  padding: 0;
  touch-action: manipulation;
  user-select: none;
}
input, textarea {
  font-size: 16px; /* Android Chrome: 16px+ evita auto-zoom no focus */
  -webkit-appearance: none;
  appearance: none;
}
a {
  color: var(--color-text-link);
  text-decoration: none;
  transition: color var(--duration-fast) var(--ease-out);
}
a:hover { color: var(--color-primary-hover); }
:focus-visible {
  outline: none;
  box-shadow: var(--ring-focus);
  border-radius: var(--radius-sm);
}
::selection {
  background: var(--color-primary-soft);
  color: var(--color-primary-active);
}
[data-theme="dark"] ::selection {
  color: var(--color-text-primary);
}
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
    scroll-behavior: auto !important;
  }
}

/* Utilitários tipográficos premium */
.tabular { font-variant-numeric: tabular-nums; }
.tracking-tight { letter-spacing: var(--tracking-tight); }
.tracking-tighter { letter-spacing: var(--tracking-tighter); }
.tracking-wide { letter-spacing: var(--tracking-wide); }

.skip-link {
  position: absolute; top: -40px; left: 12px;
  background: var(--color-primary); color: #fff; padding: 8px 14px;
  border-radius: var(--radius-sm); z-index: 10000;
  transition: top var(--duration-fast) var(--ease-out);
}
.skip-link:focus { top: 12px; color: #fff; }

/* -------------------------------------------------------------------------
   3. Typography
   ------------------------------------------------------------------------- */
h1, h2, h3, h4 { font-family: var(--font-serif); font-weight: 600; color: var(--text); margin: 0; line-height: var(--line-tight); letter-spacing: -0.02em; }
h1 { font-size: clamp(22px, 3.5vw, 30px); line-height: 1.18; letter-spacing: -0.025em; }
h2 { font-size: clamp(18px, 2.6vw, 22px); line-height: 1.22; letter-spacing: -0.02em; }
h3 { font-size: clamp(15px, 1.8vw, 17px); line-height: 1.3; letter-spacing: -0.015em; }
h4 { font-size: 14px; line-height: 1.4; letter-spacing: -0.01em; }
p { margin: 0 0 var(--space-3) 0; }
.eyebrow {
  display: inline-block;
  font-family: var(--font-sans);
  font-size: 10px; font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--primary);
  background: var(--primary-tint);
  padding: 3px 9px; border-radius: var(--radius-pill);
}
.lead { font-size: 14px; color: var(--text-dim); line-height: 1.55; }
.fs-13 { font-size: 13px !important; }
.fs-14 { font-size: 14px !important; }
.t-dim { color: var(--text-dim); }
.t-faint { color: var(--text-faint); }
.t-mono-num { font-variant-numeric: tabular-nums; }
.t-serif { font-family: var(--font-serif); }
.t-center { text-align: center; }

/* -------------------------------------------------------------------------
   4. Layout primitives
   ------------------------------------------------------------------------- */
.app { flex: 1; display: block; outline: none; }
.container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--space-5); }
.container--narrow { max-width: var(--container-narrow); }
.section { padding: var(--space-9) 0; }
.section--tight { padding: var(--space-7) 0; }
.section--alt { background: var(--surface-2); }
.stack > * + * { margin-top: var(--space-4); }
.stack-lg > * + * { margin-top: var(--space-6); }
.stack-xl > * + * { margin-top: var(--space-8); }
.row { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; }
.row--between { justify-content: space-between; }
.row--end { justify-content: flex-end; }
.grid { display: grid; gap: var(--space-5); }
.grid-2 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
.grid-3 { grid-template-columns: repeat(3, minmax(0, 1fr)); }
.grid-4 { grid-template-columns: repeat(4, minmax(0, 1fr)); }
@media (max-width: 720px) {
  .grid-3, .grid-4 { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 480px) {
  .grid-2, .grid-3, .grid-4 { grid-template-columns: 1fr; }
}
.divider { height: 1px; background: var(--border); width: 100%; }
.spacer-4 { height: var(--space-4); }
.spacer-6 { height: var(--space-6); }
.spacer-8 { height: var(--space-8); }
.hide-mobile { display: initial; }
@media (max-width: 720px) { .hide-mobile { display: none !important; } }
.show-mobile { display: none; }
@media (max-width: 720px) { .show-mobile { display: initial; } }

/* -------------------------------------------------------------------------
   5. Header
   ------------------------------------------------------------------------- */
.site-header {
  position: sticky; top: 0; z-index: 100;
  background: rgba(250, 248, 244, 0.85);
  backdrop-filter: saturate(180%) blur(14px);
  -webkit-backdrop-filter: saturate(180%) blur(14px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--t-base) var(--ease), background var(--t-base) var(--ease);
  padding-top: env(safe-area-inset-top);
}
.site-header.is-scrolled { border-bottom-color: var(--border); }
.site-header__inner {
  max-width: var(--container); margin: 0 auto;
  height: var(--header-h); padding: 0 var(--space-5);
  display: flex; align-items: center; justify-content: space-between; gap: var(--space-4);
}
.brand { display: inline-flex; align-items: center; gap: var(--space-2); color: var(--primary); }
.brand__mark { width: 28px; height: 28px; flex: none; }
.brand__name {
  font-family: var(--font-serif); font-weight: 600;
  font-size: 22px; letter-spacing: -0.02em; color: var(--primary);
}
.nav { display: flex; align-items: center; gap: var(--space-5); }
.nav__link {
  color: var(--text); font-weight: 500; font-size: 15px;
  padding: 6px 4px; border-bottom: 2px solid transparent;
  transition: color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
}
.nav__link:hover { color: var(--primary); }
.nav__link.is-active { color: var(--primary); border-bottom-color: var(--primary); }
.header-actions { display: flex; align-items: center; gap: var(--space-2); }
@media (max-width: 860px) {
  .nav { display: none; }
}
.menu-toggle {
  display: none; width: 44px; height: 44px;
  border-radius: var(--radius-sm); align-items: center; justify-content: center;
}
.menu-toggle:hover { background: var(--primary-tint); }
@media (max-width: 860px) {
  .menu-toggle { display: inline-flex; }
}
.mobile-drawer {
  position: fixed; inset: var(--header-h) 0 0 0; background: var(--bg);
  z-index: 99; padding: var(--space-6) var(--space-5);
  display: none; flex-direction: column; gap: var(--space-3);
  overscroll-behavior: contain;
  height: calc(100vh - var(--header-h));
  height: calc(100dvh - var(--header-h));
  overflow-y: auto;
}
.mobile-drawer.is-open { display: flex; animation: drawer-in var(--t-base) var(--ease-out); }
.mobile-drawer .nav__link { font-size: 17px; padding: 12px 0; border-bottom: 1px solid var(--border); }
@keyframes drawer-in { from { opacity: 0; transform: translateY(-8px); } to { opacity: 1; transform: translateY(0); } }

.app-bottom-nav {
  position: fixed; bottom: 0; left: 0; right: 0;
  background: rgba(255,255,255,0.96);
  -webkit-backdrop-filter: blur(12px);
  backdrop-filter: blur(12px);
  border-top: 1px solid var(--border);
  display: flex; justify-content: space-around;
  padding: 6px 0 calc(6px + env(safe-area-inset-bottom));
  z-index: 90;
}
.app-bottom-nav__item {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  font-size: 11px; color: var(--text-dim); padding: 6px 12px; min-width: 64px; min-height: 44px;
  border-radius: var(--radius-sm);
  transition: color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.app-bottom-nav__item.is-active { color: var(--primary); background: var(--primary-tint); }
.app-bottom-nav__icon { width: 22px; height: 22px; }
body.has-bottom-nav main { padding-bottom: calc(64px + env(safe-area-inset-bottom, 0px)); }

/* -------------------------------------------------------------------------
   6. Buttons
   ------------------------------------------------------------------------- */
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: var(--space-2);
  font-family: var(--font-sans); font-weight: 600; font-size: 14px;
  padding: 10px 18px; min-height: 42px;
  border-radius: var(--radius-pill);
  border: 1px solid transparent;
  letter-spacing: -0.01em;
  background: var(--primary); color: #fff;
  cursor: pointer; user-select: none;
  transition: transform var(--t-fast) var(--ease), background var(--t-fast) var(--ease),
              border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease),
              color var(--t-fast) var(--ease);
  text-decoration: none;
  white-space: nowrap;
}
.btn:hover { transform: translateY(-1px); box-shadow: var(--shadow-2); color: #fff; }
.btn:active { transform: translateY(0); box-shadow: var(--shadow-1); }
.btn:disabled, .btn[aria-disabled="true"] { opacity: 0.5; cursor: not-allowed; transform: none; box-shadow: none; }
.btn--primary { background: var(--primary); color: #fff; }
.btn--primary:hover { background: var(--primary-dark); }
.btn--outline {
  background: transparent; color: var(--primary);
  border-color: var(--primary);
}
.btn--outline:hover { background: var(--primary-tint); color: var(--primary-dark); border-color: var(--primary-dark); }
.btn--ghost {
  background: transparent; color: var(--text);
  border-color: transparent;
}
.btn--ghost:hover { background: var(--primary-tint); color: var(--primary-dark); }
.btn--accent { background: var(--accent); color: #2a1d10; }
.btn--accent:hover { background: #c39763; color: #2a1d10; }
.btn--danger-ghost { background: transparent; color: var(--danger); }
.btn--danger-ghost:hover { background: var(--danger-soft); color: var(--danger); }
.btn--sm { padding: 7px 14px; min-height: 36px; font-size: 13px; }
.btn--lg { padding: 14px 24px; min-height: 50px; font-size: 15px; }
.btn--block { width: 100%; }

.btn-group { display: inline-flex; gap: var(--space-2); flex-wrap: wrap; }
.btn-stack { display: flex; flex-direction: column; gap: var(--space-3); }
@media (min-width: 640px) {
  .btn-stack--wide { flex-direction: row; }
}

/* -------------------------------------------------------------------------
   7. Inputs
   ------------------------------------------------------------------------- */
.field { display: block; margin-bottom: var(--space-4); }
.field__label {
  display: block; font-size: 14px; font-weight: 500;
  color: var(--text); margin-bottom: 6px;
}
.field__hint { display: block; font-size: 13px; color: var(--text-dim); margin-top: 4px; }
.field__error { display: block; font-size: 13px; color: var(--danger); margin-top: 4px; min-height: 1em; }
.input, .select, .textarea {
  width: 100%;
  padding: 12px 14px; min-height: 48px;
  background: var(--surface);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 16px; color: var(--text);
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
}
.input::placeholder, .textarea::placeholder { color: var(--text-faint); }
.input:hover, .select:hover, .textarea:hover { border-color: var(--border-strong); }
.input:focus, .select:focus, .textarea:focus { border-color: var(--primary); outline: none; box-shadow: var(--shadow-focus); }
.textarea { min-height: 110px; resize: vertical; line-height: 1.5; }
.select { appearance: none; -webkit-appearance: none; background-image: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='14' height='14' viewBox='0 0 14 14'><path fill='none' stroke='%235C6661' stroke-width='2' stroke-linecap='round' stroke-linejoin='round' d='M3 5l4 4 4-4'/></svg>"); background-repeat: no-repeat; background-position: right 14px center; padding-right: 40px; }
.input-with-prefix { position: relative; }
.input-with-prefix__prefix { position: absolute; left: 14px; top: 50%; transform: translateY(-50%); color: var(--text-dim); pointer-events: none; }
.input-with-prefix .input { padding-left: 36px; }

/* checkbox / radio */
.check { display: flex; gap: var(--space-3); align-items: flex-start; cursor: pointer; padding: 8px 0; }
.check input { margin: 3px 0 0 0; width: 18px; height: 18px; accent-color: var(--primary); flex: none; }
.check__text { font-size: 14px; color: var(--text); line-height: 1.5; }

/* slider */
.slider {
  width: 100%; -webkit-appearance: none; appearance: none;
  height: 6px; border-radius: 999px; background: var(--border); outline: none;
}
.slider::-webkit-slider-thumb {
  -webkit-appearance: none; appearance: none;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--primary); border: 3px solid #fff; box-shadow: 0 2px 6px rgba(0,0,0,0.15);
  cursor: pointer;
}
.slider::-moz-range-thumb {
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--primary); border: 3px solid #fff; box-shadow: 0 2px 6px rgba(0,0,0,0.15);
  cursor: pointer; border: none;
}

/* segmented control */
.segmented {
  display: inline-flex; flex-wrap: wrap; gap: 6px;
  background: var(--surface-2); padding: 6px;
  border-radius: var(--radius-pill);
}
.segmented__item {
  padding: 8px 14px; font-size: 13px; font-weight: 500;
  border-radius: var(--radius-pill); color: var(--text-dim);
  transition: background var(--t-fast), color var(--t-fast);
  cursor: pointer; border: 0;
}
.segmented__item.is-active { background: var(--surface); color: var(--primary); box-shadow: var(--shadow-1); }

/* -------------------------------------------------------------------------
   8. Cards
   ------------------------------------------------------------------------- */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: var(--space-5);
  box-shadow: var(--shadow-1);
  transition: transform var(--t-base) var(--ease), box-shadow var(--t-base) var(--ease), border-color var(--t-base) var(--ease);
}
.card--interactive { cursor: pointer; }
.card--interactive:hover { transform: translateY(-2px); box-shadow: var(--shadow-3); border-color: var(--primary-soft); }
.card--accent { border-color: var(--accent-soft); background: linear-gradient(180deg, #FFFCF6 0%, #FFFFFF 100%); }
.card--soft { background: var(--primary-tint); border: 0; }
.card--feature {
  padding: var(--space-7);
  background: linear-gradient(160deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff; border-color: transparent;
}
.card--feature h2, .card--feature h3 { color: #fff; }
.card--feature .t-dim { color: rgba(255,255,255,0.85); }
.card__title { font-family: var(--font-serif); font-size: 19px; font-weight: 600; margin: 0 0 6px 0; }
.card__meta { font-size: 13px; color: var(--text-dim); }
.card__row { display: flex; gap: var(--space-3); align-items: flex-start; }
.card__row--between { justify-content: space-between; align-items: center; }

/* -------------------------------------------------------------------------
   9. Chips & badges
   ------------------------------------------------------------------------- */
.chip {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: var(--radius-pill);
  background: var(--surface-2); color: var(--text-dim);
  font-size: 13px; font-weight: 500;
  border: 1px solid var(--border);
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease);
  cursor: pointer; user-select: none;
}
.chip:hover { background: var(--primary-tint); color: var(--primary); border-color: var(--primary-soft); }
.chip.is-active { background: var(--primary); color: #fff; border-color: var(--primary); }
.chip--static { cursor: default; }
.chip--static:hover { background: var(--surface-2); color: var(--text-dim); border-color: var(--border); }
.chip--success { background: var(--success-soft); color: var(--success); border-color: rgba(95,139,110,0.3); }
.chip--success:hover { background: var(--success-soft); color: var(--success); }
.chip--warning { background: var(--warning-soft); color: var(--warning); border-color: rgba(198,138,77,0.3); }
.chip--warning:hover { background: var(--warning-soft); color: var(--warning); }
.chip--accent { background: var(--accent-soft); color: #6f4f24; border-color: rgba(212,165,116,0.4); }
.chip--accent:hover { background: var(--accent-soft); color: #6f4f24; }

.badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; font-weight: 600;
  padding: 3px 9px; border-radius: var(--radius-pill);
  background: var(--primary-tint); color: var(--primary);
}
.badge--success { background: var(--success-soft); color: var(--success); }
.badge--warning { background: var(--warning-soft); color: var(--warning); }
.badge--accent { background: var(--accent-soft); color: #6f4f24; }
.badge--solid { background: var(--primary); color: #fff; }

/* -------------------------------------------------------------------------
   10. Avatar & rating
   ------------------------------------------------------------------------- */
.avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--primary-tint); color: var(--primary);
  font-weight: 600; font-size: 17px; flex: none;
  text-transform: uppercase;
  border: 2px solid var(--surface);
}
.avatar--lg { width: 72px; height: 72px; font-size: 26px; }
.avatar--xl { width: 104px; height: 104px; font-size: 36px; }
.avatar--sm { width: 36px; height: 36px; font-size: 13px; }
.avatar--accent { background: var(--accent-soft); color: #6f4f24; }

.rating { display: inline-flex; align-items: center; gap: 6px; font-size: 14px; color: var(--text-dim); }
.rating__stars { display: inline-flex; gap: 2px; color: var(--accent); }
.rating__stars svg { width: 16px; height: 16px; }
.rating__value { font-weight: 600; color: var(--text); }

/* star input */
.stars-input { display: inline-flex; gap: 4px; }
.stars-input button {
  width: 32px; height: 32px; color: var(--border-strong);
  transition: color var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
}
.stars-input button.is-on { color: var(--accent); }
.stars-input button:hover { transform: scale(1.1); }

/* -------------------------------------------------------------------------
   11. Stepper / progress
   ------------------------------------------------------------------------- */
.progress {
  height: 6px; width: 100%;
  background: var(--border);
  border-radius: 999px; overflow: hidden;
}
.progress__bar {
  height: 100%; background: linear-gradient(90deg, var(--primary) 0%, var(--primary-soft) 100%);
  border-radius: 999px; transition: width var(--t-slow) var(--ease);
}

.stepper { display: flex; align-items: center; gap: var(--space-2); margin-bottom: var(--space-6); }
.stepper__step { display: inline-flex; align-items: center; gap: 6px; font-size: 13px; color: var(--text-dim); }
.stepper__dot { width: 24px; height: 24px; border-radius: 50%; background: var(--border); color: var(--text-dim); display: inline-flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 600; }
.stepper__step.is-active .stepper__dot { background: var(--primary); color: #fff; }
.stepper__step.is-done .stepper__dot { background: var(--success); color: #fff; }
.stepper__line { flex: 1; height: 2px; background: var(--border); }
.stepper__step.is-done + .stepper__line { background: var(--success); }

/* horizontal scrollable stepper card variant */
.steps-card {
  display: grid; gap: var(--space-3);
  grid-template-columns: repeat(4, minmax(220px, 1fr));
  padding: var(--space-3);
}
@media (max-width: 920px) {
  .steps-card { grid-template-columns: 1fr; }
}
.steps-card__item {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: var(--space-5);
  position: relative;
}
.steps-card__num {
  width: 36px; height: 36px; border-radius: 50%;
  background: var(--primary-tint); color: var(--primary);
  font-family: var(--font-serif); font-weight: 600; font-size: 18px;
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: var(--space-3);
}

/* -------------------------------------------------------------------------
   12. Toast / modal
   ------------------------------------------------------------------------- */
.toast-root {
  position: fixed; bottom: max(20px, env(safe-area-inset-bottom));
  left: 0; right: 0; display: flex; flex-direction: column; align-items: center;
  gap: var(--space-2); pointer-events: none; z-index: 1000;
}
.toast {
  pointer-events: auto;
  background: var(--text); color: #fff;
  padding: 12px 18px; border-radius: var(--radius-pill);
  font-size: 14px; font-weight: 500;
  box-shadow: var(--shadow-3);
  animation: toast-in var(--t-base) var(--ease-out);
  max-width: 90vw;
}
.toast--success { background: var(--success); }
.toast--error { background: var(--danger); }
@keyframes toast-in { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: translateY(0); } }
@keyframes toast-out { to { opacity: 0; transform: translateY(8px); } }

.modal-root {
  position: fixed; inset: 0; z-index: 1100;
  display: none; align-items: flex-end; justify-content: center;
  background: rgba(31, 42, 40, 0.45);
  padding: var(--space-4);
  -webkit-backdrop-filter: blur(4px);
  backdrop-filter: blur(4px);
  overscroll-behavior: contain;
}
.modal-root[aria-hidden="false"] { display: flex; animation: modal-bg-in var(--t-base) var(--ease); }
.modal {
  background: var(--surface); border-radius: var(--radius-xl) var(--radius-xl) 0 0;
  padding: var(--space-6) var(--space-5) calc(var(--space-6) + env(safe-area-inset-bottom));
  width: 100%; max-width: 540px;
  box-shadow: var(--shadow-3);
  animation: modal-in var(--t-base) var(--ease-out);
}
@media (min-width: 720px) {
  .modal-root { align-items: center; }
  .modal { border-radius: var(--radius-xl); padding: var(--space-7); }
}
@keyframes modal-bg-in { from { opacity: 0; } to { opacity: 1; } }
@keyframes modal-in { from { opacity: 0; transform: translateY(28px) scale(0.985); } to { opacity: 1; transform: translateY(0) scale(1); } }

/* -------------------------------------------------------------------------
   13. Hero
   ------------------------------------------------------------------------- */
.hero {
  position: relative;
  padding: var(--space-9) 0 var(--space-10) 0;
  overflow: hidden;
}
.hero__grid {
  display: grid; grid-template-columns: 1.05fr 0.95fr;
  align-items: center; gap: var(--space-9);
}
@media (max-width: 920px) { .hero__grid { grid-template-columns: 1fr; gap: var(--space-7); } }
.hero__title { font-size: clamp(34px, 5.4vw, 56px); }
.hero__title em { font-style: normal; color: var(--primary); position: relative; }
.hero__title em::after { content: ''; position: absolute; left: 0; right: 0; bottom: 4%; height: 0.18em; background: var(--accent-soft); z-index: -1; border-radius: 4px; }
.hero__subtitle { font-size: clamp(16px, 1.8vw, 19px); color: var(--text-dim); margin-top: var(--space-4); max-width: 540px; }
.hero__cta { margin-top: var(--space-6); display: flex; gap: var(--space-3); flex-wrap: wrap; }
.hero__media {
  position: relative; aspect-ratio: 4 / 5;
  border-radius: var(--radius-xl); overflow: hidden;
  background: linear-gradient(140deg, var(--primary-tint) 0%, var(--accent-soft) 100%);
  box-shadow: var(--shadow-3);
}
.hero__media svg { width: 100%; height: 100%; display: block; }
.hero__floating {
  position: absolute; padding: 12px 14px; background: #fff;
  border-radius: var(--radius-md); box-shadow: var(--shadow-2);
  display: flex; gap: 10px; align-items: center; font-size: 13px;
}
.hero__floating--top-right { top: 22px; right: 22px; }
.hero__floating--bottom-left { bottom: 22px; left: 22px; }

.metric-bar {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-5);
  padding: var(--space-6); background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-lg);
  box-shadow: var(--shadow-1);
}
@media (max-width: 720px) { .metric-bar { grid-template-columns: 1fr; gap: var(--space-4); } }
.metric { text-align: center; }
.metric__value { font-family: var(--font-serif); font-size: 28px; font-weight: 600; color: var(--primary); }
.metric__label { font-size: 13px; color: var(--text-dim); margin-top: 4px; line-height: 1.4; }

/* -------------------------------------------------------------------------
   14. Specific components
   ------------------------------------------------------------------------- */

/* category tile */
.cat-tile {
  display: flex; flex-direction: column; align-items: center; gap: 10px;
  padding: var(--space-5); background: var(--surface);
  border: 1px solid var(--border); border-radius: var(--radius-md);
  transition: all var(--t-base) var(--ease); cursor: pointer; text-align: center;
}
.cat-tile:hover { border-color: var(--primary-soft); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.cat-tile.is-active { border-color: var(--primary); background: var(--primary-tint); }
.cat-tile__icon {
  width: 44px; height: 44px; display: inline-flex; align-items: center; justify-content: center;
  background: var(--primary-tint); border-radius: 50%; color: var(--primary);
}
.cat-tile__name { font-size: 14px; font-weight: 500; color: var(--text); }

/* proposal card */
.proposal {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--space-5); display: grid; gap: var(--space-4);
  transition: all var(--t-base) var(--ease);
}
.proposal:hover { border-color: var(--primary-soft); box-shadow: var(--shadow-2); }
.proposal__head { display: flex; gap: var(--space-3); align-items: center; }
.proposal__name { font-weight: 600; font-size: 16px; color: var(--text); }
.proposal__price {
  font-family: var(--font-serif); font-weight: 600;
  font-size: 28px; color: var(--primary); line-height: 1;
}
.proposal__row { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; font-size: 13px; color: var(--text-dim); }
.proposal__msg { font-size: 14px; color: var(--text); line-height: 1.5; padding: var(--space-3); background: var(--surface-2); border-radius: var(--radius-sm); border-left: 3px solid var(--primary-soft); }
.proposal__cta { display: flex; gap: var(--space-2); margin-top: var(--space-2); flex-wrap: wrap; }

/* mobile-first layout repair for proposal card on narrow screens */
@media (max-width: 520px) {
  .proposal { padding: var(--space-4); gap: var(--space-3); }
  .proposal__head { flex-wrap: wrap; gap: var(--space-3); align-items: flex-start; }
  .proposal__head .avatar--lg { width: 56px; height: 56px; font-size: 22px; }
  .proposal__head > div:not(.avatar):not(.text-right) { flex: 1 1 calc(100% - 68px); min-width: 0; }
  .proposal__head .text-right {
    flex: 1 1 100%;
    display: flex; align-items: baseline; justify-content: flex-start;
    gap: var(--space-3); text-align: left;
    border-top: 1px dashed var(--border); padding-top: var(--space-3); margin-top: 4px;
  }
  .proposal__price { font-size: 26px; }
  .proposal__cta { flex-direction: column; }
  .proposal__cta .btn { width: 100%; justify-content: center; }
}

/* demand card (provider feed) */
.demand {
  background: var(--surface); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: var(--space-5); display: grid; gap: var(--space-3);
  transition: all var(--t-base) var(--ease); cursor: pointer;
}
.demand:hover { border-color: var(--primary-soft); transform: translateY(-2px); box-shadow: var(--shadow-2); }
.demand__head { display: flex; justify-content: space-between; align-items: flex-start; gap: var(--space-3); }
.demand__title { font-family: var(--font-serif); font-size: 18px; font-weight: 600; color: var(--text); margin: 0; }
.demand__meta { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; font-size: 13px; color: var(--text-dim); }
.demand__footer { display: flex; justify-content: space-between; align-items: center; gap: var(--space-3); flex-wrap: wrap; }

@media (max-width: 520px) {
  .demand { padding: var(--space-4); }
  .demand__title { font-size: 16px; }
  .demand__footer { flex-direction: column; align-items: stretch; gap: var(--space-3); }
  .demand__footer > .row { width: 100%; }
  .demand__footer .btn { flex: 1; justify-content: center; }
}

/* status pill list */
.status { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; font-weight: 600; padding: 4px 10px; border-radius: var(--radius-pill); }
.status::before { content: ''; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.status--waiting { background: var(--warning-soft); color: var(--warning); }
.status--proposals { background: var(--primary-tint); color: var(--primary); }
.status--hired { background: var(--accent-soft); color: #6f4f24; }
.status--done { background: var(--success-soft); color: var(--success); }
.status--review { background: rgba(95,139,110,0.18); color: var(--success); }
.status--analysis { background: var(--warning-soft); color: var(--warning); }
.status--approved { background: var(--success-soft); color: var(--success); }

/* timeline */
.timeline { display: flex; flex-direction: column; gap: 4px; padding-left: var(--space-5); position: relative; }
.timeline::before { content: ''; position: absolute; left: 9px; top: 4px; bottom: 4px; width: 2px; background: var(--border); }
.timeline__item { position: relative; padding: 6px 0; font-size: 14px; }
.timeline__item::before { content: ''; position: absolute; left: -19px; top: 12px; width: 12px; height: 12px; border-radius: 50%; background: var(--surface); border: 2px solid var(--border); }
.timeline__item.is-done::before { background: var(--success); border-color: var(--success); }
.timeline__item.is-active::before { background: var(--primary); border-color: var(--primary); box-shadow: 0 0 0 4px var(--primary-tint); }

/* empty state */
.empty {
  text-align: center; padding: var(--space-9) var(--space-5);
  color: var(--text-dim);
}
.empty__icon { width: 56px; height: 56px; margin: 0 auto var(--space-4); color: var(--primary-soft); }

/* check / cross verification list */
.checklist { display: grid; gap: var(--space-3); }
.checklist__item { display: flex; gap: var(--space-3); align-items: flex-start; }
.checklist__check {
  flex: none; width: 28px; height: 28px; border-radius: 50%;
  background: var(--success-soft); color: var(--success);
  display: inline-flex; align-items: center; justify-content: center;
}

/* footer */
.site-footer {
  background: #15201E; /* hardcoded dark — NUNCA usar --text aqui, vira light em dark mode */
  color: #C4CCC9;
  padding: var(--space-7) 0 var(--space-6);
  margin-top: var(--space-9);
}
.site-footer h3, .site-footer h4 { color: #FFFFFF; font-family: var(--font-sans); font-size: 11px; font-weight: 600; text-transform: uppercase; letter-spacing: 0.06em; margin: 0 0 var(--space-3); }
.site-footer .t-dim { color: #8A928E; }
.site-footer a { color: #C4CCC9; transition: color var(--duration-fast); }
.site-footer a:hover { color: #FFFFFF; }
.site-footer p { font-size: 13px; line-height: 1.55; }
.footer-grid { display: grid; grid-template-columns: 1.4fr 1fr 1fr 1fr; gap: var(--space-6); }
@media (max-width: 720px) { .footer-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 480px) { .footer-grid { grid-template-columns: 1fr; } }
.footer-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; font-size: 14px; }
.footer-legal { margin-top: var(--space-7); padding-top: var(--space-5); border-top: 1px solid rgba(255,255,255,0.1); font-size: 12px; color: #8a908d; line-height: 1.6; }
.footer-brand .brand__name { color: #fff; }
.footer-brand .brand { color: #fff; }

/* skeleton */
.skeleton {
  background: linear-gradient(90deg, var(--surface-2) 0%, #efe9da 50%, var(--surface-2) 100%);
  background-size: 200% 100%;
  animation: skeleton 1.4s infinite;
  border-radius: var(--radius-sm);
}
@keyframes skeleton { from { background-position: 200% 0; } to { background-position: -200% 0; } }

/* -------------------------------------------------------------------------
   15. Demo FAB + install banner
   ------------------------------------------------------------------------- */
.demo-fab {
  position: fixed; bottom: max(20px, env(safe-area-inset-bottom));
  right: 20px; z-index: 95;
  background: var(--primary); color: #fff; font-weight: 600;
  padding: 12px 18px 12px 14px;
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-3);
  display: inline-flex; gap: 10px; align-items: center;
  font-size: 14px;
  transition: transform var(--t-fast) var(--ease);
}
.demo-fab:hover { transform: translateY(-2px); }
.demo-fab__pulse {
  width: 10px; height: 10px; border-radius: 50%;
  background: var(--accent); position: relative;
}
.demo-fab__pulse::after {
  content: ''; position: absolute; inset: -3px; border-radius: 50%; border: 2px solid var(--accent);
  animation: pulse 1.6s infinite;
}
@keyframes pulse {
  0% { transform: scale(0.8); opacity: 1; }
  100% { transform: scale(1.8); opacity: 0; }
}

.install-banner {
  position: fixed; left: 12px; right: 12px; bottom: max(12px, env(safe-area-inset-bottom));
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); box-shadow: var(--shadow-3);
  padding: var(--space-4); z-index: 96;
  animation: install-in var(--t-base) var(--ease-out);
}
.install-banner__inner { display: flex; gap: var(--space-3); align-items: center; flex-wrap: wrap; justify-content: space-between; }
.install-banner__copy { display: flex; flex-direction: column; gap: 2px; font-size: 13px; color: var(--text-dim); }
.install-banner__copy strong { color: var(--text); font-size: 14px; }
.install-banner__actions { display: flex; gap: var(--space-2); }
@keyframes install-in { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }

/* tour overlay */
.tour-overlay {
  position: fixed; inset: 0; z-index: 1200; pointer-events: none;
  display: flex; flex-direction: column; align-items: center; justify-content: flex-end;
  padding: 24px;
}
.tour-overlay__caption {
  pointer-events: auto;
  background: var(--text); color: #fff;
  padding: 14px 18px; border-radius: var(--radius-md);
  max-width: 540px; width: 100%;
  box-shadow: var(--shadow-3); font-size: 14px; line-height: 1.5;
  display: flex; gap: var(--space-3); align-items: center; justify-content: space-between;
}
.tour-overlay__caption .tour-step { font-size: 11px; color: var(--accent); font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase; display: block; margin-bottom: 4px; }
.tour-overlay__actions { display: flex; gap: 6px; }
.tour-progress { position: absolute; top: 12px; left: 12px; right: 12px; height: 3px; background: rgba(255,255,255,0.2); border-radius: 999px; overflow: hidden; pointer-events: none; }
.tour-progress__bar { height: 100%; background: var(--accent); transition: width 1s linear; width: 0%; }

/* page transitions */
.app-route { animation: route-in var(--t-base) var(--ease-out); }
@keyframes route-in { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; transform: translateY(0); } }

/* utilities */
.flex-1 { flex: 1; }
.text-right { text-align: right; }
.mt-0 { margin-top: 0; } .mt-2 { margin-top: var(--space-2); } .mt-3 { margin-top: var(--space-3); } .mt-4 { margin-top: var(--space-4); } .mt-5 { margin-top: var(--space-5); } .mt-6 { margin-top: var(--space-6); } .mt-7 { margin-top: var(--space-7); }
.mb-0 { margin-bottom: 0; } .mb-2 { margin-bottom: var(--space-2); } .mb-3 { margin-bottom: var(--space-3); } .mb-4 { margin-bottom: var(--space-4); } .mb-5 { margin-bottom: var(--space-5); }
.fs-13 { font-size: 13px; } .fs-14 { font-size: 14px; } .fs-15 { font-size: 15px; }

/* simple page wrapper */
.page { padding: var(--space-7) 0 var(--space-9); }
.page--app { padding-top: var(--space-5); }
.page-head { margin-bottom: var(--space-6); }
.page-head h1 { font-size: clamp(26px, 4vw, 34px); }

/* file upload tile */
.upload-tile {
  border: 2px dashed var(--border-strong);
  border-radius: var(--radius-md);
  padding: var(--space-5); text-align: center;
  display: flex; flex-direction: column; gap: 6px; align-items: center;
  color: var(--text-dim); transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease);
  cursor: pointer; background: var(--surface);
}
.upload-tile:hover { border-color: var(--primary); background: var(--primary-tint); color: var(--primary); }
.upload-tile__icon { color: var(--primary-soft); }

/* avail grid (provider availability) */
.avail-grid {
  display: grid; grid-template-columns: 80px repeat(3, 1fr); gap: 4px;
  font-size: 12px;
}
.avail-grid__head { font-weight: 600; color: var(--text-dim); text-align: center; padding: 8px 4px; }
.avail-grid__day { font-weight: 500; color: var(--text); padding: 8px 4px; align-self: center; }
.avail-grid__cell {
  background: var(--surface-2); border-radius: var(--radius-sm);
  padding: 12px 4px; text-align: center;
  cursor: pointer; transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
  font-size: 13px; user-select: none;
}
.avail-grid__cell.is-on { background: var(--primary); color: #fff; }

/* photo grid for demand */
.photo-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: var(--space-2); }
.photo-grid__item {
  aspect-ratio: 1; border-radius: var(--radius-sm);
  background: linear-gradient(135deg, var(--primary-tint), var(--accent-soft));
  display: flex; align-items: center; justify-content: center;
  color: var(--primary); font-weight: 500; font-size: 13px;
  border: 1px solid var(--border);
}

/* standalone pages */
.standalone-page { display: flex; align-items: center; justify-content: center; min-height: 100vh; min-height: 100dvh; padding: var(--space-6); background: var(--bg); }
.standalone-page__inner { text-align: center; max-width: 440px; }
.standalone-page__inner img { margin: 0 auto var(--space-4); }
.standalone-page__inner h1 { font-family: var(--font-serif); font-size: 28px; margin-bottom: var(--space-3); }
.standalone-page__inner p { color: var(--text-dim); margin-bottom: var(--space-5); }

/* utility for visually-hidden */
.sr-only { position: absolute; width: 1px; height: 1px; padding: 0; margin: -1px; overflow: hidden; clip: rect(0,0,0,0); white-space: nowrap; border: 0; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { animation-duration: 0.001ms !important; animation-iteration-count: 1 !important; transition-duration: 0.001ms !important; scroll-behavior: auto !important; }
}

/* =========================================================================
   Demo mode: live-feel polish, iOS hardening, bottom nav, demo banner
   ========================================================================= */

/* Skeleton loading boxes (used em empty state da lista de propostas) */
.skeleton {
  display: inline-block;
  background: linear-gradient(90deg, var(--surface-2) 25%, var(--primary-tint) 50%, var(--surface-2) 75%);
  background-size: 200% 100%;
  border-radius: var(--radius-md);
  animation: skeleton-shimmer 1.4s linear infinite;
}
.skeleton--prop { width: 18px; height: 10px; border-radius: var(--radius-pill); }
@keyframes skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

/* Pulse dot (icon contínuo "respirando") */
.pulse-dot { position: relative; animation: pulse-soft 2.4s var(--ease) infinite; }
@keyframes pulse-soft {
  0%, 100% { box-shadow: 0 0 0 0 rgba(62, 107, 92, 0.35); }
  50%      { box-shadow: 0 0 0 12px rgba(62, 107, 92, 0); }
}

/* Pulse badge (contador de propostas — chama atenção quando muda) */
.pulse-badge { animation: pulse-badge 600ms var(--ease-out); }
@keyframes pulse-badge {
  0%   { transform: scale(1); }
  40%  { transform: scale(1.15); }
  100% { transform: scale(1); }
}

/* Check burst (animação curta no checkmark de demanda publicada) */
.check-burst { animation: check-burst 600ms var(--ease-out); }
@keyframes check-burst {
  0%   { transform: scale(0.6); opacity: 0; }
  60%  { transform: scale(1.08); opacity: 1; }
  100% { transform: scale(1); }
}

/* Status pills extras para os novos estados do simulator */
.status--proposals { background: var(--accent-soft); color: #6f4f24; }
.status--hired     { background: var(--success-soft); color: var(--success); }
.status--done      { background: var(--primary-tint); color: var(--primary); }

/* ----------------------------------------------------------------
   Banner Modo Demonstração — "Identity strip"
   Sage gradiente + avatar accent + microcopy bilingue (kicker + identidade)
   + live-dot estilo broadcast indicator. Comunica contexto editorial,
   não warning. Sticky no topo, ≤64px, mobile-first.
   ---------------------------------------------------------------- */
.demo-banner {
  position: sticky;
  top: 0;
  z-index: 110;
  background:
    radial-gradient(120% 220% at 0% 0%, rgba(212, 165, 116, 0.16) 0%, rgba(212, 165, 116, 0) 55%),
    linear-gradient(135deg, var(--primary) 0%, var(--primary-dark) 100%);
  color: #fff;
  font-family: var(--font-sans);
  padding-top: env(safe-area-inset-top, 0px);
  border-bottom: 1px solid rgba(255, 255, 255, 0.08);
  box-shadow: 0 1px 0 rgba(31, 42, 40, 0.04), 0 2px 12px rgba(31, 42, 40, 0.08);
  animation: demo-banner-in 420ms var(--ease-out) both;
  isolation: isolate;
}
@keyframes demo-banner-in {
  0%   { transform: translateY(-100%); opacity: 0; }
  60%  { opacity: 1; }
  100% { transform: translateY(0); opacity: 1; }
}
.demo-banner.is-dismissing {
  animation: demo-banner-out 240ms var(--ease) forwards;
  pointer-events: none;
}
@keyframes demo-banner-out {
  to { transform: translateY(-100%); opacity: 0; }
}

.demo-banner__inner {
  position: relative;
  display: flex;
  align-items: center;
  gap: 10px;
  max-width: var(--container);
  margin: 0 auto;
  padding: 8px 12px;
  padding-left: max(12px, env(safe-area-inset-left));
  /* Reserva 40px à direita pro botão × absoluto */
  padding-right: max(44px, calc(env(safe-area-inset-right) + 40px));
  line-height: 1.2;
}

/* Avatar das iniciais — borda accent fina para destacar do gradiente sage */
.demo-banner__avatar {
  flex: 0 0 auto;
  width: 36px;
  height: 36px;
  font-size: 13px;
  font-weight: 600;
  box-shadow: 0 0 0 1.5px rgba(212, 165, 116, 0.55), 0 1px 3px rgba(31, 42, 40, 0.18);
}

/* Bloco de texto — empilha eyebrow (modo demo + dot) sobre identidade */
.demo-banner__copy {
  display: flex;
  flex-direction: column;
  gap: 1px;
  min-width: 0;
  flex: 1 1 auto;
}

/* Eyebrow: kicker em caixa-alta espaçada + dot pulsante "ao vivo" */
.demo-banner__eyebrow {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-family: var(--font-sans);
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: rgba(255, 255, 255, 0.72);
}
.demo-banner__kicker { white-space: nowrap; }

/* Live dot accent — peça que vira o banner em "broadcast indicator", não warning */
.demo-banner__dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--accent);
  box-shadow: 0 0 0 0 rgba(212, 165, 116, 0.65);
  animation: demo-banner-pulse 2s var(--ease) infinite;
  flex: 0 0 auto;
}
@keyframes demo-banner-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(212, 165, 116, 0.55); transform: scale(1); }
  70%  { box-shadow: 0 0 0 7px rgba(212, 165, 116, 0);     transform: scale(1.05); }
  100% { box-shadow: 0 0 0 0   rgba(212, 165, 116, 0);     transform: scale(1); }
}

/* Identidade: nome em Fraunces (peso editorial) + lugar em Inter (peso info) */
.demo-banner__identity {
  display: inline-flex;
  align-items: baseline;
  gap: 8px;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.demo-banner__name {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 15px;
  letter-spacing: 0.005em;
  color: #fff;
  flex: 0 0 auto;
}
.demo-banner__name::before {
  content: "como ";
  font-family: var(--font-sans);
  font-weight: 400;
  font-size: 12px;
  color: rgba(255, 255, 255, 0.6);
  margin-right: 2px;
  letter-spacing: 0;
}
.demo-banner__place {
  font-size: 12.5px;
  font-weight: 400;
  color: rgba(255, 255, 255, 0.72);
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  position: relative;
  padding-left: 9px;
}
.demo-banner__place::before {
  content: "";
  position: absolute;
  left: 0;
  top: 50%;
  width: 3px;
  height: 3px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.32);
  transform: translateY(-50%);
}

/* Botão de fechar — × redondo, área de toque 32px, ancorado absoluto */
.demo-banner__close {
  position: absolute;
  top: 50%;
  right: max(6px, env(safe-area-inset-right));
  transform: translateY(-50%);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: rgba(255, 255, 255, 0.06);
  color: rgba(255, 255, 255, 0.72);
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.demo-banner__close:hover,
.demo-banner__close:focus-visible {
  background: rgba(255, 255, 255, 0.18);
  color: #fff;
  outline: none;
}
.demo-banner__close:active { transform: translateY(-50%) scale(0.92); }

/* ≤420px: comprime sem quebrar. Esconde "como" e o bullet do lugar;
   o lugar quebra pra próxima linha embaixo do nome. Altura ainda ≤64px. */
@media (max-width: 420px) {
  .demo-banner__inner { gap: 9px; padding: 7px 12px; padding-right: max(42px, calc(env(safe-area-inset-right) + 40px)); }
  .demo-banner__avatar { width: 34px; height: 34px; font-size: 12.5px; }
  .demo-banner__identity { gap: 0; flex-direction: column; align-items: flex-start; white-space: normal; }
  .demo-banner__name { font-size: 14.5px; }
  .demo-banner__name::before { display: none; }
  .demo-banner__place { padding-left: 0; font-size: 11.5px; line-height: 1.25; }
  .demo-banner__place::before { display: none; }
  .demo-banner__eyebrow { font-size: 9px; }
}

/* PWA standalone: instância instalada não precisa do aviso */
@media (display-mode: standalone) {
  .demo-banner { display: none !important; }
}

/* Reduced motion: zero animação de entrada/saída/pulse */
@media (prefers-reduced-motion: reduce) {
  .demo-banner,
  .demo-banner.is-dismissing,
  .demo-banner__dot { animation: none !important; }
  .demo-banner.is-dismissing { opacity: 0; transform: translateY(-100%); }
}

/* ----------------------------------------------------------------
   Banner "Atualizar agora" — versão accent, slide-up de baixo
   Aparece quando o SW detecta nova versão instalada e há controller
   anterior. Dispensa volta no próximo ciclo de update.
   ---------------------------------------------------------------- */
.update-banner {
  position: fixed;
  left: 0; right: 0;
  bottom: 0;
  z-index: 200; /* acima do bottom-nav e do toast-root */
  background: linear-gradient(135deg, var(--accent) 0%, #B98A52 100%);
  color: #1F2A28;
  padding-bottom: env(safe-area-inset-bottom, 0px);
  box-shadow: 0 -4px 16px rgba(31, 42, 40, 0.12), 0 -1px 0 rgba(31, 42, 40, 0.08);
  animation: update-banner-in 420ms var(--ease-out) both;
  font-family: var(--font-sans);
  isolation: isolate;
}
body.has-bottom-nav .update-banner { bottom: calc(64px + env(safe-area-inset-bottom, 0px)); }
@keyframes update-banner-in {
  0%   { transform: translateY(100%); opacity: 0; }
  100% { transform: translateY(0); opacity: 1; }
}

.update-banner__inner {
  display: flex;
  align-items: center;
  gap: 12px;
  max-width: 720px;
  margin: 0 auto;
  padding: 12px 16px;
  padding-left: max(16px, env(safe-area-inset-left));
  padding-right: max(16px, env(safe-area-inset-right));
}

.update-banner__icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: rgba(31, 42, 40, 0.10);
  color: var(--primary-dark);
  flex: 0 0 auto;
  animation: update-pulse 2.4s var(--ease) infinite;
}
@keyframes update-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(31, 42, 40, 0.20); }
  50%      { box-shadow: 0 0 0 10px rgba(31, 42, 40, 0); }
}

.update-banner__label {
  display: flex;
  flex-direction: column;
  flex: 1 1 auto;
  min-width: 0;
  line-height: 1.3;
  font-size: 13px;
}
.update-banner__label strong { font-weight: 600; font-size: 14px; color: #1F2A28; }
.update-banner__hint { color: rgba(31, 42, 40, 0.72); font-size: 12px; }
@media (max-width: 420px) { .update-banner__hint { display: none; } }

.update-banner__cta {
  background: var(--primary);
  color: #fff;
  border: 0;
  border-radius: var(--radius-pill);
  padding: 10px 16px;
  font-weight: 600;
  font-size: 13px;
  cursor: pointer;
  white-space: nowrap;
  min-height: 38px;
  touch-action: manipulation;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  flex: 0 0 auto;
  box-shadow: 0 2px 6px rgba(31, 42, 40, 0.12);
}
.update-banner__cta:hover { background: var(--primary-dark); }
.update-banner__cta:active { transform: scale(0.96); }
.update-banner__cta:disabled { opacity: 0.6; cursor: progress; }

@media (prefers-reduced-motion: reduce) {
  .update-banner, .update-banner__icon { animation: none !important; }
}

/* ----------------------------------------------------------------
   Bottom nav fixa (mobile only)
   ---------------------------------------------------------------- */
.app-bottom-nav {
  position: fixed; left: 0; right: 0; bottom: 0;
  z-index: 100;
  display: none;
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 6px env(safe-area-inset-right) calc(env(safe-area-inset-bottom, 0px) + 6px) env(safe-area-inset-left);
  box-shadow: 0 -4px 16px rgba(31, 42, 40, 0.04);
}
.app-bottom-nav__inner {
  display: grid; grid-template-columns: repeat(4, 1fr);
  max-width: 480px; margin: 0 auto;
}
.app-bottom-nav__item {
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  padding: 6px 4px;
  color: var(--text-dim);
  font-size: 11px; font-weight: 500;
  text-decoration: none;
  min-height: 44px;
  touch-action: manipulation;
  position: relative;
  transition: color var(--t-fast) var(--ease);
}
.app-bottom-nav__item.is-active { color: var(--primary); }
.app-bottom-nav__item.is-active::before {
  content: ''; position: absolute; top: -7px; left: 50%; transform: translateX(-50%);
  width: 28px; height: 3px; background: var(--primary); border-radius: 999px;
}
.app-bottom-nav__item svg { display: block; }
.app-bottom-nav__badge {
  position: absolute; top: 0px; right: calc(50% - 18px);
  background: var(--accent); color: #1F2A28;
  border-radius: 999px; font-size: 10px; font-weight: 700;
  min-width: 16px; height: 16px;
  display: inline-flex; align-items: center; justify-content: center;
  padding: 0 4px;
}
body.has-bottom-nav .app-content,
body.has-bottom-nav .app { padding-bottom: 80px; }
body.has-bottom-nav .install-banner { bottom: 64px; }
@media (max-width: 720px) {
  .app-bottom-nav { display: block; }
}

/* ----------------------------------------------------------------
   Catálogo agrupado (clientNewDemand step 1)
   ---------------------------------------------------------------- */
.cat-group + .cat-group { margin-top: var(--space-7); }
.cat-group__title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 600;
  color: var(--text);
  margin: 0 0 var(--space-4) 0;
}
.cat-group__emoji {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--primary-tint);
  font-size: 16px;
  line-height: 1;
}
.cat-group__grid {
  display: grid;
  gap: var(--space-3);
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (min-width: 720px)  { .cat-group__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (min-width: 1024px) { .cat-group__grid { grid-template-columns: repeat(6, minmax(0, 1fr)); } }
@media (max-width: 380px)  { .cat-group__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

/* Tile emoji-first (substitui o ícone SVG na variante --emoji) */
.cat-tile--emoji {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 8px 12px;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  min-height: 96px;
  cursor: pointer;
  transition: border-color var(--t-fast) var(--ease), background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  text-align: center;
  touch-action: manipulation;
}
.cat-tile--emoji:hover { border-color: var(--primary-soft); background: var(--bg); }
.cat-tile--emoji:active { transform: scale(0.97); }
.cat-tile--emoji.is-active {
  border-color: var(--primary);
  background: var(--primary-tint);
  box-shadow: 0 0 0 3px rgba(62, 107, 92, 0.12);
}
.cat-tile__emoji {
  font-size: 28px;
  line-height: 1;
}
.cat-tile--emoji .cat-tile__name {
  font-size: 12.5px;
  font-weight: 500;
  color: var(--text);
  line-height: 1.25;
}
.cat-tile--emoji.is-active .cat-tile__name { color: var(--primary-dark); font-weight: 600; }

/* ----------------------------------------------------------------
   iOS Safari hardening
   ---------------------------------------------------------------- */
html, body {
  -webkit-tap-highlight-color: transparent;
}
*, *::before, *::after {
  -webkit-tap-highlight-color: transparent;
}
.btn, .cat-tile, .chip, .nav__link, .segmented__item, [data-link],
.app-bottom-nav__item, .demo-fab, .install-banner button {
  touch-action: manipulation;
}
/* Inputs ≥16px previnem zoom-on-focus no iOS */
.input, .textarea, input, textarea, select {
  font-size: 16px;
}
/* Scroll suave em listas internas em iOS */
.scroll-inner { -webkit-overflow-scrolling: touch; }
/* Safe area no header e footer */
.site-header { padding-top: env(safe-area-inset-top); }
.site-footer { padding-bottom: env(safe-area-inset-bottom); }
.demo-fab {
  bottom: calc(env(safe-area-inset-bottom, 0px) + 24px);
}
body.has-bottom-nav .demo-fab {
  bottom: calc(env(safe-area-inset-bottom, 0px) + 88px);
}

/* Toast notifications stacking — empilha múltiplos toasts */
/* NOTA: substitui a definição original de .toast-root da seção 12.
   Definidas explicitamente right:auto e width pra evitar conflito com
   right:0 da regra anterior (que causava toast-root com largura 50% do
   viewport e toasts longos truncavam). */
.toast-root {
  position: fixed;
  left: 50%;
  right: auto;
  width: max-content;
  max-width: calc(100vw - 32px);
  bottom: calc(env(safe-area-inset-bottom, 0px) + 24px);
  transform: translateX(-50%);
  z-index: 1000;
  display: flex; flex-direction: column-reverse; align-items: center; gap: 8px;
  pointer-events: none;
}
body.has-bottom-nav .toast-root { bottom: calc(env(safe-area-inset-bottom, 0px) + 88px); }
.toast { pointer-events: auto; }

/* ----------------------------------------------------------------
   Bottom sheet de instalação PWA
   3 variantes (android/ios/in-app) renderizadas dinamicamente.
   Slide-up de baixo, drag handle, swipe-to-dismiss, focus trap.
   ---------------------------------------------------------------- */
body.no-scroll { overflow: hidden; }

.install-sheet {
  position: fixed; inset: 0; z-index: 500;
  display: flex; align-items: flex-end; justify-content: center;
}
.install-sheet[hidden] { display: none; }

.install-sheet__backdrop {
  position: absolute; inset: 0;
  background: rgba(31, 42, 40, 0.5);
  backdrop-filter: blur(4px);
  -webkit-backdrop-filter: blur(4px);
  opacity: 0;
  transition: opacity 200ms var(--ease);
}
.install-sheet.is-open .install-sheet__backdrop { opacity: 1; }
.install-sheet.is-closing .install-sheet__backdrop { opacity: 0; }

.install-sheet__card {
  position: relative;
  width: 100%;
  max-width: 480px;
  background: var(--surface);
  border-top-left-radius: 24px;
  border-top-right-radius: 24px;
  padding: 12px 24px max(32px, calc(env(safe-area-inset-bottom, 0px) + 24px));
  box-shadow: 0 -8px 32px rgba(31, 42, 40, 0.18);
  transform: translateY(100%);
  transition: transform 280ms cubic-bezier(0.16, 1, 0.3, 1);
  font-family: var(--font-sans);
  max-height: 88vh;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.install-sheet.is-open .install-sheet__card { transform: translateY(0); }
.install-sheet.is-closing .install-sheet__card { transform: translateY(100%); transition: transform 240ms var(--ease); }

@media (min-width: 720px) {
  .install-sheet { align-items: center; padding: 24px; }
  .install-sheet__card { border-radius: 24px; max-width: 420px; }
  .install-sheet__handle { display: none; }
}

.install-sheet__handle {
  width: 36px; height: 4px;
  background: var(--border-strong);
  border-radius: 999px;
  margin: 0 auto 16px;
}

.install-sheet__close {
  position: absolute; top: 18px; right: 18px;
  width: 32px; height: 32px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-dim);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
  transition: background var(--t-fast) var(--ease), color var(--t-fast) var(--ease);
}
.install-sheet__close:hover { background: var(--border); color: var(--text); }
.install-sheet__close:active { transform: scale(0.92); }

.install-sheet__body { padding-top: 8px; }

.install-sheet__art {
  display: flex; justify-content: center;
  margin: 8px 0 20px;
}

.install-sheet__title {
  font-family: var(--font-serif);
  font-size: 22px; font-weight: 600; letter-spacing: -0.01em;
  text-align: center; margin: 0 0 8px; color: var(--text);
}
.install-sheet__hint {
  text-align: center; font-size: 14px; color: var(--text-dim);
  line-height: 1.5; margin: 0 0 20px;
}

.install-sheet__feature-list {
  list-style: none; padding: 0; margin: 0 0 24px;
  display: flex; flex-direction: column; gap: 10px;
}
.install-sheet__feature-list li {
  display: flex; align-items: center; gap: 12px;
  font-size: 14px; color: var(--text); font-weight: 500;
}
.install-sheet__check {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  background: var(--success-soft); color: var(--success);
  font-weight: 700; font-size: 12px;
}

.install-sheet__steps {
  list-style: none; padding: 0; margin: 0 0 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.install-sheet__step {
  display: flex; align-items: center; gap: 12px;
  padding: 14px;
  background: var(--surface-2);
  border-radius: 14px;
  border: 1px solid var(--border);
  animation: install-step-in 320ms var(--ease-out) both;
  animation-delay: var(--delay, 0ms);
}
@keyframes install-step-in {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.install-sheet__step-num {
  flex: 0 0 auto;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--primary); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 600; font-size: 13px; font-family: var(--font-serif);
}
.install-sheet__step-icon {
  flex: 0 0 auto;
  display: inline-flex; align-items: center; justify-content: center;
  width: 32px; height: 32px; color: var(--primary);
}
.install-sheet__step-text {
  flex: 1; font-size: 14px; line-height: 1.4; color: var(--text);
}
.install-sheet__step-text strong { font-weight: 600; color: var(--primary-dark); }

.install-sheet__fallback {
  font-size: 12px; color: var(--text-faint);
  text-align: center; margin: 0 0 16px; font-style: italic;
}

.install-sheet__cta {
  width: 100%; height: 52px; border-radius: 14px;
  background: var(--primary); color: #fff;
  font-weight: 600; font-size: 15px;
  cursor: pointer; border: 0;
  transition: background var(--t-fast) var(--ease), transform var(--t-fast) var(--ease);
  touch-action: manipulation;
  margin-bottom: 8px;
}
.install-sheet__cta:hover { background: var(--primary-dark); }
.install-sheet__cta:active { transform: scale(0.98); }
.install-sheet__cta:disabled { opacity: 0.6; cursor: progress; }

.install-sheet__secondary {
  width: 100%; height: 44px;
  background: transparent; color: var(--text-dim);
  font-weight: 500; font-size: 14px;
  cursor: pointer; border: 0;
  touch-action: manipulation;
}
.install-sheet__secondary:hover { color: var(--text); }

@media (prefers-reduced-motion: reduce) {
  .install-sheet__backdrop, .install-sheet__card,
  .install-sheet__step { animation: none !important; transition: opacity 100ms linear; }
  .install-sheet__card { transform: none; }
}

/* =========================================================================
   BUSCA — search bar, filtros, card de resultado
   ========================================================================= */
.search-page { padding-bottom: 80px; }
.search-bar-wrap {
  position: sticky; top: 0; z-index: 50;
  background: var(--bg);
  padding-top: var(--space-3);
  padding-bottom: var(--space-3);
  border-bottom: 1px solid var(--border);
}
.search-bar {
  position: relative;
  display: flex; align-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 0 12px;
  height: 48px;
  transition: border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.search-bar:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(62,107,92,0.12); }
.search-bar__icon { color: var(--text-dim); display: inline-flex; align-items: center; margin-right: 8px; }
.search-bar__input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font-size: 16px; color: var(--text); height: 100%;
}
.search-bar__input::placeholder { color: var(--text-faint); }
.search-bar__clear {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-dim);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; transition: background var(--t-fast);
}
.search-bar__clear:hover { background: var(--border); color: var(--text); }

.search-actions {
  display: flex; gap: 8px; margin-top: 10px; align-items: center;
}
.search-action {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 6px 12px; border-radius: var(--radius-pill);
  background: var(--surface); color: var(--text);
  border: 1px solid var(--border); cursor: pointer;
  font-size: 13px; font-weight: 500;
  transition: background var(--t-fast), border-color var(--t-fast);
  touch-action: manipulation;
}
.search-action:hover { background: var(--surface-2); border-color: var(--border-strong); }
.search-action__badge {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--primary); color: #fff;
  border-radius: 10px; padding: 0 6px; height: 18px;
  font-size: 11px; font-weight: 700;
}

.search-history {
  background: var(--surface);
  padding: 12px 16px; border-radius: var(--radius-md);
  border: 1px solid var(--border);
}
.search-history__list { display: flex; flex-wrap: wrap; gap: 6px; }

.search-card {
  display: flex; gap: 12px; padding: 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer;
  transition: border-color var(--t-fast), box-shadow var(--t-fast);
}
.search-card:hover { border-color: var(--primary-soft); box-shadow: 0 4px 12px rgba(31,42,40,0.06); }
.search-card:active { transform: scale(0.995); }
.search-card__avatar { position: relative; flex: 0 0 auto; }
.search-card__verified {
  position: absolute; bottom: -2px; right: -2px;
  width: 18px; height: 18px; border-radius: 50%;
  background: var(--success); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 11px; font-weight: 700;
  border: 2px solid var(--surface);
}
.search-card__body { flex: 1; min-width: 0; }
.search-card__name { font-weight: 600; font-size: 15px; color: var(--text); }
.search-card__meta { display: flex; flex-wrap: wrap; gap: 4px; margin-top: 4px; }
.search-card__chip {
  font-size: 11px; padding: 2px 8px;
  background: var(--primary-tint); color: var(--primary-dark);
  border-radius: 999px; font-weight: 500;
}
.search-card__rating {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 14px; color: var(--text);
}

.search-empty {
  padding: 48px 16px;
  background: var(--surface);
  border-radius: var(--radius-md);
  border: 1px dashed var(--border);
}
.search-empty__art { font-size: 56px; line-height: 1; }

.btn-link {
  background: none; border: 0; padding: 0;
  color: var(--primary); cursor: pointer;
  font-size: 13px; font-weight: 500;
  text-decoration: underline;
}
.btn-link--sm { font-size: 11px; }

/* =========================================================================
   BOTTOM SHEET genérico (filtros, ordenação) — reusa estilo do install-sheet
   ========================================================================= */
.bottom-sheet {
  position: fixed; inset: 0; z-index: 600;
  display: flex; align-items: flex-end; justify-content: center;
}
.bottom-sheet__backdrop {
  position: absolute; inset: 0;
  background: rgba(31, 42, 40, 0.5);
  opacity: 0;
  transition: opacity 200ms var(--ease);
}
.bottom-sheet.is-open .bottom-sheet__backdrop { opacity: 1; }
.bottom-sheet__card {
  position: relative; width: 100%; max-width: 480px;
  background: var(--surface);
  border-top-left-radius: 24px; border-top-right-radius: 24px;
  padding: 12px 20px max(28px, calc(env(safe-area-inset-bottom, 0px) + 20px));
  transform: translateY(100%);
  transition: transform 280ms cubic-bezier(0.16,1,0.3,1);
  max-height: 80vh; overflow-y: auto;
  -webkit-overflow-scrolling: touch;
}
.bottom-sheet.is-open .bottom-sheet__card { transform: translateY(0); }
.bottom-sheet__handle {
  width: 36px; height: 4px; background: var(--border-strong);
  border-radius: 999px; margin: 0 auto 12px;
}
.bottom-sheet__title {
  font-family: var(--font-serif); font-size: 18px; font-weight: 600;
  margin: 0 0 16px;
}
.bottom-sheet__close {
  position: absolute; top: 16px; right: 16px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-dim);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer;
}
.bottom-sheet__body { padding: 0 0 12px; }
.bottom-sheet__card--short { padding-top: 16px; }
.bottom-sheet__footer {
  display: flex; gap: 8px; padding-top: 12px;
  border-top: 1px solid var(--border);
}
.bottom-sheet__footer .btn { flex: 1; }

.filter-section { padding: 12px 0; border-bottom: 1px solid var(--border); }
.filter-section:last-child { border-bottom: 0; }
.filter-section__label { display: block; font-size: 13px; font-weight: 600; color: var(--text); margin-bottom: 8px; }
.filter-chips { display: flex; flex-wrap: wrap; gap: 6px; }
.filter-stars { display: flex; align-items: center; gap: 4px; }
.filter-star {
  background: none; border: 0; cursor: pointer;
  font-size: 24px; color: var(--border-strong);
  padding: 4px;
  transition: color var(--t-fast);
}
.filter-star.is-on { color: var(--accent); }

.sort-option {
  display: flex; align-items: center; justify-content: space-between;
  width: 100%; padding: 14px 0; border-bottom: 1px solid var(--border);
  background: none; cursor: pointer; text-align: left;
  font-size: 15px; color: var(--text);
}
.sort-option:last-child { border-bottom: 0; }
.sort-option.is-active { color: var(--primary); font-weight: 600; }

/* =========================================================================
   CHAT — WhatsApp-style
   ========================================================================= */
.chat-page {
  display: flex; flex-direction: column;
  height: 100vh; height: 100dvh;
  background: linear-gradient(180deg, #F5F0E5 0%, #FAF8F4 100%);
}
.chat-header {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 16px;
  padding-top: max(14px, calc(env(safe-area-inset-top, 0px) + 14px));
  background: var(--primary);
  color: #fff;
  position: sticky; top: 0; z-index: 10;
}
.chat-header__back {
  background: none; border: 0; color: #fff; cursor: pointer;
  width: 36px; height: 36px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}
.chat-header__back:hover { background: rgba(255,255,255,0.12); }
.chat-header__info { flex: 1; min-width: 0; }
.chat-header__name { font-weight: 600; font-size: 15px; line-height: 1.2; }
.chat-header__status { font-size: 12px; opacity: 0.78; }

.chat-body {
  flex: 1; overflow-y: auto;
  padding: 16px 12px;
  display: flex; flex-direction: column; gap: 6px;
  -webkit-overflow-scrolling: touch;
}
.chat-system {
  align-self: center;
  background: rgba(62, 107, 92, 0.08);
  color: var(--primary-dark);
  font-size: 12px; padding: 6px 12px;
  border-radius: 999px;
  margin: 8px 0;
}
.chat-row { display: flex; }
.chat-row--me { justify-content: flex-end; }
.chat-row--them { justify-content: flex-start; }

.chat-bubble {
  max-width: 78%;
  padding: 8px 12px 6px;
  border-radius: 16px;
  box-shadow: 0 1px 2px rgba(31,42,40,0.06);
  position: relative;
  word-wrap: break-word;
}
.chat-bubble--me {
  background: var(--primary);
  color: #fff;
  border-bottom-right-radius: 4px;
}
.chat-bubble--them {
  background: var(--surface);
  color: var(--text);
  border-bottom-left-radius: 4px;
}
.chat-bubble__text { display: block; font-size: 14.5px; line-height: 1.4; }
.chat-bubble__time {
  display: block; text-align: right; font-size: 10.5px;
  margin-top: 2px; opacity: 0.72;
}
.chat-bubble--me .chat-bubble__time { color: rgba(255,255,255,0.78); }
.chat-bubble--them .chat-bubble__time { color: var(--text-faint); }
.chat-bubble__tick { display: inline-block; margin-left: 4px; letter-spacing: -1px; }
.chat-bubble__tick.is-read { color: #5AB1E8; }

.chat-bubble--typing {
  padding: 10px 14px;
  display: inline-flex; gap: 4px; align-items: center;
}
.chat-bubble--typing span {
  width: 7px; height: 7px; border-radius: 50%;
  background: var(--text-faint);
  animation: chat-typing 1.2s var(--ease) infinite;
}
.chat-bubble--typing span:nth-child(2) { animation-delay: 0.15s; }
.chat-bubble--typing span:nth-child(3) { animation-delay: 0.3s; }
@keyframes chat-typing {
  0%, 80%, 100% { opacity: 0.3; transform: translateY(0); }
  40% { opacity: 1; transform: translateY(-3px); }
}

.chat-composer {
  display: flex; align-items: flex-end; gap: 8px;
  padding: 8px 12px;
  padding-bottom: max(8px, calc(env(safe-area-inset-bottom, 0px) + 8px));
  background: var(--surface);
  border-top: 1px solid var(--border);
}
.chat-composer__attach,
.chat-composer__send {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-dim);
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; border: 0;
  transition: background var(--t-fast), color var(--t-fast);
  flex: 0 0 auto;
}
.chat-composer__send { background: var(--primary); color: #fff; }
.chat-composer__send:disabled { background: var(--surface-2); color: var(--text-faint); cursor: not-allowed; }
.chat-composer__send:not(:disabled):hover { background: var(--primary-dark); }
.chat-composer__input {
  flex: 1; min-height: 40px; max-height: 120px;
  padding: 10px 14px;
  background: var(--surface-2);
  border: 0; border-radius: 20px;
  font-size: 16px; line-height: 1.4;
  resize: none; outline: 0;
  font-family: var(--font-sans);
}

/* Chat list (conversas) */
.chat-list-item {
  display: flex; gap: 12px;
  padding: 12px 16px;
  background: var(--surface);
  border-radius: var(--radius-md);
  border: 1px solid var(--border);
  text-decoration: none; color: inherit;
  transition: background var(--t-fast);
}
.chat-list-item:hover { background: var(--surface-2); }
.chat-list-item__body { flex: 1; min-width: 0; }
.chat-list-item__preview {
  color: var(--text-dim); font-size: 13px;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  flex: 1; min-width: 0;
}
.chat-list-item__badge {
  background: var(--primary); color: #fff;
  border-radius: 999px; padding: 2px 8px;
  font-size: 11px; font-weight: 700;
  min-width: 18px; height: 18px;
  display: inline-flex; align-items: center; justify-content: center;
}

@media (prefers-reduced-motion: reduce) {
  .bottom-sheet__card, .bottom-sheet__backdrop,
  .chat-bubble--typing span { animation: none !important; transition: opacity 100ms linear; }
}

/* =========================================================================
   DASHBOARD prestador
   ========================================================================= */
.dash-header { display: flex; justify-content: space-between; align-items: flex-start; gap: 16px; }
.dash-metric {
  font-family: var(--font-serif);
  font-size: 28px; font-weight: 600;
  line-height: 1; color: #fff;
}
.dash-metric__label { font-size: 12px; color: rgba(255,255,255,0.78); margin-top: 4px; }
.dash-legend { display: inline-flex; align-items: center; gap: 6px; font-size: 12px; color: var(--text-dim); }
.dash-legend__dot { width: 10px; height: 10px; border-radius: 50%; }
.dash-today-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 0; border-bottom: 1px solid var(--border);
  text-decoration: none; color: var(--text);
}
.dash-today-item:last-child { border-bottom: 0; }
.dash-top3 { display: flex; flex-direction: column; gap: 8px; }
.dash-top3-item {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 12px; background: var(--surface-2);
  border-radius: var(--radius-md);
}
.dash-top3-item.is-me { background: var(--primary-tint); border: 1px solid var(--primary-soft); }
.dash-top3-pos { font-weight: 700; font-family: var(--font-serif); color: var(--text-dim); width: 18px; }
.dash-top3-name { flex: 1; font-size: 14px; font-weight: 500; }
.dash-top3-rating { font-size: 12px; color: var(--accent); font-weight: 600; }
.dash-tip {
  display: flex; align-items: flex-start; gap: 10px;
  padding: 10px 0; font-size: 14px; line-height: 1.4;
}
.dash-tip__icon {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--accent-soft); color: #6f4f24;
  flex: 0 0 auto;
}
.dash-history-item {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 0; text-decoration: none; color: var(--text);
  border-bottom: 1px solid var(--border);
}
.dash-history-item:last-child { border-bottom: 0; }

/* =========================================================================
   ONBOARDING prestador wizard
   ========================================================================= */
.ob-progress {
  height: 6px; background: var(--surface-2);
  border-radius: 999px; overflow: hidden;
  margin-top: var(--space-4);
}
.ob-progress__bar {
  height: 100%; background: linear-gradient(90deg, var(--primary), var(--accent));
  border-radius: 999px;
  transition: width var(--t-slow) var(--ease);
}
.ob-hero {
  display: inline-flex; align-items: center; justify-content: center;
  width: 96px; height: 96px;
  border-radius: 50%;
  background: var(--primary-tint);
  color: var(--primary);
}
.ob-checklist {
  list-style: none; padding: 0; margin: 0 auto; max-width: 360px; text-align: left;
}
.ob-checklist li {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 0; font-size: 15px;
}
.ob-photo {
  display: flex; flex-direction: column; align-items: center;
}
.ob-photo__placeholder {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  width: 160px; height: 160px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-dim);
  border: 2px dashed var(--border-strong);
}
.ob-photo__preview {
  width: 160px; height: 160px; border-radius: 50%;
  overflow: hidden; background: var(--surface-2);
  box-shadow: 0 4px 12px rgba(31,42,40,0.1);
}
.ob-photo__preview img { width: 100%; height: 100%; object-fit: cover; }

.ob-cats { display: flex; flex-direction: column; gap: 24px; }
.ob-cats__group-title { font-weight: 600; font-size: 14px; margin-bottom: 10px; color: var(--text-dim); }
.ob-cats__grid {
  display: grid; gap: 8px;
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
@media (min-width: 720px) { .ob-cats__grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 380px) { .ob-cats__grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }

.ob-cat-tile {
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  padding: 12px 8px;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-md);
  cursor: pointer; text-align: center;
  transition: all var(--t-fast) var(--ease);
}
.ob-cat-tile:active { transform: scale(0.97); }
.ob-cat-tile.is-active {
  background: var(--primary-tint);
  border-color: var(--primary);
  box-shadow: 0 0 0 3px rgba(62,107,92,0.12);
}
.ob-cat-tile.is-active span:last-child { color: var(--primary-dark); font-weight: 600; }
.ob-cat-tile__emoji { font-size: 26px; line-height: 1; }
.ob-cat-tile span:last-child { font-size: 12px; line-height: 1.2; }

.ob-price-input { flex: 1; display: flex; flex-direction: column; gap: 4px; }
.ob-price-input input {
  height: 42px; padding: 0 12px;
  background: var(--surface-2); border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  font-size: 16px;
}
.ob-price-input input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(62,107,92,0.12); }
.ob-review { list-style: none; padding: 0; margin: 12px 0 0; }
.ob-review li { padding: 6px 0; font-size: 14px; color: var(--text); }

/* FAQ accordion */
.faq-item {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  padding: 14px 16px;
}
.faq-item[open] { background: var(--surface-2); }
.faq-item summary {
  cursor: pointer;
  font-weight: 600;
  font-size: 15px;
  color: var(--text);
  list-style: none;
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 12px;
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: '+';
  color: var(--primary);
  font-size: 22px;
  line-height: 1;
  transition: transform var(--t-fast) var(--ease);
}
.faq-item[open] summary::after { content: '−'; transform: rotate(180deg); }
.faq-item p { line-height: 1.55; }

/* =========================================================================
   FAQ — tabs, search, accordion
   ========================================================================= */
.faq-search {
  position: relative;
  display: flex; align-items: center;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-pill);
  padding: 0 14px;
  height: 48px;
}
.faq-search:focus-within { border-color: var(--primary); box-shadow: 0 0 0 3px rgba(62,107,92,0.12); }
.faq-search__icon { color: var(--text-dim); margin-right: 8px; display: inline-flex; }
.faq-search__input {
  flex: 1; border: 0; outline: 0; background: transparent;
  font-size: 16px;
}
.faq-tabs {
  display: flex; gap: 4px; overflow-x: auto;
  padding-bottom: 4px;
  -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.faq-tabs::-webkit-scrollbar { display: none; }
.faq-tab {
  flex: 0 0 auto;
  padding: 8px 14px;
  border-radius: var(--radius-pill);
  background: var(--surface);
  color: var(--text);
  font-size: 13px; font-weight: 500;
  text-decoration: none;
  border: 1px solid var(--border);
  transition: all var(--t-fast) var(--ease);
  white-space: nowrap;
}
.faq-tab:hover { background: var(--surface-2); }
.faq-tab.is-active {
  background: var(--primary); color: #fff; border-color: var(--primary);
}

/* =========================================================================
   LEGAL pages (Termos + Privacidade) — layout documento
   ========================================================================= */
.legal-page { padding-bottom: 64px; }
.legal-breadcrumb {
  font-size: 13px; color: var(--text-dim);
  margin: var(--space-3) 0 var(--space-5);
}
.legal-breadcrumb a {
  color: var(--text-dim); text-decoration: none;
}
.legal-breadcrumb a:hover { color: var(--primary); text-decoration: underline; }
.legal-header {
  padding-bottom: var(--space-5);
  border-bottom: 1px solid var(--border);
  margin-bottom: var(--space-6);
}
.legal-header h1 {
  font-family: var(--font-serif);
  font-size: clamp(26px, 4vw, 34px);
  margin: 0 0 var(--space-2);
}
.legal-meta {
  font-size: 12px; color: var(--text-faint);
  margin: 0 0 var(--space-3);
}
.legal-content {
  font-family: var(--font-sans);
  font-size: 15px;
  line-height: 1.7;
  color: var(--text);
}
.legal-content section { margin-bottom: var(--space-7); }
.legal-content h2 {
  font-family: var(--font-serif);
  font-size: 18px; font-weight: 600;
  color: var(--primary-dark);
  margin: 0 0 var(--space-3);
  padding-bottom: var(--space-2);
  border-bottom: 1px solid var(--border);
}
.legal-content p { margin: 0 0 var(--space-3); }
.legal-content p strong { color: var(--text); font-weight: 600; }
.legal-content a { color: var(--primary); text-decoration: underline; }
.legal-content a:hover { color: var(--primary-dark); }
.legal-footer {
  margin-top: var(--space-7);
  padding-top: var(--space-4);
  border-top: 1px solid var(--border);
  font-size: 12px; color: var(--text-faint);
  text-align: center;
}

@media print {
  .site-header, .site-footer, .app-bottom-nav,
  .demo-banner, .demo-fab, .install-sheet, .update-banner,
  .legal-breadcrumb, .legal-header button { display: none !important; }
  .legal-page { padding: 0 !important; }
  .legal-content { font-size: 11pt; line-height: 1.5; color: #000; }
  .legal-content h2 { color: #000; }
  a { color: #000 !important; text-decoration: none !important; }
}

/* =========================================================================
   TOAST variants semânticos com stack
   ========================================================================= */
.toast {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 16px;
  background: var(--surface);
  color: var(--text);
  border-radius: var(--radius-md);
  box-shadow: var(--shadow-3);
  font-size: 14px;
  font-weight: 500;
  min-width: 220px; max-width: 360px;
  border-left: 4px solid var(--text-dim);
  animation: toast-in 250ms var(--ease-out) both;
}
.toast--success { border-left-color: var(--success); }
.toast--success::before { content: '✓'; color: var(--success); font-weight: 700; }
.toast--info { border-left-color: var(--primary); }
.toast--info::before { content: 'ⓘ'; color: var(--primary); font-weight: 700; }
.toast--warning { border-left-color: var(--warning); }
.toast--warning::before { content: '⚠'; color: var(--warning); font-weight: 700; }
.toast--danger { border-left-color: var(--danger); }
.toast--danger::before { content: '✕'; color: var(--danger); font-weight: 700; }
@keyframes toast-in {
  from { transform: translateY(20px); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
@keyframes toast-out {
  to { transform: translateY(-10px); opacity: 0; }
}

/* =========================================================================
   CHAT REACTIONS
   ========================================================================= */
.chat-bubble { position: relative; transition: transform var(--t-fast) var(--ease); }
.chat-bubble.is-pressing { transform: scale(1.02); }
.chat-reactions-menu {
  position: absolute;
  bottom: calc(100% + 8px);
  background: var(--surface);
  border-radius: var(--radius-pill);
  box-shadow: var(--shadow-3);
  padding: 6px;
  display: flex; gap: 2px;
  z-index: 100;
  animation: reactions-menu-in 200ms var(--ease-out) both;
  white-space: nowrap;
}
.chat-row--me .chat-reactions-menu { right: 0; }
.chat-row--them .chat-reactions-menu { left: 0; }
@keyframes reactions-menu-in {
  from { transform: scale(0.6) translateY(8px); opacity: 0; }
  to { transform: scale(1) translateY(0); opacity: 1; }
}
.chat-reaction-btn {
  width: 40px; height: 40px;
  border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 22px;
  background: transparent;
  cursor: pointer; border: 0;
  transition: background var(--t-fast), transform var(--t-fast);
}
.chat-reaction-btn:hover { background: var(--surface-2); transform: scale(1.1); }
.chat-reaction-btn:active { transform: scale(0.95); }

.chat-bubble__reactions {
  position: absolute;
  bottom: -10px;
  display: inline-flex; gap: 2px;
  background: var(--surface);
  padding: 2px 6px;
  border-radius: 999px;
  box-shadow: var(--shadow-1);
  font-size: 13px; line-height: 1;
}
.chat-row--me .chat-bubble__reactions { right: 8px; }
.chat-row--them .chat-bubble__reactions { left: 8px; }
.chat-bubble__reaction {
  display: inline-flex; align-items: center; gap: 2px;
  padding: 2px 4px;
  cursor: pointer;
  animation: reaction-pop 320ms cubic-bezier(0.34, 1.56, 0.64, 1) both;
}
@keyframes reaction-pop {
  from { transform: scale(0); }
  to { transform: scale(1); }
}
.chat-bubble__reaction.is-removing { animation: reaction-out 200ms var(--ease) forwards; }
@keyframes reaction-out {
  to { transform: scale(0); opacity: 0; }
}
.chat-bubble__reaction-count {
  font-size: 11px; font-weight: 600;
  color: var(--text-dim);
  min-width: 8px;
}

/* =========================================================================
   ADMIN panel
   ========================================================================= */
.admin-page { background: #F5F1E8; min-height: 100vh; }
.admin-header { background: #1F2A28; color: #fff; padding: 12px 0; }
.admin-header__inner { display: flex; align-items: center; gap: 16px; max-width: 1200px; margin: 0 auto; padding: 0 20px; }
.admin-header__logo { font-family: var(--font-serif); font-weight: 600; font-size: 16px; flex: 1; }
.admin-header__env { background: rgba(255,255,255,0.15); padding: 2px 8px; border-radius: 999px; font-size: 11px; }
.admin-header__logout { background: none; border: 0; color: #fff; cursor: pointer; opacity: 0.7; font-size: 13px; }
.admin-header__logout:hover { opacity: 1; }

.admin-tabs { background: var(--surface); border-bottom: 1px solid var(--border); }
.admin-tabs__nav { display: flex; max-width: 1200px; margin: 0 auto; padding: 0 20px; overflow-x: auto; }
.admin-tab {
  padding: 14px 18px; color: var(--text-dim);
  text-decoration: none; font-size: 14px; font-weight: 500;
  border-bottom: 2px solid transparent;
  white-space: nowrap; transition: all var(--t-fast);
}
.admin-tab:hover { color: var(--text); }
.admin-tab.is-active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }

.admin-content { max-width: 1200px; margin: 0 auto; padding: 24px 20px; }

.metric-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  margin-bottom: 24px;
}
.metric-card {
  background: var(--surface); padding: 16px; border-radius: var(--radius-md);
  box-shadow: var(--shadow-1); display: flex; flex-direction: column; gap: 4px;
}
.metric-card__emoji { font-size: 24px; }
.metric-card__label { font-size: 12px; color: var(--text-dim); }
.metric-card__value { font-family: var(--font-serif); font-size: 26px; font-weight: 600; color: var(--text); line-height: 1; }
.metric-card__sub { font-size: 11px; color: var(--text-faint); }

.admin-card {
  background: var(--surface); border-radius: var(--radius-md);
  padding: 16px; box-shadow: var(--shadow-1); margin-bottom: 16px;
}
.admin-card h3 {
  font-family: var(--font-serif); font-size: 16px; font-weight: 600;
  margin-bottom: 8px; color: var(--text);
}

.admin-toolbar { display: flex; gap: 8px; margin-bottom: 12px; flex-wrap: wrap; }
.admin-input {
  flex: 1; min-width: 180px; height: 40px; padding: 0 12px;
  border: 1px solid var(--border); border-radius: var(--radius-sm);
  background: var(--surface); font-size: 14px;
}

.admin-table-wrap { overflow-x: auto; background: var(--surface); border-radius: var(--radius-md); box-shadow: var(--shadow-1); }
.admin-table { width: 100%; border-collapse: collapse; font-size: 13px; }
.admin-table th, .admin-table td { padding: 10px 12px; text-align: left; border-bottom: 1px solid var(--border); }
.admin-table th { background: var(--surface-2); color: var(--text-dim); font-weight: 600; font-size: 12px; text-transform: uppercase; letter-spacing: 0.04em; }
.admin-table tr:hover { background: var(--surface-2); }

.admin-pill {
  display: inline-block; padding: 2px 8px;
  background: var(--surface-2); color: var(--text-dim);
  border-radius: 999px; font-size: 11px; font-weight: 600;
}
.admin-pill--ok { background: var(--success-soft); color: var(--success); }
.admin-pill--open { background: var(--success-soft); color: var(--success); }
.admin-pill--proposals { background: var(--accent-soft); color: #6f4f24; }
.admin-pill--hired { background: var(--primary-tint); color: var(--primary); }
.admin-pill--completed { background: var(--surface-2); color: var(--text-dim); }

.admin-action {
  background: none; border: 1px solid var(--border);
  padding: 4px 10px; border-radius: var(--radius-sm);
  font-size: 12px; cursor: pointer; color: var(--text);
  margin-right: 4px;
}
.admin-action:hover { background: var(--surface-2); }
.admin-action--danger { color: var(--danger); border-color: var(--danger-soft); }
.admin-action--danger:hover { background: var(--danger-soft); }

.admin-config-grid {
  display: grid; gap: 16px;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
}

/* Login admin */
.admin-login { min-height: 100vh; display: flex; align-items: center; justify-content: center; background: #1F2A28; }
.admin-login__card { background: var(--surface); padding: 32px; border-radius: var(--radius-lg); max-width: 360px; width: 90%; box-shadow: var(--shadow-3); }
.admin-login__title { font-family: var(--font-serif); font-size: 24px; margin-bottom: 4px; }
.admin-login__hint { color: var(--text-dim); font-size: 13px; margin-bottom: 24px; }
.admin-login__input {
  width: 100%; height: 48px; padding: 0 16px; font-size: 16px;
  border: 1px solid var(--border); border-radius: var(--radius-sm); margin-bottom: 12px;
}
.admin-login__cta {
  width: 100%; height: 48px; background: var(--primary); color: #fff;
  border: 0; border-radius: var(--radius-sm); font-weight: 600; cursor: pointer;
  font-size: 15px;
}
.admin-login__back { display: block; text-align: center; margin-top: 16px; color: var(--text-dim); text-decoration: none; font-size: 13px; }
.admin-login__back:hover { color: var(--primary); }

/* =========================================================================
   PAYMENT — checkout, PIX, cartão, recibo
   ========================================================================= */
.payment-page { padding-bottom: 64px; }
.payment-summary {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 16px;
}
.payment-breakdown { background: var(--surface-2); padding: 14px; border-radius: var(--radius-md); }
.payment-breakdown__divider { height: 1px; background: var(--border); margin: 12px 0; }

.payment-method-tabs { display: flex; gap: 6px; }
.payment-method-tab {
  flex: 1; display: flex; align-items: center; justify-content: center; gap: 6px;
  padding: 14px 8px; border-radius: var(--radius-md);
  background: var(--surface); border: 1px solid var(--border);
  color: var(--text); font-weight: 500; font-size: 14px;
  text-decoration: none; cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.payment-method-tab.is-active { background: var(--primary-tint); border-color: var(--primary); color: var(--primary-dark); font-weight: 600; }
.payment-method-tab:hover:not(.is-active) { background: var(--surface-2); }

.payment-pix {
  background: var(--surface); padding: 24px; border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}
.payment-pix__qr { display: flex; justify-content: center; }
.payment-pix__divider {
  text-align: center; position: relative;
  margin: 20px 0;
  color: var(--text-faint); font-size: 12px;
}
.payment-pix__divider::before, .payment-pix__divider::after {
  content: ''; position: absolute; top: 50%; width: 40%; height: 1px;
  background: var(--border);
}
.payment-pix__divider::before { left: 0; }
.payment-pix__divider::after { right: 0; }
.payment-pix__divider span { background: var(--surface); padding: 0 12px; position: relative; }
.payment-pix__copy { display: flex; gap: 8px; align-items: center; }
.payment-pix__copy .input { flex: 1; font-family: monospace; font-size: 12px; }
.payment-pix__waiting { text-align: center; }
.payment-pix__spinner {
  width: 32px; height: 32px; margin: 0 auto;
  border: 3px solid var(--border); border-top-color: var(--primary);
  border-radius: 50%; animation: spinner 1s linear infinite;
}
@keyframes spinner { to { transform: rotate(360deg); } }

.payment-card {
  background: var(--surface); padding: 20px; border-radius: var(--radius-lg);
  border: 1px solid var(--border);
}

/* RECEIPT */
.receipt-page { padding-bottom: 48px; }
.receipt-actions { display: flex; justify-content: space-between; align-items: center; margin: 16px 0 24px; }
.receipt-card {
  background: var(--surface); padding: 24px; border-radius: var(--radius-lg);
  box-shadow: var(--shadow-2); border: 1px solid var(--border);
  max-width: 480px; margin: 0 auto;
}
.receipt-card__header { display: flex; align-items: center; gap: 10px; margin-bottom: 16px; }
.receipt-card__brand { font-family: var(--font-serif); font-weight: 600; font-size: 20px; color: var(--primary); line-height: 1; }
.receipt-card__sub { font-size: 12px; color: var(--text-dim); }
.receipt-card__status {
  background: var(--success-soft); color: var(--success);
  padding: 8px 14px; border-radius: 999px; display: inline-block;
  font-weight: 600; font-size: 13px; margin-bottom: 20px;
}
.receipt-card__list { margin: 0 0 20px; }
.receipt-card__list > div {
  display: flex; justify-content: space-between;
  padding: 10px 0; border-bottom: 1px dotted var(--border);
  font-size: 13px;
}
.receipt-card__list > div:last-child { border-bottom: 0; }
.receipt-card__list dt { color: var(--text-dim); }
.receipt-card__list dd { margin: 0; color: var(--text); font-weight: 500; text-align: right; max-width: 60%; word-break: break-word; }
.receipt-card__breakdown { background: var(--surface-2); padding: 14px; border-radius: var(--radius-md); margin-bottom: 16px; }
.receipt-card__divider { height: 1px; background: var(--border); margin: 12px 0; }
.receipt-card__footer { text-align: center; font-size: 11px; color: var(--text-faint); margin-top: 12px; line-height: 1.5; }

@media print {
  .receipt-actions, .site-header, .site-footer, .app-bottom-nav,
  .demo-banner, .demo-fab, .install-sheet, .update-banner { display: none !important; }
  .print-hide { display: none !important; }
  .receipt-page { padding: 0 !important; }
  .receipt-card { box-shadow: none; border: 1px solid #ccc; max-width: 100%; }
}

/* =========================================================================
   FEATURES v2.0 — favoritos, histórico timeline, notificações, emergência,
   detalhe prestador
   ========================================================================= */

/* Favoritos */
.favorite-btn {
  background: var(--surface-2); border: 1px solid var(--border);
  width: 36px; height: 36px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 18px; cursor: pointer;
  transition: all var(--t-fast) var(--ease);
}
.favorite-btn:hover { background: var(--accent-soft); border-color: var(--accent); }
.favorite-btn.is-active { background: var(--accent); border-color: var(--accent); }
.favorite-btn:active { transform: scale(0.9); }

/* Histórico timeline */
.timeline-stack { display: flex; flex-direction: column; gap: 24px; }
.timeline-month__title {
  font-family: var(--font-serif); font-size: 18px;
  text-transform: capitalize; color: var(--text-dim);
  margin: 0;
  padding-bottom: 8px;
  border-bottom: 2px solid var(--accent-soft);
}
.timeline-item {
  display: flex; gap: 12px; align-items: center;
  padding: 14px; background: var(--surface);
  border-radius: var(--radius-md);
  border-left: 3px solid var(--primary);
  box-shadow: var(--shadow-1);
}
.timeline-item__body { flex: 1; min-width: 0; }

/* Notificações in-app */
.notif-bell {
  position: relative;
  background: none; border: 0; cursor: pointer;
  width: 40px; height: 40px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--text); transition: background var(--t-fast);
}
.notif-bell:hover { background: var(--surface-2); }
.notif-bell__badge {
  position: absolute; top: 6px; right: 6px;
  min-width: 16px; height: 16px; padding: 0 4px;
  background: var(--danger); color: #fff;
  border-radius: 999px; font-size: 10px; font-weight: 700;
  display: inline-flex; align-items: center; justify-content: center;
}

.notif-list { display: flex; flex-direction: column; gap: 4px; }
.notif-item {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px;
  background: var(--surface); border-radius: var(--radius-md);
  text-decoration: none; color: inherit;
  position: relative;
  transition: background var(--t-fast);
}
.notif-item:hover { background: var(--surface-2); }
.notif-item.is-unread { background: var(--primary-tint); }
.notif-item__cat {
  font-size: 22px; flex: 0 0 auto;
  width: 36px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--surface-2); border-radius: 50%;
}
.notif-item__body { flex: 1; min-width: 0; }
.notif-item__dot {
  position: absolute; top: 18px; right: 14px;
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--primary);
}

/* Emergência */
.emergency-page { padding-bottom: 64px; }
.emergency-header { text-align: center; padding: 24px 0; }
.emergency-icon {
  display: inline-block; font-size: 56px;
  animation: emergency-shake 1.4s ease-in-out infinite;
}
@keyframes emergency-shake {
  0%, 100% { transform: rotate(0deg); }
  10%, 30%, 50%, 70%, 90% { transform: rotate(-6deg); }
  20%, 40%, 60%, 80% { transform: rotate(6deg); }
}

.emergency-cats {
  display: grid; gap: 12px;
  grid-template-columns: repeat(2, 1fr);
}
@media (min-width: 480px) {
  .emergency-cats { grid-template-columns: repeat(3, 1fr); }
}
.emergency-cat-btn {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 18px 12px; background: var(--surface);
  border: 2px solid var(--danger-soft); border-radius: var(--radius-md);
  cursor: pointer; text-align: center;
  transition: all var(--t-fast) var(--ease);
}
.emergency-cat-btn:hover {
  background: var(--danger-soft); border-color: var(--danger);
}
.emergency-cat-btn:active { transform: scale(0.95); }
.emergency-cat-btn__emoji { font-size: 32px; line-height: 1; }
.emergency-cat-btn__name { font-weight: 600; font-size: 14px; }
.emergency-cat-btn__price { font-size: 12px; color: var(--danger); font-weight: 600; }

.emergency-foot { margin-top: 24px; padding: 16px; background: var(--surface); border-radius: var(--radius-md); }

.emergency-waiting-page { padding-bottom: 64px; }
.emergency-pulse {
  position: relative;
  width: 200px; height: 200px;
  margin: 24px auto;
  display: flex; align-items: center; justify-content: center;
}
.emergency-pulse__ring {
  position: absolute; inset: 0;
  border-radius: 50%; border: 4px solid var(--danger);
  opacity: 0;
  animation: emergency-pulse-ring 2.4s ease-out infinite;
}
@keyframes emergency-pulse-ring {
  0% { transform: scale(0.3); opacity: 1; }
  100% { transform: scale(1); opacity: 0; }
}
.emergency-pulse__center {
  position: relative; z-index: 1;
  font-size: 64px;
  background: var(--danger); color: #fff;
  width: 100px; height: 100px; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
}

/* Detalhe do prestador */
.provider-detail-page { padding-bottom: 80px; }
.provider-hero { text-align: center; padding: 20px 0; }
.provider-hero__avatar-wrap {
  position: relative; display: inline-block; margin-bottom: 12px;
}
.provider-hero__verified {
  position: absolute; bottom: 4px; right: 4px;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--success); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 14px; font-weight: 700;
  border: 3px solid var(--surface);
}
.provider-hero h1 {
  font-family: var(--font-serif); font-size: 28px;
  margin: 8px 0 0;
}
.provider-hero__tag {
  display: inline-block; font-size: 12px; font-weight: 500;
  padding: 4px 10px; border-radius: 999px;
  background: var(--primary-tint); color: var(--primary-dark);
}

.provider-tabs {
  display: flex; gap: 4px; overflow-x: auto;
  margin: 24px -20px 0; padding: 0 20px 4px;
  border-bottom: 1px solid var(--border);
  scrollbar-width: none;
}
.provider-tabs::-webkit-scrollbar { display: none; }
.provider-tab {
  flex: 0 0 auto;
  padding: 10px 14px;
  color: var(--text-dim);
  text-decoration: none; font-size: 14px; font-weight: 500;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
.provider-tab.is-active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }

.provider-portfolio {
  display: grid; gap: 8px;
  grid-template-columns: repeat(3, 1fr);
}
.provider-portfolio__item {
  aspect-ratio: 1; border-radius: var(--radius-md);
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,0.6); font-size: 32px;
  font-family: var(--font-serif); font-weight: 700;
}

.provider-rating-dist { display: flex; flex-direction: column; gap: 6px; }
.rating-dist-row {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px;
}
.rating-dist-row__star { font-weight: 600; width: 28px; }
.rating-dist-row__bar {
  flex: 1; height: 8px; background: var(--surface-2); border-radius: 999px; overflow: hidden;
}
.rating-dist-row__bar > div { height: 100%; background: var(--accent); }

.provider-verif { list-style: none; padding: 0; margin: 0; }
.provider-verif__item {
  display: flex; align-items: center; gap: 12px;
  padding: 14px 0; border-bottom: 1px solid var(--border);
}
.provider-verif__item:last-child { border-bottom: 0; }
.provider-verif__check {
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--surface-2); color: var(--text-faint);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; flex: 0 0 auto;
}
.provider-verif__item.is-ok .provider-verif__check {
  background: var(--success-soft); color: var(--success);
}

/* Map container */
.map-container {
  width: 100%; height: 300px;
  border-radius: var(--radius-md);
  overflow: hidden; border: 1px solid var(--border);
}
.map-container--large { height: 480px; }
@media (max-width: 480px) {
  .map-container--large { height: 320px; }
}

/* =========================================================================
   CHAT AUDIO + PHOTO + LIGHTBOX
   ========================================================================= */
.chat-composer__mic {
  width: 40px; height: 40px; border-radius: 50%;
  background: var(--primary); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  cursor: pointer; border: 0;
  transition: background var(--t-fast), transform var(--t-fast);
  flex: 0 0 auto;
}
.chat-composer__mic:hover { background: var(--primary-dark); }
.chat-composer__mic:active { transform: scale(0.92); }

.chat-recorder {
  display: flex; align-items: center; gap: 12px;
  padding: 12px 16px;
  background: var(--danger-soft); color: var(--danger);
  border-top: 1px solid var(--border);
}
.chat-recorder__dot {
  width: 12px; height: 12px; border-radius: 50%;
  background: var(--danger);
  animation: chat-rec-pulse 1s ease-in-out infinite;
}
@keyframes chat-rec-pulse { 0%,100% { opacity: 0.5; } 50% { opacity: 1; } }
.chat-recorder__timer { font-family: monospace; font-weight: 600; font-size: 14px; min-width: 40px; }
.chat-recorder__hint { font-size: 11px; color: var(--text-dim); flex: 1; }
.chat-recorder__cancel { background: transparent; border: 0; font-size: 16px; cursor: pointer; color: var(--danger); padding: 4px 8px; }

.chat-bubble--audio {
  display: inline-flex; align-items: center; gap: 8px; padding: 8px 12px;
}
.audio-bubble__play {
  width: 36px; height: 36px; border-radius: 50%;
  background: rgba(255,255,255,0.18); color: inherit;
  border: 0; cursor: pointer; font-size: 14px;
  display: inline-flex; align-items: center; justify-content: center;
}
.chat-bubble--them .audio-bubble__play { background: var(--primary-tint); color: var(--primary); }
.audio-bubble__wave { display: inline-flex; align-items: center; }
.audio-bubble__dur { font-size: 11px; opacity: 0.7; min-width: 32px; }

.chat-bubble--photo { padding: 4px; }
.photo-bubble { position: relative; border-radius: 12px; overflow: hidden; }
.photo-bubble img { display: block; max-width: 240px; width: 100%; height: auto; border-radius: 12px; cursor: zoom-in; }
.photo-bubble__tag {
  position: absolute; top: 8px; left: 8px;
  padding: 4px 8px; border-radius: 999px;
  background: rgba(0,0,0,0.6); color: #fff;
  font-size: 11px; font-weight: 600;
}
.photo-bubble__tag--depois { background: var(--success); }

.chat-photo-preview {
  padding: 16px; background: var(--surface); border-top: 1px solid var(--border);
}
.chat-photo-preview img {
  max-width: 100%; max-height: 220px; border-radius: var(--radius-md);
  display: block; margin: 0 auto 12px;
}
.chat-photo-preview .input { width: 100%; }
.chat-photo-preview [data-photo-tag].is-active { background: var(--primary); color: #fff; border-color: var(--primary); }

.photo-lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,0.92);
  display: flex; align-items: center; justify-content: center;
  animation: photo-lightbox-in 200ms var(--ease-out) both;
}
@keyframes photo-lightbox-in { from { opacity: 0; } to { opacity: 1; } }
.photo-lightbox img { max-width: 92vw; max-height: 90vh; border-radius: 8px; }
.photo-lightbox__close {
  position: absolute; top: 16px; right: 16px;
  width: 40px; height: 40px; border-radius: 50%;
  background: rgba(255,255,255,0.2); color: #fff;
  border: 0; cursor: pointer; font-size: 18px;
}

/* Notif bell badge — show via JS when count > 0 */
.notif-bell { background: transparent; border: 0; cursor: pointer; padding: 0; }

/* ============================================================
   Onboarding cliente quick-start (3 telas, full-screen overlay)
   ============================================================ */
.oc-overlay {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  padding-top: max(24px, env(safe-area-inset-top));
  padding-right: max(24px, env(safe-area-inset-right));
  padding-bottom: max(24px, env(safe-area-inset-bottom));
  padding-left: max(24px, env(safe-area-inset-left));
  animation: oc-fade-in 280ms var(--ease-out) both;
  overflow-y: auto;
}
@keyframes oc-fade-in { from { opacity: 0; } to { opacity: 1; } }
.oc-card {
  max-width: 420px; width: 100%;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: 16px;
}
.oc-progress { display: flex; gap: 8px; margin-bottom: 8px; }
.oc-dot {
  width: 28px; height: 4px; border-radius: 2px;
  background: var(--border);
  transition: background 200ms var(--ease-out);
}
.oc-dot.is-active { background: var(--primary); }
.oc-art { margin: 8px 0 4px; }
.oc-title { font-family: 'Fraunces', serif; font-size: 32px; line-height: 1.15; margin: 0; }
.oc-body { color: var(--text-dim); font-size: 16px; line-height: 1.55; max-width: 360px; margin: 0; }
.oc-cta { width: 100%; max-width: 320px; margin-top: 12px; }
.oc-skip { margin-top: -4px; color: var(--text-dim); }
@media (max-width: 480px) {
  .oc-title { font-size: 26px; }
  .oc-body { font-size: 15px; }
}

/* ============================================================
   Quick actions row — 3 colunas em mobile (NÃO usar .grid-3
   porque ele colapsa pra 1 coluna em <=480px)
   ============================================================ */
.quick-actions {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: var(--space-2);
}
.quick-action {
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 4px;
  padding: var(--space-3) var(--space-2);
  min-height: 72px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-md);
  color: var(--text);
  text-align: center;
  transition: transform var(--t-fast) var(--ease), border-color var(--t-fast) var(--ease), box-shadow var(--t-fast) var(--ease);
}
.quick-action:hover {
  transform: translateY(-1px);
  border-color: var(--primary-soft);
  box-shadow: var(--shadow-2);
  color: var(--text);
}
.quick-action:active { transform: translateY(0); }
.quick-action__icon { font-size: 22px; line-height: 1; }
.quick-action__label { font-size: 13px; font-weight: 600; line-height: 1.2; }
.quick-action--danger { border-left: 3px solid var(--danger); }
@media (max-width: 360px) {
  .quick-action__label { font-size: 12px; }
}

/* =========================================================================
   v2.3.0 PREMIUM POLISH — refinamentos sutis Linear/Stripe-grade
   Aplicados sobre componentes existentes. Aliases retrocompatíveis
   garantem que classes legadas continuam funcionando.
   ========================================================================= */

/* --- Botões: focus ring refinado, danger variant, transições snappy --- */
.btn { transition: background var(--duration-fast) var(--ease-out),
                    border-color var(--duration-fast) var(--ease-out),
                    box-shadow var(--duration-fast) var(--ease-out),
                    color var(--duration-fast) var(--ease-out),
                    transform var(--duration-instant) var(--ease-out); }
.btn:hover { transform: none; box-shadow: var(--shadow-sm); }
.btn:active { transform: scale(0.97); transition-duration: var(--duration-instant); }
.btn:focus-visible { box-shadow: var(--ring-focus); }
.btn--primary { box-shadow: var(--shadow-xs); }
.btn--primary:hover { box-shadow: var(--shadow-sm); }
.btn--danger { background: var(--color-danger); color: #fff; border-color: transparent; }
.btn--danger:hover { background: #A04944; }
.btn--danger:focus-visible { box-shadow: var(--ring-focus-danger); }

/* --- Cards: hover mais sutil (Linear-like), borders rgba --- */
.card { box-shadow: var(--shadow-xs); }
.card--interactive { transition: transform var(--duration-fast) var(--ease-out),
                                  box-shadow var(--duration-fast) var(--ease-out),
                                  border-color var(--duration-fast) var(--ease-out); }
.card--interactive:hover { transform: translateY(-1px); box-shadow: var(--shadow-md); border-color: var(--color-border-hover); }
.card--interactive:active { transform: translateY(0); transition-duration: var(--duration-instant); }

/* --- Inputs: focus state premium com ring + border-color --- */
.input:focus, .select:focus, .textarea:focus {
  border-color: var(--color-primary);
  outline: none;
  box-shadow: var(--ring-focus);
}

/* --- Tipografia: tracking premium em títulos --- */
h1 { letter-spacing: var(--tracking-tight); }
h2 { letter-spacing: var(--tracking-tight); }
h3 { letter-spacing: var(--tracking-tight); }

/* --- Section padding mais respirado em desktop, menos em mobile --- */
@media (max-width: 720px) {
  .section { padding: var(--space-8) 0; }
  .section--tight { padding: var(--space-6) 0; }
}

/* --- View transition: fade + slide sutil entre rotas --- */
.page, .page--app, .page--narrow {
  animation: view-enter var(--duration-slow) var(--ease-out);
}
@keyframes view-enter {
  from { opacity: 0; transform: translateY(6px); }
  to { opacity: 1; transform: translateY(0); }
}
@media (prefers-reduced-motion: reduce) {
  .page, .page--app, .page--narrow { animation: none; }
}

/* --- Eyebrow: refinado, menos shouty --- */
.eyebrow {
  font-size: var(--text-2xs);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-wider);
  padding: 4px 10px;
  background: var(--color-primary-soft);
  color: var(--color-primary);
}

/* --- Container narrow mais respirado em mobile --- */
@media (max-width: 720px) {
  .container, .container--narrow {
    padding-left: var(--space-4);
    padding-right: var(--space-4);
  }
}

/* --- Avatares: ring sutil em verificados --- */
.avatar--verified {
  box-shadow: 0 0 0 2px var(--color-surface), 0 0 0 3px var(--color-primary);
}

/* --- Skeleton screens premium com shimmer --- */
.skeleton {
  background: linear-gradient(90deg,
    var(--color-surface-3) 0%,
    var(--color-surface-2) 50%,
    var(--color-surface-3) 100%);
  background-size: 200% 100%;
  animation: skeleton-shimmer 1.5s infinite ease-in-out;
  border-radius: var(--radius-sm);
}
@keyframes skeleton-shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}
.skeleton-text { height: 14px; margin-bottom: var(--space-2); }
.skeleton-text--lg { height: 20px; }
.skeleton-text--sm { height: 12px; }
.skeleton-circle { border-radius: var(--radius-full); }

/* --- Empty state padrão --- */
.empty-state {
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  padding: var(--space-9) var(--space-5);
  text-align: center;
  gap: var(--space-4);
}
.empty-state__icon {
  width: 64px; height: 64px;
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--color-primary-soft);
  border-radius: var(--radius-full);
  color: var(--color-primary);
  font-size: 28px;
}
.empty-state__title {
  font-family: var(--font-display);
  font-size: var(--text-xl);
  font-weight: var(--font-semibold);
  letter-spacing: var(--tracking-tight);
}
.empty-state__description {
  font-size: var(--text-sm);
  color: var(--color-text-secondary);
  max-width: 280px;
  line-height: var(--leading-relaxed);
}

/* --- Header sticky com altura premium --- */
.site-header {
  background: rgba(250, 248, 244, 0.85);
  backdrop-filter: saturate(180%) blur(12px);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid transparent;
  transition: border-color var(--duration-base), background var(--duration-base);
}
[data-theme="dark"] .site-header { background: rgba(14, 20, 17, 0.85); }
.site-header.is-scrolled { border-bottom-color: var(--color-border); }

/* --- Bottom nav: padding refinado, item active mais visível --- */
.app-bottom-nav {
  background: rgba(255, 255, 255, 0.92);
  -webkit-backdrop-filter: saturate(180%) blur(12px);
  backdrop-filter: saturate(180%) blur(12px);
  border-top: 1px solid var(--color-border);
}
[data-theme="dark"] .app-bottom-nav { background: rgba(26, 38, 32, 0.92); }
.app-bottom-nav__item { transition: color var(--duration-fast) var(--ease-out),
                                     background var(--duration-fast) var(--ease-out); }
.app-bottom-nav__item:active { background: var(--color-primary-soft); }
.app-bottom-nav__item.is-active svg { transform: scale(1.05); }
.app-bottom-nav__item:active svg { transform: scale(0.92); }

/* --- Hide scrollbar gracioso (FAQ tabs etc) --- */
.no-scrollbar { scrollbar-width: none; -ms-overflow-style: none; }
.no-scrollbar::-webkit-scrollbar { display: none; }

/* =========================================================================
   v2.3.4 Theme toggle button no header
   ========================================================================= */
.theme-toggle {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 36px; height: 36px;
  border-radius: var(--radius-full);
  background: transparent;
  color: var(--color-text-secondary);
  border: 0;
  cursor: pointer;
  transition: background-color var(--duration-fast) var(--ease-out),
              color var(--duration-fast) var(--ease-out),
              transform var(--duration-instant) var(--ease-out);
  position: relative;
}
.theme-toggle:hover { background: var(--color-primary-soft); color: var(--color-primary); }
.theme-toggle:active { transform: scale(0.92); }
.theme-toggle:focus-visible { box-shadow: var(--ring-focus); outline: none; }
.theme-toggle__icon {
  position: absolute;
  inset: 0;
  margin: auto;
  transition: opacity var(--duration-base) var(--ease-out),
              transform var(--duration-base) var(--ease-out);
}
.theme-toggle[data-theme-state="light"] .theme-toggle__icon--sun { opacity: 0; transform: rotate(-90deg) scale(0.5); }
.theme-toggle[data-theme-state="light"] .theme-toggle__icon--moon { opacity: 1; transform: rotate(0) scale(1); }
.theme-toggle[data-theme-state="dark"] .theme-toggle__icon--sun { opacity: 1; transform: rotate(0) scale(1); }
.theme-toggle[data-theme-state="dark"] .theme-toggle__icon--moon { opacity: 0; transform: rotate(90deg) scale(0.5); }
