*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
:root{
  --verde:#214530;--crema:#DFD8C4;--bronce:#9F835C;--marron:#352016;
  --hueso:#F5F2E9;--blanco:#FFFFFF;
  --serif:'EB Garamond',serif;
  --sans:'Inter',sans-serif;
  --garamond:'EB Garamond',serif;
}
html{scroll-behavior:smooth}
body{font-family:var(--sans);background:var(--hueso);color:var(--marron);overflow-x:hidden}
::-webkit-scrollbar{width:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--bronce)}

/* ── NAV ── */
nav{position:fixed;top:0;left:0;width:100%;height:80px;display:flex;justify-content:space-between;align-items:center;padding:0 60px;z-index:1000;background:rgba(245,242,233,0.95);backdrop-filter:blur(14px);border-bottom:1px solid rgba(159,131,92,0.15);transition:background .3s}
.logo-group{display:flex;align-items:center;gap:0}
.logo-principal-mobile-link{display:none;text-decoration:none;line-height:0}
.logo-principal-mobile{display:block}
.logo-img{height:70px;display:flex;align-items:center;flex-shrink:0;text-decoration:none}
.logo-img img{height:100%;width:auto;object-fit:contain;transform:scale(1.5);transform-origin:left center}
.logo-wordmark{display:flex;align-items:center;text-decoration:none;margin-left:8px}
.logo-wordmark-name{font-family:var(--serif);font-size:18px;color:var(--verde);letter-spacing:2px;font-weight:400}
.admin-login-btn{background:none;border:none;cursor:pointer;color:rgba(33,69,48,0.4);padding:8px;margin-left:8px;transition:color .2s}
.admin-login-btn:hover{color:var(--verde)}
.nav-center{display:flex;gap:40px;position:absolute;left:50%;transform:translateX(-50%)}
.nav-link{font-family:var(--sans);text-decoration:none;color:#1A2E22;font-size:12px;letter-spacing:1px;text-transform:uppercase;font-weight:500;position:relative;transition:color .3s}
.nav-link::after{content:'';position:absolute;bottom:-4px;left:0;width:0;height:1px;background:#1A2E22;transition:width .3s}
.nav-link:hover::after,.nav-link.active-link::after{width:100%}
.nav-link.active-link{color:var(--bronce)}
.nav-link.active-link::after{background:var(--bronce)}
.nav-right{display:flex;gap:16px;align-items:center}
.btn-nav-outline{font-family:var(--sans);background:transparent;color:#1A2E22;border:1px solid #1A2E22;padding:10px 24px;font-size:12px;letter-spacing:1px;text-transform:uppercase;text-decoration:none;cursor:pointer;transition:all .3s;font-weight:500}
.btn-nav-outline:hover{background:#1A2E22;color:var(--hueso)}
.btn-nav-solid{font-family:var(--sans);background:#1A2E22;color:var(--hueso);padding:11px 24px;font-size:12px;letter-spacing:1px;text-transform:uppercase;text-decoration:none;border:none;cursor:pointer;transition:all .3s;font-weight:500}
.btn-nav-solid:hover{background:var(--marron)}
.mobile-menu-btn{display:none;background:none;border:none;color:#1A2E22;cursor:pointer;padding:8px;z-index:1001}
.mobile-nav-footer{display:none}
.admin-bar{display:none;position:fixed;top:0;left:0;right:0;background:var(--bronce);color:#fff;padding:8px 20px;font-size:11px;z-index:2000;justify-content:space-between;align-items:center}
.search-backdrop{display:none}

/* ── CATALOG HERO — Liquid header with gradient dissolve ── */
.catalog-hero{
  margin-top:80px;
  padding: 80px 5% 0;
  background: linear-gradient(to bottom, var(--crema) 0%, var(--crema) 70%, var(--hueso) 100%);
  text-align:center;
}
.catalog-hero .eyebrow{
  font-family:var(--sans);font-size:10px;font-weight:600;
  letter-spacing:0.25em;text-transform:uppercase;
  color:var(--bronce);margin-bottom:18px;
}
.catalog-hero h1, .catalog-hero .catalog-hero-title-visual{
  font-family:var(--serif);font-size:clamp(2.4rem,5vw,3.8rem);
  color:var(--verde);font-weight:400;letter-spacing:-0.02em;
  margin-bottom:14px;line-height:1.15;
}
.catalog-hero p{
  font-family:var(--sans);font-size:14px;color:var(--verde);
  opacity:0.65;max-width:460px;margin:0 auto;line-height:1.7;
  padding-bottom:60px;
}

/* ── HORIZON CONSOLE — Single-line filter bar ── */
.horizon-console{
  position:sticky;top:80px;z-index:500;
  background:rgba(245,242,233,0.97);
  backdrop-filter:blur(20px);
  border-bottom:1px solid rgba(159,131,92,0.18);
  padding:0 80px;
  height:60px;
  display:flex;align-items:center;gap:0;
}
.hc-sentence{
  display:flex;align-items:center;gap:0;
  font-family:var(--garamond);font-size:17px;color:rgba(53,32,22,0.55);
  flex:1;white-space:nowrap;overflow:hidden;
}
.hc-static{margin:0 4px;}
/* Elegant ultra-thin gold underline for inputs */
.hc-input{
  font-family:var(--garamond);font-size:17px;color:var(--marron);
  background:transparent;border:none;
  border-bottom:0.5px solid rgba(159,131,92,0.45);
  outline:none;padding:2px 6px 2px 2px;min-width:60px;width:auto;
  transition:border-color .25s;cursor:text;
  text-decoration-line:none;
}
.hc-input:focus{border-bottom-color:rgba(33,69,48,0.7);}
.hc-input::placeholder{color:rgba(53,32,22,0.28);font-style:italic;}
.hc-price-display,.hc-area-display{
  font-family:var(--garamond);font-size:17px;color:var(--verde);
  cursor:pointer;
  border-bottom:0.5px dotted rgba(159,131,92,0.5);
  padding:2px 4px;transition:color .2s;position:relative;
}
.hc-price-display:hover,.hc-area-display:hover{color:var(--bronce);}
.hc-sep{margin:0 8px;color:rgba(159,131,92,0.4);}
.hc-divider{width:1px;height:28px;background:rgba(159,131,92,0.2);margin:0 20px;}
.hc-divider-slim{margin:0 12px;opacity:0.6;}

/* Op Pills (Venta/Alquiler) */
.hc-op-pills{
  display:flex;gap:6px;align-items:center;
  flex-shrink:0;
}
.hc-pill.hc-op-alquiler.active {
  background:#1e293b; border-color:#1e293b;
}

.hc-type-pills{
  display:flex;gap:6px;align-items:center;
  overflow-x:auto;overflow-y:hidden;
  scrollbar-width:none;
  -webkit-overflow-scrolling:touch;
  position:relative;
  padding-right:28px;
}
@media (max-width: 992px) {
  .hc-type-pills {
    -webkit-mask-image: linear-gradient(to right, black 75%, transparent 100%);
    mask-image: linear-gradient(to right, black 75%, transparent 100%);
  }
}
.hc-type-pills::-webkit-scrollbar{display:none;}
.hc-pill{
  font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;padding:5px 12px;cursor:pointer;
  border:1px solid rgba(159,131,92,0.25);color:rgba(53,32,22,0.45);
  background:transparent;transition:all .2s;
}
.hc-pill:hover{border-color:var(--verde);color:var(--verde);}
.hc-pill.active{background:var(--verde);color:var(--crema);border-color:var(--verde);}
.hc-more-btn{
  font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(53,32,22,0.4);background:transparent;
  border:none;cursor:pointer;display:flex;align-items:center;gap:6px;
  padding:5px 0;transition:color .2s;margin-left:12px;white-space:nowrap;
}
.hc-more-btn:hover{color:var(--verde);}
.hc-more-btn svg{transition:transform .25s;}
.hc-more-btn.open svg{transform:rotate(180deg);}
.hc-results{
  font-family:var(--sans);font-size:10px;letter-spacing:1px;
  text-transform:uppercase;color:rgba(53,32,22,0.35);margin-left:auto;white-space:nowrap;
}

/* ── ADVANCED PANEL — translucent dropdown ── */
.adv-panel{
  position:sticky;top:140px;z-index:499;
  background:rgba(245,242,233,0.92);
  backdrop-filter:blur(24px);
  border-bottom:1px solid rgba(159,131,92,0.12);
  max-height:0;overflow:hidden;
  transition:max-height .4s cubic-bezier(0,0,.2,1);
}
.adv-panel.open{max-height:220px;}
.adv-panel-inner{
  padding:22px 80px 24px;
  display:flex;flex-wrap:wrap;gap:32px;align-items:center;
}
.adv-group{display:flex;flex-direction:column;gap:10px;}
.adv-label{
  font-family:var(--sans);font-size:8px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;color:rgba(53,32,22,0.35);
}
.adv-range-wrap{display:flex;flex-direction:column;gap:4px;min-width:200px;}
.adv-range-val{
  font-family:var(--garamond);font-size:15px;color:var(--verde);
}
input[type="range"].adv-slider{
  -webkit-appearance:none;width:100%;height:1px;
  background:rgba(159,131,92,0.3);outline:none;cursor:pointer;
}
input[type="range"].adv-slider::-webkit-slider-thumb{
  -webkit-appearance:none;width:12px;height:12px;
  background:var(--verde);cursor:pointer;border-radius:50%;
  border:2px solid var(--hueso);outline:1px solid var(--verde);
}
.adv-checks{display:flex;flex-wrap:wrap;gap:8px 20px;}
.adv-check{
  display:flex;align-items:center;gap:7px;cursor:pointer;
  font-family:var(--sans);font-size:11px;color:rgba(53,32,22,0.6);
  transition:color .2s;
}
.adv-check:hover{color:var(--verde);}
.adv-check input[type="checkbox"]{display:none;}
.adv-checkmark{
  width:11px;height:11px;border:1px solid rgba(159,131,92,0.4);
  flex-shrink:0;position:relative;transition:all .2s;
}
.adv-check input:checked + .adv-checkmark{background:var(--verde);border-color:var(--verde);}
.adv-check input:checked + .adv-checkmark::after{
  content:'';position:absolute;left:2px;top:-1px;
  width:4px;height:7px;border:1.5px solid var(--crema);
  border-left:none;border-top:none;transform:rotate(45deg);
}
.adv-rooms-pills{display:flex;gap:6px;}
.adv-room-pill{
  font-family:var(--sans);font-size:10px;font-weight:600;letter-spacing:.5px;
  padding:5px 11px;border:1px solid rgba(159,131,92,0.25);
  color:rgba(53,32,22,0.45);background:transparent;cursor:pointer;transition:all .2s;
}
.adv-room-pill:hover{border-color:var(--verde);color:var(--verde);}
.adv-room-pill.active{background:var(--verde);color:var(--crema);border-color:var(--verde);}
.adv-reset{
  font-family:var(--sans);font-size:9px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:rgba(53,32,22,0.35);background:transparent;
  border:1px solid rgba(159,131,92,0.2);padding:7px 14px;cursor:pointer;
  transition:all .2s;margin-left:auto;align-self:flex-end;
}
.adv-reset:hover{border-color:var(--bronce);color:var(--marron);}

/* ── CATALOGUE MAIN ── */
.catalogue-main{
  max-width:1600px;margin:0 auto;
  padding:80px 120px 120px;
}

/* ── EDITORIAL ASYMMETRIC GRID ── */
.editorial-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  grid-template-rows:auto auto;
  gap:3px;
}

/* Featured card (first) spans full width */
.editorial-grid .ec-featured{
  grid-column:1 / -1;
}

/* When few items (≤3), add large side margins */
.editorial-grid.few-items{
  max-width:1160px;margin:0 auto;
}

/* Skeleton loading */
.ec-skeleton{
  background:linear-gradient(90deg,var(--crema) 25%,rgba(223,216,196,0.5) 50%,var(--crema) 75%);
  background-size:200% 100%;
  animation:shimmer 1.6s infinite;
  height:520px;
}
@keyframes shimmer{0%{background-position:200% 0}100%{background-position:-200% 0}}

/* ── EDITORIAL CARD (no-border experience) ── */
.ec{
  position:relative;overflow:hidden;cursor:pointer;
  background:var(--marron);
}
.ec-featured{height:62vh;min-height:480px;max-height:680px;}
.ec-secondary{height:46vh;min-height:360px;max-height:520px;}

/* Image layer */
.ec-img-wrap{
  position:absolute;inset:0;overflow:hidden;
}
.ec-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;opacity:0;
  transition:opacity .5s ease;
  transform:scale(1.0);
}
.ec-img.active{opacity:1;}
/* Ken Burns on hover */
.ec:hover .ec-img.active{
  animation:kenBurns 4s ease forwards;
}
@keyframes kenBurns{
  from{transform:scale(1.0);}
  to{transform:scale(1.04);}
}

/* Gradient overlay — deep contrast for text legibility */
.ec-overlay{
  position:absolute;inset:0;
  background:linear-gradient(to top, rgba(0,0,0,0.82) 0%, rgba(0,0,0,0.38) 42%, rgba(0,0,0,0.08) 70%, rgba(0,0,0,0) 100%);
  pointer-events:none;z-index:2;
}

/* Gallery arrows */
.ec-arrow{
  position:absolute;top:50%;transform:translateY(-50%);
  width:36px;height:36px;background:rgba(255,255,255,0.08);
  border:0.5px solid rgba(255,255,255,0.3);color:#fff;
  display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;z-index:4;
  transition:opacity .3s,background .2s;backdrop-filter:blur(4px);
}
.ec:hover .ec-arrow{opacity:1;}
.ec-arrow:hover{background:rgba(255,255,255,0.2);}
.ec-arrow--prev{left:16px;}
.ec-arrow--next{right:16px;}
.ec-gallery-count{
  position:absolute;top:20px;right:20px;z-index:4;
  font-family:var(--sans);font-size:9px;font-weight:500;
  letter-spacing:2px;color:rgba(255,255,255,0.7);
  background:rgba(0,0,0,0.25);backdrop-filter:blur(6px);
  padding:4px 10px;border:0.5px solid rgba(255,255,255,0.15);
}

/* Tag badge */
.ec-tag{
  position:absolute;top:20px;left:20px;z-index:4;
  font-family:var(--sans);font-size:8.5px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:5px 14px;
  border-radius: 30px !important;
  background: var(--verde) !important;
  color: #FAF9F6 !important;
  border: 1px solid rgba(201, 168, 76, 0.35) !important;
  box-shadow: 0 2px 6px rgba(26, 46, 34, 0.15);
  transition: all 0.3s ease;
}
.ec-tag.vendido{background:#c62828 !important;color:#fff !important;border:none !important;}
.ec-tag.exclusiva,.ec-tag.nuevo,.ec-tag.destacado,.ec-tag.oportunidad,.ec-tag.off-market{
  background: var(--verde) !important;
  color: #FAF9F6 !important;
  border: 1px solid rgba(201, 168, 76, 0.35) !important;
}

/* ── Operación label (EN VENTA / EN ALQUILER) */
.prop-op-label{
  position:absolute;top:16px;right:16px;z-index:5;
  font-family:var(--sans);font-size:8px;font-weight:700;
  letter-spacing:2px;text-transform:uppercase;
  padding:5px 10px;pointer-events:none;
  backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);
}
.prop-op-venta  {background:rgba(26,46,34,0.75);color:rgba(245,242,232,0.95);}
.prop-op-alquiler{background:rgba(20,55,100,0.70);color:rgba(235,244,255,0.95);}

/* Info block — typography integrated on image */
.ec-info{
  position:absolute;bottom:0;left:0;right:0;z-index:3;
  padding:32px 28px 22px;
}
.ec-featured .ec-info{padding:40px 40px 30px;}
.ec-price{
  font-family:var(--serif);font-size:26px;font-weight:400;
  color:var(--crema);line-height:1;margin-bottom:10px;
}
.ec-featured .ec-price{font-size:34px;}
.ec-name{
  font-family:var(--serif);font-size:17px;font-weight:400;
  color:rgba(245,242,233,0.9);margin-bottom:10px;line-height:1.35;
}
.ec-featured .ec-name{font-size:22px;}
.ec-meta{
  font-family:var(--sans);font-size:10px;letter-spacing:1.5px;
  color:rgba(223,216,196,0.6);display:flex;gap:14px;
}
.ec-meta span{display:flex;align-items:center;gap:4px;}

/* Hover reveal CTA */
.ec-hover-cta{
  position:absolute;inset:0;z-index:5;
  display:flex;align-items:flex-end;justify-content:flex-end;
  padding:24px;pointer-events:none;
  opacity:0;transition:opacity .35s ease;
}
.ec:hover .ec-hover-cta{opacity:1;}
.ec-hover-cta-inner{
  font-family:var(--sans);font-size:9px;font-weight:700;
  letter-spacing:2.5px;text-transform:uppercase;
  color:var(--crema);display:flex;align-items:center;gap:8px;
  border-bottom:1px solid rgba(245,242,233,0.4);padding-bottom:3px;
}

/* ── EC META — middle-dot separators with breathing room ── */
.ec-meta{
  font-family:var(--sans);font-size:10px;letter-spacing:1px;
  color:rgba(223,216,196,0.65);display:flex;flex-wrap:wrap;gap:0;
  align-items:center;
}
.ec-meta span{
  display:flex;align-items:center;
}
.ec-meta span + span::before{
  content:'·';
  margin:0 8px;
  color:rgba(223,216,196,0.45);
  font-size:12px;
}

/* ── MINIMAL PAGINATION ── */
.catalogue-pagination{
  display:flex;align-items:center;justify-content:center;
  gap:0;margin-top:80px;padding:0 120px 20px;
}
.pag-track{
  display:flex;align-items:center;gap:0;
  position:relative;
}
.pag-line{
  width:200px;height:1px;background:rgba(159,131,92,0.2);
  position:relative;margin:0 24px;
}
.pag-line-fill{
  position:absolute;top:0;left:0;height:100%;
  background:var(--bronce);transition:width .4s ease;
}
.pag-num{
  font-family:var(--sans);font-size:11px;font-weight:500;
  letter-spacing:1.5px;color:rgba(53,32,22,0.3);
  cursor:pointer;transition:opacity .25s,color .25s;
  padding:6px 10px;
  background:transparent;border:none;
}
.pag-num:hover{color:var(--verde);}
.pag-num.active{color:var(--verde);font-weight:600;opacity:1;}
.pag-prev,.pag-next{
  background:transparent;border:none;
  color:rgba(53,32,22,0.3);cursor:pointer;
  display:flex;align-items:center;padding:6px;
  transition:color .2s;
}
.pag-prev:hover,.pag-next:hover{color:var(--verde);}
.pag-prev:disabled,.pag-next:disabled{opacity:0.2;cursor:default;}

/* ── NO RESULTS ── */
.no-results-msg{
  text-align:center;padding:80px 40px;
  font-family:var(--serif);font-size:28px;font-weight:400;
  color:rgba(53,32,22,0.3);
}

/* ── REVEAL ANIMATION ── */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .55s ease,transform .55s ease;}
.reveal.visible{opacity:1;transform:translateY(0);}

/* ── FOOTER PREMIUM (from landing.css shared styles) ── */
footer {
    background-color: var(--verde);
    padding: 35px 60px 14px;
    color: var(--hueso);
    position: relative;
    background-image:
        repeating-linear-gradient(45deg, rgba(245,242,232,0.035) 0px, rgba(245,242,232,0.035) 1px, transparent 1px, transparent 10px),
        repeating-linear-gradient(-45deg, rgba(245,242,232,0.035) 0px, rgba(245,242,232,0.035) 1px, transparent 1px, transparent 10px);
}
.footer-grid { display: grid; grid-template-columns: 2fr 1fr 1fr 1fr; gap: 60px; margin-bottom: 22px; }
.footer-brand { padding-bottom: 0; }
.footer-links h5, .footer-links h4 { margin-bottom: 14px; }
.footer-links li { margin-bottom: 8px; }
.footer-logo {
    font-family: 'EB Garamond', serif;
    font-size: 28px;
    letter-spacing: 4px;
    margin-bottom: 16px;
    color: #F5F2E8;
    -webkit-text-fill-color: #F5F2E8;
    background: transparent !important;
    background-clip: unset !important;
    -webkit-background-clip: unset !important;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
    display: inline-block;
}
/* Separadores verticales entre columnas */
.footer-links {
    border-left: 0.5px solid rgba(245, 242, 232, 0.12);
    padding-left: 40px;
}
.footer-links h5, .footer-links h4 {
    font-size: 11px;
    letter-spacing: 3px;
    text-transform: uppercase;
    font-variant: small-caps;
    margin-bottom: 30px;
    color: #C9A84C;
    text-shadow: 0 0 8px rgba(201,168,76,0.25);
}
.footer-links ul { list-style: none; }
.footer-links li { margin-bottom: 15px; }
.footer-links a { color: rgba(223, 216, 196, 0.6); text-decoration: none; font-size: 15px; transition: 0.3s; }
.footer-links a:hover { color: var(--hueso); }

/* ── NEWSLETTER BOUTIQUE ────────────────────────────────────────── */
.newsletter-section {
    display: flex;
    justify-content: space-between;
    align-items: center;
    gap: 60px;
    padding-bottom: 35px;
    margin-bottom: 0;
}
.newsletter-text {
    flex: 0 0 38%;
}
.newsletter-text h4, .newsletter-text h3 {
    font-family: 'Playfair Display', serif;
    font-size: 36px;
    margin: 0 0 14px;
    font-weight: 500;
    line-height: 1.15;
    background: linear-gradient(135deg, #E8C97A 0%, #C9A84C 40%, #F0D98A 70%, #B8922E 100%);
    -webkit-background-clip: text;
    -webkit-text-fill-color: transparent;
    background-clip: text;
    filter: drop-shadow(0 1px 2px rgba(0,0,0,0.3));
}
.newsletter-text p {
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    color: rgba(245, 242, 232, 0.65);
    line-height: 1.65;
    margin: 0;
    font-weight: 300;
}
.newsletter-form-container {
    flex: 0 0 54%;
}
.newsletter-form {
    display: flex;
    flex-direction: column;
    gap: 14px;
}
/* Barra input+botón con borde exterior único */
.newsletter-input-group {
    display: flex;
    align-items: stretch;
    gap: 10px;
    border: 1px solid rgba(245, 242, 232, 0.55);
    transition: border-color 0.3s ease;
}
.newsletter-input-group:focus-within {
    border-color: #F5F2E8;
}
#newsletter-input {
    flex: 1;
    background: transparent !important;
    background-color: transparent !important;
    -webkit-appearance: none;
    border: none;
    color: #F5F2E8 !important;
    font-family: 'Inter', sans-serif;
    font-size: 14px;
    padding: 13px 20px;
    outline: none;
    min-width: 0;
    box-shadow: none !important;
}
#newsletter-input:-webkit-autofill,
#newsletter-input:-webkit-autofill:hover,
#newsletter-input:-webkit-autofill:focus {
    -webkit-box-shadow: 0 0 0 1000px #1A2E22 inset !important;
    -webkit-text-fill-color: #F5F2E8 !important;
    transition: background-color 5000s ease-in-out 0s;
}
#newsletter-input::placeholder {
    color: rgba(245, 242, 232, 0.45);
    font-weight: 300;
}
.newsletter-btn {
    background: #F5F2E8;
    color: #1a2e22;
    border: none;
    padding: 0 32px;
    font-family: 'Inter', sans-serif;
    font-size: 11px;
    font-weight: 800;
    letter-spacing: 2.5px;
    text-transform: uppercase;
    cursor: pointer;
    transition: background-color 0.3s ease, color 0.3s ease, opacity 0.3s ease;
    white-space: nowrap;
    flex-shrink: 0;
    box-shadow: 0 2px 10px rgba(0,0,0,0.15), inset 0 1px 0 rgba(255,255,255,0.15);
}
.newsletter-btn:disabled {
    opacity: 0.45;
    cursor: not-allowed;
}
.newsletter-btn:not(:disabled):hover {
    background-color: #ffffff;
    color: #111f17;
}
.newsletter-privacy {
    display: flex;
    align-items: flex-start;
    gap: 12px;
    cursor: pointer;
}
.newsletter-privacy input[type="checkbox"] {
    margin-top: 2px;
    accent-color: #F5F2E8;
    cursor: pointer;
    width: 15px;
    height: 15px;
    flex-shrink: 0;
}
.newsletter-privacy span {
    font-family: 'Inter', sans-serif;
    font-size: 10px;
    color: rgba(245, 242, 232, 0.65);
    line-height: 1.5;
    font-weight: 300;
}
.newsletter-divider {
    width: 100%;
    height: 0.5px;
    background: rgba(245, 242, 232, 0.18);
    margin-bottom: 45px;
}

/* ── MOBILE ── */
@media(max-width:1200px){
  .catalogue-main{padding:60px 60px 80px;}
  .horizon-console{padding:0 40px;}
  .adv-panel-inner{padding:20px 40px;}
  .catalogue-pagination{padding:0 60px 20px;}
}
@media(max-width:992px){
  nav{padding:0 24px;}
  .nav-center,.nav-right{display:none;}
  .mobile-menu-btn{display:block;}
  .logo-wordmark{display:none !important;}
  .logo-img{display:none !important;}
  .logo-principal-mobile-link{display:block;flex-shrink:0;z-index:1001;}
  .logo-principal-mobile{
    display:block;
    height:22px;
    width:auto;
    object-fit:contain;
    flex-shrink:0;
    z-index:1001;
  }
  nav.menu-open{height:100vh;background:#F5F2E8!important;backdrop-filter:none;align-items:flex-start;}
  nav.menu-open .nav-center{display:flex;flex-direction:column;position:absolute;top:140px;left:0;width:100%;padding:0 20px;align-items:center;gap:15px;transform:none;}
  nav.menu-open .nav-link{font-family:var(--serif);font-size:24px;text-transform:uppercase;letter-spacing:2px;color:var(--verde);font-weight:400;}
  nav.menu-open .nav-link::after{display:none;}
  nav.menu-open .nav-right{display:flex;flex-direction:column;position:absolute;bottom:40px;left:0;width:100%;padding:0 30px;gap:12px;align-items:stretch;}
  nav.menu-open .btn-nav-outline,nav.menu-open .btn-nav-solid{text-align:center;height:42px;display:flex;align-items:center;justify-content:center;font-size:11px;letter-spacing:3px;}
  nav.menu-open .mobile-nav-footer{display:flex;flex-direction:column;align-items:center;gap:12px;margin-top:20px;}
  .mnf-socials{display:flex;gap:16px;color:rgba(33,69,48,0.5);}
  .mnf-socials a{color:inherit;transition:color .3s;}
  .editorial-grid{grid-template-columns:1fr;}
  .editorial-grid .ec-featured{grid-column:1;}
  .ec-featured{height:55vw;min-height:280px;}
  .ec-secondary{height:45vw;min-height:240px;}
  .catalogue-main{padding:40px 24px 60px;}
  /* Horizon console — mobile harmonious flow */
  .horizon-console{
    padding:12px 20px;height:auto;min-height:56px;
    flex-direction:column;align-items:flex-start;gap:10px;
  }
  .hc-sentence{
    flex-wrap:wrap;align-items:baseline;
    gap:5px;font-size:16px;line-height:1.8;
    width:100%;
  }
  .hc-static{font-size:16px;line-height:1.8;}
  .hc-input{font-size:16px;}
  .hc-price-display,.hc-area-display{font-size:16px;}
  /* Prevent lone words hanging on their own line */
  .hc-sentence .hc-static + .hc-price-display,
  .hc-sentence .hc-static + .hc-area-display{
    white-space:nowrap;
  }
  .hc-divider{display:none;}
  /* Pills row: full width, masked fade to right */
  .hc-type-pills{
    gap:5px;width:100%;
    -webkit-mask-image:linear-gradient(to right, black 75%, transparent 100%);
    mask-image:linear-gradient(to right, black 75%, transparent 100%);
    padding-right:32px;
  }
  .hc-more-btn{align-self:flex-end;margin-left:0;}
  .hc-results{display:none;}
  .adv-panel-inner{padding:18px 20px;gap:20px;}
  footer {
      padding: 24px 24px 20px;
      background-color: var(--verde);
      background-image:
          repeating-linear-gradient(45deg, rgba(245,242,232,0.035) 0px, rgba(245,242,232,0.035) 1px, transparent 1px, transparent 10px),
          repeating-linear-gradient(-45deg, rgba(245,242,232,0.035) 0px, rgba(245,242,232,0.035) 1px, transparent 1px, transparent 10px);
  }

  /* ── Newsletter ── */
  .newsletter-section {
      flex-direction: column;
      gap: 0;
      padding-bottom: 0;
      margin-bottom: 0;
  }
  .newsletter-text {
      flex: none;
      width: 100%;
      margin-bottom: 14px;
  }
  .newsletter-text h4::before, .newsletter-text h3::before {
      content: '\2726';
      display: block;
      font-size: 16px;
      color: #F5F2E8;
      margin-bottom: 10px;
      -webkit-text-fill-color: #F5F2E8;
      text-shadow: 0 0 8px rgba(245, 242, 232, 0.4);
  }
  .newsletter-text h4, .newsletter-text h3 {
      font-size: 26px;
      font-weight: 600;
      line-height: 1.2;
      background: linear-gradient(135deg, #E8C97A 0%, #C9A84C 40%, #F0D98A 70%, #B8922E 100%);
      -webkit-background-clip: text;
      -webkit-text-fill-color: transparent;
      background-clip: text;
      margin: 0 0 14px;
      filter: drop-shadow(0 1px 2px rgba(0,0,0,0.4));
      background-color: transparent !important;
  }
  .newsletter-text p {
      font-size: 13px;
      line-height: 1.8;
      color: rgba(245,242,232,0.65);
  }
  .newsletter-form-container {
      flex: none;
      width: 100%;
      background: rgba(201,168,76,0.04);
      border: 0.5px solid rgba(201,168,76,0.2);
      padding: 14px;
      margin-bottom: 18px;
      box-sizing: border-box;
  }
  .newsletter-form { gap: 18px; }
  .newsletter-input-group {
      flex-direction: column;
      gap: 16px;
      border: none;
      background: transparent;
  }
  #newsletter-input {
      border: none !important;
      border-bottom: 1px solid rgba(201,168,76,0.45) !important;
      padding: 10px 0 !important;
      font-size: 14px;
  }
  #newsletter-input:-webkit-autofill,
  #newsletter-input:-webkit-autofill:focus {
      -webkit-box-shadow: 0 0 0 1000px #111f17 inset !important;
  }
  .newsletter-btn {
      width: 100%;
      padding: 14px;
      background: #F5F2E8;
      color: #1a2e22;
      font-size: 11px;
      font-weight: 800;
      letter-spacing: 3px;
      border: none;
      box-shadow: 0 2px 12px rgba(0,0,0,0.15), inset 0 1px 0 rgba(255,255,255,0.2);
  }
  .newsletter-btn:not(:disabled):hover {
      background-color: #ffffff;
      color: #111f17;
  }
  .newsletter-privacy { gap: 10px; align-items: center; }
  .newsletter-privacy input[type="checkbox"] { display: none; }
  .newsletter-privacy::before {
      content: '';
      display: inline-flex;
      align-items: center;
      justify-content: center;
      width: 16px;
      height: 16px;
      min-width: 16px;
      background: #F5F2E8;
      color: #1a2e22;
      font-size: 10px;
      font-weight: 900;
      border-radius: 2px;
      box-shadow: 0 1px 4px rgba(0,0,0,0.15);
      transition: background-color 0.2s ease, border-color 0.2s ease;
  }
  .newsletter-privacy:has(input[type="checkbox"]:checked)::before {
      content: '\2713';
  }
  .newsletter-privacy span { font-size: 10px; color: rgba(245,242,232,0.55); }
  .newsletter-divider {
      background: linear-gradient(90deg, transparent, rgba(201,168,76,0.3), transparent);
      height: 1px;
      margin-bottom: 18px;
  }

  /* ── Identidad de Marca (footer-brand full-width) ── */
  .footer-grid {
      grid-template-columns: 1fr 1fr;
      grid-template-rows: auto auto auto;
      gap: 0;
      margin-bottom: 14px;
  }
  /* footer-brand ocupa las 2 columnas */
  .footer-grid > .footer-brand {
      grid-column: 1 / -1;
      grid-row: 1;
  }
  /* EXPLORAR — columna izquierda, abarca filas 2 y 3 */
  .footer-grid > .footer-links:nth-child(2) {
      grid-column: 1;
      grid-row: 2 / 4;
      border-right: 0.5px solid rgba(201,168,76,0.12);
      padding-right: 14px;
      margin-bottom: 0;
  }
  /* COMPAÑÍA — columna derecha, fila 2 */
  .footer-grid > .footer-links:nth-child(3) {
      grid-column: 2;
      grid-row: 2;
      padding-left: 14px;
      border-top: 0.5px solid rgba(201,168,76,0.15);
      margin-bottom: 0;
  }
  /* CONTACTO — columna derecha, fila 3 */
  .footer-grid > .footer-links:nth-child(4) {
      grid-column: 2;
      grid-row: 3;
      padding-left: 14px;
      border-top: 0.5px solid rgba(201,168,76,0.15);
      margin-bottom: 0;
  }
  .footer-logo {
      font-size: 30px;
      letter-spacing: 7px;
      color: #F5F2E8;
      -webkit-text-fill-color: #F5F2E8;
      background: transparent !important;
      background-clip: unset !important;
      -webkit-background-clip: unset !important;
      filter: drop-shadow(0 1px 3px rgba(0,0,0,0.5));
      margin-bottom: 10px;
  }
  #footer-p {
      font-size: 13px !important;
      line-height: 1.7 !important;
      color: rgba(223,216,196,0.5) !important;
      padding-bottom: 14px;
  }
  #footer-p::after {
      content: ' \2726';
      color: rgba(245, 242, 232, 0.6);
      font-size: 10px;
  }

  /* ── Capítulos de Autor (estilos comunes) ── */
  .footer-links {
      border-left: none;
      border-top: 0.5px solid rgba(201,168,76,0.15);
      padding-left: 0;
      padding-top: 10px;
      margin-bottom: 0;
  }
  .footer-links:nth-child(2) h5::before, .footer-links:nth-child(2) h4::before { content: '\25CE\0020'; }
  .footer-links:nth-child(3) h5::before, .footer-links:nth-child(3) h4::before { content: '\2767\0020'; }
  .footer-links:nth-child(4) h5::before, .footer-links:nth-child(4) h4::before { content: '\25C8\0020'; }
  .footer-links h5, .footer-links h4 {
      color: #C9A84C;
      font-size: 10px;
      letter-spacing: 4px;
      margin-bottom: 14px;
      text-shadow: 0 0 8px rgba(201,168,76,0.25);
  }
  .footer-links li {
      margin-bottom: 6px;
      padding-left: 14px;
      position: relative;
  }
  .footer-links li::before {
      content: '\2014';
      position: absolute;
      left: 0;
      color: rgba(201,168,76,0.35);
      font-size: 10px;
      line-height: 1.8;
  }
  .footer-links a {
      font-family: 'EB Garamond', serif;
      font-size: 16px;
      color: rgba(223,216,196,0.7);
      letter-spacing: 0.02em;
  }
  .footer-links a:hover { color: #C9A84C; }
  
  /* Center bottom legal bar */
  .footer-bottom-bar {
      flex-direction: column !important;
      justify-content: center !important;
      text-align: center !important;
      gap: 16px !important;
      padding-bottom: 20px;
  }
  .footer-bottom-bar > #footer-copy {
      order: 1 !important;
  }
  .footer-bottom-bar > .footer-legal-links {
      order: 2 !important;
      justify-content: center !important;
      flex-wrap: wrap !important;
  }
  .footer-bottom-bar > .footer-credit {
      order: 3 !important;
  }
}
@media(max-width:600px){
  .ec-featured{height:72vw;min-height:240px;}
  .ec-secondary{height:58vw;min-height:210px;}
  .ec-featured .ec-price{font-size:24px;}
  .ec-featured .ec-name{font-size:16px;}
  .ec-info{padding:24px 20px 20px;}
  .ec-featured .ec-info{padding:28px 20px 22px;}
  /* Tighter meta on mobile */
  .ec-meta{font-size:9px;letter-spacing:0.5px;}
  .ec-meta span + span::before{margin:0 5px;}
  .catalogue-pagination{padding:0 20px 20px;}
  .pag-line{width:80px;}
  /* Advanced panel stacks nicely */
  .adv-panel-inner{flex-direction:column;gap:18px;}
  .adv-range-wrap{min-width:unset;width:100%;}
  .adv-checks{gap:8px 12px;}
}

/* ── Unified Premium Mobile Nav Overlay (Lyvanto Boutique Style) ── */
.mobile-only-link {
    display: none !important;
}

@media (max-width: 992px) {
    /* 1. Backdrop Navigation container with fade-in and 10px slide-down */
    nav.menu-open {
        height: 100vh !important;
        background: #1A2E22 !important; /* Deep Forest Green luxury backdrop */
        backdrop-filter: blur(16px) !important;
        -webkit-backdrop-filter: blur(16px) !important;
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-start !important;
        border-bottom: 1px solid rgba(166, 137, 102, 0.15) !important;
        box-shadow: 0 10px 40px rgba(0, 0, 0, 0.2) !important;
        padding-top: 0 !important;
        opacity: 0;
        transform: translateY(-10px) !important;
        animation: menuOverlayFadeIn 0.4s cubic-bezier(0.16, 1, 0.3, 1) forwards !important;
    }

    @keyframes menuOverlayFadeIn {
        to {
            opacity: 1;
            transform: translateY(0) !important;
        }
    }

    /* 2. Top Header alignment: Logo on the left, "X" on the right */
    nav.menu-open .logo-group {
        position: absolute !important;
        top: 32px !important;
        left: 24px !important;
        transform: none !important;
        display: flex !important;
        align-items: center !important;
        margin: 0 !important;
        padding: 0 !important;
        z-index: 1002 !important;
    }
    
    nav.menu-open .logo-img {
        margin: 0 !important;
        padding: 0 !important;
        display: none !important;
    }

    nav.menu-open .logo-img img {
        height: 38px !important;
        filter: brightness(0) invert(1) !important;
        transform: scale(1.4) !important;
        transform-origin: left center !important;
    }

    nav.menu-open .logo-principal-mobile {
        display: block !important;
        height: 26px !important;
        width: auto !important;
        filter: brightness(0) invert(1) !important;
    }

    nav.menu-open .mobile-menu-btn {
        position: absolute !important;
        top: 32px !important;
        right: 24px !important;
        color: #F5F2E8 !important; /* Premium cream color for close icon */
        background: transparent !important;
        border: none !important;
        z-index: 1002 !important;
        display: block !important;
        padding: 6px !important;
    }

    /* Animation of rotation on appear for close icon */
    nav.menu-open .mobile-menu-btn svg {
        width: 24px !important;
        height: 24px !important;
        stroke: currentColor !important;
        stroke-width: 1.2 !important;
        transform: rotate(-90deg);
        opacity: 0;
        animation: rotateX 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.1s forwards !important;
    }

    @keyframes rotateX {
        to {
            transform: rotate(0);
            opacity: 1;
        }
    }

    /* 3. Center Section: Links (Generous padding, EB Garamond, fine line under active/hover) */
    nav.menu-open .nav-center {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: center !important;
        position: absolute !important;
        top: 44% !important;
        left: 0 !important;
        width: 100% !important;
        gap: 11px !important;
        padding: 0 20px !important;
        transform: translateY(-50%) !important;
        background: transparent !important;
        opacity: 0;
        animation: menuCenterSlideDown 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.15s forwards !important;
    }

    @keyframes menuCenterSlideDown {
        from {
            opacity: 0;
            transform: translateY(calc(-50% - 10px)) !important;
        }
        to {
            opacity: 1;
            transform: translateY(-50%) !important;
        }
    }

    nav.menu-open .nav-link {
        font-family: 'EB Garamond', serif !important; /* High-end brand typography */
        font-size: 19px !important; /* Slightly smaller size as requested to fit perfectly */
        font-weight: 400 !important;
        letter-spacing: 2.5px !important; /* Elegant slightly reduced letter spacing */
        color: #F5F2E8 !important; /* Cream text */
        text-transform: uppercase !important;
        text-decoration: none !important;
        padding: 6px 0 !important; /* Generous breathing room */
        position: relative !important;
        transition: all 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
        opacity: 0.8 !important;
        line-height: 1.3 !important;
        text-align: center !important;
        display: block !important;
        width: 100% !important;
    }

    /* Long and fine horizontal line that appears under hover / active */
    nav.menu-open .nav-link::after {
        content: "" !important;
        position: absolute !important;
        bottom: 2px !important;
        left: 50% !important;
        transform: translateX(-50%) !important;
        width: 0% !important;
        height: 1px !important;
        background-color: #A68966 !important; /* Bronze/gold color */
        transition: width 0.4s cubic-bezier(0.165, 0.84, 0.44, 1) !important;
        display: block !important;
    }

    nav.menu-open .nav-link::before {
        display: none !important;
    }

    nav.menu-open .nav-link:hover::after,
    nav.menu-open .nav-link.active-link::after {
        width: 120px !important; /* Long and fine horizontal line */
    }

    nav.menu-open .nav-link:hover,
    nav.menu-open .nav-link.active-link {
        color: #A68966 !important; /* Luxury bronze color on hover / active */
        opacity: 1 !important;
        letter-spacing: 4px !important;
    }

    nav.menu-open .mobile-only-link {
        display: block !important;
    }

    /* 4. Bottom Section: Social Icons (no contact button on mobile) */
    nav.menu-open .nav-right {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        justify-content: flex-end !important;
        position: absolute !important;
        bottom: 75px !important;
        left: 0 !important;
        width: 100% !important;
        padding: 0 40px !important;
        gap: 24px !important;
        background: transparent !important;
        border: none !important;
        opacity: 0;
        animation: menuRightSlideDown 0.5s cubic-bezier(0.16, 1, 0.3, 1) 0.25s forwards !important;
    }

    @keyframes menuRightSlideDown {
        from {
            opacity: 0;
            transform: translateY(10px) !important;
        }
        to {
            opacity: 1;
            transform: translateY(0) !important;
        }
    }

    /* Hide contact button on mobile menu */
    nav.menu-open .btn-nav-solid {
        display: none !important;
    }

    nav.menu-open .btn-nav-outline {
        display: none !important; /* Hide secondary outlines in menu if any */
    }

    /* Social icons — 4 icons row */
    nav.menu-open .mobile-nav-footer {
        display: flex !important;
        flex-direction: column !important;
        align-items: center !important;
        gap: 16px !important;
        margin-top: 0 !important;
    }

    nav.menu-open .mnf-socials {
        display: flex !important;
        gap: 28px !important;
        align-items: center !important;
    }

    nav.menu-open .mnf-socials a {
        display: flex !important;
        align-items: center !important;
        justify-content: center !important;
        width: 44px !important;
        height: 44px !important;
        border: 1px solid rgba(245, 242, 232, 0.15) !important;
        border-radius: 50% !important;
        color: rgba(245, 242, 232, 0.6) !important;
        text-decoration: none !important;
        transition: all 0.35s cubic-bezier(0.25, 0.46, 0.45, 0.94) !important;
    }

    nav.menu-open .mnf-socials a:hover {
        color: #A68966 !important;
        border-color: rgba(166, 137, 102, 0.4) !important;
        background: rgba(166, 137, 102, 0.08) !important;
        transform: translateY(-2px) !important;
    }

    nav.menu-open .mnf-copyright {
        font-family: 'Inter', sans-serif !important;
        font-size: 10px !important; /* Discreet copyright */
        letter-spacing: 1.5px !important;
        color: rgba(245, 242, 232, 0.25) !important;
        text-align: center !important;
        text-transform: uppercase !important;
    }
}

/* ── FOOTER CONTACT NUMBERS BOOST ── */
.footer-links a[href^="tel:"] {
    font-size: 18px !important;
}
.footer-links a[href^="tel:"] span {
    font-size: 11px !important;
}
@media (max-width: 768px) {
    .footer-links a[href^="tel:"] {
        font-size: 20px !important;
    }
    .footer-links a[href^="tel:"] span {
        font-size: 12px !important;
    }
}

/* ── NEWSLETTER TITLE COLOR BY USER REQUEST ── */
.newsletter-text h4, .newsletter-text h3, #newsletter-h4 {
    background: none !important;
    -webkit-background-clip: initial !important;
    -webkit-text-fill-color: #F5F2E8 !important; /* Beautiful premium bone white/crema */
    color: #F5F2E8 !important;
    background-clip: initial !important;
}


/* ── High-Quality Cropped Branding Wordmark Image styling ── */
.logo-wordmark-name-img {
    height: 28px;
    width: auto;
    display: block;
    object-fit: contain;
    transition: opacity 0.3s ease;
}
.logo-wordmark:hover .logo-wordmark-name-img {
    opacity: 0.8;
}