@import url('https://fonts.googleapis.com/css2?family=Orbitron:wght@500;700;900&family=Rajdhani:wght@500;600;700&display=swap');

/* ═══ Geometry Dash — design system jeux.html ═══ */
/* Agrandit le wrap pour un jeu paysage (override snake.css 480px) */
.jeu-v-wrap { max-width: 720px; margin: 0 auto; }
#game-content { overflow: hidden; }

.nd-shell {
  display: flex;
  flex-direction: column;
  gap: 14px;
  font-family: 'Rajdhani', sans-serif;
}
.nd-shell .hidden { display: none !important; }

/* ── Playfield (paysage 16/9) ── */
.nd-playfield {
  position: relative;
  width: 100%;
  aspect-ratio: 16 / 9;
  border-radius: 18px;
  overflow: hidden;
  border: 3px solid #00f0ff;
  box-shadow: 0 0 28px rgba(0, 240, 255, .25), inset 0 0 20px rgba(0, 0, 0, .30);
  background: #070112;
  touch-action: none;
  overscroll-behavior: contain;
  -webkit-user-select: none;
  user-select: none;
}

#game {
  position: absolute;
  inset: 0;
  display: block;
  width: 100%;
  height: 100%;
}

/* ── Couleurs neon (CSS custom props locales) ── */
.nd-playfield {
  --nd-cyan: #00f0ff;
  --nd-magenta: #ff2bd6;
  --nd-lime: #b6ff3d;
  --nd-gold: #ffd23d;
  --nd-ink: #e8f7ff;
}

/* ── HUD ── */
.nd-playfield #hud {
  position: absolute; top: 0; left: 0; width: 100%;
  padding: 10px 14px;
  display: flex; justify-content: space-between; align-items: flex-start;
  pointer-events: none;
  font-family: 'Orbitron', sans-serif;
  z-index: 5;
  text-shadow: 0 0 12px rgba(0,240,255,.6);
}
.nd-playfield .hud-label {
  font-size: 8px; letter-spacing: 3px; opacity: .6; font-weight: 500; color: var(--nd-ink);
}
.nd-playfield .hud-val {
  font-size: 18px; font-weight: 900; line-height: 1; color: var(--nd-ink);
}
.nd-playfield #best .hud-val {
  color: var(--nd-gold);
  text-shadow: 0 0 12px rgba(255,210,61,.6);
}
.nd-playfield #attemptsMini {
  font-family: 'Orbitron', sans-serif; font-size: 7px; letter-spacing: 2px;
  color: var(--nd-magenta); opacity: .75; margin-top: 4px;
  text-shadow: 0 0 10px rgba(255,43,214,.5);
}

/* ── Multiplier + combo ── */
.nd-playfield #score { position: relative; }
.nd-playfield #multiplier { text-align: center; }
.nd-playfield .mult-badge {
  font-family: 'Orbitron', sans-serif; font-weight: 900; font-size: 20px; line-height: 1;
  color: var(--nd-cyan); text-shadow: 0 0 16px rgba(0,240,255,.7);
  transition: transform .12s cubic-bezier(.2,1.4,.4,1), color .2s, opacity .25s;
}
.nd-playfield .mult-badge.bump { transform: scale(1.5); }
.nd-playfield .mult-badge.dim { opacity: .4; color: var(--nd-ink); text-shadow: 0 0 8px rgba(232,247,255,.3); }
.nd-playfield .combo-bar {
  width: 64px; height: 4px; margin: 5px auto 0; border-radius: 3px;
  background: rgba(255,255,255,.12); overflow: hidden;
}
.nd-playfield .combo-fill {
  height: 100%; width: 0%; border-radius: 3px;
  background: linear-gradient(90deg, var(--nd-cyan), var(--nd-magenta));
  box-shadow: 0 0 8px rgba(0,240,255,.6);
  transition: width .08s linear;
}

/* ── Pause / son buttons ── */
.nd-playfield #topRight {
  position: absolute; top: 10px; right: 12px; z-index: 6; display: flex; gap: 8px;
}
.nd-playfield .icon-btn {
  pointer-events: auto; cursor: pointer; width: 34px; height: 34px; border-radius: 7px;
  border: 1px solid rgba(0,240,255,.4); background: rgba(0,240,255,.07);
  color: var(--nd-cyan); font-size: 14px; display: flex; align-items: center; justify-content: center;
  box-shadow: 0 0 10px rgba(0,240,255,.18); transition: .15s;
}
.nd-playfield .icon-btn:hover { background: rgba(0,240,255,.18); }

/* ── Zone banner ── */
.nd-playfield #zoneBanner {
  position: absolute; top: 32%; left: 0; width: 100%;
  display: flex; flex-direction: column; align-items: center; gap: 2px;
  z-index: 7; pointer-events: none; opacity: 0;
}
.nd-playfield #zoneBanner.show { animation: ndZbIn 2.3s ease forwards; }
.nd-playfield .zb-num {
  font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 10px;
  letter-spacing: 5px; color: var(--nd-ink); opacity: .85;
}
.nd-playfield .zb-name {
  font-family: 'Orbitron', sans-serif; font-weight: 900;
  font-size: clamp(20px, 5vw, 40px); letter-spacing: 4px; color: var(--nd-cyan);
  filter: drop-shadow(0 0 16px rgba(0,240,255,.6));
}
@keyframes ndZbIn {
  0%   { opacity:0; transform:translateY(14px) scale(.9); }
  12%  { opacity:1; transform:translateY(0) scale(1); }
  78%  { opacity:1; transform:none; }
  100% { opacity:0; transform:translateY(-12px) scale(1.03); }
}

/* ── Altitude toast ── */
.nd-playfield #altToast {
  position: absolute; top: 22%; left: 50%; transform: translateX(-50%);
  z-index: 7; pointer-events: none; opacity: 0;
  font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 11px;
  letter-spacing: 2px; color: var(--nd-lime); white-space: nowrap;
  text-shadow: 0 0 12px rgba(182,255,61,.7);
}
.nd-playfield #altToast.show { animation: ndAtIn 1.4s ease forwards; }
@keyframes ndAtIn {
  0%   { opacity:0; transform:translate(-50%,10px); }
  15%  { opacity:1; transform:translate(-50%,0); }
  75%  { opacity:1; }
  100% { opacity:0; transform:translate(-50%,-12px); }
}

/* ── Overlays (start / pause / gameover) ── */
.nd-playfield .overlay {
  position: absolute; inset: 0; z-index: 10;
  display: flex; flex-direction: column; align-items: center; justify-content: center;
  text-align: center; padding: 16px;
  background: radial-gradient(circle at 50% 40%, rgba(13,5,36,.55), rgba(7,1,18,.94));
  backdrop-filter: blur(3px);
  font-family: 'Rajdhani', sans-serif;
  color: var(--nd-ink);
}
.nd-playfield .overlay.hidden { display: none; }

.nd-playfield .nd-title {
  font-family: 'Orbitron', sans-serif; font-weight: 900;
  font-size: clamp(24px, 6vw, 54px); letter-spacing: 5px; line-height: .95;
  background: linear-gradient(90deg, var(--nd-cyan), var(--nd-magenta), var(--nd-gold));
  -webkit-background-clip: text; background-clip: text; color: transparent;
  filter: drop-shadow(0 0 18px rgba(255,43,214,.45));
  animation: ndHue 6s linear infinite;
}
@keyframes ndHue { to { filter: drop-shadow(0 0 18px rgba(255,43,214,.45)) hue-rotate(360deg); } }

.nd-playfield .nd-subtitle {
  margin-top: 4px; font-size: 11px; letter-spacing: 4px; opacity: .65; text-transform: uppercase;
  color: var(--nd-ink);
}

.nd-playfield .nd-panel-go {
  font-family: 'Orbitron', sans-serif; font-weight: 900;
  font-size: clamp(22px, 5vw, 44px); letter-spacing: 3px;
  color: var(--nd-magenta); filter: drop-shadow(0 0 16px rgba(255,43,214,.6));
}

.nd-playfield .nd-btn {
  margin-top: 14px; pointer-events: auto; cursor: pointer;
  font-family: 'Orbitron', sans-serif; font-weight: 700; font-size: 13px; letter-spacing: 2px;
  padding: 10px 30px; border: 2px solid var(--nd-cyan); border-radius: 4px;
  color: var(--nd-ink); background: rgba(0,240,255,.08);
  box-shadow: 0 0 18px rgba(0,240,255,.3), inset 0 0 14px rgba(0,240,255,.1);
  transition: transform .12s ease, box-shadow .2s ease;
  text-transform: uppercase;
}
.nd-playfield .nd-btn:hover {
  transform: translateY(-2px) scale(1.03);
  background: rgba(0,240,255,.18);
  box-shadow: 0 0 28px rgba(0,240,255,.55), inset 0 0 18px rgba(0,240,255,.18);
}
.nd-playfield .nd-btn:active { transform: scale(.97); }

.nd-playfield .nd-hint {
  margin-top: 10px; font-size: 10px; letter-spacing: 1.5px; opacity: .5; line-height: 1.7;
  color: var(--nd-ink);
}

.nd-playfield .nd-stats {
  margin: 10px 0 4px; display: flex; gap: clamp(12px, 4vw, 28px);
  flex-wrap: wrap; justify-content: center;
}
.nd-playfield .nd-stat .nd-s-label {
  font-size: 9px; letter-spacing: 2px; opacity: .6; font-family: 'Orbitron', sans-serif;
  color: var(--nd-ink);
}
.nd-playfield .nd-stat .nd-s-val {
  font-size: clamp(22px, 5vw, 32px); font-weight: 700; font-family: 'Orbitron', sans-serif;
}
.nd-playfield .nd-stat.cur .nd-s-val { color: var(--nd-cyan); text-shadow: 0 0 12px rgba(0,240,255,.5); }
.nd-playfield .nd-stat.orb .nd-s-val { color: var(--nd-lime); text-shadow: 0 0 12px rgba(182,255,61,.5); }
.nd-playfield .nd-stat.bst .nd-s-val { color: var(--nd-gold); text-shadow: 0 0 12px rgba(255,210,61,.5); }

.nd-playfield #nd-newBest {
  margin-top: 6px; color: var(--nd-lime); font-family: 'Orbitron', sans-serif; font-weight: 700;
  letter-spacing: 2px; font-size: 11px; text-shadow: 0 0 12px rgba(182,255,61,.6);
  animation: ndPulse 1s ease-in-out infinite; display: none;
}
@keyframes ndPulse { 50% { opacity: .4; } }

.nd-playfield #nd-multMax { margin-top: 2px; opacity: .55; font-size: 10px; color: var(--nd-ink); }

/* ── Controls hint strip ── */
.nd-controls {
  font-size: 10px; color: var(--tx3); text-align: center;
  letter-spacing: 1px; padding: 4px 0 2px;
}

/* ── Desktop ── */
@media (min-width: 641px) {
  .jeu-v-wrap { max-width: 1000px; }
}

/* ── Mobile : jeu bord à bord ── */
@media (max-width: 600px) {
  .jeu-v-wrap {
    margin-left: -16px;
    margin-right: -16px;
  }
  .nd-playfield {
    border-radius: 0;
    aspect-ratio: unset;
    height: 72svh;
  }
  .game-h1 {
    padding-left: 16px;
  }
}
