:root {
  --green: #27ae60;
  --green-bright: #39d879;
  --green-pale: #eaf8f0;
  --navy: #112a34;
  --ink: #142228;
  --muted: #64727a;
  --line: #dce3df;
  --paper: #f5f7f4;
  --white: #fff;
  --radius: 18px;
  --shadow: 0 24px 70px rgba(9, 32, 25, .1);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  color: var(--ink);
  background: var(--white);
  font-family: "Manrope", Arial, sans-serif;
  -webkit-font-smoothing: antialiased;
}
body.menu-open, body.modal-open { overflow: hidden; }
a { color: inherit; text-decoration: none; }
button, input { font: inherit; }
button { cursor: pointer; }
img { display: block; max-width: 100%; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 auto; }
.section { padding: 112px 0; }
.skip-link { position: fixed; top: -100px; left: 16px; z-index: 999; background: #fff; padding: 12px 18px; border-radius: 8px; }
.skip-link:focus { top: 12px; }

.site-header {
  position: fixed;
  inset: 0 0 auto;
  z-index: 100;
  color: #fff;
  border-bottom: 1px solid rgba(255,255,255,.16);
  transition: .3s ease;
}
.site-header.scrolled { color: var(--ink); background: rgba(255,255,255,.94); box-shadow: 0 8px 30px rgba(5,22,16,.08); backdrop-filter: blur(18px); }
.nav-wrap { height: 82px; display: flex; align-items: center; justify-content: space-between; gap: 32px; }
.brand { flex: 0 0 auto; }
.logo-crop { width: 184px; height: 58px; display: block; overflow: hidden; position: relative; border-radius: 7px; background: #fff; }
.logo-crop img { width: 198px; max-width: none; position: absolute; left: -7px; top: -37px; }
.desktop-nav { display: flex; align-items: center; gap: 30px; margin-left: auto; }
.desktop-nav a, .text-link { font-size: 13px; font-weight: 700; }
.desktop-nav a { position: relative; }
.desktop-nav a::after { content: ""; position: absolute; left: 0; bottom: -9px; width: 0; height: 2px; background: var(--green-bright); transition: width .25s; }
.desktop-nav a:hover::after { width: 100%; }
.nav-actions { display: flex; align-items: center; gap: 22px; }
.button {
  display: inline-flex;
  justify-content: center;
  align-items: center;
  gap: 12px;
  min-height: 48px;
  padding: 0 22px;
  border: 1px solid var(--green);
  border-radius: 9px;
  color: #fff;
  background: var(--green);
  font-weight: 800;
  font-size: 13px;
  transition: transform .25s, background .25s, box-shadow .25s;
}
.button:hover { transform: translateY(-2px); background: #209a53; box-shadow: 0 13px 30px rgba(39,174,96,.26); }
.button-sm { min-height: 42px; padding: 0 18px; }
.button-lg { min-height: 56px; padding: 0 26px; font-size: 14px; }
.button-ghost { border-color: rgba(255,255,255,.5); background: rgba(255,255,255,.06); backdrop-filter: blur(8px); }
.button-ghost:hover { background: rgba(255,255,255,.14); box-shadow: none; }
.button-light { color: var(--navy); border-color: #fff; background: #fff; }
.button-light:hover { color: #fff; }
.button-dark { border-color: var(--navy); background: var(--navy); }
.pulse-dot { width: 9px; height: 9px; border-radius: 50%; background: var(--green-bright); box-shadow: 0 0 0 6px rgba(57,216,121,.14); }
.menu-toggle { display: none; border: 0; background: transparent; width: 42px; height: 42px; padding: 11px 8px; }
.menu-toggle span { display: block; height: 2px; margin: 5px 0; background: currentColor; transition: .25s; }
.mobile-menu { display: none; }

.hero { min-height: 800px; height: 100svh; max-height: 960px; position: relative; display: flex; align-items: center; overflow: hidden; color: #fff; background: #071512; }
.hero-image { position: absolute; inset: 0; width: 100%; height: 100%; object-fit: cover; }
.hero-shade { position: absolute; inset: 0; background: linear-gradient(90deg, rgba(4,17,14,.96) 0%, rgba(4,17,14,.78) 36%, rgba(4,17,14,.16) 73%, rgba(4,17,14,.18) 100%), linear-gradient(0deg, rgba(3,12,10,.62), transparent 35%); }
.hero-content { position: relative; z-index: 2; padding-top: 62px; }
.eyebrow { display: flex; align-items: center; gap: 10px; color: var(--green); font-size: 11px; letter-spacing: .18em; text-transform: uppercase; font-weight: 800; }
.eyebrow span { width: 30px; height: 1px; background: currentColor; }
.eyebrow.light { color: var(--green-bright); }
h1, h2 { margin: 0; font-family: "Space Grotesk", "Manrope", sans-serif; letter-spacing: -.045em; line-height: 1.02; }
.hero h1 { margin-top: 25px; max-width: 760px; font-size: clamp(58px, 6.3vw, 94px); }
.hero h1 em { color: var(--green-bright); font-style: normal; }
.hero-content > p { max-width: 620px; margin: 26px 0 34px; color: rgba(255,255,255,.72); font-size: 18px; line-height: 1.75; }
.hero-actions { display: flex; gap: 12px; }
.hero-trust { display: flex; margin-top: 68px; }
.hero-trust div { min-width: 142px; padding: 0 28px; border-left: 1px solid rgba(255,255,255,.2); }
.hero-trust div:first-child { padding-left: 0; border: 0; }
.hero-trust strong { display: block; font-family: "Space Grotesk"; font-size: 22px; }
.hero-trust span { display: block; margin-top: 4px; color: rgba(255,255,255,.47); font-size: 10px; text-transform: uppercase; letter-spacing: .1em; }
.scroll-cue { position: absolute; right: 38px; bottom: 32px; z-index: 2; display: flex; align-items: center; gap: 14px; color: rgba(255,255,255,.48); font-size: 10px; letter-spacing: .15em; text-transform: uppercase; transform: rotate(90deg); transform-origin: right bottom; }
.scroll-cue i { font-size: 16px; font-style: normal; }

.brand-strip { padding: 23px 0; border-bottom: 1px solid var(--line); background: #fff; overflow: hidden; }
.brand-strip .container { display: flex; align-items: center; gap: 36px; }
.brand-strip p { flex: 0 0 auto; margin: 0; padding-right: 36px; border-right: 1px solid var(--line); color: #82908b; font-size: 10px; font-weight: 800; text-transform: uppercase; letter-spacing: .12em; }
.brand-marquee { flex: 1; display: flex; justify-content: space-between; gap: 25px; color: #58635f; font-size: 12px; font-weight: 800; white-space: nowrap; }

.section-heading { display: flex; align-items: end; justify-content: space-between; gap: 50px; margin-bottom: 52px; }
.section-heading h2, .why-sticky h2, .contact-copy h2, .service-intro h2 { margin-top: 18px; font-size: clamp(40px, 4.6vw, 66px); }
.section-heading > p { max-width: 430px; margin: 0 0 6px; color: var(--muted); font-size: 15px; line-height: 1.75; }
.arrow-link { color: var(--green); font-size: 13px; font-weight: 800; border-bottom: 1px solid rgba(39,174,96,.35); padding-bottom: 6px; }
.arrow-link span { margin-left: 8px; }

.how-section { background: var(--paper); }
.steps-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.step-card { min-height: 390px; display: flex; flex-direction: column; padding: 28px; border: 1px solid #e0e6e2; border-radius: var(--radius); background: #fff; transition: transform .3s, box-shadow .3s; overflow: hidden; }
.step-card:hover { transform: translateY(-5px); box-shadow: var(--shadow); }
.step-card.dark { color: #fff; border-color: var(--navy); background: var(--navy); }
.step-top { display: flex; justify-content: space-between; color: #8a9691; font-size: 11px; font-weight: 800; }
.step-top .icon { width: 46px; height: 46px; border-radius: 50%; background: var(--green-pale); position: relative; }
.step-card h3 { margin: 60px 0 13px; font-family: "Space Grotesk"; font-size: 21px; }
.step-card p { margin: 0; color: var(--muted); font-size: 13px; line-height: 1.7; }
.step-card.dark p { color: rgba(255,255,255,.6); }
.mini-ui { margin-top: auto; }
.plate-ui { width: max-content; padding: 7px; border: 2px solid #162329; border-radius: 6px; font-size: 10px; background: #fff; color: #111; }
.plate-ui span { color: #3365a3; border-right: 1px solid #aaa; padding: 0 7px 0 3px; }
.plate-ui strong { padding: 0 7px; letter-spacing: .08em; }
.waveform { height: 48px; display: flex; align-items: center; gap: 5px; }
.waveform i, .live-wave i { width: 4px; border-radius: 4px; background: var(--green); animation: wave 1.15s ease-in-out infinite; }
.waveform i:nth-child(1), .waveform i:nth-child(7) { height: 9px; }
.waveform i:nth-child(2), .waveform i:nth-child(6) { height: 22px; animation-delay: .1s; }
.waveform i:nth-child(3), .waveform i:nth-child(5) { height: 36px; animation-delay: .2s; }
.waveform i:nth-child(4) { height: 46px; animation-delay: .3s; }
.upload-ui { display: flex; align-items: center; gap: 10px; padding: 12px; border: 1px dashed #b9c6c0; border-radius: 9px; color: #66746f; font-size: 11px; font-weight: 700; }
.upload-ui span { width: 25px; height: 25px; display: grid; place-items: center; border-radius: 50%; color: var(--green); background: var(--green-pale); }
.status-ui { display: flex; align-items: center; gap: 10px; padding: 12px; border: 1px solid rgba(255,255,255,.12); border-radius: 9px; background: rgba(255,255,255,.06); }
.status-ui > span { width: 28px; height: 28px; display: grid; place-items: center; border-radius: 50%; color: var(--navy); background: var(--green-bright); font-weight: 900; }
.status-ui small, .status-ui b { display: block; }
.status-ui small { color: rgba(255,255,255,.42); font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }
.status-ui b { margin-top: 3px; font-size: 10px; }
.vehicle-icon::after { content: "⌁"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 25px; }
.voice-icon::after { content: "≋"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 28px; transform: rotate(90deg); }
.camera-icon::after { content: "▣"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green); font-size: 21px; }
.delivery-icon::after { content: "➜"; position: absolute; inset: 0; display: grid; place-items: center; color: var(--green-bright); font-size: 21px; }

.catalog-section { background: #fff; }
.category-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.category-card { min-height: 300px; position: relative; display: flex; flex-direction: column; justify-content: end; padding: 24px; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, #f3f6f3, #e7ece8); overflow: hidden; transition: .3s; }
.category-card:hover { transform: translateY(-4px); border-color: #b9c7bf; box-shadow: var(--shadow); }
.category-card small { position: absolute; top: 22px; left: 23px; color: #8c9892; font-size: 10px; font-weight: 800; }
.category-card h3 { margin: 0 0 7px; font-family: "Space Grotesk"; font-size: 21px; }
.category-card p { margin: 0; color: var(--muted); font-size: 11px; }
.category-card > i { position: absolute; right: 22px; bottom: 23px; width: 34px; height: 34px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--navy); font-style: normal; transition: .25s; }
.category-card:hover > i { background: var(--green); transform: rotate(8deg); }
.part-art { position: absolute; top: 44px; right: 25px; color: #c5cec8; font-family: Georgia, serif; font-size: 108px; line-height: 1; text-shadow: 0 8px 20px rgba(16,35,27,.08); transform: rotate(-9deg); }
.category-brake .part-art { font-size: 130px; }
.category-suspension .part-art { font-size: 150px; transform: rotate(90deg); }
.category-filter .part-art { font-size: 105px; }
.category-electric { color: #fff; border-color: var(--navy); background: linear-gradient(145deg, #173944, #0e242b); }
.category-electric p { color: rgba(255,255,255,.55); }
.category-electric .part-art { color: var(--green-bright); }

.maya-section { color: #fff; background: radial-gradient(circle at 80% 20%, #1d5744, transparent 28%), #071b16; overflow: hidden; }
.maya-grid { display: grid; grid-template-columns: .9fr 1.1fr; align-items: center; gap: 100px; }
.maya-copy h2 { margin: 19px 0 26px; font-size: clamp(43px, 5vw, 68px); }
.maya-copy > p { max-width: 500px; color: rgba(255,255,255,.61); font-size: 15px; line-height: 1.8; }
.feature-list { display: grid; grid-template-columns: 1fr 1fr; gap: 17px; margin: 34px 0 40px; padding: 0; list-style: none; color: rgba(255,255,255,.82); font-size: 12px; font-weight: 700; }
.feature-list span { width: 20px; height: 20px; display: inline-grid; place-items: center; margin-right: 8px; border-radius: 50%; color: var(--navy); background: var(--green-bright); font-size: 10px; }
.assistant-shell { max-width: 500px; justify-self: end; border: 1px solid rgba(255,255,255,.17); border-radius: 26px; background: #f8faf9; color: var(--ink); box-shadow: 0 40px 100px rgba(0,0,0,.35); overflow: hidden; transform: rotate(1.5deg); }
.assistant-head { display: flex; align-items: center; gap: 12px; padding: 18px 20px; border-bottom: 1px solid #e0e7e3; background: #fff; }
.maya-avatar { width: 44px; height: 44px; position: relative; display: grid; place-items: center; border-radius: 14px; color: #fff; background: var(--navy); font-family: "Space Grotesk"; font-weight: 800; }
.maya-avatar i { position: absolute; right: -2px; bottom: -2px; width: 12px; height: 12px; border: 2px solid #fff; border-radius: 50%; background: var(--green); }
.assistant-head strong, .assistant-head small { display: block; }
.assistant-head strong { font-size: 14px; }
.assistant-head small { margin-top: 2px; color: #78857f; font-size: 9px; }
.assistant-head small span { display: inline-block; width: 6px; height: 6px; margin-right: 4px; border-radius: 50%; background: var(--green); }
.assistant-head button { margin-left: auto; border: 0; background: transparent; color: #7d8984; }
.chat-body { min-height: 440px; padding: 22px 20px; background-image: radial-gradient(#dbe3df 1px, transparent 1px); background-size: 18px 18px; }
.chat-time { text-align: center; color: #9aa49f; font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }
.message { max-width: 78%; margin-top: 15px; padding: 12px 15px; border-radius: 14px; font-size: 11px; line-height: 1.6; box-shadow: 0 5px 18px rgba(15,40,30,.06); }
.maya-message { border-bottom-left-radius: 3px; background: #fff; }
.user-message { margin-left: auto; border-bottom-right-radius: 3px; color: #fff; background: var(--green); }
.vehicle-result { display: grid; grid-template-columns: 54px 1fr auto; align-items: center; gap: 12px; margin-top: 13px; padding: 10px; border: 1px solid #dfe7e2; border-radius: 12px; background: rgba(255,255,255,.86); }
.vehicle-thumb { height: 45px; display: grid; place-items: center; border-radius: 9px; color: #fff; background: linear-gradient(145deg, #1d3c46, #091a20); font-size: 9px; letter-spacing: .1em; }
.vehicle-result small, .vehicle-result strong, .vehicle-result span { display: block; }
.vehicle-result small { color: var(--green); font-size: 7px; letter-spacing: .1em; font-weight: 800; }
.vehicle-result strong { margin-top: 3px; font-size: 11px; }
.vehicle-result span { margin-top: 2px; color: #81908a; font-size: 8px; }
.vehicle-result b { width: 21px; height: 21px; display: grid; place-items: center; border-radius: 50%; color: #fff; background: var(--green); font-size: 9px; }
.order-chips { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 10px; }
.order-chips span { padding: 7px 9px; border: 1px solid #dce5e0; border-radius: 20px; color: #55645e; background: #fff; font-size: 8px; font-weight: 700; }
.voice-bar { display: flex; align-items: center; gap: 12px; padding: 13px 15px; border-top: 1px solid #e0e7e3; background: #fff; }
.voice-bar button { flex: 0 0 34px; width: 34px; height: 34px; border: 0; border-radius: 50%; color: #6c7973; background: #eef2ef; }
.voice-bar span { flex: 1; color: #98a39e; font-size: 9px; }
.voice-bar .mic-button { color: #fff; background: var(--green); box-shadow: 0 0 0 5px var(--green-pale); }

.benefits-section { background: var(--paper); }
.section-heading.centered { display: block; text-align: center; }
.section-heading.centered .eyebrow { justify-content: center; }
.section-heading.centered p { margin: 18px auto 0; }
.benefit-grid { display: grid; grid-template-columns: repeat(3, 1fr); border-top: 1px solid #d8dfda; border-left: 1px solid #d8dfda; }
.benefit-card { min-height: 280px; position: relative; padding: 32px; border-right: 1px solid #d8dfda; border-bottom: 1px solid #d8dfda; background: rgba(255,255,255,.38); transition: .3s; }
.benefit-card:hover { z-index: 2; background: #fff; box-shadow: var(--shadow); transform: translateY(-3px); }
.benefit-card > span { color: #a0aaa5; font-size: 9px; font-weight: 800; }
.benefit-card i { width: 50px; height: 50px; display: grid; place-items: center; margin: 35px 0 27px; border-radius: 14px; color: var(--green); background: var(--green-pale); font-size: 24px; font-style: normal; }
.benefit-card h3 { margin: 0 0 10px; font-family: "Space Grotesk"; font-size: 19px; }
.benefit-card p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.7; }

.service-band { color: #fff; background: var(--navy); }
.service-band .container { display: grid; grid-template-columns: .75fr 1.25fr; gap: 100px; }
.service-intro { position: sticky; top: 130px; align-self: start; }
.service-intro p { max-width: 330px; color: rgba(255,255,255,.53); line-height: 1.7; }
.service-list { border-top: 1px solid rgba(255,255,255,.16); }
.service-list a { display: grid; grid-template-columns: 48px 1fr 30px; align-items: center; min-height: 82px; border-bottom: 1px solid rgba(255,255,255,.16); transition: .25s; }
.service-list a:hover { padding-left: 12px; color: var(--green-bright); }
.service-list span { color: rgba(255,255,255,.35); font-size: 9px; }
.service-list strong { font-family: "Space Grotesk"; font-size: 19px; }
.service-list i { font-style: normal; }

.product-row { display: grid; grid-template-columns: repeat(4, 1fr); gap: 14px; }
.product-card { padding-bottom: 20px; border-bottom: 1px solid var(--line); }
.product-visual { height: 270px; position: relative; display: grid; place-items: center; margin-bottom: 19px; border-radius: var(--radius); background: #edf1ee; overflow: hidden; }
.product-visual::before { content: ""; position: absolute; width: 180px; height: 180px; border-radius: 50%; background: rgba(255,255,255,.75); filter: blur(1px); }
.product-visual > span { position: relative; color: #35433d; font-family: Georgia, serif; font-size: 116px; filter: drop-shadow(0 20px 14px rgba(8,31,22,.2)); }
.product-visual small { position: absolute; top: 16px; left: 16px; padding: 6px 8px; border-radius: 5px; color: #fff; background: var(--green); font-size: 7px; font-weight: 800; letter-spacing: .08em; }
.brake-product { background: #182f38; }
.brake-product > span { color: #cbd3cf; }
.product-card > p { margin: 0 0 7px; color: #89948f; font-size: 8px; letter-spacing: .1em; font-weight: 800; }
.product-card h3 { margin: 0 0 14px; font-family: "Space Grotesk"; font-size: 19px; }
.product-card a { color: var(--green); font-size: 11px; font-weight: 800; }

.why-section { background: #fff; }
.why-grid { display: grid; grid-template-columns: .85fr 1.15fr; gap: 120px; }
.why-sticky { position: sticky; top: 130px; align-self: start; }
.why-sticky > p { max-width: 450px; margin: 27px 0 32px; color: var(--muted); font-size: 14px; line-height: 1.8; }
.reason-list { border-top: 1px solid var(--line); }
.reason-list article { display: grid; grid-template-columns: 52px 1fr; gap: 24px; padding: 31px 0; border-bottom: 1px solid var(--line); }
.reason-list article > span { padding-top: 5px; color: var(--green); font-size: 9px; font-weight: 800; }
.reason-list h3 { margin: 0 0 10px; font-family: "Space Grotesk"; font-size: 21px; }
.reason-list p { margin: 0; color: var(--muted); font-size: 12px; line-height: 1.7; }

.testimonials-section { color: #fff; background: #071b16; }
.light-heading h2 { color: #fff; }
.quote-mark { color: var(--green); font-family: Georgia, serif; font-size: 150px; line-height: .5; }
.testimonial-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 14px; }
blockquote { margin: 0; }
.testimonial-grid blockquote { min-height: 330px; display: flex; flex-direction: column; padding: 30px; border: 1px solid rgba(255,255,255,.12); border-radius: var(--radius); background: rgba(255,255,255,.04); }
.stars { color: var(--green-bright); font-size: 11px; letter-spacing: .15em; }
.testimonial-grid blockquote > p { margin: 35px 0; color: rgba(255,255,255,.75); font-family: "Space Grotesk"; font-size: 17px; line-height: 1.65; }
.testimonial-grid footer { display: flex; align-items: center; gap: 12px; margin-top: auto; }
.testimonial-grid footer > span { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; color: var(--green-bright); background: rgba(57,216,121,.12); font-size: 10px; font-weight: 800; }
.testimonial-grid footer strong, .testimonial-grid footer small { display: block; }
.testimonial-grid footer strong { font-size: 10px; }
.testimonial-grid footer small { margin-top: 4px; color: rgba(255,255,255,.4); font-size: 8px; }

.contact-section { padding: 112px 0; color: #fff; background: var(--green); }
.contact-grid { display: grid; grid-template-columns: 1fr .85fr; align-items: start; gap: 100px; }
.contact-copy .eyebrow { color: #d9ffe8; }
.contact-copy > p { max-width: 550px; margin: 25px 0 42px; color: rgba(255,255,255,.76); font-size: 16px; line-height: 1.8; }
.contact-options { display: grid; gap: 12px; }
.contact-options a, .contact-options button { width: 100%; display: flex; align-items: center; gap: 14px; padding: 15px; border: 1px solid rgba(255,255,255,.28); border-radius: 12px; color: #fff; background: rgba(255,255,255,.08); text-align: left; }
.contact-options > * > span { width: 38px; height: 38px; display: grid; place-items: center; border-radius: 50%; color: var(--green); background: #fff; }
.contact-options small, .contact-options strong { display: block; }
.contact-options small { color: rgba(255,255,255,.65); font-size: 8px; text-transform: uppercase; letter-spacing: .1em; }
.contact-options strong { margin-top: 4px; font-size: 12px; }
.lead-form { padding: 32px; border-radius: 22px; color: var(--ink); background: #fff; box-shadow: 0 30px 70px rgba(0,64,28,.2); }
.form-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 26px; padding-bottom: 19px; border-bottom: 1px solid var(--line); }
.form-head strong { font-family: "Space Grotesk"; font-size: 19px; }
.form-head span { color: #8b9892; font-size: 8px; text-transform: uppercase; letter-spacing: .08em; }
.lead-form label { display: block; margin-top: 15px; }
.lead-form label > span { display: block; margin-bottom: 7px; color: #52615b; font-size: 10px; font-weight: 800; }
.lead-form input { width: 100%; height: 48px; padding: 0 14px; border: 1px solid #d9e0dc; border-radius: 8px; outline: none; font-size: 12px; }
.lead-form input:focus { border-color: var(--green); box-shadow: 0 0 0 3px var(--green-pale); }
.lead-form .button { width: 100%; margin-top: 23px; }
.lead-form > small { display: block; margin-top: 12px; color: #98a39e; font-size: 7px; text-align: center; }

.site-footer { padding: 75px 0 28px; color: #fff; background: #06130f; }
.footer-main { display: grid; grid-template-columns: 1.6fr repeat(3, 1fr); gap: 70px; padding-bottom: 62px; }
.footer-logo { width: 175px; height: 56px; }
.footer-brand p { max-width: 310px; color: rgba(255,255,255,.45); font-size: 12px; line-height: 1.8; }
.footer-links { display: flex; flex-direction: column; gap: 13px; }
.footer-links strong { margin-bottom: 7px; color: var(--green-bright); font-size: 9px; text-transform: uppercase; letter-spacing: .13em; }
.footer-links a { color: rgba(255,255,255,.55); font-size: 11px; }
.footer-links a:hover { color: #fff; }
.footer-bottom { display: flex; justify-content: space-between; padding-top: 25px; border-top: 1px solid rgba(255,255,255,.11); color: rgba(255,255,255,.3); font-size: 9px; }
.footer-bottom div { display: flex; gap: 25px; }

.maya-modal { position: fixed; inset: 0; z-index: 300; display: grid; place-items: center; padding: 20px; opacity: 0; visibility: hidden; transition: .25s; }
.maya-modal.open { opacity: 1; visibility: visible; }
.modal-backdrop { position: absolute; inset: 0; background: rgba(2,13,10,.8); backdrop-filter: blur(10px); }
.modal-card { width: min(430px, 100%); position: relative; z-index: 1; padding: 46px 35px 34px; border: 1px solid rgba(255,255,255,.13); border-radius: 28px; color: #fff; background: radial-gradient(circle at 50% 0%, #1b5942, #081b15 48%); box-shadow: 0 30px 100px rgba(0,0,0,.5); text-align: center; }
.modal-close { position: absolute; top: 15px; right: 17px; width: 34px; height: 34px; border: 0; border-radius: 50%; color: #fff; background: rgba(255,255,255,.1); font-size: 23px; }
.maya-orb { width: 100px; height: 100px; position: relative; margin: 0 auto 26px; border-radius: 50%; background: #123c2f; box-shadow: inset 0 0 30px rgba(57,216,121,.3), 0 0 45px rgba(57,216,121,.2); }
.maya-orb i { position: absolute; inset: 20px; border: 2px solid var(--green-bright); border-radius: 48% 52% 43% 57%; animation: orbit 4s linear infinite; }
.maya-orb i:nth-child(2) { inset: 27px; animation-direction: reverse; animation-duration: 3s; }
.maya-orb i:nth-child(3) { inset: 37px; background: var(--green-bright); box-shadow: 0 0 18px var(--green-bright); }
.modal-card > small { color: var(--green-bright); font-size: 8px; font-weight: 800; letter-spacing: .16em; }
.modal-card h2 { margin: 12px 0; font-size: 38px; }
.maya-prompt { min-height: 48px; color: rgba(255,255,255,.62); font-size: 12px; line-height: 1.7; }
.live-wave { height: 45px; display: flex; justify-content: center; align-items: center; gap: 4px; opacity: .25; }
.live-wave.listening { opacity: 1; }
.live-wave i { height: 10px; }
.live-wave i:nth-child(2n) { height: 28px; animation-delay: .12s; }
.live-wave i:nth-child(3n) { height: 40px; animation-delay: .24s; }
.modal-mic { width: 68px; height: 68px; margin: 12px 0; border: 0; border-radius: 50%; color: #fff; background: var(--green); box-shadow: 0 0 0 10px rgba(39,174,96,.13); transition: .25s; }
.modal-mic.listening { transform: scale(1.08); box-shadow: 0 0 0 16px rgba(39,174,96,.1); }
.demo-note { display: block; margin-top: 8px; color: rgba(255,255,255,.3); font-size: 8px; text-transform: uppercase; letter-spacing: .12em; }
.toast { position: fixed; left: 50%; bottom: 24px; z-index: 500; padding: 13px 18px; border-radius: 9px; color: #fff; background: var(--navy); font-size: 11px; font-weight: 700; opacity: 0; transform: translate(-50%, 20px); pointer-events: none; transition: .25s; box-shadow: var(--shadow); }
.toast.show { opacity: 1; transform: translate(-50%, 0); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .7s ease, transform .7s ease; }
.reveal.visible { opacity: 1; transform: none; }
@keyframes wave { 0%, 100% { transform: scaleY(.55); } 50% { transform: scaleY(1); } }
@keyframes orbit { to { transform: rotate(360deg); } }

@media (max-width: 1020px) {
  .desktop-nav, .text-link { display: none; }
  .menu-toggle { display: block; }
  .mobile-menu { position: fixed; inset: 82px 0 0; display: flex; flex-direction: column; gap: 0; padding: 30px 20px; color: var(--ink); background: #fff; opacity: 0; visibility: hidden; transform: translateY(-10px); transition: .25s; }
  .mobile-menu.open { opacity: 1; visibility: visible; transform: none; }
  .mobile-menu a:not(.button) { padding: 17px 4px; border-bottom: 1px solid var(--line); font-family: "Space Grotesk"; font-size: 21px; }
  .mobile-menu .button { margin-top: 25px; }
  .hero { min-height: 760px; }
  .hero-image { object-position: 59% center; }
  .hero-shade { background: linear-gradient(90deg, rgba(4,17,14,.94), rgba(4,17,14,.5) 75%, rgba(4,17,14,.3)); }
  .brand-strip .container { display: block; }
  .brand-strip p { display: none; }
  .brand-marquee { overflow: hidden; }
  .steps-grid, .category-grid { grid-template-columns: repeat(2, 1fr); }
  .maya-grid { gap: 45px; }
  .benefit-grid { grid-template-columns: repeat(2, 1fr); }
  .service-band .container, .why-grid { gap: 60px; }
  .product-row { grid-template-columns: repeat(2, 1fr); gap: 35px 14px; }
  .contact-grid { gap: 50px; }
  .footer-main { grid-template-columns: 1.5fr repeat(3, 1fr); gap: 35px; }
}

@media (max-width: 760px) {
  .container { width: min(100% - 28px, 600px); }
  .section { padding: 78px 0; }
  .nav-wrap { height: 70px; }
  .logo-crop { width: 150px; height: 48px; }
  .logo-crop img { width: 163px; top: -31px; }
  .nav-actions > .button { display: none; }
  .mobile-menu { inset: 70px 0 0; }
  .hero { min-height: 720px; height: 100svh; max-height: 820px; align-items: end; padding-bottom: 42px; }
  .hero-image { object-position: 68% center; opacity: .7; }
  .hero-shade { background: linear-gradient(0deg, rgba(3,14,11,.98) 10%, rgba(3,14,11,.72) 67%, rgba(3,14,11,.35)); }
  .hero-content { padding-top: 100px; }
  .hero h1 { font-size: clamp(47px, 14vw, 66px); }
  .hero-content > p { margin: 20px 0 26px; font-size: 14px; line-height: 1.65; }
  .hero-actions { flex-direction: column; align-items: stretch; }
  .hero-trust { display: grid; grid-template-columns: repeat(2, 1fr); gap: 20px 0; margin-top: 34px; }
  .hero-trust div { min-width: 0; padding: 0 14px; }
  .hero-trust div:nth-child(3) { padding-left: 0; border-left: 0; }
  .hero-trust strong { font-size: 18px; }
  .scroll-cue { display: none; }
  .brand-marquee { justify-content: flex-start; gap: 30px; }
  .section-heading { display: block; margin-bottom: 38px; }
  .section-heading h2, .why-sticky h2, .contact-copy h2, .service-intro h2 { font-size: 40px; }
  .section-heading > p { margin-top: 20px; }
  .arrow-link { display: inline-block; margin-top: 22px; }
  .steps-grid, .category-grid, .benefit-grid, .product-row, .testimonial-grid { grid-template-columns: 1fr; }
  .step-card { min-height: 335px; }
  .category-card { min-height: 270px; }
  .maya-grid, .service-band .container, .why-grid, .contact-grid { grid-template-columns: 1fr; gap: 50px; }
  .feature-list { grid-template-columns: 1fr; }
  .assistant-shell { width: 100%; justify-self: center; transform: none; }
  .chat-body { min-height: 400px; }
  .benefit-grid { border-left: 0; }
  .benefit-card { min-height: 240px; border-left: 1px solid #d8dfda; }
  .service-intro, .why-sticky { position: static; }
  .product-visual { height: 300px; }
  .testimonial-grid { gap: 12px; }
  .contact-section { padding: 78px 0; }
  .lead-form { padding: 23px 19px; }
  .form-head { display: block; }
  .form-head span { display: block; margin-top: 5px; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 40px 25px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-bottom { flex-direction: column; gap: 15px; }
}

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after { scroll-behavior: auto !important; animation-duration: .01ms !important; animation-iteration-count: 1 !important; transition-duration: .01ms !important; }
  .reveal { opacity: 1; transform: none; }
}
