/* ============================================================
   ORLA ESTATES — orlaestates.com
   Design & code: SR Studio · 2026
   Stack: vanilla HTML/CSS/JS · sem dependências de runtime
   ============================================================ */

/* ---------- Custom properties ---------- */
:root{
  --carvao:#26231F;
  --carvao-2:#1C1A17;
  --carvao-3:#34302A;
  --creme:#F6F2EB;
  --branco:#FFFDF9;
  --linho:#E9E2D6;
  --areia:#C2AE92;
  --greige:#9A8F7F;
  --greige-2:#7E7466;

  --font-sans:"Poppins",system-ui,-apple-system,"Segoe UI",sans-serif;
  --font-serif:"Cormorant Garamond",Georgia,serif;

  --w-max:1480px;
  --gut:clamp(20px,6vw,96px);
  --sec:clamp(96px,14vh,180px);

  --fs-hero:clamp(2.6rem,7.2vw,6.8rem);
  --fs-h2:clamp(2rem,4.6vw,4.2rem);
  --fs-h3:clamp(1.5rem,3vw,2.6rem);
  --fs-lead:clamp(1.12rem,1.7vw,1.5rem);
  --fs-body:clamp(.95rem,1.05vw,1.06rem);
  --fs-meta:.78rem;

  --ease:cubic-bezier(.22,.61,.2,1);
  --ease-slow:cubic-bezier(.16,1,.3,1);
}

/* ---------- Reset ---------- */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;}
html:focus-within{scroll-behavior:smooth;}
body{
  background:var(--creme);
  color:var(--carvao);
  font-family:var(--font-sans);
  font-size:var(--fs-body);
  font-weight:300;
  line-height:1.65;
  -webkit-font-smoothing:antialiased;
  overflow-x:clip;
}
img{display:block;max-width:100%;height:auto;}
a{color:inherit;text-decoration:none;}
button{font:inherit;color:inherit;background:none;border:0;cursor:pointer;}
ul{list-style:none;}
::selection{background:var(--areia);color:var(--carvao-2);}

/* ---------- Utilities ---------- */
.wrap{max-width:var(--w-max);margin-inline:auto;padding-inline:var(--gut);}
.overline{
  font-size:var(--fs-meta);
  font-weight:400;
  letter-spacing:.32em;
  text-transform:uppercase;
  color:var(--greige);
}
.serif-it{font-family:var(--font-serif);font-style:italic;font-weight:500;}
.skip-link{
  position:fixed;top:-100px;left:16px;z-index:300;
  background:var(--carvao);color:var(--creme);
  padding:.7em 1.2em;border-radius:2px;transition:top .2s;
}
.skip-link:focus{top:16px;}

/* focus */
:focus-visible{outline:2px solid var(--areia);outline-offset:3px;}

/* ---------- Reveals ---------- */
.rv{opacity:0;transform:translateY(34px);transition:opacity .9s var(--ease-slow),transform .9s var(--ease-slow);transition-delay:var(--d,0s);}
.rv.in{opacity:1;transform:none;}
@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto;}
  .rv{opacity:1;transform:none;transition:none;}
  *,*::before,*::after{animation-duration:.001s !important;transition-duration:.001s !important;}
}

/* ---------- Loader ---------- */
.loader{
  position:fixed;inset:0;z-index:200;
  background:var(--carvao-2);
  display:grid;place-items:center;
  transition:opacity .6s var(--ease),visibility .6s;
}
.loader.done{opacity:0;visibility:hidden;}
.loader svg{width:72px;height:auto;overflow:visible;}
.loader .l-frame,.loader .l-line{stroke:var(--creme);stroke-width:12;fill:none;}
.loader .l-frame{stroke-dasharray:320;stroke-dashoffset:320;animation:draw 1.1s var(--ease) forwards;}
.loader .l-line{stroke:var(--areia);stroke-dasharray:120;stroke-dashoffset:120;animation:draw .8s .5s var(--ease) forwards;}
@keyframes draw{to{stroke-dashoffset:0;}}

/* ---------- Nav ---------- */
.nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  transition:background .45s var(--ease),box-shadow .45s var(--ease),color .45s var(--ease);
  color:var(--creme);
}
.nav-in{
  max-width:var(--w-max);margin-inline:auto;
  padding:22px var(--gut);
  display:flex;align-items:center;justify-content:space-between;gap:24px;
}
.nav.scrolled{
  background:color-mix(in srgb,var(--creme) 92%,transparent);
  backdrop-filter:blur(14px);
  -webkit-backdrop-filter:blur(14px);
  color:var(--carvao);
  box-shadow:0 1px 0 color-mix(in srgb,var(--carvao) 8%,transparent);
}
.nav.scrolled .nav-in{padding-block:14px;}
.brand{display:flex;align-items:center;gap:14px;}
.brand svg{width:26px;height:auto;}
.brand .b-mark{stroke:currentColor;stroke-width:12;fill:none;}
.brand-name{font-weight:500;font-size:1.05rem;letter-spacing:.02em;}
.brand-name span{font-weight:300;color:var(--greige);letter-spacing:.18em;font-size:.72rem;text-transform:uppercase;display:block;line-height:1.1;}
.nav-links{display:flex;gap:clamp(18px,3vw,44px);align-items:center;}
.nav-links a{
  font-size:.86rem;font-weight:400;letter-spacing:.14em;text-transform:uppercase;
  position:relative;padding-block:4px;
}
.nav-links a::after{
  content:"";position:absolute;left:0;bottom:0;height:1px;width:100%;
  background:currentColor;transform:scaleX(0);transform-origin:right;
  transition:transform .45s var(--ease);
}
.nav-links a:hover::after,.nav-links a:focus-visible::after{transform:scaleX(1);transform-origin:left;}
.lang{display:flex;gap:2px;border:1px solid color-mix(in srgb,currentColor 35%,transparent);border-radius:99px;padding:3px;}
.lang button{
  font-size:.72rem;font-weight:400;letter-spacing:.12em;
  padding:.35em .9em;border-radius:99px;opacity:.6;transition:.3s var(--ease);
}
.lang button[aria-pressed="true"]{background:currentColor;opacity:1;}
.nav .lang button[aria-pressed="true"]{color:var(--carvao-2);background:var(--creme);}
.nav.scrolled .lang button[aria-pressed="true"]{color:var(--creme);background:var(--carvao);}
.burger{display:none;}

/* mobile menu */
@media (max-width:860px){
  .nav-links{display:none;}
  .burger{
    display:grid;gap:6px;padding:8px;z-index:120;
  }
  .burger span{width:26px;height:1.6px;background:currentColor;transition:.4s var(--ease);}
  .burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7.6px) rotate(45deg);}
  .burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
  .burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7.6px) rotate(-45deg);}
  .m-menu{
    position:fixed;inset:0;z-index:110;background:var(--carvao-2);color:var(--creme);
    display:grid;place-content:center;gap:10px;text-align:center;
    opacity:0;visibility:hidden;transition:.5s var(--ease);
  }
  .m-menu.open{opacity:1;visibility:visible;}
  .m-menu a{
    font-size:clamp(1.8rem,8vw,2.6rem);font-weight:300;letter-spacing:.04em;
    padding:.35em;opacity:0;transform:translateY(20px);transition:.6s var(--ease);
  }
  .m-menu.open a{opacity:1;transform:none;}
  .m-menu.open a:nth-child(2){transition-delay:.08s;}
  .m-menu.open a:nth-child(3){transition-delay:.16s;}
  .m-menu.open a:nth-child(4){transition-delay:.24s;}
}
@media (min-width:861px){.m-menu{display:none;}}

/* ---------- Hero ---------- */
.hero{
  position:relative;min-height:100svh;
  display:flex;align-items:flex-end;
  color:var(--creme);
  background:var(--carvao-2);
  overflow:clip;
}
.hero-bg{position:absolute;inset:0;z-index:0;}
.hero-slide{position:absolute;inset:0;opacity:0;transition:opacity 1.5s var(--ease-slow);}
.hero-slide.is-active{opacity:1;}
.hero-slide img{
  width:100%;height:100%;object-fit:cover;
  transform:scale(1.08);transition:transform 8s linear;
  will-change:transform,opacity;
}
.hero-slide.is-active img{transform:scale(1);}
@media (prefers-reduced-motion:reduce){
  .hero-slide{transition:none;}
  .hero-slide img{transform:none;transition:none;}
}
.hero::after{ /* véu para legibilidade — reforçado para o slider */
  content:"";position:absolute;inset:0;z-index:1;
  background:linear-gradient(to top,rgba(28,26,23,.92) 0%,rgba(28,26,23,.6) 42%,rgba(28,26,23,.7) 100%);
}
.hero-in{position:relative;z-index:2;width:100%;padding-block:clamp(120px,16vh,180px) clamp(56px,9vh,110px);}
.hero .overline{color:var(--areia);margin-bottom:26px;}
.hero h1{
  font-size:var(--fs-hero);font-weight:300;line-height:1.04;letter-spacing:-.01em;
  max-width:30ch;
}
.hero h1 .ln{display:block;overflow:clip;}
.hero h1 .ln>span{display:block;transform:translateY(110%);animation:lnUp 1.1s var(--ease-slow) forwards;animation-delay:var(--d,.2s);}
/* Mobile: a fonte do herói escala com a largura para "A linha onde a terra" caber numa linha (não fica presa no mínimo do clamp) */
@media (max-width:600px){.hero h1{font-size:clamp(1.4rem,8.5vw,2.6rem);}}
@keyframes lnUp{to{transform:none;}}
.hero-sub{
  margin-top:30px;max-width:46ch;color:color-mix(in srgb,var(--creme) 78%,transparent);
  font-size:var(--fs-lead);font-weight:300;line-height:1.55;
}
.hero-meta{
  margin-top:54px;display:flex;flex-wrap:wrap;gap:18px 56px;
  font-size:var(--fs-meta);letter-spacing:.26em;text-transform:uppercase;color:var(--greige);
}
.scroll-cue{
  position:absolute;right:var(--gut);bottom:clamp(56px,9vh,110px);z-index:2;
  writing-mode:vertical-rl;font-size:.7rem;letter-spacing:.32em;text-transform:uppercase;
  color:color-mix(in srgb,var(--creme) 60%,transparent);
  display:flex;align-items:center;gap:14px;
}
.scroll-cue::after{
  content:"";width:1px;height:64px;background:linear-gradient(var(--areia),transparent);
  animation:cue 2.2s var(--ease) infinite;
}
@keyframes cue{0%{transform:scaleY(0);transform-origin:top;}45%{transform:scaleY(1);transform-origin:top;}55%{transform:scaleY(1);transform-origin:bottom;}100%{transform:scaleY(0);transform-origin:bottom;}}
@media (max-width:680px){.scroll-cue{display:none;}}
.hero-dots{
  position:absolute;left:var(--gut);bottom:clamp(22px,4vh,40px);z-index:3;
  display:flex;gap:10px;
}
.hero-dot{
  width:9px;height:9px;border-radius:50%;padding:0;
  background:color-mix(in srgb,var(--creme) 36%,transparent);
  transition:background .3s var(--ease),transform .3s var(--ease);
}
.hero-dot.is-on{background:var(--areia);transform:scale(1.3);}
.hero-dot:hover{background:color-mix(in srgb,var(--creme) 72%,transparent);}
@media (max-width:680px){.hero-dots{bottom:16px;}}

/* ---------- Manifesto ---------- */
.manifesto{padding-block:var(--sec);}
.manifesto .overline{margin-bottom:34px;}
.manifesto p.lead{
  font-size:clamp(1.45rem,3vw,2.5rem);font-weight:300;line-height:1.42;letter-spacing:-.005em;
  max-width:30ch;
}
.manifesto p.lead em{font-family:var(--font-serif);font-style:italic;font-weight:500;font-size:1.08em;color:var(--greige-2);}
.mani-grid{
  margin-top:clamp(56px,9vh,110px);
  display:grid;grid-template-columns:repeat(3,1fr);gap:40px;
  border-top:1px solid var(--linho);padding-top:44px;
}
.mani-grid h3{font-size:clamp(2rem,4vw,3.2rem);font-weight:300;line-height:1;}
.mani-grid h3 small{font-size:.42em;color:var(--areia);vertical-align:.85em;margin-right:.2em;font-weight:400;}
.mani-grid p{margin-top:10px;color:var(--greige-2);max-width:24ch;}
@media (max-width:760px){.mani-grid{grid-template-columns:1fr;gap:30px;}}

/* ---------- Portfolio ---------- */
.portfolio{padding-block:0 var(--sec);}
.sec-head{display:flex;align-items:baseline;justify-content:space-between;gap:24px;margin-bottom:clamp(40px,7vh,80px);}
@media (max-width:680px){.sec-head{flex-direction:column-reverse;align-items:flex-start;gap:10px;}}
.sec-head h2{font-size:var(--fs-h2);font-weight:300;letter-spacing:-.01em;}
.sec-head .overline{white-space:nowrap;}
.plist{display:grid;border-top:1px solid var(--linho);}
.prow{
  position:relative;border-bottom:1px solid var(--linho);
  display:grid;grid-template-columns:minmax(0,1.05fr) minmax(0,.95fr);
  gap:clamp(24px,4vw,64px);align-items:center;
  padding-block:clamp(28px,4.5vh,52px);
  cursor:pointer;
}
.prow:focus-visible{outline-offset:-2px;}
.prow .p-txt{display:flex;flex-direction:column;gap:14px;min-width:0;}
.prow .p-idx{
  font-size:var(--fs-meta);letter-spacing:.3em;color:var(--areia);font-weight:400;
}
.prow h3{
  font-size:var(--fs-h3);font-weight:300;line-height:1.08;letter-spacing:-.005em;
  transition:transform .6s var(--ease);
}
.prow:hover h3{transform:translateX(10px);}
.prow .p-loc{color:var(--greige-2);font-size:1rem;}
.prow .p-tags{display:flex;flex-wrap:wrap;gap:10px;margin-top:6px;}
.prow .tag{
  font-size:.7rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  border:1px solid var(--linho);border-radius:99px;padding:.45em 1em;color:var(--greige-2);
  background:var(--branco);
}
.prow .tag.ok{border-color:color-mix(in srgb,var(--areia) 60%,transparent);color:var(--carvao);background:color-mix(in srgb,var(--areia) 16%,var(--branco));}
.prow .p-media{
  position:relative;aspect-ratio:16/10;overflow:clip;border-radius:3px;
}
@property --sc{syntax:"<number>";inherits:false;initial-value:1.01;}
.prow .p-media img{
  position:absolute;left:0;top:-10%;width:100%;height:120%;object-fit:cover;
  transform:translate3d(0,var(--py,0px),0) scale(var(--sc,1.01));
  transition:--sc 1.1s var(--ease-slow);will-change:transform;
}
.prow:hover .p-media img{--sc:1.06;}
.prow .p-cta{
  position:absolute;right:0;top:50%;translate:0 -50%;
  display:none;
}
.prow.soon{cursor:default;opacity:.62;}
.prow.soon .p-media{filter:saturate(.6);}
.prow.soon:hover h3{transform:none;}
.prow.soon:hover .p-media img{--sc:1.01;}
@media (max-width:820px){
  .prow{grid-template-columns:1fr;gap:18px;}
  .prow .p-media{order:-1;}
}

/* cursor pill (pointer fino) */
.cursor-pill{
  position:fixed;z-index:90;pointer-events:none;
  background:var(--carvao);color:var(--creme);
  font-size:.72rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  padding:.85em 1.5em;border-radius:99px;
  translate:-50% -50%;scale:0;transition:scale .35s var(--ease);
  white-space:nowrap;
}
.cursor-pill.on{scale:1;}
@media (pointer:coarse){.cursor-pill{display:none;}}

/* ---------- Dialog / Residência ---------- */
dialog.pdlg{
  border:0;padding:0;max-width:100vw;max-height:100dvh;width:100vw;height:100dvh;
  background:var(--carvao-2);color:var(--creme);
}
/* Transição de entrada/saída do modal — via @keyframes (sem rAF; modal fica visível por defeito) */
@keyframes pdlgIn{from{opacity:0;}}
@keyframes pdlgUp{from{transform:translateY(18px);}}
@keyframes pdlgOut{to{opacity:0;}}
dialog.pdlg[open]{animation:pdlgIn .42s var(--ease);}
dialog.pdlg[open] .pdlg-in{animation:pdlgUp .45s var(--ease);}
dialog.pdlg.is-closing{animation:pdlgOut .34s var(--ease) forwards;}
dialog.pdlg::backdrop{background:rgba(20,18,16,.6);backdrop-filter:blur(4px);}
dialog.pdlg[open]::backdrop{animation:pdlgIn .42s var(--ease);}
dialog.pdlg.is-closing::backdrop{animation:pdlgOut .34s var(--ease) forwards;}
@media (prefers-reduced-motion:reduce){
  dialog.pdlg[open],dialog.pdlg[open] .pdlg-in,dialog.pdlg.is-closing,dialog.pdlg[open]::backdrop,dialog.pdlg.is-closing::backdrop{animation-duration:.01ms;}
}
.pdlg-in{display:grid;grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);min-height:100dvh;}
.pdlg-close{
  position:fixed;top:20px;right:max(20px,calc((100vw - var(--w-max))/2));z-index:10;
  width:52px;height:52px;border-radius:50%;
  background:color-mix(in srgb,var(--creme) 10%,transparent);
  backdrop-filter:blur(8px);
  display:grid;place-items:center;
  transition:background .3s var(--ease),rotate .5s var(--ease);
}
.pdlg-close:hover{background:color-mix(in srgb,var(--creme) 20%,transparent);rotate:90deg;}
.pdlg-close svg{width:18px;height:18px;stroke:var(--creme);stroke-width:1.6;}
.pdlg-gal{display:flex;flex-direction:column;gap:2px;}
.pdlg-gal figure{position:relative;aspect-ratio:4/3;overflow:clip;}
.pdlg-gal img{position:absolute;left:0;top:-10%;width:100%;height:120%;object-fit:cover;transform:translate3d(0,var(--py,0px),0);will-change:transform;}
.pdlg-gal figcaption{
  position:absolute;left:18px;bottom:14px;
  font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:color-mix(in srgb,var(--creme) 70%,transparent);
}
/* Switch mobilado/vazio (galeria do diálogo) */
.p-figswap .figswap{
  position:absolute;top:14px;left:14px;z-index:3;
  display:inline-flex;gap:2px;padding:3px;border-radius:999px;
  background:color-mix(in srgb,var(--carvao) 56%,transparent);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
}
.figswap-btn{
  appearance:none;border:0;cursor:pointer;font:inherit;
  font-size:.62rem;letter-spacing:.16em;text-transform:uppercase;
  color:color-mix(in srgb,var(--creme) 72%,transparent);
  background:transparent;padding:7px 14px;border-radius:999px;
  transition:background .25s,color .25s;
}
.figswap-btn:hover{color:var(--creme);}
.figswap-btn.is-on{background:var(--creme);color:var(--carvao);}
.p-figswap img{transition:opacity .2s;}
/* Botão de expand (hover) na galeria do diálogo → canto superior direito */
.pdlg-gal figure{cursor:zoom-in;}
.fig-zoom{
  position:absolute;top:14px;right:14px;z-index:4;
  width:40px;height:40px;display:grid;place-items:center;
  border:0;border-radius:50%;cursor:pointer;color:var(--creme);
  background:color-mix(in srgb,var(--carvao) 56%,transparent);
  backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);
  opacity:0;transform:translateY(-4px);
  transition:opacity .25s,transform .25s,background .25s,color .25s;
}
.pdlg-gal figure:hover .fig-zoom,.fig-zoom:focus-visible{opacity:1;transform:none;}
.fig-zoom:hover{background:var(--creme);color:var(--carvao);}
.fig-zoom svg{width:18px;height:18px;}
@media (max-width:980px){.fig-zoom{display:none;}}
/* Lightbox — imagem em ecrã inteiro */
dialog.lightbox{
  border:0;padding:0;width:100vw;height:100dvh;max-width:100vw;max-height:100dvh;
  background:rgba(18,16,14,.94);place-items:center;
}
dialog.lightbox[open]{display:grid;}
dialog.lightbox::backdrop{background:rgba(18,16,14,.6);backdrop-filter:blur(4px);}
dialog.lightbox img{max-width:92vw;max-height:88vh;object-fit:contain;border-radius:3px;}
.lb-close{
  position:fixed;top:20px;right:max(20px,calc((100vw - var(--w-max))/2));z-index:2;
  width:52px;height:52px;border-radius:50%;border:0;cursor:pointer;color:var(--creme);
  background:color-mix(in srgb,var(--creme) 12%,transparent);backdrop-filter:blur(8px);
  display:grid;place-items:center;transition:background .3s,rotate .5s;
}
.lb-close:hover{background:color-mix(in srgb,var(--creme) 22%,transparent);rotate:90deg;}
.lb-close svg{width:18px;height:18px;stroke:var(--creme);stroke-width:1.6;}
.pdlg-info{
  padding:clamp(86px,12vh,140px) clamp(28px,4.5vw,72px) 72px;
  display:flex;flex-direction:column;gap:0;
  position:sticky;top:0;align-self:start;max-height:100dvh;overflow-y:auto;
}
.pdlg-info .overline{color:var(--areia);}
.pdlg-info h2{font-size:clamp(2.2rem,4vw,3.6rem);font-weight:300;line-height:1.05;margin-top:18px;}
.pdlg-info .p-loc2{color:var(--greige);margin-top:10px;font-size:1.02rem;}
.pdlg-devlogo{margin-top:30px;max-height:66px;width:auto;max-width:210px;object-fit:contain;filter:brightness(0) invert(1);}
/* Logo com fundo opaco (ex.: Cais do Cavaco): inverte + blend "screen" → fica só as linhas brancas, sem caixa */
.pdlg-devlogo--blend{filter:invert(1);mix-blend-mode:screen;}
.pdlg-info .desc{margin-top:34px;color:color-mix(in srgb,var(--creme) 82%,transparent);max-width:54ch;}
.facts{
  margin-top:42px;display:grid;grid-template-columns:1fr 1fr;gap:0;
  border-top:1px solid var(--carvao-3);
}
.facts div{
  border-bottom:1px solid var(--carvao-3);padding:16px 4px;
}
.facts dt{font-size:.68rem;letter-spacing:.22em;text-transform:uppercase;color:var(--greige);font-weight:400;}
.facts dd{margin-top:6px;font-size:1.02rem;font-weight:300;}
.pdlg-status{
  margin-top:36px;display:flex;align-items:center;gap:14px;flex-wrap:wrap;row-gap:6px;
  font-size:.8rem;letter-spacing:.18em;text-transform:uppercase;color:var(--areia);
}
.pdlg-status::before{content:"";width:9px;height:9px;border-radius:50%;background:var(--areia);box-shadow:0 0 0 4px color-mix(in srgb,var(--areia) 22%,transparent);}
.pdlg-cta{
  margin-top:44px;display:inline-flex;align-items:center;gap:16px;align-self:flex-start;
  background:var(--creme);color:var(--carvao-2);
  font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  padding:1.2em 2.2em;border-radius:99px;
  transition:gap .35s var(--ease),background .35s var(--ease);
}
.pdlg-cta:hover{gap:26px;background:var(--areia);}
.pdlg-note{margin-top:26px;font-size:.8rem;color:var(--greige);max-width:46ch;}
@media (max-width:980px){
  .pdlg-in{grid-template-columns:1fr;}
  .pdlg-info{position:static;max-height:none;padding-top:30px;}
  .pdlg-gal{flex-direction:row;overflow-x:auto;scroll-snap-type:x mandatory;}
  .pdlg-gal figure{flex:0 0 86%;scroll-snap-align:center;aspect-ratio:1/1;}
  /* switch à esquerda, alinhado horizontalmente com o X (centro do X = 20px + 52/2 = 46px) */
  .p-figswap .figswap{left:20px;right:auto;top:46px;transform:translateY(-50%);}
}

/* ---------- Localizações ---------- */
.locais{background:var(--carvao);color:var(--creme);padding-block:var(--sec);}
.locais .sec-head h2{color:var(--creme);}
.loc-grid{display:grid;grid-template-columns:1fr 1fr;gap:2px;background:var(--carvao-3);}
.loc-card{
  background:var(--carvao);padding:clamp(34px,5vw,64px);
  display:flex;flex-direction:column;gap:16px;min-height:300px;justify-content:flex-end;
  position:relative;overflow:clip;
}
.loc-card::before{
  content:"";position:absolute;inset:0;
  background-position:center;background-size:cover;
  opacity:.28;transition:opacity .6s var(--ease),transform 1.2s var(--ease-slow);
}
.loc-card.l-norte::before{background-image:url("../assets/img/foz-02.jpg");}
.loc-card.l-sul::before{background-image:url("../assets/img/lumare-03.webp");}
.loc-card:hover::before{opacity:.4;transform:scale(1.04);}
.loc-card>*{position:relative;}
.loc-card h3{font-size:var(--fs-h3);font-weight:300;}
.loc-card p{color:color-mix(in srgb,var(--creme) 72%,transparent);max-width:44ch;}
.loc-card .overline{color:var(--areia);}
@media (max-width:760px){.loc-grid{grid-template-columns:1fr;}}

/* ---------- Contacto ---------- */
.contacto{padding-block:var(--sec);}
.c-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:clamp(40px,6vw,100px);}
.c-left h2{font-size:var(--fs-h2);font-weight:300;line-height:1.12;max-width:14ch;letter-spacing:-.01em;}
.c-left .serif-it{color:var(--greige-2);}
.c-left p.sub{margin-top:24px;color:var(--greige-2);max-width:40ch;}
.c-direct{margin-top:54px;display:grid;gap:22px;}
.c-direct a{display:block;font-size:clamp(1.1rem,2vw,1.5rem);font-weight:300;position:relative;width:fit-content;}
.c-direct a::after{content:"";position:absolute;left:0;bottom:-3px;width:100%;height:1px;background:var(--areia);transform:scaleX(.3);transform-origin:left;transition:transform .45s var(--ease);}
.c-direct a:hover::after{transform:scaleX(1);}
.c-direct .overline{margin-bottom:6px;}
form.cform{display:grid;gap:0;}
.fld{position:relative;border-bottom:1px solid var(--linho);padding:26px 0 14px;}
.fld label{
  position:absolute;left:0;top:32px;color:var(--greige);transition:.3s var(--ease);
  pointer-events:none;font-size:1rem;
}
.fld :is(input,textarea,select){
  width:100%;border:0;background:none;font:inherit;color:var(--carvao);
  padding:6px 0 2px;outline:none;resize:vertical;
}
.fld select{appearance:none;cursor:pointer;}
.fld.has-val label,.fld:focus-within label,.fld:has(select) label{top:6px;font-size:.68rem;letter-spacing:.18em;text-transform:uppercase;color:var(--areia);}
.fld::after{content:"";position:absolute;left:0;bottom:-1px;width:100%;height:1px;background:var(--carvao);transform:scaleX(0);transform-origin:left;transition:transform .5s var(--ease);}
.fld:focus-within::after{transform:scaleX(1);}
.gdpr{display:flex;gap:12px;align-items:flex-start;margin-top:26px;font-size:.85rem;color:var(--greige-2);}
.gdpr input{accent-color:var(--carvao);margin-top:4px;width:16px;height:16px;flex:none;}
.cform .send{
  margin-top:36px;justify-self:start;
  display:inline-flex;align-items:center;gap:16px;
  background:var(--carvao);color:var(--creme);
  font-size:.82rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  padding:1.25em 2.4em;border-radius:99px;
  transition:gap .35s var(--ease),background .35s var(--ease);
}
.cform .send:hover{gap:26px;background:var(--carvao-3);}
.form-ok{
  margin-top:20px;font-size:.9rem;color:var(--carvao);background:color-mix(in srgb,var(--areia) 22%,var(--branco));
  border:1px solid color-mix(in srgb,var(--areia) 50%,transparent);
  padding:14px 18px;border-radius:3px;display:none;
}
.form-ok.show{display:block;}
@media (max-width:880px){.c-grid{grid-template-columns:1fr;}}

/* ---------- Footer ---------- */
footer{background:var(--carvao-2);color:var(--creme);padding:clamp(56px,9vh,96px) 0 34px;}
.f-grid{display:flex;flex-wrap:wrap;gap:40px;justify-content:space-between;align-items:flex-end;}
.f-logo{width:min(300px,60vw);height:auto;}
.f-meta{display:flex;flex-direction:column;gap:8px;font-size:.85rem;color:var(--greige);}
.f-meta a:hover{color:var(--creme);}
.f-base{
  margin-top:54px;padding-top:22px;border-top:1px solid var(--carvao-3);
  display:flex;flex-wrap:wrap;gap:14px 36px;justify-content:space-between;
  font-size:.74rem;letter-spacing:.06em;color:var(--greige);
}
.f-base nav{display:flex;gap:26px;}
.f-base a:hover{color:var(--creme);}

/* ---------- Toast/loading bar small helpers ---------- */
.sr-only{
  position:absolute;width:1px;height:1px;margin:-1px;
  clip-path:inset(50%);overflow:hidden;white-space:nowrap;
}

/* ---------- Honeypot (anti-spam) ---------- */
.hp{position:absolute !important;left:-9999px !important;width:1px;height:1px;overflow:hidden;}

/* ---------- Form: estado de erro ---------- */
.form-ok.err{
  background:color-mix(in srgb,#a8442f 12%,var(--branco));
  border-color:color-mix(in srgb,#a8442f 42%,transparent);
  color:#7c3a2a;
}

/* ---------- Cookie consent ---------- */
.cc{
  position:fixed;left:0;right:0;bottom:0;z-index:160;
  background:var(--carvao-2);color:var(--creme);
  border-top:1px solid var(--carvao-3);
  padding:clamp(18px,2.4vw,26px) var(--gut);
  transform:translateY(112%);transition:transform .55s var(--ease-slow);
  box-shadow:0 -18px 50px rgba(20,18,16,.42);
}
.cc.in{transform:none;}
.cc-in{
  max-width:var(--w-max);margin-inline:auto;
  display:flex;align-items:center;gap:clamp(18px,4vw,56px);flex-wrap:wrap;
}
.cc-copy{flex:1 1 360px;min-width:0;}
.cc-title{font-weight:500;font-size:.96rem;margin-bottom:5px;}
.cc-copy p:not(.cc-title){font-size:.85rem;line-height:1.6;color:color-mix(in srgb,var(--creme) 78%,transparent);max-width:66ch;}
.cc-copy a{color:var(--areia);text-decoration:underline;text-underline-offset:3px;}
.cc-actions{display:flex;gap:10px;flex-wrap:wrap;align-items:center;}
.cc-btn{
  font-size:.73rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  padding:.95em 1.7em;border-radius:99px;transition:background .3s var(--ease),color .3s var(--ease);white-space:nowrap;
}
.cc-solid{background:var(--creme);color:var(--carvao-2);}
.cc-solid:hover{background:var(--areia);}
.cc-ghost{border:1px solid color-mix(in srgb,var(--creme) 30%,transparent);color:var(--creme);}
.cc-ghost:hover{background:color-mix(in srgb,var(--creme) 10%,transparent);}
.cc-prefs{
  max-width:var(--w-max);margin:16px auto 0;
  border-top:1px solid var(--carvao-3);padding-top:14px;
}
.cc-row{
  display:flex;align-items:flex-start;justify-content:space-between;gap:24px;
  padding:12px 0;border-bottom:1px solid color-mix(in srgb,var(--carvao-3) 60%,transparent);
}
.cc-row>span{font-size:.84rem;line-height:1.5;}
.cc-row strong{font-weight:500;}
.cc-row span span{color:var(--greige);}
.cc-row input{width:18px;height:18px;accent-color:var(--areia);flex:none;margin-top:3px;}
.cc-prefs-actions{margin-top:14px;}
@media (max-width:680px){
  .cc-actions{width:100%;}
  .cc-actions .cc-btn{flex:1 1 auto;text-align:center;}
}
@media (prefers-reduced-motion:reduce){.cc{transition:none;}}

/* ---------- Páginas legais (Privacidade / Cookies / Termos) ---------- */
body.legal{background:var(--creme);}
/* nav sempre em modo sólido sobre fundo claro */
body.legal .nav{
  color:var(--carvao);
  background:color-mix(in srgb,var(--creme) 92%,transparent);
  backdrop-filter:blur(14px);-webkit-backdrop-filter:blur(14px);
  box-shadow:0 1px 0 color-mix(in srgb,var(--carvao) 8%,transparent);
}
body.legal .nav .lang button[aria-pressed="true"]{color:var(--creme);background:var(--carvao);}

.legal{padding-block:clamp(116px,16vh,180px) var(--sec);}
.legal-head{margin-bottom:clamp(34px,6vh,64px);}
.legal-head h1{font-size:var(--fs-h2);font-weight:300;letter-spacing:-.01em;max-width:20ch;}
.legal-head .updated{margin-top:14px;color:var(--greige);font-size:.85rem;}
.legal-toc{margin-top:26px;display:flex;flex-wrap:wrap;gap:10px 20px;font-size:.8rem;letter-spacing:.04em;}
.legal-toc a{color:var(--greige-2);border-bottom:1px solid transparent;padding-bottom:2px;}
.legal-toc a:hover,.legal-toc a:focus-visible{color:var(--carvao);border-color:var(--areia);}
.legal-body{max-width:76ch;}
.legal-body section{padding-top:clamp(38px,6vh,60px);scroll-margin-top:100px;}
.legal-body h2{font-size:clamp(1.3rem,2.4vw,1.95rem);font-weight:400;letter-spacing:-.005em;margin-bottom:16px;}
.legal-body h2 small{color:var(--areia);font-size:.6em;font-weight:400;margin-right:.55em;letter-spacing:.1em;}
.legal-body h3{font-size:1.04rem;font-weight:500;color:var(--carvao);margin:24px 0 8px;}
.legal-body p,.legal-body li{color:var(--greige-2);line-height:1.75;font-size:1rem;}
.legal-body p+p{margin-top:14px;}
.legal-body ul{margin:14px 0 0;display:grid;gap:10px;}
.legal-body li{position:relative;padding-left:24px;}
.legal-body li::before{content:"—";position:absolute;left:0;color:var(--areia);}
.legal-body a{color:var(--carvao);border-bottom:1px solid var(--areia);}
.legal-body a:hover{color:var(--greige-2);}
.legal-body strong{color:var(--carvao);font-weight:500;}
.legal-body .muted{color:var(--greige);font-size:.9em;}
.legal-table{width:100%;border-collapse:collapse;margin-top:14px;font-size:.92rem;}
.legal-table th,.legal-table td{text-align:left;padding:11px 14px;border-bottom:1px solid var(--linho);vertical-align:top;color:var(--greige-2);}
.legal-table th{color:var(--carvao);font-weight:500;}
.legal-cta{margin-top:30px;}

/* ---------- Dialog: barra fixa de ações ---------- */
.pdlg-info{padding-bottom:clamp(104px,14vh,140px);}  /* espaço para a barra fixa */
.pdlg-bar{
  position:fixed;left:0;right:0;bottom:0;z-index:20;
  display:flex;gap:12px;align-items:center;justify-content:flex-end;
  padding:14px clamp(20px,4.5vw,72px);
  background:color-mix(in srgb,var(--carvao-2) 88%,transparent);
  backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);
  border-top:1px solid var(--carvao-3);
}
.pdlg-bbtn{
  display:inline-flex;align-items:center;gap:12px;
  font-size:.76rem;letter-spacing:.18em;text-transform:uppercase;font-weight:400;
  padding:1.05em 1.9em;border-radius:99px;white-space:nowrap;
  transition:gap .3s var(--ease),background .3s var(--ease);
}
.pdlg-bbtn.solid{background:var(--creme);color:var(--carvao-2);}
.pdlg-bbtn.solid:hover{background:var(--areia);gap:18px;}
.pdlg-bbtn.ghost{border:1px solid color-mix(in srgb,var(--creme) 32%,transparent);color:var(--creme);}
.pdlg-bbtn.ghost:hover{background:color-mix(in srgb,var(--creme) 10%,transparent);}
@media (max-width:560px){
  .pdlg-bar{gap:8px;padding:12px 16px;}
  .pdlg-bbtn{flex:1 1 0;justify-content:center;padding:1.05em .6em;font-size:.7rem;letter-spacing:.1em;}
}

/* ---------- Blueprint modal (email gate) ---------- */
.bp{
  border:0;padding:0;border-radius:6px;margin:auto;
  width:min(440px,92vw);max-width:92vw;
  background:var(--carvao-2);color:var(--creme);
  overflow:visible;
}
.bp::backdrop{background:rgba(20,18,16,.7);backdrop-filter:blur(4px);}
.bp-close{
  position:absolute;top:12px;right:12px;width:40px;height:40px;border-radius:50%;
  display:grid;place-items:center;background:color-mix(in srgb,var(--creme) 10%,transparent);
  transition:background .3s var(--ease);
}
.bp-close:hover{background:color-mix(in srgb,var(--creme) 20%,transparent);}
.bp-close svg{width:16px;height:16px;stroke:var(--creme);stroke-width:1.6;}
.bp-form{padding:clamp(30px,5vw,44px);display:flex;flex-direction:column;}
.bp-form .overline{color:var(--areia);}
.bp-form h3{font-size:clamp(1.25rem,3vw,1.65rem);font-weight:300;margin-top:10px;line-height:1.18;}
.bp-sub{margin-top:12px;color:color-mix(in srgb,var(--creme) 74%,transparent);font-size:.9rem;line-height:1.55;}
.bp-sub .bp-house{color:var(--areia);}
.bp .fld{border-bottom-color:color-mix(in srgb,var(--creme) 22%,transparent);}
.bp .fld label{color:color-mix(in srgb,var(--creme) 58%,transparent);}
.bp .fld :is(input,textarea){color:var(--creme);}
.bp .fld.has-val label,.bp .fld:focus-within label{color:var(--areia);}
.bp .fld::after{background:var(--areia);}
.bp .gdpr{color:color-mix(in srgb,var(--creme) 70%,transparent);}
.bp .gdpr a{color:var(--areia);}
.bp .gdpr input{accent-color:var(--areia);}
.bp .send{
  margin-top:26px;align-self:flex-start;display:inline-flex;align-items:center;gap:16px;
  background:var(--creme);color:var(--carvao-2);
  font-size:.8rem;letter-spacing:.2em;text-transform:uppercase;font-weight:400;
  padding:1.1em 2em;border-radius:99px;transition:gap .35s var(--ease),background .35s var(--ease);
}
.bp .send:hover{gap:24px;background:var(--areia);}
.bp .send[disabled]{opacity:.55;cursor:default;}
.bp-ok{margin-top:16px;font-size:.88rem;color:var(--areia);display:none;}
.bp-ok.show{display:block;}
.bp-ok.err{color:#e8a48f;}
.bp-download{
  margin-top:16px;display:none;align-items:center;gap:10px;align-self:flex-start;
  background:var(--areia);color:var(--carvao-2);
  font-size:.78rem;letter-spacing:.16em;text-transform:uppercase;font-weight:400;
  padding:1em 1.7em;border-radius:99px;transition:gap .3s var(--ease);
}
.bp-download:hover{gap:16px;}
.bp-download.show{display:inline-flex;}

/* ============ Mapas (Leaflet · click-to-load p/ RGPD) ============ */
.orla-map{position:relative;aspect-ratio:16/10;border-radius:4px;overflow:hidden;background:color-mix(in srgb,var(--creme) 80%,var(--areia));}
.orla-map.in-dlg{margin-top:34px;}
.orla-map .map-canvas{position:absolute;inset:0;width:100%;height:100%;}
.orla-map .map-cover{position:absolute;inset:0;z-index:5;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px;text-align:center;padding:24px;background:color-mix(in srgb,var(--creme) 90%,var(--areia));}
.orla-map.is-on .map-cover{display:none;}
.map-cover .map-h{font-size:.7rem;letter-spacing:.24em;text-transform:uppercase;color:var(--greige);}
.map-load{appearance:none;border:1px solid color-mix(in srgb,var(--carvao) 40%,transparent);background:transparent;color:var(--carvao);cursor:pointer;font:inherit;font-size:.74rem;letter-spacing:.16em;text-transform:uppercase;padding:.85em 1.5em;border-radius:99px;transition:background .25s,color .25s,border-color .25s;}
.map-load:hover{background:var(--carvao);color:var(--creme);border-color:var(--carvao);}
.map-cover .map-note{font-size:.68rem;line-height:1.5;color:var(--greige);max-width:34ch;}
/* dentro do diálogo (fundo escuro) → cover escuro, texto claro */
.pdlg .orla-map .map-cover{background:color-mix(in srgb,var(--carvao-2) 86%,#000);}
.pdlg .map-cover .map-h,.pdlg .map-cover .map-note{color:color-mix(in srgb,var(--creme) 62%,transparent);}
.pdlg .map-load{border-color:color-mix(in srgb,var(--creme) 35%,transparent);color:var(--creme);}
.pdlg .map-load:hover{background:var(--creme);color:var(--carvao);}
/* aquecer os tiles (CARTO Positron) para o tom da marca */
.orla-map .leaflet-tile{filter:sepia(.42) saturate(.62) brightness(1.05) hue-rotate(-6deg) contrast(.96);}
.orla-map .leaflet-container{background:color-mix(in srgb,var(--creme) 80%,var(--areia));font-family:inherit;}
/* pin + etiqueta */
.orla-pin-dot{display:block;width:13px;height:13px;border-radius:50%;background:var(--carvao);border:2px solid var(--creme);box-shadow:0 1px 4px rgba(0,0,0,.3);}
.leaflet-tooltip.orla-tt{background:color-mix(in srgb,var(--creme) 92%,transparent);border:0;border-radius:99px;box-shadow:0 1px 4px rgba(0,0,0,.18);color:var(--carvao);font-size:.7rem;letter-spacing:.04em;font-weight:500;padding:3px 9px;}
.leaflet-tooltip.orla-tt::before{display:none;}
/* controlos minimalistas */
.orla-map .leaflet-control-attribution{background:color-mix(in srgb,var(--creme) 75%,transparent);color:var(--greige);font-size:9px;}
.orla-map .leaflet-control-attribution a{color:var(--carvao);}
.orla-map .leaflet-bar a{background:var(--creme);color:var(--carvao);border-color:color-mix(in srgb,var(--carvao) 18%,transparent);}
.orla-map .leaflet-bar a:hover{background:var(--areia);}
/* secção Localização (norte/sul) */
.locais-map{padding-block:var(--sec);}
.maps-2col{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-top:42px;}
.maps-2col h3{font-size:.78rem;letter-spacing:.2em;text-transform:uppercase;color:var(--greige);margin-bottom:14px;font-weight:500;}
.maps-2col .orla-map{aspect-ratio:4/3;}
@media (max-width:820px){.maps-2col{grid-template-columns:1fr;gap:34px;}}

/* ----- Mapas: tema ESCURO (todos os mapas estão sobre fundo escuro) ----- */
.orla-map{background:var(--carvao-2);}
.orla-map .map-cover{background:color-mix(in srgb,var(--carvao-2) 90%,#000);}
.map-cover .map-h,.map-cover .map-note{color:color-mix(in srgb,var(--creme) 60%,transparent);}
.map-load{border-color:color-mix(in srgb,var(--creme) 34%,transparent);color:var(--creme);}
.map-load:hover{background:var(--creme);color:var(--carvao);border-color:var(--creme);}
.orla-map .leaflet-container{background:var(--carvao-2);}
.orla-map .leaflet-tile{filter:sepia(.5) hue-rotate(-12deg) saturate(.7) brightness(.92) contrast(1.06);}
.orla-pin-dot{background:var(--creme);border:2px solid var(--carvao-2);box-shadow:0 0 0 4px color-mix(in srgb,var(--creme) 16%,transparent),0 1px 3px rgba(0,0,0,.55);}
.leaflet-tooltip.orla-tt{background:color-mix(in srgb,var(--creme) 90%,transparent);color:var(--carvao);}
.orla-map .leaflet-control-attribution{background:color-mix(in srgb,var(--carvao-2) 72%,transparent);color:color-mix(in srgb,var(--creme) 50%,transparent);}
.orla-map .leaflet-control-attribution a{color:color-mix(in srgb,var(--creme) 75%,transparent);}
.orla-map .leaflet-bar a{background:var(--carvao);color:var(--creme);border-color:color-mix(in srgb,var(--creme) 16%,transparent);}
.orla-map .leaflet-bar a:hover{background:var(--carvao-3);}
/* loc-col: cartão + mapa empilhados na secção escura */
.loc-col{display:flex;flex-direction:column;gap:2px;}
.loc-col .orla-map{border-radius:0;aspect-ratio:16/11;}
@media (max-width:760px){.loc-col .orla-map{aspect-ratio:16/10;}}
/* mapa dentro do diálogo: .pdlg-info é flex-column c/ scroll → o aspect-ratio colapsava a 0; fixamos altura */
.orla-map.in-dlg{flex:0 0 auto;aspect-ratio:auto;height:clamp(220px,32vh,330px);}
/* botão "abrir mapa" no cartão de localização + mapa que desliza para fora */
.loc-mapbtn{margin-top:22px;display:inline-flex;align-items:center;gap:10px;
  border:1px solid color-mix(in srgb,var(--creme) 36%,transparent);color:var(--creme);background:transparent;
  font:inherit;font-size:.72rem;letter-spacing:.16em;text-transform:uppercase;padding:.7em 1.3em;border-radius:99px;cursor:pointer;
  transition:background .25s,color .25s,border-color .25s;}
.loc-mapbtn:hover{background:var(--creme);color:var(--carvao);border-color:var(--creme);}
.loc-mapbtn-ico{transition:transform .4s var(--ease);}
.loc-mapbtn.is-on{background:color-mix(in srgb,var(--creme) 12%,transparent);}
.loc-mapbtn.is-on .loc-mapbtn-ico{transform:rotate(180deg);}
.loc-col .orla-map{aspect-ratio:auto;height:0;overflow:hidden;transition:height .55s var(--ease);will-change:height;}
.loc-col .orla-map.is-open{height:clamp(240px,30vw,360px);}
