@import url('https://fonts.googleapis.com/css2?family=Press+Start+2P&family=Rajdhani:wght@300;400;500;600;700&display=swap');

:root {
  --bg: #050308;
  --surface: #0d0915;
  --surface2: #130f1e;
  --border: #2a1f40;
  --text: #f0e8ff;
  --muted: #7060a0;
  --accent: #ff2d78;
  --accent2: #00e5ff;
  --accent3: #ffe600;
  --radius: 4px;
  --font-display: 'Press Start 2P', monospace;
  --font-body: 'Rajdhani', sans-serif;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
  min-height:100vh;
  font-family:var(--font-body);
  background:var(--bg);
  color:var(--text);
  line-height:1.6;
  font-size:16px;
  background-image:
    repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(255,45,120,0.015) 2px,rgba(255,45,120,0.015) 4px),
    repeating-linear-gradient(90deg,transparent,transparent 2px,rgba(0,229,255,0.01) 2px,rgba(0,229,255,0.01) 4px);
}
body::after{
  content:'';position:fixed;inset:0;
  background:repeating-linear-gradient(0deg,rgba(0,0,0,0.08) 0px,rgba(0,0,0,0.08) 1px,transparent 1px,transparent 3px);
  pointer-events:none;z-index:9999;
}

/* COIN BANNER */
.coin-banner{background:var(--accent);padding:0.3rem;text-align:center;overflow:hidden}
.coin-banner-inner{
  font-family:var(--font-display);font-size:0.45rem;color:var(--bg);
  letter-spacing:0.25em;white-space:nowrap;
  animation:marquee 22s linear infinite;display:inline-block;
}
@keyframes marquee{0%{transform:translateX(50vw)}100%{transform:translateX(-100%)}}

/* HEADER */
.site-header{
  position:sticky;top:0;z-index:100;
  padding:0 1.5rem;height:64px;
  display:flex;align-items:center;gap:2rem;
  background:rgba(5,3,8,0.94);
  backdrop-filter:blur(8px);
  border-bottom:2px solid var(--accent);
  box-shadow:0 0 20px rgba(255,45,120,0.25),0 2px 0 var(--accent);
}
.logo{
  font-family:var(--font-display);font-size:0.65rem;
  color:var(--accent);text-decoration:none;
  text-shadow:0 0 10px var(--accent),0 0 20px rgba(255,45,120,0.5);
  letter-spacing:0.05em;line-height:1.5;
}
.logo:hover{color:var(--accent2);text-shadow:0 0 10px var(--accent2),0 0 20px rgba(0,229,255,0.5)}
.tagline{font-family:var(--font-body);color:var(--muted);font-size:0.85rem;letter-spacing:0.1em;text-transform:uppercase;border-left:2px solid var(--border);padding-left:1.5rem}
.breadcrumbs{font-family:var(--font-body);font-size:0.85rem;color:var(--muted);display:flex;align-items:center;gap:.5rem;text-transform:uppercase;letter-spacing:.05em}
.breadcrumbs a{color:var(--accent2);text-decoration:none}
.breadcrumbs a:hover{text-shadow:0 0 8px var(--accent2)}
.breadcrumbs .sep{color:var(--border)}

/* CONTAINER */
.container{max-width:1200px;margin:0 auto;padding:2rem 1.5rem 4rem}

/* HERO */
.hero{padding:2.5rem 0 2rem}
.hero-label{font-family:var(--font-display);font-size:0.42rem;letter-spacing:.2em;color:var(--accent3);text-shadow:0 0 8px var(--accent3);margin-bottom:1rem}
.hero h1{
  font-family:var(--font-display);font-size:clamp(0.9rem,3vw,1.6rem);
  line-height:1.6;letter-spacing:.05em;color:var(--text);
  text-shadow:3px 3px 0 var(--accent),6px 6px 0 rgba(255,45,120,0.3);
  margin-bottom:1.25rem;
}
.hero h1 span{color:var(--accent2);text-shadow:0 0 15px var(--accent2),3px 3px 0 #004455}
.hero-sub{font-family:var(--font-body);color:var(--muted);font-size:1.05rem;letter-spacing:.05em;text-transform:uppercase;max-width:50ch}

/* FILTERS */
.filters{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:2rem}
.filter-btn{
  padding:.5rem 1rem;border:1px solid var(--border);background:transparent;
  color:var(--muted);font-family:var(--font-display);font-size:0.38rem;
  cursor:pointer;letter-spacing:.1em;transition:all .15s;
}
.filter-btn:hover{border-color:var(--accent2);color:var(--accent2);text-shadow:0 0 8px var(--accent2);box-shadow:0 0 10px rgba(0,229,255,0.2),inset 0 0 10px rgba(0,229,255,0.05)}
.filter-btn.active{border-color:var(--accent);color:var(--accent);text-shadow:0 0 8px var(--accent);box-shadow:0 0 12px rgba(255,45,120,0.3),inset 0 0 12px rgba(255,45,120,0.05)}

/* SECTION */
.section-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}
.section-title{font-family:var(--font-display);font-size:0.52rem;color:var(--accent3);text-shadow:0 0 8px var(--accent3);letter-spacing:.1em}
.section-count{font-family:var(--font-display);font-size:0.38rem;color:var(--muted)}

/* GRIDS */
.featured-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem;margin-bottom:3rem}
.game-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:1rem}

/* CARDS */
.game-card{
  background:var(--surface);border:1px solid var(--border);
  text-decoration:none;color:inherit;
  display:flex;flex-direction:column;
  position:relative;transition:transform .15s;overflow:hidden;
}
.game-card::before{
  content:'';position:absolute;top:0;left:0;right:0;height:2px;
  background:linear-gradient(90deg,var(--accent),var(--accent2));
  opacity:0;transition:opacity .2s;z-index:1;
}
.game-card:hover{transform:translateY(-4px);border-color:var(--accent);box-shadow:0 0 20px rgba(255,45,120,0.25),0 0 40px rgba(255,45,120,0.1)}
.game-card:hover::before{opacity:1}
.game-card.featured{border-color:rgba(255,45,120,0.4)}
.card-img-wrap{position:relative;overflow:hidden}
.game-card img{width:100%;aspect-ratio:16/9;object-fit:cover;display:block;transition:transform .4s;filter:saturate(1.2)}
.game-card:hover img{transform:scale(1.06);filter:saturate(1.4) brightness(1.1)}
.card-badge{position:absolute;top:.5rem;left:.5rem;padding:.2rem .6rem;font-family:var(--font-display);font-size:0.3rem;letter-spacing:.12em}
.card-badge.featured-badge{background:var(--accent);color:white;box-shadow:0 0 12px rgba(255,45,120,0.6)}
.card-badge.cat-badge{background:rgba(13,9,21,0.85);color:var(--accent2);border:1px solid rgba(0,229,255,0.3);box-shadow:0 0 8px rgba(0,229,255,0.15)}
.card-play-icon{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;opacity:0;background:rgba(5,3,8,0.6);transition:opacity .2s}
.game-card:hover .card-play-icon{opacity:1}
.card-play-icon svg{width:52px;height:52px;filter:drop-shadow(0 0 12px var(--accent))}
.game-card-body{padding:.85rem 1rem;flex:1;display:flex;flex-direction:column;gap:.4rem;border-top:1px solid var(--border)}
.game-card h2{font-family:var(--font-display);font-size:0.46rem;letter-spacing:.08em;line-height:1.7;color:var(--text)}
.game-card p{font-family:var(--font-body);font-size:.85rem;color:var(--muted);line-height:1.5}
.empty-state{grid-column:1/-1;text-align:center;padding:3rem;color:var(--muted);font-family:var(--font-display);font-size:.4rem;line-height:2}

/* FOOTER */
.site-footer{padding:1.5rem;border-top:2px solid var(--accent);box-shadow:0 -1px 20px rgba(255,45,120,0.1);display:flex;gap:2rem;flex-wrap:wrap;align-items:center}
.site-footer small{font-family:var(--font-display);font-size:0.35rem;color:var(--muted);letter-spacing:.1em}
.site-footer a{color:var(--accent2);text-decoration:none}
.site-footer a:hover{text-shadow:0 0 8px var(--accent2)}

/* GAME PAGE */
.game-page-header{padding:1.5rem 0 0}
.game-meta{display:flex;align-items:center;gap:.75rem;margin-bottom:.75rem}
.game-category-tag{font-family:var(--font-display);font-size:0.36rem;padding:.25rem .7rem;border:1px solid var(--accent2);color:var(--accent2);text-shadow:0 0 8px var(--accent2);letter-spacing:.12em}
.game-page h1{font-family:var(--font-display);font-size:clamp(.7rem,2.5vw,1.1rem);line-height:1.7;color:var(--text);text-shadow:2px 2px 0 var(--accent);letter-spacing:.05em;margin-bottom:.25rem}
.player-wrap{margin:1.25rem 0}
.player-ratio{position:relative;width:100%;padding-bottom:56.25%;background:#000;border:2px solid var(--accent);box-shadow:0 0 30px rgba(255,45,120,0.2),inset 0 0 30px rgba(0,0,0,0.5);overflow:hidden}
.player-ratio[data-ratio="4/3"]{padding-bottom:75%}
.game-iframe{position:absolute;inset:0;width:100%;height:100%;border:0}
.player-toolbar{position:absolute;bottom:.75rem;right:.75rem;display:flex;gap:.5rem;z-index:10}
.toolbar-btn{width:36px;height:36px;border:1px solid var(--accent);background:rgba(5,3,8,0.85);color:var(--accent);cursor:pointer;display:flex;align-items:center;justify-content:center;backdrop-filter:blur(8px);transition:all .15s;text-decoration:none;box-shadow:0 0 8px rgba(255,45,120,0.2)}
.toolbar-btn:hover{background:rgba(255,45,120,0.15);box-shadow:0 0 16px rgba(255,45,120,0.4)}
.fallback{color:var(--muted);margin:.75rem 0 0;padding:1rem 1.25rem;border:1px solid var(--border);background:var(--surface);font-family:var(--font-display);font-size:.38rem;line-height:2}
.fallback a{color:var(--accent2)}
.hidden{display:none}
.game-desc{color:var(--muted);max-width:65ch;font-size:1rem;margin-top:.75rem;letter-spacing:.03em}
.game-actions{display:flex;gap:.75rem;margin-top:1.5rem;flex-wrap:wrap}
.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.7rem 1.4rem;font-family:var(--font-display);font-size:.38rem;letter-spacing:.08em;text-decoration:none;cursor:pointer;border:1px solid transparent;transition:all .15s}
.btn-primary{background:var(--accent);color:white;border-color:var(--accent);box-shadow:0 0 16px rgba(255,45,120,0.4)}
.btn-primary:hover{box-shadow:0 0 24px rgba(255,45,120,0.6);transform:translateY(-2px)}
.btn-ghost{background:transparent;color:var(--muted);border-color:var(--border)}
.btn-ghost:hover{color:var(--accent2);border-color:var(--accent2);text-shadow:0 0 8px var(--accent2)}

@keyframes shimmer{0%{background-position:-400px 0}100%{background-position:400px 0}}
.skeleton{background:linear-gradient(90deg,var(--surface) 25%,var(--surface2) 50%,var(--surface) 75%);background-size:800px 100%;animation:shimmer 1.4s infinite;border:1px solid var(--border)}

@media(max-width:600px){
  .site-header{padding:0 1rem;height:56px}
  .container{padding:1.25rem 1rem 3rem}
  .hero h1{font-size:.75rem}
  .featured-grid{grid-template-columns:1fr}
  .coin-banner-inner{font-size:.35rem}
}
