/* ============================================================
   DR. ÉDER MARCOLIN — protótipo de navegação (GSAP + Lenis)
   Layout mantido, navegação refeita com pegada "Awwwards".
   ============================================================ */
:root{
  --blue:#1ba0e3;
  --blue-deep:#0c6aa6;
  --ink:#141414;
  --muted:#6b6f73;
  --bg:#f4f3f1;
  --bg-soft:#ffffff;
  --line:#e4e3e0;
  --ease: cubic-bezier(.22,1,.36,1);
  --container: 1320px;
}
*{margin:0;padding:0;box-sizing:border-box}
html,body{background:var(--bg);color:var(--ink);font-family:"Manrope",system-ui,sans-serif;-webkit-font-smoothing:antialiased}
body{overflow-x:hidden}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
::selection{background:var(--blue);color:#fff}

/* ---------- CURSOR CUSTOMIZADO ---------- */
@media (hover:hover) and (pointer:fine){
  *{cursor:none !important}
  .cursor-dot,.cursor-ring{position:fixed;top:0;left:0;z-index:200;pointer-events:none;border-radius:50%;
    transform:translate(-50%,-50%);will-change:transform}
  .cursor-dot{width:7px;height:7px;background:var(--blue)}
  .cursor-ring{width:38px;height:38px;border:1.5px solid var(--blue);
    transition:width .35s var(--ease),height .35s var(--ease),background .35s,border-color .35s,opacity .3s}
  .cursor-ring.hover{width:64px;height:64px;background:rgba(27,160,227,.12);border-color:var(--blue)}
  .cursor-ring.down{width:28px;height:28px}
  body.cursor-light .cursor-dot{background:#fff}
  body.cursor-light .cursor-ring{border-color:#fff}
  body.cursor-light .cursor-ring.hover{background:rgba(255,255,255,.18)}
}

/* scrollbar discreta */
::-webkit-scrollbar{width:8px}
::-webkit-scrollbar-thumb{background:#c9c8c4;border-radius:8px}

.container{width:min(var(--container),92vw);margin-inline:auto}

/* ---------- HEADER ---------- */
.site-header{
  position:fixed;inset:0 0 auto 0;z-index:60;
  display:flex;align-items:center;justify-content:space-between;
  padding:22px clamp(18px,4vw,46px);
  mix-blend-mode:normal;pointer-events:none;
}
.site-header .brand,.site-header .menu-btn{pointer-events:auto}
.brand{display:flex;align-items:center;gap:10px;width:148px;transition:opacity .4s}
.brand img{width:100%}
.menu-btn{
  font-weight:700;font-size:15px;letter-spacing:.02em;color:#fff;
  background:var(--ink);border:1px solid rgba(255,255,255,.45);cursor:pointer;
  padding:13px 26px;border-radius:40px;
  display:inline-flex;align-items:center;gap:10px;
  transition:transform .4s var(--ease),background .4s;
}
.menu-btn:hover{transform:translateY(-2px)}
.menu-btn .dot{width:7px;height:7px;border-radius:50%;background:var(--blue);transition:.4s}

/* ---------- BOTÃO VOLTAR AO TOPO ---------- */
.to-top{position:fixed;right:clamp(18px,4vw,40px);bottom:clamp(18px,4vw,40px);z-index:70;
  width:54px;height:54px;border-radius:50%;border:1px solid rgba(255,255,255,.45);
  background:var(--ink);color:#fff;display:grid;place-items:center;cursor:pointer;
  opacity:0;visibility:hidden;transform:translateY(16px);
  transition:opacity .45s var(--ease),transform .45s var(--ease),visibility 0s linear .45s,background .4s}
.to-top.show{opacity:1;visibility:visible;transform:none;
  transition:opacity .45s var(--ease),transform .45s var(--ease),background .4s}
.to-top:hover{background:var(--blue)}
.to-top svg{width:20px;height:20px}

/* ---------- MENU OVERLAY ---------- */
.nav-overlay{
  position:fixed;inset:0;z-index:80;
  background:var(--blue);
  clip-path:circle(0% at calc(100% - 70px) 56px);
  visibility:hidden;
  transition:clip-path .8s var(--ease),visibility 0s linear .8s;
  display:flex;flex-direction:column;justify-content:center;
  padding:clamp(40px,9vw,120px);
}
.nav-overlay.open{
  clip-path:circle(150% at calc(100% - 70px) 56px);
  visibility:visible;transition:clip-path .9s var(--ease);
}
.nav-overlay .close-btn{
  position:absolute;top:22px;right:clamp(18px,4vw,46px);
  background:#fff;color:var(--blue);font-weight:700;border:none;
  padding:13px 26px;border-radius:40px;cursor:pointer;font-size:15px;
}
.nav-list{list-style:none;display:flex;flex-direction:column;gap:clamp(6px,1.4vw,14px)}
.nav-list a{
  font-size:clamp(34px,6vw,76px);font-weight:700;color:#fff;line-height:1.04;
  letter-spacing:-.02em;display:inline-block;position:relative;
  opacity:0;transform:translateY(40px);
}
.nav-list a::after{
  content:"";position:absolute;left:0;bottom:.08em;height:3px;width:0;background:#fff;
  transition:width .45s var(--ease);
}
.nav-list a:hover::after{width:100%}
.nav-social{margin-top:clamp(26px,4vw,52px);display:flex;gap:26px}
.nav-social a{color:#fff;font-weight:600;font-size:18px;opacity:.85;transition:.3s}
.nav-social a:hover{opacity:1}

/* ---------- HERO ---------- */
.hero{position:relative;min-height:100svh;display:flex;align-items:flex-end;overflow:hidden}
#particles-js{position:absolute;inset:0;width:100%;height:100%;z-index:0}
#particles-js canvas{position:absolute;inset:0}
.hero-inner{position:relative;z-index:2;padding:0 0 clamp(34px,5vh,64px);pointer-events:none}
.hero h1{
  font-size:clamp(52px,11vw,168px);line-height:.92;font-weight:800;letter-spacing:-.03em;
}
.hero .sub{
  font-size:clamp(24px,4.4vw,58px);font-weight:500;line-height:1.02;margin-top:.35em;
  color:var(--ink);max-width:14ch;
}
.hero .sub b{color:var(--blue);font-weight:700}
.scroll-cue{
  position:relative;z-index:2;margin-top:clamp(34px,6vh,72px);pointer-events:auto;cursor:pointer;
  display:flex;flex-direction:column;align-items:flex-start;gap:10px;color:var(--muted);font-size:12px;letter-spacing:.18em;text-transform:uppercase;
}
.scroll-cue .arrow{width:1px;height:54px;background:var(--ink);position:relative;animation:cue 1.8s var(--ease) infinite}
@keyframes cue{0%{transform:scaleY(.2);transform-origin:top}50%{transform:scaleY(1);transform-origin:top}50.1%{transform-origin:bottom}100%{transform:scaleY(.2);transform-origin:bottom}}

/* reveal util */
.reveal{opacity:0;transform:translateY(62px)}

/* ---------- APRESENTAÇÃO (logo animado) ---------- */
.intro{position:relative;padding:clamp(90px,16vh,180px) 0}
.intro-grid{display:grid;grid-template-columns:1fr 1fr;gap:clamp(30px,6vw,90px);align-items:center}
.logo-stage{position:relative;display:flex;justify-content:center;align-items:center;min-height:60vh;perspective:1200px}
.logo-3d{position:relative;width:min(440px,84%);aspect-ratio:1/1;transform-style:preserve-3d;will-change:transform}
/* símbolo dividido em 4 quadrantes (cinza clarinho, vetor intacto) que "estouram" no scroll */
.logo-3d .quad{position:absolute;inset:0;background:url("https://edermarcolin.com.br/wp-content/uploads/2024/10/simbolo-branco.svg") center/contain no-repeat;
  filter:brightness(0) invert(0.86) drop-shadow(0 16px 22px rgba(20,20,20,.10));will-change:transform,opacity}
.logo-3d .q1{clip-path:inset(0 50% 50% 0)}
.logo-3d .q2{clip-path:inset(0 0 50% 50%)}
.logo-3d .q3{clip-path:inset(50% 50% 0 0)}
.logo-3d .q4{clip-path:inset(50% 0 0 50%)}
.intro-text{max-width:46ch}
.intro-text p{font-size:clamp(19px,2.1vw,27px);line-height:1.5;font-weight:400;color:#26292c}
.intro-text p+p{margin-top:1.1em}
.intro-kicker{font-size:13px;letter-spacing:.22em;text-transform:uppercase;color:var(--blue);font-weight:700;margin-bottom:24px;display:block}

/* ---------- DR. ÉDER ---------- */
.doctor{position:relative;background:var(--bg-soft);padding:clamp(80px,12vh,150px) 0 0}
.doctor::before{content:"";position:absolute;inset:0 0 auto 0;height:120px;background:var(--bg);clip-path:polygon(0 0,100% 0,50% 100%)}
.doctor-info{padding-bottom:clamp(48px,9vh,110px)} /* respiro abaixo do texto; foto segue encostando no preto */
.doctor-grid{display:grid;grid-template-columns:.82fr 1.18fr;gap:clamp(30px,5vw,70px);align-items:end}
.doctor h2{font-size:clamp(26px,3.2vw,44px);color:var(--blue);font-weight:800;letter-spacing:-.02em;margin-bottom:16px}
.doctor ul{list-style:none;display:flex;flex-direction:column;gap:6px}
.doctor li{position:relative;padding-left:24px;font-size:clamp(14px,1.05vw,16px);line-height:1.3;color:#33363a}
.doctor li::before{content:"";position:absolute;left:0;top:.55em;width:8px;height:8px;border-radius:50%;background:var(--blue)}
.doctor li a{color:var(--blue);font-weight:600}
.doctor-photo{position:relative}
.doctor-photo img{width:100%;border-radius:6px;transform:scale(1.08);transform-origin:bottom center}

/* ---------- ESPECIALIDADES (horizontal pin) ---------- */
.spec{position:relative;background:var(--ink);color:#fff;overflow:hidden}
.spec-head{position:absolute;top:clamp(30px,5.5vh,56px);left:0;width:100%;z-index:3;pointer-events:none}
.spec-head .container{display:flex;flex-direction:column;align-items:center;text-align:center;gap:8px}
.spec-head h2{font-size:clamp(24px,3vw,40px);font-weight:800;letter-spacing:-.02em}
.spec-head .count{font-size:12px;letter-spacing:.24em;text-transform:uppercase;color:var(--blue);font-weight:700}
.spec-track{display:flex;align-items:center;height:100svh;padding-inline:clamp(18px,4vw,46px);will-change:transform}
.spec-card{
  position:relative;flex:0 0 clamp(280px,42vw,520px);height:62vh;margin-right:clamp(20px,3vw,46px);
  border-radius:8px;overflow:hidden;background:#222;
}
.spec-card:first-child{margin-left:clamp(0px,5vw,80px)}
.spec-card img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;opacity:.55;transition:transform .9s var(--ease),opacity .6s}
.spec-card:hover img{transform:scale(1.06);opacity:.7}
.spec-card .meta{position:absolute;inset:auto 0 0 0;padding:clamp(22px,2.4vw,34px);background:linear-gradient(to top,rgba(10,10,10,.92),transparent)}
.spec-card .num{font-size:13px;letter-spacing:.2em;color:var(--blue);font-weight:700}
.spec-card h3{font-size:clamp(21px,1.7vw,28px);font-weight:700;margin:8px 0 12px;line-height:1.1}
.spec-card p{font-size:14.5px;line-height:1.5;color:#cfd2d5;max-width:42ch;
  max-height:0;opacity:0;overflow:hidden;transition:max-height .6s var(--ease),opacity .5s,margin .5s}
.spec-card:hover p{max-height:240px;opacity:1}
.spec-progress{position:absolute;left:clamp(18px,4vw,46px);bottom:38px;width:clamp(120px,18vw,260px);height:3px;background:rgba(255,255,255,.18);z-index:3;border-radius:3px}
.spec-progress span{display:block;height:100%;width:0;background:var(--blue);border-radius:3px}
.spec-card .more{position:absolute;top:18px;right:18px;z-index:2;font-size:12px;letter-spacing:.12em;text-transform:uppercase;
  color:#fff;background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.4);backdrop-filter:blur(6px);
  padding:7px 14px;border-radius:30px;font-weight:600;opacity:0;transform:translateY(-6px);transition:.4s var(--ease)}
.spec-card:hover .more{opacity:1;transform:none}

/* ---------- MODAL LIQUID GLASS ---------- */
.modal-backdrop{position:fixed;inset:0;z-index:120;display:flex;align-items:center;justify-content:center;padding:24px;
  background:rgba(8,16,22,.55);backdrop-filter:blur(4px);opacity:0;visibility:hidden;transition:opacity .4s,visibility 0s linear .4s}
.modal-backdrop.open{opacity:1;visibility:visible;transition:opacity .4s}
.glass{position:relative;width:min(720px,100%);max-height:88vh;overflow:hidden;border-radius:22px;display:grid;grid-template-columns:42% 1fr;
  background:rgba(255,255,255,.12);backdrop-filter:blur(26px) saturate(180%);-webkit-backdrop-filter:blur(26px) saturate(180%);
  border:1px solid rgba(255,255,255,.4);box-shadow:0 40px 90px -30px rgba(0,0,0,.6),inset 0 1px 0 rgba(255,255,255,.5);
  transform:translateY(28px) scale(.96);opacity:0;transition:transform .55s var(--ease),opacity .45s}
.modal-backdrop.open .glass{transform:none;opacity:1}
.glass::before{content:"";position:absolute;inset:0;pointer-events:none;border-radius:22px;background:linear-gradient(135deg,rgba(255,255,255,.35),transparent 42%)}
.glass-media{position:relative;min-height:280px}
.glass-media img{position:absolute;inset:0;width:100%;height:100%;object-fit:cover}
.glass-body{position:relative;padding:clamp(26px,3vw,42px);color:#fff;overflow-y:auto;min-height:0;max-height:88vh;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;background:rgba(12,18,24,.30)}
.glass-num{font-size:13px;letter-spacing:.2em;color:#bfe6fa;font-weight:700}
.glass-body h3{font-size:clamp(22px,2.4vw,30px);font-weight:700;margin:8px 0 16px;line-height:1.12}
.glass-text{font-size:15px;line-height:1.62;color:#eef3f6}
.glass-text em{display:block;margin-top:14px;font-size:12.5px;color:#bcc6cd;font-style:italic}
.glass-cta{display:inline-flex;margin-top:26px;background:#fff;color:var(--blue);font-weight:700;padding:13px 26px;border-radius:40px;font-size:15px;transition:transform .35s var(--ease)}
.glass-cta:hover{transform:translateY(-3px)}
.glass-close{position:absolute;top:14px;right:14px;z-index:4;width:40px;height:40px;border-radius:50%;border:1px solid rgba(255,255,255,.5);
  background:rgba(255,255,255,.18);color:#fff;font-size:15px;cursor:pointer;backdrop-filter:blur(6px);display:grid;place-items:center}
@media(max-width:640px){.glass{grid-template-columns:1fr;max-height:90vh}.glass-media{min-height:160px;height:160px}.glass-body{max-height:calc(90vh - 160px)}}

/* ---------- LOCAIS ---------- */
.places{padding:clamp(80px,12vh,150px) 0;background:var(--bg)}
.places h2{font-size:clamp(30px,4vw,52px);font-weight:800;letter-spacing:-.02em;margin-bottom:54px;max-width:18ch}
.places-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:clamp(24px,4vw,46px)}
.place{background:var(--bg-soft);border:1px solid var(--line);border-radius:10px;padding:clamp(26px,3vw,40px);transition:transform .5s var(--ease),box-shadow .5s}
.place:hover{transform:translateY(-6px);box-shadow:0 24px 50px -28px rgba(0,0,0,.25)}
.place .logo{height:60px;display:flex;align-items:center;margin-bottom:22px}
.place .logo img{height:100%;width:auto}
.place h3{font-size:24px;color:var(--blue);font-weight:700;margin-bottom:10px}
.place address{font-style:normal;color:var(--muted);line-height:1.6;font-size:15.5px}
.place .map{display:inline-flex;align-items:center;gap:8px;margin-top:18px;color:var(--blue);font-weight:600;font-size:15px}
.place .map svg{width:16px;height:16px}

/* ---------- CTA ---------- */
.cta{position:relative;background:var(--blue);color:#fff;padding:clamp(90px,16vh,180px) 0;overflow:hidden;text-align:center}
.cta h2{font-size:clamp(38px,6.4vw,96px);font-weight:800;letter-spacing:-.03em;line-height:.98}
.cta p{font-size:clamp(18px,2.4vw,28px);font-weight:500;margin:24px auto 44px;max-width:24ch;opacity:.95}
.cta .btn{
  display:inline-flex;align-items:center;gap:14px;background:#fff;color:var(--blue);
  font-weight:700;font-size:19px;padding:20px 42px;border-radius:50px;
  transition:transform .4s var(--ease),box-shadow .4s;
}
.cta .btn:hover{transform:translateY(-4px) scale(1.02);box-shadow:0 20px 40px -18px rgba(0,0,0,.4)}
.cta .ring{position:absolute;border:1px solid rgba(255,255,255,.25);border-radius:50%}

/* ---------- FOOTER ---------- */
.site-footer{background:var(--ink);color:#fff;padding:clamp(50px,7vh,80px) 0 40px}
.footer-grid{display:flex;flex-wrap:wrap;justify-content:space-between;gap:30px;align-items:center}
.footer-grid .f-logo{width:160px}
.footer-grid .f-logo img{filter:brightness(0) invert(1)}
.footer-social{display:flex;gap:18px}
.footer-social a{width:42px;height:42px;border:1px solid rgba(255,255,255,.2);border-radius:50%;display:grid;place-items:center;transition:.3s}
.footer-social a:hover{background:var(--blue);border-color:var(--blue)}
.footer-social img{width:18px;filter:brightness(0) invert(1)}
.footer-legal{margin-top:36px;padding-top:24px;border-top:1px solid rgba(255,255,255,.12);color:#9aa0a5;font-size:13.5px;line-height:1.7}

/* ---------- RESPONSIVO ---------- */
@media (max-width:900px){
  .intro-grid{grid-template-columns:1fr;gap:40px}
  .logo-stage{min-height:42vh;order:-1}
  .doctor-grid{grid-template-columns:1fr;gap:40px}
  .places-grid{grid-template-columns:1fr}
  .spec-card{height:56vh}
}
@media (max-width:600px){
  /* HERO: copy ainda maior, ancorada embaixo, com respiro até o scroll (~30px da borda) */
  .hero-inner{padding-bottom:30px}
  .hero h1{font-size:clamp(72px,20vw,140px);line-height:.9;letter-spacing:-.04em}
  .hero .sub{font-size:clamp(29px,8.2vw,48px);max-width:14ch;margin-top:.5em;line-height:1.0}
  .scroll-cue{margin-top:clamp(54px,9vh,88px)} /* respiro claro entre chamada e o scroll */
  .scroll-cue .arrow{height:44px}
  /* ESPECIALIDADES: área empurrada ~60px pra baixo (título não sobrepõe os cards) */
  .spec-head{top:104px}
  .spec-head h2{font-size:27px}
  .spec-head .count{font-size:11px}
  .spec-track{align-items:flex-start;padding-top:200px}
  .spec-card{flex-basis:80vw;height:60vh;margin-right:16px}
  .spec-card:first-child{margin-left:5vw}
  .spec-card h3{font-size:21px}
  .spec-progress{bottom:30px}
  .spec-card .more{opacity:1;transform:none} /* selo sempre visível no touch */
}

/* ====== cor dinâmica vinda do CPT (especialidade_cor) ====== */
.spec-card{background:var(--cor,#222)}
.spec-card .num{color:var(--cor,var(--blue))}
