/*
  Los colores principales se inyectan desde index.php usando variables CSS.
  Importante: NO redefinir :root aquí, porque esta hoja se carga después del <style>
  y sobreescribe los colores guardados desde el panel admin.
*/

body{background: radial-gradient(1200px 600px at 20% 0%, rgba(var(--brand2-rgb),.25), transparent 60%),
             radial-gradient(1000px 500px at 90% 10%, rgba(var(--brand-rgb),.22), transparent 55%),
             var(--bg);
     color:#e5e7eb;}
.navbar{background: rgba(var(--bg-rgb),.6)!important; backdrop-filter: blur(10px);}
.hero{padding: 6rem 0 2.5rem 0;}
.hero h1{font-weight: 800; letter-spacing:-.02em; line-height:1.05;}
.badge-gradient{background: linear-gradient(90deg, var(--brand), var(--brand2));}
.btn-brand{background: linear-gradient(90deg, var(--brand), var(--brand2)); border:0;}
.btn-brand:hover{opacity:.95;}
.section-title{font-weight: 800; letter-spacing:-.01em;}
.card-soft{background: rgba(var(--card-rgb),.92); border: 1px solid rgba(148,163,184,.15); border-radius: 18px;}
.plan-card{position:relative; overflow:hidden;}
.plan-card.featured{border:1px solid rgba(var(--brand-rgb),.55); box-shadow: 0 0 0 1px rgba(var(--brand-rgb),.25), 0 18px 60px rgba(var(--brand-rgb),.10);}
.ribbon{position:absolute; top:18px; right:-52px; transform: rotate(35deg); background: linear-gradient(90deg, var(--brand), var(--brand2));
        color:#fff; padding:.35rem 3.5rem; font-weight:700; font-size:.75rem;}
.price-old{color:var(--muted); text-decoration: line-through;}
.price-new{font-size: 2.3rem; font-weight: 900;}
.price-cents{font-size: 1.1rem; vertical-align: super; opacity:.9;}
.icon-pill{width:44px; height:44px; border-radius:14px; background: rgba(var(--brand-rgb),.12); display:flex; align-items:center; justify-content:center;}
.gallery-img{width:100%; aspect-ratio: 16 / 10; object-fit: cover; border-radius: 16px; border:1px solid rgba(148,163,184,.15);}
.footer{border-top: 1px solid rgba(148,163,184,.12); padding: 2.5rem 0; color:var(--muted);}
.small-muted{color:var(--muted);}
hr.soft{border-color: rgba(148,163,184,.12); opacity:1;}
.accordion-item{background: rgba(var(--card-rgb),.92); border:1px solid rgba(148,163,184,.15);}
.accordion-button{background: transparent; color:#e5e7eb;}
.accordion-button:not(.collapsed){background: rgba(var(--brand-rgb),.08); color:#fff;}

/* Cards "glass" (usado en Descargar app). Si no se define, Bootstrap deja fondo blanco y el texto no se lee */
.glass{
  background: rgba(var(--card-rgb), .88) !important;
  border: 1px solid rgba(148,163,184,.18) !important;
  border-radius: 18px;
  box-shadow: 0 18px 60px rgba(0,0,0,.22);
}

/* WhatsApp flotante */
.whatsapp-float{
  position: fixed;
  width:56px;
  height:56px;
  bottom:20px;
  right:20px;
  background: linear-gradient(135deg, var(--brand), var(--brand2));
  color:#fff;
  border-radius:50%;
  text-align:center;
  font-size:28px;
  box-shadow:0 10px 25px rgba(0,0,0,.35);
  z-index:9999;
  display:flex;
  align-items:center;
  justify-content:center;
  transition:transform .2s ease, box-shadow .2s ease;
}
.whatsapp-float:hover{
  transform:scale(1.05);
  box-shadow:0 14px 30px rgba(0,0,0,.45);
  color:#fff;
  text-decoration:none;
}


/* === TEXTO BLANCO DEFAULT === */

body, p, span, li, a, label, small, div {
  color: #ffffff !important;
}

h1, h2, h3, h4, h5, h6 {
  color: #ffffff !important;
  font-weight: 900;
  text-shadow:
    0 2px 10px rgba(255,255,255,0.25),
    0 0 25px rgba(255,255,255,0.15);
}
