* { box-sizing: border-box; margin: 0; padding: 0; }
:root {
    --bg-base:#0A0B0D;
    --bg-surface:#111316;
    --bg-elevated:#1A1C20;
    --border-subtle:#1F2227;
    --border-default:#2D3138;
    --border-strong:#3D4249;
    --text-primary:#F0F1F3;
    --text-secondary:#9DA3AE;
    --text-muted:#5A6070;
    --accent:#C8CAD0;
    --accent-hover:#E0E2E6;
    --accent-active:#A8AAB0;
    --accent-subtle:rgba(200,202,208,0.10);
    --accent-glow:rgba(200,202,208,0.20);
    --glass-bg:rgba(17,19,22,0.75);
    --glass-border:rgba(208,210,215,0.08);
    --glass-blur:12px;
    --success:#85C29A;
    --success-subtle:rgba(133,194,154,0.12);
    --danger:#D88592;
    --danger-subtle:rgba(216,133,146,0.12);
    --warning:#D4A76A;
    --warning-subtle:rgba(212,167,106,0.12);
    --discord:#5865F2;
    --steam:#66c0f4;

    --bg:var(--bg-base);
    --bg2:var(--bg-surface);
    --surface:var(--glass-bg);
    --surface2:var(--bg-elevated);
    --line:var(--border-subtle);
    --line2:var(--border-default);
    --text:var(--text-primary);
    --text2:var(--text-secondary);
    --muted:var(--text-muted);
    --dim:var(--text-muted);
    --moon:var(--accent);
    --moon-strong:var(--accent-hover);
    --moon-deep:var(--accent-active);
    --silver:var(--accent);

    --f-display:'Space Grotesk', system-ui, sans-serif;
    --f-body:'Outfit', system-ui, sans-serif;
    --f-mono:'JetBrains Mono', 'Fira Code', monospace;
    --text-2xs:11px;
    --text-xs:13px;
    --text-sm:14px;
    --text-base:16px;
    --text-md:18px;
    --text-lg:21px;
    --text-xl:28px;
    --text-2xl:37px;
    --text-3xl:48px;
    --text-4xl:64px;
    --text-display:80px;
    --text-hero:clamp(40px,8vw,80px);
    --text-h1:clamp(32px,5.5vw,64px);
    --text-h2:clamp(26px,3.5vw,37px);
    --fw-regular:400;
    --fw-medium:500;
    --fw-semibold:600;
    --fw-bold:700;
    --fw-extrabold:800;
    --lh-tight:1.1;
    --lh-snug:1.25;
    --lh-normal:1.5;
    --lh-relaxed:1.65;
    --ls-tighter:-0.03em;
    --ls-tight:-0.02em;
    --ls-normal:0;
    --ls-wide:0.04em;
    --ls-wider:0.08em;

    --space-1:4px;
    --space-2:8px;
    --space-3:12px;
    --space-4:16px;
    --space-5:20px;
    --space-6:24px;
    --space-8:32px;
    --space-10:40px;
    --space-12:48px;
    --space-16:64px;
    --space-20:80px;
    --space-24:96px;
    --space-30:120px;
    --space-40:160px;

    --radius-sm:4px;
    --radius-md:8px;
    --radius-lg:12px;
    --radius-xl:16px;
    --radius-2xl:24px;
    --radius-full:9999px;

    --shadow-sm:0 1px 3px rgba(0,0,0,0.4);
    --shadow-md:0 4px 12px rgba(0,0,0,0.5);
    --shadow-lg:0 8px 24px rgba(0,0,0,0.6);
    --shadow-xl:0 16px 48px rgba(0,0,0,0.7);
    --shadow-glow:0 0 24px rgba(200,202,208,0.12);
    --shadow-glow-lg:0 0 48px rgba(200,202,208,0.08);

    --ease:cubic-bezier(0.16,1,0.3,1);
    --ease-out:cubic-bezier(0.16,1,0.3,1);
    --ease-in-out:cubic-bezier(0.4,0,0.2,1);
    --ease-spring:cubic-bezier(0.34,1.56,0.64,1);
    --duration-instant:80ms;
    --duration-fast:150ms;
    --duration-normal:250ms;
    --duration-slow:400ms;
}
html { scroll-behavior: smooth; -webkit-text-size-adjust: 100%; }
body {
    font-family: var(--f-body);
    background: var(--bg);
    color: var(--text);
    min-height: 100vh;
    -webkit-font-smoothing: antialiased;
    -moz-osx-font-smoothing: grayscale;
    text-rendering: optimizeLegibility;
    font-feature-settings: "kern", "liga", "calt", "ss01";
    line-height: 1.6;
    font-size: 15.5px;
    letter-spacing: .005em;
    overflow-x: hidden;
    position: relative;
}
h1, h2, h3, h4, h5, h6 {
    font-family: var(--f-display);
    letter-spacing: .02em;
    text-rendering: optimizeLegibility;
}

#bg-video {
    position: fixed; inset: 0; z-index: 0;
    width: 100%; height: 100%;
    object-fit: cover;
    opacity: .65;
    filter: saturate(95%) contrast(108%) brightness(95%);
    background: #0D0B22;
}

#bg-veil {
    position: fixed; inset: 0; z-index: 1;
    background:
        radial-gradient(ellipse 100% 70% at 50% 40%, transparent 0%, rgba(10, 11, 13,.30) 60%, var(--bg) 100%),
        linear-gradient(180deg, rgba(10, 11, 13,.30) 0%, rgba(10, 11, 13,.10) 30%, rgba(10, 11, 13,.55) 75%, var(--bg) 100%);
    pointer-events: none;
}
#bg-grain {
    position: fixed; inset: 0; z-index: 1;
    background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='.85' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
    opacity: .03;
    pointer-events: none;
}

.back { position: fixed; top: 1.2rem; left: 1.2rem; z-index: 999; padding: .5rem 1rem; background: rgba(17, 19, 22,.85); border: 1px solid var(--line); border-radius: 6px; color: var(--text); font-size: .8rem; text-decoration: none; backdrop-filter: blur(5px); }

.nav {
    position: fixed; top: 0; left: 0; right: 0;
    z-index: 100;
    background: rgba(10, 11, 13,.45);
    backdrop-filter: blur(8px) saturate(140%);
    -webkit-backdrop-filter: blur(8px) saturate(140%);
    border-bottom: 1px solid rgba(255,255,255,.05);
    height: 64px;
    transition: background-color .3s var(--ease), backdrop-filter .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease), height .3s var(--ease);
}
.nav.is-scrolled {
    background: rgba(10, 11, 13, .55) !important;
    backdrop-filter: blur(12px) saturate(150%) !important;
    -webkit-backdrop-filter: blur(12px) saturate(150%) !important;
    border-bottom-color: rgba(255,255,255,.08) !important;
    box-shadow: 0 6px 20px rgba(0, 0, 0, .25) !important;
    height: 56px !important;
}

#ember-canvas { display: none !important; }
@media (prefers-reduced-motion: reduce) {
    #ember-canvas { display: none !important; }
}
.nav::after {
    content: '';
    position: absolute;
    left: 0; right: 0; bottom: -1px;
    height: 1px;
    background: linear-gradient(90deg, transparent 0%, rgba(200, 202, 208,.35) 50%, transparent 100%);
    pointer-events: none;
}
.nav-in {
    max-width: 1480px;
    margin: 0 auto;
    padding: 0 1.6rem;
    height: 100%;
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 1.5rem;
}
@media (max-width: 760px) { .nav-in { padding: 0 1rem; } }

.nav-logo { display: flex; align-items: center; flex-shrink: 0; }
.nav-logo-mark {
    width: 34px; height: 34px;
    display: flex;
    align-items: center;
    justify-content: center;
    color: var(--moon);
    transition: transform .25s var(--ease), filter .25s ease;
}
.nav-logo-mark:hover { transform: scale(1.08); filter: drop-shadow(0 0 10px rgba(200, 202, 208,.5)); }
.nav-logo-mark svg { width: 100%; height: 100%; }

.nav-links {
    display: flex;
    gap: .15rem;
    align-items: center;
    flex: 0 0 auto;
    justify-content: center;
}
.nav-links a {
    position: relative;
    display: inline-flex;
    align-items: center;
    padding: .55rem 1rem;
    color: var(--muted);
    text-decoration: none;
    font-family: var(--f-display);
    font-size: .82rem;
    font-weight: 600;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    border-radius: 6px;
    transition: color .2s ease, background .2s ease;
}
.nav-links a:hover { color: var(--text); background: rgba(255,255,255,.04); }
.nav-links a.act {
    color: var(--text);
    background: rgba(200, 202, 208,.10);
}
.nav-links a.act::before {
    content: '';
    position: absolute;
    left: 1rem; right: 1rem;
    bottom: .3rem;
    height: 2px;
    background: var(--moon);
    border-radius: 1px;
}

/* Server status dots (D) */
.nav-dots {
    display: flex;
    align-items: center;
    gap: .55rem;
    padding: 0 .3rem;
    flex-shrink: 0;
}
.nav-srv {
    display: flex !important;
    align-items: center !important;
    gap: .4rem !important;
    flex-shrink: 0 !important;
    padding-right: .2rem !important;
}
.nv-srv {
    position: relative !important;
    display: inline-flex !important;
    align-items: center !important;
    gap: .42rem !important;
    padding: .38rem .65rem .38rem .55rem !important;
    background: rgba(255,255,255,.04) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 999px !important;
    text-decoration: none !important;
    color: var(--text) !important;
    font-family: 'Rajdhani', sans-serif !important;
    transition: background .2s ease, border-color .2s ease, transform .2s cubic-bezier(.22,1,.36,1), box-shadow .2s ease !important;
    cursor: pointer !important;
}
.nv-srv:hover {
    background: rgba(200, 202, 208,.08) !important;
    border-color: rgba(200, 202, 208,.35) !important;
    transform: translateY(-1px) !important;
    box-shadow: 0 4px 14px -4px rgba(200, 202, 208,.3) !important;
}
.nv-srv-dot {
    width: 7px !important; height: 7px !important;
    border-radius: 50% !important;
    background: #4ade80 !important;
    box-shadow: 0 0 6px rgba(74,222,128,.7), 0 0 0 0 rgba(74,222,128,.6) !important;
    animation: nvSrvPulse 2.2s ease-out infinite !important;
    flex-shrink: 0 !important;
}
.nv-srv.off .nv-srv-dot {
    background: #ef4444 !important;
    box-shadow: 0 0 6px rgba(239,68,68,.6) !important;
    animation: none !important;
}
.nv-srv-tag {
    font-weight: 700 !important;
    font-size: .72rem !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase !important;
    color: #fff !important;
}
.nv-srv-num {
    font-family: var(--f-mono) !important;
    font-size: .72rem !important;
    color: var(--muted) !important;
    font-weight: 600 !important;
}
.nv-srv-num i {
    color: var(--dim) !important;
    font-style: normal !important;
    margin-left: 1px !important;
}
.nv-srv.off .nv-srv-num { color: var(--dim) !important; }

@keyframes nvSrvPulse {
    0%   { box-shadow: 0 0 6px rgba(74,222,128,.7), 0 0 0 0 rgba(74,222,128,.55); }
    70%  { box-shadow: 0 0 6px rgba(74,222,128,.7), 0 0 0 7px rgba(74,222,128,0); }
    100% { box-shadow: 0 0 6px rgba(74,222,128,.7), 0 0 0 0 rgba(74,222,128,0); }
}

.nv-dot {
    position: relative;
    width: 9px; height: 9px;
    border-radius: 50%;
    background: var(--success);
    box-shadow: 0 0 8px rgba(94, 234, 212,.65);
    cursor: default;
    transition: transform .2s var(--ease);
}
.nv-dot.off { background: var(--danger); box-shadow: 0 0 8px rgba(224,112,112,.65); }
.nv-dot:hover { transform: scale(1.3); }
.nv-dot::before, .nv-dot::after {
    position: absolute;
    top: calc(100% + 12px);
    left: 50%;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s var(--ease), transform .25s var(--ease);
}
.nv-dot::before {
    content: '';
    width: 8px; height: 8px;
    background: rgba(10, 7, 28,.95);
    border-left: 1px solid var(--line2);
    border-top: 1px solid var(--line2);
    transform: translate(-50%, calc(-100% + 4px)) rotate(45deg);
    top: calc(100% + 6px);
}
.nv-dot::after {
    content: attr(data-name) ' · ' attr(data-meta);
    transform: translate(-50%, 4px);
    padding: .45rem .7rem;
    background: rgba(10, 7, 28,.95);
    border: 1px solid var(--line2);
    border-radius: 6px;
    font-family: var(--f-mono);
    font-size: .68rem;
    color: var(--text);
    letter-spacing: .5px;
    white-space: nowrap;
    backdrop-filter: blur(4px);
}
.nv-dot:hover::before, .nv-dot:hover::after { opacity: 1; transform: translate(-50%, 0); }
.nv-dot:hover::before { transform: translate(-50%, calc(-100% + 4px)) rotate(45deg); }

.nav-actions { display: flex; align-items: center; gap: .7rem; flex: 1; justify-content: flex-end; }

/* Sparkline (G) */
.nav-spark {
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .38rem .75rem;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 999px;
    transition: border-color .2s, background .2s;
}
.nav-spark:hover { border-color: rgba(200, 202, 208,.30); background: rgba(200, 202, 208,.05); }
.nav-spark-svg {
    width: 64px;
    height: 20px;
    display: block;
    overflow: visible;
}
.nav-spark-line {
    fill: none;
    stroke: var(--moon);
    stroke-width: 1.4;
    stroke-linecap: round;
    stroke-linejoin: round;
    filter: drop-shadow(0 0 4px rgba(200, 202, 208,.5));
}
.nav-spark-fill {
    fill: url(#spark-grad);
    stroke: none;
    opacity: .6;
}
.nav-spark-lbl {
    font-family: var(--f-mono);
    font-size: .68rem;
    color: var(--muted);
    letter-spacing: 1px;
    text-transform: uppercase;
    font-weight: 600;
}
@media (max-width: 860px) { .nav-spark, .nav-dots { display: none; } }

.nav-status {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    padding: .42rem .75rem;
    background: rgba(255,255,255,.03);
    border: 1px solid rgba(255,255,255,.08);
    border-radius: 999px;
    font-family: var(--f-mono);
    font-size: .72rem;
    font-weight: 600;
    color: var(--text2);
    letter-spacing: .8px;
}
.nav-status .ns-dot {
    width: 6px; height: 6px;
    background: var(--success);
    border-radius: 50%;
    box-shadow: 0 0 8px rgba(94, 234, 212,.7);
    animation: breathe 2s ease-in-out infinite;
}
@media (max-width: 760px) { .nav-status { display: none; } }

.nav-cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    gap: .55rem;
    padding: .55rem 1.15rem .55rem 1rem;
    background: linear-gradient(135deg, var(--moon-deep) 0%, var(--moon) 100%);
    color: #04111E;
    border: 1px solid var(--moon);
    border-radius: 7px;
    text-decoration: none;
    font-family: var(--f-display);
    font-weight: 700;
    font-size: .82rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: filter .25s ease, transform .2s var(--ease), box-shadow .25s ease;
    box-shadow: 0 6px 20px -8px rgba(200, 202, 208,.55);
}
.nav-cta-icon {
    width: 18px; height: 18px;
    flex-shrink: 0;
}
.nav-cta:hover {
    filter: brightness(1.10);
    transform: translateY(-1px);
    box-shadow: 0 10px 28px -8px rgba(200, 202, 208,.7);
}
.nav-cta:active { transform: translateY(0); }

@media (max-width: 900px) {
    .nav-links { display: none; }
}

.app { position: relative; z-index: 2; }

/* HERO — vanity.gg cinematic */
.hero {
    min-height: 100vh;
    display: flex;
    align-items: flex-start;
    justify-content: center;
    text-align: center;
    padding: 18vh 2rem 5rem;
    position: relative;
}
.hero-content {
    max-width: 1100px;
    width: 100%;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 2.2rem;
}
@keyframes breathe { 0%, 100% { opacity: 1; } 50% { opacity: .35; } }
@keyframes fadeIn { to { opacity: 1; } }

.hero-title-wrap {
    position: relative;
    display: inline-block;
    perspective: 1600px;
    perspective-origin: center;
    --rx: 0deg;
    --ry: 0deg;
    --glx: 50%;
    --gly: 50%;
    --proximity: 0;
    transform-style: preserve-3d;
}
#smoke-canvas { display: none !important; }

.hero-title {
    position: relative !important;
    font-family: 'Rajdhani', 'Barlow Condensed', 'Impact', sans-serif !important;
    font-weight: 800 !important;
    font-size: clamp(4rem, 10.5vw, 8rem) !important;
    line-height: .95 !important;
    letter-spacing: 5px !important;
    text-transform: uppercase !important;
    color: #FFFFFF !important;
    opacity: 1 !important;
    visibility: visible !important;
    margin: 0 !important;
    text-align: center !important;
    text-shadow: 0 4px 40px rgba(0,0,0,.55), 0 0 60px rgba(200, 202, 208,.10) !important;
    transform: none !important;
    animation: none !important;
}
.hero-title .title-line, .hero-title span {
    display: inline-block !important;
    opacity: 1 !important;
    visibility: visible !important;
}
.hero-glare { display: none !important; }
.hero-title-wrap { perspective: none !important; transform-style: flat !important; }
.hero-title span { display: inline-block; }

/* glare overlay — radial white light follows cursor across the title */
.hero-glare {
    position: absolute;
    inset: -12% -6%;
    pointer-events: none;
    border-radius: 24px;
    background: radial-gradient(circle 28% at var(--glx) var(--gly),
        rgba(255,255,255,.18) 0%,
        rgba(186,230,253,.10) 40%,
        transparent 70%);
    mix-blend-mode: screen;
    opacity: 0;
    transition: opacity .5s var(--ease);
    transform: rotateX(calc(var(--rx) * .6)) rotateY(calc(var(--ry) * .6)) translateZ(20px);
    will-change: opacity, transform;
}
.hero-title-wrap.tilt-active .hero-glare { opacity: 1; }

@media (prefers-reduced-motion: reduce) {
    .hero-title { transform: none; }
    .hero-glare { display: none; }
}
.hero-title span { display: inline-block; }
.hero-smoke { display: none; }
.hero-title span {
    display: block;
}
.hero-title span.s2 {
    color: var(--moon);
    font-weight: 700;
    letter-spacing: 6px;
    text-shadow: 0 2px 12px rgba(0, 0, 0, 0.4);
}

.hero-slot {
    position: relative;
    max-width: 760px;
    width: 100%;
    padding: 1.2rem 3.5rem;
    background: rgba(10, 7, 28,.55);
    backdrop-filter: blur(4px) saturate(120%);
    -webkit-backdrop-filter: blur(4px) saturate(120%);
    opacity: 0;
    animation: fadeIn 1s var(--ease) .9s forwards;
}
.hero-slot::before, .hero-slot::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    border-color: var(--text);
    border-style: solid;
    border-width: 0;
}
/* corner brackets */
.hero-slot::before {
    top: 0; left: 18px;
    border-top-width: 1px; border-left-width: 1px;
}
.hero-slot::after {
    bottom: 0; right: 18px;
    border-bottom-width: 1px; border-right-width: 1px;
}
.hero-slot-corners { position: absolute; inset: 0; pointer-events: none; }
.hero-slot-corners::before, .hero-slot-corners::after {
    content: '';
    position: absolute;
    width: 14px; height: 14px;
    border-color: var(--text);
    border-style: solid;
    border-width: 0;
}
.hero-slot-corners::before {
    top: 0; right: 18px;
    border-top-width: 1px; border-right-width: 1px;
}
.hero-slot-corners::after {
    bottom: 0; left: 18px;
    border-bottom-width: 1px; border-left-width: 1px;
}
.hero-slot-shoulder {
    position: absolute;
    top: 50%;
    transform: translateY(-50%);
    width: 4px;
    height: 38px;
    background: var(--moon);
    box-shadow: 0 0 12px rgba(200, 202, 208,.5);
}
.hero-slot-shoulder.left { left: -2px; }
.hero-slot-shoulder.right { right: -2px; }
.hero-slot p {
    font-family: var(--f-display);
    color: var(--text2);
    font-size: 1.02rem;
    line-height: 1.55;
    margin: 0;
    letter-spacing: .5px;
}

.hero-cta {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 1.05rem 3rem;
    background: rgba(10, 7, 28,.55);
    backdrop-filter: blur(4px);
    border: 1px solid rgba(255,255,255,.20);
    color: var(--text);
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1rem;
    letter-spacing: 4px;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .25s var(--ease), border-color .25s var(--ease), color .25s var(--ease);
    opacity: 0;
    animation: fadeIn 1s var(--ease) 1.15s forwards;
}
.hero-cta::before, .hero-cta::after {
    content: '';
    position: absolute;
    left: 50%;
    transform: translateX(-50%);
    width: 60%;
    height: 1px;
    background: var(--moon);
    box-shadow: 0 0 8px rgba(200, 202, 208,.4);
}
.hero-cta::before { top: -1px; }
.hero-cta::after { bottom: -1px; }
.hero-cta:hover { background: rgba(200, 202, 208,.10); border-color: var(--moon); color: var(--moon); }

.hero-scroll {
    position: absolute;
    bottom: 1.8rem;
    left: 50%;
    transform: translateX(-50%);
    color: var(--text2);
    font-family: var(--f-display);
    font-size: .8rem;
    letter-spacing: 3px;
    text-transform: uppercase;
    font-weight: 600;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: .55rem;
    opacity: 0;
    animation: fadeIn 1s var(--ease) 1.4s forwards, scrollBounce 2.4s ease-in-out 2s infinite;
    transition: color .2s;
}
.hero-scroll:hover { color: var(--moon); }
.hero-scroll-arrow {
    color: var(--moon);
    font-size: 1.2rem;
    line-height: 1;
}
@keyframes scrollBounce {
    0%, 100% { transform: translateX(-50%) translateY(0); }
    50% { transform: translateX(-50%) translateY(6px); }
}

.hero-art-by {
    position: absolute;
    bottom: 1.4rem;
    right: 1.5rem;
    color: var(--muted);
    font-family: var(--f-display);
    font-size: .78rem;
    letter-spacing: 1.5px;
    opacity: 0;
    animation: fadeIn 1s ease 1.6s forwards;
}
.hero-art-by strong { color: var(--moon); font-weight: 600; }

/* SERVERS — 2 yan yana, çok aşağıda */
.servers {
    padding: 6rem 2.5rem 5rem;
    max-width: 1100px;
    margin: 0 auto;
}
@media (max-width: 760px) { .servers { padding: 4rem 1.2rem 3rem; } }

.servers-head {
    text-align: center;
    margin-bottom: 3.5rem;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s var(--ease), transform 1s var(--ease);
}
.servers-head.in { opacity: 1; transform: translateY(0); }
.servers-eye {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--f-mono);
    color: var(--moon);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 1rem;
}
.servers-eye-dot { width: 6px; height: 6px; background: var(--moon); border-radius: 50%; }
.servers-h2 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2.4rem, 5vw, 3.4rem);
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    margin-bottom: .6rem;
}
.servers-sub {
    color: var(--text2);
    font-size: 1rem;
    max-width: 460px;
    margin: 0 auto;
}

.s-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.6rem;
}
@media (max-width: 760px) { .s-grid { grid-template-columns: 1fr; gap: 1rem; } }

.scard {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    overflow: hidden;
    backdrop-filter: blur(6px) saturate(115%);
    -webkit-backdrop-filter: blur(6px) saturate(115%);
    transition: border-color .35s var(--ease), background .35s var(--ease), transform .35s var(--ease);
    display: flex;
    flex-direction: column;
    opacity: 0;
    transform: translateY(24px);
}
.scard.in {
    opacity: 1;
    transform: translateY(0);
    transition: opacity .9s var(--ease), transform .9s var(--ease), border-color .35s, background .35s;
}
.scard:hover { border-color: var(--line2); background: var(--surface2); transform: translateY(-3px); }

.sc-head {
    padding: 1.8rem 2rem 1.4rem;
    border-bottom: 1px solid var(--line);
    display: flex;
    justify-content: space-between;
    align-items: flex-start;
    gap: 1rem;
}
.sc-name-block { min-width: 0; flex: 1; }
.sc-tag {
    display: inline-block;
    font-family: var(--f-mono);
    font-size: .66rem;
    color: var(--muted);
    text-transform: uppercase;
    letter-spacing: 1.5px;
    font-weight: 600;
    margin-bottom: .5rem;
}
.sc-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.85rem;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    color: var(--text);
}
.sc-status {
    display: inline-flex;
    align-items: center;
    gap: .4rem;
    padding: .3rem .7rem;
    background: rgba(94, 234, 212,.10);
    border: 1px solid rgba(94, 234, 212,.30);
    border-radius: 4px;
    font-family: var(--f-mono);
    font-size: .66rem;
    font-weight: 700;
    color: var(--success);
    text-transform: uppercase;
    letter-spacing: 1px;
    flex-shrink: 0;
}
.sc-status .sd { width: 6px; height: 6px; background: var(--success); border-radius: 50%; animation: breathe 1.8s infinite; }

.sc-body {
    padding: 1.6rem 2rem 2rem;
    flex: 1;
    display: flex;
    flex-direction: column;
    gap: 1.4rem;
}
.sc-info { display: flex; flex-direction: column; gap: .55rem; }
.sc-info-row { display: flex; justify-content: space-between; align-items: baseline; }
.sc-info-row .lb { color: var(--dim); font-family: var(--f-mono); font-size: .68rem; letter-spacing: 1.5px; text-transform: uppercase; font-weight: 600; }
.sc-info-row .vl { color: var(--text2); font-family: var(--f-mono); font-size: .85rem; text-align: right; }

.sc-players { padding-top: 1.1rem; border-top: 1px solid var(--line); }
.sc-pl-row { display: flex; justify-content: space-between; align-items: baseline; margin-bottom: .7rem; }
.sc-pl-num {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 2.4rem;
    line-height: 1;
    color: var(--text);
    letter-spacing: 0;
    font-variant-numeric: tabular-nums;
}
.sc-pl-num small { font-family: var(--f-mono); color: var(--muted); font-weight: 400; font-size: 1rem; margin-left: .25rem; }
.sc-pl-lbl { font-family: var(--f-mono); font-size: .68rem; color: var(--muted); text-transform: uppercase; letter-spacing: 1.5px; font-weight: 600; }
.sc-bar { height: 2px; background: rgba(255,255,255,.06); overflow: hidden; border-radius: 1px; }
.sc-fill { height: 100%; background: var(--moon); transition: width 1.4s var(--ease); }

.sc-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: .55rem;
    padding: 1rem;
    background: transparent;
    color: var(--text);
    border: 1px solid var(--line2);
    border-radius: 4px;
    font-family: var(--f-body);
    font-weight: 700;
    font-size: .8rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    text-decoration: none;
    transition: background .25s, color .25s, border-color .25s;
    margin-top: auto;
}
.sc-cta:hover {
    background: var(--moon);
    color: #0A1218;
    border-color: var(--moon);
}

/* INVITES — Discord + Steam */
.invites {
    padding: 4rem 2.5rem 6rem;
    max-width: 1100px;
    margin: 0 auto;
}
@media (max-width: 760px) { .invites { padding: 3rem 1.2rem 4rem; } }

.invites-head {
    text-align: center;
    margin-bottom: 3rem;
    opacity: 0;
    transform: translateY(20px);
    transition: opacity 1s var(--ease), transform 1s var(--ease);
}
.invites-head.in { opacity: 1; transform: translateY(0); }
.invites-eye {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    font-family: var(--f-mono);
    color: var(--moon);
    font-size: .72rem;
    font-weight: 600;
    letter-spacing: 2px;
    text-transform: uppercase;
    margin-bottom: 1rem;
}
.invites-h2 {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: clamp(2rem, 4.5vw, 2.8rem);
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
    margin-bottom: .6rem;
}
.invites-sub {
    color: var(--text2);
    font-size: .98rem;
    max-width: 460px;
    margin: 0 auto;
}

.inv-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.6rem;
}
@media (max-width: 760px) { .inv-grid { grid-template-columns: 1fr; gap: 1rem; } }

.inv-card {
    background: var(--surface);
    border: 1px solid var(--line);
    border-radius: 12px;
    padding: 2.4rem;
    backdrop-filter: blur(6px) saturate(115%);
    -webkit-backdrop-filter: blur(6px) saturate(115%);
    text-decoration: none;
    color: inherit;
    display: flex;
    flex-direction: column;
    gap: 1.2rem;
    transition: border-color .35s var(--ease), background .35s var(--ease), transform .35s var(--ease);
    opacity: 0;
    transform: translateY(24px);
    position: relative;
    overflow: hidden;
}
.inv-card.in { opacity: 1; transform: translateY(0); transition: opacity .9s var(--ease), transform .9s var(--ease), border-color .35s, background .35s; }
.inv-card:hover { border-color: var(--line2); background: var(--surface2); transform: translateY(-3px); }

.inv-card.discord:hover { border-color: rgba(88,101,242,.45); }
.inv-card.steam:hover { border-color: rgba(102,192,244,.45); }

.inv-icon {
    width: 56px; height: 56px;
    border-radius: 12px;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.7rem;
    color: var(--text);
    flex-shrink: 0;
}
.inv-card.discord .inv-icon { background: rgba(88,101,242,.15); border: 1px solid rgba(88,101,242,.30); color: var(--discord); }
.inv-card.steam .inv-icon { background: rgba(102,192,244,.12); border: 1px solid rgba(102,192,244,.30); color: var(--steam); }

.inv-name {
    font-family: var(--f-display);
    font-weight: 700;
    font-size: 1.7rem;
    line-height: 1;
    letter-spacing: 0;
    text-transform: uppercase;
}

.inv-tag {
    color: var(--text2);
    font-size: .95rem;
    line-height: 1.55;
}

.inv-meta {
    display: flex;
    gap: 1.2rem;
    margin-top: auto;
    padding-top: 1rem;
    border-top: 1px solid var(--line);
    font-family: var(--f-mono);
    font-size: .76rem;
    color: var(--muted);
}
.inv-meta strong { color: var(--text); font-weight: 600; }

.inv-go {
    display: inline-flex;
    align-items: center;
    gap: .5rem;
    margin-top: .5rem;
    font-family: var(--f-body);
    font-weight: 700;
    font-size: .82rem;
    letter-spacing: 1.5px;
    text-transform: uppercase;
    transition: gap .25s var(--ease);
}
.inv-card.discord .inv-go { color: var(--discord); }
.inv-card.steam .inv-go { color: var(--steam); }
.inv-card:hover .inv-go { gap: .8rem; }

.floating-invites {
    position: fixed !important;
    right: 1.6rem !important;
    bottom: 1.6rem !important;
    z-index: 200 !important;
    display: flex !important;
    flex-direction: column !important;
    gap: .75rem !important;
}
.fi-chip {
    width: 54px !important;
    height: 54px !important;
    min-width: 54px !important;
    min-height: 54px !important;
    border-radius: 50% !important;
    border: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    color: #fff !important;
    text-decoration: none !important;
    position: relative !important;
    transition: transform .25s cubic-bezier(.22,1,.36,1), box-shadow .25s ease, filter .2s ease !important;
    padding: 0 !important;
    backdrop-filter: none !important;
    -webkit-backdrop-filter: none !important;
}
.fi-chip svg { width: 26px !important; height: 26px !important; flex-shrink: 0 !important; display: block !important; fill: #fff !important; color: #fff !important; }
.fi-chip.discord {
    background: linear-gradient(135deg, #5865F2, #404eed) !important;
    box-shadow: 0 8px 24px -6px rgba(88,101,242,.55), 0 0 0 1px rgba(255,255,255,.06) inset !important;
}
.fi-chip.steam {
    background: linear-gradient(135deg, #1b2838, #2a475e) !important;
    box-shadow: 0 8px 24px -6px rgba(200, 202, 208,.45), 0 0 0 1px rgba(220, 222, 228,.25) inset !important;
}
.fi-chip:hover {
    transform: translateY(-3px) scale(1.06) !important;
    filter: brightness(1.15) !important;
}
.fi-chip.discord:hover { box-shadow: 0 14px 36px -6px rgba(88,101,242,.7), 0 0 0 1px rgba(255,255,255,.15) inset !important; }
.fi-chip.steam:hover { box-shadow: 0 14px 36px -6px rgba(200, 202, 208,.65), 0 0 0 1px rgba(220, 222, 228,.5) inset !important; }

.fi-tip {
    position: absolute;
    right: calc(100% + 10px);
    top: 50%;
    transform: translateY(-50%) translateX(6px);
    padding: .35rem .65rem;
    background: rgba(17, 19, 22,.95);
    border: 1px solid var(--line2);
    border-radius: 4px;
    font-family: var(--f-mono);
    font-size: .7rem;
    font-weight: 600;
    color: var(--text);
    letter-spacing: 1px;
    text-transform: uppercase;
    white-space: nowrap;
    opacity: 0;
    pointer-events: none;
    transition: opacity .2s, transform .25s var(--ease);
    backdrop-filter: blur(4px);
}
.fi-chip:hover .fi-tip {
    opacity: 1;
    transform: translateY(-50%) translateX(0);
}

/* === Page loader (initial mount + page transitions) === */
#page-loader {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9999 !important;
    background: #06041A !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 1 !important;
    pointer-events: all !important;
    transition: opacity .6s cubic-bezier(.22,1,.36,1), visibility .6s !important;
}
#page-loader.is-done {
    opacity: 0 !important;
    pointer-events: none !important;
    visibility: hidden !important;
}
#page-loader::before {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: radial-gradient(ellipse at center, rgba(200, 202, 208,.10) 0%, transparent 55%) !important;
    opacity: .9 !important;
}
.pl-inner {
    position: relative !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1.4rem !important;
    transform: translateY(-8px) !important;
    z-index: 2 !important;
}

/* Two star layers drift at different speeds for depth */
.pl-stars-2 {
    background-position: 22% 14% !important;
    animation-duration: 7s !important;
    animation-delay: 1.2s !important;
    opacity: .4 !important;
}

/* Loader vignette — fades centre brighter for spotlight on moon */
.pl-vignette {
    position: absolute !important;
    inset: 0 !important;
    background: radial-gradient(ellipse 60% 55% at 50% 45%,
        transparent 0%,
        rgba(10, 11, 13, .35) 50%,
        rgba(10, 11, 13, .85) 100%) !important;
    pointer-events: none !important;
    z-index: 1 !important;
}

/* Moon stage — wrapper for moon + orbit rings */
.pl-moon-stage {
    position: relative !important;
    width: 220px !important; height: 220px !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    margin-bottom: .4rem !important;
}
.pl-orbit {
    position: absolute !important;
    border-radius: 50% !important;
    border: 1px solid rgba(200, 215, 235, .15) !important;
    pointer-events: none !important;
    opacity: 0 !important;
    animation: plOrbitIn 1.4s cubic-bezier(.22,1,.36,1) .4s forwards, plOrbitSpin 28s linear .4s infinite !important;
}
.pl-orbit-a { width: 150px !important; height: 150px !important; border-style: dashed !important; border-color: rgba(200,215,235,.18) !important; }
.pl-orbit-b { width: 200px !important; height: 200px !important; border-style: dotted !important; border-color: rgba(200,202,208,.20) !important; animation-direction: reverse !important; animation-duration: 1.4s, 40s !important; }
@keyframes plOrbitIn { to { opacity: 1; } }
@keyframes plOrbitSpin { to { transform: rotate(360deg); } }

/* Second halo for richer glow */
.pl-moon-halo-2 {
    inset: -45px !important;
    background: radial-gradient(circle, rgba(200, 202, 208, .25) 0%, rgba(94, 114, 152, .10) 40%, transparent 70%) !important;
    filter: blur(20px) !important;
    animation: plHalo 5s ease-in-out infinite reverse !important;
    z-index: 0 !important;
}

/* Status pill — terminal-style cycling text */
.pl-status {
    display: inline-flex !important;
    align-items: center !important;
    gap: .55rem !important;
    padding: .4rem .9rem !important;
    border-radius: 999px !important;
    background: rgba(255, 255, 255, .03) !important;
    border: 1px solid rgba(200, 215, 235, .12) !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: .68rem !important;
    font-weight: 500 !important;
    letter-spacing: 1.4px !important;
    text-transform: uppercase !important;
    color: rgba(200, 215, 235, .8) !important;
    opacity: 0 !important;
    transform: translateY(8px) !important;
    animation: plStatusIn .8s cubic-bezier(.22,1,.36,1) 1.4s forwards !important;
}
.pl-status-dot {
    width: 6px !important; height: 6px !important;
    border-radius: 50% !important;
    background: #C8CAD0 !important;
    box-shadow: 0 0 8px rgba(200, 202, 208, .7) !important;
    animation: plStatusBlink 1.2s ease-in-out infinite !important;
}
.pl-status-text { min-width: 200px !important; text-align: left !important; transition: opacity .3s ease !important; }
.pl-status-text.fade { opacity: 0 !important; }
@keyframes plStatusIn { to { opacity: 1; transform: translateY(0); } }
@keyframes plStatusBlink {
    0%, 100% { opacity: 1; }
    50% { opacity: .35; }
}

/* Coords line at bottom — sci-fi telemetry */
.pl-coords {
    margin-top: .8rem !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: .58rem !important;
    font-weight: 400 !important;
    letter-spacing: 2px !important;
    color: rgba(200, 215, 235, .35) !important;
    opacity: 0 !important;
    animation: plCoordsIn 1s cubic-bezier(.22,1,.36,1) 2s forwards !important;
}
@keyframes plCoordsIn { to { opacity: 1; } }

/* Star field — subtle twinkling background */
.pl-stars {
    position: absolute !important;
    inset: 0 !important;
    background-image:
        radial-gradient(1.2px 1.2px at 12% 22%, rgba(255,255,255,.85), transparent 40%),
        radial-gradient(1px 1px at 28% 78%, rgba(220,222,228,.7), transparent 40%),
        radial-gradient(1.5px 1.5px at 78% 18%, rgba(255,255,255,.9), transparent 40%),
        radial-gradient(1px 1px at 65% 65%, rgba(220,222,228,.55), transparent 40%),
        radial-gradient(1.3px 1.3px at 42% 12%, rgba(255,255,255,.7), transparent 40%),
        radial-gradient(1px 1px at 88% 72%, rgba(232,222,255,.6), transparent 40%),
        radial-gradient(1.2px 1.2px at 18% 55%, rgba(220,222,228,.5), transparent 40%),
        radial-gradient(1px 1px at 55% 35%, rgba(255,255,255,.6), transparent 40%),
        radial-gradient(1.4px 1.4px at 92% 45%, rgba(220,222,228,.75), transparent 40%),
        radial-gradient(1px 1px at 8% 88%, rgba(255,255,255,.5), transparent 40%) !important;
    animation: plStars 5s ease-in-out infinite alternate !important;
    pointer-events: none !important;
}
@keyframes plStars {
    0%   { opacity: .35; }
    50%  { opacity: .85; }
    100% { opacity: .55; }
}

/* Moon wrap + body + halo */
.pl-moon-wrap {
    position: relative !important;
    width: 96px !important;
    height: 96px !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    opacity: 0 !important;
    transform: scale(.78) !important;
    animation: plMoonIn 1s cubic-bezier(.22,1,.36,1) .05s forwards !important;
}
@keyframes plMoonIn {
    to { opacity: 1; transform: scale(1); }
}
@keyframes plMoonFloat {
    0%, 100% { transform: translateY(0) rotate(0deg); }
    50%      { transform: translateY(-6px) rotate(-2deg); }
}
.pl-moon {
    width: 88px !important;
    height: 88px !important;
    display: block !important;
    filter: drop-shadow(0 0 14px rgba(200,202,208,.55)) drop-shadow(0 0 28px rgba(200,202,208,.35)) !important;
    animation: plMoonGlow 3.6s ease-in-out infinite, plMoonFloat 5s ease-in-out infinite !important;
    position: relative !important;
    z-index: 2 !important;
}
@keyframes plMoonGlow {
    0%, 100% { filter: drop-shadow(0 0 14px rgba(200,202,208,.55)) drop-shadow(0 0 28px rgba(200,202,208,.35)); }
    50%      { filter: drop-shadow(0 0 22px rgba(220,222,228,.75)) drop-shadow(0 0 44px rgba(200,202,208,.55)); }
}
.pl-moon-halo {
    position: absolute !important;
    inset: -28px !important;
    border-radius: 50% !important;
    background: radial-gradient(circle, rgba(200,202,208,.35) 0%, rgba(200,202,208,.18) 35%, transparent 65%) !important;
    filter: blur(14px) !important;
    animation: plHalo 4s ease-in-out infinite !important;
    z-index: 1 !important;
}
@keyframes plHalo {
    0%, 100% { transform: scale(.92); opacity: .55; }
    50%      { transform: scale(1.12); opacity: .9; }
}
.pl-mark {
    display: flex !important;
    gap: .6rem !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important;
    font-size: 2.4rem !important;
    letter-spacing: 8px !important;
    text-transform: uppercase !important;
    line-height: 1 !important;
}
.pl-mark-a {
    color: #fff !important;
    opacity: 0 !important;
    transform: translateY(14px) !important;
    filter: blur(10px) !important;
    animation: plMarkIn .9s cubic-bezier(.22,1,.36,1) .05s forwards !important;
}
.pl-mark-b {
    color: var(--moon) !important;
    text-shadow: none !important;
    opacity: 0 !important;
    transform: translateY(14px) !important;
    filter: blur(10px) !important;
    animation: plMarkIn .9s cubic-bezier(.22,1,.36,1) .22s forwards !important;
}
@keyframes plMarkIn {
    to { opacity: 1; transform: translateY(0); filter: blur(0); }
}
.pl-bar {
    width: 180px !important;
    height: 2px !important;
    background: rgba(255,255,255,.06) !important;
    border-radius: 2px !important;
    overflow: hidden !important;
    position: relative !important;
}
.pl-bar-fill {
    position: absolute !important;
    inset: 0 !important;
    width: 40% !important;
    background: linear-gradient(90deg, transparent, var(--moon), #C8B8FF, var(--moon), transparent) !important;
    border-radius: 2px !important;
    animation: plBar 1.4s ease-in-out infinite !important;
    box-shadow: 0 0 18px rgba(200, 202, 208,.6) !important;
}
@keyframes plBar {
    0%   { transform: translateX(-100%); }
    100% { transform: translateX(350%); }
}

/* fade body content in once loader is gone */
body { opacity: 1; transition: opacity .35s ease; }
body.is-leaving { opacity: 0 !important; }

/* page transition overlay — fades over content during nav */
#page-trans {
    position: fixed !important;
    inset: 0 !important;
    z-index: 9998 !important;
    background: radial-gradient(ellipse at center, rgba(200, 202, 208,.08), transparent 60%), #06041A !important;
    opacity: 0 !important;
    pointer-events: none !important;
    transition: opacity .35s cubic-bezier(.22,1,.36,1) !important;
}
body.is-leaving #page-trans {
    opacity: 1 !important;
}

/* respect reduced motion */
@media (prefers-reduced-motion: reduce) {
    #page-loader, .pl-bar-fill, .pl-mark-a, .pl-mark-b { animation: none !important; transition: none !important; }
    #page-loader { display: none !important; }
}

/* === Modern reveal animations (scroll-bound) === */
.reveal {
    opacity: 0;
    transform: translateY(28px);
    filter: blur(8px);
    transition:
        opacity 1.1s cubic-bezier(.22,1,.36,1),
        transform 1.1s cubic-bezier(.22,1,.36,1),
        filter 1.1s cubic-bezier(.22,1,.36,1);
    will-change: opacity, transform, filter;
}
.reveal.in {
    opacity: 1;
    transform: translateY(0);
    filter: blur(0);
}

/* hero title gets a stronger entrance */
.hero-title.reveal {
    transform: translateY(40px) scale(.96);
    filter: blur(18px);
}
.hero-title.reveal.in {
    transform: translateY(0) scale(1);
    filter: blur(0);
}

/* hero scroll parallax: title drifts up + fades as you scroll */
.hero-content {
    will-change: transform, opacity;
    transition: opacity .2s linear;
}

/* smooth card hover lift (premium feel) */
.scard {
    transition:
        transform .55s cubic-bezier(.22,1,.36,1),
        border-color .35s ease,
        background .35s ease,
        box-shadow .55s cubic-bezier(.22,1,.36,1);
    will-change: transform;
}
.scard:hover {
    transform: translateY(-6px);
    border-color: rgba(200, 202, 208,.28) !important;
    background: rgba(26, 20, 52,.92) !important;
    box-shadow:
        0 24px 60px -20px rgba(0,0,0,.6),
        0 0 0 1px rgba(200, 202, 208,.10),
        0 16px 40px -16px rgba(200, 202, 208,.20);
}

/* server card image-less subtle internal animation on hover: status dot bigger */
.scard:hover .sc-status .sd { box-shadow: 0 0 0 4px rgba(94, 234, 212,.18); }

/* connect button: magnetic + sweep on hover */
.sc-cta {
    position: relative;
    overflow: hidden;
    transition: background .25s ease, color .25s ease, border-color .25s ease, transform .35s cubic-bezier(.22,1,.36,1);
    will-change: transform;
}
.sc-cta::before {
    content: '';
    position: absolute;
    top: 0; left: -140%;
    width: 60%; height: 100%;
    background: linear-gradient(115deg, transparent, rgba(255,255,255,.18), transparent);
    transform: skewX(-22deg);
    transition: left .9s cubic-bezier(.22,1,.36,1);
    pointer-events: none;
}
.sc-cta:hover::before { left: 140%; }

/* === v2 page head (compact, for store/stats/support) === */
.v2-page-head {
    position: relative !important;
    z-index: 2 !important;
    padding: 7rem 1.5rem 2rem !important;
    max-width: 1280px !important;
    margin: 0 auto !important;
}
.v2-page-head-in {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
    padding-bottom: 1.5rem !important;
    border-bottom: 1px solid var(--line) !important;
}
.v2-page-h1 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important;
    font-size: 2rem !important;
    letter-spacing: 4px !important;
    text-transform: uppercase !important;
    color: #fff !important;
    margin: 0 !important;
    line-height: 1 !important;
}
.v2-toggle {
    display: inline-flex !important;
    gap: .35rem !important;
    padding: .3rem !important;
    background: rgba(255,255,255,.04) !important;
    border: 1px solid var(--line) !important;
    border-radius: 999px !important;
}
.v2-toggle-btn {
    padding: .5rem 1.1rem !important;
    background: transparent !important;
    border: none !important;
    border-radius: 999px !important;
    color: var(--muted) !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    cursor: pointer !important;
    transition: color .2s, background .2s !important;
}
.v2-toggle-btn:hover { color: var(--text) !important; }
.v2-toggle-btn.active {
    background: var(--moon) !important;
    color: #04111E !important;
}

/* generic "coming soon" placeholder */
.v2-coming {
    max-width: 720px !important;
    margin: 0 auto !important;
    padding: 6rem 1.5rem 4rem !important;
    text-align: center !important;
}
.v2-coming-h1 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important;
    font-size: clamp(2.5rem, 5vw, 4rem) !important;
    letter-spacing: 4px !important;
    text-transform: uppercase !important;
    color: #fff !important;
    margin: 0 0 1rem !important;
    line-height: 1 !important;
}
.v2-coming-eye {
    display: inline-flex !important;
    align-items: center !important;
    gap: .5rem !important;
    font-family: 'JetBrains Mono', monospace !important;
    font-size: .76rem !important;
    color: var(--moon) !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    margin-bottom: 1.4rem !important;
}
.v2-coming-eye .ed { width: 6px; height: 6px; background: var(--moon); border-radius: 50%; }
.v2-coming p {
    color: var(--text2) !important;
    font-size: 1rem !important;
    line-height: 1.55 !important;
    max-width: 480px !important;
    margin: 0 auto !important;
}

/* === v2 footer (compact, single bar) === */
.v2-footer {
    position: relative !important;
    z-index: 2 !important;
    border-top: 1px solid var(--line) !important;
    background: rgba(10, 7, 28,.55) !important;
    backdrop-filter: blur(6px) saturate(120%);
    -webkit-backdrop-filter: blur(6px) saturate(120%);
    padding: 0 !important;
    margin-top: 4rem !important;
}
.v2-foot-in {
    max-width: 1480px !important;
    margin: 0 auto !important;
    padding: 1rem 2rem !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
}
.v2-foot-brand {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.1rem !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: #fff !important;
}
.v2-foot-brand span { color: var(--moon) !important; }
.v2-foot-links {
    display: flex !important;
    gap: 1.5rem !important;
    flex-wrap: wrap !important;
}
.v2-foot-links a {
    color: var(--muted) !important;
    text-decoration: none !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    transition: color .2s ease !important;
}
.v2-foot-links a:hover { color: var(--text) !important; }
.v2-foot-copy {
    font-family: var(--f-mono) !important;
    font-size: .72rem !important;
    color: var(--dim) !important;
    letter-spacing: .5px !important;
}
@media (max-width: 760px) { .v2-foot-in { padding: 1.2rem !important; } }

/* hide v1 leftover footer if present */
.footer:not(.v2-footer), .footer-grid, .footer-links-group, .footer-bottom { display: none !important; }

/* ===== SUPPORT v2 ===== */
.v2-support {
    max-width: 1100px !important;
    margin: 0 auto !important;
    padding: 2rem 1.5rem 4rem !important;
    width: 100% !important;
    box-sizing: border-box !important;
}
.v2-alert {
    display: flex !important;
    align-items: center !important;
    justify-content: space-between !important;
    gap: 1rem !important;
    padding: .85rem 1.2rem !important;
    border-radius: 10px !important;
    margin-bottom: 1.5rem !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-size: .95rem !important;
    font-weight: 600 !important;
}
.v2-alert-ok { background: rgba(74,222,128,.08) !important; border: 1px solid rgba(74,222,128,.25) !important; color: #4ade80 !important; }
.v2-alert-err { background: rgba(239,68,68,.08) !important; border: 1px solid rgba(239,68,68,.25) !important; color: #ef4444 !important; }
.v2-alert-x {
    background: none !important; border: none !important; color: inherit !important;
    font-size: 1.4rem !important; cursor: pointer !important; opacity: .6 !important;
    padding: 0 .3rem !important; line-height: 1 !important;
}
.v2-alert-x:hover { opacity: 1 !important; }

.v2-card {
    background: rgba(13, 15, 20, .92) !important;
    border: 1px solid rgba(255,255,255,.10) !important;
    border-radius: 14px !important;
    padding: 1.8rem !important;
    backdrop-filter: blur(16px) !important;
    -webkit-backdrop-filter: blur(16px) !important;
    box-shadow: 0 18px 44px -18px rgba(0,0,0,.78) !important;
}
.v2-card-center {
    max-width: 520px !important;
    margin: 3rem auto !important;
    text-align: center !important;
    padding: 3rem 2rem !important;
}
.v2-card-icon-lock {
    width: 72px !important; height: 72px !important;
    margin: 0 auto 1.4rem !important;
    border-radius: 50% !important;
    display: flex !important; align-items: center !important; justify-content: center !important;
    background: linear-gradient(135deg, rgba(200, 202, 208,.12), rgba(200, 202, 208,.04)) !important;
    border: 1px solid rgba(200, 202, 208,.25) !important;
    color: var(--moon) !important;
}
.v2-card-icon-lock svg { width: 32px !important; height: 32px !important; }
.v2-card-h2 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: 1.6rem !important;
    letter-spacing: 1.5px !important; text-transform: uppercase !important;
    color: var(--text) !important; margin: 0 0 .6rem !important;
}
.v2-card-h3 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: 1.15rem !important;
    letter-spacing: 1.8px !important; text-transform: uppercase !important;
    color: var(--text) !important; margin: 0 0 1.4rem !important;
    padding-bottom: .9rem !important;
    border-bottom: 1px solid rgba(255,255,255,.05) !important;
    display: flex !important; align-items: center !important; gap: .6rem !important;
}
.v2-card-p {
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: .92rem !important; color: var(--muted) !important;
    margin: 0 0 1.8rem !important; line-height: 1.55 !important;
}
.v2-count { color: var(--dim) !important; font-weight: 500 !important; font-size: .85em !important; }

.v2-btn-steam, .v2-btn-primary {
    display: inline-flex !important; align-items: center !important; justify-content: center !important;
    gap: .55rem !important;
    padding: .9rem 1.6rem !important;
    border-radius: 10px !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: .95rem !important;
    letter-spacing: 2px !important; text-transform: uppercase !important;
    text-decoration: none !important; cursor: pointer !important;
    border: none !important;
    transition: transform .2s cubic-bezier(.22,1,.36,1), box-shadow .2s ease, background .2s ease !important;
}
.v2-btn-steam {
    background: linear-gradient(135deg, #1b2838, #2a475e) !important;
    color: #fff !important;
    border: 1px solid rgba(200, 202, 208,.3) !important;
    box-shadow: 0 6px 20px -6px rgba(0,0,0,.6) !important;
}
.v2-btn-steam:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 10px 30px -6px rgba(200, 202, 208,.4) !important;
    border-color: rgba(200, 202, 208,.6) !important;
}
.v2-btn-steam svg { width: 18px !important; height: 18px !important; }

.v2-btn-primary {
    background: linear-gradient(135deg, var(--moon), #C8B8FF) !important;
    color: #060912 !important;
    box-shadow: 0 6px 20px -6px rgba(200, 202, 208,.5) !important;
}
.v2-btn-primary:hover {
    transform: translateY(-2px) !important;
    box-shadow: 0 12px 32px -6px rgba(200, 202, 208,.7) !important;
}
.v2-btn-block { width: 100% !important; }

.v2-back-link {
    display: inline-flex !important; align-items: center !important; gap: .35rem !important;
    color: var(--muted) !important; text-decoration: none !important;
    font-family: 'Rajdhani', sans-serif !important; font-weight: 600 !important;
    font-size: .85rem !important; letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    margin-bottom: 1.5rem !important;
    transition: color .2s ease !important;
}
.v2-back-link:hover { color: var(--moon) !important; }

.v2-support-grid {
    display: grid !important;
    grid-template-columns: 1fr 1.2fr !important;
    gap: 1.5rem !important;
    align-items: start !important;
}
@media (max-width: 880px) { .v2-support-grid { grid-template-columns: 1fr !important; } }

.v2-ticket-detail-grid {
    display: grid !important;
    grid-template-columns: 2fr 1fr !important;
    gap: 1.5rem !important;
    align-items: start !important;
}
@media (max-width: 880px) { .v2-ticket-detail-grid { grid-template-columns: 1fr !important; } }

.v2-form { display: flex !important; flex-direction: column !important; gap: 1.1rem !important; }
.v2-form-row { display: flex !important; flex-direction: column !important; gap: .4rem !important; }
.v2-label {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 600 !important; font-size: .78rem !important;
    letter-spacing: 1.8px !important; text-transform: uppercase !important;
    color: var(--muted) !important;
}
.v2-label-opt { color: var(--dim) !important; font-weight: 500 !important; text-transform: none !important; letter-spacing: .5px !important; }

.v2-input, .v2-textarea, .v2-select, .v2-file {
    width: 100% !important;
    padding: .8rem .95rem !important;
    background: rgba(0,0,0,.35) !important;
    border: 1px solid rgba(255,255,255,.08) !important;
    border-radius: 8px !important;
    color: var(--text) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: .92rem !important;
    transition: border-color .2s ease, background .2s ease, box-shadow .2s ease !important;
    box-sizing: border-box !important;
    outline: none !important;
}
.v2-textarea { font-family: 'Space Grotesk', sans-serif !important; resize: vertical !important; min-height: 110px !important; line-height: 1.55 !important; }
.v2-select { appearance: none !important; -webkit-appearance: none !important; background-image: linear-gradient(45deg, transparent 50%, var(--muted) 50%), linear-gradient(135deg, var(--muted) 50%, transparent 50%) !important; background-position: calc(100% - 18px) 50%, calc(100% - 13px) 50% !important; background-size: 5px 5px, 5px 5px !important; background-repeat: no-repeat !important; padding-right: 2.2rem !important; cursor: pointer !important; }
.v2-input:focus, .v2-textarea:focus, .v2-select:focus {
    border-color: rgba(200, 202, 208,.5) !important;
    background: rgba(0,0,0,.5) !important;
    box-shadow: 0 0 0 3px rgba(200, 202, 208,.12) !important;
}
.v2-file { padding: .55rem !important; cursor: pointer !important; }
.v2-file::file-selector-button {
    background: rgba(200, 202, 208,.15) !important;
    color: var(--moon) !important;
    border: 1px solid rgba(200, 202, 208,.3) !important;
    border-radius: 6px !important;
    padding: .4rem .8rem !important;
    margin-right: .8rem !important;
    cursor: pointer !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 600 !important; font-size: .8rem !important;
    letter-spacing: 1px !important; text-transform: uppercase !important;
}
.v2-file::file-selector-button:hover { background: rgba(200, 202, 208,.25) !important; }

.v2-tickets-list { display: flex !important; flex-direction: column !important; gap: .6rem !important; }
.v2-ticket-item {
    display: block !important;
    padding: 1rem 1.1rem !important;
    background: rgba(0,0,0,.25) !important;
    border: 1px solid rgba(255,255,255,.05) !important;
    border-radius: 10px !important;
    text-decoration: none !important;
    color: inherit !important;
    transition: transform .2s cubic-bezier(.22,1,.36,1), border-color .2s ease, background .2s ease !important;
}
.v2-ticket-item:hover {
    transform: translateX(4px) !important;
    border-color: rgba(200, 202, 208,.3) !important;
    background: rgba(200, 202, 208,.04) !important;
}
.v2-ti-top { display: flex !important; align-items: center !important; justify-content: space-between !important; margin-bottom: .5rem !important; }
.v2-ti-id { font-family: var(--f-mono) !important; font-size: .75rem !important; color: var(--dim) !important; }
.v2-ti-title {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 600 !important; font-size: 1rem !important;
    color: var(--text) !important;
    margin-bottom: .4rem !important;
    letter-spacing: .3px !important;
}
.v2-ti-meta {
    display: flex !important; justify-content: space-between !important; gap: 1rem !important;
    font-size: .75rem !important; color: var(--dim) !important;
    font-family: 'Space Grotesk', sans-serif !important;
}

.v2-status {
    display: inline-flex !important; align-items: center !important;
    padding: .25rem .6rem !important;
    border-radius: 999px !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: .7rem !important;
    letter-spacing: 1.5px !important; text-transform: uppercase !important;
}
.v2-status-open { background: rgba(200, 202, 208,.14) !important; color: #C8B8FF !important; border: 1px solid rgba(200, 202, 208,.3) !important; }
.v2-status-answered { background: rgba(74,222,128,.14) !important; color: #4ade80 !important; border: 1px solid rgba(74,222,128,.3) !important; }
.v2-status-closed { background: rgba(160,170,190,.1) !important; color: var(--muted) !important; border: 1px solid rgba(255,255,255,.1) !important; }

.v2-empty {
    text-align: center !important;
    padding: 3rem 1rem !important;
    color: var(--dim) !important;
}
.v2-empty-icon { font-size: 2.5rem !important; margin-bottom: .8rem !important; opacity: .5 !important; }
.v2-empty p { font-family: 'Space Grotesk', sans-serif !important; font-size: .9rem !important; margin: 0 !important; }

.v2-ticket-detail-head { padding-bottom: 1.2rem !important; border-bottom: 1px solid rgba(255,255,255,.06) !important; margin-bottom: 1.5rem !important; }
.v2-ticket-h3 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: 1.3rem !important;
    color: var(--text) !important; margin: .6rem 0 0 !important;
    letter-spacing: .5px !important;
}
.v2-ticket-body { display: flex !important; flex-direction: column !important; gap: 1rem !important; }
.v2-msg {
    padding: 1rem 1.2rem !important;
    border-radius: 10px !important;
    background: rgba(0,0,0,.25) !important;
    border-left: 3px solid rgba(255,255,255,.1) !important;
}
.v2-msg-user { border-left-color: rgba(200, 202, 208,.5) !important; }
.v2-msg-admin { border-left-color: #4ade80 !important; background: rgba(74,222,128,.04) !important; }
.v2-msg-author {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: .9rem !important;
    color: var(--text) !important; margin-bottom: .5rem !important;
    letter-spacing: .5px !important;
    display: flex !important; align-items: center !important; gap: .5rem !important;
}
.v2-badge-admin {
    background: rgba(74,222,128,.18) !important; color: #4ade80 !important;
    padding: .15rem .5rem !important; border-radius: 4px !important;
    font-size: .65rem !important; letter-spacing: 1.2px !important; text-transform: uppercase !important;
}
.v2-msg-content {
    font-family: 'Space Grotesk', sans-serif !important; font-size: .92rem !important;
    color: var(--text) !important; line-height: 1.6 !important; word-wrap: break-word !important;
}
.v2-msg-time { font-size: .72rem !important; color: var(--dim) !important; margin-top: .6rem !important; font-family: var(--f-mono) !important; }
.v2-msg-attach { margin-top: .6rem !important; }
.v2-attach-link {
    display: inline-block !important;
    color: var(--moon) !important; text-decoration: none !important;
    font-size: .82rem !important; padding: .3rem .6rem !important;
    background: rgba(200, 202, 208,.08) !important;
    border: 1px solid rgba(200, 202, 208,.2) !important;
    border-radius: 6px !important; margin-right: .5rem !important;
}
.v2-attach-link:hover { background: rgba(200, 202, 208,.15) !important; }

.v2-reply-form { margin-top: 1rem !important; padding-top: 1.2rem !important; border-top: 1px solid rgba(255,255,255,.06) !important; display: flex !important; flex-direction: column !important; gap: .6rem !important; }
.v2-closed-notice {
    text-align: center !important; padding: 1.2rem !important;
    background: rgba(0,0,0,.25) !important; border-radius: 8px !important;
    color: var(--muted) !important; font-family: 'Rajdhani', sans-serif !important;
    font-size: .9rem !important; letter-spacing: 1px !important;
    margin-top: 1rem !important;
}

.v2-ticket-side { position: sticky !important; top: 100px !important; }
.v2-side-h4 {
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 700 !important; font-size: 1rem !important;
    letter-spacing: 1.8px !important; text-transform: uppercase !important;
    color: var(--text) !important; margin: 0 0 1.2rem !important;
    padding-bottom: .8rem !important; border-bottom: 1px solid rgba(255,255,255,.05) !important;
}
.v2-side-dl { margin: 0 !important; display: grid !important; grid-template-columns: auto 1fr !important; gap: .7rem 1rem !important; font-size: .85rem !important; }
.v2-side-dl dt { color: var(--dim) !important; font-family: 'Rajdhani', sans-serif !important; font-weight: 600 !important; letter-spacing: 1px !important; text-transform: uppercase !important; font-size: .75rem !important; }
.v2-side-dl dd { margin: 0 !important; color: var(--text) !important; font-family: 'Space Grotesk', sans-serif !important; }

/* sticky footer — kısa içerikli sayfalarda (store, stats vb.) footer ekranın altına yapışır */
html, body { height: auto !important; }
body {
    min-height: 100vh !important;
    display: flex !important;
    flex-direction: column !important;
}
body > .v2-footer { margin-top: auto !important; }
body > main, body > .app, body > section { flex-shrink: 0; }
.app { flex: 1 0 auto !important; }

/* === REACTIVE: cursor moonlight halo follows the pointer === */
#cursor-moon {
    position: fixed !important;
    top: 0 !important; left: 0 !important;
    width: 420px !important; height: 420px !important;
    border-radius: 50% !important;
    background: radial-gradient(circle,
        rgba(180, 200, 230, .14) 0%,
        rgba(200, 202, 208, .07) 35%,
        transparent 65%) !important;
    pointer-events: none !important;
    z-index: 3 !important;
    transform: translate3d(-9999px, -9999px, 0) !important;
    transition: opacity .4s ease, width .35s ease, height .35s ease !important;
    opacity: 0 !important;
    mix-blend-mode: screen !important;
    will-change: transform !important;
    filter: blur(2px) !important;
}
body.cursor-active #cursor-moon { opacity: 1 !important; }
body.cursor-press #cursor-moon { width: 540px !important; height: 540px !important; }
@media (pointer: coarse), (max-width: 760px) { #cursor-moon { display: none !important; } }

/* === REACTIVE: server cards 3D tilt — JS sets --tx, --ty === */
.scard {
    transform-style: preserve-3d !important;
    perspective: 1000px !important;
    will-change: transform !important;
}
.scard.tilt {
    transform: perspective(1000px) rotateX(var(--tx, 0deg)) rotateY(var(--ty, 0deg)) translateZ(0) !important;
    transition: transform .12s ease-out, border-color .25s ease, background .25s ease !important;
}
.scard:not(:hover) {
    transition: transform .5s cubic-bezier(.22,1,.36,1), border-color .25s ease, background .25s ease !important;
}
/* subtle inner highlight that tracks cursor on the card */
.scard::after {
    content: '' !important;
    position: absolute !important;
    inset: 0 !important;
    background: radial-gradient(circle 220px at var(--cx, 50%) var(--cy, 50%),
        rgba(200, 215, 235, .08) 0%,
        transparent 55%) !important;
    pointer-events: none !important;
    opacity: 0 !important;
    transition: opacity .25s ease !important;
    border-radius: inherit !important;
    z-index: 1 !important;
}
.scard:hover::after { opacity: 1 !important; }

/* === REACTIVE: magnetic pull on small UI bits (eyebrow + scroll arrow) === */
.hero-eyebrow, .hero-scroll {
    will-change: transform !important;
    transition: transform .35s cubic-bezier(.22,1,.36,1) !important;
}

/* === STORE page text legibility — was way too transparent === */
.store-empty {
    text-align: center !important;
    padding: 5rem 1.5rem !important;
}
.store-empty-icon, .store-empty .store-empty-icon {
    color: var(--moon) !important;
    opacity: .85 !important;
    font-size: 3.4rem !important;
    margin-bottom: 1.2rem !important;
}
.store-empty h2 {
    color: var(--text) !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1.8rem !important;
    letter-spacing: 1px !important;
    margin-bottom: .6rem !important;
    text-shadow: 0 2px 14px rgba(0, 0, 0, .55) !important;
}
.store-empty p {
    color: var(--text2) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 1rem !important;
    text-shadow: 0 1px 8px rgba(0, 0, 0, .5) !important;
}

/* Auth bar — "Login to shop" was almost invisible */
.auth-bar { padding: 1rem 0 !important; }
.auth-guest-text {
    color: var(--text) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: 1rem !important;
    font-weight: 500 !important;
    text-shadow: 0 1px 8px rgba(0, 0, 0, .5) !important;
}
.btn-steam, .btn.btn-steam {
    background: rgba(14, 17, 25, .8) !important;
    border: 1px solid var(--line2) !important;
    color: var(--text) !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 600 !important;
    padding: .55rem 1.1rem !important;
    border-radius: 6px !important;
    text-shadow: none !important;
}
.btn-steam:hover { border-color: var(--moon) !important; color: var(--moon) !important; }

/* Info cards — Instant Delivery / Secure Payment / 24/7 Support */
.store-info { padding: 3rem 0 !important; border-top: 1px solid var(--line) !important; }
.info-card { text-align: center !important; }
.info-card .info-icon, .info-icon {
    color: var(--moon) !important;
    font-size: 1.5rem !important;
    margin-bottom: .8rem !important;
    display: block !important;
    opacity: 1 !important;
}
.info-card h4 {
    color: var(--text) !important;
    font-family: 'Outfit', sans-serif !important;
    font-weight: 700 !important;
    font-size: 1rem !important;
    letter-spacing: 1.5px !important;
    text-transform: uppercase !important;
    margin-bottom: .35rem !important;
    text-shadow: 0 1px 10px rgba(0, 0, 0, .5) !important;
}
.info-card p {
    color: var(--text2) !important;
    font-family: 'Space Grotesk', sans-serif !important;
    font-size: .88rem !important;
    text-shadow: 0 1px 6px rgba(0, 0, 0, .45) !important;
}

/* =====================================================================
   LUNAR DARK OVERRIDE — no glow, matte, animated starfield bg
   (loaded last so it wins specificity wars with the older base styles)
   ===================================================================== */

/* Kill every glow/box-shadow that came from the base theme.
   Anything that *needs* a shadow re-enables it explicitly below. */
.hero-title .s2,
.hero-title,
.pl-mark-a, .pl-mark-b,
.nav-status, .nav-cta,
.sc-cta, .sc-fill,
.v2-btn-primary, .v2-btn-steam,
.btn-buy,
.fi-chip,
.fi-chip.discord, .fi-chip.steam,
.fi-chip:hover, .fi-chip.discord:hover, .fi-chip.steam:hover,
.nv-srv, .nv-srv:hover,
.nv-srv-dot,
.scard, .scard:hover,
.product-card, .product-card:hover,
.pl-moon, .pl-moon-halo,
.pl-bar-fill,
.s2,
.servers-eye-dot, .ns-dot, .sd, .ed {
    text-shadow: none !important;
    box-shadow: none !important;
    filter: none !important;
    animation: none !important;
}

/* Body — pitch dark base, no parallax video needed */
body {
    background: var(--bg) !important;
    color: var(--text) !important;
    font-family: var(--f-body) !important;
    font-weight: 400 !important;
}

/* Atmospheric veil: vignette + soft moonlit color cast + edge fade.
   Heavy enough that the video reads as background mood, not as content. */
#bg-veil {
    background:
        radial-gradient(ellipse 80% 65% at 50% 50%, transparent 0%, rgba(14, 17, 25, .35) 55%, rgba(14, 17, 25, .85) 100%),
        radial-gradient(ellipse 60% 50% at 30% 35%, rgba(200, 202, 208, .12) 0%, transparent 60%),
        radial-gradient(ellipse 55% 45% at 75% 70%, rgba(94, 114, 152, .10) 0%, transparent 60%),
        linear-gradient(180deg, rgba(14, 17, 25, .65) 0%, rgba(14, 17, 25, .30) 22%, rgba(14, 17, 25, .30) 78%, rgba(14, 17, 25, .85) 100%) !important;
    pointer-events: none !important;
    z-index: 1 !important;
    backdrop-filter: blur(.5px) saturate(85%) !important;
    -webkit-backdrop-filter: blur(.5px) saturate(85%) !important;
}

/* Video: cinematic — scroll-driven blur via --intro-blur */
#bg-video {
    z-index: 0 !important;
    opacity: .7 !important;
    background: #0E1119 !important;
    filter: blur(var(--intro-blur, 0px)) saturate(85%) brightness(85%) contrast(105%) !important;
    transform: scale(1.06) !important;
    transition: filter .25s linear !important;
    will-change: filter !important;
}
#bg-veil::after {
    content: '';
    position: absolute;
    inset: 0;
    background: rgba(6, 7, 10, var(--intro-dim, 0));
    pointer-events: none;
    transition: background-color .25s linear;
}
#bg-grain {
    background-image:
        radial-gradient(1px 1px at 13% 17%, rgba(255,255,255,.55), transparent 50%),
        radial-gradient(1px 1px at 87% 24%, rgba(200, 210, 230,.5), transparent 50%),
        radial-gradient(1.5px 1.5px at 42% 67%, rgba(255,255,255,.6), transparent 50%),
        radial-gradient(1px 1px at 71% 48%, rgba(200, 202, 208,.45), transparent 50%),
        radial-gradient(1px 1px at 27% 84%, rgba(255,255,255,.5), transparent 50%),
        radial-gradient(1.2px 1.2px at 58% 12%, rgba(200, 207, 218,.55), transparent 50%) !important;
    background-size: 100% 100% !important;
    opacity: .25 !important;
    animation: lunarStars 240s linear infinite !important;
    pointer-events: none !important;
    z-index: 2 !important;
}
@keyframes lunarStars {
    0%   { transform: translate3d(0, 0, 0); opacity: .55; }
    50%  { opacity: .9; }
    100% { transform: translate3d(-40%, -25%, 0); opacity: .55; }
}

/* Slow drifting nebula blob layer — sits *behind* the bg-video for a
   subtle color cast at the edges, doesn't cover the video itself */
body::before {
    content: '';
    position: fixed;
    inset: -20%;
    z-index: -1;
    background:
        radial-gradient(ellipse 35% 25% at 20% 30%, rgba(200, 202, 208, .12), transparent 70%),
        radial-gradient(ellipse 25% 20% at 80% 70%, rgba(94, 114, 152, .10), transparent 70%);
    filter: blur(40px);
    animation: lunarNebula 60s ease-in-out infinite alternate;
    pointer-events: none;
}
@keyframes lunarNebula {
    0%   { transform: translate3d(0, 0, 0) scale(1); opacity: .8; }
    100% { transform: translate3d(4%, -3%, 0) scale(1.15); opacity: 1; }
}

/* Hero — Orbitron sci-fi mark, matte, no glow */
.hero { padding-top: 110px !important; }
.hero-content {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: 1.4rem !important;
    text-align: center !important;
    padding: 0 1.5rem !important;
}
.hero-title { font-family: var(--f-display) !important; margin: 0 !important; }
.hero-title .s2 {
    font-family: 'Rajdhani', 'Outfit', -apple-system, sans-serif !important;
    font-weight: 600 !important;
    font-style: normal !important;
    letter-spacing: 14px !important;
    text-transform: uppercase !important;
    color: transparent !important;
    background: linear-gradient(180deg, #FFFFFF 0%, #E8EDF5 30%, #B8C8E0 65%, #6E84A8 100%) !important;
    -webkit-background-clip: text !important;
    background-clip: text !important;
    -webkit-text-fill-color: transparent !important;
    text-shadow: none !important;
    filter: drop-shadow(0 8px 32px rgba(200, 202, 208, .25)) !important;
    line-height: 1 !important;
    font-size: clamp(3rem, 9.5vw, 7.5rem) !important;
    display: inline-block !important;
    padding-right: 14px !important;
}

/* Mouse-reactive hero title — tilt + gradient that follows the cursor.
   JS sets --rx, --ry, --glx, --gly on #heroWrap. No box, no overlay. */
#heroWrap {
    perspective: 1400px !important;
    display: inline-block !important;
    position: relative !important;
    transform-style: preserve-3d !important;
    background: none !important;
    border: 0 !important;
    box-shadow: none !important;
}
#heroWrap::before, #heroWrap::after {
    display: none !important;
    content: none !important;
    background: transparent !important;
}
#heroWrap .hero-title {
    transform: none !important;
    transform-style: flat !important;
    transition: none !important;
    will-change: auto !important;
    background: none !important;
    border: 0 !important;
}

/* Eyebrow tag above title */
.hero-eyebrow {
    display: inline-flex !important;
    align-items: center !important;
    gap: .6rem !important;
    padding: .45rem 1rem !important;
    border: 1px solid var(--line) !important;
    border-radius: 999px !important;
    background: rgba(14, 17, 25, .55) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    color: var(--text2) !important;
    font-family: var(--f-mono) !important;
    font-size: .72rem !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    margin-bottom: .4rem !important;
}
.he-dot {
    width: 6px !important; height: 6px !important;
    border-radius: 50% !important;
    background: var(--moon) !important;
}

/* Tagline */
.hero-sub {
    font-family: var(--f-body) !important;
    font-weight: 300 !important;
    font-size: clamp(.9rem, 1.4vw, 1.1rem) !important;
    color: var(--text2) !important;
    letter-spacing: .5px !important;
    max-width: 480px !important;
    margin: 0 auto !important;
    line-height: 1.55 !important;
}

/* Meta stats row */
.hero-meta {
    display: flex !important;
    align-items: center !important;
    gap: 1.4rem !important;
    margin-top: .8rem !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
}
.hm-item {
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    gap: .15rem !important;
    min-width: 86px !important;
}
.hm-num {
    font-family: 'Orbitron', sans-serif !important;
    font-weight: 600 !important;
    font-size: 1.5rem !important;
    color: var(--text) !important;
    letter-spacing: 1px !important;
    line-height: 1 !important;
}
.hm-num i {
    font-style: normal !important;
    color: var(--muted) !important;
    font-size: .65em !important;
    margin-left: 1px !important;
    font-weight: 400 !important;
}
.hm-lbl {
    font-family: var(--f-mono) !important;
    font-size: .65rem !important;
    font-weight: 500 !important;
    letter-spacing: 2px !important;
    text-transform: uppercase !important;
    color: var(--dim) !important;
}
.hm-sep {
    width: 1px !important;
    height: 28px !important;
    background: var(--line) !important;
}

/* CTA pair — twin outline buttons (same style, no container chrome, no focus ring noise) */
.hero-cta {
    display: flex !important;
    gap: .6rem !important;
    margin-top: .6rem !important;
    flex-wrap: wrap !important;
    justify-content: center !important;
    background: transparent !important;
    border: 0 !important;
    box-shadow: none !important;
    outline: none !important;
    padding: 0 !important;
    position: relative !important;
}
.hero-cta::before, .hero-cta::after {
    display: none !important;
    content: none !important;
    background: transparent !important;
    width: 0 !important;
    height: 0 !important;
}
.hcta-primary, .hcta-ghost {
    display: inline-flex !important;
    align-items: center !important;
    gap: .55rem !important;
    padding: .85rem 1.8rem !important;
    border-radius: 4px !important;
    font-family: 'Orbitron', sans-serif !important;
    font-weight: 500 !important;
    font-size: .72rem !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    text-decoration: none !important;
    background: transparent !important;
    color: var(--text) !important;
    border: 1px solid rgba(200, 202, 208, .25) !important;
    box-shadow: none !important;
    outline: none !important;
    transition: background .2s ease, color .2s ease, border-color .2s ease !important;
    cursor: pointer !important;
    transform: none !important;
}
.hcta-primary svg, .hcta-ghost svg { opacity: .7 !important; }
.hcta-primary:hover, .hcta-ghost:hover {
    border-color: var(--moon) !important;
    background: rgba(200, 202, 208, .07) !important;
    color: var(--moon-strong) !important;
    transform: none !important;
    box-shadow: none !important;
}
.hcta-primary:focus, .hcta-ghost:focus,
.hcta-primary:focus-visible, .hcta-ghost:focus-visible {
    outline: none !important;
    box-shadow: none !important;
    border-color: var(--moon) !important;
}

.hero-scroll, .hero-scroll * {
    font-family: var(--f-mono) !important;
    font-weight: 500 !important;
    letter-spacing: 3px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
    font-size: .68rem !important;
}
.hero-scroll { margin-top: 2rem !important; }

@media (max-width: 640px) {
    .hm-sep { display: none !important; }
    .hero-meta { gap: 1.6rem !important; }
}

/* Navbar — variable-driven so JS can swap via :root vars on scroll */
.nav {
    background-color: var(--nav-bg, rgba(14, 17, 25, .55)) !important;
    background-image: none !important;
    border-bottom-color: var(--nav-border, var(--line)) !important;
    border-bottom-width: 1px !important;
    border-bottom-style: solid !important;
    backdrop-filter: var(--nav-blur, blur(10px) saturate(140%)) !important;
    -webkit-backdrop-filter: var(--nav-blur, blur(10px) saturate(140%)) !important;
    height: var(--nav-h, 68px) !important;
    box-shadow: var(--nav-shadow, none) !important;
    transition: background-color .3s var(--ease), backdrop-filter .3s var(--ease), -webkit-backdrop-filter .3s var(--ease), border-color .3s var(--ease), box-shadow .3s var(--ease), height .3s var(--ease) !important;
}
.nav::after {
    background: linear-gradient(90deg, transparent 0%, rgba(200, 202, 208, .14) 50%, transparent 100%) !important;
    height: 1px !important;
}
.nav-links { gap: .3rem !important; }
.nav-links a {
    font-family: 'Outfit', sans-serif !important;
    font-weight: 500 !important;
    font-size: 1rem !important;
    letter-spacing: .2px !important;
    text-transform: none !important;
    color: var(--text2) !important;
    padding: .65rem 1.15rem !important;
    border-radius: 8px !important;
}
.nav-links a:hover { background: transparent !important; color: var(--text) !important; }
.nav-links a.act { background: transparent !important; color: var(--text) !important; font-weight: 600 !important; }
.nav-links a.act::before {
    background: var(--moon) !important;
    height: 2px !important;
    left: 1.15rem !important;
    right: 1.15rem !important;
    bottom: .25rem !important;
    border-radius: 1px !important;
}

/* Sign in CTA + status pill — Outfit smooth, matte */
.nav-cta {
    font-family: 'Outfit', sans-serif !important;
    font-weight: 600 !important;
    font-size: .85rem !important;
    letter-spacing: .3px !important;
    text-transform: none !important;
    padding: .4rem .55rem !important;
    border-radius: 8px !important;
    background: transparent !important;
    border: none !important;
    color: var(--text) !important;
    transition: color .2s ease, background .2s ease !important;
}
.nav-cta:hover {
    color: var(--moon) !important;
    background: rgba(255, 255, 255, .05) !important;
}
.nav-status {
    font-family: 'Outfit', sans-serif !important;
    font-size: .8rem !important;
    letter-spacing: .3px !important;
    font-weight: 600 !important;
    padding: .5rem .4rem !important;
    background: transparent !important;
    border: none !important;
    color: var(--text2) !important;
    text-transform: none !important;
}
.nav-status .ns-dot {
    background: var(--success) !important;
    width: 6px !important; height: 6px !important;
    box-shadow: none !important;
}
/* Navbar logo accent inherits cool silver */
.nav-logo-mark { color: var(--moon) !important; }
.nav-logo-mark:hover { transform: scale(1.05) !important; filter: none !important; }

/* Nav-left group: brand + server pills */
.nav-left {
    display: flex !important;
    align-items: center !important;
    gap: 1.1rem !important;
    flex: 1 1 0 !important;
    min-width: 0 !important;
}

/* Brand: crescent moon + wordmark */
.nav-brand {
    display: inline-flex !important;
    align-items: center !important;
    gap: .65rem !important;
    text-decoration: none !important;
    padding: .25rem .35rem !important;
    border-radius: 6px !important;
    transition: opacity .2s ease !important;
}
.nav-brand:hover { opacity: .85 !important; }
.nav-brand-icon {
    width: 26px !important;
    height: 26px !important;
    flex-shrink: 0 !important;
    transition: transform .4s cubic-bezier(.22,1,.36,1) !important;
}
.nav-brand:hover .nav-brand-icon { transform: rotate(-12deg) !important; }
.nav-brand-text {
    display: inline-flex !important;
    align-items: baseline !important;
    gap: .35rem !important;
    font-family: 'Outfit', sans-serif !important;
    font-size: .92rem !important;
    letter-spacing: .8px !important;
    line-height: 1 !important;
    color: var(--text) !important;
}
.nav-brand-text b {
    font-weight: 700 !important;
    color: var(--text) !important;
}
.nav-brand-text em {
    font-style: normal !important;
    font-weight: 400 !important;
    color: var(--muted) !important;
    letter-spacing: 1px !important;
}

/* Next-wipe pill in nav-actions */
.nav-wipe {
    display: inline-flex !important;
    align-items: center !important;
    gap: .55rem !important;
    padding: .42rem .8rem !important;
    border-radius: 8px !important;
    background: rgba(255, 255, 255, .03) !important;
    border: 1px solid var(--line) !important;
    font-family: 'Outfit', sans-serif !important;
    color: var(--text2) !important;
    transition: border-color .2s ease, background .2s ease !important;
}
.nav-wipe:hover {
    border-color: rgba(200, 202, 208, .3) !important;
    background: rgba(200, 202, 208, .05) !important;
}
.nw-icon {
    color: var(--moon) !important;
    font-size: 1rem !important;
    line-height: 1 !important;
    opacity: .9 !important;
}
.nw-grp { display: inline-flex !important; flex-direction: column !important; gap: 1px !important; line-height: 1 !important; }
.nw-lbl {
    font-size: .58rem !important;
    font-weight: 500 !important;
    letter-spacing: 1.2px !important;
    text-transform: uppercase !important;
    color: var(--muted) !important;
}
.nw-val {
    font-family: 'JetBrains Mono', monospace !important;
    font-size: .82rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
}
.nw-val i {
    font-style: normal !important;
    font-weight: 400 !important;
    color: var(--muted) !important;
    font-size: .85em !important;
    margin-left: 1px !important;
    margin-right: 3px !important;
}

@media (max-width: 920px) {
    .nav-wipe, .nav-srv { display: none !important; }
}
@media (max-width: 640px) {
    .nav-brand-text { display: none !important; }
}

/* Server status pill — matte */
.nv-srv {
    background: rgba(14, 17, 25, .5) !important;
    border: 1px solid var(--line) !important;
}
.nv-srv:hover {
    background: rgba(16, 13, 28, .8) !important;
    border-color: rgba(200, 202, 208, .25) !important;
    transform: none !important;
}
.nv-srv-dot { background: #7FB89B !important; box-shadow: none !important; animation: none !important; }
.nv-srv.off .nv-srv-dot { background: #C77B92 !important; }

/* Sign in / nav CTA — matte outline */
.nav-cta, .nav-status {
    background: transparent !important;
    border: 1px solid var(--line) !important;
    color: var(--text) !important;
    box-shadow: none !important;
}
.nav-cta:hover { border-color: var(--moon) !important; background: transparent !important; }

/* Nav actions — kutusuz, hizalı, dolgun profil */
.nav-actions { gap: 1rem !important; }
.nav-actions .nav-status,
.nav-actions .nav-cta {
    height: 42px !important;
    display: inline-flex !important;
    align-items: center !important;
    white-space: nowrap !important;
    border: none !important;
    background: transparent !important;
    box-shadow: none !important;
    padding: 0 .35rem !important;
    line-height: 1 !important;
}
/* Online göstergesi — tek satır, sade */
.nav-actions .nav-status {
    gap: .5rem !important;
    font-size: .9rem !important;
    color: var(--text2) !important;
}
/* Profil — büyük avatar + dolgun isim */
.nav-actions .nav-cta {
    gap: .6rem !important;
    font-size: 1rem !important;
    font-weight: 600 !important;
    color: var(--text) !important;
}
.nav-actions .nav-cta:hover {
    color: var(--moon) !important;
    background: transparent !important;
}
.nav-actions .nav-avatar {
    width: 32px !important;
    height: 32px !important;
    border-radius: 50% !important;
    border: 2px solid var(--line) !important;
}
.nav-actions .nav-cta:hover .nav-avatar {
    border-color: var(--moon) !important;
}
.nav-actions .nav-cta-icon {
    width: 20px !important;
    height: 20px !important;
}

/* Server cards — matte border, hover = brightened border only */
.scard {
    background: rgba(14, 17, 25, .55) !important;
    border: 1px solid var(--line) !important;
    backdrop-filter: blur(4px) !important;
    -webkit-backdrop-filter: blur(4px) !important;
    transition: border-color .3s ease, background .3s ease, transform .3s ease !important;
}
.scard:hover {
    background: rgba(16, 13, 28, .72) !important;
    border-color: rgba(200, 202, 208, .35) !important;
    transform: translateY(-2px) !important;
    box-shadow: none !important;
}
.sc-cta, .v2-btn-primary, .btn-buy {
    background: transparent !important;
    border: 1px solid var(--moon) !important;
    color: var(--text) !important;
    box-shadow: none !important;
    text-shadow: none !important;
    font-family: var(--f-body) !important;
    font-weight: 500 !important;
    letter-spacing: 2.5px !important;
    transition: background .25s ease, color .25s ease !important;
}
.sc-cta:hover, .v2-btn-primary:hover, .btn-buy:hover {
    background: var(--moon) !important;
    color: var(--bg) !important;
    transform: none !important;
}
.sc-cta::before { display: none !important; }
.sc-fill { background: var(--moon) !important; box-shadow: none !important; }

/* Product card same matte treatment */
.product-card {
    background: #171A21 !important;
    border: 1px solid var(--line) !important;
    backdrop-filter: none !important;
    box-shadow: 0 12px 36px -14px rgba(0,0,0,0.55) !important;
}
.product-card:hover {
    background: #1C2029 !important;
    border-color: rgba(200, 202, 208, .35) !important;
    transform: translateY(-2px) !important;
    box-shadow: 0 20px 48px -16px rgba(0,0,0,0.7) !important;
}
.current-price { color: var(--moon) !important; font-family: var(--f-display) !important; font-weight: 600 !important; }

/* Floating Discord/Steam — matte, neutralized, smaller glow */
.fi-chip {
    background: rgba(14, 17, 25, .85) !important;
    border: 1px solid var(--line) !important;
    box-shadow: none !important;
}
.fi-chip.discord, .fi-chip.steam {
    background: rgba(14, 17, 25, .85) !important;
    box-shadow: none !important;
}
.fi-chip svg { color: var(--text) !important; fill: var(--text) !important; }
.fi-chip:hover {
    border-color: rgba(200, 202, 208, .4) !important;
    transform: translateY(-1px) scale(1) !important;
    filter: none !important;
    box-shadow: none !important;
}

/* Page loader — sharp matte moon, no halo glow */
#page-loader {
    background: var(--bg) !important;
}
#page-loader::before { display: none !important; }
.pl-stars { opacity: .35 !important; }
.pl-moon-halo { display: none !important; }
.pl-moon {
    filter: none !important;
    animation: plMoonFloat 6s ease-in-out infinite !important;
}
.pl-mark {
    font-family: var(--f-display) !important;
    font-weight: 500 !important;
    font-style: normal !important;
    letter-spacing: 7px !important;
    text-transform: uppercase !important;
    font-size: 2rem !important;
}
.pl-mark-a { color: var(--text) !important; text-shadow: none !important; }
.pl-mark-b { color: var(--moon) !important; text-shadow: none !important; }
.pl-bar { background: rgba(255,255,255,.04) !important; }
.pl-bar-fill {
    background: linear-gradient(90deg, transparent, var(--moon), transparent) !important;
    box-shadow: none !important;
    animation: plBar 1.6s ease-in-out infinite !important;
}

/* Servers section header — quiet */
.servers-eye {
    background: transparent !important;
    border: 1px solid var(--line) !important;
    color: var(--muted) !important;
    box-shadow: none !important;
}
.servers-eye-dot { background: var(--moon) !important; box-shadow: none !important; }
.servers-h2 {
    font-family: var(--f-display) !important;
    font-weight: 500 !important;
    font-style: normal !important;
    text-transform: uppercase !important;
    letter-spacing: 4px !important;
    color: var(--text) !important;
}
.servers-sub { color: var(--muted) !important; font-family: var(--f-body) !important; }

/* Status / online indicator dots — matte, no pulse glow */
.sc-status, .sd, .ns-dot { box-shadow: none !important; }
.ns-dot { background: var(--moon) !important; }

/* Navbar server chip — sol ustte, Max5'e ozel, online/offline nokta */
.nav-left { display: flex; align-items: center; flex: 0 0 auto; gap: .85rem; }
.nav-logo { display: inline-flex; align-items: center; flex-shrink: 0; }
.nav-logo-img {
    height: 46px; width: auto; display: block;
    transition: transform .2s ease, filter .2s ease;
}
.nav-logo:hover .nav-logo-img { transform: scale(1.06); filter: drop-shadow(0 0 9px rgba(200, 202, 208, .45)); }
@media (max-width: 760px) { .nav-logo-img { height: 38px; } }
.nav-srv {
    display: inline-flex; align-items: center; gap: .55rem;
    height: 38px; padding: 0 .8rem;
    border: 1px solid var(--line); border-radius: 8px;
    font-family: var(--f-mono); font-size: .82rem;
    color: var(--text); text-decoration: none; white-space: nowrap;
    transition: border-color .2s ease, background .2s ease;
}
.nav-srv:hover { border-color: var(--moon); background: rgba(255,255,255,.03); }
.nav-srv .nsv-dot { width: 7px; height: 7px; border-radius: 50%; flex-shrink: 0; }
.nav-srv.on  .nsv-dot { background: #4ADE80; box-shadow: 0 0 8px rgba(74,222,128,.65); }
.nav-srv.off .nsv-dot { background: #EF4444; box-shadow: 0 0 7px rgba(239,68,68,.5); }
.nav-srv .nsv-tag { letter-spacing: .08em; font-weight: 600; color: var(--text); }
.nav-srv .nsv-num { font-variant-numeric: tabular-nums; color: var(--text2); }
.nav-srv .nsv-sep { color: var(--text2); margin: 0 1px; opacity: .6; }
@media (max-width: 760px) { .nav-srv { height: 34px; padding: 0 .65rem; font-size: .78rem; } }

/* Page transition overlay — pure dark, no glow */
#page-trans {
    background: var(--bg) !important;
}

/* Footer — quiet */
.v2-footer { background: transparent !important; border-top: 1px solid var(--line) !important; }
.v2-foot-copy { font-family: var(--f-mono) !important; color: var(--dim) !important; }

/* ============================================================
   Nav language switcher
   ============================================================ */
.nav-lang {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    margin: 0 8px 0 4px;
}
.nav-lang-opt {
    color: var(--text-muted);
    text-decoration: none;
    padding: 4px 6px;
    border-radius: var(--radius-sm);
    transition: color var(--duration-fast) var(--ease-out), background-color var(--duration-fast) var(--ease-out);
}
.nav-lang-opt:hover { color: var(--text-secondary); }
.nav-lang-opt.is-active { color: var(--text-primary); background: var(--accent-subtle); }
.nav-lang-sep { color: var(--text-muted); opacity: .5; }

/* ============================================================
   Home Updates section
   ============================================================ */
.home-updates {
    padding: 6rem 2.5rem 5rem;
    max-width: 1280px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}
@media (max-width: 760px) { .home-updates { padding: 4rem 1.2rem 3rem; } }

.hu-head {
    text-align: center;
    margin-bottom: 2.5rem;
}
.hu-eye {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 14px;
}
.hu-eye-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent-glow);
}
.hu-h2 {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: clamp(1.8rem, 3.5vw, 2.4rem);
    letter-spacing: var(--ls-tight);
    color: var(--text-primary);
    line-height: var(--lh-snug);
    margin-bottom: 8px;
    text-transform: uppercase;
}
.hu-sub {
    font-family: var(--f-body);
    color: var(--text-muted);
    font-size: var(--text-sm);
}

.hu-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 1.4rem;
}
@media (max-width: 960px) { .hu-grid { grid-template-columns: 1fr 1fr; } }
@media (max-width: 640px) { .hu-grid { grid-template-columns: 1fr; max-width: 480px; margin: 0 auto; } }

.hu-card {
    display: flex;
    flex-direction: column;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    transition: transform var(--duration-normal) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-normal) var(--ease-out);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.hu-card:hover {
    transform: translateY(-3px);
    border-color: var(--border-default);
    box-shadow: var(--shadow-lg), var(--shadow-glow);
}

.hu-card-img {
    position: relative;
    aspect-ratio: 16/9;
    overflow: hidden;
    background: var(--bg-elevated);
}
.hu-card-img img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform var(--duration-slow) var(--ease-out);
    display: block;
}
.hu-card:hover .hu-card-img img { transform: scale(1.04); }
.hu-card-img-fallback {
    width: 100%; height: 100%;
    background: linear-gradient(135deg, var(--bg-elevated) 0%, var(--bg-surface) 100%);
}

.hu-card-body {
    padding: 20px 22px 22px;
    display: flex;
    flex-direction: column;
    flex: 1;
    gap: 8px;
}
.hu-card-date {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}
.hu-card-title {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: var(--text-md);
    letter-spacing: 0;
    color: var(--text-primary);
    line-height: var(--lh-snug);
    margin: 2px 0 4px;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: color var(--duration-fast) var(--ease-out);
}
.hu-card:hover .hu-card-title { color: var(--accent-hover); }
.hu-card-excerpt {
    font-family: var(--f-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: var(--lh-normal);
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    flex: 1;
}
.hu-card-link {
    margin-top: 10px;
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
    transition: color var(--duration-fast) var(--ease-out);
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.hu-card:hover .hu-card-link { color: var(--accent-hover); }
.hu-arrow { transition: transform var(--duration-fast) var(--ease-out); }
.hu-card:hover .hu-arrow { transform: translateX(3px); }

.hu-foot {
    text-align: center;
    margin-top: 2.5rem;
}
.hu-all {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    padding: 12px 22px;
    border: 1px solid var(--border-default);
    border-radius: var(--radius-full);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
    text-decoration: none;
    background: rgba(17, 19, 22, 0.4);
    transition: color var(--duration-fast) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                background-color var(--duration-fast) var(--ease-out);
}
.hu-all:hover {
    color: var(--text-primary);
    border-color: var(--accent);
    background: var(--accent-subtle);
}
.hu-all:hover .hu-arrow { transform: translateX(3px); }

/* ============================================================
   Community section — Discord widget + Steam
   ============================================================ */
.community {
    padding: 5rem 2.5rem 6rem;
    max-width: 1100px;
    margin: 0 auto;
    position: relative;
    z-index: 2;
}
@media (max-width: 760px) { .community { padding: 3rem 1.2rem 4rem; } }

.cm-head { text-align: center; margin-bottom: 2.5rem; }
.cm-eye {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 14px;
}
.cm-eye-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent-glow);
}
.cm-h2 {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: clamp(1.8rem, 3.5vw, 2.4rem);
    letter-spacing: var(--ls-tight);
    color: var(--text-primary);
    margin-bottom: 8px;
    text-transform: uppercase;
}
.cm-sub {
    font-family: var(--f-body);
    color: var(--text-muted);
    font-size: var(--text-sm);
}

.cm-grid {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 1.4rem;
}
@media (max-width: 760px) { .cm-grid { grid-template-columns: 1fr; } }

.cm-card {
    display: flex;
    flex-direction: column;
    gap: 16px;
    padding: 28px 28px 24px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    text-decoration: none;
    color: inherit;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: transform var(--duration-normal) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-normal) var(--ease-out);
    position: relative;
    overflow: hidden;
}
.cm-card::before {
    content: '';
    position: absolute;
    inset: 0;
    background: radial-gradient(ellipse 80% 50% at 50% 0%, var(--accent-subtle) 0%, transparent 70%);
    opacity: 0;
    transition: opacity var(--duration-normal) var(--ease-out);
    pointer-events: none;
}
.cm-card:hover {
    transform: translateY(-3px);
    border-color: var(--border-default);
    box-shadow: var(--shadow-lg), var(--shadow-glow);
}
.cm-card:hover::before { opacity: 1; }

.cm-discord:hover { border-color: rgba(88, 101, 242, 0.5); }
.cm-discord:hover::before { background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(88, 101, 242, 0.12) 0%, transparent 70%); }
.cm-steam:hover { border-color: rgba(102, 192, 244, 0.45); }
.cm-steam:hover::before { background: radial-gradient(ellipse 80% 50% at 50% 0%, rgba(102, 192, 244, 0.10) 0%, transparent 70%); }

.cm-card-top {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    position: relative;
    z-index: 1;
}
.cm-icon {
    width: 36px;
    height: 36px;
    padding: 7px;
    border-radius: var(--radius-md);
    background: var(--bg-elevated);
    border: 1px solid var(--border-subtle);
    color: var(--text-secondary);
}
.cm-discord .cm-icon { color: var(--discord); background: rgba(88, 101, 242, 0.12); border-color: rgba(88, 101, 242, 0.25); }
.cm-steam .cm-icon { color: var(--steam); background: rgba(102, 192, 244, 0.10); border-color: rgba(102, 192, 244, 0.22); }

.cm-pulse {
    display: inline-flex;
    align-items: center;
    gap: 7px;
    padding: 5px 11px;
    border-radius: var(--radius-full);
    background: var(--success-subtle);
    border: 1px solid rgba(133, 194, 154, 0.22);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--success);
    text-transform: uppercase;
}
.cm-pulse-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--success);
    box-shadow: 0 0 7px rgba(133, 194, 154, 0.7);
    animation: none;
}
@keyframes cmPulse { 0%,100%{opacity:1;} 50%{opacity:.35;} }
.cm-pulse-static {
    background: var(--accent-subtle);
    border-color: var(--glass-border);
    color: var(--text-secondary);
}

.cm-card-name {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: var(--text-lg);
    letter-spacing: 0;
    color: var(--text-primary);
    line-height: 1.2;
    margin: 0;
    position: relative;
    z-index: 1;
}

.cm-stats {
    display: flex;
    align-items: stretch;
    gap: 18px;
    padding: 16px 18px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-md);
    background: rgba(10, 11, 13, 0.4);
    position: relative;
    z-index: 1;
}
.cm-stat {
    display: flex;
    flex-direction: column;
    gap: 4px;
    flex: 1;
}
.cm-stat-num {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: var(--text-xl);
    color: var(--text-primary);
    line-height: 1;
    font-variant-numeric: tabular-nums;
}
.cm-stat-lbl {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}
.cm-stat-sep {
    width: 1px;
    background: var(--border-subtle);
}

.cm-avatars {
    display: flex;
    align-items: center;
    gap: 0;
    position: relative;
    z-index: 1;
}
.cm-avatar {
    width: 32px;
    height: 32px;
    border-radius: 50%;
    border: 2px solid var(--bg-base);
    object-fit: cover;
    margin-left: -8px;
    background: var(--bg-elevated);
    transition: transform var(--duration-fast) var(--ease-out);
}
.cm-avatar:first-child { margin-left: 0; }
.cm-avatar:hover { transform: translateY(-2px); z-index: 2; }
.cm-avatar-more {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--text-secondary);
    background: var(--bg-elevated);
    letter-spacing: 0;
    text-transform: none;
}

.cm-desc {
    font-family: var(--f-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: var(--lh-normal);
    margin: 0;
    position: relative;
    z-index: 1;
}

.cm-cta {
    margin-top: auto;
    padding-top: 4px;
    display: inline-flex;
    align-items: center;
    gap: 8px;
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
    transition: color var(--duration-fast) var(--ease-out);
    position: relative;
    z-index: 1;
}
.cm-card:hover .cm-cta { color: var(--text-primary); }
.cm-card:hover .cm-cta .hu-arrow { transform: translateX(3px); }

/* Floating chip count badge */
.fi-chip { position: relative; }
.fi-count {
    position: absolute;
    top: -4px;
    right: -4px;
    min-width: 18px;
    height: 18px;
    padding: 0 5px;
    border-radius: var(--radius-full);
    background: var(--success);
    color: #0A0B0D;
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: var(--fw-bold);
    line-height: 18px;
    text-align: center;
    border: 2px solid var(--bg-base);
    box-shadow: 0 0 8px rgba(133, 194, 154, 0.4);
}

/* ============================================================
   Wipes page (simple)
   ============================================================ */
.wp2-main {
    max-width: 760px;
    margin: 0 auto;
    padding: 9rem 1.5rem 5rem;
    position: relative;
    z-index: 2;
}
.wp2-hero {
    text-align: center;
    padding: 0 0 3rem;
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: 3rem;
}
.wp2-eyebrow {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 28px;
}
.wp2-line1 {
    font-family: var(--f-body);
    font-size: var(--text-md);
    color: var(--text-secondary);
    margin-bottom: 14px;
}
.wp2-big {
    display: inline-flex;
    align-items: baseline;
    gap: clamp(10px, 2vw, 22px);
    margin-bottom: 18px;
    line-height: 1;
}
.wp2-bu {
    display: inline-flex;
    align-items: baseline;
    gap: 4px;
}
.wp2-bn {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(3rem, 10vw, 6.5rem);
    color: var(--text-primary);
    letter-spacing: var(--ls-tight);
    text-shadow: none;
    font-variant-numeric: tabular-nums;
    min-width: 1.2ch;
    text-align: right;
    line-height: 1;
}
.wp2-bl {
    font-family: var(--f-mono);
    font-size: clamp(1rem, 2.4vw, 1.5rem);
    color: var(--text-muted);
    text-transform: lowercase;
    font-weight: var(--fw-medium);
    margin-right: 2px;
}
@media (max-width: 520px) {
    .wp2-big { gap: 8px; }
    .wp2-bu { gap: 2px; }
}
.wp2-line2 {
    font-family: var(--f-mono);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    letter-spacing: var(--ls-wide);
    margin-bottom: 36px;
    display: inline-flex;
    align-items: center;
    gap: 12px;
    flex-wrap: wrap;
    justify-content: center;
}
.wp2-type-badge {
    display: inline-flex;
    align-items: center;
    padding: 4px 12px;
    border-radius: var(--radius-full);
    font-family: var(--f-mono);
    font-size: 11px;
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    border: 1px solid;
}
.wp2-type-badge.is-force {
    color: #F4B663;
    background: rgba(212, 167, 106, 0.10);
    border-color: rgba(212, 167, 106, 0.35);
}
.wp2-type-badge.is-map {
    color: var(--text-secondary);
    background: var(--accent-subtle);
    border-color: var(--glass-border);
}
.wp2-explain {
    max-width: 540px;
    margin: 0 auto;
    padding: 22px 26px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    font-family: var(--f-body);
    font-size: var(--text-base);
    line-height: var(--lh-relaxed);
    color: var(--text-secondary);
    text-align: left;
}
.wp2-explain strong {
    color: var(--text-primary);
    font-weight: var(--fw-semibold);
    display: block;
    margin-bottom: 6px;
    font-family: var(--f-display);
    letter-spacing: var(--ls-tight);
}

.wp2-upcoming { padding-top: 0; }
.wp2-up-head {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 18px;
}
.wp2-up-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 14px;
}
@media (max-width: 600px) { .wp2-up-grid { grid-template-columns: 1fr; max-width: 320px; margin: 0 auto; } }

.wp2-card {
    position: relative;
    padding: 30px 20px 20px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    text-align: center;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);
}
.wp2-card-tag {
    position: absolute;
    top: -9px;
    left: 50%;
    transform: translateX(-50%);
    padding: 3px 10px;
    border-radius: var(--radius-full);
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    border: 1px solid;
    background: var(--bg-base);
}
.wp2-card-tag.is-force {
    color: #F4B663;
    border-color: rgba(212, 167, 106, 0.45);
}
.wp2-card-tag.is-map {
    color: var(--text-secondary);
    border-color: var(--border-default);
}
.wp2-card:hover { border-color: var(--border-default); transform: translateY(-2px); }
.wp2-card.is-next {
    border-color: var(--accent);
    background: linear-gradient(180deg, var(--accent-subtle) 0%, var(--glass-bg) 70%);
    box-shadow: 0 0 24px var(--accent-glow);
}
.wp2-card-date {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: var(--text-xl);
    color: var(--text-primary);
    line-height: 1;
    margin-bottom: 6px;
}
.wp2-card-day {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 14px;
}
.wp2-card-out {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
    display: inline-flex;
    align-items: center;
    gap: 6px;
}
.wp2-now-dot {
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 7px var(--accent-glow);
    animation: none;
}
.wp2-card.is-next .wp2-card-out { color: var(--accent); }

/* ============================================================
   Wipes page — 3 wipe types
   ============================================================ */
.wp3-main {
    max-width: 1180px;
    margin: 0 auto;
    padding: 9rem 1.5rem 5rem;
    position: relative;
    z-index: 2;
}
.wp3-intro {
    text-align: center;
    margin-bottom: 3rem;
}
.wp3-h1 {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    letter-spacing: var(--ls-tight);
    color: var(--text-primary);
    margin: 14px 0 12px;
    text-transform: uppercase;
}
.wp3-sub {
    font-family: var(--f-body);
    font-size: var(--text-md);
    color: var(--text-secondary);
    margin: 0;
}

.wp3-cards {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 18px;
    margin-bottom: 4rem;
}
@media (max-width: 960px) { .wp3-cards { grid-template-columns: 1fr; max-width: 540px; margin-left: auto; margin-right: auto; } }

.wp3-card {
    padding: 26px 26px 28px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    display: flex;
    flex-direction: column;
    gap: 14px;
    position: relative;
    transition: border-color var(--duration-fast) var(--ease-out);
}
.wp3-card.is-soonest {
    border-color: var(--accent);
    background: linear-gradient(180deg, var(--accent-subtle) 0%, var(--glass-bg) 70%);
    box-shadow: 0 0 28px var(--accent-glow);
}
.wp3-card-head {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 12px;
}
.wp3-card-cadence {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wp3-card-pill {
    padding: 3px 10px;
    border-radius: var(--radius-full);
    background: var(--accent);
    color: var(--bg-base);
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
}
.wp3-card-title {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: var(--text-xl);
    color: var(--text-primary);
    letter-spacing: var(--ls-tight);
    margin: 0;
    line-height: 1.1;
    text-transform: uppercase;
}
.wp3-card-tag {
    display: inline-block;
    width: fit-content;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    background: rgba(10, 11, 13, 0.5);
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    padding: 3px 10px;
    text-transform: uppercase;
}
.wp3-count {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 6px 4px;
    margin-top: 6px;
}
.wp3-count .wp2-bu {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    min-width: 44px;
}
.wp3-count .wp2-bn {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(1.6rem, 3.4vw, 2.3rem);
    color: var(--text-primary);
    line-height: 1;
    letter-spacing: var(--ls-tight);
    text-shadow: none;
    font-variant-numeric: tabular-nums;
    text-align: center;
}
.wp3-count .wp2-bl {
    font-family: var(--f-mono);
    font-size: 11px;
    color: var(--text-secondary);
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    font-weight: var(--fw-medium);
}
.wp3-sep {
    font-family: var(--f-display);
    font-size: clamp(1.4rem, 3vw, 2rem);
    color: var(--text-muted);
    opacity: 0.4;
    padding-bottom: 18px;
    line-height: 1;
}
@media (max-width: 420px) { .wp3-sep { display: none; } .wp3-count { gap: 6px 10px; } }
.wp3-card-when {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-secondary);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    padding-bottom: 4px;
    border-bottom: 1px solid var(--border-subtle);
}
.wp3-card-desc {
    font-family: var(--f-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
    line-height: var(--lh-relaxed);
    margin: 0;
}
.wp3-card-desc strong {
    color: var(--text-primary);
    font-weight: var(--fw-semibold);
}

.wp3-card-source {
    display: flex;
    align-items: center;
    gap: 10px;
    margin-top: 4px;
    padding: 10px 14px;
    border-radius: var(--radius-md);
    background: rgba(10, 11, 13, 0.5);
    border: 1px solid var(--border-subtle);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-secondary);
    text-decoration: none;
    text-transform: uppercase;
    letter-spacing: var(--ls-wide);
    transition: border-color var(--duration-fast) var(--ease-out), color var(--duration-fast) var(--ease-out);
}
a.wp3-card-source:hover {
    color: var(--text-primary);
    border-color: var(--border-default);
}
.wp3-src-lbl {
    color: var(--text-muted);
    flex-shrink: 0;
}
.wp3-src-val {
    flex: 1;
    color: var(--text-secondary);
    text-transform: none;
    letter-spacing: 0;
    font-family: var(--f-body);
    font-size: 12px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}
a.wp3-card-source:hover .wp3-src-val { color: var(--text-primary); }
.wp3-src-arrow {
    flex-shrink: 0;
    color: var(--text-muted);
    transition: transform var(--duration-fast) var(--ease-out);
}
a.wp3-card-source:hover .wp3-src-arrow { transform: translateX(3px); color: var(--accent); }
.wp3-card-source-static { cursor: default; }

.wp3-thursdays {
    max-width: 720px;
    margin: 0 auto;
}
.wp3-th-head {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 14px;
    text-align: center;
}
.wp3-th-list {
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    overflow: hidden;
}
.wp3-th-row {
    display: grid;
    grid-template-columns: 100px 1fr auto 90px;
    align-items: center;
    gap: 14px;
    padding: 14px 22px;
    border-bottom: 1px solid var(--border-subtle);
    font-family: var(--f-body);
    font-size: var(--text-sm);
}
.wp3-th-row:last-child { border-bottom: 0; }
.wp3-th-date {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    color: var(--text-primary);
    font-size: var(--text-md);
    letter-spacing: var(--ls-tight);
}
.wp3-th-day {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wp3-th-out {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-secondary);
    text-transform: uppercase;
    text-align: right;
}
@media (max-width: 600px) {
    .wp3-th-row { grid-template-columns: auto auto; gap: 6px 14px; padding: 12px 16px; }
    .wp3-th-day { grid-column: 1 / -1; }
    .wp3-th-out { grid-column: 2; text-align: right; }
}

/* ============================================================
   Wipes — cinematic hero version
   ============================================================ */
.wpx-main {
    max-width: 1240px;
    margin: 0 auto;
    padding: 0 1.5rem 5rem;
    position: relative;
    z-index: 2;
}

/* HERO */
.wpx-hero {
    position: relative;
    padding: 8rem 1.5rem 5rem;
    min-height: 88vh;
    display: flex;
    align-items: center;
    justify-content: center;
    overflow: hidden;
}
.wpx-moon {
    position: absolute;
    top: 50%;
    right: -6%;
    transform: translateY(-50%);
    width: clamp(420px, 60vw, 720px);
    height: clamp(420px, 60vw, 720px);
    pointer-events: none;
    opacity: 0.55;
    z-index: 0;
    filter: drop-shadow(0 0 80px rgba(200, 202, 208, 0.10));
    animation: wpxMoonFloat 14s ease-in-out infinite;
}
.wpx-moon svg { width: 100%; height: 100%; display: block; }
@keyframes wpxMoonFloat {
    0%, 100% { transform: translateY(-50%) rotate(0deg); }
    50%      { transform: translateY(calc(-50% - 18px)) rotate(2deg); }
}
@media (max-width: 880px) {
    .wpx-moon { right: -25%; top: 8%; transform: none; opacity: 0.28; }
    @keyframes wpxMoonFloat {
        0%, 100% { transform: translate(0, 0) rotate(0deg); }
        50%      { transform: translate(0, -14px) rotate(2deg); }
    }
}

.wpx-hero-in {
    position: relative;
    z-index: 1;
    max-width: 760px;
    width: 100%;
}

.wpx-eyebrow {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 8px 16px;
    border: 1px solid var(--border-default);
    border-radius: var(--radius-full);
    background: rgba(10, 11, 13, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
    margin-bottom: 28px;
}
.wpx-eyebrow-dot {
    width: 7px; height: 7px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 10px var(--accent-glow);
    animation: none;
}

.wpx-type {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(3rem, 9vw, 6.5rem);
    color: var(--text-primary);
    line-height: 0.95;
    letter-spacing: var(--ls-tighter);
    text-transform: uppercase;
    margin: 0 0 40px;
    text-shadow: none;
}

.wpx-count {
    display: flex;
    align-items: flex-end;
    flex-wrap: wrap;
    gap: 4px;
    margin-bottom: 28px;
}
.wpx-bu {
    display: inline-flex;
    flex-direction: column;
    align-items: center;
    gap: 6px;
    min-width: 78px;
}
.wpx-bn {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(2.8rem, 6vw, 4.5rem);
    color: var(--text-primary);
    line-height: 1;
    letter-spacing: var(--ls-tight);
    text-shadow: none;
    font-variant-numeric: tabular-nums;
    text-align: center;
}
.wpx-bl {
    font-family: var(--f-mono);
    font-size: var(--text-xs);
    color: var(--text-secondary);
    letter-spacing: var(--ls-wider);
    font-weight: var(--fw-medium);
    text-transform: uppercase;
}
.wpx-sep {
    font-family: var(--f-display);
    font-size: clamp(2rem, 4vw, 3rem);
    color: var(--text-muted);
    opacity: 0.4;
    padding-bottom: 22px;
    line-height: 1;
    margin: 0 6px;
}
@media (max-width: 540px) {
    .wpx-sep { display: none; }
    .wpx-bu { min-width: 60px; }
    .wpx-count { gap: 8px 14px; }
}

.wpx-when {
    display: inline-flex;
    align-items: center;
    gap: 12px;
    padding: 12px 22px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    background: rgba(10, 11, 13, 0.5);
    font-family: var(--f-mono);
    font-size: var(--text-sm);
    color: var(--text-primary);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
    margin-bottom: 22px;
}
.wpx-when-sep { color: var(--text-muted); opacity: 0.5; }
.wpx-hero-desc {
    font-family: var(--f-body);
    font-size: var(--text-md);
    color: var(--text-secondary);
    max-width: 480px;
    line-height: var(--lh-normal);
}

/* OTHERS — alt 2 wipe ufak destek satırı */
.wpx-others {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 4rem;
    position: relative;
    z-index: 2;
}
@media (max-width: 720px) { .wpx-others { grid-template-columns: 1fr; } }

.wpx-other {
    display: flex;
    align-items: center;
    justify-content: space-between;
    gap: 16px;
    padding: 22px 26px;
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: border-color var(--duration-fast) var(--ease-out), transform var(--duration-fast) var(--ease-out);
}
.wpx-other:hover {
    border-color: var(--border-default);
    transform: translateY(-2px);
}
.wpx-other-l { display: flex; flex-direction: column; gap: 4px; min-width: 0; }
.wpx-other-cadence {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wpx-other-label {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: var(--text-md);
    color: var(--text-primary);
    letter-spacing: var(--ls-tight);
    text-transform: uppercase;
}
.wpx-other-short {
    font-family: var(--f-body);
    font-size: var(--text-xs);
    color: var(--text-secondary);
}
.wpx-other-r {
    text-align: right;
    flex-shrink: 0;
    display: flex;
    flex-direction: column;
    align-items: flex-end;
    gap: 2px;
}
.wpx-other-d {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: 2.2rem;
    color: var(--text-primary);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    text-shadow: none;
}
.wpx-other-d span {
    font-family: var(--f-mono);
    font-size: 0.7rem;
    color: var(--text-muted);
    margin-left: 4px;
    font-weight: var(--fw-medium);
    text-transform: uppercase;
}
.wpx-other-when {
    font-family: var(--f-mono);
    font-size: 10px;
    color: var(--text-muted);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}

/* CALENDAR */
.wpx-cal {
    max-width: 720px;
    margin: 0 auto 3rem;
}
.wpx-cal-head {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    text-align: center;
    margin-bottom: 14px;
}
.wpx-cal-list {
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    overflow: hidden;
}
.wpx-cal-row {
    display: grid;
    grid-template-columns: 80px 1fr auto 70px;
    align-items: center;
    gap: 14px;
    padding: 14px 22px;
    border-bottom: 1px solid var(--border-subtle);
    font-family: var(--f-body);
}
.wpx-cal-row:last-child { border-bottom: 0; }
.wpx-cal-date {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: var(--text-md);
    color: var(--text-primary);
}
.wpx-cal-day {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wpx-cal-badge {
    display: inline-flex;
    padding: 4px 12px;
    border-radius: var(--radius-full);
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: var(--fw-semibold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
    border: 1px solid;
}
.wpx-cal-badge.is-full {
    color: #F4B663;
    background: rgba(212, 167, 106, 0.10);
    border-color: rgba(212, 167, 106, 0.35);
}
.wpx-cal-badge.is-map {
    color: var(--text-secondary);
    background: var(--accent-subtle);
    border-color: var(--glass-border);
}
.wpx-cal-out {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-secondary);
    text-align: right;
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
@media (max-width: 540px) {
    .wpx-cal-row { grid-template-columns: 1fr auto; gap: 6px 12px; }
    .wpx-cal-day { grid-column: 1 / -1; }
    .wpx-cal-out { grid-column: 2; text-align: right; }
}

/* SOURCE strip */
.wpx-src {
    max-width: 760px;
    margin: 0 auto;
    text-align: center;
}
.wpx-src-lbl {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 8px;
}
.wpx-src-link {
    display: inline-flex;
    align-items: center;
    gap: 10px;
    padding: 10px 18px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    background: rgba(10, 11, 13, 0.5);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-secondary);
    text-decoration: none;
    letter-spacing: var(--ls-wide);
    transition: color var(--duration-fast), border-color var(--duration-fast);
    text-transform: uppercase;
}
.wpx-src-link:hover { color: var(--text-primary); border-color: var(--accent); }
.wpx-src-name { color: var(--text-primary); }
.wpx-src-bullet { color: var(--text-muted); opacity: 0.5; }
.wpx-src-patch { color: var(--text-secondary); text-transform: none; letter-spacing: 0; font-family: var(--f-body); }
.wpx-src-link:hover .wpx-src-patch { color: var(--text-primary); }
.wpx-src-arrow { color: var(--text-muted); transition: transform var(--duration-fast); }
.wpx-src-link:hover .wpx-src-arrow { transform: translateX(3px); color: var(--accent); }

/* legacy wp- classes (eski sayfa kullanılmıyor artık ama style.css için kalabilir) */
.wipes-main { max-width: 1200px; margin: 0 auto; padding: 0 1.5rem; position: relative; z-index: 2; }

.wp-hero {
    padding: 9rem 1rem 4rem;
    text-align: center;
    border-bottom: 1px solid var(--border-subtle);
    margin-bottom: 3rem;
}
.wp-hero-in { max-width: 760px; margin: 0 auto; }
.wp-h1 {
    font-family: var(--f-display);
    font-weight: var(--fw-extrabold);
    font-size: clamp(2rem, 4.5vw, 3.2rem);
    letter-spacing: var(--ls-tight);
    color: var(--text-primary);
    margin: 14px 0 28px;
    text-transform: uppercase;
}

.wp-bigcount {
    display: inline-flex;
    align-items: stretch;
    gap: 8px;
    padding: 20px 28px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-lg);
    background: rgba(17, 19, 22, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.wp-bc-cell {
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 4px;
    min-width: 64px;
}
.wp-bc-num {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: clamp(1.8rem, 4vw, 2.8rem);
    color: var(--text-primary);
    line-height: 1;
    font-variant-numeric: tabular-nums;
    text-shadow: none;
}
.wp-bc-lbl {
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wp-bc-sep {
    font-family: var(--f-display);
    font-size: clamp(1.6rem, 3.5vw, 2.4rem);
    color: var(--text-muted);
    display: flex;
    align-items: center;
    opacity: .5;
    padding-top: 0;
    align-self: flex-start;
    margin-top: 4px;
}
@media (max-width: 520px) {
    .wp-bigcount { padding: 14px 18px; gap: 4px; }
    .wp-bc-cell { min-width: 50px; }
    .wp-bc-sep { display: none; }
}
.wp-when {
    margin-top: 18px;
    font-family: var(--f-mono);
    font-size: var(--text-xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-secondary);
    text-transform: uppercase;
}

.wp-section { margin-bottom: 4rem; }
.wp-sec-head {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    flex-wrap: wrap;
    gap: 12px;
    margin-bottom: 1.5rem;
    padding-bottom: 12px;
    border-bottom: 1px solid var(--border-subtle);
}
.wp-h2 {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: clamp(1.3rem, 2.5vw, 1.7rem);
    letter-spacing: var(--ls-tight);
    color: var(--text-primary);
    text-transform: uppercase;
}
.wp-sec-sub {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}

.wp-grid {
    display: grid;
    grid-template-columns: repeat(6, 1fr);
    gap: 14px;
}
@media (max-width: 1000px) { .wp-grid { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 560px) { .wp-grid { grid-template-columns: repeat(2, 1fr); } }

.wp-card {
    position: relative;
    padding: 22px 16px 18px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    text-align: center;
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    transition: transform var(--duration-normal) var(--ease-out),
                border-color var(--duration-fast) var(--ease-out),
                box-shadow var(--duration-normal) var(--ease-out);
}
.wp-card:hover {
    transform: translateY(-2px);
    border-color: var(--border-default);
    box-shadow: var(--shadow-md);
}
.wp-card.is-next {
    border-color: var(--accent);
    background: linear-gradient(180deg, var(--accent-subtle) 0%, var(--glass-bg) 60%);
    box-shadow: 0 0 28px var(--accent-glow);
}
.wp-pill {
    position: absolute;
    top: -10px;
    left: 50%;
    transform: translateX(-50%);
    padding: 4px 12px;
    border-radius: var(--radius-full);
    background: var(--accent);
    color: var(--bg-base);
    font-family: var(--f-mono);
    font-size: 10px;
    font-weight: var(--fw-bold);
    letter-spacing: var(--ls-wider);
    text-transform: uppercase;
}
.wp-card-month {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
    margin-bottom: 2px;
}
.wp-card-day {
    font-family: var(--f-display);
    font-weight: var(--fw-bold);
    font-size: 2.4rem;
    color: var(--text-primary);
    line-height: 1;
    margin: 4px 0;
    font-variant-numeric: tabular-nums;
}
.wp-card-year {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-muted);
    letter-spacing: var(--ls-wide);
}
.wp-card-meta {
    margin-top: 10px;
    padding-top: 10px;
    border-top: 1px solid var(--border-subtle);
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wide);
    color: var(--text-secondary);
    text-transform: uppercase;
}
.wp-card-out {
    margin-top: 8px;
    font-family: var(--f-mono);
    font-size: 10px;
    letter-spacing: var(--ls-wider);
    color: var(--accent);
    text-transform: uppercase;
}

.wp-srv-table {
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    background: var(--glass-bg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    overflow: hidden;
}
.wp-srv-row {
    display: grid;
    grid-template-columns: 1.4fr 1fr 1fr 1fr;
    align-items: center;
    gap: 12px;
    padding: 16px 22px;
    border-bottom: 1px solid var(--border-subtle);
    font-family: var(--f-body);
    font-size: var(--text-sm);
    color: var(--text-secondary);
}
.wp-srv-row:last-child { border-bottom: 0; }
.wp-srv-head-row {
    background: rgba(10, 11, 13, 0.4);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wp-srv-name {
    display: flex;
    align-items: center;
    gap: 10px;
    color: var(--text-primary);
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
}
.wp-srv-dot {
    width: 8px; height: 8px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent-glow);
}
.wp-srv-tag, .wp-srv-sched, .wp-srv-last {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
.wp-srv-sched { color: var(--text-primary); }
@media (max-width: 700px) {
    .wp-srv-row { grid-template-columns: 1fr 1fr; gap: 6px 12px; padding: 14px 16px; }
    .wp-srv-head-row { display: none; }
    .wp-srv-name { grid-column: 1 / -1; }
}

.wp-timeline {
    display: flex;
    flex-direction: column;
    gap: 2px;
    border-left: 1px solid var(--border-subtle);
    padding-left: 24px;
    margin-left: 12px;
}
.wp-tl-row {
    display: grid;
    grid-template-columns: 180px 1fr 100px;
    gap: 16px;
    align-items: center;
    padding: 14px 0;
    border-bottom: 1px solid var(--border-subtle);
    position: relative;
}
.wp-tl-row:last-child { border-bottom: 0; }
.wp-tl-marker {
    position: absolute;
    left: -29px;
    top: 50%;
    transform: translateY(-50%);
    width: 10px; height: 10px;
    border-radius: 50%;
    background: var(--bg-elevated);
    border: 2px solid var(--border-default);
}
.wp-tl-date {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    color: var(--text-primary);
    font-size: var(--text-base);
}
.wp-tl-day {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wide);
    color: var(--text-muted);
    text-transform: uppercase;
}
.wp-tl-ago {
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    color: var(--text-secondary);
    text-align: right;
    letter-spacing: var(--ls-wide);
    text-transform: uppercase;
}
@media (max-width: 600px) {
    .wp-tl-row { grid-template-columns: 1fr auto; }
    .wp-tl-day { grid-column: 1 / -1; }
}

.wp-info {
    display: grid;
    grid-template-columns: 1fr 1fr;
    gap: 16px;
    margin-bottom: 4rem;
}
@media (max-width: 700px) { .wp-info { grid-template-columns: 1fr; } }
.wp-info-card {
    padding: 22px 24px;
    background: var(--glass-bg);
    border: 1px solid var(--glass-border);
    border-radius: var(--radius-lg);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
}
.wp-info-h {
    font-family: var(--f-display);
    font-weight: var(--fw-semibold);
    font-size: var(--text-md);
    color: var(--text-primary);
    margin-bottom: 10px;
}
.wp-info-card p {
    font-family: var(--f-body);
    font-size: var(--text-sm);
    line-height: var(--lh-relaxed);
    color: var(--text-secondary);
    margin: 0;
}
.wp-info-card strong { color: var(--text-primary); font-weight: var(--fw-semibold); }

/* ============================================================
   Wipe countdown — hero bant
   ============================================================ */
.wipe-countdown {
    display: inline-flex;
    align-items: center;
    gap: 14px;
    margin-top: 18px;
    padding: 10px 18px;
    border: 1px solid var(--border-subtle);
    border-radius: var(--radius-full);
    background: rgba(17, 19, 22, 0.55);
    backdrop-filter: blur(6px);
    -webkit-backdrop-filter: blur(6px);
    font-family: var(--f-mono);
    font-size: var(--text-2xs);
    letter-spacing: var(--ls-wider);
    color: var(--text-secondary);
    text-transform: uppercase;
}
.wipe-label {
    color: var(--text-muted);
    display: inline-flex;
    align-items: center;
    gap: 8px;
}
.wipe-label::before {
    content: '';
    width: 6px; height: 6px;
    border-radius: 50%;
    background: var(--accent);
    box-shadow: 0 0 8px var(--accent-glow);
    animation: none;
}
@keyframes wipePulse {
    0%, 100% { opacity: 1; }
    50% { opacity: .35; }
}
.wipe-time {
    color: var(--text-primary);
    font-weight: var(--fw-semibold);
    letter-spacing: 0.08em;
    font-variant-numeric: tabular-nums;
    min-width: 110px;
    text-align: left;
}
.wipe-time .wt-unit { color: var(--text-muted); margin-right: 6px; font-weight: var(--fw-regular); }
.wipe-time .wt-num { color: var(--text-primary); margin-right: 2px; }
@media (max-width: 600px) {
    .wipe-countdown { gap: 10px; padding: 8px 14px; font-size: 10px; }
    .wipe-time { min-width: 90px; }
}

/* ============================================================
   Lunar Loader — eclipse: dark moon, glowing white corona
   ============================================================ */
#page-loader {
    background: #06060A !important;
    overflow: hidden !important;
}
#page-loader .pl-vignette,
#page-loader .pl-orbit,
#page-loader .pl-status,
#page-loader .pl-bar,
#page-loader .pl-coords {
    display: none !important;
}
#page-loader .pl-stars { opacity: .35 !important; filter: grayscale(1) brightness(1.1) !important; }
#page-loader .pl-stars-2 { opacity: .2 !important; filter: grayscale(1) !important; }

#page-loader .pl-inner {
    position: relative !important;
    transform: none !important;
    display: flex !important;
    flex-direction: column !important;
    align-items: center !important;
    justify-content: center !important;
    gap: 2.2rem !important;
}

#page-loader .pl-moon-stage {
    position: relative !important;
    width: 160px !important;
    height: 160px !important;
    margin: 0 !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

#page-loader .pl-moon-wrap {
    position: relative !important;
    width: 140px !important;
    height: 140px !important;
    opacity: 1 !important;
    transform: none !important;
    animation: none !important;
    display: flex !important;
    align-items: center !important;
    justify-content: center !important;
}

/* The moon body becomes a dark silhouette (eclipse disc) */
#page-loader .pl-moon {
    width: 110px !important;
    height: 110px !important;
    border-radius: 50% !important;
    background: #06060A !important;
    box-shadow: inset 0 0 18px rgba(0,0,0,.6) !important;
    filter: none !important;
    animation: none !important;
    position: relative !important;
    z-index: 2 !important;
}
/* Hide all SVG internals — moon is just a dark disc */
#page-loader .pl-moon > * { display: none !important; }

/* The corona: bright ring that hugs the moon edge, slowly pulses */
#page-loader .pl-moon-halo {
    display: block !important;
    position: absolute !important;
    inset: -6px !important;
    border-radius: 50% !important;
    background: transparent !important;
    border: 2px solid rgba(255, 255, 255, .85) !important;
    box-shadow:
        0 0 18px 2px rgba(255, 255, 255, .35),
        0 0 56px 4px rgba(255, 255, 255, .18),
        inset 0 0 14px 2px rgba(255, 255, 255, .3) !important;
    filter: none !important;
    animation: eclipseCorona 3.2s ease-in-out infinite !important;
    z-index: 1 !important;
}
@keyframes eclipseCorona {
    0%, 100% {
        transform: scale(1);
        opacity: .65;
        box-shadow:
            0 0 18px 2px rgba(255, 255, 255, .35),
            0 0 56px 4px rgba(255, 255, 255, .18),
            inset 0 0 14px 2px rgba(255, 255, 255, .3);
    }
    50% {
        transform: scale(1.03);
        opacity: .85;
        box-shadow:
            0 0 28px 4px rgba(255, 255, 255, .5),
            0 0 80px 8px rgba(255, 255, 255, .25),
            inset 0 0 18px 3px rgba(255, 255, 255, .4);
    }
}

/* Spinning bright arc — actual "loading" motion on the eclipse rim */
#page-loader .pl-moon-halo.pl-moon-halo-2 {
    display: block !important;
    position: absolute !important;
    inset: -6px !important;
    border-radius: 50% !important;
    background: conic-gradient(
        from 0deg,
        rgba(255, 255, 255, 1) 0deg,
        rgba(255, 255, 255, .8) 18deg,
        rgba(255, 255, 255, .2) 50deg,
        rgba(255, 255, 255, 0) 90deg,
        rgba(255, 255, 255, 0) 360deg
    ) !important;
    -webkit-mask: radial-gradient(circle, transparent 58%, #000 60%, #000 64%, transparent 66%) !important;
            mask: radial-gradient(circle, transparent 58%, #000 60%, #000 64%, transparent 66%) !important;
    border: 0 !important;
    box-shadow: none !important;
    filter: drop-shadow(0 0 6px rgba(255, 255, 255, .8)) drop-shadow(0 0 14px rgba(255, 255, 255, .4)) !important;
    animation: eclipseSpin 1.4s linear infinite !important;
    z-index: 3 !important;
}
@keyframes eclipseSpin {
    to { transform: rotate(360deg); }
}

/* "LUNAR RUST" — all white, minimal */
#page-loader .pl-mark {
    position: relative !important;
    left: auto !important;
    top: auto !important;
    transform: none !important;
    font-family: 'Rajdhani', sans-serif !important;
    font-weight: 400 !important;
    letter-spacing: 12px !important;
    font-size: 1.4rem !important;
    opacity: 0 !important;
    animation: eclipseMarkIn 1s cubic-bezier(.22,1,.36,1) .25s forwards !important;
}
@keyframes eclipseMarkIn {
    to { opacity: 1; }
}
#page-loader .pl-mark-a,
#page-loader .pl-mark-b {
    opacity: 1 !important;
    transform: none !important;
    filter: none !important;
    animation: none !important;
    color: rgba(232, 237, 245, .85) !important;
    text-shadow: none !important;
    padding-right: 0 !important;
}

@media (max-width: 700px) {
    #page-loader .pl-moon-stage { width: 120px !important; height: 120px !important; }
    #page-loader .pl-moon-wrap { width: 100px !important; height: 100px !important; }
    #page-loader .pl-moon { width: 80px !important; height: 80px !important; }
    #page-loader .pl-mark { font-size: 1.1rem !important; letter-spacing: 9px !important; }
}
