/* Soul Fighter site. Bundled OFL display fonts shared with the game. */
@font-face { font-family:'Anton'; font-weight:400; font-display:swap; src:url('assets/fonts/anton.woff2') format('woff2'); }
@font-face { font-family:'Oswald'; font-weight:600; font-display:swap; src:url('assets/fonts/oswald-600.woff2') format('woff2'); }
@font-face { font-family:'Oswald'; font-weight:700; font-display:swap; src:url('assets/fonts/oswald-700.woff2') format('woff2'); }

:root{
  --bg:#07051a;
  --bg2:#0d0a26;
  --panel:#140f30;
  --line:rgba(180,160,255,0.16);
  --gold:#ffc73a;
  --violet:#8f7bff;
  --violet2:#b9a8ff;
  --ink:#eae6ff;
  --mute:#9c93c4;
}

*{margin:0;padding:0;box-sizing:border-box}
html{scroll-behavior:smooth;overflow-x:hidden}
body{
  background:radial-gradient(1200px 700px at 50% -180px,#241a52 0%,var(--bg) 60%),var(--bg);
  color:var(--ink);
  font-family:'Oswald',Arial,sans-serif;
  font-weight:600;
  line-height:1.5;
  overflow-x:hidden;
}
a{color:inherit;text-decoration:none}
img{display:block;max-width:100%}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;
  font-family:'Anton',sans-serif;letter-spacing:1.5px;
  background:linear-gradient(180deg,var(--gold),#e9a915);
  color:#241000;border:none;border-radius:8px;cursor:pointer;
  padding:12px 22px;font-size:16px;
  box-shadow:0 8px 26px rgba(255,183,40,0.28);
  transition:transform .08s ease,box-shadow .12s ease,filter .12s ease;
}
.btn:hover{transform:translateY(-2px);filter:brightness(1.06);box-shadow:0 12px 34px rgba(255,183,40,0.4)}
.btn:active{transform:translateY(0)}
.btn.big{padding:16px 34px;font-size:22px}
.btn.small{padding:9px 16px;font-size:13px}
.btn.ghost{
  background:transparent;color:var(--violet2);
  border:2px solid var(--line);box-shadow:none;
}
.btn.ghost:hover{border-color:var(--violet);color:#fff}

/* top bar */
.topbar{
  position:sticky;top:0;z-index:30;
  display:flex;align-items:center;justify-content:space-between;
  padding:14px 30px;
  background:rgba(7,5,26,0.72);backdrop-filter:blur(10px);
  border-bottom:1px solid var(--line);
}
.brand{font-family:'Anton',sans-serif;font-size:24px;letter-spacing:2px;color:#fff}
.brand span{color:var(--gold)}
.nav{display:flex;align-items:center;gap:22px;font-size:15px;letter-spacing:.5px;color:var(--mute)}
.nav a:hover{color:#fff}
.nav a.btn{color:#241000}

/* hero */
.hero{position:relative;padding:130px 24px 96px;min-height:640px;display:flex;align-items:center;justify-content:center;text-align:center;overflow:hidden}
/* the game's own key art (Kael vs Grit under the moon) sits behind the wordmark */
.hero-art{
  position:absolute;inset:0;
  background:url('assets/title art.webp') center 22% / cover no-repeat;
  transform:scale(1.04);
}
.hero-scrim{
  position:absolute;inset:0;pointer-events:none;
  background:
    radial-gradient(115% 85% at 50% 28%, transparent 34%, rgba(7,5,26,0.72) 100%),
    linear-gradient(180deg, rgba(7,5,26,0.6) 0%, rgba(7,5,26,0.18) 38%, rgba(7,5,26,0.4) 66%, var(--bg) 100%);
}
.hero-glow{
  position:absolute;inset:-40% 0 auto 0;height:600px;
  background:radial-gradient(600px 320px at 50% 30%,rgba(143,123,255,0.4),transparent 70%);
  pointer-events:none;
}
.hero-inner{position:relative;z-index:2;max-width:920px;margin:0 auto}
.wordmark{
  font-family:'Anton',sans-serif;font-weight:400;
  font-size:clamp(48px,11vw,132px);line-height:.92;letter-spacing:3px;
  color:#fff;text-shadow:0 3px 26px rgba(7,5,26,0.92),0 0 48px rgba(143,123,255,0.55);
}
.tagline{
  font-family:'Anton',sans-serif;color:var(--gold);
  font-size:clamp(16px,3.4vw,30px);letter-spacing:6px;margin-top:10px;
  text-shadow:0 2px 16px rgba(7,5,26,0.9);
}
.lede{max-width:640px;margin:22px auto 0;color:#d7d2f2;font-size:clamp(15px,2vw,19px);text-shadow:0 1px 12px rgba(7,5,26,0.85)}
.cta-row{display:flex;gap:16px;justify-content:center;flex-wrap:wrap;margin-top:34px}
.powered{margin-top:26px;color:var(--mute);font-size:13px;letter-spacing:2px}
.powered b{color:var(--violet2)}

/* features */
.features{
  max-width:1120px;margin:10px auto 0;padding:30px 24px 20px;
  display:grid;grid-template-columns:repeat(4,1fr);gap:18px;
}
.feat{
  background:linear-gradient(180deg,var(--panel),rgba(20,15,48,0.4));
  border:1px solid var(--line);border-radius:14px;padding:24px 20px;
}
.feat-ico{
  font-family:'Anton',sans-serif;font-size:26px;color:var(--gold);
  width:52px;height:52px;border-radius:12px;
  display:flex;align-items:center;justify-content:center;
  background:rgba(143,123,255,0.12);border:1px solid var(--line);margin-bottom:14px;
}
.feat h3{font-size:19px;color:#fff;margin-bottom:6px}
.feat p{color:var(--mute);font-size:15px}

/* section shared */
.section-title{
  font-family:'Anton',sans-serif;font-weight:400;text-align:center;
  font-size:clamp(30px,6vw,58px);letter-spacing:2px;color:#fff;
}
.section-sub{text-align:center;max-width:680px;margin:12px auto 0;color:var(--mute);font-size:17px}

/* roster */
.roster{padding:80px 24px 40px;max-width:1180px;margin:0 auto}
.roster-grid{
  margin-top:38px;display:grid;gap:14px;
  grid-template-columns:repeat(6,1fr);
}
.card{
  position:relative;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);background:var(--bg2);
  aspect-ratio:3/4;cursor:default;
  transition:transform .12s ease,border-color .12s ease,box-shadow .12s ease;
}
.card:hover{transform:translateY(-4px);border-color:var(--violet);box-shadow:0 14px 30px rgba(0,0,0,0.5)}
.card img{width:100%;height:100%;object-fit:cover;object-position:top center}
.card .meta{
  position:absolute;left:0;right:0;bottom:0;padding:14px 12px 10px;
  background:linear-gradient(180deg,transparent,rgba(7,5,26,0.92) 62%);
}
.card .cname{font-family:'Anton',sans-serif;font-size:20px;color:#fff;letter-spacing:1px}
.card .ctitle{font-size:11px;color:var(--gold);letter-spacing:1.5px;text-transform:uppercase}

/* arenas */
.arenas{padding:80px 24px 50px;max-width:1200px;margin:0 auto}
.arena-grid{margin-top:38px;display:grid;gap:16px;grid-template-columns:repeat(4,1fr)}
.arena{
  position:relative;border-radius:12px;overflow:hidden;
  border:1px solid var(--line);background:var(--bg2);aspect-ratio:16/9;
  transition:transform .14s ease,border-color .14s ease,box-shadow .14s ease;
}
.arena:hover{transform:translateY(-4px) scale(1.01);border-color:var(--violet);box-shadow:0 16px 34px rgba(0,0,0,0.55)}
.arena img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .3s ease}
.arena:hover img{transform:scale(1.06)}
.arena .aname{
  position:absolute;left:0;right:0;bottom:0;padding:22px 14px 10px;
  font-family:'Anton',sans-serif;font-size:16px;letter-spacing:1px;color:#fff;
  text-shadow:0 2px 10px rgba(0,0,0,0.9);
  background:linear-gradient(180deg,transparent,rgba(7,5,26,0.9) 78%);
}

/* wager */
.wager{padding:70px 24px;background:linear-gradient(180deg,transparent,rgba(20,15,48,0.5),transparent)}
.wager-inner{max-width:1100px;margin:0 auto}
.steps{margin-top:40px;display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.step{
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 18px;
}
.step .num{
  font-family:'Anton',sans-serif;font-size:18px;color:#241000;
  width:34px;height:34px;border-radius:50%;display:flex;align-items:center;justify-content:center;
  background:var(--gold);margin-bottom:12px;
}
.step h4{font-size:18px;color:#fff;margin-bottom:5px}
.step p{color:var(--mute);font-size:14px}

/* token */
.token{padding:80px 24px;max-width:820px;margin:0 auto;text-align:center}
.ca-card{
  margin-top:34px;background:linear-gradient(180deg,var(--panel),rgba(20,15,48,0.4));
  border:1px solid var(--line);border-radius:16px;padding:28px 24px;
}
.ca-label{font-size:12px;letter-spacing:3px;color:var(--mute)}
.ca-row{display:flex;gap:12px;align-items:center;justify-content:center;flex-wrap:wrap;margin:14px 0 18px}
.ca-row code{
  font-family:'Oswald',monospace;font-size:clamp(14px,3vw,20px);color:var(--gold);
  background:rgba(7,5,26,0.6);border:1px solid var(--line);border-radius:8px;
  padding:10px 16px;word-break:break-all;letter-spacing:1px;
}
.ca-tags{display:flex;gap:10px;justify-content:center;flex-wrap:wrap}
.ca-tags span{
  font-size:12px;letter-spacing:2px;color:var(--violet2);
  border:1px solid var(--line);border-radius:20px;padding:6px 14px;
}

/* final cta */
.cta-final{text-align:center;padding:60px 24px 90px}
.cta-final h2{font-family:'Anton',sans-serif;font-weight:400;font-size:clamp(28px,6vw,54px);color:#fff;margin-bottom:26px;letter-spacing:2px}

/* footer */
.foot{border-top:1px solid var(--line);padding:34px 24px;text-align:center;color:var(--mute)}
.foot-brand{font-family:'Anton',sans-serif;font-size:22px;color:#fff;letter-spacing:2px}
.foot-brand span{color:var(--gold)}
.foot-links{display:flex;gap:22px;justify-content:center;margin:16px 0;font-size:15px}
.foot-links a:hover{color:#fff}
.foot-fine{font-size:13px;letter-spacing:1px}

/* reveal on scroll */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .5s ease,transform .5s ease}
.reveal.in{opacity:1;transform:none}

/* responsive */
@media (max-width:900px){
  .features{grid-template-columns:repeat(2,1fr)}
  .steps{grid-template-columns:repeat(2,1fr)}
  .roster-grid{grid-template-columns:repeat(3,1fr)}
  .arena-grid{grid-template-columns:repeat(2,1fr)}
  .nav a:not(.btn){display:none}
}
@media (max-width:520px){
  .roster-grid{grid-template-columns:repeat(2,1fr)}
  .arena-grid{grid-template-columns:1fr}
  .topbar{padding:12px 18px}
  .hero{min-height:560px}
}
/* true small phones: shrink the display type and buttons so nothing can run
   past the edge on a 320 to 400px screen */
@media (max-width:430px){
  .wordmark{font-size:clamp(38px,13vw,120px);letter-spacing:1px}
  .tagline{letter-spacing:3px}
  .hero{padding:78px 16px 66px}
  .btn.big{font-size:16px;padding:13px 18px}
  .powered{font-size:11px;letter-spacing:1px}
  .section-sub{font-size:15px}
}
