:root{
  --realblue: #4270FC;
  --realblue-secondary: #7698FE;
  --realblue-dim: #2C4FC4;
  --bg-base: #0A0D12;
  --bg-raised: #11151D;
  --bg-card: #151A24;
  --bg-card-2: #1A2030;
  --border-soft: rgba(255,255,255,0.07);
  --border-soft-2: rgba(255,255,255,0.12);
  --text-primary: #ECEEF2;
  --text-secondary: #8C94A6;
  --text-tertiary: #5C6377;
  --ok-green: #4ADE80;
  --font-display: 'Space Grotesk', system-ui, sans-serif;
  --font-body: 'Inter', system-ui, sans-serif;
  --font-mono: 'JetBrains Mono', monospace;
  --font-montserrat: 'Montserrat';
  --container-w: 1180px;
  --radius-lg: 20px;
  --radius-md: 14px;
  --radius-sm: 8px;
}

*{box-sizing:border-box;}
html{scroll-behavior:smooth;}
body{
  margin:0;
  background:var(--bg-base);
  color:var(--text-primary);
  font-family:var(--font-body);
  -webkit-font-smoothing:antialiased;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none;}
ul,ol{margin:0;padding:0;}
button{font-family:inherit;cursor:pointer;}
img{max-width:100%;display:block;}

.container{
  max-width:var(--container-w);
  margin:0 auto;
  padding:0 28px;
}

@media (prefers-reduced-motion: reduce){
  *{animation-duration:0.01ms !important; transition-duration:0.01ms !important;}
}

.bg-grid{
  position:fixed;
  inset:0;
  z-index:0;
  background-image:
    linear-gradient(rgba(255,255,255,0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255,255,255,0.035) 1px, transparent 1px);
  background-size:64px 64px;
  mask-image:linear-gradient(to bottom, rgba(0,0,0,0.9) 0%, transparent 55%);
  pointer-events:none;
}
.bg-glow{
  position:fixed;
  top:-220px;
  left:50%;
  transform:translateX(-50%);
  width:1100px;
  height:700px;
  background:radial-gradient(ellipse at center, rgba(66,112,252,0.22) 0%, rgba(66,112,252,0.06) 45%, transparent 75%);
  z-index:0;
  pointer-events:none;
  filter:blur(10px);
}

main, header, footer{position:relative; z-index:1;}

.topbar{
  position:sticky;
  top:0;
  z-index:50;
  background:rgba(10,13,18,0.72);
  backdrop-filter:blur(14px);
  border-bottom:1px solid var(--border-soft);
}
.topbar-inner{
  max-width:var(--container-w);
  margin:0 auto;
  padding:16px 28px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:24px;
}
.brand{
  display:flex;
  align-items:center;
  gap:10px;
  font-family:var(--font-display);
  font-weight:600;
  font-size:1.05rem;
  letter-spacing:0.01em;
  color:var(--text-primary);
}
.brand-logo-slot{
  display:flex;
  align-items:center;
  justify-content:center;
  width:32px;
  height:32px;
  color:var(--realblue-secondary);
  flex-shrink:0;
}
.brand-dot{color:var(--realblue); font-weight:bold; font-family: var(--font-montserrat);}

.nav-desktop{
  display:flex;
  align-items:center;
  gap:6px;
}
.nav-link{
  padding:9px 16px;
  border-radius:999px;
  font-size:0.92rem;
  font-weight:500;
  color:var(--text-secondary);
  transition:color 0.18s ease, background 0.18s ease;
  white-space:nowrap;
}
.nav-link:hover{color:var(--text-primary); background:rgba(255,255,255,0.05);}
.nav-accent{color:var(--realblue-secondary);}
.nav-accent:hover{color:var(--realblue-secondary); background:rgba(118,152,254,0.1);}
.nav-cta{
  display:flex;
  align-items:center;
  gap:7px;
  color: var(--realblue);
  margin-left:6px;
}
.nav-cta:hover{color:var(--realblue-secondary);}

.nav-burger{
  display:none;
  flex-direction:column;
  justify-content:center;
  gap:5px;
  width:36px;
  height:36px;
  background:none;
  border:none;
  padding:0;
}
.nav-burger span{
  display:block;
  height:2px;
  width:100%;
  background:var(--text-primary);
  border-radius:2px;
  transition:transform 0.2s ease, opacity 0.2s ease;
}
.nav-burger[aria-expanded="true"] span:nth-child(1){transform:translateY(7px) rotate(45deg);}
.nav-burger[aria-expanded="true"] span:nth-child(2){opacity:0;}
.nav-burger[aria-expanded="true"] span:nth-child(3){transform:translateY(-7px) rotate(-45deg);}

.nav-mobile{
  display:none;
  flex-direction:column;
  padding:8px 20px 18px;
  gap:2px;
  border-top:1px solid var(--border-soft);
}
.nav-mobile.open{display:flex;}
.nav-mobile .nav-link{padding:12px 14px;}
.nav-mobile .nav-cta{justify-content:center; margin-top:8px;}

@media (max-width:860px){
  .nav-desktop{display:none;}
  .nav-burger{display:flex;}
}

.hero{
  min-height:78vh;
  display:flex;
  align-items:center;
  justify-content:center;
  text-align:center;
  padding:80px 24px 60px;
  position:relative;
}
.hero-inner{
  max-width:680px;
  display:flex;
  flex-direction:column;
  align-items:center;
  animation:heroIn 0.8s cubic-bezier(0.16,1,0.3,1) both;
}
@keyframes heroIn{
  from{opacity:0; transform:translateY(18px);}
  to{opacity:1; transform:translateY(0);}
}
.hero-mark{
  width:128; height:128;
  margin-bottom:24px;
  color:var(--realblue-secondary);
  opacity:0.9;
}
.hero-eyebrow{
  font-family:var(--font-mono);
  font-size:0.78rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--realblue-secondary);
  margin-bottom:18px;
}
.hero-title{
  font-family:var(--font-display);
  font-size:clamp(2.4rem, 5.6vw, 4rem);
  font-weight:600;
  line-height:1.08;
  letter-spacing:-0.01em;
  margin:0 0 20px;
  color:var(--text-primary);
}
.hero-title-accent{
  background:linear-gradient(100deg, var(--realblue-secondary), var(--realblue));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.hero-sub{
  font-size:1.08rem;
  line-height:1.6;
  color:var(--text-secondary);
  max-width:520px;
  margin:0 0 36px;
}
.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  justify-content:center;
}
.hero-scroll-cue{
  position:absolute;
  bottom:32px;
  left:50%;
  transform:translateX(-50%);
  width:22px;
  height:36px;
  border:1.5px solid var(--border-soft-2);
  border-radius:14px;
  display:flex;
  justify-content:center;
  padding-top:7px;
}
.hero-scroll-cue span{
  width:3px; height:7px;
  border-radius:2px;
  background:var(--realblue-secondary);
  animation:scrollCue 1.8s ease-in-out infinite;
}
@keyframes scrollCue{
  0%{opacity:1; transform:translateY(0);}
  60%{opacity:0; transform:translateY(10px);}
  61%{opacity:0; transform:translateY(0);}
  100%{opacity:1;}
}

.btn{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:13px 24px;
  border-radius:11px;
  font-weight:600;
  font-size:0.95rem;
  border:1px solid transparent;
  transition:transform 0.15s ease, background 0.18s ease, border-color 0.18s ease;
}
.btn:active{transform:scale(0.97);}
.btn-primary{
  background:var(--realblue);
  color:#fff;
  box-shadow:0 8px 24px -8px rgba(66,112,252,0.55);
}
.btn-primary:hover{background:#3360ec;}
.btn-ghost{
  background:transparent;
  color:var(--text-primary);
  border-color:var(--border-soft-2);
}
.btn-ghost:hover{border-color:var(--realblue-secondary); color:var(--realblue-secondary);}
.btn-outline{
  background:transparent;
  border-color:var(--realblue);
  color:var(--realblue-secondary);
}
.btn-outline:hover{background:rgba(66,112,252,0.1);}
.btn-lg{padding:15px 28px; font-size:1rem;}

section{padding:88px 0;}
.section-head{margin-bottom:36px;}
.section-eyebrow{
  display:block;
  font-family:var(--font-mono);
  font-size:0.76rem;
  letter-spacing:0.08em;
  text-transform:uppercase;
  color:var(--realblue-secondary);
  margin-bottom:10px;
}
.section-title{
  font-family:var(--font-display);
  font-size:clamp(1.7rem, 3vw, 2.3rem);
  font-weight:600;
  letter-spacing:-0.01em;
  margin:0 0 14px;
}
.section-sub{
  color:var(--text-secondary);
  font-size:1.02rem;
  line-height:1.65;
  max-width:560px;
}

.server-section{padding-top:8px;}
.server-card{
  background:linear-gradient(165deg, var(--bg-card-2), var(--bg-card) 20%);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:36px 36px 28px;
  position:relative;
  overflow:hidden;
}
.server-card::before{
  content:"";
  position:absolute;
  top:-40%;
  right:-15%;
  width:480px;
  height:480px;
  pointer-events:none;
}
.server-card-top{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:20px;
  margin-bottom:28px;
  position:relative;
  z-index:1;
}
.server-card-id{
  display:flex;
  align-items:center;
  gap:14px;
}
.server-name{
  font-family:var(--font-montserrat);
  font-size:2rem;
  font-weight:100;
  margin:0;
}
.server-tag{
  font-size:0.86rem;
  color:var(--text-tertiary);
}

.server-stats {
    display: flex;
    gap: 2rem;
    align-items: flex-start;
}

.server-count {
    text-align: center;
    display: flex;
    flex-direction: column;
    align-items: center;
}

.server-count-number {
    font-family: var(--font-montserrat);
    font-size: 2.6rem;
    font-weight: 600;
    line-height: 1;
    letter-spacing: -0.01em;
}

#playerCount {
    color: var(--realblue-secondary);
}

.count-separator {
    color: rgba(255,255,255,0.2);
    margin: 0 2px;
    font-weight: 300;
}

#maxCount {
    color: rgba(255,255,255,0.25);
    font-size: 1.8rem;
}

.server-count-label {
    font-size: 0.84rem;
    color: var(--text-tertiary);
    margin-top: 4px;
}

.chart-wrap{
  position:relative;
  z-index:1;
  margin-bottom:24px;
}

.chart-tooltip {
    display: none;
    position: absolute;
    background: var(--bg-card-2, #1a1d2e);
    border: 1px solid var(--border-soft, rgba(255,255,255,0.08));
    border-radius: 10px;
    padding: 10px 14px;
    pointer-events: none;
    z-index: 10;
    min-width: 140px;
    box-shadow: 0 4px 24px rgba(0,0,0,0.4);
}

.chart-tooltip.visible {
    display: block;
}

.chart-tooltip-time {
    font-size: 0.75rem;
    color: rgba(255,255,255,0.4);
    display: block;
    margin-bottom: 8px;
}

.chart-tooltip-row {
    display: flex;
    align-items: center;
    gap: 8px;
    margin-bottom: 4px;
}

.chart-tooltip-dot {
    width: 7px;
    height: 7px;
    border-radius: 50%;
    flex-shrink: 0;
}

.chart-tooltip-dot.players { background: #4270FC; }
.chart-tooltip-dot.admins  { background: rgba(255,255,255,0.4); }

.chart-tooltip-label {
    font-size: 0.78rem;
    color: rgba(255,255,255,0.4);
    flex: 1;
}

.chart-tooltip-value {
    font-size: 0.85rem;
    font-weight: 600;
    color: #fff;
}

.chart-svg{
  width:100%;
  height:180px;
  display:block;
  overflow:visible;
}
#chartLinePath{
  filter:drop-shadow(0 0 8px rgba(66,112,252,0.5));
}
.chart-meta{
  display:flex;
  justify-content:space-between;
  font-family:var(--font-montserrat);
  font-size:0.76rem;
  color:var(--text-tertiary);
  margin-top:6px;
}
.chart-meta-now{display:flex; align-items:center; gap:6px; color:var(--text-secondary);}
.live-pulse{
  width:6px; height:6px;
  border-radius:50%;
  background:var(--realblue-secondary);
  /*animation:pulseDot 1.6s ease-out infinite; */
}

.server-links{
  display:flex;
  gap:10px;
  position:relative;
  z-index:1;
}
.server-link{
  display:flex;
  align-items:center;
  gap:8px;
  padding:10px 18px;
  border-radius:10px;
  background:rgba(255,255,255,0.04);
  border:1px solid var(--border-soft);
  font-size:0.88rem;
  font-weight:500;
  color:var(--text-secondary);
  transition:border-color 0.18s ease, color 0.18s ease;
}
.server-link:hover{border-color:var(--realblue); color:var(--text-primary);}

.client-grid{
  display:grid;
  grid-template-columns:0.85fr 1.15fr;
  gap:64px;
  align-items:center;
}
.launcher-mock{
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  overflow:hidden;
  box-shadow:0 30px 60px -30px rgba(0,0,0,0.6);
}
.launcher-mock-bar{
  display:flex;
  gap:6px;
  padding:12px 14px;
  background:var(--bg-card-2);
  border-bottom:1px solid var(--border-soft);
}
.launcher-mock-bar span{
  width:9px; height:9px;
  border-radius:50%;
  background:var(--border-soft-2);
}
.launcher-mock-body{
  display:flex;
  flex-direction:column;
  align-items:center;
  justify-content:center;
  gap:18px;
  padding:56px 20px;
  background:radial-gradient(circle at 50% 30%, rgba(66,112,252,0.18), transparent 65%);
}
.launcher-mock-mark{color:var(--realblue-secondary); opacity:0.85;}
.launcher-mock-title{
  font-family:var(--font-display);
  font-weight:600;
  font-size:1.1rem;
}
.launcher-mock-btn{
  background:var(--realblue);
  color:#fff;
  font-size:0.85rem;
  font-weight:600;
  padding:9px 22px;
  border-radius:9px;
}

.steps{
  list-style:none;
  margin:28px 0 32px;
  display:flex;
  flex-direction:column;
  gap:14px;
}
.steps li{
  display:flex;
  align-items:center;
  gap:14px;
  font-size:0.98rem;
  color:var(--text-secondary);
}
.steps-num{
  display:flex;
  align-items:center;
  justify-content:center;
  width:26px; height:26px;
  border-radius:50%;
  background:rgba(66,112,252,0.14);
  color:var(--realblue-secondary);
  font-family:var(--font-mono);
  font-size:0.78rem;
  font-weight:600;
  flex-shrink:0;
}

@media (max-width:840px){
  .client-grid{grid-template-columns:1fr; gap:40px;}
  .client-visual{order:2;}
}

.reqs-grid{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:24px;
}
.reqs-card{
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  padding:30px 30px 26px;
}
.reqs-card-accent{
  border-color:rgba(66,112,252,0.3);
  background:linear-gradient(165deg, rgba(66,112,252,0.07), var(--bg-card) 65%);
}
.reqs-title{
  font-family:var(--font-display);
  font-size:1.12rem;
  font-weight:600;
  margin:0 0 20px;
}
.reqs-list{list-style:none; display:flex; flex-direction:column; gap:13px;}
.reqs-list li{
  display:flex;
  justify-content:space-between;
  gap:20px;
  font-size:0.88rem;
  padding-bottom:13px;
  border-bottom:1px solid var(--border-soft);
}
.reqs-list li:last-child{border-bottom:none; padding-bottom:0;}
.reqs-list li span{color:var(--text-tertiary); flex-shrink:0;}
.reqs-list li strong{color:var(--text-primary); font-weight:500; text-align:right;}

@media (max-width:720px){
  .reqs-grid{grid-template-columns:1fr;}
  .reqs-list li{flex-direction:column; gap:4px;}
  .reqs-list li strong{text-align:left;}
}

.news-list{
  display:flex;
  flex-direction:column;
  gap:16px;
}
.news-placeholder{
  padding:40px;
  text-align:center;
  color:var(--text-tertiary);
  border:1px dashed var(--border-soft-2);
  border-radius:var(--radius-md);
  font-size:0.92rem;
}
.news-item{
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-md);
  padding:24px 26px;
}
.news-item-date{
  font-family:var(--font-mono);
  font-size:0.78rem;
  color:var(--text-tertiary);
}
.news-item-title{
  font-family:var(--font-display);
  font-size:1.2rem;
  font-weight:600;
  margin:6px 0 0;
}
.news-more{text-align:center; margin-top:28px;}
.link-btn{
  background:none;
  border:none;
  color:var(--realblue-secondary);
  font-weight:600;
  font-size:0.92rem;
  padding:8px 16px;
}
.link-btn:hover{text-decoration:underline;}

.community-card{
  background:var(--bg-card);
  border:1px solid var(--border-soft);
  border-radius:var(--radius-lg);
  padding:48px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:40px;
  flex-wrap:wrap;
}
.community-text .section-sub{margin-bottom:0;}
.community-links{
  display:flex;
  gap:14px;
}
.community-link{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:8px;
  width:78px;
  padding:14px 0;
  border-radius:12px;
  color:var(--text-secondary);
  font-size:0.76rem;
  font-weight:500;
  transition:background 0.18s ease, color 0.18s ease, transform 0.18s ease;
}
.community-link:hover{
  background:rgba(66,112,252,0.1);
  color:var(--text-primary);
  transform:translateY(-3px);
}

@media (max-width:600px){
  .community-card{padding:32px 24px;}
  .community-links{width:100%; justify-content:space-between;}
  .community-link{width:auto;}
}

.shop-card{
  text-align:center;
  max-width:560px;
  margin:0 auto;
  display:flex;
  flex-direction:column;
  align-items:center;
}
.shop-card .section-sub{margin:0 0 28px;}

.site-footer{
  border-top:1px solid var(--border-soft);
  padding:40px 0;
}
.footer-inner{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap:20px;
  text-align:center;
}
.footer-brand{
  display:flex;
  align-items:center;
  gap:8px;
  font-family:var(--font-display);
  font-weight:600;
  color:var(--text-secondary);
}
.footer-links{
  display:flex;
  gap:24px;
  flex-wrap:wrap;
  justify-content:center;
  font-size:0.86rem;
  color:var(--text-tertiary);
}
.footer-links a:hover{color:var(--text-secondary);}
.footer-bottom{
  display:flex;
  gap:20px;
  flex-wrap:wrap;
  justify-content:center;
  font-size:0.8rem;
  color:var(--text-tertiary);
}
.footer-bottom a:hover{color:var(--realblue-secondary);}

/* ============================================
   Focus visibility
   ============================================ */
a:focus-visible, button:focus-visible{
  outline:2px solid var(--realblue-secondary);
  outline-offset:3px;
  border-radius:6px;
}