@import url("https://fonts.googleapis.com/css2?family=DM+Sans:wght@400;500;600;700&family=Manrope:wght@400;500;600;700;800&display=swap");

:root {
    --night: #020914;
    --night-2: #061321;
    --navy: #09223a;
    --blue: #0587ff;
    --cyan: #25c2ff;
    --electric: #75ddff;
    --white: #fff;
    --off-white: #f3f6f9;
    --ink: #101c2b;
    --muted: #6d7c8e;
    --line: #dce4eb;
    --green: #23c982;
    --shell: 1240px;
    --radius: 28px;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
    margin: 0;
    color: var(--ink);
    background: var(--white);
    font-family: "DM Sans", Arial, sans-serif;
    -webkit-font-smoothing: antialiased;
}
body.menu-open { overflow: hidden; }
a { color: inherit; }
img { display: block; max-width: 100%; }
button, input, select, textarea { font: inherit; }
h1, h2, h3, p { margin-top: 0; }
h1, h2, h3 { font-family: "Manrope", "DM Sans", sans-serif; }
.shell { width: min(calc(100% - 48px), var(--shell)); margin-inline: auto; }
.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;
}
.skip-link {
    position: fixed; z-index: 999; top: 10px; left: 10px; padding: 10px 15px;
    color: #fff; background: var(--blue); border-radius: 8px; transform: translateY(-150%);
}
.skip-link:focus { transform: none; }

.site-header {
    position: fixed; z-index: 100; inset: 0 0 auto;
    color: #fff; background: rgba(2,9,20,.55);
    border-bottom: 1px solid rgba(255,255,255,.07);
    backdrop-filter: blur(18px); transition: background .25s, box-shadow .25s;
}
.site-header.scrolled { background: rgba(2,9,20,.92); box-shadow: 0 16px 45px rgba(0,0,0,.24); }
.header-inner { min-height: 82px; display: flex; align-items: center; gap: 34px; }
.brand { width: 112px; flex: 0 0 auto; }
.brand img, .footer-brand img { width: 100%; }
.main-nav { display: flex; gap: 30px; margin-left: auto; }
.main-nav a {
    position: relative; color: #a9b8c8; font-size: .78rem; font-weight: 600;
    text-decoration: none; transition: color .2s;
}
.main-nav a::after {
    position: absolute; right: 0; bottom: -10px; left: 0; height: 1px;
    content: ""; background: var(--cyan); transform: scaleX(0); transition: transform .2s;
}
.main-nav a:hover { color: #fff; }
.main-nav a:hover::after { transform: scaleX(1); }
.client-link {
    display: flex; flex-direction: column; gap: 2px; padding-left: 25px;
    text-decoration: none; border-left: 1px solid rgba(255,255,255,.15);
}
.client-link span { color: #6f8498; font-size: .58rem; }
.client-link b { color: #fff; font-size: .7rem; }
.menu-toggle {
    display: none; width: 44px; height: 44px; margin-left: auto; padding: 11px;
    background: transparent; border: 1px solid rgba(255,255,255,.18); border-radius: 50%;
}
.menu-toggle span:not(.sr-only) { display: block; height: 1px; margin: 5px 0; background: #fff; }

.button {
    min-height: 56px; display: inline-flex; align-items: center; justify-content: center;
    gap: 22px; padding: 0 27px; font-size: .78rem; font-weight: 800;
    text-decoration: none; border: 1px solid transparent; border-radius: 10px;
    transition: transform .2s, box-shadow .2s, background .2s;
}
.button:hover { transform: translateY(-3px); }
.button-primary {
    color: #fff; background: linear-gradient(135deg, #06a8ef, #0874ed);
    box-shadow: 0 18px 46px rgba(5,135,255,.3);
}
.button-primary:hover { box-shadow: 0 22px 56px rgba(5,135,255,.42); }
.button-ghost { color: #fff; background: rgba(255,255,255,.045); border-color: rgba(255,255,255,.18); }
.button-light { color: var(--night); background: #fff; }
.button-small { min-height: 44px; padding: 0 18px; }
.button-full { width: 100%; }
.button-arrow span { font-size: 1.1rem; transition: transform .2s; }
.button-arrow:hover span { transform: translateX(4px); }
.play-icon {
    width: 25px; height: 25px; display: grid; place-items: center;
    font-size: .45rem; font-style: normal; border: 1px solid rgba(255,255,255,.3); border-radius: 50%;
}
.live-dot {
    width: 8px; height: 8px; display: inline-block; background: var(--green);
    border-radius: 50%; box-shadow: 0 0 0 6px rgba(35,201,130,.12), 0 0 22px rgba(35,201,130,.8);
}
.section-index {
    display: block; color: #537089; font-size: .63rem; font-weight: 800;
    letter-spacing: .14em; text-transform: uppercase;
}
.section-index-light { color: #64809a; }

.hero {
    position: relative; overflow: hidden; padding: 185px 0 125px; color: #fff;
    background:
        radial-gradient(circle at 72% 25%, rgba(0,135,255,.17), transparent 25%),
        radial-gradient(circle at 20% 18%, rgba(29,88,150,.18), transparent 28%),
        var(--night);
}
.hero::after {
    position: absolute; right: -20%; bottom: 16%; left: -20%; height: 45%;
    content: ""; background: linear-gradient(transparent, rgba(3,11,21,.86)); pointer-events: none;
}
.hero-grid-lines {
    position: absolute; inset: 0; opacity: .12;
    background-image:
        linear-gradient(rgba(103,176,227,.18) 1px, transparent 1px),
        linear-gradient(90deg, rgba(103,176,227,.18) 1px, transparent 1px);
    background-size: 90px 90px;
    mask-image: linear-gradient(to bottom, rgba(0,0,0,.65), transparent 72%);
}
.hero-orbit { position: absolute; border: 1px solid rgba(51,176,255,.14); border-radius: 50%; }
.orbit-one { width: 850px; height: 850px; top: -280px; right: -200px; }
.orbit-two { width: 540px; height: 540px; top: -125px; right: -45px; }
.hero-copy { position: relative; z-index: 2; text-align: center; }
.hero-kicker {
    display: inline-flex; align-items: center; gap: 12px; margin-bottom: 35px;
    color: #8ba3ba; font-size: .68rem; font-weight: 700; letter-spacing: .08em; text-transform: uppercase;
}
.hero h1 {
    max-width: 1000px; margin: 0 auto; color: #fff;
    font-size: clamp(4.3rem, 8.4vw, 8rem); font-weight: 700; line-height: .9; letter-spacing: -.075em;
}
.hero h1 em, .editorial-heading h2 em, .app-copy h2 em, .independence-heading h2 em,
.legacy-copy h2 em, .process-heading h2 em, .pricing-intro h2 em, .faq-intro h2 em,
.closing-inner h2 em {
    color: transparent; font-style: normal; -webkit-text-stroke: 1px rgba(117,221,255,.75);
}
.hero-lead {
    max-width: 680px; margin: 32px auto 0; color: #9db0c3; font-size: 1rem; line-height: 1.75;
}
.hero-actions { display: flex; justify-content: center; gap: 12px; margin-top: 36px; }
.hero-metrics {
    max-width: 720px; display: grid; grid-template-columns: repeat(3,1fr);
    margin: 62px auto 0; padding-top: 24px; border-top: 1px solid rgba(255,255,255,.1);
}
.hero-metrics div { display: flex; flex-direction: column; gap: 6px; }
.hero-metrics div + div { border-left: 1px solid rgba(255,255,255,.1); }
.hero-metrics strong { font-size: .8rem; }
.hero-metrics span { color: #637b91; font-size: .6rem; }

.product-stage {
    position: relative; z-index: 3; margin-top: 85px; padding: 10px;
    background: linear-gradient(145deg, rgba(82,198,255,.32), rgba(255,255,255,.02) 28%, rgba(255,255,255,.08));
    border: 1px solid rgba(133,213,255,.18); border-radius: 25px 25px 0 0;
    box-shadow: 0 -25px 130px rgba(0,124,255,.13), 0 50px 100px rgba(0,0,0,.55);
    scroll-margin-top: 105px;
}
.product-toolbar {
    height: 47px; display: flex; align-items: center; justify-content: space-between;
    padding: 0 16px; color: #6f859a; font-size: .59rem; background: #081421; border-radius: 15px 15px 0 0;
}
.window-dots { display: flex; gap: 6px; }
.window-dots i { width: 7px; height: 7px; background: #274055; border-radius: 50%; }
.product-toolbar b { display: flex; align-items: center; gap: 9px; color: #7690a5; font-weight: 600; }
.product-toolbar .live-dot { width: 5px; height: 5px; box-shadow: 0 0 12px var(--green); }
.product-screen {
    position: relative; overflow: hidden; aspect-ratio: 1.847 / 1;
    background:
        radial-gradient(circle at 50% 45%, rgba(5,135,255,.16), transparent 27%),
        linear-gradient(rgba(80,163,220,.07) 1px, transparent 1px),
        linear-gradient(90deg, rgba(80,163,220,.07) 1px, transparent 1px),
        #061321;
    background-size: auto, 54px 54px, 54px 54px, auto;
    border-radius: 0 0 14px 14px;
}
.platform-placeholder {
    position: absolute; inset: 0; display: flex; flex-direction: column;
    align-items: center; justify-content: center; padding: 35px; text-align: center;
}
.platform-placeholder strong { margin-top: 24px; color: #fff; font-size: 1.35rem; }
.platform-placeholder p { max-width: 470px; margin: 10px 0 18px; color: #7790a5; font-size: .74rem; line-height: 1.65; }
.platform-placeholder small { color: #4d6a82; font-size: .55rem; letter-spacing: .11em; text-transform: uppercase; }
.placeholder-radar {
    position: relative; width: 125px; height: 125px; display: grid; place-items: center;
    border: 1px solid rgba(37,194,255,.18); border-radius: 50%;
    box-shadow: 0 0 70px rgba(5,135,255,.13), inset 0 0 35px rgba(5,135,255,.08);
}
.placeholder-radar::before,
.placeholder-radar::after {
    position: absolute; content: ""; border: 1px solid rgba(37,194,255,.13); border-radius: 50%;
}
.placeholder-radar::before { inset: 22px; }
.placeholder-radar::after { inset: 44px; background: rgba(5,135,255,.16); }
.placeholder-radar i {
    position: relative; z-index: 2; width: 10px; height: 10px;
    background: var(--cyan); border-radius: 50%; box-shadow: 0 0 0 8px rgba(37,194,255,.1), 0 0 25px var(--cyan);
}
.screen-glare {
    position: absolute; inset: 0; pointer-events: none;
    background: linear-gradient(120deg, rgba(255,255,255,.08), transparent 28%, transparent 70%, rgba(37,194,255,.04));
}
.floating-signal {
    position: absolute; z-index: 3; display: flex; align-items: center; gap: 11px;
    min-width: 190px; padding: 13px 15px; color: #fff; background: rgba(3,15,28,.9);
    border: 1px solid rgba(118,211,255,.22); border-radius: 12px; box-shadow: 0 18px 45px rgba(0,0,0,.38);
    backdrop-filter: blur(12px);
}
.floating-signal > i {
    width: 32px; height: 32px; display: grid; place-items: center; color: var(--cyan);
    font-style: normal; background: rgba(5,135,255,.16); border-radius: 8px;
}
.floating-signal div { display: flex; flex-direction: column; gap: 3px; }
.floating-signal span { color: #7891a8; font-size: .55rem; }
.floating-signal strong { font-size: .66rem; }
.signal-location { top: 17%; left: -38px; }
.signal-command { right: -35px; bottom: 16%; }

.control-statement { padding: 150px 0; background: #fff; }
.statement-grid { display: grid; grid-template-columns: 230px 1fr; gap: 70px; }
.statement-large {
    margin-bottom: 35px; font-family: "Manrope", sans-serif;
    font-size: clamp(2.5rem,5vw,5rem); font-weight: 500; line-height: 1.08; letter-spacing: -.055em;
}
.statement-large strong { color: var(--blue); font-weight: 700; }
.statement-copy { max-width: 690px; color: var(--muted); font-size: 1rem; line-height: 1.85; }
.statement-content { min-width: 0; }
.control-demo {
    display: grid; grid-template-columns: 1.05fr .95fr; gap: 14px;
    margin-top: 65px; padding: 14px; background: #071523;
    border: 1px solid #15334d; border-radius: 24px;
    box-shadow: 0 30px 80px rgba(4,28,53,.16);
}
.control-demo-device {
    overflow: hidden; min-height: 330px; display: flex; flex-direction: column;
    background: #f7fafc; border-radius: 15px;
}
.device-status {
    min-height: 55px; display: flex; align-items: center; gap: 11px;
    padding: 0 20px; color: #5e7489; font-size: .62rem; font-weight: 800;
    background: #fff; border-bottom: 1px solid #e0e8ef;
}
.device-status .live-dot { width: 6px; height: 6px; }
.device-map {
    position: relative; flex: 1; overflow: hidden;
    background:
        linear-gradient(31deg,transparent 48%,rgba(5,135,255,.13) 49%,rgba(5,135,255,.13) 51%,transparent 52%) 0 0/95px 95px,
        linear-gradient(121deg,transparent 48%,rgba(5,135,255,.1) 49%,rgba(5,135,255,.1) 51%,transparent 52%) 0 0/135px 135px,
        #dff0f7;
}
.device-route {
    position: absolute; top: 58%; left: 9%; width: 72%; height: 5px;
    background: var(--blue); border-radius: 99px; transform: rotate(-12deg);
    box-shadow: 0 0 20px rgba(5,135,255,.45);
}
.device-pin {
    position: absolute; top: 27%; right: 15%; width: 54px; height: 54px;
    display: grid; place-items: center; color: #fff; font-size: .55rem;
    background: var(--blue); border: 6px solid #fff; border-radius: 50%;
    box-shadow: 0 14px 30px rgba(5,135,255,.35);
}
.device-command {
    display: flex; align-items: center; justify-content: space-between; gap: 15px;
    padding: 16px 20px; background: #fff; border-top: 1px solid #e0e8ef;
}
.device-command span { display: flex; flex-direction: column; gap: 3px; }
.device-command small { color: #8595a5; font-size: .52rem; }
.device-command strong { color: var(--green); font-size: .68rem; }
.device-command button {
    min-height: 38px; padding: 0 15px; color: #fff; font-size: .58rem; font-weight: 900;
    background: var(--blue); border: 0; border-radius: 8px;
}
.control-demo-flow {
    display: flex; flex-direction: column; justify-content: center; padding: 24px 30px;
}
.control-demo-flow span {
    position: relative; display: grid; grid-template-columns: 40px 1fr;
    gap: 3px 14px; padding: 21px 0; color: #fff;
}
.control-demo-flow span + span { border-top: 1px solid rgba(255,255,255,.08); }
.control-demo-flow i {
    grid-row: 1/3; width: 40px; height: 40px; display: grid; place-items: center;
    color: var(--cyan); font-size: .58rem; font-style: normal; font-weight: 900;
    background: rgba(5,135,255,.15); border: 1px solid rgba(37,194,255,.16); border-radius: 50%;
}
.control-demo-flow b { font-size: .72rem; }
.control-demo-flow small { color: #71899f; font-size: .57rem; }

.experience-section { padding: 140px 0; background: var(--off-white); }
.section-heading { margin-bottom: 65px; }
.editorial-heading { display: grid; grid-template-columns: 230px 1fr; gap: 70px; }
.editorial-heading h2, .app-copy h2, .independence-heading h2, .legacy-copy h2,
.process-heading h2, .pricing-intro h2, .faq-intro h2, .closing-inner h2 {
    margin: 0; font-size: clamp(3rem,6vw,6.2rem); line-height: .98; letter-spacing: -.065em;
}
.editorial-heading h2 em, .process-heading h2 em, .faq-intro h2 em { -webkit-text-stroke-color: rgba(5,135,255,.55); }
.experience-grid { display: grid; grid-template-columns: 1.25fr .75fr; gap: 15px; }
.experience-feature {
    position: relative; min-height: 480px; overflow: hidden; display: flex; flex-direction: column;
    justify-content: space-between; padding: 38px; background: #fff; border: 1px solid #e3e9ef; border-radius: 22px;
}
.feature-copy { position: relative; z-index: 2; }
.feature-copy > span { color: #7790a6; font-size: .58rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; }
.feature-copy h3 { margin: 16px 0 14px; font-size: clamp(1.7rem,3vw,3.1rem); line-height: 1.05; letter-spacing: -.045em; }
.feature-copy p { max-width: 470px; margin: 0; color: var(--muted); font-size: .8rem; line-height: 1.7; }
.feature-dark { color: #fff; background: var(--night-2); border-color: var(--night-2); }
.feature-dark .feature-copy p { color: #8399ad; }
.feature-alert { color: #fff; background: linear-gradient(145deg,#0679e8,#05a8ed); border: 0; }
.feature-alert .feature-copy > span, .feature-alert .feature-copy p { color: rgba(255,255,255,.68); }
.feature-fleet { background: #e7f6ff; border-color: #cdeaf9; }
.mini-map {
    position: absolute; top: 0; right: 0; bottom: 0; width: 53%; overflow: hidden;
    background:
        linear-gradient(30deg,transparent 48%,rgba(5,135,255,.12) 49%,rgba(5,135,255,.12) 51%,transparent 52%) 0 0/90px 90px,
        linear-gradient(120deg,transparent 48%,rgba(5,135,255,.1) 49%,rgba(5,135,255,.1) 51%,transparent 52%) 0 0/120px 120px,
        #e8f2f7;
}
.route-line { position: absolute; height: 5px; background: var(--blue); border-radius: 99px; transform-origin: left center; box-shadow: 0 0 18px rgba(5,135,255,.45); }
.route-one { width: 56%; top: 42%; left: 9%; transform: rotate(19deg); }
.route-two { width: 45%; top: 59%; left: 57%; transform: rotate(-43deg); }
.map-point { position: absolute; width: 15px; height: 15px; background: #fff; border: 4px solid var(--blue); border-radius: 50%; }
.map-point.start { top: 39%; left: 8%; }
.map-point.end { top: 30%; right: 9%; width: 48px; height: 48px; display: grid; place-items: center; color: #fff; font-size: .55rem; font-weight: 900; background: var(--blue); border: 6px solid #fff; box-shadow: 0 10px 25px rgba(5,135,255,.35); }
.mini-map b { position: absolute; right: 30px; bottom: 30px; padding: 12px 15px; color: #718497; font-size: .58rem; font-weight: 600; background: rgba(255,255,255,.9); border-radius: 9px; }
.mini-map b strong { color: var(--green); }
.lock-visual { position: relative; height: 220px; display: grid; place-items: center; }
.lock-ring { position: absolute; width: 180px; height: 180px; border: 1px solid rgba(37,194,255,.2); border-radius: 50%; box-shadow: 0 0 80px rgba(5,135,255,.14), inset 0 0 50px rgba(5,135,255,.06); }
.lock-ring::before, .lock-ring::after { position: absolute; inset: 22px; content: ""; border: 1px dashed rgba(37,194,255,.28); border-radius: 50%; }
.lock-ring::after { inset: 48px; background: rgba(5,135,255,.15); border-style: solid; }
.lock-visual > i { position: relative; z-index: 2; color: var(--cyan); font-size: 2rem; font-style: normal; }
.alert-stack { display: flex; flex-direction: column; gap: 9px; margin-left: auto; width: 82%; }
.alert-stack > div { display: flex; align-items: center; gap: 13px; padding: 14px; background: rgba(4,26,55,.68); border: 1px solid rgba(255,255,255,.13); border-radius: 11px; backdrop-filter: blur(10px); }
.alert-stack > div:nth-child(2) { transform: translateX(-35px); }
.alert-stack i { width: 32px; height: 32px; display: grid; place-items: center; font-style: normal; background: rgba(37,194,255,.16); border-radius: 8px; }
.alert-stack p { display: flex; flex-direction: column; gap: 3px; margin: 0; }
.alert-stack strong { font-size: .67rem; }
.alert-stack span { color: #9fb5ca; font-size: .55rem; }
.fleet-counter { display: grid; grid-template-columns: repeat(3,1fr); gap: 8px; }
.fleet-counter span { display: flex; flex-direction: column; padding: 17px; color: #5d7890; font-size: .58rem; background: rgba(255,255,255,.78); border: 1px solid #cee7f5; border-radius: 11px; }
.fleet-counter b { margin-bottom: 4px; color: var(--blue); font-size: 1.35rem; }
.included-features {
    display: grid; grid-template-columns: 260px 1fr; gap: 45px;
    margin-top: 16px; padding: 34px 38px; color: #fff;
    background: #071523; border: 1px solid #15334d; border-radius: 20px;
}
.included-heading { display: flex; flex-direction: column; justify-content: center; gap: 10px; }
.included-heading span { color: var(--cyan); font-size: .57rem; font-weight: 900; letter-spacing: .13em; text-transform: uppercase; }
.included-heading strong { max-width: 220px; font-size: 1.05rem; line-height: 1.35; }
.included-grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 4px 20px; }
.included-grid span { min-height: 48px; display: flex; align-items: center; gap: 10px; color: #b3c2cf; font-size: .63rem; border-bottom: 1px solid rgba(255,255,255,.07); }
.included-grid i { width: 25px; height: 25px; flex: 0 0 auto; display: grid; place-items: center; color: var(--cyan); font-size: .54rem; font-style: normal; font-weight: 900; background: rgba(5,135,255,.14); border-radius: 7px; }

.app-section { position: relative; overflow: hidden; padding: 160px 0 80px; color: #fff; background: var(--night); }
.app-light { position: absolute; width: 800px; height: 800px; right: -250px; top: 0; background: radial-gradient(circle,rgba(5,135,255,.2),transparent 62%); }
.app-layout { display: grid; grid-template-columns: .85fr 1.15fr; align-items: center; gap: 60px; }
.app-copy { position: relative; z-index: 2; }
.app-copy h2 { margin: 27px 0 30px; }
.app-copy p { max-width: 520px; color: #879caf; line-height: 1.8; }
.app-points { display: flex; flex-direction: column; gap: 12px; margin-top: 35px; }
.app-points span { color: #c3d0dd; font-size: .72rem; }
.app-points i { width: 21px; height: 21px; display: inline-grid; place-items: center; margin-right: 9px; color: var(--cyan); font-size: .58rem; font-style: normal; background: rgba(5,135,255,.16); border-radius: 50%; }
.phone-stage { position: relative; min-height: 720px; display: grid; place-items: center; }
.phone-stage > img { position: relative; z-index: 2; max-height: 720px; filter: drop-shadow(0 40px 65px rgba(0,0,0,.5)); }
.phone-orbit { position: absolute; width: 580px; height: 580px; border: 1px solid rgba(37,194,255,.16); border-radius: 50%; box-shadow: inset 0 0 100px rgba(5,135,255,.08); }
.phone-orbit::before, .phone-orbit::after { position: absolute; content: ""; border: 1px solid rgba(37,194,255,.1); border-radius: 50%; }
.phone-orbit::before { inset: 55px; }
.phone-orbit::after { inset: 120px; }
.phone-label {
    position: absolute; z-index: 4; min-width: 190px; display: grid;
    grid-template-columns: 36px 1fr; gap: 2px 11px; padding: 14px; color: #fff;
    background: rgba(7,22,37,.88); border: 1px solid rgba(99,206,255,.25); border-radius: 12px; backdrop-filter: blur(12px);
}
.phone-label i { grid-row: 1/3; width: 36px; height: 36px; display: grid; place-items: center; color: var(--cyan); font-style: normal; background: rgba(5,135,255,.15); border-radius: 9px; }
.phone-label b { font-size: .65rem; }
.phone-label small { color: #7890a4; font-size: .55rem; }
.label-history { top: 24%; left: 0; }
.label-block { right: -3%; bottom: 19%; }

.independence-section { padding: 150px 0; background: #fff; }
.independence-layout { display: grid; grid-template-columns: .82fr 1.18fr; gap: 90px; }
.independence-heading h2 { margin-top: 25px; font-size: clamp(2.8rem,5vw,5rem); }
.independence-heading h2 em { -webkit-text-stroke-color: rgba(5,135,255,.55); }
.comparison { border-top: 1px solid var(--line); }
.comparison-row { display: grid; grid-template-columns: 1.1fr 1fr 1fr; align-items: center; min-height: 82px; border-bottom: 1px solid var(--line); }
.comparison-row span { font-size: .7rem; font-weight: 800; }
.comparison-row em { color: #8b98a6; font-size: .68rem; font-style: normal; }
.comparison-row b { color: var(--blue); font-size: .7rem; }
.comparison-head { min-height: 48px; }
.comparison-head strong { color: #8291a0; font-size: .58rem; text-transform: uppercase; letter-spacing: .1em; }
.comparison-head .qrv-column { color: var(--blue); }

.legacy-section { overflow: hidden; padding: 150px 0; color: #fff; background: linear-gradient(115deg,#06325c,#041322 62%); }
.legacy-layout { display: grid; grid-template-columns: .8fr 1.2fr; align-items: center; gap: 100px; }
.legacy-number { position: relative; min-height: 430px; display: flex; flex-direction: column; justify-content: center; border-right: 1px solid rgba(255,255,255,.1); }
.legacy-number::before { position: absolute; width: 430px; height: 430px; left: -100px; content: ""; border: 1px solid rgba(37,194,255,.14); border-radius: 50%; box-shadow: inset 0 0 100px rgba(5,135,255,.1); }
.legacy-number span { position: relative; z-index: 2; color: #6e8da7; font-size: .7rem; }
.legacy-number strong { position: relative; z-index: 2; font-family: "Manrope"; font-size: clamp(5rem,10vw,9rem); line-height: .9; letter-spacing: -.08em; }
.legacy-copy h2 { margin: 25px 0 30px; font-size: clamp(2.8rem,5vw,5.2rem); }
.legacy-copy p { max-width: 610px; color: #90a6b9; line-height: 1.8; }
.legacy-facts { display: grid; grid-template-columns: repeat(3,1fr); gap: 18px; margin-top: 45px; }
.legacy-facts span { display: flex; flex-direction: column; gap: 6px; color: #69839a; font-size: .58rem; }
.legacy-facts b { color: #fff; font-size: .7rem; }

.process-section { padding: 150px 0; background: var(--off-white); }
.process-heading { display: grid; grid-template-columns: 230px 1fr; gap: 70px; }
.process-line { position: relative; display: grid; grid-template-columns: repeat(4,1fr); margin-top: 75px; }
.process-line::before { position: absolute; top: 34px; right: 10%; left: 10%; height: 1px; content: ""; background: #cfdce5; }
.process-line article { position: relative; padding-right: 32px; }
.process-line article > span { width: 68px; height: 68px; display: grid; place-items: center; color: var(--blue); font-size: .7rem; font-weight: 900; background: #fff; border: 1px solid #cbdce7; border-radius: 50%; }
.process-line article > i { position: absolute; top: 29px; left: 31px; width: 9px; height: 9px; background: var(--blue); border-radius: 50%; box-shadow: 0 0 0 6px rgba(5,135,255,.12); }
.process-line h3 { margin: 25px 0 10px; font-size: 1rem; }
.process-line p { max-width: 220px; color: var(--muted); font-size: .7rem; line-height: 1.65; }

.pricing-section { padding: 150px 0; color: #fff; background: var(--night); }
.pricing-shell { display: grid; grid-template-columns: 1fr 500px; align-items: center; gap: 100px; }
.pricing-intro h2 { margin: 25px 0 30px; }
.pricing-intro p { max-width: 560px; color: #899caf; line-height: 1.8; }
.pricing-intro ul { display: grid; grid-template-columns: repeat(2,1fr); gap: 13px; margin: 40px 0 0; padding: 0; list-style: none; }
.pricing-intro li { color: #b5c4d1; font-size: .68rem; }
.pricing-intro li::before { margin-right: 9px; color: var(--cyan); content: "✓"; }
.pricing-card { padding: 40px; color: var(--ink); background: #fff; border-radius: 24px; box-shadow: 0 35px 90px rgba(0,0,0,.4), 0 0 0 1px rgba(255,255,255,.12); }
.pricing-card-top { display: flex; align-items: center; justify-content: space-between; }
.pricing-card-top span { font-size: .72rem; font-weight: 800; }
.pricing-card-top em { padding: 6px 9px; color: #fff; font-size: .52rem; font-style: normal; font-weight: 900; background: var(--blue); border-radius: 5px; text-transform: uppercase; }
.price-display { display: flex; align-items: flex-start; margin: 38px 0; }
.price-display sup { margin-top: 10px; font-size: 1rem; font-weight: 900; }
.price-display > strong { font-family: "Manrope"; font-size: 6.2rem; line-height: .78; letter-spacing: -.09em; }
.price-display > b { font-size: 1.6rem; }
.price-display small { align-self: flex-end; margin: 0 0 0 12px; color: var(--muted); font-size: .58rem; line-height: 1.4; }
.installation-price { display: grid; grid-template-columns: 1fr auto; gap: 5px 20px; margin-bottom: 22px; padding: 17px; background: var(--off-white); border-radius: 10px; }
.installation-price span, .installation-price strong { font-size: .7rem; }
.installation-price small { grid-column: 1/-1; color: var(--muted); font-size: .56rem; }
.price-assurances { display: grid; grid-template-columns: repeat(2,1fr); gap: 9px; margin-top: 22px; padding-top: 20px; border-top: 1px solid var(--line); }
.price-assurances span { color: #41566b; font-size: .61rem; font-weight: 700; }
.price-assurances span::first-letter { color: var(--green); }

.faq-section { padding: 150px 0; background: #fff; }
.faq-layout { display: grid; grid-template-columns: .7fr 1.3fr; gap: 110px; }
.faq-intro { position: sticky; top: 120px; align-self: start; }
.faq-intro h2 { margin: 25px 0; font-size: clamp(2.8rem,5vw,5rem); }
.faq-intro p { max-width: 380px; color: var(--muted); font-size: .75rem; line-height: 1.7; }
.faq-intro > a { display: inline-block; margin-top: 20px; color: var(--blue); font-size: .67rem; font-weight: 800; text-decoration: none; }
.accordion { border-top: 1px solid var(--line); }
.accordion details { border-bottom: 1px solid var(--line); }
.accordion summary { position: relative; padding: 27px 55px 27px 0; cursor: pointer; font-size: .82rem; font-weight: 800; list-style: none; }
.accordion summary::-webkit-details-marker { display: none; }
.accordion summary::after { position: absolute; top: 18px; right: 3px; width: 38px; height: 38px; display: grid; place-items: center; content: "+"; color: var(--blue); background: var(--off-white); border-radius: 50%; transition: transform .2s; }
.accordion details[open] summary::after { transform: rotate(45deg); }
.accordion p { max-width: 680px; margin: -5px 55px 27px 0; color: var(--muted); font-size: .73rem; line-height: 1.75; }

.closing-section { position: relative; overflow: hidden; padding: 145px 0; color: #fff; text-align: center; background: linear-gradient(145deg,#052b52,#020914 65%); }
.closing-orbit { position: absolute; width: 720px; height: 720px; top: -290px; left: calc(50% - 360px); border: 1px solid rgba(37,194,255,.15); border-radius: 50%; box-shadow: inset 0 0 130px rgba(5,135,255,.08); }
.closing-inner { position: relative; z-index: 2; }
.closing-inner h2 { margin: 32px 0 25px; }
.closing-inner p { margin-bottom: 32px; color: #8ea3b7; }

.site-footer { padding: 75px 0 25px; color: #788da1; background: var(--night); border-top: 1px solid rgba(255,255,255,.07); }
.footer-top { display: grid; grid-template-columns: 1.7fr repeat(3,1fr); gap: 65px; }
.footer-brand img { width: 115px; }
.footer-brand p { max-width: 310px; margin-top: 20px; font-size: .67rem; line-height: 1.7; }
.footer-top > div:not(.footer-brand) { display: flex; flex-direction: column; gap: 12px; }
.footer-top strong { margin-bottom: 7px; color: #fff; font-size: .67rem; }
.footer-top a { font-size: .63rem; text-decoration: none; }
.footer-top a:hover { color: #fff; }
.footer-bottom { display: flex; justify-content: space-between; margin-top: 55px; padding-top: 22px; font-size: .57rem; border-top: 1px solid rgba(255,255,255,.08); }
.footer-bottom a { text-decoration: none; }
.mobile-cta { display: none; }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .75s ease, transform .75s ease; }
.reveal.is-visible { opacity: 1; transform: none; }

/* Legal and error pages */
.legal-page, .error-page { background: var(--off-white); }
.legal-header .header-inner { justify-content: space-between; }
.legal-hero { padding: 170px 0 75px; color: #fff; background: radial-gradient(circle at 80% 20%,rgba(5,135,255,.22),transparent 30%),var(--night); }
.eyebrow { color: var(--cyan); font-size: .62rem; font-weight: 800; letter-spacing: .13em; text-transform: uppercase; }
.eyebrow-dark { color: var(--blue); }
.legal-hero h1 { margin: 22px 0 12px; color: #fff; font-size: clamp(2.8rem,6vw,5.5rem); line-height: 1; letter-spacing: -.06em; }
.legal-hero p { color: #9bafc1; }
.legal-content { max-width: 900px; margin-top: 50px; margin-bottom: 80px; padding: 55px 65px; background: #fff; border: 1px solid var(--line); border-radius: 22px; }
.legal-updated { margin-bottom: 40px!important; color: var(--blue)!important; font-size: .7rem!important; font-weight: 800; }
.legal-content h2 { margin: 38px 0 12px; font-size: 1.3rem; }
.legal-content h2:first-of-type { margin-top: 0; }
.legal-content p, .legal-content li { color: var(--muted); font-size: .8rem; line-height: 1.8; }
.legal-content a { color: var(--blue); font-weight: 700; }
.legal-note { margin-top: 40px; padding: 20px; background: #e9f7ff; border-left: 4px solid var(--blue); border-radius: 8px; }
.legal-footer { padding: 25px 0; color: #7890a4; background: var(--night); }
.legal-footer .shell { display: flex; justify-content: space-between; }
.legal-footer span, .legal-footer a { font-size: .62rem; text-decoration: none; }
.error-main { min-height: 100vh; display: grid; place-items: center; padding: 80px 20px; color: #fff; text-align: center; background: radial-gradient(circle at 50% 35%,rgba(5,135,255,.25),transparent 30%),var(--night); }
.error-content { max-width: 650px; }
.error-code { display: block; color: var(--blue); font-size: clamp(6rem,18vw,12rem); font-weight: 900; line-height: .8; letter-spacing: -.08em; }
.error-content h1 { margin: 35px 0 15px; color: #fff; font-size: clamp(2rem,5vw,3.5rem); }
.error-content p { margin-bottom: 30px; color: #9dafc0; }

@media (max-width: 1050px) {
    .main-nav { gap: 18px; }
    .statement-grid, .editorial-heading, .process-heading { grid-template-columns: 170px 1fr; gap: 45px; }
    .experience-grid { grid-template-columns: 1fr 1fr; }
    .experience-feature { min-height: 450px; }
    .app-layout { grid-template-columns: 1fr 1fr; }
    .phone-stage { min-height: 620px; }
    .phone-stage > img { max-height: 620px; }
    .independence-layout, .legacy-layout { gap: 55px; }
    .pricing-shell { grid-template-columns: 1fr 440px; gap: 55px; }
}

@media (max-width: 860px) {
    .client-link { display: none; }
    .menu-toggle { display: block; }
    .main-nav {
        position: fixed; top: 82px; right: 0; left: 0; height: calc(100vh - 82px);
        flex-direction: column; align-items: flex-start; gap: 0; padding: 25px;
        background: rgba(2,9,20,.98); transform: translateX(100%); transition: transform .25s;
    }
    .main-nav.open { transform: none; }
    .main-nav a { width: 100%; padding: 18px 4px; font-size: 1rem; border-bottom: 1px solid rgba(255,255,255,.08); }
    .hero { padding: 155px 0 105px; }
    .product-stage { width: calc(100% - 24px); }
    .floating-signal { display: none; }
    .statement-grid, .editorial-heading, .process-heading, .independence-layout, .legacy-layout, .faq-layout { grid-template-columns: 1fr; }
    .experience-grid { grid-template-columns: 1fr; }
    .experience-feature { min-height: 440px; }
    .included-features { grid-template-columns: 1fr; gap: 25px; }
    .included-heading strong { max-width: none; }
    .mini-map { width: 55%; }
    .app-layout { grid-template-columns: 1fr; }
    .app-copy { max-width: 650px; }
    .phone-stage { min-height: 680px; }
    .independence-layout, .legacy-layout, .faq-layout { gap: 60px; }
    .legacy-number { min-height: 300px; border-right: 0; border-bottom: 1px solid rgba(255,255,255,.1); }
    .process-line { grid-template-columns: repeat(2,1fr); gap: 45px 20px; }
    .process-line::before { display: none; }
    .pricing-shell { grid-template-columns: 1fr; }
    .pricing-card { max-width: 520px; }
    .faq-intro { position: static; }
    .footer-top { grid-template-columns: repeat(2,1fr); }
}

@media (max-width: 620px) {
    .shell { width: min(calc(100% - 28px),var(--shell)); }
    .header-inner { min-height: 70px; }
    .brand { width: 96px; }
    .main-nav { top: 70px; height: calc(100vh - 70px); }
    .hero { padding: 130px 0 90px; }
    .hero h1 { font-size: clamp(3.35rem,17vw,5rem); }
    .hero-lead { font-size: .85rem; }
    .hero-actions { flex-direction: column; }
    .hero-actions .button { width: 100%; }
    .hero-metrics { grid-template-columns: 1fr; gap: 15px; margin-top: 45px; }
    .hero-metrics div { padding: 11px 0; }
    .hero-metrics div + div { border-left: 0; border-top: 1px solid rgba(255,255,255,.08); }
    .product-stage { width: calc(100% - 12px); margin-top: 55px; padding: 5px; border-radius: 15px 15px 0 0; }
    .product-toolbar { height: 36px; border-radius: 10px 10px 0 0; }
    .product-toolbar > span { display: none; }
    .control-statement, .experience-section, .app-section, .independence-section,
    .legacy-section, .process-section, .pricing-section, .faq-section { padding: 95px 0; }
    .statement-grid, .editorial-heading, .process-heading { gap: 32px; }
    .statement-large { font-size: 2.55rem; }
    .control-demo { grid-template-columns: 1fr; margin-top: 40px; }
    .control-demo-flow { padding: 12px 20px; }
    .editorial-heading h2, .app-copy h2, .independence-heading h2, .legacy-copy h2,
    .process-heading h2, .pricing-intro h2, .faq-intro h2, .closing-inner h2 { font-size: 2.8rem; }
    .experience-feature { min-height: 500px; padding: 26px; }
    .feature-main { padding-bottom: 270px; }
    .mini-map { top: auto; width: 100%; height: 260px; }
    .alert-stack { width: 100%; }
    .alert-stack > div:nth-child(2) { transform: none; }
    .fleet-counter { grid-template-columns: 1fr; }
    .included-features { padding: 26px 20px; }
    .included-grid { grid-template-columns: 1fr; }
    .phone-stage { min-height: 540px; }
    .phone-stage > img { max-height: 520px; }
    .phone-orbit { width: 390px; height: 390px; }
    .phone-label { min-width: 155px; padding: 10px; }
    .label-history { left: -8px; }
    .label-block { right: -6px; }
    .comparison { overflow-x: auto; }
    .comparison-row { min-width: 620px; }
    .legacy-number { min-height: 260px; }
    .legacy-number::before { width: 330px; height: 330px; }
    .legacy-facts, .pricing-intro ul { grid-template-columns: 1fr; }
    .process-line { grid-template-columns: 1fr; }
    .pricing-card { padding: 28px 22px; }
    .price-display > strong { font-size: 5rem; }
    .faq-layout { gap: 45px; }
    .closing-section { padding: 100px 0; }
    .footer-top { grid-template-columns: 1fr; gap: 35px; }
    .footer-bottom, .legal-footer .shell { flex-direction: column; gap: 12px; }
    .mobile-cta {
        position: fixed; z-index: 90; right: 12px; bottom: 12px; left: 12px;
        min-height: 54px; display: flex; align-items: center; justify-content: center; gap: 20px;
        color: #fff; font-size: .75rem; font-weight: 900; text-decoration: none;
        background: linear-gradient(135deg,#06a8ef,#0874ed); border-radius: 11px;
        box-shadow: 0 15px 40px rgba(5,135,255,.4);
    }
    .site-footer { padding-bottom: 95px; }
    .legal-hero { padding: 135px 0 55px; }
    .legal-content { width: min(calc(100% - 24px),900px); margin-top: 24px; padding: 30px 21px; }
}

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