﻿:root {
      --bg: #071314;
      --surface: #0d2021;
      --surface-2: #122b2a;
      --surface-3: #173534;
      --fg: #f4f4f4;
      --muted: #c6c6c6;
      --subtle: #8d8d8d;
      --border: #244442;
      --accent: #d98a24;
      --accent-strong: #f1b04d;
      --blue: #78a9ff;
      --green: #24a148;
      --font-display: "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
      --font-body: "IBM Plex Sans", "Helvetica Neue", Arial, sans-serif;
      --font-mono: "IBM Plex Mono", Menlo, Courier, monospace;
      --container: 1440px;
      --gutter: 32px;
      --nav-h: 56px;
    }
    *, *::before, *::after { box-sizing: border-box; }
    html { scroll-behavior: smooth; }
    body {
      margin: 0;
      background:
        radial-gradient(circle at 74% 8%, color-mix(in oklch, var(--green) 14%, transparent) 0 18rem, transparent 34rem),
        radial-gradient(circle at 12% 30%, color-mix(in oklch, var(--blue) 10%, transparent) 0 16rem, transparent 32rem),
        linear-gradient(180deg, color-mix(in oklch, var(--surface-2) 42%, var(--bg)), var(--bg) 48rem);
      color: var(--fg);
      font-family: var(--font-body);
      line-height: 1.5;
      -webkit-font-smoothing: antialiased;
      text-rendering: optimizeLegibility;
    }
    a { color: inherit; text-decoration: none; }
    p, h1, h2, h3 { margin: 0; }
    p { text-wrap: pretty; }
    h1, h2, h3 { font-family: var(--font-display); text-wrap: balance; }
    .container { width: 100%; max-width: var(--container); margin: 0 auto; padding: 0 var(--gutter); }
    .topnav {
      position: sticky;
      top: 0;
      z-index: 30;
      height: var(--nav-h);
      background: color-mix(in oklch, var(--bg) 88%, transparent);
      backdrop-filter: blur(18px);
      border-bottom: 1px solid var(--border);
    }
    .nav-inner { height: var(--nav-h); display: grid; grid-template-columns: auto 1fr auto; align-items: center; gap: 24px; }
    .brand { display: flex; align-items: center; gap: 12px; min-width: 176px; font-weight: 600; letter-spacing: .16px; }
    .brand-mark { width: 32px; height: 32px; display: grid; grid-template-columns: repeat(4, 1fr); gap: 2px; }
    .brand-mark span { background: var(--accent); }
    .nav-links { display: flex; align-items: center; gap: 18px; overflow: hidden; white-space: nowrap; color: var(--muted); font-size: 14px; letter-spacing: .16px; }
    .nav-links a:hover, .nav-links a.active { color: var(--fg); }
    .btn {
      display: inline-flex;
      align-items: center;
      justify-content: space-between;
      min-height: 48px;
      padding: 14px 18px 14px 16px;
      border: 1px solid transparent;
      border-radius: 0;
      background: transparent;
      color: var(--fg);
      font-size: 14px;
      letter-spacing: .16px;
    }
    .btn::after { content: "→"; margin-left: 32px; }
    .btn-primary { background: var(--accent); color: var(--bg); }
    .btn-secondary { border-color: color-mix(in oklch, var(--green) 46%, var(--border)); background: color-mix(in oklch, var(--green) 10%, var(--surface)); }
    .btn-outline { border-color: var(--border); background: color-mix(in oklch, var(--surface) 72%, transparent); }
    .section { padding: 88px 0; border-top: 1px solid var(--border); }
    .section-header { display: grid; grid-template-columns: minmax(0, .82fr) minmax(280px, .52fr); gap: 48px; align-items: end; margin-bottom: 40px; }
    .eyebrow {
      margin-bottom: 16px;
      color: var(--accent-strong);
      font-family: var(--font-mono);
      font-size: 12px;
      line-height: 16px;
      letter-spacing: .32px;
      text-transform: uppercase;
    }
    h1 { max-width: 860px; font-size: clamp(56px, 6.6vw, 104px); line-height: .98; font-weight: 300; }
    h2 { font-size: clamp(34px, 3.2vw, 54px); line-height: 1.15; font-weight: 300; }
    h3 { font-size: 20px; line-height: 28px; font-weight: 600; }
    .lead { color: var(--muted); font-size: 18px; line-height: 30px; max-width: 820px; }
    .body-copy { display: grid; gap: 16px; color: var(--muted); font-size: 16px; line-height: 26px; }
    .meta { color: var(--subtle); font-family: var(--font-mono); font-size: 12px; letter-spacing: .32px; }
    .tags, .hero-actions, .cta-actions { display: flex; flex-wrap: wrap; gap: 12px; }
    .tag {
      display: inline-flex;
      align-items: center;
      min-height: 28px;
      padding: 4px 10px;
      border: 1px solid var(--border);
      background: color-mix(in oklch, var(--surface-2) 86%, transparent);
      color: var(--muted);
      font-size: 12px;
      letter-spacing: .16px;
    }
    .tag.hot { border-color: color-mix(in oklch, var(--accent) 42%, var(--border)); color: var(--accent-strong); background: color-mix(in oklch, var(--accent) 10%, var(--surface)); }
    .state {
      display: inline-flex;
      align-items: center;
      min-height: 24px;
      padding: 2px 8px;
      border: 1px solid color-mix(in oklch, var(--green) 42%, var(--border));
      background: color-mix(in oklch, var(--green) 10%, var(--surface));
      color: color-mix(in oklch, var(--green) 82%, var(--fg));
      font-size: 12px;
      white-space: nowrap;
    }
    .state.warn { border-color: color-mix(in oklch, var(--accent) 42%, var(--border)); background: color-mix(in oklch, var(--accent) 10%, var(--surface)); color: var(--accent-strong); }
    .state.blue { border-color: color-mix(in oklch, var(--blue) 42%, var(--border)); background: color-mix(in oklch, var(--blue) 10%, var(--surface)); color: var(--blue); }
    .hero { min-height: calc(100vh - var(--nav-h)); padding: 80px 0 96px; display: flex; align-items: center; border-top: 0; }
    .hero-grid { display: grid; grid-template-columns: minmax(0, .86fr) minmax(560px, .9fr); gap: 56px; align-items: center; }
    .hero-copy { display: flex; flex-direction: column; gap: 28px; }
    .adline { display: grid; grid-template-columns: 4px 1fr; max-width: 760px; border: 1px solid color-mix(in oklch, var(--accent) 34%, var(--border)); background: color-mix(in oklch, var(--accent) 10%, var(--surface)); }
    .adline::before { content: ""; background: var(--accent); }
    .adline strong { display: block; padding: 18px 20px; color: var(--fg); font-size: 26px; line-height: 34px; font-weight: 400; }
    .workstation {
      min-height: 720px;
      position: relative;
      overflow: hidden;
      border: 1px solid var(--border);
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--border) 42%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--border) 34%, transparent) 1px, transparent 1px),
        color-mix(in oklch, var(--surface) 90%, transparent);
      background-size: 48px 48px, 48px 48px, auto;
    }
    .workstation-top { min-height: 56px; display: flex; align-items: center; justify-content: space-between; gap: 16px; padding: 0 16px; border-bottom: 1px solid var(--border); background: color-mix(in oklch, var(--surface-2) 72%, transparent); }
    .live { display: inline-flex; align-items: center; gap: 8px; color: var(--muted); font-size: 12px; letter-spacing: .16px; }
    .live::before { content: ""; width: 8px; height: 8px; background: var(--green); box-shadow: 0 0 0 6px color-mix(in oklch, var(--green) 14%, transparent); }
    .device-area { position: relative; min-height: 664px; display: grid; place-items: center; padding: 28px; }
    .device {
      position: relative;
      z-index: 2;
      width: min(420px, 72vw);
      min-height: 460px;
      border: 1px solid color-mix(in oklch, var(--muted) 42%, var(--border));
      background: linear-gradient(180deg, color-mix(in oklch, var(--surface-2) 84%, black), var(--bg));
      box-shadow: 0 0 58px color-mix(in oklch, var(--green) 15%, transparent);
      padding: 18px;
    }
    .device-screen { min-height: 278px; border: 1px solid var(--border); background: var(--surface); padding: 16px; display: grid; gap: 12px; }
    .device-base { height: 94px; margin-top: 18px; border: 1px solid var(--border); background: color-mix(in oklch, var(--bg) 68%, var(--surface)); display: grid; grid-template-columns: 1fr auto; align-items: center; gap: 18px; padding: 18px; }
    .device-brand { color: var(--accent-strong); font-family: var(--font-mono); font-size: 24px; letter-spacing: .04em; }
    .port-grid { display: grid; grid-template-columns: repeat(3, 18px); gap: 8px; }
    .port-grid span { height: 18px; border: 1px solid var(--border); background: var(--surface); }
    .terminal-line { display: grid; grid-template-columns: 84px 1fr auto; gap: 10px; align-items: center; padding: 10px; border-left: 2px solid var(--border); background: color-mix(in oklch, var(--bg) 42%, transparent); color: var(--muted); font-size: 13px; }
    .terminal-line.hot { border-color: var(--accent); }
    .terminal-line.good { border-color: var(--green); }
    .node {
      position: absolute;
      z-index: 3;
      width: 138px;
      min-height: 72px;
      padding: 10px 12px;
      border: 1px solid var(--border);
      background: color-mix(in oklch, var(--surface-2) 92%, transparent);
      color: var(--muted);
      font-size: 13px;
      line-height: 18px;
    }
    .node span { display: block; margin-bottom: 4px; color: var(--blue); font-family: var(--font-mono); font-size: 11px; letter-spacing: .32px; text-transform: uppercase; }
    .n1 { left: 5%; top: 10%; }
    .n2 { right: 6%; top: 12%; }
    .n3 { left: 8%; top: 42%; }
    .n4 { right: 8%; top: 42%; }
    .n5 { left: 8%; bottom: 10%; }
    .n6 { right: 8%; bottom: 10%; }
    .n7 { left: 42%; top: 4%; }
    .n8 { left: 42%; bottom: 4%; }
    .link-line {
      position: absolute;
      z-index: 1;
      left: 9%;
      right: 9%;
      top: 50%;
      height: 1px;
      background: linear-gradient(90deg, transparent, color-mix(in oklch, var(--blue) 50%, var(--border)), transparent);
    }
    .link-line.v { left: 50%; right: auto; top: 8%; bottom: 8%; width: 1px; height: auto; background: linear-gradient(180deg, transparent, color-mix(in oklch, var(--green) 50%, var(--border)), transparent); }
    .split, .ecosystem, .iot-flow { display: grid; grid-template-columns: .76fr 1fr; gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .panel-copy, .panel-visual, .network, .iot-side { background: var(--surface); padding: 32px; }
    .rd-card { min-height: 410px; display: grid; grid-template-columns: 1fr; gap: 1px; background: var(--border); }
    .rd-image-wrap { background: var(--surface); padding: 22px; }
    .rd-image {
      display: block;
      width: 100%;
      height: auto;
      min-height: 260px;
      max-height: 420px;
      object-fit: cover;
      border: 1px solid color-mix(in oklch, var(--accent) 24%, var(--border));
    }
    .rd-info { display: grid; grid-template-columns: .9fr 1fr; gap: 1px; background: var(--border); }
    .rd-brand, .rd-points { background: var(--surface); padding: 28px; }
    .rd-brand strong { display: block; margin-top: 28px; color: var(--accent-strong); font-size: 34px; line-height: 42px; font-weight: 300; }
    .point-list { display: grid; gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .point { display: grid; grid-template-columns: 28px 1fr; gap: 12px; padding: 18px; background: color-mix(in oklch, var(--surface-2) 86%, transparent); color: var(--muted); }
    .point span:first-child { color: var(--accent-strong); font-family: var(--font-mono); }
    .compare { display: grid; grid-template-columns: 1fr 1fr; gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .compare-card { min-height: 360px; padding: 28px; background: var(--surface); }
    .compare-card.focus { background: radial-gradient(circle at 100% 0, color-mix(in oklch, var(--green) 15%, transparent) 0 10rem, transparent 18rem), var(--surface); }
    .grid-4, .grid-5, .grid-6, .flow { display: grid; gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .grid-4 { grid-template-columns: repeat(4, 1fr); }
    .grid-5 { grid-template-columns: repeat(5, 1fr); }
    .grid-6 { grid-template-columns: repeat(6, 1fr); }
    .tile {
      min-height: 236px;
      padding: 24px;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--border) 24%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--border) 20%, transparent) 1px, transparent 1px),
        var(--surface);
      background-size: 32px 32px;
    }
    .tile .index, .flow-step .index {
      display: block;
      margin-bottom: 28px;
      color: var(--accent-strong);
      font-family: var(--font-mono);
      font-size: 12px;
      letter-spacing: .32px;
    }
    .tile p, .flow-step p { margin-top: 10px; color: var(--muted); font-size: 14px; line-height: 22px; }
    .dataflow { display: grid; grid-template-columns: .85fr .7fr .85fr; gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .data-col { min-height: 440px; padding: 24px; background: var(--surface); }
    .data-col.center { display: grid; place-items: center; background: color-mix(in oklch, var(--surface-2) 88%, transparent); }
    .mini-device { width: 190px; min-height: 240px; border: 1px solid color-mix(in oklch, var(--accent) 42%, var(--border)); background: var(--bg); padding: 16px; display: grid; place-items: center; color: var(--accent-strong); text-align: center; font-family: var(--font-mono); }
    .data-list { display: grid; gap: 10px; margin-top: 20px; }
    .data-item { padding: 12px; border-left: 2px solid var(--border); background: color-mix(in oklch, var(--surface-2) 82%, transparent); color: var(--muted); font-size: 14px; }
    .flow { grid-template-columns: repeat(8, 1fr); }
    .flow-step { position: relative; min-height: 178px; padding: 20px; background: var(--surface); }
    .flow-step:not(:last-child)::after {
      content: "→";
      position: absolute;
      top: 50%;
      right: -15px;
      z-index: 2;
      width: 28px;
      height: 28px;
      display: grid;
      place-items: center;
      transform: translateY(-50%);
      background: var(--blue);
      color: var(--bg);
      font-family: var(--font-mono);
    }
    .network-map {
      position: relative;
      min-height: 560px;
      overflow: hidden;
      background:
        linear-gradient(90deg, color-mix(in oklch, var(--border) 42%, transparent) 1px, transparent 1px),
        linear-gradient(180deg, color-mix(in oklch, var(--border) 34%, transparent) 1px, transparent 1px);
      background-size: 40px 40px;
    }
    .network-map::before, .network-map::after {
      content: "";
      position: absolute;
      inset: 16% 16%;
      border: 1px solid color-mix(in oklch, var(--blue) 42%, var(--border));
      transform: rotate(18deg);
    }
    .network-map::after { inset: 24% 10%; border-color: color-mix(in oklch, var(--green) 46%, var(--border)); transform: rotate(-16deg); }
    .network-node {
      position: absolute;
      z-index: 2;
      min-width: 124px;
      padding: 10px 12px;
      border: 1px solid var(--border);
      background: color-mix(in oklch, var(--surface-2) 92%, transparent);
      color: var(--muted);
      font-size: 13px;
      line-height: 18px;
    }
    .network-node.core { left: 50%; top: 50%; min-width: 158px; transform: translate(-50%, -50%); border-color: color-mix(in oklch, var(--accent) 50%, var(--border)); color: var(--accent-strong); text-align: center; }
    .nn1 { left: 6%; top: 12%; }
    .nn2 { right: 7%; top: 12%; }
    .nn3 { left: 7%; bottom: 18%; }
    .nn4 { right: 7%; bottom: 18%; }
    .nn5 { left: 38%; top: 6%; }
    .nn6 { left: 40%; bottom: 6%; }
    .nn7 { left: 8%; top: 47%; }
    .nn8 { right: 8%; top: 47%; }
    .nn9 { left: 30%; top: 28%; }
    .nn10 { right: 28%; top: 70%; }
    .principles { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; border: 1px solid var(--border); background: var(--border); }
    .principle { min-height: 190px; padding: 24px; background: color-mix(in oklch, var(--surface-2) 86%, transparent); }
    .cta { background: color-mix(in oklch, var(--surface-2) 72%, var(--bg)); border-top: 1px solid var(--border); border-bottom: 1px solid var(--border); }
    .cta-box { display: grid; grid-template-columns: 1fr auto; gap: 32px; align-items: center; padding: 48px 0; }
    footer { padding: 48px 0 40px; color: var(--muted); background: var(--bg); }
    .footer-grid { display: grid; grid-template-columns: 1.2fr repeat(3, .6fr); gap: 32px; }
    footer h3 { margin-bottom: 14px; color: var(--fg); font-size: 16px; }
    footer a, footer p { display: block; margin: 8px 0 0; color: var(--muted); font-size: 14px; }
    .copyright { margin-top: 40px; padding-top: 20px; border-top: 1px solid var(--border); }
    @media (max-width: 1180px) {
      .nav-links { display: none; }
      .hero-grid, .split, .ecosystem, .iot-flow, .dataflow { grid-template-columns: 1fr; }
      .grid-4, .grid-5, .grid-6, .flow, .principles { grid-template-columns: repeat(2, 1fr); }
      .rd-card, .compare, .rd-info { grid-template-columns: 1fr; }
      .workstation { min-height: auto; }
    }
    @media (max-width: 820px) {
      :root { --gutter: 20px; }
      .section { padding: 56px 0; }
      .hero { padding: 48px 0 64px; }
      .section-header, .grid-4, .grid-5, .grid-6, .flow, .principles, .cta-box, .footer-grid { grid-template-columns: 1fr; }
      .workstation-top { align-items: flex-start; flex-direction: column; padding: 14px 16px; }
      .device-area { min-height: 820px; align-content: start; }
      .node { position: relative; inset: auto; width: 100%; min-height: 56px; margin: 6px 0; }
      .link-line { display: none; }
      .device { width: 100%; order: -1; }
      .terminal-line { grid-template-columns: 1fr; }
      .flow-step:not(:last-child)::after { display: none; }
      .network-map { min-height: 820px; }
      .network-map::before, .network-map::after { display: none; }
      .network-node { position: relative; inset: auto; transform: none; display: block; margin: 10px; }
      .network-node.core { left: auto; top: auto; transform: none; }
    }
