/* ============================================================
   🌸 TuGabinete — PLANS (SPA) · más llamativo + full recomendado
   Scope: SOLO dentro de .plans-page
   ============================================================ */

.plans-page{
  font-family: "Poppins", sans-serif;
  --tg-pink: var(--primary, #ffadad);
  --tg-cream: var(--cream, #fff3c2);

  /* acentos (más llamativo pero suave) */
  --tg-violet: #bdb2ff;
  --tg-mint: #caffbf;

  --tg-text: #222;
  --tg-muted: #444;
  --tg-card: rgba(255,255,255,0.92);
  --tg-border: rgba(255,173,173,0.22);
  --tg-shadow: 0 12px 28px rgba(0,0,0,0.07);
}

.plans-page *{ box-sizing: border-box; }

.plans-page .plans-main{
  max-width: 1100px;
  margin: 10 auto;
  padding: 50px 20px 60px;
}

/* Buttons */
.plans-page .btn-primary,
.plans-page .btn-secondary{
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 16px;
  border-radius: 12px;
  text-decoration: none;
  font-weight: 950;
  font-size: 15px;
  transition: transform .2s ease, box-shadow .2s ease;
}

.plans-page .btn-primary{
  background: var(--tg-pink);
  color: #2b2b2b;
  border: 1px solid rgba(255,173,173,0.65);
  box-shadow: 0 14px 30px rgba(255,173,173,0.40);
}
.plans-page .btn-primary:hover{
  transform: translateY(-2px);
  box-shadow: 0 18px 40px rgba(255,173,173,0.52);
}

.plans-page .btn-secondary{
  background: rgba(255,255,255,0.92);
  border: 1px solid rgba(0,0,0,0.08);
  color: #333;
  box-shadow: 0 12px 26px rgba(0,0,0,0.08);
}
.plans-page .btn-secondary:hover{ transform: translateY(-2px); }

.plans-page .full{ width: 100%; }

/* HERO */
.plans-page .plans-hero{
  padding: 28px 0 38px;
  max-width: 900px;
}

.plans-page .pill{
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,0.88);
  border: 1px solid rgba(255,173,173,0.35);
  box-shadow: 0 10px 24px rgba(0,0,0,0.07);
  color: #333;
  font-size: 13px;
  font-weight: 900;
  margin-bottom: 16px;
}

.plans-page .pill i{ color: var(--tg-pink); }

.plans-page h1{
  font-size: 46px;
  line-height: 1.10;
  margin: 0 0 14px;
  color: var(--tg-text);
  font-weight: 950;
  letter-spacing: -0.5px;
}

.plans-page .lead{
  font-size: 18px;
  line-height: 1.85;
  color: var(--tg-muted);
  margin: 0 0 18px;
}

.plans-page .hero-note{
  display: center;
  gap: 10px;
  align-items: flex-start;
  padding: 14px 14px;
  border-radius: 14px;
  background: rgba(255,243,194,0.35);
  border: 1px solid rgba(255,173,173,0.22);
  color: #333;
  font-size: 13.5px;
  line-height: 1.6;
  max-width: 860px;
}

.plans-page .hero-note i{ color: var(--tg-pink); margin-top: 2px; }

/* SECTION */
.plans-page .plans-section{
  padding: 16px 0 56px;
}

/* GRID */
.plans-page .plans-grid{
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
  align-items: stretch;
}

/* CARD BASE */
.plans-page .plan-card{
  position: relative;
  background: var(--tg-card);
  border-radius: 22px;
  border: 1px solid var(--tg-border);
  box-shadow: var(--tg-shadow);
  padding: 22px 20px 22px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
  transform: translateY(0);
  transition: transform .18s ease, box-shadow .18s ease;
}

.plans-page .plan-card:hover{
  transform: translateY(-3px);
  box-shadow: 0 22px 52px rgba(0,0,0,0.12);
}

/* Discount badge */
.plans-page .discount-badge{
  position: absolute;
  top: 14px;
  left: 14px;

  height: 30px;
  padding: 0 12px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.2px;

  color: #1f1f1f;
  background: rgba(202,255,191,0.75);
  border: 1px solid rgba(202,255,191,0.95);
  box-shadow: 0 10px 24px rgba(0,0,0,0.10);
}

/* Featured (FULL recomendado) */
.plans-page .plan-card.featured{
  border: 1px solid rgba(189,178,255,0.70);
  box-shadow: 0 26px 70px rgba(0,0,0,0.16);
  background: linear-gradient(
    160deg,
    rgba(189,178,255,0.34),
    rgba(255,173,173,0.20),
    rgba(255,243,194,0.45)
  );
}

.plans-page .plan-card.featured::before{
  content: "";
  position: absolute;
  inset: -20px;
  background: radial-gradient(circle at 30% 20%, rgba(189,178,255,0.35), transparent 55%),
              radial-gradient(circle at 80% 30%, rgba(255,173,173,0.30), transparent 55%),
              radial-gradient(circle at 60% 90%, rgba(255,243,194,0.35), transparent 55%);
  filter: blur(14px);
  opacity: 0.9;
  z-index: 0;
}

.plans-page .plan-card.featured > *{ position: relative; z-index: 1; }

/* Ribbon recomendado */
.plans-page .badge-recommended{
  position: absolute;
  top: 14px;
  right: 14px;

  height: 30px;
  padding: 0 12px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  font-size: 12px;
  font-weight: 950;

  color: #1f1f1f;
  background: rgba(189,178,255,0.78);
  border: 1px solid rgba(189,178,255,0.95);
  box-shadow: 0 14px 34px rgba(0,0,0,0.14);
}

.plans-page .badge-recommended i{
  font-size: 12px;
}


.plans-page .ribbon i{ color: #fff; }

/* Head */
.plans-page .plan-pill{
  position: absolute;
  top: 14px;
  left: 50%;
  transform: translateX(-50%);

  height: 30px;
  min-width: 86px;
  padding: 0 12px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;

  background: rgba(255,173,173,0.16);
  border: 1px solid rgba(255,173,173,0.28);

  font-size: 12px;
  font-weight: 950;
  color: #222;
}

.plans-page .plan-title{
  margin: 12px 0 6px;
  font-size: 20px;
  font-weight: 950;
  color: #222;
  letter-spacing: -0.2px;
}

.plans-page .plan-sub{
  margin: 0;
  color: #444;
  line-height: 1.75;
  font-size: 14.8px;
}

/* Price */
.plans-page .price{
  display: flex;
  align-items: baseline;
  gap: 8px;
  margin-top: 10px;
}

.plans-page .price.big .amount{
  font-size: 30px;
}

.plans-page .amount{
  font-size: 26px;
  font-weight: 950;
  color: #222;
}

.plans-page .period{
  font-size: 13px;
  font-weight: 900;
  color: rgba(51,51,51,0.75);
}

/* Old price line */
.plans-page .old-price{
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 6px;
}

.plans-page .old{
  font-size: 13.5px;
  font-weight: 900;
  color: rgba(51,51,51,0.70);
  text-decoration: line-through;
}

.plans-page .old-label{
  font-size: 12px;
  font-weight: 900;
  color: rgba(51,51,51,0.60);
}

/* Limits */
.plans-page .limit-box{
  background: rgba(255,243,194,0.16);
  border: 1px solid rgba(255,173,173,0.18);
  border-radius: 16px;
  padding: 14px 14px;
  display: grid;
  gap: 10px;
  margin-top: 6px;
}

.plans-page .limit-box.strong{
  background: rgba(189,178,255,0.16);
  border: 1px solid rgba(189,178,255,0.30);
}

.plans-page .limit-row{
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.plans-page .label{
  font-size: 13px;
  font-weight: 950;
  color: rgba(51,51,51,0.72);
}

.plans-page .value{
  font-size: 14px;
  font-weight: 950;
  color: #222;
}

/* Bullets */
.plans-page .bullets{
  list-style: none;
  padding: 0;
  margin: 8px 0 0;
  display: grid;
  gap: 10px;
}

.plans-page .bullets li{
  display: flex;
  gap: 10px;
  align-items: flex-start;
  color: #333;
  font-size: 14.4px;
  line-height: 1.55;
}

.plans-page .bullets i{
  color: var(--tg-pink);
  margin-top: 2px;
}

/* Highlight */
.plans-page .highlight{
  margin-top: 12px;
  padding: 12px 12px;
  border-radius: 14px;
  background: rgba(255,255,255,0.78);
  border: 1px solid rgba(0,0,0,0.06);
  color: #333;
  font-size: 13.6px;
  line-height: 1.6;
  display: flex;
  gap: 10px;
  align-items: flex-start;
}

.plans-page .highlight i{
  color: var(--tg-pink);
  margin-top: 2px;
}

/* Footer */
.plans-page .plan-foot{
  margin-top: auto;
  padding-top: 8px;
}

.plans-page .micro{
  margin: 10px 0 0;
  font-size: 12.8px;
  color: rgba(51,51,51,0.72);
  line-height: 1.6;
}

.plans-page .micro a{
  color: #333;
  font-weight: 950;
  text-decoration: none;
  border-bottom: 1px dashed rgba(255,173,173,0.7);
}
.plans-page .micro a:hover{ color: var(--tg-pink); }

/* Under note */
.plans-page .under{
  margin-top: 18px;
  display: flex;
  justify-content: center;
}

.plans-page .under-card{
  max-width: 900px;
  width: 100%;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  padding: 14px 14px;
  border-radius: 14px;
  background: rgba(255,243,194,0.32);
  border: 1px solid rgba(255,173,173,0.20);
  color: #333;
  font-size: 13.6px;
  line-height: 1.6;
}

.plans-page .under-card i{
  color: var(--tg-pink);
  margin-top: 2px;
}

/* CTA */
.plans-page .plans-cta{
  padding: 46px 0 10px;
  border-top: 1px solid rgba(255,173,173,0.22);
}

.plans-page .cta-card{
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 18px;
  padding: 24px 24px;
  border-radius: 20px;
  background: linear-gradient(135deg, rgba(255,173,173,0.24), rgba(255,243,194,0.40));
  border: 1px solid rgba(255,173,173,0.30);
  box-shadow: 0 18px 40px rgba(0,0,0,0.08);
}

.plans-page .cta-card h2{
  margin: 0 0 8px;
  font-size: 22px;
  font-weight: 950;
  color: #222;
}

.plans-page .cta-card p{
  margin: 0;
  color: #333;
  line-height: 1.8;
  font-size: 15.2px;
  max-width: 650px;
}

.plans-page .cta-actions{
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
}

/* Footer global */
.plans-page .bottom-links{
  text-align: center;
  padding: 25px 0;
  font-size: 15px;
}

.plans-page .links-row a{
  color: #333;
  text-decoration: none;
  margin: 0 10px;
  transition: color 0.2s;
  font-weight: 700;
}
.plans-page .links-row a:hover{ color: var(--tg-pink); }

.plans-page .social{ margin-top: 10px; }
.plans-page .social i{
  font-size: 22px;
  color: var(--tg-pink);
  margin: 0 10px;
  transition: transform 0.2s;
}
.plans-page .social i:hover{ transform: scale(1.15); }

.plans-page .copyright{
  text-align: right;
  font-size: 13px;
  color: rgba(51, 51, 51, 0.7);
  margin: 22px 25px 15px 0;
  padding-top: 10px;
  border-top: 1px solid rgba(255, 173, 173, 0.3);
}

/* ============================================================
   ✨ Micro-animaciones premium (suaves, no invasivas)
   ============================================================ */

/* 1) Badge -50% OFF: “respira” */
.plans-page .plan-chip.discount{
  animation: badgePulse 2.8s ease-in-out infinite;
  transform-origin: center;
}

@keyframes badgePulse{
  0%, 100% { transform: scale(1); box-shadow: 0 10px 24px rgba(0,0,0,0.10); }
  50%      { transform: scale(1.04); box-shadow: 0 14px 34px rgba(0,0,0,0.16); }
}

/* 2) Botón del plan Full (recomendado): shine animado */
.plans-page .plan-card.featured .btn-primary{
  position: relative;
  overflow: hidden;
}

.plans-page .plan-card.featured .btn-primary::after{
  content: "";
  position: absolute;
  top: -40%;
  left: -60%;
  width: 55%;
  height: 180%;
  background: linear-gradient(
    120deg,
    rgba(255,255,255,0) 0%,
    rgba(255,255,255,0.55) 45%,
    rgba(255,255,255,0) 100%
  );
  transform: rotate(16deg);
  animation: buttonShine 2.8s ease-in-out infinite;
  opacity: 0.9;
  pointer-events: none;
}

@keyframes buttonShine{
  0%   { left: -70%; opacity: 0.0; }
  20%  { opacity: 0.75; }
  45%  { left: 120%; opacity: 0.0; }
  100% { left: 120%; opacity: 0.0; }
}

/* 3) Ribbon recomendado: mini glow sutil */
.plans-page .plan-card.featured .plan-chip.recommended{
  animation: ribbonGlow 3.2s ease-in-out infinite;
}

@keyframes ribbonGlow{
  0%, 100% { box-shadow: 0 14px 34px rgba(0,0,0,0.20); }
  50%      { box-shadow: 0 18px 46px rgba(0,0,0,0.26); }
}

/* ==============================
   TOP ROW (alineación perfecta)
   ============================== */

.plans-page .plan-top{
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  align-items: center;
  gap: 10px;
  margin-bottom: 16px;
  min-height: 30px;
}

.plans-page .plan-chip{
  height: 30px;
  padding: 0 12px;
  border-radius: 999px;

  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;

  font-size: 12px;
  font-weight: 950;
  letter-spacing: 0.2px;

  box-shadow: 0 10px 24px rgba(0,0,0,0.10);
  border: 1px solid rgba(0,0,0,0.06);
  color: #222;
}

.plans-page .plan-chip.placeholder{
  visibility: hidden; /* mantiene simetría sin mostrar nada */
}

.plans-page .plan-chip.plan-name{
  background: rgba(255,173,173,0.16);
  border: 1px solid rgba(255,173,173,0.28);
}

.plans-page .plan-chip.discount{
  background: rgba(202,255,191,0.75);
  border: 1px solid rgba(202,255,191,0.95);
  color: #1f1f1f;
}

.plans-page .plan-chip.recommended{
  justify-self: end;
  background: rgba(189,178,255,0.78);
  border: 1px solid rgba(189,178,255,0.95);
  color: #1f1f1f;
}

.plans-page .plan-chip.recommended i{
  font-size: 12px;
}

/* Respeto accesibilidad: si el usuario tiene reduce motion, apagamos animaciones */
@media (prefers-reduced-motion: reduce){
  .plans-page .plan-chip.discount,
  .plans-page .plan-card.featured .btn-primary::after,
  .plans-page .plan-card.featured .plan-chip.recommended{
    animation: none !important;
  }
}

/* Responsive */
@media (max-width: 980px){
  .plans-page .plans-grid{ grid-template-columns: 1fr; }
  .plans-page .cta-card{ flex-direction: column; align-items: flex-start; }
  .plans-page .cta-actions{ justify-content: flex-start; }
  .plans-page h1{ font-size: 36px; }
}

@media (max-width: 480px){
  .plans-page .plans-main{ padding-top: 95px; }
  .plans-page h1{ font-size: 32px; }
  .plans-page .lead{ font-size: 16px; }
}

/* desactivar chips antiguos (ya no se usan) */
.plans-page .discount-badge,
.plans-page .badge-recommended,
.plans-page .plan-pill{
  display: none !important;
}
