/* ====== ÆSIR : IGNITION — Frontend Theme ====== */
:root{
  --accent:#f5c542;
  --accent2:#8a5cff;
  --bg:#08070c;
  --fg:#e9e7f0;
  --muted:#8a8699;
  --line:rgba(255,255,255,.14);
  --nav-h:78px;
  --font:var(--font-body,"Rajdhani","Chakra Petch",sans-serif);
  --font-head:"Orbitron","Chakra Petch",sans-serif;
  --font-body:"Rajdhani","Chakra Petch",sans-serif;
}

*{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  background:var(--bg);color:var(--fg);font-family:var(--font);
  letter-spacing:.04em;line-height:1.5;overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}
.wrap{max-width:1280px;margin:0 auto;padding:0 28px}

/* ---------- Loading screen ---------- */
#loader{
  position:fixed;inset:0;z-index:9999;background:#000;display:flex;
  align-items:center;justify-content:center;flex-direction:column;gap:18px;
  transition:opacity .8s ease,visibility .8s ease;
}
#loader.hide{opacity:0;visibility:hidden}
#loader .ld-logo{width:150px;opacity:.95}
#loader .ld-bar{width:200px;height:2px;background:rgba(255,255,255,.15);overflow:hidden}
#loader .ld-bar span{display:block;height:100%;width:40%;background:var(--accent);
  animation:ld 1.1s infinite ease-in-out}
#loader .ld-text{font-size:.72rem;letter-spacing:.5em;color:var(--muted);text-transform:uppercase}
@keyframes ld{0%{transform:translateX(-120%)}100%{transform:translateX(360%)}}

/* ---------- Navbar ---------- */
header.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);z-index:200;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 26px;background:linear-gradient(180deg,rgba(5,4,9,.92),rgba(5,4,9,0));
  backdrop-filter:blur(3px);transition:background .3s;
}
header.nav.solid{background:rgba(5,4,9,.96);border-bottom:1px solid var(--line)}
.nav-logo img{height:50px;filter:drop-shadow(0 0 10px rgba(138,92,255,.55))}
.nav-menu{display:flex;align-items:center;gap:20px}
.nav-menu a{
  font-size:.74rem;font-weight:600;letter-spacing:.18em;color:var(--fg);
  text-transform:uppercase;position:relative;padding:6px 0;opacity:.85;transition:.2s;
}
.nav-menu a:hover{opacity:1;color:var(--accent)}
.nav-menu a::after{content:"";position:absolute;left:0;bottom:0;width:0;height:1px;
  background:var(--accent);transition:width .25s}
.nav-menu a:hover::after{width:100%}
.nav-star{width:22px;margin-left:6px;animation:spin 9s linear infinite}
@keyframes spin{to{transform:rotate(360deg)}}
.nav-burger{display:none;flex-direction:column;gap:5px;cursor:pointer}
.nav-burger span{width:26px;height:2px;background:var(--fg)}

/* ---------- Hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;align-items:center;
  justify-content:center;overflow:hidden;background:#000}
.hero-media{position:absolute;inset:0;z-index:0}
.hero-video{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;
  filter:saturate(1.15) contrast(1.05) brightness(.92)}
.hero-bg{position:absolute;inset:0;background-size:cover;background-position:center;
  transform:scale(1.08);animation:heroZoom 16s ease-in-out infinite alternate}
@keyframes heroZoom{to{transform:scale(1.16)}}
.hero::before{content:"";position:absolute;inset:0;z-index:1;
  background:radial-gradient(70% 70% at 50% 45%,transparent,rgba(5,6,10,.55) 72%,var(--bg) 100%)}
.hero::after{content:"";position:absolute;inset:0;z-index:1;mix-blend-mode:screen;
  background:radial-gradient(45% 55% at 60% 50%,rgba(138,92,255,.25),transparent 70%);
  animation:hueShift 12s ease-in-out infinite alternate}
@keyframes hueShift{to{filter:hue-rotate(40deg)}}
.hero-inner{position:relative;z-index:3;text-align:center;width:100%;padding-top:var(--nav-h)}
.hero-logo{max-width:360px;margin:0 auto 14px;filter:drop-shadow(0 0 34px rgba(138,92,255,.45)) drop-shadow(0 0 14px rgba(245,197,66,.25))}
.hero-tagline{color:var(--fg);font-size:.8rem;letter-spacing:.35em;text-transform:uppercase;
  margin-bottom:42px;text-shadow:0 0 12px rgba(138,92,255,.6)}
.hero-btns{display:flex;gap:22px;justify-content:center;flex-wrap:wrap}
/* Ribbon button — meniru button_01/02.png */
.ribbon{
  position:relative;display:inline-flex;align-items:center;gap:12px;
  padding:15px 46px;font-weight:700;letter-spacing:.22em;font-size:.82rem;
  text-transform:uppercase;color:#fff;border:2px solid #fff;background:rgba(8,7,12,.35);
  clip-path:polygon(4% 0,100% 0,96% 100%,0 100%);transition:.25s;cursor:pointer;
}
.ribbon:hover{background:var(--accent);color:#0a0810;border-color:var(--accent);
  box-shadow:0 0 30px rgba(245,197,66,.4)}
.ribbon svg{width:20px;height:20px}
.scroll-hint{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:3;
  color:var(--muted);font-size:.62rem;letter-spacing:.4em}
.scroll-hint::after{content:"";display:block;width:1px;height:34px;margin:8px auto 0;
  background:linear-gradient(var(--accent),transparent);animation:drop 1.8s infinite}
@keyframes drop{0%{transform:scaleY(0);transform-origin:top}50%{transform:scaleY(1)}100%{transform:scaleY(0);transform-origin:bottom}}
.presented{position:absolute;right:26px;bottom:22px;z-index:3;text-align:right;
  color:var(--muted);font-size:.62rem;letter-spacing:.3em;text-transform:uppercase}

/* ---------- Section base ---------- */
.section{padding:110px 0;position:relative}
.section.alt{background:linear-gradient(180deg,#0b0912,#08070c)}
.sec-head{margin-bottom:54px}
.sec-kicker{color:var(--accent);font-size:.72rem;letter-spacing:.45em;text-transform:uppercase}
.sec-title{font-family:var(--font-head);font-size:clamp(2rem,5vw,3.4rem);font-weight:800;letter-spacing:.02em;line-height:1.05}
.sec-title .ul{position:relative}
.sec-title .ul::after{content:"_";color:var(--accent);animation:blink 1s steps(1) infinite}
@keyframes blink{50%{opacity:0}}
.sec-sub{color:var(--muted);margin-top:10px;max-width:640px}

/* ---------- News carousel ---------- */
.news-row{display:flex;gap:20px;overflow-x:auto;padding-bottom:14px;scroll-snap-type:x mandatory}
.news-row::-webkit-scrollbar{height:6px}.news-row::-webkit-scrollbar-thumb{background:var(--line)}
.news-card{min-width:300px;max-width:300px;scroll-snap-align:start;border:1px solid var(--line);
  background:#0c0a14;transition:.25s}
.news-card:hover{border-color:var(--accent);transform:translateY(-4px)}
.news-card img{width:100%;height:170px;object-fit:cover}
.news-card .nc-body{padding:16px}
.news-card .nc-meta{font-size:.66rem;color:var(--accent);letter-spacing:.2em;text-transform:uppercase}
.news-card h3{font-size:.95rem;margin-top:8px;font-weight:600;line-height:1.35}

/* ---------- Grids (mechs, characters, gallery, creators, shop) ---------- */
.grid{display:grid;gap:22px}
.grid.g3{grid-template-columns:repeat(3,1fr)}
.grid.g4{grid-template-columns:repeat(4,1fr)}
.card{position:relative;border:1px solid var(--line);background:#0c0a14;overflow:hidden;transition:.3s}
.card:hover{border-color:var(--accent);box-shadow:0 14px 40px rgba(0,0,0,.5)}
.card .ph{aspect-ratio:3/4;overflow:hidden;background:#000}
.card .ph img{width:100%;height:100%;object-fit:cover;transition:transform .5s}
.card:hover .ph img{transform:scale(1.07)}
.card .cb{padding:16px}
.card .cb .code{font-size:.62rem;letter-spacing:.25em;color:var(--accent);text-transform:uppercase}
.card .cb h3{font-size:1.05rem;font-weight:700;margin:4px 0 6px}
.card .cb p{font-size:.82rem;color:var(--muted)}
.card .bar{height:3px;background:var(--accent)}

/* mech showcase row (image 22 style) */
.mech-strip{display:grid;grid-template-columns:repeat(5,1fr);min-height:420px}
.mech-strip .ms{position:relative;display:flex;align-items:flex-end;padding:24px;
  background-size:cover;background-position:center;filter:saturate(.85);transition:.35s;cursor:pointer;overflow:hidden}
.mech-strip .ms::before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,transparent,rgba(0,0,0,.85))}
.mech-strip .ms:hover{filter:saturate(1.2)}
.mech-strip .ms .lbl{position:relative;z-index:2}
.mech-strip .ms .lbl .c{font-size:.6rem;letter-spacing:.3em;opacity:.8}
.mech-strip .ms .lbl h3{font-size:1.5rem;font-weight:700;line-height:1}

/* prose */
.prose{max-width:760px;color:var(--fg)}
.prose p{margin-bottom:1em;color:#cfccdd}

/* gallery */
.gal{columns:4;column-gap:14px}
.gal img{width:100%;margin-bottom:14px;border:1px solid var(--line);transition:.25s}
.gal img:hover{border-color:var(--accent);filter:brightness(1.1)}

/* soundtracks */
.ost{display:flex;align-items:center;gap:18px;border:1px solid var(--line);padding:14px;background:#0c0a14;margin-bottom:12px}
.ost img{width:64px;height:64px;object-fit:cover}
.ost .play{margin-left:auto;width:42px;height:42px;border:1px solid var(--accent);border-radius:50%;
  display:flex;align-items:center;justify-content:center;color:var(--accent);cursor:pointer}

/* ---------- Footer ---------- */
footer.ft{border-top:1px solid var(--line);padding:54px 0 34px;background:#06050a}
.ft-top{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:24px}
.ft-logo img{height:42px}
.ft-social{display:flex;gap:18px}
.ft-social a{width:38px;height:38px;border:1px solid var(--line);border-radius:50%;
  display:flex;align-items:center;justify-content:center;transition:.2s}
.ft-social a:hover{border-color:var(--accent);color:var(--accent)}
.ft-copy{margin-top:30px;color:var(--muted);font-size:.72rem;letter-spacing:.1em}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(28px);transition:.7s cubic-bezier(.2,.7,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- Responsive ---------- */
@media(max-width:1024px){.grid.g4{grid-template-columns:repeat(3,1fr)}.gal{columns:3}.mech-strip{grid-template-columns:repeat(2,1fr)}}
@media(max-width:760px){
  .nav-menu{position:fixed;inset:var(--nav-h) 0 auto 0;flex-direction:column;background:rgba(6,5,10,.98);
    padding:24px;gap:18px;transform:translateY(-130%);transition:.35s;border-bottom:1px solid var(--line)}
  .nav-menu.open{transform:none}
  .nav-burger{display:flex}.nav-star{display:none}
  .grid.g3,.grid.g4{grid-template-columns:1fr 1fr}.gal{columns:2}
  .presented{position:static;text-align:center;margin-top:30px}
}

/* ============================================================
   CYBERPUNK FX LAYER
   ============================================================ */

/* Global scanlines */
.fx-scanlines{position:fixed;inset:0;z-index:9000;pointer-events:none;
  background:repeating-linear-gradient(to bottom,rgba(255,255,255,.035) 0 1px,transparent 1px 3px);
  mix-blend-mode:overlay;opacity:.5}
/* Animated noise grain */
.fx-noise{position:fixed;inset:-50%;z-index:9001;pointer-events:none;opacity:.05;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='120' height='120'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  animation:noiseShift .5s steps(4) infinite}
@keyframes noiseShift{
  0%{transform:translate(0,0)}25%{transform:translate(-6%,3%)}
  50%{transform:translate(4%,-5%)}75%{transform:translate(-3%,6%)}100%{transform:translate(5%,2%)}}
/* Vignette + CRT flicker */
.fx-vignette{position:fixed;inset:0;z-index:8999;pointer-events:none;
  box-shadow:inset 0 0 220px 40px rgba(0,0,0,.85);animation:flicker 6s infinite}
@keyframes flicker{0%,97%,100%{opacity:1}98%{opacity:.82}99%{opacity:.94}}

/* Hero scanlines + perspective grid */
.hero-scanlines{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:repeating-linear-gradient(to bottom,rgba(0,0,0,.25) 0 2px,transparent 2px 4px);opacity:.35}
.hero-grid{position:absolute;left:0;right:0;bottom:0;height:46%;z-index:1;pointer-events:none;
  background-image:linear-gradient(rgba(138,92,255,.22) 1px,transparent 1px),
    linear-gradient(90deg,rgba(138,92,255,.18) 1px,transparent 1px);
  background-size:48px 48px;transform:perspective(380px) rotateX(70deg);transform-origin:bottom;
  mask-image:linear-gradient(to top,#000,transparent);opacity:.5;animation:gridRun 5s linear infinite}
@keyframes gridRun{to{background-position:0 48px,48px 0}}

/* HUD corner brackets */
.hud-corner{position:absolute;width:46px;height:46px;z-index:4;pointer-events:none;
  border:2px solid var(--accent);opacity:.55;filter:drop-shadow(0 0 6px var(--accent))}
.hud-corner.tl{top:84px;left:26px;border-right:0;border-bottom:0}
.hud-corner.tr{top:84px;right:26px;border-left:0;border-bottom:0}
.hud-corner.bl{bottom:26px;left:26px;border-right:0;border-top:0}
.hud-corner.br{bottom:26px;right:26px;border-left:0;border-top:0}

/* Chromatic-aberration glitch on logos/images */
.glitch-img{position:relative;animation:imgFlick 7s infinite}
@keyframes imgFlick{0%,93%,100%{filter:none}
  94%{filter:drop-shadow(2px 0 0 rgba(255,0,80,.7)) drop-shadow(-2px 0 0 rgba(0,200,255,.7))}
  96%{transform:translateX(2px)}97%{transform:translateX(-2px)}98%{transform:none}}

/* Glitch text — use data-text="..." on element with class .glitch */
.glitch{position:relative;display:inline-block;color:var(--fg)}
.glitch::before,.glitch::after{content:attr(data-text);position:absolute;left:0;top:0;width:100%;
  overflow:hidden;clip-path:inset(0)}
.glitch::before{color:#ff2e6e;transform:translate(-2px,0);animation:gl1 2.6s infinite linear alternate-reverse}
.glitch::after{color:#00e5ff;transform:translate(2px,0);animation:gl2 3.4s infinite linear alternate-reverse}
@keyframes gl1{0%{clip-path:inset(0 0 85% 0)}20%{clip-path:inset(40% 0 40% 0)}
  40%{clip-path:inset(80% 0 5% 0)}60%{clip-path:inset(20% 0 55% 0)}80%{clip-path:inset(60% 0 20% 0)}100%{clip-path:inset(10% 0 75% 0)}}
@keyframes gl2{0%{clip-path:inset(70% 0 10% 0)}25%{clip-path:inset(10% 0 70% 0)}
  50%{clip-path:inset(45% 0 35% 0)}75%{clip-path:inset(5% 0 85% 0)}100%{clip-path:inset(55% 0 25% 0)}}

/* Neon nav links + glitch hover */
.nav-menu a{text-shadow:0 0 0 transparent;transition:.2s}
.nav-menu a:hover{color:var(--accent);text-shadow:0 0 10px rgba(245,197,66,.7);
  animation:navGlitch .3s steps(2) 1}
@keyframes navGlitch{0%{transform:translate(0)}25%{transform:translate(-1px,1px)}
  50%{transform:translate(1px,-1px)}75%{transform:translate(-1px,0)}100%{transform:none}}

/* Cyberpunk ribbon buttons */
.ribbon{overflow:hidden;border-color:var(--accent);
  box-shadow:0 0 0 1px rgba(245,197,66,.25),0 0 18px rgba(138,92,255,.15)}
.ribbon::before{content:"";position:absolute;top:0;left:-120%;width:60%;height:100%;
  background:linear-gradient(120deg,transparent,rgba(255,255,255,.35),transparent);
  transform:skewX(-20deg);transition:left .5s}
.ribbon:hover::before{left:160%}
.ribbon span{position:relative;z-index:2}

/* Scramble text helper */
[data-scramble]{font-family:var(--font-head);font-variant-numeric:tabular-nums}

/* Section titles get heading font glow */
.sec-title{text-shadow:0 0 24px rgba(138,92,255,.25)}
.sec-kicker{text-shadow:0 0 10px rgba(245,197,66,.5)}

/* Card hover neon */
.card,.mech-card,.char-card{transition:transform .3s,box-shadow .3s,border-color .3s}
.card:hover,.mech-card:hover,.char-card:hover{
  box-shadow:0 0 0 1px var(--accent),0 14px 40px rgba(138,92,255,.25)}

@media (prefers-reduced-motion:reduce){
  .fx-noise,.hero-grid,.glitch-img,.glitch::before,.glitch::after,.hero::after{animation:none}
  html{scroll-behavior:auto}
}

/* ============================================================
   MOBILE RESPONSIVE (strengthened)
   ============================================================ */
@media(max-width:900px){
  .wrap{padding:0 18px}
  .hud-corner{width:30px;height:30px}
  .hero-logo{max-width:74vw}
  .nav-logo img{height:42px}
}
@media(max-width:760px){
  .hero{min-height:88vh}
  .hero-tagline{font-size:.68rem;letter-spacing:.25em;margin-bottom:30px}
  .hero-btns{gap:14px}
  .ribbon{padding:13px 30px;font-size:.74rem;letter-spacing:.16em}
  .hud-corner.tl,.hud-corner.tr{top:auto;display:none}
  .fx-noise{display:none}                /* save battery/perf on mobile */
  .news-row{display:flex;gap:14px;overflow-x:auto;scroll-snap-type:x mandatory;
    -webkit-overflow-scrolling:touch;padding-bottom:8px}
  .news-row>*{flex:0 0 78%;scroll-snap-align:start}
  .mech-strip{grid-template-columns:1fr 1fr}
  .section{padding:70px 0}
  .presented{font-size:.55rem}
}
@media(max-width:480px){
  .nav-logo img{height:38px}
  .hero-logo{max-width:84vw}
  .hero-btns{flex-direction:column;width:100%;align-items:stretch;padding:0 30px}
  .ribbon{justify-content:center;width:100%}
  .grid.g3,.grid.g4{grid-template-columns:1fr}
  .gal{columns:1}
  .mech-strip{grid-template-columns:1fr}
  .sec-title{font-size:2rem}
  .hud-corner{display:none}
}
/* tap targets & no horizontal overflow */
@media(hover:none){.nav-menu a{padding:10px 0}}
img,video{max-width:100%}

/* Scramble-in-progress styling */
.scrambling{color:var(--accent)!important;text-shadow:0 0 10px rgba(245,197,66,.6)}
.sec-kicker[data-final],.news-card h3,.nc-meta{font-variant-numeric:tabular-nums}
