/* ========== CSS VARIABLES ========== */
:root {
  --bg: #06030f;
  --purple: #7c3aed;
  --purple-light: #a855f7;
  --pink: #ec4899;
  --cyan: #06b6d4;
  --gold: #f59e0b;
  --green: #10b981;
  --card-bg: rgba(255, 255, 255, 0.04);
  --glass: rgba(124, 58, 237, 0.10);
  --border: rgba(168, 85, 247, 0.25);
  --text: #f0e6ff;
  --text-muted: #9b8abf;
}

/* ========== RESET & BODY ========== */
* {
  margin: 0;
  padding: 0;
  box-sizing: border-box;
}

html, body {
  width: 100%;
  height: 100%;
  overflow-x: hidden;
}

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Segoe UI', Tahoma, Geneva, Verdana, sans-serif;
  font-size: 16px;
  line-height: 1.6;
  position: relative;
}

/* ========== SCROLLBAR ========== */
::-webkit-scrollbar {
  width: 10px;
}

::-webkit-scrollbar-track {
  background: rgba(255, 255, 255, 0.02);
}

::-webkit-scrollbar-thumb {
  background: linear-gradient(180deg, var(--purple), var(--pink));
  border-radius: 10px;
}

::-webkit-scrollbar-thumb:hover {
  background: linear-gradient(180deg, var(--purple-light), var(--pink));
}

/* ========== PARTICLES CANVAS ========== */
#particles {
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  opacity: 0.55;
}

/* ========== ANNOUNCE BAR ========== */
.announce-bar {
  position: sticky;
  top: 0;
  z-index: 99;
  background: linear-gradient(90deg, #7c3aed, #ec4899);
  color: #fff;
  padding: 10px 0;
  font-size: 13px;
  font-weight: 700;
  letter-spacing: 0.5px;
  text-align: center;
  overflow: hidden;
}

#announceTrack {
  display: flex;
  width: max-content;
  white-space: nowrap;
  animation: scrollLeft 30s linear infinite;
}

.announce-item, .announce-sep {
  display: inline-block;
  flex-shrink: 0;
  padding: 0 8px;
}

/* ========== NAVIGATION ========== */
nav {
  position: sticky;
  top: 40px;
  z-index: 98;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 40px;
  background: rgba(6, 3, 15, 0.85);
  backdrop-filter: blur(10px);
  border-bottom: 1px solid var(--border);
  gap: 20px;
}

.logo {
  font-family: 'Orbitron', monospace;
  font-size: 24px;
  font-weight: 900;
  letter-spacing: 2px;
  background: linear-gradient(135deg, var(--purple-light), var(--pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.nav-links {
  display: flex;
  gap: 32px;
  flex: 1;
  justify-content: center;
}

.nav-links a {
  color: var(--text-muted);
  text-decoration: none;
  font-size: 14px;
  font-weight: 600;
  transition: all 0.3s;
  cursor: pointer;
  position: relative;
}

.nav-links a:hover, .nav-links a.active {
  color: var(--purple-light);
}

.nav-links a.active::after {
  content: '';
  position: absolute;
  bottom: -6px;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--purple), var(--pink));
}

.nav-right {
  display: flex;
  align-items: center;
  gap: 24px;
}

.nav-social {
  display: flex;
  gap: 16px;
}

.nav-social a {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--card-bg);
  border: 1px solid var(--border);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text-muted);
  text-decoration: none;
  font-size: 14px;
  transition: all 0.3s;
}

.nav-social a:hover {
  color: var(--purple-light);
  border-color: var(--purple-light);
  background: rgba(168, 85, 247, 0.1);
}

.cart-nav-btn {
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: var(--card-bg);
  border: 1px solid var(--border);
  color: var(--text);
  cursor: pointer;
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.3s;
}

.cart-nav-btn:hover {
  border-color: var(--purple-light);
  background: rgba(168, 85, 247, 0.1);
}

.cart-badge {
  position: absolute;
  top: -8px;
  right: -8px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: none;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  z-index: 10;
}

.nav-admin-link {
  color: var(--gold);
  text-decoration: none;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  opacity: 0.7;
  transition: all 0.3s;
}

.nav-admin-link:hover {
  opacity: 1;
  text-decoration: underline;
}

/* ========== PAGES & SECTIONS ========== */
.page {
  display: none;
}

.page.active {
  display: block;
}

.section {
  padding: 80px 40px;
  max-width: 1300px;
  margin: 0 auto;
  position: relative;
  z-index: 1;
}

/* ========== HERO SECTION ========== */
.hero {
  text-align: center;
  padding: 60px 20px;
  position: relative;
  z-index: 1;
}

.hero-badge {
  display: inline-block;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 10px 20px;
  font-size: 12px;
  color: var(--purple-light);
  font-weight: 700;
  margin-bottom: 20px;
  letter-spacing: 1px;
}

.hero h1 {
  font-family: 'Orbitron', monospace;
  font-size: 64px;
  font-weight: 900;
  margin: 20px 0;
  line-height: 1.2;
  background: linear-gradient(135deg, var(--purple-light), var(--pink), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.hero-sub {
  font-size: 18px;
  color: var(--text-muted);
  margin: 16px 0 32px;
}

.hero-desc {
  font-size: 14px;
  color: var(--text-muted);
  max-width: 600px;
  margin: 0 auto 40px;
}

.hero-ctas {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-bottom: 60px;
}

.hero-stats {
  display: flex;
  justify-content: center;
  gap: 60px;
  flex-wrap: wrap;
  margin-top: 40px;
}

.stat {
  text-align: center;
}

.stat-num {
  font-family: 'Orbitron', monospace;
  font-size: 36px;
  font-weight: 900;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
}

.stat-label {
  font-size: 12px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-top: 4px;
}

.floating-vape {
  position: absolute;
  font-size: 80px;
  opacity: 0.15;
  animation: floatUp 6s ease-in-out infinite;
  top: 20%;
}

.floating-vape:nth-child(1) { left: 5%; animation-delay: 0s; }
.floating-vape:nth-child(2) { right: 10%; animation-delay: 1s; top: 40%; }
.floating-vape:nth-child(3) { left: 15%; animation-delay: 2s; }

/* ========== BUTTONS ========== */
.btn-primary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  border: none;
  border-radius: 50px;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
}

.btn-primary:hover {
  transform: translateY(-2px);
  box-shadow: 0 15px 40px rgba(124, 58, 237, 0.4);
}

.btn-secondary {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: var(--card-bg);
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 14px 28px;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
  text-decoration: none;
}

.btn-secondary:hover {
  border-color: var(--purple-light);
  background: rgba(168, 85, 247, 0.1);
  color: var(--purple-light);
}

/* ========== TITLES & DIVIDERS ========== */
.section-title {
  font-family: 'Orbitron', monospace;
  font-size: 42px;
  font-weight: 900;
  text-align: center;
  margin-bottom: 48px;
  position: relative;
}

.title-line {
  position: absolute;
  bottom: -16px;
  left: 50%;
  transform: translateX(-50%);
  width: 80px;
  height: 3px;
  background: linear-gradient(90deg, var(--purple), var(--pink));
}

.glow-divider {
  text-align: center;
  margin: 60px 0;
  font-size: 28px;
  opacity: 0.3;
}

/* ========== FEATURES STRIP ========== */
.features-strip {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  margin: 40px 0;
}

.feature-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
  text-align: center;
  transition: all 0.3s;
}

.feature-card:hover {
  border-color: var(--purple-light);
  background: rgba(168, 85, 247, 0.08);
}

.feature-card p {
  font-size: 13px;
  color: var(--text-muted);
}

/* ========== WHY SECTION ========== */
.why-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 32px;
  margin-top: 40px;
}

.why-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 40px 28px;
  text-align: center;
  transition: all 0.3s;
}

.why-card:hover {
  border-color: var(--purple-light);
  transform: translateY(-4px);
  background: rgba(168, 85, 247, 0.08);
}

.why-card h3 {
  font-size: 18px;
  margin-bottom: 12px;
}

.why-card p {
  font-size: 13px;
  color: var(--text-muted);
}

/* ========== PRODUCTS SECTION ========== */
/* ══════════════════════════════════════════
   BARRE FILTRE PRODUITS — VERSION PREMIUM
   ══════════════════════════════════════════ */
@keyframes pfGlow {
  0%,100% { opacity:.6; transform:scale(1); }
  50%      { opacity:1;  transform:scale(1.08); }
}
@keyframes pfSlideIn {
  from { opacity:0; transform:translateY(-10px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes pfSearchGlow {
  0%,100% { box-shadow: 0 0 0 0 rgba(139,92,246,0); }
  50%     { box-shadow: 0 0 22px 4px rgba(139,92,246,0.35); }
}

/* ── Layout général produits ── */
.products-layout {
  display: flex;
  gap: 28px;
  align-items: flex-start;
}

.pf-sidebar {
  width: 240px;
  min-width: 240px;
  position: sticky;
  top: 130px;
  animation: pfSlideIn 0.4s ease both;
}

.products-main {
  flex: 1;
  min-width: 0;
}

/* ── Panneau conteneur ── */
.pf-panel {
  width: 100%;
  background: rgba(124,58,237,0.06);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 20px;
  padding: 20px 18px;
  backdrop-filter: blur(14px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  box-shadow: 0 8px 32px rgba(124,58,237,0.12), inset 0 1px 0 rgba(255,255,255,0.05);
}

.pf-panel-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
}

.pf-panel-title {
  font-size: 15px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: 0.5px;
}

.pf-reset {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  color: var(--text-muted);
  width: 28px; height: 28px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 16px;
  display: flex; align-items: center; justify-content: center;
  transition: all 0.2s;
}
.pf-reset:hover { background: rgba(139,92,246,0.2); color: var(--text); border-color: var(--purple); }

/* ── Titre section filtre ── */
.pf-label {
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 2px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: -6px;
}

/* ── Barre de recherche ── */
.pf-search-wrap {
  position: relative;
  width: 100%;
}

.pf-search-icon {
  position: absolute;
  left: 16px;
  top: 50%;
  transform: translateY(-50%);
  font-size: 16px;
  pointer-events: none;
  opacity: 0.7;
}

.pf-search-input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(168,85,247,0.25);
  border-radius: 14px;
  padding: 13px 18px 13px 46px;
  color: var(--text);
  font-size: 14px;
  font-weight: 500;
  outline: none;
  transition: all 0.3s;
  box-sizing: border-box;
}

.pf-search-input::placeholder { color: var(--text-muted); font-weight: 400; }

.pf-search-input:focus {
  border-color: var(--purple-light);
  background: rgba(139,92,246,0.08);
  animation: pfSearchGlow 2s ease infinite;
}

/* ── Séparateur ── */
.pf-divider {
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(168,85,247,0.3), transparent);
}

/* ── Filtres pills ── */
.pf-filters {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.pf-btn {
  position: relative;
  display: flex;
  align-items: center;
  gap: 7px;
  width: 100%;
  background: rgba(255,255,255,0.03);
  border: 1.5px solid rgba(255,255,255,0.08);
  color: var(--text-muted);
  padding: 10px 14px;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.34,1.56,0.64,1);
  overflow: hidden;
  text-align: left;
}

.pf-btn::before {
  content: '';
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity 0.25s;
  border-radius: inherit;
}

.pf-btn:hover {
  transform: translateY(-2px);
  color: var(--text);
  border-color: rgba(168,85,247,0.4);
}

.pf-btn:active { transform: scale(0.95); }

/* TOUS — violet-rose */
.pf-btn.pf-all::before { background: linear-gradient(135deg,#7c3aed,#ec4899); }
.pf-btn.pf-all.active {
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(124,58,237,0.55), 0 0 0 1px rgba(236,72,153,0.3);
}
.pf-btn.pf-all.active::before { opacity: 1; }
.pf-btn.pf-all .pf-dot { background: #fff; }

/* EN STOCK — vert émeraude */
.pf-btn.pf-stock::before { background: linear-gradient(135deg,#059669,#34d399); }
.pf-btn.pf-stock.active {
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(5,150,105,0.55), 0 0 0 1px rgba(52,211,153,0.3);
}
.pf-btn.pf-stock.active::before { opacity: 1; }

/* BIENTÔT RUPTURE — ambre */
.pf-btn.pf-low::before { background: linear-gradient(135deg,#b45309,#fbbf24); }
.pf-btn.pf-low.active {
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(180,83,9,0.55), 0 0 0 1px rgba(251,191,36,0.3);
}
.pf-btn.pf-low.active::before { opacity: 1; }

/* RUPTURE — rouge */
.pf-btn.pf-out::before { background: linear-gradient(135deg,#be123c,#f43f5e); }
.pf-btn.pf-out.active {
  color: #fff;
  border-color: transparent;
  box-shadow: 0 4px 20px rgba(190,18,60,0.55), 0 0 0 1px rgba(244,63,94,0.3);
}
.pf-btn.pf-out.active::before { opacity: 1; }

/* Texte au-dessus du gradient */
.pf-btn span { position: relative; z-index: 1; }

/* ── Compteur résultats ── */
.pf-count {
  font-size: 12px;
  color: var(--text-muted);
  text-align: right;
  padding-right: 2px;
}
.pf-count strong { color: var(--purple-light); }

/* ── État vide ── */
.pf-empty {
  text-align: center;
  padding: 60px 20px;
  animation: pfSlideIn 0.3s ease both;
}
.pf-empty-icon { font-size: 48px; margin-bottom: 12px; }
.pf-empty-text { color: var(--text-muted); font-size: 15px; }
.pf-empty-sub  { color: rgba(155,138,191,0.6); font-size: 13px; margin-top: 6px; }

/* ── Responsive ── */
@media (max-width: 860px) {
  .products-layout { flex-direction: column; }
  .pf-sidebar { width: 100%; min-width: unset; position: static; }
  .pf-filters { flex-direction: row; flex-wrap: wrap; }
  .pf-btn     { width: auto; padding: 8px 14px; font-size: 12px; }
}

/* ── Onglets produits ── */
.product-tabs {
  display: flex;
  justify-content: center;
  gap: 16px;
  margin-bottom: 40px;
  flex-wrap: wrap;
}

.tab-btn {
  background: var(--card-bg);
  border: 1px solid var(--border);
  color: var(--text-muted);
  padding: 12px 24px;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
}

.tab-btn:hover, .tab-btn.active {
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border-color: transparent;
  color: #fff;
}

.product-panel {
  display: none;
}

.product-panel.active {
  display: block;
}

.product-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 24px;
}

.product-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  transition: all 0.3s;
  display: flex;
  flex-direction: column;
}

.product-card:hover {
  border-color: var(--purple-light);
  background: rgba(168, 85, 247, 0.08);
  transform: translateY(-4px);
}

.product-img-wrap {
  height: 200px;
  overflow: hidden;
  position: relative;
  background: var(--glass);
}

.product-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  position: absolute;
  inset: 0;
  z-index: 2;
}

.product-img-placeholder {
  position: absolute;
  inset: 0;
  z-index: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: rgba(255, 255, 255, 0.4);
  font-size: 14px;
  gap: 8px;
}

.placeholder-icon {
  font-size: 36px;
}

.product-badge {
  position: absolute;
  top: 12px;
  right: 12px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  z-index: 3;
}

.product-info {
  padding: 20px;
  flex: 1;
  display: flex;
  flex-direction: column;
}

.product-name {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.product-flavor {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
  margin: 8px 0;
}

.product-puffs {
  font-size: 13px;
  color: var(--purple-light);
  font-weight: 700;
  margin: 8px 0 4px;
}

@keyframes priceShimmer {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

.product-price {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 15px;
  font-weight: 800;
  font-family: 'Orbitron', monospace;
  letter-spacing: 0.5px;
  margin: 2px 0 8px;
  background-image: linear-gradient(135deg, #a855f7, #ec4899, #a855f7);
  background-size: 200% auto;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: priceShimmer 2.5s linear infinite;
}

.price-16k, .price-18k {
  background-image: linear-gradient(135deg, #a855f7, #ec4899, #a855f7);
}

.product-footer {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-top: auto;
}

.in-stock {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--green);
  font-size: 12px;
  font-weight: 700;
}

.out-stock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #f87171;
  font-size: 12px;
  font-weight: 700;
  background: rgba(239,68,68,0.1);
  border: 1px solid rgba(239,68,68,0.25);
  border-radius: 50px;
  padding: 3px 10px;
}

/* Low stock — réutilisé aussi sur les cartes boutique */
.low-stock {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  color: #fb923c;
  font-size: 12px;
  font-weight: 700;
  background: rgba(249,115,22,0.1);
  border: 1px solid rgba(249,115,22,0.25);
  border-radius: 50px;
  padding: 3px 10px;
}

.stock-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--green);
  animation: pulse 2s infinite;
  flex-shrink: 0;
}

/* Carte en rupture — overlay grisé */
.product-card.card-out {
  opacity: 0.7;
  pointer-events: auto;
}

.product-card.card-out .product-img-wrap::after {
  content: 'RUPTURE';
  position: absolute;
  inset: 0;
  background: rgba(0,0,0,0.55);
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: 'Orbitron', monospace;
  font-size: 13px;
  font-weight: 900;
  letter-spacing: 2px;
  color: #f87171;
  border-radius: inherit;
}

/* Carte bientôt rupture — légère pulsation */
.product-card.card-low .product-img-wrap::after {
  content: 'LIMITÉ';
  position: absolute;
  top: 8px;
  left: 8px;
  background: rgba(249,115,22,0.85);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  letter-spacing: 1px;
  padding: 3px 8px;
  border-radius: 6px;
}

/* Bouton panier désactivé — état rupture */
.btn-add-cart:disabled {
  opacity: 0.35;
  cursor: not-allowed;
  background: rgba(255,255,255,0.05) !important;
  border-color: rgba(255,255,255,0.1) !important;
}

.btn-add-cart {
  width: 100%;
  padding: 12px;
  border: none;
  border-radius: 12px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
}

.btn-add-cart:hover:not(:disabled) {
  transform: translateY(-2px);
  box-shadow: 0 10px 30px rgba(124, 58, 237, 0.4);
}

/* Product color classes */
.pv-blue   { background: linear-gradient(135deg, rgba(59,130,246,0.2),   rgba(6,182,212,0.1)); }
.pv-pink   { background: linear-gradient(135deg, rgba(236,72,153,0.2),   rgba(167,139,250,0.1)); }
.pv-green  { background: linear-gradient(135deg, rgba(16,185,129,0.2),   rgba(34,197,94,0.1)); }
.pv-orange { background: linear-gradient(135deg, rgba(245,158,11,0.2),   rgba(239,68,68,0.1)); }
.pv-red    { background: linear-gradient(135deg, rgba(239,68,68,0.2),    rgba(249,115,22,0.1)); }
.pv-teal   { background: linear-gradient(135deg, rgba(6,182,212,0.2),    rgba(34,211,238,0.1)); }
.pv-black  { background: linear-gradient(135deg, rgba(30,30,50,0.6),     rgba(100,100,130,0.15)); }
.pv-purple { background: linear-gradient(135deg, rgba(124,58,237,0.2),   rgba(196,181,253,0.1)); }

/* ========== CART PAGE ========== */
.cart-wrapper {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 32px;
}

.cart-items {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  overflow: hidden;
}

.cart-item {
  display: flex;
  gap: 16px;
  padding: 16px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.cart-item:last-child {
  border-bottom: none;
}

.cart-item-img {
  width: 60px;
  height: 60px;
  border-radius: 12px;
  object-fit: cover;
  flex-shrink: 0;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  display: flex;
  align-items: center;
  justify-content: center;
  overflow: hidden;
}

.cart-item-img img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.cart-item-info {
  flex: 1;
}

.cart-item-name {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 700;
  text-transform: uppercase;
}

.cart-item-flavor {
  font-size: 14px;
  color: #fff;
  font-weight: 700;
  margin: 4px 0 8px;
}

.qty-controls {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
}

.qty-btn {
  width: 28px;
  height: 28px;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text);
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  font-weight: 700;
  transition: all 0.2s;
}

.qty-btn:hover {
  background: var(--purple);
  border-color: var(--purple);
}

.qty-val {
  font-weight: 700;
  min-width: 20px;
  text-align: center;
}

.remove-btn {
  margin-left: auto;
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #f87171;
  padding: 6px 12px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 14px;
  transition: all 0.2s;
}

.remove-btn:hover {
  background: rgba(239, 68, 68, 0.2);
}

.cart-totals {
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cart-summary-box {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 28px;
  position: sticky;
  top: 100px;
}

.cart-empty {
  text-align: center;
  padding: 80px 20px;
  color: var(--text-muted);
}

/* ── Sauvegarde panier ── */
.cart-save-btn {
  width: 100%;
  margin-top: 10px;
  padding: 12px;
  background: transparent;
  border: 1.5px dashed rgba(168,85,247,0.35);
  border-radius: 12px;
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: border-color .2s, color .2s, background .2s;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
}
.cart-save-btn:hover {
  border-color: var(--purple-light);
  color: var(--purple-light);
  background: rgba(124,58,237,0.06);
}

.cart-saved-banner {
  margin-top: 10px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  background: rgba(124,58,237,0.1);
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: 12px;
  padding: 10px 14px;
  animation: fadeIn .3s ease;
}

.cart-saved-info {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  color: var(--purple-light);
  font-weight: 600;
}

.cart-saved-actions {
  display: flex;
  align-items: center;
  gap: 6px;
}

.cart-restore-btn {
  padding: 6px 14px;
  border-radius: 8px;
  border: none;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s;
}
.cart-restore-btn:hover { opacity: .85; }

.cart-saved-del {
  background: transparent;
  border: none;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 14px;
  padding: 4px 6px;
  transition: color .2s;
}
.cart-saved-del:hover { color: #f87171; }

/* ========== CHECKOUT PAGE ========== */
.checkout-wrapper {
  display: grid;
  grid-template-columns: 1fr 1.2fr;
  gap: 40px;
  grid-auto-flow: dense;
}

.checkout-form-container {
  grid-column: 1;
}

.form-section-title {
  font-weight: 700;
  color: #fff;
  margin-bottom: 16px;
  font-size: 15px;
}

.form-group {
  display: flex;
  flex-direction: column;
  gap: 6px;
  margin-bottom: 16px;
}

.form-group label {
  font-size: 12px;
  color: var(--text-muted);
  font-weight: 600;
}

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

form input, form textarea, form select {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 12px 16px;
  color: #fff;
  font-size: 14px;
  outline: none;
  transition: all 0.3s;
}

form input:focus, form textarea:focus, form select:focus {
  border-color: var(--purple-light);
  background: rgba(255, 255, 255, 0.1);
}

form textarea {
  resize: vertical;
  min-height: 80px;
}

/* ── Delivery cards (new 3-option system) ── */
.delivery-cards {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin: 16px 0;
}

.delivery-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--card-bg);
  border: 1.5px solid var(--border);
  border-radius: 16px;
  padding: 16px 20px;
  cursor: pointer;
  transition: all 0.25s;
  position: relative;
  user-select: none;
}

.delivery-card:hover {
  border-color: var(--purple-light);
  background: rgba(124, 58, 237, 0.07);
}

.delivery-card.dc-selected {
  border-color: var(--purple-light);
  background: rgba(124, 58, 237, 0.12);
  box-shadow: 0 0 0 1px rgba(168,85,247,0.3), 0 4px 20px rgba(124,58,237,0.15);
}

.delivery-card input[type="radio"] {
  position: absolute;
  opacity: 0;
  width: 0;
  height: 0;
}

.delivery-card-check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 2px solid var(--border);
  flex-shrink: 0;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
}

.dc-selected .delivery-card-check {
  border-color: var(--purple-light);
  background: var(--purple);
}

.dc-selected .delivery-card-check::after {
  content: '';
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: #fff;
  display: block;
}

.delivery-card-ico {
  font-size: 26px;
  flex-shrink: 0;
}

.delivery-card-info {
  flex: 1;
  min-width: 0;
}

.delivery-card-title {
  font-weight: 700;
  color: #fff;
  font-size: 14px;
  margin-bottom: 3px;
}

.delivery-card-sub {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.4;
}

.delivery-badge-free {
  background: linear-gradient(135deg, #10b981, #059669);
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 8px;
  border-radius: 20px;
  letter-spacing: 0.5px;
  flex-shrink: 0;
}

.delivery-badge-price {
  background: rgba(245, 158, 11, 0.15);
  border: 1px solid rgba(245, 158, 11, 0.4);
  color: #f59e0b;
  font-size: 12px;
  font-weight: 800;
  padding: 4px 10px;
  border-radius: 20px;
  flex-shrink: 0;
}

.summary-shipping {
  padding: 8px 0;
  border-top: 1px solid rgba(255,255,255,0.06);
  margin-top: 4px;
}

.colissimo-logo-small {
  height: 22px;
  opacity: 0.8;
  flex-shrink: 0;
}

/* Zone main propre */
.zone-pills {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
}

.zone-pill {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 10px 18px;
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
  transition: all 0.2s;
}

.zone-pill:hover {
  border-color: var(--purple-light);
  color: var(--purple-light);
}

.zone-pill input[type="radio"] {
  accent-color: var(--purple);
  cursor: pointer;
}

/* Point relais display */
.relais-unselected {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 14px 18px;
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.25);
  border-radius: 12px;
  color: var(--gold);
  font-size: 13px;
  font-weight: 600;
  margin-bottom: 10px;
}

.relais-selected {
  padding: 14px 18px;
  background: rgba(16, 185, 129, 0.08);
  border: 1px solid rgba(16, 185, 129, 0.3);
  border-radius: 12px;
  margin-bottom: 10px;
}

.relais-selected-inner {
  display: flex;
  align-items: center;
  gap: 12px;
}

.relais-selected-check {
  font-size: 20px;
  flex-shrink: 0;
}

.relais-selected-name {
  font-weight: 700;
  color: #fff;
  font-size: 14px;
  margin-bottom: 2px;
}

.relais-selected-addr {
  font-size: 12px;
  color: var(--text-muted);
}

.btn-pick-relais {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--purple), #4f46e5);
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 12px 20px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.3s;
  width: 100%;
  justify-content: center;
}

.btn-pick-relais:hover {
  opacity: 0.9;
  transform: translateY(-1px);
  box-shadow: 0 8px 24px rgba(124, 58, 237, 0.4);
}

/* Modal Colissimo */
.colissimo-modal-box {
  background: #0d0820;
  border: 1px solid var(--border);
  border-radius: 20px;
  width: 95%;
  max-width: 820px;
  max-height: 90vh;
  overflow: hidden;
  box-shadow: 0 25px 80px rgba(0,0,0,0.7);
  display: flex;
  flex-direction: column;
}

.colissimo-modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px;
  border-bottom: 1px solid var(--border);
  background: rgba(124, 58, 237, 0.1);
}

.colissimo-modal-title {
  display: flex;
  align-items: center;
  gap: 12px;
  font-family: 'Orbitron', monospace;
  font-size: 14px;
  font-weight: 700;
  color: var(--purple-light);
  letter-spacing: 0.5px;
}

.colissimo-modal-close {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: rgba(255,255,255,0.07);
  border: 1px solid var(--border);
  color: var(--text-muted);
  cursor: pointer;
  font-size: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.2s;
}

.colissimo-modal-close:hover {
  background: rgba(239, 68, 68, 0.2);
  border-color: rgba(239, 68, 68, 0.4);
  color: #fff;
}

/* Legacy delivery options - keep for any old references */
.delivery-options { display: flex; gap: 12px; flex-wrap: wrap; margin: 20px 0; }
.delivery-option { display: flex; align-items: flex-start; gap: 12px; background: var(--card-bg); border: 1px solid var(--border); border-radius: 16px; padding: 16px; cursor: pointer; flex: 1; min-width: 200px; transition: all 0.3s; }
.delivery-option input[type=radio] { margin-top: 2px; cursor: pointer; }
.delivery-option-title { font-weight: 700; color: #fff; font-size: 14px; }
.delivery-option-sub { font-size: 12px; color: var(--text-muted); }

@media (max-width: 600px) {
  .delivery-card { padding: 14px 14px; }
  .delivery-card-ico { font-size: 22px; }
  .zone-pills { flex-direction: column; }
}

.checkout-error {
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 12px;
  padding: 12px 16px;
  color: #f87171;
  font-size: 13px;
  display: none;
  margin-bottom: 20px;
}

.checkout-summary {
  grid-column: 2;
  grid-row: 1;
}

.summary-box {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 28px;
  position: sticky;
  top: 100px;
}

.summary-title {
  font-family: 'Orbitron', monospace;
  font-size: 18px;
  color: #fff;
  margin-bottom: 20px;
}

.summary-item {
  display: flex;
  justify-content: space-between;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255, 255, 255, 0.06);
  font-size: 14px;
}

.summary-footer {
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--border);
}

.total-row {
  display: flex;
  justify-content: space-between;
  font-weight: 700;
  font-size: 16px;
  margin-bottom: 16px;
}

.summary-note {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.6;
  text-align: center;
  padding: 12px;
  background: rgba(124, 58, 237, 0.1);
  border-radius: 10px;
  margin-bottom: 16px;
}

/* ========== CONFIRMATION PAGE ========== */
.confirmation-box {
  max-width: 600px;
  margin: 0 auto;
  text-align: center;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 32px;
  padding: 60px 48px;
}

.confirmation-icon {
  font-size: 72px;
  margin-bottom: 20px;
}

.confirmation-box h2 {
  background: linear-gradient(135deg, var(--purple-light), var(--pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 20px;
  font-size: 32px;
}

.confirmation-sub {
  color: var(--text-muted);
  font-size: 14px;
  margin-bottom: 28px;
}

.order-id-display {
  font-family: 'Orbitron', monospace;
  font-size: 32px;
  font-weight: 900;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  border: 2px solid var(--border);
  border-radius: 16px;
  padding: 20px 40px;
  margin: 24px auto;
  display: inline-block;
}

.confirmation-text {
  color: var(--text-muted);
  font-size: 13px;
  line-height: 1.8;
  margin: 28px 0;
}

/* ========== PAIEMENT CHECKOUT ========== */
.payment-section {
  margin-top: 8px;
}

.payment-method-display {
  display: flex;
  align-items: center;
  gap: 16px;
  background: rgba(16, 185, 129, 0.07);
  border: 1.5px solid rgba(16, 185, 129, 0.3);
  border-radius: 16px;
  padding: 18px 20px;
  margin-top: 14px;
}

.payment-method-icon {
  font-size: 28px;
  flex-shrink: 0;
}

.payment-method-info {
  flex: 1;
}

.payment-method-name {
  font-weight: 700;
  font-size: 15px;
  color: #fff;
  margin-bottom: 4px;
}

.payment-method-sub {
  font-size: 12px;
  color: var(--text-muted);
}

.payment-method-badge {
  background: rgba(99, 91, 255, 0.15);
  border: 1px solid rgba(99, 91, 255, 0.4);
  color: #a5b4fc;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 50px;
  white-space: nowrap;
}

/* Stripe card logos row */
.stripe-logos {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-top: 10px;
  flex-wrap: wrap;
}

.stripe-logo-badge {
  background: rgba(255,255,255,0.08);
  border: 1px solid rgba(255,255,255,0.12);
  border-radius: 6px;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  letter-spacing: 0.3px;
}

.stripe-secure-row {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 12px;
  font-size: 11px;
  color: var(--text-muted);
}

/* ── Confirmation Stripe ── */
.stripe-confirm-card {
  background: linear-gradient(135deg, rgba(99,91,255,0.1) 0%, rgba(124,58,237,0.08) 100%);
  border: 1px solid rgba(99,91,255,0.3);
  border-radius: 18px;
  padding: 22px 24px 18px;
  margin: 20px 0 0;
  text-align: left;
}

.stripe-confirm-top {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  margin-bottom: 16px;
}

.stripe-confirm-icon {
  font-size: 30px;
  flex-shrink: 0;
  margin-top: 2px;
}

.stripe-confirm-title {
  font-size: 15px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 5px;
}

.stripe-confirm-sub {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.5;
}

.stripe-confirm-methods {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 12px;
}

.stripe-confirm-note {
  font-size: 12px;
  color: var(--text-muted);
  padding: 10px 14px;
  background: rgba(255,255,255,0.03);
  border-radius: 8px;
  border: 1px solid rgba(255,255,255,0.06);
}

/* Pay spinner */
.pay-spinner {
  display: inline-block;
  width: 16px;
  height: 16px;
  border: 2px solid rgba(255,255,255,0.3);
  border-top-color: #fff;
  border-radius: 50%;
  animation: spinAnim 0.7s linear infinite;
  vertical-align: middle;
  margin-right: 6px;
}

@keyframes spinAnim {
  to { transform: rotate(360deg); }
}

/* Payment toast notifications */
.payment-toast {
  position: fixed;
  bottom: 32px;
  left: 50%;
  transform: translateX(-50%) translateY(20px);
  padding: 16px 28px;
  border-radius: 50px;
  font-size: 14px;
  font-weight: 700;
  z-index: 9999;
  opacity: 0;
  transition: all 0.4s cubic-bezier(0.34,1.56,0.64,1);
  white-space: nowrap;
  box-shadow: 0 8px 32px rgba(0,0,0,0.4);
}

.payment-toast.show {
  opacity: 1;
  transform: translateX(-50%) translateY(0);
}

.payment-toast-success {
  background: linear-gradient(135deg, #065f46, #059669);
  border: 1px solid rgba(16,185,129,0.4);
  color: #fff;
}

.payment-toast-cancel {
  background: linear-gradient(135deg, #7c2d12, #c2410c);
  border: 1px solid rgba(239,68,68,0.4);
  color: #fff;
}

/* ── Toast admin (changement stock/prix) ── */
.admin-toast {
  position: fixed;
  bottom: 32px;
  right: 32px;
  background: rgba(20, 14, 40, 0.96);
  border: 1px solid var(--purple);
  border-radius: 12px;
  padding: 12px 22px;
  font-size: 13px;
  font-weight: 600;
  color: #fff;
  z-index: 9999;
  opacity: 0;
  transform: translateY(10px);
  transition: all 0.3s cubic-bezier(0.34,1.56,0.64,1);
  box-shadow: 0 4px 24px rgba(124,58,237,0.4);
  pointer-events: none;
}

.admin-toast-show {
  opacity: 1;
  transform: translateY(0);
}

.payment-info-box {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(124, 58, 237, 0.07);
  border: 1px solid var(--border);
  border-radius: 12px;
  padding: 14px 16px;
  margin-top: 12px;
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.7;
}

/* ========== BLOC RIB CONFIRMATION ========== */
.rib-card {
  background: rgba(6, 182, 212, 0.05);
  border: 1.5px solid rgba(6, 182, 212, 0.25);
  border-radius: 20px;
  padding: 28px;
  margin: 24px 0;
  text-align: left;
}

.rib-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
  padding-bottom: 18px;
  border-bottom: 1px solid rgba(255,255,255,0.06);
}

.rib-icon {
  font-size: 32px;
  flex-shrink: 0;
}

.rib-title {
  font-weight: 700;
  font-size: 16px;
  color: var(--cyan);
  margin-bottom: 4px;
}

.rib-subtitle {
  font-size: 12px;
  color: var(--text-muted);
}

.rib-fields {
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.rib-field {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 12px;
  flex-wrap: wrap;
}

.rib-field-important {
  background: rgba(6, 182, 212, 0.06);
  border-color: rgba(6, 182, 212, 0.2);
}

.rib-field-ref {
  background: rgba(245, 158, 11, 0.07);
  border-color: rgba(245, 158, 11, 0.3);
}

.rib-label {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  color: var(--text-muted);
  min-width: 130px;
  flex-shrink: 0;
}

.rib-value {
  font-size: 14px;
  color: #fff;
  font-weight: 600;
  flex: 1;
  word-break: break-all;
}

.rib-iban {
  font-family: 'Courier New', monospace;
  font-size: 13px;
  letter-spacing: 1px;
  color: var(--cyan);
}

.rib-ref {
  font-family: 'Orbitron', monospace;
  font-size: 14px;
  color: var(--gold);
  font-weight: 900;
}

.rib-copy-btn {
  background: rgba(255,255,255,0.07);
  border: 1px solid rgba(255,255,255,0.12);
  color: var(--text-muted);
  font-size: 11px;
  padding: 5px 12px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
  flex-shrink: 0;
}

.rib-copy-btn:hover {
  background: rgba(124, 58, 237, 0.2);
  border-color: var(--purple);
  color: #fff;
}

.rib-warning {
  margin-top: 18px;
  padding: 14px 16px;
  background: rgba(245, 158, 11, 0.08);
  border: 1px solid rgba(245, 158, 11, 0.25);
  border-radius: 12px;
  font-size: 12px;
  color: var(--gold);
  line-height: 1.6;
}

.rib-delay {
  margin-top: 12px;
  font-size: 12px;
  color: var(--text-muted);
  text-align: center;
}

.confirmation-actions {
  display: flex;
  gap: 16px;
  justify-content: center;
  flex-wrap: wrap;
  margin-top: 32px;
}

/* ========== TRACKING PAGE ========== */
/* ══════════════════════════════════════
   PAGE SUIVI COMMANDE — REDESIGN
   ══════════════════════════════════════ */
@keyframes trkOrbFloat {
  0%,100% { transform: translateY(0) scale(1); }
  50%      { transform: translateY(-20px) scale(1.08); }
}
@keyframes trkCardIn {
  from { opacity:0; transform:translateY(24px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes trkStepIn {
  from { opacity:0; transform:translateY(12px); }
  to   { opacity:1; transform:translateY(0); }
}
@keyframes trkRingPulse {
  0%,100% { transform:translate(-50%,-50%) scale(1);   opacity:.6; }
  50%      { transform:translate(-50%,-50%) scale(1.7); opacity:0; }
}
@keyframes trkScanLine {
  0%   { background-position: 0% 50%; }
  100% { background-position: 200% 50%; }
}

/* ── HERO ── */
.trk-hero {
  position: relative;
  overflow: hidden;
  padding: 70px 20px 60px;
  text-align: center;
}

.trk-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(60px);
  pointer-events: none;
  animation: trkOrbFloat 6s ease-in-out infinite;
}
.trk-orb1 {
  width: 320px; height: 320px;
  background: radial-gradient(circle, rgba(124,58,237,0.35), transparent 70%);
  top: -80px; left: -60px;
  animation-duration: 7s;
}
.trk-orb2 {
  width: 280px; height: 280px;
  background: radial-gradient(circle, rgba(236,72,153,0.25), transparent 70%);
  bottom: -60px; right: -40px;
  animation-duration: 9s; animation-delay: -3s;
}

.trk-hero-inner { position: relative; z-index: 1; max-width: 600px; margin: 0 auto; }

.trk-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(124,58,237,0.15);
  border: 1px solid rgba(168,85,247,0.35);
  border-radius: 50px;
  padding: 6px 18px;
  font-size: 12px;
  font-weight: 700;
  color: var(--purple-light);
  letter-spacing: 1px;
  margin-bottom: 20px;
}

.trk-title {
  font-family: 'Orbitron', monospace;
  font-size: clamp(26px, 5vw, 42px);
  font-weight: 800;
  color: #fff;
  margin: 0 0 12px;
  text-shadow: 0 0 40px rgba(168,85,247,0.4);
}

.trk-sub {
  color: var(--text-muted);
  font-size: 15px;
  margin-bottom: 32px;
}

/* ── CARTE RECHERCHE ── */
.trk-search-card {
  display: flex;
  gap: 10px;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(168,85,247,0.3);
  border-radius: 18px;
  padding: 8px 8px 8px 20px;
  max-width: 480px;
  margin: 0 auto;
  box-shadow: 0 0 40px rgba(124,58,237,0.12);
  transition: border-color 0.3s, box-shadow 0.3s;
}
.trk-search-card:focus-within {
  border-color: var(--purple-light);
  box-shadow: 0 0 0 4px rgba(139,92,246,0.15), 0 0 40px rgba(124,58,237,0.2);
}

.trk-search-wrap {
  display: flex;
  align-items: center;
  flex: 1;
  gap: 6px;
}

.trk-search-prefix {
  font-family: 'Orbitron', monospace;
  font-size: 14px;
  font-weight: 700;
  color: var(--purple-light);
  white-space: nowrap;
}

.trk-input {
  flex: 1;
  background: none;
  border: none;
  outline: none;
  color: #fff;
  font-family: 'Orbitron', monospace;
  font-size: 18px;
  font-weight: 700;
  letter-spacing: 4px;
  width: 80px;
}
.trk-input::placeholder { color: rgba(255,255,255,0.2); letter-spacing: 3px; font-size: 16px; }

.trk-btn {
  display: flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border: none;
  border-radius: 12px;
  padding: 12px 22px;
  color: #fff;
  font-size: 14px;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.25s;
  white-space: nowrap;
}
.trk-btn:hover { transform: translateY(-1px); box-shadow: 0 8px 24px rgba(124,58,237,0.45); }
.trk-btn:active { transform: scale(0.97); }
.trk-btn-icon { font-size: 16px; transition: transform 0.2s; }
.trk-btn:hover .trk-btn-icon { transform: translateX(3px); }

.trk-hint {
  margin-top: 14px;
  font-size: 12px;
  color: rgba(155,138,191,0.6);
}

/* ── CARTE RÉSULTAT ── */
.trk-card {
  background: rgba(124,58,237,0.05);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 24px;
  padding: 36px;
  box-shadow: 0 16px 48px rgba(124,58,237,0.1), inset 0 1px 0 rgba(255,255,255,0.04);
  animation: trkCardIn 0.4s cubic-bezier(0.34,1.2,0.64,1) both;
  backdrop-filter: blur(12px);
  margin-bottom: 40px;
}

/* ── EN-TÊTE COMMANDE ── */
.trk-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  flex-wrap: wrap;
  gap: 16px;
  margin-bottom: 28px;
}

.trk-order-id {
  font-family: 'Orbitron', monospace;
  font-size: 24px;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 0 20px rgba(168,85,247,0.5);
}

.trk-order-meta { font-size: 14px; color: var(--text-muted); margin-top: 5px; }
.trk-order-date { font-size: 12px; color: rgba(155,138,191,0.6); margin-top: 3px; }

.trk-status-badge {
  padding: 8px 18px;
  border-radius: 50px;
  font-size: 13px;
  font-weight: 700;
  border: 1px solid transparent;
}
.trk-sc-pending    { background:rgba(234,179,8,0.15);  border-color:rgba(234,179,8,0.4);  color:#fbbf24; }
.trk-sc-confirmed  { background:rgba(59,130,246,0.15); border-color:rgba(59,130,246,0.4); color:#93c5fd; }
.trk-sc-processing { background:rgba(139,92,246,0.15); border-color:rgba(168,85,247,0.4); color:#c4b5fd; }
.trk-sc-shipped    { background:rgba(6,182,212,0.15);  border-color:rgba(6,182,212,0.4);  color:#67e8f9; }
.trk-sc-delivered  { background:rgba(16,185,129,0.15); border-color:rgba(16,185,129,0.4); color:#6ee7b7; }
.trk-sc-cancelled  { background:rgba(239,68,68,0.15);  border-color:rgba(239,68,68,0.4);  color:#fca5a5; }

/* ── BARRE DE PROGRESSION ── */
.trk-progress-wrap {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 32px;
}

.trk-progress-bar {
  flex: 1;
  height: 6px;
  background: rgba(255,255,255,0.06);
  border-radius: 50px;
  overflow: hidden;
}

.trk-progress-fill {
  height: 100%;
  background: linear-gradient(90deg, var(--purple), var(--pink), #06b6d4);
  background-size: 200% 100%;
  border-radius: 50px;
  width: 0;
  animation: trkScanLine 2s linear infinite;
  box-shadow: 0 0 10px rgba(168,85,247,0.6);
  transition: width 1s cubic-bezier(0.4,0,0.2,1);
}

.trk-progress-pct {
  font-family: 'Orbitron', monospace;
  font-size: 13px;
  font-weight: 700;
  color: var(--purple-light);
  min-width: 38px;
  text-align: right;
}

/* ── STEPPER ── */
.trk-stepper {
  display: flex;
  justify-content: space-between;
  position: relative;
  margin-bottom: 36px;
  gap: 4px;
}

.trk-stepper::before {
  content: '';
  position: absolute;
  top: 20px;
  left: 20px;
  right: 20px;
  height: 2px;
  background: rgba(255,255,255,0.07);
  z-index: 0;
}

.trk-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  flex: 1;
  text-align: center;
  position: relative;
  z-index: 1;
  opacity: 0.3;
  animation: trkStepIn 0.4s ease both;
}

.trk-step.trk-done, .trk-step.trk-active { opacity: 1; }

.trk-step-dot {
  position: relative;
  width: 40px;
  height: 40px;
  border-radius: 50%;
  background: rgba(255,255,255,0.05);
  border: 2px solid rgba(255,255,255,0.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  margin-bottom: 8px;
  transition: all 0.3s;
}

.trk-step.trk-done .trk-step-dot {
  background: linear-gradient(135deg,#059669,#10b981);
  border-color: #10b981;
  box-shadow: 0 0 16px rgba(16,185,129,0.5);
  font-size: 18px;
  font-weight: 900;
  color: #fff;
}

.trk-step.trk-active .trk-step-dot {
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border-color: var(--purple-light);
  box-shadow: 0 0 20px rgba(124,58,237,0.6);
}

.trk-step-ring {
  position: absolute;
  top: 50%; left: 50%;
  width: 54px; height: 54px;
  border: 2px solid rgba(168,85,247,0.5);
  border-radius: 50%;
  animation: trkRingPulse 1.8s ease-out infinite;
}

.trk-step-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.3px;
}

.trk-step-sub {
  font-size: 10px;
  color: var(--purple-light);
  margin-top: 2px;
  min-height: 14px;
}

/* ── ANNULÉE ── */
.trk-cancelled {
  text-align: center;
  padding: 40px 20px;
  color: #fca5a5;
  font-weight: 600;
}
.trk-cancelled-icon { font-size: 40px; margin-bottom: 10px; }
.trk-cancelled-sub  { font-size: 13px; color: var(--text-muted); margin-top: 6px; }

/* ── ARTICLES ── */
.trk-items {
  margin-top: 8px;
  padding-top: 24px;
  border-top: 1px solid rgba(168,85,247,0.12);
}

.trk-items-title {
  font-size: 12px;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--text-muted);
  margin-bottom: 14px;
}

.trk-item-row {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 11px 16px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 10px;
  font-size: 14px;
  margin-bottom: 8px;
  transition: background 0.2s;
}
.trk-item-row:hover { background: rgba(124,58,237,0.08); }
.trk-item-qty { color: var(--purple-light); font-weight: 700; }

/* ── NOTE ADMIN ── */
.trk-note {
  margin-top: 16px;
  padding: 14px 18px;
  background: rgba(124,58,237,0.08);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 12px;
  font-size: 13px;
  color: var(--text-muted);
}

/* ── NOT FOUND ── */
.trk-notfound {
  text-align: center;
  padding: 50px 20px;
  animation: trkCardIn 0.3s ease both;
}
.trk-nf-icon { font-size: 52px; margin-bottom: 14px; }
.trk-nf-text { font-size: 16px; font-weight: 600; color: var(--text); }
.trk-nf-sub  { font-size: 13px; color: var(--text-muted); margin-top: 6px; }

/* ── RESPONSIVE ── */
@media (max-width: 600px) {
  .trk-card     { padding: 24px 16px; }
  .trk-step-label { font-size: 9px; }
  .trk-step-dot  { width: 32px; height: 32px; font-size: 13px; }
  .trk-stepper::before { top: 16px; }
}

/* ========== REVIEWS SECTION ========== */
/* ══════════════════════════════════════
   PAGE AVIS — REDESIGN COMPLET
   ══════════════════════════════════════ */
@keyframes rvOrbFloat  { 0%,100%{transform:translateY(0) scale(1);}  50%{transform:translateY(-22px) scale(1.06);} }
@keyframes rvTicker    { from{transform:translateX(0);} to{transform:translateX(-50%);} }
@keyframes rvPuffFloat { 0%,100%{transform:translateY(0) rotate(-3deg);} 50%{transform:translateY(-14px) rotate(3deg);} }
@keyframes rvRingPulse { 0%{transform:translate(-50%,-50%) scale(.8); opacity:.8;} 100%{transform:translate(-50%,-50%) scale(2.2); opacity:0;} }
@keyframes rvSmokeUp   { 0%{transform:translateY(0) scale(.6); opacity:.7;} 100%{transform:translateY(-50px) scale(1.4); opacity:0;} }
@keyframes rvCardIn    { from{opacity:0; transform:translateY(20px);} to{opacity:1; transform:translateY(0);} }
@keyframes rvTitleHL   { 0%,100%{background-position:0% 50%;} 50%{background-position:100% 50%;} }
@keyframes rvBadgeStar { 0%,100%{color:#f59e0b;} 50%{color:#fbbf24; text-shadow:0 0 8px #fbbf24;} }

/* ── HERO ── */
.rv-hero {
  position: relative;
  overflow: hidden;
  padding: 80px 40px 70px;
  text-align: center;
}

.rv-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(70px);
  pointer-events: none;
}
.rv-orb1 { width:400px;height:400px; background:radial-gradient(circle,rgba(124,58,237,.3),transparent 70%); top:-120px;left:-100px; animation:rvOrbFloat 8s ease-in-out infinite; }
.rv-orb2 { width:300px;height:300px; background:radial-gradient(circle,rgba(236,72,153,.2),transparent 70%); bottom:-80px;right:-60px; animation:rvOrbFloat 10s ease-in-out infinite; animation-delay:-4s; }
.rv-orb3 { width:200px;height:200px; background:radial-gradient(circle,rgba(6,182,212,.15),transparent 70%); top:50%;left:60%; animation:rvOrbFloat 7s ease-in-out infinite; animation-delay:-2s; }

.rv-hero-inner { position:relative; z-index:1; max-width:700px; margin:0 auto; }

.rv-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(124,58,237,.12); border:1px solid rgba(168,85,247,.3);
  border-radius:50px; padding:7px 20px; font-size:12px; font-weight:700;
  color:var(--purple-light); letter-spacing:1px; margin-bottom:24px;
}
.rv-badge-stars { animation:rvBadgeStar 2s ease infinite; }

.rv-hero-title {
  font-family:'Orbitron',monospace;
  font-size:clamp(28px,5vw,52px);
  font-weight:900; color:#fff; line-height:1.1;
  margin:0 0 16px;
}
.rv-title-hl {
  background:linear-gradient(135deg,#a855f7,#ec4899,#a855f7);
  background-size:200% auto;
  -webkit-background-clip:text; -webkit-text-fill-color:transparent;
  background-clip:text;
  animation:rvTitleHL 3s linear infinite;
}
.rv-hero-sub { color:var(--text-muted); font-size:16px; margin-bottom:36px; }

.rv-hero-stats {
  display:inline-flex; align-items:center; gap:28px;
  background:rgba(255,255,255,.04); border:1px solid rgba(168,85,247,.2);
  border-radius:16px; padding:16px 32px;
}
.rv-stat { text-align:center; }
.rv-stat-num { font-family:'Orbitron',monospace; font-size:22px; font-weight:800; color:#fff; }
.rv-stat-label { font-size:11px; color:var(--text-muted); margin-top:3px; letter-spacing:.5px; }
.rv-stat-sep { width:1px; height:36px; background:rgba(168,85,247,.25); }

/* ── Puff déco hero ── */
.rv-puff-deco {
  position:absolute; right:80px; top:50%; transform:translateY(-50%);
  animation:rvPuffFloat 4s ease-in-out infinite;
  display:flex; flex-direction:column; align-items:center;
  pointer-events:none;
}
.rv-puff-device { font-size:70px; filter:drop-shadow(0 0 20px rgba(168,85,247,.6)); }
.rv-smoke { font-size:18px; opacity:0; animation:rvSmokeUp 2s ease-out infinite; margin-top:-6px; }
.rv-smoke.s1 { animation-delay:0s; }
.rv-smoke.s2 { animation-delay:.6s; font-size:14px; }
.rv-smoke.s3 { animation-delay:1.2s; font-size:10px; }

/* ── TICKER ── */
.rv-ticker {
  position: relative;
  overflow: hidden;
  padding: 14px 0;
  white-space: nowrap;
  background: linear-gradient(90deg, rgba(124,58,237,.18), rgba(236,72,153,.12), rgba(124,58,237,.18));
  border-top: 1px solid rgba(168,85,247,.25);
  border-bottom: 1px solid rgba(168,85,247,.25);
  box-shadow: 0 0 30px rgba(124,58,237,.12);
}
/* Fondu sur les bords */
.rv-ticker::before,
.rv-ticker::after {
  content: '';
  position: absolute; top: 0; bottom: 0; width: 80px; z-index: 2;
  pointer-events: none;
}
.rv-ticker::before { left: 0;  background: linear-gradient(90deg, var(--bg), transparent); }
.rv-ticker::after  { right: 0; background: linear-gradient(-90deg, var(--bg), transparent); }

.rv-ticker-track {
  display: inline-flex;
  align-items: center;
  gap: 20px;
  animation: rvTicker 28s linear infinite;
}
.rv-tick-item {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(168,85,247,.2);
  border-radius: 50px;
  padding: 5px 16px;
  backdrop-filter: blur(4px);
  transition: border-color .2s;
}
.rv-tick-item:hover { border-color: rgba(168,85,247,.5); }
.rv-tick-stars {
  font-size: 11px;
  color: #fbbf24;
  letter-spacing: 1px;
  text-shadow: 0 0 6px rgba(251,191,36,.4);
}
.rv-tick-text {
  font-size: 12px;
  font-weight: 600;
  color: var(--text);
  letter-spacing: .3px;
}
.rv-tick-sep {
  font-size: 10px;
  color: rgba(168,85,247,.5);
  flex-shrink: 0;
}

/* ── LAYOUT PRINCIPAL ── */
.rv-main-layout {
  display:flex; flex-direction:column; gap:20px;
  max-width:1100px; margin:0 auto; padding:40px 40px 32px;
}

/* ── GRILLE AVIS ── */
.reviews-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill, minmax(280px,1fr));
  gap:20px;
  margin-bottom:48px;
}

/* ── CARTES AVIS ── */
.review-card {
  position:relative;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(168,85,247,.15);
  border-radius:20px;
  padding:28px 24px 22px;
  overflow:hidden;
  opacity:0; transform:translateY(20px);
  transition:all .35s cubic-bezier(.34,1.2,.64,1);
}
.review-card.rv-visible { animation:rvCardIn .5s cubic-bezier(.34,1.2,.64,1) both; }
.review-card::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(124,58,237,.06),transparent 60%);
  opacity:0; transition:opacity .3s; border-radius:inherit;
}
.review-card:hover { border-color:rgba(168,85,247,.4); transform:translateY(-4px); box-shadow:0 16px 40px rgba(124,58,237,.15); }
.review-card:hover::before { opacity:1; }

.rv-quote-mark {
  position:absolute; top:14px; right:20px;
  font-size:64px; line-height:1; font-family:Georgia,serif;
  color:rgba(168,85,247,.12); font-weight:900; pointer-events:none;
  user-select:none;
}

.review-header {
  display:flex; align-items:center; gap:12px; margin-bottom:14px;
}
.review-avatar {
  width:44px; height:44px; border-radius:50%;
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:800; color:#fff; flex-shrink:0;
  box-shadow:0 4px 12px rgba(0,0,0,.3);
}
.rv-author-info { flex:1; }
.review-name { font-weight:700; color:#fff; font-size:14px; }
.review-loc  { font-size:11px; color:var(--text-muted); margin-top:2px; }
.rv-verified {
  width:22px; height:22px; border-radius:50%;
  background:linear-gradient(135deg,#059669,#10b981);
  display:flex; align-items:center; justify-content:center;
  font-size:11px; color:#fff; font-weight:700; flex-shrink:0;
}

.review-stars { margin-bottom:12px; }
.rv-star     { font-size:16px; color:rgba(255,255,255,.2); }
.rv-star-on  { color:#fbbf24; text-shadow:0 0 6px rgba(251,191,36,.5); }

.review-text {
  font-size:13px; color:rgba(240,230,255,.75);
  line-height:1.7; margin-bottom:16px; font-style:italic;
}

.rv-card-footer {
  display:flex; align-items:center; justify-content:space-between;
}
.review-badge {
  display:inline-flex; align-items:center; gap:4px;
  background:rgba(16,185,129,.1); border:1px solid rgba(16,185,129,.25);
  color:#34d399; padding:4px 10px; border-radius:50px;
  font-size:10px; font-weight:700; letter-spacing:.5px;
}
.rv-card-brand { font-size:10px; color:rgba(168,85,247,.5); font-weight:700; letter-spacing:1px; }

/* ── PUFF STICKY ── */
.rv-puff-aside {
  width:120px; min-width:120px;
  position:sticky; top:140px;
}
.rv-puff-sticky {
  display:flex; flex-direction:column; align-items:center;
  gap:6px; padding:20px 10px;
  background:rgba(124,58,237,.08); border:1px solid rgba(168,85,247,.2);
  border-radius:20px; text-align:center;
  backdrop-filter:blur(10px);
}
.rv-puff-glow {
  position:absolute; width:80px; height:80px;
  background:radial-gradient(circle,rgba(168,85,247,.3),transparent 70%);
  border-radius:50%; pointer-events:none;
  animation:rvOrbFloat 4s ease-in-out infinite;
}
.rv-puff-emoji {
  font-size:48px; position:relative; z-index:1;
  animation:rvPuffFloat 3.5s ease-in-out infinite;
  filter:drop-shadow(0 0 14px rgba(168,85,247,.7));
}
.rv-puff-rings { position:relative; width:60px; height:60px; margin:-10px auto; }
.rv-ring {
  position:absolute; top:50%; left:50%;
  width:50px; height:50px; border-radius:50%;
  border:1.5px solid rgba(168,85,247,.4);
  animation:rvRingPulse 2.4s ease-out infinite;
}
.rv-ring.rv-ring2 { animation-delay:.8s; }
.rv-ring.rv-ring3 { animation-delay:1.6s; }
.rv-puff-label { font-family:'Orbitron',monospace; font-size:9px; font-weight:800; color:var(--purple-light); letter-spacing:1px; }
.rv-puff-sub   { font-size:8px; color:var(--text-muted); letter-spacing:.5px; }

/* ── CTA ── */
@keyframes rvCtaStarPop {
  0%,100% { transform:scale(1) translateY(0);   color:#fbbf24; text-shadow:0 0 8px rgba(251,191,36,.4); }
  50%     { transform:scale(1.3) translateY(-4px); color:#fde68a; text-shadow:0 0 16px rgba(251,191,36,.8); }
}
@keyframes rvCtaBorderShift {
  0%,100% { border-color:rgba(168,85,247,.35); box-shadow:0 0 30px rgba(124,58,237,.1); }
  50%     { border-color:rgba(236,72,153,.5);  box-shadow:0 0 40px rgba(236,72,153,.15); }
}
@keyframes rvCtaGlowDrift {
  0%   { transform:translate(-50%,-50%) scale(1) rotate(0deg); }
  50%  { transform:translate(-45%,-55%) scale(1.15) rotate(180deg); }
  100% { transform:translate(-50%,-50%) scale(1) rotate(360deg); }
}

.rv-cta {
  position:relative; overflow:hidden;
  background: linear-gradient(135deg, rgba(124,58,237,.1), rgba(236,72,153,.06), rgba(124,58,237,.1));
  border:1.5px solid rgba(168,85,247,.35);
  border-radius:28px; padding:52px 48px; text-align:center;
  backdrop-filter:blur(16px);
  animation: rvCtaBorderShift 4s ease-in-out infinite;
}

.rv-cta-bg-glow {
  position:absolute; border-radius:50%; pointer-events:none;
  filter:blur(60px);
}
.rv-cta-glow1 {
  width:280px; height:280px;
  background:radial-gradient(circle, rgba(124,58,237,.25), transparent 70%);
  top:50%; left:30%; transform:translate(-50%,-50%);
  animation:rvCtaGlowDrift 8s linear infinite;
}
.rv-cta-glow2 {
  width:220px; height:220px;
  background:radial-gradient(circle, rgba(236,72,153,.2), transparent 70%);
  top:50%; left:70%; transform:translate(-50%,-50%);
  animation:rvCtaGlowDrift 10s linear infinite reverse;
}

.rv-cta-inner { position:relative; z-index:1; }

.rv-cta-stars-row {
  display:flex; justify-content:center; gap:6px;
  margin-bottom:18px;
}
.rv-cta-star {
  font-size:28px; color:#fbbf24;
  display:inline-block;
  animation:rvCtaStarPop 2s ease-in-out infinite;
  text-shadow:0 0 10px rgba(251,191,36,.5);
}
.rv-cta-star-half { opacity:.5; filter:grayscale(.3); }

.rv-cta-title {
  font-family:'Orbitron',monospace;
  font-size:clamp(20px,3vw,28px);
  font-weight:900; color:#fff; margin-bottom:14px;
  text-shadow:0 0 30px rgba(168,85,247,.3);
}
.rv-cta-title-hl {
  background:linear-gradient(135deg,#a855f7,#ec4899);
  -webkit-background-clip:text; -webkit-text-fill-color:transparent; background-clip:text;
}

.rv-cta-sub {
  color:rgba(240,230,255,.65); font-size:15px;
  max-width:440px; margin:0 auto 32px; line-height:1.7;
}

.rv-cta-btn {
  display:inline-flex; align-items:center; gap:10px;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  border:none; border-radius:16px; padding:15px 36px;
  color:#fff; font-size:15px; font-weight:700; cursor:pointer;
  text-decoration:none; transition:all .3s cubic-bezier(.34,1.4,.64,1);
  box-shadow:0 8px 28px rgba(124,58,237,.4), 0 0 0 0 rgba(168,85,247,0);
  position:relative; overflow:hidden;
}
.rv-cta-btn::before {
  content:''; position:absolute; inset:0;
  background:linear-gradient(135deg,rgba(255,255,255,.15),transparent);
  opacity:0; transition:opacity .25s;
}
.rv-cta-btn:hover { transform:translateY(-3px) scale(1.02); box-shadow:0 16px 40px rgba(124,58,237,.55), 0 0 0 4px rgba(168,85,247,.2); }
.rv-cta-btn:hover::before { opacity:1; }
.rv-cta-btn:active { transform:scale(.97); }
.rv-cta-btn-icon { font-size:18px; }
.rv-cta-arrow { font-size:18px; transition:transform .2s; }
.rv-cta-btn:hover .rv-cta-arrow { transform:translateX(5px); }

.rv-cta-trust {
  margin-top:20px;
  font-size:12px; color:rgba(155,138,191,.55);
  letter-spacing:.5px;
}

/* ── RESPONSIVE ── */
@media (max-width:900px) {
  .rv-puff-deco { display:none; }
  .rv-main-layout { padding:40px 20px; flex-direction:column; }
  .rv-puff-aside { display:none; }
  .rv-hero { padding:60px 20px 50px; }
  .rv-hero-stats { flex-wrap:wrap; justify-content:center; gap:16px; padding:14px 20px; }
}

/* ══════════════════════════════════════
   PAGE FIDÉLITÉ
   ══════════════════════════════════════ */
@keyframes fdOrbFloat { 0%,100%{transform:translateY(0) scale(1);} 50%{transform:translateY(-18px) scale(1.06);} }
@keyframes fdCardIn   { from{opacity:0;transform:translateY(20px) scale(.97);} to{opacity:1;transform:translateY(0) scale(1);} }
@keyframes fdStampIn  { from{opacity:0;transform:scale(.4);} to{opacity:1;transform:scale(1);} }
@keyframes fdShimmer  { 0%{background-position:0% 50%;} 100%{background-position:200% 50%;} }
@keyframes fdGlow     { 0%,100%{box-shadow:0 0 20px rgba(124,58,237,.3);} 50%{box-shadow:0 0 40px rgba(236,72,153,.4);} }

/* ── Hero ── */
.fd-hero {
  position:relative; overflow:hidden;
  padding:70px 40px 60px; text-align:center;
}
.fd-orb {
  position:absolute; border-radius:50%; filter:blur(70px); pointer-events:none;
  animation:fdOrbFloat 7s ease-in-out infinite;
}
.fd-orb1 { width:350px;height:350px; background:radial-gradient(circle,rgba(124,58,237,.3),transparent 70%); top:-100px;left:-80px; }
.fd-orb2 { width:280px;height:280px; background:radial-gradient(circle,rgba(236,72,153,.22),transparent 70%); bottom:-60px;right:-50px; animation-delay:-3s; }

.fd-hero-inner { position:relative; z-index:1; max-width:640px; margin:0 auto; }

.fd-hero-badge {
  display:inline-flex; align-items:center; gap:8px;
  background:rgba(124,58,237,.12); border:1px solid rgba(168,85,247,.3);
  border-radius:50px; padding:7px 20px; font-size:12px; font-weight:700;
  color:var(--purple-light); letter-spacing:1px; margin-bottom:22px;
}
.fd-hero-title {
  font-family:'Orbitron',monospace; font-size:clamp(28px,5vw,48px);
  font-weight:900; color:#fff; line-height:1.1; margin:0 0 14px;
}
.fd-title-hl {
  background:linear-gradient(135deg,#a855f7,#ec4899,#a855f7);
  background-size:200% auto; -webkit-background-clip:text;
  -webkit-text-fill-color:transparent; background-clip:text;
  animation:fdShimmer 3s linear infinite;
}
.fd-hero-sub { color:var(--text-muted); font-size:16px; margin-bottom:32px; }
.fd-hero-sub strong { color:#fff; }

.fd-hero-stats {
  display:inline-flex; align-items:center; gap:24px;
  background:rgba(255,255,255,.04); border:1px solid rgba(168,85,247,.2);
  border-radius:16px; padding:16px 32px;
}
.fd-stat { text-align:center; }
.fd-stat-num { font-family:'Orbitron',monospace; font-size:22px; font-weight:800; color:#fff; }
.fd-stat-label { font-size:11px; color:var(--text-muted); margin-top:3px; }
.fd-stat-sep { font-size:22px; color:rgba(168,85,247,.4); font-weight:300; }
.fd-stat-reward .fd-stat-num { font-size:28px; }

/* ── Formulaire de création ── */
.fd-form-card {
  background:rgba(124,58,237,.06); border:1.5px solid rgba(168,85,247,.2);
  border-radius:24px; padding:36px; backdrop-filter:blur(14px);
  animation:fdCardIn .4s ease both;
  box-shadow:0 16px 48px rgba(124,58,237,.1);
}
.fd-form-header { text-align:center; margin-bottom:28px; }
.fd-form-icon { font-size:48px; margin-bottom:12px; }
.fd-form-title { font-family:'Orbitron',monospace; font-size:20px; font-weight:800; color:#fff; margin-bottom:6px; }
.fd-form-sub { font-size:13px; color:var(--text-muted); }

.fd-form-fields { display:flex; flex-direction:column; gap:16px; margin-bottom:24px; }
.fd-field { display:flex; flex-direction:column; gap:6px; }
.fd-label { font-size:12px; font-weight:700; color:var(--text-muted); letter-spacing:.5px; text-transform:uppercase; }
.fd-input {
  background:rgba(255,255,255,.05); border:1.5px solid rgba(168,85,247,.25);
  border-radius:12px; padding:12px 16px; color:#fff; font-size:14px; outline:none;
  transition:all .25s;
}
.fd-input:focus { border-color:var(--purple-light); background:rgba(124,58,237,.1); box-shadow:0 0 0 3px rgba(139,92,246,.15); }
.fd-input::placeholder { color:var(--text-muted); }

.fd-screenshot-warn {
  display:flex; align-items:flex-start; gap:12px;
  background:rgba(251,191,36,.07); border:1px solid rgba(251,191,36,.25);
  border-radius:14px; padding:14px 18px; margin-bottom:20px; font-size:13px;
  color:rgba(240,230,255,.8); line-height:1.5;
}
.fd-screenshot-remind {
  margin-top:20px; margin-bottom:0;
  background:rgba(236,72,153,.07); border-color:rgba(236,72,153,.25);
}
.fd-warn-icon { font-size:24px; flex-shrink:0; }
.fd-screenshot-warn strong { color:#fbbf24; display:block; margin-bottom:3px; }

.fd-error { color:#f87171; font-size:13px; margin-bottom:12px; min-height:18px; }

.fd-create-btn {
  display:flex; align-items:center; justify-content:center; gap:10px; width:100%;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  border:none; border-radius:14px; padding:15px; color:#fff;
  font-size:15px; font-weight:700; cursor:pointer;
  transition:all .3s cubic-bezier(.34,1.4,.64,1);
  box-shadow:0 8px 28px rgba(124,58,237,.4);
}
.fd-create-btn:hover { transform:translateY(-2px); box-shadow:0 14px 36px rgba(124,58,237,.55); }
.fd-btn-arrow { font-size:18px; transition:transform .2s; }
.fd-create-btn:hover .fd-btn-arrow { transform:translateX(4px); }

/* ── Carte visuelle ── */
.fd-card {
  position:relative; overflow:hidden;
  background:linear-gradient(135deg,#1a0a2e,#2d0a4e,#1a0a2e);
  border:1.5px solid rgba(168,85,247,.4);
  border-radius:22px; padding:28px;
  animation:fdCardIn .5s ease both, fdGlow 4s ease-in-out infinite;
  box-shadow:0 20px 60px rgba(124,58,237,.25);
  margin-bottom:24px;
}
.fd-card-bg-orb {
  position:absolute; width:200px; height:200px; border-radius:50%;
  background:radial-gradient(circle,rgba(168,85,247,.2),transparent 70%);
  top:-50px; right:-30px; pointer-events:none;
  animation:fdOrbFloat 5s ease-in-out infinite;
}

.fd-card-top { display:flex; justify-content:space-between; align-items:flex-start; margin-bottom:20px; }
.fd-card-brand { display:flex; flex-direction:column; gap:2px; }
.fd-card-logo { font-family:'Orbitron',monospace; font-size:22px; font-weight:900; color:#fff; letter-spacing:2px; }
.fd-card-program { font-size:10px; letter-spacing:2px; color:rgba(168,85,247,.8); text-transform:uppercase; }
.fd-card-id-wrap { text-align:right; }
.fd-card-id { font-family:'Orbitron',monospace; font-size:11px; color:rgba(168,85,247,.7); letter-spacing:1px; }

.fd-card-holder {
  font-family:'Orbitron',monospace; font-size:18px; font-weight:700;
  color:#fff; letter-spacing:2px; margin-bottom:24px;
  text-shadow:0 0 20px rgba(168,85,247,.4);
}

/* ── Tampons ── */
.fd-stamps-section { margin-bottom:24px; }
.fd-stamps-label { font-size:10px; letter-spacing:1.5px; color:rgba(168,85,247,.7); text-transform:uppercase; margin-bottom:10px; }
.fd-stamps-grid { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:8px; }
.fd-stamp {
  width:32px; height:32px; border-radius:50%;
  background:rgba(255,255,255,.06); border:1.5px solid rgba(168,85,247,.2);
  display:flex; align-items:center; justify-content:center;
  font-size:14px; transition:all .3s;
  animation:fdStampIn .4s ease both;
}
.fd-stamp-on {
  background:linear-gradient(135deg,rgba(124,58,237,.4),rgba(236,72,153,.3));
  border-color:rgba(168,85,247,.6);
  box-shadow:0 0 10px rgba(124,58,237,.4);
}
.fd-stamps-sub { font-size:12px; color:var(--text-muted); }

.fd-card-bottom { display:flex; justify-content:space-between; align-items:center; }
.fd-card-date { font-size:11px; color:rgba(255,255,255,.35); }
.fd-card-chip {
  background:linear-gradient(135deg,var(--purple),var(--pink));
  padding:5px 14px; border-radius:50px; font-size:11px; font-weight:800; color:#fff;
  letter-spacing:1px;
}

/* ── QR Code ── */
.fd-qr-section {
  display:flex; align-items:center; gap:20px;
  background:rgba(255,255,255,.03); border:1px solid rgba(168,85,247,.15);
  border-radius:18px; padding:20px 24px; margin-bottom:16px;
}
.fd-qr-wrap {
  background:#0d0820; border-radius:12px; padding:10px;
  border:2px solid rgba(168,85,247,.3); flex-shrink:0;
}
.fd-qr-wrap canvas, .fd-qr-wrap img { display:block; border-radius:6px; }
.fd-qr-title { font-weight:700; color:#fff; font-size:15px; margin-bottom:6px; }
.fd-qr-sub   { font-size:13px; color:var(--text-muted); line-height:1.5; }

.fd-reset-btn {
  background:none; border:1px solid rgba(248,113,113,.3);
  color:#f87171; font-size:12px; padding:8px 18px; border-radius:50px;
  cursor:pointer; transition:all .2s;
}
.fd-reset-btn:hover { background:rgba(248,113,113,.1); }

@media (max-width:600px) {
  .fd-hero { padding:50px 20px 40px; }
  .fd-form-card { padding:24px 18px; }
  .fd-card { padding:20px; }
  .fd-hero-stats { flex-wrap:wrap; gap:14px; padding:14px 20px; }
  .fd-qr-section { flex-direction:column; text-align:center; }
}

/* ══════════════════════════════════════
   SCANNER QR CODE ADMIN
   ══════════════════════════════════════ */
@keyframes qrsScanMove { 0%,100%{top:10%;} 50%{top:84%;} }
@keyframes qrsCornerPulse { 0%,100%{opacity:1;} 50%{opacity:.5;} }
@keyframes qrsSuccessIn { from{opacity:0;transform:scale(.7);} to{opacity:1;transform:scale(1);} }
@keyframes qrsFoundIn   { from{opacity:0;transform:translateY(10px);} to{opacity:1;transform:translateY(0);} }

/* Bouton ouverture scanner */
.qr-scan-open-btn {
  display:inline-flex; align-items:center; gap:8px;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  border:none; border-radius:12px; padding:11px 20px;
  color:#fff; font-size:13px; font-weight:700; cursor:pointer;
  transition:all .25s; box-shadow:0 6px 20px rgba(124,58,237,.4);
  white-space:nowrap;
}
.qr-scan-open-btn:hover { transform:translateY(-2px); box-shadow:0 10px 28px rgba(124,58,237,.55); }

.qr-or-divider { color:var(--text-muted); font-size:12px; font-weight:600; padding:0 4px; }

/* Overlay modale */
.qrs-overlay {
  position:fixed; inset:0; z-index:9999;
  background:rgba(0,0,0,.85); backdrop-filter:blur(8px);
  display:flex; align-items:center; justify-content:center;
  padding:20px;
}

.qrs-modal {
  position:relative;
  background:linear-gradient(135deg,#0d0820,#1a0a2e);
  border:1.5px solid rgba(168,85,247,.3);
  border-radius:24px; padding:28px;
  width:100%; max-width:440px;
  box-shadow:0 24px 80px rgba(124,58,237,.3);
}

.qrs-close {
  position:absolute; top:16px; right:16px;
  background:rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.1);
  color:var(--text-muted); width:32px; height:32px; border-radius:8px;
  cursor:pointer; font-size:14px; display:flex; align-items:center; justify-content:center;
  transition:all .2s;
}
.qrs-close:hover { background:rgba(248,113,113,.2); color:#f87171; }

.qrs-header { text-align:center; margin-bottom:20px; }
.qrs-title  { font-family:'Orbitron',monospace; font-size:16px; font-weight:800; color:#fff; margin-bottom:4px; }
.qrs-sub    { font-size:12px; color:var(--text-muted); }

/* Zone vidéo */
.qrs-viewport {
  position:relative; width:100%;
  aspect-ratio:1/1; max-height:280px;
  border-radius:16px; overflow:hidden;
  background:#000; margin-bottom:16px;
}

.qrs-video {
  width:100%; height:100%; object-fit:cover; display:block;
}

/* Cadre de scan */
.qrs-frame {
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  pointer-events:none;
}

.qrs-corner {
  position:absolute; width:28px; height:28px;
  border-color:rgba(168,85,247,.9); border-style:solid; border-width:0;
  animation:qrsCornerPulse 2s ease-in-out infinite;
}
.qrs-tl { top:16px;  left:16px;  border-top-width:3px;    border-left-width:3px;    border-radius:4px 0 0 0; }
.qrs-tr { top:16px;  right:16px; border-top-width:3px;    border-right-width:3px;   border-radius:0 4px 0 0; }
.qrs-bl { bottom:16px;left:16px; border-bottom-width:3px; border-left-width:3px;    border-radius:0 0 0 4px; }
.qrs-br { bottom:16px;right:16px;border-bottom-width:3px; border-right-width:3px;   border-radius:0 0 4px 0; }

.qrs-scan-line {
  position:absolute; left:16px; right:16px; height:2px;
  background:linear-gradient(90deg,transparent,rgba(168,85,247,.9),transparent);
  box-shadow:0 0 8px rgba(168,85,247,.7);
  animation:qrsScanMove 2s ease-in-out infinite;
}

.qrs-hint {
  position:absolute; bottom:10px; left:50%; transform:translateX(-50%);
  background:rgba(0,0,0,.7); backdrop-filter:blur(4px);
  border-radius:20px; padding:5px 14px;
  font-size:12px; font-weight:600; color:rgba(255,255,255,.8);
  white-space:nowrap;
}
.qrs-hint-ok  { background:rgba(16,185,129,.3); color:#6ee7b7; }
.qrs-hint-err { background:rgba(248,113,113,.3); color:#fca5a5; }

/* Résultat carte trouvée */
.qrs-result { margin-bottom:16px; }

.qrs-card-found {
  background:rgba(124,58,237,.08); border:1px solid rgba(168,85,247,.25);
  border-radius:16px; padding:16px;
  animation:qrsFoundIn .3s ease both;
}
.qrs-card-full { border-color:rgba(16,185,129,.4); background:rgba(16,185,129,.07); }

.qrs-found-top {
  display:flex; align-items:center; gap:12px; margin-bottom:12px;
}
.qrs-found-avatar {
  width:40px; height:40px; border-radius:50%; flex-shrink:0;
  background:linear-gradient(135deg,var(--purple),var(--pink));
  display:flex; align-items:center; justify-content:center;
  font-size:18px; font-weight:800; color:#fff;
}
.qrs-found-name  { font-size:15px; font-weight:700; color:#fff; }
.qrs-found-id    { font-size:10px; color:var(--purple-light); font-family:'Orbitron',monospace; }
.qrs-found-insta { font-size:11px; color:var(--text-muted); }
.qrs-found-status {
  margin-left:auto; font-size:13px; font-weight:700;
  color:var(--purple-light); white-space:nowrap;
}
.qrs-status-full { color:#10b981; }

.qrs-found-pips { display:flex; gap:4px; margin-bottom:8px; }
.qrs-found-bar  {
  height:4px; background:rgba(255,255,255,.08); border-radius:50px;
  overflow:hidden; margin-bottom:6px;
}
.qrs-found-fill {
  height:100%; border-radius:50px;
  background:linear-gradient(90deg,var(--purple),var(--pink));
  transition:width .8s ease;
}
.qrs-found-sub { font-size:11px; color:var(--text-muted); }

.qrs-card-notfound {
  text-align:center; padding:20px;
  animation:qrsFoundIn .3s ease both;
}
.qrs-nf-icon { font-size:36px; margin-bottom:8px; }
.qrs-nf-text { font-size:14px; font-weight:600; color:#fff; }
.qrs-nf-sub  { font-size:12px; color:var(--text-muted); margin-top:4px; }

/* Succès */
.qrs-success {
  text-align:center; padding:24px;
  animation:qrsSuccessIn .4s cubic-bezier(.34,1.4,.64,1) both;
}
.qrs-success-icon { font-size:52px; margin-bottom:10px; }
.qrs-success-text { font-family:'Orbitron',monospace; font-size:18px; font-weight:800; color:#fff; margin-bottom:6px; }
.qrs-success-sub  { font-size:13px; color:var(--purple-light); }

/* Boutons actions */
.qrs-actions {
  display:flex; gap:10px; flex-wrap:wrap;
}
.qrs-btn-stamp {
  flex:1; background:linear-gradient(135deg,var(--purple),var(--pink));
  border:none; border-radius:12px; padding:12px 20px;
  color:#fff; font-size:14px; font-weight:700; cursor:pointer;
  transition:all .25s; box-shadow:0 6px 20px rgba(124,58,237,.35);
}
.qrs-btn-stamp:hover:not(:disabled) { transform:translateY(-1px); }
.qrs-btn-rescan {
  background:rgba(255,255,255,.06); border:1px solid rgba(255,255,255,.1);
  border-radius:12px; padding:12px 16px;
  color:var(--text-muted); font-size:13px; font-weight:600; cursor:pointer;
  transition:all .2s;
}
.qrs-btn-rescan:hover { background:rgba(255,255,255,.1); color:var(--text); }

/* ========== CONTACT PAGE — REDESIGN ========== */

/* ── HERO ── */
.ct-hero {
  position: relative;
  text-align: center;
  padding: 80px 40px 60px;
  overflow: hidden;
}

.ct-hero-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  opacity: .18;
  pointer-events: none;
  animation: ctOrbFloat 8s ease-in-out infinite;
}
.ct-orb1 {
  width: 400px; height: 400px;
  background: radial-gradient(circle, #a855f7, transparent);
  top: -100px; left: -80px;
}
.ct-orb2 {
  width: 350px; height: 350px;
  background: radial-gradient(circle, #ec4899, transparent);
  top: -60px; right: -60px;
  animation-delay: -4s;
}
@keyframes ctOrbFloat {
  0%,100% { transform: translateY(0px) scale(1); }
  50%      { transform: translateY(30px) scale(1.08); }
}

.ct-live-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.3);
  color: #6ee7b7;
  font-size: 13px;
  font-weight: 600;
  padding: 7px 18px;
  border-radius: 50px;
  margin-bottom: 32px;
  animation: ctBadgePop .6s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes ctBadgePop {
  from { opacity:0; transform: scale(.8) translateY(-10px); }
  to   { opacity:1; transform: scale(1)  translateY(0); }
}

.ct-live-dot {
  width: 7px; height: 7px;
  border-radius: 50%;
  background: #10b981;
  display: inline-block;
  animation: ctDotPulse 1.5s ease-in-out infinite;
}
@keyframes ctDotPulse {
  0%,100% { opacity:1; transform: scale(1); }
  50%     { opacity:.4; transform: scale(.7); }
}

.ct-hero-title {
  font-family: 'Orbitron', monospace;
  font-size: clamp(36px, 7vw, 64px);
  font-weight: 900;
  line-height: 1.1;
  color: #fff;
  margin-bottom: 20px;
  animation: ctTitleIn .7s .1s cubic-bezier(.34,1.56,.64,1) both;
}
@keyframes ctTitleIn {
  from { opacity:0; transform: translateY(20px); }
  to   { opacity:1; transform: translateY(0); }
}

.ct-gradient-text {
  background: linear-gradient(135deg, #a855f7, #ec4899, #f59e0b);
  background-size: 200%;
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  background-clip: text;
  animation: ctGradShift 4s linear infinite;
}
@keyframes ctGradShift {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

.ct-hero-sub {
  font-size: 17px;
  color: var(--text-muted);
  line-height: 1.7;
  max-width: 540px;
  margin: 0 auto 44px;
  animation: ctTitleIn .7s .2s both;
}

.ct-hero-stats {
  display: inline-flex;
  align-items: center;
  gap: 32px;
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 18px 36px;
  animation: ctTitleIn .7s .3s both;
}
.ct-stat {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
}
.ct-stat-num {
  font-family: 'Orbitron', monospace;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
}
.ct-stat-num small {
  font-size: 12px;
  color: var(--purple-light);
}
.ct-stat-label {
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .8px;
}
.ct-stat-sep {
  width: 1px;
  height: 36px;
  background: var(--border);
}

/* ── CARTES SOCIALES ── */
.ct-socials {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
  max-width: 900px;
  margin: 0 auto 60px;
  padding: 0 40px;
}

.ct-social-card {
  position: relative;
  border-radius: 24px;
  padding: 36px;
  text-decoration: none;
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--card-bg);
  transition: transform .35s cubic-bezier(.34,1.2,.64,1), box-shadow .35s, border-color .3s;
  display: flex;
  flex-direction: column;
  gap: 10px;
  cursor: pointer;
}

.ct-card-glow {
  position: absolute;
  inset: 0;
  opacity: 0;
  transition: opacity .4s;
  border-radius: 24px;
}
.ct-insta .ct-card-glow {
  background: linear-gradient(135deg, rgba(245,158,11,.12), rgba(236,72,153,.15));
}
.ct-tiktok .ct-card-glow {
  background: linear-gradient(135deg, rgba(6,182,212,.12), rgba(168,85,247,.1));
}

.ct-social-card:hover .ct-card-glow { opacity: 1; }
.ct-insta:hover  { border-color: #ec4899; transform: translateY(-6px); box-shadow: 0 24px 60px rgba(236,72,153,.22); }
.ct-tiktok:hover { border-color: #06b6d4; transform: translateY(-6px); box-shadow: 0 24px 60px rgba(6,182,212,.22); }

.ct-card-top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 8px;
  position: relative;
  z-index: 1;
}

.ct-card-icon {
  font-size: 38px;
  line-height: 1;
}

.ct-card-live {
  display: flex;
  align-items: center;
  gap: 6px;
  background: rgba(16,185,129,.12);
  border: 1px solid rgba(16,185,129,.25);
  color: #6ee7b7;
  font-size: 11px;
  font-weight: 700;
  padding: 4px 12px;
  border-radius: 50px;
  text-transform: uppercase;
  letter-spacing: .5px;
}

.ct-card-network {
  font-family: 'Orbitron', monospace;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  position: relative;
  z-index: 1;
}

.ct-card-handle {
  font-size: 15px;
  font-weight: 700;
  position: relative;
  z-index: 1;
}
.ct-insta  .ct-card-handle { color: #f9a8d4; }
.ct-tiktok .ct-card-handle { color: #7dd3fc; }

.ct-card-desc {
  font-size: 13px;
  color: var(--text-muted);
  line-height: 1.6;
  position: relative;
  z-index: 1;
  margin-top: 4px;
}

.ct-card-cta {
  margin-top: 16px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-weight: 700;
  font-size: 14px;
  padding: 12px 20px;
  border-radius: 12px;
  width: fit-content;
  transition: gap .3s;
  position: relative;
  z-index: 1;
}
.ct-insta  .ct-card-cta { background: linear-gradient(135deg,rgba(245,158,11,.2),rgba(236,72,153,.2)); color: #f9a8d4; border: 1px solid rgba(236,72,153,.3); }
.ct-tiktok .ct-card-cta { background: linear-gradient(135deg,rgba(6,182,212,.2),rgba(168,85,247,.15)); color: #7dd3fc; border: 1px solid rgba(6,182,212,.3); }

.ct-cta-arrow {
  display: inline-block;
  transition: transform .3s;
}
.ct-social-card:hover .ct-cta-arrow { transform: translateX(5px); }
.ct-social-card:hover .ct-card-cta  { gap: 12px; }

/* ── GRILLE INFOS ── */
.ct-info-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  max-width: 900px;
  margin: 0 auto;
  padding: 0 40px 80px;
}

.ct-info-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-top: 2px solid var(--accent, #a855f7);
  border-radius: 16px;
  padding: 24px 20px;
  transition: transform .3s, box-shadow .3s;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.ct-info-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 12px 40px rgba(0,0,0,.3);
  border-color: var(--accent, #a855f7);
}

.ct-info-icon {
  width: 48px; height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  flex-shrink: 0;
}

.ct-info-title {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  line-height: 1.4;
}

.ct-info-text {
  font-size: 12px;
  color: var(--text-muted);
  line-height: 1.6;
}

/* ── Responsive ── */
@media (max-width: 768px) {
  .ct-hero { padding: 60px 20px 40px; }
  .ct-hero-stats { gap: 20px; padding: 14px 20px; }
  .ct-socials { grid-template-columns: 1fr; padding: 0 20px; }
  .ct-info-grid { grid-template-columns: 1fr 1fr; padding: 0 20px 60px; }
}
@media (max-width: 480px) {
  .ct-info-grid { grid-template-columns: 1fr; }
  .ct-hero-stats { flex-wrap: wrap; justify-content: center; }
}

/* ========== ADMIN LOGIN ========== */
.admin-login {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  min-height: calc(100vh - 90px);
  padding: 40px;
  text-align: center;
}

.admin-form {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 48px;
  max-width: 400px;
  width: 100%;
}

.admin-form h2 {
  font-family: 'Orbitron', monospace;
  font-size: 28px;
  margin-bottom: 28px;
  text-align: center;
}

.admin-form .form-group {
  margin-bottom: 20px;
}

.admin-form input {
  width: 100%;
}

.admin-error {
  background: rgba(239, 68, 68, 0.1);
  border: 1px solid rgba(239, 68, 68, 0.3);
  border-radius: 12px;
  padding: 12px 16px;
  color: #f87171;
  font-size: 13px;
  margin-bottom: 20px;
  display: none;
}

/* ========== ADMIN LAYOUT ========== */
.admin-layout {
  display: flex;
  min-height: calc(100vh - 90px);
}

.admin-sidebar {
  width: 240px;
  flex-shrink: 0;
  background: rgba(6, 3, 15, 0.95);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 24px 0;
  position: sticky;
  top: 90px;
  height: calc(100vh - 90px);
  overflow-y: auto;
}

.admin-logo {
  font-family: 'Orbitron', monospace;
  font-size: 20px;
  font-weight: 900;
  padding: 0 24px 24px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
}

.admin-logo span {
  color: var(--gold);
}

.admin-logo small {
  display: block;
  font-size: 10px;
  color: var(--text-muted);
  margin-top: 4px;
  letter-spacing: 2px;
}

.admin-nav {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  gap: 2px;
  padding: 8px 0;
}

.admin-nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 7px 24px;
  color: var(--text-muted);
  cursor: pointer;
  font-size: 13px;
  font-weight: 600;
  transition: all 0.2s;
  text-decoration: none;
  position: relative;
}

.admin-nav-item:hover, .admin-nav-item.active {
  color: #fff;
  background: rgba(168, 85, 247, 0.1);
  border-left: 3px solid var(--purple-light);
  padding-left: 21px;
}

.admin-nav-badge {
  background: var(--pink);
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 50px;
  margin-left: auto;
}

.admin-logout-btn {
  margin: 16px;
  padding: 12px 16px;
  border-radius: 12px;
  background: rgba(239, 68, 68, 0.12);
  border: 1px solid rgba(239, 68, 68, 0.3);
  color: #f87171;
  cursor: pointer;
  font-size: 13px;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: all 0.2s;
}

.admin-logout-btn:hover {
  background: rgba(239, 68, 68, 0.2);
}

.admin-main {
  flex: 1;
  padding: 32px;
  overflow-x: auto;
  overflow-y: auto;
}

.admin-section {
  display: none;
}

.admin-section.active {
  display: block;
}

.admin-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 28px;
  flex-wrap: wrap;
  gap: 12px;
}

.admin-page-header h1 {
  font-family: 'Orbitron', monospace;
  font-size: 24px;
  font-weight: 900;
  color: #fff;
}

/* ── KPI CARDS NEW ───────────────────────────────────────── */
.admin-kpis {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 24px;
}

.kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px;
  margin-bottom: 16px;
}

.kpi-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 18px;
  padding: 20px 22px;
  display: flex;
  align-items: center;
  gap: 16px;
  position: relative;
  overflow: hidden;
  transition: transform 0.2s, box-shadow 0.2s;
}

.kpi-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 8px 32px rgba(0,0,0,0.3);
}

.kpi-card::before {
  content: '';
  position: absolute;
  top: 0; left: 0; right: 0;
  height: 2px;
}

.kpi-accent-purple::before { background: linear-gradient(90deg, var(--purple), var(--purple-light)); }
.kpi-accent-blue::before   { background: linear-gradient(90deg, #3b82f6, #60a5fa); }
.kpi-accent-pink::before   { background: linear-gradient(90deg, var(--pink), #f472b6); }
.kpi-accent-gold::before   { background: linear-gradient(90deg, var(--gold), #fbbf24); }
.kpi-accent-green::before  { background: linear-gradient(90deg, var(--green), #34d399); }
.kpi-accent-orange::before { background: linear-gradient(90deg, #f97316, #fb923c); }
.kpi-accent-red::before    { background: linear-gradient(90deg, #ef4444, #f87171); }
.kpi-accent-cyan::before   { background: linear-gradient(90deg, var(--cyan), #22d3ee); }

.kpi-icon {
  font-size: 28px;
  flex-shrink: 0;
  width: 52px;
  height: 52px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255,255,255,0.05);
}

.kpi-body { flex: 1; min-width: 0; }

.kpi-label {
  font-size: 11px;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 6px;
  font-weight: 600;
}

.kpi-value {
  font-family: 'Orbitron', monospace;
  font-size: 22px;
  font-weight: 900;
  color: #fff;
  line-height: 1.1;
}

.kpi-sub {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 4px;
}

.kpi-trend {
  font-size: 12px;
  color: var(--green);
  margin-top: 6px;
}

/* Admin page header */
.admin-page-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  margin-bottom: 24px;
}

.admin-page-header h1 {
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 4px;
}

.admin-page-sub {
  font-size: 13px;
  color: var(--text-muted);
}

.admin-date-chip {
  background: var(--glass);
  border: 1px solid var(--border);
  border-radius: 50px;
  padding: 6px 16px;
  font-size: 12px;
  color: var(--text-muted);
  white-space: nowrap;
  text-transform: capitalize;
}

/* Admin card header */
.admin-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}

/* Small button */
.admin-btn-sm {
  background: rgba(124,58,237,0.15);
  border: 1px solid var(--border);
  border-radius: 8px;
  color: var(--purple-light);
  font-size: 12px;
  font-weight: 600;
  padding: 6px 14px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.admin-btn-sm:hover {
  background: rgba(124,58,237,0.3);
  color: #fff;
}

/* Order ID chip */
.order-id-chip {
  font-family: 'Orbitron', monospace;
  font-size: 11px;
  font-weight: 700;
  background: rgba(124,58,237,0.15);
  border: 1px solid var(--border);
  border-radius: 6px;
  padding: 4px 8px;
  color: var(--purple-light);
  white-space: nowrap;
}

/* ── GAMME SPLIT BAR ─────────────────────────────────────── */
.gamme-bar-track {
  display: flex;
  height: 32px;
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 12px;
}

.gamme-bar-16k {
  background: linear-gradient(90deg, #3b82f6, #60a5fa);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  transition: width 0.5s ease;
}

.gamme-bar-18k {
  background: linear-gradient(90deg, var(--pink), #f472b6);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  transition: width 0.5s ease;
  flex: 1;
}

.gamme-bar-legend {
  display: flex;
  gap: 20px;
  font-size: 12px;
  color: var(--text-muted);
}

.gamme-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  margin-right: 6px;
  vertical-align: middle;
}

.dot-16k { background: #60a5fa; }
.dot-18k { background: var(--pink); }

/* ── FILTER PILLS ────────────────────────────────────────── */
.admin-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.filter-pill {
  background: rgba(255,255,255,0.05);
  border: 1px solid var(--border);
  border-radius: 50px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  padding: 7px 16px;
  cursor: pointer;
  transition: all 0.2s;
}

.filter-pill:hover {
  background: rgba(124,58,237,0.15);
  color: #fff;
  border-color: var(--purple);
}

.filter-pill.active {
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border-color: transparent;
  color: #fff;
}

/* ── PRODUCTS ADMIN ──────────────────────────────────────── */
.stock-overview {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

.stock-ov-item {
  border-radius: 14px;
  padding: 16px 20px;
  border: 1px solid;
  text-align: center;
}

.ov-green  { background: rgba(16,185,129,0.08);  border-color: rgba(16,185,129,0.25); }
.ov-orange { background: rgba(249,115,22,0.08);  border-color: rgba(249,115,22,0.25); }
.ov-red    { background: rgba(239,68,68,0.08);   border-color: rgba(239,68,68,0.25);  }
.ov-blue   { background: rgba(59,130,246,0.08);  border-color: rgba(59,130,246,0.25); }

.stock-ov-num {
  font-family: 'Orbitron', monospace;
  font-size: 28px;
  font-weight: 900;
  color: #fff;
  margin-bottom: 4px;
}

.ov-green  .stock-ov-num { color: var(--green); }
.ov-orange .stock-ov-num { color: #fb923c; }
.ov-red    .stock-ov-num { color: #f87171; }
.ov-blue   .stock-ov-num { color: #60a5fa; }

.stock-ov-label {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

/* Gamme tabs */
.prod-gamme-tabs {
  display: flex;
  gap: 12px;
  margin-bottom: 20px;
}

.prod-gamme-tab {
  display: flex;
  align-items: center;
  gap: 8px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 12px;
  color: var(--text-muted);
  font-size: 14px;
  font-weight: 700;
  padding: 12px 24px;
  cursor: pointer;
  transition: all 0.2s;
}

.prod-gamme-tab.active {
  background: linear-gradient(135deg, rgba(124,58,237,0.25), rgba(236,72,153,0.15));
  border-color: var(--purple);
  color: #fff;
}

.prod-tab-count {
  background: rgba(255,255,255,0.1);
  border-radius: 50px;
  padding: 2px 8px;
  font-size: 11px;
}

/* Product admin card grid */
.prod-admin-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(300px, 1fr));
  gap: 16px;
}

.prod-admin-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  overflow: hidden;
  transition: border-color 0.2s, transform 0.2s;
  position: relative;
}

.prod-admin-card:hover {
  border-color: var(--purple);
  transform: translateY(-2px);
}

.prod-admin-img-wrap {
  height: 140px;
  position: relative;
  overflow: hidden;
}

.prod-admin-img-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.prod-admin-body {
  padding: 16px;
}

.prod-admin-name {
  font-size: 15px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 8px;
}

.prod-admin-meta {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.prod-gamme-badge {
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border-radius: 6px;
  color: #fff;
  font-size: 10px;
  font-weight: 800;
  padding: 3px 8px;
  letter-spacing: 0.5px;
}

.prod-admin-row {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}

.prod-admin-label {
  font-size: 11px;
  color: var(--text-muted);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.5px;
  min-width: 60px;
  flex-shrink: 0;
}

.prod-admin-input {
  background: rgba(255,255,255,0.06);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 7px 10px;
  color: #fff;
  font-size: 12px;
  outline: none;
  transition: border-color 0.2s;
}

.prod-admin-input:focus {
  border-color: var(--purple);
}

/* Stock status pills */
.stock-status-group {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.stock-pill {
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 50px;
  color: var(--text-muted);
  font-size: 11px;
  font-weight: 600;
  padding: 5px 12px;
  cursor: pointer;
  transition: all 0.2s;
  white-space: nowrap;
}

.stock-pill:hover { opacity: 0.85; }

.pill-green {
  background: rgba(16,185,129,0.2);
  border-color: rgba(16,185,129,0.5);
  color: var(--green);
}

.pill-orange {
  background: rgba(249,115,22,0.2);
  border-color: rgba(249,115,22,0.5);
  color: #fb923c;
}

.pill-red {
  background: rgba(239,68,68,0.2);
  border-color: rgba(239,68,68,0.5);
  color: #f87171;
}

/* Low stock display on storefront */
.low-stock {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  color: #fb923c;
  font-size: 12px;
  font-weight: 600;
}

/* ── ORDER MODAL UPGRADE ─────────────────────────────────── */
.modal-item-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 0;
  border-bottom: 1px solid rgba(255,255,255,0.05);
}

.modal-item-img {
  width: 44px;
  height: 44px;
  border-radius: 8px;
  flex-shrink: 0;
  overflow: hidden;
  background: rgba(124,58,237,0.2);
}

.modal-item-info { flex: 1; min-width: 0; }

.modal-status-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 8px;
}

.modal-status-btn {
  background: rgba(255,255,255,0.04);
  border: 1px solid var(--border);
  border-radius: 10px;
  color: var(--text-muted);
  font-size: 12px;
  font-weight: 600;
  padding: 10px 8px;
  cursor: pointer;
  text-align: center;
  transition: all 0.2s;
}

.modal-status-btn:hover {
  background: rgba(124,58,237,0.15);
  color: #fff;
}

.modal-status-btn.active {
  background: linear-gradient(135deg, rgba(124,58,237,0.3), rgba(236,72,153,0.2));
  border-color: var(--purple);
  color: #fff;
}

.admin-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 20px;
}

.admin-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 24px;
}

.admin-card-title {
  font-size: 14px;
  font-weight: 700;
  color: #fff;
  margin-bottom: 16px;
}

.admin-table {
  width: 100%;
  border-collapse: collapse;
}

.admin-table th {
  text-align: left;
  padding: 10px 12px;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}

.admin-table td {
  padding: 12px;
  font-size: 13px;
  color: var(--text);
  border-bottom: 1px solid rgba(255, 255, 255, 0.04);
}

.admin-table tr:hover td {
  background: rgba(255, 255, 255, 0.02);
}

.admin-empty {
  text-align: center;
  padding: 40px;
  color: var(--text-muted);
  font-size: 14px;
}

.status-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 50px;
  font-size: 11px;
  font-weight: 700;
}

.status-pending {
  background: rgba(245, 158, 11, 0.15);
  color: var(--gold);
  border: 1px solid rgba(245, 158, 11, 0.3);
}

.status-confirmed {
  background: rgba(59, 130, 246, 0.15);
  color: #60a5fa;
  border: 1px solid rgba(59, 130, 246, 0.3);
}

.status-processing {
  background: rgba(124, 58, 237, 0.15);
  color: var(--purple-light);
  border: 1px solid var(--border);
}

.status-shipped {
  background: rgba(6, 182, 212, 0.15);
  color: var(--cyan);
  border: 1px solid rgba(6, 182, 212, 0.3);
}

.status-delivered {
  background: rgba(16, 185, 129, 0.15);
  color: var(--green);
  border: 1px solid rgba(16, 185, 129, 0.3);
}

.status-cancelled {
  background: rgba(239, 68, 68, 0.12);
  color: #f87171;
  border: 1px solid rgba(239, 68, 68, 0.3);
}

.admin-select {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  color: #fff;
  font-size: 13px;
  cursor: pointer;
}

.admin-btn-icon {
  background: transparent;
  border: none;
  cursor: pointer;
  color: var(--text-muted);
  padding: 4px;
  transition: color 0.2s;
}

.admin-btn-icon:hover {
  color: var(--purple-light);
}

.admin-filters select {
  background: rgba(255, 255, 255, 0.07);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 8px 12px;
  color: #fff;
  font-size: 13px;
  cursor: pointer;
}

.admin-table input[type=text] {
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 6px 10px;
  color: #fff;
  font-size: 12px;
  width: 140px;
  outline: none;
}

.prod-thumb {
  width: 50px;
  height: 50px;
  border-radius: 8px;
  object-fit: cover;
  background: rgba(124, 58, 237, 0.2);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
}

.stock-toggle {
  position: relative;
  display: inline-block;
  width: 40px;
  height: 22px;
}

.stock-toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.stock-toggle-slider {
  position: absolute;
  inset: 0;
  background: #374151;
  border-radius: 22px;
  cursor: pointer;
  transition: 0.3s;
}

.stock-toggle-slider::before {
  content: '';
  position: absolute;
  height: 16px;
  width: 16px;
  left: 3px;
  bottom: 3px;
  background: white;
  border-radius: 50%;
  transition: 0.3s;
}

input:checked + .stock-toggle-slider {
  background: var(--green);
}

input:checked + .stock-toggle-slider::before {
  transform: translateX(18px);
}

.chart-bar-row {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 10px;
}

.chart-bar-label {
  font-size: 12px;
  color: var(--text-muted);
  width: 100px;
  flex-shrink: 0;
}

.chart-bar-track {
  flex: 1;
  height: 8px;
  background: rgba(255, 255, 255, 0.08);
  border-radius: 4px;
  overflow: hidden;
}

.chart-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.6s ease;
}

.chart-bar-count {
  font-size: 12px;
  font-weight: 700;
  color: #fff;
  width: 24px;
  text-align: right;
}

/* ========== MODAL ========== */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.7);
  z-index: 2000;
  display: none;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(4px);
}

.modal-overlay.open {
  display: flex;
}

.modal-box {
  background: #0d0720;
  border: 1px solid var(--border);
  border-radius: 24px;
  padding: 40px;
  max-width: 640px;
  width: 90%;
  max-height: 85vh;
  overflow-y: auto;
  position: relative;
}

.modal-close {
  position: absolute;
  top: 16px;
  right: 16px;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  color: #fff;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 16px;
  transition: all 0.2s;
}

.modal-close:hover {
  background: rgba(255, 255, 255, 0.15);
}

.modal-order-id {
  font-family: 'Orbitron', monospace;
  font-size: 20px;
  color: var(--purple-light);
  margin-bottom: 20px;
}

.modal-section {
  margin-bottom: 20px;
}

.modal-section-title {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.modal-grid-2 {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.modal-field {
  background: rgba(255, 255, 255, 0.04);
  border-radius: 10px;
  padding: 12px;
}

.modal-field label {
  font-size: 11px;
  color: var(--text-muted);
  display: block;
  margin-bottom: 4px;
}

.modal-field span {
  font-size: 14px;
  color: #fff;
  font-weight: 600;
}

textarea.admin-note {
  width: 100%;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 12px;
  color: #fff;
  font-size: 13px;
  resize: vertical;
  outline: none;
  min-height: 80px;
}

/* ========== FOOTER ========== */
footer {
  background: rgba(6, 3, 15, 0.95);
  border-top: 1px solid var(--border);
  padding: 60px 40px 20px;
}

.footer-inner {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr;
  gap: 40px;
  max-width: 1300px;
  margin: 0 auto;
}

.footer-brand {
  margin-bottom: 20px;
}

.footer-brand .logo {
  display: block;
  margin-bottom: 12px;
}

/* ---- Footer logo animé ---- */
.footer-logo-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 110px;
  height: 110px;
  margin-bottom: 14px;
  animation: footerLogoFloat 5s ease-in-out infinite;
}

.footer-logo-img {
  position: relative;
  z-index: 2;
  width: 80px;
  height: 80px;
  object-fit: contain;
  filter: drop-shadow(0 0 10px rgba(124,58,237,0.8))
          drop-shadow(0 0 24px rgba(236,72,153,0.4));
  animation: footerLogoGlow 4s ease-in-out infinite;
  transition: transform 0.3s ease;
}

.footer-logo-wrap:hover .footer-logo-img {
  transform: scale(1.12);
  filter: drop-shadow(0 0 16px rgba(236,72,153,1))
          drop-shadow(0 0 32px rgba(6,182,212,0.7));
}

.footer-logo-aura {
  position: absolute;
  z-index: 1;
  width: 90px;
  height: 90px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(124,58,237,0.3) 0%,
    rgba(236,72,153,0.12) 50%,
    transparent 70%);
  filter: blur(10px);
  animation: footerAuraPulse 4s ease-in-out infinite;
}

@keyframes footerLogoFloat {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-7px); }
}

@keyframes footerLogoGlow {
  0%   { filter: drop-shadow(0 0 10px rgba(124,58,237,0.8)) drop-shadow(0 0 24px rgba(236,72,153,0.4)); }
  40%  { filter: drop-shadow(0 0 14px rgba(236,72,153,1))   drop-shadow(0 0 28px rgba(6,182,212,0.5));  }
  80%  { filter: drop-shadow(0 0 14px rgba(6,182,212,0.9))  drop-shadow(0 0 28px rgba(124,58,237,0.5)); }
  100% { filter: drop-shadow(0 0 10px rgba(124,58,237,0.8)) drop-shadow(0 0 24px rgba(236,72,153,0.4)); }
}

@keyframes footerAuraPulse {
  0%, 100% { transform: scale(1);    opacity: 0.6; }
  50%       { transform: scale(1.3); opacity: 1;   }
}

.footer-brand p {
  font-size: 13px;
  color: var(--text-muted);
  margin-bottom: 16px;
}

.footer-col h3 {
  font-size: 13px;
  font-weight: 700;
  margin-bottom: 16px;
  text-transform: uppercase;
  letter-spacing: 1px;
}

.footer-col a {
  display: block;
  font-size: 13px;
  color: var(--text-muted);
  text-decoration: none;
  margin-bottom: 10px;
  transition: color 0.3s;
}

.footer-col a:hover {
  color: var(--purple-light);
}

.footer-bottom {
  max-width: 1300px;
  margin: 40px auto 0;
  padding: 20px 0;
  border-top: 1px solid var(--border);
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 16px;
  font-size: 12px;
  color: var(--text-muted);
}

.age-warning {
  background: rgba(245, 158, 11, 0.1);
  border: 1px solid rgba(245, 158, 11, 0.3);
  padding: 12px 16px;
  border-radius: 8px;
  font-size: 11px;
  color: var(--gold);
}

/* ========== ANIMATIONS ========== */
@keyframes fadeUp {
  from {
    opacity: 0;
    transform: translateY(20px);
  }
  to {
    opacity: 1;
    transform: translateY(0);
  }
}

@keyframes pulse {
  0%, 100% {
    opacity: 1;
  }
  50% {
    opacity: 0.5;
  }
}

@keyframes gradientShift {
  0%, 100% {
    background-position: 0% 50%;
  }
  50% {
    background-position: 100% 50%;
  }
}

@keyframes scrollLeft {
  0% {
    transform: translateX(0);
  }
  100% {
    transform: translateX(-100%);
  }
}

@keyframes floatUp {
  0%, 100% {
    transform: translateY(0px);
  }
  50% {
    transform: translateY(-20px);
  }
}

/* ========== HERO LOGO ANIMATED ========== */

/* Nav logo image */
.nav-logo {
  background: none !important;
  -webkit-background-clip: unset !important;
  -webkit-text-fill-color: unset !important;
}
.nav-logo-img {
  height: 44px;
  width: auto;
  filter: drop-shadow(0 0 8px rgba(168,85,247,0.6));
  transition: filter 0.3s;
}
.nav-logo:hover .nav-logo-img {
  filter: drop-shadow(0 0 14px rgba(236,72,153,0.9)) drop-shadow(0 0 6px rgba(6,182,212,0.6));
}

/* Hero logo wrapper */
.hero-logo-wrap {
  position: relative;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 340px;
  height: 340px;
  margin: 10px auto 20px;
  animation: heroLogoFloat 4s ease-in-out infinite;
}

/* Main logo image */
.hero-logo-img {
  position: relative;
  z-index: 3;
  width: 260px;
  height: 260px;
  object-fit: contain;
  animation: heroLogoReveal 1s cubic-bezier(0.34,1.56,0.64,1) forwards,
             heroLogoGlow 3s ease-in-out infinite 1s;
  filter: drop-shadow(0 0 18px rgba(124,58,237,0.9))
          drop-shadow(0 0 40px rgba(236,72,153,0.5));
}

/* Glowing aura blob behind logo */
.logo-glow-aura {
  position: absolute;
  z-index: 1;
  width: 240px;
  height: 240px;
  border-radius: 50%;
  background: radial-gradient(ellipse at center,
    rgba(124,58,237,0.35) 0%,
    rgba(236,72,153,0.18) 40%,
    transparent 70%);
  animation: auraPulse 3s ease-in-out infinite;
  filter: blur(18px);
}

/* Orbit ring 1 */
.logo-orbit-ring {
  position: absolute;
  z-index: 2;
  width: 310px;
  height: 310px;
  border-radius: 50%;
  border: 1.5px solid transparent;
  background: linear-gradient(#06030f, #06030f) padding-box,
              linear-gradient(135deg, var(--purple), var(--pink), var(--cyan), var(--purple)) border-box;
  animation: orbitSpin 5s linear infinite;
  opacity: 0.75;
}

/* Orbit ring 2 (counter-spin, different angle) */
.logo-orbit-ring.ring2 {
  width: 330px;
  height: 330px;
  border-width: 1px;
  background: linear-gradient(#06030f, #06030f) padding-box,
              linear-gradient(45deg, var(--cyan), var(--purple), var(--pink)) border-box;
  animation: orbitSpinReverse 8s linear infinite;
  opacity: 0.4;
}

/* ---- Keyframes ---- */

@keyframes heroLogoReveal {
  0%   { opacity: 0; transform: scale(0.5) rotate(-15deg); filter: blur(12px) brightness(2); }
  60%  { opacity: 1; transform: scale(1.08) rotate(3deg);  filter: blur(0) brightness(1.4); }
  100% { opacity: 1; transform: scale(1) rotate(0deg);     filter: drop-shadow(0 0 18px rgba(124,58,237,0.9)) drop-shadow(0 0 40px rgba(236,72,153,0.5)); }
}

@keyframes heroLogoFloat {
  0%, 100% { transform: translateY(0px); }
  50%       { transform: translateY(-14px); }
}

@keyframes heroLogoGlow {
  0%   { filter: drop-shadow(0 0 18px rgba(124,58,237,0.9)) drop-shadow(0 0 40px rgba(236,72,153,0.5)); }
  33%  { filter: drop-shadow(0 0 22px rgba(236,72,153,1))   drop-shadow(0 0 50px rgba(124,58,237,0.6)); }
  66%  { filter: drop-shadow(0 0 22px rgba(6,182,212,1))    drop-shadow(0 0 50px rgba(236,72,153,0.5)); }
  100% { filter: drop-shadow(0 0 18px rgba(124,58,237,0.9)) drop-shadow(0 0 40px rgba(236,72,153,0.5)); }
}

@keyframes auraPulse {
  0%, 100% { transform: scale(1);    opacity: 0.7; }
  50%       { transform: scale(1.25); opacity: 1;   }
}

@keyframes orbitSpin {
  from { transform: rotate(0deg); }
  to   { transform: rotate(360deg); }
}

@keyframes orbitSpinReverse {
  from { transform: rotate(0deg); }
  to   { transform: rotate(-360deg); }
}

/* ========== RESPONSIVE ========== */
@media (max-width: 1024px) {
  .admin-kpis {
    grid-template-columns: repeat(2, 1fr);
  }
}

@media (max-width: 900px) {
  .features-strip {
    grid-template-columns: repeat(2, 1fr);
  }

  .why-grid {
    grid-template-columns: repeat(2, 1fr);
  }

  .footer-inner {
    grid-template-columns: repeat(2, 1fr);
  }

  .contact-wrapper {
    grid-template-columns: 1fr;
  }

  .admin-grid-2 {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 768px) {
  nav {
    padding: 12px 20px;
  }

  .logo {
    font-size: 18px;
  }

  .nav-links {
    display: none;
  }

  .section {
    padding: 50px 20px;
  }

  .hero {
    padding: 40px 20px;
  }

  .hero h1 {
    font-size: 42px;
  }

  .hero-logo-wrap {
    width: 260px;
    height: 260px;
  }
  .hero-logo-img {
    width: 200px;
    height: 200px;
  }
  .logo-orbit-ring {
    width: 240px;
    height: 240px;
  }
  .logo-orbit-ring.ring2 {
    width: 258px;
    height: 258px;
  }
  .nav-logo-img {
    height: 36px;
  }

  .why-grid {
    grid-template-columns: 1fr;
  }

  .checkout-wrapper {
    grid-template-columns: 1fr;
  }

  .cart-wrapper {
    grid-template-columns: 1fr;
  }
}

@media (max-width: 600px) {
  .footer-inner {
    grid-template-columns: 1fr;
  }

  /* Sidebar toujours en colonne, même sur petit écran */
  .admin-layout {
    flex-direction: row;
    align-items: flex-start;
  }

  .admin-sidebar {
    width: 180px;
    min-width: 180px;
    flex-shrink: 0;
    position: sticky;
    top: 0;
    height: 100vh;
    border-right: 1px solid var(--border);
    border-bottom: none;
    overflow-y: auto;
  }

  .admin-nav {
    display: flex;
    flex-direction: column;
    padding: 8px 0;
  }

  .admin-nav-item {
    padding: 10px 16px;
    font-size: 12px;
    white-space: nowrap;
  }

  .admin-nav-item span,
  .admin-nav-item svg {
    display: inline-block;
  }

  .admin-main {
    padding: 16px;
    min-width: 0;
    flex: 1;
  }
}

/* ============================================================
   PRODUCT MODAL — ADMIN
   ============================================================ */

/* ── Bouton "Ajouter un produit" ── */
.btn-add-product {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  border: none;
  border-radius: 12px;
  padding: 12px 22px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity 0.2s, transform 0.2s;
  flex-shrink: 0;
}
.btn-add-product:hover { opacity: .85; transform: translateY(-1px); }

/* ── Badge "Custom" sur les cartes ── */
.prod-custom-card { border: 1px solid rgba(168,85,247,.35) !important; }

.prod-custom-badge {
  position: absolute;
  top: 8px;
  right: 8px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  font-size: 10px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 50px;
  letter-spacing: .5px;
  z-index: 2;
}

/* ── Boutons Modifier / Supprimer sur cartes custom ── */
.prod-admin-actions {
  display: flex;
  gap: 8px;
  margin-top: 10px;
}
.prod-action-edit,
.prod-action-del {
  flex: 1;
  padding: 8px 10px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid transparent;
  transition: all .2s;
}
.prod-action-edit {
  background: rgba(168,85,247,.12);
  border-color: rgba(168,85,247,.3);
  color: var(--purple-light);
}
.prod-action-edit:hover { background: rgba(168,85,247,.22); }
.prod-action-del {
  background: rgba(239,68,68,.1);
  border-color: rgba(239,68,68,.25);
  color: #f87171;
}
.prod-action-del:hover { background: rgba(239,68,68,.2); }

/* ── Modal box ── */
.pm-modal-box {
  max-width: 820px !important;
  width: 95vw !important;
  padding: 32px !important;
}

/* ── Layout 2 colonnes ── */
.pm-layout {
  display: grid;
  grid-template-columns: 1fr 240px;
  gap: 28px;
}

/* ── Champs ── */
.pm-fields { display: flex; flex-direction: column; gap: 16px; }

.pm-field { display: flex; flex-direction: column; gap: 6px; }

.pm-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
}

.pm-input {
  background: rgba(255,255,255,.05);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 10px 14px;
  color: #fff;
  font-size: 13px;
  font-family: inherit;
  transition: border-color .2s;
  width: 100%;
  box-sizing: border-box;
}
.pm-input:focus { outline: none; border-color: var(--purple-light); }
.pm-input option { background: #1a1a2e; }

.pm-hint {
  font-size: 11px;
  color: var(--text-muted);
  margin-top: 2px;
}
.pm-hint code {
  background: rgba(255,255,255,.08);
  padding: 1px 5px;
  border-radius: 4px;
  font-size: 11px;
}

.pm-field-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

/* ── Boutons stock ── */
.pm-stock-btns {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.pm-stock-btn {
  padding: 7px 12px;
  border-radius: 8px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border);
  background: rgba(255,255,255,.04);
  color: var(--text-muted);
  transition: all .2s;
}
.pm-stock-btn.pill-green.active  { background: rgba(16,185,129,.18); border-color: rgba(16,185,129,.4); color: #6ee7b7; }
.pm-stock-btn.pill-orange.active { background: rgba(245,158,11,.15); border-color: rgba(245,158,11,.35); color: #fcd34d; }
.pm-stock-btn.pill-red.active    { background: rgba(239,68,68,.15);  border-color: rgba(239,68,68,.35);  color: #fca5a5; }
.pm-stock-btn:hover { border-color: rgba(255,255,255,.2); }

/* ── Colonne aperçu ── */
.pm-preview-col {
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.pm-preview-label {
  font-size: 11px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .5px;
  text-align: center;
}

.pm-preview-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 14px;
  overflow: hidden;
}

.pm-preview-img-wrap {
  height: 140px;
  position: relative;
  overflow: hidden;
}
/* Inherit color class backgrounds from pv-* */
.pm-preview-img-wrap.pv-purple { background: linear-gradient(135deg,#4c1d95,#7c3aed); }
.pm-preview-img-wrap.pv-blue   { background: linear-gradient(135deg,#1e3a5f,#3b82f6); }
.pm-preview-img-wrap.pv-pink   { background: linear-gradient(135deg,#831843,#ec4899); }
.pm-preview-img-wrap.pv-red    { background: linear-gradient(135deg,#7f1d1d,#ef4444); }
.pm-preview-img-wrap.pv-orange { background: linear-gradient(135deg,#7c2d12,#f97316); }
.pm-preview-img-wrap.pv-green  { background: linear-gradient(135deg,#064e3b,#10b981); }
.pm-preview-img-wrap.pv-teal   { background: linear-gradient(135deg,#134e4a,#14b8a6); }
.pm-preview-img-wrap.pv-black  { background: linear-gradient(135deg,#0f0f0f,#374151); }

.pm-preview-info {
  padding: 10px 12px;
}

.pm-save-btn {
  width: 100%;
  padding: 14px;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  color: #fff;
  border: none;
  border-radius: 12px;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .2s;
  margin-top: auto;
}
.pm-save-btn:hover { opacity: .85; transform: translateY(-1px); }

/* ══════════════════════════════════════════════════════════════
   FIDELITE — RECHERCHE PAR RÉFÉRENCE
   ══════════════════════════════════════════════════════════════ */
.fd-ref-search-card {
  border: 1px solid rgba(168, 85, 247, 0.25) !important;
  background: linear-gradient(135deg, rgba(124,58,237,0.07) 0%, rgba(236,72,153,0.05) 100%) !important;
}

.fd-ref-input-row {
  display: flex;
  align-items: center;
  gap: 0;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(168,85,247,0.35);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
  max-width: 520px;
}

.fd-ref-input-row:focus-within {
  border-color: var(--purple-light);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.18), 0 4px 24px rgba(124,58,237,0.15);
}

.fd-ref-input-icon {
  padding: 0 16px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  color: var(--purple-light);
  background: rgba(124,58,237,0.18);
  border-right: 1px solid rgba(168,85,247,0.2);
  height: 48px;
  display: flex;
  align-items: center;
  white-space: nowrap;
  user-select: none;
}

.fd-ref-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  padding: 0 16px;
  color: #fff;
  font-size: 15px;
  font-family: monospace;
  font-weight: 700;
  letter-spacing: .06em;
  height: 48px;
}

.fd-ref-input::placeholder {
  color: rgba(155,138,191,0.5);
  font-weight: 400;
  letter-spacing: 0;
}

.fd-ref-clear-btn {
  background: transparent;
  border: none;
  padding: 0 14px;
  color: var(--text-muted);
  font-size: 14px;
  cursor: pointer;
  height: 48px;
  transition: color .2s;
}
.fd-ref-clear-btn:hover { color: #fff; }

/* Carte résultat */
.fd-ref-found-card {
  background: linear-gradient(135deg, rgba(124,58,237,0.12) 0%, rgba(236,72,153,0.08) 100%);
  border: 1px solid rgba(168,85,247,0.3);
  border-radius: 14px;
  padding: 18px 20px;
  display: flex;
  align-items: center;
  gap: 20px;
  flex-wrap: wrap;
  animation: fdRefCardIn .3s cubic-bezier(.34,1.56,.64,1) both;
}

@keyframes fdRefCardIn {
  from { opacity: 0; transform: translateY(10px) scale(.97); }
  to   { opacity: 1; transform: translateY(0) scale(1); }
}

.fd-ref-avatar {
  width: 52px;
  height: 52px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 22px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(124,58,237,0.4);
}

.fd-ref-info {
  flex: 1;
  min-width: 180px;
}

.fd-ref-name {
  font-size: 17px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 2px;
}

.fd-ref-id-chip {
  display: inline-block;
  font-family: monospace;
  font-size: 11px;
  font-weight: 700;
  color: var(--purple-light);
  background: rgba(124,58,237,0.18);
  padding: 2px 10px;
  border-radius: 20px;
  margin-bottom: 8px;
  letter-spacing: .06em;
}

.fd-ref-stamps-row {
  display: flex;
  align-items: center;
  gap: 10px;
  flex-wrap: wrap;
}

.fd-ref-stamp-pips {
  display: flex;
  gap: 4px;
}

.fd-ref-pip {
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: rgba(255,255,255,0.08);
  border: 1.5px solid rgba(168,85,247,0.25);
  transition: background .2s, border-color .2s;
  position: relative;
}
.fd-ref-pip.on {
  background: var(--purple);
  border-color: var(--purple-light);
  box-shadow: 0 0 6px rgba(168,85,247,0.5);
}
.fd-ref-pip.on::after {
  content: '';
  position: absolute;
  inset: 3px;
  border-radius: 50%;
  background: rgba(255,255,255,0.3);
}

.fd-ref-count {
  font-size: 13px;
  font-weight: 700;
}

.fd-ref-actions {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  align-items: center;
}

.fd-ref-not-found {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: rgba(239,68,68,0.06);
  border: 1px solid rgba(239,68,68,0.2);
  border-radius: 12px;
  color: #f87171;
  font-size: 14px;
  animation: fdRefCardIn .25s ease both;
}

/* ══════════════════════════════════════════════════════════════
   FIDELITE — LOOKUP PUBLIC (retrouve ta carte)
   ══════════════════════════════════════════════════════════════ */
.fd-lookup-section {
  margin-top: 40px;
}

.fd-lookup-divider {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 22px;
  color: var(--text-muted);
  font-size: 13px;
}
.fd-lookup-divider::before,
.fd-lookup-divider::after {
  content: '';
  flex: 1;
  height: 1px;
  background: rgba(168,85,247,0.18);
}

.fd-lookup-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(168,85,247,0.2);
  border-radius: 20px;
  padding: 24px 24px 20px;
}

.fd-lookup-header {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 18px;
}

.fd-lookup-icon {
  width: 44px;
  height: 44px;
  border-radius: 12px;
  background: rgba(124,58,237,0.18);
  border: 1px solid rgba(168,85,247,0.25);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  flex-shrink: 0;
}

.fd-lookup-title {
  font-size: 16px;
  font-weight: 700;
  color: #fff;
}

.fd-lookup-sub {
  font-size: 12px;
  color: var(--text-muted);
  margin-top: 2px;
}

.fd-lookup-input-row {
  display: flex;
  align-items: center;
  background: rgba(255,255,255,0.04);
  border: 1.5px solid rgba(168,85,247,0.3);
  border-radius: 14px;
  overflow: hidden;
  transition: border-color .25s, box-shadow .25s;
}
.fd-lookup-input-row:focus-within {
  border-color: var(--purple-light);
  box-shadow: 0 0 0 3px rgba(168,85,247,0.15), 0 4px 20px rgba(124,58,237,0.12);
}

.fd-lookup-prefix {
  padding: 0 15px;
  font-size: 11px;
  font-weight: 900;
  letter-spacing: .12em;
  color: var(--purple-light);
  background: rgba(124,58,237,0.18);
  border-right: 1px solid rgba(168,85,247,0.2);
  height: 48px;
  display: flex;
  align-items: center;
  user-select: none;
}

.fd-lookup-input {
  flex: 1;
  background: transparent;
  border: none;
  outline: none;
  padding: 0 16px;
  color: #fff;
  font-size: 15px;
  font-family: monospace;
  font-weight: 700;
  letter-spacing: .08em;
  height: 48px;
  text-transform: uppercase;
}
.fd-lookup-input::placeholder {
  color: rgba(155,138,191,0.4);
  font-weight: 400;
  letter-spacing: .02em;
  text-transform: none;
}

.fd-lookup-clear {
  background: transparent;
  border: none;
  padding: 0 14px;
  color: var(--text-muted);
  font-size: 14px;
  cursor: pointer;
  height: 48px;
  transition: color .2s;
}
.fd-lookup-clear:hover { color: #fff; }

/* Résultat trouvé */
.fd-lookup-result-card {
  margin-top: 18px;
  background: linear-gradient(135deg, rgba(124,58,237,0.1) 0%, rgba(236,72,153,0.06) 100%);
  border: 1px solid rgba(168,85,247,0.25);
  border-radius: 16px;
  padding: 18px 20px;
  animation: fdLookupIn .3s cubic-bezier(.34,1.56,.64,1) both;
}

@keyframes fdLookupIn {
  from { opacity:0; transform: translateY(12px) scale(.97); }
  to   { opacity:1; transform: translateY(0) scale(1); }
}

.fd-lookup-result-top {
  display: flex;
  align-items: center;
  gap: 14px;
  margin-bottom: 14px;
}

.fd-lookup-avatar {
  width: 48px;
  height: 48px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--purple), var(--pink));
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 20px;
  font-weight: 800;
  color: #fff;
  flex-shrink: 0;
  box-shadow: 0 4px 16px rgba(124,58,237,0.35);
}

.fd-lookup-result-name {
  font-size: 16px;
  font-weight: 800;
  color: #fff;
}

.fd-lookup-result-ref {
  font-family: monospace;
  font-size: 11px;
  color: var(--purple-light);
  background: rgba(124,58,237,0.15);
  padding: 2px 9px;
  border-radius: 20px;
  margin-top: 3px;
  display: inline-block;
}

.fd-lookup-progress-label {
  font-size: 12px;
  color: var(--text-muted);
  margin-bottom: 8px;
  text-transform: uppercase;
  letter-spacing: .06em;
}

.fd-lookup-pips {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-bottom: 8px;
}

.fd-lookup-pip {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: rgba(255,255,255,0.06);
  border: 1.5px solid rgba(168,85,247,0.2);
  position: relative;
  transition: background .2s, border-color .2s;
}
.fd-lookup-pip.on {
  background: linear-gradient(135deg, var(--purple), var(--pink));
  border-color: var(--purple-light);
  box-shadow: 0 0 8px rgba(168,85,247,0.5);
}
.fd-lookup-pip.on::after {
  content: '✓';
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 10px;
  color: rgba(255,255,255,0.8);
}

.fd-lookup-count {
  font-size: 14px;
  font-weight: 700;
  margin-bottom: 6px;
}

.fd-lookup-reward-banner {
  display: flex;
  align-items: center;
  gap: 10px;
  background: rgba(16,185,129,0.1);
  border: 1px solid rgba(16,185,129,0.3);
  border-radius: 10px;
  padding: 10px 14px;
  margin-top: 10px;
  color: #6ee7b7;
  font-size: 13px;
  font-weight: 700;
  animation: fdLookupIn .4s ease both;
}

.fd-lookup-not-found {
  margin-top: 14px;
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 16px;
  background: rgba(239,68,68,0.06);
  border: 1px solid rgba(239,68,68,0.18);
  border-radius: 12px;
  color: #f87171;
  font-size: 13px;
  animation: fdLookupIn .25s ease both;
}

/* ══════════════════════════════════════════════════════════════
   DELETE CONFIRMATION MODAL
   ══════════════════════════════════════════════════════════════ */
#deleteConfirmModal {
  opacity: 0;
  transition: opacity .25s ease;
  align-items: center;
  justify-content: center;
  background: rgba(0,0,0,0.72);
  backdrop-filter: blur(6px);
  z-index: 3000;
}
.del-confirm-box {
  background: linear-gradient(145deg, #120826 0%, #1a0f35 100%);
  border: 1px solid rgba(239, 68, 68, 0.35);
  border-radius: 20px;
  padding: 36px 32px 28px;
  max-width: 420px;
  width: 90%;
  margin: auto;
  text-align: center;
  box-shadow: 0 0 60px rgba(239,68,68,0.18), 0 20px 60px rgba(0,0,0,0.6);
  animation: delBoxIn .25s cubic-bezier(.34,1.56,.64,1) both;
}

@keyframes delBoxIn {
  from { opacity:0; transform: scale(.85) translateY(20px); }
  to   { opacity:1; transform: scale(1) translateY(0); }
}

.del-confirm-icon {
  font-size: 48px;
  margin-bottom: 12px;
  animation: delIconPulse 1.4s ease-in-out infinite;
  display: block;
}

@keyframes delIconPulse {
  0%,100% { transform: scale(1); }
  50%      { transform: scale(1.12); }
}

.del-confirm-title {
  font-size: 20px;
  font-weight: 800;
  color: #fff;
  margin-bottom: 8px;
}

.del-confirm-sub {
  font-size: 13px;
  color: var(--text-muted);
  margin-bottom: 20px;
}

.del-step-label {
  font-size: 12px;
  font-weight: 700;
  color: var(--text-muted);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 16px;
  padding: 8px 14px;
  background: rgba(255,255,255,0.04);
  border-radius: 8px;
  display: inline-block;
}

.del-step-warn {
  color: #f87171 !important;
  background: rgba(239,68,68,0.08) !important;
}

.del-step-type {
  font-size: 13px;
  color: var(--text-muted);
  margin-bottom: 10px;
}

.del-step-type strong {
  color: #ef4444;
  font-family: monospace;
  font-size: 15px;
  background: rgba(239,68,68,0.1);
  padding: 2px 8px;
  border-radius: 6px;
  border: 1px solid rgba(239,68,68,0.25);
}

.del-confirm-input {
  width: 100%;
  padding: 12px 16px;
  background: rgba(255,255,255,0.05);
  border: 1px solid rgba(239,68,68,0.3);
  border-radius: 10px;
  color: #ef4444;
  font-size: 15px;
  font-family: monospace;
  font-weight: 700;
  text-align: center;
  letter-spacing: .08em;
  outline: none;
  transition: border-color .2s, box-shadow .2s;
  margin-bottom: 18px;
}

.del-confirm-input:focus {
  border-color: #ef4444;
  box-shadow: 0 0 0 3px rgba(239,68,68,0.15);
}

.del-confirm-btns {
  display: flex;
  gap: 10px;
  justify-content: center;
}

.del-btn-cancel {
  padding: 11px 22px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,0.15);
  background: rgba(255,255,255,0.06);
  color: var(--text-muted);
  font-size: 13px;
  font-weight: 600;
  cursor: pointer;
  transition: background .2s, color .2s;
}
.del-btn-cancel:hover { background: rgba(255,255,255,0.1); color: #fff; }

.del-btn-next {
  padding: 11px 22px;
  border-radius: 10px;
  border: none;
  background: linear-gradient(135deg, #f59e0b, #ef4444);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .2s;
}
.del-btn-next:hover { opacity: .85; transform: translateY(-1px); }

.del-btn-delete {
  padding: 11px 22px;
  border-radius: 10px;
  border: none;
  background: linear-gradient(135deg, #ef4444, #b91c1c);
  color: #fff;
  font-size: 13px;
  font-weight: 700;
  cursor: pointer;
  transition: opacity .2s, transform .2s;
  box-shadow: 0 4px 18px rgba(239,68,68,0.4);
}
.del-btn-delete:hover:not(:disabled) { opacity: .85; transform: translateY(-1px); }
.del-btn-delete:disabled {
  opacity: .35;
  cursor: not-allowed;
  box-shadow: none;
}

/* Delete icon button in tables */
.admin-btn-del {
  padding: 5px 10px;
  border-radius: 8px;
  border: 1px solid rgba(239,68,68,0.3);
  background: rgba(239,68,68,0.08);
  color: #f87171;
  font-size: 13px;
  cursor: pointer;
  transition: background .2s, border-color .2s;
  margin-left: 6px;
}
.admin-btn-del:hover {
  background: rgba(239,68,68,0.2);
  border-color: rgba(239,68,68,0.6);
  color: #fff;
}

/* ── Responsive ── */
@media (max-width: 600px) {
  .pm-layout { grid-template-columns: 1fr; }
  .pm-preview-col { order: -1; }
  .pm-modal-box { padding: 20px !important; }
}

/* ========== LEGAL PAGES ========== */
.legal-section {
  max-width: 860px;
}

.legal-header {
  text-align: center;
  margin-bottom: 56px;
}

.legal-icon-wrap {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 80px;
  height: 80px;
  border-radius: 50%;
  background: var(--glass);
  border: 1px solid var(--border);
  margin-bottom: 24px;
  box-shadow: 0 0 30px rgba(124, 58, 237, 0.25);
  animation: pulse-glow 3s ease-in-out infinite;
}

.legal-icon {
  font-size: 36px;
}

.legal-title {
  font-family: 'Orbitron', monospace;
  font-size: 36px;
  font-weight: 900;
  background: linear-gradient(135deg, var(--purple-light), var(--pink), var(--cyan));
  -webkit-background-clip: text;
  -webkit-text-fill-color: transparent;
  margin-bottom: 12px;
  line-height: 1.2;
}

.legal-subtitle {
  color: var(--text-muted);
  font-size: 14px;
  letter-spacing: 0.5px;
}

.legal-card {
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 48px;
  backdrop-filter: blur(10px);
  position: relative;
  overflow: hidden;
}

.legal-card::before {
  content: '';
  position: absolute;
  top: 0;
  left: 0;
  right: 0;
  height: 2px;
  background: linear-gradient(90deg, var(--purple), var(--pink), var(--cyan));
}

.legal-block {
  padding: 28px 0;
  border-bottom: 1px solid rgba(168, 85, 247, 0.12);
}

.legal-block:last-child {
  border-bottom: none;
  padding-bottom: 0;
}

.legal-block:first-child {
  padding-top: 0;
}

.legal-block h2 {
  font-family: 'Orbitron', monospace;
  font-size: 15px;
  font-weight: 700;
  color: var(--purple-light);
  margin-bottom: 14px;
  display: flex;
  align-items: center;
  gap: 14px;
  letter-spacing: 0.5px;
}

.legal-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  border-radius: 10px;
  background: linear-gradient(135deg, rgba(124,58,237,0.3), rgba(236,72,153,0.2));
  border: 1px solid var(--border);
  font-size: 12px;
  font-weight: 900;
  color: var(--pink);
  font-family: 'Orbitron', monospace;
  flex-shrink: 0;
}

.legal-block p {
  color: var(--text);
  font-size: 15px;
  line-height: 1.8;
  opacity: 0.88;
}

.legal-block p + p {
  margin-top: 12px;
}

.legal-block strong {
  color: #fff;
  font-weight: 700;
}

.legal-list {
  list-style: none;
  margin: 16px 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.legal-list li {
  padding: 10px 16px;
  background: rgba(124, 58, 237, 0.07);
  border: 1px solid rgba(168, 85, 247, 0.15);
  border-radius: 8px;
  color: var(--text);
  font-size: 14px;
  line-height: 1.6;
  position: relative;
  padding-left: 36px;
}

.legal-list li::before {
  content: '▸';
  position: absolute;
  left: 14px;
  color: var(--purple-light);
  font-size: 12px;
}

.legal-link {
  color: var(--purple-light);
  cursor: pointer;
  text-decoration: underline;
  text-underline-offset: 3px;
  transition: color 0.2s;
}

.legal-link:hover {
  color: var(--pink);
}

.legal-back-wrap {
  text-align: center;
  margin-top: 48px;
}

/* Responsive legal */
@media (max-width: 768px) {
  .legal-title { font-size: 26px; }
  .legal-card { padding: 28px 20px; }
  .legal-block h2 { font-size: 13px; }
}
