:root{
  --bg0:#070812;
  --bg1:#090a16;
  --text:#f5f6ff;
  --muted: rgba(245,246,255,.72);

  --p1:#ff2d8d;
  --p2:#7c3cff;
  --p3:#2de2ff;
  --grad: linear-gradient(135deg,var(--p1),var(--p2) 55%,var(--p3));

  --card: rgba(255,255,255,.06);
  --stroke: rgba(255,255,255,.12);
  --shadow: 0 22px 80px rgba(0,0,0,.58);

  --r: 18px;
  --r2: 28px;
  --max: 1120px;
}

*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family: Manrope, system-ui, -apple-system, Segoe UI, Roboto, Arial, sans-serif;
  color: var(--text);
  background: linear-gradient(180deg, var(--bg0), var(--bg1));
  overflow-x:hidden;
}
a{color:inherit}
img{max-width:100%;height:auto;display:block}

.container{width:min(var(--max), calc(100% - 40px)); margin-inline:auto;}

.skip{position:absolute;left:-999px;top:auto;width:1px;height:1px;overflow:hidden;}
.skip:focus{left:16px;top:16px;width:auto;height:auto;padding:10px 14px;background:#111;border:1px solid var(--stroke);border-radius:12px;z-index:9999;}

/* ambient */
.ambient{position:fixed;inset:0;z-index:-2;pointer-events:none}
.orb{
  position:absolute; width:520px; height:520px; border-radius:50%;
  filter: blur(28px);
  opacity:.35;
  animation: drift 10s ease-in-out infinite;
}
.o1{left:-160px; top:-180px; background: radial-gradient(circle at 30% 30%, rgba(255,45,141,.9), transparent 60%);}
.o2{right:-220px; top:40px; width:640px;height:640px; opacity:.28; animation-duration: 12.5s;
    background: radial-gradient(circle at 35% 35%, rgba(45,226,255,.85), transparent 60%);}
.o3{left:18%; bottom:-340px; width:760px;height:760px; opacity:.22; animation-duration: 14.5s;
    background: radial-gradient(circle at 50% 50%, rgba(124,60,255,.85), transparent 60%);}
@keyframes drift{
  0%,100%{transform: translate(0,0) scale(1)}
  50%{transform: translate(30px,-18px) scale(1.04)}
}
.grid{
  position:absolute;inset:-40%;
  background:
    linear-gradient(to right, rgba(255,255,255,.05) 1px, transparent 1px) 0 0/56px 56px,
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px) 0 0/56px 56px;
  transform: rotate(-8deg);
  opacity:.14;
}
.grain{
  position:absolute; inset:0; opacity:.09;
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='240' height='240'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='.9' numOctaves='3' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='240' height='240' filter='url(%23n)' opacity='.55'/%3E%3C/svg%3E");
}

/* header */
.header{
  position:sticky;top:0;z-index:50;
  backdrop-filter: blur(12px);
  background: rgba(8,9,18,.62);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.header-inner{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:14px 0}

.brand{display:flex;align-items:center;gap:12px;text-decoration:none}
.brand-logo{
  width:42px;height:42px;border-radius:14px;
  background: rgba(255,255,255,.05);
  border:1px solid rgba(255,255,255,.12);
  padding:6px;
}
.brand-text{display:flex;flex-direction:column;line-height:1.1}
.brand-name{font-family:Sora, Manrope, sans-serif; font-weight:800; letter-spacing:.2px}
.brand-tag{font-size:12px;color: var(--muted); margin-top:2px; font-weight:700}

.nav{display:flex;align-items:center;gap:18px}
.nav a{
  text-decoration:none;
  color: rgba(245,246,255,.84);
  font-weight:800;
  font-size:14px;
  padding:10px 10px;
  border-radius: 12px;
  transition: .2s ease;
}
.nav a:hover{background: rgba(255,255,255,.06)}
.nav a.active{background: rgba(255,45,141,.12); box-shadow: inset 0 0 0 1px rgba(255,45,141,.22)}

.nav-toggle{
  display:none;
  width:44px;height:44px;border-radius:14px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.05);
  cursor:pointer;
}
.nav-toggle span{display:block;width:18px;height:2px;margin:4px auto;background: rgba(245,246,255,.85);border-radius:2px}

/* buttons */
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  padding:12px 16px;border-radius:14px;
  border:1px solid rgba(255,255,255,.14);
  background: linear-gradient(135deg, rgba(255,45,141,.28), rgba(124,60,255,.22));
  box-shadow: var(--shadow);
  text-decoration:none;
  font-weight:900;
  letter-spacing:.2px;
  transition: transform .15s ease, filter .15s ease;
}
.btn:hover{transform: translateY(-1px); filter: brightness(1.06)}
.btn:active{transform: translateY(0)}
.btn-ghost{background: rgba(255,255,255,.06); box-shadow:none}
.btn-small{padding:10px 14px; font-size:13px}

/* type */
h1,h2,h3{margin:0}
h1{
  font-family:Sora, Manrope, sans-serif;
  font-size: clamp(36px, 4.4vw, 64px);
  line-height:1.02;
  letter-spacing:-.9px;
}
h2{
  font-family:Sora, Manrope, sans-serif;
  font-size: clamp(26px, 3vw, 40px);
  line-height:1.12;
  letter-spacing:-.5px;
}
h3{font-size:18px; line-height:1.2; font-weight:900}
p{margin:0; color: rgba(245,246,255,.82); line-height:1.65}

.grad{background: var(--grad); -webkit-background-clip:text; background-clip:text; color:transparent;}
.lead{margin-top:14px; max-width: 62ch; font-size:16px}

/* hero */
.hero{position:relative; padding: 54px 0 0}
.hero-inner{display:grid; grid-template-columns: 1.2fr 1fr; gap:22px; align-items:start; padding-bottom: 28px;}
.pill-row{display:flex; gap:8px; flex-wrap:wrap; margin-bottom: 12px}
.pill{
  display:inline-flex; align-items:center; gap:8px;
  padding:8px 12px; border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  font-weight:900; font-size:12px;
}
.pill-soft{background: rgba(255,45,141,.10); border-color: rgba(255,45,141,.16)}
.hero-cta{display:flex; gap:12px; flex-wrap:wrap; margin-top: 18px}

.hero-mini{
  margin-top: 18px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:10px;
}
.mini{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:12px;
}
.mini-title{font-weight:900}
.mini-text{margin-top:4px; font-size:12px; color: var(--muted); font-weight:700; line-height:1.4}

/* panel */
.panel{
  border-radius: 30px;
  border:1px solid rgba(255,255,255,.12);
  background: linear-gradient(180deg, rgba(255,255,255,.09), rgba(255,255,255,.04));
  box-shadow: var(--shadow);
  padding:16px;
  position:relative;
  overflow:hidden;
}
.panel-glow::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(520px 320px at 0% 0%, rgba(255,45,141,.18), transparent 60%),
    radial-gradient(520px 320px at 110% 40%, rgba(45,226,255,.14), transparent 60%);
  opacity:.9;
  pointer-events:none;
}
.panel > *{position:relative; z-index:1}

.panel-top{display:flex; align-items:center; gap:12px; justify-content:space-between; flex-wrap:wrap}
.signal{
  width:14px;height:14px;border-radius:50%;
  background: linear-gradient(135deg, var(--p3), var(--p1));
  box-shadow: 0 0 0 6px rgba(45,226,255,.10), 0 0 30px rgba(255,45,141,.22);
}
.panel-title{font-weight:900}
.panel-sub{font-size:12px;color: var(--muted); font-weight:700; margin-top:2px}
.chip{
  font-size:12px; font-weight:900;
  padding:6px 10px; border-radius:999px;
  background: rgba(45,226,255,.10);
  border:1px solid rgba(45,226,255,.18);
}

.snap{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:10px;
}
.snap-item{
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(10,10,18,.32);
  padding:12px;
}
.snap-label{font-size:12px;color: var(--muted); font-weight:900}
.snap-value{margin-top:6px; font-size:26px; font-weight:900}

.panel-actions{
  margin-top: 12px;
  padding-top: 12px;
  border-top: 1px solid rgba(255,255,255,.10);
  display:flex; align-items:center; gap:10px; flex-wrap:wrap;
  color: var(--muted);
  font-size:13px;
}
.link{color: rgba(245,246,255,.88); text-decoration:none; font-weight:900}
.link:hover{text-decoration:underline}
.dot{opacity:.5}

/* stack */
.stack{margin-top:12px; display:grid; gap:10px}
.stack-card{
  border-radius: 24px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:14px;
  display:flex;
  gap:12px;
  align-items:center;
}
.stack-icon{
  width:44px;height:44px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
}
.stack-title{font-weight:900}
.stack-text{margin-top:2px; font-size:12px; color: var(--muted); font-weight:700}

/* divider */
.hero-divider svg{display:block;width:100%;height:140px}
.hero-divider path{fill: rgba(255,255,255,.04)}

/* sections */
.section{padding: 56px 0}
.section-alt{
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.06);
  border-bottom: 1px solid rgba(255,255,255,.06);
}
.section-head{max-width: 72ch}
.section-head p{margin-top:10px}

.split{
  margin-top: 20px;
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap:12px;
}
.bigcard{
  border-radius: 30px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:16px;
}
.bullets{margin:12px 0 0;padding:0;list-style:none;display:grid;gap:10px}
.bullets li{display:flex;gap:10px;align-items:flex-start;font-weight:800;color: rgba(245,246,255,.82)}
.bullets span{width:22px;display:inline-flex;justify-content:center}
.meters{margin-top:12px; display:grid; gap:12px}
.m-top{display:flex; justify-content:space-between; font-weight:900; color: rgba(245,246,255,.86)}
.bar{height:10px; border-radius: 999px; background: rgba(255,255,255,.08); border:1px solid rgba(255,255,255,.10); overflow:hidden}
.bar i{display:block; height:100%; background: linear-gradient(90deg, rgba(255,45,141,.75), rgba(45,226,255,.55)); border-radius:999px}
.hint{margin-top:10px; font-size:12px; color: var(--muted); font-weight:700}

.grid3{
  margin-top: 20px;
  display:grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap:12px;
}
.card{
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:16px;
  position:relative;
  overflow:hidden;
}
.card::before{
  content:"";
  position:absolute; inset:-2px;
  background:
    radial-gradient(420px 260px at 0% 0%, rgba(255,45,141,.12), transparent 60%),
    radial-gradient(420px 260px at 100% 40%, rgba(45,226,255,.10), transparent 60%);
  opacity:.85;
  pointer-events:none;
}
.card > *{position:relative; z-index:1}
.card-ico{
  width:44px;height:44px;border-radius:18px;
  display:flex;align-items:center;justify-content:center;
  background: rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.12);
  margin-bottom:10px;
  font-size:18px;
}
.card p{margin-top:8px; font-size:14px}

/* timeline */
.timeline{
  margin-top: 20px;
  display:grid;
  gap:12px;
}
.t-step{
  border-radius: 30px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:16px;
  display:flex;
  gap:14px;
  align-items:flex-start;
}
.t-n{
  width:44px;height:44px;border-radius:18px;
  background: linear-gradient(135deg, rgba(255,45,141,.26), rgba(45,226,255,.18));
  border:1px solid rgba(255,255,255,.12);
  display:flex;align-items:center;justify-content:center;
  font-weight:900;
}
.t-body p{margin-top:6px; font-size:14px}

/* stats */
.stat-grid{
  margin-top: 20px;
  display:grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap:12px;
}
.stat-card{
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:14px;
}
.stat-label{font-size:12px;font-weight:900;color: var(--muted)}
.stat-value{margin-top:8px;font-size:28px;font-weight:900}
.note{margin-top: 12px;font-size:12px;color: var(--muted); font-weight:700}

/* team */
.team-wrap{margin-top:20px}
.team-loading{
  display:flex; align-items:center; gap:12px;
  border-radius: 28px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding:16px;
}
.spinner{
  width:18px;height:18px;border-radius:50%;
  border:2px solid rgba(255,255,255,.18);
  border-top-color: rgba(255,45,141,.9);
  animation: spin 1s linear infinite;
}
@keyframes spin{to{transform:rotate(360deg)}}

.rank-block{margin-top:14px;border-radius:28px;border:1px solid rgba(255,255,255,.10);background: rgba(255,255,255,.04);overflow:hidden}
.rank-head{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;background: rgba(255,255,255,.04);border-bottom:1px solid rgba(255,255,255,.08)}
.rank-title{font-weight:900}
.rank-count{font-size:12px;color: var(--muted);font-weight:900}
.rank-grid{padding:14px;display:grid;grid-template-columns: repeat(4, minmax(0,1fr));gap:12px}
.member{border-radius:20px;border:1px solid rgba(255,255,255,.10);background: rgba(255,255,255,.05);padding:12px;display:flex;gap:12px;align-items:center}
.avatar{width:44px;height:44px;border-radius:16px;background: rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10);object-fit:cover}
.m-name{font-weight:900;font-size:14px}
.m-meta{font-size:12px;color: var(--muted);margin-top:2px;font-weight:700}

/* join */
.join{padding-bottom: 70px}
.join-inner{
  border-radius: 32px;
  border:1px solid rgba(255,255,255,.12);
  background: radial-gradient(900px 420px at 10% 10%, rgba(255,45,141,.18), transparent 60%),
              radial-gradient(900px 420px at 90% 40%, rgba(45,226,255,.14), transparent 60%),
              rgba(255,255,255,.05);
  padding: 18px;
  display:flex; align-items:flex-start; justify-content:space-between;
  gap:14px; flex-wrap:wrap;
}
.join-actions{display:flex; gap:12px; flex-wrap:wrap}
.checklist{margin-top:12px; display:grid; gap:8px}
.check{display:flex; align-items:center; gap:10px; font-weight:900; color: rgba(245,246,255,.84)}
.check input{width:16px;height:16px; accent-color: var(--p1)}

/* footer */
.footer{
  border-top:1px solid rgba(255,255,255,.08);
  background: rgba(8,9,18,.62);
  backdrop-filter: blur(12px);
  padding:18px 0;
}
.footer-inner{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}
.footer-left{display:flex;align-items:center;gap:10px;color: rgba(245,246,255,.76);font-weight:900}
.footer-left img{border-radius:10px;padding:3px;background: rgba(255,255,255,.05);border:1px solid rgba(255,255,255,.10)}
.footer-right{display:flex;gap:14px;flex-wrap:wrap}
.footer-right a{text-decoration:none;color: rgba(245,246,255,.68);font-weight:900;font-size:13px}
.footer-right a:hover{color: rgba(245,246,255,.92);text-decoration:underline}

/* reveal + tilt */
.reveal{opacity:0;transform: translateY(12px);transition: opacity .6s ease, transform .6s ease;}
.reveal.is-in{opacity:1;transform: translateY(0);}
.tilt{transform-style:preserve-3d; will-change: transform; transition: transform .12s ease;}
@media (hover: hover){ .tilt:hover{filter: brightness(1.04)} }

/* responsive */
@media (max-width: 980px){
  .hero-inner{grid-template-columns: 1fr}
  .hero-mini{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .grid3{grid-template-columns: 1fr}
  .stat-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
  .rank-grid{grid-template-columns: repeat(2, minmax(0, 1fr))}
}
@media (max-width: 760px){
  .nav-toggle{display:inline-block}
  .nav{
    position:absolute; right:20px; top:68px;
    width: min(380px, calc(100% - 40px));
    display:none; flex-direction:column; align-items:stretch; gap:6px;
    padding:10px;
    border-radius: 18px;
    border:1px solid rgba(255,255,255,.12);
    background: rgba(8,9,18,.92);
    box-shadow: var(--shadow);
  }
  .nav.open{display:flex}
  .nav a{padding:12px 12px}
  .rank-grid{grid-template-columns: 1fr}
}

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  *{scroll-behavior:auto !important}
  .reveal,.tilt{transition:none}
  .orb,.spinner{animation:none}
}

/* --- Gallery --- */
.gallery-toolbar{
  margin-top: 18px;
  display:flex;
  gap:10px;
  flex-wrap:wrap;
}
.gbtn{
  appearance:none;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(245,246,255,.86);
  border-radius: 999px;
  padding:10px 14px;
  font-weight:900;
  cursor:pointer;
  transition:.2s ease;
}
.gbtn:hover{filter: brightness(1.08)}
.gbtn.is-active{
  background: rgba(255,45,141,.14);
  border-color: rgba(255,45,141,.22);
  box-shadow: inset 0 0 0 1px rgba(255,45,141,.12);
}

.gallery-grid{
  margin-top: 16px;
  display:grid;
  grid-template-columns: repeat(12, minmax(0, 1fr));
  gap:12px;
}
.gitem{
  grid-column: span 4;
  margin:0;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  overflow:hidden;
  position:relative;
  cursor:pointer;
  box-shadow: 0 18px 70px rgba(0,0,0,.30);
  transition: transform .15s ease, filter .15s ease;
}
.gitem:hover{transform: translateY(-2px); filter: brightness(1.06)}
.gitem img{
  width:100%;
  height: 220px;
  object-fit: cover;
  display:block;
  transition: transform .25s ease;
}
.gitem figcaption{
  position:absolute;
  left:10px; bottom:10px;
  padding:8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(8,9,18,.68);
  backdrop-filter: blur(10px);
  font-weight:1000;
  font-size:12px;
  color: rgba(245,246,255,.9);
}

/* Hover label chip (top-left) */
.gitem::after{
  content: attr(data-label);
  position:absolute;
  left:12px; top:12px;
  padding:8px 10px;
  border-radius: 999px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(8,9,18,.68);
  backdrop-filter: blur(10px);
  font-weight:1000;
  font-size:12px;
  color: rgba(245,246,255,.92);
  transform: translateY(-6px);
  opacity:0;
  transition: .18s ease;
  pointer-events:none;
  max-width: calc(100% - 24px);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.gitem:hover::after{opacity:1; transform: translateY(0);}
.gitem:hover img{transform: scale(1.02);}

/* masonry-ish */
.gitem:nth-child(1),
.gitem:nth-child(4),
.gitem:nth-child(7),
.gitem:nth-child(10){
  grid-column: span 6;
}
.gitem:nth-child(1) img,
.gitem:nth-child(4) img,
.gitem:nth-child(7) img,
.gitem:nth-child(10) img{
  height: 280px;
}

/* filter hidden */
.gitem.is-hidden{display:none}

/* --- Lightbox --- */
.lightbox{
  position:fixed;
  inset:0;
  background: rgba(0,0,0,.72);
  backdrop-filter: blur(8px);
  display:none;
  z-index:9999;
}
.lightbox.is-open{display:block}
.lb-inner{
  position:absolute;
  left:50%; top:50%;
  transform: translate(-50%,-50%);
  width: min(1100px, calc(100% - 40px));
  border-radius: 26px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(10,10,18,.55);
  box-shadow: 0 22px 90px rgba(0,0,0,.65);
  overflow:hidden;
}
#lbImg{
  width:100%;
  height: min(70vh, 680px);
  object-fit: contain;
  display:block;
  background: rgba(0,0,0,.25);
}
.lb-meta{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 14px;
  border-top:1px solid rgba(255,255,255,.10);
}
.lb-title{font-weight:1000}
.lb-count{font-size:12px; color: rgba(245,246,255,.70); font-weight:900}
.lb-close{
  position:absolute; right:14px; top:14px;
  width:44px; height:44px;
  border-radius: 14px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: rgba(245,246,255,.9);
  cursor:pointer;
  font-size:16px;
  z-index:10000;
}
.lb-nav{
  position:absolute;
  top:50%;
  transform: translateY(-50%);
  width:46px; height:64px;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.08);
  color: rgba(245,246,255,.9);
  cursor:pointer;
  font-size:34px;
  line-height:0;
  display:flex; align-items:center; justify-content:center;
  z-index:10000;
}
.lb-prev{left:14px}
.lb-next{right:14px}

@media (max-width: 980px){
  .gitem{grid-column: span 6}
  .gitem img{height: 200px}
  .gitem:nth-child(1),
  .gitem:nth-child(4),
  .gitem:nth-child(7),
  .gitem:nth-child(10){
    grid-column: span 12;
  }
  .gitem:nth-child(1) img,
  .gitem:nth-child(4) img,
  .gitem:nth-child(7) img,
  .gitem:nth-child(10) img{
    height: 240px;
  }
}
