/* CSS Variables - Theme Tokens */
:root {
  --bg:     #04040d;
  --bg2:    #070713;
  --bg3:    #0a0a1f;
  --b:      #1d4ed8;
  --p:      #6d28d9;
  --b2:     #3b82f6;
  --p2:     #8b5cf6;
  --gt:     linear-gradient(130deg,#3b82f6 0%,#8b5cf6 50%,#a78bfa 100%);
  --gts:    linear-gradient(130deg,#1d4ed8,#6d28d9);
  --text:   #eeeeff;
  --sub:    #6b6b9a;
  --line:   rgba(109,40,217,.16);
  --line2:  rgba(61,130,246,.2);
}

*, *::before, *::after { margin: 0; padding: 0; box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'DM Sans', sans-serif;
  font-weight: 300;
  overflow-x: hidden;
  cursor: none;
}

/* Typography */
h1, h2, h3, h4, h5, h6 {
  font-family: 'Bricolage Grotesque', sans-serif;
  font-weight: 800;
  letter-spacing: -.04em;
}

/* Cursor */
#cr  { width:8px;height:8px;background:#8b5cf6;border-radius:50%;position:fixed;pointer-events:none;z-index:9999;transform:translate(-50%,-50%);transition:transform .1s,background .2s; }
#crf { width:28px;height:28px;border:1px solid rgba(139,92,246,.5);border-radius:50%;position:fixed;pointer-events:none;z-index:9998;transform:translate(-50%,-50%);transition:transform .3s ease,width .25s,height .25s,border-color .25s; }

/* Nav */
nav {
  position:fixed;
  top:0;
  left:0;
  right:0;
  z-index:500;
  padding:28px 72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  transition:padding .4s,background .4s,border .4s,box-shadow .4s;
}
nav.sc {
  padding:18px 72px;
  background:rgba(4,4,13,.75);
  backdrop-filter:blur(20px) saturate(180%);
  -webkit-backdrop-filter:blur(20px) saturate(180%);
  border-bottom:1px solid rgba(139,92,246,.15);
  box-shadow:0 4px 30px rgba(0,0,0,.3);
}

.logo-mark svg {
  width:38px;
  height:38px;
  filter:drop-shadow(0 0 14px rgba(139,92,246,.7));
  transition:transform .3s,filter .3s;
}
.nav-logo:hover .logo-mark svg {
  transform:scale(1.1) rotate(5deg);
  filter:drop-shadow(0 0 20px rgba(139,92,246,.9));
}
.logo-word {
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;
  font-size:22px;
  letter-spacing:-.5px;
}
.logo-word .lw {
  background:var(--gt);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.logo-word .la {
  font-size:13px;
  font-weight:500;
  letter-spacing:.05em;
  color:var(--sub);
  margin-left:2px;
}
.nav-logo {
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
}

.nav-links {
  display:flex;
  gap:38px;
  list-style:none;
}
.nav-links a {
  color:rgba(255,255,255,.75);
  text-decoration:none;
  font-size:14px;
  font-weight:500;
  letter-spacing:.02em;
  transition:color .25s;
  position:relative;
  padding:8px 0;
}
.nav-links a::after {
  content:'';
  position:absolute;
  bottom:0;
  left:0;
  right:0;
  height:2px;
  background:var(--gt);
  transform:scaleX(0);
  transition:transform .3s ease;
  transform-origin:left;
  border-radius:2px;
}
.nav-links a:hover,
.nav-links a.active {
  color:#fff;
}
.nav-links a:hover::after,
.nav-links a.active::after {
  transform:scaleX(1);
}

.nav-btn {
  padding:12px 32px;
  background:var(--gts);
  border:none;
  border-radius:100px;
  color:#fff;
  font-family:'DM Sans',sans-serif;
  font-size:13px;
  font-weight:500;
  cursor:none;
  letter-spacing:.04em;
  box-shadow:0 0 28px rgba(109,40,217,.5);
  transition:transform .2s,box-shadow .3s,background .3s;
  position:relative;
  overflow:hidden;
}
.nav-btn::before {
  content:'';
  position:absolute;
  inset:0;
  background:linear-gradient(130deg,rgba(255,255,255,.2) 0%,transparent 50%);
  transform:translateX(-100%);
  transition:transform .5s;
}
.nav-btn:hover::before {
  transform:translateX(100%);
}
.nav-btn:hover {
  transform:scale(1.05);
  box-shadow:0 0 50px rgba(109,40,217,.8);
}

/* Footer */
footer {
  position:relative;
  padding:80px 72px 40px;
  border-top:1px solid var(--line);
  background:linear-gradient(to bottom,var(--bg) 0%,var(--bg2) 100%);
  overflow:hidden;
}
footer::before {
  content:'';
  position:absolute;
  top:0;
  left:50%;
  transform:translateX(-50%);
  width:600px;
  height:600px;
  background:radial-gradient(circle,rgba(109,40,217,.08) 0%,transparent 70%);
  pointer-events:none;
  animation:pulse 8s ease-in-out infinite;
}
@keyframes pulse {
  0%,100% { transform:translateX(-50%) scale(1); opacity:.8; }
  50% { transform:translateX(-50%) scale(1.2); opacity:.4; }
}
.footer-content {
  position:relative;
  z-index:2;
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:60px;
  margin-bottom:60px;
}
.footer-brand {
  max-width:320px;
}
.f-logo {
  display:flex;
  align-items:center;
  gap:10px;
  text-decoration:none;
  margin-bottom:20px;
}
.f-logo svg {
  width:40px;
  height:40px;
  filter:drop-shadow(0 0 12px rgba(139,92,246,.6));
  animation:float 3s ease-in-out infinite;
}
@keyframes float {
  0%,100% { transform:translateY(0); }
  50% { transform:translateY(-8px); }
}
.f-logo-txt {
  font-family:'Bricolage Grotesque',sans-serif;
  font-weight:800;
  font-size:22px;
}
.f-logo-txt span {
  background:var(--gt);
  -webkit-background-clip:text;
  -webkit-text-fill-color:transparent;
}
.f-logo-txt small {
  font-size:12px;
  color:var(--sub);
  margin-left:2px;
}
.footer-brand p {
  font-size:14px;
  color:var(--sub);
  line-height:1.7;
  margin-bottom:24px;
}
.footer-social {
  display:flex;
  gap:12px;
}
.social-link {
  width:40px;
  height:40px;
  border-radius:10px;
  background:var(--bg3);
  border:1px solid var(--line);
  display:flex;
  align-items:center;
  justify-content:center;
  text-decoration:none;
  transition:transform .2s,border-color .3s,background .3s;
}
.social-link:hover {
  transform:translateY(-4px);
  border-color:var(--p2);
  background:rgba(139,92,246,.1);
}
.social-link svg {
  width:18px;
  height:18px;
  stroke:var(--sub);
  transition:stroke .3s;
}
.social-link:hover svg {
  stroke:var(--p2);
}
.footer-col h4 {
  font-size:14px;
  font-weight:700;
  margin-bottom:20px;
  color:var(--text);
  text-transform:uppercase;
  letter-spacing:.1em;
}
.footer-col ul {
  list-style:none;
}
.footer-col ul li {
  margin-bottom:12px;
}
.footer-col ul li a {
  font-size:14px;
  color:var(--sub);
  text-decoration:none;
  transition:color .2s,transform .2s;
  display:inline-block;
}
.footer-col ul li a:hover {
  color:var(--text);
  transform:translateX(4px);
}
.footer-bottom {
  position:relative;
  z-index:2;
  padding-top:32px;
  border-top:1px solid var(--line);
  display:flex;
  justify-content:space-between;
  align-items:center;
  flex-wrap:wrap;
  gap:20px;
}
.f-copy {
  font-size:13px;
  color:var(--sub);
}
.footer-links {
  display:flex;
  gap:24px;
}
.footer-links a {
  font-size:13px;
  color:var(--sub);
  text-decoration:none;
  transition:color .2s;
}
.footer-links a:hover {
  color:var(--text);
}

/* Burger Menu */
.burger {
  display: none;
  flex-direction: column;
  gap: 5px;
  background: none;
  border: none;
  cursor: pointer;
  padding: 8px;
  z-index: 501;
}
.burger span {
  width: 24px;
  height: 2px;
  background: var(--text);
  transition: all 0.3s;
  border-radius: 2px;
}

.mobile-menu {
  position: fixed;
  top: 0;
  right: -100%;
  width: 280px;
  height: 100vh;
  background: var(--bg2);
  border-left: 1px solid var(--line);
  z-index: 600;
  transition: right 0.4s ease;
  padding: 80px 30px 30px;
  overflow-y: auto;
}
.mobile-menu.open {
  right: 0;
}
.close-menu {
  position: absolute;
  top: 20px;
  right: 20px;
  background: none;
  border: none;
  color: var(--text);
  font-size: 28px;
  cursor: pointer;
  padding: 8px;
  line-height: 1;
}
.mobile-menu ul {
  list-style: none;
  display: flex;
  flex-direction: column;
  gap: 20px;
}
.mobile-menu ul li a {
  color: var(--text);
  text-decoration: none;
  font-size: 16px;
  font-weight: 500;
  display: block;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
  transition: color 0.3s;
}
.mobile-menu ul li a:hover {
  color: var(--p2);
}
.mobile-cta {
  background: var(--gts);
  border-radius: 100px;
  padding: 14px 24px !important;
  text-align: center;
  margin-top: 20px;
  border: none !important;
}

/* Animations */
@keyframes fu { from{opacity:0;transform:translateY(24px)} to{opacity:1;transform:translateY(0)} }
.rv { opacity:0;transform:translateY(28px);transition:opacity .7s ease,transform .7s ease; }
.rv.in { opacity:1;transform:translateY(0); }

/* Mobile Responsive */
@media (max-width: 768px) {
  /* Nav */
  nav {
    padding: 20px 20px;
  }
  nav.sc {
    padding: 14px 20px;
  }

  .nav-links {
    display: none;
  }

  .nav-btn {
    display: none;
  }

  .burger {
    display: flex;
  }

  /* Footer */
  footer {
    padding: 60px 20px 30px;
  }

  .footer-content {
    grid-template-columns: 1fr;
    gap: 40px;
  }

  .footer-bottom {
    flex-direction: column;
    text-align: center;
  }
}
