:root{
  --bg:#071826;
  --glass: rgba(14,42,69,.55);
  --text:#eaf3ff;
  --muted:rgba(234,243,255,.78);
  --line:rgba(234,243,255,.14);
  --accent:#35c2ff;
  --accent2:#7cf0d0;
  --shadow: 0 18px 45px rgba(0,0,0,.35);
  --radius2: 26px;
  --container: 1120px;
  --gap: 18px;
  --gap-lg: 28px;
  --header-h: 72px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Helvetica Neue", Helvetica;
  color:var(--text);
  line-height:1.55;
  background: radial-gradient(1200px 700px at 10% 0%, #0b2f50 0%, var(--bg) 52%, #050f18 100%);
}

a{color:inherit}
img{max-width:100%; display:block}
.container{max-width:var(--container); margin:0 auto; padding:0 18px}

.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);border:0}
.skip-link{position:absolute;left:16px;top:16px;background:#fff;color:#000;padding:10px 12px;border-radius:12px;transform:translateY(-200%);z-index:9999}
.skip-link:focus{transform:translateY(0)}

.header{
  position:sticky; top:0; z-index:50;
  backdrop-filter: blur(10px);
  background: rgba(7,24,38,.62);
  border-bottom:1px solid var(--line);
}
.header__inner{display:flex;align-items:center;justify-content:space-between;gap:14px;min-height:var(--header-h)}
.brand{display:flex;align-items:center;justify-content:center;text-decoration:none}
.brand--icon{width:44px;height:44px;border-radius:16px;background:rgba(255,255,255,.06);border:1px solid var(--line)}
.brand--icon:hover,.brand--icon:focus-visible{background:rgba(255,255,255,.09)}
.brand__mark{font-size:20px;line-height:1}

/* Brand com nome do hotel (substitui o ícone) */
.brand--hotel{
  padding:10px 14px;
  min-height:44px;
  border-radius:18px;
  background:rgba(255,255,255,.06);
  border:1px solid var(--line);
  box-shadow:0 14px 32px rgba(0,0,0,.25);
}
.brand--hotel:hover,.brand--hotel:focus-visible{
  background:rgba(255,255,255,.09);
}
.brand__stack{display:flex;flex-direction:column;gap:2px;line-height:1.05}
.brand__kicker{
  font-size:10px;
  letter-spacing:.22em;
  text-transform:uppercase;
  color:rgba(234,243,255,.72);
}
.brand__name{
  font-size:12px;
  font-weight:850;
  letter-spacing:.12em;
  text-transform:uppercase;
  white-space:nowrap;
}
@media (max-width: 520px){
  .brand--hotel{padding:8px 12px;border-radius:16px}
  .brand__name{white-space:normal;max-width:160px}
}

.nav{display:flex;align-items:center;gap:10px}
.nav a{white-space:nowrap;text-decoration:none;padding:10px 12px;border-radius:14px;color:rgba(255,255,255,.72);border:1px solid rgba(255,255,255,.09);background:rgba(255,255,255,.03);font-weight:800;font-size:.84rem;letter-spacing:.02em;transition:background .18s ease,color .18s ease,border-color .18s ease,transform .18s ease}
.nav a:hover,.nav a:focus-visible{background:rgba(255,255,255,.08);color:var(--text);border-color:rgba(255,255,255,.16)}
.nav a:active{transform:translateY(1px)}
/* Link ativo (secção atual) */
.nav a[aria-current="true"]{
  background: rgba(244,215,123,.10);
  border-color: rgba(244,215,123,.28);
  color: var(--text);
  box-shadow: 0 14px 40px rgba(0,0,0,.22);
}

/* Link especial (Valores & Ética) — mais “vivo” e dinâmico */
.nav__special{
  position:relative;
  border-color: rgba(124,240,208,.20);
  background: rgba(53,194,255,.06);
}
.nav__special::after{
  content:"";
  position:absolute;
  inset:-1px;
  border-radius:14px;
  pointer-events:none;
  background: radial-gradient(120px 80px at 15% 30%, rgba(124,240,208,.22), transparent 60%),
              radial-gradient(140px 90px at 85% 70%, rgba(53,194,255,.22), transparent 62%);
  opacity:.0;
  transition: opacity .18s ease;
}
.nav__special:hover::after,
.nav__special:focus-visible::after{opacity:1}

.nav__special.is-pulse{
  animation: navPulse 1.8s ease-in-out infinite;
}
@keyframes navPulse{
  0%,100%{ box-shadow: 0 0 0 0 rgba(124,240,208,.00); }
  50%{ box-shadow: 0 0 0 9px rgba(124,240,208,.09); }
}

.nav__cta{margin-left:8px}

/* Não quebrar a linha em "S. Jorge" no menu */
.nav a[href="#sao-jorge-garden"]{white-space:nowrap;flex-shrink:0}

/* Em ecrãs mais estreitos, reduzir espaço para caber melhor */
@media (max-width: 1220px){
  .nav{gap:6px}
  .nav a{padding:10px 8px}
}
.nav-toggle{display:none;background:transparent;border:0;padding:10px;border-radius:14px}
.nav-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:3px}
.nav-toggle__bar{display:block;width:22px;height:2px;background:var(--text);margin:5px 0;border-radius:2px}

.lang{position:relative}
.lang__btn{display:flex;align-items:center;gap:8px;background:rgba(255,255,255,.06);border:1px solid var(--line);color:var(--text);padding:9px 10px;border-radius:12px;cursor:pointer}
.lang__list{
  position:absolute;right:0;top:48px;min-width:120px;background:rgba(7,24,38,.96);
  border:1px solid var(--line);border-radius:14px;padding:6px;list-style:none;margin:0;display:none;box-shadow:var(--shadow)
}
.lang__list li{padding:10px 10px;border-radius:12px;cursor:pointer;color:var(--muted)}
.lang__list li:hover{background:rgba(255,255,255,.06);color:var(--text)}

.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 14px;border-radius:14px;border:1px solid transparent;
  text-decoration:none;cursor:pointer;user-select:none;font-weight:850;
}
.btn--primary{background:linear-gradient(135deg,var(--accent),var(--accent2));color:#02131f;border-color:rgba(255,255,255,.18)}
.btn--primary:hover{filter:brightness(1.05)}
.btn--ghost{background:rgba(255,255,255,.06);border-color:var(--line);color:var(--text)}
.btn--ghost:hover{background:rgba(255,255,255,.10)}
.btn--text{background:transparent;border-color:transparent;color:var(--muted);padding:12px 8px}
.btn--text:hover{color:var(--text)}
.btn--xl{padding:14px 16px;border-radius:16px;min-width:220px;justify-content:space-between}
.btn__spark{width:34px;height:34px;border-radius:14px;display:grid;place-items:center;background:rgba(255,255,255,.18);border:1px solid rgba(255,255,255,.22)}
.btn--icon{padding:12px;width:46px;height:46px}
.btn--icon .icon, .btn--icon svg{width:18px;height:18px;display:block;fill:currentColor}

.section__head{margin-bottom:22px}
.section__head h2{margin:0 0 8px 0;font-size:clamp(22px,2.6vw,34px)}
.muted{color:var(--muted)}
.lead{font-size:1.07rem;color:var(--muted)}
.kicker{letter-spacing:.14em;text-transform:uppercase;font-size:.8rem;color:rgba(234,243,255,.75)}

.grid{display:grid;gap:var(--gap)}
.grid--2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid--3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid--gap-lg{gap:var(--gap-lg)}
.align-center{align-items:center}

.card{
  background:linear-gradient(180deg,rgba(255,255,255,.05),rgba(255,255,255,.02));
  border:1px solid var(--line);border-radius:var(--radius2);overflow:hidden;
  box-shadow:var(--shadow);transform:translateZ(0);
}
.card__img{width:100%;height:260px;object-fit:cover}
.card__body{padding:18px}
.card__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}

.panel{background:var(--glass);border:1px solid var(--line);border-radius:var(--radius2);padding:18px;box-shadow:var(--shadow)}
.bullets{padding-left:18px;margin:10px 0 0 0;color:var(--muted)}
.bullets li{margin:6px 0}
.chips{display:flex;flex-wrap:wrap;gap:10px;margin-top:10px}
.chip{padding:8px 10px;border-radius:999px;border:1px solid var(--line);background:rgba(255,255,255,.04);color:var(--muted);font-size:.93rem}
.divider{height:1px;background:var(--line);margin:14px 0}
.facts{display:grid;gap:10px;margin:14px 0 16px 0}
.fact{display:flex;justify-content:space-between;gap:14px;padding:10px 12px;border-radius:16px;border:1px solid var(--line);background:rgba(255,255,255,.04)}
.fact__k{color:rgba(234,243,255,.72);font-size:.9rem}
.media{margin:0;border-radius:var(--radius2);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);background:rgba(14,42,69,.35)}
.media figcaption{padding:10px 12px}
.section__actions{display:flex;gap:12px;flex-wrap:wrap;margin-top:18px}

/* FULLSCREEN */
.fs-wrap{height:calc(100dvh - var(--header-h));overflow-y:auto;scroll-snap-type:y mandatory;scroll-padding-top:12px}
.fs-section{
  min-height:calc(100dvh - var(--header-h));
  scroll-snap-align:start;
  display:grid;align-items:center;
  padding:clamp(42px,7vh,88px) 0;
  position:relative;
}
.section--alt{
  background:linear-gradient(180deg,rgba(255,255,255,.03),rgba(255,255,255,0));
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
}
.fs-section::before{
  content:"";position:absolute;inset:0;
  background:
    radial-gradient(900px 600px at 10% 0%, rgba(53,194,255,.16), transparent 58%),
    radial-gradient(900px 600px at 90% 20%, rgba(124,240,208,.11), transparent 55%);
  pointer-events:none;opacity:.9;
}
.fs-section > .container{position:relative;z-index:1}

/* Motion */
[data-motion]{opacity:0;transform:translateY(18px);filter:blur(6px);transition:opacity .7s ease,transform .7s ease,filter .7s ease;will-change:opacity,transform,filter}
[data-motion].is-in{opacity:1;transform:translateY(0);filter:blur(0)}

/* Dots */
.dots{position:fixed;right:14px;top:50%;transform:translateY(-50%);display:grid;gap:10px;z-index:80}
.dots a{width:10px;height:10px;border-radius:50%;border:1px solid rgba(255,255,255,.35);background:rgba(255,255,255,.08);display:block}
.dots a[aria-current="true"]{background:linear-gradient(135deg,var(--accent),var(--accent2));border-color:rgba(255,255,255,.25)}

/* HERO */
.is-hero{overflow:hidden}
.hero__bg{
  position:absolute;inset:0;
  background: linear-gradient(180deg,rgba(7,24,38,.18),rgba(7,24,38,.92)),
              url("https://oceanohoteis.com/img/portfolio/grid/1A.jpg");
  background-size:cover;background-position:center;
  transform:scale(1.04);filter:saturate(1.05) contrast(1.06);
}
.hero-stack{display:grid;gap:18px;position:relative;max-width:1040px;margin:0 auto}
.hero__title{margin:10px 0;font-size:clamp(30px,4vw,58px);line-height:1.04;letter-spacing:-.02em}
.hero__lead{max-width:78ch}

/* HERO: formulários lado a lado (Hotel + Transferes/Tours) */
.heroForms{
  display:grid;
  /* Mais centrado e com proporções premium (evita esticar demasiado na horizontal) */
  grid-template-columns: minmax(340px, 420px) minmax(520px, 600px);
  gap:18px;
  align-items:stretch;
  margin-top:18px;
  max-width:1040px;
  width:100%;
  margin-left:auto;
  margin-right:auto;
}
.heroForms .bookingBar__head{padding:12px 14px}
.heroForms .bookingBar__form{padding:12px 14px 14px}

/* Transferes/Tours (HERO): 3 colunas para ocupar melhor a largura e reduzir espaços vazios */
.heroForms .transferBar .bb-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:8px 12px;
}
.heroForms .transferBar .span-1{grid-column:auto;}
.heroForms .transferBar .span-2{grid-column: span 2;}
.heroForms .transferBar .span-3{grid-column: 1 / -1;}

/* Dentro do formulário de transferes: ocupar melhor a largura (menos "vazio") */
.heroForms .transferBar .seg{width:100%;justify-content:space-between}
.heroForms .transferBar .seg__btn{flex:1;text-align:center}

/* HERO: Transfer (compact premium) — menos espaços vazios */
.heroForms .transferBar .bb-label{margin:0 0 4px 2px;font-size:.84rem}
.heroForms .transferBar .bb-mini{margin-top:4px;font-size:.78rem}
.heroForms .transferBar .bb-footer{padding-top:10px;margin-top:10px}

/* HERO: Botões mais compactos (sem perder destaque) */
.heroForms .dockHotel__actions .btn{padding:10px 12px;border-radius:13px}
.heroForms .bb-footer .btn--xl{min-width:190px;padding:12px 14px;border-radius:16px}
.heroForms .bb-footer .btn__spark{width:30px;height:30px;border-radius:12px}


/* DOCK: formulários (Hotel + Transfer) com o mesmo “look” do HERO */
.dockPanel .bookingBar__form{padding:12px 14px 14px}

/* DOCK: Transfer (igual ao HERO) */
.dockPanel .transferBar .bb-grid{
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:8px 12px;
}
.dockPanel .transferBar .span-1{grid-column:auto;}
.dockPanel .transferBar .span-2{grid-column: span 2;}
.dockPanel .transferBar .span-3{grid-column: 1 / -1;}
.dockPanel .transferBar .seg{width:100%;justify-content:space-between}
.dockPanel .transferBar .seg__btn{flex:1;text-align:center}
.dockPanel .transferBar .bb-label{margin:0 0 4px 2px;font-size:.84rem}
.dockPanel .transferBar .bb-mini{margin-top:4px;font-size:.78rem}
.dockPanel .transferBar .bb-footer{padding-top:10px;margin-top:10px}
.dockPanel .bb-footer .btn--xl{min-width:190px;padding:12px 14px;border-radius:16px}
.dockPanel .bb-footer .btn__spark{width:30px;height:30px;border-radius:12px}

/* DOCK: Hotel (igual ao HERO) */
.dockPanel .dockHotel.is-dim{display:none}
.dockPanel .dockHotel__actions .btn{padding:10px 12px;border-radius:13px}

@media (max-width: 760px){
  .dockPanel .transferBar .bb-grid{grid-template-columns:1fr}
  .dockPanel .transferBar .span-2,
  .dockPanel .transferBar .span-3{grid-column:auto}
}

/* Utilitário: forçar um campo a ocupar a linha toda */
.bb-full{grid-column:1 / -1;}

/* Hotel card stack (compacto e claro) */
.hotelBar .dockHotels{grid-template-columns:1fr;gap:12px}
.hotelBar .dockHotel{padding:14px;border-radius:20px}
/* Na HERO: mostrar apenas o hotel da ilha selecionada (evita scroll e mantém o card compacto) */
.hotelBar .dockHotel.is-dim{display:none}
.hotelBar .dockHotel.is-active{opacity:1}
.hotelBar__mini{margin-top:10px}

/* Hotel (HERO): preencher o espaço vazio com info útil (premium) */
.hotelBar .dockHotel__grid{display:grid;grid-template-columns:1fr 220px;gap:14px;align-items:start}
.hotelBar .dockHotel__extras{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  border-radius:18px;
  padding:12px;
}
.hotelBar .hotelQuick{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:10px}
.hotelBar .hotelQuick__item{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(7,24,38,.38);
  border-radius:16px;
  padding:10px;
}
.hotelBar .hotelQuick__k{
  display:block;
  font-size:.70rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(234,243,255,.70);
}
.hotelBar .hotelQuick__v{display:block;margin-top:4px;font-weight:950;color:rgba(234,243,255,.95);font-size:.95rem}
.hotelBar .hotelQuick__note{
  margin:10px 2px 0;
  font-size:.82rem;
  line-height:1.35;
  color:rgba(234,243,255,.72);
}
.hotelBar .hotelQuick__note strong{color:rgba(244,215,123,.95);font-weight:950}

.hotelBar .hotelQuick__note{
  margin:10px 2px 0;
  font-size:.78rem;
  line-height:1.35;
  color:rgba(234,243,255,.68);
}

@media (max-width: 1180px){
  .hotelBar .dockHotel__grid{grid-template-columns:1fr}
  .hotelBar .dockHotel__extras{margin-top:10px}
}

@media (max-width: 980px){
  .heroForms{grid-template-columns:1fr;gap:16px;margin-top:16px}
}

@media (max-width: 760px){
  .heroForms .transferBar .bb-grid{grid-template-columns:1fr}
  .heroForms .transferBar .span-2,
  .heroForms .transferBar .span-3{grid-column:auto}
}

.hero__actions{display:flex;gap:12px;flex-wrap:wrap;margin:16px 0}
.stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px}
.stat{background:rgba(14,42,69,.55);border:1px solid var(--line);border-radius:18px;padding:12px}
.stat__k{display:block;font-size:.82rem;color:rgba(234,243,255,.72)}
.stat__v{display:block;font-weight:900;margin-top:4px}
.scroll-hint{position:absolute;left:0;bottom:-10px;display:flex;align-items:center;gap:10px;opacity:.8}
.scroll-hint__dot{width:30px;height:44px;border:1px solid rgba(255,255,255,.26);border-radius:999px;position:relative}
.scroll-hint__dot::after{
  content:"";width:6px;height:6px;border-radius:999px;background:rgba(255,255,255,.8);
  position:absolute;left:50%;top:10px;transform:translateX(-50%);
  animation:scrollDot 1.25s infinite ease-in-out;
}
.scroll-hint__txt{font-size:.85rem;color:rgba(234,243,255,.75)}
@keyframes scrollDot{
  0%{opacity:.2;transform:translate(-50%,0)}
  50%{opacity:1;transform:translate(-50%,14px)}
  100%{opacity:.2;transform:translate(-50%,0)}
}

/* Video teaser */
.video-teaser{position:relative;border-radius:var(--radius2);overflow:hidden;border:1px solid var(--line);box-shadow:var(--shadow);cursor:pointer;margin:14px 0 8px}
.video-teaser img{width:100%;height:240px;object-fit:cover;filter:saturate(1.05)}
.video-teaser__overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;flex-direction:column;gap:10px;background:linear-gradient(180deg,rgba(0,0,0,.12),rgba(0,0,0,.55))}
.video-teaser__play{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.22);font-size:28px}
.video-teaser__txt{color:rgba(255,255,255,.92);font-weight:900}
.video-teaser:hover img{transform:scale(1.03);transition:transform .6s ease}

/* FAQ */
.faq{border:1px solid var(--line);border-radius:18px;background:rgba(255,255,255,.04);padding:10px 12px;margin:10px 0}
.faq summary{cursor:pointer;font-weight:900}
.faq__a{color:var(--muted);margin-top:8px}

/* Contact form */
.form{display:grid;gap:12px}
.field label{display:block;margin-bottom:6px;color:rgba(234,243,255,.78);font-size:.92rem}
.field input:not([type="checkbox"]):not([type="radio"]),.field textarea,.field select{
  width:100%;padding:12px;border-radius:14px;border:1px solid var(--line);
  background:rgba(7,24,38,.55);color:var(--text);
}
.field input[type="checkbox"],.field input[type="radio"]{
  width:auto;
  padding:0;
  border:0;
  background:transparent;
  box-shadow:none;
  accent-color: var(--accent);
}
.field textarea{
  /* Impedir redimensionamento pelo utilizador */
  resize:none;
  height:160px;
  min-height:160px;
  max-height:160px;
  overflow:auto;
}
.field input:focus,.field textarea:focus,.field select:focus{outline:2px solid var(--accent);outline-offset:2px}
.honeypot{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.check{display:flex;gap:10px;align-items:flex-start;justify-content:flex-start;color:var(--muted);font-size:.95rem;flex-direction:row}
.check input{flex:0 0 auto;margin-top:2px}
.check span{flex:1;min-width:0}
.checkRow{
  display:block;
  margin:0;
  color:var(--muted);
  font-size:.95rem;
  line-height:1.35;
}
.checkRow input{
  display:inline-block;
  width:auto;
  margin-left:10px;
  vertical-align:middle;
}

.check--compact{font-size:.9rem}
.form__feedback{min-height:22px;color:var(--muted)}
.form__feedback.is-ok{color:rgba(124,240,208,.95)}
.form__feedback.is-err{color:rgba(255,170,170,.95)}
.is-hidden{display:none !important}

/* Modal vídeo */
.modal{position:fixed;inset:0;display:none;z-index:90}
.modal.is-open{display:block}
.modal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.72)}
.modal__panel{
  position:relative;max-width:980px;margin:7vh auto;border-radius:var(--radius2);overflow:hidden;
  border:1px solid var(--line);box-shadow:var(--shadow);background:rgba(11,34,57,.92)
}
.modal__head{display:flex;align-items:center;justify-content:space-between;padding:12px 14px;border-bottom:1px solid var(--line)}
.icon-btn{background:rgba(255,255,255,.08);border:1px solid var(--line);color:var(--text);width:40px;height:40px;border-radius:14px;cursor:pointer}
.player{width:100%;aspect-ratio:16/9;background:#000}
.video-fallback{
  position:absolute;inset:auto 14px 14px 14px;padding:12px;border-radius:18px;border:1px solid rgba(255,255,255,.18);
  background:rgba(7,24,38,.75);backdrop-filter:blur(10px);
  display:flex;align-items:center;justify-content:space-between;gap:12px;
}
.video-fallback p{margin:0;color:rgba(234,243,255,.85)}

/* ====== Segmented Toggle (premium) ====== */
.seg{
  display:flex;
  gap:8px;
  padding:8px;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,24,38,.45);
  width:fit-content;
}
.seg__btn{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.06);
  color:rgba(234,243,255,.92);
  padding:10px 12px;
  border-radius:14px;
  cursor:pointer;
  font-weight:950;
  transition:transform .12s ease, background .12s ease, box-shadow .12s ease;
}
.seg__btn:hover{background:rgba(255,255,255,.10)}
.seg__btn[aria-pressed="true"]{
  background:linear-gradient(135deg, rgba(53,194,255,.28), rgba(124,240,208,.20));
  border-color:rgba(255,255,255,.18);
  box-shadow: 0 0 0 3px rgba(53,194,255,.10);
}
.seg--sm .seg__btn{padding:8px 10px;font-size:.95rem}

/* ====== Booking Bar (premium / horizontal) ====== */
.bookingBar{
  border-radius:var(--radius2);
  border:1px solid rgba(255,255,255,.14);
  background:
    radial-gradient(900px 320px at 10% 0%, rgba(53,194,255,.18), transparent 60%),
    radial-gradient(900px 320px at 90% 20%, rgba(124,240,208,.12), transparent 55%),
    linear-gradient(180deg, rgba(255,255,255,.06), rgba(255,255,255,.02));
  box-shadow:var(--shadow);
  overflow:hidden;
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  position:relative;
}
.bookingBar::after{
  content:"";
  position:absolute; inset:0;
  pointer-events:none;
  opacity:.22;
  background:
    radial-gradient(900px 240px at 15% 0%, rgba(53,194,255,.55), transparent 60%),
    radial-gradient(900px 240px at 85% 20%, rgba(124,240,208,.45), transparent 55%);
  mix-blend-mode: screen;
}

/* Theme by island (subtil) */
.bookingBar[data-island-theme="Pico"]{border-color: rgba(53,194,255,.22)}
.bookingBar[data-island-theme="São Jorge"]{border-color: rgba(124,240,208,.22)}

.bookingBar__head{
  display:flex;align-items:center;justify-content:space-between;gap:14px;
  padding:14px 16px;border-bottom:1px solid rgba(255,255,255,.12);
  background:rgba(7,24,38,.25);
  position:relative; z-index:1;
}
.pill{
  display:inline-flex;align-items:center;gap:8px;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.06);
  color:rgba(234,243,255,.90);font-weight:900;font-size:.9rem;
}
.bookingBar__title{margin-top:8px;color:rgba(234,243,255,.92);font-size:1.05rem;letter-spacing:-.01em}
.bookingBar__right{display:flex;align-items:center;gap:10px;flex-wrap:wrap;justify-content:flex-end}
.bookingBar__hintLabel{color:rgba(234,243,255,.70);font-size:.9rem}
.bookingBar__hintValue{
  display:inline-flex;align-items:center;gap:10px;padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.18);background:rgba(255,255,255,.06);
  color:rgba(234,243,255,.92);font-weight:950;
}
.bookingBar__hintValue a{text-decoration:none}
.bookingBar__form{padding:14px 16px 16px; position:relative; z-index:1}

/* grid horizontal */
.bb-grid{
  display:grid;
  grid-template-columns: repeat(10, minmax(0, 1fr));
  gap: 12px;
  align-items: start;
}
.span-1{grid-column: span 1;}
.span-2{grid-column: span 2;}
.span-3{grid-column: span 3;}

.bb-label{display:block;margin:0 0 6px 2px;font-size:.86rem;color:rgba(234,243,255,.78)}
.bb-input,.bb-select{
  width:100%;padding:12px 12px;border-radius:16px;border:1px solid rgba(255,255,255,.14);
  background:rgba(7,24,38,.58);color:var(--text);outline:0;
  transition: box-shadow .18s ease, border-color .18s ease;
}
.bb-input:focus,.bb-select:focus{
  border-color: rgba(53,194,255,.55);
  box-shadow: 0 0 0 3px rgba(53,194,255,.12);
}
.bb-mini{margin-top:6px;font-size:.80rem;color:rgba(234,243,255,.62);padding-left:2px}

.bb-stepper{
  display:flex;align-items:center;gap:10px;border-radius:16px;border:1px solid rgba(255,255,255,.14);
  background:rgba(7,24,38,.58);padding:8px;
}
.bb-stepperBtn{
  width:40px;height:40px;border-radius:14px;border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);color:rgba(234,243,255,.92);font-size:20px;font-weight:900;cursor:pointer;
}
.bb-stepperBtn:hover{background:rgba(255,255,255,.10)}
.bb-stepperInput{
  flex:1;border:0;outline:0;background:transparent;color:var(--text);
  font-size:1.05rem;font-weight:950;text-align:center;padding:8px 8px;
}

.bb-footer{
  display:flex;gap:12px;flex-wrap:wrap;align-items:center;justify-content:space-between;
  padding-top:12px;margin-top:12px;border-top:1px solid rgba(255,255,255,.12);
}

/* ====== Sticky Bar (compact premium) ====== */
.stickyBar{
  position:fixed;
  left:0; right:0;
  bottom: 14px;
  z-index: 120;
  pointer-events:none;
  opacity:0;
  transform: translateY(16px);
  transition: opacity .22s ease, transform .22s ease;
}
.stickyBar.is-show{
  opacity:1;
  transform: translateY(0);
}
.stickyBar__inner{
  pointer-events:auto;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.16);
  background: rgba(7,24,38,.72);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  box-shadow: 0 18px 55px rgba(0,0,0,.45);
  padding: 12px;
  display:grid;
  gap: 10px;
}
.stickyBar__meta{
  display:flex; gap:10px; align-items:center; justify-content:space-between;
  flex-wrap:wrap;
}
.stickyBar__tag{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  font-weight:950;
}
.stickyBar__hotel{
  color:rgba(234,243,255,.9);
  font-weight:950;
  padding:8px 10px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.05);
}
.stickyBar__hotel a{ text-decoration:none; }

.stickyBar__form{display:grid; gap:10px}
.sb-grid{
  display:grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap:10px;
  align-items:start;
}
.sb-field{min-width:0}
.sb-label{display:block;margin:0 0 6px 2px;font-size:.82rem;color:rgba(234,243,255,.76)}
.sb-input,.sb-select{
  width:100%;
  padding:10px 10px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,24,38,.62);
  color:var(--text);
}
.sb-span-2{grid-column: span 2;}
.sb-span-3{grid-column: span 3;}

.sb-stepper{
  display:flex; align-items:center; gap:8px;
  padding:6px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(7,24,38,.62);
}
.sb-stepBtn{
  width:34px; height:34px;
  border-radius:12px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(234,243,255,.92);
  font-weight:950;
  cursor:pointer;
}
.sb-stepInput{
  flex:1;
  border:0; outline:0;
  background:transparent;
  color:var(--text);
  text-align:center;
  font-weight:950;
}

.stickyBar__footer{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  justify-content:space-between;
  border-top:1px solid rgba(255,255,255,.12);
  padding-top:10px;
}
.stickyBar__more{
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.06);
  color:rgba(234,243,255,.92);
  border-radius:14px;
  padding:10px 12px;
  cursor:pointer;
  font-weight:950;
}
.stickyBar__more:hover{background:rgba(255,255,255,.10)}
.stickyBar__submit{min-width: 140px}
.stickyBar__fb{min-width: 220px}
.stickyBar__extras{width:100%}
.sb-extras-grid{
  display:grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap:10px;
  margin-top:10px;
}

.is-hidden{display:none !important}

/* Responsive */
@media (max-width: 1100px){
  .bb-grid{grid-template-columns: repeat(6, minmax(0, 1fr));}
  .grid--3{grid-template-columns:repeat(2,minmax(0,1fr))}
}
@media (max-width: 980px){
  .grid--2{grid-template-columns:1fr}
  .grid--3{grid-template-columns:1fr}
  .stats{grid-template-columns:repeat(2, minmax(0,1fr))}
  .dots{display:none}
  .modal__panel{margin: 6vh 14px}

  .nav-toggle{display:inline-block}
  .nav{
    position:absolute; right:18px; top: var(--header-h);
    display:none; flex-direction:column; align-items:stretch;
    min-width:min(360px, calc(100vw - 36px));
    padding:10px; background: rgba(7,24,38,.96);
    border:1px solid var(--line); border-radius: 18px; box-shadow: var(--shadow);
  }
  .nav.is-open{display:flex}
  .fs-wrap{scroll-snap-type:none}

  .bookingBar__head{flex-direction:column; align-items:flex-start}
  .bookingBar__right{justify-content:flex-start}
  .bb-grid{grid-template-columns: 1fr;}
  .span-1,.span-2{grid-column:auto}
  .btn--xl{min-width: 0; width:100%}

  .stickyBar{bottom: 10px}
  .sb-grid{grid-template-columns: 1fr}
  .sb-span-2,.sb-span-3{grid-column:auto}
  .sb-extras-grid{grid-template-columns: 1fr}
  .stickyBar__fb{min-width:0; width:100%}
}

@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  .fs-wrap{scroll-snap-type:none}
  [data-motion]{transition:none; opacity:1; transform:none; filter:none}
}


/* =============================
   LUXO CLÁSSICO (mais marcante)
   ============================= */
:root{
  --bg:#05060a;
  --glass: rgba(8,10,14,.62);
  --text:#f7f2e5;
  --muted:rgba(247,242,229,.78);
  --line:rgba(244,215,123,.18);
  --accent:#d4af37;
  --accent2:#f4d77b;
  --shadow: 0 24px 70px rgba(0,0,0,.52);
  --radius2: 28px;
  --container: 1140px;
}

body{
  background:
    radial-gradient(1200px 800px at 12% 0%, rgba(212,175,55,.20) 0%, transparent 55%),
    radial-gradient(1000px 700px at 88% 10%, rgba(244,215,123,.12) 0%, transparent 58%),
    radial-gradient(1200px 800px at 50% 120%, rgba(11,22,35,.75) 0%, transparent 55%),
    linear-gradient(180deg,#03040a 0%, #070813 40%, #04050b 100%);
}

/* Tipografia (luxo) */
.hero__title,
.section__head h2,
.card h3,
.panel h3,
.dockPanel__title,
.dockHotel__name{
  font-family: ui-serif, Georgia, "Times New Roman", Times, serif;
  letter-spacing: -0.01em;
}

.kicker{
  color: rgba(244,215,123,.78);
  text-shadow: 0 12px 38px rgba(0,0,0,.55);
}

/* Header mais clássico */
.header{
  background: rgba(5,6,10,.66);
  border-bottom: 1px solid rgba(244,215,123,.22);
}
.brand__text{letter-spacing:.4px}

/* CTA dourado mais marcante */
.btn{
  border-radius: 16px;
}
.btn--primary{
  position:relative;
  color:#160f05;
  border-color: rgba(244,215,123,.35);
  background:
    linear-gradient(180deg, rgba(255,255,255,.22), rgba(255,255,255,0)) ,
    linear-gradient(135deg, var(--accent) 0%, var(--accent2) 55%, #ffe7a8 100%);
  box-shadow:
    0 18px 44px rgba(212,175,55,.22),
    0 22px 60px rgba(0,0,0,.42);
}
.btn--primary::before{
  content:"";
  position:absolute; inset:0;
  border-radius: inherit;
  background: radial-gradient(420px 220px at 20% 15%, rgba(255,255,255,.40), transparent 60%);
  opacity:.55;
  pointer-events:none;
  transition: opacity .35s ease;
}
.btn--primary:hover::before{opacity:.80}
.btn--primary:hover{filter:brightness(1.04)}

.btn--ghost{
  background: rgba(255,255,255,.04);
  border-color: rgba(244,215,123,.24);
}
.btn--ghost:hover{background: rgba(244,215,123,.08)}

/* Seg toggle (ouro) */
.seg{border-color: rgba(244,215,123,.18); background: rgba(5,6,10,.38)}
.seg__btn[aria-pressed="true"]{
  background:
    linear-gradient(180deg, rgba(255,255,255,.16), rgba(255,255,255,0)),
    linear-gradient(135deg, rgba(212,175,55,.95), rgba(244,215,123,.92));
  color:#1a1207;
}

/* HERO com fotos reais + fade por ilha */
.hero__bg{
  background: none !important;
}
.hero__bg::before,
.hero__bg::after{
  content:"";
  position:absolute; inset:0;
  background-size: cover;
  background-position: center;
  filter: saturate(1.08) contrast(1.10);
  transform: scale(1.06);
  transition: opacity .9s ease;
  will-change: opacity;
}
.hero__bg::before{ background-image: url("../img/hero-pico.jpg"); background-image: image-set(url("../img/hero-pico.jpg") 1x, url("../img/hero-pico@2x.jpg") 2x); opacity: 1; }
.hero__bg::after{ background-image: url("../img/hero-sao-jorge.jpg"); background-image: image-set(url("../img/hero-sao-jorge.jpg") 1x, url("../img/hero-sao-jorge@2x.jpg") 2x); opacity: 0; }

body[data-island="São Jorge"] .hero__bg::after{ opacity: 1; }
body[data-island="São Jorge"] .hero__bg::before{ opacity: 0; }

/* Ken Burns (suave) */
@media (prefers-reduced-motion: no-preference){
  .hero__bg::before,
  .hero__bg::after{
    animation: kenburns 18s ease-in-out infinite alternate;
  }
}
@keyframes kenburns{
  from{ transform: scale(1.06) translate3d(0,0,0); }
  to{ transform: scale(1.12) translate3d(-1.5%, -1.2%, 0); }
}

/* Vignette + overlay */
.is-hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    radial-gradient(900px 600px at 12% 20%, rgba(244,215,123,.18), transparent 55%),
    radial-gradient(1200px 900px at 70% 10%, rgba(0,0,0,.30), transparent 62%),
    linear-gradient(180deg, rgba(0,0,0,.15), rgba(0,0,0,.68));
  pointer-events:none;
  z-index:0;
}

/* Spotlight que acompanha o cursor (luxo) */
.is-hero::after{
  content:"";
  position:absolute; inset:0;
  background: radial-gradient(520px 360px at var(--mx, 60%) var(--my, 35%), rgba(244,215,123,.22), transparent 60%);
  mix-blend-mode: screen;
  opacity: .85;
  pointer-events:none;
  z-index:0;
  transition: opacity .25s ease;
}
@media (prefers-reduced-motion: reduce){
  .is-hero::after{ display:none; }
}

/* BookingBar mais premium */
.bookingBar{
  border-color: rgba(244,215,123,.22);
  background: rgba(6,7,10,.56);
}

/* Scroll progress */
.scrollProgress{
  position: fixed;
  top: calc(var(--header-h) - 2px);
  left: 0;
  height: 2px;
  width: 100%;
  transform-origin: 0 50%;
  transform: scaleX(0);
  background: linear-gradient(90deg, rgba(244,215,123,.00), rgba(244,215,123,.85), rgba(212,175,55,.95));
  z-index: 85;
  pointer-events: none;
  filter: drop-shadow(0 6px 12px rgba(212,175,55,.25));
}

/* island switch no header */
.islandSwitch{display:flex;flex-direction:column;align-items:flex-start;gap:6px;margin-left:6px}
.islandSwitch__label{display:inline-flex;align-items:center;gap:8px;font-size:.72rem;font-weight:950;letter-spacing:.18em;text-transform:uppercase;color:rgba(244,215,123,.92);padding:6px 10px;border-radius:999px;border:1px solid rgba(244,215,123,.22);background:rgba(244,215,123,.06);max-width:240px}
@media (max-width: 980px){
  .islandSwitch{display:none}
}

/* DOCK premium */
.dock{position:fixed;left:0;right:0;bottom:14px;z-index:70;pointer-events:none}
.dock.is-show{pointer-events:auto}
.dock__bar{pointer-events:auto}
.dock__inner{display:flex;gap:12px;align-items:center;justify-content:center}
.dock__backdrop{position:fixed;inset:0;background:rgba(0,0,0,.62);backdrop-filter: blur(10px);opacity:0;pointer-events:none;transition:opacity .28s ease;z-index:69}
.dock.is-open .dock__backdrop{opacity:1;pointer-events:auto}

.dock__bar{
  margin: 0 auto;
  max-width: var(--container);
}

.dock__bar::before{
  content:"";
  position:absolute;
  left:50%;transform:translateX(-50%);
  bottom:-10px;
  width:min(92vw,var(--container));
  height:70px;
  background: rgba(6,7,10,.50);
  border: 1px solid rgba(244,215,123,.22);
  border-radius: 999px;
  box-shadow: 0 26px 70px rgba(0,0,0,.55);
  backdrop-filter: blur(14px);
}

.dock__bar{position:relative}

.dock__btn{
  pointer-events:auto;
  position:relative;
  border: 1px solid rgba(244,215,123,.18);
  background: rgba(10,10,12,.44);
  color: rgba(247,242,229,.92);
  padding: 12px 16px;
  border-radius: 999px;
  cursor:pointer;
  display:flex;align-items:center;gap:10px;
  box-shadow: 0 16px 40px rgba(0,0,0,.40);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.dock__btn:hover{transform: translateY(-1px); background: rgba(244,215,123,.09); border-color: rgba(244,215,123,.34)}
.dock__btn[aria-expanded="true"]{border-color: rgba(244,215,123,.55)}
.dock__btn[aria-expanded="true"]::after{
  content:"";
  position:absolute;
  left:18px; right:18px; bottom:-9px;
  height:2px;
  background: linear-gradient(90deg, rgba(244,215,123,0), rgba(244,215,123,.95), rgba(244,215,123,0));
}
.dock__btn--top{margin-left:auto}
.dock__btn--top[aria-hidden="true"]{display:none}

.dock__glyph{color: rgba(244,215,123,.95)}

.dockPanel{
  position:fixed;
  left:50%; transform: translateX(-50%) translateY(12px);
  bottom: 96px;
  width: min(var(--container), 92vw);
  opacity:0;
  pointer-events:none;
  transition: opacity .28s ease, transform .28s ease;
  z-index:70;
}
.dock.is-open .dockPanel.is-open{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto}

.dockPanel__inner{
  border:1px solid rgba(244,215,123,.25);
  border-radius: var(--radius2);
  background:
    radial-gradient(800px 450px at 20% 0%, rgba(244,215,123,.16), transparent 60%),
    rgba(6,7,10,.72);
  box-shadow: 0 30px 90px rgba(0,0,0,.62);
  backdrop-filter: blur(14px);
  padding: 18px;
}

.dockPanel__head{display:flex;align-items:flex-start;justify-content:space-between;gap:14px;margin-bottom:14px}
.dockPanel__kicker{font-size:.78rem;letter-spacing:.14em;text-transform:uppercase;color:rgba(244,215,123,.80)}
.dockPanel__title{font-weight:900;font-size:1.35rem;margin-top:2px}
.dockPanel__sub{color:rgba(247,242,229,.78);font-size:.95rem;margin-top:4px}
.dockPanel__headRight{display:flex;gap:10px;align-items:center}
.dockPanel__min{background:transparent;border:1px solid rgba(244,215,123,.22);color:rgba(247,242,229,.92);padding:10px 12px;border-radius:999px;cursor:pointer}
.dockPanel__min:hover{background:rgba(244,215,123,.10)}

.dockHotels{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
@media (max-width: 760px){
  .dockHotels{grid-template-columns:1fr}
  .dockPanel{bottom: 92px}
}

.dockHotel{
  border:1px solid rgba(244,215,123,.20);
  border-radius: 22px;
  padding: 16px;
  background: rgba(255,255,255,.03);
}
.dockHotel.is-active{border-color: rgba(244,215,123,.55); box-shadow: 0 18px 60px rgba(244,215,123,.08)}
.dockHotel__badge{display:inline-flex;align-items:center;gap:8px;padding:6px 10px;border-radius:999px;border:1px solid rgba(244,215,123,.24);color:rgba(244,215,123,.90);font-size:.85rem}
.dockHotel__name{margin:10px 0 6px 0}
.dockHotel__meta{margin:0;color:rgba(247,242,229,.74)}
.dockHotel__actions{display:flex;gap:10px;flex-wrap:wrap;margin-top:12px}

.pill--gold{border-color: rgba(244,215,123,.28); background: rgba(244,215,123,.08); color: rgba(244,215,123,.92)}

/* Ajuste das dots para combinar com ouro */
.dots a[aria-current="true"]{background:linear-gradient(135deg, var(--accent), var(--accent2));}

/* ====== Contactos: Google Maps (hotéis) ====== */
.contactMaps{margin-top:18px}
.mapWrap{
  margin-top:12px;
  border-radius:18px;
  overflow:hidden;
  border:1px solid var(--line);
  background:rgba(255,255,255,.02);
  box-shadow:var(--shadow);
}
.mapWrap iframe{width:100%;height:260px;border:0;display:block}
.coord{font-variant-numeric: tabular-nums}
@media (max-width: 980px){
  .mapWrap iframe{height:240px}
}


/* =========================
   Enriquecimentos: Experiências + Contactos (GPS/Mapas)
   ========================= */

/* Experiences (enriched) */
.expGrid{
  display:grid;
  gap:14px;
  margin-top:12px;
  grid-template-columns:repeat(auto-fit, minmax(220px, 1fr));
  align-items:start;
}
.expItem{
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  padding:12px;
  background:rgba(255,255,255,.03);
  min-width:0;
  overflow:hidden;
}
.expItem h4{margin:0 0 6px 0;font-size:1rem;font-weight:950;color:rgba(234,243,255,.92)}
.expItem .bullets{margin-top:8px}
/* Impedir qualquer overflow de texto */
.expItem, .expItem *{overflow-wrap:anywhere;word-break:break-word;hyphens:auto}


/* Experiences (cards) */
.expIslands{align-items:stretch}
.expIsland{display:flex;flex-direction:column}
.expIsland__media{position:relative;overflow:hidden;aspect-ratio:16 / 9;min-height:220px}
.expIsland__img{width:100%;height:100%;object-fit:cover;display:block;transform:scale(1.02);transition:transform .6s ease, filter .6s ease}
.expIsland__overlay{position:absolute;inset:0;display:flex;flex-direction:column;justify-content:flex-end;gap:6px;padding:18px;background:linear-gradient(180deg, rgba(0,0,0,0) 30%, rgba(0,0,0,.72) 100%)}
.expIsland__badge{display:inline-flex;align-self:flex-start;align-items:center;gap:8px;padding:8px 12px;border-radius:999px;border:1px solid rgba(244,215,123,.26);background:rgba(6,7,10,.58);backdrop-filter:blur(10px);color:rgba(244,215,123,.92);font-weight:950;font-size:.86rem;letter-spacing:.04em}
.expIsland__title{margin:0;font-weight:950;font-size:1.55rem;line-height:1.1}
.expIsland__sub{margin:0;color:rgba(247,242,229,.86);max-width:52ch}
.expIsland__body{padding-top:16px}
.expIsland:hover .expIsland__img{transform:scale(1.06);filter:saturate(1.08) contrast(1.05)}

.expCards{display:grid;gap:14px;grid-template-columns:repeat(2,minmax(0,1fr));margin-top:14px;align-items:start}
.expCard{border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:14px;background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));box-shadow:0 18px 60px rgba(0,0,0,.28);transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;min-width:0}
.expCard:hover{transform:translateY(-2px);border-color:rgba(244,215,123,.30);background:linear-gradient(180deg, rgba(244,215,123,.06), rgba(255,255,255,.02));box-shadow:0 22px 70px rgba(0,0,0,.38)}
.expCard__head{display:flex;align-items:center;gap:10px;margin-bottom:8px}
.expCard__icon{width:38px;height:38px;border-radius:14px;display:grid;place-items:center;background:rgba(244,215,123,.10);border:1px solid rgba(244,215,123,.22);box-shadow:0 12px 32px rgba(0,0,0,.24);font-size:1.1rem;flex:0 0 auto}
.expCard h4{margin:0;font-size:1.02rem;font-weight:950;color:rgba(234,243,255,.94)}
.expCard .bullets{margin-top:8px}

.expTip{margin-top:14px}

/* Impedir qualquer overflow de texto */
.expCard, .expCard *{overflow-wrap:anywhere;word-break:break-word;hyphens:auto}

@media (max-width: 580px){
  .expCards{grid-template-columns:1fr}
  .expIsland__overlay{padding:16px}
  .expIsland__title{font-size:1.35rem}
}


/* GPS typography */
.coord{font-variant-numeric:tabular-nums;letter-spacing:.01em;color:rgba(234,243,255,.92)}
.facts--compact .fact{flex-wrap:wrap}
.facts--compact .fact__v{color:rgba(234,243,255,.86)}

/* Contact maps layout (if not already defined) */
.contactMaps{margin-top:18px}
.mapWrap{margin-top:12px;border-radius:26px;overflow:hidden;border:1px solid rgba(255,255,255,.14);background:rgba(255,255,255,.03);aspect-ratio:16/10}
.mapWrap iframe{width:100%;height:100%;border:0;display:block}




/* =========================
   Valores & Ética
   ========================= */
.ethicsGrid{align-items:stretch}
.ethicsHero{position:relative;overflow:hidden}
.ethicsHero::before{
  content:"";
  position:absolute;inset:-1px;
  background:
    radial-gradient(420px 280px at 20% 20%, rgba(124,240,208,.16), transparent 60%),
    radial-gradient(520px 320px at 90% 80%, rgba(53,194,255,.16), transparent 62%);
  pointer-events:none;
  opacity:.95;
}
.ethicsHero .card__body{position:relative;z-index:1}
.ethicsHero__title{margin:8px 0 10px 0;font-size:1.35rem;letter-spacing:-.01em}

.ethicsPillRow{display:flex;flex-wrap:wrap;gap:10px;margin-top:14px}
.ethicsPill{
  display:inline-flex;align-items:center;gap:8px;
  padding:8px 10px;border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(255,255,255,.035);
  color:rgba(234,243,255,.88);
  font-weight:850;
  font-size:.92rem;
}

.ethicsDeck{display:grid;gap:12px}
.ethicCard{
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  box-shadow:0 18px 60px rgba(0,0,0,.26);
  overflow:hidden;
}
.ethicCard summary{
  display:flex;align-items:center;gap:10px;
  padding:14px 14px;
  cursor:pointer;
  user-select:none;
  color:rgba(234,243,255,.92);
  font-weight:950;
}
.ethicCard summary::-webkit-details-marker{display:none}
.ethicCard__icon{
  width:38px;height:38px;border-radius:14px;display:grid;place-items:center;
  background:rgba(244,215,123,.10);
  border:1px solid rgba(244,215,123,.22);
  box-shadow:0 12px 32px rgba(0,0,0,.22);
  flex:0 0 auto;
}
.ethicCard__title{flex:1 1 auto}
.ethicCard__chev{opacity:.9;transition:transform .18s ease}
.ethicCard[open]{
  border-color: rgba(244,215,123,.30);
  background:linear-gradient(180deg, rgba(244,215,123,.055), rgba(255,255,255,.02));
}
.ethicCard[open] .ethicCard__chev{transform:rotate(180deg)}
.ethicCard__body{padding:0 14px 14px 14px;color:rgba(234,243,255,.80)}
.ethicCard__body p{margin:10px 0 0 0}
.ethicCard__body p:first-child{margin-top:0}

/* Mini cards */
.ethicsMini{margin-top:18px}
.ethicsMiniCard{
  border:1px solid rgba(255,255,255,.14);
  border-radius:22px;
  padding:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.045), rgba(255,255,255,.02));
  box-shadow:0 18px 60px rgba(0,0,0,.28);
  transition:transform .18s ease, border-color .18s ease, background .18s ease, box-shadow .18s ease;
  min-width:0;
}
.ethicsMiniCard:hover{
  transform:translateY(-2px);
  border-color:rgba(244,215,123,.28);
  background:linear-gradient(180deg, rgba(244,215,123,.05), rgba(255,255,255,.02));
  box-shadow:0 22px 70px rgba(0,0,0,.36);
}
.ethicsMiniCard__head{display:flex;align-items:center;gap:10px;margin-bottom:6px}
.ethicsMiniCard__icon{
  width:38px;height:38px;border-radius:14px;display:grid;place-items:center;
  background:rgba(124,240,208,.10);
  border:1px solid rgba(124,240,208,.22);
  box-shadow:0 12px 32px rgba(0,0,0,.22);
  font-size:1.1rem;flex:0 0 auto;
}
.ethicsMiniCard h3{margin:0;font-size:1.02rem;font-weight:950;color:rgba(234,243,255,.94)}
.ethicsMiniCard p{margin:8px 0 0 0}

@media (max-width: 980px){
  .ethicsGrid{grid-template-columns:1fr}
}
@media (max-width: 720px){
  .ethicsMini{grid-template-columns:1fr}
}

/* Impedir qualquer overflow de texto */
.ethicCard, .ethicCard *, .ethicsMiniCard, .ethicsMiniCard *{overflow-wrap:anywhere;word-break:break-word;hyphens:auto}

/* ===== Footer / Apoios (assinatura FEDER + PDFs) ===== */
.siteFooter{
  /* Footer: não ocupar ecrã inteiro (sem “vazio” acima do ©) */
  min-height:auto;
  display:block;
  scroll-snap-align:start;
  padding: 18px 0 calc(96px + env(safe-area-inset-bottom, 0px));
}


.apoiosPanel{padding:clamp(16px, 2.2vw, 22px)}
.apoiosSig{display:flex;align-items:center;justify-content:center;padding:6px 2px}
.apoiosSig img{width:100%;height:auto;max-height:150px;object-fit:contain;display:block;filter:drop-shadow(0 10px 30px rgba(0,0,0,.35))}

.pdfRow{display:flex;flex-wrap:wrap;gap:12px;margin-top:12px}
.pdfPill{display:inline-flex;align-items:center;gap:10px;padding:10px 12px;border-radius:999px;border:1px solid rgba(255,255,255,.16);background:rgba(255,255,255,.035);color:rgba(234,243,255,.88);text-decoration:none;font-size:.92rem;line-height:1.2;max-width:100%}
.pdfPill::before{content:"📄";opacity:.9}
.pdfPill:hover{background:rgba(255,255,255,.065);border-color:rgba(255,255,255,.22)}

.footerCopy{margin:16px 0 0 0;color:rgba(234,243,255,.82);text-align:center;font-variant-numeric:tabular-nums}
.footerBrand{font-weight:700;color:rgba(234,243,255,.9)}
.small{font-size:.92rem}



/* =========================
   Cookies (banner + definições)
   ========================= */
.cookieBanner{
  position:fixed;inset:0;
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  padding:18px;
  background:rgba(0,0,0,.65);
}
.cookieBanner[hidden]{display:none}
.cookieBanner .container{width:min(980px, 100%);margin:0}

.cookieCard{
  background:rgba(255,255,255,.94);
  color:#1b2130;
  border:1px solid rgba(0,0,0,.14);
  border-radius:18px;
  box-shadow:0 18px 60px rgba(0,0,0,.38);
  padding:20px 22px;
  max-height:calc(100vh - 36px);
  overflow:auto;
}
.cookieTitle{
  margin:0 0 12px;
  font-weight:900;
  letter-spacing:.06em;
  font-size:1.02rem;
  text-transform:uppercase;
}
.cookieCard p{margin:0 0 10px;color:rgba(0,0,0,.72);line-height:1.55}
.cookieCard strong{color:rgba(0,0,0,.85)}
.cookieMore{margin-top:2px}
.cookieCard a{color:#0b62ff;text-decoration:underline}
.cookieActions{
  display:flex;gap:12px;justify-content:space-between;align-items:center;
  flex-wrap:wrap;
  margin-top:16px;
}
.cookieActions .cookieBtn{white-space:nowrap}
.cookieBanner .btn{border-radius:10px}
.cookieBanner .btn--ghost{
  background:#fff;color:#111;
  border:1px solid rgba(0,0,0,.28);
}
.cookieBanner .btn--primary{
  background:#4b4b4b;color:#fff;
  border:1px solid rgba(0,0,0,.28);
}

@media (max-width: 760px){
  .cookieBanner{padding:14px}
  .cookieActions{justify-content:flex-start}
  .cookieActions .cookieBtn{width:100%}
}

/* Modal de preferências */
.cookieModal{
  position:fixed;inset:0;
  z-index:10000;
  display:none;
  align-items:center;justify-content:center;
  padding:18px;
}
.cookieModal.is-open{display:flex}
.cookieModal__overlay{position:absolute;inset:0;background:rgba(0,0,0,.65)}
.cookieModal__panel{
  position:relative;
  width:min(760px, 100%);
  background:rgba(10,12,20,.98);
  border:1px solid var(--line);
  border-radius:22px;
  box-shadow:var(--shadow);
  overflow:hidden;
}
.cookieModal__head{
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 16px;
  border-bottom:1px solid var(--line);
}
.cookieModal__title{font-weight:900}
.cookieModal__body{padding:16px;display:grid;gap:12px}
.cookieOpt{
  display:flex;gap:14px;justify-content:space-between;align-items:flex-start;
  padding:12px;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  border-radius:16px;
}
.cookieOpt__main strong{display:block}
.cookieOpt__main .small{display:block;margin-top:4px}
.cookieToggle{
  width:18px;height:18px;
  margin-top:3px;
  flex:0 0 auto;
}
.cookieModal__actions{
  display:flex;gap:12px;justify-content:flex-end;flex-wrap:wrap;
  margin-top:6px;
}
.cookieHint{margin:6px 0 0}

/* Links no footer */
.footerLink{
  color:rgba(234,243,255,.72);
  text-decoration:none;
}
.footerLink:hover{color:rgba(255,255,255,.92);text-decoration:underline}
.footerLinkBtn{
  appearance:none;border:0;background:transparent;
  color:rgba(234,243,255,.72);
  padding:0;margin:0;
  font:inherit;cursor:pointer;
}
.footerLinkBtn:hover{color:rgba(255,255,255,.92);text-decoration:underline}


/* ====== Hotel (HERO): factos no lado esquerdo (mais espaço e legível) ====== */
.hotelBar .dockHotel__grid{grid-template-columns:1fr !important}
.dockHotel__facts{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  margin-top:12px;
}
.dockFact{
  border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03);
  border-radius:18px;
  padding:12px 12px;
}
.dockFact__k{
  display:block;
  font-size:.72rem;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:rgba(247,242,229,.70);
}
.dockFact__v{
  display:block;
  margin-top:6px;
  font-weight:950;
  color:rgba(247,242,229,.95);
  font-size:1.02rem;
  line-height:1.2;
}
.dockHotel__note{
  margin:10px 2px 0;
  font-size:.88rem;
  line-height:1.35;
  color:rgba(247,242,229,.78);
}

/* Botões do card do hotel sempre lado a lado */
.dockHotel__actions{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:10px;
  align-items:stretch;
}
.dockHotel__actions .btn{width:100%}
