/* ============================================================
   Landing Premium (Cycle / Retraite)
   Scope: .modele-landing.landing-premium
   Depends on tokens from landing-themes.css (or style-landing.css fallbacks)
   ============================================================ */

.modele-landing.landing-premium{
  /* Safety fallbacks if not defined by theme */
  --glass-bg: var(--glass-bg, rgba(255,255,255,.06));
  --glass-border: var(--glass-border, rgba(255,255,255,.12));
  --accent: var(--accent, var(--dore-lumineux, #fbbf24));
  --accent-2: var(--accent-2, var(--turquoise-energie, #22d3ee));
}

/* Premium section wrapper */
.modele-landing.landing-premium .section-premium{
  padding: clamp(56px, 6vw, 96px) 0;
}

/* Premium cards (Retraite, Cycle highlights, etc.) */
.modele-landing.landing-premium .carte-premium{
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  box-shadow: 0 18px 45px rgba(0,0,0,.25);
  padding: 22px;
}

/* Pricing card (Retraite) */
.modele-landing.landing-premium .pricing-card{
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  padding: 26px;
  max-width: 820px;
  margin: 0 auto;
  box-shadow: 0 0 40px rgba(0,0,0,.25);
}

.modele-landing.landing-premium .pricing-card h3,
.modele-landing.landing-premium .pricing-card .pricing-title{
  margin: 0 0 14px;
}

.modele-landing.landing-premium .pricing-card .pricing-price{
  font-size: clamp(2rem, 3.2vw, 2.8rem);
  font-weight: 900;
  letter-spacing: -.02em;
  color: rgba(255,255,255,.95);
  margin: 4px 0 8px;
}

.modele-landing.landing-premium .pricing-card .pricing-sub{
  color: rgba(255,255,255,.72);
  margin: 0 0 18px;
}

.modele-landing.landing-premium .pricing-card .pricing-bullets{
  list-style: none;
  padding: 0;
  margin: 18px 0 0;
}

.modele-landing.landing-premium .pricing-card .pricing-bullets li{
  padding-left: 26px;
  position: relative;
  margin: 10px 0;
  color: rgba(255,255,255,.86);
}

.modele-landing.landing-premium .pricing-card .pricing-bullets li:before{
  content: "";
  width: 12px;
  height: 12px;
  border-radius: 999px;
  position: absolute;
  left: 0;
  top: 0.35em;
  background: radial-gradient(circle at 35% 35%, var(--accent), var(--accent-2));
  box-shadow: 0 0 0 3px rgba(255,255,255,.06);
}

/* Timeline (Cycle + Retraite) */
.modele-landing.landing-premium .timeline{
  max-width: 980px;
  margin: 0 auto;
  position: relative;
  padding-left: 22px;
}

.modele-landing.landing-premium .timeline:before{
  content: "";
  position: absolute;
  left: 7px;
  top: 6px;
  bottom: 6px;
  width: 2px;
  background: linear-gradient(180deg, rgba(255,255,255,.20), rgba(255,255,255,.06));
}

.modele-landing.landing-premium .timeline-item{
  position: relative;
  margin: 18px 0;
  padding: 16px 18px 16px 22px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 16px;
}

.modele-landing.landing-premium .timeline-item-dot,
.modele-landing.landing-premium .timeline-point{
  position: absolute;
  left: -1px;
  top: 22px;
  width: 16px;
  height: 16px;
  border-radius: 999px;
  background: radial-gradient(circle at 35% 35%, var(--accent), var(--accent-2));
  box-shadow: 0 0 0 4px rgba(255,255,255,.06);
}

.modele-landing.landing-premium .timeline-titre,
.modele-landing.landing-premium .timeline-item h3{
  margin: 0 0 6px;
  font-weight: 800;
  color: rgba(255,255,255,.96);
}

.modele-landing.landing-premium .timeline-texte,
.modele-landing.landing-premium .timeline-item p{
  margin: 0;
  color: rgba(255,255,255,.82);
  line-height: 1.6;
}

.modele-landing.landing-premium .timeline-highlight{
  margin-top: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(255,255,255,.05);
  border: 1px solid rgba(255,255,255,.10);
  color: rgba(255,255,255,.88);
}

/* Cycle schema figure */
.modele-landing.landing-premium .schema-cycle-figure{
  margin: 26px auto 0;
  max-width: 980px;
  background: var(--glass-bg);
  border: 1px solid var(--glass-border);
  border-radius: 18px;
  overflow: hidden;
}

.modele-landing.landing-premium .schema-cycle-caption{
  padding: 14px 16px;
  color: rgba(255,255,255,.80);
  font-size: .95rem;
  border-top: 1px solid rgba(255,255,255,.10);
}

/* Responsive adjustments */
@media (max-width: 768px){
  .modele-landing.landing-premium .timeline{
    padding-left: 18px;
  }
  .modele-landing.landing-premium .timeline-item{
    padding: 14px 14px 14px 20px;
  }
  .modele-landing.landing-premium .pricing-card{
    padding: 20px;
  }
}

/* ------------------------------------------------------------
   FIX: Texte invisible (gradient + background-clip)
   Cause: certains bundles/minifiers retirent -webkit-background-clip:text
   alors que -webkit-text-fill-color:transparent reste actif => texte "disparaît".
   Stratégie: fallback lisible par défaut, gradient uniquement si support confirmé.
------------------------------------------------------------ */

/* Fallback lisible (par défaut) */
.modele-landing .hero-title,
.modele-landing .stat-nombre{
  color: rgba(255,255,255,.95);
  -webkit-text-fill-color: rgba(255,255,255,.95);
  background: none;
}

/* Active le gradient uniquement si le navigateur supporte le clip texte webkit */
@supports (-webkit-background-clip: text) and (-webkit-text-fill-color: transparent){
  .modele-landing .hero-title{
    background: linear-gradient(135deg, var(--blanc-lumiere) 0%, var(--dore-brillant) 50%, var(--turquoise-clair) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
  }

  .modele-landing .stat-nombre{
    background: linear-gradient(135deg, var(--dore-brillant) 0%, var(--blanc-lumiere) 100%);
    -webkit-background-clip: text;
    background-clip: text;
    -webkit-text-fill-color: transparent;
    color: transparent;
  }
}
/* FIX VISIBILITÉ TITRES (Chrome/Safari): stop gradient-text qui rend le texte invisible */
.modele-landing .hero-title,
.modele-landing .stat-nombre{
  background: none !important;
  -webkit-background-clip: border-box !important;
  background-clip: border-box !important;
  color: rgba(255,255,255,.95) !important;
  -webkit-text-fill-color: rgba(255,255,255,.95) !important;
  text-shadow: 0 2px 14px rgba(0,0,0,.35);
}
