:root{
  --azul:#04313D;
  --lima:#D0DD28;
  --coral:#DF434C;
  --oliva:#82831F;
  --fw: 'Montserrat', sans-serif;
  --bg: #f6f8f9;
  --card-bg: #ffffff;
  --muted: #6b6b6b;
}
html,body{height:100%;font-family:var(--fw);color:#111;background:var(--bg)}
/* Navbar: white background, dark links; keep active in lima */
.navbar{background:#fff}
.nav-link{color:rgba(17,17,17,0.9)!important}
.nav-link.active{color:var(--lima)!important;font-weight:700}
.btn-lima{background:var(--lima);color:var(--azul);font-weight:700}
.card-program{background:var(--card-bg);border:1px solid rgba(13,48,55,0.06);box-shadow:0 8px 20px rgba(13,48,55,0.04)}
.angled{clip-path:polygon(0 0,100% 5%,100% 95%,0 100%);} 
/* Footer: white background with dark text to match navbar */
.angled{background: linear-gradient(90deg, rgba(208,221,40,0.06), rgba(223,67,76,0.03));}
footer{background:#fff;color:#111;padding:2rem 0;border-top:1px solid rgba(0,0,0,0.06)}
.social a{color:var(--lima);margin-right:1rem}
.price{color:var(--coral);font-weight:800}
@media (max-width:768px){.hero{min-height:55vh}}
.fade-up{transform:translateY(10px);opacity:0;transition:all .6s ease-in-out}
.fade-up.show{transform:none;opacity:1}
.product{background:var(--card-bg);border-radius:8px;padding:1rem;border:1px solid rgba(13,48,55,0.05);box-shadow:0 8px 20px rgba(13,48,55,0.04)}
.contact-card{background:var(--card-bg);padding:1.25rem;border-radius:8px;border:1px solid rgba(13,48,55,0.05);box-shadow:0 6px 18px rgba(13,48,55,0.04)}
.gallery img{width:100%;height:100%;object-fit:scale-down;display:block}

.gallery-sw{position:relative}
.grid-gap{gap:10px}
.grid-gap{gap:10px}

.hero{min-height:70vh;display:flex;align-items:center;position:relative;overflow:hidden}
.hero::after{content:'';position:absolute;left:0;top:-10;right:0;bottom:0;background:linear-gradient(180deg,rgba(13,48,55,0.20),rgba(0,0,0,0.12));z-index:1}
.hero .container{position:relative;z-index:3}

/* Use an inline img so the entire photo can be visible while remaining responsive */
.hero-img{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);width:100%;height:100%;object-fit:cover;object-position:top;z-index:0}

/* Rounded logo */
.navbar-brand img, footer img{border-radius:10px;border:2px solid rgba(0,0,0,0.06)}

/* Program card: dark text on light card for clarity */
.card-program .card-body{color:#111}
.card-program h3{color:var(--azul);font-weight:700}

/* Gallery carousel tweaks */
.gallery-carousel .carousel-item{padding:10px}
.gallery-carousel .carousel-item img{width:100%;height:360px;object-fit:scale-down;border-radius:8px}

/* Carousel controls use brand azul for visibility */
.gallery-carousel .carousel-control-prev-icon,
.gallery-carousel .carousel-control-next-icon{filter:invert(18%) sepia(48%) saturate(600%) hue-rotate(140deg) brightness(95%) contrast(95%)}

/* Navbar toggler icon (fontawesome) */
.navbar-toggler .fas{color:rgba(17,17,17,0.95)}

/* Nav link hover - subtle emphasis */
.nav-link:hover{color:var(--azul)!important;text-decoration:none;font-weight:600}

/* Skip link (visually hidden but visible on focus) */
.skip-link{position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden}
.skip-link:focus, .visually-hidden-focusable:focus{position:static;left:0;top:0;width:auto;height:auto;padding:8px 12px;background:var(--lima);color:var(--azul);z-index:9999;border-radius:4px;text-decoration:none}

/* Focus visible for interactive elements */
:where(a,button,input,select,textarea){outline: none}
:where(a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible){box-shadow:0 0 0 4px rgba(208,221,40,0.16);outline:none;border-radius:4px}

/* Modal: light background, dark text for better contrast */
.modal-content{background:#fff;color:#111}
.modal-content .form-label{color:#111}
.modal-content .form-control{color:#111}

/* (lightbox removed) */

/* Header social buttons in gallery */
.py-5 .btn-outline-light{border-color:rgba(255,255,255,0.18);color:#fff}
.py-5 .btn-outline-light:hover{background:rgba(255,255,255,0.06);color:#fff}

/* hide header social buttons on small screens; they'll be available inside the collapsed menu */
@media (max-width:767.98px){
  header .d-flex.align-items-center.gap-2{display:none}
  .navbar-collapse .mobile-social{display:flex;gap:8px;margin-top:0.5rem}
}
@media (min-width:768px){
  .navbar-collapse .mobile-social{display:none}
}

/* Slide figure and caption overlay */
.slide-figure{position:relative;margin:0;width:100%;height:100%}
.slide-figure img{display:block;width:100%;height:100%;object-fit:scale-down}

/* (removed legacy Glide arrow styles) */

/* (carousel navigation/pagination styles removed) */

/* Gallery grid layout */
.gallery-grid .gallery-item{position:relative}
.gallery-img{width:100%;height:220px;object-fit:scale-down;display:block;border-radius:6px}

/* spinner/keyframes removed */

/* Program detail formatting */
#program-detail{transition:all 240ms ease}
.program-details-dl{display:block;padding:0;margin:0}
.program-details-dl dt{font-weight:700;color:var(--azul);margin-top:12px}
.program-details-dl dd{margin:4px 0 0 0;color:#333;margin-left:0}
.program-details-list{padding-left:1.25rem;margin:6px 0}
.program-details-list li{margin:4px 0}

/* Tienda: PRONTO banner and Merch video previews */
.banner-pronto{background:linear-gradient(90deg,#0f7f8a 0%, #0b5660 100%);color:#fff;font-weight:800;border-radius:12px;font-size:1.6rem;letter-spacing:1px}
.banner-pronto::before{content:'';position:absolute;left:0;top:0;right:0;bottom:0;border-radius:12px;box-shadow:inset 0 -40px 120px rgba(11,86,96,0.18)}
.banner-pronto{position:relative}
.banner-pronto.animate-pulse{animation:bannerPulse 3s ease-in-out infinite}
.merch-video{background:linear-gradient(180deg,rgba(255,255,255,0.02),rgba(0,0,0,0.04));padding:8px;border-radius:12px}
.merch-video video{border-radius:8px;box-shadow:0 12px 30px rgba(11,86,96,0.14);background:#000;display:block}
.merch-video figcaption{font-size:0.9rem;color:var(--muted);margin-top:8px;text-align:center}

@media (max-width:767.98px){
  .merch-video{padding:6px}
  .banner-pronto{font-size:1.25rem;padding:2.5rem}
}

@keyframes bannerPulse{
  0%{transform:translateY(0);box-shadow:0 8px 24px rgba(11,86,96,0.12)}
  50%{transform:translateY(-4px);box-shadow:0 18px 40px rgba(11,86,96,0.16)}
  100%{transform:translateY(0);box-shadow:0 8px 24px rgba(11,86,96,0.12)}
}

/* (Tienda-specific CSS moved to css/tienda.css) */

/* Eventos: imagen a la par del título */
.events-title-wrap{gap:12px;flex-wrap:wrap}
.events-title-wrap .events-brand{height:44px;width:auto;object-fit:contain;border-radius:6px;box-shadow:0 2px 6px rgba(0,0,0,.08)}
@media (min-width:768px){
  .events-title-wrap .events-brand{height:56px}
}

/* Eventos: header con logo a la izquierda, tamaño moderado (dentro del container) */
.events-header{position:relative;overflow:hidden}
.events-title-inline{flex-wrap:wrap}
.events-brand-left{height:48px;width:auto;object-fit:contain;border-radius:6px;box-shadow:0 2px 6px rgba(0,0,0,.12)}
@media (min-width:768px){
  .events-brand-left{height:56px}
}

