/* ==========================================================================
   PIXELPUNCH — Modern Publisher Site
   ========================================================================== */

/* ---- FONTS (self-hosted) ---- */
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-Regular.ttf') format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-Medium.ttf') format('truetype'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-SemiBold.ttf') format('truetype'); font-weight:600; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-Bold.ttf') format('truetype'); font-weight:700; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-ExtraBold.ttf') format('truetype'); font-weight:800; font-style:normal; font-display:swap; }
@font-face { font-family:'Montserrat'; src:url('/fonts/Montserrat-Black.ttf') format('truetype'); font-weight:900; font-style:normal; font-display:swap; }
@font-face { font-family:'Roboto'; src:url('/fonts/Roboto-Light.ttf') format('truetype'); font-weight:300; font-style:normal; font-display:swap; }
@font-face { font-family:'Roboto'; src:url('/fonts/Roboto-Regular.ttf') format('truetype'); font-weight:400; font-style:normal; font-display:swap; }
@font-face { font-family:'Roboto'; src:url('/fonts/Roboto-Medium.ttf') format('truetype'); font-weight:500; font-style:normal; font-display:swap; }
@font-face { font-family:'Roboto'; src:url('/fonts/Roboto-Bold.ttf') format('truetype'); font-weight:700; font-style:normal; font-display:swap; }

/* ---- TOKENS ---- */
:root {
  --red: #B22A2A;
  --red-bright: #D93636;
  --red-dark: #8A1F1F;
  --bg: #0B0B0F;
  --bg-elevated: #13131A;
  --bg-card: #18182200;
  --bg-card-solid: #181822;
  --surface: #1E1E2A;
  --border: rgba(255,255,255,0.06);
  --border-strong: rgba(255,255,255,0.12);
  --text: #F0F0F5;
  --text-secondary: #9898AA;
  --text-dim: #5C5C70;
  --heading: 'Montserrat', sans-serif;
  --body: 'Roboto', sans-serif;
  --max: 1200px;
  --max-narrow: 740px;
  --radius: 12px;
  --radius-sm: 8px;
  --punch: cubic-bezier(0.22, 1.2, 0.36, 1);
  --snap: cubic-bezier(0.5, 0, 0, 1.15);
  --slam: cubic-bezier(0.05, 0.9, 0.2, 1.2);
}

/* ---- RESET ---- */
*, *::before, *::after { margin:0; padding:0; box-sizing:border-box; }
html { scroll-behavior:smooth; -webkit-font-smoothing:antialiased; }
body { font-family:var(--body); background:var(--bg); color:var(--text); line-height:1.65; font-weight:400; overflow-x:hidden; }
img { max-width:100%; height:auto; display:block; }
a { color:inherit; text-decoration:none; }

/* ---- LAYOUT ---- */
.container { max-width:var(--max); margin:0 auto; padding:0 2rem; }
.container--narrow { max-width:var(--max-narrow); }

/* ---- NAV ---- */
.site-nav {
  position:fixed; top:0; left:0; right:0; z-index:1000;
  background:rgba(11,11,15,0.6);
  backdrop-filter:blur(20px) saturate(1.4);
  -webkit-backdrop-filter:blur(20px) saturate(1.4);
  border-bottom:1px solid var(--border);
  transition:background 0.3s;
}
.nav-inner {
  max-width:var(--max); margin:0 auto; padding:0 2rem;
  height:64px; display:flex; align-items:center; justify-content:space-between;
}
.nav-logo {
  display:flex; align-items:center; gap:0.6rem;
  font-family:var(--heading); font-weight:800; font-size:1rem;
  letter-spacing:0.08em; color:var(--text);
  transition:transform 0.2s var(--punch);
}
.nav-logo:hover { transform:scale(1.04); }
.nav-logo img { border-radius:6px; }
.nav-links { display:flex; align-items:center; gap:2rem; }
.nav-link {
  font-family:var(--heading); font-size:0.8rem; font-weight:600;
  letter-spacing:0.06em; text-transform:uppercase;
  color:var(--text-secondary); transition:color 0.15s, transform 0.2s var(--punch);
  position:relative;
}
.nav-link::after {
  content:''; position:absolute; bottom:-4px; left:50%; width:0; height:2px;
  background:var(--red-bright); transition:width 0.25s var(--snap), left 0.25s var(--snap);
}
.nav-link:hover { color:var(--text); transform:translateY(-1px); }
.nav-link:hover::after { width:100%; left:0; }
.nav-cta {
  display:inline-flex; align-items:center; gap:0.4rem;
  font-family:var(--heading); font-size:0.75rem; font-weight:700;
  letter-spacing:0.06em; text-transform:uppercase;
  padding:0.5rem 1.2rem; border-radius:6px;
  color:#fff; transition:all 0.2s var(--punch);
}
.nav-cta--discord { background:#5865F2; }
.nav-cta--discord:hover { background:#4752C4; transform:scale(1.06); box-shadow:0 4px 20px rgba(88,101,242,0.4); }
.nav-cta:active { transform:scale(0.95); }
.nav-toggle {
  display:none; background:none; border:none; cursor:pointer;
  width:28px; height:20px; position:relative; flex-direction:column; justify-content:space-between;
}
.nav-toggle span {
  display:block; width:100%; height:2px; background:var(--text); border-radius:2px;
  transition:all 0.3s;
}
@media(max-width:768px) {
  .nav-toggle { display:flex; }
  .nav-links {
    display:none; position:absolute; top:64px; left:0; right:0;
    background:rgba(11,11,15,0.97); backdrop-filter:blur(20px);
    flex-direction:column; padding:1.5rem 2rem; gap:1rem;
    border-bottom:1px solid var(--border);
  }
  .nav-open .nav-links { display:flex; }
}

/* ---- BUTTONS ---- */
.btn {
  display:inline-flex; align-items:center; gap:0.5rem;
  font-family:var(--heading); font-weight:700; font-size:0.8rem;
  letter-spacing:0.05em; text-transform:uppercase;
  padding:0.75rem 1.8rem; border-radius:var(--radius-sm);
  border:none; cursor:pointer;
  transition:all 0.2s var(--punch);
  text-decoration:none; white-space:nowrap;
  position:relative; overflow:hidden;
}
.btn::after {
  content:''; position:absolute; inset:0;
  background:rgba(255,255,255,0.15); opacity:0;
  transition:opacity 0.15s;
}
.btn:active::after { opacity:1; }
.btn:active { transform:scale(0.94) !important; transition-duration:0.08s; }

.btn .material-icons-round { font-size:1.1em; }

/* Brand-colored buttons */
.btn-red { background:var(--red); color:#fff; }
.btn-red:hover { background:var(--red-bright); transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(178,42,42,0.4); }

.btn-discord { background:#5865F2; color:#fff; }
.btn-discord:hover { background:#4752C4; color:#fff; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(88,101,242,0.4); }

.btn-itchio { background:#FA5C5C; color:#fff; }
.btn-itchio:hover { background:#e04444; color:#fff; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(250,92,92,0.3); }

.btn-reddit { background:#FF4500; color:#fff; }
.btn-reddit:hover { background:#CC3700; color:#fff; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(255,69,0,0.3); }

.btn-steam { background:#1b2838; color:#c7d5e0; }
.btn-steam:hover { background:#2a475e; color:#fff; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(27,40,56,0.5); }

.btn-youtube { background:#FF0000; color:#fff; }
.btn-youtube:hover { background:#CC0000; color:#fff; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 30px rgba(255,0,0,0.3); }

.btn-white { background:#fff; color:var(--bg); }
.btn-white:hover { background:#e8e8e8; transform:translateY(-2px) scale(1.03); box-shadow:0 8px 24px rgba(255,255,255,0.1); }
.btn-ghost { background:transparent; color:var(--text-secondary); border:1px solid var(--border-strong); }
.btn-ghost:hover { color:var(--text); border-color:var(--text-secondary); transform:translateY(-2px); }
.btn-outline-light { background:transparent; color:var(--text-secondary); border:1px solid var(--border-strong); }
.btn-outline-light:hover { color:var(--text); border-color:rgba(255,255,255,0.3); transform:translateY(-2px); }
.btn-sm { font-size:0.7rem; padding:0.5rem 1rem; }

/* ---- HERO ---- */
.hero {
  position:relative; min-height:100vh;
  display:flex; align-items:center; justify-content:center;
  text-align:center; overflow:hidden;
}
.hero-bg {
  position:absolute; inset:0;
  background:
    radial-gradient(ellipse 80% 60% at 50% 40%, rgba(178,42,42,0.08) 0%, transparent 70%),
    radial-gradient(circle at 20% 80%, rgba(178,42,42,0.04) 0%, transparent 50%);
}
.hero-inner { position:relative; z-index:1; max-width:800px; padding:2rem; }

/* Hero brand — slams in from above with overshoot */
.hero-brand {
  width:min(500px, 80vw); margin:0 auto 2rem;
  animation:slamDown 0.6s var(--slam) both;
}

/* Tagline — punches in from the left */
.hero-tagline {
  font-family:var(--heading); font-size:clamp(1.5rem, 4vw, 2.5rem);
  font-weight:800; letter-spacing:-0.02em; margin-bottom:0.5rem;
  animation:punchRight 0.5s 0.3s var(--snap) both;
}

/* Sub text — snaps in */
.hero-sub {
  font-size:1.1rem; color:var(--text-secondary); margin-bottom:2.5rem;
  animation:punchRight 0.5s 0.45s var(--snap) both;
}

/* Buttons — pop up with bounce */
.hero-actions {
  display:flex; gap:1rem; justify-content:center; flex-wrap:wrap;
  animation:popUp 0.4s 0.6s var(--slam) both;
}

.hero-scroll {
  position:absolute; bottom:2rem; left:50%; transform:translateX(-50%);
  color:var(--text-dim); animation:punchBounce 1.6s 1s infinite;
}

@keyframes slamDown {
  0% { opacity:0; transform:translateY(-60px) scale(1.15); }
  60% { opacity:1; transform:translateY(6px) scale(0.98); }
  100% { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes punchRight {
  0% { opacity:0; transform:translateX(-40px); }
  100% { opacity:1; transform:translateX(0); }
}
@keyframes popUp {
  0% { opacity:0; transform:translateY(20px) scale(0.9); }
  100% { opacity:1; transform:translateY(0) scale(1); }
}
@keyframes punchBounce {
  0%,100% { transform:translateX(-50%) translateY(0); }
  30% { transform:translateX(-50%) translateY(10px); }
  50% { transform:translateX(-50%) translateY(-2px); }
  70% { transform:translateX(-50%) translateY(6px); }
}

/* ---- SCROLL REVEAL ---- */
.game-entry, .blog-card, .press-card, .blog-preview, .section-label, .discord-section {
  opacity:0; transform:translateY(30px);
  transition:opacity 0.5s var(--snap), transform 0.5s var(--snap);
}
.game-entry.visible, .blog-card.visible, .press-card.visible,
.blog-preview.visible, .section-label.visible, .discord-section.visible {
  opacity:1; transform:translateY(0);
}

/* stagger children */
.game-entry:nth-child(2) { transition-delay:0.08s; }
.game-entry:nth-child(3) { transition-delay:0.16s; }
.game-entry:nth-child(4) { transition-delay:0.24s; }

/* ---- SECTION LABELS ---- */
.section-label {
  font-family:var(--heading); font-size:0.75rem; font-weight:700;
  letter-spacing:0.15em; text-transform:uppercase;
  color:var(--red-bright); margin-bottom:1rem;
}
.section-header {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:2rem;
}
.section-all {
  font-family:var(--heading); font-size:0.8rem; font-weight:600;
  color:var(--text-secondary); transition:color 0.15s, transform 0.2s var(--punch);
  display:inline-block;
}
.section-all:hover { color:var(--red-bright); transform:translateX(4px); }

/* ---- GAMES CATALOG ---- */
.games { padding:8rem 0; }

/* Coming soon */
.coming-soon {
  text-align:center; padding:4rem 0;
}
.coming-soon-icon {
  font-size:3rem; color:var(--text-dim); margin-bottom:1rem;
  display:block; animation:punchBounce 2s infinite;
}
.coming-soon-title {
  font-family:var(--heading); font-size:2rem; font-weight:900;
  letter-spacing:-0.02em; margin-bottom:0.5rem;
}
.coming-soon-sub {
  color:var(--text-secondary); font-size:1.05rem;
}

.game-entry {
  padding:2.5rem 0; border-bottom:1px solid var(--border);
  transition:opacity 0.5s var(--snap), transform 0.5s var(--snap);
}
.game-entry:first-of-type { border-top:1px solid var(--border); }
.game-entry-head {
  display:flex; align-items:center; gap:1rem; margin-bottom:0.3rem;
}

/* Title hover — punchy red flash */
.game-title {
  font-family:var(--heading); font-size:1.75rem; font-weight:900;
  letter-spacing:-0.02em; margin-bottom:0.25rem;
  transition:color 0.15s, transform 0.2s var(--punch);
  display:inline-block;
}
.game-entry:hover .game-title {
  color:var(--red-bright); transform:translateX(6px);
}

.game-badge {
  display:inline-block; font-family:var(--heading);
  font-size:0.65rem; font-weight:700; letter-spacing:0.1em;
  text-transform:uppercase; padding:0.3rem 0.8rem;
  border-radius:4px; margin-bottom:0.75rem;
  transition:transform 0.2s var(--punch);
}
.game-entry:hover .game-badge { transform:scale(1.08); }
.game-badge--in-development { background:rgba(178,42,42,0.15); color:var(--red-bright); }
.game-badge--planned { background:rgba(255,255,255,0.06); color:var(--text-secondary); }
.game-badge--upcoming { background:rgba(255,180,0,0.12); color:#FFB400; }
.game-badge--released { background:rgba(50,200,100,0.12); color:#32C864; }

.game-tagline {
  font-size:1.05rem; color:var(--red-bright); font-weight:500;
  margin-bottom:1rem;
}
.game-desc {
  color:var(--text-secondary); font-size:0.95rem; line-height:1.7;
  margin-bottom:1.25rem;
}
.game-features {
  list-style:none; margin-bottom:1.5rem;
}
.game-features li {
  font-size:0.85rem; color:var(--text-secondary);
  padding:0.3rem 0; padding-left:1.2rem; position:relative;
}
.game-features li::before {
  content:''; position:absolute; left:0; top:0.7rem;
  width:6px; height:6px; background:var(--red); border-radius:1px;
  transform:rotate(45deg); transition:transform 0.3s var(--slam);
}
.game-entry:hover .game-features li::before {
  transform:rotate(45deg) scale(1.4);
}
.game-links { display:flex; gap:0.75rem; flex-wrap:wrap; }

@media(max-width:768px) {
  .game-entry-head { flex-wrap:wrap; }
}

/* ---- BLOG ---- */
.blog-preview { padding:4rem 0 6rem; }
.blog-list { padding:0 0 6rem; }

.blog-grid {
  display:grid; grid-template-columns:repeat(auto-fill, minmax(320px, 1fr));
  gap:1.5rem;
}
.blog-card {
  background:var(--bg-elevated); border:1px solid var(--border);
  border-radius:var(--radius); overflow:hidden;
  transition:border-color 0.2s, transform 0.3s var(--punch), box-shadow 0.3s;
}
.blog-card:hover {
  border-color:var(--red); transform:translateY(-5px) scale(1.01);
  box-shadow:0 12px 40px rgba(178,42,42,0.12);
}
.blog-card:active {
  transform:translateY(-2px) scale(0.99); transition-duration:0.1s;
}
.blog-card-img img {
  width:100%; aspect-ratio:16/9; object-fit:cover;
}
.blog-card-body { padding:1.5rem; }
.blog-card-body time {
  font-family:var(--heading); font-size:0.7rem; font-weight:600;
  letter-spacing:0.08em; text-transform:uppercase;
  color:var(--text-dim);
}
.blog-card-body h3 {
  font-family:var(--heading); font-size:1.15rem; font-weight:700;
  margin:0.4rem 0 0.6rem; letter-spacing:-0.01em;
  transition:color 0.15s;
}
.blog-card:hover .blog-card-body h3 { color:var(--red-bright); }
.blog-card-body p {
  font-size:0.9rem; color:var(--text-secondary); line-height:1.6;
}

/* ---- POST ---- */
.post { padding:8rem 0 4rem; }
.post-meta {
  display:flex; justify-content:space-between; align-items:center;
  margin-bottom:1.5rem;
}
.post-meta a {
  font-family:var(--heading); font-size:0.8rem; font-weight:600;
  color:var(--text-secondary); transition:color 0.15s, transform 0.2s var(--punch);
  display:inline-block;
}
.post-meta a:hover { color:var(--red-bright); transform:translateX(-4px); }
.post-meta time { font-size:0.8rem; color:var(--text-dim); }
.post-title {
  font-family:var(--heading); font-size:clamp(2rem, 5vw, 3rem);
  font-weight:900; letter-spacing:-0.025em; line-height:1.15;
  margin-bottom:2rem;
  animation:punchRight 0.5s var(--snap) both;
}
.post-cover { border-radius:var(--radius); margin-bottom:2.5rem; }
.post-body { font-size:1.05rem; line-height:1.85; color:var(--text-secondary); }
.post-body h2 { font-family:var(--heading); font-size:1.5rem; font-weight:800; color:var(--text); margin:2.5rem 0 0.75rem; }
.post-body h3 { font-family:var(--heading); font-size:1.2rem; font-weight:700; color:var(--text); margin:2rem 0 0.5rem; }
.post-body p { margin-bottom:1.25rem; }
.post-body strong { color:var(--text); font-weight:600; }
.post-body a {
  color:var(--red-bright); text-decoration:underline; text-underline-offset:3px;
  transition:color 0.15s;
}
.post-body a:hover { color:#fff; }
.post-body ul, .post-body ol { margin:0.5rem 0 1.25rem 1.5rem; }
.post-body li { margin-bottom:0.35rem; }
.post-body blockquote {
  border-left:3px solid var(--red); padding:0.75rem 1.25rem;
  margin:1.25rem 0; background:var(--bg-elevated); border-radius:0 var(--radius-sm) var(--radius-sm) 0;
}
.post-body code {
  font-family:'JetBrains Mono', monospace; font-size:0.88em;
  background:var(--surface); padding:0.15em 0.4em; border-radius:4px;
}
.post-body pre {
  background:var(--surface); padding:1.25rem; border-radius:var(--radius-sm);
  overflow-x:auto; margin-bottom:1.25rem;
}
.post-body pre code { background:none; padding:0; }
.post-body img { border-radius:var(--radius); margin:1.5rem 0; }

/* ---- PAGE HERO ---- */
.page-hero {
  padding:8rem 0 3rem; text-align:center;
}
.page-hero h1 {
  font-family:var(--heading); font-size:clamp(2rem, 5vw, 3rem);
  font-weight:900; letter-spacing:-0.02em; max-width:600px; margin:0 auto;
  animation:slamDown 0.6s var(--slam) both;
}


/* ---- DISCORD SECTION ---- */
.discord-section { padding:4rem 0 6rem; }
.discord-widget-wrap {
  max-width:420px; margin:0 auto;
}
.discord-widget-wrap iframe {
  border-radius:var(--radius); border:1px solid var(--border);
  display:block;
}


/* ---- FOOTER ---- */
.site-footer {
  border-top:1px solid var(--border);
  padding:3rem 0 2rem;
}
.footer-top {
  display:grid; grid-template-columns:2fr 1fr 1fr;
  gap:3rem; margin-bottom:2.5rem;
}
.footer-logo { width:180px; margin-bottom:0.75rem; }
.footer-brand p { font-size:0.9rem; color:var(--text-dim); }
.footer-col h4 {
  font-family:var(--heading); font-size:0.7rem; font-weight:700;
  letter-spacing:0.12em; text-transform:uppercase;
  color:var(--text-dim); margin-bottom:0.75rem;
}
.footer-col a {
  display:flex; align-items:center; gap:0.5rem;
  font-size:0.9rem; color:var(--text-secondary);
  padding:0.25rem 0; transition:color 0.15s, transform 0.2s var(--punch);
}
.footer-col a:hover { color:var(--text); transform:translateX(4px); }
.footer-social--discord:hover { color:#5865F2; }
.footer-social--itchio:hover { color:#FA5C5C; }
.footer-social--reddit:hover { color:#FF4500; }
.footer-social--steam:hover { color:#c7d5e0; }
.footer-social--youtube:hover { color:#FF0000; }
.footer-bottom {
  padding-top:1.5rem; border-top:1px solid var(--border);
  font-size:0.8rem; color:var(--text-dim);
  display:flex; justify-content:space-between; align-items:center; flex-wrap:wrap; gap:0.5rem;
}
.footer-badge {
  font-size:0.78rem; color:rgba(255,255,255,0.7);
  text-decoration:none; transition:opacity 0.2s;
}
.footer-badge:hover { opacity:0.8; }
.footer-badge .badge-muted { color:#555; }
.footer-badge strong { font-weight:700; color:rgba(255,255,255,0.7); }
.footer-badge .badge-green { color:#16a34a; }
@media(max-width:768px) {
  .footer-top { grid-template-columns:1fr; gap:2rem; }
}


/* ---- DEFAULT ---- */
.default-section { padding:0 0 4rem; }
.list-item { padding:0.75rem 0; border-bottom:1px solid var(--border); }
.list-item a { font-weight:500; color:var(--text-secondary); transition:color 0.15s, transform 0.2s var(--punch); display:inline-block; }
.list-item a:hover { color:var(--text); transform:translateX(4px); }

/* ---- SELECTION ---- */
/* ---- ICON HELPERS ---- */
.mi-inline { font-size:inherit; vertical-align:middle; margin-right:4px; }
.iconify { font-size:1.1em; vertical-align:middle; }

/* ---- SELECTION ---- */
::selection { background:rgba(178,42,42,0.3); color:#fff; }

/* ---- SCROLLBAR ---- */
::-webkit-scrollbar { width:8px; }
::-webkit-scrollbar-track { background:var(--bg); }
::-webkit-scrollbar-thumb { background:var(--surface); border-radius:4px; }
::-webkit-scrollbar-thumb:hover { background:var(--text-dim); }

/* ---- SCROLL-TRIGGERED REVEAL (JS-free via IntersectionObserver in inline script) ---- */
