/* ==========================================================================
   EvolvEdu — Landing V7 "Caderno Vivo"
   Sistema: papel pautado + pétalas da marca + display arredondado
   Paleta da marca: azul #193E76 · verde #44786C · amarelo #FAB900 · laranja #E84A29
   ========================================================================== */

:root{
  /* Cores da marca */
  --blue:#193E76;
  --blue-deep:#122E59;
  --blue-ink:#0D2245;
  --green:#44786C;
  --green-deep:#356056;
  --yellow:#FAB900;
  --orange:#E84A29;
  --orange-deep:#C93A1D;
  --ink:#232323;
  --ink-soft:rgba(35,35,35,.72);
  --ink-mute:rgba(35,35,35,.55);

  /* Papel */
  --paper:#FBF8F1;
  --paper-deep:#F4EDE0;
  --card:#FFFFFF;
  --line:rgba(25,62,118,.14);
  --rule:rgba(25,62,118,.07);

  /* Tons suaves das pétalas */
  --yellow-soft:#FFF1CC;
  --green-soft:#E0EBE6;
  --orange-soft:#FBE3DB;
  --blue-soft:#E3EAF5;

  /* Tipos */
  --font-display:'Baloo 2',system-ui,sans-serif;
  --font-body:'Figtree',system-ui,-apple-system,'Segoe UI',sans-serif;
  --font-hand:'Caveat',cursive;

  /* Geometria */
  --r-sm:14px;
  --r-md:22px;
  --r-lg:30px;
  --r-petal:46% 46% 46% 12%;
  --pill:999px;
  --max:1200px;
  --gutter:24px;

  --shadow-sm:0 6px 22px rgba(25,62,118,.10);
  --shadow-md:0 18px 50px rgba(25,62,118,.14);
  --shadow-lg:0 30px 90px rgba(25,62,118,.20);

  --ease:cubic-bezier(.22,1,.36,1);
  --ease-pop:cubic-bezier(.34,1.56,.64,1);
}

/* ---------- Base ---------- */
*,*::before,*::after{box-sizing:border-box}
html{scroll-behavior:smooth}
html:focus-within{scroll-behavior:smooth}
body{
  margin:0;
  font-family:var(--font-body);
  font-size:17px;
  line-height:1.6;
  color:var(--ink);
  background:var(--paper);
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  text-rendering:optimizeLegibility;
}
img{max-width:100%;display:block;height:auto}
a{color:inherit}
button,input,textarea{font:inherit;color:inherit}
h1,h2,h3,h4,p,ul{margin:0}
ul{padding:0;list-style:none}
.container{width:min(100% - calc(var(--gutter)*2),var(--max));margin-inline:auto}
.svg-defs{position:absolute;width:0;height:0;overflow:hidden}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}

::selection{background:var(--yellow);color:var(--ink)}
:focus-visible{outline:3px solid var(--orange);outline-offset:3px;border-radius:8px}

.skip-link{position:fixed;left:16px;top:14px;z-index:300;transform:translateY(-160%);background:var(--ink);color:#fff;border-radius:var(--pill);padding:10px 18px;font-weight:700;text-decoration:none;transition:transform .25s var(--ease)}
.skip-link:focus{transform:none}

/* Barra de progresso: o "lápis" da página */
.page-progress{position:fixed;inset:0 0 auto 0;height:4px;z-index:240;pointer-events:none}
.page-progress span{display:block;height:100%;width:0;background:linear-gradient(90deg,var(--blue),var(--green) 45%,var(--yellow) 80%,var(--orange));border-radius:0 var(--pill) var(--pill) 0}

/* Pétalas: cores utilitárias */
.petal--blue{fill:var(--blue)}
.petal--green{fill:var(--green)}
.petal--yellow{fill:var(--yellow)}
.petal--orange{fill:var(--orange)}
.petal--sand{fill:var(--paper-deep)}
.petal-bg--blue{background:var(--blue)}
.petal-bg--green{background:var(--green)}
.petal-bg--yellow{background:var(--yellow)}
.petal-bg--orange{background:var(--orange)}

/* ---------- Tipografia ---------- */
.display{
  font-family:var(--font-display);
  font-weight:800;
  line-height:1.06;
  letter-spacing:-.01em;
  color:var(--ink);
}
h2.display{font-size:clamp(2rem,1.2rem + 2.6vw,3.4rem);max-width:21ch}
.section-lead{margin-top:18px;font-size:clamp(1.05rem,1rem + .3vw,1.25rem);color:var(--ink-soft);max-width:56ch}

.eyebrow{
  display:inline-flex;align-items:center;gap:10px;
  font-weight:700;font-size:.82rem;text-transform:uppercase;letter-spacing:.14em;
  color:var(--blue);margin-bottom:18px;
}
.eyebrow--light{color:rgba(255,255,255,.85)}
.eyebrow-petal{width:14px;height:14px;flex:none;fill:var(--orange)}
.eyebrow--light .eyebrow-petal{fill:var(--yellow)}

/* Marca-texto amarelo (animado via GSAP) */
.mark{font-style:normal;position:relative;white-space:nowrap;z-index:0}
.mark::before{
  content:"";position:absolute;z-index:-1;left:-.12em;right:-.12em;top:.5em;bottom:-.02em;
  background:var(--yellow);border-radius:6px;transform:skewX(-6deg) scaleX(var(--mark-x,1));
  transform-origin:left center;
}
.mark--green::before{background:var(--green-soft)}

/* Rabisco de caneta sob palavras-chave */
.scribble-wrap{position:relative;white-space:nowrap;display:inline-block}
.scribble{position:absolute;left:0;right:0;bottom:-.18em;width:100%;height:.32em;overflow:visible}
.scribble path{stroke:var(--orange);stroke-width:3.4;fill:none;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:var(--scribble,0)}
.scribble--light path{stroke:var(--yellow)}

/* Anotações à mão (Caveat) */
.hand-note{
  font-family:var(--font-hand);font-size:1.45rem;font-weight:700;color:var(--blue);
  display:inline-flex;align-items:center;gap:8px;transform:rotate(-2deg);
}
.hand-arrow{width:44px;height:32px;color:var(--blue);flex:none}
.hand-arrow--down{transform:rotate(72deg)}

/* ---------- Botões ---------- */
.btn{
  --btn-bg:var(--blue);--btn-fg:#fff;
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  background:var(--btn-bg);color:var(--btn-fg);
  border:2px solid transparent;border-radius:var(--pill);
  padding:13px 26px;font-weight:700;font-size:1rem;line-height:1.2;
  text-decoration:none;cursor:pointer;white-space:nowrap;
  transition:transform .2s var(--ease),box-shadow .25s var(--ease),background .2s var(--ease),color .2s var(--ease),border-color .2s var(--ease);
  will-change:transform;
}
.btn:hover{transform:translateY(-2px);box-shadow:0 14px 30px rgba(25,62,118,.22)}
.btn:active{transform:translateY(0) scale(.98)}
.btn--primary{--btn-bg:var(--blue)}
.btn--primary:hover{--btn-bg:var(--blue-deep)}
.btn--wa{--btn-bg:var(--green)}
.btn--wa:hover{--btn-bg:#3A685D;box-shadow:0 14px 30px rgba(68,120,108,.3)}
.btn--yellow{--btn-bg:var(--yellow);--btn-fg:var(--ink)}
.btn--yellow:hover{--btn-bg:#E8AB00;box-shadow:0 14px 32px rgba(0,0,0,.22)}
.btn--ghost{--btn-bg:transparent;--btn-fg:var(--ink);border-color:rgba(35,35,35,.22)}
.btn--ghost:hover{border-color:var(--ink);box-shadow:none;background:rgba(35,35,35,.04)}
.btn--light{--btn-bg:#fff;--btn-fg:var(--blue)}
.btn--light:hover{--btn-bg:var(--yellow);--btn-fg:var(--ink);box-shadow:0 14px 32px rgba(0,0,0,.25)}
.btn--outline-light{--btn-bg:transparent;--btn-fg:#fff;border-color:rgba(255,255,255,.45)}
.btn--outline-light:hover{border-color:#fff;box-shadow:none;background:rgba(255,255,255,.08)}
.btn--sm{padding:10px 18px;font-size:.92rem}
.btn--lg{padding:16px 32px;font-size:1.06rem}

/* ---------- Header ---------- */
.topbar{
  position:fixed;inset:0 0 auto 0;z-index:200;
  transition:background .3s var(--ease),box-shadow .3s var(--ease),transform .3s var(--ease);
}
.topbar.is-scrolled{background:rgba(251,248,241,.88);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 10px 40px rgba(25,62,118,.10)}
.topbar.is-hidden{transform:translateY(-105%)}
.topbar-inner{height:84px;display:flex;align-items:center;justify-content:space-between;gap:20px}
.brand{display:inline-flex;align-items:center;text-decoration:none}
.brand-logo{width:176px;height:auto}
.brand-logo--white{display:none}
.topbar.is-dark:not(.is-scrolled) .brand-logo--color{display:none}
.topbar.is-dark:not(.is-scrolled) .brand-logo--white{display:block}
.topbar.is-dark:not(.is-scrolled) .topbar-nav a{color:#fff}
.topbar.is-dark:not(.is-scrolled) .btn--ghost{--btn-fg:#fff;border-color:rgba(255,255,255,.4)}
.topbar.is-dark:not(.is-scrolled) .menu-toggle i{background:#fff}

.topbar-nav{display:flex;gap:4px}
.topbar-nav a{
  text-decoration:none;font-weight:600;font-size:.97rem;color:var(--ink);
  padding:9px 14px;border-radius:var(--pill);transition:background .2s var(--ease),color .2s var(--ease);
}
.topbar-nav a:hover{background:var(--yellow);color:var(--ink)}
.topbar-actions{display:flex;align-items:center;gap:10px}

.menu-toggle{display:none;background:none;border:0;padding:10px;cursor:pointer;border-radius:12px}
.menu-toggle-box{display:flex;flex-direction:column;gap:6px;width:26px}
.menu-toggle i{display:block;height:3px;border-radius:3px;background:var(--ink);transition:transform .3s var(--ease),opacity .2s}
.menu-toggle[aria-expanded="true"] i:first-child{transform:translateY(4.5px) rotate(45deg)}
.menu-toggle[aria-expanded="true"] i:last-child{transform:translateY(-4.5px) rotate(-45deg)}

/* Menu mobile em tela cheia */
.nav-overlay{
  position:fixed;inset:0;z-index:190;background:var(--paper);
  display:flex;flex-direction:column;justify-content:center;gap:34px;
  padding:110px var(--gutter) 48px;
  opacity:0;visibility:hidden;transform:translateY(-12px);
  transition:opacity .3s var(--ease),visibility .3s,transform .35s var(--ease);
}
.nav-overlay.is-open{opacity:1;visibility:visible;transform:none}
.nav-overlay-links{display:flex;flex-direction:column;gap:6px}
.nav-overlay-links a{
  font-family:var(--font-display);font-weight:800;font-size:clamp(2rem,8vw,2.8rem);
  color:var(--ink);text-decoration:none;line-height:1.25;width:fit-content;
}
.nav-overlay-links a:hover{color:var(--blue)}
.nav-overlay-ctas{display:flex;flex-direction:column;gap:12px;max-width:380px}
.nav-overlay-foot{color:var(--ink-mute);font-size:.95rem}
.nav-overlay-petals{position:absolute;inset:0;pointer-events:none;overflow:hidden}
.nav-overlay-petals .petal{position:absolute;width:120px;height:120px;opacity:.16}
.nav-overlay-petals .petal:nth-child(1){top:6%;right:-30px;transform:rotate(90deg)}
.nav-overlay-petals .petal:nth-child(2){bottom:18%;right:14%;width:80px;height:80px;transform:rotate(180deg)}
.nav-overlay-petals .petal:nth-child(3){bottom:-30px;left:-20px;width:150px;height:150px}
.nav-overlay-petals .petal:nth-child(4){top:14%;left:55%;width:56px;height:56px;transform:rotate(-90deg)}

/* ---------- Hero ---------- */
.hero{
  position:relative;
  padding:172px 0 96px;
  background:
    radial-gradient(110% 60% at 85% 0%,var(--blue-soft) 0%,transparent 55%),
    repeating-linear-gradient(to bottom,transparent 0 35px,var(--rule) 35px 36px),
    repeating-linear-gradient(to right,transparent 0 35px,var(--rule) 35px 36px),
    var(--paper);
  overflow:hidden;
}
.hero-inner{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:48px;align-items:center}
.hero-title{
  font-family:var(--font-display);font-weight:800;
  font-size:clamp(2.5rem,1.4rem + 4.4vw,4.6rem);
  line-height:1.04;letter-spacing:-.015em;margin:6px 0 22px;max-width:15ch;
}
.hero-title .word{display:inline-block;white-space:pre}
.hero-lead{font-size:clamp(1.08rem,1rem + .45vw,1.3rem);color:var(--ink-soft);max-width:52ch}
.hero-cta{display:flex;flex-wrap:wrap;gap:14px;margin-top:30px}
.hero-note{margin-top:14px;margin-left:6px}
.hero-note .hand-arrow{transform:scaleY(-1) rotate(-12deg)}

.tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:30px}
.tag{
  font-weight:700;font-size:.86rem;padding:8px 15px;border-radius:10px 10px 10px 3px;
  background:var(--card);box-shadow:var(--shadow-sm);border:1px solid var(--line);
}
.tag--yellow{background:var(--yellow-soft);border-color:transparent}
.tag--green{background:var(--green-soft);border-color:transparent}
.tag--orange{background:var(--orange-soft);border-color:transparent}
.tag--blue{background:var(--blue-soft);border-color:transparent}
.tags li:nth-child(odd){transform:rotate(-1.2deg)}
.tags li:nth-child(even){transform:rotate(1deg)}

/* Composição de pétalas + adesivos */
.hero-art{position:relative;min-height:480px}
.hero-cluster{width:100%;height:auto;display:block;overflow:visible}
.hero-dots{stroke:var(--blue);opacity:.35;stroke-width:3;fill:none}
.petal-big{filter:drop-shadow(0 18px 30px rgba(25,62,118,.16));overflow:visible}

.sticker{
  position:absolute;background:var(--card);border-radius:16px;box-shadow:var(--shadow-md);
  border:1px solid rgba(25,62,118,.08);padding:14px 16px;max-width:240px;
}
.sticker strong{display:block;font-family:var(--font-display);font-weight:700;font-size:1rem;line-height:1.2}
.sticker span{display:block;font-size:.84rem;color:var(--ink-mute);margin-top:2px}
.sticker--pin{top:7%;left:-2%;display:flex;align-items:center;gap:12px;transform:rotate(-3deg)}
.sticker-petal{width:34px;height:34px;flex:none}
.sticker--list{bottom:16%;left:4%;transform:rotate(2deg);min-width:215px}
.sticker--list strong{margin-bottom:8px}
.sticker--list li{position:relative;padding:5px 0 5px 28px;font-size:.92rem;font-weight:600;color:var(--ink-soft);border-bottom:1px dashed var(--line)}
.sticker--list li:last-child{border-bottom:0}
.sticker--list li::before{
  content:"";position:absolute;left:0;top:8px;width:16px;height:16px;border-radius:6px 6px 6px 2px;
  border:2px solid var(--green);background:transparent;
}
.sticker--list li.done{color:var(--ink)}
.sticker--list li.done::before{background:var(--green);border-color:var(--green)}
.sticker--list li.done::after{content:"✓";position:absolute;left:3px;top:4px;color:#fff;font-size:.7rem;font-weight:800}
.sticker--portal{right:-2%;bottom:32%;display:flex;align-items:center;gap:12px;transform:rotate(-2deg)}
.sticker--portal img{flex:none}

.hero-scroll{
  position:absolute;left:50%;bottom:18px;transform:translateX(-50%);
  display:flex;align-items:center;gap:10px;color:var(--ink-mute);
  font-size:.82rem;font-weight:600;text-transform:uppercase;letter-spacing:.12em;
}
.hero-scroll-dot{width:9px;height:9px;border-radius:3px 3px 3px 1px;background:var(--orange);animation:scrollDot 1.8s var(--ease) infinite}
@keyframes scrollDot{0%,100%{transform:translateY(-3px)}50%{transform:translateY(4px)}}

/* ---------- Fita marquee ---------- */
.tape{background:var(--ink);overflow:hidden;padding:14px 0;transform:rotate(-1.2deg) scale(1.02);margin:-8px 0 8px}
.tape-track{display:flex;align-items:center;gap:34px;width:max-content;animation:tape 26s linear infinite}
.tape-track span{
  font-family:var(--font-display);font-weight:700;font-size:1.05rem;color:var(--paper);
  text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;
}
.tape-petal{width:16px;height:16px;flex:none;transform:rotate(45deg)}
@keyframes tape{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* ---------- Resposta rápida: fichas ---------- */
.quick{padding:72px 0 30px}
.quick-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:26px}
.card-ficha{
  position:relative;background:var(--card);border-radius:var(--r-md);
  padding:30px 28px 28px;box-shadow:var(--shadow-sm);border:1px solid var(--line);
  background-image:linear-gradient(to bottom,transparent 0 54px,var(--rule) 54px 55px,transparent 55px 100%);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.card-ficha:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.card-ficha--tilt-l{transform:rotate(-.7deg)}
.card-ficha--tilt-r{transform:rotate(.7deg)}
.card-ficha--tilt-l:hover,.card-ficha--tilt-r:hover{transform:rotate(0) translateY(-6px)}
.ficha-label{
  position:absolute;top:-13px;left:24px;background:var(--yellow);color:var(--ink);
  font-weight:800;font-size:.74rem;text-transform:uppercase;letter-spacing:.12em;
  padding:5px 13px;border-radius:8px 8px 8px 2px;box-shadow:0 4px 12px rgba(0,0,0,.12);
}
.card-ficha:nth-child(2) .ficha-label{background:var(--green);color:#fff}
.card-ficha:nth-child(3) .ficha-label{background:var(--orange);color:#fff}
.ficha-title{font-family:var(--font-display);font-weight:700;font-size:1.3rem;line-height:1.2;margin:6px 0 12px}
.card-ficha p{color:var(--ink-soft);font-size:.99rem}

/* ---------- Seções ---------- */
.section{padding:104px 0}
.section-head{margin-bottom:54px}

/* ---------- Serviços ---------- */
.services{background:var(--paper)}
.service-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:28px}
.service-card{
  --accent:var(--yellow);--accent-soft:var(--yellow-soft);
  position:relative;background:var(--card);border-radius:var(--r-lg);
  padding:34px 32px 30px;border:1px solid var(--line);box-shadow:var(--shadow-sm);
  display:flex;flex-direction:column;gap:14px;overflow:hidden;
  transition:transform .35s var(--ease),box-shadow .35s var(--ease),border-color .35s var(--ease);
}
.service-card::before{
  content:"";position:absolute;inset:auto -40px -40px auto;width:170px;height:170px;
  background:var(--accent-soft);border-radius:46% 46% 12% 46%;
  transition:transform .4s var(--ease);transform:rotate(8deg);
}
.service-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-md);border-color:transparent}
.service-card:hover::before{transform:rotate(0) scale(1.18)}
.service-card--yellow{--accent:var(--yellow);--accent-soft:var(--yellow-soft)}
.service-card--green{--accent:var(--green);--accent-soft:var(--green-soft)}
.service-card--blue{--accent:var(--blue);--accent-soft:var(--blue-soft)}
.service-card--orange{--accent:var(--orange);--accent-soft:var(--orange-soft)}
.service-top{display:flex;align-items:center;gap:12px}
.service-petal{width:30px;height:30px;fill:var(--accent);flex:none;transition:transform .35s var(--ease-pop)}
.service-card:hover .service-petal{transform:rotate(90deg) scale(1.12)}
.service-kicker{font-weight:800;font-size:.78rem;text-transform:uppercase;letter-spacing:.14em;color:var(--ink-mute)}
.service-card h3{font-family:var(--font-display);font-weight:800;font-size:clamp(1.45rem,1.2rem + .7vw,1.85rem);line-height:1.12;position:relative;z-index:1}
.service-card > p{color:var(--ink-soft);position:relative;z-index:1;max-width:46ch}
.service-list{display:flex;flex-direction:column;gap:8px;position:relative;z-index:1;margin-top:2px}
.service-list li{position:relative;padding-left:26px;font-weight:600;font-size:.95rem;color:var(--ink-soft)}
.service-list li::before{content:"";position:absolute;left:0;top:5px;width:13px;height:13px;background:var(--accent);border-radius:5px 5px 5px 1px}
.service-cta{
  margin-top:auto;position:relative;z-index:1;width:fit-content;
  font-weight:800;text-decoration:none;color:var(--ink);
  padding-bottom:3px;border-bottom:3px solid var(--accent);
  transition:color .2s var(--ease)
}
.service-cta:hover{color:var(--blue)}
.service-cta span{display:inline-block;transition:transform .25s var(--ease)}
.service-cta:hover span{transform:translateX(5px)}

/* ---------- Rotina: trilha do dia (assinatura) ---------- */
.day{
  background:
    repeating-linear-gradient(to bottom,transparent 0 35px,var(--rule) 35px 36px),
    repeating-linear-gradient(to right,transparent 0 35px,var(--rule) 35px 36px),
    var(--paper-deep);
  overflow:hidden;
}
.day-pin{padding:104px 0 88px;display:flex;flex-direction:column;gap:40px}
.day-head{display:flex;flex-wrap:wrap;align-items:flex-end;gap:10px 36px}
.day-head .display{max-width:18ch}
.day-note{margin-bottom:10px}
.day-viewport{overflow:hidden;width:100%}
.day-track{
  position:relative;display:flex;gap:36px;align-items:stretch;
  width:max-content;padding:46px var(--gutter) 10px;will-change:transform;
}
.day-path{position:absolute;left:0;top:0;width:2330px;height:200px;pointer-events:none}
.day-path path{stroke:var(--blue);stroke-width:4;stroke-linecap:round;stroke-dasharray:1;stroke-dashoffset:var(--day-line,0);opacity:.9}
.day-step{
  position:relative;width:330px;flex:none;background:var(--card);
  border-radius:var(--r-md);border:1px solid var(--line);box-shadow:var(--shadow-sm);
  padding:58px 26px 26px;margin-top:64px;
  transition:transform .3s var(--ease),box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.day-step:nth-child(odd){margin-top:96px}
.day-step.is-active{border-color:transparent;box-shadow:var(--shadow-md);transform:translateY(-6px)}
.day-marker{
  position:absolute;top:-26px;left:24px;width:52px;height:52px;border-radius:46% 46% 46% 12%;
  display:grid;place-items:center;box-shadow:0 10px 24px rgba(25,62,118,.22);
  transform:scale(.78);transition:transform .35s var(--ease-pop);
}
.day-step.is-active .day-marker{transform:scale(1) rotate(-6deg)}
.day-marker svg{width:22px;height:22px;fill:rgba(255,255,255,.92)}
.petal-bg--yellow svg{fill:rgba(35,35,35,.85)}
.day-step h3{font-family:var(--font-display);font-weight:800;font-size:1.35rem;margin-bottom:8px}
.day-step p{color:var(--ink-soft);font-size:.97rem}
.day-foot{display:flex;justify-content:flex-start}

/* ---------- Portal ---------- */
.portal{background:var(--blue-ink);color:#fff;position:relative;overflow:hidden}
.portal::before{
  content:"";position:absolute;inset:0;pointer-events:none;
  background:radial-gradient(70% 60% at 100% 100%,rgba(250,185,0,.10),transparent 60%);
}
.portal-grid{display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);gap:60px;align-items:center;position:relative}
.portal .display{color:#fff}
.portal .section-lead{color:rgba(255,255,255,.78)}
.portal-points{margin-top:30px;display:flex;flex-direction:column;gap:16px}
.portal-points li{display:grid;grid-template-columns:auto 1fr;gap:4px 14px;align-items:baseline;padding-left:24px;position:relative}
.portal-points li::before{content:"";position:absolute;left:0;top:6px;width:13px;height:13px;background:var(--yellow);border-radius:5px 5px 5px 1px}
.portal-points strong{font-family:var(--font-display);font-size:1.08rem}
.portal-points span{grid-column:2;color:rgba(255,255,255,.7);font-size:.97rem}
.portal-ctas{display:flex;flex-wrap:wrap;gap:14px;margin-top:34px}
.portal-fine{margin-top:18px;font-size:.85rem;color:rgba(255,255,255,.55)}

.portal-stage{position:relative;display:flex;justify-content:center;padding:30px 0}
.phone{
  position:relative;width:min(320px,82%);background:#0A1A33;border-radius:42px;
  padding:14px;box-shadow:0 40px 90px rgba(0,0,0,.45),inset 0 0 0 2px rgba(255,255,255,.08);
  z-index:2;
}
.phone-notch{position:absolute;top:14px;left:50%;transform:translateX(-50%);width:110px;height:22px;background:#0A1A33;border-radius:0 0 16px 16px;z-index:3}
.phone-screen{background:var(--paper);border-radius:30px;padding:54px 18px 22px;display:flex;flex-direction:column;gap:12px;color:var(--ink)}
.phone-head{display:flex;align-items:center;gap:10px;margin-bottom:4px}
.phone-head span{display:block;font-size:.72rem;text-transform:uppercase;letter-spacing:.1em;color:var(--ink-mute);font-weight:700}
.phone-head strong{font-family:var(--font-display);font-size:1rem;line-height:1.1}
.phone-card{display:flex;flex-direction:column;gap:2px;background:var(--card);border-radius:14px;padding:12px 14px;border-left:5px solid var(--yellow);box-shadow:var(--shadow-sm)}
.phone-card b{font-size:.74rem;text-transform:uppercase;letter-spacing:.08em;color:var(--ink-mute)}
.phone-card span{font-weight:600;font-size:.93rem}
.phone-card--green{border-left-color:var(--green)}
.phone-actions{display:flex;flex-wrap:wrap;gap:8px;margin-top:4px}
.phone-chip{font-size:.8rem;font-weight:700;padding:8px 13px;border-radius:var(--pill);background:var(--blue-soft);color:var(--blue)}
.phone-chip--solid{background:var(--blue);color:#fff}
.portal-petal{position:absolute;width:120px;height:120px;right:6%;top:2%;opacity:.9;transform:rotate(90deg);z-index:1}
.portal-petal--two{width:74px;height:74px;right:auto;left:8%;top:auto;bottom:4%;transform:rotate(180deg)}

/* ---------- Cuidado ---------- */
.care{background:var(--paper)}
.care-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:24px}
.care-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);
  padding:28px 24px;box-shadow:var(--shadow-sm);
  transition:transform .3s var(--ease),box-shadow .3s var(--ease);
}
.care-card:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.care-petal{width:34px;height:34px;margin-bottom:16px;transition:transform .3s var(--ease-pop)}
.care-card:hover .care-petal{transform:rotate(90deg)}
.care-card h3{font-family:var(--font-display);font-weight:800;font-size:1.2rem;margin-bottom:8px}
.care-card p{color:var(--ink-soft);font-size:.95rem}

/* ---------- Espaço ---------- */
.space{background:var(--paper);padding-top:0}
.space-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-auto-rows:230px;gap:22px}
.space-tile{
  position:relative;border-radius:var(--r-lg);overflow:hidden;border:1px solid var(--line);
  display:flex;align-items:flex-end;box-shadow:var(--shadow-sm);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.space-tile:hover{transform:translateY(-6px);box-shadow:var(--shadow-md)}
.space-tile--big{grid-row:span 2;grid-column:span 2}
.space-tile--study{background:linear-gradient(160deg,var(--blue-soft),#D3DEF0)}
.space-tile--court{background:linear-gradient(160deg,var(--green-soft),#CFE0D8)}
.space-tile--play{background:linear-gradient(160deg,var(--yellow-soft),#FFE7A8)}
.space-caption{
  position:relative;z-index:2;margin:18px;background:rgba(255,255,255,.9);backdrop-filter:blur(6px);
  border-radius:14px;padding:12px 16px;box-shadow:var(--shadow-sm);
}
.space-caption strong{display:block;font-family:var(--font-display);font-weight:800;font-size:1.05rem}
.space-caption span{font-size:.86rem;color:var(--ink-soft)}
.space-art{position:absolute;inset:0;pointer-events:none}
.space-art span{position:absolute;display:block}
/* cabines: mesa + luminária + livros */
.art-desk{left:10%;right:10%;bottom:26%;height:10px;background:var(--blue);border-radius:6px;opacity:.85}
.art-desk::after{content:"";position:absolute;left:8%;top:10px;width:9px;height:52px;background:var(--blue);border-radius:4px}
.art-lamp{right:18%;bottom:calc(26% + 10px);width:54px;height:54px;border-radius:50% 50% 4px 4px;border:9px solid var(--orange);border-bottom:0;opacity:.9}
.art-book{left:16%;bottom:calc(26% + 10px);width:46px;height:14px;background:var(--green);border-radius:4px}
.art-book--two{left:19%;bottom:calc(26% + 24px);width:38px;background:var(--yellow)}
/* quadra: círculo central + linha + bola */
.art-court-circle{left:50%;top:42%;transform:translate(-50%,-50%);width:120px;height:120px;border:8px solid rgba(68,120,108,.55);border-radius:50%}
.art-court-line{left:0;right:0;top:42%;height:8px;background:rgba(68,120,108,.55)}
.art-ball{right:16%;bottom:30%;width:40px;height:40px;border-radius:50%;background:var(--orange);box-shadow:inset -6px -6px 0 rgba(0,0,0,.14)}
/* brinquedoteca: blocos */
.art-block{width:54px;height:54px;border-radius:12px 12px 12px 4px}
.art-block--a{left:18%;bottom:30%;background:var(--blue);transform:rotate(-8deg)}
.art-block--b{left:34%;bottom:34%;background:var(--orange);transform:rotate(7deg)}
.art-block--c{left:26%;bottom:52%;background:var(--green);transform:rotate(-3deg)}
.space-tile--cta{
  background:var(--ink);color:#fff;flex-direction:column;align-items:flex-start;justify-content:center;
  gap:18px;padding:30px;border-color:transparent;
}
.space-tile--cta h3{font-family:var(--font-display);font-weight:800;font-size:1.35rem;line-height:1.2}
.space-tile--cta .btn{align-self:flex-start}
.space-tile--cta::after{
  content:"";position:absolute;right:-26px;bottom:-26px;width:120px;height:120px;
  border-radius:46% 46% 46% 12%;background:var(--yellow);opacity:.9;transform:rotate(180deg);
}

/* ---------- Day Pass (faixa laranja) ---------- */
.daypass{
  background:linear-gradient(135deg,var(--orange) 0%,var(--orange-deep) 100%);
  color:#fff;position:relative;overflow:hidden;padding:84px 0;
}
.daypass::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.16;
  background:
    radial-gradient(circle at 12% 20%,rgba(255,255,255,.7) 0 6px,transparent 7px),
    radial-gradient(circle at 88% 70%,rgba(255,255,255,.7) 0 5px,transparent 6px),
    radial-gradient(circle at 70% 14%,rgba(255,255,255,.7) 0 4px,transparent 5px);
}
.daypass::after{
  content:"";position:absolute;left:-60px;bottom:-90px;width:240px;height:240px;
  border-radius:46% 46% 46% 12%;background:rgba(255,255,255,.10);transform:rotate(24deg);
}
.daypass-grid{display:grid;grid-template-columns:minmax(0,1.25fr) minmax(0,.75fr);gap:48px;align-items:center;position:relative;z-index:1}
.daypass-badge{
  display:inline-flex;align-items:center;gap:9px;font-weight:800;font-size:.86rem;
  letter-spacing:.09em;text-transform:uppercase;background:rgba(255,255,255,.16);
  border:1px solid rgba(255,255,255,.32);border-radius:var(--pill);padding:8px 16px;margin-bottom:18px;
}
.daypass-badge .eyebrow-petal{fill:var(--yellow)}
.daypass .display{color:#fff;max-width:22ch}
.daypass .section-lead{color:rgba(255,255,255,.88);margin-top:14px;max-width:54ch}
.daypass-action{display:flex;flex-direction:column;align-items:flex-start;gap:14px;justify-self:end}
.daypass-action small{color:rgba(255,255,255,.82);font-size:.92rem;max-width:30ch}

/* ---------- Localização ---------- */
.local-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,.9fr);gap:56px;align-items:center}
.local-commit{margin-top:26px;display:flex;flex-direction:column;gap:12px}
.local-commit li{
  display:flex;align-items:center;gap:12px;font-weight:600;color:var(--ink);
}
.local-commit li::before{
  content:"✓";flex:none;width:28px;height:28px;border-radius:46% 46% 46% 12%;
  background:var(--green);color:#fff;display:grid;place-items:center;font-size:.85rem;font-weight:800;
}
.map-card{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-lg);
  box-shadow:var(--shadow-md);overflow:hidden;transform:rotate(1.2deg);
}
.map-art{
  position:relative;height:230px;overflow:hidden;
  background:
    repeating-linear-gradient(to bottom,transparent 0 35px,var(--rule) 35px 36px),
    repeating-linear-gradient(to right,transparent 0 35px,var(--rule) 35px 36px),
    var(--blue-soft);
}
.map-road{position:absolute;background:#fff;box-shadow:0 2px 10px rgba(25,62,118,.12)}
.map-road--h{left:-5%;right:-5%;top:54%;height:26px;border-radius:13px;transform:rotate(-4deg)}
.map-road--v{top:-8%;bottom:-8%;left:34%;width:22px;border-radius:11px;transform:rotate(8deg)}
.map-pin{
  position:absolute;left:34%;top:46%;width:64px;height:64px;transform:translate(-50%,-60%);
  filter:drop-shadow(0 14px 22px rgba(232,74,41,.4));animation:pinBob 2.6s var(--ease) infinite;
}
.map-pin svg{width:100%;height:100%;transform:rotate(135deg)}
@keyframes pinBob{0%,100%{transform:translate(-50%,-60%)}50%{transform:translate(-50%,-72%)}}
.map-body{display:flex;flex-direction:column;gap:4px;padding:24px 28px 26px}
.map-body strong{font-family:var(--font-display);font-weight:800;font-size:1.25rem}
.map-body span{color:var(--ink-soft)}
.map-link{
  margin-top:12px;display:inline-flex;align-items:center;gap:8px;font-weight:700;color:var(--blue);
  text-decoration:none;width:fit-content;border-bottom:2px solid var(--yellow);padding-bottom:2px;
}
.map-link span{transition:transform .2s var(--ease)}
.map-link:hover span{transform:translateX(4px)}

/* ---------- FAQ ---------- */
.faq{background:var(--paper)}
.faq-grid{display:grid;grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);gap:56px;align-items:start}
.faq-copy{position:sticky;top:110px}
.faq-copy .btn{margin-top:26px}
.faq-list{display:flex;flex-direction:column;gap:14px}
.faq-item{
  background:var(--card);border:1px solid var(--line);border-radius:var(--r-md);
  overflow:hidden;transition:box-shadow .3s var(--ease),border-color .3s var(--ease);
}
.faq-item:has(.faq-q[aria-expanded="true"]){box-shadow:var(--shadow-sm);border-color:rgba(25,62,118,.26)}
.faq-h{margin:0}
.faq-q{
  width:100%;display:flex;align-items:center;justify-content:space-between;gap:18px;
  background:none;border:0;text-align:left;cursor:pointer;
  padding:20px 24px;font-family:var(--font-display);font-weight:700;font-size:1.08rem;line-height:1.35;
}
.faq-q:hover{color:var(--blue)}
.faq-icon{
  flex:none;position:relative;width:34px;height:34px;border-radius:46% 46% 46% 12%;
  background:var(--yellow);transition:transform .35s var(--ease-pop),background .25s var(--ease);
}
.faq-icon::before,.faq-icon::after{
  content:"";position:absolute;left:50%;top:50%;width:14px;height:3px;border-radius:2px;
  background:var(--ink);transform:translate(-50%,-50%);transition:transform .3s var(--ease);
}
.faq-icon::after{transform:translate(-50%,-50%) rotate(90deg)}
.faq-q[aria-expanded="true"] .faq-icon{transform:rotate(135deg);background:var(--orange)}
.faq-q[aria-expanded="true"] .faq-icon::before,
.faq-q[aria-expanded="true"] .faq-icon::after{background:#fff}
.faq-a{
  display:grid;grid-template-rows:0fr;transition:grid-template-rows .45s var(--ease);
}
.faq-a.is-open{grid-template-rows:1fr}
.faq-a-inner{overflow:hidden;min-height:0}
.faq-a-inner p{padding:0 24px 22px;color:var(--ink-soft)}
.faq-a-inner a{color:var(--blue);font-weight:600}

/* ---------- Agendamento (ficha escolar) ---------- */
.booking{
  background:
    radial-gradient(80% 70% at 0% 0%,rgba(250,185,0,.08),transparent 55%),
    radial-gradient(70% 60% at 100% 100%,rgba(232,74,41,.10),transparent 60%),
    var(--blue-ink);
  color:#fff;position:relative;overflow:hidden;
}
.booking::before{
  content:"";position:absolute;inset:0;pointer-events:none;opacity:.5;
  background:
    repeating-linear-gradient(to bottom,transparent 0 35px,rgba(255,255,255,.045) 35px 36px),
    repeating-linear-gradient(to right,transparent 0 35px,rgba(255,255,255,.045) 35px 36px);
}
.booking-grid{display:grid;grid-template-columns:minmax(0,.9fr) minmax(0,1.1fr);gap:60px;align-items:start;position:relative;z-index:1}
.booking .display{color:#fff}
.booking .section-lead{color:rgba(255,255,255,.82)}
.eyebrow--light{color:var(--yellow)}
.eyebrow--light .eyebrow-petal{fill:var(--yellow)}
.booking-points{margin-top:26px;display:flex;flex-direction:column;gap:12px}
.booking-points li{display:flex;align-items:center;gap:12px;color:rgba(255,255,255,.92);font-weight:600}
.booking-points li::before{
  content:"";flex:none;width:14px;height:14px;border-radius:46% 46% 46% 12%;background:var(--yellow);
}
.booking-note{color:var(--yellow);margin-top:30px;font-size:1.6rem}
.booking-note .hand-arrow{color:var(--yellow);transform:rotate(24deg) scaleX(-1)}

.booking-form{
  position:relative;background:var(--card);color:var(--ink);
  border-radius:var(--r-lg);box-shadow:var(--shadow-lg);
  padding:40px 42px 36px;overflow:hidden;
  background-image:repeating-linear-gradient(to bottom,transparent 0 35px,var(--rule) 35px 36px);
}
.booking-form::before{ /* margem vermelha de caderno */
  content:"";position:absolute;left:30px;top:0;bottom:0;width:2px;background:rgba(232,74,41,.35);
}
.form-progress{
  position:relative;height:7px;border-radius:5px;background:var(--blue-soft);
  margin-bottom:30px;overflow:hidden;
}
.form-progress span{
  position:absolute;inset:0;transform-origin:left center;transform:scaleX(.333);
  background:linear-gradient(90deg,var(--yellow),var(--orange));border-radius:5px;
  transition:transform .5s var(--ease);
}
.step{display:none;animation:stepIn .45s var(--ease)}
.step.is-active{display:block}
@keyframes stepIn{from{opacity:0;transform:translateX(18px)}to{opacity:1;transform:none}}
.step-label{
  display:inline-block;font-weight:800;font-size:.78rem;letter-spacing:.1em;text-transform:uppercase;
  color:var(--orange);margin-bottom:8px;
}
.step h3{font-family:var(--font-display);font-weight:800;font-size:1.5rem;margin-bottom:20px;line-height:1.25}
.chip-grid{display:flex;flex-wrap:wrap;gap:11px}
.chip{
  border:2px solid var(--line);background:#fff;border-radius:var(--pill);
  padding:11px 20px;font-weight:600;font-size:.97rem;cursor:pointer;
  transition:transform .2s var(--ease),border-color .2s var(--ease),background .2s var(--ease),box-shadow .2s var(--ease);
}
.chip:hover{border-color:var(--blue);transform:translateY(-2px)}
.chip.is-selected{
  background:var(--blue);border-color:var(--blue);color:#fff;
  box-shadow:0 10px 24px rgba(25,62,118,.28);
}
.step-hint{margin-top:14px;color:var(--orange);font-weight:600;font-size:.92rem}
.field-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.field{display:flex;flex-direction:column;gap:7px;font-weight:700;font-size:.92rem}
.field--full{grid-column:1/-1;margin-top:16px}
.field input,.field textarea{
  border:2px solid var(--line);border-radius:var(--r-sm);background:#fff;
  padding:13px 15px;font-weight:500;font-size:1rem;outline:none;resize:vertical;
  transition:border-color .2s var(--ease),box-shadow .2s var(--ease);
}
.field input:focus,.field textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px rgba(25,62,118,.12)}
.field input::placeholder,.field textarea::placeholder{color:rgba(35,35,35,.38);font-weight:400}
.field.is-invalid input{border-color:var(--orange);box-shadow:0 0 0 4px rgba(232,74,41,.12)}
.consent{
  display:flex;gap:12px;align-items:flex-start;margin-top:20px;
  font-size:.9rem;color:var(--ink-soft);font-weight:500;cursor:pointer;
}
.consent input{margin-top:3px;width:19px;height:19px;accent-color:var(--blue);flex:none;cursor:pointer}
.consent a{color:var(--blue);font-weight:700}
.consent.is-invalid span{color:var(--orange-deep)}
.form-actions{display:flex;justify-content:space-between;gap:14px;margin-top:30px}
.form-actions [data-prev][disabled]{opacity:.35;cursor:not-allowed}
.form-success,.form-error{text-align:center;padding:18px 6px 6px}
.success-petal{
  position:relative;display:inline-grid;place-items:center;width:84px;height:84px;margin-bottom:18px;
}
.success-petal svg{position:absolute;inset:0;width:100%;height:100%;fill:var(--green);transform:rotate(-6deg)}
.success-petal b{position:relative;color:#fff;font-size:2rem;line-height:1}
.form-success h3{font-family:var(--font-display);font-weight:800;font-size:1.7rem;margin-bottom:10px}
.form-success p{color:var(--ink-soft);max-width:42ch;margin:0 auto 22px}
.form-error{
  border:2px solid rgba(232,74,41,.35);border-radius:var(--r-md);background:var(--orange-soft);
  padding:22px;margin-top:24px;
}
.form-error strong{display:block;font-family:var(--font-display);font-size:1.15rem;margin-bottom:6px}
.form-error p{color:var(--ink-soft);margin-bottom:16px}

/* ---------- Rodapé ---------- */
.footer{background:var(--ink);color:rgba(255,255,255,.84);padding:72px 0 30px}
.footer-grid{
  display:grid;grid-template-columns:minmax(0,1.3fr) repeat(3,minmax(0,.7fr));
  gap:44px;padding-bottom:48px;border-bottom:1px solid rgba(255,255,255,.12);
}
.footer-brand img{width:190px;margin-bottom:18px}
.footer-brand p{font-size:.95rem;color:rgba(255,255,255,.66);max-width:34ch}
.footer-col{display:flex;flex-direction:column;gap:11px}
.footer-col h3{
  font-family:var(--font-display);font-weight:800;font-size:1rem;color:#fff;
  margin-bottom:6px;letter-spacing:.02em;
}
.footer-col a{color:rgba(255,255,255,.78);text-decoration:none;font-size:.95rem;width:fit-content;transition:color .2s var(--ease)}
.footer-col a:hover{color:var(--yellow)}
.footer-col span{font-size:.95rem;color:rgba(255,255,255,.66)}
.footer-bottom{
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  padding-top:26px;font-size:.88rem;color:rgba(255,255,255,.55);
}
.footer-made{display:inline-flex;align-items:center;gap:8px}
.footer-petal{width:16px;height:16px}

/* ---------- Barra fixa mobile ---------- */
.sticky-cta{
  position:fixed;left:12px;right:12px;bottom:12px;z-index:300;
  display:none;grid-template-columns:auto auto 1fr;gap:8px;
  background:rgba(255,255,255,.92);backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  border:1px solid var(--line);border-radius:var(--pill);padding:8px;
  box-shadow:0 18px 50px rgba(25,62,118,.28);
}
.sticky-cta a{
  display:flex;align-items:center;justify-content:center;
  text-decoration:none;font-weight:700;font-size:.92rem;
  border-radius:var(--pill);padding:12px 16px;white-space:nowrap;
}
.sticky-portal{color:var(--blue);border:2px solid var(--blue-soft)}
.sticky-wa{background:var(--green);color:#fff}
.sticky-main{background:var(--blue);color:#fff}


/* ==========================================================================
   Fotos reais — tratamento por seção
   ========================================================================== */

/* Herói: colagem de fotos mascaradas na pétala da marca */
.hero-art{position:relative;min-height:540px}
.hero-photos{position:absolute;inset:0}
.hero-photo{
  margin:0;position:absolute;aspect-ratio:1;overflow:hidden;
  clip-path:url(#petalClip);background:var(--blue-soft);
  box-shadow:0 26px 60px rgba(25,62,118,.22);z-index:2;
}
.hero-photo img{width:100%;height:100%;object-fit:cover;display:block}
.hero-photo--main{width:62%;left:12%;top:13%}
.hero-photo--a{width:35%;right:1%;top:1%;z-index:3}
.hero-photo--b{width:39%;left:-1%;bottom:3%;z-index:3}
.hero-accent{position:absolute;width:62px;height:62px;z-index:1;opacity:.92;filter:drop-shadow(0 12px 22px rgba(25,62,118,.18))}
.hero-accent{right:7%;bottom:15%}
.hero-accent--two{left:31%;top:-1%;width:42px;height:42px}
.hero-art .sticker{z-index:5}

/* Espaço: tiles viram foto com legenda flutuante */
.space-photo{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;display:block;z-index:0}
.space-tile::after{
  content:"";position:absolute;inset:0;z-index:1;pointer-events:none;
  background:linear-gradient(to top,rgba(13,34,69,.5) 0%,transparent 42%);
}
.space-tile--cta::after{display:none}

/* Serviços: foto sangrando no topo do card */
.service-media{
  margin:-34px -32px 4px;height:188px;overflow:hidden;position:relative;z-index:1;
  background:var(--accent-soft);
}
.service-media img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .5s var(--ease)}
.service-card:hover .service-media img{transform:scale(1.05)}

/* Rotina: foto no topo de cada cartão do dia */
.day-step{padding-top:0;overflow:hidden}
.day-photo{margin:0;height:150px;overflow:hidden;position:relative}
.day-photo img{width:100%;height:100%;object-fit:cover;display:block}
.day-step{padding-left:0;padding-right:0}
.day-step > :not(.day-photo):not(.day-marker){margin-left:26px;margin-right:26px}
.day-step h3{margin-top:18px}
.day-marker{top:124px}

/* Galeria "Momentos": mosaico em colunas (à prova de proporção) */
.gallery{background:var(--paper-deep)}
.section-head--center{text-align:center;margin-inline:auto;max-width:62ch}
.section-head--center .section-lead{margin-inline:auto}
.eyebrow--center{justify-content:center}
.gallery-grid{columns:4;column-gap:18px}
.gallery-item{
  margin:0 0 18px;break-inside:avoid;border-radius:var(--r-md);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow-sm);background:var(--blue-soft);
  transition:transform .35s var(--ease),box-shadow .35s var(--ease);
}
.gallery-item img{width:100%;height:auto;display:block}
.gallery-item:hover{transform:translateY(-5px) rotate(-.6deg);box-shadow:var(--shadow-md)}

/* ==========================================================================
   Responsivo
   ========================================================================== */
@media (max-width:1080px){
  .topbar-nav{display:none}
  .menu-toggle{display:block}
  .topbar-actions .btn--primary{display:none}
}
@media (max-width:1024px){
  .hero-inner{grid-template-columns:1fr;gap:40px}
  .hero-art{min-height:380px;max-width:560px;margin-inline:auto;width:100%}
  .portal-grid,.booking-grid,.local-grid,.faq-grid{grid-template-columns:1fr;gap:44px}
  .faq-copy{position:static}
  .daypass-grid{grid-template-columns:1fr;gap:30px}
  .daypass-action{justify-self:start;align-items:flex-start}
  .care-grid{grid-template-columns:repeat(2,1fr)}
  .space-grid{grid-template-columns:repeat(2,1fr)}
  /* Dia: trilho vira coluna (o pin só existe no desktop, via JS) */
  .day-pin{padding:88px 0 72px}
  .day-viewport{overflow:visible}
  .day-track{width:100%;flex-direction:column;gap:22px;padding:10px 0 0}
  .day-path{display:none}
  .day-step,.day-step:nth-child(odd){width:100%;max-width:560px;margin:30px 0 0}
  .day-step:first-child{margin-top:14px}
}
@media (max-width:860px){
  body{padding-bottom:84px}
  .sticky-cta{display:grid}
  .topbar-actions .btn--ghost{display:none}
  .quick-grid{grid-template-columns:1fr;gap:16px}
  .service-grid{grid-template-columns:1fr}
  .footer-grid{grid-template-columns:1fr 1fr}
}
@media (max-width:720px){
  body{font-size:16px}
  .section{padding:78px 0}
  .topbar-inner{height:72px}
  .brand-logo{width:148px}
  .hero{padding-top:128px}
  .care-grid{grid-template-columns:1fr}
  .space-grid{grid-template-columns:1fr;grid-auto-rows:210px}
  .space-tile--big{grid-column:auto;grid-row:auto}
  .booking-form{padding:30px 22px 28px}
  .booking-form::before{left:14px}
  .field-grid{grid-template-columns:1fr}
  .form-actions{flex-direction:row}
  .footer-grid{grid-template-columns:1fr;gap:32px}
  .footer-bottom{flex-direction:column;align-items:flex-start}
}
@media (max-width:560px){
  .hero-cta .btn{width:100%}
  .chip{flex:1 1 auto;text-align:center;justify-content:center}
  .form-actions{flex-wrap:wrap}
  .form-actions .btn{flex:1}
  .tape-track span{font-size:.82rem}
  .hand-note{font-size:1.25rem}
}

/* ==========================================================================
   Movimento reduzido
   ========================================================================== */
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{animation-duration:.01ms !important;animation-iteration-count:1 !important;transition-duration:.01ms !important}
  .tape-track{animation:none !important}
  .map-pin{animation:none}
  .scribble path{stroke-dashoffset:0 !important}
  .mark::before{transform:skewX(-6deg) !important}
}

/* ==========================================================================
   Responsivo — fotos e galeria
   ========================================================================== */
@media (max-width:1024px){
  .gallery-grid{columns:3}
  .hero-art{min-height:480px;max-width:560px;margin-inline:auto}
}
@media (max-width:720px){
  .gallery-grid{columns:2}
  .hero-art{min-height:420px}
  .hero-photo--main{width:60%;left:10%;top:12%}
  .sticker--list{display:none}
  .service-media{height:172px}
}
@media (max-width:480px){
  .hero-art{min-height:360px}
  .sticker--portal{display:none}
}
