/* ==========================================================================
   Klovis — pre-launch one-pager
   Faithful to the live Webflow design language (test-7c35d3.webflow.io):
   indigo accent, ink + two-tone heavy Inter, mono eyebrows, dot/grid canvas,
   layered-depth shadows, liquid-glass navbar, Lottie demo app-frame hero.
   ========================================================================== */
:root{
  --bg:#fff; --ink:#15151c; --ink-soft:#54586a; --muted:#9296a6;
  --accent:#5b56e0; --accent-soft:#e8e7fb; --accent-deep:#4b48b5; --accent-tint:#f3f2fd; --accent-line:#5b56e042;
  --line:#ececf1; --line-2:#dcdce4; --panel:#f3f3f7; --faint:#fbfbfd; --dot:#d7d8e2;
  --mono:ui-monospace,"SF Mono","SFMono-Regular",Menlo,monospace;
  --r-sm:10px; --r:14px; --r-lg:18px; --r-xl:24px; --r-pill:999px;
  --sh-sm:0 1px 2px #14152d0d,0 1px 1px #14152d08;
  --sh:0 2px 4px -2px #1e1c480f,0 10px 20px -10px #1e1c481f,inset 0 1px #ffffffb3;
  --sh-lg:0 4px 10px -4px #1e1c4814,0 26px 50px -16px #28246033,inset 0 1px #fffc;
  --nav-h:62px;
}
*{box-sizing:border-box}
html{scroll-behavior:smooth;scroll-padding-top:96px;-webkit-text-size-adjust:100%}
body{margin:0;font-family:'Inter',-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif;
  color:var(--ink);background:var(--bg);line-height:1.5;letter-spacing:-.006em;-webkit-font-smoothing:antialiased}
a{color:inherit;text-decoration:none}
img{max-width:100%;display:block}
::selection{background:var(--accent);color:#fff}
.wrap{width:100%;max-width:1180px;margin:0 auto;padding:0 24px;position:relative}
.center{text-align:center}.mauto{margin-left:auto;margin-right:auto}
.mw980{max-width:980px}.mw640{max-width:640px}.mw720{max-width:720px}

/* ---- typography ---- */
.display{color:var(--ink);letter-spacing:-.035em;margin:0 0 22px;font-size:72px;font-weight:800;line-height:.98}
.h2{color:var(--ink);letter-spacing:-.025em;margin:0 0 14px;font-size:34px;font-weight:700;line-height:1.12}
.h3{color:var(--ink);letter-spacing:-.01em;margin:0 0 8px;font-size:20px;font-weight:600}
.tone{color:var(--muted)}
.lead{max-width:50ch;color:var(--ink-soft);margin:0 0 24px;font-size:19px;line-height:1.55}
.muted{color:var(--muted)}
.mono{font-family:var(--mono);letter-spacing:.02em;font-size:13px}
.eyebrow{font-family:var(--mono);color:var(--muted);letter-spacing:.12em;text-transform:uppercase;
  margin-bottom:16px;font-size:12px;font-weight:500;display:block}
.eyebrow-accent{color:var(--accent)}
.eyebrow .num{color:var(--accent);margin-right:6px}

/* ---- buttons ---- */
.btn{border:1px solid var(--line-2);border-radius:var(--r-sm);background:var(--bg);height:44px;color:var(--ink);
  cursor:pointer;justify-content:center;align-items:center;column-gap:8px;padding:0 18px;font-size:14.5px;font-weight:500;
  text-decoration:none;transition:box-shadow .15s,transform .15s;display:inline-flex;box-shadow:var(--sh-sm);font-family:inherit}
.btn:hover{box-shadow:var(--sh);transform:translateY(-1px)}
.btn.sm{height:36px;padding:0 13px;font-size:13px}
.btn.lg{height:52px;padding:0 24px;font-size:15px}
.btn.solid{border-color:var(--ink);background:var(--ink);color:#fff}
.btn.accent{border-color:var(--accent);background:var(--accent);color:#fff;box-shadow:0 8px 24px -8px var(--accent-line)}
.btn.accent:hover{box-shadow:0 12px 32px -8px #5b56e066}
.btn.ghost{border-color:transparent;background:transparent;box-shadow:none;color:var(--accent)}

/* ---- sections ---- */
.wf{border-top:1px solid var(--line);padding:84px 0;position:relative}
.wf:first-of-type{border-top:none}
.wf.dots{background-image:radial-gradient(var(--dot) 1px,#0000 1.5px);background-size:22px 22px}
.wf.gridtex{background-image:linear-gradient(var(--line) 1px,#0000 1px),linear-gradient(90deg,var(--line) 1px,#0000 1px);background-size:30px 30px}
.glow{isolation:isolate;overflow:hidden}
.glow::after{content:"";position:absolute;top:-110px;right:-70px;width:600px;height:560px;pointer-events:none;z-index:0;
  background:radial-gradient(circle at 65% 35%,#5b56e073,#5b56e024 38%,transparent 64%);filter:blur(48px)}
.glow>.wrap{z-index:1}
.z1{position:relative;z-index:1}

/* ---- grids ---- */
.grid{display:grid;gap:24px}
.g2{grid-template-columns:repeat(2,1fr)}.g3{grid-template-columns:repeat(3,1fr)}.g4{grid-template-columns:repeat(4,1fr)}
.row2{display:grid;grid-template-columns:1fr 1fr;gap:64px;align-items:center}
.card{border:1px solid var(--line);border-radius:var(--r);background:var(--bg);padding:24px;box-shadow:var(--sh-sm);display:block}
.icon{background:var(--accent-soft);width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center}
.icon img{width:22px;height:22px}
.stat-n{color:var(--ink);letter-spacing:-.035em;font-size:46px;font-weight:800;line-height:1}
.stat-l{color:var(--muted);font-size:13.5px;margin-top:6px}

/* ==========================================================================
   NAVBAR — liquid glass
   ========================================================================== */
.nav{position:fixed;top:0;left:0;right:0;z-index:200;padding:0;
  transition:padding .45s cubic-bezier(.4,0,.2,1)}
.nav.scrolled{padding:12px 16px}
/* full-bleed translucent bar at top; contracts to a centered island on scroll */
.nav-inner{position:relative;max-width:none;margin:0;border-radius:0;overflow:visible;
  border-bottom:1px solid rgba(20,21,45,.06);
  transition:max-width .5s cubic-bezier(.4,0,.2,1),border-radius .5s cubic-bezier(.4,0,.2,1),box-shadow .45s,border-color .35s}
.nav.scrolled .nav-inner{max-width:980px;margin:0 auto;border-radius:20px;border-bottom-color:transparent;
  box-shadow:0 1px 0 #ffffffcc inset,0 20px 46px -14px #1e1c4845,0 2px 10px -4px #1e1c481f}
/* liquid-glass layers — visible at all times (Webflow look) */
.nav-glass{z-index:0;pointer-events:none;position:absolute;inset:0;overflow:hidden;border-radius:inherit}
.glass-blur{position:absolute;inset:-2px;border-radius:inherit;
  backdrop-filter:blur(10px) saturate(170%);-webkit-backdrop-filter:blur(10px) saturate(170%);
  filter:url(#glass-distortion)}
.glass-tint{position:absolute;inset:0;border-radius:inherit;background:rgba(255,255,255,.14)}
.glass-shine{position:absolute;inset:0;pointer-events:none;border-radius:inherit;
  box-shadow:inset 1px 1px 1px #ffffffb3,inset -1px -1px 1px #ffffff66}
/* inner row stays width-constrained at top, fills the island once scrolled */
.nav-row{z-index:1;align-items:center;column-gap:24px;height:var(--nav-h);display:flex;position:relative;
  max-width:1180px;margin:0 auto;padding:0 24px;transition:max-width .5s cubic-bezier(.4,0,.2,1),padding .45s}
.nav.scrolled .nav-row{max-width:none;padding:0 20px}
.nav-logo{width:auto;height:46px;display:block}
.cta-short{display:none}
.nav-items{z-index:1;align-items:center;column-gap:2px;margin-left:18px;display:flex;position:relative}
.navitem{align-items:center;display:flex;position:relative}
.navtrigger{color:var(--ink);white-space:nowrap;cursor:pointer;border-radius:8px;align-items:center;column-gap:5px;
  padding:8px 12px;font-size:14.5px;font-weight:500;display:inline-flex;background:none;border:none;font-family:inherit}
.navtrigger:hover{background:var(--panel)}
.navtrigger .chev{width:14px;height:14px;opacity:.5;transition:transform .18s}
.navitem:hover .navtrigger .chev{transform:rotate(180deg)}
.nav-right{z-index:1;align-items:center;column-gap:10px;margin-left:auto;display:flex;position:relative}

/* mega dropdown */
.mega{z-index:60;visibility:hidden;opacity:0;transform:translateY(6px);pointer-events:none;background:#fff;
  border:1px solid var(--line);border-radius:16px;margin-top:8px;padding:18px;position:absolute;top:100%;left:0;
  transition:opacity .18s,transform .18s;box-shadow:0 18px 50px -12px #1e1c4838}
.mega::before{content:"";height:16px;position:absolute;top:-16px;left:0;right:0}
.navitem:hover .mega,.navitem:focus-within .mega{visibility:visible;opacity:1;transform:translateY(0);pointer-events:auto}
.mega-product{width:600px}
.mega-grid{display:grid;grid-template-columns:1fr 1fr;gap:4px}
.mfeat{border-radius:12px;column-gap:12px;padding:11px;display:flex;align-items:flex-start}
.mfeat:hover{background:var(--accent-tint)}
.mfeat-ic{flex-shrink:0;width:22px;height:22px;margin-top:2px}
.mfeat-t{color:var(--ink);font-size:14px;font-weight:600}
.mfeat-d{color:var(--ink-soft);margin-top:2px;font-size:12px;line-height:1.35}
.mega-foot{border-top:1px solid var(--line);justify-content:space-between;align-items:center;margin-top:8px;padding-top:12px;display:flex}
.mega-foot-link{color:var(--accent);font-size:13.5px;font-weight:600}
.mega-cta{color:var(--ink);font-size:13.5px;font-weight:600}
.mega-product{width:min(600px,calc(100vw - 24px))}


/* ==========================================================================
   HERO + Lottie demo
   ========================================================================== */
.hero{padding-top:116px}
.launch-pill{display:inline-flex;align-items:center;gap:8px;height:30px;padding:0 14px;border-radius:var(--r-pill);
  background:var(--accent-tint);border:1px solid var(--accent-line);color:var(--accent-deep);font-size:12.5px;
  font-weight:600;margin-bottom:22px}
.launch-pill .dot{width:7px;height:7px;border-radius:50%;background:var(--accent);box-shadow:0 0 0 4px #5b56e022}
.hero-cta{display:flex;gap:10px;justify-content:center;flex-wrap:wrap;margin-bottom:8px}
.hero-note{color:var(--muted);font-size:13px;margin-top:14px}

/* framed product graphic (the "device" look) — used for hero + product-page heroes */
.lottie-frame{aspect-ratio:1520/900;background:#fff;background-image:radial-gradient(120% 120% at 0 0,#f7f7fb,#eeeef4 70%,#e7e7ef);
  border:1px solid var(--line);border-radius:var(--r-lg);width:100%;position:relative;overflow:hidden;box-shadow:var(--sh-lg)}
.lottie-frame dotlottie-player{width:100%;height:100%}
.hero-stage{margin-top:54px;max-width:1040px;margin-left:auto;margin-right:auto}
/* scroll-scrub graphic in feature rows */
.feat-media dotlottie-player{width:100%;height:auto;aspect-ratio:1520/900;display:block}
.scrub-media{border-radius:var(--r-lg);overflow:hidden;box-shadow:var(--sh);border:1px solid var(--line);background:#fff}

/* ==========================================================================
   CHANNELS strip
   ========================================================================== */
.chan-strip{display:flex;flex-wrap:wrap;gap:14px;justify-content:center;margin-top:28px}
.chan{display:inline-flex;align-items:center;gap:10px;height:46px;padding:0 18px;border-radius:var(--r-pill);
  border:1px solid var(--line);background:var(--bg);box-shadow:var(--sh-sm);font-size:14.5px;font-weight:500}
.chan img{width:22px;height:22px;border-radius:5px}

/* ==========================================================================
   PRODUCT feature rows
   ========================================================================== */
.feature{padding:64px 0;border-top:1px solid var(--line)}
.feature .row2{align-items:center}
.feat-media{border-radius:var(--r-lg);overflow:hidden;position:relative}
.feat-media img{width:100%;height:auto;display:block}
.feat-list{margin:18px 0 0;padding:0;list-style:none}
.feat-list li{display:flex;gap:10px;align-items:flex-start;color:var(--ink-soft);font-size:15px;padding:6px 0}
.feat-list li::before{content:"";width:18px;height:18px;flex:none;margin-top:1px;border-radius:6px;background:var(--accent-soft);
  background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%234b48b5' stroke-width='3' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='20 6 9 17 4 12'/%3E%3C/svg%3E");
  background-repeat:no-repeat;background-position:center}

/* ==========================================================================
   WHY / value cards
   ========================================================================== */
.why-card{border:1px solid var(--line);border-radius:var(--r);background:var(--bg);padding:26px;box-shadow:var(--sh-sm)}

/* ==========================================================================
   ABOUT
   ========================================================================== */
.about-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;margin-top:38px}

/* ==========================================================================
   WAITLIST — dark card
   ========================================================================== */
.cta-dark{padding:40px 0}
.cta-inner{position:relative;overflow:hidden;background:var(--ink);color:#fff;border-radius:var(--r-xl);
  padding:72px 56px;max-width:1100px;margin:0 auto;isolation:isolate;
  background-image:linear-gradient(#ffffff0d 1px,#0000 1px),linear-gradient(90deg,#ffffff0d 1px,#0000 1px);background-size:30px 30px}
.cta-inner::after{content:"";position:absolute;left:50%;bottom:-70px;transform:translateX(-50%);width:62%;height:80%;
  background:radial-gradient(circle,#5b56e0a6,transparent 58%);filter:blur(66px);z-index:0;pointer-events:none}
.cta-inner>*{position:relative;z-index:1}
.cta-inner .h2{color:#fff}
.cta-inner .lead{color:#aeb1c4;margin-left:auto;margin-right:auto}
.wait-form{display:flex;gap:10px;max-width:480px;margin:26px auto 0;flex-wrap:wrap}
.wait-form input{flex:1;min-width:220px;height:52px;border-radius:var(--r-sm);border:1px solid #ffffff2e;
  background:#ffffff14;color:#fff;padding:0 16px;font-size:15px;font-family:inherit;outline:none}
.wait-form input::placeholder{color:#ffffff80}
.wait-form input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #5b56e040}
.wait-form .btn.accent{height:52px;padding:0 24px}
.wait-success{display:none;margin:26px auto 0;max-width:480px;padding:18px 20px;border-radius:var(--r-sm);
  background:#ffffff14;border:1px solid #ffffff2e;color:#fff;font-size:15px;align-items:center;gap:10px;justify-content:center}
.wait-success.show{display:flex}
.wait-mini{color:#8a8ea3;font-size:12.5px;margin-top:14px}

/* ==========================================================================
   FOOTER
   ========================================================================== */
.ft{border-top:1px solid var(--line);background:var(--faint);padding:56px 0 36px}
.ft-grid{display:grid;grid-template-columns:1.6fr 1fr 1fr 1fr;gap:24px}
.ft-logo{height:34px;width:auto}
.ft-colh{color:var(--ink);letter-spacing:.01em;margin-bottom:12px;font-size:13px;font-weight:600}
.ft-link{color:var(--ink-soft);padding:5px 0;font-size:14px;display:block;background:none;border:none;text-align:left;cursor:pointer;font-family:inherit}
.ft-link:hover{color:var(--accent)}
.ft-bottom{border-top:1px solid var(--line);color:var(--muted);justify-content:space-between;align-items:center;
  margin-top:40px;padding-top:22px;font-size:12.5px;display:flex;gap:14px;flex-wrap:wrap}
.status{color:var(--ink-soft);align-items:center;column-gap:7px;font-size:12.5px;display:inline-flex}
.status-dot{background:#1f9d57;border-radius:50%;width:8px;height:8px}

/* ---- scroll reveal ---- */
.reveal{opacity:0;transform:translateY(18px);transition:opacity .6s ease,transform .6s ease}
.reveal.in{opacity:1;transform:none}

/* ==========================================================================
   RESPONSIVE
   ========================================================================== */
@media (max-width:991px){
  .display{font-size:56px}
  .row2{grid-template-columns:1fr;gap:36px}
  .feature .row2 .feat-media{order:-1}
  .feature.flip .row2 .feat-media{order:-1}
  .ft-grid{grid-template-columns:1fr 1fr 1fr}
}
@media (max-width:767px){
  .wf{padding:60px 0}
  .display{font-size:42px}
  .h2{font-size:28px}
  .lead{font-size:17px}
  .g3,.g4{grid-template-columns:1fr 1fr}
  .about-stats{grid-template-columns:1fr 1fr}
  .cta-inner{padding:48px 24px}
  .demo-sidebar{flex-wrap:nowrap;overflow-x:auto;justify-content:flex-start;max-width:100%;padding-bottom:6px;
    -webkit-overflow-scrolling:touch;scrollbar-width:none}
  .demo-sidebar::-webkit-scrollbar{display:none}
  .demo-tab{flex:0 0 auto}
  .ft-grid{grid-template-columns:1fr 1fr}
}
/* keep the navbar a normal, always-visible bar — just tighten it on small screens */
@media (max-width:620px){
  .nav-row{column-gap:6px;padding:0 12px}
  .nav.scrolled{padding:8px 10px}
  .nav.scrolled .nav-inner{max-width:100%}
  .nav-items{margin-left:4px;column-gap:0}
  .navtrigger{padding:8px 9px;font-size:13.5px}
  .nav-logo{height:38px}
  .nav-right .btn{height:34px;padding:0 12px;font-size:12.5px}
  /* center any nav dropdown to the viewport on small screens */
  .mega{position:fixed;top:76px;left:50%;right:auto;margin-top:0;
    width:calc(100vw - 24px);max-width:560px;
    transform:translateX(-50%) translateY(6px)}
  .navitem:hover .mega,.navitem:focus-within .mega{transform:translateX(-50%) translateY(0)}
  .mega-grid{grid-template-columns:1fr}
  .mega-product{width:calc(100vw - 24px);max-width:560px}
}
@media (max-width:479px){
  .display{font-size:36px}
  .g3,.g4{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr}
  .ft-grid{grid-template-columns:1fr}
  .wait-form .btn.accent{width:100%}
  .navtrigger{padding:8px 7px;font-size:13px}
  .cta-full{display:none}
  .cta-short{display:inline}
}

@media (prefers-reduced-motion:reduce){
  *{scroll-behavior:auto!important}
  .reveal{opacity:1!important;transform:none!important;transition:none}
  .btn:hover{transform:none}
}

/* Home page: graphics sit directly on the page — no card chrome around images */
.home .lottie-frame,
.home .scrub-media,
.home .feat-media{background:none;border:none;box-shadow:none;border-radius:0;overflow:visible}

/* Home hero: Lottie flush to the bottom edge, no divider, faded into the page */
.home .hero{padding-bottom:0}
.home .hero + .wf{border-top:none}
.home .hero-stage{position:relative;margin-bottom:0}
.home .hero-fade{position:absolute;left:50%;transform:translateX(-50%);bottom:0;width:100vw;height:30%;
  background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,var(--bg) 60%);pointer-events:none;z-index:3}
@media (max-width:767px){
  /* bigger hero Lottie on mobile — full-bleed past the page padding */
  .home .hero-stage{margin-top:36px;margin-left:-24px;margin-right:-24px;width:calc(100% + 48px);max-width:none}
  .home .hero-fade{height:24%}
}

/* ===================== revision batch ===================== */
/* never use the mono font — route --mono to the body sans stack */
:root{--mono:'Inter',-apple-system,BlinkMacSystemFont,'Segoe UI',Roboto,sans-serif}
/* card icons: no background, just the glyph */
.icon{background:none;width:auto;height:auto;justify-content:flex-start}
.icon img{width:28px;height:28px}
/* make centering utilities win over element margin/max-width defaults */
.mauto{margin-left:auto;margin-right:auto}
.mw980{max-width:980px}.mw720{max-width:720px}.mw640{max-width:640px}
/* full-width outreach sequence media */
.outreach-media-full{max-width:980px;margin:28px auto 0}
.outreach-media-full dotlottie-player{width:100%;height:auto;display:block}
/* card grids: drop to one-by-one full width once cramped */
@media (max-width:880px){.g4{grid-template-columns:1fr 1fr}}
@media (max-width:767px){
  .g3,.g4{grid-template-columns:1fr}
  .about-stats{grid-template-columns:1fr}   /* stats stop bunching in 3s */
  .hero{padding-top:110px}                   /* more room under the navbar on mobile */
}

/* ===== export graphics + square hero crop (temp site) ===== */
/* framed product screenshots */
.shot{display:block;width:100%;height:auto;border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--sh-lg)}
.shot-plain{display:block;width:100%;height:auto}
/* tall campaign-steps graphic: crop to roughly square, top steps shown, bottom faded */
.seq-crop{position:relative;width:100%;max-width:520px;margin:28px auto 0;aspect-ratio:1/1;overflow:hidden}
.seq-crop dotlottie-player{position:absolute;top:0;left:0;width:100%;height:auto;display:block}
.seq-fade{position:absolute;inset:auto 0 0 0;height:42%;pointer-events:none;z-index:2;
  background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,var(--bg) 72%)}
/* product hero without the card frame (matches the home hero, graphic on the dot grid) */
.hero-bare{position:relative}
.hero-bare .lottie-frame{background:none;border:none;box-shadow:none;border-radius:0;overflow:visible}
.hero-bare .hero-fade{position:absolute;inset:auto 0 0 0;width:100%;height:30%;pointer-events:none;z-index:3;
  background:linear-gradient(to bottom,rgba(255,255,255,0) 0%,var(--bg) 60%)}
/* nav CTA never wraps; drop About on small screens to avoid overflow */
.nav-right .btn{white-space:nowrap}
@media (max-width:620px){ .nav-items .navitem:last-child{display:none} }
/* tighter feature/why sections on mobile */
@media (max-width:767px){
  .feature{padding:42px 0}
  .why-card{padding:20px}
}
