/* ════════════════════════════════════════════════════════════
   VAIBHAV SHRESTH — PORTFOLIO  |  v3 PEAK EDITION
   ════════════════════════════════════════════════════════════ */

/* ── Variables ─────────────────────────────────────────────── */
:root {
  --bg:       #02050d;
  --bg-2:     #05091a;
  --bg-3:     #080e24;
  --surface:  #060b1a;
  --surface-2:#0c1428;
  --surface-3:#111e38;
  --text:     #e2eaff;
  --text-2:   #6b82aa;
  --text-3:   #354060;
  --a:   #6366f1;
  --a-d: #4f46e5;
  --a-2: #8b5cf6;
  --a-3: #06b6d4;
  --a-4: #f43f5e;
  --ag:  rgba(99,102,241,0.32);
  --ag2: rgba(139,92,246,0.22);
  --ag3: rgba(6,182,212,0.22);
  --border:   rgba(99,102,241,0.09);
  --border-s: rgba(99,102,241,0.22);
  --border-b: rgba(99,102,241,0.42);
  --nav-bg:   rgba(2,5,13,0.82);
  --footer-bg:#01030a;
  --sh-sm: 0 2px 12px rgba(0,0,0,0.6);
  --sh:    0 8px 40px rgba(0,0,0,0.7);
  --sh-lg: 0 24px 80px rgba(0,0,0,0.8);
  --sh-xl: 0 40px 120px rgba(0,0,0,0.9);
  --r:  16px;
  --r-l:24px;
  --nav-h: 68px;
  --ease: cubic-bezier(0.4,0,0.2,1);
  --spring: cubic-bezier(0.175,0.885,0.32,1.275);
  --bounce: cubic-bezier(0.34,1.56,0.64,1);
  --tr: all 0.35s var(--ease);
  --tr-f: all 0.16s var(--ease);
}
[data-theme="light"] {
  --bg:       #f0f4ff;
  --bg-2:     #e6ecff;
  --bg-3:     #d8e2ff;
  --surface:  #ffffff;
  --surface-2:#f5f7ff;
  --surface-3:#edf0ff;
  --text:     #0a0e1a;
  --text-2:   #4a5880;
  --text-3:   #8a9ab8;
  --a:   #6366f1;
  --a-d: #4f46e5;
  --a-2: #8b5cf6;
  --a-3: #0891b2;
  --a-4: #e11d48;
  --ag:  rgba(99,102,241,0.25);
  --ag2: rgba(139,92,246,0.18);
  --ag3: rgba(8,145,178,0.18);
  --border:   rgba(99,102,241,0.1);
  --border-s: rgba(99,102,241,0.22);
  --border-b: rgba(99,102,241,0.45);
  --nav-bg:   rgba(240,244,255,0.88);
  --footer-bg:#0a0e1a;
  --sh-sm: 0 2px 12px rgba(99,102,241,0.08);
  --sh:    0 8px 40px rgba(99,102,241,0.1);
  --sh-lg: 0 24px 80px rgba(99,102,241,0.14);
  --sh-xl: 0 40px 120px rgba(99,102,241,0.18);
}

/* ── Aliases for backwards-compat with inline page styles ─────── */
:root {
  --accent: var(--a); --accent-dark: var(--a-d); --accent-2: var(--a-2); --accent-3: var(--a-3);
  --accent-glow: var(--ag);
  --border-strong: var(--border-s);
  --radius: var(--r); --radius-lg: var(--r-l);
  --nav-bg-alias: var(--nav-bg);
  --shadow-sm: var(--sh-sm); --shadow: var(--sh); --shadow-lg: var(--sh-lg); --shadow-xl: var(--sh-xl);
  --ease-alias: var(--ease); --trans: var(--tr); --trans-fast: var(--tr-f); --spring-alias: var(--spring);
  --surface-alias: var(--surface);
}

/* ── Reset ──────────────────────────────────────────────────── */
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box;}
html{scroll-behavior:smooth;font-size:16px;}
body{
  font-family:'Inter',system-ui,-apple-system,sans-serif;
  background:var(--bg); color:var(--text);
  line-height:1.65; overflow-x:hidden;
  transition:background-color 0.5s ease,color 0.4s ease;
}
a{color:inherit;text-decoration:none;}
img{max-width:100%;display:block;}

/* ── Noise texture overlay ──────────────────────────────────── */
body::before{
  content:'';position:fixed;inset:0;z-index:9995;pointer-events:none;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:0.028;
}

/* ── Grid bg ────────────────────────────────────────────────── */
body::after{
  content:'';position:fixed;inset:0;z-index:0;pointer-events:none;
  background-image:
    linear-gradient(var(--border) 1px,transparent 1px),
    linear-gradient(90deg,var(--border) 1px,transparent 1px);
  background-size:72px 72px;
  mask-image:radial-gradient(ellipse 80% 80% at 50% 50%,black 20%,transparent 100%);
}

/* ── Loading screen ─────────────────────────────────────────── */
#loader{
  position:fixed;inset:0;z-index:9999;
  background:var(--bg);
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:28px;
  transition:opacity 0.6s var(--ease),transform 0.6s var(--ease);
}
#loader.out{opacity:0;pointer-events:none;}
.loader-logo{
  font-size:3.5rem;font-weight:900;letter-spacing:-0.06em;
  background:linear-gradient(135deg,var(--a),var(--a-2),var(--a-3));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  animation:loaderPulse 1.8s ease-in-out infinite;
}
@keyframes loaderPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.65;transform:scale(0.97)}}
.loader-bar{width:160px;height:2px;background:rgba(255,255,255,0.08);border-radius:1px;overflow:hidden;}
.loader-fill{
  height:100%;border-radius:1px;width:0%;
  background:linear-gradient(90deg,var(--a),var(--a-2),var(--a-3));
  box-shadow:0 0 12px var(--ag);
  animation:loaderFill 1.6s cubic-bezier(0.4,0,0.2,1) forwards;
}
@keyframes loaderFill{0%{width:0%}60%{width:75%}100%{width:100%}}
.loader-text{
  font-size:0.75rem;font-weight:600;letter-spacing:0.2em;text-transform:uppercase;
  color:var(--text-3);animation:loaderPulse 1.8s ease-in-out infinite 0.3s;
}

/* ── Custom cursor ──────────────────────────────────────────── */
#c-ring{
  position:fixed;top:0;left:0;z-index:9997;pointer-events:none;
  width:38px;height:38px;border-radius:50%;
  border:1.5px solid rgba(99,102,241,0.55);
  will-change:transform;
  transition:width 0.3s var(--ease),height 0.3s var(--ease),
             border-color 0.3s,background 0.3s;
}
#c-dot{
  position:fixed;top:0;left:0;z-index:9998;pointer-events:none;
  width:5px;height:5px;border-radius:50%;
  background:var(--a);will-change:transform;
  box-shadow:0 0 8px var(--ag);
}
body.cursor-hover #c-ring{
  width:56px;height:56px;
  border-color:rgba(99,102,241,0.9);
  background:rgba(99,102,241,0.06);
}
body.cursor-click #c-ring{
  width:26px;height:26px;
  background:rgba(99,102,241,0.15);
}

/* ── Page transitions — opacity only, no transforms ────────── */
/* #page-overlay removed — it caused a viewport-blue flash on every page */

/* transform on body breaks position:fixed children — opacity only */
@keyframes pageIn{from{opacity:0}to{opacity:1}}
body{animation:pageIn 0.5s ease both;}
.page-exit{opacity:0;transition:opacity 0.28s ease;}

/* ── Scroll progress ────────────────────────────────────────── */
#scroll-progress{
  position:fixed;top:0;left:0;height:2px;width:0%;z-index:9996;
  background:linear-gradient(90deg,var(--a-d),var(--a),var(--a-2),var(--a-3));
  box-shadow:0 0 16px var(--ag),0 0 32px var(--ag2);
  border-radius:0 2px 2px 0;
}

/* ── Background canvas ──────────────────────────────────────── */
#bg-canvas{
  position:fixed;top:0;left:0;width:100%;height:100%;
  z-index:0;pointer-events:none;
}

/* ── Background blobs ───────────────────────────────────────── */
.bg-blob{position:fixed;pointer-events:none;z-index:0;border-radius:50%;filter:blur(120px);}
.bg-blob-1{
  width:800px;height:800px;
  background:rgba(99,102,241,0.055);
  top:-250px;right:-200px;
  animation:blob1 22s ease-in-out infinite;
}
.bg-blob-2{
  width:600px;height:600px;
  background:rgba(139,92,246,0.04);
  bottom:-100px;left:-200px;
  animation:blob2 28s ease-in-out infinite;
}
.bg-blob-3{
  width:400px;height:400px;
  background:rgba(6,182,212,0.03);
  top:40%;right:15%;
  animation:blob3 18s ease-in-out infinite;
}
/* Blob animations — opacity only, NO transform (transform on fixed elements
   can cause GPU compositing bugs that make fixed siblings scroll with page) */
@keyframes blob1{0%,100%{opacity:0.9}50%{opacity:0.5}}
@keyframes blob2{0%,100%{opacity:0.8}50%{opacity:0.4}}
@keyframes blob3{0%,100%{opacity:0.7}33%{opacity:0.3}66%{opacity:0.6}}

/* ── Nav ────────────────────────────────────────────────────── */
.nav{
  position:fixed;top:0;left:0;right:0;height:var(--nav-h);
  background:var(--nav-bg);
  backdrop-filter:blur(48px) saturate(200%);
  -webkit-backdrop-filter:blur(48px) saturate(200%);
  border-bottom:1px solid var(--border);
  z-index:500;
  display:flex;align-items:center;justify-content:space-between;
  padding:0 52px;
  transition:background 0.5s,border-color 0.5s,box-shadow 0.4s;
}
.nav.scrolled{box-shadow:0 4px 60px rgba(0,0,0,0.4);border-bottom-color:var(--border-s);}

.nav-logo{
  font-size:1.45rem;font-weight:900;letter-spacing:-0.05em;
  background:linear-gradient(135deg,var(--a),var(--a-2),var(--a-3));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  background-size:200% auto;
  animation:gradShift 4s linear infinite;
  position:relative;
}
.nav-logo::after{
  content:'';position:absolute;bottom:-3px;left:0;right:0;height:1.5px;
  background:linear-gradient(90deg,var(--a),var(--a-3));
  transform:scaleX(0);transform-origin:left;
  transition:transform 0.4s var(--spring);
}
.nav-logo:hover::after{transform:scaleX(1);}

.nav-links{display:flex;gap:2px;list-style:none;}
.nav-links a{
  padding:8px 16px;border-radius:10px;
  font-size:0.87rem;font-weight:500;color:var(--text-2);
  transition:var(--tr);position:relative;
}
.nav-links a::before{
  content:'';position:absolute;bottom:4px;left:16px;right:16px;height:1.5px;
  background:linear-gradient(90deg,var(--a),var(--a-3));
  transform:scaleX(0);transition:transform 0.3s var(--spring);
}
.nav-links a:hover{color:var(--text);}
.nav-links a:hover::before,.nav-links a.active::before{transform:scaleX(1);}
.nav-links a.active{color:var(--a);font-weight:600;}

.nav-right{display:flex;align-items:center;gap:10px;}
.nav-cta{
  background:linear-gradient(135deg,var(--a-d),var(--a-2)) !important;
  color:white !important;
  box-shadow:0 4px 20px var(--ag) !important;
  position:relative;overflow:hidden;
}
.nav-cta::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.15),transparent);
  transform:translateX(-100%);
  transition:transform 0.5s ease;
}
.nav-cta:hover::before{transform:translateX(100%);}
.nav-cta:hover{transform:translateY(-2px)!important;box-shadow:0 10px 36px var(--ag)!important;}

/* Theme toggle */
.theme-toggle{
  width:38px;height:38px;border-radius:10px;
  background:var(--bg-3);border:1px solid var(--border);
  cursor:pointer;display:flex;align-items:center;justify-content:center;
  color:var(--text-2);transition:var(--tr);flex-shrink:0;
}
.theme-toggle:hover{
  background:var(--a);color:white;border-color:var(--a);
  box-shadow:0 0 24px var(--ag);
  transform:rotate(15deg) scale(1.1);
}
.icon-sun{display:block;}
.icon-moon{display:none;}
[data-theme="light"] .icon-sun{display:none;}
[data-theme="light"] .icon-moon{display:block;}

/* Hamburger */
.nav-hamburger{display:none;flex-direction:column;gap:5px;cursor:pointer;padding:8px;background:none;border:none;}
.nav-hamburger span{display:block;width:22px;height:2px;background:var(--text);border-radius:2px;transition:var(--tr);}
.nav-hamburger.open span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-hamburger.open span:nth-child(2){opacity:0;}
.nav-hamburger.open span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

@media(max-width:768px){
  .nav{padding:0 20px;}
  .nav-links{
    display:none;position:fixed;top:var(--nav-h);left:0;right:0;
    background:var(--bg-2);backdrop-filter:blur(24px);
    border-bottom:1px solid var(--border);
    flex-direction:column;padding:12px 20px 20px;gap:4px;
    box-shadow:var(--sh-lg);
  }
  .nav-links.open{display:flex;}
  .nav-hamburger{display:flex;}
  .nav-cta{display:none!important;}
}

/* ── Buttons ─────────────────────────────────────────────────── */
.btn{
  display:inline-flex;align-items:center;gap:8px;
  padding:13px 30px;border-radius:12px;
  font-size:0.93rem;font-weight:600;
  cursor:pointer;border:none;transition:var(--tr);
  text-decoration:none;white-space:nowrap;
  position:relative;isolation:isolate;overflow:hidden;
}
.btn::before{
  content:'';position:absolute;inset:0;
  background:linear-gradient(90deg,transparent,rgba(255,255,255,0.13),transparent);
  transform:translateX(-100%);transition:transform 0.5s ease;
}
.btn:hover::before{transform:translateX(100%);}

.btn-primary{
  background:linear-gradient(135deg,var(--a-d),var(--a),var(--a-2));
  color:white;background-size:200% auto;
  box-shadow:0 4px 24px var(--ag),0 0 0 0 var(--ag);
  animation:gradShift 4s linear infinite;
}
.btn-primary:hover{
  transform:translateY(-3px);
  box-shadow:0 16px 48px var(--ag),0 0 60px rgba(99,102,241,0.12);
}
.btn-ghost{
  background:transparent;color:var(--a);
  border:1.5px solid var(--border-s);
}
.btn-ghost:hover{
  background:var(--border);border-color:var(--a);
  transform:translateY(-3px);
  box-shadow:0 8px 32px var(--ag);
}
.btn-sm{padding:9px 22px;font-size:0.85rem;border-radius:10px;}

.btn-white{background:white;color:var(--a-d);box-shadow:0 8px 28px rgba(0,0,0,0.2);}
.btn-white:hover{transform:translateY(-3px);box-shadow:0 18px 48px rgba(0,0,0,0.25);}
.btn-white-outline{background:rgba(255,255,255,0.1);color:white;border:1.5px solid rgba(255,255,255,0.35);}
.btn-white-outline:hover{background:rgba(255,255,255,0.2);border-color:white;transform:translateY(-3px);}

/* ── Section layout ─────────────────────────────────────────── */
.section{padding:100px 52px;max-width:1240px;margin:0 auto;position:relative;z-index:1;}
.full-bg{background:var(--bg-2);transition:background 0.5s;}

.section-tag{
  display:inline-flex;align-items:center;gap:8px;
  padding:6px 16px;border-radius:20px;
  background:rgba(99,102,241,0.08);color:var(--a);
  border:1px solid var(--border-s);
  font-size:0.73rem;font-weight:700;letter-spacing:0.12em;text-transform:uppercase;
  margin-bottom:16px;
}
.section-tag::before{
  content:'';width:6px;height:6px;border-radius:50%;
  background:var(--a);box-shadow:0 0 8px var(--ag);
  animation:dotPulse 2s ease infinite;
}
@keyframes dotPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.5;transform:scale(0.75)}}

.section-title{
  font-size:clamp(2.2rem,4.5vw,3.4rem);
  font-weight:900;letter-spacing:-0.045em;line-height:1.08;
}
.section-sub{
  margin-top:14px;font-size:1.05rem;color:var(--text-2);
  max-width:560px;line-height:1.78;
}
.section-header{text-align:center;margin-bottom:72px;}
.section-header .section-sub{margin-left:auto;margin-right:auto;}

/* ── Gradient text (animated) ───────────────────────────────── */
.grad{
  background:linear-gradient(135deg,var(--a),var(--a-2),var(--a-3),var(--a));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
  background-size:300% auto;
  animation:gradShift 5s linear infinite;
}
@keyframes gradShift{0%{background-position:0% center}100%{background-position:300% center}}

/* ── Tags ────────────────────────────────────────────────────── */
.tag{
  display:inline-block;padding:4px 12px;
  background:var(--bg-3);border:1px solid var(--border);
  border-radius:20px;font-size:0.76rem;font-weight:500;color:var(--text-2);
  transition:var(--tr-f);
}
.tag-accent{background:rgba(99,102,241,0.1);color:var(--a);border-color:var(--border-s);}
.tag:hover{transform:translateY(-1px);}

/* ── Divider ─────────────────────────────────────────────────── */
.divider{
  width:60px;height:3px;border-radius:2px;
  background:linear-gradient(90deg,var(--a),var(--a-2),var(--a-3));
  margin:16px auto 0;
  box-shadow:0 0 20px var(--ag);
}

/* ── Reveal animations ───────────────────────────────────────── */
.reveal{opacity:0;transform:translateY(36px);transition:opacity 0.75s var(--ease),transform 0.75s var(--ease);}
.reveal.left{transform:translateX(-36px);}
.reveal.right{transform:translateX(36px);}
.reveal.scale{transform:scale(0.92);}
.reveal.visible{opacity:1;transform:translate(0) scale(1);}
.delay-1{transition-delay:0.08s;}.delay-2{transition-delay:0.16s;}
.delay-3{transition-delay:0.24s;}.delay-4{transition-delay:0.32s;}
.delay-5{transition-delay:0.42s;}.delay-6{transition-delay:0.52s;}

/* ── 3D tilt card ────────────────────────────────────────────── */
.tilt{transform-style:preserve-3d;will-change:transform;}

/* ── Glow card ───────────────────────────────────────────────── */
.glow-card{
  position:relative;
  background:var(--surface);
  border:1px solid var(--border);
  border-radius:var(--r);
  transition:var(--tr);
}
.glow-card::before{
  content:'';position:absolute;inset:-1px;border-radius:inherit;
  background:linear-gradient(135deg,var(--a),var(--a-2),var(--a-3),var(--a-2),var(--a));
  background-size:300% auto;
  opacity:0;z-index:-1;transition:opacity 0.4s;
  animation:gradShift 4s linear infinite;
}
.glow-card:hover::before{opacity:0.6;}
.glow-card:hover{
  border-color:transparent;
  box-shadow:0 0 40px rgba(99,102,241,0.15),var(--sh-lg);
}

/* ── Avatar with animated ring ───────────────────────────────── */
.avatar-wrap{
  width:130px;height:130px;border-radius:50%;
  margin:0 auto 20px;position:relative;flex-shrink:0;
}
.avatar-wrap::before{
  content:'';position:absolute;inset:-4px;border-radius:50%;
  background:linear-gradient(135deg,var(--a),var(--a-2),var(--a-3));
  animation:avatarSpin 5s linear infinite;z-index:0;
}
.avatar-wrap::after{
  content:'';position:absolute;inset:0;border-radius:50%;
  background:var(--surface);z-index:0;transform:scale(0.93);
}
@keyframes avatarSpin{from{transform:rotate(0deg)}to{transform:rotate(360deg)}}
.avatar-img{width:100%;height:100%;border-radius:50%;object-fit:cover;position:relative;z-index:1;transform:scale(0.93);}
.avatar-fallback{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,var(--a),var(--a-2));display:flex;align-items:center;justify-content:center;font-size:2.8rem;font-weight:900;color:white;position:relative;z-index:1;transform:scale(0.93);}

/* ── Tab active (fixed) ──────────────────────────────────────── */
.tab.active{background:var(--surface)!important;color:var(--a)!important;box-shadow:var(--sh-sm)!important;border:1px solid var(--border-s)!important;}

/* ── Social card icon (fixed) ────────────────────────────────── */
.social-card-icon{background:var(--bg-3)!important;transition:background 0.4s;}
.social-card:hover .social-card-icon{background:var(--surface-3)!important;}

/* ── Project banner ──────────────────────────────────────────── */
.proj-banner{transition:none;}
.proj-banner::before,.proj-banner::after{display:none;}
.proj-banner-img{
  position:absolute;inset:0;width:100%;height:100%;
  object-fit:cover;z-index:1;opacity:1;
  transition:transform 0.6s var(--ease);
}
.proj-card:hover .proj-banner-img{transform:scale(1.06);}
.proj-banner .banner-icon{z-index:2;display:none;}

/* ── CTA section ─────────────────────────────────────────────── */
.cta-section{
  text-align:center;padding:90px 52px;
  background:linear-gradient(135deg,#1a0a4e,var(--a),var(--a-2),#0a1a4e);
  background-size:300% auto;animation:gradShift 8s linear infinite;
  margin-top:80px;position:relative;z-index:1;overflow:hidden;
}
.cta-section::before{
  content:'';position:absolute;inset:0;
  background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='300' height='300'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.85' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity:0.04;pointer-events:none;
}
.cta-section h2{font-size:clamp(1.8rem,3.5vw,2.6rem);font-weight:900;color:white;letter-spacing:-0.04em;margin-bottom:12px;}
.cta-section p{color:rgba(255,255,255,0.8);font-size:1.05rem;margin-bottom:32px;}

/* ── Games section ───────────────────────────────────────────── */
.games-section{background:var(--bg-2);border-top:1px solid var(--border);border-bottom:1px solid var(--border);position:relative;z-index:1;}
.games-group{margin-bottom:64px;}
.games-group:last-child{margin-bottom:0;}
.games-group-header{display:flex;align-items:center;gap:12px;margin-bottom:28px;}
.status-pill{display:inline-flex;align-items:center;gap:7px;padding:5px 14px;border-radius:20px;font-size:0.78rem;font-weight:700;}
.status-pill.playing{background:rgba(16,185,129,0.1);color:#10b981;border:1px solid rgba(16,185,129,0.25);}
.status-pill.retired{background:var(--border);color:var(--text-3);border:1px solid var(--border-s);}
.status-pill.finished{background:rgba(99,102,241,0.12);color:var(--a);border:1px solid var(--border-s);}
.status-dot{width:7px;height:7px;border-radius:50%;background:currentColor;}
.status-pill.playing .status-dot{animation:sPulse 2s ease infinite;}
@keyframes sPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.4;transform:scale(0.75)}}
.game-card{border-radius:var(--r-l);overflow:hidden;border:1px solid var(--border);background:var(--surface);transition:var(--tr);position:relative;}
.game-card:hover{border-color:var(--border-s);box-shadow:var(--sh-lg);transform:translateY(-8px);}
.game-card.retired{opacity:0.65;filter:grayscale(0.3);}
.game-card.retired:hover{opacity:1;filter:none;}
.game-card.finished{opacity:0.72;}
.game-card.finished:hover{opacity:1;}
.game-img-wrap{height:130px;position:relative;overflow:hidden;}
.game-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform 0.5s ease;}
.game-card:hover .game-img{transform:scale(1.08);}
.game-img-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:3.2rem;}
.game-badge{position:absolute;top:9px;right:9px;z-index:2;padding:3px 10px;border-radius:20px;font-size:0.69rem;font-weight:700;backdrop-filter:blur(10px);display:flex;align-items:center;gap:5px;}
.game-badge.playing{background:rgba(16,185,129,0.88);color:white;}
.game-badge.retired{background:rgba(0,0,0,0.6);color:rgba(255,255,255,0.75);}
.game-badge.finished{background:rgba(99,102,241,0.85);color:white;}
.badge-pulse{width:6px;height:6px;border-radius:50%;background:white;animation:bPulse 2s ease infinite;flex-shrink:0;}
@keyframes bPulse{0%,100%{opacity:1;transform:scale(1)}50%{opacity:0.35;transform:scale(0.7)}}
.game-info{padding:13px 15px 15px;}
.game-name{font-size:0.92rem;font-weight:800;margin-bottom:3px;letter-spacing:-0.02em;line-height:1.3;}
.game-dev{font-size:0.75rem;color:var(--text-3);margin-bottom:9px;}
.game-tags{display:flex;flex-wrap:wrap;gap:5px;}
.game-tag{font-size:0.7rem;font-weight:600;padding:3px 9px;border-radius:20px;background:var(--border);color:var(--text-2);border:1px solid var(--border-s);}
.finished-check{position:absolute;top:9px;left:9px;z-index:2;width:22px;height:22px;border-radius:50%;background:rgba(99,102,241,0.85);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;font-size:11px;color:white;font-weight:900;}
.game-card.hidden{display:none;}
.steam-profile-btn{display:inline-flex;align-items:center;gap:8px;margin-top:24px;padding:11px 24px;border-radius:12px;background:rgba(23,26,33,0.85);color:#c7d5e0;border:1px solid rgba(199,213,224,0.2);font-size:0.9rem;font-weight:600;transition:var(--tr);text-decoration:none;backdrop-filter:blur(8px);}
.steam-profile-btn:hover{background:rgba(102,192,244,0.15);border-color:rgba(102,192,244,0.4);color:#66c0f4;transform:translateY(-2px);box-shadow:0 8px 24px rgba(102,192,244,0.15);}

/* ── Footer ──────────────────────────────────────────────────── */
footer{
  background:var(--footer-bg);
  color:rgba(255,255,255,0.3);
  text-align:center;padding:40px 24px;
  font-size:0.875rem;
  transition:background 0.5s;
  position:relative;z-index:1;
  border-top:1px solid var(--border);
}
footer a{color:var(--a-2);font-weight:500;}
footer a:hover{color:var(--a-3);}
footer strong{color:rgba(255,255,255,0.75);}

/* ── Scrollbar ───────────────────────────────────────────────── */
::-webkit-scrollbar{width:4px;}
::-webkit-scrollbar-track{background:transparent;}
::-webkit-scrollbar-thumb{background:linear-gradient(var(--a),var(--a-2),var(--a-3));border-radius:2px;}

/* ── Float keyframe ──────────────────────────────────────────── */
@keyframes float{0%,100%{transform:translateY(0)}50%{transform:translateY(-10px)}}
@keyframes floatR{0%,100%{transform:translateY(0) rotate(0deg)}50%{transform:translateY(-8px) rotate(3deg)}}

@media(max-width:768px){
  .section{padding:72px 20px;}
  .cta-section{padding:60px 20px;}
}
