:root{
  --paper:#080b0d;
  --paper-2:#0d1316;
  --ink:#eef7f5;
  --muted:#91a09d;
  --line:#203036;
  --panel:#10181c;
  --panel-2:#141f24;
  --deep:#061112;
  --deep-2:#0b1c1d;
  --teal:#2be4d0;
  --teal-2:#18a99b;
  --clay:#ff8a4c;
  --gold:#b7f45a;
  --shadow:0 24px 70px rgba(0,0,0,.42);
}
*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  background:
    linear-gradient(rgba(43,228,208,.045) 1px,transparent 1px),
    linear-gradient(90deg,rgba(43,228,208,.035) 1px,transparent 1px),
    radial-gradient(circle at 72% 12%,rgba(43,228,208,.12),transparent 34%),
    var(--paper);
  background-size:34px 34px,34px 34px,100% 100%,auto;
  color:var(--ink);
  font-family:-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,system-ui,sans-serif;
  line-height:1.55;
  -webkit-font-smoothing:antialiased;
}
a{color:var(--teal);text-decoration:none}
a:hover{text-decoration:underline}
img{display:block;max-width:100%}
.nav{
  position:sticky;
  top:0;
  z-index:20;
  background:rgba(8,11,13,.82);
  border-bottom:1px solid rgba(43,228,208,.16);
  backdrop-filter:blur(14px);
}
.nav .wrap{
  width:min(1160px,calc(100% - 40px));
  margin:0 auto;
  min-height:68px;
  display:flex;
  align-items:center;
  gap:18px;
}
.logo{
  display:flex;
  align-items:center;
  gap:10px;
  color:var(--ink);
  font-weight:800;
  letter-spacing:.01em;
}
.logo .b{
  width:34px;
  height:34px;
  border-radius:8px;
  display:grid;
  place-items:center;
  background:linear-gradient(135deg,var(--teal),var(--gold));
  color:#061112;
  box-shadow:0 0 24px rgba(43,228,208,.24);
}
.spacer{flex:1}
.nav a:not(.logo){
  color:var(--muted);
  font-size:14px;
  font-weight:650;
  padding:9px 10px;
  border-radius:8px;
}
.nav a:not(.logo):hover{background:rgba(43,228,208,.08);color:var(--ink);text-decoration:none}
.nav a.cta{
  background:var(--teal);
  color:#041010;
  padding-inline:16px;
  box-shadow:0 0 22px rgba(43,228,208,.2);
}
.nav a.cta:hover{background:var(--gold);color:#07100b}
.hero{
  position:relative;
  overflow:hidden;
  min-height:calc(100svh - 68px);
  display:grid;
  align-items:center;
  isolation:isolate;
  padding:86px 20px 104px;
  text-align:center;
  background:
    linear-gradient(180deg,rgba(43,228,208,.12),rgba(43,228,208,.02)),
    var(--deep);
}
.hero-home{
  padding:0;
  text-align:left;
  background:
    linear-gradient(90deg,rgba(6,17,18,.98) 0%,rgba(6,17,18,.9) 42%,rgba(6,17,18,.42) 100%),
    repeating-linear-gradient(0deg,rgba(43,228,208,.08) 0 1px,transparent 1px 76px),
    repeating-linear-gradient(90deg,rgba(43,228,208,.055) 0 1px,transparent 1px 76px),
    var(--deep);
}
.hero-device{
  position:absolute;
  right:max(-120px,calc((100vw - 1160px)/2 - 160px));
  bottom:7vh;
  width:min(840px,62vw);
  filter:drop-shadow(0 40px 70px rgba(0,0,0,.68)) drop-shadow(0 0 34px rgba(43,228,208,.18));
  z-index:-1;
}
.hero-copy{
  width:min(1160px,calc(100% - 40px));
  margin:0 auto;
  padding:86px 0 104px;
  color:#fff;
}
.hero:not(.hero-home) h1,
.hero:not(.hero-home) .sub,
.hero:not(.hero-home) .btns{
  margin-left:auto;
  margin-right:auto;
}
.hero:not(.hero-home) h1{
  max-width:920px;
}
.hero:not(.hero-home) .sub{
  max-width:760px;
}
.hero:not(.hero-home) .btns{
  justify-content:center;
}
.acc{color:var(--teal)}
.tag,.eyebrow{
  display:inline-flex;
  align-items:center;
  width:max-content;
  gap:8px;
  margin:0 0 16px;
  color:var(--teal);
  text-transform:uppercase;
  font-size:12px;
  font-weight:800;
  letter-spacing:.12em;
}
.tag{
  padding:7px 11px;
  border:1px solid rgba(43,228,208,.32);
  background:rgba(43,228,208,.08);
  border-radius:999px;
}
h1,h2,h3,h4,p{margin-top:0}
h1{
  max-width:760px;
  margin-bottom:22px;
  font-size:clamp(42px,7vw,86px);
  line-height:.96;
  letter-spacing:0;
}
.hero .sub{
  max-width:675px;
  color:rgba(238,247,245,.78);
  font-size:clamp(17px,2vw,22px);
  margin-bottom:34px;
}
.btns{display:flex;gap:12px;flex-wrap:wrap}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:46px;
  padding:12px 20px;
  border-radius:8px;
  font-weight:800;
  border:1px solid transparent;
}
.btn:hover{text-decoration:none}
.btn.primary{background:var(--gold);color:#16110a}
.btn.primary:hover{background:var(--teal)}
.btn.ghost{color:#fff;border-color:rgba(43,228,208,.34);background:rgba(43,228,208,.06)}
.btn.ghost:hover{background:rgba(43,228,208,.13)}
main section{
  width:min(1160px,calc(100% - 40px));
  margin:0 auto;
  padding:74px 0;
}
.intro{
  display:grid;
  grid-template-columns:minmax(0,.8fr) minmax(0,1.2fr);
  gap:42px;
  align-items:start;
}
h2{
  font-size:clamp(30px,4vw,52px);
  line-height:1.05;
  letter-spacing:0;
  margin-bottom:18px;
}
.lead{
  color:var(--muted);
  font-size:18px;
  max-width:760px;
}
.grid{display:grid;gap:18px}
.grid.cols3{grid-template-columns:repeat(3,minmax(0,1fr))}
.card{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:8px;
  padding:26px;
  box-shadow:0 12px 34px rgba(0,0,0,.22);
  position:relative;
  overflow:hidden;
}
.card:before{
  content:"";
  position:absolute;
  inset:0 0 auto;
  height:3px;
  background:linear-gradient(90deg,var(--teal),transparent 70%);
  opacity:.8;
}
.card-kicker{
  color:var(--gold);
  font-weight:900;
  font-size:13px;
}
.card h3{font-size:22px;margin:12px 0 10px}
.card p{color:var(--muted);font-size:15px}
.card a{font-weight:800}
.split{
  display:grid;
  grid-template-columns:minmax(0,1fr) minmax(320px,.82fr);
  gap:48px;
  align-items:center;
}
.steps{
  margin:0;
  padding:0;
  list-style:none;
  display:grid;
  gap:12px;
}
.steps li{
  background:var(--panel);
  border:1px solid var(--line);
  border-left:5px solid var(--teal);
  border-radius:8px;
  padding:18px 20px;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
}
.steps strong{display:block;font-size:18px;margin-bottom:4px}
.steps span{display:block;color:var(--muted)}
.compare{
  border-top:1px solid var(--line);
  border-bottom:1px solid var(--line);
  display:grid;
  grid-template-columns:.9fr 1.1fr;
  gap:34px;
}
.compare-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}
.check-list{
  border-radius:8px;
  padding:24px;
  border:1px solid var(--line);
}
.check-list.good{background:var(--deep);color:#fff;border-color:var(--deep)}
.check-list.good p{color:rgba(255,255,255,.78)}
.check-list.muted{background:var(--panel)}
.check-list p{color:var(--muted);margin-bottom:0}
.cta-band{
  width:min(1160px,calc(100% - 40px));
  margin:26px auto 76px;
  padding:46px;
  background:
    linear-gradient(135deg,rgba(43,228,208,.16),transparent 44%),
    var(--deep);
  color:#fff;
  border:1px solid rgba(43,228,208,.2);
  border-radius:8px;
  box-shadow:var(--shadow);
}
.product-strip{
  display:grid;
  grid-template-columns:minmax(0,.85fr) minmax(0,1.15fr);
  gap:34px;
  align-items:center;
}
.speaker-row{
  display:grid;
  grid-template-columns:1.3fr .7fr .7fr;
  gap:14px;
  align-items:end;
}
.speaker-row figure{
  margin:0;
  min-height:260px;
  display:grid;
  align-items:end;
  padding:18px;
  border:1px solid rgba(43,228,208,.16);
  border-radius:8px;
  background:
    linear-gradient(180deg,rgba(43,228,208,.08),rgba(43,228,208,.015)),
    var(--panel);
  box-shadow:0 18px 40px rgba(0,0,0,.22);
}
.speaker-row img{
  width:100%;
  max-height:250px;
  object-fit:contain;
  filter:drop-shadow(0 18px 24px rgba(0,0,0,.42));
}
.speaker-row figcaption{
  margin-top:12px;
  color:var(--muted);
  font-size:13px;
  font-weight:800;
  text-align:center;
}
.cta-band h2{max-width:760px}
.cta-band p:not(.eyebrow){max-width:720px;color:rgba(255,255,255,.78)}
footer{
  padding:42px 20px 52px;
  text-align:center;
  color:var(--muted);
  border-top:1px solid var(--line);
  font-size:13px;
}
footer a{color:var(--muted);font-weight:700}
.feature-row{display:grid;grid-template-columns:1fr 1fr;gap:36px;align-items:center;margin:36px 0}
.feature-row.rev>div:first-child{order:2}
.feature-row ul,section ol,section ul{color:var(--muted)}
.feature-row li,section li{margin:7px 0}
.app-features{
  text-align:center;
}
.app-features > h2{
  margin-left:auto;
  margin-right:auto;
}
.app-features .feature-row{
  width:min(980px,100%);
  margin:26px auto;
  text-align:left;
  background:
    linear-gradient(180deg,rgba(43,228,208,.055),rgba(43,228,208,.01)),
    var(--panel);
  border:1px solid rgba(43,228,208,.16);
  border-radius:8px;
  padding:26px;
  box-shadow:0 18px 44px rgba(0,0,0,.22);
}
.mockup{
  background:var(--panel);
  border:1px solid var(--line);
  border-radius:8px;
  min-height:360px;
  display:grid;
  place-items:center;
  box-shadow:0 12px 34px rgba(0,0,0,.22);
  overflow:hidden;
}
.speaker-mockup img{
  width:min(520px,100%);
  max-height:330px;
  object-fit:contain;
  filter:drop-shadow(0 18px 28px rgba(0,0,0,.44));
}
.code{
  background:#151816;
  color:#fff;
  border-radius:8px;
  padding:16px;
  overflow:auto;
  font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;
  font-size:13px;
}
.setup-section{
  display:flex;
  justify-content:center;
}
.setup-panel{
  width:min(880px,100%);
  text-align:center;
  background:
    linear-gradient(180deg,rgba(43,228,208,.075),rgba(43,228,208,.015)),
    var(--panel);
  border:1px solid rgba(43,228,208,.18);
  border-radius:8px;
  padding:34px;
  box-shadow:0 18px 44px rgba(0,0,0,.24);
}
.setup-panel .lead{
  margin-left:auto;
  margin-right:auto;
}
.setup-panel .code{
  text-align:left;
  margin:24px auto 0;
}
.setup-panel ul{
  width:min(720px,100%);
  margin-left:auto;
  margin-right:auto;
  text-align:left;
}
.setup-panel h3{
  text-align:center;
}
.notes-section{
  display:flex;
  justify-content:center;
}
code,.kbd{font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace}
code{
  background:rgba(43,228,208,.09);
  border-radius:5px;
  padding:2px 5px;
}
@media(max-width:860px){
  .nav .wrap{width:min(100% - 24px,1160px);gap:8px}
  .nav a:not(.logo){font-size:13px;padding:8px 7px}
  .nav a.cta{display:none}
  .hero{min-height:620px}
  .hero-device{right:-180px;bottom:12px;width:680px;opacity:.5}
  .hero-copy{width:min(100% - 28px,1160px);padding:70px 0 92px}
  main section,.cta-band{width:min(100% - 28px,1160px)}
  .intro,.split,.compare,.grid.cols3,.compare-grid,.feature-row,.product-strip,.speaker-row{grid-template-columns:1fr}
  .feature-row.rev>div:first-child{order:0}
  .cta-band{padding:30px 22px}
  h1{font-size:46px}
}
@media(max-width:520px){
  .logo span:last-child{display:none}
  .nav .wrap{min-height:60px}
  .hero{min-height:650px}
  .hero-device{right:-150px;width:480px}
  .btn{width:100%}
  main section{padding:54px 0}
}
