:root {
  --ink: #071827;
  --ink-soft: #102b3c;
  --teal: #278f91;
  --teal-light: #65c3bd;
  --cyan: #237a99;
  --paper: #f5f8f8;
  --white: #fff;
  --muted: #62727d;
  --line: #dce5e6;
  --font-body: "Manrope", sans-serif;
  --font-display: "Space Grotesk", sans-serif;
  --shadow: 0 20px 60px rgba(5, 28, 43, .12);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body { margin: 0; overflow-x: hidden; color: var(--ink); background: var(--white); font-family: var(--font-body); line-height: 1.7; -webkit-font-smoothing: antialiased; }
img { max-width: 100%; display: block; }
a { color: inherit; text-decoration: none; }
button, input, textarea { font: inherit; }
.container { width: min(1180px, calc(100% - 40px)); margin: 0 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; left: 20px; top: -80px; z-index: 999; padding: 10px 18px; color: var(--ink); background: var(--teal-light); transition: top .2s; }
.skip-link:focus { top: 10px; }

.site-header { position: fixed; inset: 0 0 auto; z-index: 100; padding: 18px 0; transition: background .25s, padding .25s, box-shadow .25s; }
.site-header.scrolled { padding: 10px 0; background: rgba(7, 24, 39, .94); box-shadow: 0 10px 30px rgba(0,0,0,.15); backdrop-filter: blur(14px); }
.nav-wrap { display: flex; align-items: center; justify-content: space-between; }
.brand { display: block; padding: 0; }
.brand img { width: 190px; filter: brightness(0) invert(1); }
.main-nav { display: flex; align-items: center; gap: 32px; }
.main-nav > a { position: relative; color: rgba(255,255,255,.78); font-size: .84rem; font-weight: 700; }
.main-nav > a:not(.nav-cta)::after { content: ""; position: absolute; left: 0; right: 100%; bottom: -7px; height: 2px; background: var(--teal-light); transition: right .25s; }
.main-nav > a:hover { color: #fff; }
.main-nav > a:hover::after { right: 0; }
.main-nav > a.active { color: #36dac5; }
.main-nav > a.active::after { right: 0; }
.main-nav .nav-cta { display: flex; align-items: center; gap: 8px; padding: 11px 18px; color: var(--ink); background: #24cfba; border-radius: 6px; }
.nav-cta svg { width: 18px; fill: none; stroke: currentColor; stroke-width: 1.5; stroke-linecap: round; stroke-linejoin: round; }
.nav-toggle { display: none; padding: 8px; border: 0; background: transparent; }
.nav-toggle span:not(.sr-only) { display: block; width: 25px; height: 2px; margin: 5px; background: #fff; }

.systems-showcase { position: relative; overflow: hidden; min-height: 100vh; padding: 132px 0 46px; color: #f5f8fa; background: radial-gradient(circle at 74% 19%, rgba(0,111,124,.2), transparent 30%), linear-gradient(145deg, #03111c, #061d2c 58%, #041421); }
.showcase-grid { position: absolute; inset: 90px 0 auto 40%; height: 330px; opacity: .18; background-image: radial-gradient(circle, #1dcbb7 1px, transparent 1.5px); background-size: 19px 19px; mask-image: linear-gradient(90deg, transparent, #000 20%, #000 75%, transparent); }
.showcase-intro { position: relative; display: grid; grid-template-columns: minmax(0,.96fr) minmax(0,1.04fr); align-items: center; gap: 70px; min-width: 0; min-height: 260px; margin-bottom: 42px; }
.showcase-copy h1 { margin: 0; font: 700 clamp(2.8rem, 3.5vw, 3.8rem)/1.08 var(--font-display); letter-spacing: -.05em; }
.showcase-copy > p:last-child { max-width: 580px; margin: 18px 0 0; color: #b4c1ca; font-size: 1rem; }
.tech-map { position: relative; min-height: 255px; }
.map-window { position: absolute; width: 265px; height: 205px; top: 5px; left: 50%; padding: 20px; border: 1px solid rgba(36,207,186,.72); border-radius: 12px; transform: translateX(-50%); background: rgba(3,28,40,.76); box-shadow: 0 0 45px rgba(0,178,165,.08); }
.map-bar { display: flex; gap: 5px; margin: -10px 0 16px -9px; }
.map-bar i { width: 6px; height: 6px; border-radius: 50%; background: #20c9b5; }
.map-widgets { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.map-widgets span { height: 48px; border: 1px solid rgba(36,207,186,.13); border-radius: 5px; background: linear-gradient(135deg, rgba(36,207,186,.12), transparent); }
.map-chart { display: flex; align-items: end; gap: 10px; height: 50px; margin: 10px 0 0 auto; padding: 7px 15px; border: 1px solid rgba(36,207,186,.12); border-radius: 5px; }
.map-chart i { width: 10px; height: 17px; background: #087f79; }
.map-chart i:nth-child(2) { height: 29px; }.map-chart i:nth-child(3) { height: 23px; }.map-chart i:nth-child(4) { height: 37px; background: #22c7b3; }
.map-node { position: absolute; display: grid; place-items: center; width: 64px; height: 64px; border: 1px solid #20bca9; border-radius: 11px; color: #24cfba; background: rgba(4,29,41,.88); }
.map-node svg { width: 31px; fill: none; stroke: currentColor; stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.node-chart { left: 4%; top: 18px; }.node-data { left: 0; bottom: 5px; border-radius: 50%; }.node-doc { right: 3%; top: 55px; }.node-users { right: 0; bottom: 0; }
.map-line { position: absolute; height: 1px; background: rgba(36,207,186,.45); transform-origin: left; }
.line-one { width: 95px; left: 12%; top: 49px; }.line-two { width: 90px; right: 12%; top: 86px; }.line-three { width: 85px; right: 8%; bottom: 45px; transform: rotate(-22deg); }
.featured-systems { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 18px; min-width: 0; }
.featured-system { position: relative; min-width: 0; overflow: hidden; padding: 26px 26px 22px; border: 1px solid rgba(116,165,180,.35); border-radius: 15px; background: linear-gradient(145deg, rgba(10,41,57,.94), rgba(5,28,42,.96)); box-shadow: 0 22px 45px rgba(0,0,0,.16); }
.featured-body { display: grid; grid-template-columns: minmax(0,1.05fr) minmax(0,.95fr); gap: 14px; min-width: 0; min-height: 235px; }
.product-heading { display: flex; align-items: center; gap: 18px; }
.product-icon { display: grid; place-items: center; flex: 0 0 auto; width: 64px; height: 64px; border: 1px solid rgba(55,224,202,.25); border-radius: 12px; color: #d9fff9; background: linear-gradient(145deg, #0aa493, #075a60); box-shadow: inset 0 0 18px rgba(70,255,225,.18); }
.product-icon svg { width: 34px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.product-heading h2 { margin: 0; font: 700 2.15rem var(--font-display); }
.product-heading p { margin: 0; color: #27d7c1; font-size: .86rem; }
.featured-copy hr { width: 72%; margin: 12px 0 14px 82px; border: 0; border-top: 1px solid rgba(128,167,178,.22); }
.featured-copy h3 { margin: 0 0 10px; font: 600 1rem var(--font-display); }
.featured-copy > p { margin: 0; color: #b8c6ce; font-size: .83rem; line-height: 1.65; }
.product-device { align-self: end; position: relative; margin: 0 auto; filter: drop-shadow(0 18px 18px rgba(0,0,0,.35)); }
.laptop-device { width: 245px; padding: 9px 9px 16px; border: 4px solid #59636a; border-bottom-width: 9px; border-radius: 9px 9px 4px 4px; background: #222b31; }
.laptop-device::after { content: ""; position: absolute; left: -26px; right: -26px; bottom: -15px; height: 9px; border-radius: 2px 2px 8px 8px; background: linear-gradient(#a8afb3, #626b70); }
.device-screen { display: flex; height: 135px; overflow: hidden; border-radius: 3px; color: #12313b; background: #f2f6f7; }
.screen-nav { display: flex; flex-direction: column; gap: 11px; width: 36px; padding: 12px 8px; background: #063449; }
.screen-nav i { width: 13px; height: 13px; border-radius: 50%; background: #23cfba; }.screen-nav span { height: 4px; border-radius: 3px; background: #5b8190; }
.screen-main { flex: 1; padding: 10px; }.screen-head { display: flex; justify-content: space-between; font-size: .43rem; }.screen-head i { width: 18px; height: 5px; border-radius: 4px; background: #2bc9b5; }
.screen-metrics { display: grid; grid-template-columns: repeat(3,1fr); gap: 5px; margin: 10px 0; }.screen-metrics span { height: 24px; border: 1px solid #d5e1e3; border-radius: 3px; background: #fff; }
.screen-graph { position: relative; height: 62px; padding: 7px; border: 1px solid #d5e1e3; background: #fff; }.screen-graph svg { width: 67%; height: 100%; }.screen-graph path { fill: none; stroke: #259eb0; stroke-width: 2; }.screen-graph i { position: absolute; right: 13px; top: 13px; width: 31px; height: 31px; border: 7px solid #21b8a6; border-right-color: #e5ae48; border-radius: 50%; }
.tablet-device { width: 235px; padding: 10px; border: 5px solid #6d7377; border-radius: 13px; background: #1a2226; transform: perspective(700px) rotateY(-5deg); }
.restaurant-screen { display: block; height: 145px; padding: 8px; }
.restaurant-nav { display: flex; align-items: center; gap: 8px; height: 19px; margin: -8px -8px 7px; padding: 0 7px; color: #fff; background: #167e76; font-size: .35rem; }.restaurant-nav i { width: 7px; height: 7px; border-radius: 50%; background: #b9fff5; }
.restaurant-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 5px; width: 68%; }.restaurant-grid i { height: 27px; border-radius: 3px; background: #eab756; }.restaurant-grid i:nth-child(2n) { background: #6cb7a9; }.restaurant-grid i:nth-child(3n) { background: #9d78b8; }
.restaurant-total { position: absolute; right: 17px; bottom: 16px; display: grid; gap: 4px; width: 61px; font-size: .35rem; }.restaurant-total b { font-size: .42rem; }.restaurant-total button { padding: 3px; color: #fff; border: 0; border-radius: 2px; background: #1db89f; font-size: .32rem; }
.feature-row { display: grid; grid-template-columns: repeat(4, 1fr); margin: 12px -26px 20px; padding: 17px 20px; border-top: 1px solid rgba(117,162,175,.18); border-bottom: 1px solid rgba(117,162,175,.18); }
.feature-row span { position: relative; display: flex; align-items: center; min-width: 0; min-height: 38px; padding: 0 10px 0 29px; overflow-wrap: anywhere; color: #c2d0d7; border-right: 1px solid rgba(117,162,175,.15); font-size: .64rem; line-height: 1.35; }
.feature-row span:last-child { border: 0; }.feature-row span::before { content: "✓"; position: absolute; left: 7px; display: grid; place-items: center; width: 15px; height: 15px; color: #25d6c0; border: 1px solid #25d6c0; border-radius: 4px; font-size: .52rem; }
.outline-button { display: inline-flex; align-items: center; justify-content: space-between; gap: 28px; padding: 9px 14px; color: #d6e2e7; border: 1px solid rgba(130,173,186,.42); border-radius: 6px; font-size: .68rem; transition: border-color .2s, color .2s, background .2s; }
.outline-button span { color: #2dd6c0; }.outline-button:hover { color: #fff; border-color: #2dd6c0; background: rgba(45,214,192,.06); }
.custom-development { display: grid; grid-template-columns: minmax(0,1fr) minmax(0,1.25fr) auto; align-items: center; gap: 30px; min-width: 0; margin-top: 20px; padding: 20px 26px; border: 1px solid rgba(116,165,180,.32); border-radius: 13px; background: rgba(8,36,52,.72); }
.custom-title { display: flex; align-items: center; gap: 16px; }.custom-title h2 { margin: 0; font: 600 1.15rem var(--font-display); }.custom-title p { margin: 2px 0 0; color: #26d5c0; font-size: .74rem; }
.code-icon { display: grid; place-items: center; width: 50px; height: 50px; color: #2cd6c1; border: 1px solid #18a999; border-radius: 50%; font: 600 1rem var(--font-display); }
.custom-development > p { margin: 0; color: #becbd2; font-size: .76rem; line-height: 1.6; }
.proof-row { display: grid; grid-template-columns: repeat(5, 1fr); margin-top: 20px; }
.proof-row div { position: relative; display: flex; flex-direction: column; min-height: 48px; padding: 0 20px 0 46px; border-right: 1px solid rgba(130,173,186,.25); }.proof-row div:last-child { border: 0; }
.proof-row div::before { content: "✓"; position: absolute; left: 10px; top: 4px; display: grid; place-items: center; width: 23px; height: 23px; color: #23d2bd; border: 1px solid #23d2bd; border-radius: 50%; font-size: .65rem; }
.proof-row strong { color: #dce6ea; font-size: .71rem; }.proof-row span { color: #9db0b9; font-size: .65rem; line-height: 1.45; }

.hero { position: relative; min-height: 760px; overflow: hidden; color: #fff; background: var(--ink); }
.hero-grid { position: absolute; inset: 0; opacity: .15; background-image: linear-gradient(rgba(255,255,255,.08) 1px, transparent 1px), linear-gradient(90deg, rgba(255,255,255,.08) 1px, transparent 1px); background-size: 58px 58px; mask-image: linear-gradient(to bottom, black, transparent 90%); }
.hero-glow { position: absolute; border-radius: 50%; filter: blur(4px); }
.hero-glow-one { width: 540px; height: 540px; top: -200px; right: 5%; background: radial-gradient(circle, rgba(39,143,145,.18), transparent 68%); }
.hero-glow-two { width: 440px; height: 440px; bottom: -260px; left: 25%; background: radial-gradient(circle, rgba(35,122,153,.14), transparent 68%); }
.hero-layout { position: relative; display: grid; grid-template-columns: 1.04fr .96fr; align-items: center; gap: 70px; min-height: 760px; padding-top: 92px; }
.eyebrow { display: flex; align-items: center; gap: 10px; margin: 0 0 20px; color: var(--teal-light); font-size: .76rem; font-weight: 800; letter-spacing: .15em; text-transform: uppercase; }
.eyebrow span { width: 28px; height: 2px; background: currentColor; }
.eyebrow.dark { color: #078d78; }
.hero h1 { max-width: 700px; margin: 0; font: 700 clamp(3.3rem, 5.6vw, 5.8rem)/.99 var(--font-display); letter-spacing: -.055em; }
.hero h1 em { color: var(--teal-light); font-style: normal; }
.hero-lead { max-width: 640px; margin: 28px 0 32px; color: #b9c8d1; font-size: 1.08rem; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 12px; }
.button { display: inline-flex; align-items: center; justify-content: center; gap: 25px; min-height: 52px; padding: 0 24px; border: 1px solid transparent; border-radius: 5px; font-weight: 800; cursor: pointer; transition: transform .2s, background .2s, border-color .2s; }
.button:hover { transform: translateY(-2px); }
.button-primary { color: var(--ink); background: var(--teal-light); }
.button-primary:hover { background: #72efd6; }
.button-ghost { color: #fff; border-color: rgba(255,255,255,.28); }
.button-ghost:hover { border-color: #fff; background: rgba(255,255,255,.06); }
.hero-proof { display: flex; gap: 42px; margin-top: 52px; }
.hero-proof div { display: grid; grid-template-columns: auto 105px; align-items: center; gap: 10px; }
.hero-proof strong { font: 700 1.75rem var(--font-display); color: #fff; }
.hero-proof span { color: #93a8b4; font-size: .72rem; line-height: 1.45; }

.hero-visual { position: relative; }
.code-window { overflow: hidden; border: 1px solid rgba(255,255,255,.12); border-radius: 16px; background: rgba(14, 43, 58, .78); box-shadow: 0 45px 100px rgba(0,0,0,.38); transform: perspective(1200px) rotateY(-4deg) rotateX(2deg); backdrop-filter: blur(12px); }
.window-bar { display: flex; align-items: center; gap: 7px; height: 43px; padding: 0 15px; border-bottom: 1px solid rgba(255,255,255,.08); }
.window-bar > span { width: 8px; height: 8px; border-radius: 50%; background: #ee6f65; }
.window-bar > span:nth-child(2) { background: #eab64d; }
.window-bar > span:nth-child(3) { background: #4bc98c; }
.window-bar p { margin: 0 auto; padding-right: 38px; color: #78909e; font-size: .68rem; }
.dashboard { display: grid; grid-template-columns: 58px 1fr; min-height: 400px; }
.dash-sidebar { display: flex; flex-direction: column; align-items: center; gap: 28px; padding-top: 22px; border-right: 1px solid rgba(255,255,255,.07); }
.mini-logo { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 7px; color: var(--ink); background: var(--teal-light); font-weight: 900; }
.dash-sidebar i { width: 17px; height: 17px; border: 2px solid #516a78; border-radius: 4px; }
.dash-content { padding: 25px; }
.dash-head { display: flex; justify-content: space-between; align-items: center; color: #dfecef; font-size: .8rem; font-weight: 800; }
.dash-head b { padding: 5px 9px; color: var(--teal-light); background: rgba(73,226,195,.1); border-radius: 20px; font-size: .58rem; text-transform: uppercase; letter-spacing: .08em; }
.metric-row { display: grid; grid-template-columns: 1fr 1fr; gap: 13px; margin: 22px 0 14px; }
.metric-row div, .chart-card { padding: 18px; border: 1px solid rgba(255,255,255,.08); border-radius: 9px; background: rgba(255,255,255,.035); }
.metric-row small { display: block; color: #7f99a7; font-size: .62rem; }
.metric-row strong { margin-right: 8px; font: 700 1.6rem var(--font-display); }
.metric-row .up { color: var(--teal-light); font-size: .58rem; }
.chart-title { display: flex; justify-content: space-between; color: #dfecef; font-size: .72rem; font-weight: 700; }
.chart-title small { color: #78909e; font-weight: 500; }
.chart-card svg { width: 100%; margin-top: 15px; overflow: visible; }
.chart-card .area { fill: url(#chartFill); }
.chart-card .line { fill: none; stroke: var(--teal-light); stroke-width: 3; }
.chart-card circle { fill: var(--teal-light); }
.floating-card { position: absolute; display: flex; align-items: center; gap: 10px; padding: 12px 16px; border: 1px solid rgba(255,255,255,.15); border-radius: 9px; background: rgba(10,31,44,.92); box-shadow: 0 16px 30px rgba(0,0,0,.3); }
.floating-card > span { display: grid; place-items: center; width: 30px; height: 30px; border-radius: 50%; color: var(--ink); background: var(--teal-light); font-weight: 900; }
.floating-card div { display: flex; flex-direction: column; }
.floating-card b { font-size: .65rem; }
.floating-card small { color: #78909e; font-size: .55rem; }
.floating-card-one { right: -35px; bottom: 52px; }
.floating-card-two { left: -42px; top: 82px; }

.trust-strip { padding: 21px 0; border-bottom: 1px solid var(--line); background: #fff; }
.trust-content { display: flex; align-items: center; justify-content: space-between; gap: 30px; }
.trust-content p { margin: 0; color: var(--muted); font-size: .72rem; font-weight: 700; }
.trust-tags { display: flex; gap: 30px; color: #38505e; font-size: .69rem; font-weight: 800; text-transform: uppercase; letter-spacing: .06em; }
.section { padding: 115px 0; }
.section-heading { display: grid; grid-template-columns: 1.1fr .7fr; align-items: end; gap: 90px; margin-bottom: 54px; }
.section-heading h2, .about-copy h2, .center-heading h2, .contact-copy h2 { margin: 0; font: 700 clamp(2.4rem, 4vw, 4.2rem)/1.08 var(--font-display); letter-spacing: -.045em; }
.section-heading > p { margin: 0 0 7px; color: var(--muted); font-size: .96rem; }
.systems { background: #f3f6f6; }
.system-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 18px; }
.system-card { position: relative; min-height: 330px; padding: 34px; overflow: hidden; border: 1px solid #d8e1e2; border-top: 4px solid #1d667d; background: #fff; box-shadow: 0 8px 26px rgba(7,24,39,.05); transition: transform .25s, box-shadow .25s, border-color .25s; }
.system-card::after { content: ""; position: absolute; right: -70px; bottom: -100px; width: 190px; height: 190px; border: 1px solid rgba(39,143,145,.13); border-radius: 50%; box-shadow: 0 0 0 35px rgba(39,143,145,.025); }
.system-card:nth-child(2) { border-top-color: #376c86; }
.system-card:nth-child(3) { border-top-color: #527d55; }
.system-card:nth-child(4) { border-top-color: #536b82; }
.system-card:hover { z-index: 1; transform: translateY(-5px); border-color: #b7cacc; box-shadow: 0 18px 45px rgba(7,24,39,.11); }
.system-top { position: relative; z-index: 1; display: flex; align-items: center; justify-content: space-between; }
.system-code { color: #175c72; font: 700 1.55rem var(--font-display); letter-spacing: -.03em; }
.system-arrow { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid #cddadc; border-radius: 50%; color: #175c72; transition: color .2s, background .2s; }
.system-card:hover .system-arrow { color: #fff; background: #175c72; }
.system-type { margin: 28px 0 8px; color: #66808c; font-size: .66rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.system-card h3 { max-width: 420px; margin: 0 0 12px; font: 700 1.35rem var(--font-display); }
.system-card > p:not(.system-type) { max-width: 490px; margin: 0; color: var(--muted); font-size: .82rem; }
.system-features { position: absolute; z-index: 1; left: 34px; right: 34px; bottom: 30px; display: flex; flex-wrap: wrap; gap: 7px; }
.system-features span { padding: 5px 9px; color: #42616e; border: 1px solid #d8e2e3; border-radius: 3px; background: #f7f9f9; font-size: .6rem; font-weight: 700; }
.service-grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.service-card { position: relative; min-height: 355px; padding: 32px 28px; border-right: 1px solid var(--line); transition: color .28s, background .28s, transform .28s; }
.service-card:last-child { border-right: 0; }
.service-card:hover { z-index: 2; color: #fff; background: var(--ink-soft); transform: translateY(-8px); box-shadow: var(--shadow); }
.service-icon { display: grid; place-items: center; width: 48px; height: 48px; margin-bottom: 46px; border-radius: 9px; color: #078d78; background: #e8f8f5; }
.service-icon svg { width: 25px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.service-number { position: absolute; top: 26px; right: 26px; margin: 0; color: #aab7bd; font: 600 .75rem var(--font-display); }
.service-card h3 { margin: 0 0 15px; font: 700 1.2rem var(--font-display); }
.service-card > p:not(.service-number) { margin: 0; color: var(--muted); font-size: .84rem; line-height: 1.75; transition: color .28s; }
.service-card:hover > p:not(.service-number) { color: #a9bbc5; }
.card-link { position: absolute; left: 28px; bottom: 28px; color: #0a927d; font-size: .72rem; font-weight: 800; }
.service-card:hover .card-link { color: var(--teal-light); }
.card-link b { margin-left: 6px; }

.solutions { color: #fff; background: var(--ink); }
.section-heading.light > p { color: #9db0bb; }
.product-list { border-top: 1px solid rgba(255,255,255,.13); }
.product-card { display: grid; grid-template-columns: 135px 1fr 55px; align-items: center; gap: 34px; padding: 34px 20px; border-bottom: 1px solid rgba(255,255,255,.13); transition: background .25s, padding .25s; }
.product-card:hover { padding-left: 34px; background: rgba(255,255,255,.04); }
.product-tag { color: #76909e; font-size: .66rem; font-weight: 800; letter-spacing: .1em; text-transform: uppercase; }
.product-main { display: grid; grid-template-columns: 90px 1.05fr 1fr; align-items: center; gap: 35px; }
.product-code { color: var(--teal-light); font: 700 1.05rem var(--font-display); }
.product-main h3 { margin: 0; font: 600 1.25rem/1.35 var(--font-display); }
.product-main p { margin: 0; color: #91a5b0; font-size: .8rem; }
.product-arrow { display: grid; place-items: center; width: 44px; height: 44px; border: 1px solid rgba(255,255,255,.17); border-radius: 50%; transition: color .2s, background .2s; }
.product-card:hover .product-arrow { color: var(--ink); background: var(--teal-light); }

.about { background: var(--paper); }
.about-layout { display: grid; grid-template-columns: .86fr 1.14fr; gap: 95px; align-items: center; }
.about-visual { position: relative; min-height: 520px; overflow: hidden; background: linear-gradient(145deg, #0c3343, #071827); }
.about-visual::before { content: ""; position: absolute; width: 340px; height: 340px; top: -100px; right: -90px; border: 1px solid rgba(73,226,195,.23); border-radius: 50%; box-shadow: 0 0 0 70px rgba(73,226,195,.025), 0 0 0 140px rgba(73,226,195,.025); }
.about-panel { position: absolute; left: 45px; right: 45px; bottom: 45px; padding-top: 25px; color: #fff; border-top: 1px solid rgba(255,255,255,.2); }
.about-year { display: block; color: var(--teal-light); font: 700 6rem/.9 var(--font-display); letter-spacing: -.08em; }
.about-panel p { max-width: 330px; margin: 20px 0 0; color: #a8bbc4; font-size: .87rem; }
.about-lines { position: absolute; left: 45px; top: 50px; display: flex; gap: 9px; align-items: end; }
.about-lines i { width: 7px; height: 42px; background: var(--teal); }
.about-lines i:nth-child(2) { height: 65px; opacity: .65; }
.about-lines i:nth-child(3) { height: 30px; opacity: .4; }
.about-lines i:nth-child(4) { height: 53px; opacity: .25; }
.about-copy > p:not(.eyebrow) { color: var(--muted); font-size: .93rem; }
.values { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 36px; padding-top: 30px; border-top: 1px solid var(--line); }
.values span { display: block; margin-bottom: 12px; color: #0a927d; font: 700 .7rem var(--font-display); }
.values b { font: 700 .88rem var(--font-display); }
.values p { margin: 8px 0 0; color: var(--muted); font-size: .7rem; line-height: 1.55; }

.clients { background: #fff; }
.center-heading { max-width: 770px; margin: 0 auto 55px; text-align: center; }
.center-heading .eyebrow { justify-content: center; }
.center-heading > p:last-child { max-width: 610px; margin: 20px auto 0; color: var(--muted); font-size: .9rem; }
.logo-grid { display: grid; grid-template-columns: repeat(4, 1fr); border: 1px solid var(--line); }
.logo-grid a { display: grid; place-items: center; min-height: 135px; padding: 25px; border-right: 1px solid var(--line); border-bottom: 1px solid var(--line); filter: grayscale(1); opacity: .63; transition: filter .2s, opacity .2s, background .2s; }
.logo-grid a:nth-child(4n) { border-right: 0; }
.logo-grid a:nth-last-child(-n+4) { border-bottom: 0; }
.logo-grid a:hover { filter: none; opacity: 1; background: var(--paper); }
.logo-grid img { max-width: 150px; max-height: 65px; object-fit: contain; }

.contact { position: relative; overflow: hidden; padding: 105px 0; color: #fff; background: #0b2d3d; }
.contact::after { content: ""; position: absolute; width: 600px; height: 600px; right: -250px; bottom: -320px; border: 1px solid rgba(73,226,195,.16); border-radius: 50%; box-shadow: 0 0 0 80px rgba(73,226,195,.025), 0 0 0 160px rgba(73,226,195,.02); }
.contact-layout { position: relative; z-index: 1; display: grid; grid-template-columns: .85fr 1fr; gap: 105px; }
.contact-copy > p:not(.eyebrow) { max-width: 500px; color: #a9bbc5; font-size: .94rem; }
.contact-details { display: grid; gap: 18px; margin-top: 38px; }
.contact-details a { display: flex; align-items: center; gap: 14px; width: fit-content; }
.contact-details a > span { display: grid; place-items: center; width: 38px; height: 38px; border: 1px solid rgba(255,255,255,.15); border-radius: 50%; color: var(--teal-light); font-size: .78rem; }
.contact-details div { display: flex; flex-direction: column; }
.contact-details small { color: #728e9c; font-size: .6rem; text-transform: uppercase; letter-spacing: .08em; }
.contact-details b { font-size: .78rem; }
.contact-form { padding: 38px; color: var(--ink); background: #fff; box-shadow: 0 25px 70px rgba(0,0,0,.18); }
.form-row { margin-bottom: 19px; }
.form-row label { display: block; margin-bottom: 6px; font-size: .68rem; font-weight: 800; }
.form-row .optional { color: #89989f; font-weight: 500; }
.form-row input, .form-row textarea { width: 100%; padding: 12px 0; color: var(--ink); border: 0; border-bottom: 1px solid #cfdadc; border-radius: 0; outline: 0; resize: vertical; font-size: .82rem; transition: border-color .2s; }
.form-row input:focus, .form-row textarea:focus { border-color: var(--teal); }
.form-row input::placeholder, .form-row textarea::placeholder { color: #9caab1; }
.form-submit { width: 100%; margin-top: 5px; border: 0; }
.form-submit:disabled { cursor: wait; opacity: .65; }
.form-status { min-height: 22px; margin: 12px 0 -10px; font-size: .72rem; font-weight: 700; text-align: center; }
.form-status.error { color: #b42318; }
.form-status.success { color: #087b68; }

.footer { padding: 35px 0; color: #8096a1; background: #06131f; }
.footer-content { display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 20px; font-size: .68rem; }
.footer-brand { display: inline-flex; justify-self: start; width: fit-content; padding: 0; border-radius: 4px; background: transparent; }
.footer-brand img { width: 70px; height: 70px; object-fit: contain; }
.footer-content p { margin: 0; }
.footer-content p:last-child { text-align: right; }

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

@media (max-width: 1020px) {
  .showcase-intro { grid-template-columns: 1fr 1fr; gap: 30px; }
  .featured-systems { grid-template-columns: minmax(0,1fr); }
  .featured-body { grid-template-columns: minmax(0,1.15fr) minmax(0,.85fr); }
  .product-device { margin-right: 25px; }
  .custom-development { grid-template-columns: 1fr 1fr; }
  .custom-development .outline-button { grid-column: 1 / -1; justify-self: start; }
  .proof-row { grid-template-columns: repeat(3, 1fr); gap: 18px 0; }
  .proof-row div:nth-child(3) { border-right: 0; }
  .hero-layout { grid-template-columns: 1fr; padding-top: 150px; padding-bottom: 100px; }
  .hero-copy { max-width: 760px; }
  .hero-visual { max-width: 670px; margin: 0 auto; }
  .service-grid { grid-template-columns: 1fr 1fr; }
  .service-card:nth-child(2) { border-right: 0; }
  .service-card:nth-child(-n+2) { border-bottom: 1px solid var(--line); }
  .about-layout { gap: 55px; }
  .contact-layout { gap: 55px; }
}

@media (max-width: 800px) {
  .nav-toggle { display: block; }
  .main-nav { position: absolute; top: calc(100% + 10px); left: 20px; right: 20px; display: none; flex-direction: column; align-items: stretch; gap: 0; padding: 15px; background: #0c2a3a; box-shadow: var(--shadow); }
  .main-nav.open { display: flex; }
  .main-nav a { padding: 13px; }
  .main-nav .nav-cta { margin-top: 6px; text-align: center; }
  .systems-showcase { padding-top: 120px; }
  .showcase-intro { grid-template-columns: minmax(0,1fr); min-height: auto; }
  .showcase-copy { position: relative; z-index: 2; }
  .tech-map { min-height: 220px; opacity: .72; }
  .featured-body { grid-template-columns: minmax(0,1fr); }
  .featured-copy { position: relative; z-index: 2; }
  .product-device { width: min(280px, 80%); margin: 18px auto 10px; }
  .feature-row { grid-template-columns: 1fr 1fr; }
  .feature-row span:nth-child(2) { border-right: 0; }
  .custom-development { grid-template-columns: 1fr; }
  .custom-development .outline-button { grid-column: auto; }
  .proof-row { grid-template-columns: 1fr 1fr; }
  .proof-row div:nth-child(3) { border-right: 1px solid rgba(130,173,186,.25); }
  .proof-row div:nth-child(2n) { border-right: 0; }
  .hero h1 { font-size: clamp(3rem, 12vw, 5rem); }
  .trust-content, .section-heading { display: block; }
  .trust-tags { margin-top: 15px; overflow-x: auto; }
  .section-heading > p { max-width: 650px; margin-top: 20px; }
  .system-grid { grid-template-columns: 1fr; }
  .about-layout, .contact-layout { grid-template-columns: 1fr; }
  .about-visual { min-height: 410px; }
  .logo-grid { grid-template-columns: repeat(2, 1fr); }
  .logo-grid a:nth-child(2n) { border-right: 0; }
  .logo-grid a:nth-child(4n) { border-right: 0; }
  .logo-grid a:nth-last-child(-n+4) { border-bottom: 1px solid var(--line); }
  .logo-grid a:nth-last-child(-n+2) { border-bottom: 0; }
  .footer-content { grid-template-columns: 1fr; text-align: center; }
  .footer-brand { margin: auto; }
  .footer-content p:last-child { text-align: center; }
}

@media (max-width: 580px) {
  .container { width: min(100% - 28px, 1180px); }
  .section { padding: 80px 0; }
  .brand img { width: 145px; }
  .systems-showcase { padding: 108px 0 35px; }
  .showcase-copy { min-width: 0; }
  .showcase-copy h1 { font-size: 2.2rem; overflow-wrap: anywhere; }
  .showcase-copy > p:last-child { font-size: .9rem; }
  .showcase-copy > p, .featured-copy > p { max-width: 100%; overflow-wrap: anywhere; }
  .tech-map { min-height: 190px; transform: scale(.85); transform-origin: center top; margin-bottom: -25px; }
  .featured-system { padding: 22px 20px 18px; }
  .featured-copy { min-width: 0; }
  .product-heading { gap: 13px; }
  .product-icon { width: 54px; height: 54px; }
  .product-heading h2 { font-size: 1.75rem; }
  .featured-copy hr { margin-left: 67px; }
  .featured-body { min-height: auto; }
  .product-device { max-width: calc(100% - 12px); }
  .laptop-device { width: min(260px, calc(100% - 58px)); }
  .tablet-device { width: min(265px, calc(100% - 24px)); }
  .feature-row { margin: 18px -20px; padding: 12px 10px; }
  .feature-row span { padding-left: 27px; font-size: .61rem; }
  .custom-development { padding: 20px; }
  .custom-title { align-items: flex-start; }
  .proof-row { grid-template-columns: 1fr; gap: 0; }
  .proof-row div, .proof-row div:nth-child(3) { min-height: 62px; padding-top: 9px; border-right: 0; border-bottom: 1px solid rgba(130,173,186,.2); }
  .proof-row div::before { top: 13px; }
  .proof-row div:last-child { border-bottom: 0; }
  .hero-layout { min-height: auto; padding-top: 130px; padding-bottom: 80px; }
  .hero h1 { font-size: 2.85rem; }
  .hero-lead { font-size: .94rem; }
  .hero-actions { display: grid; }
  .hero-proof { gap: 20px; }
  .hero-proof div { display: block; }
  .hero-proof span { display: block; max-width: 120px; margin-top: 5px; }
  .hero-visual { display: none; }
  .trust-tags { gap: 20px; }
  .section-heading h2, .about-copy h2, .center-heading h2, .contact-copy h2 { font-size: 2.35rem; }
  .service-grid { grid-template-columns: 1fr; }
  .service-card { border-right: 0; border-bottom: 1px solid var(--line); }
  .service-card:nth-child(2) { border-right: 0; }
  .service-card:last-child { border-bottom: 0; }
  .system-card { min-height: 350px; padding: 27px; }
  .system-features { left: 27px; right: 27px; bottom: 26px; }
  .about-year { font-size: 4.8rem; }
  .about-panel { left: 28px; right: 28px; bottom: 28px; }
  .values { grid-template-columns: 1fr; }
  .values div { display: grid; grid-template-columns: 30px 1fr; }
  .values span { grid-row: 1 / span 2; }
  .values p { margin-top: 3px; }
  .logo-grid a { min-height: 105px; padding: 18px; }
  .contact { padding: 80px 0; }
  .contact-form { padding: 28px 22px; }
}

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

/* Light systems showcase */
.site-header {
  padding: 17px 0;
  background: rgba(255,255,255,.96);
  border-bottom: 1px solid #edf1f2;
  backdrop-filter: blur(14px);
}
.site-header.scrolled {
  padding: 10px 0;
  background: rgba(255,255,255,.97);
  box-shadow: 0 8px 28px rgba(16,48,64,.09);
}
.brand img { filter: none; }
.main-nav > a { color: #142638; }
.main-nav > a:hover,
.main-nav > a.active { color: #07998d; }
.nav-toggle span:not(.sr-only) { background: var(--ink); }

.systems-showcase {
  min-height: 0;
  padding: 132px 0 54px;
  color: var(--ink);
  background: radial-gradient(circle at 80% 13%, rgba(31,184,169,.08), transparent 26%), linear-gradient(180deg, #fff, #fbfdfd);
}
.showcase-grid {
  inset: 105px 0 auto 43%;
  height: 300px;
  opacity: .3;
  background-image: radial-gradient(circle, #7cd9ce 1px, transparent 1.5px);
}
.showcase-copy h1 { color: #09243a; }
.showcase-copy h1 em { color: #18ac9d; font-style: normal; }
.showcase-copy > p:last-child { color: #5d6c78; }
.systems-showcase .eyebrow { color: #07998d; }
.tech-map {
  display: flex;
  align-items: center;
  justify-content: center;
}
.hero-systems-image {
  position: relative;
  z-index: 2;
  width: min(720px, 115%);
  max-width: none;
  height: auto;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 18px 25px rgba(17,61,75,.06));
}

.map-window {
  width: 330px;
  height: 220px;
  top: 0;
  border: 9px solid #303a3f;
  border-bottom-width: 16px;
  border-radius: 12px 12px 5px 5px;
  background: #fff;
  box-shadow: 0 15px 24px rgba(20,54,69,.18);
}
.map-window::after {
  content: "";
  position: absolute;
  left: -35px;
  right: -35px;
  bottom: -25px;
  height: 10px;
  border-radius: 2px 2px 8px 8px;
  background: linear-gradient(#aeb6ba,#697277);
}
.map-widgets span,
.map-chart {
  border-color: #e1e8e9;
  background: linear-gradient(135deg, #f5faf9, #fff);
}
.map-node {
  border-color: #dbe9e8;
  color: #17ae9e;
  background: rgba(255,255,255,.94);
  box-shadow: 0 8px 22px rgba(15,84,89,.09);
}

.featured-systems {
  grid-template-columns: repeat(3, minmax(0, 1fr));
}
.featured-system {
  padding: 24px 22px 20px;
  border-color: #dfe8e9;
  border-radius: 12px;
  background: #fff;
  box-shadow: 0 12px 32px rgba(20,54,69,.09);
}
.featured-body {
  position: relative;
  display: block;
  min-height: 255px;
}
.featured-copy {
  position: relative;
  z-index: 2;
  width: 100%;
}
.product-heading { gap: 14px; }
.product-icon {
  width: 58px;
  height: 58px;
  color: #fff;
}
.product-heading h2 {
  color: #0b263d;
  font-size: 1.65rem;
}
.product-heading p {
  color: #069d90;
  font-size: .72rem;
}
.featured-copy hr {
  width: 100%;
  margin: 12px 0 18px;
  border-color: #e4ebec;
}
.featured-copy h3 { color: #122b40; }
.featured-copy > p {
  max-width: 45%;
  color: #536572;
  font-size: .75rem;
}
.product-device {
  position: absolute;
  right: -18px;
  bottom: 0;
  width: 62%;
  height: 190px;
  margin: 0;
  filter: none;
}
.system-product-image {
  width: 100%;
  height: 100%;
  object-fit: contain;
  object-position: center bottom;
  mix-blend-mode: multiply;
  filter: drop-shadow(0 12px 14px rgba(17,61,75,.08));
}
.sigis-product-device {
  right: -24px;
  width: 68%;
}
.sires-product-device {
  right: -12px;
  width: 60%;
}
.laptop-device { width: 185px; }
.laptop-device .device-screen { height: 102px; }
.tablet-device { width: 175px; }
.restaurant-screen { height: 108px; }
.restaurant-grid i { height: 19px; }
.feature-row {
  margin: 12px -22px 18px;
  padding: 15px 12px;
  border-color: #e4ebec;
}
.feature-row span {
  padding: 0 7px 0 25px;
  color: #405460;
  border-color: #e1e8e9;
  font-size: .54rem;
}
.outline-button {
  color: #087f76;
  border-color: #72c9c1;
  font-weight: 700;
}
.outline-button span { color: #07998d; }
.outline-button:hover {
  color: #05675f;
  border-color: #07998d;
  background: #f0fbfa;
}
.code-product-icon { font: 700 1.1rem var(--font-display); }
.custom-card .featured-copy { width: 100%; }
.custom-card .featured-copy h3,
.custom-card .featured-copy > p { max-width: 58%; }
.custom-product-device {
  right: -12px;
  width: 58%;
  height: 185px;
}
.puzzle-visual {
  position: absolute;
  right: 5px;
  bottom: 24px;
  width: 125px;
  height: 120px;
}
.puzzle-visual i {
  position: absolute;
  width: 52px;
  height: 52px;
  border-radius: 9px 16px 9px 16px;
  background: #50bfb4;
}
.puzzle-visual i:nth-child(1) { left: 0; top: 45px; background: #b4ddd8; }
.puzzle-visual i:nth-child(2) { left: 40px; top: 45px; background: #76c9c0; }
.puzzle-visual i:nth-child(3) { left: 76px; top: 45px; background: #16a99c; }
.puzzle-visual i:nth-child(4) { left: 40px; top: 5px; background: #d1ebe8; }
.puzzle-visual i:nth-child(5) { left: 76px; top: 5px; border: 1px solid #cde7e4; background: #eff8f7; }
.proof-row {
  margin-top: 38px;
  padding: 24px 18px;
  border-radius: 10px;
  background: #f3f8f8;
}
.proof-row div { border-color: #cfdddd; }
.proof-row strong { color: #132a3d; }
.proof-row span { color: #5c6d78; }

@media (max-width: 1100px) {
  .featured-systems { grid-template-columns: 1fr 1fr; }
  .custom-card { grid-column: 1 / -1; }
  .custom-card .featured-copy { width: 55%; }
}

@media (max-width: 800px) {
  .main-nav { background: #fff; box-shadow: 0 16px 35px rgba(16,48,64,.15); }
  .systems-showcase { padding-top: 118px; }
  .hero-systems-image { width: min(680px, 110%); }
  .featured-systems { grid-template-columns: 1fr; }
  .custom-card { grid-column: auto; }
  .featured-body { min-height: 360px; }
  .featured-copy,
  .custom-card .featured-copy { width: 100%; }
  .featured-copy h3,
  .featured-copy > p,
  .custom-card .featured-copy h3,
  .custom-card .featured-copy > p { max-width: 100%; }
  .product-device { position: relative; right: auto; bottom: auto; margin: 35px auto 5px; }
  .product-device,
  .custom-product-device { width: min(330px, 100%); height: 210px; }
}

@media (max-width: 580px) {
  .systems-showcase { padding-top: 105px; }
  .showcase-copy h1 { font-size: 2.25rem; }
  .tech-map { min-height: auto; margin: 8px -35px 0; opacity: 1; transform: none; }
  .hero-systems-image { width: 100%; max-width: 100%; }
  .map-window { width: 280px; height: 195px; }
  .featured-body { min-height: 345px; }
  .feature-row { grid-template-columns: 1fr 1fr; }
}
