:root{
  --bg:#0b0f14;
  --bg-alt:#121922;
  --panel:#161f2b;
  --panel-2:#1b2635;
  --text:#e8edf4;
  --muted:#aab6c7;
  --accent:#b3262e;
  --accent-2:#d14a51;
  --line:#273243;
  --max:1180px;
  --shadow:0 16px 40px rgba(0,0,0,.28);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Segoe UI, Arial, Helvetica, sans-serif;
  background:
    radial-gradient(circle at top right, rgba(179,38,46,.08), transparent 20%),
    linear-gradient(180deg, #081018 0%, var(--bg) 100%);
  color:var(--text);
  line-height:1.6;
}
img{max-width:100%;display:block}
a{color:inherit}
.container{width:min(100% - 32px, var(--max));margin:0 auto}
.section{padding:72px 0}
.section-tight{padding:40px 0}
.eyebrow{
  display:inline-block;
  letter-spacing:.12em;
  text-transform:uppercase;
  color:#ff8a90;
  font-size:.78rem;
  margin-bottom:10px;
}
h1,h2,h3{line-height:1.15;margin:0 0 14px}
h1{font-size:clamp(2.5rem, 6vw, 4.8rem)}
h2{font-size:clamp(1.8rem, 4vw, 2.8rem)}
h3{font-size:1.2rem}
p{margin:0 0 14px;color:var(--muted)}
ul{padding-left:20px;color:var(--muted)}
.small{font-size:.92rem}
.center{text-align:center}
.grid{display:grid;gap:22px}
.grid-2{grid-template-columns:repeat(2,minmax(0,1fr))}
.grid-3{grid-template-columns:repeat(3,minmax(0,1fr))}
.grid-4{grid-template-columns:repeat(4,minmax(0,1fr))}
.card{
  background:linear-gradient(180deg, rgba(255,255,255,.02), rgba(255,255,255,.01));
  border:1px solid var(--line);
  border-radius:18px;
  padding:24px;
  box-shadow:var(--shadow);
}
.hero{
  min-height:86vh;
  display:flex;
  align-items:center;
  position:relative;
  overflow:hidden;
  border-bottom:1px solid rgba(255,255,255,.06);
}
.hero::before{
  content:"";
  position:absolute; inset:0;
  background:
    linear-gradient(90deg, rgba(8,16,24,.92) 0%, rgba(8,16,24,.78) 45%, rgba(8,16,24,.72) 100%),
    url('images/background.png') center/cover no-repeat;
  z-index:-2;
}
.hero::after{
  content:"";
  position:absolute; inset:auto 0 0 0; height:160px;
  background:linear-gradient(to top, var(--bg), transparent);
  z-index:-1;
}
.hero-copy{max-width:760px;padding:90px 0 70px}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:24px}
.button{
  display:inline-flex;align-items:center;justify-content:center;
  padding:14px 18px;border-radius:12px;text-decoration:none;
  font-weight:700;border:1px solid transparent;transition:.18s ease;
}
.button-primary{background:linear-gradient(180deg, var(--accent-2), var(--accent)); color:white}
.button-primary:hover{transform:translateY(-1px)}
.button-secondary{background:transparent;border-color:var(--line);color:var(--text)}
.button-secondary:hover{background:rgba(255,255,255,.04)}
.button-block{width:100%}
.stat{
  padding:20px;border-radius:18px;background:var(--panel);border:1px solid var(--line);
}
.stat strong{display:block;font-size:2rem;color:white}
.site-header{
  position:sticky;top:0;z-index:50;
  backdrop-filter:blur(10px);
  background:rgba(8,16,24,.76);
  border-bottom:1px solid rgba(255,255,255,.06);
}
.nav{
  display:flex;align-items:center;justify-content:space-between;
  min-height:74px;gap:20px
}
.brand{display:flex;align-items:center;gap:14px;text-decoration:none}
.brand-mark{
  width:42px;height:42px;border-radius:10px;
  background:linear-gradient(180deg, var(--accent-2), var(--accent));
  display:grid;place-items:center;font-weight:900
}
.brand-text strong{display:block}
.brand-text span{display:block;font-size:.78rem;color:var(--muted);letter-spacing:.08em;text-transform:uppercase}
.nav-links{display:flex;gap:18px;flex-wrap:wrap}
.nav-links a{
  text-decoration:none;color:var(--muted);font-weight:600;font-size:.96rem
}
.nav-links a:hover,.nav-links a.active{color:white}
.panel{
  background:linear-gradient(180deg, rgba(22,31,43,.95), rgba(16,24,34,.96));
  border:1px solid var(--line); border-radius:22px; padding:28px; box-shadow:var(--shadow);
}
.kicker-row{display:flex;gap:14px;flex-wrap:wrap;margin-top:18px}
.kicker{
  border:1px solid var(--line); border-radius:999px; padding:8px 12px;
  color:var(--muted); background:rgba(255,255,255,.03); font-size:.9rem
}
.split{
  display:grid; grid-template-columns:1.15fr .85fr; gap:24px; align-items:center
}
.table-wrap{overflow:auto}
.table{
  width:100%; border-collapse:collapse; min-width:680px;
  border:1px solid var(--line); border-radius:18px; overflow:hidden
}
.table th,.table td{padding:14px 16px; border-bottom:1px solid var(--line); text-align:left}
.table th{background:var(--panel-2); color:white}
.table tr:nth-child(even) td{background:rgba(255,255,255,.015)}
.tag{
  display:inline-block;padding:5px 10px;border-radius:999px;
  border:1px solid var(--line); background:rgba(255,255,255,.03); color:var(--muted); font-size:.8rem
}
.gallery{
  display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:16px
}
.shot{
  aspect-ratio:16/10; border-radius:18px; border:1px solid var(--line);
  overflow:hidden; position:relative; background:var(--panel)
}
.shot img{width:100%;height:100%;object-fit:cover}
.shot span{
  position:absolute; left:12px; bottom:12px; background:rgba(8,16,24,.72);
  border:1px solid rgba(255,255,255,.08); padding:6px 10px; border-radius:999px; font-size:.8rem
}
.page-hero{
  padding:72px 0 34px;
  background:
    linear-gradient(180deg, rgba(179,38,46,.12), transparent 70%),
    linear-gradient(180deg, rgba(255,255,255,.02), transparent 80%);
  border-bottom:1px solid rgba(255,255,255,.06)
}
.notice{
  padding:16px 18px;border-radius:16px;border:1px solid rgba(209,74,81,.35);
  background:rgba(179,38,46,.10); color:#ffd6d8
}
.footer{
  border-top:1px solid rgba(255,255,255,.06); padding:32px 0 60px;
  background:rgba(0,0,0,.16)
}
.footer-grid{display:grid;grid-template-columns:1.2fr .8fr .8fr;gap:24px}
.footer a{text-decoration:none;color:var(--muted)}
.footer a:hover{color:white}
.input,.textarea,.select{
  width:100%; padding:14px 14px; border-radius:12px; border:1px solid var(--line);
  background:#0d141d; color:var(--text)
}
.textarea{min-height:130px; resize:vertical}
.form-row{display:grid; grid-template-columns:1fr 1fr; gap:16px}
.divider{height:1px;background:var(--line);margin:20px 0}
.quote{
  border-left:4px solid var(--accent); padding:10px 0 10px 16px; color:#d7e0ec
}
@media (max-width:980px){
  .grid-4,.grid-3,.grid-2,.gallery,.split,.footer-grid,.form-row{grid-template-columns:1fr}
  .hero{min-height:auto}
  .hero-copy{padding:70px 0 56px}
}
@media (max-width:700px){
  .nav{padding:12px 0}
  .nav-links{gap:12px}
  .brand-text span{display:none}
  .section{padding:56px 0}
}

/* --- Restored working roster/page styles from JSON version --- */

:root{
  --bg:#060711;
  --bg2:#0a0c18;
  --panel:#0d1020;
  --panel2:#11152a;
  --line:#2b3159;
  --line-soft:rgba(133,145,255,.16);
  --text:#eef0ff;
  --muted:#b9bdd9;
  --accent:#c8c95d;
  --teal:#6ecfd0;
  --purple:#9e97dc;
  --max:1320px;
  --shadow:0 24px 60px rgba(0,0,0,.45);
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  color:var(--text);
  font-family:Segoe UI, Arial, Helvetica, sans-serif;
  background-image:
    radial-gradient(circle at 20% 10%, rgba(57,59,122,.20), transparent 20%),
    radial-gradient(circle at 80% 20%, rgba(110,207,208,.08), transparent 18%),
    linear-gradient(rgba(2,4,10,.82), rgba(3,4,12,.92)),
    url("./images/background.png");
  background-size: auto, auto, auto, cover;
  background-position: top left, top right, center, center;
  background-repeat: no-repeat, no-repeat, no-repeat, no-repeat;
  background-attachment: scroll, scroll, scroll, fixed;
  min-height:100vh;
}
body::before{
  content:"";
  position:fixed; inset:0;
  background-image:
    radial-gradient(circle at 1px 1px, rgba(255,255,255,.18) 1px, transparent 0);
  background-size: 44px 44px;
  opacity:.18;
  pointer-events:none;
}
img{max-width:100%; display:block}
a{color:inherit}
button,input,select{font:inherit}
.container{width:min(100% - 30px, var(--max)); margin:0 auto}
.site-header{
  position:sticky; top:0; z-index:80;
  background:rgba(4,6,14,.86);
  backdrop-filter:blur(12px);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.nav{
  min-height:76px; display:flex; align-items:center; justify-content:space-between; gap:20px;
}
.brand{
  display:flex; align-items:center; gap:16px; text-decoration:none;
}
.brand-mark{
  width:54px; height:54px; border-radius:50%;
  background:linear-gradient(180deg, #2f315d, #12162a);
  border:1px solid rgba(255,255,255,.12);
  display:grid; place-items:center; color:#f1f2ff; font-weight:900; letter-spacing:.05em;
  box-shadow:0 0 0 4px rgba(255,255,255,.03);
}
.brand-text small{
  display:block; text-transform:uppercase; letter-spacing:.22em; color:#b0b5da; font-size:.74rem;
}
.brand-text strong{
  display:block; font-size:1.95rem; line-height:1; font-weight:800; letter-spacing:.02em;
}
.nav-links{display:flex; gap:22px; flex-wrap:wrap}
.nav-links a{
  text-decoration:none; color:#d3d7f3; opacity:.88; font-weight:500;
}
.nav-links a:hover,.nav-links a.active{opacity:1; text-decoration:underline; text-underline-offset:5px}
.hero{
  padding:54px 0 34px;
}
.panel{
  background:
    linear-gradient(180deg, rgba(18,21,42,.96), rgba(7,9,18,.97));
  border:1px solid var(--line-soft);
  border-radius:26px;
  box-shadow:var(--shadow);
}
.hero-panel{
  padding:36px;
  position:relative;
  overflow:hidden;
}
.hero-panel::after{
  content:"";
  position:absolute; inset:auto -140px -140px auto; width:320px; height:320px;
  background:radial-gradient(circle, rgba(110,207,208,.14), transparent 60%);
  pointer-events:none;
}
.hero h1{
  margin:0 0 10px; font-size:clamp(2.2rem, 4.6vw, 4rem); line-height:1.05;
}
.hero p{margin:0; color:var(--muted); max-width:780px; font-size:1.08rem}
.button{
  display:inline-flex; align-items:center; justify-content:center;
  padding:13px 18px; border-radius:14px; text-decoration:none; cursor:pointer;
  border:1px solid var(--line); color:var(--text);
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(255,255,255,.02));
}
.button:hover{transform:translateY(-1px)}
.button-primary{
  background:linear-gradient(180deg, #262c57, #121730);
  border-color:#475297;
}
.button-accent{
  border-color:rgba(200,201,93,.35);
  color:#f1efc0;
}
.content-section{padding:24px 0 70px}
.search-toolbar{
  display:grid; grid-template-columns:minmax(0,1fr) auto auto; gap:12px;
  padding:16px; margin-bottom:18px;
}
.search-input{
  width:100%; height:54px; border-radius:18px; padding:0 18px;
  background:rgba(0,0,0,.28); color:var(--text); border:1px solid rgba(255,255,255,.08);
  outline:none;
}
.search-input::placeholder{color:#8f94bc}
.badge-toggle{
  height:54px; padding:0 18px; border-radius:999px; background:rgba(255,255,255,.03);
  color:#d8dcff; border:1px solid rgba(255,255,255,.09); cursor:pointer;
  letter-spacing:.08em; text-transform:uppercase; font-size:.82rem; font-weight:700;
}
.badge-toggle.active.rank{border-color:rgba(200,201,93,.4); color:#efe7a0}
.badge-toggle.active.role{border-color:rgba(110,207,208,.45); color:#a7e6e7}
.roster-wrap{padding:18px}
.group-grid{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:18px;
}
.group-card{
  padding:18px; border-radius:24px; background:rgba(0,0,0,.14); border:1px solid rgba(255,255,255,.08);
}
.group-head{
  display:flex; align-items:center; justify-content:space-between; gap:12px;
  margin-bottom:14px;
}
.group-head h2{margin:0; font-size:1.95rem; line-height:1.1}
.meta-pills{display:flex; gap:10px; flex-wrap:wrap}
.pill{
  border:1px solid rgba(255,255,255,.12); border-radius:999px; padding:8px 12px;
  color:#d6dbff; font-size:.82rem; letter-spacing:.12em; text-transform:uppercase; font-weight:700;
  background:rgba(255,255,255,.02);
}
.pill.teal{border-color:rgba(110,207,208,.32); color:#9de0e0}
.pill.gold{border-color:rgba(200,201,93,.34); color:#ece8a1}
.pill.purple{border-color:rgba(158,151,220,.32); color:#c9c3ff}
.record-card{
  display:grid; grid-template-columns:180px minmax(0,1fr); gap:16px;
  padding:16px; border:1px solid rgba(255,255,255,.08); border-radius:24px;
  background:linear-gradient(180deg, rgba(6,8,18,.9), rgba(5,6,14,.95));
}
.avatar-box{
  border-radius:22px; padding:12px; background:rgba(255,255,255,.02); border:1px solid rgba(255,255,255,.08);
}
.avatar-frame{
  aspect-ratio:1/1.15; border-radius:18px; overflow:hidden; border:1px solid rgba(255,255,255,.08);
  background:linear-gradient(180deg, #2a2944, #111424);
}
.avatar-label{margin-top:10px; font-size:.8rem; letter-spacing:.18em; text-transform:uppercase; color:#9ca3d5}
.avatar-title{font-size:1.55rem; font-weight:800}
.record-main{display:flex; flex-direction:column}
.record-top{
  display:flex; justify-content:space-between; gap:14px; align-items:flex-start;
}
.record-name{
  margin:0 0 6px; font-size:1.9rem; line-height:1;
}
.record-sub{color:#d6daf7; font-size:1.04rem; margin-bottom:14px}
.icon-row{display:flex; gap:10px; margin-bottom:12px}
.icon-chip{
  min-width:56px; height:38px; border-radius:12px;
  border:1px solid rgba(255,255,255,.10); background:linear-gradient(180deg,#13172c,#0b0d19);
  display:grid; place-items:center; position:relative; overflow:hidden;
}
.icon-chip.rank::before{
  content:""; position:absolute; inset:7px; background:
  repeating-linear-gradient(135deg, #d5d948 0 8px, transparent 8px 14px);
  border-radius:8px; opacity:.95;
}
.icon-chip.role::before{
  content:""; position:absolute; inset:9px 7px; background:
  repeating-linear-gradient(90deg, #d5d948 0 6px, transparent 6px 10px);
  border-radius:8px; opacity:.95;
}
.fact-grid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px}
.fact{
  border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:14px 14px 12px;
  background:rgba(255,255,255,.02);
}
.fact span{
  display:block; color:#a5abd5; text-transform:uppercase; letter-spacing:.16em; font-size:.76rem; margin-bottom:6px;
}
.fact strong{font-size:1.02rem; line-height:1.35}
.record-desc{margin:14px 0 16px; color:var(--muted); font-size:1.02rem}
.record-actions{display:flex; gap:10px; flex-wrap:wrap}
.record-card[hidden], .group-card[hidden]{display:none !important}

.card-spacer{height:8px}
.page-note{padding:0 20px 16px; color:#959bc7; font-size:.94rem}
.footer{
  padding:30px 0 60px; color:#9398c3;
}
.footer a{text-decoration:none}
.modal{
  position:fixed; inset:0; display:none; align-items:center; justify-content:center;
  background:rgba(2,3,8,.72); backdrop-filter:blur(10px); z-index:200;
  padding:18px;
}
.modal.open{display:flex}
.modal-panel{
  width:min(100%, 980px); max-height:min(90vh, 900px); overflow:auto;
  border-radius:28px; border:1px solid rgba(255,255,255,.1);
  background:linear-gradient(180deg, rgba(18,21,42,.98), rgba(7,9,18,.98));
  box-shadow:var(--shadow);
}
.modal-head{
  display:flex; align-items:flex-start; justify-content:space-between; gap:16px;
  padding:22px 24px 8px;
}
.modal-head h3{margin:0; font-size:2rem}
.modal-head p{margin:4px 0 0; color:var(--muted)}
.close-btn{
  width:44px; height:44px; border-radius:50%; border:1px solid rgba(255,255,255,.12);
  background:rgba(255,255,255,.03); color:var(--text); cursor:pointer;
}
.modal-content{padding:0 24px 24px}
.service-grid{display:grid; grid-template-columns:1.1fr .9fr; gap:18px}
.subpanel{
  border:1px solid rgba(255,255,255,.08); border-radius:22px; padding:18px;
  background:rgba(255,255,255,.02);
}
.subpanel h4{margin:0 0 14px; font-size:1.18rem}
.medal-grid, .ribbon-grid{
  display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:12px;
}
.award{
  border:1px solid rgba(255,255,255,.08); border-radius:18px; padding:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.03), rgba(255,255,255,.01));
}
.award-badge{
  width:60px; height:60px; border-radius:16px; margin-bottom:10px;
  background:radial-gradient(circle at 35% 35%, rgba(255,255,255,.35), rgba(255,255,255,.06) 45%, transparent 48%),
             linear-gradient(180deg, #414c89, #181d36);
  border:1px solid rgba(255,255,255,.1);
  position:relative;
}
.award-badge::after{
  content:""; position:absolute; left:18px; top:14px; width:24px; height:30px;
  background:linear-gradient(180deg, #e1dd7b, #aba63e);
  clip-path:polygon(50% 0, 100% 28%, 82% 100%, 18% 100%, 0 28%);
}
.ribbon{
  height:58px; border-radius:16px; border:1px solid rgba(255,255,255,.08);
  background:
    repeating-linear-gradient(90deg, #d3d84b 0 16px, #1d203a 16px 32px, #8f94df 32px 48px, #1d203a 48px 64px);
  margin-bottom:10px;
}
.timeline{
  display:grid; gap:12px;
}
.entry{
  border-left:2px solid rgba(110,207,208,.45); padding-left:14px;
}
.entry strong{display:block; margin-bottom:4px}
.muted{color:var(--muted)}
@media (max-width:1100px){
  .group-grid, .service-grid{grid-template-columns:1fr}
}
@media (max-width:760px){
  .nav{padding:10px 0}
  .nav-links{gap:14px}
  .brand-text strong{font-size:1.5rem}
  .hero-panel{padding:24px}
  .search-toolbar{grid-template-columns:1fr}
  .record-card{grid-template-columns:1fr}
  .fact-grid, .medal-grid, .ribbon-grid{grid-template-columns:1fr}
}.group-head button.collapse-btn{
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.10);
  color:#d8dcff;
  border-radius:999px;
  padding:10px 14px;
  cursor:pointer;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
  font-size:.78rem;
}
.group-head button.collapse-btn:hover{background:rgba(255,255,255,.06)}
.group-card.collapsed .group-body{display:none}
.group-card.collapsed .group-head{margin-bottom:0}

.name-list{
  display:grid;
  gap:12px;
}
.name-card{
  border:1px solid rgba(255,255,255,.08);
  border-radius:22px;
  background:linear-gradient(180deg, rgba(7,9,18,.94), rgba(5,7,14,.98));
  overflow:hidden;
}
.name-toggle{
  width:100%;
  border:0;
  background:transparent;
  color:var(--text);
  text-align:left;
  padding:18px 20px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  cursor:pointer;
}
.name-toggle:hover{background:rgba(255,255,255,.02)}
.name-main{
  display:flex;
  flex-direction:column;
  gap:6px;
}
.name-main strong{
  font-size:1.45rem;
  line-height:1.05;
}
.name-main span{
  color:var(--muted);
  font-size:1rem;
}
.chevron{
  width:40px;
  height:40px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.10);
  display:grid;
  place-items:center;
  color:#d8dcff;
  flex:0 0 auto;
}
.chevron::before{
  content:"⌄";
  font-size:1.2rem;
  transform:translateY(-1px);
}
.name-card.open .chevron::before{
  transform:rotate(180deg) translateY(1px);
}
.name-body{
  display:none;
  padding:0 18px 18px;
}
.name-card.open .name-body{
  display:block;
}
.group-card.collapsed .group-body{display:none}

.meta-pills{display:none}


.award-img{
  width:64px;
  height:64px;
  object-fit:contain;
  margin-bottom:10px;
  display:block;
}

.award strong{
  display:block;
  margin-bottom:6px;
}

.link-buttons{
  display:grid;
  grid-template-columns:1fr;
  gap:20px;
  margin-top:30px;
}

.big-link{
  display:block;
  padding:28px;
  border-radius:18px;
  text-decoration:none;
  border:1px solid rgba(255,255,255,.08);
  background:rgba(20,30,45,.6);
  transition:all .2s ease;
}

.big-link:hover{
  transform:translateY(-4px);
  border-color:rgba(255,255,255,.2);
  background:rgba(30,45,70,.7);
}

.big-link-title{
  font-size:22px;
  font-weight:600;
  margin-bottom:6px;
}

.big-link-sub{
  opacity:.7;
  font-size:14px;
}

/* Colors */
.discord{
  border-left:4px solid #5865F2;
}

.teamspeak{
  border-left:4px solid #2580C3;
}

.modpack{
  border-left:4px solid #f59e0b;
}

.brand-logo{
  width:42px;
  height:42px;
  border-radius:10px;
}

.rank-icon-img{
  width:64px;
  height:64px;
  object-fit:contain;
}

.rank-badge{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:44px;
  height:28px;
  padding:0 10px;
  border:1px solid currentColor;
  border-radius:999px;
  font-size:.8rem;
  font-weight:700;
  letter-spacing:.08em;
  text-transform:uppercase;
}

.rank-name{
  font-size:.95rem;
  color:var(--muted);
}