:root {
  --bg: #061425;
  --bg-deep: #03101d;
  --surface: #0c1d30;
  --surface-2: #11263d;
  --surface-3: #172e48;
  --text: #e7f1ff;
  --muted: #9dafc5;
  --muted-2: #7489a4;
  --line: rgba(176, 209, 255, 0.12);
  --line-strong: rgba(122, 195, 255, 0.28);
  --blue: #3b82f6;
  --blue-light: #7bc9ff;
  --cyan: #80e4ff;
  --green: #36d6a0;
  --warning: #f2c56d;
  --danger: #ff8a9b;
  --shadow: 0 26px 80px rgba(0, 0, 0, 0.32);
  --radius-sm: 8px;
  --radius: 14px;
  --radius-lg: 22px;
  --container: 1280px;
  --header-h: 76px;
  --font-display: "Geist", "Aptos Display", "Segoe UI", system-ui, sans-serif;
  --font-body: "Inter", "Aptos", "Segoe UI", system-ui, sans-serif;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; scroll-padding-top: calc(var(--header-h) + 18px); }
body { margin: 0; min-width: 320px; background: var(--bg); color: var(--text); font-family: var(--font-body); font-size: 16px; line-height: 1.6; overflow-x: hidden; }
body.menu-open { overflow: hidden; }
button, input, textarea { font: inherit; }
a { color: inherit; text-decoration: none; }
img, svg { display: block; max-width: 100%; }
ul { margin: 0; padding: 0; list-style: none; }
h1, h2, h3, p { margin-top: 0; }
button, a { -webkit-tap-highlight-color: transparent; }
::selection { background: var(--blue); color: #fff; }
:focus-visible { outline: 3px solid rgba(123, 201, 255, .72); outline-offset: 3px; }

.svg-sprite { position: absolute; width: 0; height: 0; overflow: hidden; }
.svg-sprite symbol { fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.skip-link { position: fixed; left: 16px; top: -80px; z-index: 1000; padding: 10px 14px; border-radius: 8px; background: #fff; color: #051424; font-weight: 700; transition: top .2s ease; }
.skip-link:focus { top: 12px; }
.container { width: min(calc(100% - 48px), var(--container)); margin-inline: auto; }
.section { position: relative; padding: 116px 0; }
.kicker { display: inline-block; margin-bottom: 14px; color: var(--blue-light); font-family: var(--font-display); font-size: .75rem; font-weight: 750; letter-spacing: .15em; text-transform: uppercase; }
.section-heading { margin-bottom: 50px; }
.section-heading.center { max-width: 760px; margin-inline: auto; margin-bottom: 50px; text-align: center; }
.section-heading.split { display: flex; align-items: end; justify-content: space-between; gap: 32px; }
.section-heading.split > div:first-child { max-width: 760px; }
.section-heading h2, .about-copy h2, .contact-copy h2 { margin-bottom: 18px; font-family: var(--font-display); font-size: clamp(2rem, 4vw, 3.2rem); line-height: 1.08; letter-spacing: -.035em; }
.section-heading p, .about-copy > p, .contact-copy > p { max-width: 680px; margin-bottom: 0; color: var(--muted); font-size: 1.05rem; }

.site-header { position: fixed; inset: 0 0 auto; z-index: 100; height: var(--header-h); border-bottom: 1px solid transparent; background: rgba(3, 16, 29, .55); backdrop-filter: blur(18px); transition: background .25s ease, border-color .25s ease, box-shadow .25s ease; }
.site-header.scrolled { border-color: var(--line); background: rgba(3, 16, 29, .9); box-shadow: 0 10px 34px rgba(0, 0, 0, .18); }
.header-inner { height: 100%; display: grid; grid-template-columns: 1fr auto 1fr; align-items: center; gap: 28px; }
.brand { display: inline-flex; align-items: center; gap: 10px; width: fit-content; font-family: var(--font-display); font-weight: 650; letter-spacing: -.025em; }
.brand strong { font-weight: 760; }
.brand-mark { display: grid; place-items: center; width: 30px; height: 30px; border: 1px solid rgba(123, 201, 255, .32); border-radius: 9px; background: linear-gradient(145deg, rgba(59, 130, 246, .22), rgba(59, 130, 246, .05)); color: var(--blue-light); box-shadow: inset 0 0 20px rgba(59, 130, 246, .12); }
.brand-mark svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.primary-nav { display: flex; align-items: center; gap: 30px; }
.primary-nav a { position: relative; padding: 10px 0; color: var(--muted); font-family: var(--font-display); font-size: .82rem; font-weight: 650; }
.primary-nav a::after { content: ""; position: absolute; left: 0; right: 0; bottom: 2px; height: 2px; border-radius: 2px; background: var(--blue-light); transform: scaleX(0); transition: transform .2s ease; }
.primary-nav a:hover, .primary-nav a.active { color: var(--text); }
.primary-nav a.active::after { transform: scaleX(1); }
.header-cta { justify-self: end; }
.menu-toggle { display: none; border: 0; background: transparent; color: var(--text); cursor: pointer; }
.menu-toggle svg { width: 24px; height: 24px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; }
.close-icon { display: none; }
.menu-toggle[aria-expanded="true"] .menu-icon { display: none; }
.menu-toggle[aria-expanded="true"] .close-icon { display: block; }

.button { display: inline-flex; min-height: 50px; align-items: center; justify-content: center; gap: 10px; padding: 13px 22px; border: 1px solid var(--blue); border-radius: 11px; background: linear-gradient(180deg, #4a91ff, #3478e9); color: #fff; font-family: var(--font-display); font-size: .92rem; font-weight: 730; line-height: 1; box-shadow: 0 10px 28px rgba(59, 130, 246, .28), inset 0 1px 0 rgba(255, 255, 255, .25); cursor: pointer; transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease, background .2s ease; }
.button:hover { transform: translateY(-2px); box-shadow: 0 15px 34px rgba(59, 130, 246, .36), inset 0 1px 0 rgba(255, 255, 255, .28); }
.button svg, .text-link svg, .footer-bottom a svg { width: 18px; height: 18px; fill: none; stroke: currentColor; stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.button-small { min-height: 40px; padding: 10px 17px; font-size: .78rem; border-radius: 9px; }
.button-secondary { border-color: rgba(255, 255, 255, .2); background: rgba(255, 255, 255, .045); box-shadow: inset 0 1px 0 rgba(255, 255, 255, .06); color: var(--text); }
.button-secondary:hover { border-color: var(--line-strong); background: rgba(255, 255, 255, .075); box-shadow: inset 0 1px 0 rgba(255, 255, 255, .09); }

.hero { position: relative; min-height: 880px; padding: calc(var(--header-h) + 76px) 0 82px; overflow: hidden; background: radial-gradient(circle at 76% 40%, rgba(20, 109, 190, .22), transparent 38%), linear-gradient(115deg, #061425 0%, #061425 45%, #071828 100%); }
.hero::before { content: ""; position: absolute; inset: 0; background: linear-gradient(90deg, rgba(3, 16, 29, .32), transparent 35%, transparent 78%, rgba(3, 16, 29, .45)); pointer-events: none; }
.hero-grid { position: absolute; inset: 0; opacity: .2; background-image: linear-gradient(rgba(123, 201, 255, .07) 1px, transparent 1px), linear-gradient(90deg, rgba(123, 201, 255, .07) 1px, transparent 1px); background-size: 70px 70px; mask-image: radial-gradient(circle at 72% 44%, #000, transparent 62%); }
.hero-layout { position: relative; z-index: 1; display: grid; grid-template-columns: minmax(0, .92fr) minmax(480px, 1.08fr); align-items: center; gap: 36px; min-height: 700px; }
.hero-copy { max-width: 680px; }
.eyebrow { display: inline-flex; align-items: center; gap: 10px; margin-bottom: 24px; padding: 7px 11px; border: 1px solid rgba(123, 201, 255, .3); border-radius: 999px; background: rgba(59, 130, 246, .08); color: var(--blue-light); font-family: var(--font-display); font-size: .7rem; font-weight: 750; letter-spacing: .14em; text-transform: uppercase; }
.status-dot { width: 7px; height: 7px; flex: 0 0 auto; border-radius: 50%; background: var(--green); box-shadow: 0 0 0 5px rgba(54, 214, 160, .1), 0 0 14px rgba(54, 214, 160, .65); }
.hero h1 { max-width: 780px; margin-bottom: 24px; font-family: var(--font-display); font-size: clamp(3rem, 5.6vw, 5.75rem); line-height: .98; letter-spacing: -.055em; }
.hero h1 span { display: block; color: var(--blue-light); text-shadow: 0 0 34px rgba(59, 130, 246, .25); }
.hero-copy > p { max-width: 620px; margin-bottom: 34px; color: var(--muted); font-size: 1.08rem; line-height: 1.75; }
.hero-actions { display: flex; flex-wrap: wrap; gap: 14px; }
.hero-proof { display: flex; flex-wrap: wrap; gap: 18px 26px; margin-top: 30px; color: var(--muted); font-size: .78rem; }
.hero-proof span { display: inline-flex; align-items: center; gap: 7px; }
.hero-proof svg { width: 16px; height: 16px; fill: none; stroke: var(--green); stroke-width: 2; stroke-linecap: round; stroke-linejoin: round; }

.hero-visual { position: relative; justify-self: end; width: min(100%, 680px); aspect-ratio: 1; filter: drop-shadow(0 45px 60px rgba(0, 0, 0, .4)); }
.hero-visual::before { content: ""; position: absolute; inset: 12%; border-radius: 50%; background: radial-gradient(circle, rgba(85, 187, 255, .2), rgba(59, 130, 246, .06) 42%, transparent 66%); filter: blur(20px); }
.core-lines { position: absolute; inset: 0; width: 100%; height: 100%; }
.spin-slow, .spin-medium, .spin-reverse { transform-origin: 320px 320px; }
.spin-slow { animation: spin 38s linear infinite; }
.spin-medium { animation: spin 24s linear infinite; }
.spin-reverse { animation: spin-reverse 31s linear infinite; }
.core-orbit { position: absolute; border-radius: 50%; border: 1px solid rgba(123, 201, 255, .16); }
.orbit-one { inset: 6%; border-style: dashed; animation: spin 48s linear infinite; }
.orbit-two { inset: 22%; border-color: rgba(123, 201, 255, .28); border-top-color: var(--blue-light); animation: spin-reverse 20s linear infinite; }
.orbit-three { inset: 35%; border-width: 2px; border-color: rgba(123, 201, 255, .38); box-shadow: 0 0 28px rgba(59, 130, 246, .18), inset 0 0 25px rgba(59, 130, 246, .12); }
.core-center { position: absolute; inset: 39%; display: grid; place-items: center; align-content: center; border: 1px solid rgba(123, 201, 255, .42); border-radius: 50%; background: radial-gradient(circle at 35% 30%, rgba(82, 176, 255, .28), rgba(5, 20, 36, .94) 62%); box-shadow: 0 0 55px rgba(59, 130, 246, .25), inset 0 0 30px rgba(123, 201, 255, .12); }
.core-center svg { width: 30px; height: 30px; margin-bottom: 5px; fill: none; stroke: var(--blue-light); stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.core-center strong { font-family: var(--font-display); font-size: clamp(.7rem, 1.4vw, 1rem); letter-spacing: .13em; }
.core-center span { color: var(--muted); font-size: .48rem; letter-spacing: .28em; }
.data-tag { position: absolute; display: flex; align-items: center; gap: 7px; padding: 7px 9px; border: 1px solid rgba(123, 201, 255, .18); border-radius: 6px; background: rgba(5, 20, 36, .78); backdrop-filter: blur(8px); color: #a8bad0; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .58rem; letter-spacing: .08em; box-shadow: 0 10px 26px rgba(0, 0, 0, .2); }
.data-tag span { width: 5px; height: 5px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); }
.tag-one { left: 5%; top: 29%; }
.tag-two { right: 2%; top: 42%; }
.tag-three { left: 15%; bottom: 17%; }
@keyframes spin { to { transform: rotate(360deg); } }
@keyframes spin-reverse { to { transform: rotate(-360deg); } }

.capability-strip { position: relative; z-index: 2; border-block: 1px solid var(--line); background: rgba(8, 27, 45, .92); }
.capability-grid { display: grid; grid-template-columns: repeat(4, 1fr); }
.capability-grid > div { display: grid; grid-template-columns: 36px auto; grid-template-rows: auto auto; align-items: center; padding: 25px 24px; border-right: 1px solid var(--line); }
.capability-grid > div:first-child { border-left: 1px solid var(--line); }
.capability-grid svg { grid-row: 1 / 3; width: 22px; height: 22px; fill: none; stroke: var(--blue-light); stroke-width: 1.6; stroke-linecap: round; stroke-linejoin: round; }
.capability-grid span { font-family: var(--font-display); font-size: .75rem; font-weight: 750; letter-spacing: .1em; text-transform: uppercase; }
.capability-grid small { color: var(--muted-2); font-size: .69rem; }

.operations { background: linear-gradient(180deg, var(--bg) 0%, #07182a 100%); }
.operations-shell { position: relative; display: grid; grid-template-columns: minmax(0, 2fr) minmax(280px, .75fr); gap: 32px; padding: 28px; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); background: linear-gradient(145deg, rgba(16, 39, 64, .8), rgba(7, 24, 42, .7)); box-shadow: var(--shadow), inset 0 1px 0 rgba(255, 255, 255, .04); overflow: hidden; }
.operations-shell::before { content: ""; position: absolute; left: 10%; right: 10%; top: 0; height: 1px; background: linear-gradient(90deg, transparent, var(--blue-light), transparent); box-shadow: 0 0 12px var(--blue); }
.dashboard-window { min-width: 0; overflow: hidden; border: 1px solid rgba(168, 204, 255, .12); border-radius: 14px; background: #071524; box-shadow: 0 18px 45px rgba(0, 0, 0, .3); }
.dashboard-topbar { height: 52px; display: grid; grid-template-columns: 1fr minmax(180px, 280px) auto; align-items: center; gap: 18px; padding: 0 16px; border-bottom: 1px solid var(--line); background: #0b1b2d; }
.dashboard-brand { display: flex; align-items: center; gap: 8px; color: #d9e9ff; font-size: .65rem; font-weight: 700; }
.dashboard-brand span { width: 16px; height: 16px; border: 1px solid var(--blue-light); border-radius: 5px; background: rgba(59, 130, 246, .15); }
.dashboard-search { overflow: hidden; padding: 7px 12px; border: 1px solid var(--line); border-radius: 6px; color: #657b96; background: #071524; font-size: .55rem; white-space: nowrap; text-overflow: ellipsis; }
.dashboard-user { display: grid; place-items: center; width: 28px; height: 28px; border-radius: 8px; background: #17324f; color: #a9c8e9; font-size: .55rem; font-weight: 700; }
.dashboard-body { min-height: 425px; display: grid; grid-template-columns: 54px minmax(0, 1fr); }
.dashboard-sidebar { display: flex; flex-direction: column; align-items: center; gap: 16px; padding-top: 23px; border-right: 1px solid var(--line); background: #081827; }
.dashboard-sidebar i { width: 18px; height: 18px; border: 1px solid rgba(139, 177, 223, .16); border-radius: 5px; background: rgba(139, 177, 223, .06); }
.dashboard-sidebar i.active { border-color: rgba(59, 130, 246, .6); background: rgba(59, 130, 246, .28); box-shadow: 0 0 12px rgba(59, 130, 246, .22); }
.dashboard-content { min-width: 0; padding: 22px; }
.dashboard-heading { display: flex; align-items: end; justify-content: space-between; margin-bottom: 17px; }
.dashboard-heading small { display: block; margin-bottom: 2px; color: #5f7590; font-size: .48rem; font-weight: 700; letter-spacing: .1em; }
.dashboard-heading strong { font-family: var(--font-display); font-size: .9rem; }
.live { display: inline-flex; align-items: center; gap: 6px; color: var(--green); font-size: .5rem; font-weight: 700; }
.live b { width: 5px; height: 5px; border-radius: 50%; background: var(--green); box-shadow: 0 0 7px var(--green); }
.metric-grid { display: grid; grid-template-columns: repeat(4, 1fr); gap: 10px; margin-bottom: 12px; }
.metric-grid article { min-width: 0; padding: 13px; border: 1px solid var(--line); border-radius: 8px; background: rgba(17, 38, 61, .72); }
.metric-grid small { display: block; overflow: hidden; margin-bottom: 7px; color: #6f859f; font-size: .5rem; white-space: nowrap; text-overflow: ellipsis; }
.metric-grid strong { display: block; overflow: hidden; margin-bottom: 5px; color: #e7f1ff; font-family: var(--font-display); font-size: .83rem; font-variant-numeric: tabular-nums; white-space: nowrap; text-overflow: ellipsis; }
.metric-grid em { color: var(--green); font-size: .48rem; font-style: normal; }
.metric-grid em.warning { color: var(--warning); }
.dashboard-lower { display: grid; grid-template-columns: 1.7fr .85fr; gap: 12px; }
.chart-panel, .activity-panel { min-width: 0; border: 1px solid var(--line); border-radius: 8px; background: rgba(11, 29, 48, .74); overflow: hidden; }
.panel-title { display: flex; justify-content: space-between; padding: 13px 14px 2px; font-size: .57rem; font-weight: 650; }
.panel-title small { color: #66809d; font-size: .49rem; }
.chart-panel svg { width: 100%; height: 170px; }
.chart-grid path { fill: none; stroke: rgba(158, 196, 240, .08); stroke-width: 1; }
.chart-area { fill: url(#chartFill); }
.chart-line { fill: none; stroke: #55b8ff; stroke-width: 3; vector-effect: non-scaling-stroke; filter: drop-shadow(0 0 5px rgba(85, 184, 255, .55)); }
.activity-panel ul { padding: 5px 13px 12px; }
.activity-panel li { display: flex; justify-content: space-between; gap: 8px; padding: 10px 0; border-bottom: 1px solid rgba(160, 198, 240, .08); font-size: .48rem; }
.activity-panel li:last-child { border: 0; }
.activity-panel b { color: #a7bdd4; font-weight: 550; }
.activity-panel span { color: #637d99; text-align: right; }
.operations-benefits { display: flex; flex-direction: column; justify-content: center; gap: 10px; }
.operations-benefits article { display: flex; gap: 15px; padding: 18px 10px; border-bottom: 1px solid var(--line); }
.operations-benefits article:last-child { border-bottom: 0; }
.feature-icon { display: grid; flex: 0 0 auto; place-items: center; width: 46px; height: 46px; border: 1px solid rgba(123, 201, 255, .15); border-radius: 11px; background: linear-gradient(145deg, rgba(59, 130, 246, .18), rgba(59, 130, 246, .05)); color: var(--blue-light); box-shadow: inset 0 1px 0 rgba(255, 255, 255, .05); }
.feature-icon svg { width: 22px; height: 22px; fill: none; stroke: currentColor; stroke-width: 1.7; stroke-linecap: round; stroke-linejoin: round; }
.operations-benefits h3 { margin-bottom: 6px; font-family: var(--font-display); font-size: 1rem; }
.operations-benefits p { margin-bottom: 0; color: var(--muted); font-size: .8rem; line-height: 1.6; }

.solutions { border-block: 1px solid rgba(168, 204, 255, .06); background: var(--bg-deep); }
.chips { display: flex; flex-wrap: wrap; justify-content: flex-end; gap: 10px; }
.chips span { padding: 9px 13px; border: 1px solid var(--line); border-radius: 8px; background: var(--surface); color: var(--muted); font-size: .72rem; font-weight: 650; }
.bento-grid { display: grid; grid-template-columns: repeat(12, 1fr); gap: 20px; }
.bento-card { position: relative; min-height: 260px; padding: 27px; border: 1px solid var(--line); border-radius: var(--radius); background: linear-gradient(145deg, rgba(17, 38, 61, .86), rgba(9, 28, 47, .82)); overflow: hidden; box-shadow: inset 0 1px 0 rgba(255, 255, 255, .035); transition: transform .25s ease, border-color .25s ease, background .25s ease; }
.bento-card::after { content: ""; position: absolute; width: 230px; height: 230px; left: var(--mouse-x, 50%); top: var(--mouse-y, 50%); border-radius: 50%; background: radial-gradient(circle, rgba(59, 130, 246, .14), transparent 68%); transform: translate(-50%, -50%); pointer-events: none; opacity: 0; transition: opacity .25s ease; }
.bento-card:hover { transform: translateY(-4px); border-color: var(--line-strong); background: linear-gradient(145deg, rgba(20, 44, 71, .92), rgba(10, 31, 52, .88)); }
.bento-card:hover::after { opacity: 1; }
.bento-card > * { position: relative; z-index: 1; }
.card-top { display: flex; align-items: center; justify-content: space-between; margin-bottom: 24px; }
.card-index { color: rgba(149, 181, 218, .28); font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .7rem; }
.bento-card h3 { margin-bottom: 10px; font-family: var(--font-display); font-size: 1.35rem; letter-spacing: -.02em; }
.bento-card > p { max-width: 640px; margin-bottom: 22px; color: var(--muted); font-size: .85rem; }
.client-zone { grid-column: span 7; min-height: 430px; padding-right: min(42%, 340px); }
.crm-card { grid-column: span 5; }
.integrations-card { grid-column: span 4; }
.reporting-card { grid-column: span 4; }
.infrastructure-card { grid-column: span 4; }
.check-list { display: grid; gap: 10px; margin-bottom: 25px; color: #cad9ec; font-size: .78rem; }
.check-list li { display: flex; align-items: center; gap: 9px; }
.check-list svg { width: 17px; height: 17px; fill: none; stroke: var(--blue-light); stroke-width: 1.8; stroke-linecap: round; stroke-linejoin: round; }
.text-link { display: inline-flex; align-items: center; gap: 8px; color: var(--blue-light); font-size: .76rem; font-weight: 700; }
.text-link:hover svg { transform: translateX(4px); }
.text-link svg { transition: transform .2s ease; }
.portal-preview { position: absolute; right: 25px; bottom: -52px; width: min(37%, 300px); height: 360px; padding: 22px 18px; border: 1px solid rgba(123, 201, 255, .23); border-radius: 28px 28px 0 0; background: linear-gradient(180deg, #0c2138, #071725); box-shadow: 0 20px 55px rgba(0, 0, 0, .35), inset 0 1px 0 rgba(255, 255, 255, .07); transform: rotate(2deg); }
.phone-bar { width: 38%; height: 5px; margin: 0 auto 30px; border-radius: 9px; background: rgba(174, 209, 249, .15); }
.portal-balance { padding: 18px; border: 1px solid var(--line); border-radius: 13px; background: rgba(59, 130, 246, .08); }
.portal-balance small { display: block; margin-bottom: 5px; color: #6d85a2; font-size: .52rem; }
.portal-balance strong { font-family: var(--font-display); font-size: 1.2rem; font-variant-numeric: tabular-nums; }
.portal-actions { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin: 12px 0; }
.portal-actions i { height: 45px; border: 1px solid var(--line); border-radius: 10px; background: rgba(123, 201, 255, .05); }
.portal-chart { position: relative; height: 95px; border: 1px solid var(--line); border-radius: 11px; background: linear-gradient(180deg, rgba(59, 130, 246, .08), transparent); overflow: hidden; }
.portal-chart::before, .portal-chart::after { content: ""; position: absolute; inset: 24px -10px auto; height: 2px; background: var(--blue-light); transform: rotate(-8deg); box-shadow: 42px 15px 0 #4b8fff, 96px -4px 0 var(--blue-light); }
.status-row { display: flex; justify-content: space-between; margin-top: 45px; color: var(--muted); font-size: .65rem; text-transform: uppercase; letter-spacing: .08em; }
.status-row strong { color: var(--blue-light); font-size: .6rem; }
.progress { height: 3px; margin-top: 9px; border-radius: 3px; background: rgba(255, 255, 255, .06); overflow: hidden; }
.progress span { display: block; width: 82%; height: 100%; background: linear-gradient(90deg, var(--blue), var(--cyan)); box-shadow: 0 0 10px var(--blue); }
.integration-grid { display: grid; grid-template-columns: repeat(2, 1fr); gap: 9px; }
.integration-grid span { display: grid; place-items: center; min-height: 42px; border: 1px solid var(--line); border-radius: 7px; background: rgba(255, 255, 255, .035); color: #b9c9dc; font-family: var(--font-display); font-size: .7rem; font-weight: 650; }
.mini-bars { display: flex; align-items: end; gap: 7px; height: 72px; padding-top: 12px; }
.mini-bars i { flex: 1; height: 35%; border-radius: 3px 3px 0 0; background: linear-gradient(180deg, var(--blue-light), rgba(59, 130, 246, .18)); box-shadow: 0 0 12px rgba(59, 130, 246, .12); }
.mini-bars i:nth-child(2) { height: 60%; }.mini-bars i:nth-child(3) { height: 48%; }.mini-bars i:nth-child(4) { height: 84%; }.mini-bars i:nth-child(5) { height: 72%; }.mini-bars i:nth-child(6) { height: 100%; }
.infra-status { display: grid; gap: 10px; margin-top: 24px; }
.infra-status span { display: flex; align-items: center; justify-content: space-between; padding: 8px 11px; border: 1px solid var(--line); border-radius: 7px; color: #a9bbd1; font-size: .67rem; }
.infra-status b { order: 2; width: 7px; height: 7px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); }

.about { background: linear-gradient(180deg, #07182a, var(--bg)); }
.about-layout { display: grid; grid-template-columns: minmax(0, 1fr) minmax(0, 1fr); align-items: center; gap: 72px; }
.technology-visual { position: relative; min-height: 500px; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); background: #071525; overflow: hidden; box-shadow: var(--shadow); }
.technology-visual::before { content: ""; position: absolute; z-index: 1; inset: 0; background: linear-gradient(135deg, rgba(5, 20, 36, .08), rgba(5, 20, 36, .65)); }
.technology-visual svg { width: 100%; height: 100%; min-height: 500px; object-fit: cover; }
.visual-label { position: absolute; z-index: 2; left: 20px; bottom: 20px; display: flex; align-items: center; gap: 8px; padding: 8px 10px; border: 1px solid var(--line); border-radius: 7px; background: rgba(5, 20, 36, .78); color: #9db1c9; font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .6rem; backdrop-filter: blur(8px); }
.visual-label span { width: 6px; height: 6px; border-radius: 50%; background: var(--green); box-shadow: 0 0 8px var(--green); }
.about-copy h2 span { color: var(--blue-light); }
.principles { display: grid; gap: 2px; margin-top: 34px; }
.principles article { display: grid; grid-template-columns: 40px 1fr; gap: 15px; padding: 20px 0; border-bottom: 1px solid var(--line); }
.principles article:last-child { border-bottom: 0; }
.principles article > span { color: var(--blue-light); font-family: ui-monospace, SFMono-Regular, Consolas, monospace; font-size: .7rem; font-weight: 700; }
.principles h3 { margin-bottom: 5px; font-family: var(--font-display); font-size: 1rem; }
.principles p { margin-bottom: 0; color: var(--muted); font-size: .8rem; }

.contact { border-top: 1px solid var(--line); background: var(--surface); overflow: hidden; }
.contact::before { content: ""; position: absolute; width: 720px; height: 720px; left: -350px; top: -280px; border-radius: 50%; background: radial-gradient(circle, rgba(59, 130, 246, .12), transparent 68%); }
.contact-layout { position: relative; display: grid; grid-template-columns: minmax(0, .9fr) minmax(480px, 1.1fr); gap: 70px; align-items: start; }
.contact-items { display: grid; gap: 16px; margin-top: 36px; }
.contact-items > div { display: flex; align-items: center; gap: 14px; }
.contact-items p { display: grid; margin: 0; }
.contact-items strong { font-family: var(--font-display); font-size: .86rem; }
.contact-items p span, .contact-items p a { color: var(--muted); font-size: .8rem; }
.contact-items p a:hover { color: var(--blue-light); }
.response-note { display: flex; align-items: flex-start; gap: 13px; margin-top: 36px; padding: 16px; border: 1px solid var(--line); border-radius: 10px; background: rgba(5, 20, 36, .4); }
.response-note .status-dot { margin-top: 7px; }
.response-note p { margin: 0; color: var(--muted); font-size: .74rem; }
.response-note strong { color: var(--text); }
.contact-card { padding: 32px; border: 1px solid var(--line-strong); border-radius: var(--radius-lg); background: rgba(5, 20, 36, .64); box-shadow: var(--shadow), inset 0 1px 0 rgba(255, 255, 255, .04); }
.form-row { display: grid; grid-template-columns: 1fr 1fr; gap: 18px; }
.field { position: relative; margin-bottom: 18px; }
.field label { display: block; margin-bottom: 8px; color: #b5c6db; font-family: var(--font-display); font-size: .68rem; font-weight: 700; letter-spacing: .09em; text-transform: uppercase; }
.field input, .field textarea { width: 100%; border: 1px solid rgba(171, 207, 255, .14); border-radius: 9px; background: #061425; color: var(--text); outline: none; transition: border-color .2s ease, box-shadow .2s ease, background .2s ease; }
.field input { height: 48px; padding: 0 14px; }
.field textarea { min-height: 142px; padding: 13px 14px; resize: vertical; }
.field input::placeholder, .field textarea::placeholder { color: #5f7590; }
.field input:focus, .field textarea:focus { border-color: var(--blue-light); background: #07182a; box-shadow: 0 0 0 3px rgba(59, 130, 246, .12); }
.field.invalid input, .field.invalid textarea { border-color: var(--danger); }
.field-error { display: none; margin-top: 6px; color: var(--danger); font-size: .68rem; }
.field.invalid .field-error { display: block; }
.consent { display: flex; align-items: flex-start; gap: 10px; margin: 2px 0 20px; color: var(--muted); font-size: .7rem; cursor: pointer; }
.consent input { width: 17px; height: 17px; flex: 0 0 auto; margin: 2px 0 0; accent-color: var(--blue); }
.consent a { color: var(--blue-light); text-decoration: underline; text-underline-offset: 2px; }
.form-submit { width: 100%; }
.form-status { min-height: 22px; margin: 12px 0 0; color: var(--green); font-size: .75rem; text-align: center; }
.form-status.error { color: var(--danger); }

.site-footer { border-top: 1px solid var(--line); background: #020d18; }
.footer-main { display: grid; grid-template-columns: 1.45fr repeat(3, 1fr); gap: 55px; padding-top: 66px; padding-bottom: 58px; }
.footer-brand p { max-width: 340px; margin: 20px 0 0; color: var(--muted); font-size: .78rem; }
.footer-main h2 { margin-bottom: 20px; color: #cbd9eb; font-family: var(--font-display); font-size: .68rem; letter-spacing: .12em; text-transform: uppercase; }
.footer-main ul { display: grid; gap: 10px; }
.footer-main li, .footer-main a, .footer-main li span { color: var(--muted); font-size: .74rem; }
.footer-main a:hover { color: var(--blue-light); }
.footer-bottom { display: flex; align-items: center; justify-content: space-between; gap: 24px; padding-top: 22px; padding-bottom: 22px; border-top: 1px solid var(--line); }
.footer-bottom p { margin: 0; color: var(--muted-2); font-size: .67rem; }
.footer-bottom a { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); font-size: .7rem; }
.footer-bottom a svg { width: 15px; height: 15px; transform: rotate(-90deg); }
.footer-bottom a:hover { color: var(--blue-light); }

.reveal { opacity: 0; transform: translateY(24px); transition: opacity .65s ease, transform .65s cubic-bezier(.2, .7, .2, 1); }
.reveal[data-delay="1"] { transition-delay: .12s; }
.reveal.visible { opacity: 1; transform: none; }

.legal-page { min-height: 100vh; padding-top: calc(var(--header-h) + 56px); background: linear-gradient(180deg, #061425, #03101d); }
.legal-content { max-width: 860px; padding-bottom: 90px; }
.legal-content h1 { margin-bottom: 18px; font-family: var(--font-display); font-size: clamp(2.3rem, 5vw, 4rem); line-height: 1.05; letter-spacing: -.04em; }
.legal-content .lead { margin-bottom: 40px; color: var(--muted); font-size: 1.05rem; }
.legal-content section { padding: 26px 0; border-top: 1px solid var(--line); }
.legal-content h2 { margin-bottom: 10px; font-family: var(--font-display); font-size: 1.25rem; }
.legal-content p, .legal-content li { color: var(--muted); font-size: .9rem; }
.legal-content ul { display: grid; gap: 8px; padding-left: 20px; list-style: disc; }
.legal-content a { color: var(--blue-light); text-decoration: underline; text-underline-offset: 3px; }
.not-found { min-height: 100vh; display: grid; place-items: center; padding: 40px 24px; text-align: center; }
.not-found strong { display: block; color: rgba(123, 201, 255, .22); font-family: var(--font-display); font-size: clamp(6rem, 22vw, 14rem); line-height: .8; }
.not-found h1 { margin: 28px 0 12px; font-family: var(--font-display); font-size: clamp(2rem, 5vw, 3.2rem); }
.not-found p { max-width: 540px; margin: 0 auto 28px; color: var(--muted); }

@media (max-width: 1100px) {
  .hero-layout { grid-template-columns: minmax(0, 1fr) minmax(400px, .85fr); }
  .hero h1 { font-size: clamp(3rem, 6vw, 4.6rem); }
  .operations-shell { grid-template-columns: 1fr; }
  .operations-benefits { display: grid; grid-template-columns: repeat(3, 1fr); }
  .operations-benefits article { padding: 12px; border-bottom: 0; border-right: 1px solid var(--line); }
  .operations-benefits article:last-child { border-right: 0; }
  .operations-benefits article { flex-direction: column; }
  .client-zone { grid-column: span 8; }
  .crm-card { grid-column: span 4; }
  .integrations-card, .reporting-card, .infrastructure-card { grid-column: span 4; }
  .about-layout { gap: 46px; }
  .contact-layout { gap: 40px; }
}

@media (max-width: 900px) {
  :root { --header-h: 68px; }
  .container { width: min(calc(100% - 36px), var(--container)); }
  .section { padding: 88px 0; }
  .header-inner { grid-template-columns: 1fr auto; }
  .header-cta { display: none; }
  .menu-toggle { display: grid; grid-column: 2; place-items: center; width: 42px; height: 42px; justify-self: end; border: 1px solid var(--line); border-radius: 9px; background: rgba(255, 255, 255, .03); }
  .primary-nav { position: fixed; inset: var(--header-h) 0 auto; display: grid; gap: 0; padding: 10px 18px 22px; border-bottom: 1px solid var(--line); background: rgba(3, 16, 29, .98); box-shadow: 0 24px 40px rgba(0, 0, 0, .3); transform: translateY(-130%); opacity: 0; visibility: hidden; transition: transform .25s ease, opacity .25s ease, visibility .25s ease; }
  .primary-nav.open { transform: translateY(0); opacity: 1; visibility: visible; }
  .primary-nav a { padding: 14px 4px; border-bottom: 1px solid rgba(168, 204, 255, .08); font-size: .9rem; }
  .primary-nav a:last-child { border-bottom: 0; }
  .primary-nav a::after { display: none; }
  .hero { min-height: auto; padding-top: calc(var(--header-h) + 58px); }
  .hero-layout { grid-template-columns: 1fr; gap: 18px; min-height: auto; }
  .hero-copy { max-width: 740px; }
  .hero h1 span { display: inline; }
  .hero-visual { width: min(88vw, 620px); justify-self: center; margin-top: -20px; }
  .capability-grid { grid-template-columns: repeat(2, 1fr); }
  .capability-grid > div:nth-child(2) { border-right: 0; }
  .capability-grid > div:nth-child(n+3) { border-top: 1px solid var(--line); }
  .capability-grid > div:nth-child(3) { border-left: 1px solid var(--line); }
  .section-heading.split { align-items: start; flex-direction: column; }
  .chips { justify-content: flex-start; }
  .client-zone, .crm-card, .integrations-card, .reporting-card, .infrastructure-card { grid-column: span 6; }
  .client-zone { padding-right: 27px; }
  .portal-preview { display: none; }
  .about-layout, .contact-layout { grid-template-columns: 1fr; }
  .technology-visual { min-height: 420px; }
  .technology-visual svg { min-height: 420px; }
  .contact-copy { max-width: 700px; }
  .contact-card { max-width: 720px; width: 100%; }
  .footer-main { grid-template-columns: 1.5fr 1fr 1fr; }
  .footer-main > div:last-child { grid-column: 2 / 4; }
}

@media (max-width: 680px) {
  .container { width: min(calc(100% - 28px), var(--container)); }
  .section { padding: 72px 0; }
  .section-heading, .section-heading.center { margin-bottom: 36px; }
  .section-heading h2, .about-copy h2, .contact-copy h2 { font-size: clamp(1.9rem, 9vw, 2.7rem); }
  .brand span:last-child { font-size: .9rem; }
  .hero { padding-bottom: 52px; }
  .hero h1 { font-size: clamp(2.55rem, 13vw, 4rem); }
  .hero-copy > p { font-size: .96rem; }
  .hero-actions { display: grid; grid-template-columns: 1fr; }
  .hero-actions .button { width: 100%; }
  .hero-proof { display: grid; gap: 10px; }
  .hero-visual { width: 112%; margin-left: -6%; margin-top: -12px; }
  .data-tag { display: none; }
  .capability-grid > div { grid-template-columns: 29px auto; padding: 19px 13px; }
  .capability-grid svg { width: 19px; height: 19px; }
  .capability-grid span { font-size: .66rem; }
  .capability-grid small { font-size: .58rem; }
  .operations-shell { padding: 12px; border-radius: 16px; }
  .dashboard-topbar { grid-template-columns: 1fr auto; }
  .dashboard-search { display: none; }
  .dashboard-body { min-height: 360px; grid-template-columns: 38px minmax(0, 1fr); }
  .dashboard-sidebar { gap: 12px; }
  .dashboard-sidebar i { width: 14px; height: 14px; }
  .dashboard-content { padding: 14px 10px; }
  .metric-grid { grid-template-columns: repeat(2, 1fr); }
  .metric-grid article:nth-child(n+3) { display: none; }
  .dashboard-lower { grid-template-columns: 1fr; }
  .activity-panel { display: none; }
  .chart-panel svg { height: 145px; }
  .operations-benefits { grid-template-columns: 1fr; }
  .operations-benefits article { flex-direction: row; border-right: 0; border-bottom: 1px solid var(--line); }
  .operations-benefits article:last-child { border-bottom: 0; }
  .bento-grid { grid-template-columns: 1fr; }
  .client-zone, .crm-card, .integrations-card, .reporting-card, .infrastructure-card { grid-column: auto; }
  .bento-card { min-height: 0; padding: 23px; }
  .client-zone { min-height: 390px; }
  .technology-visual { min-height: 330px; }
  .technology-visual svg { min-height: 330px; }
  .form-row { grid-template-columns: 1fr; gap: 0; }
  .contact-card { padding: 22px 18px; }
  .footer-main { grid-template-columns: 1fr 1fr; gap: 38px 24px; padding-top: 52px; }
  .footer-brand { grid-column: 1 / -1; }
  .footer-main > div:last-child { grid-column: auto; }
  .footer-bottom { align-items: flex-start; flex-direction: column; }
}

@media (max-width: 420px) {
  .capability-grid { grid-template-columns: 1fr; }
  .capability-grid > div, .capability-grid > div:first-child, .capability-grid > div:nth-child(3) { border-left: 1px solid var(--line); border-right: 1px solid var(--line); border-top: 1px solid var(--line); }
  .capability-grid > div:first-child { border-top: 0; }
  .footer-main { grid-template-columns: 1fr; }
}

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