﻿:root {
      --bg: #071314;
      --surface: #0d2021;
      --surface-2: #122b2a;
      --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 10% 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: 900px; font-size: clamp(48px, 5.6vw, 88px); line-height: 1.02; 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: 840px; }
    .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; }
    .hash { font-family: var(--font-mono); color: var(--blue); font-variant-numeric: tabular-nums; }
    .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.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, .88fr) 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: 820px; 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; }
    .trust-visual, .browser {
      min-height: 720px;
      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;
      overflow: hidden;
    }
    .visual-top, .browser-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); }
    .visual-body { min-height: 664px; position: relative; display: grid; place-items: center; padding: 28px; }
    .visual-body::before, .visual-body::after { content: ""; position: absolute; border: 1px solid color-mix(in oklch, var(--blue) 42%, var(--border)); transform: rotate(18deg); }
    .visual-body::before { inset: 12% 18%; }
    .visual-body::after { inset: 20% 10%; border-color: color-mix(in oklch, var(--green) 46%, var(--border)); transform: rotate(-15deg); }
    .spark-core { position: relative; z-index: 2; width: min(330px, 100%); min-height: 260px; display: grid; place-items: center; text-align: center; padding: 28px; border: 1px solid color-mix(in oklch, var(--accent) 48%, var(--border)); background: color-mix(in oklch, var(--accent) 9%, var(--surface)); box-shadow: 0 0 56px color-mix(in oklch, var(--accent) 12%, transparent); }
    .spark-core strong { display: block; margin-top: 12px; color: var(--accent-strong); font-size: 34px; line-height: 40px; font-weight: 300; }
    .node { position: absolute; z-index: 3; min-width: 132px; 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: 8%; top: 11%; } .n2 { right: 8%; top: 13%; } .n3 { left: 6%; bottom: 18%; } .n4 { right: 6%; bottom: 18%; } .n5 { left: 39%; top: 6%; } .n6 { left: 39%; bottom: 6%; }
    .grid-4, .grid-5, .grid-6, .flow, .ecosystem, .browser-stats { 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(3, 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; }
    .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; }
    .flow { grid-template-columns: repeat(6, 1fr); }
    .flow-step { position: relative; min-height: 206px; padding: 22px; 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); }
    .ecosystem { grid-template-columns: .76fr 1fr; }
    .eco-copy, .network { background: var(--surface); padding: 32px; }
    .network-map { position: relative; min-height: 520px; 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: 198px; transform: translate(-50%, -50%); border-color: color-mix(in oklch, var(--accent) 50%, var(--border)); color: var(--accent-strong); text-align: center; }
    .nn1 { left: 7%; top: 12%; } .nn2 { right: 8%; top: 14%; } .nn3 { left: 8%; bottom: 18%; } .nn4 { right: 8%; bottom: 16%; } .nn5 { left: 38%; top: 6%; } .nn6 { left: 40%; bottom: 6%; } .nn7 { right: 36%; top: 73%; } .nn8 { left: 34%; top: 28%; }
    .browser { min-height: auto; }
    .browser-body { display: grid; gap: 16px; padding: 16px; }
    .browser-stats { grid-template-columns: repeat(4, 1fr); }
    .stat { min-height: 148px; padding: 20px; background: radial-gradient(circle at 100% 0, color-mix(in oklch, var(--blue) 10%, transparent) 0 7rem, transparent 13rem), var(--surface); }
    .stat strong { display: block; margin: 26px 0 10px; color: var(--accent-strong); font-family: var(--font-mono); font-size: clamp(30px, 3vw, 48px); line-height: 1; font-weight: 400; font-variant-numeric: tabular-nums; }
    .table-wrap { overflow-x: auto; border: 1px solid var(--border); }
    table { width: 100%; min-width: 1180px; border-collapse: collapse; font-size: 13px; background: var(--surface); }
    th, td { padding: 14px 12px; border-bottom: 1px solid var(--border); text-align: left; white-space: nowrap; }
    th { color: var(--subtle); font-family: var(--font-mono); font-size: 12px; letter-spacing: .32px; font-weight: 400; background: color-mix(in oklch, var(--bg) 34%, var(--surface)); }
    td { color: var(--muted); }
    td strong { color: var(--fg); font-weight: 400; }
    .action-link { color: var(--accent-strong); font-family: var(--font-mono); font-size: 12px; }
    .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, .ecosystem { grid-template-columns: 1fr; }
      .grid-4, .grid-5, .grid-6, .flow, .browser-stats { grid-template-columns: repeat(2, 1fr); }
      .flow-step:not(:last-child)::after { display: none; }
    }
    @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, .browser-stats, .cta-box, .footer-grid { grid-template-columns: 1fr; }
      .visual-top, .browser-top { align-items: flex-start; flex-direction: column; padding: 14px 16px; }
      .trust-visual { min-height: auto; }
      .visual-body { min-height: 760px; align-content: start; }
      .visual-body::before, .visual-body::after, .network-map::before, .network-map::after { display: none; }
      .spark-core { width: 100%; min-height: 180px; }
      .node, .network-node { position: relative; inset: auto; transform: none; display: block; width: 100%; margin: 8px 0; }
      .network-map { min-height: 650px; }
      .network-node.core { left: auto; top: auto; transform: none; }
    }
