/* ══════════════════════════════════════════════
   BOOMPLAY STUDIO — CSS Principal
   ══════════════════════════════════════════════ */

@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Rajdhani:wght@400;600;700&family=Share+Tech+Mono&display=swap');

:root {
  --bg:      #080c10;
  --bg2:     #0d1520;
  --bg3:     #111d2e;
  --cyan:    #00f5ff;
  --pink:    #ff2d78;
  --yellow:  #ffe600;
  --green:   #39ff14;
  --white:   #e8f4f8;
  --gray:    #2a3a4a;
  --gray2:   #1a2738;
  --muted:   rgba(232,244,248,0.45);
  --glow-c:  0 0 20px #00f5ff88, 0 0 60px #00f5ff22;
  --glow-p:  0 0 20px #ff2d7888, 0 0 60px #ff2d7822;
  --radius:  4px;
  --font-pixel: 'Press Start 2P', monospace;
  --font-main:  'Rajdhani', sans-serif;
  --font-mono:  'Share Tech Mono', monospace;
}

*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--white);
  font-family: var(--font-main);
  font-size: 17px;
  line-height: 1.6;
  min-height: 100vh;
  overflow-x: hidden;
}

/* Scanlines overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background: repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,0.06) 2px,rgba(0,0,0,0.06) 4px);
  pointer-events: none;
  z-index: 9997;
}

a { color: var(--cyan); text-decoration: none; transition: opacity 0.2s; }
a:hover { opacity: 0.8; }
img { max-width: 100%; }

/* ─── NAVBAR ─────────────────────────────────── */
.navbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: 70px;
  background: rgba(8,12,16,0.95);
  border-bottom: 1px solid rgba(0,245,255,0.15);
  display: flex;
  align-items: center;
  padding: 0 2rem;
  gap: 2rem;
  z-index: 1000;
  backdrop-filter: blur(10px);
}

.nav-brand {
  font-family: var(--font-pixel);
  font-size: 1rem;
  color: var(--white);
  text-decoration: none;
  white-space: nowrap;
}
.nav-brand span { color: var(--cyan); }

.nav-menu {
  display: flex;
  gap: 0.3rem;
  flex: 1;
}

.nav-link {
  font-family: var(--font-mono);
  font-size: 0.8rem;
  letter-spacing: 2px;
  padding: 8px 16px;
  color: var(--muted);
  text-decoration: none;
  text-transform: uppercase;
  transition: all 0.2s;
  border: 1px solid transparent;
}
.nav-link:hover, .nav-link.active {
  color: var(--cyan);
  border-color: rgba(0,245,255,0.2);
  background: rgba(0,245,255,0.05);
}

.nav-actions { margin-left: auto; display: flex; align-items: center; gap: 1rem; }

.btn-nav-login {
  font-family: var(--font-pixel);
  font-size: 0.55rem;
  background: var(--cyan);
  color: var(--bg);
  padding: 10px 20px;
  text-decoration: none;
  clip-path: polygon(0 0, calc(100% - 8px) 0, 100% 8px, 100% 100%, 8px 100%, 0 calc(100% - 8px));
  transition: all 0.2s;
}
.btn-nav-login:hover { background: var(--white); opacity: 1; }

.nav-user { position: relative; display: flex; align-items: center; gap: 10px; cursor: pointer; }
.nav-avatar { width: 38px; height: 38px; border-radius: 2px; border: 2px solid var(--cyan); object-fit: cover; }
.nav-user-info { display: flex; flex-direction: column; }
.nav-pseudo { font-weight: 700; font-size: 0.9rem; }
.nav-role { font-family: var(--font-mono); font-size: 0.65rem; color: var(--cyan); }
.nav-dropdown {
  display: none;
  position: absolute;
  top: 110%;
  right: 0;
  background: var(--bg2);
  border: 1px solid rgba(0,245,255,0.2);
  min-width: 180px;
  flex-direction: column;
  z-index: 100;
}
.nav-user:hover .nav-dropdown { display: flex; }
.nav-dropdown a {
  padding: 12px 18px;
  color: var(--white);
  font-size: 0.9rem;
  display: block;
  border-bottom: 1px solid var(--gray2);
}
.nav-dropdown a:hover { background: rgba(0,245,255,0.08); color: var(--cyan); }
.nav-logout { color: var(--pink) !important; }

.nav-toggle { display: none; background: none; border: none; color: var(--cyan); font-size: 1.5rem; cursor: pointer; }

/* ─── LAYOUT ──────────────────────────────────── */
.page-content { padding-top: 70px; min-height: calc(100vh - 70px); }

.container { max-width: 1200px; margin: 0 auto; padding: 0 2rem; }

/* ─── BOUTONS ─────────────────────────────────── */
.btn {
  font-family: var(--font-pixel);
  font-size: 0.6rem;
  padding: 14px 28px;
  display: inline-block;
  cursor: pointer;
  text-decoration: none;
  transition: all 0.2s;
  border: none;
  letter-spacing: 1px;
}
.btn-primary {
  background: var(--cyan);
  color: var(--bg);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  box-shadow: var(--glow-c);
}
.btn-primary:hover { background: var(--white); transform: translateY(-2px); opacity: 1; }
.btn-pink {
  background: var(--pink);
  color: var(--white);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
  box-shadow: var(--glow-p);
}
.btn-outline {
  background: transparent;
  color: var(--cyan);
  border: 2px solid var(--cyan);
  clip-path: polygon(0 0, calc(100% - 10px) 0, 100% 10px, 100% 100%, 10px 100%, 0 calc(100% - 10px));
}
.btn-outline:hover { background: rgba(0,245,255,0.1); opacity: 1; }
.btn-danger { background: #ef4444; color: #fff; border-radius: var(--radius); }
.btn-warn   { background: #f59e0b; color: #000; border-radius: var(--radius); }
.btn-sm { font-size: 0.5rem; padding: 8px 16px; }

/* ─── FORMULAIRES ────────────────────────────── */
.form-group { margin-bottom: 1.4rem; }
.form-label {
  display: block;
  font-family: var(--font-mono);
  font-size: 0.75rem;
  color: var(--cyan);
  letter-spacing: 2px;
  margin-bottom: 6px;
}
.form-input, .form-textarea, .form-select {
  width: 100%;
  background: var(--bg3);
  border: 1px solid var(--gray);
  color: var(--white);
  padding: 12px 16px;
  font-family: var(--font-main);
  font-size: 1rem;
  outline: none;
  transition: border-color 0.2s;
  border-radius: var(--radius);
}
.form-input:focus, .form-textarea:focus, .form-select:focus {
  border-color: var(--cyan);
  box-shadow: 0 0 0 2px rgba(0,245,255,0.1);
}
.form-textarea { min-height: 120px; resize: vertical; }
.form-hint { font-size: 0.8rem; color: var(--muted); margin-top: 4px; }
.form-error { color: var(--pink); font-size: 0.85rem; margin-top: 4px; }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1.5rem; }

/* Checkbox */
.form-check { display: flex; align-items: center; gap: 10px; cursor: pointer; }
.form-check input { width: 18px; height: 18px; accent-color: var(--cyan); cursor: pointer; }

/* Password strength */
.pass-strength { margin-top: 8px; }
.pass-bar { height: 4px; background: var(--gray); border-radius: 2px; overflow: hidden; margin-bottom: 4px; }
.pass-fill { height: 100%; transition: width 0.3s, background 0.3s; }
.pass-hints { display: flex; flex-wrap: wrap; gap: 8px; }
.pass-hint {
  font-size: 0.72rem;
  font-family: var(--font-mono);
  padding: 3px 10px;
  border-radius: 20px;
  background: var(--gray2);
  color: var(--muted);
  transition: all 0.2s;
}
.pass-hint.ok { background: rgba(57,255,20,0.1); color: var(--green); }

/* ─── CARTES ──────────────────────────────────── */
.card {
  background: var(--bg2);
  border: 1px solid rgba(0,245,255,0.12);
  padding: 2rem;
  clip-path: polygon(0 0, calc(100% - 14px) 0, 100% 14px, 100% 100%, 14px 100%, 0 calc(100% - 14px));
  transition: all 0.3s;
  position: relative;
}
.card:hover { border-color: rgba(0,245,255,0.35); box-shadow: var(--glow-c); }
.card-title { font-family: var(--font-main); font-weight: 700; font-size: 1.3rem; margin-bottom: 0.5rem; }

/* ─── BADGES RÔLES ───────────────────────────── */
.badge-role {
  display: inline-block;
  font-family: var(--font-mono);
  font-size: 0.65rem;
  padding: 3px 10px;
  letter-spacing: 1px;
  border-radius: 2px;
  font-weight: bold;
}

/* ─── HERO (accueil) ─────────────────────────── */
.hero {
  position: relative;
  min-height: calc(100vh - 70px);
  display: flex;
  align-items: center;
  justify-content: center;
  text-align: center;
  padding: 4rem 2rem;
  overflow: hidden;
}
.hero-grid {
  position: absolute; inset: 0;
  background-image: linear-gradient(rgba(0,245,255,0.05) 1px, transparent 1px),
                    linear-gradient(90deg, rgba(0,245,255,0.05) 1px, transparent 1px);
  background-size: 60px 60px;
  animation: gridMove 20s linear infinite;
}
@keyframes gridMove { to { background-position: 60px 60px; } }

.hero-glow-l { position: absolute; left: -200px; top: 20%; width: 600px; height: 600px; background: radial-gradient(circle, rgba(255,45,120,0.15) 0%, transparent 70%); animation: pulse 6s ease-in-out infinite; pointer-events:none; }
.hero-glow-r { position: absolute; right: -200px; bottom: 10%; width: 600px; height: 600px; background: radial-gradient(circle, rgba(0,245,255,0.12) 0%, transparent 70%); animation: pulse 8s ease-in-out infinite reverse; pointer-events:none; }
@keyframes pulse { 0%,100% { transform:scale(1); opacity:1; } 50% { transform:scale(1.15); opacity:.7; } }

.hero-content { position: relative; z-index: 2; }
.hero-badge {
  display: inline-block;
  font-family: var(--font-mono); font-size: 0.7rem;
  color: var(--cyan); border: 1px solid var(--cyan);
  padding: 6px 18px; letter-spacing: 4px; margin-bottom: 2rem;
  box-shadow: var(--glow-c); animation: fadeDown 0.8s ease both;
}
.hero-title {
  font-family: var(--font-pixel);
  font-size: clamp(1.8rem, 5vw, 4rem);
  line-height: 1.5; margin-bottom: 1.5rem;
  animation: fadeDown 0.8s 0.2s ease both;
}
.hero-title .t-cyan { color: var(--cyan); text-shadow: var(--glow-c); }
.hero-sub {
  font-size: clamp(1rem, 2.5vw, 1.4rem);
  color: var(--muted); max-width: 620px;
  margin: 0 auto 3rem; line-height: 1.7;
  animation: fadeDown 0.8s 0.4s ease both;
}
.hero-sub em { color: var(--pink); font-style: normal; }
.hero-cta { display: flex; gap: 1.2rem; justify-content: center; flex-wrap: wrap; animation: fadeDown 0.8s 0.6s ease both; }
.hero-scroll { position: absolute; bottom: 2rem; left: 50%; transform: translateX(-50%); font-family: var(--font-mono); font-size: 0.65rem; color: rgba(0,245,255,0.4); letter-spacing: 3px; animation: bounce 2s ease-in-out infinite; }
@keyframes bounce { 0%,100% { transform: translateX(-50%) translateY(0); } 50% { transform: translateX(-50%) translateY(8px); } }
@keyframes fadeDown { from { opacity:0; transform:translateY(-30px); } to { opacity:1; transform:none; } }

/* ─── STATS BAR ──────────────────────────────── */
.stats-bar { 
    background: var(--bg); /* Fond noir profond comme l'image */
    border-top: 1px solid rgba(0,245,255,0.05); 
    border-bottom: 1px solid rgba(0,245,255,0.05); 
    padding: 3rem 1rem; 
    display: flex; 
    justify-content: center; 
    gap: 5rem; 
    flex-wrap: wrap; 
}

.stat { 
    text-align: center; 
    min-width: 150px;
}

.stat-num {
    font-family: var(--font-pixel);
    font-size: 2rem;
    color: var(--cyan);
    text-shadow: 0 0 8px rgba(0,245,255,0.7), 0 0 18px rgba(0,245,255,0.3);
    display: flex;
    align-items: center;
    justify-content: center;
    height: 64px;
    margin-bottom: 15px;
    line-height: 1;
}

/* Tous les symboles/icônes de la stats bar à la même taille */
.stat-num .symbol-big,
.stat-num .icon-big {
    font-size: 3.8rem;
    line-height: 1;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    height: 64px;
}

.stat-num .icon-big {
    font-size: 2.6rem;
    filter: drop-shadow(0 0 6px rgba(0,245,255,0.6));
}

.stat-label { 
    font-family: var(--font-mono); 
    font-size: 0.75rem; 
    color: #8a99a8; 
    letter-spacing: 3px; 
    text-transform: uppercase;
    display: block; 
}
/* ─── SECTIONS ───────────────────────────────── */
.section { padding: 5rem 2rem; }
.section-dark { background: var(--bg2); }
.section-tag { font-family: var(--font-mono); font-size: 0.7rem; color: var(--pink); letter-spacing: 4px; text-transform: uppercase; display: block; margin-bottom: 1rem; }
.section-title { font-family: var(--font-pixel); font-size: clamp(1.1rem, 2.5vw, 1.8rem); line-height: 1.5; margin-bottom: 1.5rem; }
.section-desc { font-size: 1.1rem; color: var(--muted); max-width: 600px; line-height: 1.7; }
.section-center { text-align: center; }
.section-center .section-desc { margin: 0 auto; }

/* ─── HOW IT WORKS ───────────────────────────── */
.how-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 5rem; align-items: center; }
.step { display: flex; gap: 1.5rem; margin-bottom: 2.5rem; position: relative; }
.step:not(:last-child)::after { content:''; position:absolute; left:27px; top:56px; width:2px; height:calc(100% - 10px); background:linear-gradient(var(--cyan),var(--pink)); }
.step-num { font-family:var(--font-pixel); font-size:0.8rem; width:56px; height:56px; min-width:56px; background:var(--bg); border:2px solid var(--cyan); display:flex; align-items:center; justify-content:center; color:var(--cyan); text-shadow:var(--glow-c); clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px)); position:relative; z-index:1; }
.step-title { font-weight:700; font-size:1.1rem; margin-bottom:4px; letter-spacing:1px; }
.step-text { font-size:0.95rem; color:var(--muted); }

/* ─── TERMINAL ───────────────────────────────── */
.terminal { background:#050810; border:1px solid rgba(0,245,255,0.3); border-radius:4px; width:100%; max-width:460px; box-shadow:var(--glow-c); overflow:hidden; }
.terminal-bar { background:rgba(0,245,255,0.08); padding:10px 16px; display:flex; align-items:center; gap:8px; border-bottom:1px solid rgba(0,245,255,0.15); }
.t-dot { width:10px; height:10px; border-radius:50%; }
.t-dot-r { background:var(--pink); }
.t-dot-y { background:var(--yellow); }
.t-dot-g { background:var(--green); }
.terminal-title { font-family:var(--font-mono); font-size:0.7rem; color:rgba(0,245,255,0.5); margin-left:8px; letter-spacing:2px; }
.terminal-body { padding:1.5rem; font-family:var(--font-mono); font-size:0.78rem; line-height:1.9; }
.t-line { color:rgba(0,245,255,0.35); }
.t-cmd { color:var(--cyan); }
.t-out { color:var(--muted); }
.t-pink { color:var(--pink); }
.t-green { color:var(--green); }
.t-yellow { color:var(--yellow); }
.cursor { display:inline-block; width:8px; height:14px; background:var(--cyan); animation:blink 1s step-end infinite; vertical-align:middle; }
@keyframes blink { 0%,100%{opacity:1} 50%{opacity:0} }

/* ─── JEUX ───────────────────────────────────── */
.games-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(280px,1fr)); gap:1.5rem; }
.game-card { background:var(--bg2); border:1px solid rgba(0,245,255,0.12); overflow:hidden; transition:all 0.3s; }
.game-card:hover { border-color:rgba(0,245,255,0.35); transform:translateY(-4px); box-shadow:var(--glow-c); }
.game-cover { width:100%; height:180px; object-fit:cover; display:block; background:var(--bg3); }
.game-cover-placeholder { width:100%; height:180px; background:linear-gradient(135deg,var(--bg3),var(--gray2)); display:flex; align-items:center; justify-content:center; font-size:3rem; }
.game-body { padding:1.5rem; }
.game-tags { display:flex; flex-wrap:wrap; gap:6px; margin-bottom:10px; }
.game-tag { font-family:var(--font-mono); font-size:0.62rem; padding:3px 10px; border:1px solid var(--gray); color:var(--muted); border-radius:20px; }
.game-title { font-weight:700; font-size:1.2rem; margin-bottom:6px; }
.game-desc { font-size:0.9rem; color:var(--muted); margin-bottom:1.2rem; line-height:1.5; display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden; }
.game-price { font-family:var(--font-pixel); font-size:0.9rem; color:var(--yellow); margin-bottom:1rem; }
.game-free { color:var(--green); }

/* ─── FORUM ──────────────────────────────────── */
.forum-layout { display:grid; grid-template-columns:1fr 280px; gap:2rem; padding:2rem; max-width:1200px; margin:0 auto; }
.forum-cat { margin-bottom:2rem; }
.forum-cat-header { background:var(--bg2); border:1px solid rgba(0,245,255,0.15); border-bottom:2px solid var(--cyan); padding:1rem 1.5rem; display:flex; align-items:center; gap:1rem; }
.forum-cat-icon { font-size:1.5rem; }
.forum-cat-name { font-family:var(--font-pixel); font-size:0.8rem; color:var(--cyan); }
.forum-cat-desc { font-size:0.85rem; color:var(--muted); }
.forum-subcat { background:var(--bg2); border:1px solid rgba(0,245,255,0.08); border-top:none; }
.forum-subcat-row { display:flex; align-items:center; padding:1rem 1.5rem; border-bottom:1px solid rgba(0,245,255,0.06); transition:background 0.2s; }
.forum-subcat-row:hover { background:rgba(0,245,255,0.04); }
.forum-subcat-row a { color:var(--white); font-weight:600; font-size:1rem; }
.forum-subcat-row a:hover { color:var(--cyan); }
.forum-subcat-meta { margin-left:auto; font-family:var(--font-mono); font-size:0.7rem; color:var(--muted); text-align:right; }
.forum-topic-row { display:flex; align-items:flex-start; gap:1rem; padding:1rem 1.5rem; border-bottom:1px solid rgba(0,245,255,0.06); }
.forum-topic-avatar { width:40px; height:40px; border-radius:2px; object-fit:cover; border:1px solid var(--gray); cursor:pointer; }
.forum-topic-title { font-weight:600; font-size:1rem; color:var(--white); }
.forum-topic-title:hover { color:var(--cyan); }
.forum-pinned-badge { background:var(--pink); color:#fff; font-size:0.6rem; padding:2px 8px; font-family:var(--font-mono); border-radius:2px; margin-right:6px; }
.forum-sidebar { }
.forum-sidebar-card { background:var(--bg2); border:1px solid rgba(0,245,255,0.12); padding:1.5rem; margin-bottom:1.5rem; }
.forum-sidebar-title { font-family:var(--font-pixel); font-size:0.65rem; color:var(--cyan); margin-bottom:1rem; }

/* ─── ARTICLES ───────────────────────────────── */
.articles-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(320px,1fr)); gap:2rem; }
.article-card { background:var(--bg2); border:1px solid rgba(0,245,255,0.12); overflow:hidden; transition:all 0.3s; }
.article-card:hover { border-color:rgba(0,245,255,0.35); transform:translateY(-4px); box-shadow:var(--glow-c); }
.article-cover { width:100%; height:200px; object-fit:cover; }
.article-cover-placeholder { width:100%; height:200px; background:linear-gradient(135deg,var(--bg3),var(--gray2)); display:flex; align-items:center; justify-content:center; font-size:3rem; }
.article-body { padding:1.5rem; }
.article-meta { font-family:var(--font-mono); font-size:0.7rem; color:var(--muted); margin-bottom:8px; }
.article-title { font-weight:700; font-size:1.2rem; margin-bottom:8px; color:var(--white); }
.article-title:hover { color:var(--cyan); }
.article-excerpt { font-size:0.9rem; color:var(--muted); line-height:1.5; }

/* ─── PROFIL POPUP ───────────────────────────── */
.profile-popup {
  display:none; position:fixed; inset:0; background:rgba(0,0,0,0.7);
  z-index:9000; align-items:center; justify-content:center;
}
.profile-popup.open { display:flex; }
.profile-popup-inner {
  background:var(--bg2); border:1px solid rgba(0,245,255,0.3);
  padding:2rem; max-width:400px; width:90%; position:relative;
  clip-path:polygon(0 0,calc(100% - 16px) 0,100% 16px,100% 100%,16px 100%,0 calc(100% - 16px));
}
.profile-popup-close { position:absolute; top:1rem; right:1rem; background:none; border:none; color:var(--muted); font-size:1.3rem; cursor:pointer; }
.profile-popup-avatar { width:80px; height:80px; border-radius:2px; border:2px solid var(--cyan); object-fit:cover; }
.profile-popup-pseudo { font-family:var(--font-pixel); font-size:0.9rem; margin:1rem 0 0.3rem; }
.profile-popup-bio { font-size:0.9rem; color:var(--muted); line-height:1.5; }

/* ─── LIKE BOUTON POPUP PROFIL ───────────────── */
.profile-popup-likes { margin:0.75rem 0; }
.profile-popup-like-btn {
  display:inline-flex; align-items:center; gap:0.45rem;
  background:none; border:1px solid rgba(255,45,120,0.35);
  color:rgba(255,45,120,0.7); font-family:var(--font-mono);
  font-size:0.78rem; padding:6px 16px; cursor:pointer;
  transition:all 0.2s; border-radius:2px; letter-spacing:0.5px;
}
.profile-popup-like-btn:hover {
  border-color:var(--pink); color:var(--pink);
  background:rgba(255,45,120,0.1); transform:scale(1.04);
}
.profile-popup-like-btn.liked {
  border-color:var(--pink); color:var(--pink);
  background:rgba(255,45,120,0.12);
}
.profile-popup-like-btn .like-heart {
  font-size:1rem; line-height:1; transition:transform 0.2s;
}
.profile-popup-like-btn:hover .like-heart,
.profile-popup-like-btn.liked .like-heart { transform:scale(1.2); }
.profile-popup-like-btn .like-count {
  background:rgba(255,45,120,0.15); border-radius:20px;
  padding:1px 7px; font-size:0.7rem;
}
.profile-popup-likes-display {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family:var(--font-mono); font-size:0.78rem;
}
.like-heart-static { color:var(--pink); font-size:0.9rem; }
.like-count-static { color:var(--white); font-size:0.8rem; }
.like-login-hint {
  color:var(--cyan); font-size:0.7rem; text-decoration:none;
  border-bottom:1px dashed rgba(0,245,255,0.4);
}
.like-login-hint:hover { color:var(--white); }

/* ─── COMPTE ─────────────────────────────────── */
.account-layout { display:grid; grid-template-columns:250px 1fr; gap:2rem; padding:2rem; max-width:1200px; margin:0 auto; }
.account-sidebar { background:var(--bg2); border:1px solid rgba(0,245,255,0.12); padding:1.5rem; height:fit-content; }
.account-avatar-wrap { text-align:center; margin-bottom:1.5rem; }
.account-avatar { width:100px; height:100px; border-radius:2px; border:2px solid var(--cyan); object-fit:cover; }
.account-pseudo { font-family:var(--font-pixel); font-size:0.8rem; margin-bottom:4px; text-align:center; }
.account-nav a { display:block; padding:10px 14px; color:var(--muted); border-left:2px solid transparent; font-weight:600; transition:all 0.2s; }
.account-nav a:hover, .account-nav a.active { color:var(--cyan); border-left-color:var(--cyan); background:rgba(0,245,255,0.05); }

/* ─── ADMIN PANEL ────────────────────────────── */
.admin-layout { display:grid; grid-template-columns:240px 1fr; min-height:calc(100vh - 70px); }
.admin-sidebar { background:var(--bg2); border-right:1px solid rgba(0,245,255,0.1); padding:2rem 0; position:sticky; top:70px; height:calc(100vh - 70px); overflow-y:auto; }
.admin-sidebar-title { font-family:var(--font-pixel); font-size:0.6rem; color:var(--muted); padding:0 1.5rem 1rem; letter-spacing:2px; }
.admin-nav a { display:flex; align-items:center; gap:10px; padding:12px 1.5rem; color:var(--muted); font-weight:600; transition:all 0.2s; border-left:3px solid transparent; font-size:0.9rem; }
.admin-nav a:hover, .admin-nav a.active { color:var(--cyan); border-left-color:var(--cyan); background:rgba(0,245,255,0.05); }
.admin-nav a .icon { width:20px; text-align:center; }
.admin-content { padding:2rem; overflow-x:auto; }
.admin-title { font-family:var(--font-pixel); font-size:0.9rem; color:var(--cyan); margin-bottom:2rem; }
.admin-section { margin-bottom:3rem; }
.admin-section-title { font-family:var(--font-mono); font-size:0.8rem; letter-spacing:3px; color:var(--pink); border-bottom:1px solid rgba(255,45,120,0.2); padding-bottom:8px; margin-bottom:1.5rem; }

/* Stats grid */
.stats-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(200px,1fr)); gap:1rem; margin-bottom:2rem; }
.stat-card { background:var(--bg2); border:1px solid rgba(0,245,255,0.12); padding:1.5rem; }
.stat-card-num { font-family:var(--font-pixel); font-size:1.5rem; color:var(--cyan); display:block; margin-bottom:6px; }
.stat-card-label { font-family:var(--font-mono); font-size:0.7rem; color:var(--muted); letter-spacing:2px; }

/* Table */
.data-table { width:100%; border-collapse:collapse; }
.data-table th { background:var(--bg3); padding:12px 16px; text-align:left; font-family:var(--font-mono); font-size:0.7rem; letter-spacing:2px; color:var(--cyan); border-bottom:2px solid rgba(0,245,255,0.2); }
.data-table td { padding:12px 16px; border-bottom:1px solid rgba(0,245,255,0.06); font-size:0.9rem; vertical-align:middle; }
.data-table tr:hover td { background:rgba(0,245,255,0.03); }
.flag-row td { background:rgba(255,45,120,0.05) !important; }
.flag-icon { color:var(--pink); font-size:1.1rem; }

/* ─── ÉDITEUR ARTICLES ───────────────────────── */
.editor-layout { max-width:1200px; margin:0 auto; padding:2rem; display:grid; grid-template-columns:1fr 300px; gap:2rem; }
.editor-main { }
.editor-sidebar { }
.editor-toolbar { display:flex; flex-wrap:wrap; gap:6px; background:var(--bg3); border:1px solid var(--gray); border-bottom:none; padding:8px; }
.editor-btn { background:none; border:1px solid var(--gray); color:var(--white); padding:4px 10px; font-family:var(--font-mono); font-size:0.7rem; cursor:pointer; transition:all 0.2s; }
.editor-btn:hover { border-color:var(--cyan); color:var(--cyan); }
.editor-area { width:100%; min-height:400px; background:var(--bg3); border:1px solid var(--gray); color:var(--white); padding:1rem; font-family:var(--font-main); font-size:1rem; line-height:1.7; resize:vertical; outline:none; }
.editor-area:focus { border-color:var(--cyan); }

/* ─── PAIEMENT ───────────────────────────────── */
.payment-box { max-width:500px; margin:3rem auto; background:var(--bg2); border:1px solid rgba(0,245,255,0.2); padding:2.5rem; }
.payment-title { font-family:var(--font-pixel); font-size:0.9rem; margin-bottom:2rem; color:var(--cyan); }
#payment-form .form-input { background:#0d1a2a; }
#card-element { background:#0d1a2a; border:1px solid var(--gray); padding:14px 16px; border-radius:var(--radius); margin-bottom:1rem; }
#card-errors { color:var(--pink); font-size:0.85rem; margin-bottom:1rem; }

/* ─── COOKIE BANNER ──────────────────────────── */
.cookie-banner {
  position:fixed; bottom:0; left:0; right:0; z-index:9998;
  background:var(--bg2); border-top:2px solid var(--cyan);
  padding:1.5rem 2rem;
  box-shadow:0 -10px 40px rgba(0,245,255,0.1);
}
.cookie-inner { max-width:1200px; margin:0 auto; display:flex; align-items:center; gap:2rem; flex-wrap:wrap; }
.cookie-text { flex:1; font-size:0.9rem; color:var(--muted); }
.cookie-text a { color:var(--cyan); }
.cookie-actions { display:flex; gap:1rem; }
.btn-cookie-accept { font-family:var(--font-pixel); font-size:0.55rem; background:var(--cyan); color:var(--bg); padding:12px 24px; border:none; cursor:pointer; clip-path:polygon(0 0,calc(100% - 8px) 0,100% 8px,100% 100%,8px 100%,0 calc(100% - 8px)); }
.btn-cookie-manage { font-family:var(--font-pixel); font-size:0.55rem; background:transparent; color:var(--cyan); padding:10px 22px; border:2px solid var(--cyan); cursor:pointer; }
#cookie-manager { background:var(--bg2); border-top:1px solid var(--gray); padding:1.5rem 2rem; }
.cookie-manager-inner { max-width:700px; margin:0 auto; }
.cookie-manager-inner h3 { font-family:var(--font-pixel); font-size:0.8rem; color:var(--cyan); margin-bottom:1.5rem; }
.cookie-option { display:flex; align-items:center; justify-content:space-between; padding:12px 0; border-bottom:1px solid var(--gray2); gap:1rem; }
.cookie-option p { font-size:0.85rem; color:var(--muted); margin-top:2px; }
.toggle-disabled { font-family:var(--font-mono); font-size:0.7rem; color:var(--muted); white-space:nowrap; }
.toggle-switch { position:relative; width:46px; height:24px; }
.toggle-switch input { opacity:0; width:0; height:0; }
.toggle-switch span { position:absolute; inset:0; background:var(--gray); border-radius:12px; cursor:pointer; transition:0.3s; }
.toggle-switch input:checked + span { background:var(--cyan); }
.toggle-switch span::before { content:''; position:absolute; width:18px; height:18px; left:3px; top:3px; background:#fff; border-radius:50%; transition:0.3s; }
.toggle-switch input:checked + span::before { transform:translateX(22px); }

/* ─── ALERTS ─────────────────────────────────── */
.alert { padding:1rem 1.5rem; border-radius:var(--radius); margin-bottom:1.5rem; font-size:0.95rem; border-left:4px solid; }
.alert-error { background:rgba(239,68,68,0.1); border-color:#ef4444; color:#fca5a5; }
.alert-success { background:rgba(57,255,20,0.1); border-color:var(--green); color:var(--green); }
.alert-info { background:rgba(0,245,255,0.08); border-color:var(--cyan); color:var(--cyan); }

/* ─── POLITIQUE ──────────────────────────────── */
.policy-content { max-width:800px; margin:0 auto; padding:3rem 2rem; }
.policy-content h2 { font-family:var(--font-pixel); font-size:0.8rem; color:var(--cyan); margin:2.5rem 0 1rem; }
.policy-content p, .policy-content li { color:var(--muted); line-height:1.8; margin-bottom:1rem; }
.policy-content strong { color:var(--white); }

/* ─── RESPONSIVE ─────────────────────────────── */
@media (max-width:900px) {
  .how-grid { grid-template-columns:1fr; gap:3rem; }
  .forum-layout { grid-template-columns:1fr; }
  .admin-layout { grid-template-columns:1fr; }
  .admin-sidebar { position:relative; height:auto; }
  .account-layout { grid-template-columns:1fr; }
  .editor-layout { grid-template-columns:1fr; }
  .form-row { grid-template-columns:1fr; }
}
@media (max-width:640px) {
  .nav-menu { display:none; flex-direction:column; position:absolute; top:70px; left:0; right:0; background:var(--bg2); border-bottom:1px solid rgba(0,245,255,0.1); padding:1rem; }
  .nav-menu.open { display:flex; }
  .nav-toggle { display:block; }
  .hero-title { font-size:1.5rem; }
  .stats-bar { gap:1.5rem; }
  .container { padding:0 1rem; }
  .cookie-inner { flex-direction:column; align-items:flex-start; }
}

/* ─── REVEAL ─────────────────────────────────── */
.reveal { opacity:0; transform:translateY(30px); transition:opacity 0.6s ease, transform 0.6s ease; }
.reveal.visible { opacity:1; transform:none; }

.nav-brand {
    display: flex;
    align-items: center;
    gap: 0; /* Force l'espace entre les éléments à zéro */
    text-decoration: none;
}

.nav-logo {
    height: 35px; /* Garde ta taille actuelle */
    width: auto;
    margin-right: 8px; /* Ici, tu gères l'espace UNIQUEMENT entre le logo et BOOM */
}

.nav-brand span {
    margin-left: 0; /* Assure-toi que le mot PLAY n'a pas de marge à gauche */
    padding-left: 0;
}

/* Optionnel : Ajustement pour mobile si nécessaire */
@media (max-width: 768px) {
    .nav-logo {
        height: 28px;
    }
}