/* ============================================================
   RIB Turismo — fiel ao original (Poppins, tamanhos, gradiente)
   ============================================================ */
:root {
  --paper:   oklch(0.995 0.003 250);
  --paper-2: oklch(0.965 0.014 256);   /* lavanda das seções */
  --ink:     oklch(0.25 0.006 262);    /* #181818 títulos */
  --body:    oklch(0.36 0.006 262);    /* #333 corpo */
  --muted:   oklch(0.52 0.012 258);
  --azure:   #0da7ff;
  --peri:    #477fff;
  --em:      #2f7bf5;                   /* destaque dos títulos */
  --em-light:#8fd0ff;
  --deep:    oklch(0.27 0.055 256);     /* cards escuros */
  --deep-2:  oklch(0.17 0.045 255);     /* footer / hero scrim */
  --line:    oklch(0.9 0.012 256);
  --grad:    linear-gradient(90deg, #0da7ff 0%, #0da7ff 50%, #477fff 100%);
  --on:      #ffffff;

  --font: "Poppins", system-ui, sans-serif;
  --font-foot: "Manrope", system-ui, sans-serif;

  --t-hero: clamp(2.2rem, 1.5rem + 3vw, 3.5rem);     /* 56px */
  --t-h2:   clamp(1.9rem, 1.4rem + 2.3vw, 3.0625rem);/* 49px */
  --t-card: clamp(1.55rem, 1.25rem + 1.1vw, 2.1875rem);/* 35px */
  --t-pilar:clamp(1.35rem, 1.2rem + 0.5vw, 1.625rem);/* 26px */
  --t-lead: clamp(1rem, 0.95rem + 0.2vw, 1.1rem);    /* 17.6px */
  --t-base: 1.0625rem;                               /* 17px */

  --shell: min(92vw, 1200px);
  --r: 14px; --r-lg: 22px; --r-btn: 999px; --r-pill: 999px;
  --sec-y: clamp(5rem, 9vw, 9rem);
  --shadow: 0 14px 40px -24px rgba(13, 40, 70, 0.22);
  --shadow-sm: 0 4px 14px -10px rgba(13, 40, 70, 0.16);
  --ease: cubic-bezier(0.16, 1, 0.3, 1);
}

* { box-sizing: border-box; margin: 0; }
html { -webkit-text-size-adjust: 100%; }
html.lenis, html.lenis body { height: auto; }
.lenis.lenis-smooth { scroll-behavior: auto !important; }
@media (prefers-reduced-motion: reduce) { html { scroll-behavior: auto; } *,*::before,*::after { animation-duration: .001ms !important; transition-duration: .001ms !important; } }
body { font-family: var(--font); font-size: var(--t-base); line-height: 1.6; color: var(--body); background: var(--paper); -webkit-font-smoothing: antialiased; overflow-x: hidden; }
img, svg { display: block; max-width: 100%; }
img { height: auto; }
a { color: inherit; text-decoration: none; }
ul { list-style: none; padding: 0; }
button { font: inherit; cursor: pointer; border: none; background: none; color: inherit; }
address { font-style: normal; }
::selection { background: var(--azure); color: #fff; }
.shell { width: var(--shell); margin-inline: auto; }
.skip-link { position: fixed; left: 1rem; top: -100px; z-index: 300; background: var(--ink); color: #fff; padding: .6rem 1rem; border-radius: 8px; }
.skip-link:focus { top: 1rem; }
:focus-visible { outline: 2.5px solid var(--azure); outline-offset: 3px; border-radius: 4px; }

/* —— Tipografia —— */
.h2 { font-size: var(--t-h2); font-weight: 700; line-height: 1.08; color: var(--ink); letter-spacing: -0.01em; }
.h2--light { color: #fff; }
.em { color: var(--em); }
.em-light { color: var(--em-light); }
.section-lead { font-size: var(--t-lead); font-weight: 400; color: var(--body); max-width: 60ch; margin-top: 1rem; }
.section-head--center .section-lead { margin-inline: auto; }
.pill { display: inline-block; font-size: .8rem; font-weight: 600; letter-spacing: .08em; text-transform: uppercase; color: #fff; background: var(--grad); padding: .5rem 1.1rem; border-radius: var(--r-pill); margin-bottom: 1.1rem; box-shadow: var(--shadow-sm); }

/* —— Botões —— */
.btn { display: inline-flex; align-items: center; justify-content: center; gap: .5rem; font-family: var(--font); font-weight: 600; font-size: var(--t-lead); text-transform: uppercase; letter-spacing: .02em; padding: .95rem 2.4rem; border-radius: var(--r-btn); line-height: 1; white-space: nowrap; transition: transform .35s var(--ease), box-shadow .35s var(--ease), filter .3s; }
.btn--sm { padding: .6rem 1.3rem; font-size: .85rem; }
.btn--lg { padding: 1.05rem 2.6rem; }
.btn--xl { padding: 1.15rem 3rem; font-size: 1.15rem; }
.btn--block { width: 100%; }
.btn--grad { background: var(--grad); color: #fff; box-shadow: 0 12px 26px -10px rgba(13, 167, 255, .6); }
.btn--grad:hover { transform: translateY(-2px); box-shadow: 0 18px 36px -10px rgba(13, 167, 255, .75); filter: saturate(1.08); }
.btn--grad:active { transform: translateY(0); }
.btn--ghost-light { color: #fff; box-shadow: inset 0 0 0 1.6px rgba(255,255,255,.55); }
.btn--ghost-light:hover { box-shadow: inset 0 0 0 1.6px #fff; background: rgba(255,255,255,.1); transform: translateY(-2px); }

/* —— Header / Nav —— */
.site-header { position: fixed; inset: 0 0 auto 0; z-index: 100; padding: clamp(.7rem,1.5vw,1.1rem) 0; transition: background-color .4s, box-shadow .4s, padding .4s, backdrop-filter .4s; }
.site-header.is-scrolled { background: rgba(255,255,255,.85); backdrop-filter: saturate(1.4) blur(14px); box-shadow: 0 1px 0 var(--line), var(--shadow-sm); padding: .5rem 0; }
.header-inner { display: flex; align-items: center; gap: 1.4rem; }
.brand { display: inline-flex; align-items: center; gap: .55rem; }
.brand__mark { display: inline-flex; transition: transform .5s var(--ease); }
.brand:hover .brand__mark { transform: translateY(-2px) scale(1.06); }
.brand__word { font-weight: 700; font-size: 1.3rem; color: #fff; text-shadow: 0 1px 12px rgba(10,30,60,.4); transition: color .4s, text-shadow .4s; }
.is-scrolled .brand__word { color: var(--ink); text-shadow: none; }
.brand__word-soft { color: rgba(255,255,255,.7); font-weight: 500; }
.is-scrolled .brand__word-soft { color: var(--muted); }
.nav { margin-left: auto; }
.nav__list { display: flex; align-items: center; gap: clamp(.3rem,1.4vw,1.3rem); }
.nav__link { display: inline-flex; align-items: center; gap: .35rem; font-weight: 500; font-size: 1rem; color: rgba(255,255,255,.94); padding: .5rem .4rem; position: relative; transition: color .3s; text-shadow: 0 1px 10px rgba(10,30,60,.5); }
.nav__link::after { content: ""; position: absolute; left: .4rem; right: .4rem; bottom: .25rem; height: 2px; background: var(--azure); border-radius: 2px; transform: scaleX(0); transform-origin: left; transition: transform .4s var(--ease); }
.nav__link:hover::after, .nav__link.is-active::after { transform: scaleX(1); }
.is-scrolled .nav__link { color: var(--body); text-shadow: none; }
.is-scrolled .nav__link:hover, .is-scrolled .nav__link.is-active { color: var(--ink); }
.nav__chev { transition: transform .35s var(--ease); }
.nav__item--mega:hover .nav__chev, .nav__item--mega:focus-within .nav__chev { transform: rotate(180deg); }
.nav__item--mega { position: relative; }
.mega { position: absolute; top: calc(100% + .4rem); left: 50%; translate: -50% 0; width: min(92vw, 640px); background: var(--paper); border: 1px solid var(--line); border-radius: var(--r-lg); box-shadow: var(--shadow); padding: .8rem; opacity: 0; visibility: hidden; transform: translateY(8px); transition: opacity .3s, transform .4s var(--ease), visibility .3s; }
.nav__item--mega:hover .mega, .nav__item--mega:focus-within .mega { opacity: 1; visibility: visible; transform: translateY(0); }
.mega__grid { display: grid; grid-template-columns: 1fr 1fr; gap: .3rem; }
.mega__item { display: flex; align-items: center; gap: .7rem; padding: .55rem .6rem; border-radius: var(--r); transition: background-color .25s; }
.mega__item:hover { background: var(--paper-2); }
.mega__thumb { width: 46px; height: 46px; border-radius: 10px; background-size: cover; background-position: center; flex-shrink: 0; box-shadow: var(--shadow-sm); }
.mega__item strong { display: block; font-weight: 600; font-size: 1rem; color: var(--ink); }
.mega__item em { display: block; font-style: normal; font-size: .82rem; color: var(--muted); }
.mega__item--cta { background: var(--grad); justify-content: center; text-align: center; }
.mega__item--cta strong, .mega__item--cta em { color: #fff; }
.header-cta { margin-left: .3rem; }
.nav-toggle { display: none; width: 44px; height: 44px; flex-direction: column; gap: 5px; align-items: center; justify-content: center; margin-left: auto; }
.nav-toggle span { width: 24px; height: 2px; background: #fff; border-radius: 2px; transition: transform .4s var(--ease), opacity .3s, background .4s; }
.is-scrolled .nav-toggle span { background: var(--ink); }
.nav-toggle[aria-expanded="true"] span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.nav-toggle[aria-expanded="true"] span:nth-child(2) { opacity: 0; }
.nav-toggle[aria-expanded="true"] span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }
.mobile-nav { position: fixed; inset: 0 0 auto 0; z-index: 99; padding: 5.4rem var(--shell-gut, 6vw) 2rem; display: none; flex-direction: column; gap: .15rem; background: var(--paper); box-shadow: var(--shadow); max-height: 100svh; overflow-y: auto; }
.mobile-nav:not([hidden]) { display: flex; animation: drop .45s var(--ease); }
@keyframes drop { from { transform: translateY(-12px); opacity: 0; } to { transform: none; opacity: 1; } }
.mobile-nav > a, .mobile-exp > summary { font-weight: 600; font-size: 1.3rem; padding: .55rem 0; color: var(--ink); border-bottom: 1px solid var(--line); }
.mobile-exp { border-bottom: 1px solid var(--line); }
.mobile-exp > summary { list-style: none; cursor: pointer; display: flex; justify-content: space-between; align-items: center; border-bottom: none; }
.mobile-exp > summary::after { content: "+"; color: var(--azure); }
.mobile-exp[open] > summary::after { content: "−"; }
.mobile-exp__list { display: flex; flex-direction: column; padding: 0 0 .7rem .8rem; }
.mobile-exp__list a { padding: .42rem 0; color: var(--body); font-weight: 500; }
.mobile-nav .btn { margin-top: 1.1rem; }

/* —— Hero —— */
.hero { position: relative; min-height: 100svh; display: grid; place-items: center; text-align: center; padding: 7rem 0 7rem; isolation: isolate; overflow: hidden; }
.hero__media { position: absolute; inset: 0; z-index: -2; }
.hero__media img { width: 100%; height: 100%; object-fit: cover; transform: scale(1.06); animation: kb 18s ease-out forwards; }
@keyframes kb { to { transform: scale(1); } }
.hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,18,35,.74), rgba(8,18,35,.5) 42%, rgba(8,18,35,.8)); }
.hero__content { position: relative; max-width: 60ch; }
.hero__title { font-size: var(--t-hero); font-weight: 700; line-height: 1.08; color: #f6faff; letter-spacing: -0.01em; text-shadow: 0 2px 30px rgba(10,25,50,.5); opacity: 0; animation: up .8s var(--ease) .15s forwards; }
.hero__sub { margin-top: 1.1rem; font-size: 1.125rem; font-weight: 300; color: #e8edf5; text-shadow: 0 1px 16px rgba(10,25,50,.5); opacity: 0; animation: up .8s var(--ease) .3s forwards; }
.hero__actions { margin-top: 2rem; display: flex; flex-wrap: wrap; gap: .8rem; justify-content: center; opacity: 0; animation: up .8s var(--ease) .45s forwards; }
@keyframes up { from { opacity: 0; transform: translateY(20px); } to { opacity: 1; transform: none; } }
.hero__trust { position: absolute; left: 0; right: 0; bottom: 0; z-index: 1; padding: 1rem 0; background: rgba(12,25,45,.46); backdrop-filter: blur(8px); border-top: 1px solid rgba(255,255,255,.12); }
.trust-row { display: flex; flex-wrap: wrap; align-items: center; justify-content: center; gap: .5rem 1.1rem; font-size: .85rem; color: rgba(255,255,255,.86); }
.trust-row strong { color: #fff; font-weight: 600; }
.trust-dot { width: 4px; height: 4px; border-radius: 50%; background: var(--azure); }
.hero__scroll { position: absolute; left: 50%; bottom: 5rem; translate: -50% 0; z-index: 2; width: 26px; height: 42px; border: 2px solid rgba(255,255,255,.5); border-radius: 14px; display: grid; place-items: start center; padding-top: 7px; }
.hero__scroll span { width: 4px; height: 8px; border-radius: 2px; background: #fff; animation: sd 1.8s var(--ease) infinite; }
@keyframes sd { 0%{opacity:0;transform:translateY(0)} 30%{opacity:1} 70%{opacity:1;transform:translateY(10px)} 100%{opacity:0;transform:translateY(14px)} }

/* —— Sections —— */
.section { padding-block: var(--sec-y); }
.section--alt { background: var(--paper-2); }
.section-head { margin-bottom: clamp(2.2rem, 4vw, 3.4rem); }
.section-head--center { text-align: center; }

/* —— Pilares (cards escuros, título branco 26px peso 300) —— */
.pilares { display: grid; grid-template-columns: repeat(4, 1fr); gap: clamp(1rem, 2vw, 1.5rem); }
.pilar { background: linear-gradient(160deg, var(--deep), var(--deep-2)); border-radius: var(--r-lg); padding: clamp(1.5rem, 2.4vw, 2.1rem); color: rgba(255,255,255,.78); box-shadow: var(--shadow); transition: transform .5s var(--ease); }
.pilar:hover { transform: translateY(-6px); }
.pilar__ico { display: inline-flex; align-items: center; justify-content: center; width: 56px; height: 56px; border-radius: 14px; color: #fff; background: var(--grad); margin-bottom: 1.2rem; box-shadow: 0 10px 22px -10px rgba(13,167,255,.7); }
.pilar__title { font-size: var(--t-pilar); font-weight: 300; color: #fff; line-height: 1.15; margin-bottom: .6rem; }
.pilar p { font-size: .98rem; color: rgba(255,255,255,.74); max-width: 30ch; }

/* —— Expedições (cards: imagem + corpo) —— */
.exp-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 320px), 1fr)); gap: clamp(1.2rem, 2.2vw, 1.8rem); }
.exp-card { background: var(--paper); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); display: flex; flex-direction: column; scroll-margin-top: 90px; transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.section--alt .exp-card { background: #fff; }
.exp-card:hover { transform: translateY(-6px); box-shadow: 0 30px 60px -28px rgba(13,40,70,.4); }
.exp-card__media { display: block; overflow: hidden; aspect-ratio: 4 / 3; }
.exp-card__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .9s var(--ease); }
.exp-card:hover .exp-card__media img { transform: scale(1.06); }
.exp-card__body { display: flex; flex-direction: column; align-items: flex-start; gap: .5rem; padding: clamp(1.3rem, 2.4vw, 1.8rem); text-align: left; }
.exp-card__chip { font-size: .82rem; font-weight: 600; color: var(--azure); letter-spacing: .02em; }
.exp-card__name { font-size: var(--t-card); font-weight: 700; line-height: 1.1; color: var(--ink); letter-spacing: -0.01em; }
.exp-card__desc { font-size: 1rem; color: var(--muted); margin-bottom: .4rem; }
.exp-card .btn { margin-top: auto; }

/* —— Banda Monte —— */
.band { position: relative; padding-block: clamp(5rem, 10vw, 9rem); isolation: isolate; overflow: hidden; }
.band__media { position: absolute; inset: 0; z-index: -2; }
.band__media img { width: 100%; height: 100%; object-fit: cover; }
.band__scrim { position: absolute; inset: 0; background: linear-gradient(95deg, rgba(10,22,42,.9) 6%, rgba(10,22,42,.72) 48%, rgba(10,22,42,.45)); }
.band__content { max-width: 44ch; text-align: center; margin-inline: auto; }
.band__content .h2 { margin-bottom: 1.1rem; }
.band__lead { color: rgba(255,255,255,.9); font-size: var(--t-lead); margin-bottom: 1.8rem; }

/* —— Réveillon —— */
.reveillon__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.reveillon__media { position: relative; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); }
.reveillon__media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; transition: transform .9s var(--ease); }
.reveillon__media:hover img { transform: scale(1.05); }
.reveillon__badge { position: absolute; top: 1rem; left: 1rem; background: var(--grad); color: #fff; font-weight: 600; font-size: .82rem; padding: .4rem .85rem; border-radius: var(--r-pill); }
.reveillon__date { color: var(--azure); font-weight: 500; margin: .2rem 0 .8rem; }
.reveillon__text p { color: var(--body); margin-bottom: 1rem; }
.reveillon__text .lead { font-size: 1.2rem; color: var(--ink); font-weight: 500; }
.reveillon__text .btn { margin-top: .6rem; }

/* —— Sobre —— */
.sobre__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem, 5vw, 4.5rem); align-items: center; }
.sobre__media img { width: 100%; aspect-ratio: 4 / 3; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--shadow); }
.sobre__text .h2 { margin-bottom: 1.2rem; }
.sobre__text p { color: var(--body); margin-bottom: 1rem; }
.signature { font-weight: 600; color: var(--ink); margin-top: 1.4rem !important; }

/* —— Feedbacks —— */
.quotes { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%, 290px), 1fr)); gap: clamp(1rem, 2vw, 1.6rem); }
.quote { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.6rem, 3vw, 2.1rem); display: flex; flex-direction: column; gap: 1.3rem; box-shadow: var(--shadow-sm); transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.quote:hover { transform: translateY(-4px); box-shadow: var(--shadow); }
.quote__text { font-size: 1.15rem; font-weight: 500; line-height: 1.4; color: var(--ink); }
.quote__by { display: flex; align-items: center; gap: .8rem; margin-top: auto; }
.quote__by img { width: 46px; height: 46px; border-radius: 50%; object-fit: cover; }
.quote__by span { display: flex; flex-direction: column; line-height: 1.3; }
.quote__by strong { font-weight: 600; }
.quote__by em { font-style: normal; color: var(--muted); font-size: .85rem; }
.feedbacks__note { text-align: center; margin: 2rem auto 0; color: var(--muted); font-size: .85rem; }

/* —— CTA final —— */
.cta-final { position: relative; padding-block: clamp(5rem, 11vw, 9rem); text-align: center; overflow: hidden; isolation: isolate; }
.cta-final__media { position: absolute; inset: 0; z-index: -2; }
.cta-final__media img { width: 100%; height: 100%; object-fit: cover; }
.cta-final__scrim { position: absolute; inset: 0; background: radial-gradient(110% 90% at 50% 30%, rgba(18,40,70,.6), rgba(10,20,40,.92)); }
.cta-final__inner { position: relative; z-index: 1; display: flex; flex-direction: column; align-items: center; }
.cta-final__title { font-size: var(--t-h2); font-weight: 700; line-height: 1.08; color: #fff; letter-spacing: -0.01em; }
.cta-final__sub { margin: 1.1rem auto 1.9rem; color: rgba(255,255,255,.88); font-size: var(--t-lead); max-width: 46ch; }
.cta-final__phone { margin-top: 1.1rem; color: rgba(255,255,255,.72); }
.cta-final__phone a { color: #fff; font-weight: 600; border-bottom: 1px solid rgba(255,255,255,.4); }

/* —— Footer —— */
.footer { background: var(--deep-2); color: rgba(255,255,255,.72); padding-top: clamp(3.5rem, 7vw, 5rem); }
.footer__grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1.2fr; gap: 2.5rem 2rem; padding-bottom: 2.6rem; }
.brand--footer .brand__word { color: #fff; text-shadow: none; }
.brand--footer .brand__word-soft { color: rgba(255,255,255,.6); }
.footer__tag { margin: .9rem 0 1.2rem; color: rgba(255,255,255,.72); }
.footer__siganos { font-size: .85rem; color: rgba(255,255,255,.55); margin-bottom: .6rem; }
.footer__social { display: flex; gap: .7rem; }
.footer__social a { width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; background: rgba(255,255,255,.08); color: #fff; transition: background .3s, transform .4s var(--ease); }
.footer__social a:hover { background: var(--azure); transform: translateY(-3px); }
.footer__col h3 { font-family: var(--font-foot); font-weight: 500; font-size: 1.375rem; color: #fff; margin-bottom: 1rem; }
.footer__col a, .footer__contact address { display: block; padding: .3rem 0; color: rgba(255,255,255,.66); transition: color .25s; }
.footer__col a:hover { color: #fff; }
.footer__contact address { line-height: 1.7; }
.footer__cadastur { margin-top: .8rem; font-size: .82rem; color: rgba(255,255,255,.5); }
.footer__base { display: flex; justify-content: space-between; gap: 1rem; flex-wrap: wrap; padding: 1.4rem 0 clamp(5.5rem, 11vw, 8rem); border-top: 1px solid rgba(255,255,255,.1); font-size: .85rem; color: rgba(255,255,255,.55); }
.footer__base strong { color: rgba(255,255,255,.8); font-weight: 600; }

/* —— WhatsApp flutuante —— */
.wa-float { position: fixed; right: clamp(1rem,3vw,1.8rem); bottom: clamp(1rem,3vw,1.8rem); z-index: 90; width: 58px; height: 58px; border-radius: 50%; display: grid; place-items: center; background: #25d366; color: #fff; box-shadow: 0 12px 28px -8px rgba(37,211,102,.7); transform: translateY(110px); opacity: 0; transition: transform .5s var(--ease), opacity .4s, box-shadow .3s; }
.wa-float.is-visible { transform: translateY(0); opacity: 1; }
.wa-float:hover { transform: translateY(-3px) scale(1.05); }

/* —— Reveal: fadeInLeft (igual ao original) —— */
[data-reveal] { opacity: 0; transform: translateY(28px); filter: blur(10px); transition: opacity .85s ease, transform .9s var(--ease), filter .85s ease; }
[data-reveal].is-in { opacity: 1; transform: none; filter: blur(0); }
@media (prefers-reduced-motion: reduce) { [data-reveal]{opacity:1;transform:none;filter:none} .hero__title,.hero__sub,.hero__actions{opacity:1;animation:none} .hero__media img{animation:none;transform:none} }

/* ===== Refinamento: quieter · bolder · overdrive · delight · polish ===== */

/* Botões de card discretos em repouso, gradiente no hover (quieter + delight) */
.btn--soft { background: rgba(13,167,255,.07); color: var(--azure); box-shadow: inset 0 0 0 1.5px rgba(13,167,255,.32); }
.btn--soft:hover { background: var(--grad); color: #fff; box-shadow: 0 12px 24px -12px rgba(13,167,255,.55); transform: translateY(-2px); }
.btn--soft:active { transform: translateY(0); }

/* Sombras mais suaves / mais ar (quieter) */
.pilar { box-shadow: 0 18px 42px -28px rgba(10,25,50,.5); }
.exp-card { box-shadow: 0 16px 40px -26px rgba(13,40,70,.26); }

/* Realce do CTA primário por contraste (bolder) */
.hero__actions .btn--grad, .band .btn--grad, .cta-final .btn--grad { box-shadow: 0 16px 34px -12px rgba(13,167,255,.6); }

/* Expedições: tilt 3D + parallax interno + brilho que cruza (overdrive + delight) */
.exp-grid { perspective: 1100px; }
.exp-card { transform-style: preserve-3d; will-change: transform; transition: transform .4s var(--ease), box-shadow .5s var(--ease); }
.exp-card__media { position: relative; }
.exp-card__media img { will-change: transform; backface-visibility: hidden; }
.exp-card__media::after { content: ""; position: absolute; inset: 0; z-index: 1; pointer-events: none; background: linear-gradient(105deg, transparent 32%, rgba(255,255,255,.16) 48%, transparent 64%); transform: translateX(-130%); transition: transform .9s var(--ease); }
.exp-card:hover .exp-card__media::after { transform: translateX(130%); }
@media (hover: none) { .exp-card__media::after { display: none; } }
@media (prefers-reduced-motion: reduce) { .exp-card { transform: none !important; } .exp-card__media img { transform: none !important; } }

/* Polish: feedback de clique + sem highlight de toque */
.nav-toggle, .wa-float, .footer__social a, .mega__item { -webkit-tap-highlight-color: transparent; }

/* ===== Premium pass (DESIGN-apple.md): restrição · respiro · pílula · UI plano ===== */

/* CTAs em pílula com press scale (assinatura Apple), sombra mínima */
.btn { letter-spacing: -0.01em; }
.btn:active { transform: scale(.96); }
.btn--grad { box-shadow: 0 8px 20px -12px rgba(13,167,255,.5); }
.btn--grad:hover { box-shadow: 0 12px 26px -12px rgba(13,167,255,.6); transform: translateY(-1px); }
.exp-card .btn--soft { align-self: flex-start; }

/* Tipografia "Apple tight" mantendo Poppins */
.hero__title { letter-spacing: -0.03em; }
.h2, .cta-final__title { letter-spacing: -0.028em; }
.exp-card__name { letter-spacing: -0.02em; }

/* UI mais plano: hairline + sombra quase nula (Apple usa quase nenhuma) */
.exp-card { box-shadow: 0 10px 30px -26px rgba(13,40,70,.2); border: 1px solid rgba(13,40,70,.06); }
.exp-card:hover { box-shadow: 0 26px 54px -32px rgba(13,40,70,.3); }
.quote { box-shadow: none; }
.quote:hover { box-shadow: 0 16px 40px -28px rgba(13,40,70,.2); }
.pilar { box-shadow: 0 16px 40px -30px rgba(10,25,50,.4); }
.mega { box-shadow: 0 24px 60px -28px rgba(13,40,70,.3); }

/* Mais respiro (whitespace é o pedestal) */
.section-head { margin-bottom: clamp(3rem, 5.5vw, 4.5rem); }
.hero__actions { margin-top: 2.4rem; }

/* ===== Ajustes finais: sweep · parallax · logo-only · balance ===== */

/* Títulos equilibrados, sem palavra órfã (hero usa quebra manual) */
.h2, .cta-final__title { text-wrap: balance; }

/* Light sweep contínuo (shinery) nos CTAs gradiente — como no original */
.btn--grad { position: relative; overflow: hidden; isolation: isolate; }
.btn--grad::before {
  content: ""; position: absolute; top: -20%; bottom: -20%; left: 0; width: 42%; z-index: -1;
  background: linear-gradient(100deg, transparent 0%, rgba(255,255,255,.55) 50%, transparent 100%);
  transform: translateX(-170%) skewX(-20deg);
  animation: shinery 3.4s ease-in-out infinite; pointer-events: none;
}
@keyframes shinery {
  0% { transform: translateX(-170%) skewX(-20deg); }
  55%, 100% { transform: translateX(360%) skewX(-20deg); }
}
/* Sweep no hover dos botões de card (quando preenchem) */
.btn--soft { position: relative; overflow: hidden; isolation: isolate; }
.btn--soft::before {
  content: ""; position: absolute; top: -20%; bottom: -20%; left: 0; width: 42%; z-index: -1;
  background: linear-gradient(100deg, transparent, rgba(255,255,255,.5), transparent);
  transform: translateX(-170%) skewX(-20deg); opacity: 0; pointer-events: none;
}
.btn--soft:hover::before { opacity: 1; animation: shinery 1.2s var(--ease) 1; }
@media (prefers-reduced-motion: reduce) { .btn--grad::before, .btn--soft::before { animation: none !important; display: none; } }

/* Parallax: imagem maior + clip, deslocada por JS (mais intenso, sem gaps) */
.hero__media, .band__media, .cta-final__media { inset: 0; overflow: hidden; }
.hero__media img, .band__media img, .cta-final__media img {
  position: absolute; top: -25%; left: 0; width: 100%; height: 150%;
  object-fit: cover; animation: none !important; will-change: transform;
}

/* Cards: sem tilt 3D + reveal suave (opacity+blur também transicionam, sem "pop") */
.exp-grid { perspective: none; }
.exp-card { transform-style: flat;
  transition: transform .55s var(--ease), box-shadow .5s var(--ease), opacity .85s ease, filter .85s ease; }

/* Headline do hero sem limite estreito (cabe nas 2 linhas certas) */
.hero__content { max-width: none; }

/* Logo só (sem texto) + brilho suave no rodapé */
.brand--logo-only .brand__word { display: none; }
.brand--footer .brand__mark { filter: drop-shadow(0 8px 20px rgba(13,167,255,.28)); }
.footer__social a { width: 44px; height: 44px; }

/* Progressive blur fixo no rodapé (sempre presente, como no original) */
.bottom-blur { position: fixed; left: 0; right: 0; bottom: 0; height: 172px; z-index: 70; pointer-events: none; }
.bottom-blur > div { position: absolute; inset: 0; }
.bottom-blur .blur-1 { z-index: 1; -webkit-backdrop-filter: blur(0.25px); backdrop-filter: blur(0.25px); -webkit-mask-image: linear-gradient(to bottom, transparent 0%, #000 12.5%, #000 25%, transparent 37.5%); mask-image: linear-gradient(to bottom, transparent 0%, #000 12.5%, #000 25%, transparent 37.5%); }
.bottom-blur .blur-2 { z-index: 2; -webkit-backdrop-filter: blur(0.5px); backdrop-filter: blur(0.5px); -webkit-mask-image: linear-gradient(to bottom, transparent 12.5%, #000 25%, #000 37.5%, transparent 50%); mask-image: linear-gradient(to bottom, transparent 12.5%, #000 25%, #000 37.5%, transparent 50%); }
.bottom-blur .blur-3 { z-index: 3; -webkit-backdrop-filter: blur(1px); backdrop-filter: blur(1px); -webkit-mask-image: linear-gradient(to bottom, transparent 25%, #000 37.5%, #000 50%, transparent 62.5%); mask-image: linear-gradient(to bottom, transparent 25%, #000 37.5%, #000 50%, transparent 62.5%); }
.bottom-blur .blur-4 { z-index: 4; -webkit-backdrop-filter: blur(2px); backdrop-filter: blur(2px); -webkit-mask-image: linear-gradient(to bottom, transparent 37.5%, #000 50%, #000 62.5%, transparent 75%); mask-image: linear-gradient(to bottom, transparent 37.5%, #000 50%, #000 62.5%, transparent 75%); }
.bottom-blur .blur-5 { z-index: 5; -webkit-backdrop-filter: blur(4px); backdrop-filter: blur(4px); -webkit-mask-image: linear-gradient(to bottom, transparent 50%, #000 62.5%, #000 75%, transparent 87.5%); mask-image: linear-gradient(to bottom, transparent 50%, #000 62.5%, #000 75%, transparent 87.5%); }
.bottom-blur .blur-6 { z-index: 6; -webkit-backdrop-filter: blur(8px); backdrop-filter: blur(8px); -webkit-mask-image: linear-gradient(to bottom, transparent 62.5%, #000 75%, #000 87.5%, transparent 100%); mask-image: linear-gradient(to bottom, transparent 62.5%, #000 75%, #000 87.5%, transparent 100%); }
.bottom-blur .blur-7 { z-index: 7; -webkit-backdrop-filter: blur(16px); backdrop-filter: blur(16px); -webkit-mask-image: linear-gradient(to bottom, transparent 75%, #000 87.5%, #000 100%); mask-image: linear-gradient(to bottom, transparent 75%, #000 87.5%, #000 100%); }
.bottom-blur .blur-8 { z-index: 8; -webkit-backdrop-filter: blur(32px); backdrop-filter: blur(32px); -webkit-mask-image: linear-gradient(to bottom, transparent 87.5%, #000 100%); mask-image: linear-gradient(to bottom, transparent 87.5%, #000 100%); }

/* —— Responsivo —— */
@media (max-width: 1000px) {
  .pilares { grid-template-columns: 1fr 1fr; }
  .reveillon__grid, .sobre__grid { grid-template-columns: 1fr; gap: 2.2rem; }
  .reveillon__media, .sobre__media { max-width: 520px; }
  .footer__grid { grid-template-columns: 1fr 1fr; }
}
@media (max-width: 760px) {
  .nav, .header-cta { display: none; }
  .nav-toggle { display: flex; }
  .pilares { grid-template-columns: 1fr; }
  .footer__grid { grid-template-columns: 1fr; gap: 1.8rem; }
  .hero { padding-bottom: 8.5rem; }
  .hero__scroll { display: none; }
  [data-reveal] { transform: translateY(28px); }
}

/* ============================================================
   Páginas de destino (modelo)
   ============================================================ */
.dest-hero { position: relative; min-height: 100svh; display: grid; place-items: center; text-align: center; padding: 9rem 0 5rem; isolation: isolate; overflow: hidden; }
.dest-hero__media { position: absolute; inset: 0; z-index: -2; overflow: hidden; }
.dest-hero__media img { position: absolute; top: -25%; left: 0; width: 100%; height: 150%; object-fit: cover; will-change: transform; }
.dest-hero__scrim { position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,18,35,.58), rgba(8,18,35,.4) 42%, rgba(8,18,35,.84)); }
.dest-hero__content { position: relative; max-width: 60ch; }
.dest-hero__title { font-size: clamp(3rem, 1.8rem + 5.5vw, 6rem); font-weight: 700; color: #fff; letter-spacing: -0.025em; line-height: 1; margin: 1.1rem 0 .8rem; }
.dest-hero__sub { font-size: clamp(1.1rem, 1rem + 0.5vw, 1.4rem); font-weight: 300; color: #e8edf5; }
/* Sobre/Contato: hero ocupa a tela inteira (padrão das expedições), só com o texto um pouco menor */
.dest-hero--info .dest-hero__title { font-size: clamp(2.4rem, 1.7rem + 3.2vw, 3.8rem); }
.dest-hero--info .dest-hero__sub { font-size: clamp(1rem, .95rem + .4vw, 1.25rem); }
.dest-hero--contato .dest-hero__media img { object-position: center 40%; }
.dest-hero__meta { margin-top: 1.8rem; display: flex; gap: .8rem 1.4rem; justify-content: center; flex-wrap: wrap; }
.dest-hero__meta span { display: inline-flex; align-items: center; gap: .5rem; font-weight: 500; font-size: .95rem; color: #fff; background: rgba(255,255,255,.12); border: 1px solid rgba(255,255,255,.18); padding: .5rem 1rem; border-radius: 99px; backdrop-filter: blur(6px); }
.dest-hero__actions { margin-top: 2rem; }

.dest-intro__grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4.5rem); align-items: center; }
.dest-intro__text p { color: var(--body); margin-bottom: 1rem; }
.dest-intro__text .h2 { margin-bottom: 1.2rem; }
.dest-intro__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--shadow); }

.itinerary { display: grid; grid-template-columns: repeat(auto-fit, minmax(min(100%,320px),1fr)); gap: clamp(1rem,2vw,1.4rem); }
.day { background: linear-gradient(160deg, var(--deep), var(--deep-2)); border-radius: var(--r-lg); overflow: hidden; padding: 0; color: rgba(255,255,255,.78); box-shadow: 0 16px 40px -30px rgba(10,25,50,.4); transition: transform .55s var(--ease), box-shadow .5s var(--ease), opacity .85s ease, filter .85s ease; display: flex; flex-direction: column; }
.day:hover { transform: translateY(-5px); }
.day__media { display: block; aspect-ratio: 16 / 10; overflow: hidden; }
.day__media img { width: 100%; height: 100%; object-fit: cover; transition: transform .8s var(--ease); }
.day:hover .day__media img { transform: scale(1.06); }
.day__body { padding: clamp(1.3rem,2.4vw,1.7rem); }
.day__num { font-size: .82rem; font-weight: 700; letter-spacing: .14em; color: var(--em-light); }
.day__title { font-size: 1.18rem; font-weight: 600; color: #fff; margin: .5rem 0 .55rem; line-height: 1.25; }
.day p { font-size: .95rem; color: rgba(255,255,255,.72); }

.gallery { display: grid; grid-template-columns: repeat(4,1fr); grid-auto-rows: 210px; gap: .8rem; }
.gallery a { display: block; overflow: hidden; border-radius: var(--r); }
.gallery img { width: 100%; height: 100%; object-fit: cover; transition: transform .9s var(--ease); }
.gallery a:hover img { transform: scale(1.06); }
.gallery .wide { grid-column: span 2; }
.gallery .tall { grid-row: span 2; }

.included__grid { display: grid; grid-template-columns: 1.35fr 1fr; gap: clamp(1.5rem,3vw,2.4rem); align-items: stretch; }
.included-card { background: linear-gradient(160deg, var(--deep), var(--deep-2)); border-radius: var(--r-lg); padding: clamp(1.7rem,3vw,2.4rem); color: #fff; }
.included-card h3 { font-size: 1.5rem; font-weight: 600; margin-bottom: 1.3rem; }
.included-list { display: grid; gap: .8rem; }
.included-list li { display: flex; gap: .65rem; align-items: flex-start; color: rgba(255,255,255,.82); font-size: 1.02rem; }
.included-list svg { flex-shrink: 0; color: var(--azure); margin-top: 3px; }
.price-card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.9rem,3.2vw,2.6rem); display: flex; flex-direction: column; box-shadow: var(--shadow); }
.price-card__badge { align-self: flex-start; display: inline-flex; align-items: center; gap: .45rem; font-weight: 700; font-size: .78rem; text-transform: uppercase; letter-spacing: .06em; padding: .45rem .9rem; border-radius: 99px; margin-bottom: 1.1rem; background: rgba(224,83,61,.12); color: #c8442f; }
.price-card__badge--next { background: rgba(13,167,255,.12); color: var(--azure); }
.price-card__badge::before { content: ""; width: 7px; height: 7px; border-radius: 50%; background: currentColor; }
.price-card__label { color: var(--muted); font-weight: 600; font-size: .95rem; }
.price-card__value { font-size: clamp(2.9rem, 2.1rem + 2.6vw, 4rem); font-weight: 800; color: var(--ink); letter-spacing: -0.03em; line-height: 1; margin: .3rem 0; }
.price-card__value small { font-size: 1.2rem; font-weight: 600; color: var(--muted); }
.price-card__per { color: var(--muted); margin-bottom: 1.6rem; font-size: .95rem; }
.price-card__closed-title { font-size: clamp(1.6rem,1.3rem+1vw,2rem); font-weight: 700; color: var(--ink); letter-spacing: -0.01em; line-height: 1.12; margin-bottom: .6rem; }
.price-card__closed-text { color: var(--body); font-size: .98rem; margin-bottom: 1.5rem; }
.price-card--closed .price-card__avail-row em { color: var(--muted); }
.price-card--closed .price-card__bar i { background: linear-gradient(90deg,#b7c0cd,#9aa6b5); box-shadow: none; }
.price-card__avail { margin: .3rem 0 1.6rem; }
.price-card__avail-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .65rem; }
.price-card__avail-row strong { font-size: 1rem; color: var(--ink); font-weight: 600; }
.price-card__avail-row em { font-style: normal; font-size: 1.2rem; font-weight: 800; color: var(--azure); letter-spacing: -0.01em; }
.price-card__bar { height: 16px; border-radius: 99px; background: var(--paper-2); overflow: hidden; box-shadow: inset 0 1px 4px rgba(13,40,70,.18); }
.price-card__bar i { display: block; height: 100%; background: var(--grad); border-radius: 99px; box-shadow: 0 0 16px rgba(13,167,255,.6); }
.price-card__avail-note { display: block; margin-top: .7rem; font-size: .88rem; font-weight: 600; color: var(--em); }
.price-card .btn { margin-top: auto; }

.faq__grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
.faq__media img { width: 100%; aspect-ratio: 4/3; object-fit: cover; object-position: center; border-radius: var(--r-lg); box-shadow: var(--shadow); }
.faq-list { display: grid; gap: .8rem; }
.faq-item { border: 1px solid var(--line); border-radius: var(--r); background: #fff; overflow: hidden; }
.faq-item summary { list-style: none; cursor: pointer; padding: 1.1rem 1.3rem; font-weight: 600; color: var(--ink); display: flex; justify-content: space-between; gap: 1rem; align-items: center; }
.faq-item summary::-webkit-details-marker { display: none; }
.faq-item summary::after { content: "+"; color: var(--azure); font-size: 1.4rem; line-height: 1; }
.faq-item[open] summary::after { content: "−"; }
.faq-item__body { padding: 0 1.3rem 1.2rem; color: var(--body); }
.dest-back { display: inline-flex; align-items: center; gap: .4rem; color: var(--azure); font-weight: 600; margin-bottom: 1.2rem; }
.dest-back::before { content: "←"; }

@media (max-width: 900px) {
  .dest-intro__grid, .included__grid, .faq__grid { grid-template-columns: 1fr; }
  .gallery { grid-template-columns: repeat(2,1fr); grid-auto-rows: 170px; }
  .gallery .tall { grid-row: span 1; }
}

/* ============================================================ Sobre / Contato ============================================================ */
.mvv { display: grid; grid-template-columns: repeat(3,1fr); gap: clamp(1rem,2vw,1.5rem); }
.mvv__card { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.6rem,3vw,2.2rem); box-shadow: var(--shadow-sm); transition: transform .5s var(--ease), box-shadow .5s var(--ease); }
.mvv__card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.mvv__ico { width: 54px; height: 54px; border-radius: 14px; display: grid; place-items: center; background: rgba(13,167,255,.1); color: var(--azure); margin-bottom: 1.1rem; }
.mvv__card h3 { font-size: 1.35rem; font-weight: 700; color: var(--ink); margin-bottom: .6rem; }
.mvv__card p { color: var(--body); font-size: .98rem; }
.stats-row { display: grid; grid-template-columns: repeat(3,1fr); gap: 1rem; margin-top: clamp(2rem,4vw,3rem); }
.stat-box { text-align: center; border-radius: var(--r-lg); padding: clamp(1.5rem,3vw,2.2rem); border: 1px solid var(--line); background: #fff; }
.stat-box--hl { background: var(--grad); border: none; box-shadow: 0 18px 36px -14px rgba(13,167,255,.6); }
.stat-box__num { font-size: clamp(2.3rem,1.6rem+2.2vw,3.2rem); font-weight: 800; color: var(--ink); letter-spacing: -0.02em; line-height: 1; }
.stat-box--hl .stat-box__num { color: #fff; }
.stat-box__lbl { color: var(--muted); font-size: .92rem; margin-top: .45rem; }
.stat-box--hl .stat-box__lbl { color: rgba(255,255,255,.88); }
.about-founder { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(2rem,5vw,4rem); align-items: center; }
.about-founder__media img { width: 100%; border-radius: var(--r-lg); box-shadow: var(--shadow); aspect-ratio: 4/3; object-fit: cover; }
.about-founder__cap { color: var(--muted); font-size: .95rem; margin-top: 1rem; }
.about-founder h2 { margin-bottom: 1.2rem; }
.about-founder p { color: var(--body); margin-bottom: 1rem; }

.contact__grid { display: grid; grid-template-columns: .9fr 1.1fr; gap: clamp(2rem,5vw,4rem); align-items: start; }
.contact-info h3 { font-size: 1.4rem; font-weight: 700; color: var(--ink); margin-bottom: .8rem; }
.contact-info > p { color: var(--body); margin-bottom: 1.4rem; }
.contact-channels { display: grid; gap: .9rem; margin-bottom: 1.6rem; }
.contact-channel { display: flex; align-items: center; gap: .8rem; color: var(--body); font-weight: 500; }
.contact-channel svg { color: var(--azure); flex-shrink: 0; }
.guarantee-list { display: grid; gap: .65rem; }
.guarantee-list li { display: flex; gap: .55rem; align-items: center; color: var(--body); }
.guarantee-list svg { color: var(--azure); flex-shrink: 0; }
.cform { background: #fff; border: 1px solid var(--line); border-radius: var(--r-lg); padding: clamp(1.6rem,3vw,2.4rem); box-shadow: var(--shadow); display: grid; gap: 1.1rem; }
.cform__row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.1rem; }
.cform label { font-size: .85rem; font-weight: 600; color: var(--ink); display: block; margin-bottom: .4rem; }
.cform input, .cform textarea { width: 100%; font: inherit; padding: .85rem 1rem; border: 1px solid var(--line); border-radius: 12px; background: var(--paper-2); color: var(--ink); transition: border-color .25s, background .25s; }
.cform input:focus, .cform textarea:focus { outline: none; border-color: var(--azure); background: #fff; box-shadow: 0 0 0 3px rgba(13,167,255,.12); }
.cform textarea { resize: vertical; min-height: 120px; }
.cform__hp { position: absolute !important; left: -9999px; width: 1px; height: 1px; opacity: 0; pointer-events: none; }
.cform__status { font-size: .92rem; font-weight: 600; margin: .2rem 0 0; min-height: 1.1em; }
.cform__status.is-ok { color: #1a8f4c; }
.cform__status.is-err { color: #d23b3b; }
.cform.is-sending button { opacity: .7; pointer-events: none; }
@media (max-width: 760px) {
  .mvv, .stats-row { grid-template-columns: 1fr; }
  .about-founder, .contact__grid, .cform__row { grid-template-columns: 1fr; }
}

/* ============================================================ Vídeo (facade leve do YouTube) + Avaliações Google ============================================================ */
.video-wrap { max-width: 940px; margin-inline: auto; }
.video-grid { display: grid; grid-template-columns: 1fr 1fr; gap: clamp(1rem,2vw,1.6rem); }
.video-el { display: block; width: 100%; aspect-ratio: 16 / 9; object-fit: cover; border-radius: var(--r-lg); box-shadow: var(--shadow); background: #06121f; }
.video-el--portrait { aspect-ratio: 9 / 16; max-width: 400px; margin-inline: auto; }
.video-grid--portrait { max-width: 720px; margin-inline: auto; align-items: start; }
.video-grid--portrait .video-el--portrait { max-width: 320px; }
.video-embed { position: relative; aspect-ratio: 16 / 9; border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow); cursor: pointer; background: #06121f; }
.video-embed img { width: 100%; height: 100%; object-fit: cover; transition: transform .9s var(--ease); }
.video-embed:hover img { transform: scale(1.04); }
.video-embed::after { content: ""; position: absolute; inset: 0; background: linear-gradient(180deg, rgba(8,18,35,.1), rgba(8,18,35,.4)); pointer-events: none; transition: opacity .3s; }
.video-embed__play { position: absolute; inset: 0; margin: auto; width: 76px; height: 76px; border-radius: 50%; background: rgba(13,167,255,.92); color: #fff; display: grid; place-items: center; box-shadow: 0 12px 34px rgba(0,0,0,.45); transition: transform .35s var(--ease), background .3s; }
.video-embed:hover .video-embed__play { transform: scale(1.09); background: var(--azure); }
.video-embed__play svg { margin-left: 3px; }
.video-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; z-index: 2; }
.video-embed.is-playing::after, .video-embed.is-playing .video-embed__play, .video-embed.is-playing img { display: none; }
/* Placeholder: espaço reservado para o vídeo (cliente sobe depois) */
.video-embed--soon { cursor: default; background: linear-gradient(140deg, var(--deep), var(--deep-2)); display: grid; place-items: center; }
.video-embed--soon::after { display: none; }
.video-embed__soon { display: inline-flex; flex-direction: column; align-items: center; gap: .9rem; color: rgba(255,255,255,.72); font-weight: 600; font-size: .95rem; letter-spacing: .01em; }
.video-embed__soon svg { width: 64px; height: 64px; padding: 18px; border-radius: 50%; background: rgba(13,167,255,.22); color: #fff; box-shadow: inset 0 0 0 1px rgba(255,255,255,.12); }

.greviews { display: inline-flex; align-items: center; gap: .8rem; background: #fff; border: 1px solid var(--line); border-radius: var(--r-pill); padding: .7rem 1.3rem; box-shadow: var(--shadow-sm); transition: transform .4s var(--ease), box-shadow .4s; }
.greviews:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.greviews__stars { color: #fbbc05; letter-spacing: 2px; font-size: 1.05rem; }
.greviews__txt { font-size: .92rem; color: var(--body); }
.greviews__txt strong { color: var(--ink); }
.greviews-wrap { text-align: center; margin-top: clamp(1.6rem,3vw,2.4rem); max-width: 1040px; margin-inline: auto; min-height: 84px; }
.greviews-wrap .eapps-widget, .greviews-wrap [class*="elfsight-app"] { width: 100%; }
@media (max-width: 700px) { .video-grid { grid-template-columns: 1fr; } }
