:root{
  --re-bg:#05060f;
  --re-bg2:#080a17;
  --re-panel:rgba(14,18,38,.78);
  --re-panel2:rgba(21,28,56,.9);
  --re-text:#f8fbff;
  --re-muted:#9ba8c6;
  --re-cyan:#00e5ff;
  --re-magenta:#ff2bd6;
  --re-purple:#7b3cff;
  --re-gold:#ffd166;
  --re-green:#39ff88;
  --re-red:#ff3b63;
  --re-line:rgba(255,255,255,.13);
  --re-shadow:0 22px 70px rgba(0,0,0,.55);
  --re-radius:24px;
  --re-max:1200px;
}

*{
  box-sizing:border-box;
}

html{
  scroll-behavior:smooth;
}

body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Arial,sans-serif;
  color:var(--re-text);
  background:
    radial-gradient(circle at 10% 0%, rgba(0,229,255,.22), transparent 28%),
    radial-gradient(circle at 90% 10%, rgba(255,43,214,.18), transparent 30%),
    linear-gradient(180deg,#04040b 0%,#080a17 42%,#05060f 100%);
}

body:before{
  content:"";
  position:fixed;
  inset:0;
  pointer-events:none;
  background:
    linear-gradient(rgba(255,255,255,.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,.018) 1px, transparent 1px);
  background-size:38px 38px;
  mask-image:linear-gradient(to bottom,#000,transparent 86%);
  opacity:.65;
  z-index:-1;
}

a{
  color:inherit;
  text-decoration:none;
}

img{
  display:block;
  max-width:100%;
}

.re-wrap{
  max-width:var(--re-max);
  margin:auto;
  padding:0 20px;
}

/* HEADER */

.re-topbar{
  position:sticky;
  top:0;
  z-index:9999;
  background:rgba(3,5,15,.74);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--re-line);
}

.re-nav{
  height:76px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:22px;
  position:relative;
}

.re-brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex-shrink:0;
}

.re-brand-mark{
  width:48px;
  height:48px;
  border-radius:16px;
  background:linear-gradient(135deg,rgba(0,229,255,.95),rgba(123,60,255,.95) 50%,rgba(255,43,214,.95));
  display:grid;
  place-items:center;
  box-shadow:0 0 28px rgba(0,229,255,.35), inset 0 0 18px rgba(255,255,255,.22);
  transform:skew(-7deg);
  font-weight:1000;
  letter-spacing:-.08em;
  color:#fff;
  text-shadow:0 0 14px rgba(255,255,255,.55);
}

.re-brand-text strong{
  display:block;
  font-size:1.25rem;
  letter-spacing:-.04em;
  line-height:1;
}

.re-brand-text small{
  display:block;
  color:var(--re-muted);
  font-weight:800;
  font-size:.76rem;
  text-transform:uppercase;
  letter-spacing:.12em;
  margin-top:4px;
}

/* MENU ESCRITORIO */

.re-menu{
  display:block;
}

.re-menu ul{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  gap:18px;
  align-items:center;
}

.re-menu li{
  position:relative;
}

.re-menu a,
.re-menu summary{
  opacity:.86;
  color:#d8dff3;
  font-weight:850;
  cursor:pointer;
}

.re-menu a:hover,
.re-menu summary:hover,
.re-menu .is-active{
  opacity:1;
  color:var(--re-cyan);
}

.re-menu details{
  position:relative;
}

.re-menu summary{
  list-style:none;
}

.re-menu summary::-webkit-details-marker{
  display:none;
}

.re-menu summary:after{
  content:"▾";
  font-size:.7rem;
  margin-left:7px;
  color:var(--re-cyan);
}

.re-menu details[open] summary:after{
  content:"▴";
}

.re-dropdown{
  position:absolute;
  top:calc(100% + 18px);
  left:50%;
  transform:translateX(-50%);
  min-width:270px;
  display:none;
  flex-direction:column;
  gap:6px;
  padding:10px;
  border:1px solid rgba(255,255,255,.14);
  border-radius:18px;
  background:rgba(5,6,15,.98);
  backdrop-filter:blur(18px);
  box-shadow:0 22px 70px rgba(0,0,0,.65);
  z-index:99999;
}

.re-menu details[open] .re-dropdown{
  display:flex;
}

.re-dropdown li{
  width:100%;
}

.re-dropdown li a{
  display:block;
  width:100%;
  padding:12px 14px;
  border-radius:13px;
  color:#d8dff3;
  background:rgba(255,255,255,.045);
  border:1px solid rgba(255,255,255,.06);
  white-space:nowrap;
}

.re-dropdown li a:hover{
  color:var(--re-cyan);
  background:rgba(0,229,255,.08);
  border-color:rgba(0,229,255,.22);
}

.re-add{
  border:1px solid rgba(0,229,255,.35);
  background:linear-gradient(135deg,rgba(0,229,255,.16),rgba(255,43,214,.12));
  color:#fff !important;
  border-radius:999px;
  padding:12px 17px;
  box-shadow:0 0 22px rgba(0,229,255,.12);
}

.re-menu-toggle{
  display:none;
}

/* HERO */

.re-hero{
  position:relative;
  min-height:560px;
  display:flex;
  align-items:center;
  overflow:hidden;
  isolation:isolate;
  border-bottom:1px solid var(--re-line);
}

.re-hero:before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,#05060f 0%,rgba(5,6,15,.9) 35%,rgba(5,6,15,.52) 68%,#05060f 100%),
    linear-gradient(180deg,rgba(5,6,15,.12),#05060f 100%),
    var(--hero-bg) center/cover no-repeat;
  filter:saturate(1.25) contrast(1.05);
  z-index:-2;
}

.re-hero:after{
  content:"";
  position:absolute;
  inset:-20%;
  background:
    radial-gradient(circle at 68% 42%, rgba(0,229,255,.22), transparent 24%),
    radial-gradient(circle at 84% 32%, rgba(255,43,214,.19), transparent 24%),
    linear-gradient(transparent 50%, rgba(0,0,0,.16) 50%);
  background-size:auto,auto,100% 4px;
  animation:rePulse 5s infinite alternate ease-in-out;
  z-index:-1;
  opacity:.85;
}

@keyframes rePulse{
  from{transform:translate3d(0,0,0)}
  to{transform:translate3d(-1.5%,1%,0)}
}

.re-hero-content{
  max-width:860px;
  /*padding:70px 20px;*/
  padding:30px 20px;
}

.re-kicker{
  display:inline-flex;
  align-items:center;
  gap:8px;
  color:#06111a;
  background:linear-gradient(135deg,var(--re-cyan),var(--re-green));
  padding:9px 13px;
  border-radius:999px;
  font-size:.84rem;
  font-weight:1000;
  text-transform:uppercase;
  letter-spacing:.08em;
  box-shadow:0 0 28px rgba(0,229,255,.35);
}

.re-hero h1{
  margin:20px 0 18px;
  font-size:clamp(2.9rem,6.4vw,6.4rem);
  line-height:.88;
  letter-spacing:-.085em;
  text-transform:uppercase;
  max-width:980px;
}

.re-hero p{
  max-width:760px;
  color:#dce6ff;
  font-size:1.18rem;
  line-height:1.65;
}

.re-hero-stats{
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}

.re-hero-stats span{
  border:1px solid var(--re-line);
  background:rgba(10,13,31,.68);
  border-radius:16px;
  padding:12px 14px;
  color:#dbe4ff;
  font-weight:850;
}

.re-hero-stats strong{
  color:var(--re-gold);
}

/* BREADCRUMB */

.re-breadcrumb-hero{
  display:inline-block;
  max-width:100%;
  margin-bottom:18px;
  padding:13px 18px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(5,6,15,.56);
  backdrop-filter:blur(12px);
}

.re-breadcrumb-hero ol{
  list-style:none;
  margin:0;
  padding:0;
  display:flex;
  flex-wrap:wrap;
  gap:8px;
  align-items:center;
}

.re-breadcrumb-hero li{
  color:#cdd6ee;
  font-weight:850;
  font-size:.9rem;
}

.re-breadcrumb-hero li:not(:last-child):after{
  content:"›";
  margin-left:8px;
  color:rgba(255,255,255,.45);
}

.re-breadcrumb-hero a{
  color:#dbe5ff;
}

.re-breadcrumb-hero a:hover{
  color:var(--re-cyan);
}

.re-breadcrumb-hero li:last-child a{
  color:var(--re-gold);
}

/* SEARCH */

.re-search{
  margin-top:28px;
  max-width:780px;
  display:grid;
  grid-template-columns:1fr auto;
  padding:8px;
  border-radius:22px;
  background:rgba(255,255,255,.09);
  border:1px solid rgba(0,229,255,.28);
  box-shadow:0 0 35px rgba(0,229,255,.12),var(--re-shadow);
}

.re-search input{
  min-width:0;
  border:0;
  outline:0;
  background:rgba(4,7,18,.88);
  color:#fff;
  border-radius:16px;
  padding:18px;
  font-size:1.02rem;
}

.re-search button,
.re-btn{
  border:0;
  border-radius:16px;
  padding:0 22px;
  background:linear-gradient(135deg,var(--re-cyan),var(--re-purple) 50%,var(--re-magenta));
  color:#fff;
  font-weight:1000;
  cursor:pointer;
  box-shadow:0 0 26px rgba(0,229,255,.24);
}

/* SECCIONES */

.re-section{
  padding:52px 0;
}

.re-section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:20px;
  margin-bottom:22px;
}

.re-section h2,
.re-section-head h2,
.re-text-panel h2{
  margin:0 0 8px;
  font-size:clamp(2rem,4vw,3.7rem);
  letter-spacing:-.07em;
  line-height:.95;
  text-transform:uppercase;
}

.re-section-head p{
  margin:8px 0 0;
  color:var(--re-muted);
  line-height:1.55;
}

.re-text-panel{
  border:1px solid rgba(255,255,255,.12);
  border-radius:var(--re-radius);
  background:linear-gradient(135deg,rgba(0,229,255,.08),rgba(255,43,214,.06));
  padding:28px;
  margin:26px 0;
  color:#c3cce4;
  line-height:1.75;
}

.re-text-panel h2{
  color:#fff;
}

.re-text-panel a{
  color:var(--re-cyan);
  font-weight:900;
}

/* CARDS */

.re-podium,
.re-grid{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:20px;
}

.re-grid{
  margin-top:20px;
}

.re-card{
  position:relative;
  overflow:hidden;
  border-radius:var(--re-radius);
  background:linear-gradient(180deg,rgba(20,25,52,.88),rgba(9,12,28,.94));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:var(--re-shadow);
  transition:.22s transform ease,.22s box-shadow ease;
}

.re-card:before{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(135deg,rgba(0,229,255,.18),transparent 32%,rgba(255,43,214,.13) 100%);
  opacity:.72;
}

.re-card:hover{
  transform:translateY(-4px);
  box-shadow:0 24px 80px rgba(0,0,0,.65),0 0 34px rgba(0,229,255,.16);
}

.re-card-top:nth-child(1){
  border-color:rgba(255,209,102,.45);
  box-shadow:0 24px 90px rgba(0,0,0,.65),0 0 38px rgba(255,209,102,.18);
}

.re-card-media{
  position:relative;
  display:block;
  aspect-ratio:16/12;
  overflow:hidden;
  background:#111827;
}

.re-card-top .re-card-media{
  aspect-ratio:16/13;
}

.re-card-media img:not(.re-cat-icon){
  width:100%;
  height:100%;
  object-fit:cover;
  transition:.35s transform ease;
  filter:saturate(1.08) contrast(1.05);
}

.re-card:hover .re-card-media img:not(.re-cat-icon){
  transform:scale(1.045);
}

.re-card-media:after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(180deg,transparent 35%,rgba(5,6,15,.92));
}

.re-scanlines{
  position:absolute;
  inset:0;
  background:linear-gradient(transparent 50%,rgba(0,0,0,.18) 50%);
  background-size:100% 4px;
  opacity:.38;
  mix-blend-mode:multiply;
}

.re-rank,
.re-score{
  position:absolute;
  z-index:2;
  top:14px;
  border:1px solid rgba(255,255,255,.25);
  backdrop-filter:blur(12px);
  border-radius:999px;
  font-weight:1000;
}

.re-rank{
  left:14px;
  background:rgba(4,7,18,.72);
  padding:9px 12px;
  color:#fff;
}

.re-score{
  right:14px;
  padding:8px 11px;
  background:linear-gradient(135deg,var(--re-gold),#ff7b2c);
  color:#140d08;
  box-shadow:0 0 22px rgba(255,209,102,.3);
}

.re-score strong{
  font-size:1.1rem;
}

.re-score small{
  font-size:.72rem;
  margin-left:2px;
}

.re-cat-icon{
  position:absolute;
  z-index:2;
  left:14px;
  bottom:14px;
  width:34px !important;
  height:34px !important;
  object-fit:contain !important;
  background:rgba(4,7,18,.68);
  border:1px solid rgba(255,255,255,.18);
  border-radius:12px;
  padding:6px;
}

.re-card-body{
  position:relative;
  z-index:2;
  padding:18px;
}

.re-card-title{
  display:inline;
  font-size:1.28rem;
  line-height:1.08;
  font-weight:1000;
  letter-spacing:-.04em;
  background:linear-gradient(135deg,#fff,#bff8ff);
  -webkit-background-clip:text;
  color:transparent;
}

.re-card-title:hover{
  text-shadow:0 0 18px rgba(0,229,255,.52);
}

.re-card-body p{
  color:#b9c4df;
  line-height:1.54;
  margin:11px 0 14px;
  font-size:.95rem;
}

.re-card-meta{
  display:flex;
  flex-wrap:wrap;
  gap:8px;
}

.re-card-meta span{
  color:#e8efff;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(255,255,255,.12);
  border-radius:999px;
  padding:7px 10px;
  font-weight:800;
  font-size:.82rem;
}

/* CIUDADES */

.re-cities{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.re-city-card{
  border-radius:22px;
  overflow:hidden;
  background:linear-gradient(180deg,rgba(18,23,47,.9),rgba(8,11,26,.96));
  border:1px solid rgba(255,255,255,.13);
  box-shadow:0 18px 50px rgba(0,0,0,.38);
}

.re-city-head{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:18px;
  background:radial-gradient(circle at top right,rgba(0,229,255,.26),transparent 40%),linear-gradient(135deg,rgba(123,60,255,.36),rgba(255,43,214,.12));
  border-bottom:1px solid rgba(255,255,255,.13);
}

.re-city-head small{
  display:block;
  color:#aeb9d7;
  font-weight:900;
  text-transform:uppercase;
  letter-spacing:.12em;
  font-size:.72rem;
}

.re-city-head strong{
  display:block;
  font-size:1.35rem;
  letter-spacing:-.04em;
}

.re-city-head b{
  min-width:54px;
  height:54px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(0,0,0,.35);
  border:1px solid rgba(255,255,255,.18);
  color:var(--re-gold);
  font-size:1.3rem;
}

.re-city-card ol{
  list-style:none;
  margin:0;
  padding:12px;
}

.re-city-card li{
  display:grid;
  grid-template-columns:auto auto 1fr auto;
  gap:8px;
  align-items:center;
  padding:10px 0;
  border-bottom:1px solid rgba(255,255,255,.08);
  color:#d6def4;
}

.re-city-card li:last-child{
  border-bottom:0;
}

.re-city-card li img{
  width:21px;
  height:21px;
  object-fit:contain;
}

.re-mini-rank{
  color:var(--re-magenta);
  font-weight:1000;
}

.re-city-card li a{
  font-weight:800;
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}

.re-city-card li a:hover{
  color:var(--re-cyan);
}

.re-city-card li strong{
  color:var(--re-green);
  font-weight:1000;
}

/* PAGINACIÓN */

.re-pagination{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  justify-content:center;
  margin:30px 0;
}

.re-pagination a,
.re-pagination span{
  min-width:44px;
  height:44px;
  border-radius:14px;
  display:grid;
  place-items:center;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.07);
  font-weight:1000;
}

.re-pagination .current,
.re-pagination a:hover{
  background:linear-gradient(135deg,var(--re-cyan),var(--re-purple));
  color:#fff;
}

/* DETALLE SALA */

.re-detail{
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:26px;
  align-items:start;
}

.re-detail-panel,
.re-side-panel,
.re-review,
.re-login,
.re-company-card{
  border:1px solid rgba(255,255,255,.13);
  border-radius:var(--re-radius);
  background:linear-gradient(180deg,rgba(20,25,52,.88),rgba(9,12,28,.94));
  box-shadow:var(--re-shadow);
}

.re-side-panel{

  padding: 20px;
    margin-bottom: 10pt;
}


.re-detail-image{
  border-radius:var(--re-radius);
  overflow:hidden;
  position:relative;
}

.re-detail-image img{
  width:100%;
  height:auto;
}

.re-detail-content{
  padding:24px;
  color:#c3cce4;
  line-height:1.75;
}

.re-detail-title{
  font-size:clamp(2.4rem,4vw,4.7rem);
  letter-spacing:-.07em;
  line-height:.92;
  text-transform:uppercase;
  margin:0 0 12px;
}

.re-big-score{
  display:inline-flex;
  align-items:center;
  gap:6px;
  margin-bottom:16px;
  padding:9px 14px;
  border-radius:999px;
  color:#fff;
  font-weight:1000;
  background:rgba(255,255,255,.075);
  border:1px solid rgba(0,229,255,.28);
  box-shadow:0 0 24px rgba(0,229,255,.12);
}

.re-detail-image{
  border-radius:var(--re-radius);
  overflow:hidden;
  position:relative;
}

.re-detail-image:after{
  content:"";
  position:absolute;
  inset:0;
  pointer-events:none;
  background:linear-gradient(180deg,rgba(0,0,0,.05) 45%,rgba(5,6,15,.55) 100%);
}

.re-big-score{
  position:absolute;
  right:18px;
  top:18px;
  z-index:3;
  display:inline-flex;
  align-items:center;
  gap:6px;
  padding:10px 15px;
  border-radius:999px;
  color:#fff;
  font-weight:1000;
  background:rgba(5,6,15,.72);
  border:1px solid rgba(255,209,102,.45);
  backdrop-filter:blur(14px);
  box-shadow:0 0 28px rgba(255,209,102,.18), 0 16px 40px rgba(0,0,0,.45);
}

.re-big-score:before{
  content:"★";
  color:var(--re-gold);
  font-size:1.05rem;
  line-height:1;
  text-shadow:0 0 12px rgba(255,209,102,.55);
}

.re-big-score strong{
  font-size:1.45rem;
  line-height:1;
  color:var(--re-gold);
}

.re-big-score small{
  font-size:.88rem;
  color:#dbe4ff;
  line-height:1;
}}

/* LATERAL SIN STICKY */

.re-side-panel{
  padding:20px;
  position:static;
  top:auto;
  margin-bottom:18px;
}

.re-side-panel h3{
  margin:0 0 14px;
  font-size:1.35rem;
  letter-spacing:-.04em;
}

.re-side-list{
  display:grid;
  gap:10px;
  margin-bottom:16px;
}

.re-side-list span{
  display:flex;
  justify-content:space-between;
  gap:12px;
  padding:12px;
  border:1px solid rgba(255,255,255,.1);
  border-radius:14px;
  background:rgba(255,255,255,.06);
  color:#d8e0f6;
}

.re-side-list em{
  font-style:normal;
  text-align:right;
  color:#eef4ff;
}

.re-reserve{
  display:block;
  text-align:center;
  padding:15px 18px;
  border-radius:16px;
  background:linear-gradient(135deg,var(--re-cyan),var(--re-purple) 50%,var(--re-magenta));
  font-weight:1000;
  box-shadow:0 0 26px rgba(0,229,255,.24);
}

.re-map iframe{
  border-radius:18px;
  width:100%;
  border:0;
}

.re-review{
  padding:18px;
  margin-bottom:14px;
  color:#c6d0e8;
  line-height:1.62;
}

.re-review-head{
  display:flex;
  align-items:center;
  gap:12px;
  margin-bottom:8px;
}

.re-review img{
  width:54px;
  height:54px;
  border-radius:50%;
  background:#111827;
}

.re-review h4{
  margin:0;
  color:#fff;
}

.re-review small{
  color:var(--re-muted);
}

.re-sidebar-list{
  display:grid;
  gap:14px;
}

.re-mini-item{
  display:grid;
  grid-template-columns:82px 1fr;
  gap:12px;
  align-items:center;
}

.re-mini-item img{
  width:82px;
  height:66px;
  object-fit:cover;
  border-radius:14px;
}

.re-mini-item a{
  font-weight:1000;
  color:#fff;
}

.re-mini-item a:hover{
  color:var(--re-cyan);
}

.re-mini-item span{
  display:block;
  color:var(--re-muted);
  font-size:.86rem;
  line-height:1.35;
}

/* EMPRESA */

.re-company-hero-grid{
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:22px;
}

.re-company-card{
  padding:24px;
  color:#cbd5ef;
}

.re-company-card h2{
  margin-top:0;
}

.re-info-line{
  display:flex;
  gap:12px;
  align-items:center;
  justify-content:space-between;
  margin:12px 0;
  padding:12px;
  border-radius:14px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.11);
}

.re-info-line a{
  color:var(--re-cyan);
  font-weight:900;
}

/* FOOTER */

.re-footer{
  padding:38px 0;
  border-top:1px solid var(--re-line);
  color:#9ba8c6;
  background:#04050c;
}

.re-footer-inner{
  display:flex;
  justify-content:space-between;
  gap:24px;
}

.re-footer p{
  margin:.4rem 0 0;
}

.re-footer nav{
  display:flex;
  gap:16px;
  flex-wrap:wrap;
}

.re-footer a:hover{
  color:var(--re-cyan);
}

/* RESPONSIVE TABLET */

@media(max-width:980px){

  .re-wrap{
    padding:0 20px;
  }

  .re-topbar{
    position:sticky;
    top:0;
    z-index:9999;
  }

  .re-nav{
    height:96px;
    display:flex;
    align-items:center;
    justify-content:flex-start;
    gap:0;
    position:relative;
  }

  .re-brand{
    height:96px;
    display:flex;
    align-items:center;
    max-width:calc(100% - 80px);
    padding-right:12px;
    flex:0 1 auto;
  }

  .re-brand-text{
    min-width:0;
  }

  .re-brand-text strong,
  .re-brand-text small{
    white-space:nowrap;
  }

  .re-menu-toggle{
    position:absolute;
    right:20px;
    top:50%;
    transform:translateY(-50%);
    margin:0;
    display:flex;
    align-items:center;
    justify-content:center;
    flex-direction:column;
    width:54px;
    height:54px;
    padding:0;
    border:1px solid rgba(255,255,255,.18);
    border-radius:18px;
    background:rgba(255,255,255,.08);
    box-shadow:0 0 22px rgba(255,255,255,.08);
    cursor:pointer;
    z-index:100001;
  }

  .re-menu-toggle span{
    display:block;
    width:28px;
    height:4px;
    margin:3px 0;
    border-radius:999px;
    background:#fff;
    box-shadow:0 0 10px rgba(0,229,255,.35);
  }

  .re-menu{
    display:none;
    position:absolute;
    top:96px;
    left:14px;
    right:14px;
    width:auto;
    max-width:none;
    z-index:99999;
    padding:14px;
    border-radius:22px;
    background:rgba(5,6,15,.98);
    backdrop-filter:blur(18px);
    border:1px solid rgba(255,255,255,.14);
    box-shadow:0 22px 70px rgba(0,0,0,.75);
  }

  .re-menu.is-open{
    display:block;
  }

  .re-menu ul{
    list-style:none;
    margin:0;
    padding:0;
    display:flex;
    flex-direction:column;
    align-items:stretch;
    gap:8px;
  }

  .re-menu li{
    width:100%;
    position:relative;
  }

  .re-menu a,
  .re-menu summary{
    width:100%;
    display:flex;
    align-items:center;
    justify-content:space-between;
    padding:15px 18px;
    border-radius:18px;
    color:#fff;
    font-weight:900;
    background:rgba(255,255,255,.06);
    border:1px solid rgba(255,255,255,.10);
    opacity:1;
  }

  .re-menu a:hover,
  .re-menu summary:hover{
    color:var(--re-cyan);
    background:rgba(0,229,255,.08);
  }

  .re-menu a.is-active{
    color:var(--re-cyan);
    background:rgba(0,229,255,.10);
    border-color:rgba(0,229,255,.35);
  }

  .re-mobile-dropdown{
    width:100%;
  }

  .re-mobile-dropdown summary{
    list-style:none;
    cursor:pointer;
  }

  .re-mobile-dropdown summary::-webkit-details-marker{
    display:none;
  }

  .re-mobile-dropdown summary:after{
    content:"▾";
    color:var(--re-cyan);
    font-size:.85rem;
    margin-left:auto;
  }

  .re-mobile-dropdown[open] summary:after{
    content:"▴";
  }

  .re-dropdown{
    position:static;
    left:auto;
    right:auto;
    top:auto;
    transform:none;
    width:100%;
    min-width:0;
    max-width:none;
    display:flex;
    flex-direction:column;
    gap:7px;
    margin:8px 0 0 0;
    padding:8px;
    border-radius:18px;
    background:rgba(0,0,0,.25);
    border:1px solid rgba(255,255,255,.08);
    box-shadow:none;
  }

  .re-dropdown li{
    width:100%;
  }

  .re-dropdown li a{
    width:100%;
    display:block;
    padding:13px 16px;
    border-radius:15px;
    white-space:normal;
    text-align:left;
    font-size:.96rem;
    background:rgba(255,255,255,.055);
  }

  .re-menu .re-add{
    justify-content:center;
    text-align:center;
    margin-top:6px;
    background:linear-gradient(135deg,var(--re-cyan),var(--re-purple) 50%,var(--re-magenta));
  }

  .re-podium,
  .re-grid,
  .re-cities{
    grid-template-columns:repeat(2,1fr);
  }

  .re-hero{
    min-height:auto;
  }

  .re-detail{
    grid-template-columns:1fr;
  }

  .re-company-hero-grid{
    grid-template-columns:1fr;
  }

  .re-side-panel{
    position:static;
    top:auto;
  }
}

/* RESPONSIVE MÓVIL */

@media(max-width:640px){

  .re-wrap{
    padding:0 14px;
  }

  .re-nav{
    height:96px;
  }

  .re-brand{
    height:96px;
    gap:11px;
    max-width:calc(100% - 78px);
  }

  .re-brand-mark{
    width:50px;
    height:50px;
    border-radius:15px;
  }

  .re-brand-text strong{
    font-size:1.17rem;
  }

  .re-brand-text small{
    font-size:.68rem;
    letter-spacing:.16em;
  }

  .re-menu-toggle{
    right:14px;
    width:54px;
    height:54px;
  }

  .re-menu{
    top:96px;
    left:14px;
    right:14px;
  }

  .re-hero-content{
    /*padding:46px 14px;*/
    padding:30px 14px;
  }

  .re-hero h1{
    font-size:3rem;
    line-height:.9;
  }

  .re-hero p{
    font-size:1.06rem;
  }

  .re-hero-stats{
    gap:10px;
  }

  .re-hero-stats span{
    padding:12px 14px;
  }

  .re-search{
    grid-template-columns:1fr;
  }

  .re-search button{
    height:54px;
  }

  .re-podium,
  .re-grid,
  .re-cities{
    grid-template-columns:1fr;
  }

  .re-section{
    padding:42px 0;
  }

  .re-section-head{
    display:block;
  }

  .re-detail-content{
    padding:20px;
  }

  .re-detail-title{
    font-size:2.55rem;
  }

  .re-breadcrumb-hero{
    border-radius:24px;
    padding:12px 18px;
  }

  .re-breadcrumb-hero ol{
    display:flex;
    flex-wrap:wrap;
  }

  .re-breadcrumb-hero li{
    font-size:.9rem;
    line-height:1.55;
  }

  .re-side-list span{
    display:block;
  }

  .re-side-list em{
    display:block;
    text-align:left;
    margin-top:4px;
  }

  .re-mini-item{
    grid-template-columns:78px 1fr;
  }

  .re-mini-item img{
    width:78px;
    height:64px;
  }

  .re-footer-inner{
    display:block;
  }

  .re-footer nav{
    margin-top:16px;
  }
}

/* ==============================
   CTA TODAS LAS CIUDADES
============================== */

.re-all-cities-cta {
  margin: 42px auto 20px;
  padding: 24px;
  max-width: 1120px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 22px;
  border-radius: 24px;
  background:
    radial-gradient(circle at top left, rgba(255, 210, 80, .18), transparent 34%),
    linear-gradient(135deg, rgba(22, 24, 36, .96), rgba(12, 13, 22, .98));
  border: 1px solid rgba(255, 255, 255, .10);
  box-shadow:
    0 18px 45px rgba(0, 0, 0, .30),
    inset 0 1px 0 rgba(255, 255, 255, .06);
}

.re-all-cities-content {
  min-width: 0;
}

.re-all-cities-kicker {
  display: inline-flex;
  margin-bottom: 8px;
  font-size: 12px;
  font-weight: 800;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: #ffcf56;
}

.re-all-cities-cta h2 {
  margin: 0 0 7px;
  font-size: clamp(22px, 3vw, 32px);
  line-height: 1.05;
  color: #fff;
}

.re-all-cities-cta p {
  margin: 0;
  max-width: 640px;
  font-size: 15px;
  line-height: 1.55;
  color: rgba(255, 255, 255, .72);
}

.re-all-cities-btn {
  flex: 0 0 auto;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 9px;
  min-height: 48px;
  padding: 0 20px;
  border-radius: 999px;
  background: linear-gradient(135deg, #ffd75a, #ff9f1c);
  color: #151019;
  font-size: 14px;
  font-weight: 950;
  text-decoration: none;
  box-shadow:
    0 12px 26px rgba(255, 159, 28, .26),
    inset 0 1px 0 rgba(255, 255, 255, .45);
  transition: transform .18s ease, box-shadow .18s ease, filter .18s ease;
}

.re-all-cities-btn span {
  font-size: 18px;
  line-height: 1;
  transition: transform .18s ease;
}

.re-all-cities-btn:hover {
  transform: translateY(-2px);
  filter: brightness(1.04);
  box-shadow:
    0 16px 34px rgba(255, 159, 28, .36),
    inset 0 1px 0 rgba(255, 255, 255, .55);
}

.re-all-cities-btn:hover span {
  transform: translateX(3px);
}

@media (max-width: 720px) {
  .re-all-cities-cta {
    margin-top: 30px;
    padding: 20px;
    flex-direction: column;
    align-items: stretch;
    text-align: left;
    border-radius: 20px;
  }

  .re-all-cities-btn {
    width: 100%;
  }
}
