/* Pomodorr Landing Theme */
:root{
  --gold:#f5c241; --gold-2:#ffd556; --gold-b:rgba(245,194,65,.65);
  --ink:#e5e7eb; --ink-soft:#9fb0c6; --bg-0:#0b0f19; --bg-1:#101827; --bg-2:#121a2a;
  --card:rgba(255,255,255,.06); --line:rgba(255,255,255,.10); --line-2:rgba(255,255,255,.06);
  --shadow:0 10px 28px rgba(0,0,0,.28);
  --radius:14px; --radius-sm:10px;
  --hdr-h:68px;
  --ease: cubic-bezier(.22,.61,.36,1);

  /* Tokens esperados por assets/ui/form.css (fallbacks), alinhados à paleta da landing */
  --brand-gold: var(--gold);
  --brand-gold-hover: var(--gold-2);
  --modal-bg: rgba(12,16,26,.92);
  --modal-bg-alt: rgba(16,22,34,.92);
  --modal-border: rgba(255,255,255,.12);
  --modal-text: var(--ink);
  --modal-text-soft: rgba(255,255,255,.72);
}
*{box-sizing:border-box}
html,body{margin:0; padding:0}
html{ scroll-behavior: smooth; overflow-x:hidden; scroll-snap-type: y mandatory; scroll-padding-top: var(--hdr-h); }
body{ font-family: Inter, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif; color:var(--ink); background:
  radial-gradient(1200px 600px at 50% -200px,#121826 12%,#0b0f19 60%),
  linear-gradient(180deg,#0b0f19,#0b0f19);
  overflow-x:hidden;
}
.lp-backdrop[hidden], .lp-drawer[hidden]{ display:none !important; }
.container{ width:min(1140px,92vw); margin:0 auto; }

/* Top accent bar */
.lp-topbar{ position:fixed; top:0; left:0; right:0; height:3px; background:linear-gradient(90deg, rgba(245,194,65,.15), rgba(245,194,65,.55), rgba(245,194,65,.15)); z-index:90; }

/* Header */
.lp-header{ position:fixed; top:0; left:0; right:0; z-index:80; backdrop-filter:saturate(130%) blur(8px); background: rgba(8,12,20,.55); border-bottom:1px solid var(--line-2); transition: background .18s var(--ease), border-color .18s var(--ease), backdrop-filter .18s var(--ease), opacity .18s var(--ease); }
.lp-header.is-dim{ background: rgba(8,12,20,.14); border-bottom-color: rgba(255,255,255,.02); backdrop-filter: saturate(102%) blur(4px); }
.lp-header:hover{ background: rgba(8,12,20,.55); border-bottom-color: var(--line-2); backdrop-filter: saturate(130%) blur(8px); }
.lp-header .container{ transition: opacity .18s var(--ease); }
.lp-header.is-dim .container{ opacity:.5; }
.lp-header:hover .container, .lp-header:not(.is-dim) .container{ opacity:1; }
.lp-header .container{ width:100%; max-width:none; padding:10px 12px; display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:12px; }
.logo{ display:flex; align-items:center; gap:10px; text-decoration:none; color:#fff; font-weight:800; }
.logo-img{ height:40px; width:auto; filter:none; display:block; }
.logo-img.logo-img--invert{ filter:brightness(0) invert(1); }
.lp-nav{ display:flex; gap:12px; grid-column:2; justify-self:center; }
.nav-link{ position:relative; color:var(--ink-soft); text-decoration:none; font-weight:700; padding:8px 10px; border-radius:999px; border:1px solid transparent; transition: color .18s var(--ease), background .18s var(--ease), border-color .18s var(--ease), box-shadow .18s var(--ease); }
.nav-link:hover{ color:var(--ink); background:rgba(255,255,255,.06); border-color:rgba(245,194,65,.25); box-shadow:0 6px 16px -8px rgba(245,194,65,.45) inset; }
.nav-link.active{ color:#111827; background: linear-gradient(90deg,var(--gold),var(--gold-2)); border-color: rgba(245,194,65,.55); box-shadow:0 6px 22px -8px rgba(245,194,65,.55); }
.lp-cta{ display:flex; gap:8px; grid-column:3; justify-self:end; }
.logo{ grid-column:1; justify-self:start; }
.nav-toggle{ display:none; width:40px; height:40px; border-radius:999px; border:1px solid var(--line); background:rgba(255,255,255,.06); align-items:center; justify-content:center; gap:4px; flex-direction:column; cursor:pointer; grid-column:3; justify-self:end; }
.nav-toggle .bar{ width:18px; height:2px; background:#e5e7eb; border-radius:2px; display:block; }
.nav-toggle:hover{ background: rgba(255,255,255,.12); }
.btn{ position:relative; overflow:hidden; display:inline-flex; align-items:center; gap:8px; padding:10px 14px; font-weight:800; border-radius:999px; text-decoration:none; border:1px solid var(--line); transition: transform .18s var(--ease), filter .18s var(--ease), box-shadow .18s var(--ease); }
.btn.primary{ background:linear-gradient(90deg,var(--gold),var(--gold-2)); color:#111827; border-color:rgba(245,194,65,.45); box-shadow:0 6px 22px -6px rgba(245,194,65,.45); }
.btn.primary:hover{ filter:brightness(1.04); transform: translateY(-1px); }
.btn.ghost{ background: rgba(255,255,255,.06); color:var(--ink); }
.btn.ghost:hover{ background: rgba(255,255,255,.12); transform: translateY(-1px); }
.btn.xl{ padding:12px 16px; font-size:16px; }
/* shine */
.btn::after{ content:""; position:absolute; top:-40%; left:-30%; width:40%; height:180%; background:linear-gradient(120deg, rgba(255,255,255,.0) 0%, rgba(255,255,255,.35) 45%, rgba(255,255,255,.0) 90%); transform: translateX(-140%) rotate(18deg); transition: transform .6s var(--ease); }
.btn:hover::after{ transform: translateX(260%) rotate(18deg); }

/* Premium outlined button (navbar) */
.btn.premium-outline{ position:relative; background:rgba(245,194,65,.08); border-color:rgba(245,194,65,.55); color:var(--gold); overflow:hidden; padding:10px 14px; }
.btn.premium-outline .label{ max-width:0; opacity:0; white-space:nowrap; overflow:hidden; transform:translateX(8px); transition: max-width .42s var(--ease), opacity .32s var(--ease) .04s, transform .42s var(--ease); font-weight:800; }
.btn.premium-outline i{ transition: transform .42s var(--ease), filter .42s var(--ease); }
.btn.premium-outline:hover{ background:rgba(245,194,65,.14); }
.btn.premium-outline:hover i{ transform:translateX(-6px) rotate(-10deg); filter:drop-shadow(0 2px 4px rgba(245,194,65,.45)); }
.btn.premium-outline:hover .label{ max-width:160px; opacity:1; transform:translateX(0); }
.btn.premium-outline:focus-visible{ outline:3px solid rgba(245,194,65,.55); outline-offset:3px; }
.btn.premium-outline:active{ transform:translateY(0); }

/* Hero */
.lp-hero{ position:relative; padding:54px 0 24px; min-height: calc(100vh - var(--hdr-h)); min-height: calc(100svh - var(--hdr-h)); scroll-snap-align: start; scroll-snap-stop: always; display:flex; align-items:center; overflow-x: clip; }
.hero-grid{ display:grid; grid-template-columns: 1.15fr .85fr; gap:24px; align-items:center; }
.eyebrow{ color:var(--ink-soft); font-weight:700; letter-spacing:.3px; margin:0 0 6px; }
.eyebrow .spark{ color:var(--gold); margin-right:6px; }
.lp-hero h1{ margin:0 0 8px; font-size:44px; line-height:1.05; }
.grad{ background: linear-gradient(90deg, #fff, #ffe5a6, #ffd24a); -webkit-background-clip:text; background-clip:text; -webkit-text-fill-color:transparent; }
.sr-only{ position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden; clip:rect(0,0,0,0); white-space:nowrap; border:0; }

.hero-type{ display:inline-flex; align-items:baseline; gap:2px; color: rgba(255,255,255,.96); font-weight:900; letter-spacing:.2px; }
.hero-type #heroType{ color: rgba(255,255,255,.96); text-shadow: 0 10px 30px rgba(0,0,0,.35); }
.hero-cursor{ display:inline-block; width:0; height:1em; border-left: 3px solid var(--gold); margin-left: 3px; transform: translateY(2px); animation: heroCursorBlink 720ms steps(1) infinite; }
@keyframes heroCursorBlink{ 0%,48%{ opacity:1; } 50%,100%{ opacity:0; } }

@media (prefers-reduced-motion: reduce){
  .hero-cursor{ animation:none; opacity:0; }
}
.sub{ color:var(--ink-soft); margin:0 0 14px; font-size:16px; }
.hero-ctas{ display:flex; gap:10px; margin-bottom:10px; }
.trust-row{ display:flex; flex-wrap:wrap; gap:8px; }
.chip{ display:inline-flex; gap:8px; align-items:center; padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.06); border:1px solid var(--line); color:var(--ink-soft); font-weight:700; font-size:12px; }

/* Comentários (Landing) */
.lp-comments-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 22px;
  align-items:start;
}

.lp-comments-list, .lp-comments-formwrap{
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  border-radius: 16px;
  padding: 18px;
  box-shadow: 0 10px 30px rgba(0,0,0,.22);
}

.lp-comments-header{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 12px;
  margin-bottom: 10px;
}
.lp-comments-header h3{ margin:0; font-size:16px; }

.lp-comments-items{ display:grid; gap: 12px; }

.lp-comment{
  border-radius: 14px;
  padding: 14px 14px 12px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.16);
}
.lp-comment .msg{ margin:0; color: rgba(255,255,255,.92); line-height: 1.5; }
.lp-comment .meta{
  margin-top: 10px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  color: rgba(255,255,255,.70);
  font-size: 12px;
}
.lp-comment .name{ font-weight: 700; color: rgba(255,255,255,.85); }

.lp-comment-skel{
  height: 90px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: linear-gradient(90deg, rgba(255,255,255,.05), rgba(255,255,255,.10), rgba(255,255,255,.05));
  background-size: 200% 100%;
  animation: lpSkel 1.2s ease-in-out infinite;
}
@keyframes lpSkel{ 0%{ background-position:-200% 0; } 100%{ background-position:200% 0; } }

.lp-comment-form{ display:flex; flex-direction:column; gap: 12px; }
.lp-comments-note{ margin: 10px 0 0; font-size: 12px; color: rgba(255,255,255,.70); }

.hp{ position:absolute; left:-9999px; width:1px; height:1px; opacity:0; }

.btn.sm{ padding: 8px 12px; font-size: 13px; }

@media (max-width: 920px){
  .lp-comments-grid{ grid-template-columns: 1fr; }
}
.hero-right{ position:relative; }
.mock.card{ background:var(--card); border:1px solid var(--line); border-radius:16px; box-shadow: var(--shadow); transform: translateY(var(--parallax-y, 0px)); will-change: transform; }
.mock-top{ display:flex; gap:6px; padding:8px 10px; border-bottom:1px solid var(--line-2); }
.dot{ width:10px; height:10px; border-radius:999px; display:inline-block; opacity:.9; }
.dot.red{ background:#ff6b6b } .dot.yellow{ background:#ffd166 } .dot.green{ background:#5cc19a }
.mock-body{ padding:14px; }
.mock-timer{ font-weight:900; font-size:20px; margin-bottom:8px; display:flex; align-items:center; gap:8px; }
.mock-modes{ display:flex; gap:8px; margin-bottom:10px; }
.pill{ display:inline-flex; align-items:center; padding:6px 10px; border-radius:999px; background:rgba(255,255,255,.06); color:var(--ink-soft); font-weight:800; font-size:12px; }
.pill.on{ background:linear-gradient(90deg,var(--gold),var(--gold-2)); color:#111827; }
.mock-task{ display:flex; align-items:center; gap:8px; margin-bottom:10px; }
.mock-task .idx{ font-weight:900; color:#ffe38a; } .mock-task .name{ color:var(--ink); font-weight:700; }
.mock-list{ display:flex; flex-direction:column; gap:8px; }
.mock-list .li{ display:flex; gap:8px; align-items:center; padding:8px; background:rgba(255,255,255,.05); border:1px solid var(--line-2); border-radius:10px; }
.mock-list .li.on{ border-color:rgba(245,194,65,.35); background:linear-gradient(145deg, rgba(245,194,65,.160), rgba(245,194,65,.08)); }
.floating{ position:absolute; right:-10px; top:10%; background:rgba(8,12,20,.7); border:1px solid var(--line); border-radius:12px; padding:10px 12px; box-shadow: var(--shadow); transform: translateY(var(--parallax-y, 0px)); }
.floating.badge{ top:auto; bottom:12%; }

/* Background decorations */
.bg.deco{ position:absolute; pointer-events:none; filter: blur(60px); opacity:.35; z-index:-1; contain: paint; }
.bg.deco.d1{ width:300px; height:300px; background: radial-gradient(closest-side, rgba(245,194,65,.45), transparent); left:-60px; top:-40px; }
.bg.deco.d2{ width:380px; height:380px; background: radial-gradient(closest-side, rgba(161,104,255,.35), transparent); right:-80px; bottom:-40px; }

/* Sections */
.lp-section{ padding:46px 0; min-height: calc(100vh - var(--hdr-h)); min-height: calc(100svh - var(--hdr-h)); scroll-snap-align: start; scroll-snap-stop: always; display:flex; align-items:center; overflow-x: clip; }
.lp-section.alt{ background: rgba(255,255,255,.03); border-top:1px solid var(--line-2); border-bottom:1px solid var(--line-2); }
.sec-head h2{ margin:0 0 8px; font-size:26px; display:flex; align-items:center; gap:10px; }
.sec-head h2 i{ color:var(--gold); }
.lead{ color:var(--ink-soft); margin:0 0 16px; }
.grid-3{ display:grid; grid-template-columns: repeat(3, 1fr); gap:16px; }
.feat-card{ background:var(--card); border:1px solid var(--line); border-radius:var(--radius); padding:16px; transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease; }
.feat-card .icon{ width:40px; height:40px; display:inline-flex; align-items:center; justify-content:center; border-radius:12px; background:rgba(255,255,255,.08); color:var(--gold); margin-bottom:8px; transition: transform .2s var(--ease), color .2s var(--ease), background .2s var(--ease); }
.feat-card:hover{ transform: translateY(-4px); box-shadow: var(--shadow); border-color:rgba(245,194,65,.35); background: linear-gradient(145deg, rgba(245,194,65,.10), rgba(255,255,255,.06)); }
.feat-card:hover .icon{ transform: translateY(-2px) scale(1.06); color:#111827; background: linear-gradient(90deg,var(--gold),var(--gold-2)); }

/* Steps */
.steps{ display:grid; grid-template-columns: repeat(3,1fr); gap:16px; position:relative; }
/* Linha contínua removida para segmentos por cartão */
.steps::before{ display:none; }
.step{ position:relative; background:#121a2a; border:1px solid var(--line); border-radius:var(--radius); padding:16px; }
.step::after{ content:""; position:absolute; left: calc(16px + 26px + 10px); right: 16px; top: 26px; height: 2px; border-radius:2px; background: linear-gradient(90deg, var(--gold), rgba(245,194,65,.45), rgba(245,194,65,0)); transform-origin: left center; transform: scaleX(0); box-shadow: 0 0 10px -2px rgba(245,194,65,.55); }
/* anima a linha quando o cartão entra em cena */
.reveal-enabled .step.reveal-up.is-visible::after{ transition: transform .6s var(--ease) .05s; transform: scaleX(1); }
.step{ transition: transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease); }
.step:hover{ transform: translateY(-3px); border-color: rgba(245,194,65,.35); box-shadow: 0 10px 22px -10px rgba(245,194,65,.45); }
.num{ position:relative; display:inline-flex; align-items:center; justify-content:center; width:26px; height:26px; border-radius:999px; background:linear-gradient(90deg,var(--gold),var(--gold-2)); color:#111827; font-weight:900; margin-bottom:8px; }
/* efeito sutil na bolinha ao revelar */
.step.reveal-up.is-visible .num::after{ content:""; position:absolute; inset:-4px; border-radius:50%; border:2px solid var(--gold-2); opacity:0; animation: pulseRing 1s ease-out .1s 1 forwards; }
@keyframes pulseRing{ 0%{ opacity:.6; transform: scale(.8); } 70%{ opacity:.18; transform: scale(1.25); } 100%{ opacity:0; transform: scale(1.35); } }

/* Premium */
.two-col{ display:grid; grid-template-columns: 1.1fr .9fr; gap:20px; align-items:start; }
.premium-copy .bullet{ margin:0; padding-left:18px; color:var(--ink); }
.premium-copy .bullet li{ margin:6px 0; }
.cta-row{ display:flex; gap:10px; margin-top:10px; }
.pricing{ display:grid; grid-template-columns: 1fr 1fr; gap:12px; }
.price-card{ background:#121a2a; border:1px solid var(--line); border-radius:var(--radius); padding:16px; position:relative; }
.price-card{ transition: transform .22s var(--ease), border-color .22s var(--ease), box-shadow .22s var(--ease); }
.price-card:hover{ transform: translateY(-4px); border-color: rgba(245,194,65,.35); box-shadow: 0 18px 36px -16px rgba(245,194,65,.35); }
.price-card.best{ background: linear-gradient(145deg, rgba(245,194,65,.15), rgba(245,194,65,.06)); border-color: rgba(245,194,65,.35); }
.price-card .badge{ position:absolute; top:10px; right:10px; background:rgba(255,255,255,.10); border:1px solid var(--line); padding:4px 8px; border-radius:999px; font-size:12px; font-weight:800; color:#ffe38a; }
.price{ font-weight:900; font-size:28px; margin:8px 0; }
.price small{ font-size:.65em; opacity:.9; margin-right:3px; }
.price span{ font-size:.45em; opacity:.8; margin-left:6px; }
.price-card ul{ list-style:none; padding:0; margin:8px 0 12px; color:var(--ink-soft); }
.price-card li{ margin:6px 0; }

/* Depoimentos - Carousel */
.testi{ width:min(1000px, 92vw); margin: 0 auto; }
.testi-viewport{ position:relative; min-height: 260px; }
.testi-slide{ position:absolute; inset:0; opacity:0; transform: translateX(20px) scale(.98); transition: opacity .4s ease, transform .4s ease; display:flex; align-items:center; justify-content:center; }
.testi-slide.active{ opacity:1; transform: translateX(0) scale(1); }
/* Slider directions */
.testi-slide.pos-right{ transform: translateX(40px) scale(.98); opacity:.01; }
.testi-slide.pos-left{ transform: translateX(-40px) scale(.98); opacity:.01; }
.testi-slide.leave-left{ transform: translateX(-40px) scale(.98); opacity:0; }
.testi-slide.leave-right{ transform: translateX(40px) scale(.98); opacity:0; }
.testi-card{ width:100%; background: rgba(255,255,255,.06); border:1px solid var(--line); border-radius:20px; padding:24px; box-shadow: var(--shadow); backdrop-filter: blur(8px); }
.testi-card{ transition: transform .2s var(--ease), border-color .2s var(--ease), box-shadow .2s var(--ease), background .2s var(--ease); }
.testi-card:hover{ transform: translateY(-2px); border-color: rgba(245,194,65,.35); background: linear-gradient(145deg, rgba(255,255,255,.08), rgba(245,194,65,.08)); }
.testi-quote-mark{ font-size:22px; color:var(--gold); opacity:1; margin-bottom:8px; }
.testi-text{ margin:0; color:#e5e7eb; font-size:18px; line-height:1.6; font-weight:700; letter-spacing:.2px; }
.testi-author{ margin-top:14px; }
.testi-author .name{ font-weight:800; }
.testi-author .role{ color:var(--ink-soft); font-size:13px; }
.testi-progress{ height:4px; background: rgba(255,255,255,.08); border:1px solid var(--line-2); border-radius:999px; margin-top:16px; overflow:hidden; }
.testi-progress .bar{ height:100%; width:0%; background: linear-gradient(90deg, var(--gold), var(--gold-2)); }
.testi-nav{ display:flex; align-items:center; justify-content:center; gap:12px; margin-top:12px; }
.nav-btn{ width:38px; height:38px; border-radius:999px; border:1px solid var(--line); background: rgba(255,255,255,.06); color:#e5e7eb; display:inline-flex; align-items:center; justify-content:center; }
.nav-btn:hover{ background: rgba(255,255,255,.12); }
.dots{ display:flex; gap:10px; align-items:center; }
.dot{ width:10px; height:10px; border-radius:999px; border:1px solid var(--line); background: rgba(255,255,255,.06); padding:0; }
.dot.active{ background: linear-gradient(180deg, #ffe27a, #ffd24a); border-color: rgba(245,194,65,.45); }

.testi-cta{
  margin-top: 14px;
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 8px;
}
.testi-cta .btn{ box-shadow: 0 10px 26px -14px rgba(245,194,65,.65); }
.testi-cta-note{ margin:0; font-size: 12px; color: rgba(255,255,255,.72); text-align:center; }

.testi-empty{
  width:100%;
  background: rgba(255,255,255,.04);
  border:1px dashed rgba(255,255,255,.16);
  border-radius: 20px;
  padding: 22px;
  color: rgba(255,255,255,.86);
  text-align:center;
}

.testi-skel{ height: 220px; width:100%; border-radius:20px; border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(90deg, rgba(255,255,255,.05), rgba(255,255,255,.10), rgba(255,255,255,.05));
  background-size: 200% 100%; animation: lpSkel 1.2s ease-in-out infinite;
}

/* Skeleton loading */
.skeleton{ position: relative; background: rgba(255,255,255,.08); border-radius: 10px; overflow: hidden; min-height: 32px; }
.skeleton::after{ content:""; position:absolute; inset:0; transform: translateX(-100%); background: linear-gradient(90deg, transparent, rgba(255,255,255,.18), transparent); animation: shimmer 1.2s infinite; }
@keyframes shimmer{ 100%{ transform: translateX(100%);} }
.pricing.loading .price-card a{ pointer-events: none; opacity:.6; }

/* Modal (Landing) */
.lp-modal-backdrop{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.55);
  backdrop-filter: blur(6px);
  z-index: 120;
}
.lp-modal-backdrop[hidden]{ display:none !important; }
.lp-modal{
  position:fixed;
  inset:0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 16px;
  z-index: 130;
}
.lp-modal[hidden]{ display:none !important; }
.lp-modal-card{
  width: min(560px, 92vw);
  background: rgba(12,16,26,.92);
  border:1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  box-shadow: 0 18px 52px rgba(0,0,0,.55);
  overflow:hidden;
}
.lp-modal-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 10px;
  padding: 14px 16px;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(245,194,65,.12), rgba(255,255,255,.04));
}
.lp-modal-head h3{ margin:0; font-size: 16px; display:flex; align-items:center; gap: 8px; }
.lp-modal-head i{ color: var(--gold); }
.lp-modal-close{
  width: 36px;
  height: 36px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.9);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  cursor:pointer;
}
.lp-modal-close:hover{ background: rgba(255,255,255,.12); }
.lp-modal-sub{ margin: 10px 16px 0; color: rgba(255,255,255,.75); font-size: 13px; }
.lp-modal-form{ padding: 14px 16px 16px; display:flex; flex-direction:column; gap: 12px; }
.lp-modal-actions{ display:flex; gap: 10px; justify-content:flex-end; flex-wrap:wrap; margin-top: 2px; }
.lp-modal-note{ margin: 2px 0 0; font-size: 12px; color: rgba(255,255,255,.68); }

/* Ajustes finos do formulário dentro do modal */
.lp-modal .form-label small{ font-weight: 700; opacity: .75; }
.lp-modal textarea.form-input{ min-height: 110px; resize: vertical; line-height: 1.5; }

body.lp-modal-open{ overflow:hidden; }

/* FAQ */
.faq-grid{ display:grid; grid-template-columns: repeat(2,1fr); gap:12px; }
.faq-item{ background:#121a2a; border:1px solid var(--line); border-radius:var(--radius); overflow:hidden; }
.faq-item summary{ list-style:none; cursor:pointer; display:flex; align-items:center; justify-content:space-between; gap:12px; padding:12px 14px; font-weight:800; color:var(--ink); transition: background .18s var(--ease), border-color .18s var(--ease); }
.faq-item:hover{ border-color: rgba(245,194,65,.25); }
.faq-item summary::-webkit-details-marker{ display:none; }
.faq-item .caret{ transition: transform .2s ease; color:#9fb0c6; }
.faq-item[open] .caret{ transform: rotate(180deg); }
.faq-content{ padding: 0 14px 12px; color: var(--ink-soft); max-height: 0; overflow: hidden; opacity: 0; transition: max-height .28s ease, opacity .28s ease; }
.faq-item[open] .faq-content{ max-height: 260px; opacity: 1; }
.final-cta{ text-align:center; margin-top:16px; }
.final-cta h3{ margin:0 0 10px; font-size:22px; }

/* Footer */
.lp-footer{ border-top:1px solid var(--line-2); background: rgba(255,255,255,.03); }
.lp-footer .container{ padding:16px 6px; }
.foot-grid{ display:grid; grid-template-columns: 1fr auto 1fr; align-items:center; gap:10px; }
.foot-right{ display:flex; align-items:center; justify-content:flex-end; gap:12px; }
.brand{ display:flex; align-items:center; gap:10px; }
.brand-icon{ height:26px; width:auto; display:block; }
.brand-copy{ color:var(--ink-soft); }
.foot-nav{ display:flex; gap:12px; }
.foot-nav a{ color:var(--ink-soft); text-decoration:none; font-weight:700; }
.foot-nav a:hover{ color:var(--ink); }
.foot-center{ text-align:center; color:rgba(255,255,255,.85); font-size:13px; font-weight:800; white-space:nowrap; }

.foot-social{ display:flex; align-items:center; gap:10px; }

/* Ícones sociais sem “bolinha” (os PNGs já estão tratados) */
.foot-social-link{ display:inline-flex; align-items:center; justify-content:center; overflow:hidden; line-height:0; border-radius:0; color:#fff; text-decoration:none; border:none; background: transparent; padding:0; transition: transform .15s ease, filter .15s ease; }
.foot-social-link:hover{ transform: translateY(-1px); filter: brightness(1.08); }

.foot-social-icon{ height:26px; width:auto; max-width:100%; max-height:100%; display:block; object-fit:contain; }

@media (max-width: 740px){
  .brand-icon{ height:22px; }
  .foot-grid{ grid-template-columns: auto 1fr auto; }
  .foot-center{ white-space:normal; font-size:12px; line-height:1.2; }
  .foot-social-icon{ height:22px; width:auto; }
}

/* Chips hover */
.chip{ transition: background .18s var(--ease), border-color .18s var(--ease), color .18s var(--ease); }
.chip:hover{ background: linear-gradient(90deg, rgba(245,194,65,.12), rgba(255,255,255,.06)); color:#fff; border-color: rgba(245,194,65,.35); }

/* Reveal-on-scroll */
.reveal-up{ transition: opacity .6s ease, transform .6s ease; transition-delay: var(--reveal-delay, 0s); }
.reveal-enabled .reveal-up{ opacity: 0; transform: translateY(16px); }
.reveal-enabled .reveal-up.is-visible{ opacity: 1; transform: none; }

/* Hover Tilt */
.tilt{ transform-style: preserve-3d; perspective: 800px; will-change: transform; transition: transform .2s ease; }
.tilt:hover{ transform: translateY(calc(var(--parallax-y,0px) - 4px)) rotateX(var(--tilt-x,0deg)) rotateY(var(--tilt-y,0deg)); box-shadow: 0 16px 36px -18px rgba(245,194,65,.55); border-color: rgba(245,194,65,.35); }

/* Responsive */
@media (max-width: 1000px){
  .hero-grid{ grid-template-columns: 1fr; }
  .floating{ display:none; }
  .two-col{ grid-template-columns: 1fr; }
}

/* Full-screen sections snapping */
/* main uses the document scroll; snapping declared on html */
/* main{ scroll-snap-type: y mandatory; } */
@media (max-width: 740px){
  :root{ --hdr-h: 60px; }
  .logo-img{ height:34px; }
  .grid-3{ grid-template-columns: 1fr; }
  .steps{ grid-template-columns: 1fr; }
  .pricing{ grid-template-columns: 1fr; }
  .faq-grid{ grid-template-columns: 1fr; }
  /* header layout */
  .lp-nav, .lp-cta{ display:none; }
  .nav-toggle{ display:inline-flex; }
  /* FABs mais visíveis no mobile */
  .fab-next, .fab-prev{ width:52px; height:52px; border-color: rgba(245,194,65,.42); background: linear-gradient(90deg, rgba(245,194,65,.38), rgba(255,213,86,.38)); box-shadow: 0 12px 28px -12px rgba(245,194,65,.45); }
}

/* Floating next-section button */
.fab-next{ position:fixed; right:22px; bottom:calc(22px + env(safe-area-inset-bottom, 0px)); width:48px; height:48px; border-radius:999px; border:1px solid rgba(245,194,65,.35); background: linear-gradient(90deg, rgba(245,194,65,.28), rgba(255,213,86,.28)); color:#111827; font-size:18px; display:inline-flex; align-items:center; justify-content:center; box-shadow: 0 10px 24px -12px rgba(245,194,65,.35); z-index:60; cursor:pointer; backdrop-filter: blur(2px); transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease; }
.fab-next:hover{ transform: translateY(-2px); filter:brightness(1.02); box-shadow: 0 14px 28px -14px rgba(245,194,65,.40); background: linear-gradient(90deg, rgba(245,194,65,.34), rgba(255,213,86,.34)); }
.fab-next:active{ transform: translateY(0); }
.fab-next[hidden]{ display:none !important; }

/* Prev FAB (discreta e alinhada) */
.fab-prev{ position:fixed; right:22px; bottom:calc(78px + env(safe-area-inset-bottom, 0px)); width:48px; height:48px; border-radius:999px; border:1px solid rgba(245,194,65,.35); background: linear-gradient(90deg, rgba(245,194,65,.28), rgba(255,213,86,.28)); color:#111827; font-size:18px; display:inline-flex; align-items:center; justify-content:center; box-shadow: 0 10px 24px -12px rgba(245,194,65,.35); z-index:60; cursor:pointer; backdrop-filter: blur(2px); transition: transform .18s ease, box-shadow .18s ease, filter .18s ease, background .18s ease; }
.fab-prev:hover{ transform: translateY(-2px); filter:brightness(1.02); box-shadow: 0 14px 28px -14px rgba(245,194,65,.40); background: linear-gradient(90deg, rgba(245,194,65,.34), rgba(255,213,86,.34)); }
.fab-prev:active{ transform: translateY(0); }
.fab-prev[hidden]{ display:none !important; }

/* Drawer (mobile menu) */
.lp-backdrop{ position:fixed; inset:0; background:rgba(0,0,0,.45); backdrop-filter: blur(2px); z-index:65; opacity:0; transition: opacity .18s ease; }
.lp-drawer{ position:fixed; top:var(--hdr-h); left:0; right:0; height:calc(100vh - var(--hdr-h)); background: rgba(8,12,20,.78); border-top:1px solid var(--line-2); z-index:70; transform: translateY(-8px); opacity:0; transition: transform .22s ease, opacity .22s ease; display:flex; flex-direction:column; gap:12px; padding:12px 12px 18px; }
.drawer-nav{ display:flex; flex-direction:column; gap:8px; }
.drawer-nav .nav-link{ display:block; padding:12px 14px; font-size:16px; font-weight:800; color:var(--ink); background: rgba(255,255,255,.06); border:1px solid var(--line); border-radius:12px; }
.drawer-nav .nav-link.active{ border-color: rgba(245,194,65,.45); background: linear-gradient(145deg, rgba(245,194,65,.15), rgba(255,255,255,.06)); }
.drawer-cta{ display:flex; flex-direction:column; gap:10px; margin-top:auto; }

/* Open state */
body.menu-open #lpBackdrop{ opacity:1; }
body.menu-open #lpMenu{ transform: none; opacity:1; }
body.menu-open{ overflow:hidden; }
body.menu-open .fab-next, body.menu-open .fab-prev{ display:none !important; }

/* Reduced motion */
@media (prefers-reduced-motion: reduce){
  *{ transition: none !important; animation: none !important; }
}
