
  /* cyrillic-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/c453d35c-7eec-4ea5-b901-0a04befc5375.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/e839cb57-e3e2-4a61-858c-6c62c5e07ffb.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/714ed59c-8a11-4589-97c9-8c1012a19682.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/6f4ab435-f0c9-4147-9c73-2db42f4bdcde.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/4fb6a155-3db5-440b-96fe-c70cedfc5fab.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/dc0dd827-8d8d-47c0-80ab-b7ae6552c738.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* cyrillic */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/89e47dd2-cb0f-4da6-9ad9-a917329eb833.woff2") format('woff2');
  unicode-range: U+0301, U+0400-045F, U+0490-0491, U+04B0-04B1, U+2116;
}
/* vietnamese */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/a84fd9dc-0f1a-4c17-bbdc-162a8f7aa802.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/11490925-d1ab-454d-92e2-4774bc34770b.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'IBM Plex Mono';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/d022efc0-79c4-48b9-9c17-c7b4a0a06a7a.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/94f71282-8053-4a64-956c-e55b04cf39c7.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/77ec94ba-597b-4bae-89aa-4a15ad17f02c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/22eeb8b5-9486-4682-b52f-ce83be4baa40.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url("assets/fonts/b5e83956-66b0-4c04-87dc-11267c697584.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/94f71282-8053-4a64-956c-e55b04cf39c7.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/77ec94ba-597b-4bae-89aa-4a15ad17f02c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/22eeb8b5-9486-4682-b52f-ce83be4baa40.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url("assets/fonts/b5e83956-66b0-4c04-87dc-11267c697584.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/94f71282-8053-4a64-956c-e55b04cf39c7.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/77ec94ba-597b-4bae-89aa-4a15ad17f02c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/22eeb8b5-9486-4682-b52f-ce83be4baa40.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 700;
  font-display: swap;
  src: url("assets/fonts/b5e83956-66b0-4c04-87dc-11267c697584.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}
/* cyrillic-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("assets/fonts/94f71282-8053-4a64-956c-e55b04cf39c7.woff2") format('woff2');
  unicode-range: U+0460-052F, U+1C80-1C8A, U+20B4, U+2DE0-2DFF, U+A640-A69F, U+FE2E-FE2F;
}
/* vietnamese */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("assets/fonts/77ec94ba-597b-4bae-89aa-4a15ad17f02c.woff2") format('woff2');
  unicode-range: U+0102-0103, U+0110-0111, U+0128-0129, U+0168-0169, U+01A0-01A1, U+01AF-01B0, U+0300-0301, U+0303-0304, U+0308-0309, U+0323, U+0329, U+1EA0-1EF9, U+20AB;
}
/* latin-ext */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("assets/fonts/22eeb8b5-9486-4682-b52f-ce83be4baa40.woff2") format('woff2');
  unicode-range: U+0100-02BA, U+02BD-02C5, U+02C7-02CC, U+02CE-02D7, U+02DD-02FF, U+0304, U+0308, U+0329, U+1D00-1DBF, U+1E00-1E9F, U+1EF2-1EFF, U+2020, U+20A0-20AB, U+20AD-20C0, U+2113, U+2C60-2C7F, U+A720-A7FF;
}
/* latin */
@font-face {
  font-family: 'Plus Jakarta Sans';
  font-style: normal;
  font-weight: 800;
  font-display: swap;
  src: url("assets/fonts/b5e83956-66b0-4c04-87dc-11267c697584.woff2") format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+0304, U+0308, U+0329, U+2000-206F, U+20AC, U+2122, U+2191, U+2193, U+2212, U+2215, U+FEFF, U+FFFD;
}


  :root {
    --paper:    #F7F3EB;
    --paper-2:  #FFFFFF;
    --ink:      #1E1B16;
    --ink-soft: #4F493F;
    --muted:    #8A8377;
    --line:     rgba(30, 27, 22, 0.14);

    --violet: oklch(0.56 0.18 292);
    --violet-d: oklch(0.46 0.18 292);
    --coral:  oklch(0.67 0.18 30);
    --amber:  oklch(0.84 0.14 82);
    --green:  oklch(0.70 0.14 158);
    --sky:    oklch(0.74 0.12 232);

    /* soft tints for calm card fills */
    --violet-t: oklch(0.95 0.035 292);
    --coral-t:  oklch(0.95 0.045 34);
    --amber-t:  oklch(0.96 0.05 84);
    --green-t:  oklch(0.95 0.04 158);
    --sky-t:    oklch(0.96 0.035 232);

    --shadow-soft: 0 16px 40px rgba(30,27,22,0.08);
    --shadow-card: 0 12px 30px rgba(30,27,22,0.06);

    --sans: "Plus Jakarta Sans", "Helvetica Neue", sans-serif;
    --mono: "IBM Plex Mono", ui-monospace, monospace;

    --r-lg: 30px;
    --r-md: 20px;
    --r-pill: 999px;
  }

  * { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  body {
    margin: 0;
    background: var(--paper);
    color: var(--ink);
    font-family: var(--sans);
    -webkit-font-smoothing: antialiased;
    overflow-x: hidden;
  }
  .wrap { max-width: 1140px; margin: 0 auto; padding: 0 30px; }
  a { color: inherit; }

  .mono { font-family: var(--mono); }

  /* ---------- buttons ---------- */
  .btn {
    display: inline-flex; align-items: center; gap: 10px; text-decoration: none;
    background: var(--ink); color: var(--paper);
    font-weight: 700; font-size: 17px; letter-spacing: -0.01em;
    padding: 16px 28px; border-radius: var(--r-pill);
    border: 1.5px solid var(--ink);
    box-shadow: 0 8px 20px rgba(30,27,22,0.16);
    transition: transform .14s ease, box-shadow .14s ease, background .14s ease;
    cursor: pointer;
  }
  .btn:hover { transform: translateY(-2px); box-shadow: 0 12px 26px rgba(30,27,22,0.2); }
  .btn:active { transform: translateY(0); box-shadow: 0 5px 14px rgba(30,27,22,0.18); }
  .btn.violet { background: var(--violet); border-color: var(--violet); color: #fff; box-shadow: 0 8px 22px oklch(0.56 0.18 292 / 0.35); }
  .btn.violet:hover { box-shadow: 0 12px 28px oklch(0.56 0.18 292 / 0.42); }
  .btn.ghost { background: var(--paper-2); color: var(--ink); }
  .btn.sm { font-size: 15px; padding: 11px 20px; }

  /* ---------- header ---------- */
  header { position: sticky; top: 0; z-index: 50; background: rgba(247,243,235,0.82); backdrop-filter: blur(10px); border-bottom: 1px solid var(--line); }
  .nav { display: flex; align-items: center; justify-content: space-between; padding: 16px 0; gap: 20px; }
  .lockup { display: flex; align-items: center; gap: 12px; text-decoration: none; }
  .mark { width: 38px; height: 38px; display: block; }
  .lockup .word { font-weight: 800; font-size: 20px; letter-spacing: -0.03em; white-space: nowrap; }
  .lockup .word .dot { color: var(--violet); }
  .nav-links { display: flex; align-items: center; gap: 28px; }
  .nav-links a.nl { font-family: var(--mono); font-size: 13px; font-weight: 600; letter-spacing: 0.04em; text-decoration: none; color: var(--ink-soft); white-space: nowrap; transition: color .14s ease; }
  .nav-links a.nl:hover { color: var(--violet); }

  /* ---------- decorative blobs ---------- */
  .blob { position: absolute; border-radius: 50%; z-index: 0; pointer-events: none; }

  /* ---------- hero ---------- */
  .hero { position: relative; padding: 92px 0 64px; overflow: hidden; }
  .hero-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.18fr 0.82fr; gap: 56px; align-items: center; }
  .kick {
    display: inline-flex; align-items: center; gap: 9px;
    font-family: var(--mono); font-size: 13.5px; font-weight: 600;
    letter-spacing: 0.06em; text-transform: uppercase; color: var(--violet);
    margin: 0 0 22px;
  }
  .kick .dot { width: 9px; height: 9px; border-radius: 50%; background: var(--coral); }
  h1 {
    font-size: clamp(42px, 6.6vw, 78px);
    line-height: 0.98; letter-spacing: -0.035em; font-weight: 800;
    margin: 0 0 24px; text-wrap: balance;
  }
  h1 .hl, h2 .hl { position: relative; white-space: nowrap; }
  h1 .hl span, h2 .hl span { position: relative; z-index: 1; }
  h1 .hl::after, h2 .hl::after {
    content: ""; position: absolute; left: -4px; right: -4px; bottom: 0.06em; height: 0.38em;
    background: var(--amber); z-index: 0; border-radius: 6px; transform: rotate(-1.2deg);
  }
  .sub {
    font-size: clamp(18px, 2.1vw, 22px); line-height: 1.5; color: var(--ink-soft);
    max-width: 560px; margin: 0 0 32px; text-wrap: pretty; font-weight: 500;
  }
  .sub b { color: var(--ink); font-weight: 700; }
  .cta-row { display: flex; align-items: center; gap: 14px; flex-wrap: wrap; }

  .hero-art { position: relative; }
  .hero-art .slot-card {
    position: relative; background: var(--violet); border: 2px solid var(--ink);
    border-radius: var(--r-lg); padding: 0; overflow: hidden;
    box-shadow: var(--shadow-soft); aspect-ratio: 1 / 1.04;
  }
  image-slot { width: 100%; height: 100%; display: block; --slot-bg: transparent; }
  .hero-art .tag {
    position: absolute; z-index: 3; font-family: var(--mono); font-size: 12px; font-weight: 600;
    background: var(--paper-2); border: 1.5px solid var(--ink); border-radius: var(--r-pill);
    padding: 7px 14px; box-shadow: 0 6px 16px rgba(30,27,22,0.12);
  }
  .hero-art .tag.t1 { top: -14px; left: 18px; transform: rotate(-5deg); background: var(--coral); color: #fff; }
  .hero-art .tag.t2 { bottom: 64px; right: -24px; transform: rotate(4deg); background: var(--amber); }
  .hero-art .tag.t3 { bottom: -14px; left: 24px; transform: rotate(-3deg); background: var(--green); }

  .agents { display: flex; gap: 9px; flex-wrap: wrap; margin-top: 52px; position: relative; z-index: 2; align-items: center; }
  .agents .lbl { font-family: var(--mono); font-size: 12.5px; color: var(--muted); margin-right: 4px; }
  .chip {
    display: inline-flex; align-items: center; gap: 8px;
    font-family: var(--mono); font-size: 13.5px; font-weight: 500;
    padding: 8px 15px; border: 1.5px solid var(--line); border-radius: var(--r-pill);
    color: var(--ink-soft); white-space: nowrap; background: var(--paper-2);
  }
  .chip.live { border-color: var(--ink); font-weight: 600; color: var(--ink); }
  .chip .led { width: 9px; height: 9px; border-radius: 50%; flex: none; }
  .chip.live .led { background: var(--green); box-shadow: 0 0 0 3px oklch(0.70 0.14 158 / 0.22); }
  .chip.off { color: var(--muted); border-style: dashed; border-color: var(--line); background: transparent; }
  .chip.off .led { background: var(--muted); opacity: 0.5; }
  .agents .lbl.soon { margin-left: 6px; }

  /* ---------- benefit ribbon ---------- */
  .ribbon { background: var(--violet); border-top: 2px solid var(--ink); border-bottom: 2px solid var(--ink); }
  .ribbon a {
    display: flex; align-items: center; justify-content: center; gap: 16px; flex-wrap: wrap;
    text-decoration: none; padding: 20px 30px; color: #fff;
    transition: background .14s ease;
  }
  .ribbon a:hover { background: var(--violet-d); }
  .ribbon .big { font-size: clamp(19px, 2.4vw, 25px); font-weight: 800; letter-spacing: -0.02em; }
  .ribbon .big .pl { color: var(--amber); }
  .ribbon .src { font-family: var(--mono); font-size: clamp(15px, 1.7vw, 18px); font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: #fff; display: inline-flex; align-items: center; gap: 12px; }
  .ribbon .src::before { content: ""; width: 30px; height: 2px; background: rgba(255,255,255,0.5); }
  .ribbon .arrow { transition: transform .14s ease; }
  .ribbon a:hover .arrow { transform: translateX(4px); }

  /* ---------- section scaffold ---------- */
  .sec { padding: 100px 0; position: relative; }
  .sec-head { max-width: 820px; margin: 0 0 56px; }
  .eyebrow { font-family: var(--mono); font-size: 13.5px; font-weight: 600; letter-spacing: 0.08em; text-transform: uppercase; color: var(--violet); margin: 0 0 16px; }
  h2 { font-size: clamp(30px, 4.4vw, 50px); font-weight: 800; letter-spacing: -0.03em; line-height: 1.04; margin: 0; text-wrap: balance; }
  h2 + .lede { font-size: 19px; line-height: 1.5; color: var(--ink-soft); margin: 18px 0 0; max-width: 660px; font-weight: 500; text-wrap: pretty; }

  /* ---------- how it works ---------- */
  .steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; margin-bottom: 56px; }
  .step { border: 1.5px solid var(--line); border-radius: var(--r-lg); padding: 32px 30px 34px; box-shadow: var(--shadow-card); position: relative; overflow: hidden; background: var(--paper-2); }
  .step.s1 { background: var(--amber-t); } .step.s2 { background: var(--sky-t); } .step.s3 { background: var(--green-t); }
  .step .sn { width: 38px; height: 38px; border-radius: 11px; border: 1.5px solid var(--ink); display: grid; place-items: center; font-weight: 800; font-size: 16px; margin-bottom: 18px; }
  .step.s1 .sn { background: var(--coral); color: #fff; } .step.s2 .sn { background: var(--violet); color: #fff; } .step.s3 .sn { background: var(--green); }
  .step h3 { font-size: 21px; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 10px; }
  .step p { font-size: 15.5px; line-height: 1.5; margin: 0; font-weight: 500; text-wrap: pretty; color: var(--ink-soft); }
  .step p code, .step p .kw { font-family: var(--mono); font-size: 13.5px; background: rgba(30,27,22,0.06); padding: 2px 7px; border-radius: 6px; }
  .step p i { color: var(--ink); font-style: italic; font-weight: 600; }

  /* ---------- demo strip ---------- */
  .demo-card {
    background: var(--paper-2); border: 1.5px solid var(--line); border-radius: var(--r-lg);
    box-shadow: var(--shadow-soft); overflow: hidden;
  }
  .demo-top {
    display: flex; align-items: center; gap: 10px; padding: 16px 24px;
    border-bottom: 1.5px solid var(--line); background: var(--sky-t);
  }
  .demo-top .d { width: 12px; height: 12px; border-radius: 50%; border: 1.5px solid var(--ink); }
  .demo-top .d.a { background: var(--coral); } .demo-top .d.b { background: var(--amber); } .demo-top .d.c { background: var(--green); }
  .demo-top .ttl { margin-left: 8px; font-family: var(--mono); font-size: 13px; font-weight: 600; letter-spacing: 0.04em; }
  .demo-body { padding: 34px 34px 38px; display: grid; gap: 18px; }
  .row { display: flex; gap: 14px; align-items: flex-start; }
  .row .ava { flex: none; width: 38px; height: 38px; border-radius: 12px; border: 1.5px solid var(--ink); display: grid; place-items: center; font-weight: 800; font-size: 15px; }
  .row .ava.you { background: var(--amber); }
  .row .ava.sf { background: var(--violet); color: #fff; }
  .bubble { border: 1.5px solid var(--line); border-radius: 16px; padding: 13px 17px; font-size: 16px; line-height: 1.5; font-weight: 500; max-width: 720px; }
  .bubble.you { background: var(--paper); border-bottom-left-radius: 4px; }
  .bubble.sf { background: #fff; border-bottom-left-radius: 4px; }
  .bubble .mono { font-size: 13.5px; color: var(--ink-soft); }
  .wishes { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 4px; }
  .wish { font-family: var(--mono); font-size: 13px; background: var(--paper); border: 1.5px solid var(--line); border-radius: var(--r-pill); padding: 6px 13px; }
  .matched { display: inline-flex; align-items: center; gap: 8px; font-family: var(--mono); font-size: 13.5px; font-weight: 600; background: var(--green-t); border: 1.5px solid var(--green); color: var(--ink); border-radius: var(--r-pill); padding: 7px 15px; }
  .speed { font-family: var(--mono); font-size: 13px; color: var(--muted); }

  /* ---------- benchmark ---------- */
  .bench { background: var(--paper-2); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); }
  .bench-grid { display: grid; grid-template-columns: 1.32fr 0.68fr; gap: 56px; align-items: start; }
  .bench .eyebrow { color: var(--coral); }
  .btable { margin: 0; width: 100%; border-collapse: collapse; border: 1.5px solid var(--ink); border-radius: var(--r-md); overflow: hidden; background: var(--paper); }
  .btable th, .btable td { text-align: left; padding: 16px 20px; font-size: 15.5px; border-bottom: 1px solid var(--line); }
  .btable thead th { font-family: var(--mono); font-size: 12px; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase; color: var(--muted); background: var(--paper-2); }
  .btable td:last-child, .btable th:last-child { text-align: right; }
  .btable .cond { font-weight: 700; }
  .btable .what { color: var(--ink-soft); font-size: 14.5px; }
  .btable .pct { font-family: var(--mono); font-weight: 600; font-size: 18px; }
  .btable tr.bare td { background: var(--paper); }
  .btable tr.win td { background: var(--violet-t); }
  .btable tr.win .cond { color: var(--violet-d); }
  .btable tr.win .pct { color: var(--violet-d); }
  .btable tr.oracle td { color: var(--muted); }
  .btable tr.oracle .pct { color: var(--ink-soft); }
  .btable tr:last-child td { border-bottom: none; }
  .bench-bars { margin-top: 22px; display: grid; gap: 12px; }
  .bbar { display: grid; grid-template-columns: 96px 1fr 56px; gap: 14px; align-items: center; }
  .bbar .bl { font-family: var(--mono); font-size: 12.5px; color: var(--ink-soft); }
  .bbar .track { height: 14px; border-radius: var(--r-pill); background: rgba(30,27,22,0.07); overflow: hidden; }
  .bbar .fill { height: 100%; border-radius: var(--r-pill); }
  .bbar.bare .fill { background: var(--muted); width: 47.6%; }
  .bbar.win .fill { background: var(--violet); width: 62%; }
  .bbar.oracle .fill { background: var(--amber); width: 100%; }
  .bbar .bv { font-family: var(--mono); font-size: 13px; font-weight: 600; text-align: right; }
  .bench-body p { font-size: 17px; line-height: 1.55; color: var(--ink-soft); font-weight: 500; max-width: 620px; text-wrap: pretty; margin: 28px 0 0; }
  .bench-body p b { color: var(--ink); font-weight: 700; }
  .bench-note { font-family: var(--mono); font-size: 13px; color: var(--muted); line-height: 1.55; margin: 20px 0 0; max-width: 620px; }
  .bench-art { background: var(--amber-t); border: 1.5px solid var(--ink); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-card); aspect-ratio: 1 / 1; }
  .bench-art image-slot { width: 100%; height: 100%; display: block; }
  .bench-cap { font-family: var(--mono); font-size: 12.5px; color: var(--muted); margin: 14px 2px 0; line-height: 1.5; }

  /* ---------- privacy ---------- */
  .grid3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 24px; }
  .vcard { border: 1.5px solid var(--line); border-radius: var(--r-lg); padding: 34px 30px 36px; box-shadow: var(--shadow-card); position: relative; overflow: hidden; background: var(--paper-2); }
  .vcard.c1 { background: var(--green-t); } .vcard.c2 { background: var(--coral-t); } .vcard.c3 { background: var(--violet-t); }
  .vcard .ic { width: 40px; height: 40px; border-radius: 12px; border: 1.5px solid var(--ink); display: grid; place-items: center; margin-bottom: 18px; }
  .vcard.c1 .ic { background: var(--green); } .vcard.c2 .ic { background: var(--coral); } .vcard.c3 .ic { background: var(--violet); }
  .vcard.c1 .ic::after { content: "→"; font-weight: 800; }
  .vcard.c2 .ic { color: #fff; } .vcard.c2 .ic::after { content: "✕"; font-weight: 800; }
  .vcard.c3 .ic { color: #fff; } .vcard.c3 .ic::after { content: "✓"; font-weight: 800; }
  .vcard h3 { font-size: 21px; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 12px; }
  .vcard p { font-size: 15.5px; line-height: 1.5; margin: 0; font-weight: 500; text-wrap: pretty; color: var(--ink-soft); }
  .vcard p .mono { font-family: var(--mono); font-size: 13.5px; background: rgba(30,27,22,0.05); padding: 1px 6px; border-radius: 5px; }

  /* ---------- install ---------- */
  .install { padding: 88px 0 96px; position: relative; }
  .inst-card { background: var(--ink); color: var(--paper); border: 2px solid var(--ink); border-radius: var(--r-lg); box-shadow: var(--shadow-soft); padding: 60px 56px; position: relative; overflow: hidden; }
  .inst-grid { position: relative; z-index: 2; display: grid; grid-template-columns: 1.25fr 0.75fr; gap: 48px; align-items: center; }
  .inst-card .eyebrow { color: var(--amber); }
  .inst-card h2 { color: var(--paper); }
  .inst-card .lede { color: #C9C4BA; font-size: 18px; line-height: 1.5; margin: 16px 0 0; max-width: 460px; font-weight: 500; }
  .code-list { display: grid; gap: 14px; margin: 30px 0 0; }
  .code-block { background: rgba(247,243,235,0.06); border: 1px solid rgba(247,243,235,0.18); border-radius: var(--r-md); padding: 16px 18px; }
  .code-block .cl { font-family: var(--mono); font-size: 11.5px; letter-spacing: 0.08em; text-transform: uppercase; color: var(--muted); margin: 0 0 8px; }
  .code-block .cl b { color: var(--amber); font-weight: 700; }
  .code-sub { font-family: var(--mono); font-size: 12px; color: var(--muted); margin: 8px 0 0; }
  .code-sub code { color: #C9C4BA; }
  .fallback { margin: 14px 0 0; background: rgba(247,243,235,0.04); border: 1px dashed rgba(247,243,235,0.24); border-radius: var(--r-md); padding: 16px 18px; }
  .fallback .fl-q { font-size: 14.5px; line-height: 1.5; color: #C9C4BA; font-weight: 600; margin: 0 0 12px; }
  .fallback .fl-q b { color: var(--paper); }
  .prompt-line { display: flex; align-items: flex-start; gap: 12px; justify-content: space-between; background: rgba(247,243,235,0.06); border: 1px solid rgba(247,243,235,0.16); border-radius: 12px; padding: 13px 15px; }
  .prompt-line code { font-family: var(--mono); font-size: 13px; line-height: 1.55; color: var(--paper); white-space: pre-wrap; }
  .code-line { display: flex; align-items: center; gap: 12px; justify-content: space-between; }
  .code-line code { font-family: var(--mono); font-size: 15px; color: var(--paper); }
  .code-line code .pr { color: var(--green); }
  .copy-btn { flex: none; font-family: var(--mono); font-size: 11.5px; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase; color: #C9C4BA; background: transparent; border: 1px solid rgba(247,243,235,0.24); border-radius: var(--r-pill); padding: 6px 12px; cursor: pointer; transition: all .14s ease; }
  .copy-btn:hover { color: var(--ink); background: var(--amber); border-color: var(--amber); }
  .inst-then { font-size: 15.5px; line-height: 1.55; color: #C9C4BA; margin: 26px 0 0; max-width: 500px; font-weight: 500; }
  .inst-then code { font-family: var(--mono); font-size: 13.5px; color: var(--amber); background: rgba(247,243,235,0.07); padding: 2px 7px; border-radius: 6px; }
  .inst-tagline { display: inline-flex; align-items: center; gap: 9px; font-family: var(--mono); font-size: 13px; color: var(--paper); background: rgba(247,243,235,0.08); border: 1px solid rgba(247,243,235,0.2); border-radius: var(--r-pill); padding: 9px 16px; margin: 26px 0 0; }
  .inst-tagline .dot { width: 8px; height: 8px; border-radius: 50%; background: var(--green); }
  .inst-cta { margin-top: 30px; }
  .inst-art { position: relative; }
  .inst-art .slot-card { background: rgba(247,243,235,0.08); border: 2px solid rgba(247,243,235,0.7); border-radius: var(--r-md); overflow: hidden; aspect-ratio: 1 / 1; }

  /* ---------- footer ---------- */
  footer { border-top: 1px solid var(--line); }
  .foot { display: flex; justify-content: space-between; align-items: center; gap: 18px; padding: 30px 0; font-family: var(--mono); font-size: 13px; color: var(--muted); flex-wrap: wrap; }
  .foot .fl { display: flex; align-items: center; gap: 11px; }
  .foot .fl .mark { width: 26px; height: 26px; }
  .foot .fl b { color: var(--ink-soft); font-weight: 600; }
  .foot a { color: var(--ink-soft); text-decoration: none; }
  .foot a:hover { color: var(--violet); }

  @media (max-width: 920px) {
    .nav-links { gap: 16px; }
    .nav-links .nl { display: none; }
    .hero-grid { grid-template-columns: 1fr; gap: 30px; }
    .hero-art { max-width: 380px; }
    .steps { grid-template-columns: 1fr; }
    .grid3 { grid-template-columns: 1fr; }
    .bench-grid { grid-template-columns: 1fr; gap: 40px; }
    .bench-art { max-width: 360px; }
    .inst-grid { grid-template-columns: 1fr; gap: 36px; }
    .inst-art { max-width: 300px; }
    .inst-card { padding: 44px 30px; }
  }
  @media (max-width: 560px) {
    .btable th, .btable td { padding: 12px 13px; font-size: 14px; }
    .btable .what { display: none; }
  }

  /* de-bundled: real <img> fills the slot-card like the old image-slot */
  .slot-img { width: 100%; height: 100%; object-fit: cover; display: block; }

  /* ================= SECURITY ================= */
  #security .vcard a { color: var(--violet-d); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1.5px; }
  #security .vcard a:hover { color: var(--violet); }
  #security .vcard p b { color: var(--ink); font-weight: 700; }
  .sec-note { margin: 30px 0 0; border: 1.5px solid var(--coral); border-left: 4px solid var(--coral); border-radius: var(--r-md); background: var(--coral-t); padding: 18px 22px; font-size: 15px; line-height: 1.55; color: var(--ink-soft); font-weight: 500; text-wrap: pretty; }
  .sec-note b { color: var(--ink); font-weight: 700; }
  .sec-note i { font-style: italic; color: var(--ink); }
  /* ================= PORTED: --paper-dim (undefined in source) ================= */
  :root { --paper-dim: #F1EBDF; }

  /* ================= PORTED: PROBLEM (the way it works today) ================= */
  .problem { background: var(--paper-dim); border-top: 1px solid var(--line); border-bottom: 1px solid var(--line); padding: 96px 0; }
  .prob-grid { display: grid; grid-template-columns: 0.92fr 1.08fr; gap: 64px; align-items: center; }
  .prob-stat { font-size: clamp(60px, 8vw, 104px); font-weight: 800; letter-spacing: -0.04em; line-height: 0.9; margin: 26px 0 14px; }
  .prob-stat .plus { color: var(--coral); }
  .prob-cap { font-size: 16px; line-height: 1.5; color: var(--ink-soft); max-width: 380px; font-weight: 500; font-family: var(--mono); }
  .todo { position: relative; background: var(--paper-2); border: 1.5px solid var(--line); border-radius: var(--r-lg); padding: 32px 34px 30px; box-shadow: var(--shadow-soft); transform: rotate(-0.8deg); }
  .todo .todo-lbl { font-family: var(--mono); font-size: 12.5px; font-weight: 600; letter-spacing: 0.1em; text-transform: uppercase; color: var(--muted); margin: 0 0 8px; }
  .todo ul { list-style: none; margin: 0; padding: 0; }
  .todo li { display: flex; gap: 15px; align-items: flex-start; padding: 16px 0; border-bottom: 1.5px dashed var(--line); }
  .todo li:last-child { border-bottom: none; }
  .todo .box { flex: none; width: 24px; height: 24px; border: 2px solid var(--ink); border-radius: 7px; margin-top: 1px; display: grid; place-items: center; font-size: 14px; }
  .todo .tx { font-size: 17.5px; font-weight: 600; line-height: 1.3; }
  .todo .tx small { display: block; font-size: 14px; font-weight: 500; color: var(--muted); margin-top: 3px; }
  .todo li.never .tx { color: var(--muted); }
  .todo li.never .box { border-style: dashed; border-color: var(--muted); }
  .stamp { position: absolute; top: 18px; right: -10px; transform: rotate(7deg); font-family: var(--mono); font-size: 14px; font-weight: 700; letter-spacing: 0.06em; text-transform: uppercase; color: var(--coral); border: 2.5px solid var(--coral); border-radius: 8px; padding: 6px 12px; background: var(--paper-2); opacity: 0.9; }

  /* ================= PORTED: ENTERPRISE/SECURITY ================= */
  .ent { padding: 0 0 100px; }
  .ent-grid { display: grid; grid-template-columns: 1.02fr 0.98fr; gap: 60px; align-items: start; }
  .ent-right { display: flex; flex-direction: column; gap: 22px; }
  .ent-illo { background: var(--coral-t); border: 1.5px solid var(--ink); border-radius: var(--r-lg); overflow: hidden; aspect-ratio: 16 / 10; box-shadow: var(--shadow-card); }
  .ent .eyebrow { color: var(--coral); }
  .glist { margin: 36px 0 0; display: grid; gap: 4px; }
  .gitem { display: grid; grid-template-columns: 30px 1fr; gap: 16px; padding: 20px 0; border-top: 1px solid var(--line); align-items: start; }
  .gitem .gn { width: 30px; height: 30px; border-radius: 9px; border: 1.5px solid var(--ink); display: grid; place-items: center; font-weight: 800; font-size: 14px; }
  .gitem.g1 .gn { background: var(--violet); color: #fff; } .gitem.g2 .gn { background: var(--green); } .gitem.g3 .gn { background: var(--sky); }
  .gitem h4 { font-size: 19px; font-weight: 800; letter-spacing: -0.015em; margin: 2px 0 6px; }
  .gitem p { font-size: 15.5px; line-height: 1.5; color: var(--ink-soft); margin: 0; font-weight: 500; text-wrap: pretty; }
  #security .gitem a { color: var(--violet-d); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; text-decoration-thickness: 1.5px; }
  #security .gitem a:hover { color: var(--violet); }
  .registry { background: var(--ink); color: var(--paper); border-radius: var(--r-lg); overflow: hidden; box-shadow: var(--shadow-soft); border: 1.5px solid var(--ink); }
  .reg-top { display: flex; align-items: center; gap: 10px; padding: 16px 24px; border-bottom: 1px solid rgba(247,243,235,0.14); font-family: var(--mono); font-size: 13px; color: #C9C4BA; }
  .reg-top .dd { width: 9px; height: 9px; border-radius: 50%; background: var(--green); flex: none; }
  .reg-body { padding: 12px 24px 18px; }
  .reg-row { display: grid; grid-template-columns: 1fr auto; gap: 14px; align-items: center; padding: 13px 0; border-bottom: 1px solid rgba(247,243,235,0.1); font-family: var(--mono); font-size: 14px; }
  .reg-row:last-child { border-bottom: none; }
  .reg-row .nm { color: var(--paper); }
  .reg-row .nm .v { color: var(--muted); margin-left: 8px; }
  .reg-badges { display: flex; gap: 7px; }
  .rb { font-family: var(--mono); font-size: 11.5px; font-weight: 500; padding: 4px 10px; border-radius: var(--r-pill); border: 1px solid rgba(247,243,235,0.22); color: #C9C4BA; white-space: nowrap; }
  .rb.ok { color: oklch(0.82 0.12 158); border-color: oklch(0.6 0.12 158 / 0.5); }
  .reg-foot { padding: 16px 24px; background: rgba(247,243,235,0.05); border-top: 1px solid rgba(247,243,235,0.14); font-family: var(--mono); font-size: 13px; color: #C9C4BA; display: flex; justify-content: space-between; gap: 14px; }
  .reg-foot b { color: var(--amber); font-weight: 600; }

  @media (max-width: 920px) {
    .prob-grid { grid-template-columns: 1fr; gap: 40px; }
    .ent-grid { grid-template-columns: 1fr; gap: 40px; }
  }
  /* ================= decorative blobs on mid-page sections ================= */
  .problem { position: relative; overflow: hidden; }
  #privacy { overflow: hidden; }
  #security { position: relative; overflow: hidden; }
  .problem > .wrap, #privacy > .wrap, #security > .wrap { position: relative; z-index: 2; }