
  :root {
    --deep: #14211c;
    --deep-2: #1a2a23;
    --deep-3: #0f1a15;
    --near: #0b1512;
    --green: #2f4a3d;
    --sage: #7f9c82;
    --sage-bright: #aac2ad;
    --mist: #cdd8cf;
    --paper: #f4f6f1;
    --paper-2: #e8ede5;
    --ink: #16241f;
    --ink-soft: #37473e;
    --ink-mute: #55675c;
    --amber: #f4c15d;
    --amber-deep: #e2a63a;
    --amber-soft: #fbe6b5;
    --amber-ink: #2b2308;
    --stamp: #2f7d5a;
    --line-light: rgba(22, 36, 31, 0.16);
    --line-dark: rgba(190, 210, 194, 0.16);
    --press: 4px 4px 0 0 var(--near);
    --press-sm: 3px 3px 0 0 var(--near);
    --press-ink: 4px 4px 0 0 var(--ink);
    --press-ink-sm: 3px 3px 0 0 var(--ink);
    --radius: 16px;
    --radius-sm: 11px;
    --font: "Bricolage Grotesque", "Inter", system-ui, sans-serif;
    --mono: "Martian Mono", ui-monospace, "Cascadia Mono", Consolas, monospace;
  }

  * { box-sizing: border-box; }
  html { scroll-behavior: smooth; }
  html, body { margin: 0; padding: 0; }
  body { background: var(--deep); }
  .sr {
    font-family: var(--font);
    color: var(--paper);
    background: var(--deep);
    min-height: 100vh;
    display: flex;
    flex-direction: column;
    overflow-x: hidden;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
    line-height: 1.6;
  }
  .sr a { color: inherit; text-decoration: none; }
  .sr img, .sr svg { max-width: 100%; }
  .sr :focus-visible { outline: 3px solid var(--amber); outline-offset: 2px; border-radius: 4px; }

  .sr-shell { width: min(1120px, 100% - 3rem); margin-inline: auto; }
  .sr-shell--narrow { width: min(780px, 100% - 3rem); margin-inline: auto; }

  /* ---- buttons: shelf-label stickers ---- */
  .sr-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: 0.5rem;
    font-family: var(--font); font-weight: 700; font-size: 1rem; line-height: 1;
    padding: 0.9rem 1.4rem; border-radius: 999px; cursor: pointer;
    border: 2.5px solid var(--near); white-space: nowrap;
    transition: transform 0.12s ease, box-shadow 0.12s ease, background 0.2s ease;
  }
  .sr-btn--amber { background: var(--amber); color: var(--amber-ink); box-shadow: var(--press-sm); }
  .sr-btn--amber:hover { transform: translate(-2px, -2px); box-shadow: var(--press); background: #f8ce78; }
  .sr-btn--amber:active { transform: translate(2px, 2px); box-shadow: 0 0 0 0 var(--near); }
  .sr-btn--ghost { background: var(--paper); color: var(--ink); box-shadow: var(--press-sm); }
  .sr-btn--ghost:hover { transform: translate(-2px, -2px); box-shadow: var(--press); }
  .sr-btn--ghost:active { transform: translate(2px, 2px); box-shadow: 0 0 0 0 var(--near); }
  .sr-btn--lg { padding: 1.05rem 1.7rem; font-size: 1.05rem; }

  /* ---- kicker: a mono rack label ---- */
  .sr-kicker {
    display: inline-flex; align-items: center; gap: 0.5rem;
    font-family: var(--mono); font-size: 0.72rem; font-weight: 600;
    letter-spacing: 0.14em; text-transform: uppercase; color: var(--amber);
    border: 1.5px dashed var(--amber-deep); padding: 0.42rem 0.8rem;
    border-radius: 999px; transform: rotate(-1deg);
  }
  .sr-kicker--ink { color: var(--stamp); border-color: var(--stamp); }

  /* ---- header ---- */
  .sr-header-wrap {
    position: sticky; top: 0; z-index: 50;
    background: color-mix(in srgb, var(--deep) 82%, transparent);
    backdrop-filter: saturate(160%) blur(10px);
    border-bottom: 2px solid var(--near);
  }
  .sr-header {
    display: flex; align-items: center; justify-content: space-between;
    padding-block: 0.85rem; gap: 1rem;
  }
  .sr-lockup { display: flex; align-items: center; gap: 0.7rem; }
  .sr-tile {
    width: 42px; height: 42px; border-radius: 12px; background: var(--paper);
    display: grid; place-items: center; flex: none;
    border: 2.5px solid var(--near); box-shadow: var(--press-sm);
    transition: transform 0.2s ease;
  }
  .sr-lockup:hover .sr-tile { transform: rotate(-4deg); }
  .sr-tile img { width: 30px; height: 30px; display: block; }
  .sr-name { font-weight: 800; font-size: 1.3rem; letter-spacing: -0.03em; }
  .sr-header-nav { display: flex; align-items: center; gap: 1.5rem; }
  .sr-header-link {
    font-size: 0.95rem; font-weight: 600; color: var(--mist);
    border-bottom: 2px solid transparent; padding-bottom: 2px;
  }
  .sr-header-link:hover { color: var(--paper); border-bottom-color: var(--amber); }
  .sr-header .sr-btn { padding: 0.62rem 1.1rem; font-size: 0.92rem; }
  @media (max-width: 720px) {
    .sr-header-nav { gap: 0.9rem; }
    .sr-header-link.sr-hide-sm { display: none; }
  }

  /* ---- hero ---- */
  .sr-hero {
    padding-block: clamp(2.6rem, 7vh, 5rem) clamp(2.4rem, 6vh, 4rem);
    display: grid; grid-template-columns: 1fr; gap: 2rem; align-items: center;
  }
  @media (min-width: 940px) {
    .sr-hero { grid-template-columns: minmax(0, 1.02fr) minmax(0, 0.98fr); gap: 2.6rem; }
  }
  .sr-hero--compact { padding-block: clamp(2.2rem, 6vh, 4rem) clamp(1.6rem, 4vh, 2.6rem); }
  @media (min-width: 940px) { .sr-hero--compact { grid-template-columns: 1fr; } }
  .sr-hero-copy { min-width: 0; }
  .sr-deadline { margin: 0 0 1.1rem; }
  .sr-hero h1 {
    font-size: clamp(2.5rem, 6vw, 4.1rem);
    line-height: 1.0; letter-spacing: -0.035em; font-weight: 800;
    margin: 0; max-width: 15ch; text-wrap: balance;
  }
  .sr-hero--compact h1 { font-size: clamp(2.1rem, 5vw, 3.3rem); max-width: 20ch; }
  .sr-hl {
    position: relative; white-space: nowrap; display: inline-block;
    transform: rotate(-1.4deg); background: var(--amber); color: var(--amber-ink);
    padding: 0 0.28em; border-radius: 7px; box-shadow: 2px 2px 0 0 var(--near);
  }
  .sr-hero .sr-sub {
    font-size: clamp(1.05rem, 1.8vw, 1.24rem); line-height: 1.55; font-weight: 400;
    color: var(--mist); max-width: 46ch; margin: 1.3rem 0 0; text-wrap: pretty;
  }
  .sr-sub strong { color: var(--paper); font-weight: 600; }
  .sr-hero-art { position: relative; }
  .sr-trust {
    margin-top: 1.3rem; font-size: 0.9rem; color: var(--sage-bright);
    display: flex; align-items: center; gap: 0.55rem;
  }
  .sr-trust svg { color: var(--sage-bright); flex: none; }

  /* ---- install ---- */
  .sr-install { margin-top: 1.8rem; }
  .sr-install-row { display: flex; gap: 0.7rem; flex-wrap: wrap; align-items: center; }
  .sr-fineprint { margin: 0.85rem 0 0; font-size: 0.88rem; color: var(--sage-bright); }

  /* ---- hero scene ---- */
  .sr-scene { display: block; width: 100%; height: auto; user-select: none; overflow: visible; }
  .sr-scene-tag { transform-box: fill-box; transform-origin: 392px 82px; animation: sr-sway 3.6s ease-in-out infinite alternate; }
  @keyframes sr-sway { from { transform: rotate(3deg); } to { transform: rotate(-3deg); } }
  .sr-scene-stamp { transform-box: fill-box; transform-origin: center; animation: sr-stamp 0.6s cubic-bezier(0.2, 1.5, 0.4, 1) both 0.5s; }
  @keyframes sr-stamp { 0% { opacity: 0; transform: scale(2) rotate(-30deg); } 60% { opacity: 1; transform: scale(0.94) rotate(-11deg); } 100% { opacity: 1; transform: rotate(-13deg); } }
  .sr-scene-spark { transform-box: fill-box; transform-origin: center; animation: sr-spark 2.8s ease-in-out infinite; }
  .sr-scene-spark2 { animation-delay: 1.3s; }
  @keyframes sr-spark { 0%, 100% { opacity: 0.3; transform: scale(0.8); } 50% { opacity: 1; transform: scale(1.15) rotate(18deg); } }

  /* ---- marquee ---- */
  .sr-marquee {
    border-top: 2.5px solid var(--near); border-bottom: 2.5px solid var(--near);
    background: var(--amber); color: var(--amber-ink);
    overflow: hidden; padding: 0.72rem 0; transform: rotate(-0.6deg) scale(1.02); margin: 0.5rem 0;
  }
  .sr-marquee-track { display: flex; gap: 2.6rem; width: max-content; animation: sr-roll 30s linear infinite; }
  .sr-marquee:hover .sr-marquee-track { animation-play-state: paused; }
  .sr-marquee span {
    font-family: var(--mono); font-weight: 600; font-size: 0.82rem; letter-spacing: 0.06em;
    text-transform: uppercase; white-space: nowrap; display: inline-flex; align-items: center; gap: 2.6rem;
  }
  .sr-marquee span::after { content: "▪"; font-size: 0.6rem; }
  @keyframes sr-roll { from { transform: translateX(0); } to { transform: translateX(-50%); } }

  /* ---- sections ---- */
  .sr-section { padding-block: clamp(3rem, 8vh, 5.5rem); }
  .sr-head { max-width: 640px; margin: 0 auto clamp(2rem, 5vh, 3rem); text-align: center; }
  .sr-head h2, .sr-manifest h2 {
    font-size: clamp(1.8rem, 3.8vw, 2.7rem); font-weight: 800; letter-spacing: -0.03em;
    margin: 0.8rem 0 0.5rem; line-height: 1.06; text-wrap: balance;
  }
  .sr-head p { font-size: 1.08rem; color: var(--mist); margin: 0; }

  /* ---- light band (manifest / how / compare) ---- */
  .sr-manifest { background: var(--paper); color: var(--ink);
    border-top: 2.5px solid var(--near); border-bottom: 2.5px solid var(--near); }
  .sr-manifest-inner { padding-block: clamp(3rem, 8vh, 5.5rem); }
  .sr-manifest h2 { color: var(--ink); margin: 0 0 0.4rem; text-align: left; }
  .sr-manifest .sr-lede { margin: 0 0 2.4rem; color: var(--ink-soft); font-size: 1.08rem; max-width: 60ch; }

  /* ---- shelf-label cards ---- */
  .sr-labels { display: grid; gap: 1.4rem; grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
  .sr-label {
    position: relative; background: #fff; border: 2.5px solid var(--ink); border-radius: var(--radius);
    padding: 1.7rem 1.4rem 1.4rem; box-shadow: var(--press-ink-sm);
    transition: transform 0.18s ease, box-shadow 0.18s ease;
  }
  .sr-label::before {
    content: ""; position: absolute; top: 0.85rem; left: 1.4rem; width: 12px; height: 12px;
    border-radius: 50%; background: var(--paper-2); border: 2.5px solid var(--ink);
  }
  .sr-label:nth-child(odd) { transform: rotate(-1deg); }
  .sr-label:nth-child(even) { transform: rotate(0.8deg); }
  .sr-label:hover { transform: rotate(0deg) translate(-3px, -3px); box-shadow: var(--press-ink); }
  .sr-label-badge {
    width: 48px; height: 48px; border-radius: 13px; display: grid; place-items: center;
    background: var(--green); color: var(--paper); border: 2.5px solid var(--ink);
    margin-top: 0.6rem;
  }
  .sr-label:nth-child(even) .sr-label-badge { background: var(--amber); color: var(--amber-ink); }
  .sr-label h3 { font-size: 1.22rem; font-weight: 800; letter-spacing: -0.02em; margin: 1rem 0 0.5rem; color: var(--ink); }
  .sr-label p { margin: 0; color: var(--ink-soft); font-size: 0.98rem; line-height: 1.5; }

  /* ---- rows (migrate callout, reused by compare) ---- */
  .sr-rows { margin-top: 1.6rem; }
  .sr-row {
    display: grid; grid-template-columns: minmax(11rem, 15rem) 1fr;
    gap: 0.4rem 2rem; padding: 1.1rem 0.2rem; border-bottom: 1px solid var(--line-light);
  }
  .sr-row-name { font-weight: 700; font-size: 1.08rem; letter-spacing: -0.01em; color: var(--ink); }
  .sr-row-desc { color: var(--ink-soft); line-height: 1.55; margin: 0; max-width: 62ch; align-self: center; }
  .sr-row-desc a { color: var(--stamp); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
  .sr-row--migrate {
    grid-template-columns: 1fr; gap: 0.6rem; align-items: start;
    background: var(--amber-soft); border: 2.5px solid var(--ink); border-radius: var(--radius);
    box-shadow: var(--press-ink-sm); padding: 1.4rem 1.5rem; margin-top: 1.6rem; border-bottom: none;
    transform: rotate(-0.4deg);
  }
  .sr-row--migrate .sr-row-name { display: flex; align-items: center; gap: 0.7rem; flex-wrap: wrap; }
  .sr-tag {
    display: inline-flex; align-items: center; font-family: var(--mono); background: var(--stamp); color: #fff;
    font-size: 0.68rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
    padding: 0.28rem 0.6rem; border-radius: 999px; border: 2px solid var(--ink);
  }

  /* ---- steps: the goods-in slip ---- */
  .sr-steps {
    position: relative; display: grid; grid-template-columns: repeat(3, 1fr); gap: 2rem;
    background: #fff; border: 2.5px solid var(--ink); border-radius: 20px;
    padding: 2.6rem 2.2rem 2.2rem; box-shadow: var(--press-ink); color: var(--ink);
  }
  .sr-steps::before {
    content: "GOODS-IN · SLIP Nº 0043"; position: absolute; top: -0.85rem; left: 1.8rem;
    font-family: var(--mono); font-size: 0.68rem; font-weight: 600; letter-spacing: 0.1em;
    background: var(--amber); color: var(--amber-ink); border: 2.5px solid var(--ink);
    padding: 0.25rem 0.8rem; border-radius: 999px; transform: rotate(-1deg);
  }
  @media (max-width: 800px) { .sr-steps { grid-template-columns: 1fr; gap: 1.6rem; } }
  .sr-step-num {
    width: 50px; height: 50px; border-radius: 50%; display: grid; place-items: center;
    border: 3px dashed var(--stamp); color: var(--stamp); background: transparent;
    font-weight: 800; font-size: 1.35rem; transform: rotate(-7deg);
  }
  .sr-step:nth-child(2) .sr-step-num { border-color: var(--amber-deep); color: var(--amber-deep); transform: rotate(5deg); }
  .sr-step:nth-child(3) .sr-step-num { border-color: var(--green); color: var(--green); transform: rotate(-4deg); }
  .sr-step h3 { font-size: 1.2rem; font-weight: 800; letter-spacing: -0.02em; margin: 1rem 0 0.4rem; color: var(--ink); }
  .sr-step p { margin: 0; color: var(--ink-soft); font-size: 0.98rem; line-height: 1.5; }

  /* ---- checks list ---- */
  .sr-checks { list-style: none; padding: 0; margin: 1.4rem 0 0; display: grid; gap: 0.7rem; }
  .sr-checks li { display: flex; gap: 0.6rem; align-items: flex-start; font-size: 1rem; }
  .sr-checks li .sr-tick { color: var(--stamp); flex: none; margin-top: 2px; }
  .sr-checks li .sr-cross { color: #c65a3f; flex: none; margin-top: 2px; }

  /* ---- split (POS) ---- */
  .sr-split { display: grid; grid-template-columns: 1fr; gap: 2.4rem; align-items: center; }
  @media (min-width: 900px) { .sr-split { grid-template-columns: 1fr 1fr; gap: 3rem; } }
  .sr-split h2 { font-size: clamp(1.7rem, 3.4vw, 2.4rem); font-weight: 800; letter-spacing: -0.03em; margin: 0.7rem 0 0.6rem; line-height: 1.08; }
  .sr-split p { color: var(--mist); font-size: 1.06rem; margin: 0; max-width: 48ch; }
  .sr-split .sr-checks li { color: var(--mist); }
  .sr-frame {
    border: 2.5px solid var(--near); border-radius: 18px; box-shadow: var(--press);
    overflow: hidden; background: var(--deep-2);
  }

  /* ---- callout: boring on purpose ---- */
  .sr-callout {
    position: relative; background: var(--deep-2); border: 2.5px solid var(--near);
    border-radius: var(--radius); box-shadow: var(--press); overflow: hidden;
    display: grid; grid-template-columns: 104px 1fr; gap: 1.8rem; align-items: center;
    padding: 2.2rem 2.3rem;
  }
  @media (max-width: 640px) { .sr-callout { grid-template-columns: 1fr; gap: 1.2rem; } }
  .sr-callout-stamp {
    position: relative; width: 104px; height: 104px; border-radius: 50%;
    border: 3px solid var(--amber); color: var(--amber); display: grid; place-items: center;
    text-align: center; font-family: var(--mono); font-weight: 600; font-size: 0.62rem;
    letter-spacing: 0.1em; text-transform: uppercase; line-height: 1.35; transform: rotate(-11deg);
  }
  .sr-callout-stamp::before { content: ""; position: absolute; inset: 8px; border: 1.5px solid var(--amber); border-radius: 50%; }
  .sr-callout h3 { font-size: 1.5rem; font-weight: 800; letter-spacing: -0.02em; margin: 0 0 0.6rem; }
  .sr-callout p { margin: 0; color: var(--mist); font-size: 1.02rem; line-height: 1.55; }
  .sr-callout p strong { color: var(--amber); }

  /* ---- pricing: the big swing tag ---- */
  .sr-pricetag-wrap { display: grid; place-items: center; }
  .sr-pricetag {
    position: relative; width: min(430px, 100%);
    background: var(--amber); color: var(--amber-ink);
    border: 3px solid var(--near); border-radius: 20px;
    padding: 3.2rem 2.4rem 2.2rem; text-align: center;
    clip-path: polygon(16% 0, 84% 0, 100% 8%, 100% 100%, 0 100%, 0 8%);
    box-shadow: 9px 11px 0 0 var(--near); transform: rotate(-1.4deg);
  }
  .sr-pricetag::before {
    content: ""; position: absolute; left: 50%; top: 0.9rem; width: 20px; height: 20px;
    transform: translateX(-50%); border-radius: 50%; background: var(--deep);
    border: 4px solid var(--near);
  }
  .sr-pricetag-num { font-size: 4rem; font-weight: 800; letter-spacing: -0.04em; line-height: 1; margin-top: 0.5rem; }
  .sr-pricetag-num small { font-size: 1.1rem; font-weight: 700; color: color-mix(in srgb, var(--amber-ink) 68%, transparent); }
  .sr-pricetag-note { font-family: var(--mono); font-size: 0.76rem; font-weight: 600; letter-spacing: 0.04em; margin-top: 0.5rem; color: color-mix(in srgb, var(--amber-ink) 80%, transparent); }
  .sr-pricetag .sr-checks { max-width: 290px; margin: 1.5rem auto 1.6rem; text-align: left; }
  .sr-pricetag .sr-checks li { color: var(--amber-ink); font-weight: 500; border-bottom: 1.5px dashed color-mix(in srgb, var(--amber-ink) 30%, transparent); padding-bottom: 0.6rem; }
  .sr-pricetag .sr-checks li .sr-tick { color: #1f6b49; }
  .sr-pricetag .sr-btn { width: 100%; border-color: var(--amber-ink); box-shadow: 3px 3px 0 0 var(--amber-ink); }
  .sr-pricetag .sr-btn:hover { box-shadow: 4px 4px 0 0 var(--amber-ink); }
  .sr-pricetag-fine { font-size: 0.78rem; margin: 0.9rem 0 0; color: color-mix(in srgb, var(--amber-ink) 76%, transparent); }

  /* ---- price band (compare page) ---- */
  .sr-price { padding-block: clamp(2.6rem, 7vh, 4.5rem); }
  .sr-price-inner { display: flex; align-items: baseline; gap: 1rem 2.5rem; flex-wrap: wrap; }
  .sr-price-num { font-size: clamp(2.6rem, 6vw, 4rem); font-weight: 800; letter-spacing: -0.03em; }
  .sr-price-num sub { font-size: 0.4em; font-weight: 600; color: var(--sage-bright); vertical-align: baseline; }
  .sr-price-copy { color: var(--mist); font-size: 1.08rem; line-height: 1.5; max-width: 46ch; margin: 0; }
  .sr-price-copy strong { color: var(--paper); }

  /* ---- FAQ ---- */
  .sr-faq { display: grid; gap: 0.9rem; }
  .sr-faq details {
    background: var(--deep-2); border: 2.5px solid var(--near); border-radius: var(--radius-sm);
    padding: 0.2rem 1.3rem; box-shadow: var(--press-sm);
  }
  .sr-faq summary {
    cursor: pointer; list-style: none; padding: 1rem 0; font-weight: 700; font-size: 1.05rem;
    display: flex; justify-content: space-between; align-items: center; gap: 1rem;
  }
  .sr-faq summary::-webkit-details-marker { display: none; }
  .sr-faq summary::after { content: "+"; color: var(--amber); font-weight: 500; font-size: 1.5rem; font-family: var(--mono); flex: none; line-height: 1; }
  .sr-faq details[open] summary::after { content: "\2212"; }
  .sr-faq details p { color: var(--mist); margin: 0 0 1.1rem; font-size: 0.98rem; line-height: 1.6; }

  /* ---- final CTA ---- */
  .sr-cta { text-align: center; }
  .sr-cta h2 { font-size: clamp(2rem, 4.6vw, 3.1rem); font-weight: 800; letter-spacing: -0.035em; line-height: 1.04; margin: 0 0 0.7rem; text-wrap: balance; }
  .sr-cta p { color: var(--mist); font-size: 1.1rem; margin: 0 0 1.6rem; }

  /* ---- footer ---- */
  .sr-footer { background: var(--deep-3); border-top: 2.5px solid var(--near); padding-block: clamp(2.6rem, 6vh, 3.6rem) 2rem; margin-top: auto; }
  .sr-foot-grid { display: grid; grid-template-columns: 1.5fr 1fr 1fr 1fr; gap: 2rem; }
  @media (max-width: 760px) { .sr-foot-grid { grid-template-columns: 1fr 1fr; gap: 1.8rem; } }
  .sr-foot-brand { max-width: 30ch; }
  .sr-foot-brand .sr-lockup { margin-bottom: 0.9rem; }
  .sr-foot-brand p { color: var(--sage-bright); font-size: 0.92rem; margin: 0; line-height: 1.55; }
  .sr-footer h4 { font-family: var(--mono); font-size: 0.7rem; letter-spacing: 0.12em; text-transform: uppercase; color: var(--amber); margin: 0 0 0.9rem; }
  .sr-footer ul { list-style: none; padding: 0; margin: 0; display: grid; gap: 0.6rem; }
  .sr-footer li a { color: var(--mist); font-size: 0.94rem; }
  .sr-footer li a:hover { color: var(--paper); }
  .sr-foot-bottom {
    margin-top: 2.4rem; padding-top: 1.4rem; border-top: 1px solid var(--line-dark);
    display: flex; justify-content: space-between; flex-wrap: wrap; gap: 0.8rem;
    font-size: 0.85rem; color: var(--sage-bright);
  }

  /* ---- compare table ---- */
  .sr-compare { width: 100%; border-collapse: collapse; }
  .sr-compare th {
    text-align: left; font-family: var(--mono); font-size: 0.78rem; text-transform: uppercase;
    letter-spacing: 0.06em; padding: 0.7rem 0.5rem; border-bottom: 2.5px solid var(--ink); color: var(--ink);
  }
  .sr-compare td { vertical-align: top; padding: 0.9rem 0.5rem; border-bottom: 1px solid var(--line-light); color: var(--ink-soft); line-height: 1.5; }
  .sr-compare td:first-child { font-weight: 700; color: var(--ink); width: 42%; padding-right: 1.4rem; }
  .sr-compare-scroll { overflow-x: auto; }

  /* ---- entrance motion ---- */
  @keyframes sr-rise { from { opacity: 0; transform: translateY(16px); } to { opacity: 1; transform: none; } }
  .sr-hero-copy > * { animation: sr-rise 0.66s cubic-bezier(0.22, 1, 0.36, 1) both; }
  .sr-hero-copy > *:nth-child(2) { animation-delay: 0.07s; }
  .sr-hero-copy > *:nth-child(3) { animation-delay: 0.14s; }
  .sr-hero-copy > *:nth-child(4) { animation-delay: 0.21s; }
  .sr-hero-copy > *:nth-child(5) { animation-delay: 0.28s; }
  .sr-hero-art { animation: sr-rise 0.8s cubic-bezier(0.22, 1, 0.36, 1) 0.18s both; }

  @media (max-width: 640px) {
    .sr-row { grid-template-columns: 1fr; }
    .sr-row-desc { align-self: start; }
    .sr-compare td:first-child { width: 48%; }
  }

  @media (prefers-reduced-motion: reduce) {
    html { scroll-behavior: auto; }
    .sr-hero-copy > *, .sr-hero-art { animation: none; }
    .sr-scene-tag, .sr-scene-stamp, .sr-scene-spark { animation: none; }
    .sr-scene-stamp { opacity: 1; }
    .sr-marquee-track { animation: none; flex-wrap: wrap; width: auto; }
    .sr-btn, .sr-label, .sr-tile { transition: none; }
  }


  /* ---- legal / prose pages (static site) ---- */
  .sr-prose { max-width: 72ch; color: var(--ink-soft); font-size: 1.02rem; line-height: 1.7; }
  .sr-prose > p:first-of-type { font-size: 1.12rem; color: var(--ink); }
  .sr-prose h2 { font-size: clamp(1.3rem, 2.4vw, 1.7rem); font-weight: 800; letter-spacing: -0.02em; color: var(--ink); margin: 2.2rem 0 0.7rem; }
  .sr-prose h3 { font-size: 1.15rem; font-weight: 700; color: var(--ink); margin: 1.6rem 0 0.5rem; }
  .sr-prose p { margin: 0 0 1rem; }
  .sr-prose ul { margin: 0 0 1.2rem; padding-left: 1.3rem; display: grid; gap: 0.6rem; }
  .sr-prose li { padding-left: 0.2rem; }
  .sr-prose strong { color: var(--ink); font-weight: 700; }
  .sr-prose a { color: var(--stamp); font-weight: 600; text-decoration: underline; text-underline-offset: 2px; }
  .sr-prose code {
    font-family: var(--mono); font-size: 0.84em; background: var(--paper-2);
    border: 1px solid var(--line-light); border-radius: 6px; padding: 0.08em 0.4em; color: var(--ink);
  }
  .sr-prose .sr-updated { font-family: var(--mono); font-size: 0.8rem; letter-spacing: 0.04em; text-transform: uppercase; color: var(--ink-mute); margin-bottom: 1.4rem; }
  .sr-legal-hero { padding-block: clamp(2.4rem, 6vh, 4rem) clamp(1.2rem, 3vh, 2rem); }
  .sr-legal-hero h1 { font-size: clamp(2.1rem, 5vw, 3.3rem); font-weight: 800; letter-spacing: -0.035em; line-height: 1.02; margin: 0; }
