@import url("https://fonts.googleapis.com/css2?family=Poppins:wght@400;500;600;700;800&display=swap");

:root{
  --bg1:#120013;
  --bg2:#0a0614;

  --text:#f4efff;
  --muted: rgba(244,239,255,.74);

  --navBg: rgba(255,255,255,.06);
  --border: rgba(255,255,255,.14);

  --btn: #f4efff;
  --btnText:#170019;

  --accent:#c55cff;
  --accent2:#7cf7d2;

  --shadow: 0 24px 70px rgba(0,0,0,.45);

  --max: 1120px;
  --pad: 24px;
  --radius: 22px;
}

*{ box-sizing:border-box; }
html{ scroll-behavior:smooth; }
body{
  margin:0;
  font-family: Poppins, ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Arial, "Noto Sans", "Liberation Sans", sans-serif;
  color: var(--text);
  background:
    radial-gradient(900px 560px at 85% 35%, rgba(178,76,240,.42), transparent 60%),
    radial-gradient(820px 520px at 15% 85%, rgba(122,26,166,.30), transparent 62%),
    linear-gradient(180deg, var(--bg1), var(--bg2));
  min-height: 100vh;
}

a{ color:inherit; text-decoration:none; }
.container{ width:min(var(--max), calc(100% - 2*var(--pad))); margin:0 auto; }

.sr-only{
  position:absolute; width:1px; height:1px; padding:0; margin:-1px; overflow:hidden;
  clip:rect(0,0,0,0); white-space:nowrap; border:0;
}

/* Animated background visuals */
.bg{
  position: fixed;
  inset: 0;
  z-index: 0;
  pointer-events: none;
  overflow: hidden;
}
.topbar, .hero, .section, .footer{
  position: relative;
  z-index: 1;
}

/* Moving grid */
.bg-grid{
  position:absolute;
  inset:-40%;
  background:
    linear-gradient(to right, rgba(255,255,255,.06) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.06) 1px, transparent 1px);
  background-size: 64px 64px;
  opacity: .08;
  transform: rotate(12deg);
  animation: grid-drift 18s linear infinite;
  mask-image: radial-gradient(circle at 40% 30%, rgba(0,0,0,1), rgba(0,0,0,.1) 55%, rgba(0,0,0,0) 75%);
}
@keyframes grid-drift{
  0%{ transform: translate3d(0,0,0) rotate(12deg); }
  100%{ transform: translate3d(-160px, 120px, 0) rotate(12deg); }
}

/* Glowing blobs */
.bg-blobs{ position:absolute; inset:0; }
.blob{
  position:absolute;
  width: 520px;
  height: 520px;
  border-radius: 999px;
  filter: blur(42px);
  opacity: .55;
  mix-blend-mode: screen;
  animation: blob-float 10s ease-in-out infinite;
}
.blob-1{
  left: -160px;
  top: -120px;
  background: radial-gradient(circle at 30% 30%, rgba(197,92,255,.85), rgba(197,92,255,0) 60%);
  animation-duration: 12s;
}
.blob-2{
  right: -180px;
  top: 10%;
  background: radial-gradient(circle at 30% 30%, rgba(178,76,240,.80), rgba(178,76,240,0) 60%);
  animation-duration: 14s;
  animation-delay: -3s;
}
.blob-3{
  left: 12%;
  bottom: -220px;
  width: 640px;
  height: 640px;
  background: radial-gradient(circle at 30% 30%, rgba(124,247,210,.55), rgba(124,247,210,0) 60%);
  animation-duration: 16s;
  animation-delay: -5s;
}
@keyframes blob-float{
  0%,100%{ transform: translate3d(0,0,0) scale(1); }
  50%{ transform: translate3d(40px,-28px,0) scale(1.05); }
}

/* Mouse spotlight */
.bg-spotlight{
  position:absolute;
  inset:0;
  opacity: .65;
  background: radial-gradient(260px 260px at 50% 40%, rgba(255,255,255,.12), transparent 60%);
  transition: opacity .3s ease;
  will-change: background;
}

/* Mobile menu backdrop */
.menu-backdrop{
  position: fixed;
  inset: 0;
  z-index: 90;
  background: rgba(0,0,0,.35);
  backdrop-filter: blur(8px);
}

/* Topbar */
.topbar{
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 100;
}
.topbar-inner{
  display:flex; align-items:center; justify-content:space-between;
  padding: 22px 0;
  gap: 14px;
}

.logo{ display:inline-flex; align-items:center; justify-content:center; }
.logo-text{
  display:inline-flex;
  align-items:center;
  gap: 8px;
  padding: 10px 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.08);
  border: 1px solid var(--border);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 40px rgba(0,0,0,.25);
  font-weight: 800;
  letter-spacing: .02em;
  color: var(--text);
}
.logo-text span{ color: var(--accent2); font-weight: 800; }

.nav{
  display:flex; align-items:center; gap: 18px;
  padding: 10px 16px;
  border-radius: 999px;
  border: 1px solid var(--border);
  background: var(--navBg);
  backdrop-filter: blur(12px);
  box-shadow: 0 18px 50px rgba(0,0,0,.20);
}

.nav-link{
  font-size: .92rem;
  font-weight: 600;
  opacity: .88;
  position: relative;
  padding: 6px 8px;
  color: var(--text);
  transition: opacity .2s ease, transform .2s ease;
}
.nav-link:hover{ opacity: 1; transform: translateY(-1px); }

.nav-link.active::after{
  content:"";
  position:absolute;
  left: 10px; right: 10px; bottom: -6px;
  height: 3px;
  border-radius: 999px;
  background: linear-gradient(90deg, var(--accent), var(--accent2));
}

body.menu-open{
  overflow: hidden;
}

.nav-cta{
  padding: 10px 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: linear-gradient(90deg, rgba(197,92,255,.35), rgba(124,247,210,.18));
  color: var(--text);
  font-weight: 700;
  box-shadow: 0 20px 55px rgba(0,0,0,.25);
  transition: transform .18s ease;
}
.nav-cta:hover{ transform: translateY(-1px); }

.menu-btn{ display:none; }

/* Mobile menu overlay */
.mobile-nav{
  position: fixed;
  top: 84px; /* under the topbar */
  left: 0;
  right: 0;
  z-index: 110;
  padding: 0 18px;
}
.mobile-nav-card{
  max-width: 520px;
  margin: 0 auto;
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.40);
  backdrop-filter: blur(16px);
  box-shadow: 0 24px 70px rgba(0,0,0,.45);
  padding: 14px;
  display:flex;
  flex-direction: column;
  gap: 10px;
}
.mobile-nav-card a{
  padding: 12px 12px;
  border-radius: 14px;
  font-weight: 700;
  opacity: .95;
}
.mobile-nav-card a:hover{
  background: rgba(255,255,255,.06);
}
.nav-cta-mobile{
  margin-top: 6px;
  display:flex;
  justify-content:center;
}

.hero{
  padding-top: 92px;
  min-height: 100vh;
  display:flex;
  position: relative;
}

.hero-grid{
  display:grid;
  grid-template-columns: 1.1fr .9fr;
  gap: 32px;
  align-items: center;
  padding: 28px 0 30px;
}

.kicker{
  margin: 0 0 16px;
  font-size: .78rem;
  letter-spacing: .14em;
  text-transform: uppercase;
  opacity: .9;
}

.headline{ margin:0; line-height: 1.08; }
.headline-name{ font-weight: 700; opacity: .95; }
.headline-big{
  display:inline-block;
  margin-top: 8px;
  font-size: clamp(2.1rem, 4.8vw, 3.4rem);
  font-weight: 800;
}
.headline-accent{ color: var(--accent); text-shadow: 0 0 30px rgba(197,92,255,.25); }
.headline-accent2{ color: var(--accent2); text-shadow: 0 0 30px rgba(124,247,210,.20); }

.subtext{
  margin: 14px 0 22px;
  color: var(--muted);
  max-width: 62ch;
  font-size: .98rem;
  line-height: 1.75;
}

.hero-actions{
  display:flex;
  gap: 14px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  padding: 12px 18px;
  border-radius: 999px;
  border: 1px solid transparent;
  font-weight: 700;
  font-size: .95rem;
  letter-spacing: .01em;
  color: var(--btnText);
  background: var(--btn);
  box-shadow: 0 20px 55px rgba(0,0,0,.25);
  transition: transform .18s ease, box-shadow .18s ease, background .18s ease, border-color .18s ease;
  will-change: transform;
}
.btn:hover{ transform: translateY(-2px); }
.btn:active{ transform: translateY(0); }

.btn-primary{ background: linear-gradient(180deg, #ffffff, #f3e9ff); color: #170019; }
.btn-outline{
  background: transparent;
  color: var(--text);
  border-color: rgba(255,255,255,.28);
  box-shadow: none;
}
.btn-outline:hover{ background: rgba(255,255,255,.06); }

.social-row{
  display:flex;
  gap: 12px;
  margin-top: 8px;
}
.social{
  width: 42px; height: 42px;
  display:inline-flex;
  align-items:center;
  justify-content:center;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.06);
  color: var(--text);
  font-weight: 700;
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
  transition: transform .18s ease, background .18s ease, border-color .18s ease;
}
.social:hover{
  transform: translateY(-3px) scale(1.03);
  background: rgba(255,255,255,.10);
  border-color: rgba(255,255,255,.28);
}
.social svg{ display:block; }

.stats{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-top: 18px;
}
.stat{ padding: 14px; }
.stat-num{ font-weight: 800; font-size: 1.05rem; }

.hero-right{ display:flex; justify-content:center; }
.frame{
  width: min(520px, 100%);
  aspect-ratio: 1 / 1;
  border-radius: 44px;
  background: radial-gradient(circle at 30% 30%, rgba(255,255,255,.10), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.14);
  box-shadow: var(--shadow);
  position: relative;
  transform: rotate(-10deg);
  display:flex;
  align-items:center;
  justify-content:center;
  transition: transform .35s ease;
  will-change: transform;
}
.frame:hover{ transform: rotate(-10deg) translateY(-6px); }

.frame img{
  width: 82%;
  height: 82%;
  object-fit: cover;
  border-radius: 32px;
  transform: rotate(10deg);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.25);
}

.frame-pill{
  position:absolute;
  width: 56px; height: 14px;
  border-radius: 999px;
  background: rgba(255,255,255,.14);
  border: 1px solid rgba(255,255,255,.18);
}
.frame-pill-1{ top: 12%; left: 12%; transform: rotate(35deg); }
.frame-pill-2{ bottom: 18%; left: 6%; transform: rotate(-30deg); }
.frame-pill-3{ top: 18%; right: 10%; transform: rotate(-20deg); }

.scroll-down{
  position: absolute;
  left: 50%;
  bottom: 22px;
  transform: translateX(-50%);
  width: 44px; height: 44px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  background: rgba(255,255,255,.08);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color: var(--text);
  box-shadow: 0 18px 50px rgba(0,0,0,.18);
}

.section{ padding: 74px 0; }
.section-alt{
  background: rgba(255,255,255,.03);
  border-top: 1px solid rgba(255,255,255,.08);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
h2{ margin:0 0 10px; font-size: 1.65rem; }
h3{ margin: 16px 0 10px; font-size: 1.12rem; }
.subhead{ margin-top: 24px; }
.muted{ color: var(--muted); line-height: 1.75; }

.two-col{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap: 14px;
  margin-top: 14px;
}

.cards{
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-top: 16px;
}
.card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.05);
  padding: 18px;
  box-shadow: 0 20px 55px rgba(0,0,0,.22);
  transition: transform .22s ease, box-shadow .22s ease, border-color .22s ease;
}
.card:hover{
  transform: translateY(-6px);
  border-color: rgba(255,255,255,.22);
  box-shadow: 0 30px 80px rgba(0,0,0,.35);
}

.list{ margin: 0; padding-left: 18px; color: var(--muted); line-height: 1.8; }

.pill-grid{
  display:flex;
  flex-wrap:wrap;
  gap: 10px;
  margin-top: 14px;
}
.pill{
  padding: 9px 12px;
  border-radius: 999px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  font-weight: 700;
}
.pill-soft{ background: rgba(197,92,255,.10); border-color: rgba(197,92,255,.22); }

.tags{ display:flex; flex-wrap:wrap; gap: 8px; margin: 12px 0 6px; }
.tag{
  font-size: .82rem;
  padding: 6px 10px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(124,247,210,.10);
  font-weight: 700;
}
.card-links{ display:flex; gap: 14px; margin-top: 10px; }
.link{
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 4px;
  opacity: .9;
}
.link:hover{ opacity: 1; }

.timeline{
  display:grid;
  grid-template-columns: 1fr;
  gap: 12px;
  margin-top: 16px;
}
.t-title{ font-weight: 800; margin-bottom: 6px; }

.form{ margin-top: 14px; }
.form-row{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 12px;
}
label span{ display:block; font-weight: 700; margin-bottom: 6px; }

input, textarea{
  width: 100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.16);
  background: rgba(0,0,0,.22);
  color: var(--text);
  padding: 12px 12px;
  font: inherit;
  outline: none;
}
input:focus, textarea:focus{
  border-color: rgba(124,247,210,.35);
  box-shadow: 0 0 0 4px rgba(124,247,210,.10);
}
.form-actions{
  display:flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 12px;
}
.tiny{ font-size: .9rem; margin: 10px 0 0; }

.footer{ padding: 28px 0 44px; }
.footer-inner{ display:flex; justify-content:space-between; gap: 12px; flex-wrap:wrap; }

/* Scroll reveal animations */
.reveal{
  opacity: 0;
  transform: translateY(18px);
  filter: blur(6px);
  transition: opacity .7s ease, transform .7s ease, filter .7s ease;
}
.reveal.is-visible{
  opacity: 1;
  transform: translateY(0);
  filter: blur(0);
}
.reveal.reveal-left{ transform: translateX(-22px); }
.reveal.reveal-right{ transform: translateX(22px); }
.reveal.reveal-left.is-visible,
.reveal.reveal-right.is-visible{ transform: translateX(0); }

.stagger > *{
  opacity: 0;
  transform: translateY(14px);
  transition: opacity .6s ease, transform .6s ease;
}
.stagger.is-visible > *{
  opacity: 1;
  transform: translateY(0);
}
.stagger.is-visible > *:nth-child(1){ transition-delay: .05s; }
.stagger.is-visible > *:nth-child(2){ transition-delay: .12s; }
.stagger.is-visible > *:nth-child(3){ transition-delay: .19s; }
.stagger.is-visible > *:nth-child(4){ transition-delay: .26s; }
.stagger.is-visible > *:nth-child(5){ transition-delay: .33s; }
.stagger.is-visible > *:nth-child(6){ transition-delay: .40s; }

/* reduced motion */
@media (prefers-reduced-motion: reduce){
  .bg-grid, .blob{ animation: none !important; }
  .bg-spotlight{ transition: none !important; }
  .reveal, .stagger > *, .btn, .card, .social, .nav-link, .frame, .nav-cta{
    transition: none !important;
    transform: none !important;
    filter: none !important;
  }
}

/* Responsive */
@media (max-width: 980px){
  .nav, .nav-cta{ display:none; }

  .menu-btn{
    display:inline-flex;
    width: 50px; height: 50px;
    border-radius: 16px;
    border: 1px solid rgba(255,255,255,.18);
    background: rgba(255,255,255,.10);
    color: var(--text);
    align-items:center;
    justify-content:center;
    box-shadow: 0 20px 60px rgba(0,0,0,.25);
  }
  .menu-lines{
    width: 18px; height: 2px; background: currentColor; position: relative;
  }
  .menu-lines::before,.menu-lines::after{
    content:""; position:absolute; left:0; width:18px; height:2px; background: currentColor;
  }
  .menu-lines::before{ top:-6px; }
  .menu-lines::after{ top: 6px; }

  .hero-grid{ grid-template-columns: 1fr; }
  .frame{ width: min(520px, 92%); margin: 10px auto 0; }
  .cards{ grid-template-columns: 1fr; }
  .two-col{ grid-template-columns: 1fr; }
  .form-row{ grid-template-columns: 1fr; }
  .stats{ grid-template-columns: 1fr; }
  .scroll-down{ display:none; }
}
