/* ───────────────────────────────────────────────────────────────
   Bichudo · site (bichudo.app)
   Sistema visual derivado da identidade: roxo + menta, off-white,
   grafite. Quicksand (display) + Nunito Sans (texto). Tom acolhedor.
─────────────────────────────────────────────────────────────── */
:root{
  --roxo:#6D4AFF; --roxo-d:#5636D9; --roxo-2:#8B6BFF;
  --menta:#A8E6B0; --verde:#63B97A;
  --paper:#FAF9F7; --grafite:#2B2B33; --grafite-2:#3A3743;
  --lilas:#F2EEFB; --lilas-2:#EBE4F8;
  --ink:#2B2B33;
  --sec:rgba(43,43,51,.62);
  --ter:rgba(43,43,51,.42);
  --line:rgba(43,43,51,.10);
  --card:#fff;
  --accent:#C9BBFF;             /* cor de acento dos detalhes (Roxo claro) */
  --shadow-sm:0 1px 2px rgba(43,43,51,.04), 0 4px 14px rgba(43,43,51,.05);
  --shadow-md:0 2px 6px rgba(43,43,51,.05), 0 18px 44px rgba(43,43,51,.10);
  --shadow-lg:0 30px 70px rgba(43,43,51,.16), 0 8px 24px rgba(43,43,51,.08);
  --display:'Quicksand', system-ui, sans-serif;
  --text:'Nunito Sans', system-ui, sans-serif;
  --mono:'Courier New', ui-monospace, monospace;
  --maxw:1180px;
  --r:24px;
}
*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0; font-family:var(--text); color:var(--ink);
  background:var(--paper); line-height:1.6;
  -webkit-font-smoothing:antialiased; text-rendering:optimizeLegibility;
}
img{max-width:100%; display:block;}
a{color:inherit; text-decoration:none;}
/* remove o realce de toque retangular (tamanho/forma errados) no mobile */
a, button{-webkit-tap-highlight-color:transparent;}
h1,h2,h3,h4{font-family:var(--display); font-weight:700; letter-spacing:-.02em; line-height:1.06; margin:0;}
p{margin:0;}
.bi .acc{fill:var(--accent); stroke:none;}

.wrap{max-width:var(--maxw); margin:0 auto; padding:0 28px;}
.eyebrow{font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:.16em;
  text-transform:uppercase; color:var(--roxo);}
.eyebrow.on-dark{color:var(--menta);}
.lead{font-size:clamp(17px,1.5vw,19px); color:var(--sec); max-width:46ch;}

/* ── botões ───────────────────────────────────────────── */
.btn{display:inline-flex; align-items:center; gap:10px; font-family:var(--display);
  font-weight:700; font-size:16px; border:none; cursor:pointer; border-radius:999px;
  padding:14px 26px; transition:transform .16s ease, box-shadow .16s ease, background .16s;}
.btn:active{transform:translateY(1px);}
.btn-primary{background:var(--roxo); color:#fff; box-shadow:0 8px 22px rgba(109,74,255,.32);}
.btn-primary:hover{background:var(--roxo-d); box-shadow:0 12px 28px rgba(109,74,255,.40);}
.btn-ghost{background:rgba(109,74,255,.08); color:var(--roxo-d);}
.btn-ghost:hover{background:rgba(109,74,255,.14);}
.btn-light{background:#fff; color:var(--roxo-d); box-shadow:var(--shadow-sm);}
.btn-light:hover{box-shadow:var(--shadow-md);}

/* ── store badges ─────────────────────────────────────── */
.stores{display:flex; gap:14px; flex-wrap:wrap;}
.store{display:inline-flex; align-items:center; gap:12px; background:var(--grafite); color:#fff;
  border-radius:16px; padding:11px 20px 11px 18px; transition:transform .16s ease, box-shadow .16s;
  box-shadow:0 6px 18px rgba(43,43,51,.16); min-width:210px; box-sizing:border-box;}
.store:hover{transform:translateY(-2px); box-shadow:0 12px 26px rgba(43,43,51,.22);}
.store svg{width:26px; height:26px; flex-shrink:0;}
.store > span{display:flex; flex-direction:column; line-height:1.15;}
.store .st-cap{font-size:11px; letter-spacing:.04em; opacity:.78; line-height:1.1;}
.store .st-name{font-family:var(--display); font-weight:700; font-size:18px; line-height:1.15;}
.stores.on-dark .store{background:#fff; color:var(--grafite); box-shadow:0 6px 18px rgba(0,0,0,.18);}

/* ── nav ──────────────────────────────────────────────── */
.nav{position:sticky; top:0; z-index:50; transition:background .25s, box-shadow .25s, border-color .25s;
  border-bottom:1px solid transparent;}
.nav.scrolled{background:rgba(250,249,247,.82); backdrop-filter:blur(14px) saturate(160%);
  -webkit-backdrop-filter:blur(14px) saturate(160%); border-bottom-color:var(--line);}
.nav .wrap{display:flex; align-items:center; justify-content:space-between; height:74px;}
.brand{display:flex; align-items:center; gap:11px;}
.brand img{height:38px; width:auto;}
.brand .wm{font-family:var(--display); font-weight:700; font-size:24px; letter-spacing:-.02em; color:var(--grafite);}
.nav-cta{display:flex; align-items:center; gap:14px;}

/* ── hero ─────────────────────────────────────────────── */
.hero{position:relative; overflow:hidden; padding:64px 0 92px;
  background:
    radial-gradient(110% 80% at 78% 8%, rgba(168,230,176,.22), transparent 52%),
    radial-gradient(120% 90% at 18% 0%, rgba(109,74,255,.16), transparent 55%),
    var(--paper);}
.hero .inner{display:grid; grid-template-columns:minmax(0,1.05fr) minmax(0,1fr);
  gap:48px; align-items:center;}
.hero-copy h1{font-size:clamp(42px,5.6vw,68px); letter-spacing:-.03em;}
.hero-copy h1 em{font-style:normal; color:var(--roxo);}
.hero-copy .lead{margin:22px 0 30px; font-size:clamp(17px,1.6vw,20px); max-width:42ch;}
.hero-actions{display:flex; flex-direction:column; gap:18px;}
.hero-note{display:flex; align-items:center; gap:10px; font-size:14px; color:var(--ter);}
.hero-note .dot{width:7px; height:7px; border-radius:50%; background:var(--verde);}

/* palco de telefones */
.phones{position:relative; display:flex; justify-content:center; align-items:flex-end; min-height:560px;}
.phone{width:300px; filter:drop-shadow(0 36px 60px rgba(43,43,51,.20)); }
.phones .ph-main{position:relative; z-index:3;}
.phones .ph-side{position:absolute; width:240px; z-index:1; opacity:.96;}
.phones .ph-left{left:-2%; bottom:34px; transform:rotate(-7deg); z-index:2;}
.phones .ph-right{right:-2%; bottom:34px; transform:rotate(7deg); z-index:2;}
.phones .ph-extra{display:none;}

/* variação: centralizado / leque */
body.hero-centro .hero .inner{grid-template-columns:1fr; text-align:center; justify-items:center; gap:40px;}
body.hero-centro .hero-copy .lead{margin-left:auto; margin-right:auto;}
body.hero-centro .hero-actions{align-items:center;}
body.hero-centro .phones{min-height:600px; width:100%;}
body.hero-centro .phones .ph-side{display:block;}
body.hero-centro .phones .ph-left{left:14%; bottom:60px;}
body.hero-centro .phones .ph-right{right:14%; bottom:60px;}
@media(max-width:560px){
  body.hero-centro .phones .ph-left{left:-4%;}
  body.hero-centro .phones .ph-right{right:-4%;}
}

/* tira de confiança */
.trust{padding:30px 0; border-top:1px solid var(--line); border-bottom:1px solid var(--line);
  background:var(--paper);}
.trust .inner{display:flex; align-items:center; justify-content:space-between; gap:24px; flex-wrap:wrap;}
.trust .stat{display:flex; flex-direction:column; gap:2px;}
.trust .stat b{font-family:var(--display); font-weight:700; font-size:30px; color:var(--ink); letter-spacing:-.02em;}
.trust .stat span{font-size:13.5px; color:var(--sec);}
.trust .sep{width:1px; height:42px; background:var(--line);}

/* ── seções genéricas ─────────────────────────────────── */
section{scroll-margin-top:84px;}
.band{padding:96px 0;}
.band.lilac{background:linear-gradient(180deg,#F6F2FD,var(--lilas));}
.band.paper{background:var(--paper);}
.sec-head{max-width:620px; margin-bottom:48px;}
.sec-head.center{margin-left:auto; margin-right:auto; text-align:center;}
.sec-head h2{font-size:clamp(30px,3.8vw,46px); margin:14px 0 0;}
.sec-head p{margin-top:16px; font-size:18px; color:var(--sec);}

/* ── features: zigzag (alternado) ─────────────────────── */
.feat-row{display:grid; grid-template-columns:1fr 1fr; gap:56px; align-items:center; padding:40px 0;}
.feat-row + .feat-row{border-top:1px solid var(--line);}
.feat-row:nth-child(even) .feat-media{order:2;}
.feat-media{display:flex;}
/* telefone alinhado à borda externa → margens externas simétricas dos dois lados */
.feat-row:nth-child(odd) .feat-media{justify-content:flex-start;}
.feat-row:nth-child(even) .feat-media{justify-content:flex-end;}
.feat-media .phone{width:286px; filter:drop-shadow(0 30px 56px rgba(43,43,51,.18));}
/* família: telefone na coluna direita → encosta à direita (margens simétricas) */
.split .feat-media{justify-content:flex-end;}
.feat-copy .pill{display:inline-flex; align-items:center; gap:9px; background:rgba(109,74,255,.08);
  color:var(--roxo-d); font-family:var(--display); font-weight:700; font-size:13px;
  padding:7px 14px; border-radius:999px; margin-bottom:18px;}
.feat-copy .pill .ic{display:inline-flex; color:var(--roxo-d);}
.feat-copy h3{font-size:clamp(26px,2.6vw,34px);}
.feat-copy p{margin-top:14px; font-size:17.5px; color:var(--sec); max-width:46ch;}
.feat-list{list-style:none; padding:0; margin:22px 0 0; display:flex; flex-direction:column; gap:12px;}
.feat-list li{display:flex; align-items:flex-start; gap:12px; font-size:16px; color:var(--ink);}
.feat-list .tick{width:24px; height:24px; flex-shrink:0; border-radius:50%; background:var(--accent);
  display:flex; align-items:center; justify-content:center; margin-top:1px;}
.feat-list .tick svg{width:14px; height:14px; stroke:var(--grafite); stroke-width:2.6;}

/* ── features: grade (alternativa) ────────────────────── */
.feat-grid{display:none; grid-template-columns:repeat(3,1fr); gap:22px;}
.fcard{background:var(--card); border:1px solid var(--line); border-radius:var(--r);
  padding:30px 26px; box-shadow:var(--shadow-sm); transition:transform .18s, box-shadow .18s;}
.fcard:hover{transform:translateY(-4px); box-shadow:var(--shadow-md);}
.fcard .fic{width:54px; height:54px; border-radius:16px; background:var(--lilas);
  display:flex; align-items:center; justify-content:center; color:var(--roxo-d); margin-bottom:18px;}
.fcard h3{font-size:21px;}
.fcard p{margin-top:9px; font-size:15.5px; color:var(--sec);}

body.feat-grade .feat-zig{display:none;}
body.feat-grade .feat-grid{display:grid;}

/* ── família / cuidado compartilhado ──────────────────── */
.split{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;}
.roles{display:flex; flex-direction:column; gap:14px; margin-top:8px;}
.role{display:flex; align-items:center; gap:16px; background:#fff; border:1px solid var(--line);
  border-radius:18px; padding:16px 18px; box-shadow:var(--shadow-sm);}
.role .av{width:44px; height:44px; border-radius:50%; flex-shrink:0; display:flex; align-items:center;
  justify-content:center; font-family:var(--display); font-weight:700; color:var(--grafite); font-size:16px;}
.role .meta b{font-family:var(--display); font-weight:700; font-size:16px;}
.role .meta span{display:block; font-size:13.5px; color:var(--sec);}
.role .tag{margin-left:auto; font-family:var(--display); font-weight:700; font-size:12px;
  padding:5px 12px; border-radius:999px; background:rgba(109,74,255,.10); color:var(--roxo-d);}

/* ── comunidade (dark) ────────────────────────────────── */
.band.dark{background:radial-gradient(120% 100% at 80% 0%, #3A3147, var(--grafite));
  color:#fff;}
.band.dark .sec-head h2{color:#fff;}
.band.dark .sec-head p{color:rgba(255,255,255,.72);}
.band.dark .lead{color:rgba(255,255,255,.74);}
.comm-grid{display:grid; grid-template-columns:1fr 1fr; gap:60px; align-items:center;}
.comm-points{list-style:none; padding:0; margin:26px 0 0; display:flex; flex-direction:column; gap:20px;}
.comm-points li{display:flex; gap:16px; align-items:flex-start;}
.comm-points .cic{width:48px; height:48px; border-radius:14px; flex-shrink:0; color:#fff;
  background:rgba(168,230,176,.16); display:flex; align-items:center; justify-content:center;}
.comm-points b{font-family:var(--display); font-weight:700; font-size:18px; display:block;}
.comm-points span{color:rgba(255,255,255,.72); font-size:15.5px;}

/* ── preços ───────────────────────────────────────────── */
.bill-toggle{display:inline-flex; align-items:center; gap:0; background:var(--lilas-2);
  border-radius:999px; padding:5px; margin:0 auto 40px; box-shadow:inset 0 0 0 1px var(--line);}
.bill-toggle button{font-family:var(--display); font-weight:700; font-size:14.5px; border:none;
  background:none; cursor:pointer; padding:10px 22px; border-radius:999px; color:var(--sec);
  transition:all .18s;}
.bill-toggle button.active{background:#fff; color:var(--roxo-d); box-shadow:var(--shadow-sm);}
.bill-toggle .save{margin-left:6px; font-size:11px; color:var(--verde);}
.plans{display:grid; grid-template-columns:repeat(3,1fr); gap:22px; align-items:stretch;}
.plan{position:relative; background:var(--card); border:1px solid var(--line); border-radius:26px;
  padding:32px 28px; box-shadow:var(--shadow-sm); display:flex; flex-direction:column;}
.plan.featured{border-color:transparent; box-shadow:var(--shadow-lg); transform:translateY(-8px);
  outline:2px solid var(--roxo);}
.plan .badge{position:absolute; top:-13px; left:50%; transform:translateX(-50%);
  background:var(--roxo); color:#fff; font-family:var(--display); font-weight:700; font-size:12px;
  letter-spacing:.04em; padding:6px 16px; border-radius:999px; white-space:nowrap;}
.plan .pic{width:50px; height:50px; border-radius:15px; background:var(--lilas);
  display:flex; align-items:center; justify-content:center; color:var(--roxo-d); margin-bottom:16px;}
.plan h3{font-size:24px;}
.plan .tagline{font-size:14.5px; color:var(--sec); margin-top:4px;}
.plan .price{margin:20px 0 4px; display:flex; align-items:baseline; gap:6px;}
.plan .price .amt{font-family:var(--display); font-weight:700; font-size:38px; color:var(--ink); letter-spacing:-.02em;}
.plan .price .per{font-size:14px; color:var(--sec);}
.plan .econ{font-size:13px; color:var(--verde); min-height:18px;}
.plan ul{list-style:none; padding:0; margin:22px 0 26px; display:flex; flex-direction:column; gap:11px;}
.plan ul li{display:flex; gap:10px; align-items:flex-start; font-size:15px; color:var(--ink);}
.plan ul .tick{width:20px; height:20px; flex-shrink:0; border-radius:50%; background:var(--accent);
  display:flex; align-items:center; justify-content:center; margin-top:1px;}
.plan ul .tick svg{width:12px; height:12px; stroke:var(--grafite); stroke-width:2.8;}
.plan .incl{font-size:13px; color:var(--ter); margin:-12px 0 14px;}
.plan .btn{width:100%; justify-content:center; margin-top:auto;}

/* ── depoimentos ──────────────────────────────────────── */
.quotes{display:grid; grid-template-columns:repeat(3,1fr); gap:22px;}
.quote{background:#fff; border:1px solid var(--line); border-radius:var(--r); padding:28px 26px;
  box-shadow:var(--shadow-sm); display:flex; flex-direction:column; gap:18px;}
.quote .stars{display:flex; gap:3px; color:var(--roxo);}
.quote .stars svg{width:17px; height:17px;}
.quote p{font-size:16.5px; color:var(--ink); line-height:1.6;}
.quote .by{display:flex; align-items:center; gap:12px; margin-top:auto;}
.quote .by .av{width:42px; height:42px; border-radius:50%; flex-shrink:0; display:flex;
  align-items:center; justify-content:center; font-family:var(--display); font-weight:700;
  color:var(--grafite); font-size:15px;}
.quote .by b{font-family:var(--display); font-weight:700; font-size:15px; display:block;}
.quote .by span{font-size:13px; color:var(--sec);}

/* ── CTA final ────────────────────────────────────────── */
.cta{background:radial-gradient(120% 130% at 50% -20%, var(--roxo-2), var(--roxo) 60%, var(--roxo-d));
  color:#fff; text-align:center; padding:90px 0; position:relative; overflow:hidden;}
.cta h2{font-size:clamp(32px,4.2vw,52px); color:#fff;}
.cta p{font-size:19px; color:rgba(255,255,255,.86); margin:18px auto 32px; max-width:48ch;}
.cta .stores{justify-content:center;}
.cta .mark{height:64px; margin:0 auto 22px;}

/* ── rodapé ───────────────────────────────────────────── */
footer{background:var(--grafite); color:rgba(255,255,255,.7); padding:64px 0 36px;}
.foot-top{display:grid; grid-template-columns:1.4fr 1fr 1fr 1fr; gap:40px; padding-bottom:44px;
  border-bottom:1px solid rgba(255,255,255,.12);}
.foot-brand .wm{display:flex; align-items:center; gap:11px; margin-bottom:16px;}
.foot-brand .wm img{height:36px;}
.foot-brand .wm b{font-family:var(--display); font-weight:700; font-size:22px; color:#fff;}
.foot-brand p{font-size:15px; max-width:34ch;}
.foot-col h4{font-family:var(--display); font-weight:700; font-size:13px; letter-spacing:.08em;
  text-transform:uppercase; color:rgba(255,255,255,.55); margin-bottom:16px;}
.foot-col a{display:block; font-size:15px; color:rgba(255,255,255,.78); padding:6px 0; transition:color .15s;}
.foot-col a:hover{color:#fff;}
.foot-bottom{display:flex; align-items:center; justify-content:space-between; gap:18px;
  padding-top:26px; flex-wrap:wrap;}
.foot-bottom span{font-size:13.5px; color:rgba(255,255,255,.5);}
.foot-bottom .dom{font-family:var(--mono); color:var(--menta);}
.foot-social{display:flex; gap:12px;}
.foot-social a{width:38px; height:38px; border-radius:50%; background:rgba(255,255,255,.10);
  display:flex; align-items:center; justify-content:center; transition:background .15s;}
.foot-social a:hover{background:rgba(255,255,255,.20);}
.foot-social svg{width:18px; height:18px; fill:#fff;}

/* entrada: desativada (ambiente de preview congela animações) — conteúdo estático e sempre visível */

/* ── responsivo ───────────────────────────────────────── */
@media(max-width:980px){
  /* CTA "Baixar" compacto na barra em telas estreitas */
  .nav-cta .btn{padding:10px 18px; font-size:15px; white-space:nowrap;}
  .hero .inner{grid-template-columns:1fr; text-align:center; gap:36px; justify-items:center;}
  .hero-copy .lead{margin-left:auto; margin-right:auto;}
  .hero-actions{align-items:center;}
  .phones{min-height:520px;}
  .feat-row{grid-template-columns:1fr; gap:30px; text-align:center;}
  .feat-row:nth-child(even) .feat-media{order:0;}
  .feat-copy .pill{margin-left:auto; margin-right:auto;}
  .feat-copy p, .feat-list{margin-left:auto; margin-right:auto;}
  .feat-list li{text-align:left;}
  .feat-media{order:-1; justify-content:center;}
  .feat-grid{grid-template-columns:1fr 1fr;}
  .split, .comm-grid{grid-template-columns:1fr; gap:40px;}
  .comm-media{order:-1;}
  .plans{grid-template-columns:1fr; max-width:440px; margin:0 auto;}
  .plan.featured{transform:none;}
  .quotes{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr 1fr; gap:32px;}
}
@media(max-width:560px){
  .wrap{padding:0 20px;}
  .band{padding:68px 0;}
  .trust .sep{display:none;}
  .trust .inner{justify-content:center; gap:28px 40px;}
  .feat-grid{grid-template-columns:1fr;}
  .foot-top{grid-template-columns:1fr;}
}

/* ── páginas legais (privacidade, termos) ─────────────── */
.legal-hero{padding:72px 0 40px;
  background:
    radial-gradient(110% 80% at 80% 0%, rgba(168,230,176,.18), transparent 52%),
    radial-gradient(120% 90% at 16% 0%, rgba(109,74,255,.14), transparent 55%),
    var(--paper);
  border-bottom:1px solid var(--line);}
.legal-hero .wrap{max-width:820px;}
.legal-hero h1{font-size:clamp(34px,5vw,52px); letter-spacing:-.03em;}
.legal-hero .updated{margin-top:16px; font-size:14.5px; color:var(--ter);
  display:flex; align-items:center; gap:8px; flex-wrap:wrap;}
.legal-hero .updated .dot{width:7px; height:7px; border-radius:50%; background:var(--verde);}
.legal{padding:56px 0 80px; background:var(--paper);}
.legal .wrap{max-width:820px;}
.legal-doc{color:var(--ink);}
.legal-doc .intro{font-size:18px; color:var(--sec); margin-bottom:14px;}
.legal-doc h2{font-size:clamp(22px,2.6vw,28px); margin:44px 0 0; scroll-margin-top:90px;}
.legal-doc h2 .num{color:var(--roxo); margin-right:10px;}
.legal-doc h3{font-size:18px; margin:26px 0 0;}
.legal-doc p{margin-top:14px; font-size:16.5px; color:var(--grafite-2); line-height:1.72;}
.legal-doc ul{margin:14px 0 0; padding-left:0; list-style:none;
  display:flex; flex-direction:column; gap:11px;}
.legal-doc ul li{position:relative; padding-left:26px; font-size:16px;
  color:var(--grafite-2); line-height:1.65;}
.legal-doc ul li::before{content:""; position:absolute; left:4px; top:9px;
  width:8px; height:8px; border-radius:50%; background:var(--accent);}
.legal-doc a{color:var(--roxo-d); text-decoration:underline; text-underline-offset:2px;}
.legal-doc a:hover{color:var(--roxo);}
.legal-doc strong{font-weight:700; color:var(--ink);}
.legal-doc .toc{margin:36px 0 8px; padding:22px 24px; background:var(--lilas);
  border:1px solid var(--line); border-radius:var(--r);}
.legal-doc .toc h2{margin:0 0 14px; font-size:15px; letter-spacing:.06em;
  text-transform:uppercase; color:var(--roxo-d);}
.legal-doc .toc ol{margin:0; padding-left:20px; columns:2; column-gap:32px;
  font-size:15px; line-height:1.9;}
.legal-doc .toc a{color:var(--grafite-2); text-decoration:none;}
.legal-doc .toc a:hover{color:var(--roxo); text-decoration:underline;}
.legal-doc .note{margin-top:18px; padding:16px 18px; border-radius:16px;
  background:rgba(109,74,255,.06); border:1px solid var(--line); font-size:15px; color:var(--sec);}
.legal-doc .contact-card{margin-top:18px; padding:20px 22px; border-radius:var(--r);
  background:#fff; border:1px solid var(--line); box-shadow:var(--shadow-sm); font-size:16px;}
@media(max-width:640px){ .legal-doc .toc ol{columns:1;} }
