/* ==========================================================================
   PROJECT LAZARUS - shared UI polish and motion layer
   Loaded after page styles so it can enhance every main-site page without
   refactoring each inline stylesheet.
   ========================================================================== */

:root{
  --fx-ease:cubic-bezier(.2,.8,.2,1);
  --fx-fast:180ms;
  --fx-med:320ms;
  --fx-slow:720ms;
}

::selection{background:rgba(157,255,43,.28);color:var(--bone)}

[hidden]{display:none!important}

a:focus-visible,
button:focus-visible,
summary:focus-visible,
input:focus-visible,
textarea:focus-visible,
select:focus-visible{
  outline:3px solid rgba(157,255,43,.72);
  outline-offset:3px;
}

.laz-ambient,
.laz-spotlight{
  position:fixed;
  inset:0;
  pointer-events:none;
  z-index:0;
}

.laz-ambient{
  overflow:hidden;
  opacity:.82;
  mix-blend-mode:screen;
}

.laz-ambient__glow,
.laz-ambient__grid,
.laz-ambient__sweep{
  position:absolute;
  inset:0;
}

.laz-ambient__glow{
  background:
    radial-gradient(circle at 16% 22%,rgba(157,255,43,.10),transparent 26%),
    radial-gradient(circle at 82% 18%,rgba(230,184,74,.08),transparent 24%),
    radial-gradient(circle at 52% 92%,rgba(157,255,43,.08),transparent 30%);
  filter:blur(14px);
}

.laz-ambient__grid{
  opacity:.28;
  background-image:
    linear-gradient(rgba(157,255,43,.07) 1px,transparent 1px),
    linear-gradient(90deg,rgba(157,255,43,.06) 1px,transparent 1px);
  background-size:96px 96px;
  mask-image:radial-gradient(ellipse at center,#000 0%,transparent 78%);
  -webkit-mask-image:radial-gradient(ellipse at center,#000 0%,transparent 78%);
  transform:perspective(800px) rotateX(58deg) translateY(18%);
  transform-origin:50% 100%;
}

.laz-ambient__sweep{
  opacity:.35;
  background:linear-gradient(110deg,transparent 0 42%,rgba(157,255,43,.16) 48%,transparent 55% 100%);
  transform:translateX(-120%);
  animation:lazSweep 9s var(--fx-ease) infinite;
}

.laz-spotlight{
  opacity:.46;
  background:radial-gradient(circle 320px at var(--spot-x,50%) var(--spot-y,30%),rgba(157,255,43,.10),transparent 68%);
  transition:opacity var(--fx-med) ease;
}

.laz-reveal{
  opacity:0;
  transform:translateY(22px);
  transition:
    opacity var(--fx-slow) var(--fx-ease),
    transform var(--fx-slow) var(--fx-ease),
    border-color var(--fx-med) ease,
    box-shadow var(--fx-med) ease,
    background var(--fx-med) ease;
}

.laz-reveal.is-visible{
  opacity:1;
  transform:none;
}

.btn,
.nav__cta,
.nav-account__trigger,
.server__btn,
.gm-card__cta,
.promo__cta,
.link-out a,
.discord-btn,
.sa-btn,
.cta a{
  position:relative;
  overflow:hidden;
  will-change:transform;
}

.btn::after,
.nav__cta::after,
.nav-account__trigger::after,
.server__btn--connect::after,
.gm-card__cta.is-primary::after,
.promo__cta::after,
.link-out a::after,
.discord-btn::after,
.cta a::after{
  content:"";
  position:absolute;
  inset:0 auto 0 0;
  width:42%;
  pointer-events:none;
  background:linear-gradient(100deg,transparent,rgba(255,255,255,.48),transparent);
  transform:translateX(-180%) skewX(-18deg);
  transition:transform .7s var(--fx-ease);
}

.btn:hover::after,
.nav__cta:hover::after,
.nav-account__trigger:hover::after,
.server__btn--connect:hover::after,
.gm-card__cta.is-primary:hover::after,
.promo__cta:hover::after,
.link-out a:hover::after,
.discord-btn:hover::after,
.cta a:hover::after{
  transform:translateX(320%) skewX(-18deg);
}

/* Shared homepage nav treatment for every main-site page. */
.nav{
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:50;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  padding:22px 40px;
  background:linear-gradient(180deg,rgba(10,13,10,.94) 0%,rgba(10,13,10,.72) 70%,rgba(10,13,10,0) 100%);
  border-bottom:0;
  box-shadow:0 16px 48px rgba(0,0,0,.22);
  backdrop-filter:blur(8px);
}

.nav::before{
  content:"";
  position:absolute;
  left:0;
  right:0;
  bottom:0;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(157,255,43,.48),rgba(230,184,74,.26),transparent);
  opacity:.75;
  pointer-events:none;
}

.nav__brand{
  display:flex;
  align-items:center;
  gap:12px;
  flex:0 0 auto;
}

.nav__brand img,
.nav > a:first-child img{
  height:54px;
  width:auto;
  animation:navLogoPulse 2.8s ease-in-out infinite;
  transform-origin:center;
}

.nav__links{
  display:flex;
  align-items:stretch;
  justify-content:center;
  gap:22px;
  flex:1 1 auto;
  flex-wrap:wrap;
}

.nav__links > a,
.nav__more > button{
  display:inline-flex;
  align-items:center;
  min-height:36px;
  padding:10px 0;
  border:0;
  border-bottom:2px solid transparent;
  background:none;
  color:var(--bone-2);
  cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:600;
  letter-spacing:.1em;
  line-height:1;
  text-transform:uppercase;
  white-space:nowrap;
}

.nav__links > a:hover,
.nav__links > a.is-active,
.nav__more > button:hover{
  color:var(--green);
  border-color:var(--green);
}

.nav__more{
  position:relative;
  display:inline-flex;
  align-items:stretch;
}

.nav__more > button::after{
  content:"";
  width:6px;
  height:6px;
  margin-left:8px;
  border-right:1.5px solid currentColor;
  border-bottom:1.5px solid currentColor;
  transform:rotate(45deg) translateY(-2px);
  opacity:.72;
}

.nav__more::after{
  content:"";
  position:absolute;
  left:0;
  right:0;
  top:100%;
  height:18px;
}

.nav__more-panel{
  position:absolute;
  top:100%;
  right:0;
  min-width:220px;
  display:none;
  margin-top:12px;
  padding:8px;
  background:rgba(10,13,10,.96);
  border:1px solid var(--hair-2);
  box-shadow:0 12px 40px rgba(0,0,0,.6);
}

.nav__more:hover .nav__more-panel,
.nav__more:focus-within .nav__more-panel{
  display:block;
}

.nav__more-panel a{
  display:block;
  padding:10px 12px;
  border-left:2px solid transparent;
  color:var(--bone-2);
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  letter-spacing:.12em;
  text-transform:uppercase;
}

.nav__more-panel a:hover,
.nav__more-panel a.is-active{
  color:var(--green);
  border-color:var(--green);
  background:rgba(157,255,43,.06);
}

.nav__toggle{
  display:none;
}

.nav__cta{
  display:inline-flex;
  align-items:center;
  gap:8px;
  min-height:44px;
  padding:12px 20px;
  border-radius:2px;
  background:var(--green);
  color:#0a0d0a;
  box-shadow:0 0 0 1px rgba(157,255,43,.5),0 8px 24px rgba(157,255,43,.15);
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:800;
  letter-spacing:.1em;
  line-height:1;
  text-transform:uppercase;
  transition:transform var(--fx-fast) ease,box-shadow var(--fx-fast) ease;
}

.nav__cta:hover{
  transform:translateY(-1px);
  box-shadow:0 0 0 1px var(--green),0 10px 30px rgba(157,255,43,.35);
}

.nav-account{
  position:relative;
  z-index:52;
  flex:0 0 auto;
}

.nav-account__trigger{
  display:inline-flex;
  align-items:center;
  gap:10px;
  min-height:44px;
  padding:8px 14px;
  border:1px solid rgba(157,255,43,.55);
  border-radius:2px;
  background:var(--green);
  color:#0a0d0a;
  cursor:pointer;
  box-shadow:0 0 0 1px rgba(157,255,43,.45),0 8px 24px rgba(157,255,43,.16);
  transition:transform var(--fx-fast) ease,box-shadow var(--fx-fast) ease;
}

.nav-account__trigger:hover,
.nav-account__trigger:focus-visible{
  transform:translateY(-1px);
  box-shadow:0 0 0 1px var(--green),0 12px 34px rgba(157,255,43,.36);
}

.nav-account__avatar{
  width:30px;
  height:30px;
  border:1px solid rgba(10,13,10,.45);
  border-radius:50%;
  overflow:hidden;
  background:rgba(10,13,10,.18);
  flex:0 0 auto;
}

.nav-account__avatar img{
  width:100%;
  height:100%;
  object-fit:cover;
}

.nav-account__mark{
  width:9px;
  height:9px;
  border-radius:50%;
  background:#0a0d0a;
  box-shadow:0 0 0 0 rgba(10,13,10,.6);
  animation:pulse 1.8s ease-out infinite;
  flex:0 0 auto;
}

.nav-account.is-signed-in.has-avatar .nav-account__mark{
  display:none;
}

.nav-account__text{
  display:flex;
  flex-direction:column;
  align-items:flex-start;
  gap:1px;
  min-width:0;
}

.nav-account__label{
  max-width:132px;
  overflow:hidden;
  color:#0a0d0a;
  font-family:'Barlow Condensed',sans-serif;
  font-size:14px;
  font-weight:800;
  letter-spacing:.1em;
  line-height:1;
  text-overflow:ellipsis;
  text-transform:uppercase;
  white-space:nowrap;
}

.nav-account__sub{
  color:#0a0d0a;
  font-family:'Barlow Condensed',sans-serif;
  font-size:10px;
  font-weight:700;
  letter-spacing:.18em;
  line-height:1;
  opacity:.72;
  text-transform:uppercase;
}

.nav-account__chev{
  width:8px;
  height:8px;
  border-right:2px solid currentColor;
  border-bottom:2px solid currentColor;
  opacity:.75;
  transform:rotate(45deg) translateY(-2px);
  flex:0 0 auto;
}

.nav-account__trigger[aria-expanded="true"] .nav-account__chev{
  transform:rotate(225deg) translate(-1px,-1px);
}

.account-drawer{
  position:absolute;
  top:calc(100% + 14px);
  right:0;
  width:380px;
  max-width:calc(100vw - 32px);
  padding:18px;
  border:1px solid rgba(157,255,43,.32);
  border-radius:4px;
  background:rgba(10,13,10,.96);
  box-shadow:0 24px 70px rgba(0,0,0,.72);
  backdrop-filter:blur(14px);
}

.account-drawer::before{
  content:"";
  position:absolute;
  top:0;
  left:0;
  right:0;
  height:3px;
  background:linear-gradient(90deg,var(--green) 0%,var(--green) 58%,transparent 58%);
}

.account-drawer__head{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  margin-bottom:12px;
}

.account-drawer__kicker{
  display:block;
  margin-bottom:5px;
  color:var(--green);
  font-family:'Barlow Condensed',sans-serif;
  font-size:11px;
  font-weight:800;
  letter-spacing:.24em;
  text-transform:uppercase;
}

.account-drawer__head strong{
  display:block;
  color:var(--bone);
  font-family:'Barlow Condensed',sans-serif;
  font-size:24px;
  letter-spacing:.06em;
  line-height:1;
  text-transform:uppercase;
}

.account-drawer__close{
  position:relative;
  width:34px;
  height:34px;
  border:1px solid var(--hair-2);
  border-radius:2px;
  background:rgba(255,255,255,.04);
  cursor:pointer;
  flex:0 0 auto;
}

.account-drawer__close::before,
.account-drawer__close::after{
  content:"";
  position:absolute;
  left:9px;
  right:9px;
  top:15px;
  height:2px;
  background:var(--bone);
}

.account-drawer__close::before{transform:rotate(45deg)}
.account-drawer__close::after{transform:rotate(-45deg)}
.account-drawer__close:hover{border-color:var(--green);background:rgba(157,255,43,.08)}

.account-drawer__body{
  margin-bottom:14px;
  color:var(--bone-2);
  font-size:14px;
  line-height:1.55;
}

.account-drawer__primary,
.account-drawer__signout{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  width:100%;
  min-height:44px;
  border:1px solid var(--green);
  border-radius:2px;
  background:var(--green);
  color:#0a0d0a;
  cursor:pointer;
  font-family:'Barlow Condensed',sans-serif;
  font-size:15px;
  font-weight:800;
  letter-spacing:.12em;
  text-transform:uppercase;
  transition:transform var(--fx-fast) ease,box-shadow var(--fx-fast) ease;
}

.account-drawer__primary:hover,
.account-drawer__signout:hover{
  transform:translateY(-1px);
  box-shadow:0 12px 30px rgba(157,255,43,.22);
}

.account-drawer__links{
  display:grid;
  gap:8px;
  margin-top:14px;
}

.account-drawer__links a{
  display:block;
  padding:12px 13px;
  border:1px solid rgba(255,255,255,.08);
  border-radius:2px;
  background:rgba(255,255,255,.03);
  transition:border-color var(--fx-fast) ease,background var(--fx-fast) ease;
}

.account-drawer__links a:hover{
  border-color:rgba(157,255,43,.42);
  background:rgba(157,255,43,.07);
}

.account-drawer__links span{
  display:block;
  color:var(--bone);
  font-family:'Barlow Condensed',sans-serif;
  font-size:15px;
  font-weight:800;
  letter-spacing:.1em;
  text-transform:uppercase;
}

.account-drawer__links small{
  display:block;
  margin-top:3px;
  color:var(--bone-2);
  font-size:12px;
  line-height:1.45;
}

.account-drawer__signout{
  margin-top:12px;
  background:transparent;
  color:var(--bone);
  border-color:var(--hair-2);
}

.account-drawer__signout:hover{
  border-color:var(--bone);
  background:rgba(255,255,255,.06);
  box-shadow:none;
}

.page-hero,
.hero,
.sa-hero,
.cs,
.hero404{
  isolation:isolate;
}

.page-hero > .wrap::after,
.cs::after,
.hero404::after{
  content:"";
  position:absolute;
  right:0;
  bottom:18px;
  width:min(38vw,420px);
  height:1px;
  pointer-events:none;
  background:linear-gradient(90deg,transparent,rgba(157,255,43,.9));
  box-shadow:0 0 22px rgba(157,255,43,.34);
  opacity:.72;
}

.page-hero h1,
.cs__title,
.hero404__num,
.hero404__title{
  text-shadow:
    0 10px 28px rgba(0,0,0,.62),
    0 0 34px rgba(157,255,43,.12);
}

.page-hero .kicker,
.section-kicker,
.cs__kicker,
.hero404__kicker,
.sa-hero__kicker{
  text-shadow:0 0 18px rgba(157,255,43,.28);
}

.livepanel,
.wipe-card,
.server,
.gm-card,
.pillar,
.promo,
.rule-card,
.faq details,
.box,
.sa-card,
.cs__feat,
.account-drawer{
  transition:
    transform var(--fx-med) var(--fx-ease),
    border-color var(--fx-med) ease,
    box-shadow var(--fx-med) ease,
    background var(--fx-med) ease;
}

.livepanel:hover,
.wipe-card:hover,
.server:hover,
.pillar:hover,
.rule-card:hover,
.faq details:hover,
.box:hover,
.sa-card:hover,
.cs__feat:hover{
  transform:translateY(-3px);
  border-color:rgba(157,255,43,.36);
  box-shadow:0 18px 48px rgba(0,0,0,.32),0 0 0 1px rgba(157,255,43,.10);
}

.server--life:hover,
.wipe-card.is-life:hover{
  border-color:rgba(230,184,74,.42);
  box-shadow:0 18px 48px rgba(0,0,0,.32),0 0 0 1px rgba(230,184,74,.12);
}

.gm-card__bg,
.promo__bg,
.community__bg,
.sa-hero__bg{
  will-change:transform;
}

.gm-card:hover .gm-card__bg{
  transform:scale(1.045);
  transition:transform .9s var(--fx-ease);
}

.faq details[open] .faq-body{
  animation:lazFaqIn .28s var(--fx-ease) both;
}

.panel.is-active{
  animation:lazPanelIn .34s var(--fx-ease) both;
}

.tab,
.faq-nav a,
.nav__links a,
.nav__more button{
  transition:
    color var(--fx-fast) ease,
    border-color var(--fx-fast) ease,
    background var(--fx-fast) ease,
    transform var(--fx-fast) ease;
}

.tab:hover,
.faq-nav a:hover,
.nav__links a:hover,
.nav__more button:hover{
  transform:translateY(-1px);
}

.hero__eyebrow,
.livepanel,
.hero__logo{
  animation:lazHeroIn .8s var(--fx-ease) both;
}

.hero__logo{animation-delay:.08s}
.livepanel{animation-delay:.18s}

.cs__feat:nth-child(2),
.pillar:nth-child(2),
.rule-card:nth-child(2){transition-delay:40ms}

.cs__feat:nth-child(3),
.pillar:nth-child(3),
.rule-card:nth-child(3){transition-delay:80ms}

.pillar:nth-child(4){transition-delay:120ms}

@keyframes lazSweep{
  0%,72%{transform:translateX(-120%)}
  100%{transform:translateX(120%)}
}

@keyframes lazFaqIn{
  from{opacity:0;transform:translateY(-6px)}
  to{opacity:1;transform:none}
}

@keyframes lazPanelIn{
  from{opacity:0;transform:translateY(10px)}
  to{opacity:1;transform:none}
}

@keyframes lazHeroIn{
  from{opacity:0;transform:translateY(18px)}
  to{opacity:1;transform:none}
}

@keyframes navLogoPulse{
  0%,100%{filter:drop-shadow(0 0 4px rgba(157,255,43,.15));transform:scale(1)}
  50%{filter:drop-shadow(0 0 22px rgba(157,255,43,.75));transform:scale(1.03)}
}

@keyframes pulse{
  0%{box-shadow:0 0 0 0 rgba(10,13,10,.6)}
  100%{box-shadow:0 0 0 10px rgba(10,13,10,0)}
}

@media (hover:none){
  .livepanel:hover,
  .wipe-card:hover,
  .server:hover,
  .pillar:hover,
  .rule-card:hover,
  .faq details:hover,
  .box:hover,
  .sa-card:hover,
  .cs__feat:hover,
  .tab:hover,
  .faq-nav a:hover,
  .nav__links a:hover,
  .nav__more button:hover{
    transform:none;
  }
}

@media (max-width:1060px){
  .nav{
    padding:18px 20px;
  }

  .nav__brand img,
  .nav > a:first-child img{
    height:44px;
  }

  .nav__toggle{
    display:inline-flex;
    flex:0 0 44px;
    width:44px;
    height:44px;
    margin-left:auto;
    margin-right:12px;
    padding:0 11px;
    flex-direction:column;
    align-items:center;
    justify-content:center;
    gap:5px;
    border:1px solid var(--hair-2);
    border-radius:3px;
    background:rgba(255,255,255,.02);
    cursor:pointer;
  }

  .nav__toggle span{
    display:block;
    width:22px;
    height:2px;
    border-radius:1px;
    background:var(--bone);
    transition:transform var(--fx-fast) ease,opacity var(--fx-fast) ease;
  }

  .nav--open .nav__toggle span:nth-child(1){transform:translateY(7px) rotate(45deg)}
  .nav--open .nav__toggle span:nth-child(2){opacity:0}
  .nav--open .nav__toggle span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

  .nav__links{
    position:absolute;
    top:100%;
    left:0;
    right:0;
    display:none;
    flex-direction:column;
    align-items:stretch;
    gap:0;
    max-height:calc(100vh - 72px);
    overflow-y:auto;
    padding:6px 20px 14px;
    border-top:1px solid var(--hair);
    border-bottom:1px solid var(--hair-2);
    background:rgba(10,13,10,.98);
    box-shadow:0 24px 50px rgba(0,0,0,.55);
  }

  .nav--open .nav__links{
    display:flex;
  }

  .nav__links > a,
  .nav__more > button{
    width:100%;
    min-height:44px;
    justify-content:flex-start;
    padding:14px 2px;
    border-top:0;
    border-bottom:1px solid rgba(255,255,255,.06);
    font-size:16px;
  }

  .nav__more{
    position:static;
    display:block;
    width:100%;
  }

  .nav__more::after{
    display:none;
  }

  .nav__more > button{
    cursor:default;
  }

  .nav__more-panel{
    position:static;
    display:block;
    min-width:0;
    margin:0;
    padding:0 0 0 14px;
    border:0;
    background:transparent;
    box-shadow:none;
  }

  .nav__more-panel a{
    padding:12px 2px;
    border-left:0;
    border-bottom:1px solid rgba(255,255,255,.05);
    font-size:15px;
  }
}

@media (max-width:640px){
  .nav-account__trigger{
    min-height:42px;
    padding:8px 12px;
  }

  .nav-account__label{
    max-width:94px;
    font-size:13px;
  }

  .nav-account__sub{
    display:none;
  }

  .nav-account__avatar{
    width:28px;
    height:28px;
  }

  .account-drawer{
    position:fixed;
    top:76px;
    left:16px;
    right:16px;
    width:auto;
    max-width:none;
  }

  .page-hero > .wrap::after,
  .cs::after,
  .hero404::after{
    width:58vw;
    bottom:0;
  }

  .laz-ambient__grid{
    background-size:64px 64px;
    opacity:.18;
  }
}

@media (max-width:420px){
  .nav-account__label{
    max-width:72px;
  }

  .account-drawer{
    left:12px;
    right:12px;
    padding:16px;
  }

  .account-drawer__head strong{
    font-size:22px;
  }
}

@media (prefers-reduced-motion:reduce){
  html{scroll-behavior:auto}

  .laz-reveal,
  .laz-reveal.is-visible{
    opacity:1;
    transform:none;
    transition:none;
  }

  .laz-ambient__sweep,
  .laz-spotlight{
    display:none;
  }

  .hero__particles::before,
  .hero__particles::after,
  .hero__fog,
  .hero__logo,
  .hero__eyebrow,
  .hero__eyebrow .pulse,
  .hero__scroll::after,
  .ticker__track,
  .nav__brand img,
  .nav-account__mark,
  .livepanel,
  .sa-hero__bg,
  .sa-hero__particles span,
  .sa-hero__kicker,
  .sa-hero__title,
  .sa-hero__lede,
  .sa-hero__meta,
  .sa-card,
  .sa-btn::after,
  .cs__kicker::before,
  .panel.is-active,
  .faq details[open] .faq-body{
    animation:none!important;
  }

  .hero__bg{transform:scale(1.04)!important}

  .btn,
  .nav__cta,
  .nav-account__trigger,
  .server__btn,
  .gm-card__cta,
  .promo__cta,
  .link-out a,
  .discord-btn,
  .cta a,
  .livepanel,
  .wipe-card,
  .server,
  .gm-card,
  .pillar,
  .promo,
  .rule-card,
  .faq details,
  .box,
  .sa-card,
  .cs__feat{
    transition:none!important;
  }
}
