/* ═══════════════════════════════════════════════════════
   fragster.gg — Homepage CSS  (v3.6.5)
   Matches homepage-v2-mockup.html exactly
═══════════════════════════════════════════════════════ */

@keyframes hp-scan  { 0%{transform:translateY(-100%)} 100%{transform:translateY(1200%)} }
@keyframes hp-pulse { 0%,100%{opacity:1} 50%{opacity:.25} }
@keyframes hp-float { 0%,100%{transform:translateY(0)} 50%{transform:translateY(-8px)} }
@keyframes hp-ticker{ 0%{transform:translateX(0)} 100%{transform:translateX(-50%)} }
@keyframes hp-fadein{ from{opacity:0;transform:translateY(18px)} to{opacity:1;transform:none} }

/* ── HERO ─────────────────────────────────────────── */
.hp-hero {
  position:relative; padding:56px 0 48px; overflow:hidden;
  min-height:440px; display:flex; align-items:center;
}
.hp-hero-bg {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background:
    radial-gradient(ellipse 65% 70% at 72% 45%,rgba(170,255,0,.07) 0%,transparent 60%),
    radial-gradient(ellipse 45% 55% at 90% 85%,rgba(25,229,255,.04) 0%,transparent 55%);
}
.hp-hero-grid {
  position:absolute; inset:0; pointer-events:none; z-index:0;
  background-image:
    linear-gradient(rgba(170,255,0,.02) 1px,transparent 1px),
    linear-gradient(90deg,rgba(170,255,0,.02) 1px,transparent 1px);
  background-size:52px 52px;
  mask-image:radial-gradient(ellipse 90% 90% at 70% 50%,black 0%,transparent 70%);
}
.hp-hero-scan {
  position:absolute; left:0; right:0; height:1px; pointer-events:none; z-index:0;
  background:linear-gradient(90deg,transparent,rgba(170,255,0,.15),transparent);
  animation:hp-scan 10s linear infinite;
}
.hp-hero-inner {
  position:relative; z-index:2; width:100%;
  display:grid; grid-template-columns:1fr 360px; gap:52px; align-items:center;
  animation:hp-fadein .6s ease both;
}

/* Copy */
.hp-hero-copy { max-width:500px; }
.hp-eyebrow {
  display:inline-flex; align-items:center; gap:7px; margin-bottom:20px;
  padding:5px 13px; border-radius:20px;
  background:rgba(170,255,0,.08); border:1px solid rgba(170,255,0,.2);
  font-size:10px; font-weight:800; color:var(--lime); letter-spacing:.1em; text-transform:uppercase;
}
.hp-ey-dot { width:5px; height:5px; border-radius:50%; background:var(--lime); animation:hp-pulse 1.5s infinite; }
.hp-h1 {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:68px; font-weight:900; text-transform:uppercase;
  line-height:.88; letter-spacing:-1.2px; color:var(--t1); margin-bottom:16px;
}
.hp-h1 em { color:var(--lime); font-style:normal; display:block; }
.hp-h1-sub { display:block; font-size:40px; color:var(--t2); font-weight:700; margin-top:6px; line-height:1; }
.hp-desc { font-size:15px; color:var(--t2); line-height:1.7; max-width:420px; margin-bottom:28px; }

/* Steam button */
.hp-steam-btn {
  display:inline-flex; align-items:center; gap:12px; padding:15px 26px;
  border-radius:11px; background:#1a2035; border:1px solid rgba(25,229,255,.15);
  color:var(--t1); font-size:15px; font-weight:700; font-family:var(--font,sans-serif);
  letter-spacing:.02em; text-decoration:none; transition:all .2s; margin-bottom:14px;
}
.hp-steam-btn:hover { background:#202840; border-color:rgba(25,229,255,.35); transform:translateY(-2px); box-shadow:0 10px 30px rgba(0,0,0,.4); color:#fff; }

/* Login block */
.hp-login-block { margin-bottom:28px; }
.hp-login-note { font-size:11px; color:var(--t3); margin-bottom:6px; line-height:1.5; max-width:360px; }
.hp-admin-lnk { font-size:11px; color:var(--t3); text-decoration:none; transition:.15s; }
.hp-admin-lnk:hover { color:var(--t2); }

/* Quick actions (logged in) */
.hp-quick-actions { display:flex; gap:8px; flex-wrap:wrap; margin-bottom:28px; }
.hp-qa {
  display:inline-flex; align-items:center; gap:7px; padding:8px 16px; border-radius:8px;
  font-size:12px; font-weight:700; cursor:pointer; border:1px solid var(--border2);
  background:var(--bg3); color:var(--t2); font-family:var(--font,sans-serif);
  text-decoration:none; letter-spacing:.04em; text-transform:uppercase; transition:all .15s;
}
.hp-qa:hover { color:var(--t1); background:var(--bg4); }
.hp-qa-primary { background:var(--lime); color:#050607; border-color:var(--lime); }
.hp-qa-primary:hover { background:var(--lime2,#c8ff30); transform:translateY(-1px); box-shadow:0 6px 20px rgba(170,255,0,.25); }

/* Stats bar */
.hp-stats-bar {
  display:flex; background:var(--bg2); border:1px solid var(--border);
  border-radius:12px; overflow:hidden;
}
.hp-stat { flex:1; padding:11px 16px; border-right:1px solid var(--border); }
.hp-stat:last-child { border-right:none; }
.hp-stat-v { font-family:var(--mono,'JetBrains Mono',monospace); font-size:20px; font-weight:700; color:var(--lime); line-height:1; }
.hp-stat-l { font-size:9px; color:var(--t3); text-transform:uppercase; letter-spacing:.07em; margin-top:3px; }
.hp-live-dot { display:inline-block; width:7px; height:7px; border-radius:50%; background:var(--green); animation:hp-pulse 2s infinite; flex-shrink:0; }

/* Match card */
.hp-hero-visual { animation:hp-fadein .7s ease .15s both; }
.hp-live-card {
  background:var(--bg2); border:1px solid var(--border); border-radius:16px;
  overflow:hidden; box-shadow:0 24px 64px rgba(0,0,0,.55);
  animation:hp-float 5s ease-in-out infinite;
}
.hp-lc-hdr {
  padding:11px 15px; border-bottom:1px solid var(--border);
  background:var(--bg3); display:flex; align-items:center; gap:8px;
}
.hp-dots { display:flex; gap:4px; }
.hp-dot-r,.hp-dot-y,.hp-dot-g { width:8px; height:8px; border-radius:50%; }
.hp-dot-r { background:#ff5f56; } .hp-dot-y { background:#ffbd2e; } .hp-dot-g { background:#27c93f; }
.hp-lc-ttl { flex:1; text-align:center; font-size:10px; font-weight:700; color:var(--t3); text-transform:uppercase; letter-spacing:.08em; }
.hp-live-badge { display:flex; align-items:center; gap:4px; font-size:10px; font-weight:900; color:var(--red); }
.hp-lpulse { width:6px; height:6px; border-radius:50%; background:var(--red); animation:hp-pulse .9s infinite; }
.hp-lc-body { padding:14px; }
.hp-map-prev { height:80px; border-radius:10px; margin-bottom:12px; position:relative; overflow:hidden; background:linear-gradient(135deg,#050F1A 0%,#0A1A2A 65%,#050F1A 100%); }
.hp-map-glow { position:absolute; inset:0; background:radial-gradient(ellipse 80% 60% at 65% 40%,rgba(170,255,0,.08),transparent); }
.hp-map-lbl { position:absolute; bottom:7px; left:11px; font-family:var(--mono,monospace); font-size:9px; font-weight:700; color:rgba(255,255,255,.35); text-transform:uppercase; letter-spacing:.12em; }
.hp-match-row { display:flex; align-items:center; gap:10px; margin-bottom:9px; }
.hp-mt { flex:1; }
.hp-mt-n { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:14px; font-weight:800; color:var(--t1); }
.hp-mt-n.win { color:var(--lime); }
.hp-mt-e { font-size:10px; margin-top:2px; }
.hp-score { font-family:var(--mono,monospace); font-size:26px; font-weight:700; color:var(--lime); text-align:center; min-width:60px; line-height:1; }
.hp-score-sep { font-size:13px; color:var(--t3); }
.hp-prog { height:2px; background:var(--bg4); border-radius:1px; margin-bottom:10px; overflow:hidden; }
.hp-prog-f { height:100%; width:60%; background:linear-gradient(90deg,var(--lime),var(--cyan)); border-radius:1px; }
.hp-prow { display:flex; align-items:center; gap:7px; padding:6px 9px; background:var(--bg3); border-radius:7px; border:1px solid var(--border); margin-bottom:4px; }
.hp-prow:last-child { margin-bottom:0; }
.hp-pav { width:20px; height:20px; border-radius:50%; background:var(--bg5); display:flex; align-items:center; justify-content:center; font-size:7px; font-weight:700; color:var(--lime); flex-shrink:0; }
.hp-pname { flex:1; font-size:11px; font-weight:600; color:var(--t1); }
.hp-pkda { font-family:var(--mono,monospace); font-size:10px; color:var(--t3); }
.hp-pkda b { color:var(--lime); }

/* ── TICKER ───────────────────────────────────────── */
.hp-ticker {
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  background:var(--bg2); padding:10px 0; overflow:hidden; display:flex;
}
.hp-ticker-lbl {
  flex-shrink:0; padding:0 20px; font-size:10px; font-weight:800;
  color:var(--lime); letter-spacing:.1em; text-transform:uppercase;
  border-right:1px solid var(--border); display:flex; align-items:center; gap:7px; white-space:nowrap;
}
.hp-ticker-pulse { width:6px; height:6px; border-radius:50%; background:var(--red); animation:hp-pulse .9s infinite; }
.hp-ticker-wrap { overflow:hidden; flex:1; display:flex; align-items:center; padding-left:20px; }
.hp-ticker-track { display:flex; animation:hp-ticker 26s linear infinite; white-space:nowrap; }
.hp-ti { display:inline-flex; align-items:center; gap:6px; padding:0 22px; font-size:12px; color:var(--t2); border-right:1px solid var(--border2); }
.hp-ti b { color:var(--t1); }
.hp-ti-w { color:var(--lime); }

/* ── SECTIONS ─────────────────────────────────────── */
.hp-sec { padding:64px 0; }
.hp-sec-hd {
  display:flex; align-items:flex-end; justify-content:space-between;
  margin-bottom:36px; flex-wrap:wrap; gap:16px;
}
.hp-sec-ey {
  font-size:10px; font-weight:800; color:var(--lime); letter-spacing:.14em;
  text-transform:uppercase; margin-bottom:6px; display:flex; align-items:center; gap:8px;
}
.hp-sec-ey::after { content:''; width:28px; height:1px; background:rgba(170,255,0,.35); }
.hp-sec-h {
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:46px; font-weight:900; text-transform:uppercase; line-height:.9; color:var(--t1);
}
.hp-sec-h em { color:var(--lime); font-style:normal; }
.hp-sec-p { font-size:13px; color:var(--t2); max-width:400px; line-height:1.65; }

/* ── FEATURES GRID ────────────────────────────────── */
.hp-feat-grid { display:grid; grid-template-columns:repeat(3,1fr); gap:12px; }
.hp-fc {
  background:var(--bg2); border:1px solid var(--border); border-radius:14px;
  padding:22px; position:relative; overflow:hidden; transition:all .22s;
}
.hp-fc::before {
  content:''; position:absolute; top:0; left:0; right:0; height:2px;
  background:linear-gradient(90deg,transparent,var(--lime),transparent);
  transform:scaleX(0); transition:.3s; transform-origin:left;
}
.hp-fc:hover { border-color:rgba(170,255,0,.18); transform:translateY(-3px); box-shadow:0 14px 40px rgba(0,0,0,.35); }
.hp-fc:hover::before { transform:scaleX(1); }
.hp-fc-wide { grid-column:span 2; }
.hp-fc-dark { background:linear-gradient(135deg,#060A1E,#0A0E28); }
.hp-feat-inner { display:grid; grid-template-columns:1fr 1fr; gap:22px; align-items:start; }
.hp-fbadge {
  display:inline-flex; padding:3px 10px; border-radius:20px; font-size:9px; font-weight:800;
  letter-spacing:.06em; text-transform:uppercase; margin-bottom:14px;
}
.hp-badge-lime   { background:rgba(170,255,0,.1); border:1px solid rgba(170,255,0,.25); color:var(--lime); }
.hp-badge-orange { background:rgba(255,140,26,.1); border:1px solid rgba(255,140,26,.25); color:var(--orange); }
.hp-fi {
  width:44px; height:44px; border-radius:10px; margin-bottom:14px;
  display:flex; align-items:center; justify-content:center; font-size:18px;
  background:rgba(170,255,0,.08); border:1px solid rgba(170,255,0,.12);
}
.hp-fi-c { background:rgba(25,229,255,.08); border-color:rgba(25,229,255,.12); }
.hp-fi-g { background:rgba(245,166,35,.08); border-color:rgba(245,166,35,.12); }
.hp-fi-r { background:rgba(255,60,90,.08); border-color:rgba(255,60,90,.12); }
.hp-fi-p { background:rgba(139,92,246,.08); border-color:rgba(139,92,246,.12); }
.hp-fi-o { background:rgba(255,140,26,.08); border-color:rgba(255,140,26,.12); }
.hp-ft { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:17px; font-weight:800; color:var(--t1); text-transform:uppercase; margin-bottom:7px; }
.hp-fd { font-size:12px; color:var(--t2); line-height:1.6; }
.hp-fl {
  display:inline-flex; align-items:center; gap:5px; margin-top:12px;
  font-size:11px; font-weight:700; color:var(--lime); text-decoration:none;
  letter-spacing:.04em; text-transform:uppercase; transition:gap .18s;
}
.hp-fl:hover { gap:9px; }
.hp-q-grid { display:flex; flex-direction:column; gap:7px; }
.hp-qc { padding:10px 13px; border-radius:8px; border:1px solid; }
.hp-qc-l { background:rgba(170,255,0,.04); border-color:rgba(170,255,0,.1); }
.hp-qc-c { background:rgba(25,229,255,.04); border-color:rgba(25,229,255,.1); }
.hp-qc-o { background:rgba(255,140,26,.04); border-color:rgba(255,140,26,.1); }
.hp-qc-lbl { font-size:9px; color:var(--t3); text-transform:uppercase; letter-spacing:.07em; margin-bottom:3px; }
.hp-qc-val { font-family:var(--mono,monospace); font-size:16px; font-weight:700; line-height:1; }
.hp-qc-sub { font-size:10px; color:var(--t3); margin-top:2px; }

/* ── TWO COL: Matches + Leaderboard ──────────────── */
.hp-two-col { display:grid; grid-template-columns:1fr 300px; gap:18px; align-items:start; }
.hp-subsec-hd { display:flex; align-items:center; justify-content:space-between; margin-bottom:13px; }
.hp-subsec-ey { font-size:9px; font-weight:800; color:var(--lime); letter-spacing:.1em; text-transform:uppercase; margin-bottom:3px; }
.hp-subsec-h { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:22px; font-weight:900; text-transform:uppercase; color:var(--t1); }
.hp-more-lnk { font-size:11px; font-weight:700; color:var(--lime); text-decoration:none; }

/* Match cards */
.hp-mc-grid { display:grid; grid-template-columns:1fr 1fr; gap:9px; }
.hp-mc {
  display:block; text-decoration:none; background:var(--bg2); border:1px solid var(--border);
  border-radius:11px; padding:13px; transition:all .18s;
}
.hp-mc:hover { border-color:rgba(170,255,0,.15); transform:translateY(-2px); box-shadow:0 8px 24px rgba(0,0,0,.3); }
.hp-mc-hd { display:flex; justify-content:space-between; margin-bottom:9px; }
.hp-mc-mode { font-size:9px; font-weight:800; color:var(--t3); text-transform:uppercase; letter-spacing:.07em; }
.hp-mc-ts   { font-size:10px; color:var(--t3); font-family:var(--mono,monospace); }
.hp-mc-teams { display:flex; align-items:center; gap:9px; margin-bottom:7px; }
.hp-mct { flex:1; }
.hp-mct-r { text-align:right; }
.hp-mct-n { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:13px; font-weight:800; color:var(--t1); }
.hp-mct-w .hp-mct-n { color:var(--lime); }
.hp-mct-e { font-size:10px; margin-top:2px; font-family:var(--mono,monospace); }
.hp-mcs { font-family:var(--mono,monospace); font-size:20px; font-weight:700; color:var(--lime); text-align:center; min-width:48px; line-height:1.1; }
.hp-mcs-s { font-size:11px; color:var(--t3); }
.hp-mc-map { font-size:10px; color:var(--t3); }
.hp-empty-matches {
  grid-column:1/-1; padding:24px; text-align:center; color:var(--t3);
  font-size:13px; background:var(--bg3); border:1px solid var(--border); border-radius:11px;
}

/* Leaderboard */
.hp-lb { background:var(--bg2); border:1px solid var(--border); border-radius:12px; overflow:hidden; }
.hp-lb-hd {
  padding:11px 15px; border-bottom:1px solid var(--border); background:var(--bg3);
  display:flex; align-items:center; justify-content:space-between;
}
.hp-lb-ttl { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:12px; font-weight:800; text-transform:uppercase; letter-spacing:.06em; color:var(--t1); }
.hp-lb-live { font-size:10px; color:var(--lime); display:flex; align-items:center; gap:5px; }
.hp-lb-row {
  display:grid; grid-template-columns:30px 1fr 60px 50px; align-items:center;
  padding:9px 15px; border-bottom:1px solid var(--border); transition:.1s;
}
.hp-lb-row:last-child { border-bottom:none; }
.hp-lb-row:hover { background:rgba(255,255,255,.02); }
.hp-lb-me { background:rgba(170,255,0,.03); }
.hp-lb-rn { font-family:var(--mono,monospace); font-size:11px; font-weight:700; color:var(--t3); }
.hp-lb-pl { display:flex; align-items:center; gap:7px; }
.hp-lb-av { width:24px; height:24px; border-radius:50%; background:var(--bg5); display:flex; align-items:center; justify-content:center; font-size:8px; font-weight:700; color:var(--lime); }
.hp-lb-n  { font-size:12px; font-weight:600; color:var(--t1); }
.hp-lb-you { font-size:8px; background:rgba(170,255,0,.08); border:1px solid rgba(170,255,0,.2); color:var(--lime); padding:1px 5px; border-radius:10px; margin-top:2px; display:inline-block; font-weight:800; letter-spacing:.04em; text-transform:uppercase; }
.hp-lb-tier { display:inline-flex; padding:2px 6px; border-radius:20px; font-size:9px; font-weight:800; text-align:center; justify-content:center; }
.hp-lb-elo { font-family:var(--mono,monospace); font-size:12px; font-weight:700; color:var(--gold,#F5A623); text-align:right; }

/* ── SERVER STRIP ─────────────────────────────────── */
.hp-server-strip {
  border-top:1px solid var(--border); border-bottom:1px solid var(--border);
  background:var(--bg2); padding:16px 0;
}
.hp-server-inner { display:flex; align-items:center; gap:12px; flex-wrap:wrap; }
.hp-server-lbl { font-size:11px; font-weight:800; color:var(--t2); text-transform:uppercase; letter-spacing:.08em; padding-right:12px; border-right:1px solid var(--border); white-space:nowrap; }
.hp-svc { display:flex; align-items:center; gap:9px; padding:9px 14px; background:var(--bg3); border:1px solid var(--border); border-radius:10px; flex:1; min-width:200px; max-width:260px; }
.hp-svc-dot { width:7px; height:7px; border-radius:50%; flex-shrink:0; }
.hp-svc-nm   { font-family:var(--font-cond,'Barlow Condensed',sans-serif); font-size:13px; font-weight:800; color:var(--t1); }
.hp-svc-addr { font-family:var(--mono,monospace); font-size:10px; color:var(--t3); }
.hp-svc-badge { margin-left:auto; font-size:9px; font-weight:800; padding:3px 9px; border-radius:20px; text-transform:uppercase; letter-spacing:.05em; white-space:nowrap; }
.hp-svc-ok   { background:rgba(34,197,94,.1); border:1px solid rgba(34,197,94,.2); color:var(--green); }
.hp-svc-busy { background:rgba(255,140,26,.1); border:1px solid rgba(255,140,26,.2); color:var(--orange); }

/* ── CTA ──────────────────────────────────────────── */
.hp-cta { padding:80px 0; text-align:center; position:relative; overflow:hidden; }
.hp-cta-glow { position:absolute; inset:0; pointer-events:none; background:radial-gradient(ellipse 55% 55% at 50% 50%,rgba(170,255,0,.05) 0%,transparent 70%); }
.hp-cta-h {
  position:relative; z-index:1;
  font-family:var(--font-cond,'Barlow Condensed',sans-serif);
  font-size:58px; font-weight:900; text-transform:uppercase; line-height:.9; color:var(--t1); margin-bottom:12px;
}
.hp-cta-h em { color:var(--lime); font-style:normal; }
.hp-cta-p { position:relative; z-index:1; font-size:15px; color:var(--t2); max-width:400px; margin:0 auto 28px; line-height:1.65; }
.hp-cta .hp-steam-btn { margin:0 auto; position:relative; z-index:1; }

/* ── RESPONSIVE ───────────────────────────────────── */
@media(max-width:1100px) {
  .hp-hero-inner { grid-template-columns:1fr; }
  .hp-hero-visual { display:none; }
  .hp-h1 { font-size:52px; }
  .hp-h1-sub { font-size:34px; }
  .hp-feat-grid { grid-template-columns:1fr 1fr; }
  .hp-fc-wide { grid-column:span 2; }
  .hp-two-col { grid-template-columns:1fr; }
  .hp-server-inner { flex-direction:column; align-items:stretch; }
  .hp-svc { max-width:100%; }
}
@media(max-width:768px) {
  .hp-hero { padding:40px 0 36px; }
  .hp-h1 { font-size:42px; }
  .hp-h1-sub { font-size:28px; }
  .hp-feat-grid { grid-template-columns:1fr; }
  .hp-fc-wide { grid-column:span 1; }
  .hp-feat-inner { grid-template-columns:1fr; }
  .hp-mc-grid { grid-template-columns:1fr; }
  .hp-cta-h { font-size:42px; }
  .hp-sec { padding:48px 0; }
}
