/* =========================================================
   1. VARIABLES Y CONFIGURACIÓN BASE
   ========================================================= */
:root {
  --black: #050505; --gold: #C9A84C; --gold-light: #E8C97A;
  --white: #F5F0E8; --cream: #EDE4D0; --red: #8B1A1A; --green: #1A5C2A;
}
* { margin: 0; padding: 0; box-sizing: border-box; }
html { scroll-behavior: smooth; overflow-x: hidden; }
body { background: var(--black); color: var(--white); font-family: 'Cormorant Garamond', serif; overflow-x: hidden; max-width: 100vw; }
body::before { content:''; position:fixed; inset:0; background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E"); pointer-events:none; z-index:1000; opacity:0.5; }

/* =========================================================
   2. NAVEGACIÓN Y MENÚ MÓVIL
   ========================================================= */
nav { position:fixed; top:0; left:0; right:0; z-index:100; padding:1.5rem 4rem; display:flex; justify-content:space-between; align-items:center; background:linear-gradient(to bottom,rgba(5,5,5,0.95) 0%,transparent 100%); transition:background 0.4s; }
nav.scrolled { background:rgba(5,5,5,0.97); border-bottom:1px solid rgba(201,168,76,0.15); }
.nav-logo { display:flex; align-items:center; gap:0.8rem; }
.nav-flag { width:28px; height:28px; border-radius:50%; border:1.5px solid var(--gold); overflow:hidden; display:flex; flex-shrink:0; }
.nav-flag-inner { display:flex; width:100%; height:100%; }
.flag-g { flex:1; background:#009246; } .flag-w { flex:1; background:#fff; } .flag-r { flex:1; background:#CE2B37; }
.nav-title { font-family:'Playfair Display',serif; font-style:italic; font-size:1.1rem; color:var(--white); }
.nav-links { display:flex; gap:2.5rem; list-style:none; }
.nav-links a { font-family:'Cinzel',serif; font-size:0.62rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--cream); text-decoration:none; opacity:0.7; transition:opacity 0.3s,color 0.3s; }
.nav-links a:hover { opacity:1; color:var(--gold); }

/* Menú Hamburguesa */
.hamburger { display:none; flex-direction:column; gap:5px; cursor:pointer; padding:4px; background:none; border:none; z-index: 1000; position: relative; }
.hamburger span { display:block; width:24px; height:2px; background:var(--gold); transition:transform 0.3s, opacity 0.3s; }
.hamburger.open span:nth-child(1) { transform:translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity:0; }
.hamburger.open span:nth-child(3) { transform:translateY(-7px) rotate(-45deg); }

.mobile-menu { position:fixed; top:0; right:-100%; width:280px; height:100vh; background:#0a0805; z-index:999; padding:6rem 2rem 2rem; display:flex; flex-direction:column; gap:1.5rem; transition:right 0.4s cubic-bezier(0.4, 0, 0.2, 1); border-left:1px solid rgba(201,168,76,0.15); box-shadow: -5px 0 20px rgba(0,0,0,0.8); }
.mobile-menu.open { right:0; }
.mobile-menu a { font-family:'Cinzel',serif; font-size:0.8rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--cream); text-decoration:none; opacity:0.8; transition:opacity 0.3s,color 0.3s; padding:1rem 0; border-bottom:1px solid rgba(201,168,76,0.1); }
.mobile-menu a:hover { opacity:1; color:var(--gold); }

.mobile-overlay { position:fixed; inset:0; background:rgba(0,0,0,0.8); z-index:998; opacity:0; visibility:hidden; transition:all 0.4s ease; }
.mobile-overlay.open { opacity:1; visibility:visible; }

/* =========================================================
   3. HERO SECTION
   ========================================================= */
#hero { position:relative; height:100vh; display:flex; flex-direction:column; align-items:center; justify-content:center; text-align:center; overflow:hidden; padding-top:2rem; padding-bottom:1rem; }
.hero-bg { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 50% 60%,rgba(201,168,76,0.07) 0%,transparent 70%),radial-gradient(ellipse 40% 40% at 20% 80%,rgba(139,26,26,0.05) 0%,transparent 60%),radial-gradient(ellipse 40% 40% at 80% 20%,rgba(26,92,42,0.04) 0%,transparent 60%); }
.hero-lines { position:absolute; bottom:0; left:0; right:0; height:3px; display:flex; }
.hero-lines span { flex:1; }
.hero-lines .l1 { background:var(--green); } .hero-lines .l2 { background:var(--white); opacity:0.6; } .hero-lines .l3 { background:var(--red); }
.hero-flag-big { width:60px; height:60px; border-radius:50%; border:2.5px solid var(--gold); overflow:hidden; display:flex; margin:0 auto 1.1rem; box-shadow:0 0 28px rgba(201,168,76,0.4), 0 0 0 5px rgba(201,168,76,0.07); animation:fadeUp 1s 0.1s ease both; transition:all 0.4s ease; position:relative; z-index:91; flex-shrink:0; }
.hero-flag-big.is-fixed { position:fixed; top:1.2rem; left:50%; transform:translateX(-50%); width:36px; height:36px; margin:0; box-shadow:0 0 14px rgba(201,168,76,0.35); animation:none; z-index:101; }
.hero-h1 { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(3.5rem,8vw,7rem); font-weight:400; line-height:0.95; color:var(--white); animation:fadeUp 1s 0.2s ease both; }
.hero-h1 em { font-style:normal; color:var(--gold); }
.hero-tagline { margin-top:1.4rem; font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(1.3rem, 3vw, 2.1rem); letter-spacing:0.06em; color:var(--gold); text-shadow:0 0 40px rgba(201,168,76,0.5); animation:fadeUp 1s 0.35s ease both; }
.hero-divider { width:80px; height:1px; background:linear-gradient(to right,transparent,var(--gold),transparent); margin:1.4rem auto; animation:fadeUp 1s 0.45s ease both; }
.hero-awards { display:flex; gap:0.6rem; justify-content:center; flex-wrap:wrap; margin-bottom:1.6rem; animation:fadeUp 1s 0.5s ease both; }
.award-badge { font-family:'Cinzel',serif; font-size:0.45rem; letter-spacing:0.12em; padding:0.35rem 0.7rem; border:1px solid rgba(201,168,76,0.3); color:var(--gold); opacity:0.8; }
.hero-cta { display:flex; gap:0.7rem; justify-content:center; flex-wrap:wrap; animation:fadeUp 1s 0.58s ease both; }

/* Botones Universales */
.btn-gold { font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.25em; text-transform:uppercase; padding:1rem 2.5rem; background:var(--gold); color:var(--black); border:none; cursor:pointer; text-decoration:none; transition:background 0.3s,transform 0.2s; display:inline-block; text-align:center; }
.btn-gold:hover { background:var(--gold-light); transform:translateY(-2px); }
.btn-outline { font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.25em; text-transform:uppercase; padding:1rem 2.5rem; background:transparent; color:var(--cream); border:1px solid rgba(201,168,76,0.4); cursor:pointer; text-decoration:none; transition:border-color 0.3s,color 0.3s,transform 0.2s; display:inline-block; text-align:center; }
.btn-outline:hover { border-color:var(--gold); color:var(--gold); transform:translateY(-2px); }

section { padding:8rem 6rem; position:relative; }
.section-eyebrow { font-family:'Cinzel',serif; font-size:0.6rem; letter-spacing:0.4em; text-transform:uppercase; color:var(--gold); display:block; margin-bottom:1rem; }
.section-title { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(2.5rem,5vw,4rem); font-weight:400; color:var(--white); line-height:1.1; margin-bottom:1.5rem; }
.section-sub { font-size:1.1rem; font-weight:300; color:var(--cream); opacity:0.65; line-height:1.8; }
.gold-line { width:50px; height:1px; background:var(--gold); margin:1.8rem 0; }

/* =========================================================
   4. SERVICIOS (6 CAJAS DE EVENTOS)
   ========================================================= */
#servicios { background:linear-gradient(to bottom,#060504,#050505); }
.servicios-header { text-align:center; margin-bottom:5rem; }
.servicios-header .section-sub { margin:0 auto; max-width:560px; }
.servicios-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5px; }
.servicio-card { background:#0a0905; padding:2.8rem 2.3rem; position:relative; overflow:hidden; transition:background 0.4s; cursor:pointer; }
.servicio-card::before { content:''; position:absolute; bottom:0; left:0; width:0; height:2px; background:var(--gold); transition:width 0.5s ease; }
.servicio-card:hover { background:#100e08; }
.servicio-card:hover::before { width:100%; }
.servicio-number { font-family:'Playfair Display',serif; font-size:5rem; color:rgba(201,168,76,0.07); line-height:1; margin-bottom:1.2rem; display:block; font-style:italic; }
.servicio-thumb { margin: -2.8rem -2.3rem 1.5rem -2.3rem; height: 220px; overflow: hidden; position: relative; background:#0a0905; }
.servicio-thumb img { width: 100%; height: 100%; object-fit: cover; transition: transform 0.6s ease; display:block; }
.servicio-card:hover .servicio-thumb img { transform: scale(1.08); }
.servicio-title { font-family:'Playfair Display',serif; font-style:italic; font-size:1.45rem; color:var(--white); margin-bottom:0.8rem; }
.servicio-desc { font-size:0.9rem; font-weight:300; color:var(--cream); opacity:0.55; line-height:1.8; }
.servicio-cta { font-family:'Cinzel',serif; font-size:0.5rem; letter-spacing:0.2em; color:var(--gold); opacity:0.7; text-transform:uppercase; margin-top:1.2rem; display:block; transition:opacity 0.3s; text-decoration:none; }
.servicio-card:hover .servicio-cta { opacity:1; color:var(--gold-light); }

/* =========================================================
   5. SUCURSALES (LOCACIONES)
   ========================================================= */
#sucursales { background:linear-gradient(to bottom,#050505,#0c0a06,#050505); }
.sucursales-header { display:flex; align-items:flex-end; justify-content:space-between; margin-bottom:4rem; gap:2rem; }
.sucursales-grid { display:grid; grid-template-columns:repeat(4,1fr); gap:1.5px; }
.sucursal-card { position:relative; overflow:hidden; cursor:pointer; aspect-ratio:3/4; background:#111; }
.sc-placeholder { width:100%; height:100%; display:flex; align-items:center; justify-content:center; transition:transform 0.6s ease; background:#050505; }
.sucursal-card:hover .sc-placeholder { transform:scale(1.06); }
.sc-placeholder img { width: 100%; height: 100%; object-fit: contain; background: #050505; }
.sc-bg-1 { background:linear-gradient(135deg,#1a1a0f,#0d0d08); }
.sc-bg-2 { background:linear-gradient(135deg,#14180a,#0a0d06); }
.sc-bg-3 { background:linear-gradient(135deg,#1a0f0a,#0d0805); }
.sc-bg-4 { background:linear-gradient(135deg,#0f1219,#080a0e); }
.sc-bg-5 { background:linear-gradient(135deg,#190f14,#0d080b); }
.sc-bg-6 { background:linear-gradient(135deg,#121a10,#090e08); }
.sc-overlay { position:absolute; inset:0; background:linear-gradient(to top,rgba(5,5,5,0.97) 0%,rgba(5,5,5,0.4) 50%,transparent 100%); opacity:0.75; transition:opacity 0.4s; display:flex; flex-direction:column; justify-content:flex-end; padding:1.5rem; }
.sucursal-card:hover .sc-overlay { opacity:1; }
.sc-name { font-family:'Playfair Display',serif; font-style:italic; font-size:1.05rem; color:var(--white); margin-bottom:0.3rem; }
.sc-sector { font-family:'Cinzel',serif; font-size:0.52rem; letter-spacing:0.18em; color:var(--gold); text-transform:uppercase; margin-bottom:0.8rem; }
.sc-details { display:flex; gap:0.6rem; flex-wrap:wrap; opacity:0; transform:translateY(8px); transition:opacity 0.3s 0.1s,transform 0.3s 0.1s; }
.sucursal-card:hover .sc-details { opacity:1; transform:translateY(0); }
.sc-badge { font-family:'Cinzel',serif; font-size:0.48rem; letter-spacing:0.1em; padding:0.25rem 0.6rem; border:1px solid rgba(201,168,76,0.4); color:var(--cream); white-space:nowrap; }

/* =========================================================
   6. MODALES UNIVERSALES (CARRUSEL, INFO Y PAQUETES)
   ========================================================= */
.modal-backdrop { position:fixed; inset:0; background:rgba(0,0,0,0.92); z-index:500; display:none; align-items:center; justify-content:center; padding:2rem; }
.modal-backdrop.open { display:flex; }
.modal { 
    background:#0d0b08; 
    border:1px solid rgba(201,168,76,0.2); 
    width: 100%; 
    max-width: 760px; 
    max-height: 90vh; 
    overflow-y: auto; 
    overflow-x: hidden; /* CORTA EL DESBORDE HORIZONTAL */
    position: relative; 
    box-sizing: border-box;
}
.modal-close { position:absolute; top:0.8rem; right:1rem; font-family:'Cinzel',serif; font-size:0.62rem; letter-spacing:0.2em; color:var(--gold); cursor:pointer; background:rgba(5,5,5,0.75); border:1px solid rgba(201,168,76,0.3); z-index:10; padding:0.5rem 0.9rem; min-height:44px; display:flex; align-items:center; border-radius:2px; }

.modal-hero { width:100%; height:300px; display:flex; align-items:center; justify-content:center; border-bottom:1px solid rgba(201,168,76,0.15); position:relative; overflow:hidden; transition: height 0.35s ease; background:#050505; }
.modal-hero-overlay { position:absolute; inset:0; background:linear-gradient(to top,#0d0b08 0%,transparent 60%); }
.modal-body { padding: 2.5rem; width: 100%; box-sizing: border-box; }
.modal-name { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(1.6rem, 5vw, 2rem); color:var(--white); margin-bottom:0.4rem; word-wrap: break-word; }
.modal-sector-label { font-family:'Cinzel',serif; font-size:0.58rem; letter-spacing:0.3em; color:var(--gold); text-transform:uppercase; margin-bottom:1.5rem; }

.modal-specs { display:grid; grid-template-columns:repeat(3,1fr); gap:1.5px; margin-bottom:2rem; width: 100%; }
.modal-spec { background:#13110d; padding:1.4rem; text-align:center; }
.modal-spec-val { font-family:'Playfair Display',serif; font-size:1.8rem; color:var(--gold); display:block; }
.modal-spec-key { font-family:'Cinzel',serif; font-size:0.48rem; letter-spacing:0.2em; text-transform:uppercase; color:var(--cream); opacity:0.5; margin-top:0.3rem; display:block; }
.modal-desc-txt { font-size:1.05rem; font-weight:300; color:var(--cream); opacity:0.65; line-height:1.8; margin-bottom:1.5rem; }
.modal-addr-txt { font-family:'Cinzel',serif; font-size:0.58rem; letter-spacing:0.15em; color:var(--gold); opacity:0.7; margin-bottom:2rem; }

/* Carrusel */
.carousel-container { position: relative; width: 100%; height: 300px; overflow: hidden; display: flex; align-items: center; background-color: #050505; transition: height 0.35s ease; }
.carousel-track { display: flex; width: 100%; height: 100%; transition: transform 0.4s ease-in-out; }
.carousel-track img { min-width: 100%; width: 100%; height: 100%; object-fit: contain; object-position: center; }
.carousel-btn { position: absolute; top: 50%; transform: translateY(-50%); background: rgba(5, 5, 5, 0.85); color: var(--gold); border: 1px solid rgba(201, 168, 76, 0.6); width: 44px; height: 44px; border-radius: 50%; cursor: pointer; z-index: 10; display: flex; align-items: center; justify-content: center; font-size: 1.1rem; transition: background 0.3s; box-shadow: 0 4px 12px rgba(0,0,0,0.6); }
.carousel-btn:hover { background: var(--gold); color: var(--black); }
.carousel-btn.prev { left: 1rem; }
.carousel-btn.next { right: 1rem; }

/* Componentes que inyecta JS dentro del Modal */
.svc-pkg-container { display: grid; grid-template-columns: repeat(auto-fit, minmax(140px, 1fr)); gap: 1rem; margin-bottom: 1.5rem; width: 100%; }
.svc-pkg-card { background: rgba(255, 255, 255, 0.02); border: 1px solid rgba(201, 168, 76, 0.15); border-radius: 12px; padding: 1.2rem; text-align: center; width: 100%; box-sizing: border-box; }
.svc-pkg-card h4 { font-family: 'Playfair Display', serif; color: var(--white); font-size: 1.1rem; font-style: italic; margin-bottom: 0.4rem; }
.svc-pkg-price { font-family: 'Cinzel', serif; color: var(--gold); font-size: 1.1rem; font-weight: 600; }
.svc-pkg-price span { font-size: 0.65rem; color: var(--cream); opacity: 0.6; letter-spacing: 1px; font-family: 'DM Sans', sans-serif; font-weight: 400; }

.svc-val-container { background: linear-gradient(135deg, rgba(201,168,76,0.05) 0%, rgba(0,0,0,0) 100%); border: 1px solid rgba(201, 168, 76, 0.2); border-left: 3px solid var(--gold); border-radius: 12px; padding: 1.8rem; width: 100%; box-sizing: border-box; }
.svc-val-title { font-family: 'Playfair Display', serif; color: var(--gold); font-size: 1.3rem; font-style: italic; margin-bottom: 1.2rem; }
.svc-val-list { list-style: none; display: grid; grid-template-columns: repeat(auto-fit, minmax(200px, 1fr)); gap: 12px; padding: 0; width: 100%; }
.svc-val-item { font-family: 'DM Sans', sans-serif; font-size: 0.85rem; color: var(--cream); opacity: 0.85; display: flex; gap: 10px; align-items: flex-start; line-height: 1.5; }
.svc-val-item i { color: var(--gold); font-size: 0.7rem; margin-top: 4px; flex-shrink: 0; }

/* =========================================================
   7. CONTACTO Y FOOTER
   ========================================================= */
#contacto { padding:6rem; text-align:center; background:#060504; border-top:1px solid rgba(201,168,76,0.1); }
.contact-tagline { font-family:'Playfair Display',serif; font-style:italic; font-size:clamp(2rem,4vw,3.2rem); color:var(--white); margin-bottom:1rem; }
.contact-sub { font-size:1.1rem; font-weight:300; color:var(--cream); opacity:0.5; margin-bottom:0.5rem; }
.contact-phone { font-family:'Cinzel',serif; font-size:0.85rem; letter-spacing:0.2em; color:var(--gold); margin-bottom:3rem; display:block; text-decoration:none; }
.contact-phone:hover { opacity:0.8; }
.contact-btns { display:flex; gap:1.5rem; justify-content:center; flex-wrap:wrap; margin-bottom:4rem; }
.btn-wsp { display:inline-flex; align-items:center; gap:0.7rem; font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.2em; padding:1.1rem 2.5rem; background:#128C7E; color:#fff; text-decoration:none; transition:background 0.3s,transform 0.2s; border-radius: 50px; }
.btn-wsp:hover { background:#0d7a6c; transform:translateY(-2px); }
.btn-ig { display:inline-flex; align-items:center; gap:0.7rem; font-family:'Cinzel',serif; font-size:0.65rem; letter-spacing:0.2em; padding:1.1rem 2.5rem; background:linear-gradient(45deg,#833ab4,#fd1d1d,#fcb045); color:#fff; text-decoration:none; transition:opacity 0.3s,transform 0.2s; border-radius: 50px; }
.btn-ig:hover { opacity:0.9; transform:translateY(-2px); }
.footer-divider { width:80px; height:1px; background:linear-gradient(to right,transparent,var(--gold),transparent); margin:0 auto 2rem; }
.footer-copy { font-family:'Cinzel',serif; font-size:0.52rem; letter-spacing:0.25em; color:var(--cream); opacity:0.2; }

.wsp-float { position:fixed; bottom:2rem; right:2rem; width:56px; height:56px; background:#128C7E; border-radius:50%; display:flex; align-items:center; justify-content:center; text-decoration:none; z-index:200; box-shadow:0 4px 20px rgba(18,140,126,0.4); transition:transform 0.3s,box-shadow 0.3s; }
.wsp-float:hover { transform:scale(1.1); box-shadow:0 6px 30px rgba(18,140,126,0.5); }

/* Animaciones Generales */
@keyframes fadeUp { from{opacity:0;transform:translateY(30px)} to{opacity:1;transform:translateY(0)} }
.reveal { opacity:0; transform:translateY(40px); transition:opacity 0.8s ease,transform 0.8s ease; }
.reveal.visible { opacity:1; transform:translateY(0); }
@media(prefers-reduced-motion:reduce) { *,*::before,*::after{animation-duration:.01ms!important;transition-duration:.01ms!important} }

/* =========================================================
   MEJORAS UX/UI PRO MAX — ACCESIBILIDAD, TOUCH, PERFORMANCE
   (Aplica a TODOS los formatos: móvil, tablet, PC)
   ========================================================= */

/* 1. TOUCH-ACTION: elimina el delay de 300ms en dispositivos táctiles */
.sucursal-card, .servicio-card, .btn-gold, .btn-outline,
.btn-wsp, .btn-ig, .modal-close, .carousel-btn,
.wsp-float, .hamburger, .nav-links a, .mobile-menu a,
.pkg-toggle-btn, .hero-cta a, .btn-event-type, .hero-scroll-hint {
  touch-action: manipulation;
}

/* 2. FOCUS STATES — accesibilidad para navegación con teclado */
:focus-visible {
  outline: 2px solid var(--gold);
  outline-offset: 3px;
}
.btn-gold:focus-visible { outline-color: var(--black); }
.modal-close:focus-visible, .carousel-btn:focus-visible { outline-offset: 2px; }

/* 3. HERO CTA — nuevo layout: cotiza tu evento + tipos de evento + navegación */
.hero-cta {
  flex-direction: column;
  align-items: center;
  gap: 0.8rem;
}
.hero-cotiza-label {
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  letter-spacing: 0.3em;
  color: var(--gold);
  text-transform: uppercase;
  opacity: 0.8;
  margin-bottom: 0.2rem;
}
.hero-event-types {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  justify-content: center;
}
.btn-event-type {
  font-family: 'Cinzel', serif;
  font-size: 0.55rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--black);
  background: var(--gold);
  border: 1px solid var(--gold);
  padding: 0.9rem 1.6rem;
  text-decoration: none;
  cursor: pointer;
  transition: background 0.25s ease, transform 0.2s ease, box-shadow 0.25s ease;
  display: inline-block;
  text-align: center;
  white-space: nowrap;
}
.btn-event-type:hover {
  background: var(--gold-light);
  border-color: var(--gold-light);
  transform: translateY(-2px);
  box-shadow: 0 6px 24px rgba(201,168,76,0.35);
}
.btn-event-type:active { transform: scale(0.97); }
.hero-nav-actions {
  display: flex;
  gap: 0.8rem;
  flex-wrap: wrap;
  justify-content: center;
  margin-top: 0.2rem;
}
/* Botones outline dentro del hero: más compactos que en el resto del sitio */
.hero-nav-actions .btn-outline {
  padding: 0.9rem 2rem;
  font-size: 0.55rem;
}

/* 4. SCROLL INDICATOR en Hero — flujo normal en desktop, absoluto en móvil */
@keyframes scrollBounceDesktop {
  0%, 100% { transform: translateY(0);   opacity: 0.6; }
  50%       { transform: translateY(7px); opacity: 1;   }
}
/* Reglas de máxima especificidad para forzar color dorado sobre el estilo por defecto de <a> */
a.hero-scroll-hint,
a.hero-scroll-hint:link,
a.hero-scroll-hint:visited,
a.hero-scroll-hint:hover,
a.hero-scroll-hint:active {
  color: var(--gold) !important;
  text-decoration: none !important;
}
.hero-scroll-hint {
  /* Desktop: en el flujo flex normal, siempre debajo de los botones */
  position: static;
  margin-top: 1.1rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.4rem;
  color: var(--gold);
  text-decoration: none;
  animation: scrollBounceDesktop 2.4s ease-in-out infinite;
  z-index: 10;
  pointer-events: auto;
}
.scroll-hint-label {
  font-family: 'Cinzel', serif;
  font-size: 0.6rem;
  letter-spacing: 0.35em;
  color: var(--gold) !important;
  opacity: 0.7;
  text-transform: uppercase;
  white-space: nowrap;
}
.scroll-hint-icon {
  color: var(--gold) !important;
  opacity: 0.7;
  font-size: 0.8rem;
}

/* 5. DOTS INDICADORES del carrusel */
.carousel-dots {
  position: absolute;
  bottom: 0.75rem;
  left: 50%;
  transform: translateX(-50%);
  display: flex;
  gap: 10px;
  z-index: 15;
  padding: 0.3rem 0.6rem;
}
.carousel-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: rgba(201,168,76,0.35);
  border: 1px solid rgba(201,168,76,0.5);
  cursor: pointer;
  padding: 0;
  transition: background 0.25s ease, transform 0.25s ease;
  touch-action: manipulation;
  flex-shrink: 0;
}
.carousel-dot.active {
  background: var(--gold);
  transform: scale(1.4);
  border-color: var(--gold);
}

/* 6. MODAL OVERLAY — z-index explícito para que los dots queden encima */
.modal-hero-overlay { z-index: 2; }

/* 7. MODAL — entrada animada en TODOS los dispositivos */
.modal-backdrop.open .modal {
  animation: modalEnter 0.28s cubic-bezier(0.34, 1.15, 0.64, 1) both;
}
@keyframes modalEnter {
  from { opacity: 0; transform: scale(0.94) translateY(14px); }
  to   { opacity: 1; transform: scale(1)    translateY(0); }
}

/* 8. PRESS FEEDBACK en cards y botones (funciona en desktop con click también) */
.servicio-card:active, .sucursal-card:active {
  transform: scale(0.988);
  transition: transform 0.1s ease;
}
.btn-gold:active    { transform: translateY(-1px) scale(0.97); transition: transform 0.1s ease; }
.btn-outline:active { transform: scale(0.97); transition: transform 0.1s ease; }

/* 9. TARJETAS DE LOCACIÓN — badges visibles en dispositivos táctiles (sin hover) */
@media (hover: none) {
  .sc-details {
    opacity: 1 !important;
    transform: translateY(0) !important;
  }
  .sc-overlay {
    opacity: 1 !important;
    background: linear-gradient(to top,rgba(5,5,5,0.97) 0%,rgba(5,5,5,0.48) 55%,transparent 100%) !important;
  }
}

/* 10. SAFE AREA — WhatsApp y scroll hint no tapados por barra del navegador iOS */
.wsp-float {
  bottom: calc(2rem + env(safe-area-inset-bottom, 0px));
  right:  calc(2rem + env(safe-area-inset-right, 0px));
}

/* 11. HERO MÓVIL — evitar desborde de contenido con height fija */
@media (max-width: 768px) {
  #hero {
    min-height: 100dvh;      /* dvh = dynamic viewport height, evita el salto de la barra del navegador */
    height: auto;
    padding-top: 5.5rem;
    padding-bottom: 4rem;
  }
  .hero-scroll-hint {
    position: absolute;
    bottom: calc(1.2rem + env(safe-area-inset-bottom, 0px));
    left: 50%;
    transform: translateX(-50%);
    margin-top: 0;
    animation: scrollBounceMobile 2.4s ease-in-out infinite;
  }
  @keyframes scrollBounceMobile {
    0%, 100% { transform: translateX(-50%) translateY(0);   opacity: 0.6; }
    50%       { transform: translateX(-50%) translateY(6px); opacity: 1;   }
  }
}

/* 12. DESKTOP GRANDE (≥1280px) — 4 columnas locaciones, 3 columnas servicios */
@media (min-width: 1280px) {
  .sucursales-grid {
    grid-template-columns: repeat(4, 1fr) !important;
  }
  section { padding: 8rem 8rem; }
  .servicios-grid { grid-template-columns: repeat(3, 1fr); }
}

/* 13. DESKTOP MUY GRANDE (≥1600px) — contener el ancho máximo */
@media (min-width: 1600px) {
  nav, section, #contacto {
    max-width: 1520px;
    margin-left: auto;
    margin-right: auto;
  }
  nav {
    left: 50%;
    transform: translateX(-50%);
    width: 100%;
  }
}

/* 14. TABLET (768px–1024px) — ajuste fino de grillas y tipografía */
@media (min-width: 769px) and (max-width: 1024px) {
  .servicios-grid     { grid-template-columns: repeat(2, 1fr); }
  .sucursales-grid    { grid-template-columns: repeat(3, 1fr) !important; }
  .sucursales-header  { flex-direction: row; align-items: flex-end; }
  .modal { max-width: 92vw; }
  .modal-specs { grid-template-columns: repeat(3, 1fr); }
  .hero-cta { gap: 0.7rem; }
  .hero-event-types { gap: 0.5rem; }
  .btn-event-type { padding: 0.75rem 1.1rem; font-size: 0.5rem; }
}

/* =========================================================
   8. MEDIA QUERIES ESTRICTOS (LA MAGIA RESPONSIVA)
   ========================================================= */

@media(max-width: 1024px) {
    section { padding: 6rem 3rem; }
    nav { padding: 1.5rem 2rem; }
    .nav-links { gap: 1.5rem; }
    .servicios-grid { grid-template-columns: repeat(2, 1fr); }
    .sucursales-grid { grid-template-columns: repeat(3, 1fr); }
}

@media(max-width: 768px) {
    section { padding: 5rem 1.5rem; }
    nav { padding: 1.2rem 1.5rem; }
    
    /* Activar Menú Móvil */
    .nav-links { display: none; }
    .hamburger { display: flex; }
    
    .hero-h1 { font-size: clamp(3rem, 12vw, 5rem); }
    .hero-flag-big.is-fixed { display: none !important; }
    
    .servicios-grid { grid-template-columns: repeat(2, 1fr); }
    .hero-event-types { gap: 0.5rem; }
    .btn-event-type { padding: 0.8rem 1rem; font-size: 0.5rem; flex: 1 1 calc(50% - 0.25rem); text-align: center; }
    .sucursales-grid { grid-template-columns: repeat(2, 1fr); }
    .sucursales-header { flex-direction: column; align-items: flex-start; }
    
    /* MODAL RESPONSIVO */
    .modal-backdrop { padding: 1rem !important; }
    .modal-body { padding: 1.5rem !important; }
    
    /* Forzar paquetes a 1 columna en móvil */
    .svc-pkg-container { display: flex !important; flex-direction: column !important; }
    .svc-val-list { grid-template-columns: 1fr !important; }
}

@media(max-width: 480px) {
    nav .nav-logo img { height: 38px; }
    .sucursales-grid { grid-template-columns: 1fr 1fr; }
    .contact-btns { flex-direction: column; align-items: center; }
    
    /* Modal en teléfonos pequeños */
    .modal-backdrop { padding: 0.5rem !important; }
    .modal { max-height: 95vh; }
    .modal-body { padding: 1.2rem !important; }
    .svc-val-container { padding: 1.2rem !important; }
}

/* =========================================================
   SECCIÓN EXPERIENCIA NOS AVALA
   ========================================================= */
#experiencia {
  background: linear-gradient(180deg, #050505 0%, #090704 60%, #050505 100%);
  border-top: 1px solid rgba(201,168,76,0.12);
  border-bottom: 1px solid rgba(201,168,76,0.12);
}
.exp-header {
  text-align: center;
  margin-bottom: 3.5rem;
}

/* Contadores */
.exp-stats {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 1px;
  background: rgba(201,168,76,0.12);
  border: 1px solid rgba(201,168,76,0.12);
  margin-bottom: 4rem;
}
.exp-stat {
  background: #050505;
  padding: 2rem 1rem;
  text-align: center;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.exp-stat-num {
  font-family: 'Playfair Display', serif;
  font-size: clamp(2rem, 4vw, 3.2rem);
  font-style: italic;
  color: var(--gold);
  line-height: 1;
}
.exp-stat-label {
  font-family: 'Cinzel', serif;
  font-size: 0.42rem;
  letter-spacing: 0.2em;
  text-transform: uppercase;
  color: var(--cream);
  opacity: 0.6;
}

/* Categorías de clientes */
.exp-clients {
  display: flex;
  flex-direction: column;
  gap: 2.8rem;
}
.exp-category {}
.exp-cat-title {
  font-family: 'Cinzel', serif;
  font-size: 0.55rem;
  letter-spacing: 0.25em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.75;
  margin-bottom: 1rem;
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.exp-cat-title i {
  font-size: 0.7rem;
  opacity: 0.8;
}
.exp-cat-title::after {
  content: '';
  flex: 1;
  height: 1px;
  background: linear-gradient(to right, rgba(201,168,76,0.3), transparent);
  margin-left: 0.6rem;
}
.exp-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
}
.exp-tag {
  font-family: 'Cinzel', serif;
  font-size: 0.48rem;
  letter-spacing: 0.1em;
  padding: 0.4rem 0.9rem;
  border: 1px solid rgba(201,168,76,0.2);
  background: rgba(201,168,76,0.04);
  color: var(--cream);
  opacity: 0.85;
  transition: border-color 0.25s, background 0.25s, opacity 0.25s;
  white-space: nowrap;
}
.exp-tag:hover {
  border-color: rgba(201,168,76,0.55);
  background: rgba(201,168,76,0.1);
  opacity: 1;
}
.exp-tag-gold {
  border-color: rgba(201,168,76,0.4);
  background: rgba(201,168,76,0.07);
  color: var(--gold);
  opacity: 1;
}
.exp-tag-gold:hover {
  background: rgba(201,168,76,0.15);
  border-color: var(--gold);
}

/* ---- LOGO WALL / TICKER ---- */
.logo-wall {
  margin: 3.5rem 0;
  overflow: hidden;
}
.logo-wall-label {
  font-family: 'Cinzel', serif;
  font-size: 0.5rem;
  letter-spacing: 0.3em;
  text-transform: uppercase;
  color: var(--gold);
  opacity: 0.5;
  text-align: center;
  margin-bottom: 1.8rem;
}
.logo-marquee-wrap {
  overflow: hidden;
  /* Fade a los costados */
  mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  -webkit-mask-image: linear-gradient(to right, transparent 0%, black 8%, black 92%, transparent 100%);
  margin-bottom: 0.8rem;
}
@keyframes marqueeLeft {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
@keyframes marqueeRight {
  0%   { transform: translateX(-50%); }
  100% { transform: translateX(0); }
}
.logo-marquee-track {
  display: flex;
  width: max-content;
  gap: 1rem;
  animation: marqueeLeft 35s linear infinite;
}
.logo-marquee-reverse {
  animation: marqueeRight 38s linear infinite;
}
.logo-marquee-wrap:hover .logo-marquee-track {
  animation-play-state: paused;
}
.logo-item {
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0.7rem 1.8rem;
  border: 1px solid rgba(201,168,76,0.18);
  background: rgba(201,168,76,0.03);
  min-width: 160px;
  height: 56px;
  flex-shrink: 0;
  transition: border-color 0.3s, background 0.3s;
}
.logo-item:hover {
  border-color: rgba(201,168,76,0.5);
  background: rgba(201,168,76,0.08);
}
/* Texto placeholder — se reemplaza por <img> cuando haya logo real */
.logo-name {
  font-family: 'Cinzel', serif;
  font-size: 0.52rem;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--cream);
  opacity: 0.6;
  white-space: nowrap;
  transition: opacity 0.3s, color 0.3s;
}
.logo-item:hover .logo-name {
  opacity: 1;
  color: var(--gold);
}
/* Cuando haya imagen real dentro de .logo-item */
.logo-item img {
  max-height: 36px;
  max-width: 130px;
  width: auto;
  object-fit: contain;
  filter: brightness(0) invert(1) opacity(0.55);
  transition: filter 0.3s;
}
.logo-item:hover img {
  filter: brightness(0) invert(1) opacity(0.9) sepia(1) saturate(3) hue-rotate(5deg);
}

/* Responsive experiencia */
@media (max-width: 1024px) {
  .exp-stats { grid-template-columns: repeat(3, 1fr); }
}
@media (max-width: 768px) {
  .exp-stats { grid-template-columns: repeat(2, 1fr); }
  .exp-tag { font-size: 0.44rem; padding: 0.35rem 0.7rem; }
}
@media (max-width: 480px) {
  .exp-stats { grid-template-columns: repeat(2, 1fr); }
}

/* =========================================================
   ACORDEÓN DE PAQUETES (UI/UX INTERACTIVO)
   ========================================================= */
.pkg-toggle-btn {
    background: transparent;
    border: 1px solid rgba(201, 168, 76, 0.4);
    color: var(--gold);
    padding: 0.5rem 1rem;
    border-radius: 50px;
    font-family: 'DM Sans', sans-serif;
    font-size: 0.75rem;
    font-weight: 500;
    cursor: pointer;
    transition: all 0.3s ease;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    margin: 0.5rem auto 0;
}
.pkg-toggle-btn:hover {
    background: rgba(201, 168, 76, 0.1);
    transform: translateY(-2px);
}
.pkg-toggle-btn i {
    transition: transform 0.4s ease;
}
.pkg-items-list {
    list-style: none;
    padding: 0;
    margin: 0;
    max-height: 0; /* Oculto por defecto */
    opacity: 0;
    overflow: hidden;
    transition: all 0.5s cubic-bezier(0.4, 0, 0.2, 1);
    text-align: left;
}
.pkg-items-list li {
    font-family: 'DM Sans', sans-serif;
    font-size: 0.85rem;
    color: var(--cream);
    opacity: 0.85;
    margin-bottom: 0.6rem;
    display: flex;
    align-items: flex-start;
    gap: 8px;
    line-height: 1.4;
}
.pkg-items-list li strong {
    color: var(--white);
    font-weight: 600;
}
.pkg-items-list li i {
    color: var(--gold);
    font-size: 0.7rem;
    margin-top: 4px;
    flex-shrink: 0;
}

/* =========================================================
   PARCHE MAESTRO DEFINITIVO: GRILLAS Y RESPONSIVIDAD
   ========================================================= */

/* 1. CAMBIO A 3 COLUMNAS PARA LOCACIONES (Diseño tipo Póster) */
.sucursales-grid { 
    grid-template-columns: repeat(3, 1fr) !important; 
}

/* 2. REGLAS ESTRICTAS ANTI-DESBORDE PARA EL MODAL EN MÓVILES */
@media (max-width: 768px) {
    /* Ajuste de Locaciones en Tablet */
    .sucursales-grid { 
        grid-template-columns: repeat(2, 1fr) !important; 
    }
    
    /* Forzar al fondo oscuro a contener el modal sin empujarlo */
    .modal-backdrop { 
        padding: 1rem !important; 
        align-items: flex-start !important; /* Evita que el modal se esconda arriba */
        overflow-y: auto !important;
    }
    
    /* El modal DEBE respetar el 100% del espacio disponible */
    .modal {
        width: 100% !important;
        max-width: 100% !important;
        margin: 2rem auto !important;
        box-sizing: border-box !important;
        overflow-x: hidden !important;
    }
    
    /* Márgenes internos del modal más amigables para celular */
    .modal-body { 
        padding: 1.5rem 1.2rem !important; 
        box-sizing: border-box !important;
        overflow-x: hidden !important; 
    }
    
    /* Paquetes y proposiciones de valor: columna vertical */
    .svc-pkg-container,
    .svc-val-list {
        display: flex !important;
        flex-direction: column !important;
        width: 100% !important;
        gap: 1rem !important;
        box-sizing: border-box !important;
    }

    /* Specs (capacidad / estac / plazas): mantener en fila horizontal, más compactas */
    .modal-specs {
        display: grid !important;
        grid-template-columns: repeat(3, 1fr) !important;
        gap: 1.5px !important;
        width: 100% !important;
        box-sizing: border-box !important;
    }
    .modal-spec {
        padding: 0.9rem 0.4rem !important;
        box-sizing: border-box !important;
    }
    .modal-spec-val {
        font-size: 1.35rem !important;
    }
    .modal-spec-key {
        font-size: 0.42rem !important;
        letter-spacing: 0.12em !important;
    }

    /* Tarjetas de paquetes y valor */
    .svc-pkg-card,
    .svc-val-item {
        width: 100% !important;
        box-sizing: border-box !important;
    }
    
    /* Textos largos que rompían la caja ahora se rompen hacia abajo */
    .modal-name { 
        font-size: 1.6rem !important; 
        word-wrap: break-word !important; 
        hyphens: auto !important; 
        line-height: 1.1 !important;
    }
    
    /* Carrusel responsivo: altura la controla JS según imagen activa */
    .carousel-track img {
        width: 100% !important;
        height: 100% !important;
        object-fit: contain !important;
    }
}

@media (max-width: 480px) {
    /* En teléfonos pequeños, 1 sola columna para locaciones */
    .sucursales-grid {
        grid-template-columns: 1fr !important;
    }

    /* En teléfonos pequeños se respeta la altura dinámica del JS */

    /* Specs: fila horizontal compacta con texto aún más pequeño */
    .modal-specs {
        grid-template-columns: repeat(3, 1fr) !important;
    }
    .modal-spec {
        padding: 0.7rem 0.2rem !important;
    }
    .modal-spec-val {
        font-size: 1.1rem !important;
    }
    .modal-spec-key {
        font-size: 0.38rem !important;
        letter-spacing: 0.08em !important;
    }

    /* Modal body con menos padding en pantallas muy pequeñas */
    .modal-body {
        padding: 1rem 1rem !important;
    }
}