:root{
  --bg:#00172b;
  --panel:#002a4a;
  --text:#e6edf6;
  --muted:#9fb3c8;
  --accent:#1ad1b9;
  --accent-2:#37a9e0;
  --ring:#263247;
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;background:var(--bg);color:var(--text);font:16px/1.5 'Inter',system-ui,-apple-system,Segoe UI,Roboto,Arial,sans-serif}
.container{max-width:1100px;margin:0 auto;padding:24px}
.nav{position:sticky;top:0;backdrop-filter:saturate(140%) blur(8px);background:linear-gradient(180deg, rgba(0,16,32,.88), rgba(0,16,32,.72));border-bottom:1px solid #1b2636;z-index:50}
.nav-inner{display:flex;align-items:center;justify-content:space-between;gap:16px}
.brand{display:flex;align-items:center;gap:10px;color:var(--text);text-decoration:none;font-weight:700;letter-spacing:.3px}
.nav a{color:var(--muted);text-decoration:none;margin-left:16px}
.nav a:hover{color:var(--text)}
.hero{display:grid;grid-template-columns:1.1fr .9fr;gap:28px;align-items:center;min-height:70vh}
.hero h1{font-size:clamp(28px,5vw,48px);line-height:1.1;margin:0 0 8px}
.accent{background:linear-gradient(90deg,var(--accent),var(--accent-2));-webkit-background-clip:text;background-clip:text;color:transparent}
.lead{color:#c7d2e2;max-width:60ch}
.cta-row{display:flex;gap:12px;margin:18px 0 6px}
.btn{display:inline-block;padding:12px 18px;border-radius:14px;border:1px solid #2a3a55;text-decoration:none;color:var(--text);transition:.15s ease;cursor:pointer}
.btn.primary{background:linear-gradient(180deg,#1ad1b9,#37a9e0)}
.btn.primary:hover{transform:translateY(-1px)}
.btn.ghost{background:transparent}
.fine{color:var(--muted);font-size:.9rem}
.hero-media .device{background:radial-gradient(1200px 500px at 50% 0%, #1b2a41, transparent);border:1px solid #1f2b41;border-radius:20px;padding:10px;box-shadow:0 10px 50px rgba(0,0,0,.25)}
.hero-media img{width:100%;height:auto;display:block;border-radius:12px}
.two-col{display:grid;grid-template-columns:1fr 1fr;gap:24px}
.card{background:var(--panel);border:1px solid #1f2b41;border-radius:16px;padding:18px}
.steps{list-style:none;padding:0;margin:0}
.steps li{display:flex;align-items:center;gap:12px;margin:10px 0}
.step{display:inline-grid;place-items:center;width:28px;height:28px;border-radius:8px;background:#1d2a3f;border:1px solid #2a3f62;color:#cfe1ff;font-weight:700}
.feature-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:18px}
.feature{background:var(--panel);border:1px solid #1f2b41;border-radius:16px;padding:18px;min-height:120px}
.demo .video-wrap{border:1px dashed #2a3a55;border-radius:16px;padding:8px}
.video-placeholder{display:grid;place-items:center;aspect-ratio:16/9;background:#0f1520;border-radius:12px;color:#7f93aa}
.download .waitlist{display:flex;gap:10px;margin:16px 0}
.footer{border-top:1px solid #1b2636;margin-top:40px}
.foot-inner{display:flex;gap:18px;align-items:center;justify-content:space-between}
@media (max-width:980px){
  .hero{grid-template-columns:1fr}
  .two-col{grid-template-columns:1fr}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
}
@media (max-width:560px){
  .feature-grid{grid-template-columns:1fr}
}


/* --- Slider --- */
.slider{position:relative;border:1px solid #1f2b41;border-radius:16px;overflow:hidden;background:#0f1520}
.slider .slides{display:flex;transition:transform .4s ease;will-change:transform}
.slider img{width:100%;height:auto;display:block;flex:0 0 100%}
.slider .dots{position:absolute;left:0;right:0;bottom:10px;display:flex;gap:6px;justify-content:center}
.slider .dot{width:10px;height:10px;border-radius:10px;border:1px solid #9fb3c8;background:transparent;opacity:.8}
.slider .dot.active{background:#9fb3c8}


/* --- Hero right-side 3-shot gallery --- */
.hero-media{display:flex;justify-content:center}
.hero-gallery{display:grid;gap:12px;align-content:start}
.hero-gallery .shot{
  width:80%;            /* 20% smaller than full width */
  border-radius:14px;
  border:1px solid #1f2b41;
  background:#0f1520;
  display:block;
  box-shadow:0 6px 30px rgba(0,0,0,.25);
}
@media (max-width:980px){
  .hero-gallery .shot{width:90%;}
}


/* --- Hero carousel (right side) --- */
.hero-media{display:flex;justify-content:center}
.hero-slider{position:relative;border:1px solid #1f2b41;border-radius:16px;overflow:hidden;background:#0f1520;max-width:336px;width:100%}
.hero-slides{display:flex;transition:transform .4s ease;will-change:transform}
.hero-slides img{width:100%;height:auto;display:block;flex:0 0 100%}
.hero-dots{position:absolute;left:0;right:0;bottom:8px;display:flex;gap:6px;justify-content:center}
.hero-dot{width:8px;height:8px;border-radius:10px;border:1px solid #9fb3c8;background:transparent;opacity:.85;cursor:pointer}
.hero-dot.active{background:#9fb3c8}

@media (max-width:980px){
  .hero-slider{max-width:520px;margin-top:10px}
}

/* --- Smaller video (50% width on desktop) --- */
.video-wrap.small{display:flex;justify-content:center}
.video-wrap.small video{width:25%;min-width:240px}
@media (max-width:980px){
  .video-wrap.small video{width:100%}
}


/* Override: make demo video 25% width on desktop (and keep 100% on mobile) */
.video-wrap.small video{width:25% !important; min-width:240px}
@media (max-width:980px){
  .video-wrap.small video{width:100% !important}
}


/* --- Bigger brand (2x) --- */
.brand img{width:80px;height:80px}
.brand span{font-size:2rem; line-height:1}
.nav-inner{gap:20px}


/* Match video width to hero carousel width */
.video-wrap.small{max-width:336px; margin-left:auto; margin-right:auto}
.video-wrap.small video{width:100% !important; min-width:0}
