@font-face{font-family:'Inter';font-style:normal;font-weight:400;font-display:swap;src:url(../assets/fonts/inter-400.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:500;font-display:swap;src:url(../assets/fonts/inter-500.woff2) format('woff2')}
@font-face{font-family:'Inter';font-style:normal;font-weight:600;font-display:swap;src:url(../assets/fonts/inter-600.woff2) format('woff2')}
@font-face{font-family:'Roboto Slab';font-style:normal;font-weight:500;font-display:swap;src:url(../assets/fonts/roboto-slab-500.woff2) format('woff2')}
@font-face{font-family:'Roboto Slab';font-style:normal;font-weight:700;font-display:swap;src:url(../assets/fonts/roboto-slab-700.woff2) format('woff2')}
:root{
  --bg:#1C1C1E; --panel:#232327; --panel2:#2A2A2E; --ink:#F2F2F2; --muted:#A8A8A8;
  --line:rgba(255,255,255,.08); --accent:#7aa6ff;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:80px}
body{margin:0;background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,Arial,sans-serif;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3{font-family:'Roboto Slab',Georgia,serif;font-weight:700;letter-spacing:.2px;margin:0 0 .5em}
a{color:var(--ink);text-decoration:none}
.wrap{max-width:1080px;margin:0 auto;padding:0 22px}
.pad{padding:54px 22px}
.muted{color:var(--muted)} .small{font-size:.85rem}
.rainbow{height:3px;background:linear-gradient(90deg,#ff5e5e,#ffae3b,#ffe14d,#7bd86b,#46c6e2,#7aa6ff,#b07bff,#ff5ec0)}
/* nav */
.nav{position:sticky;top:0;z-index:20;background:rgba(28,28,30,.82);backdrop-filter:blur(10px);border-bottom:1px solid var(--line)}
.nav-inner{display:flex;align-items:center;justify-content:space-between;height:64px}
.brand{display:flex;align-items:center;gap:11px;font-family:'Roboto Slab',serif;font-weight:700;font-size:1.05rem}
.brand img{width:34px;height:34px;border-radius:50%}
.links ul{display:flex;gap:6px;align-items:center;list-style:none;margin:0;padding:0}
.links a{padding:8px 14px;border-radius:8px;color:var(--muted);font-weight:500;font-size:.95rem;transition:.15s}
.links a:hover{color:var(--ink);background:var(--panel2)}
.nav-right{display:flex;align-items:center;gap:8px}
.cta-link{padding:8px 14px;border-radius:8px;color:var(--ink);font-weight:600;font-size:.95rem;background:linear-gradient(90deg,#3457b8,#6a3fb8);transition:.15s;white-space:nowrap}
.cta-link:hover{filter:brightness(1.1)}
.nav-toggle{display:none;align-items:center;justify-content:center;width:40px;height:38px;border-radius:8px;border:1px solid var(--line);background:var(--panel2);color:var(--ink);font-size:1.25rem;line-height:1;cursor:pointer}
/* hero */
.hero{text-align:center;padding:78px 22px 40px;background:radial-gradient(900px 360px at 50% -8%,rgba(122,166,255,.14),transparent)}
.hero-logo{width:118px;height:118px;border-radius:50%;box-shadow:0 0 0 1px var(--line),0 18px 50px rgba(0,0,0,.5)}
.hero h1{font-size:3rem;margin:.35em 0 .15em}
.tagline{color:var(--muted);font-size:1.15rem;margin:0 0 18px}
.prog-badge{display:inline-block;padding:7px 16px;border:1px solid var(--line);border-radius:999px;color:var(--ink);font-size:.9rem;background:var(--panel)}
.btns{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-top:26px}
.btn{display:inline-block;padding:12px 22px;border-radius:10px;border:1px solid var(--line);background:var(--panel2);font-weight:600;transition:.15s}
.btn:hover{background:#33333a;transform:translateY(-1px)}
.btn.primary{background:linear-gradient(90deg,#3457b8,#6a3fb8);border:none;color:var(--ink)}
.btn.primary:hover{filter:brightness(1.08)}
/* panels + stats */
.panel{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:26px 28px;margin:0 0 26px}
.panel h2{margin-top:0}
.panel p{color:#dcdcdc;margin:0}
.stats{display:grid;grid-template-columns:repeat(4,1fr);gap:16px}
.stat{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 18px;text-align:center}
.stat .num{display:block;font-family:'Roboto Slab',serif;font-weight:700;font-size:1.5rem}
.stat .lbl{display:block;color:var(--muted);font-size:.86rem;margin-top:4px}
.page-head{margin-bottom:30px}
.page-head h1{font-size:2.3rem;margin-bottom:.1em}
/* roster */
.role-h{font-size:1.35rem;margin:34px 0 14px;padding-bottom:8px;border-bottom:1px solid var(--line)}
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(min(100%,300px),1fr));gap:14px}
.member{display:flex;align-items:center;flex-wrap:wrap;gap:6px 11px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:15px 18px;transition:.15s}
.member:hover{background:var(--panel2);transform:translateY(-1px)}
.dot{width:11px;height:11px;border-radius:50%;flex:0 0 auto}
.mname{font-weight:600}
.mspec{margin-left:auto;font-size:.84rem;font-weight:500}
/* progression */
.prog-hero{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.prog-hero .num{font-family:'Roboto Slab',serif;font-weight:700;font-size:2.6rem;color:#ff7c7c}
.prog-hero .lbl{color:#dcdcdc;font-size:1.05rem}
.boss-list{display:flex;flex-direction:column;gap:10px}
.boss{display:flex;align-items:center;gap:14px;background:var(--panel);border:1px solid var(--line);border-radius:11px;padding:15px 18px}
.boss[data-status=progressing]{border-color:rgba(255,170,60,.4)}
.bname{font-family:'Roboto Slab',serif;font-weight:500;font-size:1.05rem}
.bstatus{margin-left:auto;font-size:.78rem;font-weight:600;padding:4px 11px;border-radius:999px}
.s-defeated{background:rgba(123,216,107,.16);color:#9be08a}
.s-progressing{background:rgba(255,170,60,.18);color:#ffc06a}
.s-upcoming{background:var(--panel2);color:var(--muted)}
.bnote{color:var(--muted);font-size:.84rem;margin-left:12px}
.note{margin-top:18px}
code{background:var(--panel2);padding:2px 6px;border-radius:5px;font-size:.85em}
/* recruit */
.cols{display:grid;grid-template-columns:1fr 1fr;gap:22px}
.needs,.expect{list-style:none;padding:0;margin:8px 0 0}
.needs li,.expect li{padding:9px 0;border-bottom:1px solid var(--line);color:#dcdcdc}
.needs li:last-child,.expect li:last-child{border-bottom:none}
.needs .hi,.needs .open{display:inline-block;min-width:62px;font-size:.72rem;font-weight:700;padding:2px 8px;border-radius:6px;margin-right:10px;text-align:center}
.needs .hi{background:rgba(255,120,120,.18);color:#ff9b9b}
.needs li:nth-child(2) .hi{background:rgba(255,170,60,.18);color:#ffc06a}
.needs .open{background:rgba(123,216,107,.16);color:#9be08a}
.apply{text-align:center}
.apply .btns{margin-top:8px}
/* why-us perks + apply steps/factors */
.perks{list-style:none;padding:0;margin:0;display:grid;grid-template-columns:1fr 1fr;gap:8px 26px}
.perks li{position:relative;padding:9px 0 9px 28px;border-bottom:1px solid var(--line);color:#dcdcdc}
.perks li::before{content:"\2713";position:absolute;left:2px;top:9px;color:#9be08a;font-weight:700}
.steps{display:flex;flex-direction:column;gap:14px;counter-reset:step;margin-bottom:26px}
.step{position:relative;background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 26px 22px 70px}
.step::before{counter-increment:step;content:counter(step);position:absolute;left:22px;top:22px;width:34px;height:34px;border-radius:50%;background:linear-gradient(90deg,#3457b8,#6a3fb8);color:#fff;font-family:'Roboto Slab',serif;font-weight:700;display:flex;align-items:center;justify-content:center}
.step h2{margin:.15em 0 .45em;font-size:1.12rem}
.step p{color:#dcdcdc;margin:0}
.step ul{margin:.5em 0 0;padding-left:20px;color:#dcdcdc}
.step ul li{margin:4px 0}
.factors{list-style:none;counter-reset:f;padding:0;margin:0}
.factors li{position:relative;padding:12px 0 12px 42px;border-bottom:1px solid var(--line);color:#dcdcdc}
.factors li:last-child{border-bottom:none}
.factors li b{color:var(--ink)}
.factors li::before{counter-increment:f;content:counter(f);position:absolute;left:2px;top:11px;width:26px;height:26px;border-radius:50%;background:var(--panel2);border:1px solid var(--line);color:var(--ink);font-weight:700;font-size:.8rem;display:flex;align-items:center;justify-content:center}
.apply-embed{display:block;width:100%;min-height:560px;border:0;border-radius:10px;background:transparent}
.apply-cta{text-align:center}
.apply-cta h2{margin-top:0}
.apply-cta p{color:#dcdcdc;margin:0 0 18px}
.apply-toggle{font-family:inherit;font-size:1rem;cursor:pointer}
.apply-toggle .caret{display:inline-block;margin-left:9px;transition:transform .3s ease}
.apply-toggle.is-open .caret{transform:rotate(180deg)}
.form-reveal{border-radius:14px}
/* accessibility */
.skip-link{position:absolute;left:-999px;top:0;z-index:40}
.skip-link:focus{left:8px;top:8px;background:var(--panel2);color:var(--ink);padding:8px 14px;border-radius:8px;outline:2px solid var(--accent)}
:where(a,button,input,[tabindex]):focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:8px}
#main:focus{outline:none}                                  /* skip-link target: move reading point, no visible ring */
.links a[aria-current="page"]{color:var(--ink)}            /* visible "you are here", not just programmatic */
.vh{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}
/* Windows High Contrast / forced-colors: keep gradient controls visible when backgrounds are stripped */
@media (forced-colors: active){
  .btn,.cta-link,.nav-toggle,.prog-badge{border:1px solid}
  .rainbow{forced-color-adjust:none}
}
/* colour-blind mode toggle (footer) */
.cb-toggle{margin-top:16px;display:flex;align-items:center;justify-content:center;gap:8px;font-size:.85rem;color:var(--muted)}
.cb-toggle input{width:16px;height:16px;cursor:pointer;accent-color:var(--accent)}
.cb-toggle label{cursor:pointer}
/* colour-blind friendly mode (opt-in): shape cues so status/labels are never colour-only, + higher-contrast text */
.cb .bstatus::before{margin-right:5px;font-weight:700}
.cb .s-defeated::before{content:"\2713"}
.cb .s-progressing::before{content:"\25B6"}
.cb .s-upcoming::before{content:"\25CB"}
.cb .s-progressing{background:rgba(70,150,255,.20);color:#8fb8ff}
.cb .needs .hi::before,.cb .needs .open::before{margin-right:6px;font-weight:700}
.cb .needs .hi::before{content:"\25B2"}
.cb .needs .open::before{content:"\25CB"}
.cb .mspec{color:var(--ink)!important}
.cb .prog-hero .num{color:var(--ink)}
/* footer */
.foot{border-top:1px solid var(--line);margin-top:40px;padding:30px 0;text-align:center}
.foot p{margin:3px 0;color:var(--muted)}
@media(max-width:720px){
  .hero h1{font-size:2.2rem}.stats{grid-template-columns:repeat(2,1fr)}.cols{grid-template-columns:1fr}
  .brand span{display:none}
  .nav-toggle{display:inline-flex}
  .links{position:absolute;top:100%;left:0;right:0;display:none;background:rgba(28,28,30,.97);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);box-shadow:0 14px 30px rgba(0,0,0,.4)}
  .links.open{display:block}
  .links ul{flex-direction:column;align-items:stretch;gap:2px;padding:10px 14px}
  .links a{display:block;padding:12px 14px;font-size:1rem}
  .perks{grid-template-columns:1fr}.step{padding-left:64px}
}
@media (prefers-reduced-motion: reduce){
  html{scroll-behavior:auto}
  *,*::before,*::after{transition-duration:.001ms !important;animation-duration:.001ms !important}
}