
:root{
  --bg:#07090b;
  --panel:rgba(255,255,255,.06);
  --panel2:rgba(0,0,0,.22);
  --border:rgba(255,255,255,.10);
  --text:rgba(255,255,255,.92);
  --muted:rgba(255,255,255,.72);
  --muted2:rgba(255,255,255,.58);
  --accent:#23d160;
  --shadow:0 18px 50px rgba(0,0,0,.45);
  --radius:18px;
  --radius2:12px;
}

#top{scroll-margin-top:90px;}
@media (max-width:640px){ #top{scroll-margin-top:130px;} }


*{box-sizing:border-box}
html,body{height:100%}
body{
  margin:0;
  font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;
  background: radial-gradient(2000px 800px at 80% -20%, rgba(35,209,96,.18), transparent 40%),
              radial-gradient(2000px 600px at 10% 110%, rgba(35,209,96,.10), transparent 45%),
              var(--bg);
  color:var(--text);
  padding-top:74px;
  font-size:13.5px;
}

a{color:inherit}
.container{width:min(1080px, calc(100% - 44px)); margin:0 auto}
.page{padding:22px 0 64px 0}

.topbar{
  position:fixed; top:0; left:0; right:0; z-index:50;
  background:rgba(6,8,10,1);
  border-bottom:1px solid rgba(255,255,255,.08);
}
.topbar-inner{display:flex; align-items:center; justify-content:space-between; height:64px; gap:16px}
.brandlink{display:flex; align-items:center; gap:10px; text-decoration:none}
.nav-icon{
  width:40px; height:40px;
  border-radius:10px;
  object-fit:contain;
  background:rgba(0,0,0,.95);
  box-shadow:0 10px 30px rgba(5,59,0,.22);
}

.nav-title{font-size:20px; letter-spacing:.3px}
.navlinks{display:flex; align-items:center; gap:10px; flex-wrap:wrap; justify-content:flex-end}
.navlinks a{text-decoration:none; color:rgba(255,255,255,.88); font-size:10px}
.navlinks a:hover{color:#fff}
.nav-cta{padding:6px 10px; border-radius:999px; border:1px solid rgba(255,255,255,.14); background:rgba(6,59,0,.18)}
.navlinks a{ display:inline-block; transition:transform .15s ease;}
.navlinks a:hover{transform:scale(1.1);
}

@media (max-width: 640px){
  .topbar-inner{display:flex; flex-wrap:wrap; align-items:center}
  .navlinks{flex:0 0 100%; width:100%; justify-content:space-evenly; margin-top:10px}
}

@media (max-width: 640px){
  /* remove the gap */
  .navlinks{ margin-top:0 !important; }

  /* make the second-row bar full-bleed (edge-to-edge) */
  .navlinks{
    position:relative;
    padding:10px 12px;
    justify-content:space-evenly;
    z-index:1000;
  }

  .navlinks::before{
    content:"";
    position:absolute;
    top:0;
    bottom:0;
    left:50%;
    transform:translateX(-50%);
    width:100vw;                
    background:rgba(6,8,10,1);
    border-bottom:1px solid rgba(255,255,255,.08);
    z-index:-1;                
  }
}



.kicker{letter-spacing:.22em; font-size:12px; opacity:.72; margin:0 0 10px 0}
h1{font-size:40px; line-height:1.05; margin:0 0 12px 0; letter-spacing:-.01em}
h2{font-size:20px; margin:0 0 12px 0}
h3{font-size:16px; margin:0 0 8px 0}
.subhead{font-size:15px; color:var(--muted); line-height:1.55; margin:0 0 16px 0}
.lead{font-size:14px; line-height:1.6; margin:0 0 10px 0}
.muted{color:var(--muted)}
.small{font-size:12px; color:var(--muted2)}
.mono{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace; color:var(--muted2)}

.hero{
  display:grid;
  grid-template-columns: 1.2fr .8fr;
  gap:26px;
  align-items:center;
  padding:18px 0 10px 0;
}
.hero-media{display:flex; justify-content:flex-end}
/* Non-carousel image 50% smaller than earlier: target ~320px */
.hero-shot{
  width:min(320px, 100%);
  height:auto;
  border-radius:18px;
  border:1px solid var(--border);
  background:rgba(0,0,0,.16);
  box-shadow:var(--shadow);
}

.cta-row{
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  align-items:center;
  margin:12px 0 12px 0;
}
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:8px;
  padding:10px 14px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(0,0,0,.18);
  text-decoration:none;
  color:rgba(255,255,255,.92);
  font-weight:600;
  cursor:pointer;
}
.btn:hover{border-color:rgba(255,255,255,.24); background:rgba(0,0,0,.24)}
.btn.primary{background:rgba(35,209,96,.18); border-color:rgba(35,209,96,.35)}
.btn.primary:hover{background:rgba(35,209,96,.24)}
.btn.disabled{opacity:.55; pointer-events:none}

.hero-bullets{display:flex; flex-wrap:wrap; gap:8px; margin:10px 0 0 0}
.pill{
  font-size:12px;
  padding:6px 8px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.12);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.84);
}

.section{padding:28px 0; border-top:1px solid rgba(255,255,255,.06)}
.section:first-of-type{border-top:none}
.sectionhead-row{display:flex; align-items:baseline; justify-content:space-between; gap:12px; flex-wrap:wrap;}

/* Fix anchor scrolling offset for sticky header */
.section{
  scroll-margin-top:74px;
}

.cards3{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:14px; margin-top:12px}
.copygrid{display:grid; grid-template-columns:repeat(2,minmax(0,1fr)); gap:8px; margin-top:12px}
.modegrid{display:grid; grid-template-columns:repeat(3,minmax(0,1fr)); gap:10px; margin-top:10px}

.card{
  background:linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.18));
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:14px 14px;
}
.smallcard{padding:14px}
.widecard{
  margin-top:14px;
  background:linear-gradient(180deg, rgba(255,255,255,.05), rgba(0,0,0,.22));
  border:1px solid rgba(255,255,255,.10);
  border-radius:var(--radius);
  padding:16px;
}

.mode{
  padding:10px 12px;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.18);
  color:rgba(255,255,255,.86);
  font-weight:600;
  font-size:14px;
}

.list{margin:8px 0 0 0; padding-left:18px}
.list li{margin:8px 0; color:rgba(255,255,255,.84)}
.tip{margin-top:10px; color:rgba(255,255,255,.76)}

.screens-block{margin-top:16px}
.screens-head{display:flex; align-items:center; justify-content:space-between; gap:10px; flex-wrap:wrap}
.controls{display:flex; gap:8px}

.carousel{
  margin-top:10px;
  border:1px solid rgba(255,255,255,.10);
  border-radius:18px;
  background:rgba(0,0,0,.16);
  overflow:hidden;
}
.carousel-track{
  display:flex;
  gap:12px;
  align-items:center;
  padding:12px;
  overflow-x:auto;
  scroll-snap-type:x mandatory;
}
.carousel-item{flex:0 0 auto; scroll-snap-align:center}
/* Thumbs: smaller & easy to scan */
.carousel-item img{
  height:150px;
  width:auto;
  border-radius:14px;
  display:block;
  cursor:pointer;
  border:1px solid rgba(255,255,255,.10);
  background:rgba(0,0,0,.10);
}

.footer{border-top:1px solid rgba(255,255,255,.08); padding:18px 0 24px 0}
.footer-inner{display:flex; gap:10px; justify-content:space-between; flex-wrap:wrap; color:rgba(255,255,255,.74)}

/* Lightbox viewer: ~50% of screen, click-through */
.noscroll{overflow:hidden}
.lightbox{
  position:fixed; inset:0;
  background:rgba(0,0,0,.72);
  display:none;
  align-items:center;
  justify-content:center;
  z-index:100;
}
.lightbox.open{display:flex}
.lightbox-img{
  max-width:70vw;   /* ~50-70% of screen depending on aspect */
  max-height:70vh;
  width:auto;
  height:auto;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.14);
  box-shadow:0 30px 90px rgba(0,0,0,.6);
}
.lightbox-close{
  position:fixed; top:18px; right:18px;
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.35);
  color:#fff;
  font-size:26px;
  line-height:1;
  cursor:pointer;
}
.lightbox-nav{
  position:fixed;
  top:50%;
  transform:translateY(-50%);
  width:44px; height:44px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.16);
  background:rgba(0,0,0,.35);
  color:#fff;
  cursor:pointer;
}
.lightbox-nav.prev{left:18px}
.lightbox-nav.next{right:18px}

@media (max-width: 580px){
  .hero{grid-template-columns:1fr}
  .hero-media{justify-content:flex-start}
  h1{font-size:40px}
  .cards3{grid-template-columns:1fr}
  .copygrid{grid-template-columns:1fr}
  .modegrid{grid-template-columns:1fr}
  .carousel-item img{height:140px}
  .lightbox-img{max-width:92vw; max-height:78vh}
}


/* --- Locked vertical spacing + device tiles (v7) --- */
:root{
  --section-pad: 34px;
  --section-gap: 14px;
}

.page{padding:24px 0 72px 0}
.hero{padding:22px 0 18px 0}
.section{padding: var(--section-pad) 0; border-top:1px solid rgba(255,255,255,.06)}
.section h2{margin-bottom: var(--section-gap)}
.section p{margin: 0 0 12px 0}
.section .card p:last-child{margin-bottom:0}
.cards3{margin-top:14px}
.copygrid{margin-top:14px}
.widecard{margin-top:14px}

.device-tiles{
  display:grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap:14px;
  margin-top:14px;
}

.device-tile{
  display:flex;
  gap:14px;
  align-items:center;
  width:100%;
  text-align:left;
  padding:14px;
  border-radius: 22px;
  border:1px solid rgba(255,255,255,.10);
  background: linear-gradient(180deg, rgba(255,255,255,.06), rgba(0,0,0,.18));
  cursor:pointer;
}

.device-tile:hover{
  border-color: rgba(255,255,255,.18);
  background: linear-gradient(180deg, rgba(255,255,255,.075), rgba(0,0,0,.22));
}

.device-tile:active{transform: translateY(1px)}

.device-tile-media img{
  height: 210px; /* bigger preview tile */
  width:auto;
  border-radius: 18px;
  border:1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.10);
  display:block;
}

.device-tile-title{
  font-size: 18px;
  font-weight: 650;
  color: rgba(255,255,255,.66);
  margin-bottom: 6px;
}

.device-tile-sub{
  font-size: 14px;
  color: rgba(255,255,255,.66);
}

.lightbox-badge{
  position: fixed;
  bottom: 18px;
  left: 50%;
  transform: translateX(-50%);
  padding: 8px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(0,0,0,.35);
  color: rgba(255,255,255,.90);
  font-size: 13px;
  backdrop-filter: blur(10px);
}

@media (max-width: 980px){
  .device-tiles{grid-template-columns:1fr}
  .device-tile-media img{height: 200px}
}
