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

:root{
  --bg:#06040F;
  --bg2:#080612;
  --card:#0D0A1A;
  --card2:#110E20;
  --border:#1E1830;
  --border2:#2E2848;
  --purple:#7C3AED;
  --purple2:#A855F7;
  --purple3:#C084FC;
  --purple-glow:rgba(124,58,237,0.25);
  --cyan:#22D3EE;
  --green:#10B981;
  --text:#F0ECFF;
  --muted:#ACA4C8;
  --white:#FFFFFF;
}

html{scroll-behavior:smooth;scroll-padding-top:66px;overflow-x:hidden}

body{
  background:var(--bg);
  color:var(--text);
  font-family:'Plus Jakarta Sans',sans-serif;
  overflow-x:hidden;
}

/* ── ANIMATIONS ── */
@keyframes fadeUp{from{opacity:0;transform:translateY(28px)}to{opacity:1;transform:translateY(0)}}
@keyframes fadeIn{from{opacity:0}to{opacity:1}}
@keyframes blink{0%,100%{opacity:1}50%{opacity:0.2}}
@keyframes float{
  0%{transform:translateY(100vh) translateX(0);opacity:0}
  10%{opacity:0.7}90%{opacity:0.7}
  100%{transform:translateY(-10vh) translateX(var(--drift,30px));opacity:0}
}
@keyframes halo{0%,100%{opacity:0.4;transform:scale(1)}50%{opacity:0.9;transform:scale(1.015)}}
@keyframes bubblePop{from{opacity:0;transform:scale(0)}to{opacity:1;transform:scale(1)}}
@keyframes bubblePulse{
  0%,100%{box-shadow:0 0 20px rgba(124,58,237,0.6),0 0 40px rgba(124,58,237,0.3)}
  50%{box-shadow:0 0 30px rgba(124,58,237,0.9),0 0 60px rgba(124,58,237,0.5)}
}

/* ── SCROLL REVEAL ── */
.reveal{opacity:0;transform:translateY(22px);transition:opacity 0.7s ease,transform 0.7s ease}
.reveal.visible{opacity:1;transform:none}
.reveal-d1{transition-delay:0.1s}
.reveal-d2{transition-delay:0.2s}
.reveal-d3{transition-delay:0.3s}
.reveal-d4{transition-delay:0.4s}

/* ── NAV ── */
nav{
  position:fixed;top:0;left:0;right:0;z-index:200;
  padding:22px 52px;display:flex;align-items:center;justify-content:space-between;
  transition:all 0.4s;--nav-pad-y:22px;
}
nav.scrolled{
  background:rgba(6,4,15,0.92);backdrop-filter:blur(24px);
  border-bottom:1px solid var(--border);padding:14px 52px;--nav-pad-y:14px;
}
.nav-logo{
  display:flex;align-items:center;gap:8px;
  font-family:'Syne',sans-serif;font-weight:400;font-size:1.2rem;color:var(--white);
  text-decoration:none;letter-spacing:-0.5px;
}
.nav-logo-icon{width:44px;height:44px;flex-shrink:0}
.nav-logo span{
  background:linear-gradient(135deg,var(--purple2),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.nav-links{display:flex;align-items:center;gap:44px;list-style:none}
.nav-links a{
  font-size:0.72rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;
  color:var(--muted);text-decoration:none;transition:color 0.2s;
}
.nav-links a:hover,.nav-links a.active{color:var(--purple3)}
.nav-cta{
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  color:var(--white)!important;padding:9px 22px;border-radius:6px;
  box-shadow:0 0 20px var(--purple-glow);
}

/* ── NAV DROPDOWN ── */
.nav-links li{position:relative}
.drop-arrow{font-size:0.5rem;margin-left:4px;display:inline-block;transition:transform 0.2s;vertical-align:middle}
.nav-links li.dd-open .drop-arrow{transform:rotate(180deg)}
.nav-dropdown{
  position:absolute;top:calc(100% + var(--nav-pad-y));left:50%;
  transform:translateX(-50%) translateY(-4px);
  background:#07040F;
  border:1px solid rgba(124,58,237,0.35);border-top:2px solid var(--purple);
  border-radius:0 0 10px 10px;min-width:160px;overflow:hidden;
  opacity:0;visibility:hidden;pointer-events:none;
  transition:opacity 0.2s,transform 0.2s,visibility 0.2s;
  z-index:300;
}
.nav-links li.dd-open .nav-dropdown{opacity:1;visibility:visible;pointer-events:all;transform:translateX(-50%) translateY(0)}
.nav-dd-item{
  display:flex;align-items:center;
  padding:9px 14px;text-decoration:none;
  font-family:'DM Mono',monospace;font-size:0.65rem;
  border-left:2px solid transparent;
  border-bottom:1px solid rgba(30,24,48,0.6);
  transition:background 0.15s,border-color 0.15s;
  white-space:nowrap;
}
.nav-dd-item:last-child{border-bottom:none}
.nav-dd-item:hover{background:rgba(124,58,237,0.08);border-left-color:var(--purple2)}
.nav-dd-ln{color:rgba(107,100,133,0.35);font-size:0.58rem;width:18px;text-align:right;margin-right:12px;flex-shrink:0;user-select:none;transition:color 0.15s}
.nav-dd-item:hover .nav-dd-ln{color:var(--purple3)}
.nav-dd-var{color:var(--purple3);margin-right:5px}

/* ── HAMBURGER ── */
.hamburger{
  display:none;flex-direction:column;justify-content:center;
  gap:5px;background:none;border:none;padding:8px;
  cursor:pointer;z-index:310;min-width:44px;min-height:44px;
}
.ham-line{
  width:22px;height:2px;background:var(--text);border-radius:2px;
  transition:transform 0.3s,opacity 0.3s;transform-origin:center;
}
.hamburger.open .ham-line:nth-child(1){transform:translateY(7px) rotate(45deg)}
.hamburger.open .ham-line:nth-child(2){opacity:0;transform:scaleX(0)}
.hamburger.open .ham-line:nth-child(3){transform:translateY(-7px) rotate(-45deg)}

/* ── MOBILE MENU ── */
.mobile-menu-overlay{
  display:none;position:fixed;inset:0;z-index:280;
  background:rgba(6,4,15,0.6);backdrop-filter:blur(2px);
}
.mobile-menu-overlay.open{display:block;}
.mobile-menu{
  position:fixed;top:0;right:0;bottom:0;z-index:290;
  width:82vw;max-width:420px;
  background:rgba(8,6,18,0.98);backdrop-filter:blur(24px);
  border-left:1px solid var(--border2);
  display:flex;flex-direction:column;align-items:stretch;
  padding:20px 28px 32px;gap:0;overflow-y:auto;
  transform:translateX(100%);
  transition:transform 0.35s cubic-bezier(0.4,0,0.2,1);
}
.mobile-menu.open{transform:translateX(0)}

/* close button */
.mobile-menu-close{
  display:flex;align-items:center;justify-content:flex-end;
  margin-bottom:16px;flex-shrink:0;
}
.mobile-menu-close-btn{
  background:none;border:none;cursor:pointer;padding:6px;
  color:var(--muted);transition:color 0.2s;line-height:0;
}
.mobile-menu-close-btn:hover{color:var(--white);}

/* regular links */
.mobile-menu-link{
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.6rem;font-weight:600;
  letter-spacing:0.5px;color:var(--muted);text-decoration:none;
  padding:22px 0;min-height:68px;width:100%;
  border-bottom:1px solid var(--border);
  display:flex;align-items:center;justify-content:space-between;
  transition:color 0.2s;
}
.mobile-menu-link:hover{color:var(--purple3);}

/* services accordion */
.mobile-services-item{border-bottom:1px solid var(--border);}
.mobile-services-trigger{
  width:100%;background:none;border:none;cursor:pointer;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.6rem;font-weight:600;
  letter-spacing:0.5px;color:var(--muted);
  padding:22px 0;min-height:68px;display:flex;align-items:center;justify-content:space-between;
  transition:color 0.2s;
}
.mobile-services-trigger:hover{color:var(--purple3);}
.mobile-services-trigger.open{color:var(--purple3);}
.mobile-svc-chevron{
  width:14px;height:14px;flex-shrink:0;
  transition:transform 0.25s;
}
.mobile-services-trigger.open .mobile-svc-chevron{transform:rotate(180deg);}
.mobile-services-sub{
  max-height:0;overflow:hidden;
  transition:max-height 0.3s cubic-bezier(0.4,0,0.2,1);
  padding-left:12px;
}
.mobile-services-sub.open{max-height:500px;}
.mobile-sub-link{
  display:flex;align-items:center;gap:10px;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:1.05rem;letter-spacing:0.3px;
  color:#a59fba;text-decoration:none;padding:17px 0;min-height:58px;
  border-bottom:1px solid rgba(30,24,48,0.6);transition:color 0.2s;
}
.mobile-sub-link:last-child{border-bottom:none;}
.mobile-sub-link:hover{color:var(--purple3);}
.mobile-sub-num{color:#9666c5;font-size:0.8rem;width:20px;flex-shrink:0;}

/* cta button */
.mobile-menu-cta{
  display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  color:var(--white);font-family:'Plus Jakarta Sans',sans-serif;font-size:0.9rem;font-weight:700;
  padding:15px 20px;border-radius:8px;text-decoration:none;margin-top:auto;
  box-shadow:0 0 20px rgba(124,58,237,0.35);flex-shrink:0;
}

/* ── STICKY CTA (mobile) ── */
.sticky-cta{
  display:none;position:fixed;bottom:0;left:0;right:0;z-index:200;
  padding:12px 20px;padding-bottom:calc(12px + env(safe-area-inset-bottom,0px));
  background:rgba(6,4,15,0.96);backdrop-filter:blur(20px);
  border-top:1px solid var(--border);gap:10px;
  transform:translateY(100%);transition:transform 0.4s cubic-bezier(0.4,0,0.2,1);
}
.sticky-cta.show{transform:translateY(0)}
.sticky-call{
  flex:1;display:flex;align-items:center;justify-content:center;gap:8px;
  background:var(--card2);border:1px solid var(--border2);color:var(--text);
  font-size:0.78rem;font-weight:700;padding:13px;border-radius:10px;
  text-decoration:none;min-height:44px;
}
.sticky-quote{
  flex:2;display:flex;align-items:center;justify-content:center;gap:8px;
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  color:var(--white);font-size:0.78rem;font-weight:700;
  padding:13px;border-radius:10px;text-decoration:none;
  min-height:44px;box-shadow:0 0 20px rgba(124,58,237,0.3);
}

/* ── SCROLL DOTS ── */
.scroll-dots{display:none;justify-content:center;gap:6px;margin-top:16px}
.scroll-dot{width:6px;height:6px;border-radius:50%;background:var(--border2);transition:background 0.3s,width 0.3s}
.scroll-dot.active{background:var(--purple2);width:18px;border-radius:3px}

/* ── SHARED BUTTONS ── */
.btn-purple{
  display:inline-flex;align-items:center;gap:10px;
  background:linear-gradient(135deg,var(--purple),var(--purple2));
  color:var(--white);font-size:0.78rem;font-weight:700;
  padding:15px 28px;border-radius:8px;text-decoration:none;
  box-shadow:0 0 30px rgba(124,58,237,0.4);transition:all 0.3s;
}
.btn-purple:hover{transform:translateY(-3px);box-shadow:0 0 60px rgba(124,58,237,0.65)}
.btn-outline{
  display:inline-flex;align-items:center;gap:8px;
  border:1px solid var(--border2);color:var(--text);
  font-size:0.78rem;font-weight:600;
  padding:15px 28px;border-radius:8px;text-decoration:none;transition:all 0.3s;
}
.btn-outline:hover{border-color:var(--purple2);color:var(--purple3)}

/* ── SHARED SECTION LABELS ── */
.section-eyebrow{
  display:inline-flex;align-items:center;gap:8px;
  font-family:'DM Mono',monospace;font-size:0.6rem;
  letter-spacing:2px;text-transform:uppercase;color:var(--purple3);margin-bottom:16px;
}
.section-eyebrow::before{content:'//';color:var(--border2);margin-right:2px}

h2.big{
  font-family:'Poppins',sans-serif;
  font-size:2.5rem;font-weight:400;line-height:1.05;color:var(--white);
}
h2.big em{
  font-family:'Poppins',sans-serif;
  display:inline;padding-right:0.08em;
  background:linear-gradient(135deg,var(--purple2),var(--cyan));
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}

section.pad{padding:100px 52px}

/* ── FOOTER ── */
footer{
  padding:32px 52px;border-top:1px solid var(--border);
  display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:14px;
}
.footer-links{display:flex;flex-wrap:wrap;gap:24px}
.footer-links a{
  font-size:0.72rem;font-weight:600;letter-spacing:1px;text-transform:uppercase;
  color:var(--muted);text-decoration:none;transition:color 0.2s;
}
.footer-links a:hover{color:var(--purple3)}
.footer-bottom{display:flex;align-items:center;gap:20px;flex-wrap:wrap}
.footer-copy{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:1px;color:var(--muted)}
.footer-legal{display:flex;align-items:center;gap:10px}
.footer-legal a{font-family:'DM Mono',monospace;font-size:0.58rem;letter-spacing:1px;color:var(--muted);text-decoration:none;transition:color 0.2s}
.footer-legal a:hover{color:var(--purple3)}
.footer-legal-sep{color:var(--border2);font-size:0.58rem}

/* ── PARTICLES ── */
.particle{
  position:absolute;border-radius:50%;pointer-events:none;
  animation:float var(--d,8s) var(--delay,0s) infinite linear;
  bottom:-10px;
}

@media(max-width:1380px){
  nav{padding:22px 36px}
  nav.scrolled{padding:14px 36px}
  .nav-links{gap:28px}
}
@media(max-width:1200px){
  .nav-links{display:none}
  .hamburger{display:flex}
  nav{padding:16px 24px}
  nav.scrolled{padding:12px 24px}
}
/* ── Tablet only: hamburger larger, easier to tap ── */
@media(min-width:769px) and (max-width:1200px){
  .hamburger{padding:12px;min-width:56px;min-height:56px;gap:7px}
  .ham-line{width:28px;height:2.5px}
  .hamburger.open .ham-line:nth-child(1){transform:translateY(9px) rotate(45deg)}
  .hamburger.open .ham-line:nth-child(3){transform:translateY(-9px) rotate(-45deg)}
}

@media(max-width:768px){
  nav{padding:14px 20px}
  nav.scrolled{padding:12px 20px}
  .sticky-cta{display:flex}
  .nav-logo-icon{width:28px;height:28px}
  .mobile-menu-link{font-size:1.5rem;padding:20px 0;min-height:64px}
  .mobile-services-trigger{font-size:1.5rem;padding:20px 0;min-height:64px}
  .mobile-sub-link{font-size:1rem;padding:16px 0;min-height:56px}

  footer{
    flex-direction:column;align-items:center;text-align:center;
    padding:36px 24px 28px;gap:0;
  }
  footer .nav-logo{margin-bottom:28px}
  .footer-links{
    display:grid;grid-template-columns:1fr 1fr;
    gap:18px 40px;justify-items:center;
    width:100%;max-width:300px;
    margin-bottom:28px;
  }
  .footer-bottom{
    flex-direction:column;align-items:center;gap:10px;
    width:100%;padding-top:20px;
    border-top:1px solid var(--border);
  }
  .footer-copy{line-height:1.6}
  .footer-legal{justify-content:center}
}
@media(max-width:480px){
  footer{padding:32px 20px 24px}
  .footer-links{max-width:260px;gap:16px 32px}
  .mobile-menu-link{font-size:1.35rem;padding:17px 0;min-height:58px}
  .mobile-services-trigger{font-size:1.35rem;padding:17px 0;min-height:58px}
  .mobile-sub-link{font-size:0.95rem;padding:14px 0;min-height:52px}
}
@media(max-width:360px){
  nav{padding:12px 14px}
  nav.scrolled{padding:10px 14px}
  .nav-logo-icon{width:26px;height:26px}
  footer{padding:28px 16px 20px}
  .footer-links{max-width:240px;gap:14px 24px}
  .mobile-menu-link{font-size:1.2rem;padding:15px 0;min-height:54px}
  .mobile-services-trigger{font-size:1.2rem;padding:15px 0;min-height:54px}
  .mobile-sub-link{font-size:0.875rem;padding:13px 0;min-height:48px}
}
/* ── Large monitors (1600px+) ── */
@media(min-width:1600px){
  nav{padding:18px 80px}
  nav.scrolled{padding:14px 80px}
  footer{padding:28px 80px}
}
/* ── iMac 24–27" (2200px+) ── */
@media(min-width:2200px){
  nav{padding:22px 120px}
  nav.scrolled{padding:16px 120px}
  footer{padding:36px 120px}
  .nav-logo-icon{width:52px;height:52px}
}

/* ── REDUCED MOTION: skip all animations, show all content immediately ── */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:0.01ms!important;animation-delay:0.01ms!important;transition-duration:0.01ms!important}
  .reveal,.reveal-d1,.reveal-d2,.reveal-d3,.reveal-d4{opacity:1;transform:none}
}
