/* ============================================================
   Clínica Tiago Almeida — 24H Draft v4 · "Celestia"
   Moldura azul + shell branco · navy bold · dente de vidro
   ============================================================ */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}

:root{
  --bg:#ffffff;
  --bg-soft:#f3f7ff;
  --panel:#ffffff;
  --ink:#0c2150;
  --ink-2:#0a1c44;
  --ink-soft:#4a5a7d;
  --muted:#8593b0;
  --line:#e7edf8;
  --line-2:#d7e1f3;
  --primary:#2563eb;
  --primary-deep:#1b4fd1;
  --primary-soft:#e9f0ff;
  --sky:#5b9dff;
  --navy:#0c2150;
  --gold:#f6b13f;
  --on-primary:#ffffff;
  --shadow-sm:0 2px 10px rgba(16,46,110,.06);
  --shadow:0 16px 40px -18px rgba(16,46,110,.30);
  --shadow-lg:0 40px 90px -38px rgba(16,46,110,.45);
  --shadow-blue:0 16px 34px -12px rgba(37,99,235,.5);
  --r-card:24px;
  --r-md:18px;
  --r-sm:13px;
  --r-page:40px;
  --wrap:1180px;
  --font-d:'Plus Jakarta Sans',system-ui,sans-serif;
  --font-b:'General Sans',system-ui,sans-serif;
  --page-bg:linear-gradient(160deg,#4a8cf7 0%,#2a62e0 48%,#1c3fae 100%);
}
html[data-theme="dark"]{
  --bg:#0b1426;
  --bg-soft:#0f1c36;
  --panel:#101e3c;
  --ink:#eaf1ff;
  --ink-2:#ffffff;
  --ink-soft:#aebcd9;
  --muted:#7e8db0;
  --line:#1c2c4d;
  --line-2:#27395f;
  --primary:#4f8cff;
  --primary-deep:#6ea2ff;
  --primary-soft:#15294f;
  --navy:#0a1426;
  --on-primary:#06122a;
  --shadow-sm:0 2px 10px rgba(0,0,0,.4);
  --shadow:0 16px 40px -18px rgba(0,0,0,.7);
  --shadow-lg:0 40px 90px -38px rgba(0,0,0,.85);
  --shadow-blue:0 16px 36px -12px rgba(79,140,255,.45);
  --page-bg:linear-gradient(160deg,#0a1f4a 0%,#08163a 55%,#050d26 100%);
}

html{scroll-behavior:smooth}
body{background:var(--page-bg) fixed;color:var(--ink);font-family:var(--font-b);line-height:1.6;-webkit-font-smoothing:antialiased;
  padding:clamp(0px,1.5vw,22px);transition:color .4s}
img{display:block;max-width:100%}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:none;background:none;color:inherit}
svg{display:block}

/* the white "card" shell on blue */
.page{max-width:1340px;margin:0 auto;background:var(--bg);border-radius:var(--r-page);box-shadow:0 40px 120px -50px rgba(8,22,70,.7);transition:background .4s}
.nav{border-radius:var(--r-page) var(--r-page) 0 0}
.footer{border-radius:0 0 var(--r-page) var(--r-page)}

.wrap{width:100%;max-width:var(--wrap);margin:0 auto;padding:0 clamp(1.2rem,4vw,2.6rem)}
.section{padding:clamp(3.4rem,7vw,6rem) 0}

/* ---------- type ---------- */
.h2{font-family:var(--font-d);font-weight:700;font-size:clamp(1.9rem,4vw,2.95rem);line-height:1.08;letter-spacing:-.03em;color:var(--ink)}
.h2--light{color:#fff}
.lead{color:var(--ink-soft);font-size:1.08rem;max-width:52ch;margin-top:1rem}
.grad{background:linear-gradient(100deg,var(--primary),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}

/* ---------- pills ---------- */
.pill{display:inline-flex;align-items:center;gap:.5rem;font-family:var(--font-d);font-weight:600;font-size:.8rem;padding:.45rem .9rem;border-radius:100px}
.pill--eyebrow,.pill--label{background:var(--primary-soft);color:var(--primary)}
.pill--label{margin-bottom:1.1rem}
.pill--on-blue{background:rgba(255,255,255,.18);color:#fff}
.pulse{width:8px;height:8px;border-radius:50%;background:var(--primary);box-shadow:0 0 0 0 rgba(37,99,235,.5);animation:pulse 2s infinite}
@keyframes pulse{0%{box-shadow:0 0 0 0 rgba(37,99,235,.45)}70%{box-shadow:0 0 0 8px rgba(37,99,235,0)}100%{box-shadow:0 0 0 0 rgba(37,99,235,0)}}

/* ---------- buttons ---------- */
.btn{display:inline-flex;align-items:center;justify-content:center;gap:.55rem;font-family:var(--font-d);font-weight:600;font-size:.95rem;line-height:1;
  padding:.82rem 1.35rem;border-radius:100px;transition:transform .15s,box-shadow .25s,background .2s,color .2s,border-color .2s;white-space:nowrap}
.btn svg{width:18px;height:18px}
.btn--primary{position:relative;overflow:hidden;background:var(--primary);color:var(--on-primary);box-shadow:var(--shadow-blue)}
.btn--primary::after{content:"";position:absolute;top:0;left:-70%;width:45%;height:100%;pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.4),transparent);transform:skewX(-18deg);transition:left .6s ease}
.btn--primary:hover::after{left:135%}
.btn--primary:hover{background:var(--primary-deep);transform:translateY(-2px)}
.btn--ghost{background:transparent;color:var(--ink);border:1.5px solid var(--line-2)}
.btn--ghost:hover{border-color:var(--primary);color:var(--primary);transform:translateY(-2px)}
.btn--white{background:#fff;color:var(--primary);box-shadow:0 12px 28px -12px rgba(0,0,0,.3)}
.btn--white:hover{transform:translateY(-2px);background:#eef5ff}
.btn--ghost-light{background:rgba(255,255,255,.12);color:#fff;border:1.5px solid rgba(255,255,255,.35)}
.btn--ghost-light:hover{background:rgba(255,255,255,.22);transform:translateY(-2px)}
.btn--lg{padding:1rem 1.7rem;font-size:1rem}
.btn--block{width:100%}

/* ---------- nav ---------- */
.nav{position:sticky;top:0;z-index:40;background:color-mix(in srgb,var(--bg) 86%,transparent);backdrop-filter:blur(16px);border-bottom:1px solid transparent;transition:border-color .3s,background .3s}
.nav.solid{border-bottom-color:var(--line);background:color-mix(in srgb,var(--bg) 94%,transparent)}
.nav__inner{display:flex;align-items:center;justify-content:space-between;gap:1.4rem;height:74px}
.brand{display:flex;align-items:center;gap:.65rem}
.brand__icon{display:inline-block;width:34px;height:40px;flex:none;background:var(--primary);
  -webkit-mask:url('assets/logo-mark.png') center/contain no-repeat;mask:url('assets/logo-mark.png') center/contain no-repeat}
.brand__icon svg{display:none}
.brand__txt{display:flex;flex-direction:column;line-height:1.18}
.brand__name{font-family:var(--font-d);font-weight:700;font-size:1rem;letter-spacing:.1em;text-transform:uppercase;color:var(--ink)}
.brand__sub{font-size:.58rem;letter-spacing:.24em;text-transform:uppercase;color:var(--muted);font-family:var(--font-d);font-weight:600;margin-top:1px}
.nav__links{display:flex;align-items:center;gap:1.9rem}
.nav__links a{font-family:var(--font-d);font-weight:500;font-size:.93rem;color:var(--ink-soft);position:relative;transition:color .2s}
.nav__links a:hover{color:var(--primary)}
.nav__links a::after{content:"";position:absolute;left:0;right:100%;bottom:-7px;height:2px;background:var(--primary);border-radius:2px;transition:right .25s}
.nav__links a:hover::after{right:0}
.nav__actions{display:flex;align-items:center;gap:.6rem}
.iconbtn{display:grid;place-items:center;width:42px;height:42px;border-radius:13px;border:1.5px solid var(--line-2);color:var(--ink-soft);transition:.2s}
.iconbtn:hover{border-color:var(--primary);color:var(--primary)}
.iconbtn svg{width:19px;height:19px}
.theme__moon{display:none}
html[data-theme="dark"] .theme__sun{display:none}
html[data-theme="dark"] .theme__moon{display:block}
.burger{display:none;flex-direction:column;gap:4px}
.burger span{width:18px;height:2px;background:currentColor;border-radius:2px;transition:.25s}

/* ---------- hero ---------- */
.hero{position:relative;padding:clamp(2rem,5vw,4.5rem) 0 clamp(2.5rem,5vw,4.5rem);overflow:hidden}
.hero::before{content:"";position:absolute;inset:0;z-index:0;background:
  radial-gradient(46% 60% at 82% 30%,color-mix(in srgb,var(--sky) 26%,transparent),transparent 62%),
  radial-gradient(40% 50% at 8% 4%,color-mix(in srgb,var(--primary) 12%,transparent),transparent 60%)}
.hero__watermark{position:absolute;left:50%;top:54%;transform:translate(-50%,-50%);z-index:0;font-family:var(--font-d);font-weight:800;
  font-size:clamp(3rem,11vw,9rem);letter-spacing:-.04em;color:var(--ink);opacity:.035;white-space:nowrap;pointer-events:none}
.hero__grid{position:relative;z-index:2;display:grid;grid-template-columns:1.02fr .98fr;gap:clamp(1.5rem,4vw,3rem);align-items:center}
.hero__title{font-family:var(--font-d);font-weight:800;font-size:clamp(2.4rem,5.2vw,4.05rem);line-height:1.02;letter-spacing:-.04em;margin:1.2rem 0 0;color:var(--ink)}
.hero__lead{color:var(--ink-soft);font-size:1.14rem;margin-top:1.3rem;max-width:44ch}
.hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;margin-top:2rem}
.hero__proof{display:flex;align-items:center;gap:1rem;margin-top:2rem}
.avatars{display:flex}
.avatars img{width:44px;height:44px;border-radius:50%;object-fit:cover;border:3px solid var(--bg);margin-left:-14px;box-shadow:var(--shadow-sm)}
.avatars img:first-child{margin-left:0}
.avatars__more{width:44px;height:44px;border-radius:50%;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);
  font-family:var(--font-d);font-weight:700;font-size:.86rem;border:3px solid var(--bg);margin-left:-14px}
.hero__proof-txt{display:flex;flex-direction:column;gap:.1rem}
.hero__proof-txt b{font-family:var(--font-d);font-weight:700;font-size:.95rem;color:var(--ink)}
.hero__proof-txt span{font-size:.88rem;color:var(--muted)}

.hero__visual{position:relative;display:grid;place-items:center}
.hero__visual::before{content:"";position:absolute;width:90%;height:90%;border-radius:50%;
  background:radial-gradient(circle,color-mix(in srgb,var(--sky) 32%,transparent),transparent 62%);filter:blur(12px);z-index:0}
.hero__photo{position:relative;z-index:1;width:min(450px,100%);aspect-ratio:4/4.7;border-radius:220px 220px 30px 30px;overflow:hidden;
  box-shadow:var(--shadow-lg);border:6px solid var(--panel);animation:floaty 7s ease-in-out infinite}
.hero__photo img{width:100%;height:100%;object-fit:cover}
@keyframes floaty{0%,100%{transform:translateY(0)}50%{transform:translateY(-12px)}}
.chip{position:absolute;z-index:3;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);box-shadow:var(--shadow);display:flex;align-items:center;gap:.6rem;padding:.7rem .9rem}
.chip b{font-family:var(--font-d);font-weight:700;font-size:.92rem;color:var(--ink);display:block;line-height:1.1}
.chip span{font-size:.74rem;color:var(--muted)}
.chip__ic{flex:none;width:36px;height:36px;border-radius:11px;display:grid;place-items:center;background:var(--primary);color:#fff}
.chip__ic--soft{background:var(--primary-soft);color:var(--primary)}
.chip__ic svg{width:20px;height:20px}
.chip--a{left:-5%;bottom:12%;animation:floaty 5.4s ease-in-out infinite .3s}
.chip--b{right:-5%;top:14%;animation:floaty 6.2s ease-in-out infinite .6s}

/* ---------- porquê ---------- */
.porque{background:var(--bg-soft)}
.porque__grid{display:grid;grid-template-columns:.95fr 1.05fr;gap:clamp(2rem,5vw,4.5rem);align-items:center}
.porque__photo{aspect-ratio:4/4.3;border-radius:var(--r-card);overflow:hidden;box-shadow:var(--shadow);border:1px solid var(--line)}
.porque__photo img{width:100%;height:100%;object-fit:cover}
.feature-list{list-style:none;margin:1.6rem 0 2rem;display:flex;flex-direction:column;gap:1rem}
.feature-list li{display:flex;gap:.9rem;align-items:flex-start}
.feature__ic{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary)}
.feature__ic svg{width:18px;height:18px}
.feature-list b{font-family:var(--font-d);font-weight:700;font-size:1.02rem;color:var(--ink)}
.feature-list p{font-size:.94rem;color:var(--ink-soft);margin-top:.15rem}

/* ---------- statband (duotone) ---------- */
.statband{position:relative;overflow:hidden}
.statband__bg{position:absolute;inset:0;z-index:0}
.statband__bg img{width:100%;height:100%;object-fit:cover}
.statband::after{content:"";position:absolute;inset:0;z-index:1;background:linear-gradient(150deg,rgba(20,58,150,.92),rgba(12,33,96,.96))}
.statband__inner{position:relative;z-index:2;padding:clamp(3rem,6vw,5rem) 0}
.statband__head{max-width:640px;margin-bottom:2.4rem}
.statband__head .h2{margin-top:.8rem}
.statband__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem}
.gcard{background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.22);border-radius:var(--r-md);padding:1.5rem 1.4rem;backdrop-filter:blur(8px)}
.gcard b{font-family:var(--font-d);font-weight:800;font-size:2.3rem;line-height:1;letter-spacing:-.03em;color:#fff;display:block}
.gcard span{font-size:.9rem;color:rgba(255,255,255,.8);margin-top:.4rem;display:block}

/* ---------- section heads ---------- */
.shead{margin-bottom:2.6rem;max-width:760px}
.shead .h2{margin-top:.2rem}
.shead__note{font-size:1.02rem;color:var(--ink-soft);margin-top:1rem}
.shead--center{margin-inline:auto;text-align:center}
.shead--center .shead__note{margin-inline:auto}

/* ---------- serviços ---------- */
.svc-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem}
.svc{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);padding:1.6rem;box-shadow:var(--shadow-sm);display:flex;flex-direction:column;transition:transform .22s,box-shadow .22s,border-color .22s}
.svc:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:var(--line-2)}
.svc__ico{width:56px;height:56px;border-radius:17px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);margin-bottom:1.1rem;transition:.25s}
.svc:hover .svc__ico{background:var(--primary);color:#fff;transform:rotate(-6deg)}
.svc__ico svg{width:28px;height:28px}
.svc__nome{font-family:var(--font-d);font-weight:700;font-size:1.26rem;letter-spacing:-.01em;color:var(--ink)}
.svc__resumo{font-size:.97rem;color:var(--ink-soft);margin-top:.5rem}
.svc__inclui{list-style:none;margin:0;display:flex;flex-direction:column;gap:.55rem;max-height:0;opacity:0;overflow:hidden;transition:max-height .35s,opacity .3s,margin .3s}
.svc.open .svc__inclui{max-height:220px;opacity:1;margin:1.1rem 0 .4rem}
.svc__inclui li{display:flex;align-items:flex-start;gap:.55rem;font-size:.92rem;color:var(--ink-soft)}
.svc__inclui svg{width:17px;height:17px;color:var(--primary);flex:none;margin-top:.18rem}
.svc__link{position:absolute;inset:0;z-index:1;border-radius:var(--r-card)}
.svc__foot{position:relative;z-index:2;margin-top:auto;display:flex;align-items:center;justify-content:space-between;gap:.5rem;padding-top:1.1rem}
.svc__more{font-family:var(--font-d);font-weight:600;font-size:.9rem;color:var(--primary);display:inline-flex;align-items:center;gap:.35rem}
.svc__more svg{width:16px;height:16px;transition:transform .2s}
.svc:hover .svc__more svg{transform:translateX(3px)}
.svc__book{position:relative;z-index:2;font-family:var(--font-d);font-weight:600;font-size:.86rem;color:var(--ink-soft);
  border:1.5px solid var(--line-2);padding:.5rem .9rem;border-radius:100px;transition:.2s}
.svc__book:hover{border-color:var(--primary);color:var(--primary)}
.svc__toggle{font-family:var(--font-d);font-size:.88rem;font-weight:600;color:var(--muted);display:inline-flex;align-items:center;gap:.35rem}
.svc__toggle svg{width:15px;height:15px;transition:transform .3s}
.svc.open .svc__toggle svg{transform:rotate(180deg)}
.svc__book{font-family:var(--font-d);font-weight:600;font-size:.9rem;color:var(--primary);display:inline-flex;align-items:center;gap:.35rem}
.svc__book svg{width:16px;height:16px;transition:transform .2s}
.svc__book:hover svg{transform:translateX(3px)}

/* ---------- corpo clínico ---------- */
.corpo__grid{display:grid;grid-template-columns:.78fr 1.22fr;gap:clamp(2rem,4vw,3.5rem);align-items:start}
.corpo__intro{position:sticky;top:100px}
.corpo__intro .lead{margin-bottom:1.6rem}
.team-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1.1rem}
.member{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .22s,box-shadow .22s}
.member:hover{transform:translateY(-6px);box-shadow:var(--shadow)}
.member__photo{aspect-ratio:1/1.04;position:relative;overflow:hidden;background:var(--primary-soft)}
.member__photo img{width:100%;height:100%;object-fit:cover;object-position:center top;transition:transform .5s}
.member:hover .member__photo img{transform:scale(1.05)}
.member__photo--icon{display:grid;place-items:center;background:linear-gradient(160deg,var(--primary-soft),color-mix(in srgb,var(--sky) 22%,var(--panel)))}
.member__icon{display:grid;place-items:center;width:84px;height:84px;border-radius:50%;background:var(--panel);color:var(--primary);box-shadow:var(--shadow-sm);border:1px solid var(--line)}
.member__icon svg{width:46px;height:46px}
.member__tag{position:absolute;top:.8rem;left:.8rem;z-index:2;font-family:var(--font-d);font-size:.68rem;font-weight:600;background:color-mix(in srgb,var(--panel) 88%,transparent);color:var(--primary);padding:.32rem .65rem;border-radius:100px;backdrop-filter:blur(4px)}
.member__ph{position:absolute;bottom:0;left:0;right:0;z-index:2;text-align:center;font-size:.68rem;font-weight:600;background:color-mix(in srgb,var(--primary) 90%,transparent);color:#fff;padding:.3rem}
.member__body{padding:1.05rem 1.15rem 1.3rem}
.member__nome{font-family:var(--font-d);font-weight:700;font-size:1.08rem;letter-spacing:-.01em;color:var(--ink)}
.member__cargo{font-size:.84rem;color:var(--muted);margin-top:.15rem}
.member__foco{display:flex;flex-wrap:wrap;gap:.4rem;margin-top:.8rem}
.member__foco span{font-size:.72rem;color:var(--primary);background:var(--primary-soft);padding:.26rem .55rem;border-radius:100px;font-weight:500}

/* ---------- marcações (painel azul) ---------- */
.marc{position:relative;overflow:hidden;border-radius:var(--r-card);padding:clamp(1.6rem,3vw,2.6rem);background:linear-gradient(140deg,var(--primary),var(--primary-deep) 60%,#15389e);
  background-size:180% 180%;animation:gradShift 14s ease infinite;
  display:grid;grid-template-columns:1fr 1fr 1fr;gap:1.2rem;box-shadow:var(--shadow-lg)}
@keyframes gradShift{0%{background-position:0% 50%}50%{background-position:100% 50%}100%{background-position:0% 50%}}
.marc::before{content:"";position:absolute;top:-50%;right:-10%;width:55%;height:180%;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,.14),transparent 60%)}
.marc__panel,.marc__center{position:relative;z-index:2;background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.16);border-radius:var(--r-md);padding:1.4rem;backdrop-filter:blur(6px)}
.marc__col-label{display:block;font-family:var(--font-d);font-size:.7rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;color:rgba(255,255,255,.7);margin-bottom:1.1rem}
.marc__steps{list-style:none;display:flex;flex-direction:column;gap:1rem;margin-bottom:1.4rem}
.marc__steps li{display:flex;gap:.75rem;align-items:flex-start}
.marc__steps span{flex:none;width:28px;height:28px;border-radius:50%;display:grid;place-items:center;background:rgba(255,255,255,.2);color:#fff;font-family:var(--font-d);font-weight:700;font-size:.85rem}
.marc__steps b{font-family:var(--font-d);font-weight:600;color:#fff;font-size:.98rem}
.marc__steps p{font-size:.86rem;color:rgba(255,255,255,.75)}
.marc__cta{display:flex;flex-direction:column;gap:.6rem}
.marc__center{display:flex;flex-direction:column;align-items:center}
.marc__tooth{flex:1;display:grid;place-items:center;width:100%;padding:1rem 0}
.marc__tooth svg{width:clamp(120px,60%,180px);height:auto;filter:drop-shadow(0 14px 30px rgba(0,0,0,.3));animation:floaty 6s ease-in-out infinite}
.marc__chips{display:flex;flex-wrap:wrap;gap:.45rem;justify-content:center}
.marc__chips span{font-size:.74rem;color:#fff;background:rgba(255,255,255,.16);padding:.3rem .65rem;border-radius:100px}
.rcard{background:#fff;border-radius:var(--r-sm);padding:.9rem 1rem;margin-bottom:.7rem}
.rcard:last-child{margin-bottom:0}
.rcard b{font-family:var(--font-d);font-weight:700;font-size:.95rem;color:var(--navy);display:block}
.rcard span{font-size:.82rem;color:#5a6a8a;display:block;margin-top:.2rem}
.rcard__top{display:flex;align-items:center;justify-content:space-between}
.rcard__ok{width:22px;height:22px;border-radius:50%;background:#e7f6ee;color:#1f9d5b;display:grid;place-items:center;font-size:.8rem;font-weight:700}
.rcard--urg{background:#fff4ec}
.rcard--urg b{color:#c4622a}
.rcard--urg span{color:#9c6a45}

/* ---------- frase / manifesto ---------- */
.statement-sec{padding-top:0}
.statement{position:relative;text-align:center;max-width:880px;margin:0 auto;background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-card);padding:clamp(2.4rem,5vw,3.6rem) clamp(1.5rem,5vw,3.5rem)}
.statement__mark{position:absolute;top:-.2em;left:.3em;font-family:var(--font-d);font-weight:800;font-size:5rem;color:var(--primary);opacity:.18;line-height:1}
.statement__text{position:relative;font-family:var(--font-d);font-weight:600;font-size:clamp(1.3rem,2.8vw,1.9rem);line-height:1.32;letter-spacing:-.02em;color:var(--ink)}
.statement__by{display:block;margin-top:1.4rem;font-family:var(--font-d);font-weight:600;font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--muted)}

/* ---------- faq ---------- */
.faq__grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start}
.faq__intro{position:sticky;top:100px}
.faq__intro .lead{margin-bottom:1.6rem}
.faq__list{display:flex;flex-direction:column;gap:.8rem}
.faq__item{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);overflow:hidden;transition:border-color .2s,box-shadow .2s}
.faq__item.open{border-color:var(--line-2);box-shadow:var(--shadow-sm)}
.faq__q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;text-align:left;padding:1.15rem 1.4rem;font-family:var(--font-d);font-weight:600;font-size:1.02rem;color:var(--ink)}
.faq__q svg{width:22px;height:22px;color:var(--primary);flex:none;transition:transform .3s}
.faq__item.open .faq__q svg{transform:rotate(45deg)}
.faq__a{max-height:0;opacity:0;overflow:hidden;transition:max-height .35s,opacity .3s,padding .3s;padding:0 1.4rem}
.faq__item.open .faq__a{max-height:240px;opacity:1;padding:0 1.4rem 1.3rem}
.faq__a p{color:var(--ink-soft);font-size:.97rem}

/* ---------- cta final ---------- */
.cta-wrap{padding-bottom:clamp(3rem,7vw,6rem)}
.cta{position:relative;overflow:hidden;text-align:center;border-radius:var(--r-card);padding:clamp(2.6rem,6vw,4.5rem) 1.5rem;background:linear-gradient(135deg,var(--primary),var(--primary-deep) 55%,#15389e);
  background-size:180% 180%;animation:gradShift 14s ease infinite;box-shadow:var(--shadow-lg)}
.cta__glow{position:absolute;inset:0;background:radial-gradient(50% 120% at 50% 0%,rgba(255,255,255,.2),transparent 60%)}
.cta__title{position:relative;font-family:var(--font-d);font-weight:800;font-size:clamp(1.8rem,4vw,2.8rem);letter-spacing:-.03em;color:#fff}
.cta__lead{position:relative;color:rgba(255,255,255,.85);margin-top:.8rem;font-size:1.08rem}
.cta__actions{position:relative;display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.8rem}

/* ---------- footer ---------- */
.footer{background:var(--bg-soft);border-top:1px solid var(--line);padding:clamp(3rem,6vw,4.5rem) 0 2rem}
.footer__top{display:grid;grid-template-columns:1.5fr 1fr 1fr 1.1fr;gap:2rem}
.footer__brand p{color:var(--muted);font-size:.94rem;margin:1rem 0;max-width:34ch}
.brand--footer{margin-bottom:.3rem}
.footer__social{display:flex;gap:1rem}
.footer__social a{font-family:var(--font-d);font-size:.9rem;font-weight:500;color:var(--ink-soft)}
.footer__social a:hover{color:var(--primary)}
.footer__col h4{font-family:var(--font-d);font-weight:700;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;color:var(--muted);margin-bottom:1rem}
.footer__col address{font-style:normal;color:var(--ink-soft);font-size:.95rem;line-height:1.7}
.footer__hours{list-style:none;display:flex;flex-direction:column;gap:.7rem}
.footer__hours li{display:flex;flex-direction:column;font-size:.92rem;color:var(--ink)}
.footer__hours li span{color:var(--muted);font-size:.76rem;text-transform:uppercase;letter-spacing:.05em}
.footer__hours li.muted b{color:var(--muted)}
.footer__contact{list-style:none;display:flex;flex-direction:column;gap:.6rem}
.footer__contact a{font-size:1rem;font-weight:500;color:var(--ink)}
.footer__contact a:hover{color:var(--primary)}
.footer__contact span{font-size:.78rem;color:var(--muted)}
.footer__bottom{display:flex;justify-content:space-between;gap:1rem;flex-wrap:wrap;margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--line);font-size:.84rem;color:var(--muted)}
.footer__bottom a:hover{color:var(--primary)}

/* ---------- fab ---------- */
.fab{position:fixed;right:clamp(1rem,3vw,2rem);bottom:clamp(1rem,3vw,2rem);z-index:35;display:flex;align-items:center;gap:.45rem;background:var(--primary);color:#fff;
  padding:.9rem 1.3rem;border-radius:100px;font-family:var(--font-d);font-weight:600;box-shadow:var(--shadow-blue);
  opacity:0;transform:translateY(20px) scale(.9);pointer-events:none;transition:opacity .3s,transform .3s}
.fab.show{opacity:1;transform:none;pointer-events:auto}
.fab svg{width:20px;height:20px}

/* ---------- modal ---------- */
.modal{position:fixed;inset:0;z-index:60;display:none;align-items:flex-end;justify-content:center}
.modal.show{display:flex}
.modal__scrim{position:absolute;inset:0;background:rgba(8,18,40,.55);backdrop-filter:blur(4px);animation:fade .3s}
.modal__panel{position:relative;width:min(560px,100%);max-height:92vh;display:flex;flex-direction:column;background:var(--panel);border-radius:26px 26px 0 0;box-shadow:var(--shadow-lg);animation:slideUp .35s cubic-bezier(.2,.8,.25,1)}
@keyframes fade{from{opacity:0}to{opacity:1}}
@keyframes slideUp{from{transform:translateY(40px);opacity:0}to{transform:translateY(0);opacity:1}}
.modal__close{position:absolute;top:1rem;right:1rem;width:38px;height:38px;border-radius:12px;display:grid;place-items:center;color:var(--muted);background:var(--bg-soft);z-index:2}
.modal__close:hover{color:var(--ink)}
.modal__close svg{width:18px;height:18px}
.modal__progress{height:4px;background:var(--line);overflow:hidden;border-radius:26px 26px 0 0}
.modal__progress span{display:block;height:100%;width:33%;background:linear-gradient(90deg,var(--primary),var(--sky));transition:width .35s}
.modal__head{padding:1.5rem 1.6rem .4rem}
.modal__step{font-family:var(--font-d);font-size:.74rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--primary)}
.modal__head h3{font-family:var(--font-d);font-weight:700;font-size:1.5rem;margin-top:.3rem;letter-spacing:-.02em;color:var(--ink)}
.modal__body{padding:1rem 1.6rem;overflow-y:auto}
.modal__foot{display:flex;justify-content:space-between;gap:.8rem;padding:1.1rem 1.6rem;border-top:1px solid var(--line)}
.modal__foot .btn{flex:1}
#back[hidden]{display:none}
.q-label{font-family:var(--font-d);font-weight:700;font-size:1.08rem;margin-bottom:1rem;color:var(--ink)}
.choices{display:grid;gap:.6rem}
.choices--2{grid-template-columns:1fr 1fr}
.choice{display:flex;align-items:center;gap:.7rem;text-align:left;padding:.9rem 1rem;border:1.5px solid var(--line-2);border-radius:14px;transition:.18s;font-size:.96rem;color:var(--ink)}
.choice:hover{border-color:var(--primary)}
.choice.sel{border-color:var(--primary);background:var(--primary-soft);color:var(--primary);font-weight:600}
.choice__ic{flex:none;width:30px;height:30px;border-radius:9px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary)}
.choice.sel .choice__ic{background:var(--primary);color:#fff}
.choice__ic svg{width:17px;height:17px}
.choice__mono{flex:none;width:30px;height:30px;border-radius:50%;display:grid;place-items:center;background:var(--bg-soft);font-family:var(--font-d);font-weight:700;font-size:.78rem;color:var(--primary)}
.field-grid{display:grid;gap:.9rem}
.field label{display:block;font-family:var(--font-d);font-size:.82rem;font-weight:600;color:var(--ink-soft);margin-bottom:.35rem}
.field input,.field textarea{width:100%;font-family:inherit;font-size:.96rem;color:var(--ink);background:var(--bg-soft);border:1.5px solid var(--line-2);border-radius:12px;padding:.78rem .9rem;transition:border-color .2s}
.field input:focus,.field textarea:focus{outline:none;border-color:var(--primary)}
.field textarea{resize:vertical;min-height:74px}
.field-row{display:grid;grid-template-columns:1fr 1fr;gap:.9rem}
.hint{font-size:.83rem;color:var(--muted);margin-top:.9rem;display:flex;gap:.45rem;align-items:flex-start}
.hint svg{width:16px;height:16px;color:var(--primary);flex:none;margin-top:.15rem}
.summary{display:flex;flex-direction:column;gap:.6rem;background:var(--bg-soft);border-radius:14px;padding:1rem 1.1rem;margin-bottom:1rem}
.summary__row{display:flex;justify-content:space-between;gap:1rem;font-size:.92rem}
.summary__row span{color:var(--muted)}
.summary__row b{font-weight:600;text-align:right;color:var(--ink)}
.success{text-align:center;padding:1rem 0 .5rem}
.success__ring{width:74px;height:74px;border-radius:50%;background:var(--primary-soft);display:grid;place-items:center;margin:0 auto 1.1rem}
.success__ring svg{width:38px;height:38px;color:var(--primary)}
.success h4{font-family:var(--font-d);font-weight:700;font-size:1.4rem;margin-bottom:.5rem;color:var(--ink)}
.success p{color:var(--ink-soft);font-size:.98rem;max-width:40ch;margin:0 auto}
.success__actions{display:flex;flex-direction:column;gap:.6rem;margin-top:1.4rem}

/* ---------- reveal ---------- */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .7s,transform .7s cubic-bezier(.2,.8,.25,1)}
.js .reveal--left{transform:translateX(-42px)}
.js .reveal--right{transform:translateX(42px)}
.js .reveal--zoom{transform:scale(.92)}
.reveal.in{opacity:1;transform:none}
.js [data-stagger].in>*{animation:rise .6s both}
[data-stagger].in>*:nth-child(2){animation-delay:.07s}
[data-stagger].in>*:nth-child(3){animation-delay:.14s}
[data-stagger].in>*:nth-child(4){animation-delay:.21s}
[data-stagger].in>*:nth-child(5){animation-delay:.28s}
[data-stagger].in>*:nth-child(6){animation-delay:.35s}
[data-stagger].in>*:nth-child(7){animation-delay:.42s}
@keyframes rise{from{opacity:0;transform:translateY(18px)}to{opacity:1;transform:none}}
@media(prefers-reduced-motion:reduce){
  .reveal,[data-stagger]>*,.chip,.hero__photo,.marc__tooth svg,.marc,.cta{animation:none!important;opacity:1!important;transform:none!important;transition:none!important}
  .btn--primary::after{display:none}
}

/* ============================================================
   PÁGINAS DE SERVIÇO
   ============================================================ */
.svc-hero{position:relative;overflow:hidden;text-align:center;padding:clamp(2.5rem,6vw,4.5rem) 0 clamp(2rem,4vw,3rem)}
.svc-hero__glow{position:absolute;inset:0;z-index:0;background:
  radial-gradient(50% 70% at 50% 0%,color-mix(in srgb,var(--sky) 26%,transparent),transparent 60%),
  radial-gradient(40% 50% at 85% 20%,color-mix(in srgb,var(--primary) 12%,transparent),transparent 60%)}
.svc-hero__inner{position:relative;z-index:2;display:flex;flex-direction:column;align-items:center}
.crumbs{font-family:var(--font-d);font-size:.82rem;color:var(--muted);margin-bottom:1.6rem;display:flex;gap:.5rem;flex-wrap:wrap;justify-content:center}
.crumbs a:hover{color:var(--primary)}
.crumbs b{color:var(--ink)}
.svc-hero__ico{width:74px;height:74px;border-radius:22px;display:grid;place-items:center;background:var(--primary);color:#fff;box-shadow:var(--shadow-blue);margin-bottom:1.3rem}
.svc-hero__ico svg{width:38px;height:38px}
.svc-hero__title{font-family:var(--font-d);font-weight:800;font-size:clamp(2.2rem,5vw,3.4rem);letter-spacing:-.03em;color:var(--ink)}
.svc-hero__tagline{color:var(--ink-soft);font-size:1.15rem;max-width:40ch;margin:1rem auto 0}
.svc-hero__cta{display:flex;flex-wrap:wrap;gap:.8rem;justify-content:center;margin-top:1.8rem}
.svc-hero__stats{display:flex;flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2.4rem}
.svc-stat{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:1rem 1.4rem;min-width:150px;box-shadow:var(--shadow-sm)}
.svc-stat b{display:block;font-family:var(--font-d);font-weight:800;font-size:1.5rem;letter-spacing:-.02em;
  background:linear-gradient(120deg,var(--primary),var(--sky));-webkit-background-clip:text;background-clip:text;color:transparent}
.svc-stat span{font-size:.82rem;color:var(--muted)}

.svc-intro{display:grid;grid-template-columns:1.4fr .9fr;gap:clamp(1.5rem,4vw,3rem);align-items:start}
.svc-intro__lead{font-size:1.14rem;color:var(--ink-soft);line-height:1.7;margin-top:.4rem}
.svc-ind{background:var(--bg-soft);border:1px solid var(--line);border-radius:var(--r-card);padding:1.6rem}
.svc-ind h3{font-family:var(--font-d);font-weight:700;font-size:1.1rem;margin-bottom:1rem;color:var(--ink)}
.svc-ind ul{list-style:none;display:flex;flex-direction:column;gap:.7rem;margin-bottom:1.4rem}
.svc-ind li{display:flex;gap:.6rem;align-items:flex-start;font-size:.95rem;color:var(--ink-soft)}
.svc-ind li svg{width:18px;height:18px;color:var(--primary);flex:none;margin-top:.15rem}

.svc-proc-sec{background:var(--bg-soft);border-block:1px solid var(--line)}
.svc-proc{display:grid;grid-template-columns:repeat(4,1fr);gap:1.1rem}
.proc{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);padding:1.5rem;box-shadow:var(--shadow-sm);position:relative}
.proc__n{font-family:var(--font-d);font-weight:800;font-size:1.6rem;color:color-mix(in srgb,var(--primary) 32%,transparent);display:block;margin-bottom:.5rem}
.proc b{font-family:var(--font-d);font-weight:700;font-size:1.05rem;color:var(--ink);display:block}
.proc p{font-size:.92rem;color:var(--ink-soft);margin-top:.3rem}

/* tabela de comparação */
.cmp-wrap{overflow-x:auto;border:1px solid var(--line);border-radius:var(--r-card);box-shadow:var(--shadow);background:var(--panel)}
.cmp{width:100%;border-collapse:collapse;min-width:560px}
.cmp th,.cmp td{padding:1rem 1.2rem;text-align:center;border-bottom:1px solid var(--line);font-size:.95rem}
.cmp thead th{font-family:var(--font-d);font-weight:700;color:var(--ink);font-size:1rem;background:var(--bg-soft);position:relative}
.cmp .cmp__crit{text-align:left;color:var(--ink-soft);font-weight:600;font-family:var(--font-d)}
.cmp tbody tr:last-child td{border-bottom:none}
.cmp tbody td.cmp__crit{color:var(--ink)}
.cmp .cmp__best{background:color-mix(in srgb,var(--primary) 8%,transparent)}
.cmp thead th.cmp__best{background:var(--primary);color:#fff;border-radius:14px 14px 0 0;padding-top:.8rem}
.cmp__tag{display:block;width:max-content;margin:0 auto .45rem;background:var(--gold);color:#3a2600;font-size:.6rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase;padding:.2rem .55rem;border-radius:100px;white-space:nowrap}
.cmp__yes{display:inline-flex;align-items:center;gap:.35rem;color:#1f9d5b;font-weight:600}
.cmp__yes svg{width:17px;height:17px}
.cmp__no{color:var(--muted)}
.cmp__note{font-size:.82rem;color:var(--muted);margin-top:1rem;text-align:center}

.svc-ben-sec{background:var(--bg-soft);border-block:1px solid var(--line)}
.svc-ben{display:grid;grid-template-columns:repeat(3,1fr);gap:1.1rem}
.ben{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-card);padding:1.6rem;box-shadow:var(--shadow-sm)}
.ben__ic{width:46px;height:46px;border-radius:13px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);margin-bottom:1rem}
.ben__ic svg{width:24px;height:24px}
.ben b{font-family:var(--font-d);font-weight:700;font-size:1.1rem;color:var(--ink);display:block}
.ben p{font-size:.95rem;color:var(--ink-soft);margin-top:.35rem}

.svc-other{display:grid;grid-template-columns:repeat(3,1fr);gap:.9rem}
.other{display:flex;align-items:center;gap:.8rem;background:var(--panel);border:1px solid var(--line);border-radius:var(--r-md);padding:1rem 1.2rem;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s,border-color .2s}
.other:hover{transform:translateY(-3px);box-shadow:var(--shadow);border-color:var(--line-2)}
.other__ic{width:42px;height:42px;border-radius:12px;display:grid;place-items:center;background:var(--primary-soft);color:var(--primary);flex:none}
.other__ic svg{width:22px;height:22px}
.other b{font-family:var(--font-d);font-weight:600;font-size:.98rem;color:var(--ink);flex:1}
.other__go{color:var(--primary)}
.other__go svg{width:18px;height:18px;transition:transform .2s}
.other:hover .other__go svg{transform:translateX(3px)}

@media(max-width:980px){
  .svc-intro{grid-template-columns:1fr}
  .svc-proc{grid-template-columns:repeat(2,1fr)}
  .svc-ben,.svc-other{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  .svc-proc,.svc-ben,.svc-other{grid-template-columns:1fr}
}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .hero__grid,.porque__grid,.faq__grid,.corpo__grid{grid-template-columns:1fr}
  .corpo__intro,.faq__intro{position:static}
  .hero__visual{order:-1}
  .marc{grid-template-columns:1fr}
  .svc-grid,.depo-grid,.team-grid,.statband__grid{grid-template-columns:repeat(2,1fr)}
  .footer__top{grid-template-columns:1fr 1fr}
}
@media(max-width:680px){
  :root{--r-page:26px}
  .nav__links{position:fixed;inset:74px 0 auto 0;flex-direction:column;align-items:stretch;gap:0;background:var(--panel);border-bottom:1px solid var(--line);padding:.5rem 1.5rem 1.2rem;transform:translateY(-150%);transition:transform .3s;z-index:30}
  .nav.open .nav__links{transform:none}
  .nav__links a{padding:.9rem 0;border-bottom:1px solid var(--line)}
  .nav__links a::after{display:none}
  .burger{display:flex}
  .nav__book{display:none}
  .nav.open .burger span:nth-child(1){transform:translateY(6px) rotate(45deg)}
  .nav.open .burger span:nth-child(2){opacity:0}
  .nav.open .burger span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}
  .svc-grid,.depo-grid,.team-grid,.statband__grid{grid-template-columns:1fr}
  .footer__top{grid-template-columns:1fr}
  .field-row,.choices--2{grid-template-columns:1fr}
  .modal{align-items:stretch}
  .modal__panel{border-radius:0;max-height:100vh}
  .chip--a{left:0}.chip--b{right:0}
}
