/* =========================
   THEME & VARIABLES - Couleurs identiques à l'app mobile
========================= */
:root {
  --bg-primary: #2a1a5e;
  --bg-gradient: linear-gradient(135deg, #4a148c 0%, #2a1a5e 50%, #1a0033 100%);

  --glass-bg: rgba(45, 25, 90, 0.4);
  --glass-border: rgba(255, 215, 0, 0.35);

  --accent-yellow: #FFD700;
  --accent-orange: #FF8C00;

  --text-primary: #ffffff;
  --text-secondary: rgba(255, 255, 255, 0.85);

  --glow-yellow: rgba(255, 215, 0, 0.6);
  --glow-orange: rgba(255, 140, 0, 0.6);

  --radius-lg: 28px;
  --radius-xl: 32px;
}

/* =========================
   RESET & BASE
========================= */
*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html { scroll-behavior: smooth; }

body {
  font-family: 'Inter', system-ui, sans-serif;
  background: var(--bg-primary);
  color: var(--text-primary);
  min-height: 100vh;
  overflow-x: hidden;
}

/* Background gradient */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: var(--bg-gradient);
  opacity: 0.6;
  z-index: -2;
}

/* Vignette */
body::after {
  content: '';
  position: fixed;
  inset: 0;
  background: radial-gradient(circle at 50% 20%, transparent 30%, rgba(0,0,0,0.5) 100%);
  z-index: -1;
  pointer-events: none;
}

/* =========================
   GLASS CARD
========================= */
.glass-card {
  background: var(--glass-bg);
  backdrop-filter: blur(18px);
  border: 1px solid var(--glass-border);
  border-radius: var(--radius-lg);
  padding: 2rem;
  box-shadow: 0 10px 40px rgba(0,0,0,0.6);
  will-change: transform;
}

/* Glow helpers */
.glow-yellow { box-shadow: 0 0 40px var(--glow-yellow); }
.glow-orange { box-shadow: 0 0 40px var(--glow-orange); }

/* =========================
   HERO LAYOUT (corrigé + responsive)
========================= */
.hero {
  max-width: 1400px;
  margin: 0 auto;
  padding: 8rem 2rem 12rem;
  display: grid;
  grid-template-columns: 1fr 1.15fr 1fr;
  gap: 3rem;
  align-items: center;
}

@media (max-width: 1024px) {
  .hero {
    grid-template-columns: 1fr;
    gap: 3.5rem;
    padding: 6rem 1.5rem 7rem;
  }
}

/* =========================
   ✅ GSAP visibility fix
   - On ne cache PAS par défaut.
   - On cache seulement si JS a confirmé qu'il est actif.
========================= */
html.js-ready.gsap-init .hero-title,
html.js-ready.gsap-init .hero-subtitle,
html.js-ready.gsap-init .cta-buttons,
html.js-ready.gsap-init .payment-card,
html.js-ready.gsap-init .mockup-left,
html.js-ready.gsap-init .mockup-right,
html.js-ready.gsap-init .download-section > * {
  opacity: 0;
}

/* =========================
   MOCKUPS
========================= */
.mockup-left,
.mockup-right {
  position: relative;
  transform: translateZ(0);
}

.mockup-img {
  width: 100%;
  display: block;
  border-radius: var(--radius-lg);
  border: 1px solid rgba(255,215,0,0.18);
  box-shadow: 0 18px 52px rgba(0,0,0,0.7);
}

/* =========================
   HERO TEXT
========================= */
.hero-center { text-align: center; }

.hero-title {
  font-size: clamp(2.8rem, 6vw, 5.5rem);
  font-weight: 900;
  line-height: 1.05;
  margin-bottom: 1.6rem;
}

.hero-title span {
  background: linear-gradient(to right, var(--accent-yellow), var(--accent-orange));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero-subtitle {
  font-size: clamp(1.05rem, 1.6vw, 1.5rem);
  color: var(--text-secondary);
  max-width: 720px;
  margin: 0 auto 2.5rem;
}

/* =========================
   CTA BUTTONS
========================= */
.cta-buttons {
  display: flex;
  justify-content: center;
  gap: 1.4rem;
  flex-wrap: wrap;
}

.btn-primary,
.btn-secondary {
  border-radius: 999px;
  font-weight: 800;
  text-decoration: none;
  cursor: pointer;
  transition: transform .2s ease, box-shadow .2s ease, opacity .2s ease;
  will-change: transform;
}

.btn-primary {
  background: var(--accent-yellow);
  color: #000;
  padding: 1rem 2.6rem;
  box-shadow: 0 0 34px var(--glow-yellow);
}

.btn-primary:hover { transform: translateY(-3px) scale(1.02); opacity: .98; }

.btn-secondary {
  color: var(--accent-yellow);
  border: 2px solid rgba(255,215,0,0.85);
  padding: 1rem 2.6rem;
}

.btn-secondary:hover { transform: translateY(-3px) scale(1.02); }

/* =========================
   PAYMENT CARD
========================= */
.payment-card {
  border-radius: var(--radius-xl);
  padding: 2.5rem;
  margin: 3rem 0;
}

.payment-title {
  font-size: clamp(2rem, 4vw, 4rem);
  font-weight: 900;
  color: var(--accent-yellow);
}

.payment-amount {
  font-size: clamp(2.4rem, 5vw, 5rem);
  font-weight: 900;
  margin: 1.4rem 0;
}

/* =========================
   DOWNLOAD
========================= */
.download-section {
  padding: 8rem 2rem;
  text-align: center;
}

.download-title {
  font-size: clamp(2.2rem, 5vw, 4rem);
  font-weight: 900;
  margin-bottom: 3rem;
}

.download-buttons {
  display: flex;
  justify-content: center;
  gap: 3rem;
  flex-wrap: wrap;
}

.store-badge { height: 70px; transition: transform .2s ease; }
.store-badge:hover { transform: translateY(-4px); }

.qr-code {
  width: 220px;
  height: 220px;
  border: 6px solid var(--accent-yellow);
  border-radius: 22px;
  box-shadow: 0 0 50px var(--glow-yellow);
}

/* =========================
   REDUCED MOTION
========================= */
@media (prefers-reduced-motion: reduce) {
  * { animation: none !important; transition: none !important; }
}

/* =========================================================
   ADMIN FIXES (gestion_contenu / settings / dashboard)
   Objectif:
   - Rendre les champs d'édition lisibles (texte noir sur fond clair OU blanc sur fond sombre)
   - Ne pas casser la landing page
   - Éviter le "opacity:1 sur tout" (ça peut casser des effets/GSAP)
========================================================= */

.admin-page {
  color: var(--text-primary);
}

/* Chip + boutons (si utilisés en admin) */
.admin-page .chip{
  display:inline-flex;align-items:center;gap:.5rem;
  padding:.55rem .85rem;border-radius:999px;
  border:1px solid rgba(255,215,0,0.25);
  background: rgba(45,25,90,0.25);
  color: rgba(255,255,255,0.88);
  backdrop-filter: blur(12px);
  font-weight:800;font-size:.95rem;white-space:nowrap;
}

.admin-page .btn{
  border-radius: 999px;
  padding: .75rem 1.1rem;
  font-weight: 900;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap:.5rem;
}

.admin-page .btn.btn-gold{
  background: linear-gradient(45deg, #FFD700, #FFC107);
  color:#000;
  box-shadow: 0 0 28px rgba(255,215,0,.18);
}

.admin-page .btn.btn-ghost{
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.92);
  border: 1px solid rgba(255,255,255,.10);
}

.admin-page .btn.btn-danger{
  background: rgba(255,60,60,.12);
  border: 1px solid rgba(255,60,60,.35);
  color: rgba(255,255,255,.92);
}

/* ✅ Champs formulaire: fond sombre + texte blanc (lisible) */
.admin-page .input,
.admin-page input,
.admin-page textarea,
.admin-page select {
  background: rgba(0, 0, 0, 0.35) !important;
  color: #fff !important;
  caret-color: #FFD700;
  border: 1px solid rgba(255, 215, 0, 0.35) !important;
  border-radius: 18px;
}

/* Focus lisible */
.admin-page .input:focus,
.admin-page input:focus,
.admin-page textarea:focus,
.admin-page select:focus {
  outline: none !important;
  border-color: #FFD700 !important;
  box-shadow: 0 0 0 4px rgba(255, 215, 0, 0.18) !important;
}

/* Placeholders */
.admin-page .input::placeholder,
.admin-page input::placeholder,
.admin-page textarea::placeholder {
  color: rgba(255,255,255,0.55) !important;
}

/* Important: textarea parfois "blanchit" sur Chrome */
.admin-page textarea {
  -webkit-text-fill-color: #fff !important;
}

/* ✅ Tables: garder la couleur (sans écraser tout le site) */
.admin-page table { width: 100%; }
.admin-page th { color: rgba(255,255,255,0.65) !important; font-weight: 900; }
.admin-page td { color: rgba(255,255,255,0.88) !important; }

/* ✅ Fix autofill Chrome (sinon texte illisible) */
.admin-page input:-webkit-autofill,
.admin-page textarea:-webkit-autofill,
.admin-page select:-webkit-autofill {
  -webkit-text-fill-color: #fff !important;
  transition: background-color 9999s ease-out 0s;
  box-shadow: 0 0 0px 1000px rgba(0,0,0,0.35) inset !important;
  border: 1px solid rgba(255, 215, 0, 0.35) !important;
}

/* ❌ On ne met PAS opacity:1 sur tout (ça casse les animations/effets) */
/* (supprimé volontairement) */
