:root {
  --ink: #10251f;
  --muted: #667873;
  --line: #dce6e1;
  --paper: #f5f8f5;
  --white: #fff;
  --green: #123d33;
  --green-2: #1b5547;
  --mint: #b7ead5;
  --acid: #eaff6d;
  --blue: #d9ecff;
  --coral: #ffe0d4;
  --shadow: 0 24px 70px rgba(15, 55, 45, .11);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; color: var(--ink); background: var(--paper); font-family: "DM Sans", sans-serif; -webkit-font-smoothing: antialiased; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { cursor: pointer; }
.site-header { position: sticky; z-index: 20; top: 0; min-height: 76px; display: flex; align-items: center; justify-content: space-between; gap: 28px; padding: 0 max(28px, calc((100vw - 1180px) / 2)); border-bottom: 1px solid rgba(18,61,51,.08); background: rgba(245,248,245,.9); backdrop-filter: blur(18px); }
.brand { display: flex; align-items: center; gap: 10px; font: 800 19px "Manrope"; }
.brand > span:last-child span { color: #91a91c; }
.brand-mark { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 11px; background: var(--acid); }
.brand-mark svg { width: 22px; fill: none; stroke: var(--green); stroke-width: 2.4; stroke-linejoin: round; }
.site-header nav, .header-actions { display: flex; align-items: center; gap: 27px; }
.site-header nav a, .login-link { color: #52655f; font-size: 13px; font-weight: 600; }
.site-header nav a:hover, .login-link:hover { color: var(--green); }
.menu-button { display: none; border: 0; background: none; font-size: 24px; }
.button { display: inline-flex; align-items: center; justify-content: center; min-height: 50px; padding: 0 22px; border-radius: 11px; color: white; background: var(--green); box-shadow: 0 12px 28px rgba(18,61,51,.18); font-weight: 700; transition: transform .18s ease, background .18s ease; }
.button:hover { transform: translateY(-2px); background: var(--green-2); }
.button-small { min-height: 40px; padding: 0 16px; font-size: 12px; }
.button-wide { width: 100%; }
.button-light { color: var(--green); background: var(--acid); box-shadow: none; }
.button-light:hover { background: #f0ff91; }
.hero { min-height: 690px; display: grid; grid-template-columns: 1.05fr .95fr; align-items: center; gap: 60px; max-width: 1180px; margin: 0 auto; padding: 78px 28px 72px; }
.status-pill { display: inline-flex; align-items: center; gap: 9px; padding: 8px 12px; border: 1px solid #d8e3de; border-radius: 999px; color: #526b63; background: rgba(255,255,255,.75); font-size: 11px; font-weight: 700; letter-spacing: .035em; }
.status-pill i { width: 7px; height: 7px; border-radius: 50%; background: #5fc69f; box-shadow: 0 0 0 5px rgba(95,198,159,.12); }
.hero h1 { max-width: 720px; margin: 24px 0 22px; font: 800 clamp(43px, 5.2vw, 69px)/1.04 "Manrope"; letter-spacing: -.055em; }
.hero h1 em { color: var(--green-2); font-style: normal; background: linear-gradient(transparent 68%, var(--acid) 0); }
.hero-copy > p { max-width: 630px; margin: 0; color: var(--muted); font-size: 17px; line-height: 1.7; }
.hero-actions { display: flex; align-items: center; gap: 24px; margin-top: 32px; }
.text-link { display: flex; align-items: center; gap: 9px; font-size: 13px; font-weight: 700; }
.text-link span { width: 34px; height: 34px; display: grid; place-items: center; border: 1px solid var(--line); border-radius: 50%; background: white; font-size: 10px; }
.trust-row { display: flex; flex-wrap: wrap; gap: 18px; margin-top: 25px; color: #71817c; font-size: 11px; font-weight: 600; }
.hero-visual { position: relative; min-height: 520px; display: grid; place-items: center; }
.visual-glow { position: absolute; width: 420px; height: 420px; border-radius: 50%; background: radial-gradient(circle, rgba(127,213,177,.35), transparent 67%); filter: blur(8px); }
.scan-card { position: relative; z-index: 2; width: min(430px, 92vw); padding: 19px; overflow: hidden; border: 1px solid rgba(255,255,255,.13); border-radius: 27px; color: white; background: linear-gradient(145deg, #102f28, #164c40); box-shadow: 0 38px 90px rgba(13,48,40,.25); transform: rotate(1.5deg); }
.scan-card::before { content: ""; position: absolute; inset: 0; opacity: .08; background-image: linear-gradient(rgba(255,255,255,.2) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.2) 1px, transparent 1px); background-size: 34px 34px; }
.scan-head { position: relative; z-index: 2; display: flex; align-items: center; gap: 10px; }
.scan-icon { width: 39px; height: 39px; display: grid; place-items: center; border-radius: 11px; color: var(--green); background: var(--acid); font-size: 21px; }
.scan-head strong, .scan-head small { display: block; }
.scan-head strong { font: 700 13px "Manrope"; }
.scan-head small { margin-top: 2px; color: #8eaaa3; font-size: 9px; }
.live-dot { width: 8px; height: 8px; margin-left: auto; border-radius: 50%; background: var(--acid); box-shadow: 0 0 0 6px rgba(234,255,109,.1); }
.scan-map { position: relative; height: 270px; margin: 13px 0; overflow: hidden; border-radius: 17px; background: radial-gradient(circle at 50% 50%, rgba(234,255,109,.08), transparent 2px), #0d2b25; }
.radar-ring { position: absolute; left: 50%; top: 50%; aspect-ratio: 1; border: 1px solid rgba(234,255,109,.13); border-radius: 50%; transform: translate(-50%,-50%); }
.ring-one { width: 140px; }.ring-two { width: 245px; }
.radar-sweep { position: absolute; left: 50%; top: 50%; width: 135px; height: 135px; border-left: 2px solid var(--acid); transform-origin: 0 0; background: conic-gradient(from 270deg, rgba(234,255,109,.15), transparent 28%); animation: sweep 4.5s linear infinite; }
@keyframes sweep { to { transform: rotate(360deg); } }
.home-pin { position: absolute; z-index: 2; left: 50%; top: 50%; width: 42px; height: 42px; display: grid; place-items: center; border-radius: 50%; color: var(--green); background: var(--acid); transform: translate(-50%,-50%); }
.map-dot { position: absolute; width: 8px; height: 8px; border-radius: 50%; background: var(--acid); animation: pulse 2.4s infinite; }
.dot-one { left: 27%; top: 27%; }.dot-two { right: 21%; top: 37%; animation-delay: .8s; }.dot-three { left: 35%; bottom: 20%; animation-delay: 1.5s; }
@keyframes pulse { 50% { box-shadow: 0 0 0 9px rgba(234,255,109,0); } }
.match-card { position: relative; z-index: 2; padding: 16px; border: 1px solid rgba(255,255,255,.09); border-radius: 15px; background: rgba(255,255,255,.08); backdrop-filter: blur(10px); }
.match-top { display: flex; justify-content: space-between; color: var(--acid); font-size: 8px; font-weight: 800; letter-spacing: .13em; }
.match-top small { color: #8fa8a1; letter-spacing: 0; }
.match-card > strong { display: block; margin-top: 9px; font: 700 14px "Manrope"; }
.match-card > p { margin: 5px 0 11px; color: #9db3ad; font-size: 10px; }
.match-score { display: flex; align-items: center; gap: 9px; color: #b8cbc6; font-size: 9px; }
.match-score i { width: 120px; height: 5px; overflow: hidden; border-radius: 9px; background: rgba(255,255,255,.1); }
.match-score i::after { content: ""; display: block; width: var(--score); height: 100%; border-radius: inherit; background: var(--acid); }
.notification-bubble { position: absolute; z-index: 3; right: -10px; bottom: 58px; display: flex; align-items: center; gap: 10px; padding: 12px 15px; border: 1px solid white; border-radius: 14px; background: rgba(255,255,255,.94); box-shadow: var(--shadow); animation: float 3s ease-in-out infinite; }
@keyframes float { 50% { transform: translateY(-7px); } }
.notification-bubble > span { color: #5865f2; font-size: 28px; line-height: .5; }
.notification-bubble strong, .notification-bubble small { display: block; }
.notification-bubble strong { font-size: 11px; }.notification-bubble small { margin-top: 2px; color: var(--muted); font-size: 8px; }
.proof-strip { max-width: 1180px; display: grid; grid-template-columns: repeat(4, 1fr); margin: 0 auto; padding: 0 28px 72px; }
.proof-strip div { padding: 23px 30px; border: 1px solid var(--line); border-right: 0; background: rgba(255,255,255,.65); }
.proof-strip div:first-child { border-radius: 15px 0 0 15px; }.proof-strip div:last-child { border-right: 1px solid var(--line); border-radius: 0 15px 15px 0; }
.proof-strip strong, .proof-strip span { display: block; }.proof-strip strong { font: 800 26px "Manrope"; }.proof-strip span { margin-top: 3px; color: var(--muted); font-size: 10px; }
.section { max-width: 1180px; margin: 0 auto; padding: 100px 28px; }
.section-heading { max-width: 690px; margin-bottom: 45px; }
.section-heading.centered { margin-inline: auto; text-align: center; }
.eyebrow { margin: 0; color: #799087; font-size: 10px; font-weight: 800; letter-spacing: .17em; }
.section-heading h2, .calculator-copy h2 { margin: 11px 0 14px; font: 800 clamp(32px, 4vw, 48px)/1.1 "Manrope"; letter-spacing: -.045em; }
.section-heading > p:last-child, .calculator-copy > p { color: var(--muted); line-height: 1.65; }
.feature-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }
.feature-card { min-height: 265px; padding: 28px; border: 1px solid var(--line); border-radius: 20px; background: white; box-shadow: 0 13px 35px rgba(18,61,51,.045); }
.feature-large { grid-column: span 2; }.feature-wide { grid-column: span 2; display: grid; grid-template-columns: 1fr 1fr; align-items: center; gap: 24px; }
.dark-card { color: white; background: linear-gradient(140deg, #102e27, #164c40); }
.feature-kicker { color: var(--acid); font-size: 9px; font-weight: 800; letter-spacing: .14em; }
.feature-card h3 { margin: 17px 0 10px; font: 750 21px/1.25 "Manrope"; letter-spacing: -.025em; }
.feature-large h3 { max-width: 620px; font-size: 30px; }.feature-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.65; }.dark-card p { color: #9db6af; }
.feature-icon { width: 44px; height: 44px; display: grid; place-items: center; border-radius: 12px; font-size: 22px; }.mint { background: var(--mint); }.yellow { background: var(--acid); }.blue { background: var(--blue); }.coral { background: var(--coral); }
.source-cloud { display: flex; flex-wrap: wrap; gap: 8px; margin-top: 28px; }.source-cloud span { padding: 8px 11px; border: 1px solid rgba(255,255,255,.12); border-radius: 8px; color: #bed0cb; background: rgba(255,255,255,.05); font-size: 10px; }
.noise-demo { display: grid; gap: 10px; }.noise-demo span { display: flex; justify-content: space-between; padding: 13px; border-radius: 10px; font-size: 10px; }.rejected { color: #86685f; background: #fff2ed; text-decoration: line-through; }.accepted { color: #215546; background: #e8f8f1; }.noise-demo b { text-decoration: none; }
.workflow-section { max-width: none; background: #eef3ef; }.workflow-section > * { max-width: 1124px; margin-left: auto; margin-right: auto; }
.workflow { display: grid; grid-template-columns: repeat(3, 1fr); gap: 15px; }.workflow article { position: relative; padding: 28px; border: 1px solid var(--line); border-radius: 19px; background: white; }.workflow article > span { position: absolute; right: 20px; top: 17px; color: #d7e1dd; font: 800 34px "Manrope"; }.workflow article > i { width: 45px; height: 45px; display: grid; place-items: center; border-radius: 13px; color: var(--green); background: var(--acid); font-style: normal; font-size: 21px; }.workflow h3 { margin: 20px 0 8px; font: 750 17px "Manrope"; }.workflow p { color: var(--muted); font-size: 12px; line-height: 1.6; }
.calculator-section { display: grid; grid-template-columns: 1.25fr .75fr; gap: 55px; align-items: center; }.calculator-copy label { display: flex; justify-content: space-between; max-width: 600px; margin: 28px 0 8px; font-size: 12px; }.calculator-copy input { width: 100%; max-width: 600px; accent-color: var(--green); }.time-result { padding: 35px; border-radius: 22px; color: white; background: var(--green); box-shadow: var(--shadow); }.time-result span { color: #a8beb8; font-size: 11px; }.time-result strong { display: block; margin: 8px 0 12px; color: var(--acid); font: 800 43px "Manrope"; }.time-result p { margin: 0; color: #aac0ba; font-size: 12px; line-height: 1.65; }
.pricing-section { max-width: none; background: #102f28; color: white; }.pricing-section > * { max-width: 850px; margin-left: auto; margin-right: auto; }.pricing-section .section-heading > p:last-child { color: #9bb2ac; }.billing-toggle { width: max-content; display: flex; padding: 4px; margin-bottom: 25px; border: 1px solid rgba(255,255,255,.1); border-radius: 11px; background: rgba(255,255,255,.05); }.billing-toggle button { padding: 10px 15px; border: 0; border-radius: 8px; color: #9bb0ab; background: none; font-size: 11px; font-weight: 700; }.billing-toggle button.active { color: var(--green); background: var(--acid); }.billing-toggle span { margin-left: 5px; padding: 2px 5px; border-radius: 5px; color: var(--green); background: rgba(18,61,51,.13); font-size: 8px; }
.pricing-card { display: grid; grid-template-columns: .9fr 1.1fr; overflow: hidden; border-radius: 24px; background: white; color: var(--ink); box-shadow: 0 35px 90px rgba(0,0,0,.22); }.pricing-main, .pricing-features { padding: 38px; }.pricing-main { border-right: 1px solid var(--line); }.popular-label { color: #638078; font-size: 9px; font-weight: 800; letter-spacing: .14em; }.price { display: flex; align-items: end; gap: 8px; margin: 17px 0 8px; }.price strong { font: 800 42px "Manrope"; letter-spacing: -.05em; }.price span { padding-bottom: 7px; color: var(--muted); font-size: 11px; }.pricing-main > p { min-height: 37px; color: var(--muted); font-size: 11px; }.pricing-main small { display: block; margin-top: 9px; color: #899893; text-align: center; font-size: 8px; }.pricing-features > strong { font: 750 14px "Manrope"; }.pricing-features ul { display: grid; gap: 13px; padding: 0; margin: 21px 0 0; list-style: none; }.pricing-features li { color: #556660; font-size: 11px; }.pricing-features li::before { content: "✓"; width: 20px; height: 20px; display: inline-grid; place-items: center; margin-right: 9px; border-radius: 50%; color: var(--green); background: var(--mint); font-weight: 800; }.annual-saving { margin-top: 20px; color: #a9beb8; text-align: center; font-size: 11px; }.annual-saving strong { color: var(--acid); }
.faq-section { display: grid; grid-template-columns: .7fr 1.3fr; gap: 70px; }.faq-list { border-top: 1px solid var(--line); }.faq-list details { border-bottom: 1px solid var(--line); }.faq-list summary { padding: 20px 5px; cursor: pointer; font: 700 14px "Manrope"; }.faq-list p { padding: 0 5px 20px; margin: 0; color: var(--muted); font-size: 12px; line-height: 1.7; }
.final-cta { max-width: 1124px; display: flex; align-items: center; justify-content: space-between; gap: 30px; margin: 0 auto 90px; padding: 48px; border-radius: 24px; color: white; background: linear-gradient(135deg, #123d33, #1d5b4c); }.final-cta .eyebrow { color: #9eb5af; }.final-cta h2 { margin: 11px 0 0; font: 800 33px/1.15 "Manrope"; letter-spacing: -.04em; }
footer { max-width: 1180px; display: flex; align-items: center; justify-content: space-between; gap: 25px; margin: 0 auto; padding: 30px 28px 45px; border-top: 1px solid var(--line); }.footer p, footer > p { color: var(--muted); font-size: 10px; }footer > div { display: flex; gap: 18px; color: var(--muted); font-size: 10px; }
@media (max-width: 900px) {
  .site-header nav, .header-actions { display: none; }.site-header.open nav { position: absolute; left: 18px; right: 18px; top: 68px; display: grid; gap: 0; padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: white; box-shadow: var(--shadow); }.site-header.open nav a { padding: 12px; }.menu-button { display: block; }
  .hero { grid-template-columns: 1fr; padding-top: 55px; }.hero-visual { min-height: 480px; }.proof-strip { grid-template-columns: repeat(2,1fr); }.proof-strip div, .proof-strip div:first-child, .proof-strip div:last-child { border: 1px solid var(--line); border-radius: 0; }
  .feature-grid { grid-template-columns: 1fr 1fr; }.feature-large, .feature-wide { grid-column: span 2; }.workflow { grid-template-columns: 1fr; }.calculator-section, .faq-section { grid-template-columns: 1fr; }.pricing-card { grid-template-columns: 1fr; }.pricing-main { border-right: 0; border-bottom: 1px solid var(--line); }
}
@media (max-width: 620px) {
  .site-header { padding: 0 18px; }.hero { padding: 45px 20px 55px; }.hero h1 { font-size: 43px; }.hero-actions { align-items: stretch; flex-direction: column; }.text-link { justify-content: center; }.trust-row { display: grid; gap: 9px; }.hero-visual { min-height: 430px; }.scan-card { transform: none; }.notification-bubble { right: 0; bottom: 25px; }
  .proof-strip { grid-template-columns: 1fr 1fr; padding: 0 20px 50px; }.proof-strip div { padding: 18px; }.section { padding: 75px 20px; }.feature-grid { grid-template-columns: 1fr; }.feature-large, .feature-wide { grid-column: auto; }.feature-wide { grid-template-columns: 1fr; }.calculator-section { gap: 28px; }.pricing-main, .pricing-features { padding: 28px; }.final-cta { align-items: flex-start; flex-direction: column; margin: 0 20px 60px; padding: 32px; }.final-cta h2 { font-size: 27px; }footer { align-items: flex-start; flex-direction: column; padding: 28px 20px; }
}
