/* =========================
   Jeux d'Ailleurs — Space/Alien theme (v2)
   ========================= */

:root{
  --bg0:#040615;
  --bg1:#060B1A;
  --panel:#0B1330cc;
  --panel2:#0A0F25cc;
  --stroke:#1E2A55;
  --text:#EAF2FF;
  --muted:#A8B5D6;

  --alien:#39FF88;
  --violet:#B56CFF;
  --cyan:#3EEBFF;
  --hot:#FF3EE7;

  --shadow: 0 18px 60px rgba(0,0,0,.45);
  --radius: 18px;

  --font: ui-sans-serif, system-ui, -apple-system, "SF Pro Display", "Segoe UI", Roboto, Helvetica, Arial;
  --font-future: ui-rounded, system-ui, -apple-system, "SF Pro Display", "Segoe UI", Roboto, Helvetica, Arial;
}

html, body {
  height: 100%;
  margin: 0;
  background: radial-gradient(1200px 900px at 20% 10%, #101d47 0%, var(--bg0) 55%, #02030a 100%);
  color: var(--text);
  font-family: var(--font);
  overscroll-behavior: none;
}

* { box-sizing: border-box; }
button, input { font-family: inherit; }
.hidden { display: none !important; }

body::before{
  content:"";
  position: fixed;
  inset: 0;
  background:
    radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.9) 0 60%, transparent 61%),
    radial-gradient(1px 1px at 80% 55%, rgba(255,255,255,.8) 0 60%, transparent 61%),
    radial-gradient(1.5px 1.5px at 55% 12%, rgba(255,255,255,.8) 0 60%, transparent 61%),
    radial-gradient(1px 1px at 40% 70%, rgba(255,255,255,.7) 0 60%, transparent 61%),
    radial-gradient(2px 2px at 70% 85%, rgba(255,255,255,.8) 0 60%, transparent 61%);
  opacity: .35;
  pointer-events: none;
  animation: drift 14s linear infinite;
}

@keyframes drift{
  0% { transform: translate3d(0,0,0); }
  50% { transform: translate3d(-8px, 6px, 0); }
  100% { transform: translate3d(0,0,0); }
}

.app{
  min-height: 100%;
  display: grid;
  grid-template-rows: auto 1fr auto;
  padding: env(safe-area-inset-top) 14px env(safe-area-inset-bottom);
}

/* Topbar */
.topbar{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 10px 8px;
  gap: 10px;
}

.brand{
  display:flex;
  align-items:center;
  gap: 10px;
}

.brand-logo{
  width: 40px;
  height: 40px;
  border-radius: 14px;
  box-shadow: 0 0 22px rgba(57,255,136,.22), 0 0 18px rgba(181,108,255,.18);
  border: 1px solid rgba(62,235,255,.22);
  background: rgba(6,11,26,.35);
}

.brand-title{
  font-family: var(--font-future);
  font-weight: 800;
  letter-spacing: .04em;
  font-size: 16px;
  text-transform: uppercase;
}
.brand-sub{
  font-size: 12px;
  color: var(--muted);
  margin-top: 2px;
}
.topbar-actions{ display:flex; gap: 8px; }

/* Buttons */
.btn{
  border: 1px solid rgba(62,235,255,.18);
  background: linear-gradient(180deg, rgba(30,42,85,.45), rgba(10,15,37,.25));
  color: var(--text);
  padding: 10px 12px;
  border-radius: 14px;
  box-shadow: 0 10px 30px rgba(0,0,0,.25);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  font-weight: 800;
  letter-spacing: .02em;
  touch-action: manipulation;
}
.btn:active{ transform: translateY(1px) scale(.99); filter: brightness(1.1); }

.btn-primary{
  border-color: rgba(57,255,136,.35);
  background: linear-gradient(180deg, rgba(57,255,136,.28), rgba(181,108,255,.18));
  box-shadow: 0 0 30px rgba(57,255,136,.18), 0 0 26px rgba(181,108,255,.16), var(--shadow);
}

.btn-ghost{ background: transparent; border-color: rgba(168,181,214,.18); box-shadow: none; }

.main{ padding: 8px; }

.screen{ display:none; animation: screenIn .35s ease both; }
.screen-active{ display:block; }
@keyframes screenIn{ from{ opacity:0; transform: translateY(10px);} to{ opacity:1; transform: translateY(0);} }

/* Hero */
.hero{
  padding: 16px 12px;
  border-radius: var(--radius);
  background: linear-gradient(180deg, rgba(11,19,48,.65), rgba(6,11,26,.25));
  border: 1px solid rgba(62,235,255,.16);
  box-shadow: var(--shadow);
  position: relative;
  overflow: hidden;
}
.hero::after{
  content:"";
  position:absolute;
  inset:-60%;
  background: radial-gradient(closest-side, rgba(57,255,136,.25), transparent 60%);
  transform: translate3d(40%, 10%, 0);
  filter: blur(8px);
  animation: pulse 3.2s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulse{
  0%,100%{ opacity:.35; transform: translate3d(40%,10%,0) scale(1); }
  50%{ opacity:.55; transform: translate3d(35%,5%,0) scale(1.08); }
}

.hero-title{
  font-family: var(--font-future);
  font-weight: 950;
  font-size: 20px;
  letter-spacing: .04em;
  text-transform: uppercase;
}
.glow{ text-shadow: 0 0 10px rgba(57,255,136,.22), 0 0 18px rgba(181,108,255,.18); }
.hero-text{ margin: 10px 0 0; color: var(--muted); line-height: 1.35; }

/* Game grid */
.game-grid{
  margin-top: 14px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}

.game-card{
  position: relative;
  border-radius: 18px;
  padding: 14px 12px 12px;
  border: 1px solid rgba(62,235,255,.16);
  background: linear-gradient(180deg, rgba(11,19,48,.62), rgba(6,11,26,.18));
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
  overflow:hidden;
  text-align:left;
  touch-action: manipulation;
}

.game-card::before{
  content:"";
  position:absolute;
  inset:-60%;
  background: conic-gradient(from 90deg, rgba(57,255,136,.18), transparent, rgba(181,108,255,.14), transparent, rgba(62,235,255,.16));
  animation: spin 10s linear infinite;
  opacity:.85;
}

@keyframes spin{ to{ transform: rotate(1turn);} }

.game-card > * { position: relative; }
.game-ic{ font-size: 22px; filter: drop-shadow(0 0 10px rgba(62,235,255,.12)); }
.game-title{ margin-top: 8px; font-weight: 950; text-transform: uppercase; letter-spacing:.04em; font-family: var(--font-future); font-size: 13px; }
.game-sub{ margin-top: 6px; color: var(--muted); font-size: 12px; line-height: 1.25; }

/* Tips */
.tips{ margin-top: 14px; display:flex; flex-direction: column; gap: 8px; }
.tip{
  border-radius: 16px;
  padding: 10px 12px;
  border: 1px solid rgba(168,181,214,.14);
  background: linear-gradient(180deg, rgba(10,15,37,.35), rgba(10,15,37,.12));
  color: rgba(234,242,255,.92);
  display:flex; align-items:center; gap: 10px;
}
.tip-ic{ filter: drop-shadow(0 0 8px rgba(62,235,255,.16)); }

/* Install gate */
.install-gate{
  position: fixed;
  inset: 0;
  z-index: 9000;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 16px;
  background: radial-gradient(1000px 700px at 50% 25%, rgba(16,29,71,.30), rgba(0,0,0,.86));
}
.install-card{
  width: min(560px, 100%);
  border-radius: 26px;
  border: 1px solid rgba(62,235,255,.24);
  background: linear-gradient(180deg, rgba(11,19,48,.75), rgba(6,11,26,.42));
  box-shadow: 0 0 50px rgba(57,255,136,.12), 0 0 46px rgba(181,108,255,.12), var(--shadow);
  padding: 18px 16px;
  position: relative;
  overflow:hidden;
}
.install-card::before{
  content:"";
  position:absolute;
  inset:-60%;
  background: radial-gradient(closest-side, rgba(255,62,231,.10), transparent 65%);
  transform: translate3d(15%, 10%, 0);
  filter: blur(10px);
  animation: pulse 3.6s ease-in-out infinite;
  pointer-events:none;
  opacity:.9;
}
.install-card > * { position: relative; }
.install-title{
  font-family: var(--font-future);
  font-weight: 950;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size: 16px;
}
.install-text{
  margin-top: 8px;
  color: var(--muted);
  line-height: 1.35;
}
.install-steps{ margin-top: 12px; display:flex; flex-direction:column; gap: 10px; }
.step{ display:flex; gap: 10px; align-items:flex-start; }
.step-dot{
  width: 26px; height: 26px; border-radius: 999px;
  display:flex; align-items:center; justify-content:center;
  border: 1px solid rgba(57,255,136,.28);
  background: rgba(57,255,136,.10);
  font-weight: 950;
}
.step-txt{ color: rgba(234,242,255,.92); font-size: 13px; line-height:1.25; }
.kbd{
  display:inline-flex;
  padding: 2px 8px;
  border-radius: 999px;
  border: 1px solid rgba(168,181,214,.16);
  background: rgba(10,15,37,.24);
  font-size: 12px;
  margin: 0 2px;
}
.install-actions{ margin-top: 14px; display:flex; gap: 10px; flex-wrap: wrap; }
.install-note{ margin-top: 10px; font-size: 12px; color: var(--muted); }

/* HUD + Playfield */
.hud{
  display:grid;
  grid-template-columns: 1fr 1.4fr 1fr;
  align-items:center;
  gap: 8px;
  padding: 8px 4px 12px;
}
.hud-center{ text-align:center; }
.hud-title{
  font-family: var(--font-future);
  font-weight: 950;
  letter-spacing:.04em;
  text-transform: uppercase;
  font-size: 14px;
}
.hud-sub{
  margin-top: 4px;
  font-size: 12px;
  color: var(--muted);
  display:flex;
  justify-content:center;
  gap: 6px;
  align-items:center;
}
.dot{ opacity:.55; }

.playfield{
  position: relative;
  height: calc(100vh - 210px);
  min-height: 380px;
  border-radius: 22px;
  border: 1px solid rgba(62,235,255,.18);
  background:
    radial-gradient(900px 650px at 40% 25%, rgba(181,108,255,.16), transparent 60%),
    radial-gradient(800px 600px at 70% 75%, rgba(57,255,136,.14), transparent 55%),
    linear-gradient(180deg, rgba(11,19,48,.55), rgba(6,11,26,.22));
  box-shadow: var(--shadow);
  overflow: hidden;
  display:flex;
  align-items: center;
  justify-content: center;
  padding: 12px;
}

.scorebar{
  margin-top: 12px;
  display:flex;
  gap: 8px;
  flex-wrap: wrap;
  justify-content: center;
}
.score-pill{
  border-radius: 999px;
  padding: 8px 10px;
  border: 1px solid rgba(168,181,214,.16);
  background: rgba(10,15,37,.20);
  font-size: 12px;
  color: rgba(234,242,255,.92);
  display:flex;
  align-items:center;
  gap: 8px;
}
.score-pill .bar{
  width: 84px; height: 8px; border-radius: 999px;
  background: rgba(168,181,214,.14);
  overflow:hidden;
}
.score-pill .bar > div{
  height:100%; width:0%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(57,255,136,.95), rgba(62,235,255,.85));
}

/* Shared panels */
.panel{
  width: min(680px, 100%);
  border-radius: 22px;
  border: 1px solid rgba(62,235,255,.18);
  background: rgba(4,6,21,.28);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  padding: 12px;
}

/* Starwar zones (multitouch) */
.zones{
  width: 100%;
  height: 100%;
  display:grid;
}
.zone{
  position: relative;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
  touch-action: none;
  user-select: none;
  -webkit-user-select: none;
  -webkit-touch-callout: none;
}
.zone-inner{
  position: relative;
  width: min(86%, 280px);
  padding: 14px 12px;
  border-radius: 20px;
  border: 1px solid rgba(168,181,214,.16);
  background: rgba(4,6,21,.32);
  text-align:center;
}
.zone-player{
  font-family: var(--font-future);
  font-weight: 950;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size: 12px;
  opacity:.95;
}
.zone-btn{
  margin-top: 10px;
  width: 100%;
  padding: 18px 12px;
  border-radius: 18px;
  border: 1px solid rgba(62,235,255,.2);
  background: linear-gradient(180deg, rgba(30,42,85,.45), rgba(10,15,37,.18));
  color: var(--text);
  font-weight: 950;
  letter-spacing:.04em;
  text-transform: uppercase;
  box-shadow: 0 0 24px rgba(62,235,255,.08);
}
.zone-btn:active{ filter: brightness(1.14); transform: translateY(1px) scale(.99); }
.meter{ margin-top: 12px; height: 10px; border-radius: 999px; background: rgba(168,181,214,.14); overflow:hidden; border: 1px solid rgba(168,181,214,.14); }
.meter > div{
  height:100%; width:0%;
  border-radius: 999px;
  background: linear-gradient(90deg, rgba(57,255,136,.95), rgba(181,108,255,.85), rgba(62,235,255,.85));
  box-shadow: 0 0 18px rgba(57,255,136,.22);
}

/* Snake canvas */
.canvas-wrap{
  width: min(720px, 100%);
  aspect-ratio: 1 / 1;
  max-height: 100%;
  border-radius: 22px;
  overflow:hidden;
  border: 1px solid rgba(62,235,255,.18);
  background: rgba(0,0,0,.18);
  box-shadow: 0 0 40px rgba(57,255,136,.09);
}
canvas{ display:block; width:100%; height:100%; touch-action:none; }

/* TicTacToe */
.ttt-grid{
  width: min(520px, 100%);
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.ttt-cell{
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  border: 1px solid rgba(62,235,255,.18);
  background: rgba(10,15,37,.22);
  font-size: 34px;
  font-weight: 950;
  color: var(--text);
  text-shadow: 0 0 14px rgba(62,235,255,.10);
  touch-action: manipulation;
}
.ttt-cell:active{ transform: translateY(1px) scale(.99); filter: brightness(1.1); }

/* Memory */
.mem-grid{
  width: min(680px, 100%);
  display:grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}
.mem-card{
  aspect-ratio: 1 / 1;
  border-radius: 18px;
  border: 1px solid rgba(62,235,255,.18);
  background: rgba(10,15,37,.22);
  position: relative;
  overflow:hidden;
  touch-action: manipulation;
}
.mem-card .face{
  position:absolute; inset:0;
  display:flex; align-items:center; justify-content:center;
  font-size: 30px;
  font-weight: 950;
  transform: rotateY(0deg);
  backface-visibility: hidden;
  transition: transform .25s ease;
}
.mem-card .back{
  transform: rotateY(0deg);
  background: radial-gradient(300px 220px at 30% 30%, rgba(57,255,136,.14), transparent 60%),
              radial-gradient(280px 220px at 70% 70%, rgba(181,108,255,.12), transparent 55%),
              rgba(4,6,21,.30);
}
.mem-card .front{
  transform: rotateY(180deg);
  background: rgba(4,6,21,.18);
}
.mem-card.revealed .back{ transform: rotateY(180deg); }
.mem-card.revealed .front{ transform: rotateY(0deg); }
.mem-card.matched{ border-color: rgba(57,255,136,.32); box-shadow: 0 0 22px rgba(57,255,136,.12); }

/* Footer */
.footer{
  padding: 10px 8px 6px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap: 8px;
  color: rgba(234,242,255,.85);
}
.pill{
  display:inline-flex;
  align-items:center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(168,181,214,.14);
  background: rgba(10,15,37,.18);
  font-size: 12px;
}
.tiny{ font-size: 12px; opacity:.8; }

/* Desktop Gate (unchanged) */
.gate{
  position: fixed;
  inset: 0;
  display:flex;
  align-items:center;
  justify-content:center;
  padding: 20px;
  background: radial-gradient(900px 700px at 50% 30%, rgba(16,29,71,.35), rgba(0,0,0,.86));
  z-index: 9999;
}
.gate-card{
  width: min(520px, 100%);
  border-radius: 26px;
  border: 1px solid rgba(62,235,255,.24);
  background: linear-gradient(180deg, rgba(11,19,48,.75), rgba(6,11,26,.42));
  box-shadow: 0 0 50px rgba(57,255,136,.12), 0 0 46px rgba(181,108,255,.12), var(--shadow);
  padding: 18px 16px 16px;
  position: relative;
  overflow:hidden;
  text-align:center;
}
.gate-badge{
  display:inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,62,231,.25);
  background: rgba(255,62,231,.08);
  color: rgba(255,210,250,.95);
  font-weight: 900;
  letter-spacing:.05em;
  text-transform: uppercase;
  font-size: 12px;
}
.gate h1{ margin: 10px 0 6px; font-family: var(--font-future); letter-spacing:.05em; text-transform: uppercase; font-size: 18px; }
.gate p{ margin: 0 auto; max-width: 44ch; color: var(--muted); line-height:1.35; }
.gate-qr{ margin-top: 14px; display:flex; flex-direction: column; align-items:center; gap: 8px; }
#qrCanvas{ border-radius: 18px; border: 1px solid rgba(168,181,214,.16); background: rgba(4,6,21,.35); box-shadow: 0 0 22px rgba(62,235,255,.10); }
.gate-qr-note{ font-size: 12px; color: var(--muted); }
.gate-orbit{ position:absolute; right: -50px; bottom: -50px; width: 220px; height: 220px; border-radius: 999px; border: 1px dashed rgba(62,235,255,.22); opacity:.8; }
.planet{ position:absolute; left: 50%; top: 50%; width: 62px; height: 62px; border-radius: 999px; transform: translate(-50%, -50%); background: radial-gradient(circle at 30% 30%, rgba(57,255,136,.9), rgba(181,108,255,.55)); box-shadow: 0 0 28px rgba(57,255,136,.20), 0 0 30px rgba(181,108,255,.18); }
.satellite{ position:absolute; left: 50%; top: 50%; width: 22px; height: 22px; border-radius: 999px; background: radial-gradient(circle at 35% 35%, rgba(62,235,255,.95), rgba(62,235,255,.25)); box-shadow: 0 0 16px rgba(62,235,255,.22); transform: translate(-50%, -50%); animation: orbit 2.6s linear infinite; transform-origin: 0 0; }
@keyframes orbit{ from{ transform: translate(-50%, -50%) rotate(0deg) translateX(110px);} to{ transform: translate(-50%, -50%) rotate(360deg) translateX(110px);} }

@media (prefers-reduced-motion: reduce){
  * { animation-duration: .001ms !important; animation-iteration-count: 1 !important; transition-duration: .001ms !important; }
}

@media (max-height: 680px){
  .playfield{ height: calc(100vh - 190px); min-height: 340px; }
  .zone-btn{ padding: 14px 10px; }
}


/* Hub extras */
.cup-teaser{
  margin-top: 12px;
  border-radius: 18px;
  padding: 12px 12px;
  border: 1px solid rgba(57,255,136,.18);
  background: linear-gradient(180deg, rgba(57,255,136,.10), rgba(10,15,37,.16));
  display:flex;
  align-items:center;
  gap: 10px;
  box-shadow: 0 0 26px rgba(57,255,136,.10);
}
.cup-ic{ font-size: 18px; filter: drop-shadow(0 0 10px rgba(255,62,231,.12)); }
.cup-title{
  font-family: var(--font-future);
  font-weight: 950;
  letter-spacing:.06em;
  text-transform: uppercase;
  font-size: 13px;
}
.cup-sub{ color: var(--muted); font-size: 12px; margin-top: 2px; }

@media (max-width: 420px){
  .game-grid{ grid-template-columns: 1fr; }
}
