    :root {
      /* Reclar green design system (matches the app). Variable names kept for
         minimal churn; values remapped from the old cobalt/paper palette. */
      --paper: oklch(98.6% 0.003 255);
      --paper-2: oklch(96% 0.004 255);
      --ink: oklch(24% 0.02 262);
      --ink-2: oklch(46% 0.016 262);
      --ink-3: oklch(53% 0.014 262);
      --line: oklch(91% 0.006 255);
      --cobalt: oklch(57% 0.12 195);
      --cobalt-ink: oklch(47% 0.11 195);
      --delivered: oklch(58% 0.13 155);
      --amber: oklch(70% 0.13 75);
      --radius: 14px;
      --maxw: 1120px;
      --font-display: "Schibsted Grotesk", system-ui, sans-serif;
      --font-body: "Schibsted Grotesk", system-ui, sans-serif;
      --font-mono: "JetBrains Mono", ui-monospace, monospace;
    }
    * { box-sizing: border-box; margin: 0; padding: 0; }
    html { scroll-behavior: smooth; }
    body {
      font-family: var(--font-body);
      color: var(--ink);
      background: var(--paper);
      line-height: 1.55;
      -webkit-font-smoothing: antialiased;
      overflow-x: hidden;
    }
    a { color: inherit; text-decoration: none; }
    .wrap { max-width: var(--maxw); margin: 0 auto; padding: 0 28px; }

    nav, footer { position: relative; z-index: 1; }

    /* ---------- Nav ---------- */
    nav {
      display: flex; align-items: center; justify-content: space-between;
      max-width: var(--maxw); margin: 0 auto; padding: 22px 28px;
    }
    .brand { font-family: var(--font-display); font-weight: 700; font-size: 1.4rem; letter-spacing: -0.02em; display: inline-flex; align-items: center; gap: 9px; }
    .brand .mark { width: 30px; height: 30px; border-radius: 8px; background: var(--cobalt); color: #fff; display: inline-grid; place-items: center; font-family: var(--font-mono); font-weight: 700; font-size: 1.05rem; }
    .brand-lock { display: inline-flex; flex-direction: column; line-height: 1; gap: 2px; }
    .brand-name { font-weight: 700; }
    .brand-tag { font-size: 0.58em; font-weight: 600; letter-spacing: 0.12em; text-transform: uppercase; color: var(--ink-3); }
    .brand .dot { color: var(--cobalt); }
    .nav-actions { display: flex; align-items: center; gap: 10px; }
    .btn {
      font-family: var(--font-body); font-size: 0.95rem; font-weight: 500;
      padding: 10px 18px; border-radius: 999px; border: 1px solid transparent;
      cursor: pointer; transition: transform .12s ease, background .15s ease, box-shadow .15s ease, color .15s ease;
      display: inline-flex; align-items: center; gap: 8px; white-space: nowrap;
    }
    .btn-ghost { color: var(--ink); border-color: var(--line); background: transparent; }
    .btn-ghost:hover { background: var(--paper-2); }
    .btn-solid { background: var(--ink); color: var(--paper); }
    .btn-solid:hover { transform: translateY(-1px); box-shadow: 0 8px 22px rgba(22,20,14,.18); }
    .btn-cobalt { background: var(--cobalt); color: #fff; }
    .btn-cobalt:hover { transform: translateY(-1px); box-shadow: 0 10px 26px color-mix(in oklch, var(--cobalt) 34%, transparent); }
    .btn-lg { padding: 14px 26px; font-size: 1.02rem; }
    .btn:focus-visible, .nav-actions a:focus-visible, .links a:focus-visible, .brand:focus-visible {
      outline: none; box-shadow: 0 0 0 3px color-mix(in oklch, var(--cobalt) 32%, transparent); border-radius: 999px;
    }

    /* ---------- Hero ---------- */
    .hero { padding-block: 56px 64px; }
    .hero-grid { display: grid; grid-template-columns: 1.05fr 0.95fr; gap: 56px; align-items: center; }
    .eyebrow {
      font-family: var(--font-mono); font-size: 0.78rem; letter-spacing: 0.14em; text-transform: uppercase;
      color: var(--cobalt-ink); display: inline-flex; align-items: center; gap: 9px; margin-bottom: 22px;
    }
    .eyebrow::before { content: ""; width: 26px; height: 1px; background: var(--cobalt); }
    h1 {
      font-family: var(--font-display); font-weight: 800; letter-spacing: -0.035em;
      font-size: clamp(2.4rem, 5.1vw, 3.9rem); line-height: 1.07; color: var(--ink);
    }
    h1 em { font-style: italic; color: var(--cobalt); }
    .lede { font-size: 1.15rem; color: var(--ink-2); margin: 24px 0 8px; max-width: 32em; }
    .lede code { font-family: var(--font-mono); font-size: 0.92em; background: var(--paper-2); padding: 1px 6px; border-radius: 6px; color: var(--ink); }
    .hero-cta { display: flex; gap: 12px; margin-top: 30px; flex-wrap: wrap; }
    .hero-note { margin-top: 18px; font-size: 0.9rem; color: var(--ink-3); display: flex; align-items: center; gap: 8px; }
    .hero-note .tick { color: var(--delivered); font-weight: 600; }

    /* ---------- Inbox demo ---------- */
    .demo {
      background: #fff; border: 1px solid var(--line); border-radius: var(--radius);
      box-shadow: 0 30px 60px -30px rgba(22,20,14,.28), 0 2px 0 var(--line);
      overflow: hidden; transform: rotate(0.6deg);
    }
    .demo-bar { display: flex; align-items: center; gap: 8px; padding: 13px 16px; border-bottom: 1px solid var(--line); background: var(--paper); }
    .demo-bar .lamp { width: 11px; height: 11px; border-radius: 50%; background: var(--line); }
    .demo-bar .lamp.a { background: #f0a8a0; } .demo-bar .lamp.b { background: #f0cf8f; } .demo-bar .lamp.c { background: #a8d8b0; }
    .demo-bar .addr {
      margin-left: 10px; font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink-2);
      background: var(--paper-2); border-radius: 6px; padding: 4px 10px; flex: 1;
    }
    .demo-bar .addr b { color: var(--cobalt-ink); }
    .row {
      display: grid; grid-template-columns: auto 1fr auto; gap: 12px; align-items: center;
      padding: 14px 18px; border-bottom: 1px solid var(--line);
      opacity: 0; transform: translateY(8px); animation: drop .5s cubic-bezier(.2,.7,.3,1) forwards;
    }
    .row:last-child { border-bottom: 0; }
    .row .pin { width: 30px; height: 30px; border-radius: 8px; background: var(--paper-2); display: grid; place-items: center; color: var(--ink-3); font-size: 13px; }
    .row.new .pin { background: rgba(20,137,79,.12); color: var(--delivered); }
    .row .meta .to { font-family: var(--font-mono); font-size: 0.78rem; color: var(--cobalt-ink); }
    .row .meta .sub { font-size: 0.92rem; color: var(--ink); font-weight: 450; }
    .row .when { font-size: 0.76rem; color: var(--ink-3); white-space: nowrap; }
    .row .pill { font-size: 0.7rem; font-family: var(--font-mono); padding: 2px 8px; border-radius: 999px; background: rgba(20,137,79,.1); color: var(--delivered); }
    .row:nth-child(2) { animation-delay: .25s; }
    .row:nth-child(3) { animation-delay: .45s; }
    .row:nth-child(4) { animation-delay: .65s; }
    .row:nth-child(5) { animation-delay: 1.4s; }
    @keyframes drop { to { opacity: 1; transform: translateY(0); } }
    @media (prefers-reduced-motion: reduce) { .row { animation: none; opacity: 1; transform: none; } }

    /* ---------- Trust strip ---------- */
    .trust { border-block: 1px solid var(--line); background: color-mix(in oklch, var(--paper-2) 60%, transparent); }
    .trust-row { display: flex; flex-wrap: wrap; gap: 14px 34px; padding: 20px 0; justify-content: center; }
    .trust-row .t { display: inline-flex; align-items: center; gap: 9px; font-size: 0.92rem; color: var(--ink-2); }
    .trust-row .t .tick { color: var(--delivered); font-weight: 700; }

    /* ---------- Section scaffolding ---------- */
    section.wrap { padding-block: 92px; }
    .sec-eyebrow { font-family: var(--font-mono); font-size: 0.76rem; letter-spacing: 0.14em; text-transform: uppercase; color: var(--ink-3); margin-bottom: 14px; }
    h2 { font-family: var(--font-display); font-weight: 700; letter-spacing: -0.02em; font-size: clamp(1.9rem, 3.6vw, 2.7rem); line-height: 1.14; }
    .sec-lede { color: var(--ink-2); font-size: 1.08rem; max-width: 34em; margin-top: 18px; }

    /* ---------- Use cases ---------- */
    .uc-flagship {
      margin-top: 52px; background: #fff; border: 1px solid var(--line); border-radius: 18px;
      display: grid; grid-template-columns: 1.15fr 0.85fr; gap: 40px; padding: 40px;
      position: relative; overflow: hidden;
    }
    .uc-flagship::before { content: ""; position: absolute; left: 0; top: 0; bottom: 0; width: 4px; background: var(--cobalt); }
    .uc-tag { display: inline-block; font-family: var(--font-mono); font-size: 0.66rem; font-weight: 700; letter-spacing: 0.1em; text-transform: uppercase; color: #fff; background: var(--cobalt); border-radius: 999px; padding: 3px 10px; margin-bottom: 14px; }
    .uc-flagship h3 { font-family: var(--font-display); font-size: 1.55rem; font-weight: 700; letter-spacing: -0.02em; margin-bottom: 12px; }
    .uc-flagship p { color: var(--ink-2); font-size: 1.02rem; max-width: 34em; }
    .uc-flagship ul { list-style: none; margin-top: 20px; display: grid; gap: 12px; }
    .uc-flagship li { display: flex; gap: 10px; align-items: flex-start; color: var(--ink-2); font-size: 0.98rem; }
    .uc-flagship li .tick { color: var(--delivered); font-weight: 700; flex-shrink: 0; }
    .uc-aside { background: var(--paper); border: 1px solid var(--line); border-radius: 12px; padding: 18px; align-self: center; }
    .uc-aside .cap { font-size: 0.78rem; color: var(--ink-3); text-transform: uppercase; letter-spacing: 0.1em; font-family: var(--font-mono); margin-bottom: 12px; }
    .uc-aside .achip { display: block; font-family: var(--font-mono); font-size: 0.82rem; color: var(--ink); background: #fff; border: 1px solid var(--line); border-radius: 8px; padding: 9px 12px; margin-bottom: 9px; }
    .uc-aside .achip b { color: var(--cobalt-ink); }
    .uc-aside .achip .rsvp { float: right; color: var(--delivered); }
    .uc-row { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 22px; }
    .uc { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 28px 26px; }
    .uc .ic { width: 38px; height: 38px; border-radius: 10px; background: var(--paper); border: 1px solid var(--line); display: grid; place-items: center; margin-bottom: 14px; color: var(--cobalt); }
    .uc h3 { font-size: 1.15rem; font-weight: 600; letter-spacing: -0.01em; margin-bottom: 8px; }
    .uc p { color: var(--ink-2); font-size: 0.96rem; }

    /* steps */
    .steps { display: grid; grid-template-columns: repeat(3, 1fr); gap: 22px; margin-top: 52px; }
    .step { background: #fff; border: 1px solid var(--line); border-radius: var(--radius); padding: 26px 24px; position: relative; }
    .step .n { font-family: var(--font-display); font-size: 2.4rem; color: var(--paper-2); position: absolute; top: 14px; right: 20px; line-height: 1; font-weight: 600; }
    .step h3 { font-size: 1.15rem; font-weight: 600; margin-bottom: 8px; letter-spacing: -0.01em; }
    .step p { color: var(--ink-2); font-size: 0.96rem; }
    .step .ex { font-family: var(--font-mono); font-size: 0.82rem; margin-top: 12px; color: var(--cobalt-ink); background: var(--paper); border: 1px solid var(--line); border-radius: 8px; padding: 8px 10px; display: inline-block; }

    /* catch-all band */
    .band { background: var(--ink); color: var(--paper); border-radius: 20px; padding: 56px 48px; text-align: center; position: relative; overflow: hidden; }
    .band::after { content: ""; position: absolute; inset: 0; background-image: radial-gradient(rgba(255,255,255,.06) 1px, transparent 1px); background-size: 22px 22px; }
    .band > * { position: relative; }
    .band h2 { color: var(--paper); }
    .band p { color: #c9c4b6; max-width: 38em; margin: 16px auto 0; font-size: 1.06rem; }
    .band .addrs { display: flex; flex-wrap: wrap; gap: 10px; justify-content: center; margin-top: 26px; }
    .band .chip { font-family: var(--font-mono); font-size: 0.84rem; padding: 7px 13px; border-radius: 999px; border: 1px solid rgba(255,255,255,.16); color: var(--paper); }
    .band .chip b { color: #7be0a8; }

    /* features */
    .features { display: grid; grid-template-columns: repeat(3, 1fr); gap: 1px; background: var(--line); border: 1px solid var(--line); border-radius: var(--radius); overflow: hidden; margin-top: 52px; }
    .feat { background: var(--paper); padding: 34px 26px; }
    .feat .ic { width: 38px; height: 38px; border-radius: 10px; background: #fff; border: 1px solid var(--line); display: grid; place-items: center; margin-bottom: 16px; color: var(--cobalt); }
    .feat h3 { font-size: 1.05rem; font-weight: 600; margin-bottom: 7px; letter-spacing: -0.01em; }
    .new-pill {
      display: inline-block; vertical-align: 2px; margin-left: 6px;
      font-family: var(--font-mono); font-size: 0.62rem; font-weight: 700; letter-spacing: 0.08em;
      color: #fff; background: var(--cobalt); border-radius: 999px; padding: 2px 8px;
    }
    .feat p { color: var(--ink-2); font-size: 0.93rem; }

    /* ---- product tour + carousel ---- */
    .tour h2 { max-width: 20em; }

    /* browser-chrome frame */
    .shot {
      width: 100%;
      border: 1px solid var(--line);
      border-radius: var(--radius);
      overflow: hidden;
      box-shadow: 0 24px 56px -24px rgba(22,20,14,.22), 0 2px 0 var(--line);
      background: #fff;
    }
    .shot-bar {
      display: flex;
      align-items: center;
      gap: 6px;
      padding: 10px 14px;
      border-bottom: 1px solid var(--line);
      background: var(--paper);
    }
    .shot-lamp {
      width: 10px; height: 10px; border-radius: 50%; background: var(--line);
      flex-shrink: 0;
    }
    .shot-lamp.a { background: #f0a8a0; }
    .shot-lamp.b { background: #f0cf8f; }
    .shot-lamp.c { background: #a8d8b0; }
    .shot-addr {
      margin-left: 8px;
      flex: 1;
      height: 22px;
      background: var(--paper-2);
      border-radius: 5px;
      border: 1px solid var(--line);
    }
    .shot img {
      display: block;
      width: 100%;
      height: auto;
    }

    /* carousel shell */
    .carousel {
      position: relative;
      margin-top: 52px;
    }
    .carousel-viewport {
      overflow: hidden;
      border-radius: var(--radius);
    }
    .carousel-track {
      display: flex;
      transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1);
      will-change: transform;
    }

    /* each slide: image beside text, 2-col grid */
    .carousel-slide {
      min-width: 100%;
      display: grid;
      grid-template-columns: 1fr 1fr;
      gap: 48px;
      align-items: center;
      padding: 12px 0 48px;
    }
    .carousel-media {
      min-width: 0;
    }
    .carousel-text {
      min-width: 0;
      padding: 0 8px;
    }
    .carousel-text h3 {
      font-family: var(--font-display);
      font-size: 1.55rem;
      font-weight: 700;
      letter-spacing: -0.02em;
      line-height: 1.2;
      margin-bottom: 14px;
      color: var(--ink);
    }
    .carousel-text p {
      font-size: 1.05rem;
      line-height: 1.6;
      color: var(--ink-2);
    }

    /* prev/next arrows */
    .carousel-arrow {
      position: absolute;
      bottom: 0;
      width: 38px;
      height: 38px;
      border-radius: 50%;
      border: 1px solid var(--line);
      background: var(--paper);
      color: var(--ink);
      font-size: 1.4rem;
      line-height: 1;
      cursor: pointer;
      display: grid;
      place-items: center;
      transition: background 0.15s ease, border-color 0.15s ease;
      z-index: 2;
    }
    .carousel-arrow:hover { background: var(--paper-2); border-color: var(--ink-3); }
    .carousel-prev { right: 50px; }
    .carousel-next { right: 4px; }

    /* dot indicators */
    .carousel-dots {
      display: flex;
      align-items: center;
      justify-content: center;
      gap: 8px;
      padding-bottom: 6px;
    }
    .carousel-dot {
      width: 8px;
      height: 8px;
      border-radius: 50%;
      border: none;
      background: var(--line);
      cursor: pointer;
      padding: 0;
      transition: background 0.2s ease, transform 0.2s ease;
      flex-shrink: 0;
    }
    .carousel-dot.is-active {
      background: var(--cobalt);
      transform: scale(1.3);
    }
    .carousel-dot:focus-visible {
      outline: 2px solid var(--cobalt);
      outline-offset: 2px;
    }

    @media (prefers-reduced-motion: reduce) {
      .carousel-track { transition: none; }
    }

    /* pricing */
    .price-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 20px; margin-top: 52px; align-items: stretch; }
    .price { border: 1px solid var(--line); border-radius: var(--radius); padding: 34px 30px; background: #fff; display: flex; flex-direction: column; }
    .price.pro { background: var(--ink); color: var(--paper); border-color: var(--ink); }
    .price .tier { font-family: var(--font-mono); font-size: 0.8rem; letter-spacing: 0.1em; text-transform: uppercase; color: var(--ink-3); }
    .price.pro .tier { color: #7be0a8; }
    .price .amt { font-family: var(--font-display); font-size: 2.4rem; font-weight: 800; margin: 12px 0 4px; letter-spacing: -0.02em; }
    .price .amt small { font-family: var(--font-body); font-size: 1rem; color: var(--ink-3); font-weight: 400; }
    .price-alt { font-size: 0.9rem; color: var(--ink-3); margin: 0 0 4px; min-height: 1.1em; }
    .price.pro .price-alt { color: #c9c4b6; }
    .price.pro .amt small { color: #c9c4b6; }
    .price ul { list-style: none; margin: 20px 0 26px; display: grid; gap: 11px; }
    .price li { display: flex; gap: 10px; align-items: flex-start; font-size: 0.94rem; color: var(--ink-2); }
    .price.pro li { color: #d8d3c5; }
    .price li .tick { color: var(--delivered); font-weight: 700; flex-shrink: 0; }
    .price.pro li .tick { color: #6ee0a3; }
    .price li code { font-family: var(--font-mono); font-size: 0.9em; }
    .price .btn { width: 100%; justify-content: center; margin-top: auto; }
    .price .btn-outline { border-color: var(--line); color: var(--ink); background: transparent; }
    .price .btn-outline:hover { background: var(--paper-2); }

    /* value comparison */
    .compare { display: grid; grid-template-columns: 1fr 1fr; gap: 22px; margin-top: 52px; }
    .compare-col { border: 1px solid var(--line); border-radius: var(--radius); padding: 30px 28px; background: #fff; }
    .compare-col.manual { background: var(--paper-2); }
    .compare-col.with { border-color: color-mix(in oklch, var(--cobalt) 40%, var(--line)); box-shadow: 0 12px 34px -20px color-mix(in oklch, var(--cobalt) 55%, transparent); }
    .compare-col h3 { font-size: 1.08rem; font-weight: 600; margin-bottom: 18px; letter-spacing: -0.01em; }
    .compare-col.manual h3 { color: var(--ink-3); }
    .compare-col ul { list-style: none; display: grid; gap: 14px; }
    .compare-col li { display: flex; gap: 11px; align-items: flex-start; font-size: 0.96rem; }
    .compare-col.manual li { color: var(--ink-3); }
    .compare-col.with li { color: var(--ink-2); }
    .compare-col .mk { flex-shrink: 0; font-weight: 700; line-height: 1.5; }
    .compare-col.manual .mk { color: var(--ink-3); }
    .compare-col.with .mk { color: var(--delivered); }
    .compare-note { text-align: center; color: var(--ink-2); font-size: 1.04rem; margin: 30px auto 0; max-width: 42em; }

    /* footer */
    footer { border-top: 1px solid var(--line); margin-top: 40px; }
    .foot { display: flex; align-items: center; justify-content: space-between; padding: 34px 0; flex-wrap: wrap; gap: 16px; }
    .foot .links { display: flex; gap: 22px; font-size: 0.92rem; color: var(--ink-2); flex-wrap: wrap; }
    .foot .links a:hover { color: var(--cobalt); }
    .foot .small { font-size: 0.85rem; color: var(--ink-3); }

    /* ---------- Modals (lead capture + sales) ---------- */
    .lead-overlay {
      position: fixed; inset: 0; z-index: 50; display: none;
      align-items: center; justify-content: center; padding: 24px;
      background: color-mix(in oklch, var(--ink) 45%, transparent);
    }
    .lead-overlay.open { display: flex; }
    .lead-modal {
      background: var(--paper); border: 1px solid var(--line); border-radius: var(--radius);
      box-shadow: 0 30px 60px -30px rgba(22,20,14,.4);
      width: 100%; max-width: 460px; padding: 34px 32px; max-height: 92vh; overflow-y: auto;
    }
    .lead-modal h2 { font-size: 1.5rem; margin-bottom: 6px; }
    .lead-modal .lead-sub { font-size: 0.95rem; color: var(--ink-2); }
    .lead-modal .lead-micro { font-size: 0.85rem; color: var(--ink-3); margin-top: 14px; }
    .lead-field { margin-top: 16px; display: flex; flex-direction: column; gap: 6px; }
    .lead-field label { font-size: 0.88rem; font-weight: 600; color: var(--ink-2); }
    .lead-field input, .lead-field select, .lead-field textarea {
      font-family: var(--font-body); font-size: 0.95rem; color: var(--ink);
      background: #fff; border: 1px solid var(--line); border-radius: 9px; padding: 10px 12px;
    }
    .lead-field textarea { resize: vertical; min-height: 84px; }
    .lead-field input:focus-visible, .lead-field select:focus-visible, .lead-field textarea:focus-visible {
      outline: none; border-color: var(--cobalt);
      box-shadow: 0 0 0 3px color-mix(in oklch, var(--cobalt) 24%, transparent);
    }
    .lead-actions { display: flex; align-items: center; gap: 16px; margin-top: 22px; }
    .lead-skip { font-size: 0.9rem; color: var(--ink-3); text-decoration: underline; cursor: pointer; }
    .lead-skip:hover { color: var(--cobalt); }
    .lead-error { color: oklch(55% 0.2 25); font-size: 0.85rem; margin-top: 12px; min-height: 1em; }
    .lead-success { display: none; text-align: center; padding: 12px 0 4px; }
    .lead-success .ok-mark { width: 46px; height: 46px; border-radius: 50%; background: rgba(20,137,79,.12); color: var(--delivered); display: grid; place-items: center; font-size: 1.4rem; margin: 0 auto 14px; }
    .lead-success h2 { margin-bottom: 8px; }
    .lead-success p { color: var(--ink-2); font-size: 0.96rem; }
    .lead-modal.done .lead-form-body { display: none; }
    .lead-modal.done .lead-success { display: block; }

    @media (max-width: 880px) {
      .hero-grid { grid-template-columns: 1fr; gap: 40px; }
      .demo { transform: none; }
      .steps, .features { grid-template-columns: 1fr; }
      .uc-flagship { grid-template-columns: 1fr; gap: 26px; padding: 30px 26px; }
      .uc-row { grid-template-columns: 1fr; }
      .compare { grid-template-columns: 1fr; }
      .price-grid { grid-template-columns: 1fr; }
      .band { padding: 40px 26px; }
      nav .btn-ghost.hide-sm { display: none; }
      .carousel-slide { grid-template-columns: 1fr; gap: 24px; padding-bottom: 56px; }
      .carousel-text { padding: 0; }
      .shot { border-radius: 10px; }
    }

    /* ---- legal pages ---- */
    .legal-wrap {
      max-width: 760px;
      margin: 48px auto 80px;
      padding: 0 28px;
      line-height: 1.7;
    }
    .legal-wrap h1 { font-size: 1.8rem; margin-bottom: 0.5rem; letter-spacing: -0.02em; }
    .legal-wrap .effective { color: var(--ink-3); font-size: 0.9rem; margin-bottom: 2rem; }
    .legal-wrap h2 { font-size: 1.2rem; font-weight: 600; margin: 2rem 0 0.75rem; color: var(--ink); letter-spacing: -0.01em; }
    .legal-wrap p, .legal-wrap li { margin-bottom: 0.75rem; font-size: 0.95rem; color: var(--ink-2); }
    .legal-wrap ul { padding-left: 1.5rem; }
    .legal-wrap a { color: var(--cobalt-ink); }
    .legal-wrap a:hover { text-decoration: underline; }
    .back {
      display: inline-block; margin-bottom: 1.5rem;
      color: var(--cobalt-ink); text-decoration: none; font-size: 0.9rem;
    }
    .back:hover { text-decoration: underline; }
    .notice {
      background: oklch(97% 0.04 90);
      border: 1px solid oklch(80% 0.1 75);
      border-radius: 8px;
      padding: 1rem 1.25rem;
      margin-bottom: 2rem;
      font-size: 0.9rem;
      color: var(--ink-2);
    }
    .legal-wrap table { width: 100%; border-collapse: collapse; margin: 1rem 0; }
    .legal-wrap th, .legal-wrap td { text-align: left; padding: 0.6rem 0.75rem; border-bottom: 1px solid var(--line); font-size: 0.9rem; color: var(--ink-2); }
    .legal-wrap th { background: var(--paper-2); font-weight: 600; color: var(--ink); }
