/* Torque — Stylesheet compartilhado entre / (landing) e /app (plataforma)
 * Última atualização: v1.3.21 — Plataforma Torque (paywall + tier + integração MP em produção)
 */

:root {
  --bg: #fafaf9;
  --bg-elev: #ffffff;
  --bg-mute: #f5f5f4;
  --ink: #0a0a0a;
  --ink-soft: #404040;
  --ink-mute: #737373;
  --line: #e5e5e3;
  --line-soft: #f0f0ee;
  --primary: #991b1b;
  --primary-strong: #7f1d1d;
  --primary-soft: #fef2f2;
  --primary-glow: rgba(153, 27, 27, 0.12);
  --primary-on: #ffffff;
  --ok: #15803d;
  --ok-soft: #dcfce7;
  --danger: #b91c1c;
  --warn: #c2410c;
  --radius: 14px;
  --radius-sm: 10px;
  --radius-lg: 22px;
  --shadow: 0 1px 2px rgba(0,0,0,0.04), 0 8px 24px rgba(0,0,0,0.06);
  --shadow-lift: 0 8px 16px rgba(0,0,0,0.06), 0 16px 40px rgba(0,0,0,0.10);
  --maxw: 1120px;
  --gap: 16px;
  --ease: cubic-bezier(0.4, 0, 0.2, 1);
  --header-h: 68px;
}
[data-theme="dark"] {
  --bg: #0a0a0a;
  --bg-elev: #161616;
  --bg-mute: #1f1f1f;
  --ink: #f5f5f5;
  --ink-soft: #b5b5b5;
  --ink-mute: #888888;
  --line: #2a2a2a;
  --line-soft: #1f1f1f;
  --primary: #ef4444;
  --primary-strong: #dc2626;
  --primary-soft: rgba(239, 68, 68, 0.12);
  --primary-glow: rgba(239, 68, 68, 0.22);
  --primary-on: #0a0a0a;
  --ok: #22c55e;
  --ok-soft: rgba(34, 197, 94, 0.15);
  --shadow: 0 1px 2px rgba(0,0,0,0.4), 0 8px 24px rgba(0,0,0,0.5);
  --shadow-lift: 0 8px 16px rgba(0,0,0,0.4), 0 16px 40px rgba(0,0,0,0.6);
}
* { box-sizing: border-box; }
*:focus { outline: none; }
*:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
  border-radius: 4px;
}
html, body { margin: 0; padding: 0; }
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 12px); }
@media (prefers-reduced-motion: reduce) {
  html { scroll-behavior: auto; }
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: 0.01ms !important;
  }
}
body {
  font-family: "Space Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif;
  background: var(--bg);
  color: var(--ink);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  transition: background-color 0.2s var(--ease), color 0.2s var(--ease);
}
::selection { background: var(--primary); color: var(--primary-on); }
.wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 20px; }
.mono { font-feature-settings: "tnum","cv11"; font-variant-numeric: tabular-nums; }

/* Skip to content (a11y) */
.skip-link {
  position: absolute; top: -100px; left: 12px;
  background: var(--ink); color: var(--bg); padding: 12px 16px;
  text-decoration: none; font-weight: 600; border-radius: 8px;
  z-index: 1000; transition: top 0.2s var(--ease);
}
.skip-link:focus { top: 12px; }

/* Header / Nav */
header.topbar {
  position: sticky; top: 0; z-index: 50;
  background: color-mix(in srgb, var(--bg) 90%, transparent);
  backdrop-filter: saturate(180%) blur(10px);
  -webkit-backdrop-filter: saturate(180%) blur(10px);
  border-bottom: 1px solid var(--line);
}
.topbar-inner { display: flex; align-items: center; gap: 24px; height: var(--header-h); }
.logo { display: inline-flex; align-items: center; gap: 10px; text-decoration: none; color: var(--ink); font-weight: 700; font-size: 1.05rem; letter-spacing: -0.01em; }
.logo-mark { width: 30px; height: 30px; flex-shrink: 0; }
.logo span { letter-spacing: 0.16em; font-size: 0.95rem; text-transform: uppercase; }
nav.main-nav { display: flex; gap: 18px; flex: 1; flex-wrap: nowrap; min-width: 0; }
nav.main-nav a {
  color: var(--ink-soft); text-decoration: none; font-size: 0.9rem; font-weight: 500;
  transition: color 0.15s var(--ease); padding: 6px 2px;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}
@media (max-width: 1180px) { nav.main-nav { gap: 14px; } nav.main-nav a { font-size: 0.85rem; } }
nav.main-nav a:hover { color: var(--ink); }
nav.main-nav a.active { color: var(--primary); border-bottom-color: var(--primary); }
.header-actions { display: flex; align-items: center; gap: 10px; }
.theme-toggle {
  background: transparent; border: 1px solid var(--line); cursor: pointer;
  width: 38px; height: 38px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-soft); transition: all 0.15s var(--ease);
}
.theme-toggle:hover { border-color: var(--ink); color: var(--ink); }
.theme-toggle svg { width: 18px; height: 18px; }
.nav-cta {
  background: var(--ink); color: var(--bg); border: none;
  padding: 10px 18px; border-radius: 999px; font-weight: 600; font-size: 0.9rem;
  cursor: pointer; text-decoration: none; transition: background 0.15s var(--ease);
  font-family: inherit;
}
.nav-cta:hover { background: var(--primary); color: var(--primary-on); }
@media (max-width: 880px) { nav.main-nav { display: none; } }

/* ================================================================
   Nav drawer (overlay com lista completa quando navbar inline nao cabe)
   ================================================================ */
.nav-drawer-toggle {
  display: inline-flex;
  align-items: center; gap: 6px;
  background: transparent; border: 1px solid var(--line); cursor: pointer;
  padding: 8px 12px; border-radius: 999px;
  color: var(--ink-soft); font-family: inherit; font-size: 0.85rem; font-weight: 500;
  transition: all 0.15s var(--ease);
}
.nav-drawer-toggle:hover { border-color: var(--ink); color: var(--ink); }
.nav-drawer-toggle-label { font-size: 0.85rem; }
.nav-drawer {
  position: fixed; inset: 0; z-index: 100;
  pointer-events: none; opacity: 0; transition: opacity 0.18s var(--ease);
}
.nav-drawer.is-open { pointer-events: auto; opacity: 1; }
.nav-drawer-backdrop {
  position: absolute; inset: 0;
  background: rgba(0,0,0,0.55); backdrop-filter: blur(2px);
}
.nav-drawer-panel {
  position: absolute; top: 0; right: 0; bottom: 0;
  width: min(380px, 92vw);
  background: var(--bg); border-left: 1px solid var(--line);
  display: flex; flex-direction: column;
  box-shadow: -10px 0 40px rgba(0,0,0,0.25);
  transform: translateX(100%); transition: transform 0.22s var(--ease);
  overflow-y: auto;
}
.nav-drawer.is-open .nav-drawer-panel { transform: translateX(0); }
.nav-drawer-head {
  display: flex; align-items: center; justify-content: space-between;
  padding: 18px 20px; border-bottom: 1px solid var(--line);
  position: sticky; top: 0; background: var(--bg); z-index: 1;
}
.nav-drawer-head strong {
  font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-soft);
}
.nav-drawer-close {
  background: transparent; border: 1px solid var(--line); cursor: pointer;
  width: 36px; height: 36px; border-radius: 999px;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--ink-soft); transition: all 0.15s var(--ease);
}
.nav-drawer-close:hover { border-color: var(--ink); color: var(--ink); }
.nav-drawer-list {
  display: flex; flex-direction: column; gap: 8px;
  padding: 14px 20px 28px;
}
.nav-drawer-group {
  display: flex; flex-direction: column;
  padding: 10px 0; border-bottom: 1px solid var(--line);
}
.nav-drawer-group:last-child { border-bottom: 0; }
.nav-drawer-eyebrow {
  font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); margin: 4px 0 8px;
}
.nav-drawer-list a {
  display: block; padding: 10px 0;
  color: var(--ink); text-decoration: none;
  font-size: 0.96rem; font-weight: 500;
  transition: color 0.15s var(--ease);
}
.nav-drawer-list a:hover { color: var(--primary); }

/* Em telas estreitas: esconde nav inline (drawer ja eh sempre visivel) */
@media (max-width: 1100px) {
  nav.main-nav { display: none; }
  .nav-drawer-toggle-label { display: none; }
}

/* Spacer no topbar do app.html (sem nav inline, drawer + actions a direita) */
.topbar-spacer { flex: 1; }

/* Hero */
section.hero { padding: 64px 0 48px; position: relative; overflow: hidden; }
.hero::before {
  content: ""; position: absolute; top: -100px; right: -120px;
  width: 360px; height: 360px; border-radius: 50%;
  background: radial-gradient(circle, var(--primary-glow) 0%, transparent 70%);
  pointer-events: none; z-index: 0;
}
.hero .wrap { position: relative; z-index: 1; }
.hero-eyebrow {
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.75rem; font-weight: 600; letter-spacing: 0.14em; text-transform: uppercase;
  color: var(--primary); padding: 6px 14px;
  background: var(--primary-soft); border-radius: 999px;
  margin-bottom: 22px;
  border: 1px solid color-mix(in srgb, var(--primary) 25%, transparent);
}
.hero-eyebrow .dot { width: 6px; height: 6px; border-radius: 50%; background: var(--primary); animation: pulse 2s var(--ease) infinite; }
@keyframes pulse {
  0%, 100% { opacity: 1; transform: scale(1); }
  50% { opacity: 0.5; transform: scale(1.4); }
}
h1.hero-title {
  font-size: clamp(1.9rem, 4.2vw + 0.6rem, 3.6rem);
  line-height: 1.05; letter-spacing: -0.025em; font-weight: 700;
  margin: 0 0 20px; max-width: 100%;
}
h1.hero-title .underline { color: var(--primary); }
p.hero-sub {
  font-size: clamp(1rem, 0.8vw + 0.6rem, 1.16rem);
  color: var(--ink-soft); max-width: 880px; margin: 0 0 28px; line-height: 1.55;
}
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.btn {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 14px 24px; font-size: 1rem; font-weight: 600;
  border-radius: 12px; border: 1px solid transparent;
  cursor: pointer; text-decoration: none;
  transition: transform 0.06s var(--ease), background 0.15s var(--ease), border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
  font-family: inherit;
}
.btn:active { transform: translateY(1px); }
.btn-primary { background: var(--primary); color: var(--primary-on); }
.btn-primary:hover { background: var(--primary-strong); box-shadow: 0 8px 16px var(--primary-glow); }
.btn-ghost { background: transparent; color: var(--ink); border-color: var(--line); }
.btn-ghost:hover { border-color: var(--ink); }
.btn-secondary { background: var(--ink); color: var(--bg); border: none; font-family: inherit; }
.btn-secondary:hover { background: var(--primary); color: var(--primary-on); }
.btn-tertiary { background: transparent; color: var(--ink-soft); border: 1px solid var(--line); font-family: inherit; }
.btn-tertiary:hover { color: var(--ink); border-color: var(--ink); }

/* Stats / Trust strip */
.stats { display: grid; grid-template-columns: repeat(4, 1fr); gap: var(--gap); margin-top: 40px; padding: 24px; background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); }
@media (max-width: 720px) { .stats { grid-template-columns: repeat(2, 1fr); } }
.stat-num { font-size: 1.5rem; font-weight: 700; letter-spacing: -0.01em; color: var(--primary); }
.stat-num .small { font-size: 0.78rem; font-weight: 500; color: var(--ink-mute); margin-left: 2px; }
.stat-lbl { font-size: 0.82rem; color: var(--ink-soft); margin-top: 2px; }

/* Sections base */
section { padding: 72px 0; }
section + section { border-top: 1px solid var(--line-soft); }
.section-head { max-width: 720px; margin-bottom: 36px; }
.eyebrow { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--primary); }
h2 { font-size: clamp(1.7rem, 3vw + 0.5rem, 2.5rem); line-height: 1.1; letter-spacing: -0.02em; font-weight: 700; margin: 8px 0 14px; }
h3 { font-size: 1.2rem; letter-spacing: -0.01em; font-weight: 600; margin: 0; }
.lead { font-size: 1.05rem; color: var(--ink-soft); margin: 0; line-height: 1.6; }

/* Segments strip */
.segments-strip { margin-top: 36px; }
.segments-strip .strip-eyebrow { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 14px; }
.segments-grid { display: flex; flex-wrap: wrap; gap: 8px; }
.segment-chip {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: 999px;
  padding: 10px 16px; font-size: 0.9rem; font-weight: 500; color: var(--ink);
  display: inline-flex; align-items: center; gap: 8px;
  transition: all 0.15s var(--ease);
}
.segment-chip:hover { border-color: var(--primary); color: var(--primary); transform: translateY(-1px); }
.segment-chip .seg-mark { color: var(--primary); font-size: 0.7rem; }

/* Calculator card */
.calc-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-lg);
  box-shadow: var(--shadow); overflow: hidden;
  display: grid; grid-template-columns: 1fr 1fr;
}
@media (max-width: 880px) { .calc-card { grid-template-columns: 1fr; } }
.calc-form { padding: 32px; }
.calc-results { padding: 32px; background: linear-gradient(165deg, #0a0a0a 0%, #1a0808 100%); color: #fff; position: relative; }
.calc-results::before {
  content: ""; position: absolute; top: -40px; right: -40px;
  width: 200px; height: 200px; border-radius: 50%;
  background: radial-gradient(circle, rgba(153,27,27,0.25) 0%, transparent 70%);
  pointer-events: none;
}
.field { margin-bottom: 20px; }
.field label { display: block; font-size: 0.88rem; font-weight: 600; margin-bottom: 6px; color: var(--ink); }
.field .hint { font-size: 0.78rem; color: var(--ink-mute); margin-top: 4px; line-height: 1.45; }
.field input[type="number"], .field input[type="text"] {
  width: 100%; padding: 14px 14px; font-size: 1.05rem; font-weight: 500;
  border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--bg);
  color: var(--ink); font-family: inherit;
  -moz-appearance: textfield;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.field input::-webkit-outer-spin-button,
.field input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.field input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.input-prefix { position: relative; display: block; }
.input-prefix::before {
  content: attr(data-prefix);
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  color: var(--ink-mute); font-weight: 600; pointer-events: none;
  font-size: 0.95rem; z-index: 1;
}
.input-prefix > input[type="number"],
.input-prefix > input[type="text"] { padding-left: 38px !important; }
.form-actions { display: flex; gap: 10px; margin-top: 8px; flex-wrap: wrap; }
.form-actions button { flex: 1; min-width: 130px; }

.result-eyebrow { font-size: 0.72rem; font-weight: 700; letter-spacing: 0.16em; text-transform: uppercase; color: rgba(255,255,255,0.6); margin-bottom: 4px; }
.result-main {
  margin: 8px 0 28px; padding-bottom: 24px;
  border-bottom: 1px solid rgba(255,255,255,0.12);
  position: relative;
}
.result-main .num {
  font-size: clamp(2.6rem, 5vw + 0.5rem, 3.8rem);
  font-weight: 700; letter-spacing: -0.035em; line-height: 1;
  color: var(--primary);
}
[data-theme="dark"] .result-main .num { color: #ef4444; }
.result-main .lbl { font-size: 0.95rem; color: rgba(255,255,255,0.75); margin-top: 8px; }
.result-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.result-item .num { font-size: 1.3rem; font-weight: 700; color: #fff; letter-spacing: -0.01em; }
.result-item .lbl { font-size: 0.74rem; color: rgba(255,255,255,0.6); text-transform: uppercase; letter-spacing: 0.08em; margin-top: 2px; line-height: 1.4; }
.result-actions { display: flex; gap: 8px; margin-top: 22px; padding-top: 18px; border-top: 1px solid rgba(255,255,255,0.1); flex-wrap: wrap; }
.result-action {
  flex: 1; min-width: 110px;
  background: rgba(255,255,255,0.06); color: #fff; border: 1px solid rgba(255,255,255,0.1);
  padding: 10px 12px; border-radius: 8px; font-size: 0.82rem; font-weight: 500; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  transition: all 0.15s var(--ease); font-family: inherit;
}
.result-action:hover { background: var(--primary); border-color: var(--primary); }
.result-action svg { width: 14px; height: 14px; }
.save-status { font-size: 0.78rem; color: var(--ok); margin-top: 12px; min-height: 16px; }
.save-status.error { color: var(--danger); }

/* Mini calcs */
.mini-calcs { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); margin-top: 28px; }
@media (max-width: 720px) { .mini-calcs { grid-template-columns: 1fr; } }
.mini-calc {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px; display: flex; flex-direction: column; gap: 16px;
  transition: transform 0.18s var(--ease), box-shadow 0.18s var(--ease), border-color 0.18s var(--ease);
}
.mini-calc:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-lift); }
.mini-calc h3 { font-size: 1.12rem; }
.mini-calc .mini-sub { margin: 0; font-size: 0.88rem; color: var(--ink-soft); line-height: 1.5; }
.mini-calc .mini-fields { display: grid; gap: 12px; }
.mini-calc .mini-field { display: flex; flex-direction: column; gap: 4px; }
.mini-calc .mini-field label { font-size: 0.78rem; font-weight: 600; color: var(--ink); }
.mini-calc .mini-field input {
  padding: 12px 14px; font-size: 1rem; border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: var(--bg); color: var(--ink); font-family: inherit;
  -moz-appearance: textfield;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.mini-calc .mini-field input::-webkit-outer-spin-button,
.mini-calc .mini-field input::-webkit-inner-spin-button { -webkit-appearance: none; margin: 0; }
.mini-calc .mini-field input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.mini-calc .mini-field .input-prefix { position: relative; }
.mini-calc .mini-field .input-prefix::before {
  content: attr(data-prefix); position: absolute; left: 12px; top: 50%; transform: translateY(-50%);
  color: var(--ink-mute); font-weight: 600; pointer-events: none; font-size: 0.92rem;
}
.mini-calc .mini-field .input-prefix input { padding-left: 32px; }
.mini-calc .smart-fill {
  font-size: 0.76rem; color: var(--primary); cursor: pointer; user-select: none;
  border: none; background: transparent; padding: 0; text-align: left; font-family: inherit;
  text-decoration: underline; text-decoration-style: dotted; text-underline-offset: 3px;
}
.mini-calc .smart-fill:hover { color: var(--primary-strong); }
.mini-calc .mini-result {
  margin-top: auto; padding: 18px; background: var(--ink); color: #fff; border-radius: var(--radius-sm);
  display: flex; align-items: baseline; justify-content: space-between; gap: 12px; flex-wrap: wrap;
}
.mini-calc .mini-result .lbl { font-size: 0.74rem; color: rgba(255,255,255,0.7); text-transform: uppercase; letter-spacing: 0.06em; }
.mini-calc .mini-result .val { font-size: 1.55rem; font-weight: 700; color: var(--primary); letter-spacing: -0.01em; }
[data-theme="dark"] .mini-calc .mini-result .val { color: #ef4444; }

/* Plate search */
.plate-search {
  background: linear-gradient(135deg, #0a0a0a 0%, #1a0808 100%); color: #fff;
  border-radius: var(--radius-lg); padding: 48px;
  display: grid; gap: 28px; grid-template-columns: 1.1fr 1fr; align-items: center;
  position: relative; overflow: hidden;
}
.plate-search::before {
  content: ""; position: absolute; bottom: -80px; right: -80px;
  width: 280px; height: 280px; border-radius: 50%;
  background: radial-gradient(circle, rgba(153,27,27,0.3) 0%, transparent 70%);
  pointer-events: none;
}
.plate-search > * { position: relative; z-index: 1; }
@media (max-width: 880px) { .plate-search { grid-template-columns: 1fr; padding: 32px; } }
.plate-eyebrow { display: inline-block; font-size: 0.72rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: #ef4444; margin-bottom: 12px; }
.plate-search h3 { font-size: 1.7rem; letter-spacing: -0.02em; line-height: 1.15; margin: 0 0 14px; color: #fff; }
.plate-desc { margin: 0; color: rgba(255,255,255,0.78); font-size: 0.98rem; line-height: 1.6; }
.plate-form { display: flex; gap: 10px; flex-wrap: wrap; align-items: stretch; }
.plate-input {
  flex: 1 1 220px; min-width: 0; padding: 16px 18px;
  font-size: 1.2rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  border: 2px solid rgba(255,255,255,0.18); border-radius: var(--radius-sm); background: rgba(255,255,255,0.04);
  color: #fff; font-family: ui-monospace, "SF Mono", Consolas, monospace;
  transition: border-color 0.15s var(--ease), background 0.15s var(--ease);
}
.plate-input::placeholder { color: rgba(255,255,255,0.32); letter-spacing: 0.06em; }
.plate-input:focus { outline: none; border-color: #ef4444; background: rgba(255,255,255,0.08); }
.plate-cta {
  background: var(--primary); color: #fff; border: none;
  padding: 16px 24px; border-radius: var(--radius-sm); font-weight: 700; font-size: 0.95rem;
  cursor: pointer; transition: background 0.15s var(--ease); font-family: inherit;
}
.plate-cta:hover { background: var(--primary-strong); }
.plate-feedback { font-size: 0.9rem; color: #ef4444; min-height: 1.3em; margin-top: 8px; }
.plate-feedback.hidden { display: none; }

/* Roadmap cards */
.cards { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--gap); }
.card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px; position: relative;
  transition: transform 0.18s var(--ease), box-shadow 0.18s var(--ease), border-color 0.18s var(--ease);
}
.card:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); border-color: var(--ink); }
.card .phase {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); margin-bottom: 14px;
}
.card .phase-mark { width: 8px; height: 8px; border-radius: 50%; background: var(--line); display: inline-block; }
.card.live .phase { color: var(--ok); }
.card.live .phase-mark { background: var(--ok); box-shadow: 0 0 0 3px var(--ok-soft); }
.card.next .phase { color: var(--primary); }
.card.next .phase-mark { background: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.card h3 { font-size: 1.18rem; margin: 0 0 8px; }
.card p { margin: 0; color: var(--ink-soft); font-size: 0.96rem; line-height: 1.55; }

/* Plans */
.plans { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--gap); }
.plan {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 32px 28px; display: flex; flex-direction: column; gap: 14px; position: relative;
  transition: transform 0.18s var(--ease), box-shadow 0.18s var(--ease), border-color 0.18s var(--ease);
}
.plan:hover { transform: translateY(-3px); box-shadow: var(--shadow-lift); }
.plan.recommended { border-color: var(--primary); border-width: 2px; box-shadow: 0 0 0 6px var(--primary-glow); }
.plan.recommended::before {
  content: "Recomendado"; position: absolute; top: -12px; left: 24px;
  background: var(--primary); color: var(--primary-on); font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.12em; padding: 5px 12px; border-radius: 999px; text-transform: uppercase;
}
.plan-name { font-size: 0.85rem; font-weight: 700; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.12em; }
.plan-price { font-size: 2.4rem; font-weight: 700; letter-spacing: -0.025em; line-height: 1; }
.plan-price .per { font-size: 0.95rem; font-weight: 500; color: var(--ink-mute); }
.plan-trial-tag {
  display: inline-block; align-self: flex-start;
  font-size: 0.68rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--ok-soft); color: var(--ok);
  padding: 5px 12px; border-radius: 999px;
}
.plan ul { list-style: none; padding: 0; margin: 6px 0 0; display: flex; flex-direction: column; gap: 10px; }
.plan li { font-size: 0.94rem; color: var(--ink-soft); display: flex; gap: 10px; align-items: flex-start; line-height: 1.5; }
.plan li::before { content: "✓"; color: var(--primary); font-size: 0.82rem; font-weight: 800; flex-shrink: 0; transform: translateY(2px); }
.plan .btn { margin-top: auto; }

/* Comparativo */
.compare-grid { display: grid; grid-template-columns: 1fr 1fr; gap: var(--gap); }
@media (max-width: 720px) { .compare-grid { grid-template-columns: 1fr; } }
.compare-card { background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius); padding: 32px; }
.compare-card.torque { border-color: var(--primary); border-width: 2px; }
.compare-tag {
  display: inline-block; font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  padding: 5px 12px; border-radius: 999px; margin-bottom: 18px;
}
.compare-card.torque .compare-tag { background: var(--primary); color: var(--primary-on); }
.compare-card.legacy .compare-tag { background: var(--bg-mute); color: var(--ink-mute); }
.compare-card h3 { font-size: 1.25rem; margin: 0 0 18px; }
.compare-card ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 14px; }
.compare-card li { display: flex; gap: 12px; align-items: flex-start; font-size: 0.96rem; line-height: 1.55; color: var(--ink); }
.compare-card.legacy li { color: var(--ink-soft); }
.compare-card .marker { flex-shrink: 0; font-size: 0.85rem; line-height: 1.6; font-weight: 700; }
.compare-card.torque .marker { color: var(--primary); }
.compare-card.legacy .marker { color: var(--ink-mute); }
.compare-foot { margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); font-size: 0.82rem; color: var(--ink-mute); line-height: 1.5; }

/* FAQ */
.faq-list { display: flex; flex-direction: column; gap: 10px; }
.faq-item {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; transition: border-color 0.15s var(--ease);
}
.faq-item[open] { border-color: var(--primary); }
.faq-item summary {
  list-style: none; cursor: pointer; padding: 22px 26px;
  font-size: 1.02rem; font-weight: 600; color: var(--ink);
  display: flex; align-items: center; justify-content: space-between; gap: 16px;
  transition: color 0.15s var(--ease);
}
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after {
  content: "+"; font-size: 1.6rem; font-weight: 400; color: var(--primary);
  line-height: 1; transition: transform 0.2s var(--ease);
}
.faq-item[open] summary::after { content: "−"; }
.faq-item summary:hover { color: var(--primary); }
.faq-answer {
  padding: 0 26px 22px; color: var(--ink-soft); line-height: 1.65; font-size: 0.97rem;
}

/* CTA Final */
.cta-final {
  background: linear-gradient(135deg, var(--ink) 0%, #1a0808 100%); color: #fff;
  border-radius: var(--radius-lg); padding: 56px;
  text-align: center; position: relative; overflow: hidden;
}
.cta-final::before {
  content: ""; position: absolute; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 600px; height: 600px; border-radius: 50%;
  background: radial-gradient(circle, var(--primary-glow) 0%, transparent 60%);
  pointer-events: none;
}
.cta-final > * { position: relative; z-index: 1; }
.cta-final h2 { color: #fff; max-width: 720px; margin: 0 auto 16px; }
.cta-final p { color: rgba(255,255,255,0.75); max-width: 580px; margin: 0 auto 28px; font-size: 1.05rem; line-height: 1.6; }
.cta-final .hero-actions { justify-content: center; }
@media (max-width: 720px) { .cta-final { padding: 40px 24px; } }

/* Footer */
footer.site-foot {
  background: var(--bg-elev); border-top: 1px solid var(--line);
  padding: 56px 0 24px; margin-top: 24px;
}
.foot-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 32px; margin-bottom: 40px; }
@media (max-width: 880px) { .foot-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 540px) { .foot-grid { grid-template-columns: 1fr; } }
.foot-brand .logo { margin-bottom: 14px; }
.foot-tag { font-size: 0.92rem; color: var(--ink-soft); line-height: 1.55; max-width: 320px; }
.foot-col h4 { font-size: 0.78rem; font-weight: 700; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-mute); margin: 0 0 14px; }
.foot-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.foot-col a { color: var(--ink-soft); text-decoration: none; font-size: 0.92rem; transition: color 0.15s var(--ease); }
.foot-col a:hover { color: var(--primary); }
.foot-bottom {
  border-top: 1px solid var(--line); padding-top: 20px;
  display: flex; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  font-size: 0.82rem; color: var(--ink-mute);
}
.foot-badge {
  display: inline-block; font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.14em; text-transform: uppercase;
  background: var(--primary-soft); color: var(--primary);
  padding: 5px 12px; border-radius: 999px;
}
[data-theme="dark"] .foot-badge { background: var(--primary-soft); color: #ef4444; }

/* Reveal-on-scroll */
.reveal { opacity: 0; transform: translateY(20px); transition: opacity 0.6s var(--ease), transform 0.6s var(--ease); }
.reveal.in { opacity: 1; transform: translateY(0); }

/* Modal */
.modal-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6);
  display: none; align-items: center; justify-content: center; z-index: 10001;
  padding: 20px; backdrop-filter: blur(4px);
}
.modal-backdrop.open { display: flex; animation: fade 0.2s var(--ease); }
@keyframes fade { from { opacity: 0; } to { opacity: 1; } }
.modal {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-lg);
  max-width: 480px; width: 100%; padding: 32px; box-shadow: var(--shadow-lift);
  max-height: 90vh; overflow-y: auto;
  animation: slideUp 0.25s var(--ease);
}
@keyframes slideUp { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: translateY(0); } }
.modal-head { display: flex; align-items: flex-start; justify-content: space-between; gap: 16px; margin-bottom: 20px; }
.modal-head h3 { font-size: 1.35rem; letter-spacing: -0.015em; margin: 0; }
.modal-head .modal-sub { font-size: 0.92rem; color: var(--ink-soft); margin: 6px 0 0; line-height: 1.5; }
.modal-close {
  background: transparent; border: 1px solid var(--line); width: 36px; height: 36px;
  border-radius: 999px; cursor: pointer; flex-shrink: 0;
  color: var(--ink-soft); font-size: 1.2rem; display: inline-flex; align-items: center; justify-content: center;
  font-family: inherit; line-height: 1;
}
.modal-close:hover { color: var(--ink); border-color: var(--ink); }
.modal form { display: flex; flex-direction: column; gap: 14px; }
.modal label { display: block; font-size: 0.85rem; font-weight: 600; margin-bottom: 4px; color: var(--ink); }
.modal input, .modal select, .modal textarea {
  width: 100%; padding: 12px 14px; font-size: 1rem; border: 1px solid var(--line);
  border-radius: var(--radius-sm); background: var(--bg); color: var(--ink); font-family: inherit;
  transition: border-color 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.modal textarea { resize: vertical; min-height: 80px; }
.modal input:focus, .modal select:focus, .modal textarea:focus {
  outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow);
}
.modal .submit-row { display: flex; gap: 10px; margin-top: 8px; }
.modal .submit-row button { flex: 1; }
.modal-status { font-size: 0.86rem; min-height: 1.4em; margin-top: 6px; }
.modal-status.ok { color: var(--ok); }
.modal-status.err { color: var(--danger); }
.modal-status.info { color: var(--ink-soft); }

/* === Landing page específico === */

/* Steps numerados (Como funciona) */
.steps { display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); gap: var(--gap); counter-reset: step-counter; }
.step {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px; position: relative; counter-increment: step-counter;
  transition: transform 0.18s var(--ease), border-color 0.18s var(--ease);
}
.step:hover { transform: translateY(-3px); border-color: var(--primary); }
.step::before {
  content: counter(step-counter, decimal-leading-zero);
  position: absolute; top: 24px; right: 26px;
  font-size: 2rem; font-weight: 700; color: var(--primary);
  letter-spacing: -0.02em; opacity: 0.85;
}
.step h3 { font-size: 1.15rem; margin: 0 0 10px; max-width: 80%; }
.step p { margin: 0; color: var(--ink-soft); font-size: 0.96rem; line-height: 1.55; }

/* Manual / guia de features */
.guide-list { display: flex; flex-direction: column; gap: var(--gap); }
.guide-item {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px; display: grid; grid-template-columns: 60px 1fr; gap: 20px; align-items: flex-start;
}
@media (max-width: 540px) { .guide-item { grid-template-columns: 1fr; } }
.guide-icon {
  width: 60px; height: 60px; border-radius: var(--radius-sm);
  background: var(--primary-soft); color: var(--primary);
  display: inline-flex; align-items: center; justify-content: center;
  font-size: 1.4rem; font-weight: 800; flex-shrink: 0;
}
.guide-body h3 { margin: 0 0 8px; font-size: 1.18rem; }
.guide-body p { margin: 0 0 12px; color: var(--ink-soft); font-size: 0.97rem; line-height: 1.6; }
.guide-body p:last-child { margin-bottom: 0; }
.guide-body code {
  background: var(--bg-mute); color: var(--primary); padding: 2px 6px; border-radius: 4px;
  font-family: ui-monospace, "SF Mono", Consolas, monospace; font-size: 0.88em;
}

/* Diretrizes / regras */
.principles { display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--gap); }
.principle {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 26px; transition: border-color 0.18s var(--ease);
}
.principle:hover { border-color: var(--primary); }
.principle .pmark {
  display: inline-block; width: 30px; height: 30px; border-radius: 8px;
  background: var(--primary-soft); color: var(--primary);
  font-size: 0.9rem; font-weight: 700; line-height: 30px; text-align: center;
  margin-bottom: 14px;
}
.principle h3 { font-size: 1.08rem; margin: 0 0 8px; }
.principle p { margin: 0; color: var(--ink-soft); font-size: 0.93rem; line-height: 1.55; }

/* === Fase 2: Banco de tempos-padrão === */

.service-filters {
  display: flex; gap: 8px; flex-wrap: wrap; margin-bottom: 28px;
}
.service-filter-chip {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: 999px;
  padding: 8px 16px; font-size: 0.88rem; font-weight: 500; color: var(--ink);
  cursor: pointer; transition: all 0.15s var(--ease); font-family: inherit;
}
.service-filter-chip:hover { border-color: var(--primary); color: var(--primary); }
.service-filter-chip.active { background: var(--primary); color: var(--primary-on); border-color: var(--primary); }

.services-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: var(--gap);
}
.service-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; cursor: pointer;
  display: flex; flex-direction: column; gap: 10px;
  transition: all 0.18s var(--ease);
  text-align: left; font-family: inherit; color: var(--ink); width: 100%;
}
.service-card:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-lift); }
.service-card .cat-badge {
  display: inline-block; font-size: 0.66rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--primary-soft); color: var(--primary);
  padding: 3px 9px; border-radius: 999px; align-self: flex-start;
}
.service-card h3 { font-size: 1.04rem; margin: 0; line-height: 1.3; font-weight: 600; }
.service-card .descr { font-size: 0.85rem; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.service-card .time-row {
  display: flex; align-items: baseline; gap: 8px;
  padding-top: 12px; border-top: 1px solid var(--line-soft);
  margin-top: auto;
}
.service-card .time-num { font-size: 1.45rem; font-weight: 700; color: var(--primary); letter-spacing: -0.01em; }
.service-card .time-lbl { font-size: 0.76rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.06em; }

/* Modal de orçamento (reusa .modal base) */
.orcamento-info {
  background: var(--bg-mute); border-radius: var(--radius-sm); padding: 16px 18px;
  margin-bottom: 18px;
}
.orcamento-info .o-cat {
  font-size: 0.68rem; color: var(--primary); text-transform: uppercase;
  letter-spacing: 0.12em; font-weight: 700;
}
.orcamento-info .o-name {
  font-size: 1.08rem; font-weight: 600; margin: 4px 0 6px; color: var(--ink); line-height: 1.3;
}
.orcamento-info .o-detail { font-size: 0.84rem; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.orcamento-info .o-detail strong { color: var(--ink); }

.orcamento-result {
  background: var(--ink); color: #fff; padding: 18px;
  border-radius: var(--radius-sm); display: flex; flex-direction: column; gap: 8px;
  margin-top: 4px;
}
.orcamento-result .o-row {
  display: flex; justify-content: space-between; font-size: 0.92rem; color: rgba(255,255,255,0.75);
}
.orcamento-result .o-total {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-top: 12px; border-top: 1px solid rgba(255,255,255,0.15); margin-top: 4px;
}
.orcamento-result .o-total span:first-child {
  font-size: 0.78rem; color: rgba(255,255,255,0.65); text-transform: uppercase; letter-spacing: 0.08em;
}
.orcamento-result .o-total .val {
  font-size: 1.7rem; font-weight: 800; color: var(--primary); letter-spacing: -0.02em;
}
[data-theme="dark"] .orcamento-result .o-total .val { color: #ef4444; }

.fase2-disclaimer {
  background: var(--primary-soft); border: 1px solid color-mix(in srgb, var(--primary) 25%, transparent);
  border-radius: var(--radius-sm); padding: 14px 18px;
  font-size: 0.86rem; color: var(--ink-soft); line-height: 1.55;
  margin-bottom: 28px;
}
.fase2-disclaimer strong { color: var(--primary); }

/* Orçamento — ações pós-cálculo */
.orc-actions {
  display: flex; gap: 8px; margin-top: 18px; flex-wrap: wrap;
}
.orc-action {
  flex: 1 1 calc(50% - 4px); min-width: 130px;
  background: var(--bg-mute); color: var(--ink);
  border: 1px solid var(--line); border-radius: 10px;
  padding: 11px 12px; font-size: 0.85rem; font-weight: 500;
  cursor: pointer; font-family: inherit;
  display: inline-flex; align-items: center; justify-content: center; gap: 6px;
  transition: all 0.15s var(--ease);
}
.orc-action svg { width: 14px; height: 14px; }
.orc-action:hover { background: var(--primary); color: var(--primary-on); border-color: var(--primary); }
.orc-action.danger:hover { background: var(--danger); color: #fff; border-color: var(--danger); }
.orc-status { font-size: 0.85rem; min-height: 1.4em; margin-top: 8px; color: var(--ok); }
.orc-status.err { color: var(--danger); }
.orc-status.info { color: var(--ink-soft); }

/* Form de feedback de tempo */
.orc-feedback {
  margin-top: 18px; padding: 18px; background: var(--bg-mute);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
}
.orc-feedback h4 { margin: 0 0 6px; font-size: 1rem; font-weight: 600; }
.orc-feedback p { margin: 0 0 14px; font-size: 0.86rem; color: var(--ink-soft); line-height: 1.5; }
.feedback-fields { display: flex; flex-direction: column; gap: 12px; }
.feedback-fields textarea { resize: vertical; min-height: 60px; padding: 10px 12px; border: 1px solid var(--line); border-radius: var(--radius-sm); background: var(--bg); color: var(--ink); font-family: inherit; font-size: 0.95rem; }
.feedback-fields textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.feedback-actions { display: flex; gap: 10px; margin-top: 12px; }
.feedback-actions .btn { flex: 1; }

/* Histórico de orçamentos salvos */
.orc-history {
  margin-top: 28px;
}
.orc-history h3 {
  font-size: 1.1rem; font-weight: 600; margin: 0 0 14px; color: var(--ink);
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  flex-wrap: wrap;
}
.orc-history-tools {
  display: inline-flex; gap: 6px; flex-wrap: wrap; align-items: center;
}
.orc-export-btn {
  font-size: 0.74rem; font-weight: 600; letter-spacing: 0.04em;
  background: var(--bg-mute); color: var(--ink);
  border: 1px solid var(--line); border-radius: 999px;
  padding: 4px 12px; cursor: pointer; font-family: inherit;
  transition: all 0.15s var(--ease);
}
.orc-export-btn:hover { background: var(--primary); color: var(--primary-on); border-color: var(--primary); }
.orc-history h3 .clear-all {
  font-size: 0.78rem; font-weight: 500; color: var(--ink-mute);
  background: transparent; border: 1px solid var(--line); border-radius: 999px;
  padding: 4px 12px; cursor: pointer; font-family: inherit;
  transition: all 0.15s var(--ease);
}
.orc-history h3 .clear-all:hover { color: var(--danger); border-color: var(--danger); }
.services-empty {
  grid-column: 1 / -1;
  text-align: center; padding: 32px 18px;
  color: var(--ink-mute); font-size: 0.92rem;
  border: 1px dashed var(--line); border-radius: var(--radius-sm);
}

/* === Fase 3 — Manuais técnicos === */
.manuais-disclaimer {
  background: color-mix(in srgb, var(--danger) 8%, transparent);
  border-left: 3px solid var(--danger);
  border-radius: var(--radius-sm); padding: 14px 18px;
  font-size: 0.84rem; color: var(--ink-soft); line-height: 1.55;
  margin-bottom: 24px;
}
.manuais-disclaimer strong { color: var(--danger); }

.manuais-tools {
  display: flex; align-items: flex-start; justify-content: space-between;
  gap: 14px; margin-bottom: 22px; flex-wrap: wrap;
}
.manual-search-wrap {
  position: relative; flex: 1 1 100%;
  display: flex; align-items: center;
}
.manual-search-icon {
  position: absolute; left: 14px;
  width: 18px; height: 18px; color: var(--ink-mute);
  pointer-events: none;
}
.manual-search-input {
  width: 100%;
  padding: 11px 40px 11px 42px;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  font-size: 0.92rem; color: var(--ink);
  font-family: inherit;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.manual-search-input:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--primary-glow);
}
.manual-search-input::placeholder { color: var(--ink-mute); }
.manual-search-clear {
  position: absolute; right: 8px;
  width: 28px; height: 28px;
  background: none; border: none;
  color: var(--ink-mute); cursor: pointer;
  font-size: 1.4rem; line-height: 1;
  border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
}
.manual-search-clear:hover { background: var(--bg-mute); color: var(--ink); }
.manual-filters {
  display: flex; gap: 8px; flex-wrap: wrap; flex: 1;
}
.submit-manual-btn {
  white-space: nowrap; align-self: flex-start;
  padding: 8px 14px; font-size: 0.86rem;
}

.manuais-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(290px, 1fr)); gap: var(--gap);
}
.manual-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; cursor: pointer;
  display: flex; flex-direction: column; gap: 10px;
  transition: all 0.18s var(--ease);
  text-align: left; font-family: inherit; color: var(--ink); width: 100%;
}
.manual-card:hover { border-color: var(--primary); transform: translateY(-2px); box-shadow: var(--shadow-lift); }
.manual-card .cat-badge {
  display: inline-block; font-size: 0.66rem; font-weight: 700;
  letter-spacing: 0.1em; text-transform: uppercase;
  background: var(--primary-soft); color: var(--primary);
  padding: 3px 9px; border-radius: 999px; align-self: flex-start;
}
.manual-card h3 { font-size: 1.04rem; margin: 0; line-height: 1.3; font-weight: 600; }
.manual-card .descr { font-size: 0.85rem; color: var(--ink-soft); margin: 0; line-height: 1.5; }
.manual-meta-row {
  display: flex; align-items: center; gap: 14px;
  padding-top: 12px; border-top: 1px solid var(--line-soft);
  margin-top: auto; font-size: 0.82rem;
  flex-wrap: wrap;
}
.manual-meta-row .diff { color: var(--ink-soft); }
.manual-meta-row .diff-bar { color: var(--primary); letter-spacing: 0.1em; margin-right: 4px; }
.manual-meta-row .time { color: var(--ink); font-weight: 600; margin-left: auto; }
.manual-meta-row .votos { color: var(--ok); font-weight: 600; }

/* Modal grande pra manuais */
.modal.modal-lg { max-width: 760px; }

.manual-cat-badge {
  display: inline-block; font-size: 0.68rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  background: var(--primary-soft); color: var(--primary);
  padding: 4px 10px; border-radius: 999px;
  margin-bottom: 8px;
}
.manual-modal-title { font-size: 1.4rem !important; line-height: 1.25; margin: 0 0 4px; }
.manual-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px;
  background: var(--bg-mute); border-radius: var(--radius-sm);
  padding: 14px 16px; margin: 14px 0 18px;
}
.manual-meta .meta-cell { display: flex; flex-direction: column; gap: 2px; }
.manual-meta .meta-lbl { font-size: 0.66rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.1em; font-weight: 600; }
.manual-meta .meta-val { font-size: 0.92rem; color: var(--ink); font-weight: 500; line-height: 1.3; }
.manual-meta .meta-val.tiny { font-size: 0.78rem; color: var(--ink-soft); font-weight: 400; }
.manual-meta .meta-val .diff-bar { color: var(--primary); margin-right: 4px; }

.manual-tabs {
  display: flex; gap: 0; border-bottom: 1px solid var(--line);
  margin-bottom: 14px; overflow-x: auto;
}
.manual-tab {
  background: transparent; border: none; border-bottom: 2px solid transparent;
  padding: 10px 14px; font-size: 0.88rem; font-weight: 500;
  color: var(--ink-mute); cursor: pointer; font-family: inherit;
  white-space: nowrap; transition: all 0.15s var(--ease);
}
.manual-tab:hover { color: var(--ink); }
.manual-tab.active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }

.manual-tab-body { min-height: 180px; padding: 4px 0 12px; }
.manual-list { padding-left: 18px; margin: 0; }
.manual-list li { margin: 8px 0; line-height: 1.55; font-size: 0.94rem; color: var(--ink); }
.manual-list.manual-warn li { color: #b45309; }
.manual-list.manual-tips li { color: #0369a1; }
[data-theme="dark"] .manual-list.manual-warn li { color: #fbbf24; }
[data-theme="dark"] .manual-list.manual-tips li { color: #38bdf8; }
.manual-procedure {
  padding-left: 0; margin: 0;
  list-style: none; counter-reset: proc;
}
.manual-procedure li {
  counter-increment: proc;
  padding: 10px 12px 10px 44px; position: relative;
  font-size: 0.94rem; line-height: 1.55; color: var(--ink);
  border-bottom: 1px solid var(--line-soft);
}
.manual-procedure li::before {
  content: counter(proc, decimal-leading-zero);
  position: absolute; left: 12px; top: 11px;
  font-size: 0.78rem; font-weight: 700; color: var(--primary);
  letter-spacing: 0.04em; font-family: var(--font-mono, monospace);
}
.manual-procedure li:last-child { border-bottom: none; }
.manual-pecas {
  margin-top: 12px; padding: 10px 14px;
  background: var(--bg-mute); border-radius: var(--radius-sm);
  font-size: 0.88rem; color: var(--ink-soft);
}
.manual-pecas strong { color: var(--ink); }

.manual-actions {
  display: flex; gap: 8px; margin-top: 18px;
  padding-top: 14px; border-top: 1px solid var(--line);
  flex-wrap: wrap;
}
.manual-actions .orc-action { flex: 1 1 calc(25% - 6px); min-width: 110px; }

/* === Fase 4 — Orçamentos PRO + Clientes + Catálogo de peças === */
.orc-pro-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); gap: var(--gap);
  margin-bottom: 24px;
}
.orc-pro-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; display: flex; flex-direction: column; gap: 10px;
}
.orc-pro-icon {
  width: 36px; height: 36px;
  background: var(--primary-soft); color: var(--primary);
  border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
}
.orc-pro-icon svg { width: 18px; height: 18px; }
.orc-pro-card h3 { font-size: 1.05rem; margin: 4px 0 0; font-weight: 600; }
.orc-pro-status {
  font-size: 0.86rem; color: var(--ink-soft); margin: 0;
  flex: 1;
}
.orc-pro-status.configured { color: var(--ok); font-weight: 500; }
.orc-pro-card .btn { align-self: flex-start; padding: 8px 16px; font-size: 0.86rem; }

.orc-pro-list { margin-top: 28px; }
.orc-pro-list h3 { font-size: 1.1rem; font-weight: 600; margin: 0 0 14px; }
.orc-pro-list-items { display: flex; flex-direction: column; gap: 10px; }
.orc-pro-item {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 18px;
  display: grid; grid-template-columns: 1fr auto auto; gap: 14px; align-items: center;
}
.orc-pro-item .op-num { font-size: 0.78rem; color: var(--ink-mute); font-weight: 600; letter-spacing: 0.04em; }
.orc-pro-item .op-cli { font-weight: 600; color: var(--ink); margin: 2px 0; }
.orc-pro-item .op-dt { font-size: 0.78rem; color: var(--ink-mute); }
.orc-pro-item .op-tot { font-size: 1.1rem; font-weight: 700; color: var(--primary); white-space: nowrap; }
.orc-pro-item .op-actions { display: flex; gap: 6px; }

/* Lista de clientes (modal) */
.clientes-list-actions { margin-bottom: 14px; }
.clientes-list-actions .btn { padding: 8px 16px; font-size: 0.88rem; }
.clientes-list-body { display: flex; flex-direction: column; gap: 8px; max-height: 50vh; overflow-y: auto; padding-right: 4px; }
.cliente-item {
  background: var(--bg-mute); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 12px 14px;
  display: flex; justify-content: space-between; align-items: center; gap: 12px;
}
.cliente-item:hover { border-color: var(--primary); }
.cliente-item .cl-nome { font-weight: 600; color: var(--ink); }
.cliente-item .cl-meta { font-size: 0.82rem; color: var(--ink-mute); margin-top: 2px; }
.cliente-item .cl-actions { display: flex; gap: 6px; }
.cl-action-btn {
  background: transparent; border: 1px solid var(--line); border-radius: 6px;
  width: 30px; height: 30px; cursor: pointer; color: var(--ink-mute);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: inherit; font-size: 0.92rem;
  transition: all 0.15s var(--ease);
}
.cl-action-btn:hover { color: var(--primary); border-color: var(--primary); }
.cl-action-btn.cl-danger:hover { color: var(--danger); border-color: var(--danger); }

/* Logo preview */
.logo-preview {
  display: flex; align-items: center; gap: 10px;
  margin-top: 8px; padding: 8px; background: var(--bg-mute);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
}
.logo-preview img {
  width: 48px; height: 48px; object-fit: contain;
  background: white; border-radius: 4px;
}

/* Orçamento PRO modal — itens dinâmicos */
.op-cliente-row { display: flex; gap: 8px; align-items: stretch; }
.op-cliente-row select { flex: 1; }

.op-itens-block {
  margin: 18px 0;
  border-top: 1px solid var(--line);
  padding-top: 16px;
}
.op-itens-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 12px;
}
.op-itens-head h4 { font-size: 1rem; font-weight: 600; margin: 0; }
.op-itens-head .btn { padding: 6px 12px; font-size: 0.82rem; }
.op-itens-empty {
  padding: 18px;
  text-align: center; font-size: 0.86rem; color: var(--ink-mute);
  border: 1px dashed var(--line); border-radius: var(--radius-sm);
}
.op-item {
  background: var(--bg-mute); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 12px 14px; margin-bottom: 8px;
}
.op-item-row { display: flex; gap: 8px; align-items: center; }
.op-item-row + .op-item-row { margin-top: 8px; }
.op-item-desc { flex: 1; padding: 8px 10px; font-size: 0.92rem; }
.op-item-vals {
  display: grid; grid-template-columns: 1fr 1fr 1fr auto; gap: 8px;
  align-items: end;
}
.op-item-vals label {
  display: flex; flex-direction: column; gap: 2px;
  font-size: 0.72rem; color: var(--ink-mute); font-weight: 500;
}
.op-item-vals input {
  padding: 6px 8px; font-size: 0.88rem;
  border: 1px solid var(--line); border-radius: 6px;
  background: var(--bg); color: var(--ink); font-family: inherit;
}
.op-item-vals input:focus { outline: none; border-color: var(--primary); }
.op-item-total {
  font-weight: 700; color: var(--primary); white-space: nowrap;
  align-self: end; padding-bottom: 6px;
}

.op-totais {
  background: var(--bg-mute); border-radius: var(--radius-sm);
  padding: 14px 18px; margin: 8px 0;
  display: flex; flex-direction: column; gap: 6px;
}
.op-row {
  display: flex; justify-content: space-between; font-size: 0.92rem; color: var(--ink-soft);
}
.op-row-input {
  display: flex; justify-content: space-between; align-items: center;
}
.op-row-input label { font-size: 0.86rem; color: var(--ink-soft); margin-bottom: 0; }
.op-row-input input {
  text-align: right; padding: 4px 8px; font-size: 0.88rem;
  border: 1px solid var(--line); border-radius: 4px;
  background: var(--bg); color: var(--ink);
}
.op-total {
  display: flex; justify-content: space-between; align-items: center;
  padding-top: 10px; border-top: 1px solid var(--line);
  font-size: 1.1rem;
}
.op-total span:last-child { font-weight: 700; color: var(--primary); font-size: 1.4rem; }

/* Catálogo de peças */
.pecas-search-bar { margin-bottom: 14px; }
.pecas-search-bar input {
  width: 100%;
  padding: 12px 16px; font-size: 0.95rem;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: var(--bg-elev); color: var(--ink); font-family: inherit;
}
.pecas-search-bar input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }

.pecas-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr)); gap: var(--gap);
  margin: 18px 0;
}
.peca-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 20px;
  display: flex; flex-direction: column; gap: 8px;
  transition: all 0.15s var(--ease);
}
.peca-card:hover { border-color: var(--primary); }
.peca-card h3 { font-size: 1rem; margin: 0; font-weight: 600; line-height: 1.3; }
.peca-card p { font-size: 0.86rem; color: var(--ink-soft); margin: 0; line-height: 1.5; flex: 1; }
.peca-card .peca-cat {
  font-size: 0.7rem; color: var(--primary); font-weight: 600;
  letter-spacing: 0.06em; text-transform: uppercase;
}
.peca-card .peca-go {
  align-self: flex-start; padding: 7px 14px; font-size: 0.84rem;
}
.pecas-disclaimer {
  background: var(--bg-mute); border: 1px solid var(--line);
  border-radius: var(--radius-sm); padding: 12px 16px;
  font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5;
  margin-top: 12px;
}
.pecas-disclaimer strong { color: var(--ink); }

/* === Auth UI === */
.auth-wrap { position: relative; }
.auth-btn {
  background: var(--bg-elev); color: var(--ink);
  border: 1px solid var(--line); border-radius: 999px;
  padding: 6px 14px 6px 10px;
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.84rem; font-weight: 500; cursor: pointer; font-family: inherit;
  min-height: 36px;
  transition: all 0.15s var(--ease);
}
.auth-btn:hover { border-color: var(--primary); color: var(--primary); }
.auth-btn .auth-avatar {
  display: inline-flex; align-items: center; justify-content: center;
  width: 28px; height: 28px; border-radius: 50%;
  background: var(--primary); color: var(--primary-on);
  font-weight: 700; font-size: 0.86rem;
}
.auth-menu {
  position: absolute; top: calc(100% + 6px); right: 0;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: var(--radius-sm); box-shadow: var(--shadow-lift);
  min-width: 240px; padding: 6px;
  display: none; z-index: 100;
}
.auth-menu.open { display: block; }
.auth-menu-head {
  padding: 12px 14px; border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}
.auth-menu-name { font-size: 0.92rem; font-weight: 600; color: var(--ink); }
.auth-menu-email { font-size: 0.78rem; color: var(--ink-mute); margin-top: 2px; word-break: break-all; }
.auth-menu-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px; font-size: 0.86rem; color: var(--ink);
  background: transparent; border: none; border-radius: 6px;
  cursor: pointer; text-align: left; width: 100%;
  font-family: inherit; text-decoration: none;
  transition: background 0.12s var(--ease);
}
.auth-menu-item[hidden] { display: none; }

/* Paywall overlay (cobre /app inteiro quando user nao tem assinatura ativa) */
.paywall-overlay {
  position: fixed; inset: 0; z-index: 9999;
  background: var(--bg);
  overflow-y: auto;
  display: flex; align-items: flex-start; justify-content: center;
  padding: 40px 20px;
}
.paywall-overlay[hidden] { display: none; }
.paywall-card {
  width: 100%; max-width: 980px;
  display: flex; flex-direction: column; gap: 22px;
}
.paywall-hero {
  display: flex; flex-direction: column; gap: 10px;
  padding: 4px 0 4px;
}
.paywall-eyebrow {
  font-size: 0.74rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--primary); font-weight: 600;
}
.paywall-features {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px; margin: 8px 0 4px;
}
.paywall-feature {
  display: flex; flex-direction: column; gap: 4px;
  padding: 16px 18px;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 10px;
  transition: all 0.15s var(--ease);
}
.paywall-feature:hover {
  border-color: var(--primary);
  transform: translateY(-2px);
}
.paywall-feature svg {
  width: 22px; height: 22px;
  color: var(--primary);
  margin-bottom: 4px;
}
.paywall-feature strong {
  font-size: 0.92rem; color: var(--ink); font-weight: 700;
}
.paywall-feature span {
  font-size: 0.78rem; color: var(--ink-soft); line-height: 1.4;
}
.paywall-plans-eyebrow {
  font-size: 0.78rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 600;
  margin-top: 14px;
  display: flex; align-items: center; gap: 10px;
}
.paywall-plans-eyebrow::after {
  content: ""; flex: 1; height: 1px; background: var(--line);
}
.paywall-trust {
  display: flex; flex-wrap: wrap; gap: 16px; justify-content: center;
  padding: 18px 0;
  border-top: 1px solid var(--line);
  border-bottom: 1px solid var(--line);
  margin-top: 14px;
}
.paywall-trust-item {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.78rem; color: var(--ink-soft);
  line-height: 1.4;
}
.paywall-trust-item svg {
  width: 22px; height: 22px;
  color: var(--primary); flex-shrink: 0;
}
.paywall-trust-item strong { color: var(--ink); font-weight: 700; }
.paywall-logo {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--ink); font-weight: 700;
}
.paywall-logo svg { width: 32px; height: 32px; }
.paywall-logo strong {
  font-size: 1rem; letter-spacing: 0.16em; text-transform: uppercase;
}
.paywall-title {
  font-size: 2rem; font-weight: 700; line-height: 1.18;
  letter-spacing: -0.01em; margin: 6px 0 0;
}
.paywall-sub {
  color: var(--ink-soft); font-size: 0.96rem; line-height: 1.55;
  margin: 0; max-width: 640px;
}
.paywall-plans {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 14px; margin-top: 14px;
}
.paywall-plan {
  display: flex; flex-direction: column; gap: 6px;
  padding: 18px 18px 20px;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; text-decoration: none;
  transition: all 0.15s var(--ease);
  position: relative;
}
.paywall-plan:hover {
  border-color: var(--primary); transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(239,68,68,0.12);
}
.paywall-plan-recommended {
  border-color: var(--primary); background: var(--bg-elev);
}
.paywall-plan-empresarial {
  border-color: var(--ink); background: var(--bg-elev);
}
.paywall-plan-tag {
  position: absolute; top: -10px; left: 14px;
  background: var(--primary); color: var(--primary-on);
  font-size: 0.66rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; padding: 3px 10px; border-radius: 999px;
}
.paywall-plan-empresarial .paywall-plan-tag {
  background: var(--ink); color: var(--bg);
}
.paywall-plan-name {
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em;
  text-transform: uppercase; color: var(--primary);
}
.paywall-plan-empresarial .paywall-plan-name { color: var(--ink); }
.paywall-plan-price {
  font-size: 1.65rem; font-weight: 700;
  color: var(--ink); font-family: 'JetBrains Mono', ui-monospace, monospace;
  margin: 2px 0;
}
.paywall-plan-price small {
  font-size: 0.78rem; font-weight: 500; color: var(--ink-mute); margin-left: 3px;
}
.paywall-plan-desc {
  font-size: 0.84rem; color: var(--ink-soft); line-height: 1.4;
}
.paywall-actions {
  display: flex; flex-wrap: wrap; gap: 16px; margin-top: 20px;
  padding-top: 18px; border-top: 1px solid var(--line);
}
.paywall-link-back {
  background: none; border: none; padding: 0;
  color: var(--ink-mute); font-family: inherit; font-size: 0.9rem;
  cursor: pointer; text-decoration: none;
  transition: color 0.15s var(--ease);
}
.paywall-link-back:hover { color: var(--primary); }
.paywall-link-back[hidden] { display: none; }
body.paywall-active { overflow: hidden; }

/* ================================================================
   Estoque de peças (Tier 2 Oficina) — CRUD + alerta + movimentação
   ================================================================ */
.estoque-tools {
  display: flex; flex-wrap: wrap; gap: 14px; align-items: flex-start;
  justify-content: space-between;
  margin: 18px 0 22px;
}
.estoque-stats {
  display: flex; flex-wrap: wrap; gap: 18px;
  font-size: 0.86rem; color: var(--ink-soft);
}
.estoque-stat strong {
  color: var(--ink); font-weight: 700;
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.estoque-stat-warning strong { color: #ef4444; }
.estoque-actions { display: flex; gap: 8px; flex-wrap: wrap; align-items: center; }
.estoque-actions input[type="search"] {
  padding: 8px 12px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--line);
  color: var(--ink); font-family: inherit; font-size: 0.86rem;
  min-width: 240px;
}
.estoque-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(280px, 1fr));
  gap: 12px;
}
.estoque-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; padding: 16px 18px;
  display: flex; flex-direction: column; gap: 8px;
  transition: all 0.15s var(--ease);
}
.estoque-card:hover { border-color: var(--ink-soft); }
.estoque-card.is-baixo { border-color: rgba(239, 68, 68, 0.45); background: linear-gradient(180deg, var(--bg-elev) 0%, rgba(239,68,68,0.04) 100%); }
.estoque-card.is-zero { border-color: #ef4444; }
.estoque-card-head { display: flex; justify-content: space-between; align-items: flex-start; gap: 8px; }
.estoque-card-nome { font-size: 0.96rem; font-weight: 600; color: var(--ink); line-height: 1.3; flex: 1; }
.estoque-tag {
  font-size: 0.66rem; padding: 3px 8px; border-radius: 999px;
  font-weight: 700; letter-spacing: 0.06em; flex-shrink: 0;
}
.estoque-tag-baixo { background: rgba(239, 68, 68, 0.12); color: #ef4444; }
.estoque-tag-zero { background: #ef4444; color: #fff; }
.estoque-card-meta { display: flex; gap: 8px; flex-wrap: wrap; font-size: 0.74rem; color: var(--ink-mute); }
.estoque-card-qty {
  display: flex; align-items: baseline; gap: 8px;
  padding: 8px 0; border-top: 1px solid var(--line); border-bottom: 1px solid var(--line);
}
.estoque-qtd-num {
  font-size: 1.8rem; font-weight: 700; color: var(--ink);
  font-family: 'JetBrains Mono', ui-monospace, monospace; line-height: 1;
}
.estoque-card.is-zero .estoque-qtd-num { color: #ef4444; }
.estoque-qtd-lbl { font-size: 0.78rem; color: var(--ink-soft); }
.estoque-card-financeiro { display: flex; gap: 12px; flex-wrap: wrap; font-size: 0.78rem; color: var(--ink-soft); }
.estoque-card-financeiro strong { color: var(--ink); font-family: 'JetBrains Mono', ui-monospace, monospace; }
.estoque-margem { background: var(--ok-soft); color: var(--ok); padding: 1px 8px; border-radius: 999px; font-weight: 700; }
.estoque-card-actions { display: flex; gap: 6px; margin-top: 4px; }
.estoque-empty {
  text-align: center; padding: 60px 30px;
  background: var(--bg-elev); border: 1px dashed var(--line); border-radius: 12px;
}
.estoque-empty h3 { margin: 16px 0 6px; font-size: 1.1rem; }
.estoque-empty p { color: var(--ink-soft); max-width: 480px; margin: 0 auto; font-size: 0.92rem; }
.esm-tipo-row { display: flex; gap: 8px; }
.esm-tipo-btn {
  flex: 1; padding: 10px 14px;
  background: var(--bg); border: 1px solid var(--line); border-radius: 10px;
  color: var(--ink-soft); font-family: inherit; font-size: 0.92rem; font-weight: 600;
  cursor: pointer; transition: all 0.15s var(--ease);
}
.esm-tipo-btn:hover { color: var(--ink); border-color: var(--ink-soft); }
.esm-tipo-btn.is-active { background: var(--primary); color: var(--primary-on); border-color: var(--primary); }

/* Importação de dados (Conta → Importar) */
.import-tabs { display: flex; gap: 4px; border-bottom: 1px solid var(--line); margin-bottom: 14px; padding: 0; }
.import-tab {
  background: transparent; border: none; padding: 10px 14px;
  color: var(--ink-soft); font-family: inherit; font-size: 0.86rem; font-weight: 500;
  cursor: pointer; border-bottom: 2px solid transparent;
  transition: all 0.15s var(--ease);
}
.import-tab.is-active { color: var(--primary); border-bottom-color: var(--primary); font-weight: 600; }
.import-tab:hover { color: var(--ink); }
.import-help {
  background: var(--bg); border: 1px solid var(--line); border-radius: 8px;
  padding: 10px 12px; margin: 8px 0;
  font-size: 0.78rem; color: var(--ink-soft); line-height: 1.5;
}
.import-help code { background: var(--bg-mute, var(--line)); padding: 1px 6px; border-radius: 4px; font-size: 0.84em; color: var(--ink); }
.import-textarea {
  width: 100%; min-height: 140px;
  padding: 10px 12px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--line); color: var(--ink);
  font-family: 'JetBrains Mono', ui-monospace, monospace; font-size: 0.82rem;
  line-height: 1.5; resize: vertical;
}
.import-preview {
  background: var(--bg); border: 1px solid var(--line); border-radius: 8px;
  padding: 10px 12px; max-height: 220px; overflow: auto;
  font-size: 0.78rem; color: var(--ink-soft);
  margin: 10px 0;
}
.import-preview-row { padding: 4px 0; border-bottom: 1px solid var(--line); }
.import-preview-row:last-child { border-bottom: 0; }

/* Calculadora ROI (landing) */
.roi-calculator {
  background: linear-gradient(135deg, var(--bg-elev) 0%, var(--bg) 100%);
  border: 1px solid var(--line); border-radius: 16px;
  padding: 36px; margin: 30px auto 0; max-width: 920px;
  display: grid; grid-template-columns: 1fr 1fr; gap: 30px;
}
.roi-inputs { display: flex; flex-direction: column; gap: 16px; }
.roi-inputs label { display: flex; flex-direction: column; gap: 4px; font-size: 0.84rem; color: var(--ink-soft); font-weight: 500; }
.roi-inputs input { padding: 11px 14px; border-radius: 10px; background: var(--bg); border: 1px solid var(--line); color: var(--ink); font-family: inherit; font-size: 1.05rem; font-weight: 600; }
.roi-inputs input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px rgba(239,68,68,0.18); }
.roi-results {
  display: flex; flex-direction: column; gap: 14px;
  padding: 24px;
  background: var(--bg); border-radius: 12px; border: 1px solid var(--line);
}
.roi-result-item { display: flex; flex-direction: column; gap: 2px; }
.roi-result-label { font-size: 0.74rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.roi-result-value {
  font-size: 1.7rem; font-weight: 700; color: var(--primary);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
}
.roi-result-value.muted { color: var(--ink); }
.roi-result-detail { font-size: 0.82rem; color: var(--ink-soft); }
.roi-cta {
  margin-top: 8px; padding: 12px 18px; border-radius: 10px;
  background: var(--primary); color: var(--primary-on);
  text-decoration: none; text-align: center; font-weight: 600;
  transition: opacity 0.15s var(--ease);
}
.roi-cta:hover { opacity: 0.92; }
@media (max-width: 700px) {
  .roi-calculator { grid-template-columns: 1fr; padding: 24px; }
}

/* ================================================================
   Aba Parceiros & Benefícios (placeholder · futuro programa de afiliação)
   ================================================================ */
.parceiros-preview {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 12px; margin-top: 14px;
}
.parceiro-card {
  background: var(--bg); border: 1px solid var(--line);
  border-radius: 10px; padding: 18px;
  display: flex; flex-direction: column; gap: 6px;
  position: relative; overflow: hidden;
}
.parceiro-card-empty {
  background: linear-gradient(180deg, var(--bg) 0%, var(--bg-elev) 100%);
  border-style: dashed;
  opacity: 0.85;
}
.parceiro-icone {
  width: 38px; height: 38px; border-radius: 10px;
  background: var(--primary); color: var(--primary-on);
  display: inline-flex; align-items: center; justify-content: center;
  margin-bottom: 4px;
}
.parceiro-card strong {
  font-size: 0.92rem; color: var(--ink); line-height: 1.3;
}
.parceiro-card span {
  font-size: 0.78rem; color: var(--ink-soft); line-height: 1.4;
}

/* ================================================================
   Custo médio de mercado (crowdsource de preços de peças)
   ================================================================ */
.pecas-precos-section {
  margin-top: 30px; padding-top: 26px;
  border-top: 1px solid var(--line);
}
.pecas-precos-head {
  display: flex; flex-wrap: wrap; gap: 14px;
  align-items: flex-start; justify-content: space-between;
  margin-bottom: 20px;
}
.pecas-precos-head h3 { font-size: 1.15rem; letter-spacing: -0.01em; }
.pecas-precos-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.preco-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; padding: 18px 20px;
  display: flex; flex-direction: column; gap: 6px;
}
.preco-card-nome {
  font-size: 0.96rem; font-weight: 600; color: var(--ink);
  line-height: 1.3;
}
.preco-card-valor {
  font-size: 1.5rem; font-weight: 700; color: var(--primary);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  margin: 4px 0 2px;
}
.preco-card-meta {
  display: flex; flex-wrap: wrap; gap: 6px;
  font-size: 0.74rem; color: var(--ink-mute); margin-top: 4px;
}
.preco-card-tag {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 999px; background: var(--line);
  color: var(--ink-soft); font-weight: 500;
}
.preco-card-min-max {
  display: flex; gap: 12px; font-size: 0.78rem; color: var(--ink-soft);
  margin-top: 2px;
}
.preco-card-min-max strong { color: var(--ink); font-family: 'JetBrains Mono', ui-monospace, monospace; }
.preco-card-vazio {
  grid-column: 1/-1; text-align: center; padding: 30px 20px;
  color: var(--ink-mute); font-size: 0.92rem;
  background: var(--bg-elev); border: 1px dashed var(--line); border-radius: 12px;
}

/* ================================================================
   Vehicle category picker — seletor visual de tipo de veiculo
   Aplicado em #manuais, #tempos-padrao, #catalogo-pecas, #ferramentas-extras
   ================================================================ */
.vehicle-picker {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(120px, 1fr));
  gap: 10px;
  margin: 18px 0 24px;
}
.vehicle-pick {
  position: relative;
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 12px 14px;
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 14px; cursor: pointer;
  transition: all 0.18s var(--ease);
  font-family: inherit; color: var(--ink-soft);
  text-align: center;
}
.vehicle-pick:hover {
  border-color: var(--primary); color: var(--ink);
  transform: translateY(-2px);
  box-shadow: 0 8px 24px rgba(239, 68, 68, 0.1);
}
.vehicle-pick.is-active {
  border-color: var(--primary);
  background: linear-gradient(180deg, var(--bg-elev) 0%, rgba(239,68,68,0.08) 100%);
  color: var(--primary);
}
.vehicle-pick.is-active::after {
  content: ""; position: absolute; bottom: -1px; left: 20%; right: 20%;
  height: 3px; background: var(--primary); border-radius: 999px 999px 0 0;
}
.vehicle-pick-icon {
  width: 56px; height: 36px;
  display: inline-flex; align-items: center; justify-content: center;
}
.vehicle-pick-icon svg { width: 100%; height: 100%; }
.vehicle-pick-label {
  font-size: 0.78rem; font-weight: 600; letter-spacing: 0.02em;
  line-height: 1.2;
}
.vehicle-pick-count {
  display: inline-block;
  font-size: 0.66rem; padding: 2px 8px; border-radius: 999px;
  background: var(--line); color: var(--ink-mute);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  font-weight: 600; line-height: 1.4;
}
.vehicle-pick.is-active .vehicle-pick-count {
  background: var(--primary); color: var(--primary-on);
}
.vehicle-pick.is-eletrico .vehicle-pick-icon svg path[fill="#22c55e"] {
  filter: drop-shadow(0 0 4px rgba(34,197,94,0.5));
}
.vehicle-pick-badge-eletrico {
  position: absolute; top: 8px; right: 8px;
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.06em;
  background: #22c55e; color: #fff; padding: 2px 6px; border-radius: 999px;
}
@media (max-width: 600px) {
  .vehicle-picker { grid-template-columns: repeat(3, 1fr); gap: 8px; }
  .vehicle-pick { padding: 12px 6px 10px; }
  .vehicle-pick-icon { width: 44px; height: 28px; }
  .vehicle-pick-label { font-size: 0.7rem; }
}
@media (max-width: 380px) {
  .vehicle-picker { grid-template-columns: repeat(2, 1fr); }
}
.vehicle-picker-eyebrow {
  display: flex; align-items: center; gap: 8px;
  font-size: 0.78rem; letter-spacing: 0.1em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 600; margin-top: 24px;
}
.vehicle-picker-eyebrow::after {
  content: ""; flex: 1; height: 1px; background: var(--line);
}

/* ================================================================
   Splash de loading entre tabs (Torque · UX profissional)
   ================================================================ */
.tab-splash {
  position: fixed; inset: 0; z-index: 8500;
  background: var(--bg);
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  gap: 22px;
  pointer-events: none;
  opacity: 0; transition: opacity 0.18s var(--ease);
}
.tab-splash.is-active {
  opacity: 1;
  pointer-events: auto;
}
.tab-splash-logo {
  display: flex; flex-direction: column; align-items: center; gap: 14px;
}
.tab-splash-mark {
  width: 64px; height: 64px;
  animation: tab-splash-pulse 1.4s ease-in-out infinite;
}
@keyframes tab-splash-pulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50% { transform: scale(0.92); opacity: 0.85; }
}
.tab-splash-name {
  font-size: 0.86rem; letter-spacing: 0.18em; text-transform: uppercase;
  color: var(--ink-soft); font-weight: 600;
}
.tab-splash-target {
  font-size: 1.05rem; font-weight: 600; color: var(--ink);
  letter-spacing: -0.01em;
}
.tab-splash-bar {
  width: 240px; height: 3px; border-radius: 999px;
  background: var(--line);
  overflow: hidden;
  position: relative;
}
.tab-splash-bar::after {
  content: ""; position: absolute; left: 0; top: 0; bottom: 0;
  width: 40%; background: var(--primary); border-radius: 999px;
  animation: tab-splash-progress 1.2s ease-in-out infinite;
}
@keyframes tab-splash-progress {
  0% { left: -40%; }
  100% { left: 100%; }
}

/* ================================================================
   v1.9.33 — APP-TRANSITION overlay (logo gigante na landing)
   Sem este CSS, o overlay fica visível por default e o SVG vai
   pra tela cheia. Só deve aparecer ao clicar "Abrir plataforma".
   ================================================================ */
.app-transition {
  position: fixed; inset: 0; z-index: 10000;
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity 0.3s ease;
}
.app-transition.is-active {
  opacity: 1; pointer-events: auto;
}
.app-transition-card {
  display: flex; flex-direction: column; align-items: center;
  gap: 18px; padding: 40px; text-align: center;
}
.app-transition-mark {
  width: 80px; height: 80px;
  animation: torque-trans-pulse 1.5s ease-in-out infinite;
}
.app-transition-name {
  font-family: 'Space Grotesk', system-ui, sans-serif;
  font-size: 1.6rem; font-weight: 800;
  letter-spacing: 0.08em;
  color: var(--ink);
}
.app-transition-bar {
  width: 200px; height: 3px;
  background: var(--line);
  border-radius: 99px;
  overflow: hidden;
  position: relative;
}
.app-transition-bar::after {
  content: ''; position: absolute; inset: 0;
  background: var(--primary);
  animation: torque-trans-bar 1.5s ease-in-out infinite;
}
.app-transition-msg {
  font-size: 0.88rem;
  color: var(--ink-mute);
  letter-spacing: 0.02em;
}
@keyframes torque-trans-pulse {
  0%, 100% { transform: scale(1); opacity: 0.9; }
  50%      { transform: scale(1.06); opacity: 1; }
}
@keyframes torque-trans-bar {
  0%   { transform: translateX(-100%); }
  100% { transform: translateX(100%); }
}

/* ================================================================
   v1.9.32 — RESTAURADAS regressões perdidas pelo OneDrive revert
   ================================================================ */

/* PWA install banner (cont.21) — só mobile (≤820px) */
.pwa-install-banner {
  position: fixed; bottom: 16px; left: 16px; right: 16px; z-index: 9000;
  max-width: 720px; margin: 0 auto;
  background: var(--ink); color: var(--bg);
  border-radius: 14px; padding: 16px 20px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  display: flex; align-items: center; gap: 16px; flex-wrap: wrap;
  animation: slideUp 0.3s ease-out;
}
.pwa-install-banner[hidden] { display: none; }
.pwa-install-content { flex: 1; min-width: 200px; }
.pwa-install-content strong { display: block; font-size: 0.96rem; margin-bottom: 4px; }
.pwa-install-content span { font-size: 0.84rem; color: rgba(255,255,255,0.75); }
.pwa-install-actions { display: flex; gap: 8px; }
.pwa-install-actions .btn { padding: 8px 16px; font-size: 0.84rem; }
@keyframes slideUp { from { transform: translateY(20px); opacity: 0; } to { transform: translateY(0); opacity: 1; } }
@media (min-width: 821px) {
  .pwa-install-banner { display: none !important; }
}

/* Botão flutuante de feedback (cont.4) */
.fb-fab {
  position: fixed; bottom: 18px; right: 18px; z-index: 8500;
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 16px;
  background: var(--ink); color: var(--bg);
  border: none; border-radius: 999px;
  font-family: inherit; font-size: 0.86rem; font-weight: 600;
  box-shadow: 0 8px 24px rgba(0,0,0,0.25);
  cursor: pointer; transition: transform 0.15s, box-shadow 0.15s;
}
.fb-fab:hover { transform: translateY(-2px); box-shadow: 0 12px 32px rgba(0,0,0,0.3); }
.fb-fab svg { display: block; }
@media (max-width: 600px) {
  .fb-fab span { display: none; }
  .fb-fab { padding: 12px; }
}

/* Calc-formula explicativa CHH/orçamento (cont.16) — passo-a-passo A→E */
.calc-formula {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; padding: 18px 22px;
  margin-top: 16px;
  display: flex; flex-direction: column; gap: 10px;
}
.calc-formula-title {
  font-size: 0.84rem; font-weight: 700; text-transform: uppercase;
  color: var(--ink-mute); letter-spacing: 0.05em; margin-bottom: 4px;
}
.calc-formula-step {
  display: flex; align-items: flex-start; gap: 12px;
  padding: 8px 0;
  border-bottom: 1px dashed var(--line);
}
.calc-formula-step:last-child { border-bottom: none; }
.calc-formula-letter {
  display: inline-flex; align-items: center; justify-content: center;
  width: 26px; height: 26px; border-radius: 50%;
  background: var(--primary); color: var(--primary-on);
  font-size: 0.78rem; font-weight: 700; flex-shrink: 0;
}
.calc-formula-text { flex: 1; font-size: 0.92rem; line-height: 1.45; color: var(--ink); }
.calc-formula-value {
  font-family: var(--font-mono, ui-monospace, SFMono-Regular, Menlo, monospace);
  font-weight: 600; color: var(--primary);
  background: var(--primary-glow, rgba(220,38,38,0.08));
  padding: 2px 8px; border-radius: 6px; margin-left: 6px;
}

/* Cursor custom de chave inglesa (Lucide-style, dual-theme pra contraste em qualquer fundo) */
@media (hover: hover) and (pointer: fine) {
  /* Light theme: chave preta com outline branco (visivel em fundos claros e escuros) */
  body {
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='-1 -1 26 26'><g transform='translate(24 0) scale(-1 1)'><path d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z' fill='%23111' stroke='%23fff' stroke-width='1.6' stroke-linejoin='round'/></g></svg>") 24 22, auto;
  }
  a, button, [role="button"], input[type="submit"], .vehicle-pick, .conta-plano-btn, .app-tab, .paywall-plan, .preco-card, .parceiro-card, .vehicle-pick *, .conta-plano-btn *, .app-tab *, .paywall-plan *, .nav-drawer-list a, .footer a {
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='-1 -1 26 26'><g transform='translate(24 0) scale(-1 1)'><path d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z' fill='%23ef4444' stroke='%23fff' stroke-width='1.6' stroke-linejoin='round'/></g></svg>") 24 22, pointer;
  }
  /* Dark theme: inverte (chave branca com outline preto) */
  [data-theme="dark"] body {
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='28' height='28' viewBox='-1 -1 26 26'><g transform='translate(24 0) scale(-1 1)'><path d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z' fill='%23f5f5f4' stroke='%23000' stroke-width='1.6' stroke-linejoin='round'/></g></svg>") 24 22, auto;
  }
  [data-theme="dark"] a, [data-theme="dark"] button, [data-theme="dark"] [role="button"], [data-theme="dark"] input[type="submit"], [data-theme="dark"] .vehicle-pick, [data-theme="dark"] .conta-plano-btn, [data-theme="dark"] .app-tab, [data-theme="dark"] .paywall-plan, [data-theme="dark"] .preco-card, [data-theme="dark"] .parceiro-card, [data-theme="dark"] .nav-drawer-list a, [data-theme="dark"] .footer a {
    cursor: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' width='30' height='30' viewBox='-1 -1 26 26'><g transform='translate(24 0) scale(-1 1)'><path d='M14.7 6.3a1 1 0 0 0 0 1.4l1.6 1.6a1 1 0 0 0 1.4 0l3.77-3.77a6 6 0 0 1-7.94 7.94l-6.91 6.91a2.12 2.12 0 0 1-3-3l6.91-6.91a6 6 0 0 1 7.94-7.94l-3.76 3.76z' fill='%23ef4444' stroke='%23000' stroke-width='1.6' stroke-linejoin='round'/></g></svg>") 24 22, pointer;
  }
  /* Inputs de texto mantêm cursor padrão (I-beam) — usabilidade */
  input[type="text"], input[type="email"], input[type="password"], input[type="number"], input[type="tel"], input[type="search"], textarea, select,
  [data-theme="dark"] input[type="text"], [data-theme="dark"] input[type="email"], [data-theme="dark"] input[type="password"], [data-theme="dark"] input[type="number"], [data-theme="dark"] input[type="tel"], [data-theme="dark"] input[type="search"], [data-theme="dark"] textarea, [data-theme="dark"] select {
    cursor: auto;
  }
}
@media (hover: none) {
  body { cursor: auto; }
}

/* ================================================================
   Banner de consentimento LGPD/cookies (bottom-fixed)
   ================================================================ */
.lgpd-banner {
  position: fixed; bottom: 16px; left: 16px; right: 16px; z-index: 9000;
  max-width: 720px; margin: 0 auto;
  background: var(--ink); color: var(--bg);
  border-radius: 14px; padding: 18px 22px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.4);
  display: flex; flex-wrap: wrap; align-items: center; gap: 14px;
  animation: lgpd-slide 0.4s var(--ease);
}
.lgpd-banner[hidden] { display: none; }
@keyframes lgpd-slide {
  from { transform: translateY(100%); opacity: 0; }
  to { transform: translateY(0); opacity: 1; }
}
.lgpd-banner-text {
  flex: 1; min-width: 240px; font-size: 0.86rem; line-height: 1.45;
}
.lgpd-banner-text a {
  color: var(--bg); text-decoration: underline; opacity: 0.85;
}
.lgpd-banner-text a:hover { opacity: 1; }
.lgpd-banner-actions { display: flex; gap: 8px; flex-wrap: wrap; }
.lgpd-banner-btn {
  background: var(--primary); color: var(--primary-on);
  border: none; padding: 9px 18px; border-radius: 999px;
  font-family: inherit; font-size: 0.84rem; font-weight: 600;
  cursor: pointer; transition: opacity 0.15s var(--ease);
}
.lgpd-banner-btn:hover { opacity: 0.92; }
.lgpd-banner-btn-ghost {
  background: transparent; color: var(--bg);
  border: 1px solid rgba(255,255,255,0.3);
}
@media (max-width: 600px) {
  .lgpd-banner { padding: 14px 16px; }
  .lgpd-banner-text { font-size: 0.82rem; }
}

/* ================================================================
   Player de video nativo (Universidade Torque - sem YouTube)
   ================================================================ */
.torque-player {
  position: relative; width: 100%; aspect-ratio: 16 / 9;
  background: #000; border-radius: 12px; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
}
.torque-player video {
  width: 100%; height: 100%; display: block;
  background: #000; cursor: pointer;
}
.torque-player-poster {
  position: absolute; inset: 0; background: rgba(0,0,0,0.4);
  display: flex; align-items: center; justify-content: center;
  z-index: 2; cursor: pointer;
}
.torque-player-poster-btn {
  width: 76px; height: 76px; border-radius: 50%;
  background: rgba(0,0,0,0.6); border: 2px solid rgba(255,255,255,0.85);
  color: #fff; cursor: pointer;
  display: inline-flex; align-items: center; justify-content: center;
  transition: all 0.15s var(--ease);
}
.torque-player-poster-btn:hover { background: var(--primary); border-color: var(--primary); transform: scale(1.06); }
.torque-player-poster-btn svg { width: 32px; height: 32px; margin-left: 4px; }
.torque-player-controls {
  position: absolute; bottom: 0; left: 0; right: 0;
  background: linear-gradient(to top, rgba(0,0,0,0.78) 0%, rgba(0,0,0,0.55) 60%, transparent 100%);
  padding: 36px 14px 12px; opacity: 0;
  transition: opacity 0.18s var(--ease); z-index: 3;
}
.torque-player:hover .torque-player-controls,
.torque-player.is-paused .torque-player-controls,
.torque-player:focus-within .torque-player-controls { opacity: 1; }
.torque-player-progress-wrap { padding: 0 4px 8px; }
.torque-player-progress {
  position: relative; height: 5px; background: rgba(255,255,255,0.22);
  border-radius: 999px; cursor: pointer;
  transition: height 0.15s var(--ease);
}
.torque-player-progress:hover { height: 8px; }
.torque-player-buffered {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 0%; background: rgba(255,255,255,0.4); border-radius: 999px;
}
.torque-player-progress-fill {
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 0%; background: var(--primary); border-radius: 999px;
}
.torque-player-progress-thumb {
  position: absolute; top: 50%; left: 0%;
  width: 14px; height: 14px; border-radius: 50%;
  background: var(--primary); transform: translate(-50%, -50%);
  pointer-events: none; opacity: 0;
  transition: opacity 0.15s var(--ease);
  box-shadow: 0 0 0 4px rgba(239,68,68,0.25);
}
.torque-player-progress:hover .torque-player-progress-thumb { opacity: 1; }
.torque-player-bottom {
  display: flex; align-items: center; gap: 10px;
  color: #fff;
}
.torque-player-btn {
  background: transparent; border: none; cursor: pointer;
  width: 36px; height: 36px; border-radius: 8px;
  display: inline-flex; align-items: center; justify-content: center;
  color: #fff; transition: background 0.12s var(--ease);
}
.torque-player-btn:hover { background: rgba(255,255,255,0.1); }
.torque-player-btn svg { width: 20px; height: 20px; }
.torque-player-time {
  font-size: 0.78rem; color: rgba(255,255,255,0.85);
  font-family: 'JetBrains Mono', ui-monospace, monospace;
  white-space: nowrap;
}
.torque-player-volume-wrap {
  display: flex; align-items: center; gap: 4px;
}
.torque-player-volume {
  width: 0; opacity: 0; transition: width 0.2s var(--ease), opacity 0.18s var(--ease);
  appearance: none; -webkit-appearance: none;
  height: 4px; border-radius: 999px;
  background: rgba(255,255,255,0.3);
  cursor: pointer;
}
.torque-player-volume::-webkit-slider-thumb {
  appearance: none; -webkit-appearance: none;
  width: 12px; height: 12px; border-radius: 50%; background: #fff;
  cursor: pointer;
}
.torque-player-volume::-moz-range-thumb {
  width: 12px; height: 12px; border-radius: 50%; background: #fff; border: none;
  cursor: pointer;
}
.torque-player-volume-wrap:hover .torque-player-volume,
.torque-player-volume:focus { width: 70px; opacity: 1; }
.torque-player-spacer { flex: 1; }
.torque-player-speed {
  background: rgba(255,255,255,0.1); color: #fff;
  border: 1px solid rgba(255,255,255,0.2); border-radius: 6px;
  padding: 4px 8px; font-size: 0.78rem; cursor: pointer;
  font-family: inherit;
}
.torque-player-speed option { color: #1f1f1f; background: #fff; }
.torque-player-fallback {
  position: absolute; inset: 0; z-index: 4;
  display: flex; align-items: center; justify-content: center;
  background: rgba(0,0,0,0.85); color: #fff;
  text-align: center; padding: 20px;
  font-size: 0.92rem;
}
.torque-player.is-fullscreen { border-radius: 0; }
@media (max-width: 600px) {
  .torque-player-time { font-size: 0.72rem; }
  .torque-player-btn { width: 32px; height: 32px; }
  .torque-player-volume-wrap { display: none; }
}

/* ================================================================
   Aba Conta - perfil + assinatura + pagamento + cancelar
   ================================================================ */
.conta-grid {
  /* v1.9.32 — restaurado fix cont.13 (perdido pelo OneDrive revert):
     cards Conta em coluna única (980px max, centralizada) — antes ficava
     narrow com grid auto-fit deixando vazio do lado em desktop wide. */
  display: flex;
  flex-direction: column;
  gap: 16px;
  max-width: 980px;
  margin: 22px auto 0;
}
.conta-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 12px; padding: 22px 24px;
  display: flex; flex-direction: column; gap: 14px;
}
.conta-card-wide { grid-column: 1 / -1; }
.conta-card-head {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.conta-card-head h3 { margin: 0; font-size: 1.05rem; letter-spacing: -0.01em; }
.btn-sm { padding: 7px 14px !important; font-size: 0.84rem !important; }
.conta-perfil-row { display: flex; align-items: center; gap: 14px; }
.conta-avatar {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--primary); color: var(--primary-on);
  display: inline-flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1.1rem; flex-shrink: 0;
  text-transform: uppercase;
}
.conta-perfil-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.conta-perfil-info strong { font-size: 0.96rem; color: var(--ink); }
.conta-perfil-info span { font-size: 0.82rem; color: var(--ink-soft); word-break: break-all; }
.conta-perfil-info .muted { color: var(--ink-mute); font-size: 0.78rem; }
.conta-perfil-form {
  display: flex; flex-direction: column; gap: 10px;
}
.conta-perfil-form label {
  display: flex; flex-direction: column; gap: 4px;
  font-size: 0.78rem; color: var(--ink-soft); font-weight: 500;
}
.conta-perfil-form input {
  padding: 9px 12px; border-radius: 8px;
  background: var(--bg); border: 1px solid var(--line);
  color: var(--ink); font-family: inherit; font-size: 0.92rem;
}
.conta-perfil-form input:focus {
  outline: none; border-color: var(--primary);
  box-shadow: 0 0 0 3px var(--primary-glow, rgba(239,68,68,0.18));
}
.conta-acoes { display: flex; gap: 8px; flex-wrap: wrap; }
.conta-badge {
  font-size: 0.7rem; padding: 3px 10px; border-radius: 999px;
  font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase;
  background: var(--line); color: var(--ink-soft);
}
.conta-badge.is-authorized { background: var(--ok-soft); color: var(--ok); }
.conta-badge.is-pending    { background: rgba(239,68,68,0.12); color: var(--primary); }
.conta-badge.is-cancelled  { background: var(--line); color: var(--ink-mute); }
.conta-assinatura-info {
  display: grid; grid-template-columns: 1fr 1fr; gap: 10px;
  font-size: 0.9rem; color: var(--ink-soft); margin: 8px 0 14px;
}
.conta-assinatura-info strong { color: var(--ink); display: block; font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; margin-bottom: 2px; }
.conta-planos-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
}
.conta-plano-btn {
  display: flex; flex-direction: column; gap: 4px; align-items: flex-start;
  padding: 14px 16px;
  background: var(--bg); border: 1px solid var(--line); border-radius: 10px;
  cursor: pointer; transition: all 0.15s var(--ease);
  font-family: inherit; text-align: left;
}
.conta-plano-btn:hover {
  border-color: var(--primary);
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(239,68,68,0.1);
}
.conta-plano-btn.is-current {
  border-color: var(--ok); background: var(--ok-soft);
}
.conta-plano-btn.is-current::after {
  content: "Atual"; font-size: 0.66rem; padding: 2px 8px;
  background: var(--ok); color: #fff; border-radius: 999px; font-weight: 700;
  position: absolute; top: 8px; right: 8px;
}
.conta-plano-btn { position: relative; }
.conta-plano-nome { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--primary); font-weight: 700; }
.conta-plano-preco { font-size: 1.2rem; font-weight: 700; color: var(--ink); font-family: 'JetBrains Mono', ui-monospace, monospace; }
.conta-plano-preco small { font-size: 0.7rem; color: var(--ink-mute); margin-left: 2px; font-weight: 500; }
.conta-plano-desc { font-size: 0.78rem; color: var(--ink-soft); line-height: 1.4; }
.muted { color: var(--ink-mute); }
.conta-acoes a.btn { text-decoration: none; }
@media (max-width: 600px) {
  .conta-card { padding: 18px 18px; }
  .conta-assinatura-info { grid-template-columns: 1fr; }
}

/* ================================================================
   App tabs (nav abaixo do header com 9 categorias)
   ================================================================ */
.app-tabs {
  position: sticky; top: var(--header-h, 60px); z-index: 50;
  background: var(--bg);
  border-bottom: 1px solid var(--line);
  overflow-x: auto; -webkit-overflow-scrolling: touch;
  scrollbar-width: none;
}
.app-tabs::-webkit-scrollbar { display: none; }
.app-tabs .wrap {
  /* v1.9.34 — flex centralizado em vez de grid forçado (que dava largura igual em tab curto/longo,
     causando "Início" e "Calculadora" parecendo desalinhadas com texto largo de "IA Assistente"). */
  display: flex; gap: 4px; padding: 8px 16px;
  width: max-content; min-width: 100%;
  max-width: 1600px;
}
@media (min-width: 821px) {
  .app-tabs .wrap {
    width: 100%;
    margin: 0 auto;
    justify-content: center;
    flex-wrap: wrap;
    gap: 6px;
  }
}
.app-tab {
  display: inline-flex; align-items: center; justify-content: center; gap: 8px;
  padding: 10px 16px;
  background: transparent; border: 1px solid transparent; border-radius: 999px;
  color: var(--ink-mute); font-family: inherit; font-size: 0.88rem; font-weight: 500;
  cursor: pointer; white-space: nowrap;
  transition: all 0.15s var(--ease);
  position: relative;
}
.app-tab svg { width: 16px; height: 16px; flex-shrink: 0; }
.app-tab:hover { color: var(--ink); background: var(--bg-elev); }
.app-tab.is-active {
  color: var(--primary-on); background: var(--primary);
}
.app-tab.is-active:hover { background: var(--primary); color: var(--primary-on); opacity: 0.92; }
.app-tab.is-tier-locked::after {
  content: "";
  display: block;
  width: 12px; height: 12px;
  background: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23999' stroke-width='2.4' stroke-linecap='round' stroke-linejoin='round'><rect x='3' y='11' width='18' height='11' rx='2'/><path d='M7 11V7a5 5 0 0 1 10 0v4'/></svg>") no-repeat center / contain;
}
section[data-tab-group] { display: none; }
section[data-tab-group].is-tab-active { display: block; }
@media (max-width: 720px) {
  .app-tab { padding: 8px 12px; font-size: 0.82rem; }
  .app-tab svg { width: 14px; height: 14px; }
}

/* ================================================================
   Tier locks - sections de tier superior aparecem visualmente bloqueadas
   ================================================================ */
section[data-tier-required].is-locked {
  position: relative;
  pointer-events: none;
  user-select: none;
}
section[data-tier-required].is-locked > * { filter: blur(2px) saturate(0.6); opacity: 0.55; }
section[data-tier-required].is-locked .tier-lock-overlay { filter: none; opacity: 1; }
.tier-lock-overlay {
  pointer-events: auto;
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  background: rgba(10,10,10,0.4);
  backdrop-filter: blur(6px); -webkit-backdrop-filter: blur(6px);
  z-index: 10;
}
.tier-lock-card {
  background: var(--bg-elev); border: 1px solid var(--line);
  border-radius: 14px; padding: 24px 28px; max-width: 440px; text-align: center;
  box-shadow: 0 20px 60px rgba(0,0,0,0.3);
  display: flex; flex-direction: column; align-items: center; gap: 12px;
}
.tier-lock-icon {
  width: 48px; height: 48px; border-radius: 12px;
  background: var(--primary); color: var(--primary-on);
  display: inline-flex; align-items: center; justify-content: center;
}
.tier-lock-icon svg { width: 22px; height: 22px; }
.tier-lock-eyebrow {
  font-size: 0.72rem; letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--ink-mute); font-weight: 600;
}
.tier-lock-title {
  font-size: 1.15rem; font-weight: 700; line-height: 1.2;
  margin: 0; letter-spacing: -0.01em; color: var(--ink);
}
.tier-lock-text {
  font-size: 0.86rem; color: var(--ink-soft); line-height: 1.45;
  margin: 0; max-width: 360px;
}
.tier-lock-cta {
  margin-top: 4px;
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--primary); color: var(--primary-on);
  padding: 10px 18px; border-radius: 999px;
  font-weight: 600; font-size: 0.9rem; text-decoration: none;
  transition: transform 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.tier-lock-cta:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(239,68,68,0.3); }
.tier-lock-cta svg { width: 14px; height: 14px; }
@media (max-width: 600px) {
  .tier-lock-card { padding: 18px 20px; gap: 10px; }
  .tier-lock-title { font-size: 1rem; }
}
@media (max-width: 700px) {
  .paywall-title { font-size: 1.5rem; }
  .paywall-card { gap: 14px; }
  .paywall-overlay { padding: 24px 16px; }
}
.auth-menu-item:hover { background: var(--bg-mute); color: var(--primary); }

.auth-google-btn {
  width: 100%; padding: 11px 14px;
  background: var(--bg); color: var(--ink);
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  display: inline-flex; align-items: center; justify-content: center; gap: 10px;
  font-size: 0.92rem; font-weight: 500; font-family: inherit;
  cursor: pointer; transition: all 0.15s var(--ease);
  margin-bottom: 4px;
}
.auth-google-btn:hover { border-color: var(--primary); }

.auth-divider {
  display: flex; align-items: center; gap: 12px;
  margin: 14px 0 10px;
  font-size: 0.74rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.1em;
}
.auth-divider::before, .auth-divider::after {
  content: ""; flex: 1; height: 1px; background: var(--line);
}
.auth-row { display: flex; justify-content: space-between; align-items: center; }
.auth-link {
  color: var(--ink-soft); font-size: 0.82rem; text-decoration: none;
  cursor: pointer;
}
.auth-link:hover { color: var(--primary); text-decoration: underline; }

/* === Fase 5 — Hub educacional === */
.hub-disclaimer {
  background: var(--bg-mute); border: 1px solid var(--line);
  border-radius: var(--radius-sm); padding: 12px 16px;
  font-size: 0.82rem; color: var(--ink-soft); line-height: 1.5;
  margin-top: 18px;
}
.hub-disclaimer strong { color: var(--ink); }
.hub-tools { margin: 18px 0 0; }

.trilhas-grid {
  display: grid; grid-template-columns: 1fr; gap: 18px;
}
.trilha-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden;
}
.trilha-head {
  padding: 22px 24px;
  border-bottom: 1px solid var(--line);
  border-left: 4px solid var(--trilha-color, var(--primary));
}
.trilha-eyebrow {
  display: inline-block; font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--trilha-color, var(--primary)); margin-bottom: 8px;
}
.trilha-head h3 { font-size: 1.18rem; margin: 0; font-weight: 600; }
.trilha-head p { font-size: 0.9rem; color: var(--ink-soft); margin: 8px 0 14px; line-height: 1.55; }
.trilha-progress { display: flex; align-items: center; gap: 10px; }
.trilha-progress-bar {
  flex: 1; height: 6px; background: var(--bg-mute); border-radius: 99px; overflow: hidden;
}
.trilha-progress-bar span { display: block; height: 100%; transition: width 0.3s var(--ease); }
.trilha-progress-num { font-size: 0.78rem; color: var(--ink-soft); white-space: nowrap; }

.trilha-aulas { display: flex; flex-direction: column; }
.aula-row {
  display: flex; align-items: center; gap: 14px;
  padding: 14px 24px;
  background: transparent; border: none; border-bottom: 1px solid var(--line-soft);
  cursor: pointer; font-family: inherit; text-align: left; width: 100%;
  color: var(--ink); transition: background 0.15s var(--ease);
}
.aula-row:hover { background: var(--bg-mute); }
.aula-row:last-child { border-bottom: none; }
.aula-row.done { opacity: 0.65; }
.aula-row.done .aula-title { text-decoration: line-through; }
.aula-idx {
  font-size: 0.78rem; color: var(--ink-mute);
  min-width: 24px;
}
.aula-info { flex: 1; display: flex; flex-direction: column; gap: 2px; }
.aula-info .aula-title { font-size: 0.94rem; font-weight: 500; color: var(--ink); }
.aula-info .aula-meta-row { font-size: 0.78rem; color: var(--ink-mute); }
.aula-status { display: flex; align-items: center; }

/* Modal de aula com vídeo */
.aula-video-wrap {
  position: relative; padding-bottom: 56.25%; height: 0; overflow: hidden;
  background: #000; border-radius: var(--radius-sm);
  margin: -10px 0 16px;
}
.aula-video-wrap iframe {
  position: absolute; top: 0; left: 0; width: 100%; height: 100%;
}
.aula-meta {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 10px;
  margin-bottom: 12px;
}
.aula-descricao {
  background: var(--bg-mute); padding: 14px 16px;
  border-radius: var(--radius-sm); font-size: 0.92rem; color: var(--ink);
  line-height: 1.55; margin-bottom: 14px;
}
.aula-descricao p { margin: 0; }

/* === Fase 6: Financeiro + Assistente IA + WhatsApp FAB === */

/* Financeiro */
.fin-summary {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px;
  margin-bottom: 22px;
}
.fin-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 18px 20px;
}
.fin-card .fin-lbl { font-size: 0.74rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.08em; font-weight: 600; }
.fin-card .fin-num { font-size: 1.7rem; font-weight: 700; letter-spacing: -0.02em; margin-top: 6px; }
.fin-card .fin-sub { font-size: 0.78rem; color: var(--ink-soft); margin-top: 4px; }
.fin-card.fin-receber { border-left: 3px solid var(--ok); }
.fin-card.fin-receber .fin-num { color: var(--ok); }
.fin-card.fin-pagar { border-left: 3px solid var(--danger); }
.fin-card.fin-pagar .fin-num { color: var(--danger); }
.fin-card.fin-saldo { border-left: 3px solid var(--primary); }

.fin-tools {
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
  margin-bottom: 18px;
}
.fin-tools .btn { padding: 8px 14px; font-size: 0.86rem; }
.fin-tools select, .fin-tools input[type="month"] {
  padding: 8px 12px; font-size: 0.84rem;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: var(--bg-elev); color: var(--ink); font-family: inherit;
}

.fin-list { display: flex; flex-direction: column; gap: 8px; }
.fin-item {
  display: grid; grid-template-columns: auto 1fr auto auto; gap: 14px; align-items: center;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 12px 16px;
  transition: border-color 0.15s var(--ease);
}
.fin-item:hover { border-color: var(--primary); }
.fin-tipo-badge {
  width: 36px; height: 36px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.3rem; font-weight: 700;
}
.fin-tipo-badge.fin-receber { background: color-mix(in srgb, var(--ok) 15%, transparent); color: var(--ok); }
.fin-tipo-badge.fin-pagar { background: color-mix(in srgb, var(--danger) 15%, transparent); color: var(--danger); }
.fin-main .fin-desc { font-weight: 600; font-size: 0.94rem; }
.fin-main .fin-meta { font-size: 0.78rem; color: var(--ink-mute); margin-top: 2px; }
.fin-val { font-size: 1.05rem; font-weight: 700; white-space: nowrap; }
.fin-val.fin-receber { color: var(--ok); }
.fin-val.fin-pagar { color: var(--danger); }
.fin-actions { display: flex; gap: 4px; }

.lanc-tipo-row { display: flex; gap: 8px; }
.lanc-tipo-opt { flex: 1; }
.lanc-tipo-opt input[type="radio"] { display: none; }
.lanc-tipo-label {
  display: block; padding: 10px 12px; text-align: center;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  cursor: pointer; font-weight: 500; font-size: 0.92rem;
  transition: all 0.15s var(--ease);
}
.lanc-tipo-opt input[type="radio"]:checked + .lanc-tipo-label.fin-receber {
  background: var(--ok); color: #fff; border-color: var(--ok);
}
.lanc-tipo-opt input[type="radio"]:checked + .lanc-tipo-label.fin-pagar {
  background: var(--danger); color: #fff; border-color: var(--danger);
}

/* Assistente IA */
.ia-disclaimer {
  background: color-mix(in srgb, var(--primary) 6%, transparent);
  border-left: 3px solid var(--primary);
  border-radius: var(--radius-sm); padding: 12px 16px;
  font-size: 0.84rem; color: var(--ink-soft); line-height: 1.55;
  margin-bottom: 22px;
}
.ia-disclaimer strong { color: var(--primary); }

.ia-wrap {
  display: grid; grid-template-columns: 1fr; gap: 18px;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px;
}
.ia-input-group label { display: block; font-size: 0.86rem; font-weight: 600; margin-bottom: 6px; }
.ia-input-group textarea {
  width: 100%; padding: 12px 14px; font-size: 0.95rem;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: var(--bg); color: var(--ink); font-family: inherit;
  resize: vertical; min-height: 70px;
}
.ia-input-group textarea:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.ia-input-group .btn { margin-top: 12px; padding: 10px 24px; }

.ia-quick-tags { display: flex; gap: 6px; flex-wrap: wrap; margin: 10px 0 4px; }
.ia-tag {
  background: var(--bg-mute); color: var(--ink); border: 1px solid var(--line);
  border-radius: 999px; padding: 5px 12px; font-size: 0.8rem;
  cursor: pointer; font-family: inherit;
  transition: all 0.15s var(--ease);
}
.ia-tag:hover { border-color: var(--primary); color: var(--primary); }

.ia-output {
  border-top: 1px solid var(--line);
  padding-top: 18px;
}
.ia-result-head {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 14px;
}
.ia-eyebrow {
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em;
  text-transform: uppercase; color: var(--primary);
}
.ia-empty {
  padding: 18px; background: var(--bg-mute); border-radius: var(--radius-sm);
  font-size: 0.9rem; color: var(--ink-soft);
}

.ia-diag {
  background: var(--bg-mute); border-radius: var(--radius-sm);
  padding: 16px 18px; margin-bottom: 12px;
  border-left: 3px solid var(--primary);
}
.ia-diag[data-rank="2"] { border-left-color: #f59e0b; opacity: 0.95; }
.ia-diag[data-rank="3"] { border-left-color: var(--ink-mute); opacity: 0.85; }
.ia-diag-head {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.78rem; font-weight: 600;
  margin-bottom: 8px;
}
.ia-rank { color: var(--primary); text-transform: uppercase; letter-spacing: 0.06em; }
.ia-diag[data-rank="2"] .ia-rank { color: #f59e0b; }
.ia-diag[data-rank="3"] .ia-rank { color: var(--ink-mute); }
.ia-sistema {
  font-size: 0.78rem; color: var(--ink-mute); font-weight: 600;
  letter-spacing: 0.08em; margin: 0 0 12px;
}
.ia-bloco { margin: 10px 0; font-size: 0.9rem; }
.ia-bloco strong { color: var(--ink); display: block; margin-bottom: 4px; font-size: 0.84rem; }
.ia-bloco ul { padding-left: 18px; margin: 0; }
.ia-bloco li { margin: 3px 0; line-height: 1.55; color: var(--ink); }
.ia-manuais {
  margin-top: 10px; padding-top: 10px; border-top: 1px solid var(--line);
  font-size: 0.84rem; color: var(--ink-soft);
}
.ia-manuais strong { color: var(--ink); margin-right: 6px; }
.ia-link {
  color: var(--primary); text-decoration: none;
  background: var(--primary-soft); padding: 2px 8px; border-radius: 999px;
  font-size: 0.78rem; font-weight: 500;
  display: inline-block; margin: 2px 0;
}
.ia-link:hover { background: var(--primary); color: var(--primary-on); }

.ia-foot {
  margin-top: 14px; padding-top: 12px;
  border-top: 1px solid var(--line);
}

/* WhatsApp FAB (floating action button) */
.wa-fab {
  position: fixed; bottom: 24px; right: 24px; z-index: 90;
  background: #25D366; color: #fff;
  border-radius: 999px; padding: 12px 18px 12px 16px;
  display: inline-flex; align-items: center; gap: 8px;
  font-size: 0.86rem; font-weight: 600;
  box-shadow: 0 6px 20px rgba(37, 211, 102, 0.4);
  text-decoration: none; transition: transform 0.15s var(--ease), box-shadow 0.15s var(--ease);
}
.wa-fab:hover { transform: translateY(-2px); box-shadow: 0 10px 28px rgba(37, 211, 102, 0.5); color: #fff; }
.wa-fab svg { width: 22px; height: 22px; flex-shrink: 0; }
.wa-fab-label { font-size: 0.86rem; }

@media (max-width: 480px) {
  .wa-fab { padding: 12px; bottom: 16px; right: 16px; }
  .wa-fab-label { display: none; }
}

/* === Tabela comparativa Torque vs concorrentes (landing) === */
.compare-table-wrap {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  overflow-x: auto; margin-bottom: 22px;
}
.compare-table {
  width: 100%; border-collapse: collapse; font-size: 0.9rem;
  min-width: 720px;
}
.compare-table th, .compare-table td {
  padding: 12px 16px; text-align: center; border-bottom: 1px solid var(--line-soft);
}
.compare-table thead th {
  background: var(--bg-mute); font-size: 0.78rem; font-weight: 700;
  text-transform: uppercase; letter-spacing: 0.06em;
  color: var(--ink); border-bottom: 2px solid var(--line);
}
.compare-table thead th.t-torque {
  background: var(--primary); color: var(--primary-on);
  font-weight: 700; letter-spacing: 0.04em;
}
.compare-table tbody td:first-child {
  text-align: left; color: var(--ink);
}
.compare-table tbody td.ok { color: var(--ok); font-weight: 700; }
.compare-table tbody td.ko { color: var(--ink-mute); }
.compare-table tbody td.parcial { color: #f59e0b; font-weight: 600; font-size: 0.84rem; }
.compare-table tbody td.t-torque {
  background: color-mix(in srgb, var(--primary) 6%, transparent);
  font-weight: 600;
}
.compare-table tr.row-preco td { font-weight: 600; }
.compare-table tr:hover td { background: var(--bg-mute); }
.compare-table tr:hover td.t-torque { background: color-mix(in srgb, var(--primary) 12%, transparent); }

.compare-summary {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px 24px; text-align: center;
}
.compare-summary p {
  font-size: 0.96rem; line-height: 1.65; color: var(--ink-soft);
  max-width: 720px; margin: 0 auto 18px;
}
.compare-summary p strong { color: var(--ink); }
.compare-summary p strong:last-of-type { color: var(--primary); }
.compare-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.compare-cta .btn { padding: 12px 24px; font-size: 0.92rem; }

/* === Calculadora de prejuízo oculto (landing) === */
.prejuizo-widget {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px;
  display: grid; grid-template-columns: 1.1fr 1fr; gap: 22px;
  align-items: center;
}
@media (max-width: 720px) { .prejuizo-widget { grid-template-columns: 1fr; } }
.prej-fields { display: flex; flex-direction: column; gap: 14px; }
.prej-field label { font-size: 0.86rem; font-weight: 600; margin-bottom: 6px; display: block; color: var(--ink); }
.prej-field input {
  width: 100%; padding: 11px 14px; font-size: 1rem;
  border: 1px solid var(--line); border-radius: var(--radius-sm);
  background: var(--bg); color: var(--ink); font-family: inherit;
}
.prej-field input:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.prej-result {
  background: var(--ink); color: #fff;
  border-radius: var(--radius); padding: 28px 24px;
  text-align: center;
  display: flex; flex-direction: column; gap: 12px; justify-content: center;
  min-height: 200px;
  transition: background 0.3s var(--ease);
}
.prej-result .prej-num {
  font-size: 2.6rem; font-weight: 800; letter-spacing: -0.02em;
  color: var(--primary);
}
.prej-result .prej-lbl {
  font-size: 0.96rem; line-height: 1.55; color: rgba(255,255,255,0.85);
}
.prej-result .prej-lbl strong { color: var(--primary); font-weight: 700; }
.prej-result.alarme { background: linear-gradient(180deg, var(--ink) 0%, #2d0606 100%); }
.prej-result.alarme .prej-num { color: #fb923c; }
.prej-result.alarme .prej-lbl strong { color: #fb923c; }
.prej-result.tudo-ok { background: linear-gradient(180deg, #14532d 0%, #0a3d1f 100%); }
.prej-result.tudo-ok .prej-num { color: #4ade80; }
.prej-cta {
  grid-column: 1 / -1;
  display: flex; flex-direction: column; align-items: center; gap: 6px;
  margin-top: 8px; padding-top: 18px; border-top: 1px solid var(--line);
}
.prej-cta .btn { padding: 12px 28px; font-size: 0.94rem; }
.prej-cta-sub { font-size: 0.78rem; color: var(--ink-mute); }

/* === IA Counter freemium === */
.ia-head-row {
  display: flex; justify-content: space-between; align-items: center;
  margin-bottom: 6px; gap: 12px;
}
.ia-counter {
  display: inline-flex; align-items: center; gap: 6px;
  padding: 4px 12px; border-radius: 999px;
  background: var(--bg-mute); border: 1px solid var(--line);
  font-size: 0.78rem;
}
.ia-counter-num {
  font-weight: 800; color: var(--primary); font-size: 0.92rem;
}
.ia-counter-num.esgotado { color: var(--danger); }
.ia-counter-lbl { color: var(--ink-soft); font-size: 0.74rem; }
.ia-counter-lbl a { color: var(--primary); text-decoration: none; }
.ia-counter-lbl a:hover { text-decoration: underline; }

/* === EV Highlight badge no segments-strip === */
.segment-chip.ev-highlight {
  background: linear-gradient(90deg, color-mix(in srgb, var(--primary) 8%, var(--bg-elev)), var(--bg-elev));
  border: 1px solid color-mix(in srgb, var(--primary) 40%, transparent);
  color: var(--primary);
  font-weight: 600;
}
.segment-chip.ev-highlight .seg-mark { font-size: 1rem; }
.segment-chip.ev-highlight small {
  display: inline-block;
  margin-left: 4px;
  font-size: 0.66rem; font-weight: 700;
  padding: 1px 6px; border-radius: 4px;
  background: var(--primary); color: #fff;
  text-transform: uppercase; letter-spacing: 0.06em;
}

/* === 4 Gatilhos (Agilidade/Liberdade/Segurança/Lucratividade) === */
.gatilhos-grid {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(250px, 1fr)); gap: 18px;
}
.gatilho-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 12px;
}
.gatilho-icon {
  width: 48px; height: 48px;
  background: var(--primary-soft); color: var(--primary);
  border-radius: 12px;
  display: inline-flex; align-items: center; justify-content: center;
}
.gatilho-icon svg { width: 24px; height: 24px; }
.gatilho-card h3 { font-size: 1.2rem; margin: 0; font-weight: 700; }
.gatilho-card p { font-size: 0.92rem; color: var(--ink-soft); margin: 0; line-height: 1.6; }
.gatilho-card p strong { color: var(--ink); }

/* === Amador vs Profissional === */
.amador-pro-grid {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin-bottom: 22px;
}
@media (max-width: 720px) { .amador-pro-grid { grid-template-columns: 1fr; } }
.amador-pro-col {
  background: var(--bg-elev); border-radius: var(--radius);
  padding: 28px 24px;
  border: 1px solid var(--line);
  display: flex; flex-direction: column; gap: 12px;
}
.amador-pro-col.col-amador { opacity: 0.95; border-color: var(--line); }
.amador-pro-col.col-pro { border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.amador-pro-tag {
  display: inline-block; align-self: flex-start;
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.12em; text-transform: uppercase;
  padding: 4px 10px; border-radius: 999px;
}
.col-amador .amador-pro-tag { background: var(--bg-mute); color: var(--ink-mute); }
.col-pro .amador-pro-tag { background: var(--primary); color: var(--primary-on); }
.amador-pro-col h3 { font-size: 1.3rem; margin: 0; }
.col-amador h3 { color: var(--ink-mute); }
.col-pro h3 { color: var(--primary); }
.amador-pro-col ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 10px; }
.amador-pro-col li {
  position: relative;
  padding-left: 32px;
  font-size: 0.92rem; line-height: 1.55;
}
.col-amador li { color: var(--ink-soft); }
.col-pro li { color: var(--ink); }
.ap-mark {
  position: absolute; left: 0; top: 1px;
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%;
  font-weight: 700; font-size: 0.85rem;
}
.col-amador .ap-mark { background: color-mix(in srgb, var(--danger) 12%, transparent); color: var(--danger); }
.col-pro .ap-mark { background: color-mix(in srgb, var(--ok) 18%, transparent); color: var(--ok); }
.amador-pro-cta { display: flex; gap: 12px; justify-content: center; flex-wrap: wrap; }
.amador-pro-cta .btn { padding: 12px 28px; font-size: 0.94rem; }

.soon-tag {
  display: inline-block;
  font-size: 0.62rem; font-weight: 700; letter-spacing: 0.05em;
  padding: 1px 6px; border-radius: 4px;
  background: color-mix(in srgb, var(--ink) 14%, transparent);
  color: var(--ink-mute);
  text-transform: uppercase;
  vertical-align: 1px;
  margin-left: 5px;
  white-space: nowrap;
  line-height: 1.3;
}
.plans .plan li {
  word-break: break-word; overflow-wrap: anywhere;
}

/* === Planos 4 (Solo/Oficina/Master/Empresarial) === */
.plans.plans-4 {
  display: grid; gap: 16px;
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1100px) { .plans.plans-4 { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .plans.plans-4 { grid-template-columns: 1fr; } }
.plans-4 .plan {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px 20px;
  display: flex; flex-direction: column; gap: 12px;
}
.plans-4 .plan.recommended {
  border-color: var(--primary);
  box-shadow: 0 0 0 2px var(--primary-glow);
  position: relative;
}
.plans-4 .plan.plan-empresarial {
  border-color: var(--ink);
  background: linear-gradient(180deg, color-mix(in srgb, var(--ink) 4%, var(--bg-elev)), var(--bg-elev));
  position: relative;
}
.plan-badge {
  position: absolute; top: -10px; right: 14px;
  background: var(--ink); color: var(--bg);
  font-size: 0.7rem; font-weight: 700; letter-spacing: 0.04em;
  padding: 4px 10px; border-radius: 999px;
  text-transform: uppercase;
}
.plans-4 .plan-name { font-size: 1.04rem; font-weight: 700; color: var(--primary); letter-spacing: 0.04em; text-transform: uppercase; }
.plans-4 .plan-empresarial .plan-name { color: var(--ink); }
.plans-4 .plan-price { font-size: 1.65rem; font-weight: 700; letter-spacing: -0.02em; color: var(--ink); }
.plans-4 .plan-price .per { font-size: 0.78rem; font-weight: 500; color: var(--ink-mute); margin-left: 4px; }
.plans-4 .plan-trial-tag {
  display: inline-block; align-self: flex-start;
  font-size: 0.72rem; font-weight: 600;
  background: var(--primary-soft); color: var(--primary);
  padding: 3px 8px; border-radius: 999px;
}
.plans-4 .plan-empresarial .plan-trial-tag {
  background: color-mix(in srgb, var(--ink) 14%, transparent); color: var(--ink);
}
.plans-4 .plan ul { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-direction: column; gap: 6px; flex: 1; font-size: 0.86rem; line-height: 1.45; }
.plans-4 .plan li { padding-left: 16px; position: relative; color: var(--ink-soft); }
.plans-4 .plan li::before { content: "✓"; position: absolute; left: 0; color: var(--primary); font-weight: 700; }
.plans-4 .plan-empresarial li::before { color: var(--ink); }
.plans-4 .plan li strong { color: var(--ink); }
.plans-4 .plan .btn { padding: 10px; font-size: 0.86rem; width: 100%; margin-top: 4px; }

.plans-disclaimer {
  margin-top: 22px; padding: 14px 18px;
  background: var(--bg-mute); border: 1px solid var(--line); border-radius: var(--radius-sm);
  font-size: 0.82rem; color: var(--ink-soft); line-height: 1.55;
}
.plans-disclaimer p { margin: 0; }
.plans-disclaimer strong { color: var(--ink); }
.orc-history-list { display: flex; flex-direction: column; gap: 10px; }
.orc-history-item {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px 18px;
  display: flex; align-items: center; justify-content: space-between; gap: 14px;
  font-size: 0.92rem; transition: border-color 0.15s var(--ease);
}
.orc-history-item:hover { border-color: var(--primary); }
.orc-history-item .h-name { font-weight: 600; color: var(--ink); }
.orc-history-item .h-meta { font-size: 0.78rem; color: var(--ink-mute); margin-top: 2px; }
.orc-history-item .h-total { font-size: 1.05rem; font-weight: 700; color: var(--primary); white-space: nowrap; }
.orc-history-item .h-actions { display: flex; gap: 6px; }
.orc-history-item .h-action {
  background: transparent; border: 1px solid var(--line); border-radius: 6px;
  width: 28px; height: 28px; cursor: pointer; color: var(--ink-mute);
  display: inline-flex; align-items: center; justify-content: center;
  font-family: inherit; font-size: 0.85rem;
}
.orc-history-item .h-action:hover { color: var(--danger); border-color: var(--danger); }
.orc-history-empty {
  text-align: center; padding: 24px; color: var(--ink-mute);
  font-size: 0.92rem; border: 1px dashed var(--line); border-radius: var(--radius-sm);
}

/* Vehicle selector (BrasilAPI FIPE) */
.vehicle-selector {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 22px; margin-top: 16px;
}
.vehicle-selector .vs-eyebrow {
  display: inline-block; font-size: 0.7rem; font-weight: 700;
  letter-spacing: 0.12em; text-transform: uppercase;
  color: var(--primary); margin-bottom: 10px;
}
.vehicle-selector h4 { margin: 0 0 6px; font-size: 1.05rem; font-weight: 600; }
.vehicle-selector p { margin: 0 0 14px; font-size: 0.86rem; color: var(--ink-soft); line-height: 1.5; }
.vs-fields { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 10px; }
@media (max-width: 720px) { .vs-fields { grid-template-columns: 1fr; } }
.vs-fields select {
  padding: 11px 12px; font-size: 0.95rem; border: 1px solid var(--line);
  border-radius: var(--radius-sm); background: var(--bg); color: var(--ink);
  font-family: inherit; transition: border-color 0.15s var(--ease);
  width: 100%;
}
.vs-fields select:focus { outline: none; border-color: var(--primary); box-shadow: 0 0 0 3px var(--primary-glow); }
.vs-fields select:disabled { opacity: 0.5; cursor: not-allowed; }
.vs-result {
  margin-top: 14px; padding: 14px 18px;
  background: var(--ok-soft); color: var(--ok);
  border-radius: var(--radius-sm); font-size: 0.92rem; font-weight: 500;
  display: none;
}
.vs-result.shown { display: block; }
.vs-result strong { display: block; margin-bottom: 2px; font-weight: 700; }
[data-theme="dark"] .vs-result { color: #22c55e; }

/* Rules list (numerada) */
.rules-list { list-style: none; padding: 0; margin: 0; counter-reset: rule-counter; display: flex; flex-direction: column; gap: 14px; }
.rules-list li {
  counter-increment: rule-counter;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 18px 22px 18px 64px; position: relative;
  font-size: 0.96rem; color: var(--ink); line-height: 1.6;
}
.rules-list li::before {
  content: counter(rule-counter, decimal-leading-zero);
  position: absolute; left: 22px; top: 18px;
  font-size: 0.95rem; font-weight: 700; color: var(--primary);
  letter-spacing: 0.04em;
}
.rules-list li strong { color: var(--ink); }

/* === Fase 7: Agenda + Ordem de Serviço === */
.agenda-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; margin-bottom: 18px; flex-wrap: wrap;
}
.agenda-stats {
  display: flex; gap: 8px; flex-wrap: wrap;
}
.agenda-stat-chip {
  font-size: 0.78rem; padding: 4px 10px; border-radius: 999px;
  background: var(--bg-mute); color: var(--ink-soft);
  border: 1px solid var(--line);
}
.agenda-stat-chip strong { color: var(--ink); margin-right: 4px; }
.agenda-board {
  display: grid; gap: 14px;
  grid-template-columns: repeat(4, 1fr);
}
@media (max-width: 1100px) { .agenda-board { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 600px) { .agenda-board { grid-template-columns: 1fr; } }
.agenda-col {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px;
  display: flex; flex-direction: column; gap: 10px;
  min-height: 200px;
}
.agenda-col-head {
  display: flex; align-items: center; justify-content: space-between;
}
.agenda-col-head h3 { font-size: 0.92rem; font-weight: 700; margin: 0; color: var(--primary); text-transform: uppercase; letter-spacing: 0.04em; }
.agenda-col-count {
  font-size: 0.74rem; padding: 2px 8px; border-radius: 999px;
  background: var(--primary-soft); color: var(--primary); font-weight: 700;
}
.agenda-col-desc { font-size: 0.74rem; color: var(--ink-mute); margin: 0; line-height: 1.4; }
.agenda-col-list {
  display: flex; flex-direction: column; gap: 8px; flex: 1;
}
.agenda-empty {
  padding: 20px 0; text-align: center;
  font-size: 0.82rem; color: var(--ink-mute); font-style: italic;
}
.agenda-card {
  text-align: left; cursor: pointer;
  background: var(--bg); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 10px 12px;
  display: flex; flex-direction: column; gap: 4px;
  font-family: inherit; color: var(--ink);
  transition: border-color 0.12s, box-shadow 0.12s;
}
.agenda-card:hover { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-glow); }
.agenda-card-head {
  display: flex; justify-content: space-between; align-items: center; gap: 8px;
}
.agenda-card-head strong { font-size: 0.92rem; color: var(--ink); }
.agenda-placa { font-size: 0.72rem; padding: 2px 6px; border-radius: 4px; background: var(--bg-mute); color: var(--ink-soft); }
.agenda-card-veiculo { font-size: 0.82rem; color: var(--ink-soft); font-weight: 600; }
.agenda-card-desc { font-size: 0.78rem; color: var(--ink-mute); line-height: 1.4; }
.agenda-card-foot {
  display: flex; justify-content: space-between; align-items: center;
  font-size: 0.78rem; color: var(--ink-soft); margin-top: 4px;
}
.agenda-prazo { color: var(--primary); font-weight: 600; }

/* === Fase 7: Equipe === */
.equipe-toolbar, .filiais-toolbar {
  display: flex; align-items: center; justify-content: space-between;
  gap: 14px; margin-bottom: 14px; flex-wrap: wrap;
}
.equipe-counter, .filiais-counter {
  font-size: 0.82rem; color: var(--ink-soft);
  padding: 4px 10px; border-radius: 999px; background: var(--bg-mute);
}
.equipe-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(2, 1fr);
}
@media (max-width: 700px) { .equipe-grid { grid-template-columns: 1fr; } }
.equipe-card {
  display: flex; gap: 14px; align-items: center;
  text-align: left; cursor: pointer;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px;
  font-family: inherit; color: var(--ink);
  transition: border-color 0.12s, box-shadow 0.12s;
}
.equipe-card:hover { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-glow); }
.equipe-card-avatar {
  width: 48px; height: 48px; border-radius: 50%;
  background: var(--primary); color: var(--primary-on);
  display: flex; align-items: center; justify-content: center;
  font-weight: 700; font-size: 1.2rem; flex-shrink: 0;
}
.equipe-card-info { display: flex; flex-direction: column; gap: 2px; flex: 1; min-width: 0; }
.equipe-card-info strong { font-size: 0.96rem; color: var(--ink); }
.equipe-card-cargo { font-size: 0.82rem; color: var(--primary); font-weight: 600; }
.equipe-card-email { font-size: 0.76rem; color: var(--ink-soft); overflow: hidden; text-overflow: ellipsis; }
.equipe-card-role { font-size: 0.74rem; color: var(--ink-mute); margin-top: 2px; }
.equipe-disclaimer, .filiais-disclaimer {
  margin-top: 14px; padding: 10px 14px;
  background: var(--bg-mute); border: 1px solid var(--line); border-radius: var(--radius-sm);
  font-size: 0.78rem; color: var(--ink-mute); line-height: 1.5;
}

/* === Fase 7: Filiais === */
.filiais-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 900px) { .filiais-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .filiais-grid { grid-template-columns: 1fr; } }
.filial-card {
  text-align: left; cursor: pointer;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 14px;
  display: flex; flex-direction: column; gap: 4px;
  font-family: inherit; color: var(--ink);
  transition: border-color 0.12s, box-shadow 0.12s;
}
.filial-card:hover { border-color: var(--primary); box-shadow: 0 0 0 2px var(--primary-glow); }
.filial-card strong { font-size: 0.96rem; color: var(--primary); }
.filial-meta { font-size: 0.78rem; color: var(--ink-soft); line-height: 1.4; }

/* === White-label checkbox === */
.of-checkbox-label {
  display: flex; align-items: flex-start; gap: 10px; cursor: pointer;
  padding: 10px 12px; background: var(--bg-mute); border: 1px solid var(--line); border-radius: var(--radius-sm);
  font-size: 0.86rem; line-height: 1.4; color: var(--ink-soft);
}
.of-checkbox-label input[type="checkbox"] {
  margin-top: 3px; flex-shrink: 0; width: 16px; height: 16px;
  accent-color: var(--primary);
}
.of-checkbox-label strong { color: var(--ink); }

/* === Fase 10: Dashboard de gerência === */
.kpi-grid {
  display: grid; gap: 14px; margin-bottom: 22px;
  grid-template-columns: repeat(3, 1fr);
}
@media (max-width: 900px) { .kpi-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 540px) { .kpi-grid { grid-template-columns: 1fr; } }
.kpi-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 18px 16px;
  display: flex; flex-direction: column; gap: 4px;
}
.kpi-card.kpi-positivo { border-left: 3px solid var(--ok); }
.kpi-card.kpi-negativo { border-left: 3px solid var(--danger); }
.kpi-card.kpi-alerta { border-left: 3px solid var(--danger); background: color-mix(in srgb, var(--danger) 5%, var(--bg-elev)); }
.kpi-label { font-size: 0.74rem; color: var(--ink-mute); text-transform: uppercase; letter-spacing: 0.06em; font-weight: 600; }
.kpi-num { font-size: 1.6rem; font-weight: 700; color: var(--ink); letter-spacing: -0.01em; line-height: 1.1; margin-top: 2px; }
.kpi-card.kpi-positivo .kpi-num { color: var(--ok); }
.kpi-card.kpi-negativo .kpi-num { color: var(--danger); }
.kpi-card.kpi-alerta .kpi-num { color: var(--danger); }
.kpi-sub { font-size: 0.74rem; color: var(--ink-soft); margin-top: 2px; }

.kpi-secondary {
  display: grid; gap: 14px; margin-bottom: 18px;
  grid-template-columns: 1fr 1fr;
}
@media (max-width: 800px) { .kpi-secondary { grid-template-columns: 1fr; } }
.kpi-card-large {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius-sm);
  padding: 20px 18px;
}
.kpi-card-large h3 { margin: 0 0 14px; font-size: 0.96rem; color: var(--primary); text-transform: uppercase; letter-spacing: 0.04em; }
.kpi-top-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; counter-reset: top; }
.kpi-top-list li { display: flex; gap: 10px; align-items: center; font-size: 0.92rem; padding: 8px 10px; background: var(--bg-mute); border-radius: 6px; counter-increment: top; }
.kpi-top-list li::before { content: counter(top); width: 22px; height: 22px; flex-shrink: 0; background: var(--primary); color: var(--primary-on); border-radius: 50%; display: inline-flex; align-items: center; justify-content: center; font-size: 0.74rem; font-weight: 700; }
.kpi-top-list li.kpi-empty::before { display: none; }
.kpi-top-list li.kpi-empty { color: var(--ink-mute); font-style: italic; background: transparent; padding: 0; }
.kpi-top-name { flex: 1; }
.kpi-top-qtd { color: var(--primary); font-weight: 700; font-family: var(--font-mono); }

.kpi-bars { display: flex; flex-direction: column; gap: 10px; }
.kpi-bar-row { display: grid; grid-template-columns: 110px 1fr 70px; gap: 10px; align-items: center; font-size: 0.86rem; }
.kpi-bar-label { color: var(--ink-soft); font-weight: 600; }
.kpi-bar-track { height: 8px; background: var(--bg-mute); border-radius: 999px; overflow: hidden; }
.kpi-bar-fill { height: 100%; background: var(--primary); transition: width 0.3s var(--ease); }
.kpi-bar-val { font-family: var(--font-mono); color: var(--ink-mute); font-size: 0.78rem; text-align: right; }
.kpi-empty { font-size: 0.86rem; color: var(--ink-mute); font-style: italic; padding: 14px 0; text-align: center; }

.kpi-actions { display: flex; gap: 10px; flex-wrap: wrap; justify-content: flex-end; }

/* === Fundadores === */
.founder-story {
  max-width: 760px; margin: 0 auto 36px;
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 24px 28px;
}
.founder-story h3 { margin: 0 0 12px; color: var(--primary); font-size: 1rem; text-transform: uppercase; letter-spacing: 0.06em; }
.founder-story p { color: var(--ink-soft); line-height: 1.7; margin: 0 0 12px; }
.founder-story p:last-child { margin-bottom: 0; }
.founder-story strong { color: var(--ink); }

.founders-grid {
  display: grid; gap: 20px;
  grid-template-columns: 1fr 1fr;
  max-width: 1080px; margin: 0 auto;
}
@media (max-width: 800px) { .founders-grid { grid-template-columns: 1fr; } }

.founder-card {
  background: var(--bg-elev); border: 1px solid var(--line); border-radius: var(--radius);
  padding: 28px 24px;
  display: flex; flex-direction: column; gap: 16px;
  transition: border-color 0.18s var(--ease), transform 0.18s var(--ease);
}
.founder-card:hover { border-color: var(--primary); transform: translateY(-2px); }
/* v1.9.34 — alinhamento de cards: info ocupa altura disponível, links sempre no fundo */
.founder-card .founder-info { display: flex; flex-direction: column; flex: 1; }
.founder-card .founder-tags { margin-top: auto; }
.founder-card .founder-links { margin-top: 0; }

.founder-avatar {
  width: 96px; height: 96px; border-radius: 50%;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; font-weight: 800; letter-spacing: -0.02em;
  color: #fff;
  flex-shrink: 0; align-self: flex-start;
  position: relative; overflow: hidden;
  border: 3px solid var(--bg);
  box-shadow: 0 0 0 1px var(--line);
}
.founder-avatar-paulo {
  background: linear-gradient(135deg, #1a1a1a 0%, #991b1b 100%);
}
.founder-avatar-ailton {
  background: linear-gradient(135deg, #991b1b 0%, #ef4444 100%);
}
.founder-initials {
  position: absolute; inset: 0;
  display: flex; align-items: center; justify-content: center;
  font-size: 1.8rem; font-weight: 800; letter-spacing: -0.02em;
  color: #fff;
  z-index: 1;
}
img.founder-photo {
  position: absolute; inset: 0;
  width: 100%; height: 100%;
  object-fit: cover;
  object-position: center top;
  z-index: 2;
  border-radius: inherit;
}

.founder-info h3 {
  margin: 0 0 4px; font-size: 1.4rem; letter-spacing: -0.01em; color: var(--ink);
}
.founder-role {
  font-size: 0.78rem; font-weight: 700; letter-spacing: 0.08em; text-transform: uppercase;
  color: var(--primary);
  display: block; margin-bottom: 14px;
}
.founder-bio {
  color: var(--ink-soft); line-height: 1.65; font-size: 0.96rem; margin: 0 0 16px;
}
.founder-tags {
  display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 14px;
}
.founder-tag {
  display: inline-block; padding: 4px 10px;
  font-size: 0.72rem; font-weight: 600;
  background: var(--bg-mute); color: var(--ink-soft);
  border-radius: 999px; border: 1px solid var(--line);
}
.founder-links {
  display: flex; flex-wrap: wrap; gap: 10px; padding-top: 12px;
  border-top: 1px solid var(--line);
}
.founder-link {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.84rem; color: var(--primary); font-weight: 600;
  text-decoration: none; padding: 6px 12px;
  border: 1px solid var(--primary); border-radius: 999px;
  transition: background 0.18s var(--ease);
}
.founder-link svg { width: 14px; height: 14px; }
.founder-link:hover { background: var(--primary-soft); }

.founders-disclaimer {
  text-align: center; max-width: 600px; margin: 28px auto 0;
  color: var(--ink-mute); font-size: 0.86rem;
}

/* Minha assinatura — card no topo de #planos quando user tem assinatura ativa */
#minha-assinatura { margin: 0 0 28px; }
.minha-assinatura-card {
  background: var(--surface, var(--bg));
  border: 1px solid var(--line);
  border-radius: 12px;
  padding: 18px 22px;
  display: flex; flex-direction: column; gap: 14px;
}
.minha-assinatura-card .ma-row {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  font-size: 0.92rem;
}
.minha-assinatura-card .ma-label {
  color: var(--ink-mute); font-size: 0.78rem; text-transform: uppercase;
  letter-spacing: 0.05em; margin-right: 4px;
}
.minha-assinatura-card .ma-pill {
  font-size: 0.74rem; font-weight: 600; padding: 3px 10px;
  border-radius: 999px; text-transform: uppercase; letter-spacing: 0.04em;
  background: var(--line); color: var(--ink-soft);
}
.minha-assinatura-card .ma-pill-authorized { background: var(--ok-soft); color: var(--ok); }
.minha-assinatura-card .ma-pill-pending    { background: var(--primary-glow, rgba(239,68,68,0.12)); color: var(--primary); }
.minha-assinatura-card .ma-pill-cancelled  { background: var(--line); color: var(--ink-mute); }
.minha-assinatura-card .ma-pill-paused     { background: var(--line); color: var(--ink-soft); }
.minha-assinatura-card .ma-actions {
  display: flex; gap: 10px; flex-wrap: wrap;
}
.minha-assinatura-card .ma-status {
  font-size: 0.85rem; color: var(--ink-mute);
}
@media (max-width: 600px) {
  .minha-assinatura-card { padding: 14px 16px; }
  .minha-assinatura-card .ma-row { font-size: 0.86rem; }
}

/* =====================================================================
   Comunidade Torque — chat estilo Telegram (v1.9.34)
   ===================================================================== */
.comunidade-empty, .comunidade-paywall {
  text-align: center; padding: 48px 20px; max-width: 600px; margin: 24px auto;
  border: 1px dashed var(--line); border-radius: var(--radius);
  color: var(--ink-soft);
}
.comunidade-paywall h3 { margin: 0 0 12px; color: var(--primary); }
.comunidade-paywall p { margin: 0 0 18px; line-height: 1.6; }

.comunidade-app {
  display: grid; grid-template-columns: 280px 1fr; gap: 0;
  height: 70vh; min-height: 520px;
  border: 1px solid var(--line); border-radius: var(--radius);
  overflow: hidden; background: var(--bg-elev);
}
@media (max-width: 820px) {
  .comunidade-app { grid-template-columns: 1fr; height: auto; min-height: auto; }
}

.comunidade-sidebar {
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
  background: var(--bg);
}
@media (max-width: 820px) {
  .comunidade-sidebar { border-right: 0; border-bottom: 1px solid var(--line); }
}
.comunidade-sidebar-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 16px; border-bottom: 1px solid var(--line);
}
.comunidade-sidebar-head h3 { margin: 0; font-size: 0.95rem; letter-spacing: 0.02em; }
.com-btn-admin { font-size: 0.78rem; padding: 6px 10px; }
.comunidade-canais-list {
  list-style: none; margin: 0; padding: 8px;
  overflow-y: auto; flex: 1;
}
.comunidade-canais-list li {
  padding: 10px 12px; border-radius: 8px;
  cursor: pointer; transition: background 0.15s var(--ease);
  font-size: 0.92rem;
}
.comunidade-canais-list li:hover { background: var(--bg-elev); }
.comunidade-canais-list li.is-active {
  background: var(--primary); color: var(--primary-on);
}
.comunidade-canais-list li .com-canal-meta {
  display: block; font-size: 0.74rem; opacity: 0.7; margin-top: 2px;
}

.comunidade-chat {
  display: flex; flex-direction: column;
  min-width: 0; /* impede overflow horizontal */
}
.comunidade-chat-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 12px 18px; border-bottom: 1px solid var(--line);
  background: var(--bg);
}
.com-canal-info { min-width: 0; flex: 1; }
.com-canal-info strong { display: block; font-size: 1rem; }
.com-canal-desc { font-size: 0.78rem; color: var(--ink-mute); display: block; }
.com-chat-tools { display: flex; gap: 6px; }
.com-icon-btn {
  background: transparent; border: 1px solid transparent;
  color: var(--ink-mute); cursor: pointer;
  width: 34px; height: 34px; display: inline-flex; align-items: center; justify-content: center;
  border-radius: 8px; transition: background 0.15s var(--ease);
}
.com-icon-btn:hover { background: var(--bg-elev); color: var(--ink); }
.com-icon-btn:disabled { opacity: 0.4; cursor: not-allowed; }
.com-icon-btn svg { width: 18px; height: 18px; }

.com-search-bar {
  display: flex; gap: 6px; padding: 10px 14px;
  border-bottom: 1px solid var(--line); background: var(--bg-mute);
}
.com-search-bar input {
  flex: 1; padding: 8px 12px;
  border: 1px solid var(--line); border-radius: 8px;
  background: var(--bg); color: var(--ink); font-family: inherit;
}

.com-pinned {
  padding: 8px 16px; background: var(--bg-mute);
  border-bottom: 1px solid var(--line);
  font-size: 0.84rem; color: var(--ink-soft);
  display: flex; gap: 8px; align-items: center;
}
.com-pinned-label { flex-shrink: 0; font-weight: 600; }
.com-pinned-text { overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }

.com-mensagens {
  flex: 1; overflow-y: auto;
  padding: 18px; display: flex; flex-direction: column; gap: 8px;
  background: var(--bg);
}
.com-msg {
  max-width: 75%; padding: 8px 12px;
  border-radius: 12px;
  background: var(--bg-elev); border: 1px solid var(--line);
  font-size: 0.92rem; line-height: 1.5;
  position: relative;
  word-wrap: break-word; overflow-wrap: anywhere;
}
.com-msg.is-own {
  align-self: flex-end;
  background: var(--primary-soft, rgba(239,68,68,0.12));
  border-color: var(--primary);
}
.com-msg-head {
  display: flex; gap: 8px; align-items: baseline;
  font-size: 0.74rem; color: var(--ink-mute);
  margin-bottom: 2px;
}
.com-msg-autor { font-weight: 700; color: var(--ink); }
.com-msg-time { opacity: 0.6; }
.com-msg-text { white-space: pre-wrap; }
.com-msg-text.is-deleted { font-style: italic; color: var(--ink-mute); }
.com-msg-edited { font-size: 0.7rem; color: var(--ink-mute); margin-left: 4px; }
.com-msg-reply {
  border-left: 3px solid var(--primary);
  padding: 4px 8px; margin-bottom: 6px;
  font-size: 0.78rem; color: var(--ink-soft);
  background: var(--bg-mute); border-radius: 4px;
}
.com-msg-reply strong { color: var(--ink); }
.com-msg-actions {
  display: flex; gap: 4px; margin-top: 4px;
  opacity: 0; transition: opacity 0.15s var(--ease);
}
.com-msg:hover .com-msg-actions, .com-msg:focus-within .com-msg-actions { opacity: 1; }
.com-msg-action {
  background: transparent; border: 0;
  font-size: 0.74rem; color: var(--ink-mute);
  cursor: pointer; padding: 2px 6px; border-radius: 4px;
}
.com-msg-action:hover { background: var(--bg-mute); color: var(--ink); }

.com-reply-preview {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 14px; background: var(--bg-mute);
  border-top: 1px solid var(--line);
  font-size: 0.84rem;
}
.com-reply-label { flex-shrink: 0; color: var(--ink-mute); }
.com-reply-trecho { flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; color: var(--ink-soft); }

.com-form {
  display: flex; gap: 8px; align-items: center;
  padding: 12px 14px; border-top: 1px solid var(--line);
  background: var(--bg);
}
.com-form input[type="text"] {
  flex: 1; padding: 10px 14px;
  border: 1px solid var(--line); border-radius: 999px;
  background: var(--bg-mute); color: var(--ink);
  font-family: inherit; font-size: 0.94rem;
}
.com-form input[type="text"]:focus {
  outline: none; border-color: var(--primary); background: var(--bg);
}
.com-form .btn { padding: 8px 14px; font-size: 0.86rem; }
.com-form .btn svg { width: 16px; height: 16px; margin-right: 4px; }
@media (max-width: 600px) {
  .com-form .com-btn-label { display: none; }
  .com-form .btn { padding: 8px; }
  .com-form .btn svg { margin-right: 0; }
  .com-msg { max-width: 90%; }
}

.com-empty-mensagens {
  text-align: center; color: var(--ink-mute); padding: 36px 20px;
  font-size: 0.92rem;
}
