/* ===== PALETA BASADA EN EL LOGO (ROJO + GRIS CLARO) ===== */
:root{
  --rojo-capi: #E30613;
  --rojo-oscuro: #b1000e;
  --gris-claro: #d9d9d9;
  --gris-medio: #a8a8a8;
  --gris-oscuro: #5a5a5a;
  --carbon: #1a1a1a;
  --blanco: #fff;
}

*{ box-sizing: border-box; margin: 0; padding: 0; }
html{ scroll-behavior: smooth; }
html, body{ height: 100%; }
body{
  font-family: 'Poppins', sans-serif;
  color: var(--blanco);
  overflow-x: hidden;
  background:
    radial-gradient(1400px 900px at -8% -8%, rgba(227,6,19,.12), transparent 65%),
    radial-gradient(1100px 700px at 108% 8%, rgba(217,217,217,.10), transparent 60%),
    #0d0d0d;
}

#particles-canvas{ position: fixed; inset: 0; z-index: 0; pointer-events: none; }

#scroll-bar{
  position: fixed; top:0; left:0; height:5px; width:0%;
  background: linear-gradient(90deg, var(--rojo-capi), var(--gris-claro), var(--rojo-capi));
  background-size: 200% 100%;
  z-index: 1000;
  box-shadow: 0 0 15px rgba(227,6,19,.6), 0 0 30px rgba(217,217,217,.3);
  animation: shimmer-bar 3s linear infinite;
}
@keyframes shimmer-bar{ 0%{background-position:200% 0} 100%{background-position:-200% 0} }

/* ===== NAVBAR ===== */
.logo{ height: 48px; filter: drop-shadow(0 2px 8px rgba(227,6,19,.5)); }
.navbar.transparent-nav{ background: transparent; transition: background .4s, box-shadow .4s, backdrop-filter .4s; z-index: 1001; }
.navbar.navbar-scrolled{
  background: rgba(13,13,13,.90);
  backdrop-filter: blur(12px) saturate(180%);
  box-shadow: 0 8px 24px rgba(0,0,0,.6), inset 0 0 0 1px rgba(227,6,19,.25);
}
.navbar-brand span{
  font-weight: 700;
  background: linear-gradient(90deg, var(--blanco), var(--gris-claro));
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent;
}
.navbar .nav-link{
  color: var(--blanco) !important; margin-left: 12px; padding: 8px 16px !important;
  border-radius: 8px; transition: all .3s; position: relative;
}
.navbar .nav-link::after{
  content: ''; position: absolute; bottom: 4px; left: 50%; width: 0; height: 2px;
  background: var(--rojo-capi); transform: translateX(-50%); transition: width .3s;
}
.navbar .nav-link:hover{ color: var(--rojo-capi) !important; text-shadow: 0 0 12px rgba(227,6,19,.6); transform: translateY(-2px); }
.navbar .nav-link:hover::after{ width: 60%; }
.btn-pedido-nav{
  background: linear-gradient(135deg, var(--rojo-capi), var(--rojo-oscuro)) !important;
  border-radius: 20px !important; padding: 8px 20px !important;
  box-shadow: 0 4px 15px rgba(227,6,19,.4);
}
.btn-pedido-nav:hover{ transform: translateY(-2px) scale(1.05) !important; box-shadow: 0 6px 20px rgba(227,6,19,.6), 0 0 20px rgba(217,217,217,.3); }

/* ===== HERO ===== */
.hero{ position: relative; z-index:1; min-height:100vh; padding-top:120px; text-shadow: 2px 2px 8px rgba(0,0,0,.6); }
.hero-logo{ width: 220px; filter: drop-shadow(0 10px 28px rgba(227,6,19,.5)); }
.floating{ animation: float 4s ease-in-out infinite; }
@keyframes float{ 0%,100%{transform:translateY(0) rotate(0)} 25%{transform:translateY(-8px) rotate(-1deg)} 75%{transform:translateY(-12px) rotate(1deg)} }
.hero-title{ font-size: clamp(2.2rem, 5.5vw, 3.8rem); margin-top: 28px; font-weight: 700; }
.gradient-shine{
  background: linear-gradient(90deg, var(--gris-claro), #fff, var(--gris-medio), #fff, var(--gris-claro));
  -webkit-background-clip: text; background-clip: text; -webkit-text-fill-color: transparent;
  background-size: 200% auto; animation: shine 6s linear infinite;
}
@keyframes shine{ 0%{background-position:0% 50%} 100%{background-position:200% 50%} }
.hero-text{ max-width:780px; margin:18px auto 36px; font-size:1.18rem; opacity:.94; line-height:1.65; }
.hero-cta-group{ display:flex; gap:18px; flex-wrap:wrap; justify-content:center; }

/* BOTONES ESTILO CAPI */
.btn-capi{
  position: relative; overflow: hidden; border: none; font-weight: 700; border-radius: 32px;
  padding: 15px 36px; font-size: 1.08rem; transition: all .35s; text-decoration: none;
  display: inline-flex; align-items: center; text-shadow: none;
}
.btn-capi::before{
  content: ''; position: absolute; top:0; left:-100%; width:100%; height:100%;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.35), transparent); animation: sweep-enhanced 4.5s infinite;
}
@keyframes sweep-enhanced{ 0%{left:-100%} 50%,100%{left:100%} }

.btn-capi.btn-primary{
  background: linear-gradient(135deg, var(--rojo-capi), var(--rojo-oscuro));
  color: var(--blanco);
  box-shadow: 0 12px 30px rgba(227,6,19,.4), 0 0 0 1px rgba(227,6,19,.3) inset;
}
.btn-capi.btn-primary:hover{
  transform: translateY(-3px) scale(1.04);
  box-shadow: 0 18px 42px rgba(227,6,19,.6), 0 0 32px rgba(217,217,217,.3);
  color: var(--blanco);
}

.btn-capi.btn-promo{
  background: linear-gradient(135deg, #fff, var(--gris-claro));
  color: var(--rojo-capi);
  font-weight: 800;
  box-shadow: 0 12px 30px rgba(255,255,255,.3), 0 0 0 2px var(--rojo-capi) inset;
}
.btn-capi.btn-promo:hover{
  background: var(--blanco);
  transform: translateY(-4px) scale(1.06);
  box-shadow: 0 18px 42px rgba(255,255,255,.5), 0 0 40px rgba(227,6,19,.4);
  color: var(--rojo-capi);
}

.pulse-btn{ animation: pulse-glow 3s ease-in-out infinite; }
@keyframes pulse-glow{
  0%,100%{ transform:scale(1); box-shadow:0 12px 30px rgba(227,6,19,.4) }
  50%{ transform:scale(1.02); box-shadow:0 18px 42px rgba(227,6,19,.6), 0 0 38px rgba(217,217,217,.35) }
}

/* REVEAL */
.reveal{ opacity:0; transform: translateY(60px) scale(.97); filter: blur(5px); }
.reveal.show{ opacity:1; transform:none; filter:none; transition: all 1s cubic-bezier(0.34, 1.56, 0.64, 1); }

/* HEADERS DE SECCIÃ“N */
.section-header{ position: relative; }
.badge-section{
  display:inline-block; padding:7px 22px; background: rgba(227,6,19,.15);
  border:1px solid rgba(227,6,19,.4); border-radius:22px; color: var(--rojo-capi);
  font-size:.88rem; font-weight:600; letter-spacing:1.6px; text-transform:uppercase; margin-bottom:18px;
}
.divider-shine{ width:90px; height:3px; background: linear-gradient(90deg, transparent, var(--gris-claro), transparent); margin:0 auto; border-radius:2px; box-shadow: 0 0 12px rgba(217,217,217,.4); }

/* ESPECIALIDADES */
.especialidades{ position: relative; z-index:1; padding:90px 0; }
.card.especialidad{
  border:none; border-radius:22px; overflow:hidden; background: rgba(255,255,255,.04); backdrop-filter: blur(10px);
  box-shadow: 0 12px 32px rgba(0,0,0,.35), inset 0 0 0 1px rgba(227,6,19,.15); transition: all .4s cubic-bezier(0.34, 1.56, 0.64, 1); position: relative;
}
.card.especialidad::before{
  content:''; position:absolute; inset:0; background: linear-gradient(135deg, rgba(227,6,19,.08), transparent 50%); opacity:0; transition: opacity .4s; pointer-events:none; z-index:1;
}
.card.especialidad:hover::before{ opacity:1; }
.card.especialidad:hover{
  transform: translateY(-10px);
  box-shadow: 0 24px 56px rgba(0,0,0,.45), 0 0 0 2px rgba(227,6,19,.5) inset, 0 0 45px rgba(227,6,19,.25);
}
.card.especialidad img{ height:230px; object-fit: cover; transition: all .5s; }
.card.especialidad:hover img{ transform: scale(1.1) translateY(-5px); filter: brightness(1.14) saturate(1.18) contrast(1.06); }

.badge-popular{
  position:absolute; top:14px; right:14px; background: linear-gradient(135deg, var(--rojo-capi), var(--rojo-oscuro));
  color:#fff; padding:7px 16px; border-radius:22px; font-size:.82rem; font-weight:600; z-index:10; box-shadow: 0 5px 14px rgba(227,6,19,.6); animation: bounce-badge 2.2s ease-in-out infinite;
}
.badge-fresh{ background: linear-gradient(135deg, #0077b6, #005f8a); }
@keyframes bounce-badge{ 0%,100%{transform:scale(1)} 50%{transform:scale(1.09)} }

.card-icon{ 
  font-size:2.8rem; 
  color: var(--rojo-capi); 
  margin-bottom:14px; 
  filter: drop-shadow(0 5px 10px rgba(227,6,19,.5));
  display: block;
  text-align: center;
}
.card-title{ color: var(--gris-claro); font-weight:700; margin-top:10px; font-size:1.35rem; }
.card-text{ color: rgba(255,255,255,.82); font-size:.97rem; line-height:1.55; }

.tilt-3d{ transform-style: preserve-3d; perspective: 1000px; }
.tilt-3d .card-body{ transform: translateZ(32px); position: relative; z-index: 2; }
.carousel-control-prev-icon, .carousel-control-next-icon{
  background-color: rgba(0,0,0,.85); border: 2px solid rgba(227,6,19,.7); border-radius: 50%; box-shadow: 0 0 16px rgba(227,6,19,.5); padding: 22px;
}

/* PROMOCIONES */
.promociones{ position: relative; z-index:1; padding: 90px 0; background: rgba(255,255,255,.02); }

.promo-pack{
  border-radius: 16px;
  background: rgba(255,255,255,.05);
  backdrop-filter: blur(10px);
  border: 1px solid rgba(227,6,19,.15);
  overflow: hidden;
  transition: all .4s cubic-bezier(0.34, 1.56, 0.64, 1);
  display: flex;
  flex-direction: column;
  height: 100%;
}

.promo-pack:hover{
  transform: translateY(-8px);
  background: rgba(227,6,19,.08);
  border-color: rgba(227,6,19,.3);
  box-shadow: 0 15px 40px rgba(0,0,0,.3);
}

.promo-pack.popular-pack{
  transform: scale(1.05);
  background: rgba(227,6,19,.12);
  border: 2px solid rgba(227,6,19,.4);
  box-shadow: 0 20px 50px rgba(227,6,19,.25);
}

.promo-pack.popular-pack:hover{
  transform: scale(1.08) translateY(-4px);
  box-shadow: 0 25px 60px rgba(227,6,19,.35);
}

.pack-header{
  position: relative;
  height: 100px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px;
  color: white;
  font-weight: 700;
}

.pack-1{ background: linear-gradient(135deg, #ff6b6b, #ee5a6f); }
.pack-2{ background: linear-gradient(135deg, var(--rojo-capi), #ff4a4a); }
.pack-3{ background: linear-gradient(135deg, #e74c3c, #c0392b); }

.pack-number{
  font-size: 0.9rem;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  background: rgba(255,255,255,.2);
  padding: 6px 14px;
  border-radius: 20px;
}

.pack-badge-popular{
  font-size: 0.85rem;
  letter-spacing: 1.2px;
  text-transform: uppercase;
  background: linear-gradient(135deg, #FFD700, #ffae00);
  color: var(--rojo-capi);
  padding: 7px 16px;
  border-radius: 22px;
  font-weight: 800;
}

.pack-price{ font-size: 1.8rem; text-shadow: 0 2px 8px rgba(0,0,0,.3); }

.pack-content{
  padding: 20px;
  display: flex;
  flex-direction: column;
  flex-grow: 1;
}

.pack-content h5{ color: var(--gris-claro); margin-bottom: 14px; font-weight: 700; font-size: 1.2rem; }

.pack-description{
  color: rgba(255,255,255,.80);
  font-size: 0.95rem;
  line-height: 1.5;
  margin-bottom: 16px;
  padding: 14px;
  background: rgba(0,0,0,.2);
  border-radius: 10px;
  border-left: 3px solid rgba(227,6,19,.5);
}

.promo-pack:hover .pack-description{
  background: rgba(227,6,19,.1);
  border-left-color: var(--rojo-capi);
  color: rgba(255,255,255,.95);
}

.pack-list{
  list-style: none;
  margin: 0;
  padding: 0;
  text-align: left;
}

.pack-list li{
  color: rgba(255,255,255,.85);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 0.95rem;
  line-height: 1.4;
}

.pack-list i{ 
  color: var(--rojo-capi); 
  font-size: 1.1rem;
  flex-shrink: 0;
}

/* PROMOCIÃ“N DESTACADA */
.promocion{
  position: relative; z-index:1; padding:110px 24px;
  background: linear-gradient(-45deg, var(--rojo-oscuro), var(--rojo-capi), #ff3030, var(--rojo-capi), var(--rojo-oscuro));
  background-size: 400% 400%; animation: gradient-shift 16s ease infinite;
  border-top: 2px solid rgba(255,255,255,.25); border-bottom: 2px solid rgba(255,255,255,.25);
  text-shadow: 2px 2px 10px rgba(0,0,0,.6);
}
@keyframes gradient-shift{ 0%,100%{background-position:0% 50%} 50%{background-position:100% 50%} }
.promo-icon{ font-size:4.5rem; animation: fire-pulse 1.6s ease-in-out infinite; margin-bottom:22px; }
@keyframes fire-pulse{ 0%,100%{transform:scale(1) rotate(0)} 50%{transform:scale(1.18) rotate(6deg)} }
.promocion h2{ font-size:2.8rem; margin-bottom:20px; }
.promo-details{ font-size:1.25rem; margin-bottom:36px; max-width:650px; margin-inline:auto; line-height: 1.7; }

/* POR QUÃ‰ ELEGIRNOS */
.por-que-elegirnos{ position: relative; z-index:1; background: rgba(255,255,255,.02); padding: 90px 0; }
.feature-box{
  padding: 44px 24px; border-radius:18px; background: rgba(255,255,255,.03); backdrop-filter: blur(8px);
  border:1px solid rgba(227,6,19,.12); transition: all .4s;
}
.feature-box:hover{ transform: translateY(-10px); background: rgba(227,6,19,.08); border-color: rgba(227,6,19,.35); box-shadow: 0 18px 40px rgba(0,0,0,.35), 0 0 35px rgba(227,6,19,.25); }
.feature-icon{ font-size:3.8rem; color: var(--rojo-capi); margin-bottom:22px; display:inline-block; filter: drop-shadow(0 5px 14px rgba(227,6,19,.6)); }
.feature-box h5{ color: var(--gris-claro); font-weight:700; margin-bottom:14px; font-size:1.35rem; }
.feature-box p{ color: rgba(255,255,255,.78); line-height:1.65; }

/* TESTIMONIOS */
.testimonios{ position: relative; z-index:1; padding: 90px 0; }
.testimonio-card{
  padding: 36px; border-radius:18px; background: rgba(255,255,255,.05); backdrop-filter: blur(10px);
  border:1px solid rgba(227,6,19,.18); transition: all .4s; height:100%;
}
.testimonio-card:hover{ transform: translateY(-8px); background: rgba(227,6,19,.08); box-shadow: 0 14px 34px rgba(0,0,0,.35), 0 0 28px rgba(227,6,19,.22); border-color: rgba(227,6,19,.4); }
.stars{ color: var(--rojo-capi); font-size: 1.25rem; margin-bottom:18px; }
.testimonio-text{ font-style: italic; color: rgba(255,255,255,.87); line-height:1.75; margin-bottom:22px; font-size:1.02rem; }
.testimonio-autor{ display:flex; flex-direction:column; gap:5px; }
.testimonio-autor strong{ color: var(--gris-claro); font-size:1.12rem; }
.testimonio-autor span{ color: rgba(255,255,255,.62); font-size:.92rem; }

/* CONTACTO */
.contacto{ position: relative; z-index:1; background: rgba(255,255,255,.02); padding: 90px 0; }
.contacto-info{ display:flex; flex-direction:column; gap:26px; }
.contacto-item{
  display:flex; align-items:flex-start; gap:22px; padding:22px; border-radius:14px;
  background: rgba(255,255,255,.04); backdrop-filter: blur(8px); border:1px solid rgba(227,6,19,.14); transition: all .35s;
}
.contacto-item:hover{ background: rgba(227,6,19,.08); border-color: rgba(227,6,19,.35); transform: translateX(10px); }
.contacto-item i{ font-size:2.2rem; color: var(--rojo-capi); flex-shrink:0; }
.contacto-item h6{ color: var(--gris-claro); font-weight:700; margin-bottom:8px; }
.contacto-item p{ color: rgba(255,255,255,.82); margin:0; line-height:1.55; }
.contacto-item a{ color: rgba(255,255,255,.82); text-decoration: none; transition: color .3s; }
.contacto-item a:hover{ color: var(--rojo-capi); }

.mapa-container{ border-radius:18px; overflow: hidden; box-shadow: 0 12px 32px rgba(0,0,0,.4), 0 0 0 1px rgba(227,6,19,.2); }

/* FOOTER */
.footer{ background: rgba(0,0,0,.92); border-top:2px solid rgba(227,6,19,.3); box-shadow: 0 -18px 45px rgba(0,0,0,.6); position: relative; z-index: 1; }
.footer-logo img{ filter: drop-shadow(0 5px 14px rgba(227,6,19,.5)); }
.footer p{ color: rgba(255,255,255,.82); }
.social-icons a{ color: var(--gris-claro); margin:0 14px; font-size:1.6rem; transition: all .35s; display:inline-block; }
.social-icons a:hover{ color: var(--rojo-capi); transform: translateY(-5px) scale(1.25); filter: drop-shadow(0 5px 14px rgba(227,6,19,.7)); }

/* Top button */
#btnTop{
  position: fixed; right:26px; bottom:28px; width:56px; height:56px; border-radius:50%; border:2px solid rgba(227,6,19,.5);
  cursor:pointer; display:none; background: linear-gradient(135deg, var(--rojo-capi), var(--rojo-oscuro)); color:#fff; font-size:28px;
  box-shadow: 0 0 22px rgba(227,6,19,.5); z-index:1001; transition: all .35s;
}
#btnTop:hover{ transform: scale(1.14) translateY(-5px); box-shadow: 0 0 40px rgba(227,6,19,.8); border-color: var(--gris-claro); }

/* RESPONSIVE */
@media (max-width: 991px){
  .hero-title{ font-size: 2.4rem; }
  .hero-text{ font-size: 1.08rem; }
  .hero-cta-group{ flex-direction: column; align-items: center; }
  .btn-capi{ width: 100%; max-width: 320px; justify-content: center; }
  .section-header h2{ font-size: 2.2rem; }
  .promocion h2{ font-size: 2.2rem; }
  .promo-pack.popular-pack{ transform: scale(1.02); }
  .promo-pack.popular-pack:hover{ transform: scale(1.04) translateY(-4px); }
}

@media (max-width: 768px){
  .feature-icon{ font-size: 3rem; }
  .contacto-item{ flex-direction: column; align-items: center; text-align: center; }
  .mapa-container iframe{ height: 350px; }
  .pack-description{
    font-size: 0.9rem;
    padding: 12px;
    margin-bottom: 12px;
  }
  .pack-list li{
    font-size: 0.9rem;
    gap: 10px;
  }
}
.text-muted-small {
  color: var(--blanco) !important;
}

.text-muted {
  color: var(--blanco) !important;
}
