/* =========================================================
   LAGO DOS TAMBAQUIS — camada de refino visual & efeitos
   (carregado após styles.css; sobrescreve e adiciona)
   ========================================================= */

:root{
  --font-body:"Outfit", system-ui, sans-serif;
  --ring:0 0 0 1px rgba(255,255,255,.6);
}

body{font-weight:400;letter-spacing:-.01em}
.title{letter-spacing:-1px}
.lead{line-height:1.7}

/* ---------------- Ícones SVG ---------------- */
.ic{width:1.1em;height:1.1em;display:inline-block;vertical-align:-0.18em;flex:0 0 auto}
.btn .ic{width:1.15em;height:1.15em}
.ic--arrow{transition:transform .3s var(--ease)}
.btn:hover .ic--arrow{transform:translateX(5px)}

/* ---------------- Grão / textura premium ---------------- */
.grain{
  position:fixed;inset:0;z-index:120;pointer-events:none;opacity:.05;mix-blend-mode:overlay;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
}

/* ---------------- Barra de progresso de scroll ---------------- */
.scroll-progress{
  position:fixed;top:0;left:0;height:4px;width:100%;z-index:130;transform:scaleX(0);transform-origin:0 50%;
  background:linear-gradient(90deg,var(--pink),var(--yellow),var(--cyan),var(--green));
  box-shadow:0 1px 6px rgba(0,0,0,.15);
}

/* fundo com leve deriva */
.bg-flow{animation:bgDrift 26s ease-in-out infinite alternate}
@keyframes bgDrift{from{transform:translate3d(0,0,0) scale(1)}to{transform:translate3d(0,-2%,0) scale(1.06)}}

/* ---------------- Eyebrow com traço ---------------- */
.eyebrow--line{display:inline-flex;align-items:center;gap:.6em;background:transparent;padding-left:0}
.eyebrow--line::before{content:"";width:26px;height:2px;border-radius:2px;background:currentColor;opacity:.7}
.eyebrow{background:transparent;padding-left:0}
.eyebrow:not(.eyebrow--light){color:var(--pink)}

/* ---------------- Crédito do rodapé ---------------- */
.footer__credit{margin-top:.5rem;font-size:.82rem;opacity:.9;letter-spacing:.02em}
.footer__credit strong{font-family:var(--font-display);font-weight:700;
  background:linear-gradient(90deg,var(--cyan),var(--pink),var(--yellow));
  -webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;color:var(--cyan)}

/* ---------------- Navbar: link ativo (scrollspy) ---------------- */
.nav__links a.active:not(.btn)::after{right:0}
.nav.scrolled .nav__links a.active:not(.btn){color:var(--pink)}

/* =========================================================
   HERO — texto cinético + camadas
   ========================================================= */
.hero__tint{position:absolute;inset:0;background:
   radial-gradient(60% 50% at 18% 30%, rgba(236,45,138,.22), transparent 70%),
   radial-gradient(55% 50% at 85% 75%, rgba(22,185,198,.25), transparent 70%);
   mix-blend-mode:screen;pointer-events:none}
.hero__video{scale:1.12}
/* fallback: imagem estática atrás do vídeo (aparece se o vídeo não carregar/tocar) */
.hero__media{background:#0a3f43 url('../assets/img/hero-poster.jpg') center/cover no-repeat}

.hero__title .line{display:block;overflow:hidden;padding-bottom:.06em}
.hero__title .word{display:inline-block;transform:translateY(115%);opacity:0}
.is-ready .hero__title .word{animation:wordUp 1s var(--ease) forwards}
.is-ready .hero__title .line:nth-child(1) .word:nth-child(1){animation-delay:.15s}
.is-ready .hero__title .line:nth-child(1) .word:nth-child(2){animation-delay:.27s}
.is-ready .hero__title .line:nth-child(1) .word:nth-child(3){animation-delay:.39s}
.is-ready .hero__title .line:nth-child(2) .word:nth-child(1){animation-delay:.5s}
.is-ready .hero__title .line:nth-child(2) .word:nth-child(2){animation-delay:.6s}
@keyframes wordUp{to{transform:translateY(0);opacity:1}}

.reveal-up{opacity:0;transform:translateY(26px)}
.is-ready .hero__sub{animation:fadeUp .9s var(--ease) .75s forwards}
.is-ready .hero__actions{animation:fadeUp .9s var(--ease) .9s forwards}
@keyframes fadeUp{to{opacity:1;transform:none}}

.hero__scroll{display:flex;flex-direction:column;align-items:center;gap:.5rem}
.hero__scroll-txt{font-family:var(--font-display);font-size:.7rem;letter-spacing:.25em;text-transform:uppercase;color:rgba(255,255,255,.8)}

/* =========================================================
   ONDAS DE ÁGUA EM MOVIMENTO
   ========================================================= */
.wave-anim{position:absolute;left:0;right:0;bottom:-1px;height:clamp(80px,10vw,140px);z-index:4;pointer-events:none}
.wave-anim::before,.wave-anim::after{content:"";position:absolute;inset:0;background-repeat:repeat-x;background-position:bottom center}
.wave-anim--hero::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 120' preserveAspectRatio='none'%3E%3Cpath d='M0 56 C40 18 80 94 120 56 C160 18 200 94 240 56 L240 120 L0 120 Z' fill='%23fbf6ec'/%3E%3C/svg%3E");background-size:240px 100%;animation:waveMove 11s linear infinite}
.wave-anim--hero::after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 120' preserveAspectRatio='none'%3E%3Cpath d='M0 64 C36 34 72 92 100 64 C128 36 164 92 200 64 L200 120 L0 120 Z' fill='%23fbf6ec'/%3E%3C/svg%3E");background-size:200px 100%;opacity:.55;animation:waveMove 7s linear infinite reverse}
.wave-anim--cta::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 120' preserveAspectRatio='none'%3E%3Cpath d='M0 56 C40 18 80 94 120 56 C160 18 200 94 240 56 L240 120 L0 120 Z' fill='%2308363b'/%3E%3C/svg%3E");background-size:240px 100%;animation:waveMove 12s linear infinite}
.wave-anim--cta::after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 120' preserveAspectRatio='none'%3E%3Cpath d='M0 64 C36 34 72 92 100 64 C128 36 164 92 200 64 L200 120 L0 120 Z' fill='%2308363b'/%3E%3C/svg%3E");background-size:200px 100%;opacity:.5;animation:waveMove 8s linear infinite reverse}
@keyframes waveMove{from{background-position-x:0}to{background-position-x:240px}}

/* =========================================================
   MARQUEE
   ========================================================= */
.marquee{background:linear-gradient(90deg,var(--teal),var(--cyan-deep));overflow:hidden;padding:.85rem 0;
  border-top:2px solid rgba(255,255,255,.18);border-bottom:2px solid rgba(255,255,255,.18);position:relative;z-index:5}
.marquee__track{display:inline-flex;align-items:center;gap:2.4rem;white-space:nowrap;will-change:transform;animation:marquee 28s linear infinite}
.marquee:hover .marquee__track{animation-play-state:paused}
.marquee__track span{font-family:var(--font-display);font-weight:700;font-size:clamp(1.1rem,2vw,1.6rem);color:#fff;text-transform:uppercase;letter-spacing:.02em}
.marquee__track .ic{color:var(--yellow);width:1.1em;height:1.1em}
@keyframes marquee{from{transform:translateX(0)}to{transform:translateX(-50%)}}

/* =========================================================
   BOLHAS (sobem na água)
   ========================================================= */
.bubbles{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
.bubble{position:absolute;bottom:-40px;border-radius:50%;
  background:radial-gradient(circle at 32% 28%, rgba(255,255,255,.85), rgba(255,255,255,.18) 55%, rgba(255,255,255,0) 70%);
  box-shadow:inset 0 0 6px rgba(255,255,255,.4);animation:rise linear infinite;opacity:0}
@keyframes rise{
  0%{transform:translateY(0) translateX(0) scale(.7);opacity:0}
  10%{opacity:.7}
  50%{transform:translateY(-46vh) translateX(14px) scale(1)}
  90%{opacity:.5}
  100%{transform:translateY(-92vh) translateX(-10px) scale(1.05);opacity:0}
}

/* =========================================================
   BOTÕES — ripple, magnético, refino
   ========================================================= */
.btn{position:relative;overflow:hidden;isolation:isolate;font-family:var(--font-display);letter-spacing:.01em}
.btn>*{position:relative;z-index:1}
.btn--ghost{backdrop-filter:blur(3px)}
[data-magnetic]{will-change:transform}

.ripple{position:absolute;border-radius:50%;background:rgba(255,255,255,.5);transform:translate(-50%,-50%) scale(0);
  pointer-events:none;z-index:0;animation:rippleGo .65s var(--ease) forwards;mix-blend-mode:overlay}
@keyframes rippleGo{to{transform:translate(-50%,-50%) scale(1);opacity:0}}

/* ripple de água global ao clicar */
.water-ripple{position:fixed;z-index:115;width:14px;height:14px;border-radius:50%;pointer-events:none;
  border:2px solid rgba(22,185,198,.7);transform:translate(-50%,-50%) scale(.4);animation:waterRipple .8s var(--ease) forwards}
@keyframes waterRipple{to{transform:translate(-50%,-50%) scale(6);opacity:0;border-color:rgba(236,45,138,.0)}}

/* =========================================================
   TILT (perspectiva nos cards)
   ========================================================= */
[data-tilt]{transform:perspective(900px) rotateX(0) rotateY(0);transition:transform .4s var(--ease),box-shadow .4s var(--ease);transform-style:preserve-3d}
.card[data-tilt]:hover,.price[data-tilt]:hover,.pill[data-tilt]:hover,.info-card[data-tilt]:hover{transition:transform .12s linear,box-shadow .3s}

/* =========================================================
   PILLS / ÍCONES coloridos
   ========================================================= */
.pill__ico{display:grid;place-items:center;width:54px;height:54px;border-radius:16px;flex-shrink:0;
  background:linear-gradient(135deg,var(--cyan),var(--teal));color:#fff;font-size:1.5rem;box-shadow:0 8px 18px rgba(12,124,132,.25)}
.pill:nth-child(1) .pill__ico{background:linear-gradient(135deg,var(--pink),var(--pink-deep))}
.pill:nth-child(2) .pill__ico{background:linear-gradient(135deg,var(--green),var(--green-deep))}
.pill:nth-child(3) .pill__ico{background:linear-gradient(135deg,var(--blue),var(--blue-deep))}
.pill:nth-child(4) .pill__ico{background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));color:#5a3d00}
.pill{transition:transform .3s var(--ease),box-shadow .3s var(--ease)}
.pill:hover{box-shadow:var(--shadow)}

/* sticker */
.sticker{display:inline-flex;align-items:center;gap:.4em}
.sticker .ic{width:1.05em;height:1.05em}

/* =========================================================
   ATRAÇÕES — refino dos cards
   ========================================================= */
.card{border:1px solid rgba(12,124,132,.06)}
.card__img::after{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,60,67,.25));opacity:0;transition:opacity .4s}
.card:hover .card__img::after{opacity:1}
.card__body h3{display:flex;align-items:center;gap:.4em}
.card__body{position:relative}
.card__body::before{content:"";position:absolute;top:0;left:1.25rem;right:1.25rem;height:3px;border-radius:3px;
  background:linear-gradient(90deg,var(--cyan),var(--pink));transform:scaleX(0);transform-origin:0;transition:transform .4s var(--ease)}
.card:hover .card__body::before{transform:scaleX(1)}

/* =========================================================
   TICKLIST — fish icon inline
   ========================================================= */
.ticklist li{display:flex;align-items:flex-start;gap:.7rem;padding-left:0}
.ticklist li::before{content:none}
.ticklist .ic{color:var(--cyan-deep);width:1.3em;height:1.3em;margin-top:.15em}

/* =========================================================
   GASTRONOMIA
   ========================================================= */
.gastro__item::after{content:"";position:absolute;inset:0;border:2px solid transparent;border-radius:var(--r);transition:border-color .3s}
.gastro__item:hover::after{border-color:rgba(255,255,255,.5)}

/* =========================================================
   DAY USE — preços refinados + flag
   ========================================================= */
.price__ico{display:grid;place-items:center;width:64px;height:64px;margin:0 auto .6rem;border-radius:50%;font-size:1.7rem;
  background:linear-gradient(135deg,var(--cyan),var(--teal));color:#fff;box-shadow:0 10px 22px rgba(12,124,132,.25)}
.price:nth-child(1) .price__ico{background:linear-gradient(135deg,var(--green),var(--green-deep))}
.price--feat .price__ico{background:linear-gradient(135deg,var(--pink),var(--pink-deep))}
.price:nth-child(3) .price__ico{background:linear-gradient(135deg,var(--blue),var(--blue-deep))}
.price{position:relative;overflow:hidden}
.price__flag{position:absolute;top:14px;right:-34px;transform:rotate(38deg);background:var(--yellow);color:#5a3d00;
  font-family:var(--font-display);font-weight:700;font-size:.72rem;padding:.3em 2.6em;box-shadow:0 4px 10px rgba(0,0,0,.15)}
.incluso__grid li{display:inline-flex;align-items:center;gap:.5em}
.incluso__grid .ic{color:var(--yellow);width:1.05em;height:1.05em}

/* =========================================================
   AVISOS — ícone no header dos cards
   ========================================================= */
.info-card{overflow:visible}
.info-card h3{display:flex;align-items:center;gap:.6rem}
.info-card__ico{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;color:#fff;font-size:1.2rem;flex-shrink:0}
.info-card--cyan .info-card__ico{background:linear-gradient(135deg,var(--cyan),var(--cyan-deep))}
.info-card--pink .info-card__ico{background:linear-gradient(135deg,var(--pink),var(--pink-deep))}
.info-card--yellow .info-card__ico{background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));color:#5a3d00}
.info-card__closed::before{content:"";display:inline-block;width:1em;height:1em;margin-right:.4em;vertical-align:-.15em;
  background:currentColor;-webkit-mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='9' fill='none' stroke='%23000' stroke-width='2'/%3E%3Cpath d='M6 6l12 12' stroke='%23000' stroke-width='2'/%3E%3C/svg%3E") center/contain no-repeat;
  mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24'%3E%3Ccircle cx='12' cy='12' r='9' fill='none' stroke='%23000' stroke-width='2'/%3E%3Cpath d='M6 6l12 12' stroke='%23000' stroke-width='2'/%3E%3C/svg%3E") center/contain no-repeat}

/* =========================================================
   CONTATO — ícones em círculo
   ========================================================= */
.contact-list .ci{display:grid;place-items:center;width:42px;height:42px;border-radius:12px;flex-shrink:0;
  background:rgba(12,124,132,.1);color:var(--teal-deep);font-size:1.1rem}

/* =========================================================
   GALERIA — refino do ícone de zoom
   ========================================================= */
.gallery__item::after{content:"+";font-size:2.2rem;font-weight:300;font-family:var(--font-display)}

/* =========================================================
   FOOTER social como botões redondos
   ========================================================= */
.footer__social a{display:grid;place-items:center;width:44px;height:44px;border-radius:50%;padding:0;font-size:1.2rem}
.footer__social a .ic{width:1.2em;height:1.2em}

/* =========================================================
   BOTÕES FLUTUANTES — stack
   ========================================================= */
.fab-stack{position:fixed;right:22px;bottom:22px;z-index:60;display:flex;flex-direction:column;gap:12px;align-items:center}
.fab{position:relative;right:auto;bottom:auto}
.fab--whats{order:3}
.fab--top{order:2;width:50px;height:50px}
.fab--sound{order:1;width:50px;height:50px;background:#fff;color:var(--teal-deep);box-shadow:0 10px 26px rgba(8,60,67,.22)}
.fab--sound .ic{width:1.4em;height:1.4em}
.fab--sound.is-on{background:linear-gradient(135deg,var(--cyan),var(--teal));color:#fff}
.fab--sound.is-on::after{content:"";position:absolute;inset:-4px;border-radius:50%;border:2px solid var(--cyan);
  animation:soundPulse 1.6s ease-out infinite}
@keyframes soundPulse{0%{transform:scale(.9);opacity:.8}100%{transform:scale(1.5);opacity:0}}
.fab--top .ic{transform:rotate(-90deg);width:1.3em;height:1.3em}

/* dica de som */
.sound-hint{position:fixed;right:84px;bottom:30px;z-index:59;background:#fff;color:var(--teal-deep);
  font-family:var(--font-display);font-weight:600;font-size:.85rem;padding:.55em 1em;border-radius:999px;
  box-shadow:var(--shadow);display:flex;align-items:center;gap:.4em;opacity:0;transform:translateX(10px);
  transition:opacity .4s,transform .4s;pointer-events:none}
.sound-hint.show{opacity:1;transform:none}
.sound-hint::after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%) rotate(45deg);width:12px;height:12px;background:#fff}
.sound-hint .ic{color:var(--cyan-deep);animation:wavePulse 1.4s ease-in-out infinite}
@keyframes wavePulse{0%,100%{transform:translateY(0)}50%{transform:translateY(-2px)}}

/* =========================================================
   REVEAL — variações com direção
   ========================================================= */
.reveal{opacity:0;transform:translateY(40px) scale(.98);transition:opacity .8s var(--ease),transform .8s var(--ease)}
.reveal.in{opacity:1;transform:none}
.cards .card{transition-delay:calc(var(--i,0) * .05s)}

/* =========================================================
   RESPONSIVO — ajustes da camada de efeitos
   ========================================================= */
@media (max-width:900px){
  .fab-stack{right:16px;bottom:16px}
  .sound-hint{right:74px;bottom:22px}
  [data-tilt]{transform:none!important}
}
@media (max-width:760px){
  .pill__ico{width:46px;height:46px;font-size:1.25rem}
  .hero__title .word{transform:translateY(108%)}
  .marquee__track{gap:1.6rem}
}

/* desativa custom cursor/tilt em toque */
@media (hover:none){
  [data-tilt]{transform:none!important}
}

/* =========================================================
   FOLHAGENS (tema natureza / eco)
   ========================================================= */
.leaf{position:absolute;pointer-events:none;z-index:1;opacity:.5;background-repeat:no-repeat;background-size:contain;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 80 120'%3E%3Cpath d='M40 3 C13 31 11 81 40 117 C69 81 67 31 40 3 Z' fill='%231f9e6e'/%3E%3Cg fill='none' stroke='%230c6b4c' stroke-width='2.4' stroke-linecap='round' opacity='.55'%3E%3Cpath d='M40 12 L40 110'/%3E%3Cpath d='M40 32 C31 36 25 42 21 52'/%3E%3Cpath d='M40 32 C49 36 55 42 59 52'/%3E%3Cpath d='M40 58 C31 62 25 68 21 79'/%3E%3Cpath d='M40 58 C49 62 55 68 59 79'/%3E%3Cpath d='M40 82 C33 85 28 90 25 98'/%3E%3Cpath d='M40 82 C47 85 52 90 55 98'/%3E%3C/g%3E%3C/svg%3E");
  transform-origin:top center;animation:sway 7s ease-in-out infinite}
.leaf--a{width:170px;height:255px;top:-40px;left:-46px;transform:rotate(28deg);opacity:.4}
.leaf--b{width:130px;height:195px;bottom:-30px;right:-30px;transform:rotate(-150deg);opacity:.35;animation-delay:-3s}
.leaf--c{width:150px;height:225px;top:-30px;right:4%;transform:rotate(18deg);opacity:.28;animation-delay:-2s}
@keyframes sway{0%,100%{rotate:0deg}50%{rotate:4deg}}
.leaf--b{animation-name:swayB}
@keyframes swayB{0%,100%{rotate:0deg}50%{rotate:-4deg}}

/* =========================================================
   TOUR EM VÍDEO
   ========================================================= */
.tour{background:linear-gradient(165deg,#0d6b62 0%,#0a4a4a 55%,#0c5a3f 100%);color:#fff;isolation:isolate;overflow:hidden}
.tour .container{position:relative;z-index:2}
.video{position:relative;max-width:960px;margin:0 auto;border-radius:var(--r-xl);overflow:hidden;
  box-shadow:0 40px 90px rgba(0,0,0,.4);border:6px solid rgba(255,255,255,.9);aspect-ratio:16/9;
  background:#06302f url('../assets/img/hero-poster.jpg') center/cover no-repeat}
.video__el{width:100%;height:100%;object-fit:cover;display:block}
.video__play,.video__sound{position:absolute;border:none;cursor:pointer;display:grid;place-items:center;color:#fff;
  background:rgba(8,60,67,.55);backdrop-filter:blur(6px);border-radius:50%;transition:transform .25s var(--ease),background .25s,opacity .3s}
.video__play{inset:auto;top:50%;left:50%;transform:translate(-50%,-50%);width:84px;height:84px;font-size:2rem;
  box-shadow:0 12px 30px rgba(0,0,0,.35)}
.video__play .ic{width:1.4em;height:1.4em;margin-left:.04em}
.video__play:hover{background:var(--pink);transform:translate(-50%,-50%) scale(1.08)}
.video.is-playing .video__play{opacity:0;pointer-events:none}
.video:hover .video__play{opacity:1;pointer-events:auto}
.video__sound{right:16px;bottom:16px;width:50px;height:50px}
.video__sound:hover{background:var(--cyan-deep);transform:scale(1.08)}
.video__sound .ic{width:1.3em;height:1.3em}
.video__badge{position:absolute;left:16px;top:16px;display:inline-flex;align-items:center;gap:.45em;
  background:rgba(255,255,255,.92);color:var(--teal-deep);font-family:var(--font-display);font-weight:700;
  font-size:.85rem;padding:.45em .9em;border-radius:999px;box-shadow:0 6px 16px rgba(0,0,0,.2)}
.video__badge .ic{color:var(--cyan-deep)}
.wave-anim--tour::before{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 240 120' preserveAspectRatio='none'%3E%3Cpath d='M0 56 C40 18 80 94 120 56 C160 18 200 94 240 56 L240 120 L0 120 Z' fill='%23eaf4f3'/%3E%3C/svg%3E");background-size:240px 100%;animation:waveMove 11s linear infinite}
.wave-anim--tour::after{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 200 120' preserveAspectRatio='none'%3E%3Cpath d='M0 64 C36 34 72 92 100 64 C128 36 164 92 200 64 L200 120 L0 120 Z' fill='%23eaf4f3'/%3E%3C/svg%3E");background-size:200px 100%;opacity:.55;animation:waveMove 7s linear infinite reverse}

/* =========================================================
   AVALIAÇÕES (mural subindo)
   ========================================================= */
.reviews{overflow:hidden}
.reviews__head{display:grid;grid-template-columns:1.3fr .9fr;gap:2rem;align-items:end;margin-bottom:2.4rem}
.reviews__intro .lead{margin-top:.3rem}
.reviews__badge{background:#fff;border-radius:var(--r-lg);padding:1.6rem;box-shadow:var(--shadow);text-align:center;
  border:1px solid rgba(12,124,132,.07)}
.reviews__glogo{width:34px;height:34px;margin-bottom:.5rem}
.stars{display:inline-flex;gap:.12em;color:#ffb400}
.stars .ic{width:1.05em;height:1.05em}
.stars .is-empty{color:#d8e0e0}
.stars--lg{font-size:1.4rem;display:flex;justify-content:center;margin-bottom:0}
.reviews__score-row{display:flex;align-items:center;justify-content:center;gap:.7rem;margin-bottom:.4rem}
.reviews__num{font-family:var(--font-display);font-weight:800;font-size:2.5rem;line-height:1;color:var(--teal-deep)}
.reviews__count{color:var(--muted);font-size:.92rem;margin-bottom:1rem}
.reviews__count strong{color:var(--teal-deep)}

.reviews__wall{display:grid;grid-template-columns:repeat(3,1fr);gap:1.2rem;height:min(72vh,580px);overflow:hidden;position:relative;
  -webkit-mask:linear-gradient(180deg,transparent 0,#000 13%,#000 87%,transparent 100%);
  mask:linear-gradient(180deg,transparent 0,#000 13%,#000 87%,transparent 100%)}
.reviews__col{display:flex;flex-direction:column;gap:1.2rem;animation:riseCol 34s linear infinite;will-change:transform}
.reviews__col--down{animation-duration:42s;animation-direction:reverse}
.reviews__col--3{animation-duration:38s}
.reviews__wall:hover .reviews__col{animation-play-state:paused}
@keyframes riseCol{from{transform:translateY(0)}to{transform:translateY(-50%)}}

.review{background:#fff;border-radius:var(--r-lg);padding:1.3rem 1.4rem;box-shadow:var(--shadow-sm);
  border:1px solid rgba(12,124,132,.06);flex-shrink:0}
.review__top{display:flex;align-items:center;gap:.7rem;margin-bottom:.7rem}
.review__avatar{display:grid;place-items:center;width:42px;height:42px;border-radius:50%;flex-shrink:0;
  background:var(--c,#16b9c6);color:#fff;font-family:var(--font-display);font-weight:700;font-size:1.1rem}
.review__who{display:flex;flex-direction:column;line-height:1.2;flex:1}
.review__who strong{font-family:var(--font-display);color:var(--ink);font-size:1rem}
.review__who span{font-size:.8rem;color:var(--muted)}
.review__g{width:20px;height:20px;flex-shrink:0}
.review .stars{font-size:.95rem;margin-bottom:.5rem}
.review p{color:#3a565b;font-size:.96rem;line-height:1.55}

/* =========================================================
   CORREÇÕES DE CONTRASTE (ícones)
   ========================================================= */
.incluso__grid .ic{color:#fff}                        /* check branco sobre a pill translúcida */
.incluso__grid li{background:rgba(255,255,255,.18);border-color:rgba(255,255,255,.32)}
.footer__social a{color:rgba(255,255,255,.92)}        /* social mais legível */
.footer__social a:hover{color:#fff}
.contact-list .ci{background:var(--teal);color:#fff}  /* ícone branco em fundo teal sólido */
.hero__scroll-txt{color:#fff}
.eyebrow--light{color:#fff}
.title--light .hl--yellow::after{opacity:.95}
.marquee__track .ic{color:#ffe27a}                    /* peixe mais claro sobre o teal */

/* =========================================================
   POLIMENTOS GERAIS
   ========================================================= */
.splash--mid{opacity:.32}                              /* suaviza a mancha que parecia "borrão" */
.bg-flow{animation-duration:40s}                       /* deriva mais lenta e discreta */
.section--alt{background:linear-gradient(180deg,#f3faf8,#e9f4f2)}
.frame,.tq-photo{border-color:#fff}
.card__body h3{gap:0}                                  /* sem gap fantasma quando não há ícone */
.nav__links{gap:1.15rem}                               /* acomoda o item extra "Avaliações" */
.nav__links>a:not(.btn){font-size:.98rem}

/* =========================================================
   HERO — foto nítida em alta com zoom suave (Ken Burns)
   ========================================================= */
.hero__photo{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);animation:kenburns 30s ease-in-out infinite alternate;will-change:transform}
@keyframes kenburns{from{transform:scale(1.08) translate3d(0,0,0)}to{transform:scale(1.2) translate3d(-1.5%,-2%,0)}}
.hero__content{position:relative;z-index:2}
/* leve realce de cor no vídeo do tour (compensa a compressão) */
.video__el{filter:saturate(1.1) contrast(1.04)}

/* =========================================================
   CARDUMES DE TAMBAQUIS (peixes nadando)
   ========================================================= */
.fish-layer{position:absolute;inset:0;overflow:hidden;pointer-events:none;z-index:1}
/* garante o conteúdo das seções acima dos peixes (cardumes nadam no fundo) */
.section > .container{position:relative;z-index:2}
.fish{position:absolute;left:0;width:var(--size,80px);opacity:var(--op,.55);color:#10151b;
  animation:swimLTR var(--dur,24s) linear infinite;animation-delay:var(--delay,0s);will-change:transform}
.fish--rtl{animation-name:swimRTL}
.fish__svg{display:block;width:100%;height:auto;
  animation:fishBob 3.4s ease-in-out infinite alternate, fishWiggle 1.1s ease-in-out infinite}
.fish--rtl .fish__svg{scale:-1 1}
/* peixes totalmente escuros em todas as seções (sobre claro ou colorido) */
.fish-layer--soft .fish,.fish-layer--light .fish{color:#10151b}

/* cardume interativo GLOBAL — camada sobre o site todo, não bloqueia cliques */
/* camada do cardume SEMPRE atrás de todo o conteúdo (não atrapalha a leitura).
   Fica acima do fundo (.bg-flow z-index:-2) e abaixo das seções/conteúdo. */
#fishOcean{position:fixed;top:0;left:0;pointer-events:none;z-index:-1}
@keyframes swimLTR{from{transform:translateX(-18vw)}to{transform:translateX(118vw)}}
@keyframes swimRTL{from{transform:translateX(118vw)}to{transform:translateX(-18vw)}}
@keyframes fishBob{from{transform:translateY(-7px)}to{transform:translateY(7px)}}
@keyframes fishWiggle{0%,100%{rotate:-3deg}50%{rotate:3deg}}

/* =========================================================
   LAGO KOI INTERATIVO (canvas)
   ========================================================= */
.koi-pond{position:relative;width:100%;aspect-ratio:1/1;border-radius:var(--r-lg);overflow:hidden;cursor:crosshair;
  background:radial-gradient(125% 100% at 50% 0%, #fdfaf3 0%, #f4f0e5 65%, #ece5d6 100%);
  box-shadow:var(--shadow-lg), inset 0 0 70px rgba(150,138,110,.14);border:6px solid #fff}
.koi-pond canvas{display:block;width:100%;height:100%;touch-action:none}
.koi-pond::after{content:"";position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  box-shadow:inset 0 0 50px rgba(120,110,90,.10)}
.koi-hint{position:absolute;left:50%;bottom:14px;transform:translateX(-50%);display:inline-flex;align-items:center;gap:.45em;
  font-family:var(--font-display);font-weight:600;font-size:.78rem;color:var(--muted);
  background:rgba(255,255,255,.72);padding:.4em .95em;border-radius:999px;pointer-events:none;
  backdrop-filter:blur(3px);white-space:nowrap;box-shadow:var(--shadow-sm)}
.koi-hint .ic{color:var(--cyan-deep)}

/* =========================================================
   SHOWS DO MÊS
   ========================================================= */
.shows{overflow:hidden}
.shows .eyebrow .ic{width:1.05em;height:1.05em;margin-right:.1em}
.shows__grid{display:grid;grid-template-columns:.82fr 1fr;gap:clamp(2rem,4.5vw,3.8rem);align-items:center}
.shows__poster{position:relative;border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--shadow-lg);
  border:6px solid #fff;max-width:430px;justify-self:center;margin:0}
.shows__poster img{width:100%;height:auto;display:block;transition:transform .6s var(--ease)}
.shows__poster:hover img{transform:scale(1.04)}
.shows__poster figcaption{position:absolute;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;gap:.5em;
  padding:1.4rem .8rem .8rem;color:#fff;font-family:var(--font-display);font-weight:700;font-size:.95rem;
  background:linear-gradient(transparent,rgba(8,60,67,.82))}
.shows__agenda h3{font-family:var(--font-display);font-weight:700;color:var(--teal-deep);font-size:1.5rem;margin-bottom:1.2rem}
.agenda{display:flex;flex-direction:column;gap:.65rem;margin-bottom:1.3rem}
.agenda li{display:flex;align-items:center;gap:1rem;background:#fff;border-radius:var(--r);padding:.65rem .9rem;
  box-shadow:var(--shadow-sm);border:1px solid rgba(12,124,132,.06);transition:transform .25s var(--ease),box-shadow .25s}
.agenda li:hover{transform:translateX(6px);box-shadow:var(--shadow)}
.agenda__date{display:flex;flex-direction:column;align-items:center;justify-content:center;width:54px;height:54px;flex-shrink:0;
  border-radius:14px;color:#fff;line-height:1;background:linear-gradient(135deg,var(--pink),var(--pink-deep))}
.agenda li:nth-child(2) .agenda__date{background:linear-gradient(135deg,var(--cyan),var(--cyan-deep))}
.agenda li:nth-child(3) .agenda__date{background:linear-gradient(135deg,var(--yellow),var(--yellow-deep));color:#5a3d00}
.agenda li:nth-child(4) .agenda__date{background:linear-gradient(135deg,var(--green),var(--green-deep))}
.agenda li:nth-child(5) .agenda__date{background:linear-gradient(135deg,var(--blue),var(--blue-deep))}
.agenda li:nth-child(6) .agenda__date{background:linear-gradient(135deg,var(--teal),var(--cyan-deep))}
.agenda__date b{font-family:var(--font-display);font-size:1.4rem}
.agenda__date small{font-size:.6rem;text-transform:uppercase;letter-spacing:.08em;opacity:.92}
.agenda__name{font-family:var(--font-display);font-weight:700;color:var(--ink);font-size:1.12rem}
.shows__note{display:inline-flex;align-items:center;gap:.5em;color:var(--teal-deep);font-weight:700;margin-bottom:1.4rem}
.shows__note .ic{color:var(--green-deep)}
@media (max-width:860px){
  .shows__grid{grid-template-columns:1fr}
  .shows__poster{max-width:340px}
}

/* =========================================================
   RESPONSIVO — novas seções
   ========================================================= */
@media (max-width:980px){
  .reviews__head{grid-template-columns:1fr;gap:1.4rem;text-align:center}
  .reviews__intro .eyebrow--line{justify-content:center}
  .reviews__wall{grid-template-columns:repeat(2,1fr)}
  .reviews__col--3{display:none}
}
@media (max-width:620px){
  .reviews__wall{grid-template-columns:1fr;height:min(80vh,520px)}
  .reviews__col--down{display:none}
  .video__play{width:66px;height:66px}
}

@media (prefers-reduced-motion:reduce){
  .bg-flow,.marquee__track,.wave-anim::before,.wave-anim::after,.bubble,.fab--sound.is-on::after,.sound-hint .ic,.leaf,.reviews__col,.hero__photo{animation:none!important}
  .hero__title .word{transform:none;opacity:1;animation:none!important}
  .reveal-up,.hero__sub,.hero__actions{opacity:1!important;transform:none!important;animation:none!important}
  .bubbles,.fish-layer{display:none}
  .reviews__wall{height:auto;-webkit-mask:none;mask:none}
  .reviews__col{gap:1.2rem}
}
