/* ═══════════════════════════════════════════════════════════
   RESIDENCIAL L-11 · TEMA CLARO
   Fuentes: Cormorant Garamond (display) + DM Sans (UI)
═══════════════════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Inter:ital,opsz,wght@0,14..32,100..900;1,14..32,100..900&family=Montserrat:ital,wght@0,100..900;1,100..900&display=swap');

/* ── VARIABLES ─────────────────────────────────────────── */
:root {
  --gold:        #B8935A;
  --gold-light:  #D4AF82;
  --gold-dark:   #8B6B3D;
  --gold-dim:    rgba(184,147,90,0.10);
  --gold-border: rgba(184,147,90,0.30);

  --bg:          #F7F5F2;
  --bg2:         #EFEDE9;
  --bg3:         #E8E4DE;
  --white:       #FFFFFF;
  --surface:     #FFFFFF;

  --text:        #1A1814;
  --text2:       #5A5550;
  --text3:       #9A9590;

  --border:      rgba(0,0,0,0.08);
  --border2:     rgba(0,0,0,0.14);

  --radius:      6px;
  --font-display:'Inter', Georgia, serif;
  --font-ui:     'DM Sans', sans-serif;
  --shadow-sm:   0 2px 12px rgba(0,0,0,0.06);
  --shadow-md:   0 8px 40px rgba(0,0,0,0.10);
  --transition:  all 0.35s cubic-bezier(0.25,0.46,0.45,0.94);
}

/* ── RESET ─────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }
body {
  font-family: var(--font-ui);
  background: var(--bg);
  color: var(--text);
  -webkit-font-smoothing: antialiased;
  overflow-x: hidden;
}

/* ── TIPOGRAFÍA BASE ───────────────────────────────────── */
h1,h2,h3,h4 { font-family: var(--font-display); font-weight: 300; }
p { line-height: 1.75; color: var(--text2); }

/* ── CURSOR ────────────────────────────────────────────── */
* { cursor: none !important; }
#cursor { position: fixed; top:0; left:0; pointer-events:none; z-index:9999; }
#cursor-dot {
  width:8px; height:8px; background:var(--gold);
  border-radius:50%; transform:translate(-50%,-50%);
  transition: width .2s, height .2s;
}
#cursor-ring {
  position:absolute; top:50%; left:50%;
  width:32px; height:32px;
  border:1.5px solid rgba(184,147,90,0.5);
  border-radius:50%; transform:translate(-50%,-50%);
  transition: width .3s, height .3s, border-color .3s;
}
body.cursor-hover #cursor-dot  { width:12px; height:12px; }
body.cursor-hover #cursor-ring { width:44px; height:44px; border-color:var(--gold); }

/* ── BOTONES ───────────────────────────────────────────── */
.btn {
  display:inline-flex; align-items:center; gap:8px;
  font-family:var(--font-ui); font-size:12px; font-weight:500;
  letter-spacing:1.5px; text-transform:uppercase;
  padding:14px 28px; border:1.5px solid var(--gold-border);
  color:var(--gold-dark); background:transparent;
  transition:var(--transition); text-decoration:none;
  border-radius:var(--radius); white-space:nowrap;
}
.btn:hover { background:var(--gold-dim); border-color:var(--gold); color:var(--gold); }
.btn-solid {
  background:var(--gold); color:#fff;
  border-color:var(--gold); font-weight:500;
}
.btn-solid:hover { background:var(--gold-dark); border-color:var(--gold-dark); color:#fff; }
.btn-ghost { border-color:var(--border2); color:var(--text2); }
.btn-ghost:hover { border-color:var(--gold-border); color:var(--text); }
button { border:none; background:none; font-family:inherit; }

/* ── BADGE ─────────────────────────────────────────────── */
.badge {
  display:inline-flex; align-items:center; gap:5px;
  font-size:10px; letter-spacing:1px; font-weight:500;
  text-transform:uppercase; padding:4px 10px; border-radius:20px;
}
.badge::before { content:''; width:5px; height:5px; border-radius:50%; }
.badge-disponible { background:rgba(22,163,74,0.10); color:#15803D; }
.badge-disponible::before { background:#16A34A; }
.badge-vendido    { background:rgba(220,38,38,0.10); color:#B91C1C; }
.badge-vendido::before    { background:#DC2626; }
.badge-reservado  { background:rgba(202,138,4,0.12); color:#92400E; }
.badge-reservado::before  { background:#D97706; }

/* ── DIVIDER ───────────────────────────────────────────── */
.divider { width:48px; height:2px; background:var(--gold); opacity:.5; margin:0 auto; }
.divider-left { margin:0; }
.section-label {
  font-size:11px; letter-spacing:4px; text-transform:uppercase;
  color:var(--gold); margin-bottom:10px; font-weight:500;
}

/* ── OVERLAY ───────────────────────────────────────────── */
#overlay {
  position:fixed; inset:0; background:var(--white);
  z-index:1000; display:flex; align-items:center; justify-content:center;
  transition:opacity .6s ease;
}
#overlay.hide { opacity:0; pointer-events:none; }
.overlay-logo {
  font-family:var(--font-display); font-size:52px; font-weight:300;
  letter-spacing:8px; color:var(--gold);
  opacity:0; animation:fadeUp 1s ease .3s forwards;
}
@keyframes fadeUp {
  from { opacity:0; transform:translateY(16px); }
  to   { opacity:1; transform:translateY(0); }
}

/* ── NAVBAR ────────────────────────────────────────────── */
#navbar {
  position:fixed; top:0; left:0; right:0; z-index:100;
  display:flex; align-items:center; justify-content:space-between;
  padding:20px 56px;
  background:rgba(247,245,242,0.0);
  transition:var(--transition);
}
#navbar.scrolled {
  background:rgba(247,245,242,0.96);
  backdrop-filter:blur(16px);
  border-bottom:1px solid var(--border);
  box-shadow:var(--shadow-sm);
  padding:14px 56px;
}
.navbar-logo {
  font-family:var(--font-display); font-size:22px; font-weight:400;
  letter-spacing:3px; color:var(--text);
}
.navbar-logo span { color:var(--gold); }
.navbar-nav { display:flex; gap:36px; }
.navbar-nav a {
  font-size:12px; letter-spacing:1.5px; text-transform:uppercase;
  color:var(--text2); text-decoration:none; font-weight:500;
  transition:color .25s;
}
.navbar-nav a:hover { color:var(--gold); }

/* ── HERO ──────────────────────────────────────────────── */
#hero {
  position:relative; height:100vh;
  display:flex; align-items:center; justify-content:center; overflow:hidden;
}
#hero-bg { position:absolute; inset:0; background:var(--bg2); }
#hero-img {
  position:absolute; inset:0; width:100%; height:100%;
  object-fit:cover; opacity:0; transition:opacity 1.2s ease;
}
#hero-img.loaded { opacity:1; }
.hero-overlay {
  position:absolute; inset:0;
  background:linear-gradient(to bottom, rgba(247,245,242,0.15) 0%, rgba(26,24,20,0.55) 100%);
}
.hero-content {
  position:relative; z-index:2; text-align:center; padding:0 24px;
  animation:fadeUp 1s ease .8s both;
}
.hero-eyebrow {
  font-size:11px; letter-spacing:5px; text-transform:uppercase;
  color:rgba(255,255,255,0.75); margin-bottom:20px; font-weight:400;
}
.hero-title {
  font-family:var(--font-display);
  font-size:clamp(56px,9vw,110px);
  font-weight:300; letter-spacing:0.06em;
  color:#fff; line-height:1.0; margin-bottom:20px;
}
.hero-subtitle {
  font-size:14px; letter-spacing:2px; text-transform:uppercase;
  color:rgba(255,255,255,0.65); margin-bottom:52px; font-weight:300;
}
.hero-actions { display:flex; gap:14px; justify-content:center; }
.hero-actions .btn { border-color:rgba(255,255,255,0.4); color:#fff; background:rgba(255,255,255,0.08); }
.hero-actions .btn:hover { background:rgba(255,255,255,0.18); border-color:rgba(255,255,255,0.7); }
.hero-actions .btn-solid { background:var(--gold); border-color:var(--gold); color:#fff; }
.hero-actions .btn-solid:hover { background:var(--gold-dark); border-color:var(--gold-dark); }

.hero-scroll {
  position:absolute; bottom:40px; left:50%; transform:translateX(-50%);
  display:flex; flex-direction:column; align-items:center; gap:8px;
  color:rgba(255,255,255,0.5); font-size:9px; letter-spacing:3px; text-transform:uppercase;
  animation:fadeUp 1s ease 1.4s both;
}
.scroll-line {
  width:1px; height:40px;
  background:linear-gradient(to bottom,rgba(255,255,255,0.6),transparent);
  animation:scrollLine 2s ease-in-out infinite;
}
@keyframes scrollLine {
  0%   { transform:scaleY(0); transform-origin:top; }
  50%  { transform:scaleY(1); transform-origin:top; }
  51%  { transform:scaleY(1); transform-origin:bottom; }
  100% { transform:scaleY(0); transform-origin:bottom; }
}

/* ── SECCIÓN DISPONIBILIDAD ────────────────────────────── */
#pisos { padding:100px 0; background:var(--bg); }
.pisos-intro { text-align:center; margin-bottom:72px; padding:0 24px; }
.pisos-titulo {
  font-size:clamp(36px,5vw,60px); color:var(--text);
  margin-bottom:16px; letter-spacing:1px;
}
.pisos-desc { font-size:15px; color:var(--text2); letter-spacing:.5px; }

/* ── SELECTOR (render + lista) ─────────────────────────── */
#edificio-selector {
  display:flex; gap:56px; max-width:1240px;
  margin:0 auto; padding:0 56px; align-items:flex-start;
}
.edificio-visual { flex:0 0 400px; position:sticky; top:100px; }

/* Render lateral */
.edificio-render-wrap {
  border-radius:12px; overflow:hidden;
  box-shadow:var(--shadow-md);
  background:var(--bg2);
  aspect-ratio:3/4;
}
.edificio-render-wrap img { width:100%; height:100%; object-fit:cover; display:block; }

/* Leyenda */
.edificio-leyenda {
  display:flex; gap:16px; margin-top:20px; justify-content:center;
  flex-wrap:wrap;
}

/* ── ENCABEZADO DE PISO ────────────────────────────────── */
#pisos-lista { flex:1; display:flex; flex-direction:column; }

.piso-grupo-header {
  display:flex; align-items:center; gap:16px;
  padding:32px 0 12px; border-top:1px solid var(--border);
}
.piso-grupo-header:first-child { border-top:none; padding-top:0; }
.piso-grupo-numero {
  font-family:var(--font-display); font-size:52px; font-weight:300;
  color:var(--bg3); line-height:1; min-width:60px; user-select:none;
}
.piso-grupo-etiqueta {
  font-family:var(--font-display); font-size:26px; font-weight:300;
  letter-spacing:1px; color:var(--text);
}
.piso-grupo-linea { flex:1; height:1px; background:var(--border); }
.piso-grupo-count {
  font-size:11px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text3); font-weight:400;
}

/* ── FILA APARTAMENTO ──────────────────────────────────── */
.apto-row {
  border:1.5px solid var(--border);
  border-radius:var(--radius);
  background:var(--surface);
  margin-bottom:6px;
  overflow:hidden;
  transition:border-color .3s, box-shadow .3s;
  box-shadow:var(--shadow-sm);
}
.apto-row:hover { border-color:var(--gold-border); box-shadow:0 4px 24px rgba(184,147,90,0.12); }
.apto-row.active { border-color:var(--gold); box-shadow:0 4px 24px rgba(184,147,90,0.15); }

.apto-row-main {
  display:flex; align-items:flex-start;
  justify-content:space-between;
  gap:24px; padding:24px 28px; cursor:pointer;
}

.apto-row-left { flex:1; }
.apto-nombre {
  font-family:var(--font-display); font-size:24px; font-weight:400;
  letter-spacing:.5px; color:var(--text); margin-bottom:4px;
}
.apto-specs {
  font-size:13px; letter-spacing:.5px; color:var(--text2);
  margin-bottom:14px; font-weight:400;
}
.apto-features { display:flex; flex-wrap:wrap; gap:6px; }
.apto-feature {
  font-size:11px; color:var(--text2); padding:5px 12px;
  border:1px solid var(--border2); border-radius:20px;
  background:var(--bg); font-weight:400;
}

.apto-row-right {
  display:flex; flex-direction:column;
  align-items:flex-end; gap:10px; flex-shrink:0;
}
.apto-precio {
  font-family:var(--font-display); font-size:26px; font-weight:400;
  color:var(--text); letter-spacing:.5px;
}
.apto-actions { display:flex; gap:8px; align-items:center; margin-top:4px; }
.apto-btn-ver { font-size:11px; padding:10px 18px; }

/* Body expandible */
.apto-row-body {
  max-height:0; overflow:hidden;
  transition:max-height .45s cubic-bezier(0.25,0.46,0.45,0.94);
  border-top:0px solid var(--border);
}
.apto-row.active .apto-row-body {
  max-height:320px;
  border-top-width:1px;
}
.apto-thumb-wrap {
  margin:0 28px 24px;
  height:200px;
  border:1.5px dashed var(--border2);
  border-radius:var(--radius);
  overflow:hidden;
  display:flex; align-items:center; justify-content:center;
  background:var(--bg);
  transition:border-color .3s;
}
.apto-thumb-wrap.loaded { border-style:solid; border-color:var(--border); }
.apto-thumb-placeholder span {
  font-size:11px; letter-spacing:2px; color:var(--text3); text-transform:uppercase;
}

/* ── VISOR DE PLANTA ───────────────────────────────────── */
#visor-planta {
  position:fixed; inset:0; z-index:200;
  background:rgba(247,245,242,0.98); backdrop-filter:blur(20px);
  display:none; flex-direction:column;
  opacity:0; transition:opacity .4s ease;
}
#visor-planta.open { display:flex; opacity:1; }

.visor-header {
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px;
  border-bottom:1px solid var(--border);
  background:var(--white);
  flex-shrink:0;
}
.visor-header-left { display:flex; align-items:center; gap:20px; }
.visor-breadcrumb {
  display:flex; align-items:center; gap:8px;
  font-size:11px; letter-spacing:2px; text-transform:uppercase; color:var(--text2);
  font-weight:500;
}
.visor-breadcrumb .bc-sep   { color:var(--text3); }
.visor-breadcrumb .bc-active{ color:var(--gold); }
.visor-close {
  width:38px; height:38px; display:flex; align-items:center; justify-content:center;
  border:1.5px solid var(--border2); border-radius:50%;
  color:var(--text2); font-size:16px; transition:var(--transition);
  background:transparent;
}
.visor-close:hover { border-color:var(--gold-border); color:var(--gold); background:var(--gold-dim); }

.visor-body { flex:1; display:flex; overflow:hidden; }

/* Panel planta */
.planta-panel {
  flex:0 0 56%; position:relative; overflow:hidden;
  border-right:1px solid var(--border); background:var(--bg);
}
.planta-img-wrap { position:relative; width:100%; height:100%; }
.planta-img-wrap img {
  width:100%; height:100%; object-fit:contain; padding:40px;
}
.planta-placeholder {
  width:100%; height:100%;
  display:flex; align-items:center; justify-content:center;
  flex-direction:column; gap:12px;
}
.planta-placeholder p { font-size:12px; letter-spacing:2px; text-transform:uppercase; color:var(--text3); }

/* Hotspots en planta */
.planta-hotspot { position:absolute; transform:translate(-50%,-50%); z-index:10; }
.hs-btn {
  width:36px; height:36px; border-radius:50%;
  border:2px solid var(--gold);
  background:rgba(184,147,90,0.15);
  display:flex; align-items:center; justify-content:center;
  transition:var(--transition); position:relative; color:var(--gold);
}
.hs-btn::before {
  content:''; position:absolute; inset:-7px; border-radius:50%;
  border:1px solid rgba(184,147,90,0.25);
  animation:hsPulse 2.5s ease-in-out infinite;
}
@keyframes hsPulse {
  0%,100% { transform:scale(1); opacity:.7; }
  50%     { transform:scale(1.2); opacity:.2; }
}
.hs-btn:hover { background:var(--gold); color:#fff; transform:scale(1.1); }
.hs-btn svg { width:14px; height:14px; }
.hs-label {
  position:absolute; bottom:calc(100% + 10px); left:50%;
  transform:translateX(-50%); white-space:nowrap;
  background:var(--text); border-radius:4px;
  padding:5px 10px; font-size:10px; letter-spacing:1px;
  text-transform:uppercase; color:#fff;
  opacity:0; transition:opacity .2s; pointer-events:none;
}
.planta-hotspot:hover .hs-label { opacity:1; }

/* Panel info derecha */
.info-panel {
  flex:1; display:flex; flex-direction:column;
  padding:36px; overflow-y:auto; gap:28px;
  background:var(--white);
}
.info-piso-nombre {
  font-family:var(--font-display); font-size:40px; font-weight:300;
  letter-spacing:1px; color:var(--text);
}
.info-piso-precio {
  font-family:var(--font-display); font-size:32px; font-weight:400;
  color:var(--gold-dark); letter-spacing:.5px;
}
.info-specs-grid { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
.info-spec {
  background:var(--bg); border-radius:var(--radius);
  padding:16px 18px; border:1px solid var(--border);
}
.info-spec-label {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  color:var(--text3); margin-bottom:6px; font-weight:500;
}
.info-spec-value {
  font-family:var(--font-display); font-size:26px;
  color:var(--text); letter-spacing:.5px;
}
.info-caracteristicas { display:flex; flex-direction:column; gap:10px; }
.info-caracteristica {
  display:flex; align-items:center; gap:12px;
  font-size:14px; color:var(--text2); font-weight:400;
}
.info-caracteristica::before {
  content:''; width:24px; height:1.5px; background:var(--gold); flex-shrink:0;
}
.info-espacios-title {
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:var(--gold); margin-bottom:12px; font-weight:500;
}
.info-espacios { display:flex; flex-direction:column; gap:6px; }
.espacio-btn {
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 18px; border:1.5px solid var(--border);
  border-radius:var(--radius); background:var(--bg);
  transition:var(--transition); text-align:left; width:100%; color:var(--text);
}
.espacio-btn:hover { border-color:var(--gold-border); background:var(--gold-dim); }
.espacio-nombre { font-size:14px; font-weight:500; margin-bottom:2px; }
.espacio-area   { font-size:12px; color:var(--text2); }
.espacio-arrow  { color:var(--gold); font-size:18px; }
.info-cta { display:flex; flex-direction:column; gap:10px; margin-top:auto; }

/* ── VISOR PANORAMA 360° ───────────────────────────────── */
#visor-pano {
  position:fixed; inset:0; z-index:300;
  background:#1A1814;
  display:none; opacity:0; transition:opacity .4s ease;
}
#visor-pano.open { display:block; opacity:1; }

.pano-header {
  position:absolute; top:0; left:0; right:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:18px 32px;
  background:linear-gradient(to bottom,rgba(26,24,20,0.85),transparent);
}
.pano-header-left { display:flex; align-items:center; gap:20px; }
.pano-room-tabs { display:flex; gap:4px; }
.pano-tab {
  font-size:10px; letter-spacing:2px; text-transform:uppercase;
  padding:7px 16px; border:1px solid rgba(255,255,255,0.15);
  color:rgba(255,255,255,0.6); border-radius:3px;
  transition:var(--transition); background:rgba(26,24,20,0.5);
  font-weight:500;
}
.pano-tab:hover,.pano-tab.active {
  border-color:rgba(184,147,90,0.6); color:#D4AF82;
  background:rgba(184,147,90,0.12);
}

#pannellum-container { width:100%; height:100%; }

/* Info overlay panorama */
.pano-info-overlay {
  position:absolute; bottom:32px; left:32px; z-index:10;
  background:rgba(247,245,242,0.95); backdrop-filter:blur(12px);
  border:1px solid var(--border2); border-radius:8px;
  padding:18px 22px; max-width:300px;
  box-shadow:var(--shadow-md);
}
.pano-room-name {
  font-family:var(--font-display); font-size:26px; font-weight:300;
  color:var(--text); margin-bottom:4px;
}
.pano-room-desc { font-size:12px; color:var(--text2); line-height:1.6; }

/* Controles */
.pano-controls {
  position:absolute; bottom:32px; right:32px; z-index:10;
  display:flex; gap:8px;
}
.pano-ctrl-btn {
  width:40px; height:40px; border-radius:50%;
  border:1px solid rgba(255,255,255,0.2);
  background:rgba(247,245,242,0.12);
  color:rgba(255,255,255,0.8); display:flex; align-items:center; justify-content:center;
  font-size:18px; transition:var(--transition); backdrop-filter:blur(8px);
}
.pano-ctrl-btn:hover { border-color:rgba(184,147,90,0.6); color:#D4AF82; }

/* Drag hint */
.pano-drag-hint {
  position:absolute; top:50%; left:50%; transform:translate(-50%,-50%);
  z-index:5; text-align:center; pointer-events:none;
  animation:hintFade 3s ease 1s forwards;
}
@keyframes hintFade { 0%{opacity:.8} 100%{opacity:0} }
.pano-drag-hint p {
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.6); margin-top:10px; font-weight:400;
}

/* Brújula */
.pano-compass {
  position:absolute; top:80px; right:32px; z-index:10;
  width:52px; height:52px;
  border:1px solid rgba(255,255,255,0.15); border-radius:50%;
  background:rgba(247,245,242,0.1); backdrop-filter:blur(10px);
  display:flex; align-items:center; justify-content:center;
}
.compass-inner { transition:transform .1s linear; }

/* Loading panorama */
.pano-loading {
  position:absolute; inset:0; z-index:20;
  display:flex; align-items:center; justify-content:center;
  background:#1A1814; flex-direction:column; gap:16px;
}
.pano-loading.hide { opacity:0; pointer-events:none; transition:opacity .5s; }
.loading-ring {
  width:44px; height:44px; border-radius:50%;
  border:1.5px solid rgba(184,147,90,0.15);
  border-top-color:var(--gold);
  animation:spin 1s linear infinite;
}
@keyframes spin { to { transform:rotate(360deg); } }
.loading-text {
  font-size:11px; letter-spacing:3px; text-transform:uppercase;
  color:rgba(255,255,255,0.4); font-weight:400;
}

/* ── CONTACTO ──────────────────────────────────────────── */
#contacto {
  padding:100px 56px; max-width:960px;
  margin:0 auto; text-align:center;
}
.contacto-titulo {
  font-size:clamp(30px,4vw,52px); margin-bottom:14px; color:var(--text);
}
.contacto-sub {
  font-size:15px; letter-spacing:.5px; color:var(--text2); margin-bottom:64px;
}
.contacto-grid {
  display:grid; grid-template-columns:repeat(3,1fr); gap:16px; margin-bottom:48px;
}
.contacto-card {
  background:var(--white); border:1.5px solid var(--border);
  padding:36px 24px; border-radius:10px;
  transition:var(--transition); box-shadow:var(--shadow-sm);
}
.contacto-card:hover {
  border-color:var(--gold-border);
  box-shadow:0 8px 32px rgba(184,147,90,0.12);
  transform:translateY(-2px);
}
.contacto-icon {
  width:44px; height:44px; border:1.5px solid var(--gold-border);
  border-radius:50%; display:flex; align-items:center; justify-content:center;
  margin:0 auto 18px; color:var(--gold);
}
.contacto-label {
  font-size:10px; letter-spacing:3px; text-transform:uppercase;
  color:var(--text3); margin-bottom:10px; font-weight:500;
}
.contacto-valor { font-size:15px; color:var(--text); font-weight:400; }

/* ── FOOTER ────────────────────────────────────────────── */
footer {
  border-top:1px solid var(--border);
  background:var(--white);
  padding:32px 56px;
  display:flex; align-items:center; justify-content:space-between;
}
.footer-logo {
  font-family:var(--font-display); font-size:20px; font-weight:300;
  letter-spacing:3px; color:var(--text2);
}
.footer-logo span { color:var(--gold); }
.footer-copy    { font-size:12px; color:var(--text3); }
.footer-powered { font-size:11px; color:var(--text3); letter-spacing:1px; }

/* ── RESPONSIVE ────────────────────────────────────────── */
@media (max-width:1024px) {
  #edificio-selector { flex-direction:column; padding:0 32px; }
  .edificio-visual { flex:none; width:100%; position:static; }
  .edificio-render-wrap { aspect-ratio:16/9; }
}
@media (max-width:768px) {
  #navbar { padding:16px 24px; }
  #navbar.scrolled { padding:12px 24px; }
  .navbar-nav { display:none; }
  #pisos { padding:72px 0; }
  #edificio-selector { padding:0 20px; }
  .visor-body { flex-direction:column; }
  .planta-panel { flex:0 0 50%; border-right:none; border-bottom:1px solid var(--border); }
  .contacto-grid { grid-template-columns:1fr; }
  footer { flex-direction:column; gap:10px; text-align:center; }
  .pano-room-tabs { display:none; }
  .apto-row-main { flex-direction:column; gap:16px; }
  .apto-row-right { align-items:flex-start; }
  #contacto { padding:72px 24px; }
}
