:root{
  --bg:#07111f;
  --bg-2:#0b1d35;
  --surface:#0f243f;
  --surface-2:#132b4b;
  --surface-soft:rgba(255,255,255,.055);
  --ink:#fbf7ef;
  --muted:#d7dfeb;
  --muted-2:#aebbd0;
  --gold:#d4b47c;
  --gold-2:#f1ddb9;
  --navy:#07111f;
  --line:rgba(241,221,185,.16);
  --line-strong:rgba(241,221,185,.28);
  --shadow:0 28px 70px rgba(0,0,0,.28);
  --shadow-soft:0 16px 44px rgba(0,0,0,.20);
  --radius-lg:28px;
  --radius-md:20px;
  --radius-sm:14px;
  --max:1180px;
  --gutter:clamp(18px,4vw,40px);
  --anchor-offset:118px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;text-size-adjust:100%;scroll-padding-top:var(--anchor-offset)}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 8% 0%,rgba(40,82,142,.42),transparent 34rem),
    radial-gradient(circle at 88% 8%,rgba(212,180,124,.13),transparent 28rem),
    linear-gradient(180deg,var(--bg) 0%,#0a1a30 48%,var(--bg-2) 100%);
  font-size:16px;
  line-height:1.55;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background-image:linear-gradient(rgba(255,255,255,.025) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.025) 1px,transparent 1px);
  background-size:42px 42px;
  mask-image:linear-gradient(to bottom,rgba(0,0,0,.8),transparent 70%);
}
img{display:block;max-width:100%;height:auto}
:where(main,section,article,div,h2,h3,h4)[id]{scroll-margin-top:var(--anchor-offset)}
a{color:inherit;text-decoration:none}
button,input{font:inherit}
:focus-visible{outline:3px solid var(--gold-2);outline-offset:4px}
::selection{background:rgba(212,180,124,.32);color:#fff}
.wrap{width:min(var(--max),calc(100% - 2 * var(--gutter)));margin-inline:auto}
.skip-link{
  position:absolute;left:16px;top:10px;z-index:1000;
  transform:translateY(-150%);
  padding:10px 14px;border-radius:999px;
  background:var(--gold-2);color:var(--navy);font-weight:800;
}
.skip-link:focus{transform:translateY(0)}
.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}

.header{
  position:sticky;top:0;z-index:50;
  background:rgba(7,17,31,.82);
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px) saturate(140%);
}
.header-inner{
  min-height:92px;
  display:grid;
  grid-template-columns:auto 1fr auto;
  align-items:center;
  gap:22px;
}
.brand{
  display:inline-flex;align-items:center;
  border-radius:16px;
}
.brand img{width:230px;height:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,.18))}
.nav{
  justify-self:center;
  display:flex;align-items:center;gap:8px;
  color:rgba(251,247,239,.78);
  font-size:.95rem;
}
.nav a,.lang a{
  min-height:42px;
  display:inline-flex;align-items:center;justify-content:center;
  border-radius:999px;
  transition:background .18s ease,color .18s ease,transform .18s ease,border-color .18s ease;
}
.nav a{padding:9px 13px;white-space:nowrap}
.nav a:hover{color:var(--gold-2);background:rgba(255,255,255,.055)}
.lang{display:flex;gap:8px;align-items:center}
.lang a{
  min-width:42px;
  padding:9px 12px;
  border:1px solid rgba(241,221,185,.16);
  background:rgba(255,255,255,.045);
  color:var(--ink);
  font-weight:800;
  font-size:.9rem;
}
.lang a.active,.lang a[aria-current="true"]{
  color:var(--navy);
  border-color:#e1c798;
  background:linear-gradient(180deg,#f0dfbf 0%,#d3b276 100%);
}

.hero{padding:clamp(36px,6vw,84px) 0 clamp(26px,5vw,64px)}
.hero-layout{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(420px,.88fr);
  gap:clamp(22px,4vw,46px);
  align-items:center;
}
.hero-copy{
  padding:clamp(28px,5vw,56px);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 0 0,rgba(212,180,124,.14),transparent 24rem),
    linear-gradient(180deg,rgba(19,43,75,.90),rgba(10,28,52,.92));
  box-shadow:var(--shadow);
}
.eyebrow,.badge{
  width:max-content;
  max-width:100%;
  margin:0 0 16px;
  padding:8px 12px;
  border:1px solid rgba(241,221,185,.18);
  border-radius:999px;
  background:rgba(212,180,124,.13);
  color:var(--gold-2);
  font-weight:850;
  letter-spacing:.02em;
  font-size:.88rem;
}
.hero h1{
  max-width:11.5ch;
  margin:0;
  font-size:clamp(2.7rem,7.2vw,6rem);
  line-height:.92;
  letter-spacing:-.062em;
  text-wrap:balance;
}
.hero-lede{
  max-width:62ch;
  margin:22px 0 0;
  color:var(--muted);
  font-size:clamp(1.02rem,1.4vw,1.17rem);
}
.hero-actions{
  display:flex;flex-wrap:wrap;gap:12px;
  margin-top:28px;
}
.hero-actions.centered{justify-content:center}
.btn{
  min-height:50px;
  display:inline-flex;align-items:center;justify-content:center;
  padding:13px 20px;
  border-radius:999px;
  border:1px solid transparent;
  font-weight:850;
  line-height:1;
  transition:transform .18s ease,box-shadow .18s ease,background .18s ease,border-color .18s ease;
}
.btn:hover{transform:translateY(-1px)}
.btn-primary{
  color:var(--navy);
  background:linear-gradient(180deg,#f2dfbd 0%,#d2b06f 100%);
  box-shadow:0 16px 34px rgba(0,0,0,.22),inset 0 1px 0 rgba(255,255,255,.44);
}
.btn-secondary{
  color:var(--ink);
  border-color:rgba(241,221,185,.18);
  background:rgba(255,255,255,.055);
}
.btn-secondary:hover{background:rgba(255,255,255,.09);border-color:rgba(241,221,185,.3)}
.hero-points{
  display:flex;flex-wrap:wrap;gap:10px;
  margin:28px 0 0;
  padding:0;list-style:none;
}
.hero-points li{
  padding:9px 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.11);
  color:var(--muted);
  background:rgba(255,255,255,.045);
  font-weight:700;
  font-size:.92rem;
}
.hero-media{
  position:relative;
  border-radius:var(--radius-lg);
  overflow:hidden;
  min-height:clamp(460px,62vw,660px);
  border:1px solid var(--line);
  box-shadow:var(--shadow);
  isolation:isolate;
}
.hero-media::after{
  content:"";
  position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(7,17,31,.04),rgba(7,17,31,.26));
  pointer-events:none;
}
.hero-image{
  width:100%;height:100%;
  min-height:inherit;
  object-fit:cover;
  object-position:center;
}

.section{padding:clamp(34px,6vw,76px) 0}
.section + .section{padding-top:clamp(26px,4.5vw,58px)}
.section-head{
  display:grid;
  grid-template-columns:minmax(0,.82fr) minmax(280px,.72fr);
  gap:clamp(18px,4vw,52px);
  align-items:end;
  margin-bottom:clamp(22px,3.5vw,38px);
}
.section-head h2{
  margin:0;
  font-size:clamp(2rem,4vw,4.05rem);
  line-height:.98;
  letter-spacing:-.052em;
  text-wrap:balance;
}
.section-head p{
  margin:0;
  color:var(--muted);
  max-width:66ch;
}
.stats{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:14px;
  margin:0;
  padding:0;
  list-style:none;
}
.stats li,.proposal-card,.content-card,.location-copy,.final-box{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(19,43,75,.82),rgba(12,30,56,.88));
  box-shadow:var(--shadow-soft);
  border-radius:var(--radius-md);
}
.stats li{
  padding:22px;
  text-align:center;
}
.stats strong{
  display:block;
  font-size:clamp(1.05rem,1.7vw,1.42rem);
  letter-spacing:-.025em;
}

.apartment-stack{display:grid;gap:clamp(22px,3vw,34px)}
.apartment-card{
  display:grid;
  grid-template-columns:minmax(330px,.72fr) minmax(0,1fr);
  gap:18px;
  align-items:stretch;
}
.apartment-card:nth-child(even){grid-template-columns:minmax(0,1fr) minmax(330px,.72fr)}
.apartment-card:nth-child(even) .apartment-copy{order:2}
.apartment-card:nth-child(even) .gallery{order:1}
.apartment-copy{
  padding:clamp(24px,3.5vw,40px);
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:
    radial-gradient(circle at 0 0,rgba(212,180,124,.10),transparent 18rem),
    linear-gradient(180deg,rgba(20,45,79,.9),rgba(11,29,54,.92));
  box-shadow:var(--shadow-soft);
}
.apartment-copy h3{
  margin:0 0 12px;
  font-size:clamp(1.7rem,2.8vw,2.55rem);
  line-height:1.04;
  letter-spacing:-.045em;
  text-wrap:balance;
}
.apartment-copy p:not(.badge){margin:0;color:var(--muted)}
.apartment-meta{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:8px;
  margin:22px 0 0;
}
.apartment-meta div{
  padding:12px;
  border:1px solid rgba(241,221,185,.12);
  border-radius:16px;
  background:rgba(255,255,255,.045);
}
.apartment-meta dt{
  margin:0 0 2px;
  color:var(--muted-2);
  font-size:.78rem;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.apartment-meta dd{
  margin:0;
  color:var(--ink);
  font-weight:800;
  line-height:1.25;
}
.feature-list,.cond-list{
  display:grid;
  gap:10px;
  margin:20px 0 0;
  padding:0;
  list-style:none;
}
.feature-list li,.cond-list li{
  position:relative;
  padding:13px 15px 13px 38px;
  border:1px solid rgba(241,221,185,.11);
  border-radius:16px;
  background:rgba(255,255,255,.045);
  color:var(--muted);
}
.feature-list li::before,.cond-list li::before{
  content:"";
  position:absolute;left:16px;top:1.15em;
  width:8px;height:8px;border-radius:999px;
  background:var(--gold);
  box-shadow:0 0 0 4px rgba(212,180,124,.12);
}
.gallery{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(19,43,75,.80),rgba(11,29,54,.88));
  box-shadow:var(--shadow-soft);
}
.gallery-item{
  position:relative;
  display:block;
  min-height:176px;
  overflow:hidden;
  border-radius:18px;
  background:#101c31;
}
.gallery-item:first-child{
  grid-row:span 2;
  min-height:362px;
}
.gallery-item img{
  width:100%;height:100%;object-fit:cover;
  transition:transform .28s ease,filter .28s ease;
}
.gallery-item::after{
  content:"Ampliar";
  position:absolute;right:10px;bottom:10px;
  padding:7px 10px;
  border-radius:999px;
  color:var(--navy);
  background:rgba(242,223,189,.95);
  font-size:.78rem;
  font-weight:850;
  opacity:0;
  transform:translateY(4px);
  transition:opacity .18s ease,transform .18s ease;
}
html[lang^="en"] .gallery-item::after{content:"View"}
html[lang^="zh"] .gallery-item::after{content:"查看"}
.gallery-item:hover img,.gallery-item:focus-visible img{transform:scale(1.035);filter:brightness(1.02)}
.gallery-item:hover::after,.gallery-item:focus-visible::after{opacity:1;transform:translateY(0)}

.proposal-grid{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.proposal-card{padding:24px}
.proposal-card span{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:40px;height:40px;
  margin-bottom:28px;
  border-radius:999px;
  background:rgba(212,180,124,.14);
  color:var(--gold-2);
  border:1px solid rgba(241,221,185,.18);
  font-weight:850;
}
.proposal-card h3{
  margin:0 0 8px;
  font-size:1.16rem;
  letter-spacing:-.025em;
}
.proposal-card p{margin:0;color:var(--muted)}

.split-grid,.location-grid{
  display:grid;
  grid-template-columns:minmax(330px,.72fr) minmax(0,1fr);
  gap:18px;
  align-items:stretch;
}
.content-card,.location-copy{padding:clamp(24px,3.5vw,38px)}
.cond-list{margin:0}
.image-pair{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:12px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(19,43,75,.80),rgba(11,29,54,.88));
  box-shadow:var(--shadow-soft);
}
.image-pair img{
  width:100%;height:100%;min-height:360px;
  object-fit:cover;
  border-radius:20px;
}
.location-photo-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:12px;
  padding:12px;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(19,43,75,.80),rgba(11,29,54,.88));
  box-shadow:var(--shadow-soft);
}
.location-photo-grid img{
  width:100%;height:100%;min-height:360px;
  object-fit:cover;
  object-position:center center;
  border-radius:20px;
}
.location-photo-grid img:first-child{object-position:center center}
.location-copy{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  justify-content:center;
  gap:20px;
}
.location-copy img{width:181px;height:auto}
.location-copy p{margin:0;color:var(--muted)}




#mapa-zona{scroll-margin-top:var(--anchor-offset)}

/* Interactive OpenStreetMap POI block */
.map-card{
  margin-top:clamp(22px,4vw,42px);
  overflow:hidden;
  border:1px solid var(--line);
  border-radius:var(--radius-lg);
  background:linear-gradient(180deg,rgba(19,43,75,.86),rgba(11,29,54,.92));
  box-shadow:var(--shadow-soft);
}
.map-copy{
  padding:clamp(24px,3.6vw,42px) clamp(22px,3.6vw,42px) clamp(18px,2.2vw,26px);
}
.map-copy h3{
  margin:10px 0 12px;
  max-width:22ch;
  color:var(--gold-2);
  font-size:clamp(1.55rem,3vw,2.55rem);
  line-height:1.05;
  letter-spacing:-.042em;
  text-wrap:balance;
}
.map-copy p{
  margin:0;
  max-width:76ch;
  color:var(--muted);
}
.map-copy p + p{margin-top:10px}
.map-note{font-size:.95rem;color:var(--muted-2)!important}
.poi-preview-grid{
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:10px;
  padding:0 clamp(18px,3.2vw,34px) clamp(18px,3.2vw,34px);
}
.poi-preview-grid article{
  min-width:0;
  padding:16px;
  border:1px solid rgba(241,221,185,.13);
  border-radius:18px;
  background:rgba(255,255,255,.045);
}
.poi-preview-grid span{
  display:block;
  margin-bottom:8px;
  color:var(--gold-2);
  font-size:.78rem;
  font-weight:850;
  letter-spacing:.08em;
  text-transform:uppercase;
}
.poi-preview-grid strong{
  display:block;
  color:var(--text);
  line-height:1.25;
}
.poi-preview-grid small{
  display:block;
  margin-top:7px;
  color:var(--muted);
  line-height:1.45;
}
.map-placeholder{
  position:relative;
  min-height:430px;
  display:grid;
  place-items:center;
  padding:24px;
  overflow:hidden;
  border-top:1px solid var(--line);
  background:
    linear-gradient(180deg,rgba(7,17,31,.64),rgba(7,17,31,.84)),
    url('../img/responsive/madrid-ubicacion-03-1200.webp') center/cover no-repeat;
}
.map-placeholder__inner{
  width:min(720px,100%);
  display:grid;
  gap:14px;
  justify-items:center;
  text-align:center;
  padding:clamp(22px,4vw,36px);
  border:1px solid rgba(241,221,185,.22);
  border-radius:24px;
  background:rgba(7,17,31,.68);
  box-shadow:0 24px 70px rgba(0,0,0,.28);
  backdrop-filter:blur(12px) saturate(130%);
}
.map-placeholder__inner strong{
  color:var(--gold-2);
  font-size:clamp(1.3rem,2.2vw,1.8rem);
  letter-spacing:-.025em;
}
.map-placeholder__inner span{max-width:56ch;color:var(--muted)}
.map-actions{display:flex;flex-wrap:wrap;justify-content:center;gap:12px;margin-top:8px}
.map-placeholder.is-loading .btn{opacity:.7;pointer-events:none}
.map-placeholder.is-loaded{
  display:block;
  min-height:0;
  padding:clamp(10px,2vw,16px);
  background:linear-gradient(180deg,rgba(7,17,31,.92),rgba(7,17,31,.98));
}
.poi-map-shell{
  display:grid;
  grid-template-columns:minmax(0,1.34fr) minmax(310px,.66fr);
  gap:14px;
  align-items:stretch;
}
.poi-map-canvas{
  width:100%;
  height:min(68vh,580px);
  min-height:460px;
  overflow:hidden;
  border:1px solid rgba(241,221,185,.14);
  border-radius:24px;
  background:#d8d2c3;
  box-shadow:0 24px 62px rgba(0,0,0,.24);
}
.poi-panel{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:12px;
  padding:14px;
  border:1px solid rgba(241,221,185,.14);
  border-radius:24px;
  background:rgba(255,255,255,.055);
}
.poi-panel__head h4{margin:0 0 6px;color:var(--gold-2);font-size:1.15rem;letter-spacing:-.02em}
.poi-panel__head p{margin:0;color:var(--muted);font-size:.94rem;line-height:1.45}
.poi-filter{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}
.poi-filter button{
  border:1px solid rgba(241,221,185,.18);
  border-radius:999px;
  padding:8px 10px;
  color:var(--text);
  background:rgba(255,255,255,.055);
  font:inherit;
  font-size:.86rem;
  font-weight:760;
  cursor:pointer;
}
.poi-filter button[aria-pressed="true"]{
  color:var(--navy);
  border-color:transparent;
  background:var(--gold-2);
}
.poi-list{
  display:grid;
  gap:9px;
  max-height:430px;
  overflow:auto;
  padding-right:4px;
  scrollbar-width:thin;
}
.poi-card{
  display:grid;
  grid-template-columns:auto 1fr auto;
  gap:10px;
  align-items:start;
  width:100%;
  padding:12px;
  border:1px solid rgba(241,221,185,.12);
  border-radius:18px;
  text-align:left;
  color:var(--text);
  background:rgba(7,17,31,.36);
  cursor:pointer;
}
.poi-card:hover,.poi-card:focus-visible{border-color:rgba(212,180,124,.52);outline:none;background:rgba(255,255,255,.07)}
.poi-card__icon,.poi-marker span{
  display:grid;
  place-items:center;
  width:34px;
  height:34px;
  border-radius:999px;
  color:var(--navy);
  background:var(--gold-2);
  font-size:1rem;
  box-shadow:0 10px 28px rgba(0,0,0,.28);
}
.poi-card__body{min-width:0}
.poi-card__body strong{display:block;color:var(--text);line-height:1.25;overflow-wrap:anywhere}
.poi-card__body span{display:block;margin-top:4px;color:var(--muted);font-size:.9rem;line-height:1.35}
.poi-card__meta{white-space:nowrap;color:var(--gold-2);font-size:.82rem;font-weight:850;justify-self:end}
.poi-card--home{grid-template-columns:auto minmax(0,1fr)}
.poi-card--home .poi-card__meta{grid-column:2;justify-self:start;white-space:normal;margin-top:-2px}
.poi-panel__links{display:flex;flex-wrap:wrap;gap:8px;margin-top:auto}
.poi-panel__links a{font-size:.88rem}

@media (max-width:1180px){
  .poi-card{grid-template-columns:auto minmax(0,1fr)}
  .poi-card__meta{grid-column:2;justify-self:start;white-space:normal;margin-top:-2px}
}

.poi-marker{border:0;background:transparent}
.poi-marker span{border:2px solid rgba(7,17,31,.85)}
.leaflet-container{font-family:inherit;color:#1d2534}
.leaflet-popup-content{margin:12px 14px;line-height:1.45}
.poi-popup strong{display:block;margin-bottom:4px;color:#081225}
.poi-popup span{display:block;color:#334155}
.poi-popup__links{display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}
.poi-popup__links a{display:inline-block;color:#0b3a66;font-weight:800;text-decoration:none}
.poi-map-error{width:min(720px,100%);margin:auto;text-align:center;color:var(--muted)}
.poi-map-error strong{display:block;margin-bottom:8px;color:var(--gold-2);font-size:1.2rem}


/* SEO-friendly nearby POI guide */
.poi-seo-list{
  margin:clamp(18px,3.2vw,34px);
  padding:clamp(20px,3.2vw,36px);
  border:1px solid rgba(241,221,185,.14);
  border-radius:28px;
  background:
    radial-gradient(circle at top right,rgba(212,180,124,.14),transparent 30rem),
    linear-gradient(180deg,rgba(255,255,255,.052),rgba(255,255,255,.026)),
    rgba(7,17,31,.56);
  box-shadow:0 24px 64px rgba(0,0,0,.18);
}
.poi-seo-list__head{
  max-width:860px;
  margin:0 0 clamp(18px,2.8vw,28px);
}
.poi-seo-list__head h4{
  margin:8px 0 10px;
  color:var(--gold-2);
  font-size:clamp(1.7rem,3vw,2.55rem);
  line-height:1.04;
  letter-spacing:-.044em;
  text-wrap:balance;
}
.poi-seo-list__head p{
  max-width:72ch;
  margin:0;
  color:rgba(251,247,239,.78);
  line-height:1.7;
}
.poi-seo-list__grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.poi-seo-group{
  min-width:0;
  display:flex;
  flex-direction:column;
  gap:14px;
  padding:17px;
  border:1px solid rgba(241,221,185,.13);
  border-radius:22px;
  background:linear-gradient(180deg,rgba(255,255,255,.055),rgba(255,255,255,.028));
  box-shadow:inset 0 1px 0 rgba(255,255,255,.05);
}
.poi-seo-group__head{
  display:grid;
  grid-template-columns:auto minmax(0,1fr);
  align-items:center;
  gap:12px;
}
.poi-seo-group__icon{
  display:grid;
  place-items:center;
  width:42px;
  height:42px;
  border-radius:999px;
  color:var(--navy);
  background:var(--gold-2);
  font-size:1rem;
  font-weight:900;
  line-height:1;
  box-shadow:0 14px 32px rgba(0,0,0,.22);
}
.poi-seo-group__count{
  display:block;
  margin:0 0 4px;
  color:rgba(251,247,239,.56);
  font-size:.72rem;
  font-weight:850;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.poi-seo-group h5{
  margin:0;
  color:var(--text);
  font-size:1.14rem;
  line-height:1.12;
  letter-spacing:-.02em;
}
.poi-seo-group ul{
  display:grid;
  gap:9px;
  margin:0;
  padding:0;
  list-style:none;
}
.poi-seo-group li{
  padding:11px 12px;
  border:1px solid rgba(241,221,185,.095);
  border-radius:15px;
  background:rgba(7,17,31,.22);
}
.poi-seo-group li strong{
  display:block;
  margin:0 0 4px;
  color:var(--text);
  font-size:.98rem;
  line-height:1.25;
}
.poi-seo-group li span{
  display:block;
  color:var(--muted);
  font-size:.91rem;
  line-height:1.45;
}

@media (max-width:1080px){
  .poi-preview-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .poi-seo-list__grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .poi-map-shell{grid-template-columns:1fr}
  .poi-list{max-height:none}
}
@media (max-width:760px){
  .map-copy{padding:22px 18px 14px}
  .map-copy h3{max-width:14ch;font-size:clamp(1.7rem,8.2vw,2.35rem)}
  .poi-preview-grid{grid-template-columns:1fr;padding:0 14px 16px;gap:8px}
  .poi-seo-list{margin:14px;padding:18px 14px;border-radius:22px}
  .poi-seo-list__head{margin-bottom:16px}
  .poi-seo-list__head h4{font-size:clamp(1.45rem,7vw,2rem)}
  .poi-seo-list__grid{grid-template-columns:1fr;gap:12px}
  .poi-seo-group{gap:12px;padding:15px 13px;border-radius:18px}
  .poi-seo-group__icon{width:38px;height:38px}
  .poi-seo-group li{padding:10px 11px;border-radius:14px}
  .poi-preview-grid article{padding:14px;border-radius:16px}
  .map-placeholder{min-height:360px;padding:16px 12px}
  .map-placeholder__inner{padding:22px 16px;border-radius:20px}
  .map-actions{width:100%}
  .map-actions .btn{width:100%}
  .map-placeholder.is-loaded{padding:10px;background:#07111f}
  .poi-map-shell{gap:10px}
  .poi-map-canvas{height:min(58vh,430px);min-height:330px;border-radius:18px}
  .poi-panel{padding:12px;border-radius:18px}
  .poi-filter{flex-wrap:nowrap;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}
  .poi-filter::-webkit-scrollbar{display:none}
  .poi-filter button{flex:0 0 auto;min-height:40px}
  .poi-card{grid-template-columns:auto 1fr;gap:9px;padding:11px;border-radius:16px}
  .poi-card__meta{grid-column:2;white-space:normal;margin-top:-4px}
}
@media (max-width:420px){
  .poi-map-canvas{height:360px;min-height:320px}
  .poi-card__icon,.poi-marker span{width:32px;height:32px}
}


.final{padding:clamp(34px,6vw,84px) 0 clamp(44px,7vw,96px)}
.final-box{
  position:relative;
  overflow:hidden;
  padding:clamp(28px,5vw,58px);
  text-align:center;
  background:
    radial-gradient(circle at top,rgba(212,180,124,.16),transparent 28rem),
    linear-gradient(135deg,#06101d 0%,#0c213d 54%,#173457 100%);
}
.final-box .final-logo{width:min(316px,78vw);height:auto;margin:0 auto 20px}
.final-box h2{
  max-width:820px;
  margin:0 auto 12px;
  font-size:clamp(2rem,4vw,4rem);
  line-height:1;
  letter-spacing:-.052em;
  text-wrap:balance;
}
.final-box p{
  max-width:720px;
  margin:0 auto;
  color:rgba(251,247,239,.78);
}
.contact-steps{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:10px;
  max-width:760px;
  margin:28px auto 0;
}
.contact-steps div{
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding:12px;
  border-radius:16px;
  border:1px solid rgba(241,221,185,.14);
  background:rgba(255,255,255,.055);
  text-align:center;
}
.contact-steps strong{
  flex:0 0 auto;
  display:inline-flex;align-items:center;justify-content:center;
  width:30px;height:30px;
  border-radius:999px;
  color:var(--navy);
  background:var(--gold-2);
}
.contact-steps span{color:var(--muted);font-weight:750}

.contact-methods{
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:12px;
  max-width:920px;
  margin:26px auto 0;
  text-align:center;
}
.contact-method{
  min-width:0;
  display:flex;
  flex-direction:column;
  justify-content:center;
  align-items:center;
  gap:6px;
  padding:18px;
  border-radius:20px;
  border:1px solid rgba(241,221,185,.16);
  background:rgba(255,255,255,.065);
  color:var(--cream);
  text-align:center;
  text-decoration:none;
  box-shadow:inset 0 1px 0 rgba(255,255,255,.08);
}
.contact-method:hover{transform:translateY(-1px);border-color:rgba(234,205,146,.38);background:rgba(255,255,255,.09)}
.contact-method span{
  color:var(--gold-2);
  font-size:.78rem;
  font-weight:900;
  letter-spacing:.12em;
  text-transform:uppercase;
}
.contact-method strong{
  overflow-wrap:anywhere;
  font-size:clamp(1rem,1.35vw,1.18rem);
  line-height:1.25;
}
.contact-method-qr{
  grid-column:1 / -1;
  display:grid;
  grid-template-columns:minmax(0,1fr) auto;
  align-items:center;
  justify-items:center;
  gap:clamp(24px,4vw,56px);
}
.contact-method-qr > div{
  justify-self:center;
  text-align:center;
}

.contact-method-qr > div span,
.contact-method-qr > div strong{
  display:block;
}
.contact-method-qr > div span{margin-bottom:6px}
.contact-method-qr img{
  display:block;
  justify-self:center;
  width:min(260px,100%);
  height:auto;
  margin-inline:auto;
  padding:8px;
  border-radius:18px;
  background:#fff;
  box-shadow:0 18px 50px rgba(0,0,0,.18);
}


.footer{
  padding:0 0 34px;
  color:rgba(251,247,239,.68);
  text-align:center;
}
.footer p{margin:.4rem 0}
.footer-nav{display:flex;flex-wrap:wrap;justify-content:center;gap:8px 0;margin:.65rem auto 0;color:var(--muted);font-size:.95rem}
.footer-nav a{color:var(--gold-2);text-decoration:none;white-space:nowrap}
.footer-nav a + a::before{content:"·";display:inline-block;margin:0 12px;color:var(--muted-2)}
.footer-nav a:hover{text-decoration:underline;text-underline-offset:4px}
.legal-links{margin:.55rem 0 0;color:var(--muted);font-size:.95rem}
.legal-links a,.footer-cookie-button{color:var(--gold-2);text-decoration:none}
.legal-links a:hover,.footer-cookie-button:hover{text-decoration:underline;text-underline-offset:4px}
.footer-cookie-button{font:inherit;background:none;border:0;padding:0;cursor:pointer}

.footer-credit{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:.38rem;margin:.9rem 0 0;color:rgba(251,247,239,.58);font-size:.86rem;line-height:1.35}
.footer-credit-link{display:inline-flex;align-items:center;gap:.36rem;color:var(--gold-2);text-decoration:none;line-height:1.15;vertical-align:middle}
.footer-credit-link:hover{text-decoration:underline;text-underline-offset:4px}
.footer-credit-logo{width:auto;height:17px;display:block;object-fit:contain;border:0;border-radius:0;box-shadow:none;flex:0 0 auto;transform:translateY(-.5px)}

.lightbox{
  position:fixed;inset:0;z-index:1200;
  display:grid;
  place-items:center;
}
.lightbox[hidden]{display:none}
.lightbox-backdrop{
  position:absolute;inset:0;
  background:rgba(3,8,16,.9);
  backdrop-filter:blur(8px);
}
.lightbox-dialog{
  position:relative;z-index:1;
  width:min(1380px,calc(100vw - 24px));
  height:min(94vh,1000px);
  display:grid;
  grid-template-columns:64px 1fr 64px;
  gap:12px;
  align-items:center;
}
.lightbox-figure{
  margin:0;
  min-width:0;height:100%;
  display:flex;flex-direction:column;
  align-items:center;justify-content:center;
  gap:12px;
}
.lightbox-image{
  max-width:100%;
  max-height:calc(94vh - 96px);
  width:auto;height:auto;
  object-fit:contain;
  border-radius:22px;
  box-shadow:0 34px 90px rgba(0,0,0,.52);
  background:#111b2c;
}
.lightbox-caption{max-width:min(920px,calc(100vw - 48px));color:var(--gold-2);font-weight:800;text-align:center;line-height:1.35;text-wrap:balance}
.lightbox-close,.lightbox-nav{
  appearance:none;
  border:1px solid rgba(241,221,185,.22);
  background:rgba(9,22,42,.74);
  color:var(--gold-2);
  cursor:pointer;
  backdrop-filter:blur(12px);
  transition:background .18s ease,transform .18s ease;
}
.lightbox-close:hover,.lightbox-nav:hover{background:rgba(241,221,185,.14);transform:translateY(-1px)}
.lightbox-close{
  position:absolute;right:6px;top:6px;
  z-index:2;
  width:48px;height:48px;
  border-radius:999px;
  font-size:1.6rem;
  line-height:1;
}
.lightbox-nav{
  width:54px;height:54px;
  border-radius:999px;
  font-size:2rem;
  line-height:1;
}
.lightbox-nav.prev{justify-self:start}
.lightbox-nav.next{justify-self:end}

/* Legal pages and cookie preferences */
.legal-page{background:linear-gradient(180deg,#081225 0%,#102445 100%)}
.legal-main{max-width:980px;margin:0 auto;padding:132px 22px 72px}
.legal-card{background:rgba(255,255,255,.07);border:1px solid var(--line);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:clamp(24px,4vw,52px);color:var(--ink)}
.legal-card h1{font-size:clamp(2.1rem,5vw,4rem);line-height:1.02;margin:0 0 22px;color:var(--gold-2);letter-spacing:-.045em}
.legal-card h2{font-size:clamp(1.25rem,2.2vw,1.75rem);margin:34px 0 12px;color:var(--gold-2)}
.legal-card p,.legal-card li{color:var(--muted);line-height:1.75}
.legal-card a{color:var(--gold-2);text-decoration:underline;text-underline-offset:4px}
.legal-updated{margin:0 0 16px;color:var(--gold)!important;font-weight:700}
.legal-warning{border:1px solid rgba(241,221,185,.35);background:rgba(241,221,185,.1);border-radius:18px;padding:16px 18px;margin:24px 0;color:var(--gold-2);line-height:1.65}
.legal-table{width:100%;border-collapse:collapse;margin:20px 0 28px;overflow:hidden;border-radius:18px}
.legal-table th,.legal-table td{border:1px solid rgba(241,221,185,.18);padding:14px 16px;text-align:left;vertical-align:top;color:var(--muted)}
.legal-table th{width:32%;background:rgba(241,221,185,.08);color:var(--gold-2);font-weight:800}

.cookie-banner{position:fixed;left:18px;right:18px;bottom:18px;z-index:9998;display:none}
.cookie-banner.is-visible{display:block}
.cookie-banner__box{max-width:980px;margin:0 auto;background:#f8f1e6;color:#1d2534;border:1px solid rgba(8,18,37,.18);border-radius:24px;box-shadow:0 24px 80px rgba(0,0,0,.28);padding:20px;display:grid;gap:14px}
.cookie-banner__box h2{font-size:1.2rem;margin:0;color:#081225}
.cookie-banner__box p{margin:0;color:#334155;line-height:1.55}
.cookie-banner__box a{color:#081225;text-decoration:underline;text-underline-offset:4px}
.cookie-banner__actions{display:flex;flex-wrap:wrap;gap:10px;align-items:center}
.cookie-btn{appearance:none;border:1px solid #081225;border-radius:999px;padding:11px 16px;font-weight:800;cursor:pointer;background:#081225;color:#fff}
.cookie-btn.secondary{background:transparent;color:#081225}
.cookie-btn.link{border:0;background:transparent;color:#081225;text-decoration:underline;text-underline-offset:4px;padding:8px}
.cookie-modal{position:fixed;inset:0;z-index:9999;display:none;align-items:center;justify-content:center;padding:20px;background:rgba(2,8,23,.68)}
.cookie-modal.is-visible{display:flex}
.cookie-modal__panel{width:min(720px,100%);max-height:90vh;overflow:auto;background:#f8f1e6;color:#1d2534;border-radius:26px;padding:24px;box-shadow:0 30px 90px rgba(0,0,0,.45)}
.cookie-modal__panel h2{margin:0 0 10px;color:#081225}
.cookie-modal__panel p{color:#334155;line-height:1.55}
.cookie-option{display:flex;gap:12px;align-items:flex-start;border:1px solid rgba(8,18,37,.16);border-radius:18px;padding:14px;margin:12px 0;background:rgba(255,255,255,.45)}
.cookie-option strong{display:block;color:#081225;margin-bottom:4px}
.cookie-option small{display:block;color:#475569;line-height:1.45}
.cookie-modal__actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}

@media (max-width:1080px){
  :root{--anchor-offset:176px}
  .header-inner{
    min-height:auto;
    grid-template-columns:1fr auto;
    padding:12px 0;
    gap:12px;
  }
  .brand img{width:220px}
  .nav{
    grid-column:1 / -1;
    justify-self:start;
    width:100%;
    overflow-x:auto;
    padding-bottom:4px;
    scrollbar-width:none;
  }
  .nav::-webkit-scrollbar{display:none}
  .nav a{background:rgba(255,255,255,.035)}
  .hero-layout{grid-template-columns:1fr}
  .hero h1{max-width:12.5ch}
  .hero-media{min-height:520px}
  .section-head{grid-template-columns:1fr}
  .proposal-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .apartment-card,.apartment-card:nth-child(even),.split-grid,.location-grid{grid-template-columns:1fr}
  .apartment-card:nth-child(even) .apartment-copy{order:1}
  .apartment-card:nth-child(even) .gallery{order:2}
}
@media (max-width:820px){
  :root{--anchor-offset:168px}
  .brand img{width:205px}
  .hero{padding-top:24px}
  .hero-copy{padding:26px}
  .hero h1{font-size:clamp(2.55rem,12vw,4.5rem)}
  .hero-media{min-height:390px}
  .stats{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery{grid-template-columns:repeat(2,minmax(0,1fr))}
  .gallery-item,.gallery-item:first-child{grid-row:auto;min-height:168px}
  .apartment-meta{grid-template-columns:1fr}
  .image-pair,.location-photo-grid{grid-template-columns:1fr}
  .image-pair img,.location-photo-grid img{min-height:260px}
  .contact-steps{grid-template-columns:1fr}
  .contact-methods{grid-template-columns:1fr}
  .contact-method-qr{grid-column:auto;grid-template-columns:1fr;justify-items:center;text-align:center}
  .contact-method-qr img{justify-self:center;width:min(260px,82vw);margin-inline:auto}
  .lightbox-dialog{grid-template-columns:44px 1fr 44px;gap:8px}
  .lightbox-nav{width:40px;height:40px;font-size:1.5rem}
  .lightbox-close{width:42px;height:42px}
}
@media (max-width:560px){
  :root{--gutter:16px}
  body{font-size:15px}
  .header-inner{grid-template-columns:1fr}
  .brand img{width:185px}
  .brand{justify-self:start}
  .lang{position:absolute;right:var(--gutter);top:14px}
  .lang a{min-width:38px;min-height:38px;padding:8px 10px;font-size:.82rem}
  .hero-copy,.apartment-copy,.content-card,.location-copy,.final-box{border-radius:22px}
  .hero-actions .btn{width:100%}
  .hero-points{display:grid;grid-template-columns:1fr}
  .stats,.proposal-grid{grid-template-columns:1fr}
  .gallery{gap:8px;padding:8px;border-radius:22px}
  .gallery-item,.gallery-item:first-child{min-height:138px;border-radius:14px}
  .gallery-item::after{display:none}
  .section{padding:34px 0}
  .section-head h2,.final-box h2{letter-spacing:-.04em}
  .legal-main{padding-top:104px}
  .legal-table,.legal-table tbody,.legal-table tr,.legal-table th,.legal-table td{display:block;width:100%}
  .legal-table th{border-bottom:0}
  .cookie-banner{left:10px;right:10px;bottom:10px}
  .cookie-banner__actions,.cookie-modal__actions{flex-direction:column;align-items:stretch}
  .cookie-btn{width:100%}
}
@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{scroll-behavior:auto!important;animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}
}

/* 2026-04-30: Spanish desktop hero integration fix
   Keep the mobile composition intact, but reduce the ES headline scale on tablet/desktop
   so the copy block feels integrated instead of oversized or clipped. */
@media (min-width:821px){
  html[lang="es"] .hero h1{
    max-width:14.25ch;
    font-size:clamp(3.05rem,5vw,4.75rem);
    line-height:.98;
    letter-spacing:-.055em;
  }
  html[lang="es"] .hero-lede{
    max-width:58ch;
  }
}

@media (min-width:821px) and (max-width:1080px){
  html[lang="es"] .hero-copy{
    width:min(100%,940px);
    margin-inline:auto;
    padding:clamp(34px,5vw,52px);
  }
  html[lang="es"] .hero h1{
    max-width:13.85ch;
    font-size:clamp(3.15rem,6.35vw,4.65rem);
  }
  html[lang="es"] .hero-actions{
    max-width:720px;
  }
}

@media (min-width:1081px){
  html[lang="es"] .hero-layout{
    grid-template-columns:minmax(0,.94fr) minmax(390px,.82fr);
  }
}

/* Local OSM fallback: keeps the approved POI presentation working if Leaflet CDN is unavailable */
.poi-map-canvas--fallback{
  position:relative;
  overflow:hidden;
  background:
    linear-gradient(rgba(246,224,182,.05) 1px, transparent 1px),
    linear-gradient(90deg, rgba(246,224,182,.05) 1px, transparent 1px),
    radial-gradient(circle at 50% 50%, rgba(246,224,182,.10), rgba(6,18,33,.22) 62%);
  background-size:38px 38px,38px 38px,100% 100%;
  touch-action:manipulation;
}

.poi-fallback-grid{
  position:absolute;
  inset:0;
  pointer-events:none;
}

.poi-fallback-tile{
  position:absolute;
  width:256px;
  height:256px;
  object-fit:cover;
  max-width:none;
}

.poi-fallback-marker{
  position:absolute;
  z-index:5;
  transform:translate(-50%,-50%);
  border:0;
  cursor:pointer;
}

.poi-fallback-marker:hover,
.poi-fallback-marker:focus-visible{
  transform:translate(-50%,-50%) scale(1.08);
  outline:2px solid var(--gold-2);
  outline-offset:3px;
}

.poi-fallback-controls{
  position:absolute;
  top:16px;
  left:16px;
  z-index:10;
  display:grid;
  overflow:hidden;
  border:1px solid rgba(6,18,33,.18);
  border-radius:12px;
  background:rgba(255,255,255,.95);
  box-shadow:0 12px 30px rgba(0,0,0,.18);
}

.poi-fallback-controls button{
  width:44px;
  height:42px;
  border:0;
  border-bottom:1px solid rgba(6,18,33,.16);
  background:#fff;
  color:#071426;
  font-size:1.7rem;
  font-weight:800;
  line-height:1;
  cursor:pointer;
}

.poi-fallback-controls button:last-child{border-bottom:0}

.poi-fallback-notice{
  position:absolute;
  top:16px;
  right:16px;
  z-index:8;
  max-width:min(320px,calc(100% - 92px));
  padding:8px 11px;
  border:1px solid rgba(246,224,182,.45);
  border-radius:999px;
  background:rgba(6,18,33,.78);
  color:var(--cream);
  font-size:.78rem;
  font-weight:700;
  backdrop-filter:blur(10px);
}

.poi-fallback-attribution{
  position:absolute;
  right:0;
  bottom:0;
  z-index:8;
  padding:3px 7px;
  background:rgba(255,255,255,.86);
  color:#15324a;
  font-size:.74rem;
}

.poi-fallback-attribution a{color:#087aa3;text-decoration:none}

.poi-fallback-popup{
  position:absolute;
  z-index:20;
  width:min(248px,calc(100% - 24px));
  display:grid;
  gap:6px;
  padding:14px 16px 15px;
  border:1px solid rgba(6,18,33,.15);
  border-radius:18px;
  background:#fff;
  color:#071426;
  box-shadow:0 18px 50px rgba(0,0,0,.25);
}

.poi-fallback-popup button{
  position:absolute;
  top:6px;
  right:8px;
  width:28px;
  height:28px;
  border:0;
  border-radius:999px;
  background:rgba(7,20,38,.08);
  color:#071426;
  font-weight:900;
  cursor:pointer;
}

.poi-fallback-popup strong{
  padding-right:24px;
  color:#071426;
  font-size:1rem;
}

.poi-fallback-popup span{
  color:#344254;
  line-height:1.35;
}

.poi-fallback-popup .poi-popup__links{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:3px;
}

.poi-fallback-popup .poi-popup__links a{
  color:#087aa3;
  font-weight:900;
  text-decoration:none;
}

@media (max-width:760px){
  .poi-fallback-notice{
    top:auto;
    right:10px;
    bottom:32px;
    left:10px;
    max-width:none;
    border-radius:16px;
    text-align:center;
  }

  .poi-fallback-controls{
    top:12px;
    left:12px;
  }
}


/* V19 mobile fix: keep the approved conditions section stable on phones.
   Avoid image overlap caused by height:100% on stacked grid images and keep
   the condition text in a clean card above the photo pair. */
#condiciones .split-grid{
  isolation:isolate;
}
#condiciones .content-card{
  position:relative;
  z-index:2;
}
#condiciones .image-pair{
  position:relative;
  z-index:1;
  overflow:hidden;
}
#condiciones .image-pair img{
  display:block;
}

@media (max-width:820px){
  #condiciones .split-grid{
    grid-template-columns:1fr;
    gap:14px;
    align-items:start;
  }
  #condiciones .content-card{
    padding:clamp(20px,5vw,28px);
  }
  #condiciones .image-pair{
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px;
    padding:10px;
    border-radius:24px;
  }
  #condiciones .image-pair img{
    width:100%;
    height:auto;
    min-height:0;
    aspect-ratio:4 / 5;
    object-fit:cover;
    object-position:center;
    border-radius:16px;
  }
}

@media (max-width:560px){
  #condiciones .section-head{
    margin-bottom:18px;
  }
  #condiciones .content-card{
    padding:18px 16px;
    border-radius:22px;
  }
  #condiciones .cond-list{
    gap:9px;
  }
  #condiciones .cond-list li{
    padding:12px 13px 12px 36px;
    border-radius:14px;
    line-height:1.45;
  }
  #condiciones .cond-list li::before{
    left:15px;
    top:1.08em;
  }
  #condiciones .image-pair{
    grid-template-columns:1fr;
    padding:8px;
    border-radius:22px;
  }
  #condiciones .image-pair img{
    aspect-ratio:4 / 5;
    max-height:none;
    object-fit:cover;
    border-radius:16px;
  }
}


/* Conversion, trust and availability improvements */
.trust-grid,.process-grid{
  display:grid;
  grid-template-columns:repeat(3,minmax(0,1fr));
  gap:14px;
}
.trust-card,.process-card,.contact-form-card,.faq-list details{
  border:1px solid var(--line);
  background:linear-gradient(180deg,rgba(19,43,75,.82),rgba(12,30,56,.88));
  box-shadow:var(--shadow-soft);
  border-radius:var(--radius-md);
}
.trust-card,.process-card{padding:24px}
.trust-card span,.process-card span{
  display:inline-flex;align-items:center;justify-content:center;
  width:40px;height:40px;margin-bottom:22px;
  border-radius:999px;background:rgba(212,180,124,.14);
  color:var(--gold-2);border:1px solid rgba(241,221,185,.18);font-weight:900;
}
.trust-card h3,.process-card h3,.contact-form-card h3{
  margin:0 0 8px;font-size:1.16rem;letter-spacing:-.025em;
}
.trust-card p,.process-card p{margin:0;color:var(--muted)}
.section-cta{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:clamp(22px,3.5vw,36px)}
.process-grid{grid-template-columns:repeat(4,minmax(0,1fr))}
.process-card{position:relative}
.process-card span{color:var(--navy);background:var(--gold-2)}
.faq-list{display:grid;gap:12px}
.faq-list details{padding:0;overflow:hidden}
.faq-list summary{
  cursor:pointer;list-style:none;padding:18px 22px;font-weight:900;color:var(--ink);
  display:flex;align-items:center;justify-content:space-between;gap:16px;
}
.faq-list summary::-webkit-details-marker{display:none}
.faq-list summary::after{content:"+";flex:0 0 auto;color:var(--gold-2);font-size:1.35rem;line-height:1}
.faq-list details[open] summary::after{content:"−"}
.faq-list p{margin:0;padding:0 22px 20px;color:var(--muted)}
.contact-box{text-align:left}
.contact-layout{display:grid;grid-template-columns:minmax(0,.9fr) minmax(360px,1fr);gap:clamp(24px,4vw,46px);align-items:start}
.contact-intro .final-logo{margin:0 0 20px;width:min(316px,78vw);height:auto}
.contact-box h2{margin-left:0;margin-right:0;max-width:760px}
.contact-box p{margin-left:0;margin-right:0;max-width:720px}
.contact-layout .contact-steps{grid-template-columns:repeat(2,minmax(0,1fr));max-width:none;margin-left:0;margin-right:0}
.contact-layout .contact-methods{grid-template-columns:1fr;max-width:none;margin-left:0;margin-right:0;text-align:left}
.contact-layout .contact-method{align-items:flex-start;text-align:left}
.contact-layout .contact-method-qr{grid-template-columns:minmax(0,1fr) auto;text-align:left}
.contact-form-card{padding:clamp(22px,3.2vw,34px);background:linear-gradient(180deg,rgba(255,255,255,.08),rgba(255,255,255,.045))}
.contact-form-card h3{font-size:clamp(1.5rem,2.4vw,2.05rem);margin-bottom:18px}
.availability-form{display:grid;gap:16px}
.form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}
.availability-form label{display:grid;gap:7px;color:var(--muted);font-weight:750}
.availability-form label span:first-child{color:var(--gold-2);font-size:.82rem;text-transform:uppercase;letter-spacing:.08em;font-weight:900}
.availability-form input,.availability-form select,.availability-form textarea{
  width:100%;border:1px solid rgba(241,221,185,.18);border-radius:14px;
  background:rgba(255,255,255,.08);color:var(--ink);padding:13px 14px;outline:none;
}
.availability-form select option{color:#081225;background:#fff}
.availability-form textarea{resize:vertical;min-height:130px}
.availability-form input:focus,.availability-form select:focus,.availability-form textarea:focus{border-color:var(--gold-2);box-shadow:0 0 0 3px rgba(241,221,185,.14)}
.form-field-full{grid-column:1 / -1}
.form-consent{display:flex!important;grid-template-columns:auto 1fr!important;align-items:flex-start;gap:10px!important;font-size:.9rem;line-height:1.45}
.form-consent input{width:auto;margin-top:3px;accent-color:var(--gold)}
.form-consent a{text-decoration:underline;text-underline-offset:3px;color:var(--gold-2)}
.form-note{font-size:.92rem;color:var(--muted-2)!important;margin:0!important}
.whatsapp-float{display:none}
@media (max-width:1080px){
  .trust-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .process-grid{grid-template-columns:repeat(2,minmax(0,1fr))}
  .contact-layout{grid-template-columns:1fr}
}
@media (max-width:820px){
  .contact-layout .contact-method-qr{grid-template-columns:1fr;text-align:center;justify-items:center}
  .contact-layout .contact-method-qr > div{text-align:center}
  .whatsapp-float{
    position:fixed;right:16px;bottom:16px;z-index:60;display:inline-flex;align-items:center;justify-content:center;
    min-height:48px;padding:12px 18px;border-radius:999px;background:linear-gradient(180deg,#f2dfbd 0%,#d2b06f 100%);
    color:var(--navy);font-weight:900;box-shadow:0 16px 34px rgba(0,0,0,.28);
  }
}
@media (max-width:560px){
  .trust-grid,.process-grid,.form-grid{grid-template-columns:1fr}
  .contact-layout .contact-steps{grid-template-columns:1fr}
  .form-field-full{grid-column:auto}
  .contact-box{text-align:left}
}


/* APGV security hardening: protected contact form */
.form-hp{
  position:absolute!important;
  left:-10000px!important;
  width:1px!important;
  height:1px!important;
  overflow:hidden!important;
  opacity:0!important;
  pointer-events:none!important;
}
.form-status{
  min-height:1.2em;
  margin:0!important;
  color:var(--gold-2)!important;
  font-size:.92rem;
  font-weight:800;
}
.form-status.is-error{
  color:#ffd1d1!important;
}
.form-security-note{
  margin:0!important;
  color:var(--muted-2)!important;
  font-size:.82rem;
}
