/* ===================================================================
   LUSOCARE — Imagiologia Dentária Digital
   Folha de estilos premium · responsiva · funciona offline
   =================================================================== */

:root{
  --ink:#0b1a30;
  --ink-2:#102c4d;
  --ink-3:#0e2745;
  --blue:#1f6fc0;
  --blue-2:#2f88d4;
  --blue-soft:#e8f1fb;
  --gold:#c8a24a;
  --gold-2:#dcbd72;
  --green:#1faf5a;
  --green-2:#168f49;
  --bg:#ffffff;
  --soft:#e4ecf6;
  --soft-2:#dae5f1;
  --text:#152031;
  --muted:#52617a;
  --line:#dde5ef;
  --card:#ffffff;
  --radius:18px;
  --radius-sm:12px;
  --maxw:1200px;
  --shadow:0 24px 50px -28px rgba(11,26,48,.42);
  --shadow-sm:0 12px 30px -18px rgba(11,26,48,.28);
  --font:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,"Helvetica Neue",Arial,"Noto Sans",sans-serif;
}

*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%}
body{
  font-family:var(--font);
  color:var(--text);
  background:var(--bg);
  line-height:1.65;
  font-size:16.5px;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
  text-rendering:optimizeLegibility;
  font-feature-settings:"kern","liga","clig";
  overflow-x:hidden;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit;text-decoration:none}
ul{list-style:none}
h1,h2,h3,h4{font-weight:800;color:var(--ink);letter-spacing:-.022em;text-wrap:balance}
h1{font-size:clamp(2.05rem,1.2rem + 2.8vw,3.2rem);line-height:1.08}
h2{font-size:clamp(1.55rem,1.05rem + 1.8vw,2.3rem);line-height:1.15;letter-spacing:-.025em}
h3{font-size:1.28rem;line-height:1.25;letter-spacing:-.016em}
p{color:var(--text)}
strong{font-weight:700}
:focus-visible{outline:3px solid var(--blue-2);outline-offset:2px;border-radius:4px}

.wrap{max-width:var(--maxw);margin:0 auto;padding:0 24px;width:100%}

/* ---- skip link ---- */
.skip{position:absolute;left:-999px;top:0;background:var(--gold);color:var(--ink);
  padding:10px 18px;font-weight:700;z-index:200;border-radius:0 0 8px 0}
.skip:focus{left:0}

/* ---- announce bar ---- */
.announce{
  background:#06121f;color:#cdd9e8;font-size:13.2px;text-align:center;
  padding:9px 18px;letter-spacing:.01em;
}
.announce strong{color:#fff}
.announce a{color:var(--gold-2);font-weight:700;white-space:nowrap}
.announce a:hover{color:#fff}

/* ===================================================================
   HEADER / NAV  (cabeçalho branco)
   =================================================================== */
.topbar{
  position:sticky;top:0;z-index:120;
  background:rgba(255,255,255,.97);
  backdrop-filter:saturate(150%) blur(9px);
  border-bottom:1px solid var(--line);
}
.nav{
  max-width:var(--maxw);margin:0 auto;padding:0 24px;
  display:flex;align-items:center;justify-content:space-between;
  min-height:80px;position:relative;
}
.brand{display:flex;align-items:center;gap:11px}
.brand img{height:52px;width:auto}
.brand span{display:none}
.navtoggle{display:none}
.hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:9px;
  border-radius:9px;border:1px solid var(--line)}
.hamburger span{width:22px;height:2.4px;background:var(--ink);border-radius:2px;transition:.25s}
.navtoggle:checked ~ .hamburger span:nth-child(1){transform:translateY(7.4px) rotate(45deg)}
.navtoggle:checked ~ .hamburger span:nth-child(2){opacity:0}
.navtoggle:checked ~ .hamburger span:nth-child(3){transform:translateY(-7.4px) rotate(-45deg)}

.navlinks{display:flex;align-items:center;gap:5px}
.navlinks a{
  color:var(--text);font-size:14.6px;font-weight:600;padding:9px 13px;border-radius:9px;
  transition:.18s;
}
.navlinks a:hover{color:var(--blue);background:var(--soft)}
.navlinks a.active{color:var(--blue)}
.navlinks a.active:not(.navcta){box-shadow:inset 0 -2px 0 var(--gold)}
.navcta{
  background:linear-gradient(180deg,var(--gold-2),var(--gold));
  color:var(--ink)!important;font-weight:800;margin-left:8px;
  padding:10px 18px!important;border-radius:999px;
}
.navcta:hover{filter:brightness(1.06)}

/* ===================================================================
   BUTTONS
   =================================================================== */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:9px;
  font-weight:700;font-size:15px;line-height:1;cursor:pointer;
  padding:15px 28px;border-radius:999px;border:1.7px solid transparent;
  transition:transform .15s,box-shadow .2s,filter .2s,background .2s;
  white-space:nowrap;text-align:center;
}
.btn svg{width:18px;height:18px;flex:none}
.btn:hover{transform:translateY(-2px)}
.btn:active{transform:translateY(0)}
.btn.gold{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:var(--ink);
  box-shadow:0 12px 26px -14px rgba(200,162,74,.9)}
.btn.gold:hover{filter:brightness(1.07)}
.btn.green{background:linear-gradient(180deg,#28c06a,var(--green));color:#fff;
  box-shadow:0 12px 26px -14px rgba(31,175,90,.85)}
.btn.green:hover{filter:brightness(1.06)}
.btn.blue{background:linear-gradient(180deg,var(--blue-2),var(--blue));color:#fff;
  box-shadow:0 12px 26px -14px rgba(31,111,192,.85)}
.btn.blue:hover{filter:brightness(1.07)}
.btn.ghost{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.34);color:#fff}
.btn.ghost:hover{background:rgba(255,255,255,.14)}
.btn.outline{background:#fff;border-color:var(--line);color:var(--ink)}
.btn.outline:hover{border-color:var(--blue-2);color:var(--blue)}
.btn.white{background:#fff;color:var(--ink)}
.btn.white:hover{filter:brightness(.97)}
.btn.sm{padding:11px 17px;font-size:13.6px}

/* ===================================================================
   HERO
   =================================================================== */
.hero{
  background:
    radial-gradient(900px 460px at 82% 8%,rgba(47,136,212,.32),transparent 60%),
    radial-gradient(700px 500px at 6% 100%,rgba(31,111,192,.26),transparent 60%),
    linear-gradient(160deg,var(--ink) 0%,var(--ink-2) 64%,var(--ink-3) 100%);
  color:#fff;padding:74px 0 84px;position:relative;
}
.hero-inner{
  max-width:var(--maxw);margin:0 auto;padding:0 24px;
  display:grid;grid-template-columns:1.06fr .94fr;gap:48px;align-items:center;
}
.hero.compact{padding:56px 0 62px}
.hero .eyebrow{
  display:inline-block;font-size:12.5px;font-weight:800;letter-spacing:.15em;
  text-transform:uppercase;color:var(--gold-2);
  background:rgba(200,162,74,.12);border:1px solid rgba(200,162,74,.32);
  padding:7px 14px;border-radius:999px;margin-bottom:18px;
}
.hero h1{color:#fff}
.hero .lead{
  color:#c7d4e6;font-size:clamp(1.02rem,.95rem + .35vw,1.18rem);
  margin-top:17px;max-width:600px;line-height:1.62;
}
.hero .cta{margin-top:26px}
.cta{display:flex;flex-wrap:wrap;gap:12px}
.cta.center{justify-content:center}

/* hero — homepage com banner */
.hero-home{
  padding:0;min-height:clamp(440px,46vw,560px);
  display:flex;align-items:center;
  background:
    linear-gradient(95deg,rgba(8,17,30,.96) 0%,rgba(8,17,30,.90) 33%,rgba(8,17,30,.60) 62%,rgba(8,17,30,.34) 100%),
    url("../images/img-hero-clinica.webp") right center/cover no-repeat,
    var(--ink);
}
.hero-home .hero-inner{
  grid-template-columns:1fr;max-width:100%;
  padding:54px 24px 54px clamp(20px,2.6vw,44px);
}
.hero-home .hero-text{max-width:600px}

/* trust row */
.trust{
  display:grid;grid-template-columns:repeat(3,1fr);gap:14px;margin-top:32px;
  max-width:600px;
}
.trust div{
  background:rgba(255,255,255,.055);border:1px solid rgba(255,255,255,.11);
  border-radius:var(--radius-sm);padding:13px 14px;
}
.trust strong{display:block;color:#fff;font-size:14.5px;margin-bottom:2px}
.trust span{color:#9fb2c8;font-size:12.4px;line-height:1.45}

/* hero card */
.hero-card{
  background:rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.12);
  border-radius:var(--radius);padding:14px;box-shadow:var(--shadow);
}
.image-frame{border-radius:12px;overflow:hidden}
.image-frame img{width:100%;aspect-ratio:4/3;object-fit:cover}
.hero-card .caption{
  display:flex;flex-direction:column;padding:13px 6px 5px;
}
.hero-card .caption b{color:#fff;font-size:15px}
.hero-card .caption span{color:#9fb2c8;font-size:13px}

/* ===================================================================
   STAT BAND
   =================================================================== */
.statband{background:var(--ink-2);border-top:1px solid rgba(255,255,255,.07)}
.grid-stats{
  max-width:var(--maxw);margin:0 auto;padding:30px 24px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:14px;
}
.stat{text-align:center;padding:10px 12px;position:relative}
.stat + .stat::before{
  content:"";position:absolute;left:0;top:18%;height:64%;width:1px;
  background:rgba(255,255,255,.12);
}
.stat .num{
  font-size:clamp(1.75rem,1.2rem + 1.3vw,2.3rem);font-weight:800;
  color:#fff;letter-spacing:-.02em;line-height:1.1;
}
.stat .lbl{color:#aebfd6;font-size:13px;margin-top:5px;line-height:1.4}

/* ===================================================================
   SECTIONS
   =================================================================== */
.section{padding:86px 0}
.section.soft{background:var(--soft)}
.section.darkband{
  background:
    radial-gradient(800px 400px at 85% 0%,rgba(47,136,212,.26),transparent 62%),
    linear-gradient(160deg,var(--ink),var(--ink-2));
  color:#fff;
}
.section-title{max-width:740px;margin:0 auto 50px;text-align:center}
.section-title .kicker{
  display:inline-block;font-size:12px;font-weight:800;letter-spacing:.18em;
  text-transform:uppercase;color:var(--blue);margin-bottom:13px;
}
.section.darkband .section-title .kicker{color:var(--gold-2)}
.section.darkband h2{color:#fff}
.section-title h2{margin-bottom:0}
.section-title p{color:var(--muted);margin-top:15px;font-size:1.06rem;line-height:1.6}
.section.darkband .section-title p{color:#c4d2e4}
.kicker{font-weight:800}

/* ===================================================================
   GRIDS / CARDS
   =================================================================== */
.split{display:grid;grid-template-columns:1fr 1fr;gap:30px}
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:28px}
.grid.two{grid-template-columns:1fr 1fr}
.grid.four{grid-template-columns:repeat(4,1fr)}

.card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);overflow:hidden;
  display:flex;flex-direction:column;transition:transform .2s,box-shadow .25s;
}
.card:hover{transform:translateY(-6px);box-shadow:var(--shadow);border-color:#c4d3e7}
.card > img{width:100%;aspect-ratio:16/10;object-fit:cover;transition:transform .5s ease}
.card > .tag,.card > h2,.card > h3,.card > p,.card > ul,.card > .stars,
.card > .who,.card > .icon,.card > .cta,.card > .badge{margin-left:22px;margin-right:22px}
.card > .tag,.card > .badge,.card > .icon{margin-top:20px}
.card > h2,.card > h3{margin-top:15px}
.card > p{margin-top:10px;color:var(--muted);font-size:15px;line-height:1.62}
.card > .cta{margin-top:auto;padding-top:18px;padding-bottom:22px}
.card > p:last-child{padding-bottom:22px}
.card > ul:last-child{padding-bottom:22px}
.card > .stars{margin-top:20px}

.tag,.badge{
  display:inline-block;align-self:flex-start;font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.07em;padding:6px 12px;border-radius:999px;
}
.tag{background:var(--blue-soft);color:var(--blue)}
.badge{background:linear-gradient(180deg,var(--gold-2),var(--gold));color:var(--ink)}

/* card with body wrapper (index locations) */
.card .body{padding:22px}
.card .body h2,.card .body h3{margin-bottom:8px}
.card .body > p{color:var(--muted);font-size:15px;margin-bottom:14px;line-height:1.62}
.card .body .badge{margin-bottom:12px}
/* cartoes de localizacao: nivelar morada/horario/botao entre os 2 cartoes */
.card.location .body{display:flex;flex-direction:column;flex:1}
.card.location .body .metalist{margin-top:auto}
.card.location .body .cta{margin-top:18px}

/* metalist */
.metalist{display:flex;flex-direction:column;gap:9px}
.metalist li{
  display:flex;gap:10px;align-items:flex-start;font-size:14px;color:var(--text);
}
.metalist li svg{width:19px;height:19px;flex:none;color:var(--blue-2);margin-top:2px}
.metalist li a{color:var(--blue);font-weight:600}

/* ===================================================================
   FEATURE (media + texto)
   =================================================================== */
.feature{
  display:grid;grid-template-columns:1fr 1.06fr;gap:62px;align-items:center;
}
.feature + .feature{margin-top:84px}
.feature.rev .feat-media{order:2}
.feat-media{position:relative;border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow)}
.feat-media img{
  width:100%;aspect-ratio:4/3;object-fit:cover;display:block;
  transition:transform .55s ease;
}
.feature .kicker{display:inline-block;margin-bottom:12px}
.feature h3{font-size:clamp(1.35rem,1.1rem + .8vw,1.68rem);margin:0 0 14px}
.feature p{color:var(--muted);line-height:1.7}
.section.darkband .feature h3{color:#fff}
.section.darkband .feature p{color:#c4d2e4}
.feature .cta{margin-top:26px}

/* checklist */
.checklist{display:flex;flex-direction:column;gap:13px;margin-top:18px}
.checklist li{display:flex;gap:12px;align-items:flex-start;font-size:15px;line-height:1.5}
.checklist li svg{
  width:24px;height:24px;flex:none;padding:4px;border-radius:50%;
  background:var(--blue-soft);color:var(--blue);
}
.section.darkband .checklist li svg{background:rgba(47,136,212,.22);color:#9fd0f5}

/* ===================================================================
   PROCESS / STEPS
   =================================================================== */
.process{
  display:grid;grid-template-columns:repeat(4,1fr);gap:20px;counter-reset:step;
}
.process.five{grid-template-columns:repeat(5,1fr)}
.step{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px 20px 22px;counter-increment:step;position:relative;
  box-shadow:var(--shadow-sm);
}
.step::before{
  content:counter(step);display:flex;align-items:center;justify-content:center;
  width:42px;height:42px;border-radius:12px;font-weight:800;font-size:18px;
  color:#fff;background:linear-gradient(180deg,var(--blue-2),var(--blue));
  margin-bottom:14px;box-shadow:0 10px 20px -10px rgba(31,111,192,.8);
}
.step h3{font-size:1.06rem;margin-bottom:5px}
.step p{color:var(--muted);font-size:14px;line-height:1.55}

/* ===================================================================
   RATING BAND / QUOTES
   =================================================================== */
.rating-band{
  display:flex;align-items:center;justify-content:center;gap:38px;flex-wrap:wrap;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:30px 34px;margin-bottom:34px;
}
.big{font-size:3.2rem;font-weight:800;color:var(--ink);line-height:1}
.stars{color:var(--gold);letter-spacing:2px;font-size:17px}
.src{color:var(--muted);font-size:13px;margin-top:4px}
.divider-v{width:1px;align-self:stretch;background:var(--line)}

.card.quote{padding:24px 22px}
.card.quote .stars{margin:0 0 10px}
.card.quote p{color:var(--text);font-size:15px;font-style:italic;margin:0 0 16px;line-height:1.62}
.who{display:flex;align-items:center;gap:12px;margin:0}
.avatar{
  width:44px;height:44px;border-radius:50%;flex:none;
  display:flex;align-items:center;justify-content:center;font-weight:800;color:#fff;
  background:linear-gradient(150deg,var(--blue-2),var(--ink-2));
}
.who b{display:block;font-size:14.5px;color:var(--ink)}
.who span{font-size:12.5px;color:var(--muted)}

/* ===================================================================
   EXAM LIST
   =================================================================== */
.exam-list{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.exam{
  display:flex;gap:18px;align-items:flex-start;
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  padding:26px;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .25s;
}
.exam:hover{transform:translateY(-4px);box-shadow:var(--shadow);border-color:#c4d3e7}
.exam .icon{
  width:50px;height:50px;flex:none;border-radius:13px;
  display:flex;align-items:center;justify-content:center;
  background:linear-gradient(160deg,var(--blue-soft),#dfeafa);color:var(--blue);
}
.exam .icon svg{width:26px;height:26px}
.exam h3{font-size:1.08rem;margin-bottom:6px}
.exam p{color:var(--muted);font-size:14px;line-height:1.62}
.where{
  display:inline-block;margin-top:8px;font-size:11.5px;font-weight:800;
  text-transform:uppercase;letter-spacing:.06em;
  background:var(--blue-soft);color:var(--blue);padding:4px 10px;border-radius:999px;
}

/* generic .icon block (cards sobre / preparação) */
.icon{display:inline-flex;align-items:center;justify-content:center}
.card .icon{
  width:52px;height:52px;border-radius:13px;
  background:linear-gradient(160deg,var(--blue-soft),#dfeafa);color:var(--blue);
}
.card .icon svg{width:26px;height:26px}

/* ===================================================================
   SEALS
   =================================================================== */
.seals{display:grid;grid-template-columns:repeat(4,1fr);gap:22px}
.seal{
  text-align:center;background:var(--card);border:1px solid var(--line);
  border-radius:var(--radius);padding:28px 18px;box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;align-items:center;
}
.seal svg{
  width:54px;height:54px;padding:12px;border-radius:14px;
  background:linear-gradient(160deg,var(--blue-soft),#dfeafa);color:var(--blue);
  margin-bottom:13px;
}
.seal b{font-size:15px;color:var(--ink);margin-bottom:3px}
.seal span{font-size:13px;color:var(--muted);line-height:1.5}

/* ===================================================================
   FAQ
   =================================================================== */
.faq{max-width:820px;margin:0 auto;display:flex;flex-direction:column;gap:12px}
.faq details{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius-sm);
  box-shadow:var(--shadow-sm);overflow:hidden;
}
.faq summary{
  cursor:pointer;list-style:none;padding:17px 52px 17px 20px;position:relative;
  font-weight:700;color:var(--ink);font-size:15.5px;
}
.faq summary::-webkit-details-marker{display:none}
.faq summary::after{
  content:"+";position:absolute;right:20px;top:50%;transform:translateY(-50%);
  font-size:22px;font-weight:400;color:var(--blue);line-height:1;transition:.2s;
}
.faq details[open] summary::after{content:"\2212";color:var(--gold)}
.faq details[open] summary{color:var(--blue)}
.faq p{padding:0 20px 18px;color:var(--muted);font-size:14.6px;line-height:1.6}

/* ===================================================================
   CONTACTOS
   =================================================================== */
.contact-grid{display:grid;grid-template-columns:1fr 1fr;gap:28px}
.contact-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);overflow:hidden;display:flex;flex-direction:column;
}
.contact-card .head{
  padding:20px 22px;color:#fff;
  background:linear-gradient(150deg,var(--ink),var(--ink-2));
}
.contact-card .head h3{color:#fff;font-size:1.2rem}
.contact-card .head span{font-size:12.5px;color:#9fb4cd}
.clinic-photo{width:100%;aspect-ratio:16/9;object-fit:cover}
.mapframe{width:100%;height:220px;border:0;display:block;background:var(--soft)}
.contact-card .body{padding:22px;display:flex;flex-direction:column;gap:16px}
.hours{display:flex;flex-direction:column;gap:0;border-top:1px solid var(--line)}
.hours li{
  display:flex;justify-content:space-between;font-size:14px;
  padding:8px 0;border-bottom:1px solid var(--line);
}
.hours li span:first-child{color:var(--muted)}
.hours li span:last-child{font-weight:700;color:var(--ink)}
.hours li.closed span:last-child{color:#c0392b;font-weight:600}

/* ===================================================================
   FORM
   =================================================================== */
.form{
  max-width:760px;margin:0 auto;background:var(--card);
  border:1px solid var(--line);border-radius:var(--radius);
  box-shadow:var(--shadow-sm);padding:28px;
}
.form .row{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}
.field{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}
.field label{font-size:13.5px;font-weight:700;color:var(--ink)}
.field input,.field select,.field textarea{
  font-family:inherit;font-size:15px;color:var(--text);
  border:1.6px solid var(--line);border-radius:10px;padding:12px 13px;background:#fbfcfe;
  transition:border-color .18s,box-shadow .18s;width:100%;
}
.field textarea{min-height:108px;resize:vertical}
.field input:focus,.field select:focus,.field textarea:focus{
  outline:none;border-color:var(--blue-2);box-shadow:0 0 0 4px rgba(47,136,212,.13);
}
.form .cta{margin-top:6px}
.note{font-size:12.6px;color:var(--muted);margin-top:14px;line-height:1.55}

/* editnote */
.editnote{
  max-width:820px;margin:24px auto 0;font-size:13px;color:var(--muted);
  background:#fff8e8;border:1px solid #f0e0b8;border-left:3px solid var(--gold);
  border-radius:8px;padding:12px 16px;line-height:1.55;
}
.section.darkband .editnote{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.15);color:#cdd9e8}

/* ===================================================================
   FOOTER
   =================================================================== */
.footer{background:#081320;color:#aab9cc;padding:58px 0 0}
.footer-grid{
  max-width:var(--maxw);margin:0 auto;padding:0 24px 44px;
  display:grid;grid-template-columns:1.5fr 1fr 1fr 1.4fr;gap:34px;
}
.fbrand img{height:54px;margin-bottom:14px}
.footer-grid > div > p{font-size:13.6px;line-height:1.6;color:#93a3b8}
.footer h4{
  color:#fff;font-size:13px;text-transform:uppercase;letter-spacing:.1em;
  margin-bottom:14px;
}
.footer-grid a{display:block;font-size:13.8px;color:#aab9cc;padding:3.5px 0;transition:.16s}
.footer-grid a:hover{color:var(--gold-2)}
.footer-grid a[style*="inline"]{padding:0}
.social{display:flex;gap:10px;margin-top:14px}
.social a{
  width:38px;height:38px;border-radius:10px;display:flex;align-items:center;
  justify-content:center;background:rgba(255,255,255,.07);
  border:1px solid rgba(255,255,255,.1);padding:0;
}
.social a svg{width:18px;height:18px;color:#cdd9e8}
.social a:hover{background:var(--gold);border-color:var(--gold)}
.social a:hover svg{color:var(--ink)}
.footer-bottom{
  border-top:1px solid rgba(255,255,255,.08);
  max-width:var(--maxw);margin:0 auto;padding:18px 24px;
  display:flex;justify-content:space-between;gap:14px;flex-wrap:wrap;
  font-size:12.3px;color:#7e8ea3;
}

/* ===================================================================
   FLOATING WHATSAPP / STICKY CTA
   =================================================================== */
.wa-float{
  position:fixed;right:18px;bottom:18px;z-index:90;
  width:56px;height:56px;border-radius:50%;
  background:linear-gradient(180deg,#28c06a,var(--green));
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 14px 30px -10px rgba(31,175,90,.8);
  animation:wapulse 2.6s infinite;
}
.wa-float svg{width:30px;height:30px;color:#fff}
@keyframes wapulse{
  0%,100%{box-shadow:0 14px 30px -10px rgba(31,175,90,.8)}
  50%{box-shadow:0 14px 30px -10px rgba(31,175,90,.8),0 0 0 12px rgba(31,175,90,.12)}
}

.sticky-cta{
  display:none;position:fixed;left:0;right:0;bottom:0;z-index:95;
  background:rgba(9,19,33,.98);border-top:1px solid rgba(255,255,255,.1);
  padding:9px 12px;gap:8px;
}
.sticky-cta .btn{flex:1;padding:12px 8px}

/* ===================================================================
   REVEAL (animação ao scroll — só ativa com JS)
   =================================================================== */
.js .reveal{opacity:0;transform:translateY(24px);transition:opacity .6s ease,transform .6s ease}
.js .reveal.in{opacity:1;transform:none}
@media (prefers-reduced-motion:reduce){
  .js .reveal{opacity:1;transform:none;transition:none}
  html{scroll-behavior:auto}
}

/* ===================================================================
   RESPONSIVO
   =================================================================== */
@media (max-width:1000px){
  .grid.four{grid-template-columns:repeat(2,1fr)}
  .process,.process.five{grid-template-columns:repeat(2,1fr)}
  .seals{grid-template-columns:repeat(2,1fr)}
  .footer-grid{grid-template-columns:1fr 1fr;gap:30px}
}
@media (max-width:960px){
  .hamburger{display:flex}
  .navlinks{
    display:none;position:absolute;top:100%;left:0;right:0;
    flex-direction:column;align-items:stretch;gap:2px;
    background:#fff;border-top:1px solid var(--line);
    padding:14px;box-shadow:0 26px 44px -20px rgba(11,26,48,.30);
  }
  .navtoggle:checked ~ .navlinks{display:flex}
  .navlinks a{padding:13px 14px;border-radius:10px;font-size:15.5px}
  .navlinks a.active:not(.navcta){box-shadow:none;background:var(--soft)}
  .navcta{margin-left:0;margin-top:6px;text-align:center}
  .hero-inner{grid-template-columns:1fr;gap:34px}
  .hero-card{order:-1}
  .hero-home .hero-card{display:none}
  .feature{grid-template-columns:1fr;gap:34px}
  .feature.rev .feat-media{order:0}
  .split,.grid,.grid.two,.exam-list,.contact-grid{grid-template-columns:1fr}
  .grid{gap:22px}
}
@media (max-width:760px){
  .section{padding:58px 0}
  .grid-stats{grid-template-columns:1fr 1fr;gap:8px;padding:24px 16px}
  .stat:nth-child(3)::before{display:none}
  .form .row{grid-template-columns:1fr;gap:0}
  .rating-band{gap:22px;padding:24px}
  .divider-v{display:none}
  .footer-grid{grid-template-columns:1fr}
  .footer-bottom{flex-direction:column;text-align:center}
  .sticky-cta{display:flex}
  .wa-float{bottom:74px}
}
@media (max-width:480px){
  .grid.four{grid-template-columns:1fr}
  .process,.process.five,.seals{grid-template-columns:1fr}
  .trust{grid-template-columns:1fr}
  .hero .cta .btn,.cta.center .btn{flex:1 1 auto}
}

/* ---- micro-interacoes premium ---- */
.card:hover > img{transform:scale(1.055)}
.feature:hover .feat-media img{transform:scale(1.045)}
@media (prefers-reduced-motion:reduce){.card>img,.feat-media img{transition:none!important;transform:none!important}}
