
:root{
  --ink:#0b0d14;
  --deep:#070912;
  --glow1:#a17bff;
  --glow2:#00ffa3;
  --text:#e9efff;
  --muted:#9ca6c1;
  --card:#12172a;
  --accent:#7ad0ff;
}

*{box-sizing:border-box;margin:0;padding:0}
html,body{height:100%}
body{
  font-family: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, "Helvetica Neue", Arial;
  color:var(--text);
  background: radial-gradient(1200px 800px at 20% -10%, rgba(161,123,255,0.12), transparent 60%),
              radial-gradient(1000px 600px at 100% 0%, rgba(0,255,163,0.10), transparent 65%),
              linear-gradient(180deg, var(--ink), var(--deep));
  overflow-x:hidden;
}

/* floating particles backdrop */
#particles{position:fixed;inset:0;pointer-events:none; z-index:0; background:
  radial-gradient(2px 2px at 20% 30%, rgba(255,255,255,.15), transparent 60%),
  radial-gradient(1.5px 1.5px at 60% 40%, rgba(255,255,255,.12), transparent 60%),
  radial-gradient(1.5px 1.5px at 80% 20%, rgba(255,255,255,.10), transparent 60%);
  animation: drift 30s linear infinite;
  opacity:.4;
}
@keyframes drift{to{background-position: 2000px 0, -1500px 0, 1000px 0;}}

.site-nav{
  position:sticky; top:0; z-index:10;
  display:flex; align-items:center; justify-content:space-between;
  padding:14px 22px; backdrop-filter: blur(10px);
  background: rgba(10,12,22,.35); border-bottom:1px solid rgba(255,255,255,.06);
}
.site-nav .brand{font-weight:800; letter-spacing:.3px}
.site-nav nav a{color:var(--text); text-decoration:none; margin-right:18px; opacity:.85}
.site-nav nav a:hover{opacity:1}
.site-nav .cta{background:linear-gradient(90deg,var(--glow1),var(--glow2)); border:none; color:#05141a;
  padding:8px 14px; border-radius:8px; font-weight:800; cursor:pointer}

.hero{display:grid; grid-template-columns:1.1fr .9fr; gap:24px; align-items:center; padding:48px 22px; z-index:1; position:relative}
.hero h1{font-size: clamp(32px, 5vw, 56px); line-height:1.05}
.hero .small{font-size:.55em; color:var(--muted); font-weight:600}
.lead{color:var(--muted); margin-top:12px; max-width:48ch}
.hero .buttons{margin-top:18px}
.btn{padding:10px 16px; border-radius:10px; cursor:pointer; font-weight:800; border:1px solid rgba(255,255,255,.12); color:var(--text); background:transparent}
.btn.primary{border:none; background:linear-gradient(90deg, var(--glow1), var(--glow2)); color:#041018}
.btn.ghost{background:rgba(255,255,255,.06)}
.hero-right img{width:100%; border-radius:14px; box-shadow:0 30px 60px rgba(0,0,0,.35)}

section{padding:56px 22px; position:relative; z-index:1}

.story h2, .play h2, .chapters h2, .join h2{font-size: clamp(26px,4vw,36px); margin-bottom:10px}
.story p{color:var(--muted); max-width:80ch}
.story-cards{display:grid; grid-template-columns: repeat(auto-fit, minmax(220px,1fr)); gap:16px; margin-top:18px}
.card{background:var(--card); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:16px}
.card{background:var(--card); border:1px solid rgba(255,255,255,.06); border-radius:12px; padding:16px; transition:transform .25s ease, box-shadow .25s ease}
.card:hover{transform:translateY(-4px) scale(1.02); box-shadow:0 12px 24px rgba(0,0,0,.3)}
.card h3{margin-bottom:6px; color:var(--accent)}

.play .hint{color:var(--muted); margin-bottom:10px}
.game-wrap{position:relative; max-width:1100px; margin:10px auto 0 auto; border-radius:14px; overflow:hidden; border:1px solid rgba(255,255,255,.06); box-shadow:0 25px 60px rgba(0,0,0,.45)}
#game{width:100%; display:block; background:radial-gradient(1200px 700px at 50% -10%, rgba(161,123,255,.10), transparent 60%), linear-gradient(#071225,#02140f 70%)}
.hud{position:absolute; inset:10px 10px auto 10px; display:flex; gap:8px; align-items:center; justify-content:space-between; pointer-events:none}
.hud #score{font-weight:900; color:#00ffa3; text-shadow:0 2px 8px rgba(0,0,0,.6)}
.hud-btn{pointer-events:auto; border:none; background:rgba(255,255,255,.12); color:var(--text); padding:6px 10px; border-radius:8px; cursor:pointer}

.chapters .chapters-grid{display:grid; grid-template-columns:repeat(auto-fit,minmax(220px,1fr)); gap:12px; margin-top:14px}
.chapter{background:linear-gradient(90deg, rgba(161,123,255,.2), rgba(0,255,163,.15)); border:1px solid rgba(255,255,255,.08); color:var(--text); border-radius:12px; padding:14px; cursor:pointer; text-align:left}
.chapter:hover{filter:brightness(1.12)}

.join p{color:var(--muted)}
.join-form{margin-top:10px; display:flex; gap:10px; flex-wrap:wrap}
.join-form input{flex:1 1 260px; padding:10px 12px; border-radius:10px; border:1px solid rgba(255,255,255,.12); background:#0c1325; color:var(--text)}
.join-form button{flex:0 0 auto}
.join-form small{display:block; margin-top:6px; color:var(--accent)}
.socials{margin-top:16px; display:flex; gap:16px}
.social{color:var(--accent); text-decoration:none}
.social:hover{text-decoration:underline}

.site-footer{padding:22px; color:#9aa3bf; border-top:1px solid rgba(255,255,255,.06)}

/* modal */
.modal{position:fixed; inset:0; display:grid; place-items:center; background:rgba(0,0,0,.55); z-index:100}
.modal.hidden{display:none}
.modal-card{background:var(--card); border:1px solid rgba(255,255,255,.08); border-radius:12px; width:min(680px, 92vw); padding:18px 18px 22px 18px; position:relative}
.modal .close{position:absolute; right:10px; top:8px; background:transparent; border:none; color:var(--text); font-size:20px; cursor:pointer}
.lore-body{color:var(--muted); margin-top:10px; line-height:1.6}

@media (max-width: 900px){
  .hero{grid-template-columns:1fr}
}

/* minimap */
.mini-wrap{pointer-events:none; margin-left:auto; margin-right:8px}
.minimap{display:block; width:120px; height:120px; border-radius:10px; border:1px solid rgba(255,255,255,.12); box-shadow:0 6px 18px rgba(0,0,0,.35); background:#0b1222; opacity:.95}
@media(max-width:768px){ .minimap{display:none} }

/* Fullscreen adjustments */
.game-wrap:fullscreen{
  width:100vw;
  height:100vh;
  max-width:none;
  margin:0;
  border-radius:0;
}
.game-wrap:fullscreen #game{
  height:100%;
}
.game-wrap:fullscreen .hud{
  inset:12px;
}
.game-wrap:fullscreen .minimap{
  display:block;
  width:160px;
  height:160px;
}

/* meme wall */
.memes .hint{color:var(--muted); margin-bottom:10px}
.meme-form{margin-top:10px; display:flex; gap:10px; flex-wrap:wrap}
.meme-form input{flex:1 1 260px; padding:10px 12px; border-radius:10px; border:1px solid rgba(255,255,255,.12); background:#0c1325; color:var(--text)}
.meme-form small{display:block; margin-top:6px; color:var(--accent)}
.memes-grid{display:grid; grid-template-columns: repeat(auto-fit, minmax(180px,1fr)); gap:12px; margin-top:14px}
.memes-grid .m{position:relative; overflow:hidden; border-radius:12px; border:1px solid rgba(255,255,255,.08); background:#0c1325}
.memes-grid .m{position:relative; overflow:hidden; border-radius:12px; border:1px solid rgba(255,255,255,.08); background:#0c1325; transition:transform .25s ease}
.memes-grid .m:hover{transform:scale(1.05)}
.memes-grid .m img{width:100%; height:180px; object-fit:cover; display:block}
.memes-grid .m .remove{position:absolute; top:6px; right:6px; pointer-events:auto; background:rgba(0,0,0,.5); color:#fff; border:none; border-radius:8px; padding:4px 8px; cursor:pointer; font-weight:700}

/* hit alert */
.alert{pointer-events:none; position:absolute; left:120px; top:10px; font-weight:900; color:#ff6b6b; text-shadow:0 2px 8px rgba(0,0,0,.7); opacity:0; transition:opacity .2s ease}
.alert.show{opacity:1}
.hidden{display:none}

/* Story interactive timeline */
.story-timeline{
  margin-top:32px;
  display:flex;
  flex-direction:column;
  gap:28px;
}
.story-entry{
  display:flex;
  align-items:center;
  opacity:0;
  transform:translateX(-50px);
  transition:opacity .6s ease, transform .6s ease;
}
/* alternate direction for even entries */
.story-entry:nth-child(even){
  flex-direction:row-reverse;
  text-align:right;
}
.story-entry.in-view{
  opacity:1;
  transform:translateX(0);
}
.entry-img{
  width:80px;
  height:80px;
  object-fit:cover;
  border-radius:12px;
  margin-right:16px;
  margin-left:0;
  flex-shrink:0;
  box-shadow:0 6px 14px rgba(0,0,0,.35);
}
.story-entry:nth-child(even) .entry-img{
  margin-left:16px;
  margin-right:0;
}
.entry-text h4{
  margin-bottom:6px;
  font-size:1.2rem;
  color:var(--accent);
}
.entry-text p{
  color:var(--muted);
  font-size:.95rem;
  line-height:1.4;
}
@media(max-width:700px){
  .story-entry{
    flex-direction:column;
    text-align:left;
    align-items:flex-start;
  }
  .story-entry:nth-child(even){
    flex-direction:column;
    text-align:left;
  }
  .entry-img{
    margin:0 0 12px 0;
    width:100%;
    height:auto;
  }
}
