/* ========================================
   CORE STYLES & CSS CUSTOM PROPERTIES
   ======================================== */

:root{
  /* Color Palette */
  --color-bg:#070712;
  --color-surface:#131125;
  --color-surface-alt:#1c1933;
  --color-primary:#8b5cf6;
  --color-primary-dark:#6d28d9;
  --color-primary-glow:#b794f4;
  --color-accent:#22d3ee;
  --color-text:#ffffff;
  --color-muted:#a2a1c2;
  
  /* Border Radius */
  --radius-lg:26px;
  --radius-md:18px;
  --radius-sm:10px;
  
  /* Shadows */
  --shadow-card:0 18px 45px rgba(8,6,18,0.55);
  --shadow-glow:0 0 45px rgba(139,92,246,0.45);
  --shadow-hover:0 24px 58px rgba(8,6,18,0.65);
  
  /* Layout */
  --max-width:1200px;
  
  /* Gradients */
  --gradient-hero:linear-gradient(135deg,#4c1d95 0%,#2f155c 40%,#34146d 65%,#4f1f8b 100%);
  --gradient-section:linear-gradient(135deg,#1a003e 0%,#4b0082 60%,#9d00ff 100%);
  --gradient-nebula:radial-gradient(circle at 20% 20%,rgba(34,211,238,0.22),transparent 55%),radial-gradient(circle at 80% 10%,rgba(139,92,246,0.28),transparent 52%),radial-gradient(circle at 50% 80%,rgba(255,68,204,0.2),transparent 60%);
  
  /* Motion Timings */
  --motion-fast:160ms;
  --motion-medium:320ms;
  --motion-slow:620ms;
  --page-transition: var(--motion-slow);
  
  font-size:16px;
}

/* ========================================
   RESET & BASE STYLES
   ======================================== */
/* ========================================
   RESET & BASE STYLES
   ======================================== */

*{box-sizing:border-box;}

html{
  scroll-behavior:smooth;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}

html,body{
  margin:0;
  padding:0;
  background:var(--color-bg);
  color:var(--color-text);
  font-family:"Outfit",Inter,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  line-height:1.6;
  min-height:100%;
  position:relative;
}
body::before{
  content:"";
  position:fixed;
  inset:0;
  background:var(--gradient-nebula);
  opacity:.85;
  z-index:-2;
}
body::after{
  content:"";
  position:fixed;
  inset:0;
  background:
    radial-gradient(circle at 10% 10%,rgba(255,255,255,0.06) 0%,transparent 45%),
    radial-gradient(circle at 80% 20%,rgba(34,211,238,0.11) 0%,transparent 40%),
    repeating-linear-gradient(120deg,rgba(139,92,246,0.08) 0 1px,transparent 1px 240px);
  mix-blend-mode:screen;
  opacity:.22;
  pointer-events:none;
  z-index:-1;
}
/* ========================================
   ACCESSIBILITY & FOCUS STATES
   ======================================== */

a:focus-visible,
.btn:focus-visible,
.menu-toggle:focus-visible,
summary:focus-visible,
.input-field:focus-visible{
  outline:3px solid rgba(34,211,238,0.95);
  outline-offset:4px;
  border-radius:var(--radius-sm);
}

/* Improved focus indicators for keyboard navigation */
*:focus-visible{
  outline:2px solid rgba(34,211,238,0.8);
  outline-offset:3px;
  transition:outline-offset var(--motion-fast) ease;
}

*:focus-visible:active{
  outline-offset:1px;
}

.skip-link{
  position:absolute;left:-9999px;top:auto;width:1px;height:1px;overflow:hidden;
}
.skip-link:focus{
  position:fixed;left:1rem;top:1rem;width:auto;height:auto;padding:.6rem .9rem;z-index:9999;background:#0b0b18;color:#fff;border:2px solid rgba(34,211,238,0.9);border-radius:10px;
  box-shadow:0 8px 24px rgba(34,211,238,0.35);
}
/* ========================================
   TYPOGRAPHY & IMAGES
   ======================================== */

img{
  max-width:100%;
  display:block;
  border-radius:var(--radius-md);
  height:auto;
}

a{
  color:var(--color-accent);
  text-decoration:none;
  transition:color var(--motion-fast) ease,transform var(--motion-fast) ease;
}

a:hover{
  color:var(--color-primary);
}

a:active{
  transform:scale(0.98);
}

/* ========================================
   LAYOUT & CONTAINERS
   ======================================== */

.container{width:min(92%,var(--max-width));margin-inline:auto;}

#content{
  transition:opacity var(--page-transition) ease,transform var(--page-transition) ease,filter var(--page-transition) ease;
  will-change:opacity,transform,filter;
}
body.page-enter #content{
  opacity:0;
  transform:translate3d(0,24px,0) scale(.985);
  filter:blur(14px);
  pointer-events:none;
}
body.page-enter.page-enter-active #content{
  opacity:1;
  transform:none;
  filter:none;
  pointer-events:auto;
}
body.page-exit #content{
  opacity:1;
  pointer-events:none;
}
body.page-exit.page-exit-active #content{
  opacity:0;
  transform:translate3d(0,-24px,0) scale(.985);
  filter:blur(14px);
}

header{
  position:sticky;top:0;z-index:10;
  -webkit-backdrop-filter:blur(14px);
  backdrop-filter:blur(14px);
  background:rgba(10,8,25,0.78);
  border-bottom:1px solid rgba(139,92,246,0.18);
  transition:background var(--motion-medium) ease,border-color var(--motion-medium) ease;
}
.nav{
  position:relative;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:1rem 0;
}
.brand{display:flex;align-items:center;gap:.75rem;font-weight:700;letter-spacing:.08em;text-transform:uppercase;}
.brand-logo{width:48px;height:48px;border-radius:50%;background:var(--gradient-section);display:grid;place-items:center;overflow:hidden;box-shadow:0 12px 24px rgba(64,22,155,0.4);}
.brand-logo img{width:70%;height:auto;display:block;filter:drop-shadow(0 4px 12px rgba(8,4,18,0.45));}
.menu-toggle{display:none;background:none;border:none;color:var(--color-text);font-size:1.75rem;}
.menu{
  display:flex;
  gap:1.25rem;
}
.menu a{color:var(--color-text);padding:.4rem .9rem;border-radius:var(--radius-sm);font-weight:600;}
.menu a:hover{background:rgba(139,92,246,0.18);} 
/* Active tab styles */
.menu a[aria-current="page"]{
  background:linear-gradient(120deg, rgba(139,92,246,0.28), rgba(34,211,238,0.22));
  border:1px solid rgba(139,92,246,0.45);
  box-shadow:0 10px 22px rgba(109,40,217,0.25);
}

.hero{
  background:var(--gradient-hero);
  padding:6.5rem 0 5.5rem;
  border-bottom-left-radius:var(--radius-lg);
  border-bottom-right-radius:var(--radius-lg);
  box-shadow:var(--shadow-card);
  position:relative;
  overflow:hidden;
}

/* Three.js Particle Container */
.hero-particles{
  position:absolute;
  top:0;
  left:0;
  width:100%;
  height:100%;
  pointer-events:none;
  z-index:0;
}
.hero-particles canvas{
  display:block;
  width:100%;
  height:100%;
}

.hero-content{position:relative;z-index:1;}
.hero-copy{display:grid;gap:1.4rem;}
.hero-decor{position:absolute;inset:-12% -8%;pointer-events:none;z-index:0;filter:blur(0);}
.hero-orbit{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:50%;border:1px solid rgba(139,92,246,0.28);mix-blend-mode:screen;opacity:.65;transition:opacity var(--motion-medium) ease,transform var(--motion-medium) ease;}
.hero-orbit--primary{width:38vw;max-width:620px;height:38vw;max-height:620px;background:radial-gradient(circle,rgba(139,92,246,0.22) 0%,transparent 70%);} 
.hero-orbit--accent{width:48vw;max-width:780px;height:48vw;max-height:780px;border-color:rgba(34,211,238,0.2);opacity:.45;box-shadow:0 0 60px rgba(34,211,238,0.18);}
.hero-orbit--spark{width:22vw;max-width:360px;height:22vw;max-height:360px;background:radial-gradient(circle,rgba(255,255,255,0.35) 0%,rgba(139,92,246,0.28) 40%,transparent 70%);filter:blur(2px);opacity:.55;}
.hero-highlights{margin:1.75rem 0 0;padding:0;list-style:none;display:flex;flex-wrap:wrap;gap:1rem;}
.hero-highlights li{min-width:170px;padding:.8rem 1.1rem;border-radius:var(--radius-sm);border:1px solid rgba(255,255,255,0.08);background:linear-gradient(130deg,rgba(12,10,32,0.88),rgba(28,24,52,0.78));box-shadow:0 14px 32px rgba(7,5,18,0.45);backdrop-filter:blur(12px);display:flex;flex-direction:column;gap:.35rem;transition:transform var(--motion-medium) ease,border-color var(--motion-medium) ease,box-shadow var(--motion-medium) ease;}
.hero-highlights li:hover{transform:translateY(-6px);border-color:rgba(34,211,238,0.38);box-shadow:var(--shadow-glow);}
.hero-highlights__label{text-transform:uppercase;font-size:.72rem;letter-spacing:.16em;color:rgba(34,211,238,0.85);font-weight:700;opacity:.92;}
.hero-highlights__value{font-weight:600;color:#fff;}
.hero::before,.hero::after{
  content:"";
  position:absolute;
  width:520px;
  height:520px;
  border-radius:50%;
  filter:blur(70px);
  opacity:.45;
  z-index:0;
  animation:drift 18s ease-in-out infinite;
}
.hero::before{
  top:-240px;
  left:-180px;
  background:radial-gradient(circle at center,rgba(139,92,246,0.7),transparent 70%);
}
.hero::after{
  bottom:-260px;
  right:-120px;
  background:radial-gradient(circle at center,rgba(34,211,238,0.55),transparent 70%);
  animation-delay:6s;
}
.hero-content{display:grid;gap:3rem;align-items:center;
  grid-template-columns:repeat(auto-fit,minmax(260px,1fr));
}
.hero h1{font-size:clamp(2.5rem,3.5vw,3.95rem);line-height:1.08;margin:0;font-family:"Anton",sans-serif;background:linear-gradient(110deg,#fff 0%,rgba(189,189,255,0.92) 40%,rgba(139,92,246,0.8) 70%,rgba(34,211,238,0.85) 100%);-webkit-background-clip:text;background-clip:text;color:transparent;}
.hero p{color:var(--color-muted);max-width:540px;}
.actions{display:flex;gap:1rem;flex-wrap:wrap;}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding:.9rem 1.6rem;
  border-radius:var(--radius-sm);
  font-weight:700;
  cursor:pointer;
  transition:
    transform var(--motion-fast) ease,
    box-shadow var(--motion-fast) ease,
    background var(--motion-fast) ease,
    border-color var(--motion-fast) ease;
  position:relative;
}

.btn:active{
  transform:translateY(1px) scale(0.98);
}

.btn-primary{
  background:linear-gradient(100deg,rgba(106,28,241,1) 0%,rgba(142,24,230,1) 55%,rgba(34,211,238,0.75) 100%);
  color:#fff;
  box-shadow:0 16px 32px rgba(109,40,217,0.42);
  position:relative;
  overflow:hidden;
  border:0;
}

.btn-primary::before{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(100deg,rgba(106,28,241,1) 0%,rgba(142,24,230,1) 55%,rgba(34,211,238,0.85) 100%);
  opacity:0;
  transition:opacity var(--motion-fast) ease;
  z-index:-1;
}

.btn-primary::after{
  content:"";
  position:absolute;
  inset:-40%;
  background:radial-gradient(circle at center,rgba(255,255,255,0.55),transparent 60%);
  opacity:0;
  transition:opacity var(--motion-fast) ease;
  z-index:-1;
}

.btn-primary:hover{
  transform:translateY(-3px) scale(1.02);
  box-shadow:
    0 20px 42px rgba(109,40,217,0.55),
    0 0 40px rgba(139,92,246,0.3);
}

.btn-primary:hover::before{
  opacity:1;
}

.btn-primary:hover::after{
  opacity:0.35;
}

.btn-primary > *{
  position:relative;
  z-index:1;
  color:#fff;
  text-shadow:0 1px 2px rgba(0,0,0,0.3);
}
.btn-outline{
  border:2px solid rgba(139,92,246,0.6);
  color:var(--color-text);
  background:transparent;
  position:relative;
  overflow:hidden;
}

.btn-outline::before{
  content:"";
  position:absolute;
  inset:0;
  background:rgba(139,92,246,0.18);
  opacity:0;
  transition:opacity var(--motion-fast) ease;
  z-index:0;
}

.btn-outline:hover{
  background:rgba(139,92,246,0.22);
  transform:translateY(-2px);
  border-color:rgba(139,92,246,0.85);
  box-shadow:0 12px 28px rgba(139,92,246,0.25);
}

.btn-outline:hover::before{
  opacity:1;
}

.btn-outline > *{
  position:relative;
  z-index:1;
}

/* Disabled button states */
.btn[aria-disabled="true"],
.btn:disabled{
  opacity:0.5;
  cursor:not-allowed;
  pointer-events:none;
}

.section{
  padding:4.75rem 0;
  position:relative;
}
.section.section--accent,.section.section--split,.section.section--testimonial,.section.section--faq,.section.section--contact{overflow:hidden;}
.section::before{
  content:"";
  position:absolute;
  left:50%;
  width:min(68%,720px);
  transform:translateX(-50%);
  top:1.2rem;
  height:1px;
  background:linear-gradient(90deg,transparent,rgba(139,92,246,0.45),rgba(34,211,238,0.35),transparent);
  opacity:.5;
  pointer-events:none;
}
.section-decor{position:absolute;inset:-18% -12%;pointer-events:none;z-index:0;filter:blur(0);}
[data-parallax]{will-change:transform;display:block;transform:translate3d(0,0,0);transition:transform var(--motion-slow) ease,opacity var(--motion-medium) ease;}
.section-pulse{position:absolute;border-radius:50%;filter:blur(12px);opacity:.45;mix-blend-mode:screen;}
.section-pulse--cyan{width:460px;height:460px;background:radial-gradient(circle at center,rgba(34,211,238,0.32) 0%,transparent 70%);top:18%;left:-12%;}
.section-pulse--violet{width:540px;height:540px;background:radial-gradient(circle at center,rgba(139,92,246,0.35) 0%,transparent 72%);bottom:-18%;right:-6%;}
.section-stripe{position:absolute;width:120%;height:180px;top:20%;left:-10%;background:linear-gradient(100deg,rgba(139,92,246,0.18) 0%,rgba(34,211,238,0) 50%,rgba(255,68,204,0.18) 100%);filter:blur(18px);opacity:.32;}
.section-spark{position:absolute;width:280px;height:280px;border-radius:50%;background:radial-gradient(circle,rgba(255,255,255,0.35) 0%,rgba(34,211,238,0.25) 45%,transparent 70%);top:55%;right:6%;box-shadow:0 0 120px rgba(255,255,255,0.16);}
.section-aurora{position:absolute;width:520px;height:520px;border-radius:40%;background:conic-gradient(from 120deg,rgba(34,211,238,0.18),rgba(139,92,246,0.28),rgba(255,68,204,0.12),rgba(34,211,238,0.18));top:-10%;left:10%;filter:blur(22px);opacity:.4;}
.section-orb{position:absolute;width:340px;height:340px;border-radius:50%;background:radial-gradient(circle,rgba(139,92,246,0.38),transparent 70%);bottom:-14%;right:14%;mix-blend-mode:screen;opacity:.35;}
.section-grid{position:absolute;inset:20% 15%;border-radius:30px;border:1px solid rgba(255,255,255,0.08);background:linear-gradient(140deg,rgba(19,17,37,0.75),rgba(12,10,28,0.6));box-shadow:0 24px 48px rgba(7,5,18,0.45);opacity:.35;filter:blur(6px);}
.section-glow{position:absolute;width:420px;height:420px;border-radius:50%;background:radial-gradient(circle,rgba(34,211,238,0.28),transparent 72%);top:10%;right:-6%;opacity:.26;}
.section-rings{position:absolute;width:420px;height:420px;border-radius:50%;border:1px solid rgba(255,255,255,0.07);top:8%;left:-14%;box-shadow:0 0 110px rgba(139,92,246,0.25);}
.section-rings::after{content:"";position:absolute;inset:18%;border-radius:50%;border:1px solid rgba(34,211,238,0.25);} 
.section-rings--offset{left:auto;right:-12%;top:auto;bottom:-16%;opacity:.4;}
.section.section--testimonial .section-header{position:relative;z-index:1;}
.section.section--testimonial .testimonial{position:relative;z-index:1;}
.section.section--faq .faq{position:relative;z-index:1;}
.section.section--contact .grid{position:relative;z-index:1;}
.section.section--accent .grid{position:relative;z-index:1;}
.section-header{text-align:center;margin-bottom:3rem;}
.section-header h2{margin-bottom:.75rem;font-family:"Anton",sans-serif;font-size:clamp(2rem,2.6vw,3rem);background:linear-gradient(120deg,#fff,rgba(139,92,246,0.65),rgba(34,211,238,0.85));-webkit-background-clip:text;background-clip:text;color:transparent;}
.section-header p{color:var(--color-muted);}

/* About */
.about-grid{display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));align-items:start}
.about-copy p{margin-top:0;color:#e9e8ff}
.pills{list-style:none;padding:0;margin:1rem 0 0;display:flex;flex-wrap:wrap;gap:.6rem}
.pill{background:rgba(139,92,246,0.16);border:1px solid rgba(139,92,246,0.35);color:#fff;padding:.45rem .8rem;border-radius:999px;font-weight:600;font-size:.9rem}
.about-kpis{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}
.kpi{backdrop-filter:blur(10px);background:linear-gradient(140deg,rgba(26,22,50,0.9),rgba(23,20,44,0.82));}
.kpi h3{margin:.2rem 0 0;font-size:1.9rem;color:#fff;}
.kpi p{color:rgba(226,225,255,0.7)}

.grid{
  display:grid;
  gap:1.5rem;
}
.grid-3{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));}
.grid-2{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));}

/* Utility: wide card that matches member width in stacked/single grids */
.card--wide{
  max-width:1020px;
  width:100%;
  margin-inline:auto;
}

.card{
  --tilt-rotate-x:0deg;
  --tilt-rotate-y:0deg;
  --tilt-translate-x:0px;
  --tilt-translate-y:0px;
  --tilt-scale:1;
  --lift-translate-y:0px;
  --lift-scale:1;
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1.9rem;
  border:1px solid rgba(255,255,255,0.08);
  box-shadow:var(--shadow-card);
  min-height:100%;
  position:relative;
  overflow:hidden;
  transition:transform var(--motion-medium) ease,box-shadow var(--motion-medium) ease,border-color var(--motion-medium) ease,background var(--motion-medium) ease;
  transform:var(--tilt-transform)
    translate3d(0,var(--lift-translate-y),0)
    scale(var(--lift-scale));
}
.card::before{
  content:"";
  position:absolute;
  inset:-2px;
  border-radius:inherit;
  background:linear-gradient(140deg,rgba(139,92,246,0.7),rgba(34,211,238,0.35),rgba(255,68,204,0.28));
  opacity:0;
  transition:opacity var(--motion-medium) ease;
  z-index:0;
}
.card > *{position:relative;z-index:1;}
.card h3,.card h4{margin-top:0;font-family:"Anton",sans-serif;}
.card p{margin-bottom:0;color:var(--color-muted);}
.card p, .card li, .card a{overflow-wrap:anywhere; word-break:break-word;}
.card::after{
  content:"";
  position:absolute;
  inset:0;
  border-radius:inherit;
  background:radial-gradient(circle at top,rgba(139,92,246,0.18),transparent 60%);
  opacity:.4;
  transition:opacity var(--motion-medium) ease;
  pointer-events:none;
}
.card:hover{
  --lift-translate-y:-10px;
  --lift-scale:1.012;
  border-color:rgba(139,92,246,0.45);
  background:linear-gradient(145deg,rgba(19,17,37,0.92),rgba(26,22,50,0.92));
  box-shadow:
    0 24px 58px rgba(8,6,18,0.65),
    0 0 60px rgba(139,92,246,0.25),
    inset 0 1px 0 rgba(255,255,255,0.1);
}

.card:hover::before{
  opacity:0.75;
}

.card:hover::after{
  opacity:0.55;
}

.card:active{
  --lift-translate-y:-4px;
  --lift-scale:0.995;
  transition-duration:var(--motion-fast);
}

[data-tilt]{
  --tilt-rotate-x:0deg;
  --tilt-rotate-y:0deg;
  --tilt-translate-x:0px;
  --tilt-translate-y:0px;
  --tilt-scale:1;
  --tilt-transform:perspective(1200px)
    rotateX(var(--tilt-rotate-x))
    rotateY(var(--tilt-rotate-y))
    translate3d(var(--tilt-translate-x),var(--tilt-translate-y),0)
    scale(var(--tilt-scale));
  transition:transform var(--motion-medium) ease,box-shadow var(--motion-medium) ease,border-color var(--motion-medium) ease,background var(--motion-medium) ease;
  transform-style:preserve-3d;
}
[data-tilt]:not(.card):not(.testimonial):not(.faq){transform:var(--tilt-transform);}
[data-tilt].is-tilting{
  box-shadow:0 28px 54px rgba(12,9,28,0.55);
}

.testimonial[data-tilt]{
  transform:var(--tilt-transform);
}
.faq[data-tilt]{
  transform:var(--tilt-transform);
}

.badge{
  display:inline-flex;
  align-items:center;
  gap:.4rem;
  padding:.45rem .75rem;
  border-radius:999px;
  background:rgba(34,211,238,0.1);
  color:var(--color-accent);
  font-size:.75rem;
  font-weight:600;
  text-transform:uppercase;
  letter-spacing:.08em;
}
.member__head{display:flex;align-items:center;gap:1.1rem;margin-bottom:.6rem}
.member__avatar{width:112px;height:112px;border-radius:50%;overflow:hidden;border:1px solid rgba(255,255,255,0.08);box-shadow:0 10px 24px rgba(7,5,18,0.45)}
.member__avatar img{width:100%;height:100%;object-fit:cover;display:block}
.member__meta h3{margin:.1rem 0}
.member .role{margin:.2rem 0 0;color:var(--color-muted)}
.member__links{display:flex;gap:.5rem;margin-top:.75rem}

.member-grid{display:grid;gap:2.2rem 2rem;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));align-items:start}
.member-grid.member-grid--solo,
.member-grid.member-grid--single,
.member-grid.member-grid--stacked{justify-items:center;grid-template-columns:minmax(0,1fr);padding-block:2rem 0}
.member-grid.member-grid--solo .member,
.member-grid.member-grid--single .member,
.member-grid.member-grid--stacked .member{max-width:1020px;width:100%}

/* Team member layout: photo left, text right aligned to portrait ratio */
.member{width:100%;display:grid;grid-template-columns:minmax(320px,420px) minmax(0,1fr);gap:2.25rem;align-items:stretch;padding:2.4rem;background:linear-gradient(150deg,rgba(18,16,38,0.95),rgba(29,24,54,0.9));border:1px solid rgba(139,92,246,0.28);box-shadow:0 28px 58px rgba(8,6,22,0.55);position:relative;overflow:hidden}
.member::before{content:"";position:absolute;inset:-40% -20%;background:
    radial-gradient(circle at 18% 22%,rgba(139,92,246,0.42),transparent 60%),
    radial-gradient(circle at 82% 18%,rgba(34,211,238,0.32),transparent 55%),
    radial-gradient(circle at 50% 90%,rgba(255,68,204,0.25),transparent 62%);
  opacity:.55;filter:blur(14px);z-index:0;transition:transform var(--motion-medium) ease,opacity var(--motion-medium) ease}
.member:hover::before{opacity:.82;transform:scale(1.05)}
.member > *{position:relative;z-index:1}
/* Large team photo without stretching; lock to 3:4 portrait (≈3080x4080) */
.member__photo{margin:0;border-radius:var(--radius-md);overflow:hidden;line-height:0;border:1px solid rgba(255,255,255,0.12);box-shadow:0 24px 48px rgba(7,5,18,0.55);width:100%;max-width:420px;aspect-ratio:3/4}
.member__photo img{display:block;width:100%;height:100%;object-fit:cover;aspect-ratio:inherit}

/* Partner logos - 225x225 square format */
.member.partner .member__photo{
  aspect-ratio:1/1;
  max-width:225px;
  display:flex;
  align-items:center;
  justify-content:center;
  background:rgba(255,255,255,0.03);
  padding:1rem;
}
.member.partner .member__photo img{
  object-fit:contain;
  width:100%;
  height:100%;
}

.member__meta{display:flex;flex-direction:column;justify-content:flex-start;gap:1.5rem;min-height:100%}
.member__meta > *:last-child{margin-top:auto}
.member .badge{margin-bottom:.45rem;box-shadow:0 0 0 1px rgba(139,92,246,0.35);background:rgba(139,92,246,0.16)}
.member__meta h3{font-size:clamp(2rem,2.6vw,2.75rem);letter-spacing:.01em}
.member .role{font-size:1.18rem;line-height:1.8;color:#e0dffb;max-width:560px}

@media (max-width:780px){
  .member-grid{gap:1.75rem}
  .member{grid-template-columns:1fr;padding:1.85rem;gap:1.6rem}
  .member__photo{max-width:420px;margin-inline:auto}
  .member__meta{gap:1.1rem}
}
.member__discord{display:flex;align-items:center;gap:.65rem;margin-top:auto;padding-top:1.6rem;border-top:1px solid rgba(139,92,246,0.22);width:100%;max-width:520px}
.member__discord-avatar{width:28px;height:28px;border-radius:50%;object-fit:cover;border:1px solid rgba(255,255,255,0.1)}
.member__discord-name{font-weight:600;color:var(--color-text);letter-spacing:.02em}
.member__contact{margin-left:auto;font-size:.98rem;font-weight:600;color:#d3d2f5;display:flex;align-items:center;gap:.4rem}
.member__contact a{color:inherit;text-decoration:none}
.member__contact a:hover{color:var(--color-accent)}
.member__discord[hidden]{display:none !important}
.price-tag{font-size:2.5rem;font-weight:800;margin:.5rem 0;color:#fff;}
.compare{color:var(--color-muted);text-decoration:line-through;font-size:1rem;}

.list{list-style:none;padding:0;margin:0;display:grid;gap:.6rem;}
.list li{display:flex;align-items:flex-start;gap:.6rem;color:var(--color-muted);} 
.list li::before{content:"✔";color:var(--color-accent);}

.testimonial{display:grid;gap:1.5rem;align-items:center;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));}
.testimonial blockquote{margin:0;font-size:1.05rem;color:var(--color-text);font-weight:500;}
.testimonial cite{display:block;margin-top:1rem;color:var(--color-accent);font-style:normal;font-weight:700;}
.testimonial[data-tilt]{backdrop-filter:blur(0);border-radius:var(--radius-lg);padding:2.2rem;background:linear-gradient(140deg,rgba(20,18,40,0.85),rgba(12,10,28,0.65));border:1px solid rgba(139,92,246,0.18);box-shadow:0 24px 48px rgba(7,5,18,0.55);}

.faq details{
  background:var(--color-surface);
  border-radius:var(--radius-md);
  padding:1rem 1.25rem;
  border:1px solid rgba(255,255,255,0.05);
}
.faq summary{
  cursor:pointer;font-weight:700;display:flex;align-items:center;justify-content:space-between;gap:1rem;
}
.faq p{margin:.75rem 0 0;color:var(--color-muted);}

.footer{
  background:rgba(9,8,25,0.85);
  border-top:1px solid rgba(139,92,246,0.18);
  padding:3rem 0 2rem;
}
.footer-top{display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));}
.footer h4{margin-top:0;font-family:"Anton",sans-serif;font-size:1.2rem;}
.footer ul{list-style:none;padding:0;margin:0;display:grid;gap:.4rem;}
.footer ul a{color:var(--color-muted);} 
.footer ul a:hover{color:#fff;}
.footer-bottom{text-align:center;color:var(--color-muted);margin-top:2rem;font-size:.9rem;}
.newsletter-form{
  display:flex;
  gap:.75rem;
  align-items:center;
  flex-wrap:wrap;
}
.newsletter-form .input-field{
  flex:1 1 240px;
  padding:.85rem 1rem;
  border-radius:var(--radius-sm);
  border:1px solid rgba(255,255,255,0.08);
  background:rgba(255,255,255,0.04);
  color:var(--color-text);
  transition:border-color var(--motion-fast) ease,box-shadow var(--motion-fast) ease,background var(--motion-fast) ease;
}
.newsletter-form .input-field::placeholder{color:var(--color-muted);}
.newsletter-form .input-field:focus{
  outline:none;
  border-color:rgba(34,211,238,0.45);
  box-shadow:0 0 0 3px rgba(34,211,238,0.16);
  background:rgba(8,8,24,0.65);
}

/* Reveal Animations */
.reveal{opacity:0;transform:translate3d(0,26px,0);transition:opacity calc(var(--motion-medium) + 120ms) ease,transform calc(var(--motion-medium) + 120ms) ease;transition-delay:var(--delay,0ms);will-change:opacity,transform;}
.reveal.active{opacity:1;transform:none;}

/* Micro-stagger inside components: headline/badge first, body +60ms */
.card.reveal > .badge,
.card.reveal > h3,
.card.reveal > h4{
  opacity:0;
  transform:translate3d(0,6px,0);
  transition:opacity calc(var(--motion-medium) + 60ms) ease, transform calc(var(--motion-medium) + 60ms) ease;
  transition-delay:var(--delay,0ms);
}
.card.reveal.active > .badge,
.card.reveal.active > h3,
.card.reveal.active > h4{opacity:1;transform:none;}

.card.reveal > p,
.card.reveal > ul,
.card.reveal > ol,
.card.reveal > .list{
  opacity:0;
  transform:translate3d(0,8px,0);
  transition:opacity calc(var(--motion-medium) + 60ms) ease, transform calc(var(--motion-medium) + 60ms) ease;
  transition-delay:calc(var(--delay,0ms) + 60ms);
}
.card.reveal.active > p,
.card.reveal.active > ul,
.card.reveal.active > ol,
.card.reveal.active > .list{opacity:1;transform:none;}

/* Section header micro-stagger: h2 then paragraph */
.section-header.reveal h2{
  opacity:0;
  transform:translate3d(0,6px,0);
  transition:opacity calc(var(--motion-medium) + 60ms) ease, transform calc(var(--motion-medium) + 60ms) ease;
  transition-delay:var(--delay,0ms);
}
.section-header.reveal p{
  opacity:0;
  transform:translate3d(0,8px,0);
  transition:opacity calc(var(--motion-medium) + 60ms) ease, transform calc(var(--motion-medium) + 60ms) ease;
  transition-delay:calc(var(--delay,0ms) + 60ms);
}
.section-header.reveal.active h2,
.section-header.reveal.active p{opacity:1;transform:none;}

.hero{--tilt-x:0;--tilt-y:0;}
.hero-image{position:relative;transform:translate3d(calc(var(--tilt-x)*14px),calc(var(--tilt-y)*-14px),0) rotate(calc(var(--tilt-x)*2deg));transition:transform .35s ease,filter .35s ease;filter:drop-shadow(0 22px 35px rgba(0,0,0,0.45));border-radius:var(--radius-lg);overflow:hidden;}
.hero-image{min-height:clamp(180px,28vw,360px)}
.member__photo{contain:layout paint}
.hero-image picture{display:block;height:100%;}
.hero-image img{border-radius:inherit;}
.hero-image::after{
  content:"";
  position:absolute;
  inset:0;
  background:linear-gradient(120deg,rgba(139,92,246,0.35),transparent 55%);
  border-radius:inherit;
  mix-blend-mode:screen;
  opacity:.4;
  pointer-events:none;
}

@media (max-width:1100px){
  .hero{padding:5.5rem 0 4.5rem;}
  .hero-content{gap:2.5rem;}
  .section{padding:4.25rem 0;}
}

@media (max-width:960px){
  .nav{flex-wrap:wrap;gap:1rem;}
  .brand{font-size:.95rem;}
  .hero-content{text-align:center;}
  .hero-content>div:first-child{display:grid;gap:1.25rem;justify-items:center;}
  .hero .actions{justify-content:center;}
  .hero-image{max-width:360px;margin-inline:auto;}
  .hero-highlights{justify-content:center;}
  .hero-highlights li{min-width:0;max-width:280px;}
  .testimonial{gap:2rem;}
}

@media (max-width:780px){
  .grid-3,.grid-2{grid-template-columns:1fr;}
  .card{max-width:520px;margin-inline:auto;}
  .testimonial{grid-template-columns:1fr;text-align:center;}
  .testimonial .hero-image{margin-inline:auto;max-width:280px;}
  .faq details{padding:1.1rem 1.4rem;}
  .footer-top{text-align:center;}
  .footer-top ul{justify-items:center;}
  .newsletter-form{flex-direction:column;align-items:stretch;}
  .newsletter-form .btn{width:100%;justify-content:center;}
  .section-decor{display:none;}
}

.grid-3 .card,.grid-2 .card,.testimonial,.faq details,.footer-top>div{transition:transform var(--motion-medium) ease,box-shadow var(--motion-medium) ease;}
.faq details:hover{transform:translateY(-4px);}

.faq summary::after{content:"+";flex:0 0 1.75rem;height:1.75rem;border-radius:50%;background:rgba(139,92,246,0.16);display:grid;place-items:center;font-weight:700;color:var(--color-accent);transition:transform var(--motion-fast) ease,background var(--motion-fast) ease;}
.faq details[open] summary{color:var(--color-accent);}
.faq details[open] summary::after{content:"−";background:rgba(34,211,238,0.16);}

@keyframes float{
  0%{transform:translate3d(0,0,0) rotate(0deg);}
  50%{transform:translate3d(0,-12px,0) rotate(1deg);}
  100%{transform:translate3d(0,0,0) rotate(-1deg);}
}

@keyframes drift{
  0%{transform:translate3d(0,0,0) scale(1);opacity:.65;}
  50%{transform:translate3d(8%,6%,0) scale(1.08);opacity:.85;}
  100%{transform:translate3d(-6%,12%,0) scale(.95);opacity:.55;}
}

@keyframes glowPulse{
  0%,100%{box-shadow:0 12px 26px rgba(109,40,217,0.4);}
  50%{box-shadow:0 18px 36px rgba(139,92,246,0.55);}
}

/* Responsive navigation */
@media (max-width:820px){
  .menu{position:absolute;top:76px;right:4%;left:4%;flex-direction:column;background:rgba(12,10,24,0.95);padding:1.25rem;border-radius:var(--radius-md);border:1px solid rgba(139,92,246,0.18);transform:scale(.97);opacity:0;pointer-events:none;transition:opacity .2s ease,transform .2s ease;}
  .menu.open{opacity:1;transform:scale(1);pointer-events:auto;}
  .menu-toggle{display:block;}
}

/* Lock background scroll when mobile nav is open */
body[data-nav-open]{overflow:hidden;}

@media (max-width:600px){
  .section{padding:3.75rem 0;}
  .hero{padding:4.5rem 0 3.5rem;}
  .actions{width:100%;}
  .btn{flex:1 1 100%;justify-content:center;}
  .hero-highlights{flex-direction:column;}
  .hero-highlights li{width:100%;}
}

@media (max-width:560px){
  header{border-bottom-color:rgba(139,92,246,0.28);}
  .brand{font-size:.88rem;}
  .brand-logo{width:40px;height:40px;}
  .hero h1{font-size:clamp(2.2rem,8vw,2.75rem);}
  .section-header h2{font-size:clamp(1.85rem,7vw,2.3rem);}
  .card{padding:1.5rem;}
  .price-tag{font-size:2.2rem;}
  .footer-bottom{font-size:.85rem;}
}

@media (max-width:420px){
  .newsletter-form .input-field{flex:1 1 100%;}
  .hero .actions{gap:.75rem;}
  .btn{padding:.8rem 1.4rem;}
}

@media (prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:1ms!important;animation-iteration-count:1!important;transition-duration:1ms!important;scroll-behavior:auto!important;}
  .reveal{opacity:1;transform:none;}
  body.page-enter #content,
  body.page-enter.page-enter-active #content,
  body.page-exit #content,
  body.page-exit.page-exit-active #content{
    transition:none!important;
    opacity:1!important;
    transform:none!important;
    filter:none!important;
    pointer-events:auto!important;
  }
}

/* ========================================
   ADDITIONAL RESPONSIVE IMPROVEMENTS
   ======================================== */

/* Ensure images never break layout */
img, video, iframe {
  max-width: 100%;
  height: auto;
}

/* Responsive container improvements */
@media (max-width: 1200px) {
  .container {
    width: min(94%, var(--max-width));
  }
}

@media (max-width: 900px) {
  .container {
    width: min(96%, var(--max-width));
  }
}

/* Responsive sections */
@media (max-width: 780px) {
  .section {
    padding: 3.25rem 0;
  }
  
  .hero {
    padding: 4rem 0 3rem;
  }
}

@media (max-width: 560px) {
  .section {
    padding: 2.75rem 0;
  }
  
  .hero {
    padding: 3.5rem 0 2.5rem;
  }
}

/* Better text wrapping */
h1, h2, h3, h4, h5, h6, p, li {
  overflow-wrap: break-word;
  word-wrap: break-word;
  hyphens: auto;
}

/* Prevent horizontal scroll */
body {
  overflow-x: hidden;
}

.container {
  overflow-x: hidden;
}

/* Touch device optimizations */
@media (hover: none) and (pointer: coarse) {
  /* Larger tap targets */
  .btn, a {
    min-height: 44px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
  }
  
  /* Disable hover animations on touch */
  .card:hover {
    transform: translateY(-6px);
  }
  
  .btn:hover {
    transform: translateY(-2px);
  }
  
  /* Add tactile feedback */
  .btn:active {
    transform: scale(0.96);
  }
  
  .card:active {
    transform: scale(0.98);
  }
}

/* Viewport height fix for mobile browsers */
.full-height {
  height: 100vh;
  height: calc(var(--vh, 1vh) * 100);
}

/* Responsive tables */
@media (max-width: 780px) {
  table {
    display: block;
    overflow-x: auto;
    white-space: nowrap;
  }
}

/* Better form element sizing on mobile */
@media (max-width: 640px) {
  input, textarea, select, button {
    font-size: 16px; /* Prevents zoom on iOS */
  }
}

/* Ensure decorative elements don't cause overflow */
.section-decor,
.hero-orbit,
.section-pulse,
.section-stripe,
.section-spark,
.section-aurora,
.section-orb,
.section-grid,
.section-glow,
.section-rings {
  max-width: 100vw;
}

/* Accessibility - Focus visible */
*:focus-visible {
  outline: 3px solid var(--color-accent);
  outline-offset: 3px;
}

/* Mobile menu overlay */
@media (max-width: 820px) {
  body[data-nav-open]::before {
    content: '';
    position: fixed;
    inset: 0;
    background: rgba(0,0,0,0.7);
    z-index: 9;
    backdrop-filter: blur(2px);
  }
}

/* Print optimization */
@media print {
  header, footer, .menu-toggle, .actions {
    display: none !important;
  }
  
  body {
    background: white !important;
    color: black !important;
  }
  
  .card, .section {
    page-break-inside: avoid;
  }
}

/* Loading state */
.page-loading {
  opacity: 0;
  pointer-events: none;
}

body.page-loaded .page-loading {
  opacity: 1;
  pointer-events: auto;
  transition: opacity 0.3s ease;
}

/* Smooth scroll offset for anchor links */
html {
  scroll-padding-top: 100px;
}

/* Better focus for keyboard navigation */
body.keyboard-nav *:focus {
  outline: 3px solid var(--color-accent);
  outline-offset: 3px;
}

body:not(.keyboard-nav) *:focus {
  outline: none;
}

/* Ensure background effects don't cause performance issues */
@media (max-width: 780px) {
  body::before,
  body::after,
  .hero::before,
  .hero::after {
    display: none;
  }
}

/* Better line height for readability */
p, li {
  line-height: 1.7;
}

@media (max-width: 640px) {
  p, li {
    line-height: 1.6;
  }
}

/* Ensure buttons are always clickable */
.btn {
  position: relative;
  z-index: 1;
}

/* Lazy loading placeholder */
img[loading="lazy"]:not(.loaded) {
  background: linear-gradient(90deg, var(--color-surface) 0%, var(--color-surface-alt) 50%, var(--color-surface) 100%);
  background-size: 200% 100%;
  animation: shimmer 1.5s infinite;
}

@keyframes shimmer {
  0% { background-position: 200% 0; }
  100% { background-position: -200% 0; }
}

img.loaded {
  animation: fadeIn 0.3s ease;
}

/* Mobile Safari fixes */
@supports (-webkit-touch-callout: none) {
  /* Fix for iOS Safari viewport height */
  .hero,
  .section {
    min-height: -webkit-fill-available;
  }
}

/* Stats Section */
.card--stat {
  text-align: center;
  padding: 2.5rem 1.5rem;
  background: linear-gradient(145deg, rgba(26,22,50,0.95), rgba(23,20,44,0.88));
  border: 1px solid rgba(139,92,246,0.25);
  position: relative;
  overflow: hidden;
}
.card--stat::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: linear-gradient(145deg, rgba(139,92,246,0.4), rgba(34,211,238,0.3));
  opacity: 0;
  border-radius: inherit;
  transition: opacity var(--motion-medium) ease;
  z-index: -1;
}
.card--stat:hover::before {
  opacity: 0.35;
}
.stat-icon {
  width: 64px;
  height: 64px;
  margin: 0 auto 1.5rem;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: var(--radius-md);
  animation: float 3s ease-in-out infinite;
}
@keyframes float {
  0%, 100% { transform: translateY(0px); }
  50% { transform: translateY(-8px); }
}
.stat-content {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
}
.stat-number {
  font-family: "Anton", sans-serif;
  font-size: clamp(2.2rem, 3.5vw, 3.5rem);
  background: linear-gradient(135deg, #fff, rgba(139,92,246,0.85), rgba(34,211,238,0.95));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin: 0;
  line-height: 1.1;
}
.stat-label {
  color: rgba(226,225,255,0.75);
  font-size: 0.95rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
  font-weight: 600;
  margin: 0;
}

/* Partner Section */
.partner-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem;
  margin-bottom: 3rem;
}
.partner-logo {
  background: rgba(255,255,255,0.04);
  border: 1px solid rgba(255,255,255,0.08);
  border-radius: var(--radius-md);
  padding: 2rem;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--motion-medium) ease;
  position: relative;
  overflow: hidden;
}
.partner-logo::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: linear-gradient(145deg, rgba(139,92,246,0.6), rgba(34,211,238,0.4));
  opacity: 0;
  border-radius: inherit;
  transition: opacity var(--motion-medium) ease;
  z-index: -1;
}
.partner-logo:hover {
  transform: translateY(-6px);
  border-color: rgba(139,92,246,0.35);
  box-shadow: 0 12px 32px rgba(139,92,246,0.25);
}
.partner-logo:hover::before {
  opacity: 0.25;
}
.partner-logo img {
  max-width: 100%;
  height: auto;
  object-fit: contain;
  filter: brightness(0.9) contrast(1.1);
  transition: filter var(--motion-medium) ease;
}
.partner-logo:hover img {
  filter: brightness(1.1) contrast(1.2);
}
.partner-logo--placeholder {
  background: linear-gradient(145deg, rgba(26,22,50,0.5), rgba(23,20,44,0.4));
  border-style: dashed;
  border-color: rgba(139,92,246,0.25);
  min-height: 180px;
  font-size: 0.9rem;
  color: rgba(226,225,255,0.45);
  text-align: center;
  display: flex;
  align-items: center;
  justify-content: center;
  font-weight: 600;
  letter-spacing: 0.05em;
}
.card-icon {
  font-size: 2.5rem;
  margin-bottom: 1rem;
  display: inline-block;
  filter: drop-shadow(0 4px 12px rgba(139,92,246,0.4));
}
.card h3 {
  margin-bottom: 0.75rem;
  font-family: "Anton", sans-serif;
  font-size: 1.5rem;
  color: #fff;
}
.card p {
  color: rgba(226,225,255,0.7);
  line-height: 1.6;
}

/* Project Cards */
.project-card {
  position: relative;
  padding: 2.5rem 2rem;
}
.project-tag {
  display: inline-block;
  background: linear-gradient(135deg, rgba(139,92,246,0.25), rgba(34,211,238,0.2));
  border: 1px solid rgba(139,92,246,0.4);
  color: #fff;
  padding: 0.5rem 1rem;
  border-radius: 999px;
  font-size: 0.9rem;
  font-weight: 700;
  margin-bottom: 1.5rem;
  letter-spacing: 0.05em;
}
.project-stats {
  list-style: none;
  padding: 0;
  margin: 1.5rem 0;
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 1rem;
}
.project-stats li {
  background: rgba(139,92,246,0.12);
  border: 1px solid rgba(139,92,246,0.25);
  padding: 0.75rem 1rem;
  border-radius: 8px;
  text-align: center;
  font-size: 0.9rem;
  color: rgba(226,225,255,0.75);
}
.project-stats strong {
  display: block;
  font-family: "Anton", sans-serif;
  font-size: 1.6rem;
  background: linear-gradient(135deg, #fff, rgba(139,92,246,0.9));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 0.25rem;
}

/* Benefits Grid (Partner CTA) */
.card--gradient {
  background: linear-gradient(145deg, rgba(26,22,50,0.98), rgba(23,20,44,0.92));
  border: 1px solid rgba(139,92,246,0.3);
  position: relative;
  overflow: hidden;
}
.card--gradient::before {
  content: "";
  position: absolute;
  inset: -2px;
  background: linear-gradient(145deg, rgba(139,92,246,0.5), rgba(34,211,238,0.35));
  opacity: 0.15;
  border-radius: inherit;
  z-index: -1;
}
.benefits-content {
  position: relative;
  z-index: 1;
}
.benefits-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 2rem;
  margin-bottom: 2rem;
}
.benefit-item {
  text-align: center;
}
.benefit-icon {
  font-size: 2.5rem;
  display: block;
  margin-bottom: 0.75rem;
  filter: drop-shadow(0 4px 12px rgba(139,92,246,0.4));
}
.benefit-item strong {
  display: block;
  font-size: 1.1rem;
  margin-bottom: 0.5rem;
  color: #fff;
  font-weight: 700;
}
.benefit-item p {
  font-size: 0.9rem;
  color: rgba(226,225,255,0.65);
  margin: 0;
}
.btn-lg {
  padding: 1rem 2.5rem;
  font-size: 1.1rem;
  font-weight: 700;
}

/* Testimonial Cards */
.testimonial-card {
  display: flex;
  flex-direction: column;
  gap: 1.5rem;
  padding: 2rem;
}
.testimonial-header {
  display: flex;
  align-items: center;
  gap: 1rem;
}
.testimonial-avatar {
  width: 60px;
  height: 60px;
  border-radius: 50%;
  overflow: hidden;
  border: 2px solid rgba(139,92,246,0.4);
  flex-shrink: 0;
}
.testimonial-avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}
.testimonial-avatar--placeholder {
  background: linear-gradient(145deg, rgba(139,92,246,0.2), rgba(34,211,238,0.15));
  display: flex;
  align-items: center;
  justify-content: center;
  color: rgba(226,225,255,0.6);
}
.testimonial-header strong {
  display: block;
  font-size: 1.1rem;
  color: #fff;
  margin-bottom: 0.25rem;
}
.testimonial-header span {
  display: block;
  font-size: 0.85rem;
  color: rgba(226,225,255,0.55);
  font-weight: 600;
  letter-spacing: 0.05em;
}
.testimonial-card blockquote {
  font-size: 1rem;
  line-height: 1.7;
  color: rgba(226,225,255,0.85);
  font-style: italic;
  margin: 0;
  padding: 0;
  border: none;
  position: relative;
}
.testimonial-card blockquote::before {
  content: '"';
  position: absolute;
  left: -1.5rem;
  top: -0.5rem;
  font-size: 4rem;
  color: rgba(139,92,246,0.25);
  font-family: Georgia, serif;
  line-height: 1;
}
.testimonial-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  margin-top: auto;
  padding-top: 1.5rem;
  border-top: 1px solid rgba(255,255,255,0.08);
}
.testimonial-stats > div {
  text-align: center;
}
.testimonial-stats strong {
  display: block;
  font-family: "Anton", sans-serif;
  font-size: 1.4rem;
  background: linear-gradient(135deg, #fff, rgba(139,92,246,0.85));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-bottom: 0.25rem;
}
.testimonial-stats div {
  font-size: 0.8rem;
  color: rgba(226,225,255,0.6);
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

/* Map Code Display */
.map-code {
  background: rgba(139,92,246,0.12);
  border: 1px solid rgba(139,92,246,0.3);
  border-radius: var(--radius-md);
  padding: 1.25rem;
  margin: 1.5rem 0;
  text-align: center;
}
.map-code strong {
  display: block;
  margin-bottom: 0.5rem;
  color: rgba(226,225,255,0.75);
  font-size: 0.9rem;
  text-transform: uppercase;
  letter-spacing: 0.08em;
}
.map-code code {
  font-family: "Courier New", Courier, monospace;
  font-size: 1.8rem;
  font-weight: 700;
  background: linear-gradient(135deg, #fff, rgba(139,92,246,0.9));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  letter-spacing: 0.1em;
  display: inline-block;
  padding: 0.5rem 1rem;
  border-radius: 8px;
  background-color: rgba(0,0,0,0.2);
  user-select: all;
  cursor: pointer;
  transition: all var(--motion-medium) ease;
}
.map-code code:hover {
  background-color: rgba(139,92,246,0.25);
  transform: scale(1.05);
}

/* Modal (Discord join) */
.modal[hidden]{display:none!important;}
.modal{position:fixed;inset:0;z-index:10000;display:grid;place-items:center;}
.modal__overlay{position:absolute;inset:0;background:rgba(8,7,18,0.75);backdrop-filter:blur(4px);}
.modal__dialog{position:relative;background:var(--color-surface);border:1px solid rgba(255,255,255,0.08);border-radius:var(--radius-md);box-shadow:var(--shadow-card);padding:1.5rem;max-width:min(92vw,520px);width:100%;}
.modal__header h2{margin:0 0 .5rem;font-family:"Anton",sans-serif;}
.modal__body p{color:var(--color-muted);}
.modal__fineprint{font-size:.85rem;opacity:.8;margin-top:.75rem}
.modal__close{position:absolute;top:.6rem;right:.6rem;background:transparent;border:0;color:#fff;font-size:1.25rem;cursor:pointer;opacity:.8}
.btn-block{display:block;width:100%;text-align:center;margin-top:.75rem}
