/* ============================================================
   Dra. Jéssica Garofalo — Endocrinologia & Nutrição Veterinária
   Design system + page styles
   ============================================================ */

/* ---- Tokens ---- */
:root{
  --lilac-signature:#B294E8;
  --lilac-coat:#A98ACB;
  --lilac-vivid:#9B6FE8;
  --lilac-tint:#DBB1E7;
  --lilac-mist:#EDE3FA;
  --plum-ink:#2E2440;
  --plum-soft:#4A3D63;
  --cream:#FBF8F3;
  --white:#FFFFFF;
  --line:rgba(46,36,64,.12);
  --line-soft:rgba(46,36,64,.08);

  --serif:"Cormorant Garamond",Georgia,serif;
  --sans:"Hanken Grotesk",system-ui,-apple-system,sans-serif;
  --script:"Parisienne",cursive;

  --maxw:1240px;
  --gutter:clamp(20px,5vw,64px);
  --section-y:clamp(72px,11vw,140px);
  --radius:18px;
  --radius-sm:12px;
  --shadow-sm:0 1px 2px rgba(46,36,64,.04),0 8px 24px rgba(46,36,64,.06);
  --shadow-md:0 2px 6px rgba(46,36,64,.05),0 22px 48px rgba(46,36,64,.12);
  --ease:cubic-bezier(.2,.7,.2,1);
  --ease-out:cubic-bezier(.22,.61,.36,1);
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;-webkit-text-size-adjust:100%;}
@media (prefers-reduced-motion:reduce){html{scroll-behavior:auto;}}

body{
  margin:0;
  background:var(--cream);
  color:var(--plum-ink);
  font-family:var(--sans);
  font-size:clamp(16px,1.05vw,18px);
  line-height:1.7;
  font-weight:400;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{display:block;max-width:100%;}
a{color:inherit;text-decoration:none;}

/* ---- Layout ---- */
.wrap{max-width:var(--maxw);margin-inline:auto;padding-inline:var(--gutter);}
section{padding-block:var(--section-y);}
.lede{font-size:clamp(1.1rem,1.55vw,1.3rem);line-height:1.65;color:var(--plum-soft);max-width:62ch;}

/* ---- Type ---- */
h1,h2,h3{font-family:var(--serif);font-weight:500;line-height:1.05;letter-spacing:-.01em;margin:0;color:var(--plum-ink);text-wrap:balance;}
h1{font-size:clamp(2.6rem,5.6vw,4.6rem);}
h2{font-size:clamp(2rem,3.9vw,3.3rem);line-height:1.08;}
h3{font-size:clamp(1.4rem,2.1vw,1.85rem);}
.script{font-family:var(--script);font-weight:400;color:var(--lilac-coat);font-size:1.18em;line-height:.9;}

.eyebrow{
  display:inline-flex;align-items:center;gap:.7em;
  font-family:var(--sans);font-size:.72rem;font-weight:600;
  letter-spacing:.22em;text-transform:uppercase;
  color:var(--lilac-coat);margin:0 0 1.4rem;
}
.eyebrow::before{content:"";width:26px;height:1px;background:var(--lilac-coat);opacity:.6;}
.eyebrow.center{justify-content:center;}

/* ---- Buttons ---- */
.btn{
  display:inline-flex;align-items:center;gap:.6em;
  font-family:var(--sans);font-weight:600;font-size:.98rem;
  padding:.95em 1.5em;border-radius:999px;border:1px solid transparent;
  cursor:pointer;transition:transform .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease),color .2s var(--ease);
  line-height:1;white-space:nowrap;min-height:48px;
}
.btn svg{width:18px;height:18px;flex:none;}
.btn-primary{background:var(--plum-ink);color:var(--cream);box-shadow:0 10px 26px rgba(46,36,64,.35);}
.btn-primary:hover{background:var(--plum-soft);color:var(--white);transform:translateY(-2px);box-shadow:0 16px 34px rgba(46,36,64,.42);}
.btn-ghost{background:transparent;color:var(--plum-ink);border-color:var(--line);}
.btn-ghost:hover{border-color:var(--plum-ink);background:rgba(46,36,64,.05);transform:translateY(-2px);}
.btn-light{background:var(--cream);color:var(--plum-ink);}
.btn-light:hover{background:var(--white);transform:translateY(-2px);box-shadow:0 16px 34px rgba(0,0,0,.18);}

.txtlink{display:inline-flex;align-items:center;gap:.5em;font-weight:600;color:var(--plum-ink);border-bottom:1px solid var(--line);padding-bottom:.2em;transition:gap .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);}
.txtlink:hover{color:var(--lilac-vivid);border-color:var(--lilac-coat);gap:.75em;}

/* ---- Cards ---- */
.card{
  background:var(--white);border:1px solid var(--line-soft);border-radius:var(--radius);
  padding:clamp(1.6rem,2.4vw,2.4rem);box-shadow:var(--shadow-sm);
  transition:transform .25s var(--ease),box-shadow .25s var(--ease);
}
.card:hover{transform:translateY(-4px);box-shadow:var(--shadow-md);}

/* ---- Photo treatments ---- */
.framed{border-radius:var(--radius);overflow:hidden;box-shadow:var(--shadow-md);}
.framed img{width:100%;height:100%;object-fit:cover;}
/* soft lilac duotone for secondary photos */
.duotone{position:relative;isolation:isolate;}
.duotone img{filter:grayscale(.62) contrast(1.04) brightness(1.02);}
.duotone::after{content:"";position:absolute;inset:0;background:linear-gradient(155deg,rgba(178,148,232,.42),rgba(219,177,231,.18) 60%,rgba(251,248,243,.12));mix-blend-mode:multiply;z-index:1;}
.duotone::before{content:"";position:absolute;inset:0;background:var(--lilac-mist);mix-blend-mode:screen;opacity:.35;z-index:1;}

/* ============================================================
   NAV
   ============================================================ */
.nav{position:fixed;inset:0 0 auto 0;z-index:60;transition:padding .3s var(--ease),background .3s var(--ease),box-shadow .3s var(--ease),backdrop-filter .3s var(--ease);}
.nav-inner{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:1.5rem;padding-block:clamp(1.2rem,2.2vw,1.9rem);transition:padding .3s var(--ease);}
.nav.scrolled{background:rgba(251,248,243,.82);backdrop-filter:saturate(140%) blur(14px);box-shadow:0 1px 0 var(--line-soft),0 8px 30px rgba(46,36,64,.06);}
.nav.scrolled .nav-inner{padding-block:.6rem;}
.brand{justify-self:center;display:flex;align-items:center;}
.brand img{height:clamp(58px,6.4vw,96px);width:auto;transition:height .3s var(--ease);}
.nav.scrolled .brand img{height:40px;}
.nav-left{justify-content:flex-start;}
.nav-right{justify-content:flex-end;}
.nav-links{display:flex;align-items:center;gap:clamp(1rem,1.9vw,1.9rem);}
.nav-links a{font-size:1rem;font-weight:500;color:var(--plum-soft);letter-spacing:.005em;padding:.55em .95em;border-radius:999px;transition:color .2s var(--ease),background .25s var(--ease);}
.nav-links a:hover{color:var(--plum-ink);background:var(--lilac-mist);}
.nav-toggle{display:none;background:none;border:none;cursor:pointer;padding:8px;color:var(--plum-ink);}
.nav-toggle svg{width:26px;height:26px;}

/* mobile menu */
.mobile-menu{position:fixed;inset:0;z-index:80;background:var(--cream);transform:translateY(-100%);opacity:0;visibility:hidden;transition:transform .4s var(--ease),opacity .3s var(--ease),visibility .3s;display:flex;flex-direction:column;padding:clamp(18px,5vw,28px);}
.mobile-menu.open{transform:translateY(0);opacity:1;visibility:visible;}
.mm-head{display:flex;align-items:center;justify-content:space-between;padding-bottom:1.1rem;border-bottom:1px solid var(--line-soft);}
.mm-logo{height:44px;width:auto;}
.mobile-close{background:var(--white);border:1px solid var(--line);border-radius:50%;width:46px;height:46px;display:grid;place-items:center;cursor:pointer;color:var(--plum-ink);box-shadow:var(--shadow-sm);transition:background .2s var(--ease);}
.mobile-close:hover{background:var(--lilac-mist);}
.mobile-close svg{width:22px;height:22px;}
.mm-links{display:flex;flex-direction:column;margin-top:1.6rem;}
.mm-links a{font-family:var(--serif);font-size:clamp(1.7rem,7vw,2.15rem);font-weight:500;color:var(--plum-ink);padding:.6em 0;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:1rem;transition:color .2s var(--ease),padding-left .25s var(--ease);}
.mm-links a::after{content:"→";font-family:var(--sans);font-size:1.05rem;color:var(--lilac-coat);opacity:.55;transition:transform .25s var(--ease);}
.mm-links a:hover,.mm-links a:active{color:var(--lilac-vivid);padding-left:.45rem;}
.mm-links a:hover::after{transform:translateX(4px);}
.mm-cta{margin-top:auto;display:flex;align-items:center;justify-content:center;gap:.65rem;background:var(--plum-ink);color:var(--cream);font-family:var(--sans);font-weight:600;font-size:1.02rem;line-height:1;padding:1.1rem 1.5rem;border-radius:999px;box-shadow:0 10px 26px rgba(46,36,64,.3);min-height:54px;}
.mm-cta svg{width:22px;height:22px;flex:none;}

/* ============================================================
   HERO
   ============================================================ */
.hero{padding-top:clamp(120px,16vw,170px);position:relative;overflow:hidden;}
.hero-particles{position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:1;}
.hero .wrap{position:relative;z-index:2;}
.hero-grid{display:grid;grid-template-columns:1.02fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.hero-copy{max-width:38rem;}
.hero h1{margin-bottom:1.5rem;}
.hero h1 em{font-style:normal;font-family:var(--script);color:var(--lilac-coat);font-weight:400;}
.hero-sub{font-size:clamp(1.05rem,1.4vw,1.22rem);color:var(--plum-soft);line-height:1.6;max-width:34rem;margin-bottom:2.2rem;}
.hero-actions{display:flex;align-items:center;gap:1.4rem;flex-wrap:wrap;margin-bottom:2.4rem;}
.cred-strip{display:flex;flex-wrap:wrap;align-items:center;gap:.6rem 1.1rem;font-size:.92rem;color:var(--plum-soft);}
.cred-strip span{display:inline-flex;align-items:center;gap:1.1rem;}
.cred-strip span+span::before{content:"";width:5px;height:5px;border-radius:50%;background:var(--lilac-coat);}
.hero-photo{position:relative;}
.hero-photo .framed{aspect-ratio:4/4.7;}
.hero-photo .framed img{will-change:transform;object-position:50% 100%;}
.hero-badge{position:absolute;right:-18px;bottom:34px;background:var(--white);border-radius:16px;padding:1rem 1.25rem;box-shadow:var(--shadow-md);display:flex;align-items:center;gap:.85rem;max-width:235px;border:1px solid var(--line-soft);}
.hero-badge .dot{width:42px;height:42px;border-radius:50%;background:var(--lilac-mist);display:grid;place-items:center;flex:none;color:var(--lilac-vivid);}
.hero-badge .dot svg{width:22px;height:22px;}
.hero-badge .bt{display:flex;flex-direction:column;min-width:0;}
.hero-badge b{font-family:var(--serif);font-size:1.05rem;font-weight:600;display:block;line-height:1.15;}
.hero-badge small{font-size:.78rem;color:var(--plum-soft);line-height:1.3;display:block;margin-top:2px;}
.hero-blob{position:absolute;border-radius:50%;background:radial-gradient(circle,rgba(178,148,232,.42),transparent 70%);filter:blur(50px);z-index:-1;}

/* ============================================================
   WHY / EDITORIAL
   ============================================================ */
.why-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,6vw,6rem);align-items:start;}
.why-grid h2{margin-bottom:0;}
.feature-row{display:grid;gap:1.4rem;margin-top:2.6rem;}
.feature{display:flex;gap:1.1rem;align-items:flex-start;padding-bottom:1.4rem;border-bottom:1px solid var(--line-soft);}
.feature:last-child{border-bottom:none;padding-bottom:0;}
.feature .num{font-family:var(--serif);font-size:1.5rem;color:var(--lilac-coat);line-height:1;flex:none;width:1.6em;}
.feature b{font-family:var(--serif);font-size:1.25rem;font-weight:600;display:block;margin-bottom:.15rem;}
.feature p{margin:0;font-size:.96rem;color:var(--plum-soft);}

/* ============================================================
   ESPECIALIDADES
   ============================================================ */
.section-head{max-width:46rem;margin-bottom:clamp(2.4rem,4vw,3.6rem);}
.section-head.center{margin-inline:auto;text-align:center;}
.spec-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;}
.spec-card{display:flex;flex-direction:column;gap:1.1rem;}
.spec-icon{width:58px;height:58px;border-radius:14px;background:var(--lilac-mist);display:grid;place-items:center;color:var(--lilac-vivid);}
.spec-icon svg{width:30px;height:30px;}
.spec-card h3{margin-bottom:0;}
.spec-card p{margin:0;color:var(--plum-soft);flex:1;}
.spec-card .txtlink{align-self:flex-start;margin-top:.4rem;font-size:.95rem;}

/* ============================================================
   ATENDIMENTO
   ============================================================ */
.atend{background:var(--lilac-mist);}
.format-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.6rem;margin-bottom:clamp(3rem,5vw,4.5rem);}
.format{background:var(--white);border-radius:var(--radius);padding:clamp(1.8rem,2.6vw,2.6rem);border:1px solid var(--line-soft);}
.format .tag{display:inline-block;font-size:.72rem;font-weight:600;letter-spacing:.14em;text-transform:uppercase;color:var(--lilac-vivid);background:var(--lilac-mist);padding:.4em .8em;border-radius:999px;margin-bottom:1rem;}
.format h3{margin-bottom:.7rem;}
.format p{margin:0;color:var(--plum-soft);}
.steps{display:grid;grid-template-columns:repeat(4,1fr);gap:1.4rem;counter-reset:step;}
.step{position:relative;}
.step .n{font-family:var(--serif);font-size:2.4rem;color:var(--lilac-coat);line-height:1;display:block;margin-bottom:.7rem;}
.step b{font-family:var(--serif);font-size:1.2rem;font-weight:600;display:block;margin-bottom:.4rem;}
.step p{margin:0;font-size:.92rem;color:var(--plum-soft);}
.step:not(:last-child)::after{content:"";position:absolute;top:1.1rem;right:-.7rem;width:1.4rem;height:1px;background:var(--line);}
.note-muted{margin-top:2.4rem;font-size:.9rem;color:var(--plum-soft);font-style:italic;display:flex;align-items:center;gap:.6rem;}
.note-muted::before{content:"";width:18px;height:1px;background:var(--lilac-coat);}

/* ============================================================
   SOBRE
   ============================================================ */
.sobre-grid{display:grid;grid-template-columns:.92fr 1.08fr;gap:clamp(2rem,5vw,4.5rem);align-items:center;}
.sobre-photo{position:relative;}
.sobre-collage{position:relative;aspect-ratio:4/4.7;}
.sobre-collage .ph{position:absolute;margin:0;overflow:hidden;border-radius:14px;box-shadow:var(--shadow-md);background:var(--cream);}
.sobre-collage .ph img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .7s var(--ease);}
.sobre-collage .ph:hover img{transform:scale(1.07);}
.sobre-collage .ph-1{left:0;top:0;width:60%;height:100%;z-index:1;}
.sobre-collage .ph-2{right:0;top:0;width:48%;height:48.5%;z-index:2;border:5px solid var(--cream);}
.sobre-collage .ph-3{right:0;bottom:0;width:48%;height:48.5%;z-index:2;border:5px solid var(--cream);}
.sobre-photo .accent-tag{position:absolute;left:-16px;bottom:30px;z-index:5;background:var(--plum-ink);color:var(--cream);border-radius:14px;padding:.9rem 1.2rem;box-shadow:var(--shadow-md);font-family:var(--serif);}
.sobre-photo .accent-tag b{font-size:1.7rem;display:block;line-height:1;}
.sobre-photo .accent-tag small{font-family:var(--sans);font-size:.72rem;letter-spacing:.04em;color:var(--lilac-tint);}
.sobre-body p{color:var(--plum-soft);max-width:46ch;}
.sobre-body .warm{color:var(--plum-ink);font-family:var(--serif);font-size:1.35rem;line-height:1.45;font-style:italic;border-left:2px solid var(--lilac-coat);padding-left:1.2rem;margin:2rem 0;}
.formacao{margin-top:2rem;}
.chips{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:1rem;}
.chip{font-size:.85rem;font-weight:500;padding:.5em 1em;border-radius:999px;background:var(--white);border:1px solid var(--line);color:var(--plum-ink);}

/* ============================================================
   COBERTURA
   ============================================================ */
.cobertura{background:var(--plum-ink);color:var(--cream);}
.cobertura .eyebrow{color:var(--lilac-tint);}
.cobertura .eyebrow::before{background:var(--lilac-tint);}
.cobertura h2{color:var(--cream);}
.cob-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(2rem,5vw,5rem);align-items:center;}
.cob-grid p{color:rgba(251,248,243,.72);max-width:42ch;}
.coverage-list{display:flex;flex-direction:column;border-top:1px solid rgba(251,248,243,.14);}
.coverage-item{display:flex;justify-content:space-between;align-items:baseline;padding:1.4rem 0;border-bottom:1px solid rgba(251,248,243,.14);gap:2rem;transition:padding-left .3s var(--ease);}
.coverage-item:hover{padding-left:.8rem;}
.coverage-item .city{font-family:var(--serif);font-size:clamp(1.6rem,2.6vw,2.2rem);font-weight:500;color:var(--cream);line-height:1;letter-spacing:-.01em;}
.coverage-item .meta{font-family:var(--sans);font-size:.82rem;letter-spacing:.08em;text-transform:uppercase;color:var(--lilac-tint);text-align:right;flex:none;}

/* ---- Coverage: itens clicáveis ---- */
.coverage-item{cursor:pointer;}
.coverage-item .cov-right{display:flex;align-items:center;gap:1.1rem;flex:none;}
.coverage-item .cov-chev{width:20px;height:20px;color:var(--lilac-tint);opacity:.65;flex:none;transition:transform .3s var(--ease),opacity .3s var(--ease);}
.coverage-item:hover .cov-chev,.coverage-item:focus-visible .cov-chev{transform:translateX(4px);opacity:1;}
.coverage-item:focus-visible{outline:none;padding-left:.8rem;}

/* ---- Bottom sheet — clínicas por cidade ---- */
body.sheet-lock{overflow:hidden;}
.sheet-overlay{position:fixed;inset:0;z-index:110;background:rgba(18,12,28,.62);opacity:0;transition:opacity .35s var(--ease);-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);}
.sheet-overlay.open{opacity:1;}
.sheet-overlay[hidden]{display:none;}
.bottom-sheet{position:fixed;left:50%;bottom:0;z-index:120;width:100%;max-width:640px;max-height:88vh;transform:translate(-50%,100%);background:var(--plum-ink);color:var(--cream);border:1px solid rgba(251,248,243,.12);border-bottom:none;border-radius:26px 26px 0 0;box-shadow:0 -24px 64px rgba(18,12,28,.5);display:flex;flex-direction:column;transition:transform .35s cubic-bezier(.22,.61,.36,1);}
.bottom-sheet.open{transform:translate(-50%,0);}
.bottom-sheet[hidden]{display:none;}
.sheet-handle{width:44px;height:5px;border-radius:99px;background:rgba(251,248,243,.28);margin:14px auto 2px;flex:none;}
.sheet-close{position:absolute;top:15px;right:16px;width:38px;height:38px;border-radius:50%;border:1px solid rgba(251,248,243,.18);background:transparent;color:var(--cream);display:grid;place-items:center;cursor:pointer;transition:background .2s var(--ease),border-color .2s var(--ease);}
.sheet-close:hover{background:rgba(251,248,243,.1);border-color:rgba(251,248,243,.32);}
.sheet-close svg{width:16px;height:16px;}
.sheet-head{padding:.7rem clamp(1.3rem,4vw,2rem) 1.1rem;border-bottom:1px solid rgba(251,248,243,.12);flex:none;}
.sheet-eyebrow{font-family:var(--sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--lilac-tint);margin:0 0 .35rem;font-weight:600;}
.sheet-title{font-family:var(--serif);font-size:clamp(1.8rem,4.4vw,2.4rem);font-weight:500;color:var(--cream);margin:0;line-height:1.05;}
.sheet-body{padding:.4rem clamp(1.3rem,4vw,2rem) clamp(1.6rem,5vw,2.2rem);overflow-y:auto;-webkit-overflow-scrolling:touch;}
.clinic{display:flex;align-items:center;justify-content:space-between;gap:1.2rem;padding:1.05rem 0;border-bottom:1px solid rgba(251,248,243,.1);}
.clinic:last-child{border-bottom:none;}
.clinic-info{min-width:0;}
.clinic-info b{display:block;font-family:var(--serif);font-size:1.24rem;font-weight:600;color:var(--cream);line-height:1.2;}
.clinic-info span{display:block;font-size:.9rem;line-height:1.45;color:rgba(251,248,243,.6);margin-top:3px;}
.clinic-wa{flex:none;display:inline-flex;align-items:center;gap:.42rem;padding:.5rem .9rem;border-radius:99px;background:transparent;border:1px solid rgba(178,148,232,.5);color:var(--lilac-tint);font-family:var(--sans);font-size:.82rem;font-weight:600;white-space:nowrap;transition:background .2s var(--ease),border-color .2s var(--ease),color .2s var(--ease),transform .15s var(--ease);}
.clinic-wa:hover{background:var(--lilac-signature);border-color:var(--lilac-signature);color:var(--plum-ink);transform:translateY(-1px);}
.clinic-wa svg{width:15px;height:15px;flex:none;}

/* ---- Item destacado: atendimento domiciliar ---- */
.coverage-item.is-home .city{display:flex;align-items:center;gap:.7rem;flex-wrap:wrap;color:var(--lilac-tint);}
.home-tag{font-family:var(--sans);font-size:.62rem;font-weight:700;letter-spacing:.16em;text-transform:uppercase;color:var(--plum-ink);background:var(--lilac-signature);padding:.32em .7em;border-radius:99px;line-height:1;align-self:center;}
.coverage-item.is-home:hover .city,.coverage-item.is-home:focus-visible .city{color:var(--cream);}

/* ---- Sub-grupo por zona dentro do sheet ---- */
.clinic-zone{font-family:var(--sans);font-size:.72rem;font-weight:700;letter-spacing:.18em;text-transform:uppercase;color:var(--lilac-tint);padding:1.1rem 0 .35rem;border-bottom:1px solid rgba(251,248,243,.1);margin-bottom:.2rem;}
.clinic-zone:first-child{padding-top:.35rem;}

/* ---- Formulário de atendimento domiciliar ---- */
.home-form{display:flex;flex-direction:column;gap:1.35rem;padding-top:.5rem;}
.home-intro{margin:0;font-size:.96rem;line-height:1.55;color:rgba(251,248,243,.72);}
.home-intro b{color:var(--cream);font-weight:600;}
.hf-field{display:flex;flex-direction:column;gap:.6rem;}
.hf-label{font-family:var(--sans);font-size:.78rem;font-weight:600;letter-spacing:.12em;text-transform:uppercase;color:var(--lilac-tint);}
.hf-input{font-family:var(--sans);font-size:1rem;color:var(--cream);background:rgba(251,248,243,.06);border:1px solid rgba(251,248,243,.2);border-radius:14px;padding:.85rem 1rem;line-height:1.45;resize:vertical;min-height:3.2rem;transition:border-color .2s var(--ease),background .2s var(--ease);}
.hf-input::placeholder{color:rgba(251,248,243,.4);}
.hf-input:focus{outline:none;border-color:var(--lilac-signature);background:rgba(251,248,243,.1);}
.hf-seg{display:grid;grid-template-columns:1fr 1fr;gap:.6rem;}
.hf-seg-3{grid-template-columns:1fr 1fr 1fr;}
.hf-opt{font-family:var(--sans);font-size:.96rem;font-weight:600;color:var(--cream);background:rgba(251,248,243,.06);border:1px solid rgba(251,248,243,.2);border-radius:99px;padding:.78rem .7rem;cursor:pointer;transition:all .2s var(--ease);}
.hf-opt:hover{border-color:rgba(178,148,232,.6);background:rgba(178,148,232,.12);}
.hf-opt.is-active{background:var(--lilac-signature);border-color:var(--lilac-signature);color:var(--plum-ink);}
.hf-error{margin:-.5rem 0 0;font-size:.9rem;color:#F0B7C4;font-weight:500;}
.hf-submit{display:inline-flex;align-items:center;justify-content:center;gap:.6rem;font-family:var(--sans);font-size:1rem;font-weight:600;color:var(--plum-ink);background:var(--lilac-signature);border:none;border-radius:99px;padding:1rem 1.4rem;cursor:pointer;line-height:1.2;text-align:center;transition:background .2s var(--ease),transform .2s var(--ease);}
.hf-submit:hover{background:var(--lilac-tint);transform:translateY(-2px);}
.hf-submit svg{width:18px;height:18px;flex:none;}
@media (max-width:560px){
  .coverage-item .meta{font-size:.74rem;}
  .coverage-item.is-home .city{font-size:1.5rem;}
  .clinic{flex-direction:column;align-items:flex-start;gap:.75rem;}
  .clinic-wa{align-self:stretch;justify-content:center;padding:.7rem;font-size:.88rem;}
  .hf-submit{font-size:.94rem;padding:.95rem 1rem;}
}
@media (prefers-reduced-motion:reduce){
  .bottom-sheet,.sheet-overlay{transition:none;}
}

/* ============================================================
   DEPOIMENTOS — avaliações do Google (reais)
   ============================================================ */
.depo-section .section-head{margin-bottom:clamp(2.4rem,4vw,3.4rem);}
.gstars{display:inline-block;letter-spacing:.1em;color:#F4B400;font-size:1.05rem;line-height:1;}

/* Rating summary — minimal */
.rating-panel{
  display:flex;align-items:center;justify-content:center;flex-wrap:wrap;
  gap:clamp(1rem,3vw,2.4rem);
  margin-bottom:clamp(1.8rem,3.2vw,2.6rem);
}
.rp-score{display:flex;align-items:center;gap:.85rem;}
.rp-num{font-family:var(--serif);font-weight:600;font-size:clamp(2.8rem,5vw,3.6rem);line-height:.85;color:var(--plum-ink);letter-spacing:-.01em;}
.rp-score .gstars{font-size:1.35rem;}
.rp-div{width:1px;height:38px;background:var(--line);}
.rp-google{display:inline-flex;align-items:center;gap:.55rem;font-size:.9rem;font-weight:600;color:var(--plum-ink);}
.rp-google svg{width:22px;height:22px;display:block;flex:none;}
.rp-google small{display:block;font-weight:500;font-size:.74rem;color:var(--plum-soft);letter-spacing:.01em;}
.rp-cta{font-weight:600;font-size:.92rem;color:var(--lilac-vivid);display:inline-flex;align-items:center;gap:.35em;transition:gap .2s var(--ease);}
.rp-cta:hover{gap:.6em;}

/* Reviews — marquee automático (infinito) */
.rv-marquee{position:relative;overflow:hidden;padding:.4rem 0 1.2rem;
  -webkit-mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);
  mask-image:linear-gradient(90deg,transparent,#000 5%,#000 95%,transparent);}
.rv-track{display:flex;gap:1rem;width:max-content;will-change:transform;animation:rvScroll 60s linear infinite;}
.rv-marquee:hover .rv-track,.rv-marquee:focus-within .rv-track{animation-play-state:paused;}
@keyframes rvScroll{from{transform:translateX(0);}to{transform:translateX(-50%);}}
.review{
  flex:0 0 clamp(248px,80vw,300px);
  background:var(--white);border:1px solid var(--line-soft);
  border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);
  padding:1.2rem 1.25rem;
  display:flex;flex-direction:column;gap:.7rem;
}
.rv-head{display:flex;align-items:center;gap:.65rem;}
.rv-av{width:36px;height:36px;flex:none;border-radius:50%;display:grid;place-items:center;color:var(--white);font-family:var(--sans);font-weight:600;font-size:.92rem;background:var(--c,var(--lilac-coat));}
.rv-id{flex:1;min-width:0;line-height:1.2;}
.rv-id b{display:block;font-family:var(--sans);font-weight:600;font-size:.9rem;color:var(--plum-ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;}
.rv-id span{font-size:.72rem;color:var(--plum-soft);}
.rv-g{width:18px;height:18px;flex:none;align-self:flex-start;}
.rv-meta{display:flex;align-items:center;gap:.55rem;}
.rv-meta .gstars{font-size:.88rem;}
.rv-text{margin:0;font-size:.9rem;line-height:1.55;color:var(--plum-soft);
  display:-webkit-box;-webkit-line-clamp:6;line-clamp:6;-webkit-box-orient:vertical;overflow:hidden;}

@media (prefers-reduced-motion:reduce){
  .rv-track{animation:none;}
  .rv-marquee{overflow-x:auto;-webkit-mask-image:none;mask-image:none;}
}
@media (max-width:760px){
  .rp-div{display:none;}
}

/* ============================================================
   IMERSÃO
   ============================================================ */
.imersao{background:var(--white);border-block:1px solid var(--line-soft);}
.imersao-card{display:grid;grid-template-columns:1.4fr 1fr;gap:clamp(1.5rem,4vw,3.5rem);align-items:center;}
.imersao .eyebrow{color:var(--plum-soft);}
.imersao .eyebrow::before{background:var(--plum-soft);}
.imersao h2{font-size:clamp(1.7rem,3vw,2.5rem);}
.imersao p{color:var(--plum-soft);max-width:50ch;margin:1rem 0 1.8rem;}
.imersao .badge-vet{display:inline-flex;align-items:center;gap:.6rem;font-size:.82rem;font-weight:600;color:var(--plum-soft);}
.imersao-visual{aspect-ratio:5/4;border-radius:var(--radius);background:linear-gradient(150deg,var(--plum-ink),var(--plum-soft));display:grid;place-items:center;position:relative;overflow:hidden;}
.imersao-visual .stamp{text-align:center;color:var(--cream);}
.imersao-visual .stamp .script{font-size:3rem;letter-spacing:-.01em;color:var(--lilac-tint);display:block;text-transform:none;}
.imersao-visual .stamp span{font-size:.74rem;letter-spacing:.28em;text-transform:uppercase;color:rgba(251,248,243,.6);}

/* ============================================================
   FAQ
   ============================================================ */
.faq-grid{display:grid;grid-template-columns:.8fr 1.2fr;gap:clamp(2rem,5vw,4rem);align-items:start;}
.faq-list{display:flex;flex-direction:column;}
.faq-item{border-bottom:1px solid var(--line);}
.faq-q{width:100%;background:none;border:none;cursor:pointer;text-align:left;display:flex;justify-content:space-between;align-items:center;gap:1.5rem;padding:1.5rem 0;font-family:var(--serif);font-size:clamp(1.15rem,1.7vw,1.4rem);font-weight:500;color:var(--plum-ink);transition:color .2s var(--ease);}
.faq-q:hover{color:var(--lilac-vivid);}
.faq-q .ico{flex:none;width:26px;height:26px;border-radius:50%;border:1px solid var(--line);display:grid;place-items:center;position:relative;transition:background .2s,border-color .2s;}
.faq-q .ico::before,.faq-q .ico::after{content:"";position:absolute;background:var(--plum-ink);transition:transform .25s var(--ease),background .2s;}
.faq-q .ico::before{width:11px;height:1.5px;}
.faq-q .ico::after{width:1.5px;height:11px;}
.faq-item.open .faq-q .ico{background:var(--lilac-signature);border-color:var(--lilac-signature);}
.faq-item.open .faq-q .ico::before,.faq-item.open .faq-q .ico::after{background:var(--plum-ink);}
.faq-item.open .faq-q .ico::after{transform:scaleY(0);}
.faq-a{overflow:hidden;height:0;transition:height .3s var(--ease);}
.faq-a .faq-a-inner{padding-bottom:1.5rem;color:var(--plum-soft);max-width:60ch;}

/* ============================================================
   FINAL CTA + FOOTER
   ============================================================ */
.final-cta{background:var(--lilac-mist);color:var(--plum-ink);text-align:center;box-shadow:inset 0 1px 0 rgba(178,148,232,.3),inset 0 -1px 0 rgba(178,148,232,.3);}
.final-cta .wrap{max-width:760px;}
.final-cta h2{color:var(--plum-ink);margin-bottom:1rem;}
.final-cta p{color:var(--plum-soft);opacity:1;font-size:1.15rem;margin:0 auto 2.2rem;max-width:46ch;}

.footer{background:var(--plum-ink);color:rgba(251,248,243,.66);padding-block:clamp(3.5rem,6vw,5rem) 2rem;}
.footer-top{display:grid;grid-template-columns:1.6fr 1fr 1fr;gap:2.5rem;padding-bottom:3rem;border-bottom:1px solid rgba(251,248,243,.12);}
.footer img.flogo{height:54px;width:auto;margin-bottom:1.2rem;filter:brightness(0) invert(1);opacity:.92;}
.footer-brand p{max-width:34ch;font-size:.95rem;line-height:1.6;margin:0;}
.footer-col h4{font-family:var(--sans);font-size:.72rem;letter-spacing:.18em;text-transform:uppercase;color:var(--lilac-tint);margin:0 0 1.2rem;font-weight:600;}
.footer-col a{display:block;color:rgba(251,248,243,.72);padding:.35rem 0;font-size:.96rem;transition:color .2s var(--ease);}
.footer-col a:hover{color:var(--cream);}
.footer-social{display:flex;gap:.7rem;}
.footer-social a{width:42px;height:42px;border-radius:50%;border:1px solid rgba(251,248,243,.18);display:grid;place-items:center;color:rgba(251,248,243,.8);transition:background .2s,color .2s,border-color .2s;}
.footer-social a:hover{background:var(--lilac-signature);color:var(--plum-ink);border-color:var(--lilac-signature);}
.footer-social svg{width:19px;height:19px;}

/* ---- Footer contact list ---- */
.footer-contact{display:flex;flex-direction:column;gap:.7rem;}
.footer-contact a{display:flex;align-items:center;gap:.85rem;padding:.55rem .7rem .55rem .55rem;margin:0 -.7rem 0 -.55rem;border-radius:12px;color:rgba(251,248,243,.82);transition:background .2s var(--ease),color .2s var(--ease);}
.footer-contact a:hover{background:rgba(251,248,243,.06);color:var(--cream);}
.footer-contact .fc-ico{flex:none;width:40px;height:40px;border-radius:50%;border:1px solid rgba(251,248,243,.18);display:grid;place-items:center;color:rgba(251,248,243,.85);transition:background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);}
.footer-contact a:hover .fc-ico{background:var(--lilac-signature);color:var(--plum-ink);border-color:var(--lilac-signature);}
.footer-contact .fc-ico svg{width:19px;height:19px;}
.footer-contact .fc-txt{display:flex;flex-direction:column;line-height:1.25;}
.footer-contact .fc-txt b{font-weight:600;font-size:.96rem;color:var(--cream);}
.footer-contact .fc-txt small{font-size:.74rem;letter-spacing:.04em;color:rgba(251,248,243,.5);}
.footer-legal{display:flex;justify-content:space-between;flex-wrap:wrap;gap:1rem;padding-top:2rem;font-size:.84rem;color:rgba(251,248,243,.5);}
.footer-legal .small-print{max-width:48ch;}

/* ---- Floating WhatsApp ---- */
.float-wa{position:fixed;right:clamp(16px,3vw,28px);bottom:clamp(16px,3vw,28px);z-index:70;display:flex;align-items:center;gap:.7rem;background:var(--plum-ink);color:var(--cream);padding:.85rem 1.25rem .85rem .95rem;border-radius:999px;font-weight:600;font-size:.95rem;box-shadow:0 12px 30px rgba(46,36,64,.32);transition:transform .25s var(--ease),background .2s var(--ease),box-shadow .25s var(--ease);}
.float-wa:hover{transform:translateY(-3px) scale(1.02);background:var(--plum-soft);color:var(--white);box-shadow:0 18px 40px rgba(46,36,64,.4);}
.float-wa svg{width:26px;height:26px;flex:none;}
.float-wa .lbl{white-space:nowrap;}

/* ============================================================
   MOTION
   ============================================================ */
.reveal{opacity:0;transform:translateY(26px);transition:opacity .7s var(--ease),transform .7s var(--ease);}
.reveal.in{opacity:1;transform:none;}
.reveal.d1{transition-delay:.06s;}.reveal.d2{transition-delay:.12s;}.reveal.d3{transition-delay:.18s;}.reveal.d4{transition-delay:.24s;}

/* ---- Hero entrance choreography ---- */
@media (prefers-reduced-motion:no-preference){
  .hero .eyebrow,
  .hero h1,
  .hero .hero-sub,
  .hero .hero-actions,
  .hero .cred-strip{opacity:0;animation:heroUp .85s var(--ease-out) both;}
  .hero h1{animation-delay:.30s;}
  .hero .hero-sub{animation-delay:.45s;}
  .hero .hero-actions{animation-delay:.60s;}
  .hero .cred-strip{animation-delay:.75s;}
  .hero .eyebrow{animation-delay:.15s;}
  .hero .eyebrow::before{transform:scaleX(0);transform-origin:left center;animation:lineDraw .6s var(--ease-out) .15s both;}
  .hero-photo{opacity:0;animation:heroInRight 1s var(--ease-out) .60s both;}
  .hero .hero-actions .btn-primary{animation:ctaPulse 2s ease-in-out 1.6s infinite;}
}
@keyframes heroUp{from{opacity:0;transform:translateY(20px);}to{opacity:1;transform:translateY(0);}}
@keyframes heroInRight{from{opacity:0;transform:translateX(40px);}to{opacity:1;transform:translateX(0);}}
@keyframes lineDraw{from{transform:scaleX(0);}to{transform:scaleX(1);}}
@keyframes ctaPulse{
  0%{box-shadow:0 10px 26px rgba(46,36,64,.35),0 0 0 0 rgba(155,111,232,.45);}
  70%{box-shadow:0 10px 26px rgba(46,36,64,.35),0 0 0 16px rgba(155,111,232,0);}
  100%{box-shadow:0 10px 26px rgba(46,36,64,.35),0 0 0 0 rgba(155,111,232,0);}
}
@media (prefers-reduced-motion:reduce){.reveal{opacity:1;transform:none;transition:none;}}

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width:980px){
  .nav-links{display:none;}
  .nav-toggle{display:block;}
  .nav-inner{display:flex;justify-content:space-between;}
  .brand{justify-self:auto;}
  .brand img{height:46px;}
  .nav.scrolled .brand img{height:38px;}
  .hero-grid,.why-grid,.sobre-grid,.cob-grid,.imersao-card,.faq-grid{grid-template-columns:1fr;}
  .hero-photo{order:-1;}
  .sobre-photo .framed{aspect-ratio:4/3.4;}
  .spec-grid,.format-grid,.footer-top{grid-template-columns:1fr;}
  .steps{grid-template-columns:1fr 1fr;gap:2rem 1.4rem;}
  .step:not(:last-child)::after{display:none;}
  .footer-top{gap:2.2rem;}
}
@media (max-width:560px){
  .steps{grid-template-columns:1fr;}
  .hero-actions{gap:1rem;}
  .hero-badge{right:8px;left:auto;}
  .float-wa .lbl{display:none;}
  .float-wa{padding:.9rem;}
  .footer-legal{flex-direction:column;}
}
