:root{
  --bg: #070b0a;
  --card: rgba(255,255,255,.06);
  --card2: rgba(255,255,255,.04);
  --stroke: rgba(255,255,255,.10);
  --text: rgba(255,255,255,.92);
  --muted: rgba(255,255,255,.72);
  --muted2: rgba(255,255,255,.60);
  --green: #33d06b;
  --green2: rgba(51,208,107,.22);
  --shadow: 0 24px 80px rgba(0,0,0,.55);
  --radius: 22px;
  --radius2: 16px;
  --max: 1120px;
  --font: ui-sans-serif, system-ui, -apple-system, Segoe UI, Roboto, Helvetica, Arial, "Apple Color Emoji","Segoe UI Emoji";

  /* Sticky header offset for anchor scrolling */
  --scroll-offset: 76px;
}


*{box-sizing:border-box}

html{
  height: 100%;
  scroll-behavior: smooth;
  scroll-padding-top: var(--scroll-offset);
}

body{height:100%}

@media (prefers-reduced-motion: reduce){
  html{ scroll-behavior: auto; }
}

body{
  margin:0;
  font-family: var(--font);
  background: var(--bg); /* matte base — no global gradients */
  color: var(--text);
  overflow-x:hidden;
}


a{color:inherit; text-decoration:none}
img{max-width:100%; display:block}

.container{
  width: min(var(--max), calc(100% - 48px));
  margin: 0 auto;
}

.bg-glow{
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: -1;

  /* One controlled glow, no banding / repeats */
  background: radial-gradient(900px 520px at 50% 10%, rgba(51,208,107,.14), transparent 60%);
  filter: blur(60px);
  opacity: .35;
}


/* Header */
.site-header{
  position: sticky;
  top:0;
  z-index: 40;
  background: linear-gradient(to bottom, rgba(0,0,0,.65), rgba(0,0,0,.15));
  border-bottom: 1px solid rgba(255,255,255,.06);
  backdrop-filter: blur(10px);
}
.header-inner{
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding: 14px 0;
  gap: 18px;
}
.brand{display:flex; align-items:center; gap:12px}
.brand-mark{height: 34px; width:auto}

.nav{display:flex; gap:18px}
.nav a{
  color: rgba(255,255,255,.75);
  font-weight: 650;
  font-size: 14px;
}
.nav a:hover{color: rgba(255,255,255,.92)}

.header-cta{display:flex; gap:10px; align-items:center}

/* Buttons & pills */
.btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  padding: 11px 16px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.88);
  font-weight: 750;
  font-size: 14px;
  cursor:pointer;
  transition: transform .15s ease, background .15s ease, border-color .15s ease;
}
.btn:hover{transform: translateY(-1px)}
.btn-primary{
  background: linear-gradient(180deg, rgba(51,208,107,.95), rgba(35,166,82,.95));
  color: rgba(0,0,0,.88);
  border-color: rgba(51,208,107,.65);
  box-shadow: 0 18px 60px rgba(51,208,107,.18);
}
.btn-primary:hover{border-color: rgba(51,208,107,.85)}
.btn-ghost{
  background: rgba(255,255,255,.04);
  border-color: rgba(255,255,255,.10);
}
.w-100{width:100%}

.pill{
  display:inline-flex;
  align-items:center;
  padding: 7px 12px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  color: rgba(255,255,255,.76);
  font-size: 12px;
  font-weight: 700;
}
.pill-green{
  border-color: rgba(51,208,107,.30);
  background: rgba(51,208,107,.12);
  color: rgba(255,255,255,.88);
}

.dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--green);
  box-shadow: 0 0 0 6px rgba(51,208,107,.14);
  display:inline-block;
}

/* Hero */
.hero{
  padding: 54px 0 22px;
}
.hero-grid{
  display:grid;
  grid-template-columns: 1.08fr .92fr;
  gap: 36px;
  align-items:center;
}
.eyebrow{
  display:flex;
  align-items:center;
  gap: 10px;
  color: rgba(255,255,255,.72);
  font-weight: 700;
  font-size: 13px;
}
.hero h1{
  font-size: clamp(42px, 5vw, 64px);
  line-height: 1.03;
  letter-spacing: -0.04em;
  margin: 12px 0 16px;
}
.lead{
  color: rgba(255,255,255,.70);
  font-size: 15px;
  line-height: 1.55;
  max-width: 56ch;
  margin: 0 0 18px;
}
.hero-actions{display:flex; gap: 12px; flex-wrap:wrap}
.hero-pills{display:flex; gap:10px; flex-wrap:wrap; margin-top: 12px}

.hero-visual{
  display:flex;
  flex-direction:column;
  align-items:center;
  gap: 12px;
}

.device-card{
  width: 100%;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.025);
  box-shadow: inset 0 1px 0 rgba(255,255,255,.05), 0 30px 90px rgba(0,0,0,.42);
  overflow:hidden;
  position:relative;
}
.device-card:before{
  content:"";
  position:absolute;
  inset:-2px;
  background: radial-gradient(520px 360px at 38% 22%, rgba(51,208,107,.14), transparent 62%);
  pointer-events:none;
}
.hero-devices{
  padding: 18px;
  filter: drop-shadow(0 24px 70px rgba(0,0,0,.62));
}


.hero-badges{
  display:flex;
  gap: 10px;
  flex-wrap:wrap;
  justify-content:center;
}

/* Sections */
.section{padding: 42px 0}
/* Reduce spacing specifically for 30-day section */
#setup-runway{
  padding-top: 28px;
  padding-bottom: 32px;
}


/* Matte band for pricing (prevents background glow from bleeding through) */

#pricing{
  background: #000;
}

/* Matte black band behind the Features + Chaos/Control sections
   (removes the “repeating gradient” look caused by the global body background) */
#features,
#features + .section{
  background: #000;
}

/* Matte black band behind the Product section too (removes body glow/gradient bleed) */
#product{
  background: #000;
}


/* Keep spacing rhythm consistent when the two sections share one background band */
#features{padding-bottom: 26px;}
#features + .section{padding-top: 26px;}

.section-center{text-align:center}
.section-title{
  font-size: clamp(26px, 3.2vw, 40px);
  letter-spacing: -0.03em;
  margin: 0;
}
.section-subtitle{
  color: rgba(255,255,255,.68);
  margin: 10px auto 0;
  max-width: 72ch;
  line-height: 1.6;
  font-size: 14px;
}
.section-head{
  text-align:center;
  margin-bottom: 18px;
}

/* Feature cards grid */
.card-grid{
  display:grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}
.feature-card{
  border-radius: var(--radius);
  background: rgba(255,255,255,.035);
  border: 1px solid rgba(255,255,255,.10);
  padding: 20px;
  box-shadow: 0 22px 80px rgba(0,0,0,.38);
  position:relative;
  overflow:hidden;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}
.feature-card:hover{
  transform: translateY(-2px);
  border-color: rgba(255,255,255,.16);
  background: rgba(255,255,255,.045);
}
.feature-card:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(420px 320px at 30% 18%, rgba(51,208,107,.12), transparent 64%);
  opacity: .9;
  pointer-events:none;
}

.feature-icon{
  font-size: 18px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  display:flex;
  align-items:center;
  justify-content:center;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
  margin-bottom: 12px;
}
.feature-card h3{
  margin: 0 0 8px;
  font-size: 16px;
  letter-spacing: -0.02em;
}
.feature-card p{
  margin:0;
  color: rgba(255,255,255,.66);
  font-size: 13px;
  line-height: 1.55;
}

/* Workflow power strip */
.workflow-strip{
  margin-top: 16px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
}
.workflow-item{
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  padding: 14px 16px;
  position:relative;
  overflow:hidden;
}
.workflow-item:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(520px 360px at 30% 20%, rgba(51,208,107,.10), transparent 62%);
  pointer-events:none;
  opacity:.65;
}
.workflow-title{
  font-size: 13px;
  letter-spacing: .02em;
  text-transform: uppercase;
  color: rgba(255,255,255,.86);
  margin: 0 0 6px;
}
.workflow-item p{
  margin:0;
  font-size: 13px;
  line-height: 1.55;
  color: rgba(255,255,255,.66);
}


/* Split old/new */
.split{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}
.split-card{
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.035);
  padding: 20px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.old-way{
  background: rgba(0,0,0,.18);
  border-color: rgba(255,255,255,.08);
}
.old-way:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(520px 380px at 30% 18%, rgba(255,255,255,.05), transparent 62%);
  pointer-events:none;
  opacity:.55;
}
.new-way{
  border-color: rgba(51,208,107,.24);
  background: rgba(51,208,107,.04);
}
.new-way:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(620px 440px at 30% 18%, rgba(51,208,107,.20), transparent 62%);
  pointer-events:none;
  opacity:.9;
}

.split-title{
  margin: 0 0 10px;
  font-size: 18px;
  letter-spacing: -0.02em;
}
.checklist{
  list-style:none;
  margin:10px 0 0;
  padding:0;
}
.checklist li{
  position:relative;
  padding-left: 22px;
  margin: 8px 0;
  color: rgba(255,255,255,.7);
  font-size: 13px;
}

/* Default = GOOD (green check) */
.new-way .checklist li:before{
  content:"✓";
  position:absolute;
  left:0;
  top:0;
  color: var(--green);
  font-weight:700;
}

/* Old Way = muted red X (bad) */
.old-way .checklist li:before{
  content:"✕";
  position:absolute;
  left:0;
  top:0;
  color: rgba(255,95,95,.72);
  font-weight:800;
}


.track-line{
  display:flex;
  justify-content:center;
  gap: 10px;
  margin-top: 18px;
  opacity:.9;
}
.track-dot{
  width: 10px;
  height: 10px;
  border-radius: 999px;
  background: rgba(51,208,107,.35);
  box-shadow: 0 0 0 6px rgba(51,208,107,.10);
}

.product-showcase{
  display:grid;
  grid-template-columns: 0.86fr 1.36fr;
  gap: 18px;
  align-items: start;
  margin-top: 14px;
}

/* Cap the left column so the screenshot always wins on wide screens */
.showcase-left{
  max-width: 460px;
}


/* Walkthrough layout: match left stack height and center the preview */
.product-showcase.is-walkthrough{
  align-items: stretch;
}

.product-showcase.is-walkthrough .feature-item{cursor:pointer}

/* Disable sticky for this section so the preview can center against the full left stack */
.product-showcase.is-walkthrough .showcase-right{
  position: static;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.showcase-hint{
  margin-top: 12px;
  color: rgba(255,255,255,.55);
  font-size: 12px;
  padding-left: 2px;
}

.feature-stack{
  display:grid;
  gap: 9px;
}


.feature-item{
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 10px 11px;
  position:relative;
  overflow:hidden;
  transition: border-color .25s ease, background .25s ease, transform .25s ease;
}


.feature-item:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(520px 360px at 30% 20%, rgba(51,208,107,.12), transparent 62%);
  opacity: .0;
  pointer-events:none;
  transition: opacity .25s ease;
}
.feature-item.is-active{
  border-color: rgba(51,208,107,.26);
  background: rgba(51,208,107,.06);
  transform: translateY(-1px);
}
.feature-item.is-active:before{opacity:.9}
.feature-kicker{
  color: rgba(51,208,107,.95);
  font-weight: 800;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: .08em;
}

.feature-title{
  margin-top: 5px;
  font-size: 15px;
  font-weight: 850;
  letter-spacing:-0.02em;
}

.feature-desc{
  margin-top: 5px;
  color: rgba(255,255,255,.70);
  font-size: 12.5px;
  line-height: 1.5;
}


.screen-frame{
  border-radius: 22px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  box-shadow: var(--shadow);
  overflow:hidden;
  transform-style: preserve-3d;
  transition: transform .12s ease;
  position:relative;
  min-height: 420px;
}
.screen-frame:before{
  content:"";
  position:absolute;
  inset:-1px;
  background:
    radial-gradient(800px 520px at 40% 30%, rgba(51,208,107,.22), transparent 62%),
    radial-gradient(560px 360px at 70% 10%, rgba(255,255,255,.08), transparent 60%);
  opacity: .9;
  pointer-events:none;
}

.screen-glow{
  position:absolute;
  inset:-20%;
  background: radial-gradient(closest-side, rgba(51,208,107,.35), transparent 60%);
  filter: blur(18px);
  opacity: .55;
  animation: pulseGlow 3.6s ease-in-out infinite;
  pointer-events:none;
}
@keyframes pulseGlow{
  0%,100%{transform: translate3d(0,0,0) scale(1)}
  50%{transform: translate3d(0,-6px,0) scale(1.04)}
}

.screen-shine{
  position:absolute;
  inset:-60%;
  background: linear-gradient(120deg, transparent 40%, rgba(255,255,255,.10) 50%, transparent 60%);
  transform: translateX(-18%);
  animation: shine 5.8s ease-in-out infinite;
  pointer-events:none;
}
@keyframes shine{
  0%{transform: translateX(-28%) rotate(0deg)}
  50%{transform: translateX(16%) rotate(0deg)}
  100%{transform: translateX(-28%) rotate(0deg)}
}

.screen{
  position:absolute;
  inset: 0;
  width:100%;
  height:100%;
  object-fit: contain;
  padding: 18px;
  opacity: 0;
  transform: translate3d(24px,0,0) scale(.985);
  filter: drop-shadow(0 18px 50px rgba(0,0,0,.55));
  transition: opacity .45s ease, transform .55s cubic-bezier(.2,.9,.2,1);
}
.screen.is-active{
  opacity: 1;
  transform: translate3d(0,0,0) scale(1);
}

.screen-badges{
  position:absolute;
  left: 18px;
  right: 18px;
  bottom: 14px;
  display:flex;
  gap: 10px;
  flex-wrap: wrap;
  z-index: 2;
}

.proof-bar{
  margin-top: 14px;
  padding: 12px 14px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.03);
  display:grid;
  gap: 8px;
}
.proof-item{
  display:flex;
  align-items:flex-start;
  gap: 10px;
  color: rgba(255,255,255,.72);
  font-size: 13px;
  line-height: 1.45;
}
.proof-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-top: 5px;
  background: rgba(51,208,107,.95);
  box-shadow: 0 0 0 3px rgba(51,208,107,.14);
  flex: 0 0 auto;
}


/* Pricing */
.pricing-actions{
  display:flex;
  justify-content:center;
  margin: 18px 0 22px;
}
.toggle{
  display:inline-flex;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.05);
  padding: 4px;
  gap: 4px;
}
.toggle-btn{
  border:0;
  cursor:pointer;
  border-radius: 999px;
  padding: 9px 12px;
  background: transparent;
  color: rgba(255,255,255,.70);
  font-weight: 700;
}
.toggle-btn.is-active{
  background: rgba(51,208,107,.18);
  color: rgba(255,255,255,.92);
  border: 1px solid rgba(51,208,107,.26);
}

.pricing-grid{
  display:grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-top: 18px;
}

/* Blunt operator fine print */
.pricing-fineprint{
  margin-top: 14px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  border-radius: 16px;
  padding: 12px 14px;
}
.fine-row{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  color: rgba(255,255,255,.75);
  font-size: 13px;
  line-height: 1.45;
  padding: 8px 0;
}
.fine-row + .fine-row{
  border-top: 1px solid rgba(255,255,255,.08);
}
.fine-dot{
  width: 8px;
  height: 8px;
  border-radius: 999px;
  margin-top: 6px;
  background: rgba(51,208,107,.9);
  flex: 0 0 auto;
}


/* Right column wrapper (Broker + trust stack) */
.pricing-side{
  display:grid;
  gap: 12px;
}

/* Trust pills stacked (not 3-wide row) */
.mini-fineprint--stack{
  grid-template-columns: 1fr;
  margin-top: 0;
}

/* Subtle emphasis for primary card (Carrier) */
.pricing-card.is-primary{
  border-color: rgba(51,208,107,.28);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}

.pricing-card{
  border-radius: var(--radius);
  background: rgba(255,255,255,.04);
  border: 1px solid rgba(255,255,255,.10);
  padding: 18px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
/* Pricing cards: no glow overlay (keeps this section clean) */
.pricing-card:before{
  display:none;
}

.pricing-top{position:relative}
.pricing-label{font-weight:900; letter-spacing:-0.02em}
.pricing-price{margin-top:10px; display:flex; gap:8px; align-items:baseline}
.price{font-size: 44px; font-weight: 950; letter-spacing:-0.04em}
.unit{font-size: 14px; font-weight: 900; color: rgba(255,255,255,.82)}
.per{font-size: 14px; color: rgba(255,255,255,.65); font-weight: 700}
.pricing-note{margin-top: 6px; color: rgba(255,255,255,.65); font-size: 13px}

.pricing-list{
  margin: 14px 0 0;
  padding: 0;
  list-style:none;
  display:grid;
  gap: 8px;
  color: rgba(255,255,255,.72);
  position:relative;
}
.pricing-list li{padding-left: 18px; position:relative; font-size:13px; line-height:1.5}
.pricing-list li:before{
  content:"•";
  position:absolute;
  left:0;
  top:0;
  color: rgba(51,208,107,.95);
  font-weight: 900;
}

.pricing-cta{margin-top: 14px; display:grid; gap:10px; position:relative}

/* Carrier bullets under fleet table */
.carrier-bullets{
  list-style: none;
  padding: 0;
  margin: 16px 0 0;
  display: grid;
  gap: 8px;
  color: rgba(255,255,255,.74);
  font-size: 13px;
}
.carrier-bullets li{
  position: relative;
  padding-left: 18px;
  line-height: 1.35;
}
.carrier-bullets li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 7px;
  width: 7px;
  height: 7px;
  border-radius: 999px;
  background: rgba(51,208,107,.95);
}
.carrier-bullets strong{
  color: rgba(255,255,255,.88);
  font-weight: 600;
}


.fleet-table{
  margin-top: 12px;
  border-radius: 16px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.18);
  overflow:hidden;
  position:relative;
}
.fleet-row{
  display:flex;
  justify-content:space-between;
  padding: 9px 14px; /* tighter */
  border-bottom: 1px solid rgba(255,255,255,.07);
  color: rgba(255,255,255,.78);
  font-size: 13px;
  line-height: 1.2;
}

.fleet-row:last-child{border-bottom:0}
.fleet-row strong{color: rgba(255,255,255,.92)}

.mini-fineprint{
  margin-top: 14px;
  display:grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
}
.mini-pill{
  display:flex;
  gap: 10px;
  align-items:flex-start;
  padding: 14px;
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  box-shadow: 0 18px 60px rgba(0,0,0,.35);
}
.mini-icon{
  width: 36px;
  height: 36px;
  display:flex;
  align-items:center;
  justify-content:center;
  border-radius: 12px;
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.10);
}
.mini-title{font-weight: 900; letter-spacing:-0.02em}
.mini-sub{color: rgba(255,255,255,.68); font-size: 13px; margin-top:4px; line-height:1.45}

/* CTA */
.cta{
  padding: 56px 0 70px;
}
.cta-inner{
  text-align:center;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(255,255,255,.04);
  padding: 26px 18px;
  box-shadow: var(--shadow);
  position:relative;
  overflow:hidden;
}
.cta-inner:before{
  content:"";
  position:absolute;
  inset:-1px;
  background: radial-gradient(760px 520px at 50% 40%, rgba(51,208,107,.20), transparent 62%);
  pointer-events:none;
}
.cta-inner h2{margin:0; font-size: 34px; letter-spacing:-0.03em}
.cta-inner p{margin:10px auto 0; color: rgba(255,255,255,.70); max-width:70ch}
.cta-actions{display:flex; gap: 12px; justify-content:center; flex-wrap:wrap; margin-top: 16px; position:relative}

/* Footer */
.site-footer{
  border-top: 1px solid rgba(255,255,255,.06);
  padding: 18px 0 28px;
  color: rgba(255,255,255,.68);
}
.footer-inner{display:flex; justify-content:space-between; align-items:center; gap: 14px; flex-wrap:wrap}
.footer-links{display:flex; gap: 14px}
.footer-links a{color: rgba(255,255,255,.68)}
.footer-links a:hover{color: rgba(255,255,255,.9)}

/* Modal */
.modal{position:fixed; inset:0; display:none; z-index: 60}
.modal[aria-hidden="false"]{display:block}
.modal-backdrop{
  position:absolute; inset:0;
  background: rgba(0,0,0,.62);
  backdrop-filter: blur(6px);
}
.modal-panel{
  position:relative;
  width: min(860px, calc(100% - 28px));
  margin: 8vh auto 0;
  border-radius: var(--radius);
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(20,24,22,.92);
  box-shadow: var(--shadow);
  padding: 18px;
}
.modal-close{
  position:absolute;
  right: 14px;
  top: 10px;
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.86);
  cursor:pointer;
  font-size: 22px;
}
.modal-panel h3{margin: 4px 0 6px; font-size: 22px}
.modal-sub{margin:0 0 14px; color: rgba(255,255,255,.68); font-size: 13px; line-height:1.5}

.modal-form{display:grid; gap: 12px}
.form-row{display:grid; grid-template-columns: 1fr 1fr; gap: 12px}
label{display:grid; gap: 8px; color: rgba(255,255,255,.78); font-weight: 750; font-size: 13px}
input,select,textarea{
  width:100%;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.22);
  color: rgba(255,255,255,.92);
  padding: 12px 12px;
  font: inherit;
  outline:none;
}
textarea{resize: vertical}
input:focus,select:focus,textarea:focus{border-color: rgba(51,208,107,.35)}
.form-actions{display:flex; gap: 10px; justify-content:flex-end; flex-wrap:wrap}
.form-hint{color: rgba(255,255,255,.55); font-size: 12px}

@media (max-width: 980px){
  .hero-grid{grid-template-columns: 1fr; gap: 18px}
  .card-grid{grid-template-columns: repeat(2,1fr)}
  .workflow-strip{grid-template-columns: 1fr}
  .split{grid-template-columns: 1fr}
  .pricing-grid{grid-template-columns: 1fr}
  .mini-fineprint{grid-template-columns: 1fr}
  .product-showcase{grid-template-columns: 1fr}
  .showcase-right{position: static; top: auto}
}


@media (max-width: 560px){
  .nav{display:none}
  .card-grid{grid-template-columns: 1fr}
  .form-row{grid-template-columns: 1fr}
}


/* Screenshot lightbox */
.lightbox{
  position: fixed;
  inset: 0;
  display: none;
  z-index: 9999;
}
.lightbox.is-open{ display:block; }

.lightbox-backdrop{
  position:absolute;
  inset:0;
  background: rgba(0,0,0,.72);
}

.lightbox-panel{
  position: absolute;
  left: 50%;
  top: 50%;
  transform: translate(-50%,-50%);
  width: min(1100px, calc(100vw - 28px));
  border-radius: 18px;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(0,0,0,.55);
  box-shadow: 0 30px 120px rgba(0,0,0,.55);
  padding: 14px;
}

.lightbox-img{
  width: 100%;
  height: auto;
  display:block;
  border-radius: 12px;
}

.lightbox-close{
  position:absolute;
  right: 10px;
  top: 10px;
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(255,255,255,.14);
  background: rgba(255,255,255,.06);
  color: rgba(255,255,255,.88);
  cursor:pointer;
}
.lightbox-close:hover{
  background: rgba(255,255,255,.10);
}

/* FAQ */
.faq .section-head{ margin-bottom: 18px; }

.faq-list{
  max-width: 920px;
  margin: 0 auto;
  display: grid;
  gap: 10px;
}

.faq-item{
  border: 1px solid rgba(255,255,255,.10);
  background: rgba(0,0,0,.35);
  border-radius: 16px;
  overflow: hidden;
}

.faq-item summary{
  cursor: pointer;
  list-style: none;
  padding: 16px 18px;
  font-weight: 600;
  color: rgba(255,255,255,.88);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}

.faq-item summary::-webkit-details-marker{ display: none; }

.faq-icon{
  width: 18px;
  height: 18px;
  border-radius: 999px;
  border: 1px solid rgba(255,255,255,.18);
  position: relative;
  flex: 0 0 auto;
}

.faq-icon::before,
.faq-icon::after{
  content: "";
  position: absolute;
  left: 50%;
  top: 50%;
  width: 10px;
  height: 2px;
  background: rgba(51,208,107,.95);
  transform: translate(-50%,-50%);
}

.faq-icon::after{
  transform: translate(-50%,-50%) rotate(90deg);
}

.faq-item[open] .faq-icon::after{
  display: none;
}

.faq-content{
  padding: 0 18px 16px;
  color: rgba(255,255,255,.72);
  font-size: 14px;
  line-height: 1.55;
  border-top: 1px solid rgba(255,255,255,.08);
}


/* 30 Day Setup Runway */
.setup-runway{
  background: #000; /* clean matte band */
}

.setup-copy{
  max-width: 760px;
  margin: 18px auto 0;
  color: var(--muted);
  font-size: 15px;
  line-height: 1.65;
}

.setup-copy strong{
  color: var(--text);
}


.setup-list li{
  position: relative;
  padding-left: 20px;
}

.setup-list li::before{
  content: "";
  position: absolute;
  left: 0;
  top: 8px;
  width: 8px;
  height: 8px;
  border-radius: 999px;
  background: var(--green);
}

.setup-footnote{
  margin-top: 16px;
  font-size: 13px;
  color: var(--muted2);
}


/* 30-Day Runway (Inside Pricing) */

.pricing-runway{
  margin-top: 12px;
  padding-top: 8px;
  text-align: center;
}


.pricing-runway h3{
  font-size: 28px;
  margin-bottom: 12px;
}

.pricing-runway-body{
  max-width: 820px;
  margin: 0 auto 10px auto;
  color: #bdbdbd;
  line-height: 1.6;
}

.pricing-runway-footnote{
  font-size: 13px;
  color: #8a8a8a;
}

#pricing{
  padding-bottom: 40px;
}

/* ============================= */
/* Legal / EULA Page Styling     */
/* ============================= */

.legal-section{
  padding: 72px 0;
  background: #000;
}

.legal-container{
  max-width: 920px;
  margin: 0 auto;
}

.legal-container h1{
  font-size: 40px;
  margin-bottom: 12px;
}

.legal-date{
  font-size: 14px;
  color: var(--muted2);
  margin-bottom: 32px;
}

.legal-container h2{
  font-size: 20px;
  margin-top: 36px;
  margin-bottom: 12px;
}

.legal-container p{
  color: var(--muted);
  line-height: 1.7;
  margin-bottom: 16px;
  font-size: 15px;
}

.legal-container ul{
  margin: 12px 0 16px 20px;
  color: var(--muted);
  line-height: 1.7;
  font-size: 15px;
}

.legal-container li{
  margin-bottom: 8px;
}

.legal-divider{
  margin: 48px 0;
  border-top: 1px solid rgba(255,255,255,0.08);
}


/* ============================= */
/* Cookie Banner                 */
/* ============================= */

.cookie-banner{
  position: fixed;
  left: 16px;
  right: 16px;
  bottom: 16px;
  z-index: 9999;
}

.cookie-inner{
  max-width: 1100px;
  margin: 0 auto;
  border: 1px solid rgba(255,255,255,.12);
  background: rgba(10,10,10,.92);
  backdrop-filter: blur(10px);
  border-radius: var(--radius2);
  padding: 14px 14px;
  display: flex;
  gap: 14px;
  align-items: center;
  justify-content: space-between;
  box-shadow: 0 20px 70px rgba(0,0,0,.55);
}

.cookie-copy{
  min-width: 0;
}

.cookie-title{
  font-weight: 700;
  margin-bottom: 4px;
}

.cookie-text{
  color: var(--muted);
  font-size: 13px;
  line-height: 1.45;
}

.cookie-text a{
  color: var(--text);
  text-decoration: underline;
  text-underline-offset: 3px;
}

.cookie-actions{
  display: flex;
  gap: 10px;
  flex-shrink: 0;
}

@media (max-width: 720px){
  .cookie-inner{
    flex-direction: column;
    align-items: stretch;
  }
  .cookie-actions{
    justify-content: flex-end;
  }
}
