:root{
  --bg:#050814;
  --bg-soft:#081126;
  --card:#0b162b;
  --card-2:#101f39;
  --text:#f7f9ff;
  --muted:#aab8d2;
  --muted-2:#8191ad;
  --line:rgba(255,255,255,.105);
  --blue:#00c2ff;
  --blue-2:#1164ff;
  --green:#20f6c9;
  --danger:#ff6b8a;
  --shadow:0 28px 80px rgba(0,0,0,.36);
  --radius:26px;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,Arial,sans-serif;
  background:
    radial-gradient(circle at 17% 7%,rgba(0,137,255,.25),transparent 32%),
    radial-gradient(circle at 83% 18%,rgba(0,255,229,.12),transparent 30%),
    linear-gradient(180deg,#050814 0%,#040712 62%,#02040a 100%);
  color:var(--text);
  line-height:1.6;
}

a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
.container{width:min(1140px,calc(100% - 40px));margin:0 auto}
.skip-link{position:absolute;left:-999px}
.skip-link:focus{left:20px;top:20px;z-index:99;background:#fff;color:#000;padding:10px 14px;border-radius:10px}

.site-header{
  position:sticky;
  top:0;
  z-index:20;
  border-bottom:1px solid var(--line);
  backdrop-filter:blur(18px);
  background:rgba(5,8,20,.78);
}

.nav{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:15px 0;
}

.brand{
  display:flex;
  align-items:center;
  gap:12px;
  font-size:22px;
  font-weight:900;
  letter-spacing:-.035em;
}

.brand img{
  width:43px;
  height:43px;
  border-radius:13px;
  box-shadow:0 0 28px rgba(0,151,255,.28);
}

.nav-links{
  display:flex;
  align-items:center;
  gap:22px;
  color:var(--muted);
  font-size:15px;
  font-weight:650;
}

.nav-links a:hover{color:var(--text)}
.nav-cta{
  padding:10px 16px;
  border-radius:999px;
  color:white!important;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  box-shadow:0 12px 28px rgba(0,122,255,.25);
}

.menu-btn{
  display:none;
  background:rgba(255,255,255,.04);
  border:1px solid var(--line);
  color:var(--text);
  padding:10px 12px;
  border-radius:12px;
  font-weight:800;
}

.hero{
  padding:92px 0 70px;
  position:relative;
  overflow:hidden;
}

.hero-grid{
  display:grid;
  grid-template-columns:1.05fr .95fr;
  gap:50px;
  align-items:center;
}

.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  padding:8px 13px;
  border-radius:999px;
  border:1px solid rgba(0,194,255,.27);
  background:rgba(0,194,255,.08);
  color:#bdefff;
  font-size:14px;
  font-weight:850;
}

.eyebrow span{
  width:8px;
  height:8px;
  border-radius:999px;
  background:var(--green);
  box-shadow:0 0 18px var(--green);
}

h1{
  margin:23px 0 22px;
  font-size:clamp(46px,7vw,92px);
  line-height:.95;
  letter-spacing:-.078em;
}

.lead{
  color:var(--muted);
  font-size:clamp(18px,2vw,22px);
  max-width:690px;
}

.hero-actions{
  display:flex;
  gap:14px;
  flex-wrap:wrap;
  margin-top:34px;
}

.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:52px;
  padding:14px 20px;
  border-radius:16px;
  border:1px solid var(--line);
  font-weight:900;
  transition:.18s ease;
}

.btn.primary{
  border-color:transparent;
  background:linear-gradient(135deg,var(--blue),var(--blue-2));
  color:#fff;
  box-shadow:0 18px 48px rgba(0,122,255,.26);
}

.btn.secondary{
  background:rgba(255,255,255,.052);
  color:var(--text);
}

.btn:hover{transform:translateY(-2px)}

.hero-card{
  position:relative;
  overflow:hidden;
  padding:18px;
  border:1px solid var(--line);
  border-radius:34px;
  background:linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.026));
  box-shadow:var(--shadow);
}

.hero-card::before{
  content:"";
  position:absolute;
  inset:-30%;
  background:radial-gradient(circle,rgba(0,194,255,.20),transparent 35%);
  filter:blur(20px);
}

.hero-card img{
  position:relative;
  width:100%;
  border-radius:25px;
  aspect-ratio:16/9;
  object-fit:cover;
}

.stats{
  position:relative;
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin-top:18px;
}

.stat{
  padding:18px;
  border:1px solid var(--line);
  border-radius:18px;
  background:rgba(5,10,22,.74);
}

.stat strong{
  display:block;
  font-size:24px;
  letter-spacing:-.03em;
}

.stat span{
  color:var(--muted-2);
  font-size:13px;
}

.section{padding:80px 0}
.section-head{
  display:flex;
  align-items:end;
  justify-content:space-between;
  gap:30px;
  margin-bottom:30px;
}

.section h2{
  margin:0;
  font-size:clamp(32px,4vw,54px);
  line-height:1;
  letter-spacing:-.058em;
}

.section-intro{
  color:var(--muted);
  max-width:660px;
  margin:12px 0 0;
  font-size:18px;
}

.grid-3{
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:18px;
}

.card{
  padding:26px;
  border:1px solid var(--line);
  border-radius:var(--radius);
  background:linear-gradient(180deg,rgba(255,255,255,.07),rgba(255,255,255,.025));
  box-shadow:0 18px 45px rgba(0,0,0,.16);
}

.card h3{
  margin:0 0 10px;
  font-size:22px;
  letter-spacing:-.032em;
}

.card p{margin:0;color:var(--muted)}
.icon-bubble{
  width:50px;
  height:50px;
  display:grid;
  place-items:center;
  margin-bottom:18px;
  border-radius:16px;
  border:1px solid rgba(0,194,255,.19);
  background:linear-gradient(135deg,rgba(0,194,255,.24),rgba(17,100,255,.22));
  font-size:22px;
}

.app-card{
  display:grid;
  grid-template-columns:132px 1fr;
  gap:25px;
  align-items:center;
  padding:28px;
  border-radius:30px;
  border:1px solid rgba(0,194,255,.16);
  background:
    radial-gradient(circle at 16% 14%,rgba(0,194,255,.20),transparent 28%),
    linear-gradient(180deg,rgba(255,255,255,.075),rgba(255,255,255,.025));
  box-shadow:var(--shadow);
}

.app-card + .app-card{margin-top:18px}
.app-card img{
  width:132px;
  height:132px;
  object-fit:cover;
  border-radius:31px;
  border:1px solid var(--line);
  box-shadow:0 20px 60px rgba(0,0,0,.36);
}

.status{
  color:#9affdf;
  font-weight:900;
  margin-bottom:4px;
}

.app-card h3{
  margin:0 0 6px;
  font-size:34px;
  letter-spacing:-.055em;
}

.app-card p{
  color:var(--muted);
  margin:0;
  max-width:760px;
}

.badges{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin:15px 0 18px;
}

.badge{
  padding:7px 10px;
  border-radius:999px;
  border:1px solid var(--line);
  background:rgba(255,255,255,.06);
  color:#cbd7ef;
  font-size:13px;
  font-weight:800;
}

.timeline{display:grid;gap:14px}
.timeline-row{
  display:grid;
  grid-template-columns:160px 1fr;
  gap:20px;
  padding:22px;
  border:1px solid var(--line);
  border-radius:22px;
  background:rgba(255,255,255,.043);
}

.timeline-row strong{color:#cdefff}
.timeline-row p{margin:0;color:var(--muted)}

.contact-box{
  padding:44px;
  border:1px solid var(--line);
  border-radius:34px;
  background:
    radial-gradient(circle at 85% 20%,rgba(0,194,255,.22),transparent 30%),
    linear-gradient(135deg,rgba(16,31,57,.92),rgba(5,10,22,.96));
  box-shadow:var(--shadow);
}

.contact-box h2{margin-bottom:14px}

.footer{
  border-top:1px solid var(--line);
  padding:32px 0;
  color:var(--muted-2);
}

.footer-grid{
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:18px;
  flex-wrap:wrap;
}

.footer-links{
  display:flex;
  gap:18px;
  flex-wrap:wrap;
}

.page-hero{
  padding:76px 0 30px;
}

.page-hero h1{
  font-size:clamp(42px,6vw,72px);
  max-width:850px;
}

.legal-page{
  padding:70px 0;
}

.legal-page article{
  max-width:930px;
  padding:40px;
  border:1px solid var(--line);
  border-radius:30px;
  background:rgba(255,255,255,.045);
}

.legal-page h1{
  font-size:48px;
  line-height:1.05;
}

.legal-page h2{
  margin-top:32px;
  letter-spacing:-.032em;
}

.legal-page p,
.legal-page li{
  color:var(--muted);
}

.legal-page a{
  color:#9deaff;
  text-decoration:underline;
}

.notice{
  border-left:4px solid var(--blue);
  padding:14px 18px;
  border-radius:12px;
  background:rgba(0,194,255,.08);
  color:#d7f5ff!important;
}

@media (max-width:900px){
  .hero-grid,
  .grid-3{
    grid-template-columns:1fr;
  }

  .section-head{
    display:block;
  }

  .app-card{
    grid-template-columns:1fr;
  }

  .timeline-row{
    grid-template-columns:1fr;
  }

  .nav-links{
    display:none;
    position:absolute;
    left:20px;
    right:20px;
    top:76px;
    padding:18px;
    border:1px solid var(--line);
    border-radius:20px;
    background:rgba(5,8,20,.98);
    flex-direction:column;
    align-items:flex-start;
  }

  .nav-links.open{display:flex}
  .menu-btn{display:block}
}

@media (max-width:520px){
  .container{width:min(100% - 28px,1140px)}
  .hero{padding:58px 0}
  .stats{grid-template-columns:1fr}
  .contact-box{padding:28px}
  .legal-page article{padding:26px}
  .app-card img{width:108px;height:108px;border-radius:26px}
}

/* Finished Sutton Labs launch polish */
.app-card{grid-template-columns:250px 1fr;}
.app-card.featured{border-color:rgba(255,157,32,.25);background:radial-gradient(circle at 14% 15%,rgba(255,157,32,.18),transparent 28%),radial-gradient(circle at 92% 14%,rgba(0,194,255,.11),transparent 24%),linear-gradient(180deg,rgba(255,255,255,.078),rgba(255,255,255,.027));}
.app-logo-panel{min-height:170px;border-radius:28px;border:1px solid var(--line);background:#09090c;box-shadow:0 20px 60px rgba(0,0,0,.36);display:flex;align-items:center;justify-content:center;padding:14px;overflow:hidden;}
.app-logo-panel img{width:100%;height:auto;border-radius:18px;object-fit:contain;}
.orange-text{color:#ffbd70!important;}
.orange-badge{border-color:rgba(255,157,32,.22)!important;background:rgba(255,157,32,.09)!important;color:#ffcf95!important;}
.btn.orange{border-color:transparent;background:linear-gradient(135deg,#ff9d20,#ff6b00);color:#0b0b0d;box-shadow:0 18px 48px rgba(255,128,0,.18);}
@media (max-width:900px){.app-card{grid-template-columns:1fr}.app-logo-panel{max-width:360px}}
@media (max-width:520px){.app-logo-panel{min-height:130px;max-width:100%}}
