/* === RESET & BASE === */
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth;scroll-padding-top:4rem}
body{
  font-family:'Space Grotesk',system-ui,sans-serif;
  background:#08060d;
  color:#eae2fa;
  overflow-x:hidden;
  -webkit-font-smoothing:antialiased;
  -moz-osx-font-smoothing:grayscale;
}
:root{
  --bg-deep:#08060d;
  --bg-surface:#0f0d16;
  --bg-card:#151320;
  --text-primary:#eae2fa;
  --text-muted:#9d95b4;
  --pink:#ff6b9b;
  --pink-cta:#d6246a;
  --pink-cta-deep:#b8164d;
  --cyan:#00dddd;
  --lavender:#b3a2ff;
  --mint:#86f9c5;
}
img,svg{display:block;max-width:100%}

/* === ACCESSIBLE HIDDEN === */
.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}

/* === TYPOGRAPHY === */
.font-headline{font-family:'Plus Jakarta Sans',sans-serif}
.font-body{font-family:'Space Grotesk',system-ui,sans-serif}
.text-gradient-pink{
  background:linear-gradient(135deg,#ff6b9b,#ff8fc6 50%,#b3a2ff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.text-gradient-cyan{
  background:linear-gradient(135deg,#00dddd,#3de7f3 50%,#b3a2ff);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.text-gradient-lavender{
  background:linear-gradient(135deg,#b3a2ff,#c4b5ff 50%,#00dddd);
  -webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;
}
.text-muted{color:var(--text-muted)}
.leading-relaxed{line-height:1.65}
.mt-3{margin-top:.75rem}

/* === STICKY NAV === */
.site-nav{
  position:fixed;top:0;left:0;right:0;z-index:100;
  background:rgba(8,6,13,.82);
  backdrop-filter:blur(16px);
  -webkit-backdrop-filter:blur(16px);
  border-bottom:1px solid rgba(255,255,255,.04);
  transition:transform .3s,background .3s;
}
.site-nav.hidden{transform:translateY(-100%)}
.nav-inner{
  max-width:72rem;margin:0 auto;padding:.75rem 1.5rem;
  display:flex;align-items:center;justify-content:space-between;
}
.nav-logo{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1.05rem;
  color:var(--text-primary);text-decoration:none;
  display:flex;align-items:center;gap:.4rem;
}
.nav-logo-icon{width:22px;height:22px}
.hero-brand-row{
  display:flex;align-items:center;gap:clamp(0.5rem,1.5vw,1rem);
  justify-content:center;margin-bottom:1rem;
}
@media(min-width:768px){.hero-brand-row{justify-content:flex-start}}
.hero-logo{
  height:clamp(2.8rem,8vw,5rem);width:auto;flex-shrink:0;
  filter:drop-shadow(0 0 20px rgba(255,107,155,.15)) drop-shadow(0 0 40px rgba(179,162,255,.1));
}
.hero-text-col{
  display:flex;flex-direction:column;justify-content:center;
}
.brand-line{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:800;
  font-size:clamp(2.2rem,7vw,4.5rem);
  line-height:.92;
  letter-spacing:-.02em;
  white-space:nowrap;
  text-shadow:0 0 40px rgba(8,6,13,.92),0 0 80px rgba(8,6,13,.7),0 0 40px rgba(255,107,155,.12),0 0 80px rgba(179,162,255,.08);
}
.footer-logo-icon{width:18px;height:18px;flex-shrink:0}
.nav-links{display:none;gap:1.5rem}
.nav-links a{
  color:var(--text-muted);text-decoration:none;font-size:.85rem;font-weight:500;
  transition:color .2s;padding:.25rem 0;
}
.nav-links a:hover,.nav-links a.active{color:var(--text-primary)}
.nav-cta{
  background:linear-gradient(135deg,var(--pink-cta),var(--pink-cta-deep));
  color:#fff;text-decoration:none;padding:.45rem 1rem;
  border-radius:9999px;font-size:.8rem;font-weight:600;
  transition:transform .2s,box-shadow .2s;
}
.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 20px rgba(255,107,155,.25)}
@media(min-width:768px){.nav-links{display:flex}}

/* === HERO === */
.hero-section{
  position:relative;
  min-height:100dvh;
  display:flex;
  align-items:center;
  justify-content:center;
  overflow:hidden;
}
#hero-canvas{
  position:absolute;inset:0;width:100%;height:100%;pointer-events:none;z-index:0;
}
#hero-loader{
  position:absolute;inset:0;z-index:5;
  display:flex;align-items:center;justify-content:center;
  background:var(--bg-deep);
  transition:opacity .6s;
}
#hero-loader.hidden{opacity:0;pointer-events:none}
.hero-loader-dot{
  width:12px;height:12px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--lavender));
  animation:loader-pulse 1s ease-in-out infinite;
}
@keyframes loader-pulse{0%,100%{transform:scale(1);opacity:.6}50%{transform:scale(1.6);opacity:1}}

.text-overlay{
  position:absolute;inset:0;z-index:10;pointer-events:none;
  background:radial-gradient(ellipse 50% 45% at 50% 50%,rgba(8,6,13,.9) 0%,rgba(8,6,13,.5) 55%,transparent 100%);
}
.hero-content{
  position:relative;z-index:20;
  display:grid;grid-template-columns:1fr;
  width:100%;max-width:72rem;
  margin:0 auto;padding:6rem 1.5rem;
}
.hero-brand{
  text-align:center;max-width:40rem;margin:0 auto;
}
.brand-tagline{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:400;font-size:clamp(1.1rem,2.5vw,1.5rem);
  color:var(--text-primary);opacity:.85;margin-bottom:.75rem;
}
.brand-sub{
  font-size:clamp(.875rem,1.5vw,1.05rem);
  color:var(--text-muted);line-height:1.65;
  max-width:26rem;margin:0 auto 1.75rem;
}
.hero-actions{
  display:flex;flex-direction:column;align-items:center;gap:.75rem;
}
.hero-fade-bottom{
  position:absolute;bottom:0;left:0;right:0;height:8rem;z-index:10;pointer-events:none;
  background:linear-gradient(to top,var(--bg-deep),var(--bg-deep) 20%,transparent);
}

/* Hero device pair (CSS illustration for desktop right-half) */
.hero-device-pair{
  display:none;align-items:center;justify-content:center;gap:1.5rem;position:relative;
}
.hero-device{
  width:5rem;border-radius:1.25rem;background:var(--bg-card);
  border:1px solid rgba(255,255,255,.06);
  padding:1rem .7rem;display:flex;flex-direction:column;align-items:center;gap:.6rem;
  position:relative;overflow:hidden;
}
.hero-device-left{transform:rotate(-6deg)}
.hero-device-right{transform:rotate(6deg)}
.hero-device-screen{
  width:3.5rem;height:1.3rem;border-radius:.35rem;
  background:var(--bg-deep);border:1px solid rgba(255,255,255,.04);
}
.hero-device-pulse{
  width:100%;height:100%;border-radius:.35rem;
  background:rgba(0,221,221,.15);animation:hero-dev-flash 2.5s ease-in-out infinite;
}
.hero-device-right .hero-device-pulse{animation-delay:.8s}
@keyframes hero-dev-flash{0%,100%{opacity:.2}40%{opacity:.8}}
.hero-device-dot{
  width:.35rem;height:.35rem;border-radius:50%;background:var(--pink);
  box-shadow:0 0 6px rgba(255,107,155,.4);
}
.hero-connect-line{
  position:absolute;width:2.5rem;height:1px;
  background:linear-gradient(90deg,transparent,rgba(179,162,255,.4),transparent);
  top:50%;
}
.hero-connect-spark{
  position:absolute;width:6px;height:6px;border-radius:50%;
  background:var(--lavender);top:calc(50% - 3px);
  box-shadow:0 0 10px rgba(179,162,255,.6);
  animation:spark-travel 2.5s ease-in-out infinite;
}
@keyframes spark-travel{
  0%{left:0;opacity:.3}50%{left:calc(100% - 6px);opacity:1}100%{left:0;opacity:.3}
}

@media(min-width:768px){
  .hero-content{grid-template-columns:1fr 1fr;align-items:center;padding:4rem 3rem}
  .hero-brand{text-align:left;margin:0}
  .hero-device-pair{display:flex;order:2}
  .text-overlay{
    background:linear-gradient(to right,rgba(8,6,13,.78) 0%,rgba(8,6,13,.5) 40%,rgba(8,6,13,.15) 65%,transparent 100%);
  }
  .brand-sub{margin:0 0 1.75rem}
  .hero-actions{justify-content:flex-start}
}

/* === BUTTONS === */
.btn-primary{
  background:linear-gradient(135deg,var(--pink-cta),var(--pink-cta-deep));
  color:#fff;font-weight:600;border-radius:9999px;
  padding:.75rem 1.75rem;font-size:.925rem;
  letter-spacing:.01em;transition:all .25s cubic-bezier(.4,0,.2,1);
  border:none;cursor:pointer;
  display:inline-flex;align-items:center;gap:.5rem;
  box-shadow:0 0 20px rgba(255,107,155,.18),0 4px 14px rgba(229,38,110,.22);
  text-decoration:none;
}
.btn-primary:hover{transform:translateY(-1px);box-shadow:0 0 35px rgba(255,107,155,.28),0 8px 22px rgba(229,38,110,.3)}
.btn-primary:focus-visible{outline:2px dashed var(--pink);outline-offset:3px}
.btn-secondary{
  background:rgba(255,255,255,.04);color:var(--text-primary);font-weight:600;
  border-radius:9999px;padding:.75rem 1.75rem;font-size:.925rem;
  letter-spacing:.01em;transition:all .25s cubic-bezier(.4,0,.2,1);
  border:1px solid rgba(255,255,255,.1);cursor:pointer;
  display:inline-flex;align-items:center;gap:.5rem;text-decoration:none;
}
.btn-secondary:hover{background:rgba(255,255,255,.07);border-color:rgba(255,255,255,.18);transform:translateY(-1px)}
.btn-secondary:focus-visible{outline:2px dashed var(--lavender);outline-offset:3px}
.btn-lg{padding:1rem 2.5rem;font-size:1.05rem}

/* === SECTIONS === */
.section{padding:4rem 1.5rem}
.section-inner{max-width:64rem;margin:0 auto}
.section-heading{
  font-family:'Plus Jakarta Sans',sans-serif;
  font-weight:700;font-size:clamp(1.8rem,4vw,2.5rem);
  text-align:center;margin-bottom:1.5rem;line-height:1.2;
}
.section-sub{color:var(--text-muted);text-align:center;margin-bottom:3rem}

/* === DEVICE === */
.device-grid{display:flex;flex-direction:column;gap:2.5rem;align-items:center}
.device-mockup-wrapper{order:0}
.device-mockup{position:relative;width:12rem}
.device-glow{
  position:absolute;inset:-1rem;border-radius:1.75rem;
  background:linear-gradient(135deg,rgba(255,107,155,.12),rgba(0,221,221,.06),rgba(179,162,255,.08));
  filter:blur(24px);
}
.device-body{
  position:relative;border-radius:1.5rem;background:var(--bg-card);
  border:1px solid rgba(255,255,255,.05);
  padding:1.5rem 1.25rem;
  display:flex;flex-direction:column;align-items:center;gap:1rem;
  overflow:hidden;
}
.device-top-line{
  position:absolute;top:0;left:0;right:0;height:1px;
  background:linear-gradient(90deg,transparent,rgba(255,107,155,.2),transparent);
}
.device-screen{
  width:6rem;height:2rem;border-radius:.5rem;
  background:var(--bg-deep);border:1px solid rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;
}
.device-screen-pulse{width:4rem;height:.25rem;border-radius:9999px;background:rgba(0,221,221,.12);animation:screen-pulse 2s ease-in-out infinite}
@keyframes screen-pulse{0%,100%{opacity:.5}50%{opacity:1}}
.device-heart{
  width:3.5rem;height:3.5rem;border-radius:50%;
  background:rgba(255,107,155,.06);border:1px solid rgba(255,107,155,.12);
  display:flex;align-items:center;justify-content:center;
  box-shadow:0 0 20px rgba(255,107,155,.08);
}
.device-button{
  width:2.75rem;height:2.75rem;border-radius:.75rem;
  background:var(--bg-deep);border:1px solid rgba(255,255,255,.04);
  display:flex;align-items:center;justify-content:center;
}
.device-button-inner{width:1rem;height:1rem;border-radius:.25rem;background:rgba(255,107,155,.15);animation:btn-pulse 1.5s ease-in-out infinite}
@keyframes btn-pulse{0%,100%{transform:scale(1);opacity:.4}50%{transform:scale(1.2);opacity:.8}}
.specs-list{display:flex;flex-direction:column;gap:1.25rem}
.spec{display:flex;gap:1rem}
.spec-dot{width:.35rem;border-radius:9999px;flex-shrink:0;margin-top:.55rem}
.spec-dot-pink{background:var(--pink);box-shadow:0 0 8px rgba(255,107,155,.4);height:.35rem}
.spec-dot-cyan{background:var(--cyan);box-shadow:0 0 8px rgba(0,221,221,.4);height:.35rem}
.spec-dot-lavender{background:var(--lavender);box-shadow:0 0 8px rgba(179,162,255,.4);height:.35rem}
.spec-dot-mint{background:var(--mint);box-shadow:0 0 8px rgba(134,249,197,.4);height:.35rem}
.spec-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:.95rem;margin-bottom:.15rem}
.spec-desc{color:var(--text-muted);font-size:.825rem;line-height:1.55}

/* === STEPS === */
.steps-grid{
  display:grid;grid-template-columns:1fr;gap:2.5rem;
  max-width:48rem;margin:0 auto;
}
.step{display:flex;flex-direction:column;align-items:center;text-align:center;gap:1rem}
.step-number{
  width:48px;height:48px;border-radius:50%;
  display:flex;align-items:center;justify-content:center;
  font-size:1.25rem;font-weight:700;
  font-family:'Plus Jakarta Sans',sans-serif;
  flex-shrink:0;
}
.step-pink{background:rgba(255,107,155,.08);color:var(--pink);box-shadow:0 0 18px rgba(255,107,155,.12)}
.step-cyan{background:rgba(0,221,221,.08);color:var(--cyan);box-shadow:0 0 18px rgba(0,221,221,.12)}
.step-lavender{background:rgba(179,162,255,.08);color:var(--lavender);box-shadow:0 0 18px rgba(179,162,255,.12)}
.step-mint{background:rgba(134,249,197,.08);color:var(--mint);box-shadow:0 0 18px rgba(134,249,197,.12)}
.step-title{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1.1rem;margin-bottom:.3rem}
.step-desc{color:var(--text-muted);font-size:.875rem;line-height:1.6;max-width:18rem}

/* === PRESETS === */
.presets-grid{
  display:grid;grid-template-columns:1fr;gap:.75rem;
}
.preset-card{
  background:var(--bg-card);border-radius:1rem;padding:1.25rem;
  border:1px solid rgba(255,255,255,.04);
  transition:border-color .25s;
}
.preset-card:hover{border-color:rgba(255,255,255,.1)}
.preset-icon{font-size:1.25rem;display:block;margin-bottom:.4rem}
.preset-name{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1rem;margin-bottom:.2rem}
.preset-desc{color:var(--text-muted);font-size:.825rem;line-height:1.55}

/* === APP MOCKUP === */
.app-grid{display:flex;flex-direction:column;gap:2.5rem;align-items:center}
.app-mockup-wrapper{order:0}
.app-mockup{position:relative;width:13rem}
.app-glow{
  position:absolute;inset:-1.5rem;border-radius:2.5rem;
  background:linear-gradient(135deg,rgba(0,221,221,.1),rgba(179,162,255,.06));
  filter:blur(28px);
}
.app-frame{
  position:relative;border-radius:2rem;background:#0f0d16;
  border:2px solid rgba(255,255,255,.08);
  padding:.75rem .6rem .6rem;
  overflow:hidden;
  aspect-ratio:9/19.5;
}
.app-notch{
  width:5rem;height:1.5rem;border-radius:0 0 1rem 1rem;
  background:#08060d;margin:0 auto .5rem;
}
.app-screen{
  background:var(--bg-surface);border-radius:1.25rem;
  height:calc(100% - 2rem);padding:.6rem .5rem;
  display:flex;flex-direction:column;gap:.4rem;
  position:relative;overflow:hidden;
}
.app-statusbar{
  display:flex;justify-content:space-between;
  font-size:.45rem;color:var(--text-muted);padding:0 .2rem;
}
.app-nav{
  display:flex;gap:.25rem;justify-content:center;
  font-size:.45rem;color:var(--text-muted);
}
.app-nav-item{padding:.15rem .35rem;border-radius:9999px}
.app-nav-active{background:rgba(255,255,255,.06);color:var(--text-primary)}
.app-card{
  background:var(--bg-card);border-radius:.55rem;padding:.4rem;
  display:flex;gap:.35rem;align-items:center;
}
.app-card-avatar{
  width:1.3rem;height:1.3rem;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--lavender));
  flex-shrink:0;
}
.app-card-lines{display:flex;flex-direction:column;gap:.15rem;flex:1}
.app-card-line{height:.2rem;border-radius:9999px;background:rgba(255,255,255,.08)}
.app-presets{
  display:flex;gap:.3rem;justify-content:center;margin-top:auto;
}
.app-preset-dot{width:.4rem;height:.4rem;border-radius:50%}
.app-fab{
  position:absolute;bottom:.4rem;right:.4rem;
  width:1.3rem;height:1.3rem;border-radius:50%;
  background:linear-gradient(135deg,var(--pink-cta),var(--pink-cta-deep));
  box-shadow:0 0 10px rgba(255,107,155,.25);
}
.store-badges{
  display:flex;flex-wrap:wrap;gap:1rem;margin-top:1.5rem;
}
.store-badge{
  display:flex;align-items:center;gap:.5rem;
  background:rgba(255,255,255,.06);border:1px solid rgba(255,255,255,.08);
  border-radius:.75rem;padding:.55rem 1rem;
  text-decoration:none;transition:background .2s,border-color .2s,transform .2s;
}
.store-badge:hover{background:rgba(255,255,255,.1);border-color:rgba(255,255,255,.14);transform:translateY(-1px)}
.store-badge-label{font-size:.75rem;font-weight:500;color:var(--text-primary)}

/* === STORE BADGE (coming soon) === */
.store-soon-tag{font-size:.6rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--lavender);background:rgba(179,162,255,.1);padding:.1rem .4rem;border-radius:9999px;margin-left:.35rem}
.store-badge{cursor:pointer}

/* === WAITLIST (sign up another) === */
.waitlist-again{margin-top:1.25rem;background:transparent;border:1px solid rgba(255,255,255,.12);color:var(--text-primary);font-family:inherit;font-size:.85rem;font-weight:600;padding:.6rem 1.25rem;border-radius:9999px;cursor:pointer;transition:background .2s,border-color .2s}
.waitlist-again:hover{background:rgba(255,255,255,.06);border-color:rgba(255,255,255,.2)}

/* === PRESET ICONS (SVG, cross-platform) === */
.preset-icon{width:1.5rem;height:1.5rem;display:block;margin-bottom:.5rem}

/* === FAQ === */
.faq-list{max-width:42rem;margin:0 auto;display:flex;flex-direction:column;gap:.5rem}
.faq-item{background:var(--bg-card);border:1px solid rgba(255,255,255,.04);border-radius:1rem;overflow:hidden}
.faq-q{width:100%;display:flex;justify-content:space-between;align-items:center;gap:1rem;background:none;border:none;color:var(--text-primary);font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1rem;text-align:left;padding:1.1rem 1.25rem;cursor:pointer}
.faq-q .faq-icon{flex-shrink:0;transition:transform .25s;color:var(--text-muted)}
.faq-item.open .faq-q .faq-icon{transform:rotate(45deg)}
.faq-a{max-height:0;overflow:hidden;transition:max-height .3s ease}
.faq-item.open .faq-a{max-height:14rem}
.faq-a-inner{padding:0 1.25rem 1.15rem;color:var(--text-muted);font-size:.9rem;line-height:1.65}

/* === POSITIONING ROW (pricing/timeline) === */
.positioning-row{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center;margin-top:1.5rem}
.positioning-chip{display:inline-flex;align-items:center;gap:.4rem;font-size:.78rem;font-weight:500;color:var(--text-muted);background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.06);padding:.4rem .8rem;border-radius:9999px}
.positioning-chip strong{color:var(--text-primary);font-weight:600}

/* === LOOM === */
.loom-grid{display:flex;flex-direction:column;gap:2.5rem;align-items:center}
.loom-mockup-wrapper{order:0}
.loom-mockup{position:relative;width:10rem;height:8rem}
.loom-glow{
  position:absolute;inset:-1rem;border-radius:2rem;
  background:radial-gradient(ellipse at center,rgba(179,162,255,.1),transparent 70%);
  filter:blur(24px);
}
.loom-body{
  position:relative;border-radius:1rem;background:var(--bg-card);
  border:1px solid rgba(255,255,255,.05);height:100%;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;
}
.loom-antenna{
  position:absolute;top:-.6rem;left:50%;transform:translateX(-50%);
  width:.25rem;height:.6rem;border-radius:9999px 9999px 0 0;
  background:var(--text-muted);
}
.loom-led{width:.4rem;height:.4rem;border-radius:50%;position:absolute}
.loom-led-cyan{top:.6rem;left:.8rem;background:var(--cyan);box-shadow:0 0 5px rgba(0,221,221,.6)}
.loom-led-pink{top:.6rem;right:.8rem;background:var(--pink);box-shadow:0 0 5px rgba(255,107,155,.6)}
.loom-bridge-icon{opacity:.6}
.loom-wave{
  position:absolute;bottom:-.1rem;left:50%;transform:translateX(-50%);
  border-radius:50%;border:1px solid rgba(179,162,255,.12);
}
.loom-wave-1{width:105%;height:2rem}
.loom-wave-2{width:112%;height:3rem;opacity:.5}
.coming-soon-pill{
  display:inline-block;
  font-size:.7rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase;
  color:var(--lavender);background:rgba(179,162,255,.08);
  padding:.3rem .7rem;border-radius:9999px;
  border:1px solid rgba(179,162,255,.15);
}

/* === ECOSYSTEM === */
.ecosystem-grid{
  display:grid;grid-template-columns:1fr;gap:.75rem;
  max-width:56rem;margin:0 auto;
}
.eco-card{
  background:var(--bg-card);border-radius:1rem;padding:1.25rem;
  border:1px solid rgba(255,255,255,.04);
  display:flex;flex-direction:column;gap:.5rem;
  transition:border-color .25s,transform .25s;
}
.eco-card:hover{border-color:rgba(255,255,255,.1);transform:translateY(-1px)}
.eco-icon{width:2.5rem;height:2.5rem;border-radius:.75rem;display:flex;align-items:center;justify-content:center}
.eco-pulse .eco-icon{background:rgba(255,107,155,.08);color:var(--pink)}
.eco-app .eco-icon{background:rgba(0,221,221,.08);color:var(--cyan)}
.eco-loom .eco-icon{background:rgba(179,162,255,.08);color:var(--lavender)}
.eco-name{font-family:'Plus Jakarta Sans',sans-serif;font-weight:600;font-size:1.05rem}
.eco-desc{color:var(--text-muted);font-size:.825rem;line-height:1.55}

/* === VALUES PILL === */
.values-pill{
  display:flex;align-items:center;gap:.6rem;
  background:rgba(179,162,255,.05);border:1px solid rgba(179,162,255,.1);
  border-radius:.75rem;padding:.65rem 1rem;max-width:32rem;margin:2rem auto 0;
  font-size:.8rem;color:var(--text-muted);
}
.values-pill svg{flex-shrink:0;color:var(--lavender);opacity:.7}

/* === SOCIAL PROOF === */
.testimonials-grid{
  display:grid;grid-template-columns:1fr;gap:1rem;
  max-width:56rem;margin:0 auto;
}
.testimonial-card{
  background:var(--bg-card);border-radius:1rem;padding:1.5rem;
  border:1px solid rgba(255,255,255,.04);
  display:flex;flex-direction:column;gap:.75rem;
}
.testimonial-quote{
  color:var(--text-primary);font-size:.9rem;line-height:1.65;
  position:relative;padding-left:1.25rem;
}
.testimonial-quote::before{
  content:'\201C';position:absolute;left:0;top:-.3rem;
  font-family:'Plus Jakarta Sans',sans-serif;font-size:2rem;font-weight:800;
  color:var(--pink);opacity:.4;line-height:1;
}
.testimonial-author{
  display:flex;align-items:center;gap:.5rem;
}
.testimonial-avatar{
  width:2rem;height:2rem;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--lavender));
  flex-shrink:0;
}
.testimonial-name{font-size:.8rem;font-weight:600;color:var(--text-primary)}
.testimonial-role{font-size:.7rem;color:var(--text-muted)}

/* === WAITLIST === */
.waitlist-form{
  max-width:28rem;margin:0 auto;width:100%;
  display:flex;gap:.5rem;flex-wrap:wrap;
}
.waitlist-form .waitlist-input{flex:1 1 12rem;min-width:0}
.waitlist-form .waitlist-btn{flex-shrink:0}
.waitlist-input{
  flex:1;background:rgba(255,255,255,.04);border:1px solid rgba(255,255,255,.08);
  border-radius:9999px;padding:.8rem 1.25rem;color:var(--text-primary);
  font-family:inherit;font-size:.925rem;outline:none;
  transition:border-color .2s;
}
.waitlist-input:focus{border-color:var(--pink)}
.waitlist-input::placeholder{color:var(--text-muted)}
.waitlist-btn{
  background:linear-gradient(135deg,var(--pink-cta),var(--pink-cta-deep));
  color:#fff;font-weight:600;border-radius:9999px;
  padding:.8rem 1.5rem;font-size:.925rem;border:none;cursor:pointer;
  font-family:inherit;white-space:nowrap;
  transition:transform .2s,box-shadow .2s;
  box-shadow:0 0 20px rgba(255,107,155,.18),0 4px 14px rgba(229,38,110,.22);
}
.waitlist-btn:hover{transform:translateY(-1px);box-shadow:0 0 35px rgba(255,107,155,.28)}
.waitlist-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}
.waitlist-error{
  color:var(--pink);font-size:.8rem;text-align:center;margin-top:.5rem;display:none;
}
.waitlist-error.show{display:block}
.waitlist-success{
  text-align:center;padding:1.5rem;display:none;
}
.waitlist-success.show{display:block}
.waitlist-success .success-icon{
  font-size:2.5rem;margin-bottom:.5rem;
}
.waitlist-success h3{
  font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;font-size:1.25rem;margin-bottom:.25rem;
}
.waitlist-success p{color:var(--text-muted);font-size:.875rem}

/* === FOOTER === */
.site-footer{border-top:1px solid rgba(255,255,255,.04);background:var(--bg-deep);padding:2.5rem 1.5rem}
.footer-inner{max-width:64rem;margin:0 auto;display:flex;flex-direction:column;align-items:center;gap:1rem}
.footer-brand{display:flex;align-items:center;gap:.5rem;color:var(--text-muted);font-size:.825rem;flex-wrap:wrap;justify-content:center}
.footer-name{font-family:'Plus Jakarta Sans',sans-serif;font-weight:700;color:var(--text-primary)}
.footer-link{color:var(--text-muted);text-decoration:none;transition:color .2s}
.footer-link:hover{color:var(--cyan)}
.footer-links{display:flex;gap:1.5rem;font-size:.825rem}
.footer-links a{color:var(--text-muted);text-decoration:none;transition:color .2s}
.footer-links a:hover{color:var(--text-primary)}

/* === SCROLL ANIMATION === */
.animate-on-scroll{
  opacity:0;transform:translateY(24px);
  transition:opacity .6s ease-out,transform .6s ease-out;
}
.animate-on-scroll.visible{opacity:1;transform:translateY(0)}
.animate-on-scroll:nth-child(2){transition-delay:.1s}
.animate-on-scroll:nth-child(3){transition-delay:.2s}
.animate-on-scroll:nth-child(4){transition-delay:.3s}
.animate-on-scroll:nth-child(5){transition-delay:.35s}
.animate-on-scroll:nth-child(6){transition-delay:.4s}

/* === BACK TO TOP === */
.back-to-top{
  position:fixed;bottom:1.5rem;right:1.5rem;z-index:90;
  width:2.5rem;height:2.5rem;border-radius:50%;
  background:var(--bg-card);border:1px solid rgba(255,255,255,.08);
  color:var(--text-muted);display:flex;align-items:center;justify-content:center;
  cursor:pointer;opacity:0;pointer-events:none;
  transition:opacity .3s,transform .2s;
  text-decoration:none;
}
.back-to-top.visible{opacity:1;pointer-events:auto}
.back-to-top:hover{transform:translateY(-2px);color:var(--text-primary);border-color:rgba(255,255,255,.15)}

/* === NO‑JS FALLBACK === */
noscript .hero-device-pair{display:flex!important}
noscript .animate-on-scroll{opacity:1!important;transform:none!important}

/* === ACCESSIBILITY === */
@media(prefers-reduced-motion:reduce){
  *,*::before,*::after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}
  .animate-on-scroll{transition:none!important}
}

/* === RESPONSIVE === */

/* sm — 640px */
@media(min-width:640px){
  .hero-content{padding:6rem 2rem}
  .hero-actions{flex-direction:row}
  .ecosystem-grid{grid-template-columns:repeat(3,1fr)}
  .steps-grid{grid-template-columns:repeat(2,1fr);gap:3rem}
  .step{flex-direction:column}
  .presets-grid{grid-template-columns:repeat(2,1fr)}
  .testimonials-grid{grid-template-columns:repeat(2,1fr)}
  .section{padding:5rem 2rem}
}

/* md — 768px */
@media(min-width:768px){
  .app-grid{flex-direction:row;gap:3rem;align-items:center}
  .app-mockup-wrapper{order:1}
  .app-mockup{width:15rem}
  .loom-grid{flex-direction:row-reverse;gap:3rem;align-items:center}
  .device-grid{flex-direction:row;gap:3rem;align-items:center}
  .device-mockup-wrapper{order:1}
  .device-mockup{width:14rem}
  .section-heading.text-left,.section-heading.text-left-md{text-align:left}
  .steps-grid{grid-template-columns:repeat(4,1fr);gap:2.5rem}
  .ecosystem-grid{grid-template-columns:repeat(3,1fr)}
  .testimonials-grid{grid-template-columns:repeat(3,1fr)}
  .eco-card{align-items:center;text-align:center}
}

/* lg — 1024px */
@media(min-width:1024px){
  .presets-grid{grid-template-columns:repeat(3,1fr)}
  .device-grid{gap:5rem}
  .device-mockup{width:17rem}
  .app-mockup{width:17rem}
  .section-heading{font-size:2.5rem}
}

/* === GLOBAL FOCUS (a11y) === */
a:focus-visible,button:focus-visible,.waitlist-input:focus-visible{outline:2px solid var(--lavender);outline-offset:3px;border-radius:.3rem}
.nav-logo:focus-visible,.back-to-top:focus-visible,.store-badge:focus-visible{outline:2px solid var(--lavender);outline-offset:3px}

/* === MOBILE NAV (hamburger) === */
.nav-inner{position:relative}
.nav-toggle{display:flex;align-items:center;justify-content:center;width:2.5rem;height:2.5rem;background:transparent;border:1px solid rgba(255,255,255,.1);border-radius:.6rem;color:var(--text-primary);cursor:pointer}
@media(min-width:768px){.nav-toggle{display:none}}
@media(max-width:767px){
  .nav-links{
    position:absolute;top:calc(100% + .5rem);right:0;left:0;
    flex-direction:column;align-items:stretch;gap:.15rem;
    background:var(--bg-card);border:1px solid rgba(255,255,255,.08);
    border-radius:1rem;padding:.6rem;
    box-shadow:0 16px 48px rgba(0,0,0,.55);
    display:none;
  }
  .nav-links.open{display:flex}
  .nav-links a{padding:.7rem .8rem;border-radius:.5rem;font-size:.95rem}
  .nav-links a:hover,.nav-links a.active{background:rgba(255,255,255,.05);color:var(--text-primary)}
}

/* === SKIP LINK (a11y) === */
.skip-link{position:absolute;left:-9999px;top:1rem;z-index:200;background:var(--bg-card);color:var(--text-primary);padding:.75rem 1.25rem;border-radius:.5rem;border:1px solid var(--lavender);text-decoration:none;font-size:.9rem;font-weight:600}
.skip-link:focus{left:1rem}

/* === HERO TITLE (h1 wraps brand lines as spans for validity) === */
.hero-title{margin:0}
.brand-line{display:block}

/* === APP SCREENS (rendered frontend) === */
.app-shots{display:flex;justify-content:center;align-items:center;margin:0 auto}
.app-shot{margin:0;flex:0 0 auto;width:min(11rem,42vw)}
.app-shot img{display:block;width:100%;aspect-ratio:390/844;object-fit:cover;border-radius:1.6rem;border:1px solid rgba(255,255,255,.1);box-shadow:0 0 50px rgba(179,162,255,.16),0 18px 50px rgba(0,0,0,.5)}
.app-shot.back{transform:translateX(1.1rem) translateY(-.4rem) scale(.95);opacity:.9;z-index:1}
.app-shot.front{z-index:2;transform:translateX(-.6rem)}
