:root{
  --navy:#08214a;
  --navy-2:#0b326d;
  --ink:#172033;
  --muted:#657189;
  --line:#e7ecf5;
  --soft:#f5f8fc;
  --white:#ffffff;
  --cyan:#20c8f4;
  --blue:#2e69ff;
  --purple:#7b3ff2;
  --pink:#f23c8f;
  --orange:#ff9a24;
  --green:#5bd45b;
  --shadow:0 24px 70px rgba(8,33,74,.14);
  --radius:28px;
  --content-max:1475px;
}

@font-face{
  font-family:'PublicSansThin';
  src:url('../fonts/PublicSans-Thin.woff2') format('woff2');
  font-weight:100;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'PublicSansBold';
  src:url('../fonts/PublicSans-Bold.woff2') format('woff2');
  font-weight:700;
  font-style:normal;
  font-display:swap;
}
@font-face{
  font-family:'Aptos Display';
  src:
    local('Aptos Display Bold'),
    local('Aptos-Display-Bold'),
    url('../fonts/Aptos-Display-Bold.ttf') format('truetype');
  font-weight:700;
  font-style:normal;
  font-display:swap;
}

*{box-sizing:border-box}
html{scroll-behavior:smooth}
body{
  margin:0;
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;
  color:var(--ink);
  background:
    radial-gradient(circle at 7% 5%, rgba(32,200,244,.22), transparent 27%),
    radial-gradient(circle at 85% 9%, rgba(255,154,36,.18), transparent 29%),
    linear-gradient(180deg,#f8fbff 0%,#ffffff 44%,#f4f8ff 100%);
  line-height:1.5;
}

a{color:inherit;text-decoration:none}
img,svg{max-width:100%;display:block}

.page-shell{
  width:min(var(--content-max), calc(100% - 36px));
  margin:0 auto;
}

.announcement{
  width:min(var(--content-max), calc(100% - 36px));
  margin:18px auto 0;
  padding:10px 16px;
  border:1px solid rgba(46,105,255,.18);
  background:rgba(255,255,255,.72);
  backdrop-filter:blur(18px);
  border-radius:999px;
  display:flex;
  align-items:center;
  justify-content:center;
  gap:10px;
  color:#2f3e57;
  font-size:13px;
  box-shadow:0 10px 30px rgba(8,33,74,.07);
}
.announcement .dot{
  width:9px;height:9px;border-radius:50%;
  background:linear-gradient(135deg,var(--pink),var(--orange),var(--green));
  box-shadow:0 0 0 6px rgba(242,60,143,.10);
  flex:0 0 auto;
}

header{
  width:min(var(--content-max), calc(100% - 36px));
  margin:18px auto 0;
  border:1px solid rgba(231,236,245,.82);
  background:rgba(255,255,255,.82);
  backdrop-filter:blur(22px);
  border-radius:26px;
  padding:16px 18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  position:sticky;
  top:14px;
  z-index:10;
  box-shadow:0 12px 40px rgba(8,33,74,.08);
}

.brand{display:flex;align-items:center;font-weight:900;color:var(--navy)}
.brand-logo{
  height:52.5px;
  width:auto;
  max-width:240px;
  display:block;
  object-fit:contain;
}
nav{display:flex;align-items:center;gap:26px;color:#526076;font-size:14px;font-weight:700}
nav a:hover{color:var(--blue)}
.nav-cta{
  padding:12px 17px;
  border-radius:14px;
  color:white;
  background:linear-gradient(135deg,var(--navy),var(--blue));
  box-shadow:0 12px 24px rgba(46,105,255,.24);
}
.nav-login{
  padding:12px 17px;
  border-radius:14px;
  color:var(--navy);
  background:#fff;
  border:1px solid #dce4f2;
  box-shadow:0 10px 24px rgba(8,33,74,.08);
}
.nav-login:hover{color:var(--blue);border-color:#c8d6ee}

.hero{
  width:min(var(--content-max), calc(100% - 36px));
  margin:28px auto 56px;
  display:grid;
  grid-template-columns: .95fr 1.05fr;
  min-height:680px;
  border-radius:var(--radius);
  overflow:hidden;
  background:rgba(255,255,255,.88);
  box-shadow:var(--shadow);
  border:1px solid rgba(231,236,245,.9);
}

.hero-visual{
  min-height:680px;
  background:
    linear-gradient(180deg,rgba(8,33,74,.08),rgba(8,33,74,.64)),
    radial-gradient(circle at 78% 24%, rgba(32,200,244,.55), transparent 20%),
    radial-gradient(circle at 22% 72%, rgba(255,154,36,.42), transparent 26%),
    linear-gradient(135deg,#dce8f5 0%,#a8bfd9 43%,#203a61 100%);
  position:relative;
  padding:34px;
  color:white;
  isolation:isolate;
}
.hero-visual::before{
  content:"";
  position:absolute;inset:0;
  background:
    linear-gradient(90deg,transparent 0 12%,rgba(255,255,255,.08) 12% 12.35%,transparent 12.35% 23%,rgba(255,255,255,.08) 23% 23.35%,transparent 23.35% 100%),
    linear-gradient(0deg,transparent 0 16%,rgba(255,255,255,.08) 16% 16.25%,transparent 16.25% 29%,rgba(255,255,255,.08) 29% 29.25%,transparent 29.25% 100%);
  opacity:.65;
  z-index:-2;
}
.hero-visual::after{
  content:"";
  position:absolute;
  right:-80px;bottom:-120px;
  width:330px;height:330px;
  border-radius:50%;
  background:radial-gradient(circle,rgba(32,200,244,.5),transparent 64%);
  z-index:-1;
}

.plant-card{
  position:absolute;
  left:36px;right:36px;bottom:36px;
  padding:24px;
  border-radius:24px;
  background:rgba(8,33,74,.72);
  border:1px solid rgba(255,255,255,.18);
  backdrop-filter:blur(18px);
  box-shadow:0 26px 70px rgba(0,0,0,.28);
  text-align:center;
}
.plant-card h3{margin:0 0 6px;font-size:24px;letter-spacing:-.04em;line-height:1.05}
.plant-card p{margin:0 auto;color:rgba(255,255,255,.76);font-size:14px;max-width:420px}

.hero-slider{
  position:absolute;
  left:20px;right:20px;
  top:14px;
  bottom:168px;
}
.hero-slider-viewport{
  width:100%;
  height:100%;
  overflow:hidden;
  border-radius:18px;
  border:1px solid rgba(255,255,255,.24);
  box-shadow:0 22px 44px rgba(0,0,0,.28);
  background:linear-gradient(180deg,#b8cfe4 0%,#8fadc8 100%);
  position:relative;
}
.hero-slider-track{
  display:flex;
  height:100%;
  transition:transform .55s ease;
}
.hero-slider-slide{
  position:relative;
  min-width:100%;
  height:100%;
  flex:0 0 100%;
  overflow:hidden;
}
.hero-slider-slide img{
  width:100%;
  height:100%;
  object-fit:cover;
  object-position:center center;
  display:block;
}
.hero-slider-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:38px;
  height:38px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.88);
  color:var(--navy);
  font-size:24px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 10px 24px rgba(0,0,0,.18);
  transition:transform .2s ease, background .2s ease;
  z-index:2;
}
.hero-slider-btn:hover{transform:translateY(-50%) scale(1.05);background:#fff}
.hero-slider-btn--prev{left:10px}
.hero-slider-btn--next{right:10px}
.hero-slider-dots{
  position:absolute;
  left:50%;
  bottom:12px;
  transform:translateX(-50%);
  display:flex;
  gap:8px;
  z-index:2;
}
.hero-slider-dot{
  width:9px;
  height:9px;
  border:none;
  border-radius:50%;
  padding:0;
  background:rgba(255,255,255,.45);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease;
}
.hero-slider-dot.is-active{
  background:#fff;
  transform:scale(1.15);
}
@media (prefers-reduced-motion: reduce){
  .hero-slider-track{transition:none}
}

.hero-content{
  padding:56px 56px 44px;
  display:flex;
  flex-direction:column;
  justify-content:space-between;
  position:relative;
  overflow:hidden;
}
.hero-content::before{
  content:"";
  position:absolute;right:-110px;top:-150px;width:360px;height:360px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,105,255,.14),transparent 66%);
}
.eyebrow{
  display:inline-flex;
  align-items:center;
  gap:9px;
  width:max-content;
  padding:9px 12px;
  border-radius:999px;
  background:#edf5ff;
  color:#174896;
  font-size:13px;
  font-weight:900;
  letter-spacing:.02em;
  margin-bottom:22px;
}
.eyebrow svg{width:15px;height:15px}
h1:not(#hero-title){
  font-size:clamp(44px,5vw,78px);
  line-height:.92;
  margin:0;
  color:var(--navy);
  letter-spacing:-.075em;
  max-width:720px;
}
h2.display-heading,
.display-heading,
#outcomes .dark-band h2.display-heading,
#outcomes .dark-band h2{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif !important;
  font-weight:700 !important;
  letter-spacing:.008em !important;
  font-size:clamp(34px,3.6vw,54px) !important;
  line-height:1.06 !important;
  max-width:none;
  width:max-content;
  margin:0 0 20px;
  color:inherit;
}
#hero-title,
.hero-content .display-heading{
  font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif !important;
  font-weight:700 !important;
  letter-spacing:-.04em !important;
  font-size:clamp(33.1px,3.51vw,52.6px) !important;
  line-height:1.05 !important;
  max-width:none;
  width:max-content;
  margin:0 0 20px;
  color:var(--navy);
}
#outcomes .dark-band .display-heading,
#outcomes .dark-band h2{
  color:#fff;
}
.display-heading .hero-title-line,
#hero-title .hero-title-line,
#outcomes .dark-band h2 .hero-title-line{
  display:block;
  white-space:nowrap;
}
.display-heading .gradient-text,
#hero-title .gradient-text{
  background:linear-gradient(105deg,var(--blue),var(--cyan),var(--green),var(--orange));
  -webkit-background-clip:text;background-clip:text;color:transparent;
}
.hero-tagline{
  font-size:19px;
  font-weight:650;
  color:var(--navy);
  max-width:675px;
  margin:26px 0 0;
  line-height:1.45;
}
.hero-lead{
  font-size:19px;
  color:#4e5d74;
  max-width:675px;
  margin:14px 0 0;
}
.hero-lead strong{color:var(--navy)}
.hero-actions{display:flex;gap:14px;flex-wrap:wrap;margin-top:34px}
.btn{
  display:inline-flex;align-items:center;justify-content:center;gap:10px;
  min-height:52px;padding:0 22px;border-radius:16px;
  font-weight:900;border:1px solid transparent;
  transition:.2s ease;
}
.btn-primary{background:linear-gradient(135deg,var(--navy),var(--blue));color:#fff;box-shadow:0 18px 34px rgba(46,105,255,.28)}
.btn-primary:hover{transform:translateY(-2px);box-shadow:0 22px 45px rgba(46,105,255,.34)}
.btn-secondary{background:#fff;color:var(--navy);border-color:#dce4f2;box-shadow:0 12px 30px rgba(8,33,74,.08)}
.btn-secondary:hover{transform:translateY(-2px);border-color:#c9d4e6}

.stat-strip{
  display:grid;
  grid-template-columns:repeat(4,1fr);
  gap:12px;
  margin-top:42px;
}
.stat{
  padding:16px;
  border:1px solid var(--line);
  border-radius:20px;
  background:linear-gradient(180deg,#fff,#f8fbff);
  min-height:118px;
}
.stat b{
  display:block;
  font-size:22px;
  letter-spacing:-.04em;
  margin-bottom:5px;
  background:linear-gradient(105deg,var(--blue),var(--cyan),var(--green),var(--orange));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.stat:nth-child(3) b,
.stat:nth-child(4) b{
  background:linear-gradient(105deg,var(--green),#9ad36e,#d2c254,var(--orange));
  -webkit-background-clip:text;
  background-clip:text;
  color:transparent;
}
.stat span{display:block;color:#5d687d;font-size:12.5px;font-weight:750;line-height:1.35}

.showcase-band{
  width:89%;
  max-width:100%;
  margin:0 auto 32px;
  padding:0;
}
.showcase-slider{
  position:relative;
  border-radius:0;
  overflow:hidden;
  background:linear-gradient(90deg,#404d6d 0%,#2a3954 48%,#3e6c8e 100%);
  border:none;
  border-top:1px solid rgba(62,108,142,.35);
  border-bottom:1px solid rgba(62,108,142,.35);
  box-shadow:0 24px 70px rgba(8,33,74,.18);
}
.showcase-slider-viewport{
  width:100%;
  aspect-ratio:1693 / 929;
  overflow:hidden;
  background:linear-gradient(90deg,#404d6d 0%,#2a3954 48%,#3e6c8e 100%);
}
.showcase-slider .hero-slider-track,
.showcase-slider .hero-slider-slide{
  height:100%;
}
.showcase-slider .hero-slider-slide img{
  width:100%;
  height:100%;
  object-fit:contain;
  object-position:center center;
  display:block;
  padding:12px clamp(12px, 2vw, 28px);
}
.showcase-slider-btn{
  position:absolute;
  top:50%;
  transform:translateY(-50%);
  width:44px;
  height:44px;
  border:none;
  border-radius:50%;
  background:rgba(255,255,255,.92);
  color:#2a3954;
  font-size:26px;
  line-height:1;
  cursor:pointer;
  box-shadow:0 12px 28px rgba(0,0,0,.22);
  transition:transform .2s ease, background .2s ease;
  z-index:2;
}
.showcase-slider-btn:hover{
  transform:translateY(-50%) scale(1.05);
  background:#fff;
}
.showcase-slider-btn--prev{left:16px}
.showcase-slider-btn--next{right:16px}
.showcase-slider-dots{
  position:absolute;
  left:50%;
  bottom:16px;
  transform:translateX(-50%);
  display:flex;
  gap:10px;
  z-index:2;
  padding:8px 14px;
  border-radius:999px;
  background:rgba(255,255,255,.14);
  backdrop-filter:blur(10px);
  box-shadow:0 8px 24px rgba(0,0,0,.16);
  border:1px solid rgba(255,255,255,.18);
}
.showcase-slider-dot{
  width:10px;
  height:10px;
  border:none;
  border-radius:50%;
  padding:0;
  background:rgba(255,255,255,.38);
  cursor:pointer;
  transition:transform .2s ease, background .2s ease;
}
.showcase-slider-dot.is-active{
  background:#fff;
  transform:scale(1.15);
}

.section{padding:92px 0}
#features.section{padding-top:48px;padding-bottom:48px}
#features .section-head{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  align-items:flex-start;
  gap:48px 56px;
  margin-bottom:48px;
}
#features .section-head .kicker{margin-bottom:18px}
#features .section-head h2{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;
  letter-spacing:.008em;
  font-size:clamp(34px,3.6vw,54px);
  line-height:1.06;
  max-width:none;
  width:max-content;
  color:var(--navy);
  margin:0;
}
#features .section-head h2 .hero-title-line{
  display:block;
  white-space:nowrap;
}
#features .section-head p{
  max-width:420px;
  line-height:1.65;
  padding-top:6px;
}
#outcomes.section{padding-top:48px;padding-bottom:48px}
#outcomes .dark-grid{gap:48px 56px}
#outcomes .dark-band .kicker{margin-bottom:18px}
#outcomes .dark-band > .dark-grid > div > p{
  line-height:1.65;
  max-width:560px;
}
#workflow.section{padding-top:48px;padding-bottom:48px}
#workflow .section-head{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  align-items:flex-start;
  gap:48px 56px;
  margin-bottom:48px;
}
#workflow .section-head .kicker{margin-bottom:18px}
#workflow .section-head h2{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;
  letter-spacing:.008em;
  font-size:clamp(34px,3.6vw,54px);
  line-height:1.06;
  max-width:none;
  width:max-content;
  color:var(--navy);
  margin:0;
}
#workflow .section-head h2 .hero-title-line{
  display:block;
  white-space:nowrap;
}
#workflow .section-head p{
  max-width:420px;
  line-height:1.65;
  padding-top:6px;
}
#field-feedback.section{padding-top:48px;padding-bottom:20px}
#field-feedback .section-head{
  display:grid;
  grid-template-columns:minmax(0,1.15fr) minmax(0,.85fr);
  align-items:flex-start;
  gap:48px 56px;
  margin-bottom:48px;
}
#field-feedback .section-head .kicker{margin-bottom:18px}
#field-feedback .section-head h2{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;
  letter-spacing:.008em;
  font-size:clamp(34px,3.6vw,54px);
  line-height:1.06;
  max-width:none;
  width:max-content;
  color:var(--navy);
  margin:0;
}
#field-feedback .section-head h2 .hero-title-line{
  display:block;
  white-space:nowrap;
}
#field-feedback .section-head p{
  max-width:420px;
  line-height:1.65;
  padding-top:6px;
}
#dashboard.section{padding-top:20px;padding-bottom:20px}
#demo.section{padding-top:20px}

.insights-band{
  position:relative;
  overflow:hidden;
  background:
    radial-gradient(circle at 8% 14%, rgba(32,200,244,.24), transparent 30%),
    radial-gradient(circle at 92% 10%, rgba(255,154,36,.2), transparent 28%),
    radial-gradient(circle at 78% 88%, rgba(46,105,255,.14), transparent 34%),
    radial-gradient(circle at 18% 82%, rgba(123,63,242,.1), transparent 32%),
    linear-gradient(135deg,#edf6ff 0%,#f7fbff 42%,#eef4ff 68%,#fff6ec 100%);
  border-top:1px solid rgba(231,236,245,.95);
  border-bottom:1px solid rgba(231,236,245,.95);
}
.insights-band::before{
  content:"";
  position:absolute;
  inset:0;
  background:
    linear-gradient(90deg,transparent 0 12%,rgba(255,255,255,.35) 12% 12.35%,transparent 12.35% 23%,rgba(255,255,255,.35) 23% 23.35%,transparent 23.35% 100%),
    linear-gradient(0deg,transparent 0 16%,rgba(255,255,255,.28) 16% 16.25%,transparent 16.25% 29%,rgba(255,255,255,.28) 29% 29.25%,transparent 29.25% 100%);
  opacity:.45;
  pointer-events:none;
}
.insights-band > .section{
  position:relative;
  z-index:1;
}
.insights-band .proof-card{
  background:rgba(255,255,255,.94);
  backdrop-filter:blur(10px);
  box-shadow:0 18px 48px rgba(8,33,74,.08);
}
.insights-band .proof-card.large{
  background:linear-gradient(180deg,rgba(255,255,255,.98),rgba(247,251,255,.92));
}

.section-head{display:flex;justify-content:space-between;gap:40px;align-items:flex-end;margin-bottom:34px}
.kicker{font-weight:900;color:var(--blue);font-size:13px;letter-spacing:.14em;text-transform:uppercase;margin:0 0 10px}
h2{font-size:clamp(34px,4vw,58px);line-height:1;margin:0;color:var(--navy);letter-spacing:-.06em;max-width:750px}
.section-head p{max-width:460px;margin:0;color:var(--muted);font-size:17px}

.feature-grid{display:grid;grid-template-columns:repeat(5,1fr);gap:18px}
.feature-card{
  min-height:290px;
  background:white;
  border:1px solid var(--line);
  border-radius:26px;
  padding:24px;
  box-shadow:0 14px 40px rgba(8,33,74,.06);
  position:relative;
  overflow:hidden;
}
.feature-card::before{
  content:"";
  position:absolute;right:-70px;top:-70px;width:160px;height:160px;border-radius:50%;
  background:radial-gradient(circle,rgba(46,105,255,.12),transparent 64%);
}
.icon{
  width:50px;height:50px;border-radius:16px;
  display:grid;place-items:center;
  margin-bottom:42px;
  background:linear-gradient(135deg,#eff6ff,#ffffff);
  border:1px solid #e2ebf7;
}
.icon svg{width:25px;height:25px;color:var(--blue)}
.feature-card h3{font-size:20px;line-height:1.08;letter-spacing:-.035em;margin:0 0 10px;color:var(--navy)}
.feature-card p{margin:0;color:var(--muted);font-size:14.5px}

.dark-band{
  background:linear-gradient(135deg,#071b3c 0%,#0b326d 62%,#123e87 100%);
  color:white;
  border-radius:36px;
  padding:54px;
  position:relative;
  overflow:hidden;
  box-shadow:0 30px 80px rgba(8,33,74,.25);
}
.dark-band::before{
  content:"";
  position:absolute;inset:-1px;
  background:
    radial-gradient(circle at 90% 14%, rgba(32,200,244,.4), transparent 23%),
    radial-gradient(circle at 12% 84%, rgba(255,154,36,.28), transparent 28%);
  pointer-events:none;
}
.dark-band > *{position:relative}
.dark-grid{display:grid;grid-template-columns:.85fr 1.15fr;gap:40px;align-items:start}
.dark-band h2{color:#fff;max-width:520px}
.dark-band p{color:rgba(255,255,255,.74)}
.outcome-list{display:grid;gap:14px;margin-top:8px}
.outcome{
  display:grid;grid-template-columns:56px 1fr;gap:18px;
  padding:20px;
  border:1px solid rgba(255,255,255,.14);
  background:rgba(255,255,255,.08);
  border-radius:22px;
  backdrop-filter:blur(12px);
}
.outcome-number{width:56px;height:56px;border-radius:18px;display:grid;place-items:center;background:rgba(255,255,255,.12);font-weight:900;color:#8ee8ff}
.outcome h3{margin:0 0 5px;color:white;letter-spacing:-.03em}
.outcome p{margin:0;font-size:14.5px}

.workflow{
  display:grid;
  grid-template-columns:repeat(6,1fr);
  gap:14px;
  margin-top:34px;
}
.flow-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  padding:20px;
  min-height:190px;
  box-shadow:0 14px 36px rgba(8,33,74,.06);
}
.flow-card .step{
  display:inline-grid;place-items:center;
  width:34px;height:34px;border-radius:12px;
  background:linear-gradient(135deg,var(--blue),var(--cyan));
  color:white;font-weight:900;margin-bottom:28px;
}
.flow-card h3{margin:0 0 8px;color:var(--navy);font-size:17px;letter-spacing:-.03em;line-height:1.15}
.flow-card p{margin:0;color:var(--muted);font-size:13.5px}

.proof{
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:22px;
  align-items:stretch;
}
.proof-card{
  border-radius:30px;
  padding:34px;
  background:#fff;
  border:1px solid var(--line);
  box-shadow:0 14px 44px rgba(8,33,74,.07);
}
.proof-card.large{
  background:linear-gradient(180deg,#fff,#f7fbff);
}
.proof-card h3{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;
  font-size:29px;
  letter-spacing:.008em;
  line-height:1.12;
  margin:0 0 14px;
  color:var(--navy);
}
.proof-card p{color:var(--muted);margin:0 0 22px}
.check-list{display:grid;gap:12px;margin:0;padding:0;list-style:none}
.check-list li{display:flex;gap:12px;align-items:flex-start;color:#34445d;font-weight:700;font-size:14.5px}
.check-list li::before{content:"✓";width:22px;height:22px;border-radius:50%;display:grid;place-items:center;flex:0 0 auto;background:#eaf7ee;color:#149447;font-weight:900;font-size:13px}

.cta-panel{
  text-align:center;
  padding:72px 28px;
  border-radius:36px;
  position:relative;
  overflow:hidden;
  color:#fff;
  background:
    radial-gradient(circle at 90% 14%, rgba(32,200,244,.35), transparent 23%),
    radial-gradient(circle at 12% 84%, rgba(255,154,36,.24), transparent 28%),
    linear-gradient(135deg,#071b3c 0%,#0b326d 62%,#123e87 100%);
  border:1px solid rgba(255,255,255,.12);
  box-shadow:0 30px 80px rgba(8,33,74,.28);
}
.cta-panel .kicker{color:#8ee8ff;margin-bottom:18px}
.cta-panel h2{
  font-family:'Aptos Display',Aptos,'Segoe UI',Inter,system-ui,-apple-system,BlinkMacSystemFont,sans-serif;
  font-weight:700;
  letter-spacing:.008em;
  font-size:clamp(34px,3.6vw,54px);
  line-height:1.06;
  margin:0 auto 24px;
  max-width:none;
  width:max-content;
  color:#fff;
}
.cta-panel h2 .hero-title-line{
  display:block;
  white-space:nowrap;
}
.cta-panel p{max-width:720px;margin:0 auto 30px;color:rgba(255,255,255,.76);font-size:18px}
.cta-panel .btn-secondary{
  background:rgba(255,255,255,.95);
  color:var(--navy);
  border-color:rgba(255,255,255,.35);
}
.cta-panel .btn-secondary:hover{
  background:#fff;
  border-color:#fff;
}

.demo-form-wrap{
  max-width:640px;
  margin:0 auto;
  text-align:left;
}
.demo-alert{
  border-radius:20px;
  padding:14px 18px;
  margin-bottom:24px;
  font-size:14px;
  line-height:1.55;
}
.demo-alert--success{
  background:#fff;
  border:1px solid #86efac;
  color:#166534;
  font-weight:600;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.demo-alert--error{
  background:#fff;
  border:1px solid #fca5a5;
  color:#991b1b;
  font-weight:600;
  box-shadow:0 8px 24px rgba(0,0,0,.12);
}
.demo-form{
  display:grid;
  gap:18px;
  padding:28px 24px;
  background:#fff;
  border:1px solid var(--line);
  border-radius:26px;
  box-shadow:0 14px 40px rgba(8,33,74,.06);
}
.demo-field label{
  display:block;
  color:var(--navy);
  font-size:17px;
  font-weight:700;
  margin-bottom:10px;
  line-height:1.35;
}
.demo-field input,
.demo-field textarea{
  width:100%;
  border-radius:16px;
  border:1px solid #dce4f2;
  background:#fff;
  color:var(--ink);
  padding:15px 16px;
  font:inherit;
  font-size:17px;
  outline:none;
  transition:border-color .2s ease, box-shadow .2s ease;
}
.demo-field input:focus,
.demo-field textarea:focus{
  border-color:var(--blue);
  box-shadow:0 0 0 3px rgba(46,105,255,.12);
}
.demo-field textarea{
  resize:vertical;
  min-height:160px;
}
.demo-error{
  color:#b91c1c;
  font-size:14px;
  font-weight:600;
  margin:8px 0 0;
}
.demo-submit{
  width:100%;
  margin-top:4px;
  border:none;
  cursor:pointer;
}
.demo-honeypot{
  position:absolute;
  left:-9999px;
  width:1px;
  height:1px;
  overflow:hidden;
  opacity:0;
  pointer-events:none;
}

footer{
  padding:36px 0 48px;
  color:#6d7890;
  font-size:14px;
}
.footer-row{display:flex;align-items:center;justify-content:space-between;gap:20px;border-top:1px solid var(--line);padding-top:24px}
.footer-row .brand{letter-spacing:.05em}
.footer-meta{
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  justify-content:flex-end;
  gap:10px 18px;
  text-align:right;
}
.footer-link{
  color:var(--blue);
  font-weight:700;
  white-space:nowrap;
}
.footer-link:hover{text-decoration:underline}

.legal-page{
  padding:36px 0 56px;
}
.legal-card{
  background:#fff;
  border:1px solid var(--line);
  border-radius:28px;
  box-shadow:0 18px 48px rgba(8,33,74,.08);
  overflow:hidden;
}
.legal-header{
  padding:42px 48px 28px;
  border-bottom:1px solid var(--line);
  background:linear-gradient(180deg,#f8fbff 0%,#fff 100%);
}
.legal-kicker{
  margin:0 0 10px;
  font-size:13px;
  font-weight:800;
  letter-spacing:.14em;
  text-transform:uppercase;
  color:var(--blue);
}
.legal-header h1{
  margin:0;
  font-size:clamp(34px,4vw,52px);
  line-height:1.05;
  letter-spacing:-.05em;
  color:var(--navy);
}
.legal-updated{
  margin:14px 0 0;
  color:var(--muted);
  font-size:15px;
}
.legal-content{
  padding:36px 48px 48px;
  color:#334155;
  font-size:16px;
  line-height:1.75;
}
.legal-content section{
  margin-bottom:34px;
}
.legal-content section:last-child{
  margin-bottom:0;
}
.legal-content h2{
  margin:0 0 14px;
  font-size:22px;
  line-height:1.25;
  letter-spacing:-.03em;
  color:var(--navy);
}
.legal-content p{
  margin:0 0 14px;
}
.legal-content p:last-child{
  margin-bottom:0;
}
.legal-content ul{
  margin:0 0 14px;
  padding-left:1.35rem;
}
.legal-content li{
  margin-bottom:8px;
}
.legal-content li:last-child{
  margin-bottom:0;
}
.legal-content a{
  color:var(--blue);
  font-weight:600;
}
.legal-content a:hover{text-decoration:underline}
.legal-caps{
  font-size:15px;
  line-height:1.65;
  letter-spacing:.01em;
}
.legal-table-wrap{
  overflow-x:auto;
  margin:8px 0 14px;
  border:1px solid var(--line);
  border-radius:18px;
}
.legal-table{
  width:100%;
  border-collapse:collapse;
  font-size:15px;
  line-height:1.55;
}
.legal-table th,
.legal-table td{
  padding:14px 16px;
  text-align:left;
  vertical-align:top;
  border-bottom:1px solid var(--line);
}
.legal-table th{
  background:#f5f8fc;
  color:var(--navy);
  font-size:13px;
  font-weight:800;
  letter-spacing:.06em;
  text-transform:uppercase;
}
.legal-table tr:last-child td,
.legal-table tr:last-child th{
  border-bottom:none;
}
.legal-table td:first-child{
  font-weight:700;
  color:var(--navy);
}
.legal-quote{
  margin:0 0 14px;
  padding:16px 18px;
  border-left:4px solid var(--blue);
  background:#f5f8fc;
  border-radius:0 14px 14px 0;
  color:#334155;
}
.legal-inline-button{
  display:inline;
  padding:0;
  border:none;
  background:none;
  color:var(--blue);
  font:inherit;
  font-weight:700;
  cursor:pointer;
  text-decoration:underline;
}
.legal-inline-button:hover{color:var(--navy)}
.sr-only{
  position:absolute;
  width:1px;
  height:1px;
  padding:0;
  margin:-1px;
  overflow:hidden;
  clip:rect(0,0,0,0);
  white-space:nowrap;
  border:0;
}
.footer-link-button{
  border:none;
  background:none;
  padding:0;
  cursor:pointer;
  font:inherit;
}
body.cookie-modal-open{overflow:hidden}

.cookie-banner{
  position:fixed;
  left:0;
  right:0;
  bottom:0;
  z-index:40;
  padding:18px 0 22px;
  background:rgba(7,27,60,.96);
  border-top:1px solid rgba(255,255,255,.12);
  box-shadow:0 -18px 50px rgba(0,0,0,.28);
  color:#fff;
}
.cookie-banner-inner{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:24px;
}
.cookie-banner-title{
  margin:0 0 8px;
  font-size:18px;
  font-weight:800;
  color:#fff;
}
.cookie-banner-desc{
  margin:0;
  max-width:760px;
  font-size:14px;
  line-height:1.65;
  color:rgba(255,255,255,.82);
}
.cookie-banner-desc a{
  color:#8ee8ff;
  font-weight:700;
}
.cookie-banner-actions{
  display:flex;
  flex-wrap:wrap;
  justify-content:flex-end;
  gap:10px;
  flex:0 0 auto;
}
.cookie-btn{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-height:42px;
  padding:10px 16px;
  border-radius:12px;
  border:1px solid transparent;
  font:inherit;
  font-size:14px;
  font-weight:700;
  cursor:pointer;
  transition:background .2s ease, border-color .2s ease, color .2s ease;
}
.cookie-btn--primary{
  background:linear-gradient(135deg,var(--navy),var(--blue));
  color:#fff;
}
.cookie-btn--secondary{
  background:#fff;
  color:var(--navy);
}
.cookie-btn--ghost{
  background:transparent;
  color:#fff;
  border-color:rgba(255,255,255,.24);
}
.cookie-btn--ghost:hover{
  background:rgba(255,255,255,.08);
}

.cookie-modal{
  position:fixed;
  inset:0;
  z-index:50;
  place-items:center;
  padding:24px;
}
.cookie-modal:not([hidden]){
  display:grid;
}
.cookie-modal[hidden]{
  display:none !important;
}
.cookie-banner[hidden]{
  display:none !important;
}
.cookie-modal-backdrop{
  position:absolute;
  inset:0;
  background:rgba(8,33,74,.58);
}
.cookie-modal-panel{
  position:relative;
  width:min(720px,100%);
  max-height:calc(100vh - 48px);
  overflow:auto;
  background:#fff;
  border:1px solid var(--line);
  border-radius:24px;
  box-shadow:0 28px 80px rgba(8,33,74,.24);
  padding:28px;
}
.cookie-modal-header{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:16px;
  margin-bottom:12px;
}
.cookie-modal-header h2{
  margin:0;
  font-size:28px;
  line-height:1.1;
  letter-spacing:-.04em;
  color:var(--navy);
}
.cookie-modal-close{
  width:36px;
  height:36px;
  border:none;
  border-radius:10px;
  background:#f5f8fc;
  color:var(--navy);
  font-size:24px;
  line-height:1;
  cursor:pointer;
}
.cookie-modal-lead{
  margin:0 0 18px;
  color:var(--muted);
  line-height:1.6;
}
.cookie-setting-list{
  display:grid;
  gap:14px;
  margin-bottom:22px;
}
.cookie-setting-item{
  display:flex;
  align-items:flex-start;
  justify-content:space-between;
  gap:18px;
  padding:16px 18px;
  border:1px solid var(--line);
  border-radius:16px;
  background:#fafcff;
}
.cookie-setting-copy h3{
  margin:0 0 6px;
  font-size:16px;
  color:var(--navy);
}
.cookie-setting-copy p{
  margin:0;
  font-size:14px;
  line-height:1.55;
  color:var(--muted);
}
.cookie-setting-badge{
  flex:0 0 auto;
  padding:6px 10px;
  border-radius:999px;
  background:#e8f1ff;
  color:var(--blue);
  font-size:12px;
  font-weight:800;
  letter-spacing:.04em;
  text-transform:uppercase;
}
.cookie-toggle{
  position:relative;
  display:inline-flex;
  align-items:center;
  flex:0 0 auto;
}
.cookie-toggle input{
  position:absolute;
  opacity:0;
  width:0;
  height:0;
}
.cookie-toggle-ui{
  width:48px;
  height:28px;
  border-radius:999px;
  background:#cbd5e1;
  transition:background .2s ease;
  position:relative;
}
.cookie-toggle-ui::after{
  content:"";
  position:absolute;
  top:3px;
  left:3px;
  width:22px;
  height:22px;
  border-radius:50%;
  background:#fff;
  box-shadow:0 2px 6px rgba(0,0,0,.18);
  transition:transform .2s ease;
}
.cookie-toggle input:checked + .cookie-toggle-ui{
  background:var(--blue);
}
.cookie-toggle input:checked + .cookie-toggle-ui::after{
  transform:translateX(20px);
}
.cookie-toggle input:focus-visible + .cookie-toggle-ui{
  outline:3px solid rgba(46,105,255,.25);
  outline-offset:2px;
}
.cookie-modal-actions{
  display:flex;
  flex-wrap:wrap;
  gap:10px;
}

@media(max-width:1000px){
  .cookie-banner-inner{
    flex-direction:column;
  }
  .cookie-banner-actions{
    justify-content:flex-start;
  }
  .cookie-setting-item{
    flex-direction:column;
  }
}

@media(max-width:1000px){
  .legal-header,
  .legal-content{
    padding-left:24px;
    padding-right:24px;
  }
  .footer-meta{
    justify-content:flex-start;
    text-align:left;
  }
}

@media(max-width:1000px){
  nav{display:none}
  .hero{grid-template-columns:1fr;min-height:auto}
  .hero-visual{min-height:560px;order:2}
  .hero-content{padding:42px 30px 34px;order:1}
  .stat-strip{grid-template-columns:repeat(2,1fr)}
  .feature-grid{grid-template-columns:repeat(2,1fr)}
  .dark-grid,.proof{grid-template-columns:1fr}
  .workflow{grid-template-columns:repeat(2,1fr)}
  .section-head{display:block}
  .section-head p{margin-top:14px}
  #features .section-head{display:block}
  #workflow .section-head{display:block}
  #field-feedback .section-head{display:block}
  #features .section-head h2{width:auto;max-width:100%}
  #workflow .section-head h2{width:auto;max-width:100%}
  #field-feedback .section-head h2{width:auto;max-width:100%}
  #features .section-head h2 .hero-title-line{white-space:normal}
  #workflow .section-head h2 .hero-title-line{white-space:normal}
  #field-feedback .section-head h2 .hero-title-line{white-space:normal}
  #demo .cta-panel h2{width:auto;max-width:100%}
  #demo .cta-panel h2 .hero-title-line{white-space:normal}
  #hero-title,
  h2.display-heading,
  #outcomes .dark-band h2{width:auto;max-width:100%}
  #hero-title .hero-title-line,
  .display-heading .hero-title-line{white-space:normal}
}
@media(max-width:620px){
  .page-shell,header,.hero,.announcement{width:min(100% - 22px,var(--content-max))}
  header{top:8px;border-radius:20px}
  .announcement{border-radius:22px;align-items:flex-start;justify-content:flex-start}
  #features .section-head h2{font-size:clamp(34px,9vw,42px);line-height:1.08}
  .hero-content{padding:34px 22px}
  .hero-visual{min-height:500px;padding:22px}
  .plant-card{left:20px;right:20px;bottom:20px}
  .hero-slider{left:12px;right:12px;top:12px;bottom:158px}
  .hero-slider-btn{width:34px;height:34px;font-size:20px}
  .stat-strip,.feature-grid,.workflow{grid-template-columns:1fr}
  .feature-grid{gap:12px}
  .feature-card{
    min-height:auto;
    padding:18px 18px 16px;
    border-radius:22px;
  }
  .feature-card .icon{
    width:44px;
    height:44px;
    margin-bottom:14px;
    border-radius:14px;
  }
  .feature-card .icon svg{width:22px;height:22px}
  .feature-card h3{font-size:18px;margin-bottom:8px}
  .feature-card p{font-size:14px;line-height:1.45}
  .dark-band{padding:30px 22px;border-radius:28px}
  .section{padding:64px 0}
  .hero{margin-bottom:40px}
  .showcase-band{margin-bottom:24px}
  .showcase-slider-viewport{aspect-ratio:1693 / 929}
  .showcase-slider .hero-slider-slide img{padding:8px 10px}
  .showcase-slider-btn{width:38px;height:38px;font-size:22px}
  .showcase-slider-btn--prev{left:10px}
  .showcase-slider-btn--next{right:10px}
  #features.section{padding-top:36px}
  #outcomes.section{padding-top:32px;padding-bottom:32px}
  #workflow.section{padding-top:32px;padding-bottom:32px}
  #field-feedback.section{padding-top:32px;padding-bottom:16px}
  #dashboard.section{padding-top:16px;padding-bottom:16px}
  #demo.section{padding-top:16px}
  #demo .cta-panel{padding:40px 18px;border-radius:28px}
  #demo .cta-panel h2{
    font-size:clamp(22px,5.8vw,30px);
    line-height:1.18;
    margin-bottom:16px;
  }
  #demo .cta-panel p{font-size:15px;line-height:1.55;margin-bottom:22px}
  .footer-row{display:block}
}
