/* ============ TOKENS — derivados directamente del logo ============ */
:root{
  /* Fondos negros del logo */
  --bg:        #05080d;
  --bg-1:     #0a0f17;
  --bg-2:     #0f1620;
  --bg-3:     #141c28;
  --line:     #1c2533;
  --line-2:   #28344a;

  /* Plata / acero del tridente */
  --silver:   #e6ebf0;
  --silver-2: #b9c1cb;
  --silver-3: #8a93a0;
  --silver-4: #5a6271;

  /* Azul profundo del logo (interior del escudo) */
  --blue-deep:#1e3a8a;
  --blue:     #2557c4;

  /* Cian/celeste brillante (acento de la maqueta) */
  --cyan:     #22d3ee;
  --cyan-2:   #06b6d4;
  --cyan-soft:rgba(34,211,238,.12);

  /* Tipografía */
  --f-display: "Oswald", "Arial Narrow", sans-serif;
  --f-body:    "Inter", system-ui, sans-serif;

  --radius:    14px;
  --radius-lg: 18px;
  --maxw: 1280px;
}

*{box-sizing:border-box}
html,body{margin:0;padding:0}
body{
  background:var(--bg);
  color:var(--silver);
  font-family:var(--f-body);
  font-size:15px;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
button{font-family:inherit;cursor:pointer;border:0;background:none;color:inherit}
img{max-width:100%;display:block}



/* ============ HEADER ============ */
header.site{
  position:sticky;top:0;z-index:50;
  background:rgba(5,8,13,.85);
  backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.navrow{display:flex;align-items:center;gap:32px;height:78px}
.brand{display:flex;align-items:center;gap:12px;flex-shrink:0}
.brand .mark{width:42px;height:42px}
.brand .word{font-family:var(--f-display);font-weight:700;letter-spacing:.04em;
  font-size:22px;color:var(--silver);line-height:1}
.brand .tag{font-size:9.5px;letter-spacing:.22em;color:var(--silver-3);
  text-transform:uppercase;margin-top:3px;font-weight:500}

nav.primary{display:flex;gap:30px;flex:1;justify-content:center}
nav.primary a{
  font-size:14px;font-weight:500;color:var(--silver-2);
  padding:8px 2px;position:relative;transition:color .2s;
}
nav.primary a:hover{color:var(--silver)}
nav.primary a.active{color:var(--silver)}
nav.primary a.active::after{
  content:"";position:absolute;left:0;right:0;bottom:-2px;height:2px;background:var(--cyan);
}

.navtail{display:flex;align-items:center;gap:14px;flex-shrink:0}
.flag{width:26px;height:18px;border-radius:3px;overflow:hidden;display:inline-block;
  background:linear-gradient(to bottom,#74acdf 33%,#fff 33%,#fff 66%,#74acdf 66%);
  border:1px solid var(--line-2)}
.btn-contact{
  display:inline-flex;align-items:center;gap:8px;
  background:var(--cyan);color:#04141a;
  padding:10px 18px;border-radius:10px;font-weight:600;font-size:14px;
  transition:transform .15s, box-shadow .15s;
}
.btn-contact:hover{transform:translateY(-1px);box-shadow:0 6px 22px -4px rgba(34,211,238,.45)}

.menu-toggle{display:none}

/* ============ HERO ============ */
.hero{
  position:relative;overflow:hidden;
  padding:72px 0 56px;
  background:
    radial-gradient(900px 500px at 75% 35%, rgba(34,211,238,.10), transparent 65%),
    radial-gradient(700px 400px at 80% 70%, rgba(30,58,138,.18), transparent 60%),
    var(--bg);
}
.hero h1{
  font-family:var(--f-display);font-weight:700;
  font-size:clamp(44px, 5.6vw, 78px);line-height:.98;letter-spacing:.005em;
  margin:0 0 18px;color:#fff;
}
.hero h1 .accent{color:var(--cyan);display:block}
.hero p.lead{
  font-size:16px;color:var(--silver-2);max-width:430px;margin:0 0 28px;
}

.search-row{
  grid-template-columns:1fr 1fr auto;gap:10px;max-width:540px;margin-bottom:22px;
}
.select{
  background:var(--bg-2);border:1px solid var(--line-2);border-radius:10px;
  padding:13px 16px;display:flex;align-items:center;gap:10px;color:var(--silver-2);
  font-size:14px;cursor:pointer;transition:border-color .15s;
}
.select:hover{border-color:var(--cyan-2)}
.select.light{background:#eef1f5;color:#0f1620;border-color:#eef1f5}
.select .chev{margin-left:auto;opacity:.6}
.btn-search{
  background:var(--cyan);color:#04141a;border-radius:10px;
  padding:13px 22px;font-weight:600;font-size:14px;display:flex;align-items:center;gap:8px;
  white-space:nowrap;
}

.quicklinks{display:flex;gap:12px;flex-wrap:wrap}
.ql{
  display:inline-flex;align-items:center;gap:10px;
  padding:14px 20px;border:1px solid var(--line-2);border-radius:12px;
  background:rgba(15,22,32,.6);font-size:14px;font-weight:500;color:var(--silver);
  transition:border-color .15s, background .15s;
}
.ql:hover{border-color:var(--cyan-2);background:rgba(34,211,238,.05)}
.ql.feature{
  background:var(--cyan);color:#04141a;border-color:var(--cyan);
  flex-direction:column;align-items:flex-start;gap:0;padding:10px 22px;
}
.ql.feature .small{font-size:11.5px;font-weight:500;opacity:.8}
.ql.feature .big{display:flex;align-items:center;gap:8px;font-weight:600}

.hero-art{position:relative;aspect-ratio:16/11;border-radius:var(--radius-lg);overflow:hidden;
  background:linear-gradient(135deg,#0a0f17,#1a2334)}

/* ============ EMPRESAS DESTACADAS ============ */

.eyebrow{
  font-family:var(--f-display);font-weight:600;letter-spacing:.18em;
  font-size:14px;color:var(--silver);text-transform:uppercase;
  text-align:center;margin:0 0 28px;
}
.eyebrow.left{text-align:left;font-size:13px;letter-spacing:.22em;color:var(--silver-3);margin-bottom:18px}

.empcard{
  background:var(--bg-2);border:1px solid var(--line);border-radius:12px;
  height:78px;display:flex;align-items:center;justify-content:center;
  transition:border-color .15s, transform .15s;
  font-family:var(--f-display);font-weight:700;letter-spacing:.04em;font-size:22px;
}
.empcard:hover{border-color:var(--line-2);transform:translateY(-2px)}
.empcard.plusmar{background:linear-gradient(180deg,#c81d25 0%, #f4c918 100%);color:#1a1a1a;
  text-shadow:1px 1px 0 rgba(0,0,0,.2);font-style:italic}
.empcard.iserin{background:#fff;color:#0d2c4d;letter-spacing:.06em}
.empcard.nogal{background:#0d1a17;color:#d4a449;font-size:13px;line-height:1.05;text-align:center;letter-spacing:.06em}
.empcard.nogal small{display:block;font-size:11px;color:#fff;letter-spacing:.04em;margin-top:2px}
.empcard.bonsur{background:#0a1b14;color:#f7e600;font-style:italic;text-decoration:underline;text-decoration-color:#f7e600;text-underline-offset:4px}
.empcard.vertodas{flex-direction:column;gap:6px;font-size:13px;font-family:var(--f-body);font-weight:500;letter-spacing:0;color:var(--silver-2)}

/* ============ UNIDADES DESTACADAS ============ */
.titlerow{display:flex;align-items:flex-end;justify-content:space-between;margin-bottom:22px}
.seeall{font-size:13.5px;color:var(--cyan);font-weight:500;display:inline-flex;gap:8px;align-items:center}
.seeall:hover{text-decoration:underline}

.unitslider{position:relative}
.unit{height:100%}
.unit{
  background:var(--bg-2);border:1px solid var(--line);border-radius:14px;
  overflow:hidden;display:flex;flex-direction:column;
  transition:transform .2s, border-color .2s;
}
.unit:hover{transform:translateY(-3px);border-color:var(--line-2)}
.unit .photo{
  aspect-ratio:4/3;position:relative;background:#0e1620;
  border-bottom:1px solid var(--line);
}
.unit .badge-emp{
  position:absolute;top:10px;right:10px;
  padding:5px 10px;border-radius:6px;font-family:var(--f-display);font-weight:700;
  font-size:12px;letter-spacing:.04em;
}
.unit .badge-emp.plusmar{background:linear-gradient(180deg,#c81d25,#f4c918);color:#1a1a1a;font-style:italic}
.unit .badge-emp.iserin{background:#fff;color:#0d2c4d}
.unit .badge-emp.nogal{background:#0d1a17;color:#d4a449}
.unit .badge-emp.bonsur{background:#0a1b14;color:#f7e600;font-style:italic}
.unit .badge-fin{
  position:absolute;left:10px;bottom:-1px;
  background:rgba(34,211,238,.95);color:#04141a;
  padding:5px 12px;border-radius:6px 6px 0 0;font-size:11.5px;font-weight:600;
}
.unit .body{padding:16px 18px 18px;display:flex;flex-direction:column;gap:6px}
.unit h3{
  margin:0;font-family:var(--f-display);font-weight:600;font-size:18px;letter-spacing:.02em;color:#fff;
}
.unit .year{font-size:13px;color:var(--cyan);font-weight:500}
.unit .price{font-family:var(--f-display);font-weight:700;font-size:22px;color:#fff;margin-top:4px}
.unit .loc{font-size:12.5px;color:var(--silver-3);display:flex;align-items:center;gap:6px;margin-top:2px}
.btn-consult{
  margin-top:14px;
  display:flex;align-items:center;justify-content:center;gap:9px;
  background:transparent;border:1px solid var(--line-2);
  padding:11px;border-radius:10px;font-size:13.5px;font-weight:500;color:var(--silver);
  transition:border-color .15s, background .15s;
}
.btn-consult:hover{border-color:var(--cyan);background:var(--cyan-soft);color:var(--cyan)}

.arrow{
  position:absolute;top:38%;width:38px;height:38px;border-radius:50%;
  background:rgba(15,22,32,.85);border:1px solid var(--line-2);color:var(--silver);
  display:flex;align-items:center;justify-content:center;cursor:pointer;
  transition:background .15s;
}
.arrow:hover{background:var(--cyan);color:#04141a;border-color:var(--cyan)}
.arrow.left{left:-18px}
.arrow.right{right:-18px}

.dots{display:flex;gap:8px;justify-content:center;margin-top:24px}
.dots span{width:8px;height:8px;border-radius:50%;background:var(--line-2)}
.dots span.on{background:var(--cyan);width:22px;border-radius:4px}

/* ============ ZONA + FINANCIACIÓN ============ */
.col-panel .panel{height:100%}
.panel{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:28px;
}
.panel h2{
  font-family:var(--f-display);font-weight:700;font-size:24px;letter-spacing:.04em;
  margin:0 0 8px;color:#fff;text-transform:uppercase;
}
.panel p.sub{margin:0 0 18px;font-size:14px;color:var(--silver-3)}

.zona{display:grid;grid-template-columns:auto 1fr;gap:22px;align-items:center}
.map-svg{width:130px;height:auto}
.zonalist{display:flex;flex-direction:column;gap:2px}
.zonalist a{
  display:flex;align-items:center;justify-content:space-between;
  padding:10px 14px;border-radius:8px;font-size:14px;font-weight:500;color:var(--silver);
  transition:background .15s;
}
.zonalist a:hover{background:var(--bg-3)}
.zonalist a .arr{color:var(--cyan);opacity:.7}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--line-2);padding:10px 16px;border-radius:9px;
  font-size:13.5px;font-weight:500;color:var(--silver);margin-top:8px;
  transition:border-color .15s, color .15s;
}
.btn-outline:hover{border-color:var(--cyan);color:var(--cyan)}

.fin-grid{display:grid;grid-template-columns:1fr auto;gap:24px;align-items:center}
.fin-content{display:flex;flex-direction:column;gap:16px}
.fin-list{display:flex;flex-direction:column;gap:14px;font-size:14.5px;color:var(--silver)}
.fin-list li{display:flex;align-items:center;gap:12px;list-style:none}
.fin-list .check{
  width:22px;height:22px;border-radius:50%;border:1.5px solid var(--cyan);
  display:flex;align-items:center;justify-content:center;color:var(--cyan);flex-shrink:0;
}
.fin-list{padding:0;margin:0}
.fin-art{width:170px;color:var(--cyan);opacity:.85}

.btn-primary-fin{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg, #22d3ee 0%, #06b6d4 100%);
  padding:14px 24px;border-radius:12px;
  font-size:14px;font-weight:600;color:#04141a;
  transition:transform .2s, box-shadow .2s;
  border:none;cursor:pointer;text-decoration:none;
}
.btn-primary-fin:hover{
  transform:translateY(-2px);
  box-shadow:0 8px 20px rgba(34, 211, 238, 0.4);
}

/* ============ TRUST BAR ============ */
.trust{
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);
  padding:28px;
}
.trust .item{display:flex;flex-direction:column;align-items:center;gap:8px;justify-content:center;text-align:center}
@media (min-width:992px){
  .trust .item{flex-direction:row;gap:16px;text-align:left}
}
.trust .ico{
  width:44px;height:44px;border-radius:10px;
  color:var(--cyan);display:flex;align-items:center;justify-content:center;flex-shrink:0;
}
.trust .lab{
  font-family:var(--f-display);font-weight:600;letter-spacing:.06em;font-size:13.5px;
  color:#fff;text-transform:uppercase;line-height:1.15;
}

/* ============ SOBRE + CTA ============ */
.about-cta{
  margin-top:18px;
  background:var(--bg-2);border:1px solid var(--line);border-radius:var(--radius-lg);overflow:hidden;
}
.about-cta .left{padding:36px;border-right:1px solid var(--line);height:100%}
.about-cta .right{height:100%}
.about-cta .left h2{font-family:var(--f-display);font-weight:700;font-size:26px;color:#fff;
  text-transform:uppercase;letter-spacing:.04em;margin:0 0 14px}
.about-cta .left p{font-size:14px;color:var(--silver-2);margin:0 0 12px}
.about-cta .right{
  position:relative;padding:36px;
  background:
    linear-gradient(120deg, rgba(10,15,23,.85) 0%, rgba(10,15,23,.45) 60%, rgba(10,15,23,.2) 100%),
    radial-gradient(800px 300px at 80% 100%, rgba(30,58,138,.4), transparent 70%),
    #0a0f17;
}
.about-cta .right h2{font-family:var(--f-display);font-weight:700;font-size:30px;color:#fff;
  text-transform:uppercase;letter-spacing:.03em;margin:0 0 12px;line-height:1.05}
.about-cta .right p{font-size:14.5px;color:var(--silver-2);margin:0 0 24px}
.cta-btns{display:flex;gap:12px;flex-wrap:wrap}
.btn-primary{
  display:inline-flex;align-items:center;gap:10px;
  background:var(--cyan);color:#04141a;padding:13px 22px;border-radius:10px;font-weight:600;font-size:14.5px;
}
.btn-primary:hover{filter:brightness(1.08)}
.btn-secondary{
  display:inline-flex;align-items:center;gap:10px;
  border:1px solid var(--line-2);padding:13px 22px;border-radius:10px;font-weight:500;font-size:14.5px;color:var(--silver);
}
.btn-secondary:hover{border-color:var(--cyan);color:var(--cyan)}

/* ============ FOOTER ============ */
footer.site{
  border-top:1px solid var(--line);padding:34px 0 18px;background:var(--bg-1);
}
.footbrand{display:flex;align-items:center;gap:12px}
.footbrand .word{font-family:var(--f-display);font-weight:700;letter-spacing:.04em;font-size:20px}
.footbrand .tag{font-size:9px;letter-spacing:.22em;color:var(--silver-3);text-transform:uppercase;margin-top:2px}

.socials{display:flex;gap:16px;justify-content:center}
.socials a{
  width:38px;height:38px;border-radius:8px;background:var(--bg-3);
  display:flex;align-items:center;justify-content:center;color:var(--cyan);
  transition:background .15s;
}
.socials a:hover{background:var(--cyan);color:#04141a}

.footloc{font-size:13.5px;color:var(--silver-2);text-align:right;display:flex;align-items:center;justify-content:flex-end;gap:14px}
.footloc .lines{display:flex;flex-direction:column;align-items:flex-end}

.footbottom{
  margin-top:24px;padding-top:18px;border-top:1px solid var(--line);
  display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;
  font-size:12.5px;color:var(--silver-3);
}
.footlinks{display:flex;gap:24px}
.footlinks a:hover{color:var(--cyan)}

/* ============ RESPONSIVE ============ */
@media (max-width: 991.98px){
  .hero-art{order:-1;aspect-ratio:16/9}
  .about-cta .left{border-right:0;border-bottom:1px solid var(--line)}
  .footloc{justify-content:center;text-align:center}
  .footloc .lines{align-items:center}
}
@media (max-width: 767.98px){
  .wrap{padding:0 18px}
  nav.primary,.flag{display:none}
  .menu-toggle{display:flex;width:40px;height:40px;border:1px solid var(--line-2);border-radius:8px;
    align-items:center;justify-content:center;color:var(--silver)}
  .navrow{height:64px}
  .brand .word{font-size:18px}
  .brand .mark{width:36px;height:36px}
  
  .hero{padding:48px 0 36px}
  .hero h1{font-size:42px}
  .search-row{grid-template-columns:1fr 1fr;gap:8px}
  .btn-search{grid-column:span 2}
  .panel,.about-cta .left,.about-cta .right{padding:24px}
  .footbottom{justify-content:center;text-align:center}
}

/* ============ BREADCRUMB ============ */
.crumb-inner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  flex-wrap: wrap;
}

.crumb-path {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  font-size: 14px;
  color: var(--silver-2);
}

.crumb-path a {
  color: var(--silver-2);
  transition: color .2s;
  white-space: nowrap;
}

.crumb-path a:hover {
  color: var(--cyan);
}

.crumb-path .cur {
  color: var(--silver);
  font-weight: 500;
  white-space: nowrap;
}

.crumb-path .sep {
  color: var(--silver-4);
  flex-shrink: 0;
}

.crumb-actions {
  display: flex;
  align-items: center;
  gap: 16px;
  flex-shrink: 0;
}

.crumb-actions a {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 13px;
  color: var(--silver-3);
  transition: color .2s;
}

.crumb-actions a:hover {
  color: var(--cyan);
}

@media (max-width: 767.98px) {
  .crumb-inner {
    flex-direction: column;
    align-items: flex-start;
    gap: 12px;
  }
  
  .crumb-path {
    font-size: 12px;
    gap: 4px;
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    -ms-overflow-style: none;
    flex-wrap: nowrap;
    padding-bottom: 4px;
  }
  
  .crumb-path::-webkit-scrollbar {
    display: none;
  }
  
  .crumb-actions {
    width: 100%;
    justify-content: flex-start;
  }
}

/* ============ PUBBY / PUBLISHER SECTION ============ */
.pubby {
  background: linear-gradient(135deg, var(--bg-2) 0%, var(--bg-1) 100%);
  border: 1px solid var(--line);
  border-radius: var(--radius-lg);
  padding: 32px;
  margin-top: 24px;
}

.pubby .logo-emp {
  width: 100%;
  height: 100%;
  min-height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--cyan-soft) 0%, transparent 60%);
  border: 1px solid var(--line-2);
  border-radius: var(--radius);
  font-family: var(--f-display);
  font-size: 24px;
  font-weight: 700;
  color: var(--cyan);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.pubby .meta-emp .small {
  font-size: 12px;
  color: var(--silver-3);
  text-transform: uppercase;
  letter-spacing: .1em;
  margin-bottom: 4px;
}

.pubby .meta-emp .nm {
  font-family: var(--f-display);
  font-size: 28px;
  font-weight: 700;
  color: var(--silver);
  margin-bottom: 8px;
}

.pubby .meta-emp .desc {
  font-size: 14px;
  color: var(--silver-2);
  line-height: 1.6;
  margin-bottom: 16px;
}

.pubby .btn-emp {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--bg-3);
  color: var(--silver);
  padding: 10px 16px;
  border-radius: 8px;
  font-size: 13px;
  font-weight: 500;
  border: 1px solid var(--line-2);
  transition: all .2s ease;
}

.pubby .btn-emp:hover {
  background: var(--cyan);
  color: var(--bg);
  border-color: var(--cyan);
}

.pubby .stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 8px;
  padding: 20px 16px;
  background: var(--bg-1);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  height: 100%;
  justify-content: center;
}

.pubby .stat .ico {
  color: var(--cyan);
}

.pubby .stat .ico svg {
  filter: drop-shadow(0 0 8px rgba(34, 211, 238, 0.3));
}

.pubby .stat .num {
  font-family: var(--f-display);
  font-size: 22px;
  font-weight: 700;
  color: var(--silver);
  line-height: 1;
}

.pubby .stat .lab {
  font-size: 12px;
  color: var(--silver-3);
  line-height: 1.4;
}

.pubby .rating {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  text-align: center;
  gap: 4px;
  padding: 20px 16px;
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.1) 0%, transparent 100%);
  border: 1px solid var(--line-2);
  border-radius: var(--radius);
  height: 100%;
}

.pubby .rating .num {
  font-size: 13px;
  color: var(--silver-2);
  font-weight: 500;
}

.pubby .rating .stars {
  font-size: 18px;
  color: #fbbf24;
  letter-spacing: 2px;
  text-shadow: 0 0 10px rgba(251, 191, 36, 0.4);
}

.pubby .rating .reviews {
  font-size: 12px;
  color: var(--silver-3);
}

@media (max-width: 991.98px) {
  .pubby {
    padding: 24px;
  }
  .pubby .logo-emp {
    min-height: 80px;
  }
  .pubby .stat,
  .pubby .rating {
    padding: 16px 12px;
  }
}

@media (max-width: 767.98px) {
  .pubby {
    padding: 20px;
  }
  .pubby .meta-emp .nm {
    font-size: 22px;
  }
  .pubby .stat .num {
    font-size: 18px;
  }
}

/* ============ SPEC CARDS ============ */
.spec-card {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 18px 16px;
  background: var(--bg-2);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  transition: all .2s ease;
}
.spec-card:hover {
  border-color: var(--line-2);
  background: var(--bg-3);
}
.spec-card .ico {
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: linear-gradient(135deg, var(--cyan-soft) 0%, transparent 100%);
  border: 1px solid var(--line-2);
  border-radius: 10px;
  flex-shrink: 0;
}
.spec-card .ico i {
  font-size: 18px;
  color: var(--cyan);
}
.spec-card .lab {
  font-size: 12px;
  color: var(--silver-3);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 2px;
}
.spec-card .val {
  font-size: 15px;
  font-weight: 600;
  color: var(--silver);
}
