/* =====================================================================
   Concrete RP — site theme (V5 cinematic)
   ===================================================================== */
:root{
  --pink:#ee3df0; --magenta:#e23ad0; --purple:#8b3af0;
  --blue:#3a86e8; --cyan:#33c6ee; --yellow:#ffc21f;
  --bg:#08070a; --bg2:#0c0a10; --panel:#100d15; --panel2:#15111c;
  --ink:#f3eef7; --mut:#a596b2; --line:rgba(238,61,240,.14);
  --grad:linear-gradient(90deg,var(--magenta),var(--blue));
  --grad-text:linear-gradient(90deg,var(--pink),var(--cyan));
  --radius:16px; --shadow:0 18px 50px rgba(0,0,0,.5);
  --maxw:1200px;
}
*{margin:0;padding:0;box-sizing:border-box}
/* keyboard focus visibility (accessibility) */
a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{
  outline:2px solid var(--pink);outline-offset:2px;border-radius:4px}
/* respect reduced-motion preference */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.001ms!important;animation-iteration-count:1!important;
    transition-duration:.001ms!important;scroll-behavior:auto!important}
  .hero-bg{animation:none!important}
}
html{scroll-behavior:smooth;scroll-padding-top:90px}
body{background:var(--bg);color:var(--ink);font-family:'Inter',system-ui,sans-serif;
  overflow-x:hidden;line-height:1.6;-webkit-font-smoothing:antialiased}
h1,h2,h3,h4,.display{font-family:'Sora',system-ui,sans-serif;line-height:1.1}
a{color:inherit}
img{max-width:100%;display:block}
.accent{background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
/* screen-reader-only (SEO/a11y headings without visual change) */
.sr-only{position:absolute!important;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;
  clip:rect(0,0,0,0);white-space:nowrap;border:0}
.wrap{max-width:var(--maxw);margin:0 auto;padding:0 5vw}
.section{position:relative;z-index:2;max-width:var(--maxw);margin:0 auto;padding:100px 5vw}
.eyebrow{font-size:13px;letter-spacing:3px;text-transform:uppercase;color:var(--magenta);font-weight:600}
.h2{font-size:clamp(30px,4vw,48px);font-weight:800;margin:10px 0 14px}
.sub{color:var(--mut);font-size:17px;max-width:580px}
.section-head-center{text-align:center;max-width:680px;margin:0 auto 4px}
.section-head-center .sub{margin:0 auto}

/* ---------- buttons ---------- */
.btn{font-family:'Sora';font-weight:700;font-size:15px;letter-spacing:.3px;cursor:pointer;
  border:none;border-radius:12px;padding:13px 26px;transition:.22s;display:inline-flex;
  align-items:center;gap:8px;text-decoration:none;white-space:nowrap}
.btn-primary{background:var(--grad);color:#fff;box-shadow:0 10px 30px rgba(226,58,208,.4)}
.btn-primary:hover{transform:translateY(-3px);box-shadow:0 16px 42px rgba(58,134,232,.55)}
.btn-ghost{background:rgba(255,255,255,.05);color:#efe5f4;border:1px solid rgba(238,61,240,.4)}
.btn-ghost:hover{background:rgba(238,61,240,.14);transform:translateY(-3px)}
.btn-lg{padding:16px 36px;font-size:16px}

/* ---------- nav ---------- */
.nav{position:fixed;inset:0 0 auto 0;z-index:100;display:flex;align-items:center;
  justify-content:space-between;padding:18px 5vw;transition:.3s;background:transparent}
.nav.scrolled{background:rgba(10,8,13,.94);padding:11px 5vw;border-bottom:1px solid var(--line);
  box-shadow:0 8px 30px rgba(0,0,0,.4)}
.nav-logo{height:42px;width:auto;filter:drop-shadow(0 2px 10px rgba(0,0,0,.6));transition:.3s}
.nav.scrolled .nav-logo{height:36px}
.nav-right{display:flex;align-items:center;gap:14px}

/* floating centered pill nav */
.nav-pill{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);display:flex;gap:4px;
  padding:6px;border-radius:40px;background:rgba(16,13,21,.66);border:1px solid var(--line);
  box-shadow:0 8px 30px rgba(0,0,0,.3)}
.nav-pill a{color:#d4c6dd;text-decoration:none;font-weight:600;font-size:14.5px;letter-spacing:.2px;
  padding:9px 20px;border-radius:30px;transition:.18s;position:relative}
.nav-pill a:hover{color:#fff;background:rgba(238,61,240,.14)}
.nav-pill a.active{color:#fff;background:var(--grad);box-shadow:0 6px 18px rgba(226,58,208,.4)}
.nav-pill a.nav-store{color:var(--yellow)}
.nav-pill a.nav-store:hover{color:#1a1206;background:var(--yellow)}

/* hamburger button (mobile only) */
.nav-toggle{display:none;flex-direction:column;justify-content:center;gap:5px;width:46px;height:46px;
  border:1px solid var(--line);border-radius:12px;background:rgba(15,10,18,.6);cursor:pointer;
  padding:0 12px;transition:.2s}
.nav-toggle:hover{border-color:rgba(238,61,240,.5)}
.nav-toggle span{display:block;height:2px;width:100%;background:#f0e4f5;border-radius:2px;transition:.28s}
body.menu-open .nav-toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
body.menu-open .nav-toggle span:nth-child(2){opacity:0}
body.menu-open .nav-toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}
.status-pill{display:inline-flex;gap:8px;align-items:center;font-size:12.5px;font-weight:600;
  letter-spacing:.5px;color:#e9d6f0;padding:7px 14px;border-radius:30px;
  background:rgba(15,10,18,.7);border:1px solid rgba(238,61,240,.4)}
.dot{width:8px;height:8px;border-radius:50%}
.dot.on{background:#36e07a;box-shadow:0 0 10px #36e07a;animation:blink 1.6s infinite}
.dot.off{background:#e0506a;box-shadow:0 0 10px #e0506a}
@keyframes blink{0%,100%{opacity:1}50%{opacity:.35}}

/* ---------- hero ---------- */
.hero{position:relative;min-height:100vh;display:flex;flex-direction:column;align-items:center;
  justify-content:center;text-align:center;padding:120px 5vw 80px;overflow:hidden}
.hero-bg{position:absolute;inset:0;z-index:0;background-size:cover;background-position:center;
  animation:slowzoom 26s ease-in-out infinite alternate}
.hero-bg::after{content:'';position:absolute;inset:0;
  background:linear-gradient(180deg,rgba(8,7,10,.55),rgba(8,7,10,.72) 55%,var(--bg))}
@keyframes slowzoom{from{transform:scale(1)}to{transform:scale(1.12)}}
/* YouTube background video — sized to cover the hero (16:9), no controls. */
.hero-video{position:absolute;inset:0;z-index:1;overflow:hidden;pointer-events:none}
.hero-video iframe{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%) scale(1.45);
  width:100vw;height:56.25vw;min-height:100vh;min-width:177.78vh;border:0;pointer-events:none}
/* dark veil over the video so the logo + text stay readable */
.hero-veil{position:absolute;inset:0;z-index:2;pointer-events:none;
  background:linear-gradient(180deg,rgba(8,7,10,.5),rgba(8,7,10,.62) 55%,var(--bg))}

/* Soft glows via radial-gradient — no blur filter, no per-frame repaint. */
.orb{position:absolute;border-radius:50%;z-index:3;pointer-events:none}
.orb.a{width:620px;height:620px;top:-18%;left:-12%;
  background:radial-gradient(circle,rgba(226,58,208,.45),transparent 68%)}
.orb.b{width:580px;height:580px;bottom:-20%;right:-12%;
  background:radial-gradient(circle,rgba(58,134,232,.42),transparent 68%)}
.hero-inner{position:relative;z-index:5;display:flex;flex-direction:column;align-items:center}
.pill{display:inline-flex;gap:10px;align-items:center;font-size:13px;font-weight:600;letter-spacing:1.5px;
  text-transform:uppercase;color:#f0dcf4;padding:8px 18px;border-radius:30px;margin-bottom:28px;
  background:rgba(15,10,18,.7);border:1px solid rgba(238,61,240,.45)}
.hero-logo{width:min(720px,90vw);filter:drop-shadow(0 24px 60px rgba(226,58,208,.45)) drop-shadow(0 10px 24px rgba(0,0,0,.8));
  animation:rise 1.1s cubic-bezier(.2,.8,.2,1) both,sway 7s ease-in-out 1.1s infinite}
@keyframes rise{from{opacity:0;transform:translateY(40px) scale(.94)}to{opacity:1;transform:none}}
@keyframes sway{0%,100%{transform:rotate(-.6deg)}50%{transform:rotate(.6deg)}}
.hero .lead{margin-top:26px;font-size:clamp(17px,2vw,22px);color:#e2d6ea;max-width:640px;
  text-shadow:0 2px 14px rgba(0,0,0,.7)}
.hero .actions{margin-top:38px;display:flex;gap:16px;flex-wrap:wrap;justify-content:center}
.scroll-cue{position:absolute;bottom:26px;left:50%;transform:translateX(-50%);z-index:5;color:#b9a8c5;
  font-size:12px;letter-spacing:2px;text-transform:uppercase;animation:bob 2s ease-in-out infinite}
@keyframes bob{0%,100%{transform:translate(-50%,0)}50%{transform:translate(-50%,8px)}}

/* ---------- stats ribbon ---------- */
.ribbon{position:relative;z-index:3;background:linear-gradient(90deg,rgba(226,58,208,.12),rgba(58,134,232,.12));
  border-top:1px solid var(--line);border-bottom:1px solid var(--line);display:flex;justify-content:center;
  gap:clamp(28px,6vw,90px);flex-wrap:wrap;padding:28px 5vw}
.ribbon .stat{text-align:center}
.ribbon .n{font-family:'Sora';font-weight:800;font-size:clamp(28px,3.4vw,40px);
  background:var(--grad-text);-webkit-background-clip:text;background-clip:text;color:transparent}
.ribbon .l{font-size:12px;letter-spacing:2px;text-transform:uppercase;color:var(--mut);margin-top:2px}

/* ---------- reveal ---------- */
.reveal{opacity:0;transform:translateY(34px);transition:.7s cubic-bezier(.2,.8,.2,1)}
.reveal.in{opacity:1;transform:none}

/* ---------- feature cards ---------- */
.grid{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:46px}
.card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:30px;
  transition:.28s;position:relative;overflow:hidden}
.card::before{content:'';position:absolute;inset:0;opacity:0;transition:.28s;
  background:linear-gradient(160deg,rgba(238,61,240,.1),rgba(58,134,232,.06))}
.card:hover{transform:translateY(-7px);border-color:rgba(238,61,240,.45)}
.card:hover::before{opacity:1}
.card>*{position:relative}
.card .ic{width:52px;height:52px;border-radius:14px;display:grid;place-items:center;font-size:25px;
  margin-bottom:18px;background:var(--grad);box-shadow:0 8px 24px rgba(226,58,208,.35)}
.card h3{font-size:20px;margin-bottom:8px}
.card p{color:var(--mut);font-size:14.5px}

/* ---------- gallery ---------- */
.gallery{display:grid;grid-template-columns:repeat(4,1fr);gap:14px;margin-top:46px}
.shot{aspect-ratio:3/4;border-radius:16px;overflow:hidden;position:relative;border:1px solid rgba(255,255,255,.06)}
.shot img{width:100%;height:100%;object-fit:cover;transition:.5s}
.shot:hover img{transform:scale(1.08)}
.shot::after{content:'';position:absolute;inset:0;background:linear-gradient(180deg,transparent 55%,rgba(8,7,10,.7))}
.shot{cursor:pointer}

/* ---------- lightbox ---------- */
.lightbox{position:fixed;inset:0;z-index:200;display:none;align-items:center;justify-content:center;
  background:rgba(6,5,8,.93);padding:40px}
body.lb-open{overflow:hidden}
body.lb-open .lightbox{display:flex}
.lb-img{max-width:90vw;max-height:86vh;border-radius:12px;box-shadow:0 30px 80px rgba(0,0,0,.65);
  border:1px solid rgba(238,61,240,.3);animation:lbin .25s ease}
@keyframes lbin{from{opacity:0;transform:scale(.96)}to{opacity:1;transform:none}}
.lb-close{position:fixed;top:20px;right:26px;width:46px;height:46px;border-radius:12px;font-size:24px;line-height:1;
  background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;cursor:pointer;transition:.18s}
.lb-close:hover{background:rgba(238,61,240,.22);border-color:var(--magenta)}
.lb-nav{position:fixed;top:50%;transform:translateY(-50%);width:54px;height:54px;border-radius:50%;font-size:28px;line-height:1;
  background:rgba(255,255,255,.08);border:1px solid var(--line);color:#fff;cursor:pointer;transition:.18s}
.lb-nav:hover{background:rgba(238,61,240,.22);border-color:var(--magenta)}
.lb-prev{left:22px}.lb-next{right:22px}
.lb-count{position:fixed;bottom:24px;left:50%;transform:translateX(-50%);color:#cdbcd6;font-size:13px;letter-spacing:1px}
@media(max-width:640px){.lb-nav{width:42px;height:42px;font-size:22px}.lb-prev{left:10px}.lb-next{right:10px}}

/* ---------- FAQ ---------- */
.faq{max-width:820px;margin:46px auto 0;display:flex;flex-direction:column;gap:12px}
.faq-item{background:var(--panel);border:1px solid var(--line);border-radius:14px;overflow:hidden;transition:border-color .2s}
.faq-item[open]{border-color:rgba(238,61,240,.4)}
.faq-item summary{cursor:pointer;padding:20px 24px;font-family:'Sora';font-weight:600;font-size:17px;color:var(--ink);
  list-style:none;display:flex;justify-content:space-between;align-items:center;gap:16px;transition:color .2s}
.faq-item summary::-webkit-details-marker{display:none}
.faq-item summary::after{content:'+';font-size:26px;line-height:1;color:var(--magenta);transition:transform .25s;font-weight:300}
.faq-item[open] summary::after{transform:rotate(45deg)}
.faq-item summary:hover{color:#fff}
.faq-a{padding:0 24px 22px;color:var(--mut);font-size:15px;line-height:1.7}

/* ---------- CTA band ---------- */
.cta-band{position:relative;z-index:2;margin:40px 5vw 0;max-width:var(--maxw);
  margin-left:auto;margin-right:auto;border-radius:26px;overflow:hidden;text-align:center;padding:70px 5vw;
  background:linear-gradient(120deg,rgba(226,58,208,.18),rgba(58,134,232,.18)),var(--panel);
  border:1px solid rgba(238,61,240,.3)}
.cta-band h2{font-size:clamp(28px,4vw,44px);font-weight:800}
.cta-band .eyebrow{margin-bottom:8px}
.cta-band p{color:#d8cae0;margin:12px auto 28px;max-width:560px;font-size:17px}
.cta-band p strong{color:#fff}
.cta-band .actions{display:flex;gap:16px;justify-content:center;flex-wrap:wrap}
.cta-trust{margin-top:22px;font-size:12.5px;letter-spacing:1.5px;text-transform:uppercase;color:#9a8aa6}

/* ---------- footer ---------- */
.footer{position:relative;z-index:2;margin-top:90px;border-top:1px solid var(--line);
  padding:54px 5vw 36px;display:grid;grid-template-columns:1.4fr 1fr 1fr 1fr;gap:30px;
  max-width:var(--maxw);margin-left:auto;margin-right:auto}
.footer .nav-logo{height:40px;margin-bottom:14px}
.footer p{color:var(--mut);font-size:14px}
.footer h4{color:#fff;font-family:'Sora';font-size:14px;letter-spacing:1px;text-transform:uppercase;margin-bottom:12px}
.footer a{color:var(--mut);text-decoration:none;display:block;padding:5px 0;font-size:14px;transition:.18s}
.footer a:hover{color:#fff}
.footer .socials{display:flex;gap:10px;margin-top:14px}
.footer .socials a{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;font-size:18px;
  background:var(--panel2);border:1px solid var(--line);padding:0}
.footer .socials a:hover{border-color:var(--magenta);transform:translateY(-2px)}
.copyright{max-width:var(--maxw);margin:0 auto;padding:18px 5vw 40px;color:#6f6379;font-size:13px;
  border-top:1px solid var(--line);text-align:center}

/* ---------- sub-page header band ---------- */
.page-head{position:relative;padding:140px 5vw 60px;text-align:center;overflow:hidden}
.page-head::before{content:'';position:absolute;inset:0;z-index:0;
  background:radial-gradient(80% 120% at 50% 0,rgba(226,58,208,.22),transparent 60%)}
.page-head .inner{position:relative;z-index:2;max-width:760px;margin:0 auto}
.page-head h1{font-size:clamp(36px,6vw,68px);font-weight:800}
.page-head h1 .accent{display:inline}
.page-head p{color:var(--mut);font-size:18px;margin-top:14px}

/* ---------- RULES page ---------- */
.rules-layout{display:grid;grid-template-columns:260px 1fr;gap:40px;max-width:var(--maxw);
  margin:0 auto;padding:40px 5vw 60px;align-items:start}
.rules-side{position:sticky;top:90px}
.rules-search{width:100%;padding:13px 16px;border-radius:12px;background:var(--panel);
  border:1px solid var(--line);color:var(--ink);font-size:15px;margin-bottom:18px}
.rules-search:focus{outline:none;border-color:var(--magenta)}
.jump-nav a{display:flex;align-items:center;gap:10px;color:var(--mut);text-decoration:none;
  padding:10px 12px;border-radius:10px;font-size:14.5px;transition:.16s}
.jump-nav a:hover,.jump-nav a.active{color:#fff;background:rgba(238,61,240,.12)}
.rule-cat{margin-bottom:26px;scroll-margin-top:90px}
.rule-cat-head{display:flex;align-items:center;gap:12px;width:100%;text-align:left;cursor:pointer;
  background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:18px 22px;
  color:var(--ink);font-family:'Sora';font-weight:700;font-size:20px;transition:.2s}
.rule-cat-head:hover{border-color:rgba(238,61,240,.4)}
.rule-cat-head .ic{font-size:22px}
.rule-cat-head .chev{margin-left:auto;transition:.25s;color:var(--mut)}
.rule-cat.collapsed .chev{transform:rotate(-90deg)}
.rule-cat-body{padding:10px 0 0}
.rule-cat.collapsed .rule-cat-body{display:none}
.rule-item{background:var(--panel);border:1px solid var(--line);border-radius:14px;padding:22px 24px;
  margin-top:12px;transition:.2s}
.rule-item:hover{border-color:rgba(238,61,240,.32)}
.rule-item h3{font-size:17px;margin-bottom:8px;color:#fff}
.rule-item .body{color:#c9bcd4;font-size:15px}
.rule-item .body p{margin:0 0 10px}
.rule-item .body ul,.rule-item .body ol{margin:6px 0 12px 22px}
.rule-item .body li{margin:4px 0}
.rule-item .body a{color:var(--cyan)}
.rule-item .body table{width:100%;border-collapse:collapse;margin:8px 0 4px;font-size:14px}
.rule-item .body th,.rule-item .body td{border:1px solid var(--line);padding:10px 12px;text-align:left}
.rule-item .body th{background:rgba(238,61,240,.12);color:#fff}
.rule-hidden{display:none!important}
.no-results{color:var(--mut);padding:30px;text-align:center;display:none}

/* ---------- STAFF page ---------- */
.staff-group{max-width:var(--maxw);margin:0 auto;padding:10px 5vw 40px}
.staff-group h2{font-size:24px;font-weight:800;margin:34px 0 18px;display:flex;align-items:center;gap:12px}
.staff-group h2::after{content:'';flex:1;height:1px;background:var(--line)}
.staff-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.staff-card{background:var(--panel);border:1px solid var(--line);border-radius:18px;padding:26px 20px;
  text-align:center;transition:.26s}
.staff-card:hover{transform:translateY(-6px);border-color:rgba(238,61,240,.45)}
.staff-av{width:92px;height:92px;border-radius:50%;margin:0 auto 16px;object-fit:cover;
  border:3px solid transparent;background:var(--grad);padding:3px}
.staff-av-fallback{width:92px;height:92px;border-radius:50%;margin:0 auto 16px;display:grid;place-items:center;
  font-family:'Sora';font-weight:800;font-size:32px;color:#fff;background:var(--grad)}
.staff-card .name{font-family:'Sora';font-weight:700;font-size:18px}
.staff-card .rank{color:var(--magenta);font-size:13.5px;font-weight:600;margin-top:3px}
.staff-card .dc{color:var(--mut);font-size:13px;margin-top:8px}

/* ---------- APPLY page ---------- */
.apply-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px;max-width:980px;margin:0 auto;padding:10px 5vw 40px}
.apply-card{display:flex;gap:18px;align-items:flex-start;background:var(--panel);border:1px solid var(--line);
  border-radius:18px;padding:26px;transition:.26s}
.apply-card:hover{transform:translateY(-5px);border-color:rgba(238,61,240,.45)}
.apply-card .ic{flex:none;width:56px;height:56px;border-radius:14px;display:grid;place-items:center;
  font-size:26px;background:var(--grad);box-shadow:0 8px 24px rgba(226,58,208,.35)}
.apply-card .ic svg{width:28px;height:28px}
.apply-card .txt{flex:1}
.apply-card h3{font-size:19px;margin-bottom:6px}
.apply-card p{color:var(--mut);font-size:14.5px;margin-bottom:14px}

/* ---------- DISCORD page ---------- */
.discord-hero{max-width:760px;margin:0 auto;padding:20px 5vw 80px;text-align:center}
.discord-card{background:linear-gradient(160deg,rgba(88,101,242,.16),rgba(226,58,208,.1)),var(--panel);
  border:1px solid rgba(88,101,242,.4);border-radius:24px;padding:48px 36px;box-shadow:var(--shadow)}
.discord-card .big{font-size:clamp(28px,4vw,40px);font-weight:800;font-family:'Sora'}
.discord-icon{width:84px;height:84px;border-radius:24px;margin:0 auto 18px;display:block;
  border:1px solid var(--line);box-shadow:0 10px 30px rgba(0,0,0,.4)}
.discord-stats{display:flex;justify-content:center;gap:50px;margin:28px 0}
.discord-stats .n{font-family:'Sora';font-weight:800;font-size:34px;color:#fff;
  display:flex;align-items:center;justify-content:center;gap:9px}
.status-dot{width:11px;height:11px;border-radius:50%;display:inline-block}
.status-dot.online{background:#36e07a;box-shadow:0 0 10px #36e07a;animation:blink 1.6s infinite}
.discord-stats .l{color:var(--mut);font-size:13px;letter-spacing:1px;text-transform:uppercase}
.btn-discord{background:#5865F2;color:#fff;box-shadow:0 10px 30px rgba(88,101,242,.5)}
.btn-discord:hover{transform:translateY(-3px);background:#4752d4}

/* ---------- responsive ---------- */
@media(max-width:980px){
  .grid,.gallery,.staff-grid{grid-template-columns:repeat(2,1fr)}
  .footer{grid-template-columns:1fr 1fr}
  .rules-layout{grid-template-columns:1fr}
  .rules-side{position:static}
  .apply-grid{grid-template-columns:1fr}
}
@media(max-width:860px){
  .nav-toggle{display:flex}
  .nav-pill{position:fixed;top:74px;left:12px;right:12px;transform:none;flex-direction:column;
    align-items:stretch;gap:4px;border-radius:18px;padding:10px;display:none}
  .nav-pill.open{display:flex}
  .nav-pill a{padding:13px 18px;border-radius:12px;font-size:16px}
}
@media(max-width:720px){
  .status-pill .lbl{display:none}
  .gallery{grid-template-columns:1fr 1fr}
  .footer{grid-template-columns:1fr}
}
