/* ============================================================
   A1 Conta — sistema das páginas de NICHO (modelo v2)
   Conceito: "ficha viva" + craft de motion. Compartilhado por
   todas as páginas de nicho. Cada página define só o conteúdo
   e as imagens (hero/CTA) inline na própria <section> via background-image.
   ============================================================ */
:root{
  --ease-out:cubic-bezier(.23,1,.32,1);   /* forte, responsivo (entrada) */
  --ease-io:cubic-bezier(.77,0,.175,1);    /* movimento na tela */
  --r-card:10px;
}
html{color-scheme:dark}

/* ---- MOTION: reveal + stagger (uma curva, um ritmo) ---- */
.r{opacity:0;transform:translateY(12px);transition:opacity .6s var(--ease-out),transform .6s var(--ease-out);transition-delay:calc(var(--i,0)*55ms)}
.r.in{opacity:1;transform:none}

/* ---- press feedback em TODO elemento pressionável ---- */
.btn{transition:transform .14s var(--ease-out),box-shadow .25s var(--ease-out),border-color .2s var(--ease-out),color .2s var(--ease-out)}
.btn:active{transform:scale(.97)}
.wa-float{transition:transform .16s var(--ease-out),box-shadow .25s var(--ease-out)}
.wa-float:active{transform:scale(.94)}

/* ---- HERO ---- */
/* aqui fica só o gradiente navy padrão; cada página define background-image inline
   (gradiente + url da foto) na própria <section>, para a url() resolver relativo ao documento */
/* fundo padrão = só o gradiente navy; cada página acrescenta a foto inline (url no contexto do documento) */
.lp-hero{position:relative;overflow:hidden;padding:150px 0 92px;background-color:var(--black);background-image:linear-gradient(108deg,rgba(20,42,61,.97) 0%,rgba(22,47,68,.9) 40%,rgba(31,64,96,.7) 100%);background-size:cover;background-position:center}
.lp-hero::after{content:"";position:absolute;inset:0;pointer-events:none;background:radial-gradient(circle at 86% 14%,var(--gold-soft),transparent 46%),linear-gradient(180deg,transparent 70%,var(--black) 100%)}
.lp-hero-grid{position:relative;z-index:2;display:grid;grid-template-columns:1.05fr .95fr;gap:58px;align-items:center}
.lp-hero h1{font-size:clamp(2.2rem,4.7vw,3.55rem);font-weight:600;line-height:1.08;letter-spacing:-.025em;margin:14px 0 20px;text-wrap:balance}
.lp-hero h1 b{color:var(--gold-light);font-weight:700}
.lp-hero p{color:var(--grey);font-size:1.16rem;line-height:1.55;max-width:520px;margin-bottom:30px;text-wrap:pretty}
.lp-cta{display:flex;gap:14px;flex-wrap:wrap}
@media(max-width:900px){.lp-hero-grid{grid-template-columns:1fr;gap:44px}.lp-hero{padding:128px 0 72px}}

/* ---- THE STAR: ficha viva (reutilizável por nicho) ---- */
.contract{position:relative;background:linear-gradient(180deg,rgba(31,64,96,.55),rgba(25,53,77,.5));border:1px solid var(--line);border-radius:var(--radius);padding:32px 30px;backdrop-filter:blur(6px);box-shadow:0 34px 70px -28px rgba(0,0,0,.7)}
.contract::before{content:"";position:absolute;top:-2px;left:-2px;width:30px;height:30px;border-top:3px solid var(--gold);border-left:3px solid var(--gold)}
.contract::after{content:"";position:absolute;bottom:-2px;right:-2px;width:30px;height:30px;border-bottom:3px solid var(--gold);border-right:3px solid var(--gold)}
.contract-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:12px}
.contract-eyebrow{color:var(--gold);font-size:.7rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase}
.contract-live{display:inline-flex;align-items:center;gap:7px;color:var(--grey);font-size:.72rem;font-weight:600;white-space:nowrap}
.contract-live::before{content:"";width:7px;height:7px;border-radius:50%;background:var(--gold-light);box-shadow:0 0 0 0 rgba(220,193,136,.6);animation:pulse 2.4s var(--ease-io) infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(220,193,136,.55)}70%{box-shadow:0 0 0 7px rgba(220,193,136,0)}100%{box-shadow:0 0 0 0 rgba(220,193,136,0)}}
.row{display:flex;justify-content:space-between;align-items:baseline;gap:16px;padding:8px 0}
.row dt,.row .k{color:var(--grey);font-size:.92rem}
.row dd,.row .v{margin:0;color:var(--white);font-weight:600;font-size:.98rem;font-variant-numeric:tabular-nums}
.bar{position:relative;height:11px;border-radius:6px;background:rgba(197,167,103,.13);margin:16px 0 8px;overflow:hidden}
/* nível da barra controlado por --fill (default 60%) definido na página */
.bar-fill{position:absolute;inset:0;border-radius:6px;background:linear-gradient(90deg,var(--gold),var(--gold-light));clip-path:inset(0 calc(100% - var(--fill,60%)) 0 0);transition:clip-path .95s var(--ease-out)}
.bar-cap{display:flex;justify-content:space-between;color:var(--grey);font-size:.8rem}
.bar-cap em{color:var(--gold-light);font-style:normal;font-weight:700}
.contract hr{border:none;border-top:1px solid var(--line);margin:18px 0}
.margin-row{display:flex;justify-content:space-between;align-items:flex-end;gap:12px}
.margin-row .k{color:#fff;font-size:.96rem;font-weight:500}
.margin-val{display:flex;align-items:baseline;gap:8px}
.margin-val strong{color:var(--gold-light);font-size:2.1rem;font-weight:800;line-height:1;letter-spacing:-.03em;font-variant-numeric:tabular-nums}
.margin-chip{opacity:0;transform:translateY(4px);transition:opacity .4s var(--ease-out),transform .4s var(--ease-out);display:inline-flex;align-items:center;gap:4px;font-size:.74rem;font-weight:700;color:#bfe6c4;background:rgba(120,200,140,.14);border:1px solid rgba(120,200,140,.3);padding:3px 8px;border-radius:999px;white-space:nowrap}
.margin-chip.show{opacity:1;transform:none}

/* ---- SECTIONS / HEAD ---- */
.lp-sec{padding:92px 0}
.lp-band{background:linear-gradient(135deg,var(--black-2),var(--black-3));border-top:1px solid var(--line);border-bottom:1px solid var(--line)}
.lp-head{max-width:680px;margin:0 auto 50px;text-align:center}
.lp-head h2{font-size:clamp(1.7rem,3.3vw,2.4rem);font-weight:700;letter-spacing:-.02em;line-height:1.15;margin-top:12px;text-wrap:balance}
.lp-head p{color:var(--grey);margin-top:14px;font-size:1.04rem;text-wrap:pretty}

/* ---- ONE card language ---- */
.lp-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(264px,1fr));gap:18px}
.lp-grid.cols-3{grid-template-columns:repeat(3,1fr)}
@media(max-width:900px){.lp-grid.cols-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:560px){.lp-grid.cols-3{grid-template-columns:1fr}}
.card{position:relative;background:rgba(31,64,96,.32);border:1px solid var(--line);border-radius:var(--r-card);padding:26px 24px;transition:transform .25s var(--ease-out),border-color .25s var(--ease-out),background .25s var(--ease-out)}
.card .badge{width:42px;height:42px;border-radius:11px;display:flex;align-items:center;justify-content:center;background:var(--gold-soft);color:var(--gold-light);margin-bottom:16px}
.card .badge .icon{width:21px;height:21px}
.card .tag{display:inline-block;font-size:.68rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:var(--gold);margin-bottom:10px}
.card h3{font-size:1.08rem;font-weight:600;letter-spacing:-.01em;margin-bottom:7px}
.card p{color:var(--grey);font-size:.92rem;line-height:1.5;margin:0}
@media(hover:hover) and (pointer:fine){
  .card:hover{transform:translateY(-4px);border-color:rgba(197,167,103,.45);background:rgba(31,64,96,.5)}
}

/* ---- trust line ---- */
.trust{display:flex;flex-wrap:wrap;justify-content:center;gap:12px 34px;padding:22px 0}
.trust span{display:inline-flex;align-items:center;gap:9px;color:var(--grey);font-size:.92rem}
.trust span::before{content:"";width:6px;height:6px;border-radius:50%;background:var(--gold-light);flex-shrink:0}
.trust b{color:#fff;font-weight:600}

/* ---- steps (sequência real → numerada) ---- */
.steps{display:grid;grid-template-columns:repeat(3,1fr);gap:20px}
.step{position:relative;padding:30px 26px;background:rgba(31,64,96,.32);border:1px solid var(--line);border-radius:var(--r-card)}
.step .n{font-size:2.2rem;font-weight:800;color:var(--gold);letter-spacing:-.03em;line-height:1;font-variant-numeric:tabular-nums;display:block;margin-bottom:14px}
.step h3{font-size:1.08rem;font-weight:600;margin-bottom:7px}
.step p{color:var(--grey);font-size:.92rem;line-height:1.5;margin:0}
.step:not(:last-child)::after{content:"";position:absolute;top:46px;right:-12px;width:22px;height:2px;background:var(--line)}
@media(max-width:760px){.steps{grid-template-columns:1fr}.step:not(:last-child)::after{display:none}}

/* ---- depoimento (opcional) ---- */
.quote{max-width:760px;margin:0 auto;text-align:center}
.quote-photo{width:86px;height:86px;border-radius:50%;object-fit:cover;display:block;margin:0 auto 20px;border:2px solid var(--gold);box-shadow:0 10px 28px rgba(0,0,0,.45)}
.quote blockquote{margin:0 0 18px;font-size:1.32rem;line-height:1.5;color:#fff;font-weight:500;text-wrap:pretty}
.quote cite{font-style:normal;color:var(--gold-light);font-weight:600;font-size:.95rem}
.quote cite span{display:block;color:var(--grey);font-weight:400;font-size:.85rem;margin-top:3px}

/* ---- AUTORIDADE / credenciais ---- */
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:42px}
.stat{text-align:center;padding:24px 16px;background:rgba(31,64,96,.32);border:1px solid var(--line);border-radius:var(--r-card)}
.stat strong{display:block;font-size:2rem;font-weight:800;color:var(--gold-light);letter-spacing:-.02em;line-height:1;margin-bottom:9px;font-variant-numeric:tabular-nums}
.stat span{color:var(--grey);font-size:.86rem;line-height:1.4}
@media(max-width:720px){.stats{grid-template-columns:1fr 1fr}}
.seals{display:flex;flex-wrap:wrap;gap:30px 48px;justify-content:center;margin-bottom:36px}
.seal-group{text-align:center}
.seal-group .lbl{display:block;color:var(--gold);font-size:.68rem;font-weight:700;letter-spacing:.15em;text-transform:uppercase;margin-bottom:14px}
.logos{display:flex;flex-wrap:wrap;gap:14px;justify-content:center}
.logo-plate{display:inline-flex;align-items:center;gap:10px;height:56px;padding:0 20px;background:#fff;border-radius:11px;box-shadow:0 10px 24px -12px rgba(0,0,0,.55);transition:transform .25s var(--ease-out)}
@media(hover:hover) and (pointer:fine){.logo-plate:hover{transform:translateY(-3px)}}
.logo-plate img{height:26px;width:26px;object-fit:contain;display:block;flex-shrink:0}
.logo-plate .wordmark{color:#19354d;font-weight:700;font-size:.98rem;letter-spacing:-.01em;white-space:nowrap}
.creds{max-width:760px;margin:0 auto;text-align:center;color:var(--grey);font-size:.82rem;line-height:1.7;border-top:1px solid var(--line);padding-top:24px}
.creds b{color:#fff;font-weight:600}

/* ---- FAQ (interrompível: grid-rows 0fr→1fr) ---- */
.lp-faq{max-width:780px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.lp-faq-item{border:1px solid var(--line);border-radius:var(--r-card);background:rgba(31,64,96,.32);overflow:hidden}
.lp-faq-q{width:100%;text-align:left;font:inherit;color:inherit;cursor:pointer;background:none;border:none;padding:19px 22px;display:flex;justify-content:space-between;align-items:center;gap:16px;font-size:1rem;font-weight:600}
.lp-faq-q:focus-visible{outline:2px solid var(--gold);outline-offset:-2px}
.lp-faq-q .pm{flex-shrink:0;width:18px;height:18px;position:relative;transition:transform .22s var(--ease-out)}
.lp-faq-q .pm::before,.lp-faq-q .pm::after{content:"";position:absolute;background:var(--gold-light);border-radius:2px}
.lp-faq-q .pm::before{top:8px;left:0;width:18px;height:2px}
.lp-faq-q .pm::after{left:8px;top:0;width:2px;height:18px;transition:transform .22s var(--ease-out)}
.lp-faq-item.open .pm{transform:rotate(180deg)}
.lp-faq-item.open .pm::after{transform:scaleY(0)}
.lp-faq-a{display:grid;grid-template-rows:0fr;transition:grid-template-rows .24s var(--ease-out)}
.lp-faq-item.open .lp-faq-a{grid-template-rows:1fr}
.lp-faq-a>div{overflow:hidden}
.lp-faq-a p{color:var(--grey);font-size:.95rem;line-height:1.55;padding:0 22px 20px}

/* ---- CTA (imagem inline na própria seção; aqui só o overlay padrão) ---- */
.lp-cta-sec{text-align:center;background-color:var(--black);background-image:radial-gradient(circle at 50% 0,var(--gold-soft),transparent 55%),linear-gradient(0deg,rgba(20,42,61,.93),rgba(20,42,61,.93));background-size:cover;background-position:center}
.lp-cta-sec h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:700;letter-spacing:-.02em;max-width:760px;margin:12px auto 16px;text-wrap:balance}
.lp-cta-sec h2 b{color:var(--gold-light)}
.lp-cta-sec p{color:var(--grey);max-width:560px;margin:0 auto 28px}
.cta-note{margin-top:16px;color:var(--grey);font-size:.86rem}
.cta-note b{color:var(--gold-light);font-weight:600}

/* ---- skip link ---- */
.skip{position:absolute;left:12px;top:-60px;z-index:200;background:var(--gold);color:#15120a;padding:10px 16px;border-radius:2px;font-weight:700;transition:top .2s var(--ease-out)}
.skip:focus{top:12px}

/* ---- POPUP: convite ao site principal (acima do WhatsApp) ---- */
.site-pop{position:fixed;right:calc(24px + env(safe-area-inset-right));bottom:calc(98px + env(safe-area-inset-bottom));z-index:95;width:min(304px,calc(100vw - 40px));opacity:0;transform:translateY(14px) scale(.96);transform-origin:bottom right;transition:opacity .38s var(--ease-out),transform .38s var(--ease-out);pointer-events:none}
.site-pop.show{opacity:1;transform:none;pointer-events:auto}
.site-pop-card{position:relative;display:flex;align-items:center;gap:13px;background:var(--black-2);border:1px solid var(--line);border-radius:14px;padding:14px 38px 14px 15px;box-shadow:0 20px 44px -14px rgba(0,0,0,.7);text-decoration:none;color:inherit;transition:transform .25s var(--ease-out),border-color .25s var(--ease-out)}
.site-pop-card:active{transform:scale(.985)}
.site-pop-ico{position:relative;flex-shrink:0;width:44px;height:44px;border-radius:12px;background:var(--gold-soft);display:flex;align-items:center;justify-content:center;color:var(--gold-light)}
.site-pop-ico .icon{width:23px;height:23px}
.site-pop-ico::after{content:"";position:absolute;top:-3px;right:-3px;width:10px;height:10px;border-radius:50%;background:var(--gold-light);box-shadow:0 0 0 0 rgba(220,193,136,.6);animation:pulse 2.2s var(--ease-io) infinite}
.site-pop-txt{display:flex;flex-direction:column;gap:3px;min-width:0}
.site-pop-txt strong{color:#fff;font-size:.96rem;font-weight:700;letter-spacing:-.01em}
.site-pop-txt span{color:var(--grey);font-size:.8rem;line-height:1.35}
.site-pop-arrow{margin-left:auto;color:var(--gold-light);font-size:1.15rem;font-weight:700;transition:transform .25s var(--ease-out)}
.site-pop-close{position:absolute;top:7px;right:7px;width:24px;height:24px;border:none;background:transparent;color:var(--grey);font-size:1.15rem;line-height:1;cursor:pointer;border-radius:7px;display:flex;align-items:center;justify-content:center;z-index:2;transition:background .2s var(--ease-out),color .2s var(--ease-out)}
@media(hover:hover) and (pointer:fine){
  .site-pop-card:hover{transform:translateY(-3px);border-color:var(--gold)}
  .site-pop-card:hover .site-pop-arrow{transform:translateX(4px)}
  .site-pop-close:hover{background:rgba(255,255,255,.08);color:#fff}
}
@media(prefers-reduced-motion:reduce){.site-pop{transform:none}.site-pop-ico::after{animation:none}}

/* ---- touch + safe-area ---- */
.btn,.lp-faq-q,.nav-links a,.map-link,.menu-btn,.wa-float,.foot-social a,.site-pop-card,.site-pop-close{touch-action:manipulation;-webkit-tap-highlight-color:rgba(197,167,103,.2)}
.wa-float{bottom:calc(24px + env(safe-area-inset-bottom));right:calc(24px + env(safe-area-inset-right))}

/* ---- reduced motion ---- */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
  .r{opacity:1!important;transform:none!important}
  html{scroll-behavior:auto}
}
