:root{
  --neon-pink:#ff2ec4;
  --neon-cyan:#00fff2;
  --neon-yellow:#f9f871;
  --neon-purple:#9d4edd;
  --bg-dark:#05010f;
  --bg-panel:#0d0821;
}
*{box-sizing:border-box;}
html,body{margin:0;padding:0;}
body{
  background:var(--bg-dark);
  color:#e8e8ff;
  font-family:'Consolas','Courier New',monospace;
  overflow-x:hidden;
  position:relative;
  min-height:100vh;
}

/* ---------- background grid ---------- */
.grid-bg{
  position:fixed;inset:0;z-index:0;
  background-image:
    linear-gradient(rgba(0,255,242,0.08) 1px, transparent 1px),
    linear-gradient(90deg, rgba(0,255,242,0.08) 1px, transparent 1px);
  background-size:40px 40px;
  animation:gridmove 8s linear infinite;
  mask-image:radial-gradient(ellipse at center, black 40%, transparent 90%);
}
@keyframes gridmove{
  0%{background-position:0 0;}
  100%{background-position:40px 40px;}
}
.scanlines{
  position:fixed;inset:0;z-index:1;pointer-events:none;
  background:repeating-linear-gradient(
    to bottom,
    rgba(255,255,255,0.03) 0px,
    rgba(255,255,255,0.03) 1px,
    transparent 2px,
    transparent 4px
  );
  mix-blend-mode:overlay;
}
.noise-flicker{
  position:fixed;inset:0;z-index:2;pointer-events:none;
  background:rgba(157,78,221,0.02);
  animation:flicker 6s infinite;
}
@keyframes flicker{
  0%,19%,21%,23%,25%,54%,56%,100%{opacity:1;}
  20%,24%,55%{opacity:0.85;}
}

main{position:relative;z-index:3;max-width:1000px;margin:0 auto;padding:40px 20px 120px;}

/* ---------- boot screen ---------- */
#boot{
  position:fixed;inset:0;z-index:50;background:#000;
  color:var(--neon-cyan);font-size:14px;padding:40px;
  display:flex;flex-direction:column;justify-content:center;
  transition:opacity 0.8s ease, visibility 0.8s ease;
}
#boot .line{opacity:0;animation:appear 0.15s forwards;white-space:pre;}
@keyframes appear{to{opacity:1;}}
#boot.hide{opacity:0;visibility:hidden;}
.bar-track{width:100%;max-width:400px;height:14px;border:1px solid var(--neon-cyan);margin-top:16px;}
.bar-fill{height:100%;width:0%;background:var(--neon-cyan);box-shadow:0 0 10px var(--neon-cyan);transition:width 2.2s linear;}

/* ---------- glitch title ---------- */
.hero{text-align:center;padding:60px 0 30px;}
.glitch{
  font-size:clamp(32px,7vw,64px);
  font-weight:900;
  letter-spacing:4px;
  position:relative;
  color:#fff;
  text-shadow:0 0 8px var(--neon-cyan),0 0 20px var(--neon-pink);
}
.glitch::before,.glitch::after{
  content:attr(data-text);
  position:absolute;left:0;top:0;width:100%;
  overflow:hidden;background:var(--bg-dark);
}
.glitch::before{
  left:2px;text-shadow:-2px 0 var(--neon-pink);
  animation:glitch1 3s infinite linear alternate-reverse;
}
.glitch::after{
  left:-2px;text-shadow:-2px 0 var(--neon-cyan);
  animation:glitch2 2.2s infinite linear alternate-reverse;
}
@keyframes glitch1{
  0%{clip-path:inset(20% 0 60% 0);} 20%{clip-path:inset(10% 0 80% 0);}
  40%{clip-path:inset(70% 0 5% 0);} 60%{clip-path:inset(40% 0 40% 0);}
  80%{clip-path:inset(85% 0 2% 0);} 100%{clip-path:inset(5% 0 90% 0);}
}
@keyframes glitch2{
  0%{clip-path:inset(60% 0 20% 0);} 25%{clip-path:inset(15% 0 65% 0);}
  50%{clip-path:inset(45% 0 45% 0);} 75%{clip-path:inset(5% 0 88% 0);}
  100%{clip-path:inset(90% 0 3% 0);}
}
.subtitle{
  margin-top:18px;font-size:16px;color:var(--neon-yellow);
  letter-spacing:2px;
}
.typewriter{
  display:inline-block;border-right:2px solid var(--neon-yellow);
  padding-right:4px;white-space:nowrap;overflow:hidden;
}
.status-tag{
  display:inline-block;margin-top:24px;padding:6px 16px;
  border:1px solid var(--neon-cyan);border-radius:20px;
  font-size:12px;color:var(--neon-cyan);letter-spacing:2px;
  box-shadow:0 0 12px rgba(0,255,242,0.4) inset;
}

/* ---------- section headers ---------- */
.section-title{
  font-size:22px;color:var(--neon-pink);letter-spacing:3px;
  margin:70px 0 24px;text-transform:uppercase;
  border-left:4px solid var(--neon-pink);padding-left:14px;
}
.section-title .num{color:var(--neon-cyan);margin-right:8px;}

/* ---------- achievements ---------- */
.achv-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:18px;}
.achv-card{
  background:linear-gradient(160deg, var(--bg-panel), #170a33);
  border:1px solid rgba(0,255,242,0.3);border-radius:10px;
  padding:18px;position:relative;overflow:hidden;
  transition:transform 0.25s, box-shadow 0.25s;
}
.achv-card:hover{
  transform:translateY(-6px);
  box-shadow:0 8px 30px rgba(255,46,196,0.35);
  border-color:var(--neon-pink);
}
.achv-card .icon{font-size:28px;}
.achv-card h3{margin:10px 0 6px;color:var(--neon-yellow);font-size:15px;letter-spacing:1px;}
.achv-card p{margin:0;font-size:13px;color:#c9c9f2;line-height:1.6;}
.achv-card .badge{
  position:absolute;top:12px;right:14px;font-size:11px;
  color:var(--neon-cyan);border:1px solid var(--neon-cyan);
  padding:2px 8px;border-radius:10px;
}

/* ---------- photo wall ---------- */
.photo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:16px;}
.photo-slot{
  aspect-ratio:1/1;border-radius:8px;position:relative;
  background:
    repeating-linear-gradient(45deg, rgba(0,255,242,0.06) 0 10px, transparent 10px 20px),
    linear-gradient(135deg,#170a33,#05010f);
  border:1px solid var(--neon-cyan);
  display:flex;flex-direction:column;align-items:center;justify-content:center;
  color:var(--neon-cyan);font-size:13px;letter-spacing:1px;
  overflow:hidden;
  box-shadow:0 0 0 rgba(0,255,242,0);
  transition:transform 0.25s, box-shadow 0.25s, border-color 0.25s;
}
.photo-slot:hover{
  transform:translateY(-6px) scale(1.02);
  border-color:var(--neon-pink);
  box-shadow:0 10px 30px rgba(255,46,196,0.35);
  z-index:2;
}
.photo-slot img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;filter:saturate(1.05) contrast(1.05);
  transition:transform 0.4s;
}
.photo-slot:hover img{transform:scale(1.08);}
.photo-slot .tag{
  position:absolute;bottom:0;left:0;right:0;
  padding:18px 10px 8px;font-size:11px;line-height:1.4;
  color:#fff;letter-spacing:1px;text-align:left;
  background:linear-gradient(to top, rgba(5,1,15,0.92), transparent);
  z-index:1;
}
.photo-slot .tag b{color:var(--neon-yellow);}
.photo-slot .plus{font-size:34px;color:var(--neon-pink);margin-bottom:6px;}
.photo-hint{
  text-align:center;color:#9d94c4;font-size:12px;margin-top:14px;
}

/* ---------- interactive zone ---------- */
.interactive{
  text-align:center;padding:30px 20px;border:1px solid rgba(157,78,221,0.4);
  border-radius:14px;background:radial-gradient(circle at 50% 0%, rgba(157,78,221,0.12), transparent 70%);
}
#cake{
  font-size:90px;cursor:pointer;display:inline-block;
  filter:drop-shadow(0 0 14px var(--neon-yellow));
  transition:transform 0.2s;
  user-select:none;
}
#cake:hover{transform:scale(1.08) rotate(-3deg);}
#cake:active{transform:scale(0.95);}
#cake-hint{color:#9d94c4;font-size:13px;margin-top:8px;}
#secret-msg{
  margin-top:20px;font-size:16px;color:var(--neon-yellow);
  min-height:24px;
}
#fx-canvas{position:fixed;inset:0;pointer-events:none;z-index:40;}

.buff-btn{
  margin-top:26px;background:transparent;border:2px solid var(--neon-pink);
  color:var(--neon-pink);padding:12px 26px;font-family:inherit;
  font-size:14px;letter-spacing:2px;border-radius:6px;cursor:pointer;
  transition:all 0.2s;
}
.buff-btn:hover{background:var(--neon-pink);color:#05010f;box-shadow:0 0 20px var(--neon-pink);}
#buff-output{
  margin-top:18px;font-size:15px;color:#fff;min-height:50px;
  max-width:600px;margin-left:auto;margin-right:auto;line-height:1.7;
}

/* ---------- target raid shooting game ---------- */
.shoot-zone{padding-top:10px;}
.shoot-status{font-size:12px;color:var(--neon-cyan);margin-bottom:16px;letter-spacing:1px;}
.shoot-arena{
  position:relative;width:100%;max-width:480px;height:280px;
  margin:0 auto 20px;border-radius:12px;overflow:hidden;
  border:2px solid var(--neon-cyan);
  background:
    repeating-linear-gradient(0deg, rgba(0,255,242,0.06) 0 1px, transparent 1px 22px),
    repeating-linear-gradient(90deg, rgba(0,255,242,0.06) 0 1px, transparent 1px 22px),
    linear-gradient(160deg,var(--bg-panel),#170a33);
  cursor:crosshair;
  display:flex;align-items:center;justify-content:center;
}
.shoot-target{
  position:absolute;font-size:26px;line-height:1;cursor:pointer;
  user-select:none;filter:drop-shadow(0 0 8px rgba(255,46,196,0.7));
  animation:targetPop 0.15s ease-out;
}
.shoot-target.decoy{
  filter:drop-shadow(0 0 9px rgba(255,30,60,0.9));
}
@keyframes targetPop{from{transform:scale(0);}to{transform:scale(1);}}
.shoot-target.hit{animation:targetHit 0.25s forwards;pointer-events:none;}
@keyframes targetHit{to{transform:scale(1.7);opacity:0;}}
#shoot-result{
  margin:6px auto 18px;font-size:14px;line-height:1.8;
  max-width:420px;min-height:20px;white-space:pre-line;
}
#shoot-result.jackpot{
  color:#fff;font-size:15px;padding:16px;border-radius:12px;
  background:linear-gradient(160deg,#3a0d4d,#170a33);
  border:1px solid var(--neon-pink);
  box-shadow:0 0 30px rgba(255,46,196,0.5) inset;
  animation:jackpotGlow 1.4s ease-in-out infinite alternate;
}
#shoot-result.fail{color:#9d94c4;}
@keyframes jackpotGlow{
  from{box-shadow:0 0 20px rgba(255,46,196,0.5) inset;}
  to{box-shadow:0 0 50px rgba(0,255,242,0.7) inset;}
}

footer{
  text-align:center;margin-top:80px;color:#665a8f;font-size:12px;
  letter-spacing:2px;
}
footer span{color:var(--neon-cyan);}

::selection{background:var(--neon-pink);color:#05010f;}
