/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */
@layer properties;
@layer theme, base, components, utilities;
@layer theme {
  :root, :host {
    --font-sans: "Hanken Grotesk", ui-sans-serif, system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    --font-mono: "Hanken Grotesk", ui-sans-serif, system-ui, sans-serif;
    --color-white: #fff;
    --spacing: 0.25rem;
    --container-xs: 20rem;
    --container-sm: 24rem;
    --container-xl: 36rem;
    --container-3xl: 48rem;
    --container-4xl: 56rem;
    --container-5xl: 64rem;
    --text-xs: 0.75rem;
    --text-xs--line-height: calc(1 / 0.75);
    --text-sm: 0.875rem;
    --text-sm--line-height: calc(1.25 / 0.875);
    --text-base: 1rem;
    --text-base--line-height: calc(1.5 / 1);
    --text-lg: 1.125rem;
    --text-lg--line-height: calc(1.75 / 1.125);
    --text-xl: 1.25rem;
    --text-xl--line-height: calc(1.75 / 1.25);
    --text-2xl: 1.5rem;
    --text-2xl--line-height: calc(2 / 1.5);
    --text-3xl: 1.875rem;
    --text-3xl--line-height: calc(2.25 / 1.875);
    --text-4xl: 2.25rem;
    --text-4xl--line-height: calc(2.5 / 2.25);
    --font-weight-medium: 500;
    --font-weight-semibold: 600;
    --font-weight-bold: 700;
    --tracking-tight: -0.025em;
    --tracking-wide: 0.025em;
    --radius-md: 0.375rem;
    --radius-lg: 20px;
    --default-transition-duration: 150ms;
    --default-transition-timing-function: cubic-bezier(0.4, 0, 0.2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono);
    --color-brand-50: var(--p-brand-50);
    --color-brand-100: var(--p-brand-100);
    --color-brand-200: var(--p-brand-200);
    --color-brand-300: var(--p-brand-300);
    --color-brand-400: var(--p-brand-400);
    --color-brand-500: var(--p-brand-500);
    --color-brand-600: var(--p-brand-600);
    --color-brand-700: var(--p-brand-700);
    --color-brand-800: var(--p-brand-800);
    --color-brand-900: var(--p-brand-900);
    --color-accent: var(--p-accent);
    --color-ink: var(--p-ink);
    --color-body: var(--p-body);
    --color-muted: var(--p-muted);
    --color-line: var(--p-line);
    --color-surface: var(--p-surface);
    --color-surface-soft: var(--p-surface-soft);
    --color-surface-raised: var(--p-surface-raised);
    --color-inverse: var(--p-inverse);
    --font-display: "Fraunces", Georgia, "Times New Roman", serif;
    --radius-card: 12px;
    --radius-pill: 999px;
    --shadow-card: 0 6px 20px rgba(40, 32, 20, 0.07);
    --shadow-pop: 0 16px 40px rgba(40, 32, 20, 0.10);
  }
}
@layer base {
  *, ::after, ::before, ::backdrop, ::file-selector-button {
    box-sizing: border-box;
    margin: 0;
    padding: 0;
    border: 0 solid;
  }
  html, :host {
    line-height: 1.5;
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    font-family: var(--default-font-family, ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");
    font-feature-settings: var(--default-font-feature-settings, normal);
    font-variation-settings: var(--default-font-variation-settings, normal);
    -webkit-tap-highlight-color: transparent;
  }
  hr {
    height: 0;
    color: inherit;
    border-top-width: 1px;
  }
  abbr:where([title]) {
    -webkit-text-decoration: underline dotted;
    text-decoration: underline dotted;
  }
  h1, h2, h3, h4, h5, h6 {
    font-size: inherit;
    font-weight: inherit;
  }
  a {
    color: inherit;
    -webkit-text-decoration: inherit;
    text-decoration: inherit;
  }
  b, strong {
    font-weight: bolder;
  }
  code, kbd, samp, pre {
    font-family: var(--default-mono-font-family, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);
    font-feature-settings: var(--default-mono-font-feature-settings, normal);
    font-variation-settings: var(--default-mono-font-variation-settings, normal);
    font-size: 1em;
  }
  small {
    font-size: 80%;
  }
  sub, sup {
    font-size: 75%;
    line-height: 0;
    position: relative;
    vertical-align: baseline;
  }
  sub {
    bottom: -0.25em;
  }
  sup {
    top: -0.5em;
  }
  table {
    text-indent: 0;
    border-color: inherit;
    border-collapse: collapse;
  }
  :-moz-focusring {
    outline: auto;
  }
  progress {
    vertical-align: baseline;
  }
  summary {
    display: list-item;
  }
  ol, ul, menu {
    list-style: none;
  }
  img, svg, video, canvas, audio, iframe, embed, object {
    display: block;
    vertical-align: middle;
  }
  img, video {
    max-width: 100%;
    height: auto;
  }
  button, input, select, optgroup, textarea, ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    border-radius: 0;
    background-color: transparent;
    opacity: 1;
  }
  :where(select:is([multiple], [size])) optgroup {
    font-weight: bolder;
  }
  :where(select:is([multiple], [size])) optgroup option {
    padding-inline-start: 20px;
  }
  ::file-selector-button {
    margin-inline-end: 4px;
  }
  ::placeholder {
    opacity: 1;
  }
  @supports (not (-webkit-appearance: -apple-pay-button))  or (contain-intrinsic-size: 1px) {
    ::placeholder {
      color: currentcolor;
      @supports (color: color-mix(in lab, red, red)) {
        color: color-mix(in oklab, currentcolor 50%, transparent);
      }
    }
  }
  textarea {
    resize: vertical;
  }
  ::-webkit-search-decoration {
    -webkit-appearance: none;
  }
  ::-webkit-date-and-time-value {
    min-height: 1lh;
    text-align: inherit;
  }
  ::-webkit-datetime-edit {
    display: inline-flex;
  }
  ::-webkit-datetime-edit-fields-wrapper {
    padding: 0;
  }
  ::-webkit-datetime-edit, ::-webkit-datetime-edit-year-field, ::-webkit-datetime-edit-month-field, ::-webkit-datetime-edit-day-field, ::-webkit-datetime-edit-hour-field, ::-webkit-datetime-edit-minute-field, ::-webkit-datetime-edit-second-field, ::-webkit-datetime-edit-millisecond-field, ::-webkit-datetime-edit-meridiem-field {
    padding-block: 0;
  }
  ::-webkit-calendar-picker-indicator {
    line-height: 1;
  }
  :-moz-ui-invalid {
    box-shadow: none;
  }
  button, input:where([type="button"], [type="reset"], [type="submit"]), ::file-selector-button {
    appearance: button;
  }
  ::-webkit-inner-spin-button, ::-webkit-outer-spin-button {
    height: auto;
  }
  [hidden]:where(:not([hidden="until-found"])) {
    display: none !important;
  }
}
@layer utilities {
  .collapse {
    visibility: collapse;
  }
  .invisible {
    visibility: hidden;
  }
  .visible {
    visibility: visible;
  }
  .absolute {
    position: absolute;
  }
  .fixed {
    position: fixed;
  }
  .relative {
    position: relative;
  }
  .static {
    position: static;
  }
  .sticky {
    position: sticky;
  }
  .isolate {
    isolation: isolate;
  }
  .col-12 {
    grid-column: 12;
  }
  .container {
    width: 100%;
    @media (width >= 40rem) {
      max-width: 40rem;
    }
    @media (width >= 48rem) {
      max-width: 48rem;
    }
    @media (width >= 64rem) {
      max-width: 64rem;
    }
    @media (width >= 80rem) {
      max-width: 80rem;
    }
    @media (width >= 96rem) {
      max-width: 96rem;
    }
  }
  .container-fdc {
    margin-inline: auto;
    width: 100%;
    max-width: 1200px;
    padding-inline: clamp(1.5rem, 0.25rem + 5.5vw, 5rem);
  }
  .mx-auto {
    margin-inline: auto;
  }
  .my-6 {
    margin-block: calc(var(--spacing) * 6);
  }
  .prose {
    color: var(--tw-prose-body);
    max-width: 65ch;
    :where(p):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 1.25em;
      margin-bottom: 1.25em;
    }
    :where([class~="lead"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-lead);
      font-size: 1.25em;
      line-height: 1.6;
      margin-top: 1.2em;
      margin-bottom: 1.2em;
    }
    :where(a):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-links);
      text-decoration: underline;
      font-weight: 500;
    }
    :where(strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-bold);
      font-weight: 600;
    }
    :where(a strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(blockquote strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(thead th strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(ol):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: decimal;
      margin-top: 1.25em;
      margin-bottom: 1.25em;
      padding-inline-start: 1.625em;
    }
    :where(ol[type="A"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: upper-alpha;
    }
    :where(ol[type="a"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: lower-alpha;
    }
    :where(ol[type="A" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: upper-alpha;
    }
    :where(ol[type="a" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: lower-alpha;
    }
    :where(ol[type="I"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: upper-roman;
    }
    :where(ol[type="i"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: lower-roman;
    }
    :where(ol[type="I" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: upper-roman;
    }
    :where(ol[type="i" s]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: lower-roman;
    }
    :where(ol[type="1"]):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: decimal;
    }
    :where(ul):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      list-style-type: disc;
      margin-top: 1.25em;
      margin-bottom: 1.25em;
      padding-inline-start: 1.625em;
    }
    :where(ol > li):not(:where([class~="not-prose"],[class~="not-prose"] *))::marker {
      font-weight: 400;
      color: var(--tw-prose-counters);
    }
    :where(ul > li):not(:where([class~="not-prose"],[class~="not-prose"] *))::marker {
      color: var(--tw-prose-bullets);
    }
    :where(dt):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 600;
      margin-top: 1.25em;
    }
    :where(hr):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      border-color: var(--tw-prose-hr);
      border-top-width: 1px;
      margin-top: 3em;
      margin-bottom: 3em;
    }
    :where(blockquote):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 500;
      font-style: italic;
      color: var(--tw-prose-quotes);
      border-inline-start-width: 0.25rem;
      border-inline-start-color: var(--tw-prose-quote-borders);
      quotes: "\201C""\201D""\2018""\2019";
      margin-top: 1.6em;
      margin-bottom: 1.6em;
      padding-inline-start: 1em;
    }
    :where(blockquote p:first-of-type):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
      content: open-quote;
    }
    :where(blockquote p:last-of-type):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
      content: close-quote;
    }
    :where(h1):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 800;
      font-size: 2.25em;
      margin-top: 0;
      margin-bottom: 0.8888889em;
      line-height: 1.1111111;
    }
    :where(h1 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 900;
      color: inherit;
    }
    :where(h2):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 700;
      font-size: 1.5em;
      margin-top: 2em;
      margin-bottom: 1em;
      line-height: 1.3333333;
    }
    :where(h2 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 800;
      color: inherit;
    }
    :where(h3):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 600;
      font-size: 1.25em;
      margin-top: 1.6em;
      margin-bottom: 0.6em;
      line-height: 1.6;
    }
    :where(h3 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 700;
      color: inherit;
    }
    :where(h4):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 600;
      margin-top: 1.5em;
      margin-bottom: 0.5em;
      line-height: 1.5;
    }
    :where(h4 strong):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 700;
      color: inherit;
    }
    :where(img):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 2em;
      margin-bottom: 2em;
    }
    :where(picture):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      display: block;
      margin-top: 2em;
      margin-bottom: 2em;
    }
    :where(video):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 2em;
      margin-bottom: 2em;
    }
    :where(kbd):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      font-weight: 500;
      font-family: inherit;
      color: var(--tw-prose-kbd);
      box-shadow: 0 0 0 1px var(--tw-prose-kbd-shadows), 0 3px 0 var(--tw-prose-kbd-shadows);
      font-size: 0.875em;
      border-radius: 0.3125rem;
      padding-top: 0.1875em;
      padding-inline-end: 0.375em;
      padding-bottom: 0.1875em;
      padding-inline-start: 0.375em;
    }
    :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-code);
      font-weight: 600;
      font-size: 0.875em;
    }
    :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
      content: "`";
    }
    :where(code):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
      content: "`";
    }
    :where(a code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(h1 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(h2 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
      font-size: 0.875em;
    }
    :where(h3 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
      font-size: 0.9em;
    }
    :where(h4 code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(blockquote code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(thead th code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: inherit;
    }
    :where(pre):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-pre-code);
      background-color: var(--tw-prose-pre-bg);
      overflow-x: auto;
      font-weight: 400;
      font-size: 0.875em;
      line-height: 1.7142857;
      margin-top: 1.7142857em;
      margin-bottom: 1.7142857em;
      border-radius: 0.375rem;
      padding-top: 0.8571429em;
      padding-inline-end: 1.1428571em;
      padding-bottom: 0.8571429em;
      padding-inline-start: 1.1428571em;
    }
    :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      background-color: transparent;
      border-width: 0;
      border-radius: 0;
      padding: 0;
      font-weight: inherit;
      color: inherit;
      font-size: inherit;
      font-family: inherit;
      line-height: inherit;
    }
    :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *))::before {
      content: none;
    }
    :where(pre code):not(:where([class~="not-prose"],[class~="not-prose"] *))::after {
      content: none;
    }
    :where(table):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      width: 100%;
      table-layout: auto;
      margin-top: 2em;
      margin-bottom: 2em;
      font-size: 0.875em;
      line-height: 1.7142857;
    }
    :where(thead):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      border-bottom-width: 1px;
      border-bottom-color: var(--tw-prose-th-borders);
    }
    :where(thead th):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-headings);
      font-weight: 600;
      vertical-align: bottom;
      padding-inline-end: 0.5714286em;
      padding-bottom: 0.5714286em;
      padding-inline-start: 0.5714286em;
    }
    :where(tbody tr):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      border-bottom-width: 1px;
      border-bottom-color: var(--tw-prose-td-borders);
    }
    :where(tbody tr:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      border-bottom-width: 0;
    }
    :where(tbody td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      vertical-align: baseline;
    }
    :where(tfoot):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      border-top-width: 1px;
      border-top-color: var(--tw-prose-th-borders);
    }
    :where(tfoot td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      vertical-align: top;
    }
    :where(th, td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      text-align: start;
    }
    :where(figure > *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
      margin-bottom: 0;
    }
    :where(figcaption):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      color: var(--tw-prose-captions);
      font-size: 0.875em;
      line-height: 1.4285714;
      margin-top: 0.8571429em;
    }
    --tw-prose-body: oklch(37.3% 0.034 259.733);
    --tw-prose-headings: oklch(21% 0.034 264.665);
    --tw-prose-lead: oklch(44.6% 0.03 256.802);
    --tw-prose-links: oklch(21% 0.034 264.665);
    --tw-prose-bold: oklch(21% 0.034 264.665);
    --tw-prose-counters: oklch(55.1% 0.027 264.364);
    --tw-prose-bullets: oklch(87.2% 0.01 258.338);
    --tw-prose-hr: oklch(92.8% 0.006 264.531);
    --tw-prose-quotes: oklch(21% 0.034 264.665);
    --tw-prose-quote-borders: oklch(92.8% 0.006 264.531);
    --tw-prose-captions: oklch(55.1% 0.027 264.364);
    --tw-prose-kbd: oklch(21% 0.034 264.665);
    --tw-prose-kbd-shadows: color-mix(in oklab, oklch(21% 0.034 264.665) 10%, transparent);
    --tw-prose-code: oklch(21% 0.034 264.665);
    --tw-prose-pre-code: oklch(92.8% 0.006 264.531);
    --tw-prose-pre-bg: oklch(27.8% 0.033 256.848);
    --tw-prose-th-borders: oklch(87.2% 0.01 258.338);
    --tw-prose-td-borders: oklch(92.8% 0.006 264.531);
    --tw-prose-invert-body: oklch(87.2% 0.01 258.338);
    --tw-prose-invert-headings: #fff;
    --tw-prose-invert-lead: oklch(70.7% 0.022 261.325);
    --tw-prose-invert-links: #fff;
    --tw-prose-invert-bold: #fff;
    --tw-prose-invert-counters: oklch(70.7% 0.022 261.325);
    --tw-prose-invert-bullets: oklch(44.6% 0.03 256.802);
    --tw-prose-invert-hr: oklch(37.3% 0.034 259.733);
    --tw-prose-invert-quotes: oklch(96.7% 0.003 264.542);
    --tw-prose-invert-quote-borders: oklch(37.3% 0.034 259.733);
    --tw-prose-invert-captions: oklch(70.7% 0.022 261.325);
    --tw-prose-invert-kbd: #fff;
    --tw-prose-invert-kbd-shadows: rgb(255 255 255 / 10%);
    --tw-prose-invert-code: #fff;
    --tw-prose-invert-pre-code: oklch(87.2% 0.01 258.338);
    --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
    --tw-prose-invert-th-borders: oklch(44.6% 0.03 256.802);
    --tw-prose-invert-td-borders: oklch(37.3% 0.034 259.733);
    font-size: 1rem;
    line-height: 1.75;
    :where(picture > img):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
      margin-bottom: 0;
    }
    :where(li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0.5em;
      margin-bottom: 0.5em;
    }
    :where(ol > li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-start: 0.375em;
    }
    :where(ul > li):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-start: 0.375em;
    }
    :where(.prose > ul > li p):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0.75em;
      margin-bottom: 0.75em;
    }
    :where(.prose > ul > li > p:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 1.25em;
    }
    :where(.prose > ul > li > p:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-bottom: 1.25em;
    }
    :where(.prose > ol > li > p:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 1.25em;
    }
    :where(.prose > ol > li > p:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-bottom: 1.25em;
    }
    :where(ul ul, ul ol, ol ul, ol ol):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0.75em;
      margin-bottom: 0.75em;
    }
    :where(dl):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 1.25em;
      margin-bottom: 1.25em;
    }
    :where(dd):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0.5em;
      padding-inline-start: 1.625em;
    }
    :where(hr + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
    }
    :where(h2 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
    }
    :where(h3 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
    }
    :where(h4 + *):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
    }
    :where(thead th:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-start: 0;
    }
    :where(thead th:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-end: 0;
    }
    :where(tbody td, tfoot td):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-top: 0.5714286em;
      padding-inline-end: 0.5714286em;
      padding-bottom: 0.5714286em;
      padding-inline-start: 0.5714286em;
    }
    :where(tbody td:first-child, tfoot td:first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-start: 0;
    }
    :where(tbody td:last-child, tfoot td:last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      padding-inline-end: 0;
    }
    :where(figure):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 2em;
      margin-bottom: 2em;
    }
    :where(.prose > :first-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-top: 0;
    }
    :where(.prose > :last-child):not(:where([class~="not-prose"],[class~="not-prose"] *)) {
      margin-bottom: 0;
    }
  }
  .mt-1 {
    margin-top: calc(var(--spacing) * 1);
  }
  .mt-2 {
    margin-top: calc(var(--spacing) * 2);
  }
  .mt-3 {
    margin-top: calc(var(--spacing) * 3);
  }
  .mt-4 {
    margin-top: calc(var(--spacing) * 4);
  }
  .mt-5 {
    margin-top: calc(var(--spacing) * 5);
  }
  .mt-6 {
    margin-top: calc(var(--spacing) * 6);
  }
  .mt-8 {
    margin-top: calc(var(--spacing) * 8);
  }
  .mt-10 {
    margin-top: calc(var(--spacing) * 10);
  }
  .mt-12 {
    margin-top: calc(var(--spacing) * 12);
  }
  .mt-14 {
    margin-top: calc(var(--spacing) * 14);
  }
  .mt-16 {
    margin-top: calc(var(--spacing) * 16);
  }
  .mb-5 {
    margin-bottom: calc(var(--spacing) * 5);
  }
  .eyebrow {
    display: inline-block;
    font-size: 0.8125rem;
    font-weight: 600;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    color: var(--color-brand-600);
  }
  .block {
    display: block;
  }
  .contents {
    display: contents;
  }
  .flex {
    display: flex;
  }
  .grid {
    display: grid;
  }
  .hidden {
    display: none;
  }
  .inline {
    display: inline;
  }
  .table {
    display: table;
  }
  .h-8 {
    height: calc(var(--spacing) * 8);
  }
  .h-10 {
    height: calc(var(--spacing) * 10);
  }
  .min-h-screen {
    min-height: 100vh;
  }
  .w-8 {
    width: calc(var(--spacing) * 8);
  }
  .w-10 {
    width: calc(var(--spacing) * 10);
  }
  .max-w-3xl {
    max-width: var(--container-3xl);
  }
  .max-w-4xl {
    max-width: var(--container-4xl);
  }
  .max-w-5xl {
    max-width: var(--container-5xl);
  }
  .max-w-none {
    max-width: none;
  }
  .max-w-sm {
    max-width: var(--container-sm);
  }
  .max-w-xl {
    max-width: var(--container-xl);
  }
  .max-w-xs {
    max-width: var(--container-xs);
  }
  .min-w-\[34rem\] {
    min-width: 34rem;
  }
  .flex-1 {
    flex: 1;
  }
  .shrink {
    flex-shrink: 1;
  }
  .grow {
    flex-grow: 1;
  }
  .transform {
    transform: var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,);
  }
  .flex-col {
    flex-direction: column;
  }
  .items-center {
    align-items: center;
  }
  .justify-center {
    justify-content: center;
  }
  .gap-1 {
    gap: calc(var(--spacing) * 1);
  }
  .gap-2 {
    gap: calc(var(--spacing) * 2);
  }
  .gap-2\.5 {
    gap: calc(var(--spacing) * 2.5);
  }
  .gap-4 {
    gap: calc(var(--spacing) * 4);
  }
  .gap-5 {
    gap: calc(var(--spacing) * 5);
  }
  .gap-6 {
    gap: calc(var(--spacing) * 6);
  }
  .gap-7 {
    gap: calc(var(--spacing) * 7);
  }
  .gap-10 {
    gap: calc(var(--spacing) * 10);
  }
  .space-y-2 {
    :where(& > :not(:last-child)) {
      --tw-space-y-reverse: 0;
      margin-block-start: calc(calc(var(--spacing) * 2) * var(--tw-space-y-reverse));
      margin-block-end: calc(calc(var(--spacing) * 2) * calc(1 - var(--tw-space-y-reverse)));
    }
  }
  .truncate {
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .overflow-x-auto {
    overflow-x: auto;
  }
  .card {
    border: 1px solid var(--color-line);
    border-radius: var(--radius-card);
    background: var(--color-surface-raised);
    box-shadow: var(--shadow-card);
  }
  .rounded-card {
    border-radius: var(--radius-card);
  }
  .rounded-lg {
    border-radius: var(--radius-lg);
  }
  .rounded-md {
    border-radius: var(--radius-md);
  }
  .border {
    border-style: var(--tw-border-style);
    border-width: 1px;
  }
  .border-t {
    border-top-style: var(--tw-border-style);
    border-top-width: 1px;
  }
  .border-l-4 {
    border-left-style: var(--tw-border-style);
    border-left-width: 4px;
  }
  .border-brand-200 {
    border-color: var(--color-brand-200);
  }
  .border-brand-500 {
    border-color: var(--color-brand-500);
  }
  .border-line {
    border-color: var(--color-line);
  }
  .bg-brand-50 {
    background-color: var(--color-brand-50);
  }
  .bg-brand-600 {
    background-color: var(--color-brand-600);
  }
  .bg-surface-soft {
    background-color: var(--color-surface-soft);
  }
  .p-5 {
    padding: calc(var(--spacing) * 5);
  }
  .p-10 {
    padding: calc(var(--spacing) * 10);
  }
  .py-2 {
    padding-block: calc(var(--spacing) * 2);
  }
  .py-14 {
    padding-block: calc(var(--spacing) * 14);
  }
  .py-16 {
    padding-block: calc(var(--spacing) * 16);
  }
  .section {
    padding-block: clamp(4rem, 2rem + 9vw, 8rem);
  }
  .pt-3 {
    padding-top: calc(var(--spacing) * 3);
  }
  .pt-6 {
    padding-top: calc(var(--spacing) * 6);
  }
  .pb-4 {
    padding-bottom: calc(var(--spacing) * 4);
  }
  .pb-20 {
    padding-bottom: calc(var(--spacing) * 20);
  }
  .text-center {
    text-align: center;
  }
  .font-display {
    font-family: var(--font-display);
  }
  .text-2xl {
    font-size: var(--text-2xl);
    line-height: var(--tw-leading, var(--text-2xl--line-height));
  }
  .text-3xl {
    font-size: var(--text-3xl);
    line-height: var(--tw-leading, var(--text-3xl--line-height));
  }
  .text-4xl {
    font-size: var(--text-4xl);
    line-height: var(--tw-leading, var(--text-4xl--line-height));
  }
  .text-base {
    font-size: var(--text-base);
    line-height: var(--tw-leading, var(--text-base--line-height));
  }
  .text-lg {
    font-size: var(--text-lg);
    line-height: var(--tw-leading, var(--text-lg--line-height));
  }
  .text-sm {
    font-size: var(--text-sm);
    line-height: var(--tw-leading, var(--text-sm--line-height));
  }
  .text-xl {
    font-size: var(--text-xl);
    line-height: var(--tw-leading, var(--text-xl--line-height));
  }
  .text-xs {
    font-size: var(--text-xs);
    line-height: var(--tw-leading, var(--text-xs--line-height));
  }
  .text-\[1\.18rem\] {
    font-size: 1.18rem;
  }
  .text-\[2\.2rem\] {
    font-size: 2.2rem;
  }
  .text-\[2\.4rem\] {
    font-size: 2.4rem;
  }
  .text-\[7rem\] {
    font-size: 7rem;
  }
  .leading-\[1\.04\] {
    --tw-leading: 1.04;
    line-height: 1.04;
  }
  .leading-\[1\.05\] {
    --tw-leading: 1.05;
    line-height: 1.05;
  }
  .leading-none {
    --tw-leading: 1;
    line-height: 1;
  }
  .font-bold {
    --tw-font-weight: var(--font-weight-bold);
    font-weight: var(--font-weight-bold);
  }
  .font-medium {
    --tw-font-weight: var(--font-weight-medium);
    font-weight: var(--font-weight-medium);
  }
  .font-semibold {
    --tw-font-weight: var(--font-weight-semibold);
    font-weight: var(--font-weight-semibold);
  }
  .tracking-\[0\.13em\] {
    --tw-tracking: 0.13em;
    letter-spacing: 0.13em;
  }
  .tracking-tight {
    --tw-tracking: var(--tracking-tight);
    letter-spacing: var(--tracking-tight);
  }
  .tracking-wide {
    --tw-tracking: var(--tracking-wide);
    letter-spacing: var(--tracking-wide);
  }
  .text-balance {
    text-wrap: balance;
  }
  .text-body {
    color: var(--color-body);
  }
  .text-brand-600 {
    color: var(--color-brand-600);
  }
  .text-brand-700 {
    color: var(--color-brand-700);
  }
  .text-ink {
    color: var(--color-ink);
  }
  .text-muted {
    color: var(--color-muted);
  }
  .text-white {
    color: var(--color-white);
  }
  .text-white\/70 {
    color: color-mix(in srgb, #fff 70%, transparent);
    @supports (color: color-mix(in lab, red, red)) {
      color: color-mix(in oklab, var(--color-white) 70%, transparent);
    }
  }
  .lowercase {
    text-transform: lowercase;
  }
  .uppercase {
    text-transform: uppercase;
  }
  .italic {
    font-style: italic;
  }
  .underline {
    text-decoration-line: underline;
  }
  .ring {
    --tw-ring-shadow: var(--tw-ring-inset,) 0 0 0 calc(1px + var(--tw-ring-offset-width)) var(--tw-ring-color, currentcolor);
    box-shadow: var(--tw-inset-shadow), var(--tw-inset-ring-shadow), var(--tw-ring-offset-shadow), var(--tw-ring-shadow), var(--tw-shadow);
  }
  .outline {
    outline-style: var(--tw-outline-style);
    outline-width: 1px;
  }
  .blur {
    --tw-blur: blur(8px);
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .filter {
    filter: var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,);
  }
  .transition {
    transition-property: color, background-color, border-color, outline-color, text-decoration-color, fill, stroke, --tw-gradient-from, --tw-gradient-via, --tw-gradient-to, opacity, box-shadow, transform, translate, scale, rotate, filter, -webkit-backdrop-filter, backdrop-filter, display, content-visibility, overlay, pointer-events;
    transition-timing-function: var(--tw-ease, var(--default-transition-timing-function));
    transition-duration: var(--tw-duration, var(--default-transition-duration));
  }
  .prose-slate {
    --tw-prose-body: oklch(37.2% 0.044 257.287);
    --tw-prose-headings: oklch(20.8% 0.042 265.755);
    --tw-prose-lead: oklch(44.6% 0.043 257.281);
    --tw-prose-links: oklch(20.8% 0.042 265.755);
    --tw-prose-bold: oklch(20.8% 0.042 265.755);
    --tw-prose-counters: oklch(55.4% 0.046 257.417);
    --tw-prose-bullets: oklch(86.9% 0.022 252.894);
    --tw-prose-hr: oklch(92.9% 0.013 255.508);
    --tw-prose-quotes: oklch(20.8% 0.042 265.755);
    --tw-prose-quote-borders: oklch(92.9% 0.013 255.508);
    --tw-prose-captions: oklch(55.4% 0.046 257.417);
    --tw-prose-kbd: oklch(20.8% 0.042 265.755);
    --tw-prose-kbd-shadows: color-mix(in oklab, oklch(20.8% 0.042 265.755) 10%, transparent);
    --tw-prose-code: oklch(20.8% 0.042 265.755);
    --tw-prose-pre-code: oklch(92.9% 0.013 255.508);
    --tw-prose-pre-bg: oklch(27.9% 0.041 260.031);
    --tw-prose-th-borders: oklch(86.9% 0.022 252.894);
    --tw-prose-td-borders: oklch(92.9% 0.013 255.508);
    --tw-prose-invert-body: oklch(86.9% 0.022 252.894);
    --tw-prose-invert-headings: #fff;
    --tw-prose-invert-lead: oklch(70.4% 0.04 256.788);
    --tw-prose-invert-links: #fff;
    --tw-prose-invert-bold: #fff;
    --tw-prose-invert-counters: oklch(70.4% 0.04 256.788);
    --tw-prose-invert-bullets: oklch(44.6% 0.043 257.281);
    --tw-prose-invert-hr: oklch(37.2% 0.044 257.287);
    --tw-prose-invert-quotes: oklch(96.8% 0.007 247.896);
    --tw-prose-invert-quote-borders: oklch(37.2% 0.044 257.287);
    --tw-prose-invert-captions: oklch(70.4% 0.04 256.788);
    --tw-prose-invert-kbd: #fff;
    --tw-prose-invert-kbd-shadows: rgb(255 255 255 / 10%);
    --tw-prose-invert-code: #fff;
    --tw-prose-invert-pre-code: oklch(86.9% 0.022 252.894);
    --tw-prose-invert-pre-bg: rgb(0 0 0 / 50%);
    --tw-prose-invert-th-borders: oklch(44.6% 0.043 257.281);
    --tw-prose-invert-td-borders: oklch(37.2% 0.044 257.287);
  }
  .hover\:border-brand-200 {
    &:hover {
      @media (hover: hover) {
        border-color: var(--color-brand-200);
      }
    }
  }
  .hover\:text-brand-600 {
    &:hover {
      @media (hover: hover) {
        color: var(--color-brand-600);
      }
    }
  }
  .sm\:grid-cols-2 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .sm\:grid-cols-3 {
    @media (width >= 40rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .sm\:flex-row {
    @media (width >= 40rem) {
      flex-direction: row;
    }
  }
  .sm\:items-center {
    @media (width >= 40rem) {
      align-items: center;
    }
  }
  .sm\:justify-between {
    @media (width >= 40rem) {
      justify-content: space-between;
    }
  }
  .sm\:text-\[2\.7rem\] {
    @media (width >= 40rem) {
      font-size: 2.7rem;
    }
  }
  .sm\:text-\[3\.1rem\] {
    @media (width >= 40rem) {
      font-size: 3.1rem;
    }
  }
  .md\:flex {
    @media (width >= 48rem) {
      display: flex;
    }
  }
  .md\:hidden {
    @media (width >= 48rem) {
      display: none;
    }
  }
  .lg\:sticky {
    @media (width >= 64rem) {
      position: sticky;
    }
  }
  .lg\:top-24 {
    @media (width >= 64rem) {
      top: calc(var(--spacing) * 24);
    }
  }
  .lg\:grid-cols-2 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(2, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-3 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(3, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-4 {
    @media (width >= 64rem) {
      grid-template-columns: repeat(4, minmax(0, 1fr));
    }
  }
  .lg\:grid-cols-\[1fr_1\.05fr\] {
    @media (width >= 64rem) {
      grid-template-columns: 1fr 1.05fr;
    }
  }
  .lg\:gap-16 {
    @media (width >= 64rem) {
      gap: calc(var(--spacing) * 16);
    }
  }
  .lg\:self-start {
    @media (width >= 64rem) {
      align-self: flex-start;
    }
  }
  .prose-headings\:scroll-mt-24 {
    & :is(:where(h1, h2, h3, h4, h5, h6, th):not(:where([class~="not-prose"],[class~="not-prose"] *))) {
      scroll-margin-top: calc(var(--spacing) * 24);
    }
  }
  .prose-a\:text-brand-600 {
    & :is(:where(a):not(:where([class~="not-prose"],[class~="not-prose"] *))) {
      color: var(--color-brand-600);
    }
  }
}
@layer base {
  html {
    scroll-behavior: smooth;
    scroll-padding-top: 5rem;
  }
  body {
    font-family: var(--font-sans);
    color: var(--color-body);
    background: var(--color-surface);
    font-size: 1.125rem;
    line-height: 1.6;
    -webkit-font-smoothing: antialiased;
    text-rendering: optimizeLegibility;
  }
  h1, h2 {
    font-family: var(--font-display);
    color: var(--color-ink);
    font-weight: 500;
    margin: 0;
  }
  h3, h4 {
    font-family: var(--font-sans);
    color: var(--color-ink);
    font-weight: 600;
    margin: 0;
  }
  h1 {
    font-size: clamp(2.35rem, 1.4rem + 3.6vw, 3.6rem);
    line-height: 1.08;
    letter-spacing: -0.015em;
  }
  h2 {
    font-size: clamp(1.7rem, 1.2rem + 1.8vw, 2.4rem);
    line-height: 1.15;
    letter-spacing: -0.01em;
  }
  h3 {
    font-size: 1.25rem;
    line-height: 1.3;
  }
  p {
    margin: 0;
  }
  a {
    color: inherit;
    text-decoration: none;
  }
  img, svg {
    max-width: 100%;
    height: auto;
    display: block;
  }
  ::selection {
    background: var(--color-brand-50);
    color: var(--color-ink);
  }
  :focus-visible {
    outline: 2px solid var(--color-brand-600);
    outline-offset: 2px;
  }
}
.btn-primary, .btn-ghost {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: var(--radius-card);
  padding: 0.9rem 1.6rem;
  font-size: 1rem;
  font-weight: 600;
  line-height: 1;
  cursor: pointer;
  transition: background-color .16s ease-out, border-color .16s ease-out, transform .16s ease-out;
}
.btn-primary {
  background: var(--color-brand-600);
  color: var(--color-inverse);
  border: 1px solid var(--color-brand-600);
}
.btn-primary:hover {
  background: var(--color-brand-700);
  border-color: var(--color-brand-700);
}
.btn-ghost {
  background: transparent;
  color: var(--color-ink);
  border: 1px solid var(--color-line);
}
.btn-ghost:hover {
  border-color: var(--color-brand-600);
}
.btn-sm {
  padding: 0.62rem 1.15rem;
  font-size: 0.9rem;
}
.btn-block {
  width: 100%;
}
@media (prefers-reduced-motion: no-preference) {
  .btn-primary:hover, .btn-ghost:hover {
    transform: translateY(-1px);
  }
}
.site-nav {
  display: none;
}
@media (min-width: 768px) {
  .site-nav {
    display: flex;
    align-items: center;
    gap: 1.75rem;
  }
}
.nav-link {
  font-size: 0.95rem;
  font-weight: 500;
  color: var(--color-muted);
  transition: color .15s ease;
}
.nav-link:hover {
  color: var(--color-ink);
}
.site-footer {
  border-top: 1px solid var(--color-line);
  background: var(--color-surface);
}
.site-footer__inner {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
  padding-block: 2.5rem;
  font-size: 0.9rem;
  color: var(--color-muted);
}
@media (min-width: 640px) {
  .site-footer__inner {
    flex-direction: row;
    align-items: center;
    justify-content: space-between;
  }
}
.site-footer__links {
  display: flex;
  flex-wrap: wrap;
  gap: 1.3rem;
}
.footer-link {
  color: var(--color-muted);
  transition: color .15s ease;
}
.footer-link:hover {
  color: var(--color-ink);
}
.mobile-cta {
  display: none;
}
@media (max-width: 767px) {
  .mobile-cta {
    display: flex;
    align-items: center;
    justify-content: center;
    position: fixed;
    inset: auto 0.75rem 0.75rem;
    z-index: 60;
    padding: 0.95rem;
    border-radius: var(--radius-pill);
    background: var(--color-brand-600);
    color: var(--color-inverse);
    font-weight: 600;
    box-shadow: var(--shadow-pop);
  }
  body {
    padding-bottom: 5.5rem;
  }
}
@media (prefers-reduced-motion: no-preference) {
  @keyframes fdc-rise {
    from {
      opacity: 0;
      transform: translateY(14px);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }
  .fdc-rise > * {
    animation: fdc-rise .6s cubic-bezier(.22, 1, .36, 1) backwards;
  }
  .fdc-rise > *:nth-child(2) {
    animation-delay: .08s;
  }
  .fdc-rise > *:nth-child(3) {
    animation-delay: .16s;
  }
  .fdc-rise > *:nth-child(4) {
    animation-delay: .24s;
  }
}
.lede {
  margin-top: 1.3rem;
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.2rem);
  color: var(--color-muted);
}
.lede + .lede {
  margin-top: 1rem;
}
.demo {
  display: flex;
  flex-direction: column;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
}
.demo__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.1rem;
  border-bottom: 1px solid var(--color-line);
}
.demo__dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-brand-600);
}
.demo__title {
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--color-ink);
}
.demo__tag {
  margin-left: auto;
  font-size: 0.68rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.demo__thread {
  flex: 1;
  min-height: 17rem;
  max-height: 22rem;
  overflow-y: auto;
  padding: 1.1rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.demo__msg {
  max-width: 86%;
  padding: 0.6rem 0.85rem;
  border-radius: var(--radius-card);
  font-size: 0.92rem;
  line-height: 1.5;
}
.demo__msg--bot {
  align-self: flex-start;
  background: var(--color-inverse);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
  border-bottom-left-radius: 0.3rem;
}
.demo__msg--you {
  align-self: flex-end;
  background: var(--color-surface-soft);
  color: var(--color-ink);
  border-bottom-right-radius: 0.3rem;
}
.demo__typing {
  display: flex;
  gap: 0.22rem;
}
.demo__typing span {
  width: 0.4rem;
  height: 0.4rem;
  border-radius: 999px;
  background: var(--color-muted);
  opacity: 0.4;
}
.demo__card {
  align-self: flex-start;
  width: 86%;
  padding: 0.9rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  border: 1px solid var(--color-brand-100);
}
.demo__card-label {
  font-weight: 600;
  font-size: 0.85rem;
  color: var(--color-brand-700);
}
.demo__card-detail {
  margin-top: 0.2rem;
  font-size: 0.9rem;
  color: var(--color-ink);
}
.demo__card-btn {
  margin-top: 0.7rem;
  width: 100%;
  padding: 0.55rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font: inherit;
  font-size: 0.85rem;
  font-weight: 600;
  cursor: pointer;
}
.demo__card-btn:disabled {
  opacity: 0.65;
  cursor: default;
}
.demo__chips {
  display: flex;
  flex-wrap: wrap;
  gap: 0.45rem;
  padding: 0.9rem 1.1rem;
  border-top: 1px solid var(--color-line);
}
.demo__chip {
  padding: 0.45rem 0.85rem;
  border-radius: var(--radius-pill);
  border: 1px solid var(--color-line);
  background: var(--color-surface);
  color: var(--color-ink);
  font: inherit;
  font-size: 0.83rem;
  cursor: pointer;
  transition: border-color .15s ease;
}
.demo__chip:hover {
  border-color: var(--color-brand-600);
}
.demo__done {
  font-size: 0.85rem;
  color: var(--color-muted);
}
.demo__noscript {
  font-size: 0.9rem;
  color: var(--color-muted);
}
@media (prefers-reduced-motion: no-preference) {
  .demo__dot {
    animation: demo-pulse 2s ease-in-out infinite;
  }
  @keyframes demo-pulse {
    0%, 100% {
      opacity: 1;
    }
    50% {
      opacity: 0.35;
    }
  }
  .demo__typing span {
    animation: demo-blink 1.2s infinite;
  }
  .demo__typing span:nth-child(2) {
    animation-delay: 0.2s;
  }
  .demo__typing span:nth-child(3) {
    animation-delay: 0.4s;
  }
  @keyframes demo-blink {
    0%, 60%, 100% {
      opacity: 0.25;
    }
    30% {
      opacity: 0.9;
    }
  }
}
.hero {
  background: var(--color-surface);
}
.hero__grid {
  display: grid;
  gap: clamp(2.5rem, 5vw, 4rem);
  align-items: center;
}
@media (min-width: 960px) {
  .hero__grid {
    grid-template-columns: 1fr 1fr;
  }
}
.hero__sub {
  margin-top: 1.4rem;
  font-size: clamp(1.05rem, 1rem + 0.4vw, 1.2rem);
  color: var(--color-muted);
}
.hero__cta {
  margin-top: 1.75rem;
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.75rem;
}
.hero__cta-note {
  flex-basis: 100%;
  margin-top: 0.15rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--color-muted);
}
.hero__trust {
  margin-top: 1.5rem;
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.03em;
  color: var(--color-muted);
}
.pain {
  background: var(--color-surface-soft);
}
.paincal {
  margin: 0;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
}
.paincal__head {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.85rem 1.1rem;
  border-bottom: 1px solid var(--color-line);
}
.paincal__dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-brand-600);
}
.paincal__title {
  font-weight: 600;
  font-size: 0.92rem;
  color: var(--color-ink);
}
.paincal__meta {
  margin-left: auto;
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.paincal__list {
  list-style: none;
  margin: 0;
  padding: 0.6rem;
  display: flex;
  flex-direction: column;
  gap: 0.4rem;
}
.paincal__slot {
  display: flex;
  gap: 0.85rem;
  padding: 0.7rem 0.75rem;
  border-radius: var(--radius-card);
}
.paincal__time {
  flex-shrink: 0;
  width: 5rem;
  padding-top: 0.05rem;
  font-size: 0.78rem;
  font-weight: 600;
  white-space: nowrap;
  color: var(--color-muted);
}
.paincal__event {
  flex: 1;
  border-left: 2px solid var(--color-line);
  padding-left: 0.8rem;
}
.paincal__label {
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--color-ink);
}
.paincal__tag {
  display: inline-block;
  margin-top: 0.15rem;
  font-size: 0.78rem;
  line-height: 1.4;
  color: var(--color-muted);
}
.paincal__slot[data-kind="wrong"] {
  background: var(--color-surface-soft);
}
.paincal__slot[data-kind="wrong"] .paincal__label {
  font-weight: 500;
  color: var(--color-muted);
}
.paincal__slot[data-kind="missed"] .paincal__event {
  border-left-style: dashed;
}
.paincal__slot[data-kind="missed"] .paincal__label {
  font-weight: 500;
  color: var(--color-muted);
  text-decoration: line-through;
  text-decoration-color: var(--color-line);
}
.paincal__slot[data-kind="real"] {
  background: var(--color-brand-50);
}
.paincal__slot[data-kind="real"] .paincal__event {
  border-left-color: var(--color-brand-600);
}
.paincal__slot[data-kind="real"] .paincal__tag {
  font-weight: 600;
  color: var(--color-brand-700);
}
.pain__pivot {
  margin-top: clamp(2.5rem, 5vw, 4rem);
  padding-top: 2rem;
  border-top: 1px solid var(--color-line);
  text-align: center;
}
.pain__pivot-text {
  max-width: 40rem;
  margin-inline: auto;
  font-family: var(--font-display);
  font-size: clamp(1.35rem, 1.1rem + 1vw, 1.85rem);
  line-height: 1.32;
  letter-spacing: -0.015em;
  color: var(--color-ink);
}
.pain__badges {
  list-style: none;
  margin: 1.5rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.6rem;
}
.pain__badge {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 0.95rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font-size: 0.92rem;
  font-weight: 600;
}
.pain__badge svg {
  width: 0.85rem;
  height: 0.85rem;
}
.how {
  background: var(--color-surface);
}
.how__intro {
  max-width: 56ch;
}
.how__steps {
  list-style: none;
  margin: 2.75rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.5rem;
}
@media (min-width: 880px) {
  .how__steps {
    grid-template-columns: repeat(3, 1fr);
  }
}
.how__step {
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.how__head {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}
.how__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.7rem;
  height: 1.7rem;
  flex-shrink: 0;
  border-radius: 999px;
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font-size: 0.82rem;
  font-weight: 700;
}
.how__step-name {
  font-size: 1.15rem;
  color: var(--color-ink);
}
.how__stage {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 9.5rem;
  margin-top: 1rem;
  padding: 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
}
.how__step-text {
  margin-top: 1rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.how__chat {
  display: flex;
  flex-direction: column;
  gap: 0.45rem;
}
.how__bubble {
  max-width: 92%;
  padding: 0.55rem 0.8rem;
  border-radius: var(--radius-card);
  font-size: 0.86rem;
  line-height: 1.5;
}
.how__bubble--you {
  align-self: flex-end;
  background: var(--color-surface-soft);
  color: var(--color-ink);
  border-bottom-right-radius: 0.3rem;
}
.how__bubble--bot {
  align-self: flex-start;
  background: var(--color-inverse);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
  border-bottom-left-radius: 0.3rem;
}
.how__pay {
  padding: 0.9rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  border: 1px solid var(--color-brand-100);
}
.how__pay-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-brand-700);
}
.how__pay-detail {
  margin-top: 0.15rem;
  font-size: 0.88rem;
  color: var(--color-ink);
}
.how__pay-btn {
  display: block;
  margin-top: 0.7rem;
  padding: 0.55rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font-size: 0.85rem;
  font-weight: 600;
  text-align: center;
}
.how__booked {
  display: flex;
  gap: 0.7rem;
  align-items: flex-start;
  padding: 0.9rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  border: 1px solid var(--color-brand-100);
}
.how__booked-check {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.6rem;
  height: 1.6rem;
  flex-shrink: 0;
  border-radius: 999px;
  background: var(--color-brand-600);
  color: var(--color-inverse);
}
.how__booked-check svg {
  width: 0.9rem;
  height: 0.9rem;
}
.how__booked-title {
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-brand-700);
}
.how__booked-detail {
  margin-top: 0.15rem;
  font-size: 0.86rem;
  line-height: 1.5;
  color: var(--color-ink);
}
.how__cta {
  margin-top: 2.5rem;
}
.works {
  background: var(--color-surface);
}
.works__viz {
  display: flex;
  flex-direction: column;
  gap: 1.3rem;
}
.browser {
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  background: var(--color-inverse);
  box-shadow: var(--shadow-pop);
  overflow: hidden;
}
.browser__bar {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.7rem 0.9rem;
  background: var(--color-surface);
  border-bottom: 1px solid var(--color-line);
}
.browser__dot {
  width: 0.5rem;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-line);
}
.browser__url {
  margin-left: 0.5rem;
  padding: 0.2rem 0.75rem;
  border-radius: 999px;
  background: var(--color-surface-soft);
  font-size: 0.75rem;
  color: var(--color-muted);
}
.browser__page {
  position: relative;
  display: flex;
  flex-direction: column;
  gap: 0.8rem;
  min-height: 14rem;
  padding: 1.1rem;
}
.browser__nav {
  display: flex;
  align-items: center;
  justify-content: space-between;
}
.browser__logo {
  width: 3rem;
  height: 0.7rem;
  border-radius: 999px;
  background: var(--color-brand-200);
}
.browser__navlinks {
  width: 6rem;
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-line);
}
.browser__hero {
  height: 4.75rem;
  border-radius: var(--radius-card);
  background: var(--color-surface-soft);
}
.browser__lines {
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.browser__lines span {
  height: 0.5rem;
  border-radius: 999px;
  background: var(--color-line);
}
.browser__lines span:nth-child(1) {
  width: 88%;
}
.browser__lines span:nth-child(2) {
  width: 72%;
}
.browser__lines span:nth-child(3) {
  width: 80%;
}
.browser__widget {
  position: absolute;
  right: 0.9rem;
  bottom: 0.9rem;
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.5rem 0.9rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font-size: 0.8rem;
  font-weight: 600;
  box-shadow: var(--shadow-card);
}
.browser__widget svg {
  width: 0.95rem;
  height: 0.95rem;
}
.works__connects-label {
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-ink);
  text-align: center;
}
.works__chips {
  list-style: none;
  margin: 0.7rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 0.5rem;
}
.works__chip {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.45rem 0.9rem;
  border-radius: var(--radius-pill);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-ink);
}
.works__chip svg {
  width: 0.8rem;
  height: 0.8rem;
  color: var(--color-brand-600);
}
@media (prefers-reduced-motion: no-preference) {
  .browser__widget {
    animation: works-pop 0.5s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  }
  @keyframes works-pop {
    from {
      opacity: 0;
      transform: scale(0.7);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }
}
.setup {
  background: var(--color-surface-soft);
  --setup-dwell: 6.5s;
}
.setup__intro {
  max-width: 54ch;
}
.setup__acc {
  margin-top: 2.6rem;
}
.setup__item {
  position: relative;
  border-top: 1px solid var(--color-line);
  transition: background 0.25s ease;
}
.setup__item.is-open {
  background: var(--color-surface-raised);
}
.setup__h {
  margin: 0;
}
.setup__btn {
  width: 100%;
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1.1rem 1.35rem;
  background: none;
  border: 0;
  font: inherit;
  text-align: left;
  cursor: pointer;
  -webkit-tap-highlight-color: transparent;
}
.setup__btn:focus-visible {
  outline: 2px solid var(--color-brand-600);
  outline-offset: -3px;
}
.setup__icon {
  display: grid;
  place-items: center;
  width: 2.6rem;
  height: 2.6rem;
  flex-shrink: 0;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  color: var(--color-brand-600);
  transition: background 0.3s ease, color 0.3s ease;
}
.setup__icon svg {
  width: 1.3rem;
  height: 1.3rem;
}
.setup__item.is-open .setup__icon {
  background: var(--color-brand-600);
  color: var(--color-inverse);
}
.setup__name {
  flex: 1;
  font-family: var(--font-display);
  font-size: 1.22rem;
  font-weight: 500;
  letter-spacing: -0.01em;
  color: var(--color-ink);
}
.setup__chev {
  display: grid;
  place-items: center;
  color: var(--color-muted);
  transition: transform 0.35s cubic-bezier(0.4, 0, 0.2, 1), color 0.25s ease;
}
.setup__chev svg {
  width: 1.15rem;
  height: 1.15rem;
}
.setup__item.is-open .setup__chev {
  transform: rotate(180deg);
  color: var(--color-brand-600);
}
.setup__panel {
  display: grid;
  grid-template-rows: 0fr;
  transition: grid-template-rows 0.44s cubic-bezier(0.4, 0, 0.2, 1);
}
.setup__item.is-open .setup__panel {
  grid-template-rows: 1fr;
}
.setup__clip {
  overflow: hidden;
  min-height: 0;
}
.setup__inner {
  display: grid;
  gap: 1.4rem;
  padding: 0.35rem 1.35rem 1.7rem;
}
.setup__text {
  font-size: 1rem;
  line-height: 1.6;
  color: var(--color-body);
}
@media (min-width: 800px) {
  .setup__inner {
    grid-template-columns: 0.82fr 1.18fr;
    gap: 2.2rem;
    align-items: center;
    padding: 0.5rem 1.6rem 1.95rem 4.95rem;
  }
}
.setup__bar {
  position: absolute;
  left: 0;
  right: 0;
  bottom: 0;
  height: 3px;
  background: var(--color-brand-50);
  opacity: 0;
  transition: opacity 0.25s ease;
}
.setup__item.is-open .setup__bar {
  opacity: 1;
}
.setup__bar i {
  display: block;
  height: 100%;
  width: 0;
  background: var(--color-brand-500);
}
.setup__item.is-open .setup__bar i {
  animation: setup-fill var(--setup-dwell) linear forwards;
}
.setup__acc.is-paused .setup__item.is-open .setup__bar i, .setup__acc.is-away .setup__item.is-open .setup__bar i {
  animation-play-state: paused;
}
@keyframes setup-fill {
  to {
    width: 100%;
  }
}
.setup__viz {
  display: flex;
  align-items: center;
  justify-content: center;
}
.brf {
  width: 100%;
  max-width: 21rem;
}
.brf__card {
  width: 100%;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.brf__top {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  padding: 0.9rem;
  border-bottom: 1px solid var(--color-line);
}
.brf__avatar {
  display: grid;
  place-items: center;
  width: 2.5rem;
  height: 2.5rem;
  flex-shrink: 0;
  border-radius: var(--radius-pill);
  background: var(--color-brand-600);
  color: var(--color-inverse);
}
.brf__avatar svg {
  width: 1.2rem;
  height: 1.2rem;
}
.brf__id {
  flex: 1;
  display: flex;
  flex-direction: column;
  gap: 0.1rem;
}
.brf__name {
  font-size: 0.92rem;
  font-weight: 700;
  color: var(--color-ink);
}
.brf__role {
  font-size: 0.78rem;
  color: var(--color-muted);
}
.brf__status {
  display: inline-flex;
  align-items: center;
  gap: 0.32rem;
  flex-shrink: 0;
  font-size: 0.68rem;
  font-weight: 700;
  color: var(--color-brand-700);
}
.brf__statusdot {
  width: 0.42rem;
  height: 0.42rem;
  border-radius: var(--radius-pill);
  background: var(--color-accent);
}
.brf__caps {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.4rem;
  padding: 0.85rem 0.9rem;
}
.brf__caplabel {
  font-size: 0.66rem;
  font-weight: 700;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-muted);
  margin-right: 0.1rem;
}
.brf__cap {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.3rem 0.66rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-50);
  color: var(--color-brand-700);
}
.rdoc {
  width: 100%;
  max-width: 21rem;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
  box-shadow: var(--shadow-card);
  overflow: hidden;
}
.rdoc__top {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.6rem 0.9rem;
  background: var(--color-surface-soft);
  border-bottom: 1px solid var(--color-line);
}
.rdoc__tab {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-ink);
}
.rdoc__hint {
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.rdoc__lines {
  list-style: none;
  margin: 0;
  padding: 0.75rem 0.9rem;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.rdoc__line {
  display: flex;
  align-items: flex-start;
  gap: 0.55rem;
}
.rdoc__tick {
  display: grid;
  place-items: center;
  width: 1.1rem;
  height: 1.1rem;
  margin-top: 0.06rem;
  flex-shrink: 0;
  border-radius: var(--radius-pill);
  background: var(--color-brand-50);
  color: var(--color-brand-600);
}
.rdoc__tick svg {
  width: 0.68rem;
  height: 0.68rem;
}
.rdoc__txt {
  font-size: 0.88rem;
  line-height: 1.45;
  color: var(--color-body);
}
.rdoc__line--write {
  min-height: 1.1rem;
}
.rdoc__caret {
  display: block;
  width: 2px;
  height: 1.05rem;
  margin-left: 1.65rem;
  background: var(--color-brand-600);
}
.sess {
  width: 100%;
  max-width: 20rem;
  display: flex;
  flex-direction: column;
  gap: 0.9rem;
}
.sess__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.55rem;
}
.sess__row {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  padding: 0.7rem 0.85rem;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
}
.sess__dot {
  width: 0.5rem;
  height: 0.5rem;
  flex-shrink: 0;
  border-radius: var(--radius-pill);
  background: var(--color-brand-400);
}
.sess__name {
  flex: 1;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-ink);
}
.sess__len {
  font-size: 0.78rem;
  color: var(--color-muted);
}
.sess__fee {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--color-brand-700);
  padding: 0.2rem 0.6rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-50);
}
.sess__fee.is-free {
  color: var(--color-muted);
  background: var(--color-surface-soft);
}
.sess__meet {
  display: flex;
  flex-wrap: wrap;
  gap: 0.4rem;
}
.sess__pill {
  font-size: 0.76rem;
  font-weight: 600;
  padding: 0.35rem 0.72rem;
  border-radius: var(--radius-pill);
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  color: var(--color-muted);
}
.sess__pill.is-on {
  background: var(--color-brand-600);
  border-color: var(--color-brand-600);
  color: var(--color-inverse);
}
.cnx {
  display: flex;
  flex-direction: column;
  align-items: center;
  width: 100%;
  max-width: 17rem;
}
.cnx__node {
  display: flex;
  align-items: center;
  gap: 0.7rem;
  width: 100%;
  padding: 0.75rem 0.9rem;
  border-radius: var(--radius-card);
}
.cnx__node--app {
  background: var(--color-surface);
  border: 1px solid var(--color-line);
}
.cnx__node--hub {
  background: var(--color-brand-600);
  border: 1px solid var(--color-brand-700);
  box-shadow: var(--shadow-card);
}
.cnx__ic, .cnx__hubmark {
  display: grid;
  place-items: center;
  width: 2rem;
  height: 2rem;
  flex-shrink: 0;
  border-radius: 8px;
}
.cnx__ic {
  background: var(--color-brand-50);
  color: var(--color-brand-600);
}
.cnx__hubmark {
  background: rgba(255, 255, 255, 0.16);
  color: var(--color-inverse);
}
.cnx__ic svg, .cnx__hubmark svg {
  width: 1.1rem;
  height: 1.1rem;
}
.cnx__label {
  flex: 1;
  font-size: 0.92rem;
  font-weight: 600;
  color: var(--color-ink);
}
.cnx__node--hub .cnx__label {
  color: var(--color-inverse);
}
.cnx__tick {
  display: grid;
  place-items: center;
  width: 1.4rem;
  height: 1.4rem;
  flex-shrink: 0;
  border-radius: var(--radius-pill);
  background: var(--color-accent);
  color: var(--color-inverse);
}
.cnx__tick svg {
  width: 0.8rem;
  height: 0.8rem;
}
.cnx__wire {
  width: 2px;
  height: 1.35rem;
  background: var(--color-brand-200);
  border-radius: 2px;
}
.setup__cta {
  margin-top: 2.4rem;
}
@media (prefers-reduced-motion: no-preference) {
  .setup__item.is-open .brf__card {
    animation: setup-rise 0.5s both;
    animation-delay: 0.14s;
  }
  .setup__item.is-open .brf__cap {
    animation: setup-pop 0.4s both;
    animation-delay: calc(var(--ci) * 0.09s + 0.42s);
  }
  .setup__item.is-open .rdoc__line {
    animation: setup-rise 0.46s both;
    animation-delay: calc(var(--ln) * 0.11s + 0.18s);
  }
  .setup__item.is-open .rdoc__caret {
    animation: setup-blink 1.05s steps(1, end) infinite;
    animation-delay: 0.95s;
  }
  .setup__item.is-open .sess__row, .setup__item.is-open .sess__meet {
    animation: setup-rise 0.46s both;
    animation-delay: calc(var(--ln) * 0.1s + 0.16s);
  }
  .setup__item.is-open .cnx__node {
    animation: setup-rise 0.5s both;
    animation-delay: calc(var(--ln) * 0.12s + 0.12s);
  }
  .setup__item.is-open .cnx__wire {
    transform-origin: top;
    animation: setup-grow 0.32s both;
    animation-delay: calc(var(--ln) * 0.12s + 0.28s);
  }
  .setup__item.is-open .cnx__tick {
    animation: setup-pop 0.4s both;
    animation-delay: calc(var(--ln) * 0.12s + 0.46s);
  }
}
@keyframes setup-rise {
  from {
    opacity: 0;
    transform: translateY(9px);
  }
  to {
    opacity: 1;
    transform: none;
  }
}
@keyframes setup-grow {
  from {
    transform: scaleY(0);
  }
  to {
    transform: scaleY(1);
  }
}
@keyframes setup-pop {
  from {
    opacity: 0;
    transform: scale(0.4);
  }
  to {
    opacity: 1;
    transform: scale(1);
  }
}
@keyframes setup-blink {
  0%, 50% {
    opacity: 1;
  }
  50.01%, 100% {
    opacity: 0;
  }
}
@media (prefers-reduced-motion: reduce) {
  .setup__bar {
    display: none;
  }
}
.control {
  background: var(--color-surface);
}
.control__body {
  max-width: 54ch;
}
.control__points {
  list-style: none;
  margin: 2.75rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.5rem;
}
@media (min-width: 880px) {
  .control__points {
    grid-template-columns: repeat(3, 1fr);
  }
}
.control__card {
  display: flex;
  flex-direction: column;
  padding: 1.5rem;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.control__card-title {
  font-size: 1.15rem;
  color: var(--color-ink);
}
.control__stage {
  flex: 1;
  display: flex;
  flex-direction: column;
  justify-content: flex-start;
  min-height: 11rem;
  margin-top: 1rem;
  padding: 1rem;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
}
.control__card-text {
  margin-top: 1rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.cv-rules {
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.cv-rules__head {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.cv-rules__dot {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-brand-600);
}
.cv-rules__list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.5rem;
}
.cv-rules__list li {
  padding-left: 0.7rem;
  border-left: 2px solid var(--color-brand-300);
  font-size: 0.86rem;
  line-height: 1.45;
  color: var(--color-ink);
}
.cv-flow {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.cv-flow__chain {
  width: 100%;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.25rem;
}
.cv-flow__node {
  width: 100%;
  max-width: 13rem;
  padding: 0.5rem 0.9rem;
  text-align: center;
  border-radius: var(--radius-card);
  background: var(--color-inverse);
  border: 1px solid var(--color-line);
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--color-ink);
}
.cv-flow__node--end {
  background: var(--color-brand-600);
  border-color: var(--color-brand-600);
  color: var(--color-inverse);
}
.cv-flow__arrow {
  display: flex;
  color: var(--color-brand-400);
}
.cv-flow__arrow svg {
  width: 1.05rem;
  height: 1.05rem;
}
.cv-flow__caption {
  margin-top: 0.75rem;
  font-size: 0.8rem;
  line-height: 1.45;
  text-align: center;
  color: var(--color-muted);
}
.cv-appr {
  padding: 0.95rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  border: 1px solid var(--color-brand-100);
}
.cv-appr__head {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-brand-700);
}
.cv-appr__label {
  margin-top: 0.4rem;
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-ink);
}
.cv-appr__meta {
  margin-top: 0.1rem;
  font-size: 0.8rem;
  color: var(--color-muted);
}
.cv-appr__btns {
  display: flex;
  gap: 0.5rem;
  margin-top: 0.85rem;
}
.cv-appr__btn {
  flex: 1;
  padding: 0.5rem;
  text-align: center;
  border-radius: var(--radius-card);
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
}
.cv-appr__btn--ok {
  background: var(--color-brand-600);
  border-color: var(--color-brand-600);
  color: var(--color-inverse);
}
.control__trust-heading {
  margin-top: clamp(3rem, 6vw, 4.5rem);
  max-width: 24ch;
}
.control__trust {
  list-style: none;
  margin: 2rem 0 0;
  padding: 0;
  display: grid;
  gap: 1.25rem;
}
@media (min-width: 760px) {
  .control__trust {
    grid-template-columns: repeat(3, 1fr);
    gap: 1.5rem;
  }
}
.control__tcard {
  padding: 1.4rem;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-card);
}
.control__tcard-title {
  color: var(--color-ink);
}
.control__tcard-text {
  margin-top: 0.4rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.improve {
  background: var(--color-surface-soft);
}
.improve__body {
  max-width: 54ch;
}
.improve__grid {
  margin-top: 2.75rem;
  display: grid;
  gap: 1.75rem;
  align-items: center;
}
@media (min-width: 880px) {
  .improve__grid {
    grid-template-columns: 1fr 1fr;
    gap: 2.5rem;
  }
}
.improve__steps {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 1.25rem;
}
.improve__step {
  display: flex;
  gap: 0.9rem;
  align-items: flex-start;
}
.improve__num {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 1.7rem;
  height: 1.7rem;
  flex-shrink: 0;
  border-radius: 999px;
  background: var(--color-brand-600);
  color: var(--color-inverse);
  font-size: 0.82rem;
  font-weight: 700;
}
.improve__step-title {
  font-size: 1.1rem;
  color: var(--color-ink);
}
.improve__step-text {
  margin-top: 0.3rem;
  font-size: 0.95rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.improve__panel {
  padding: 1.5rem;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.ip__tag {
  display: flex;
  align-items: center;
  gap: 0.45rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-brand-700);
}
.ip__dot {
  width: 0.45rem;
  height: 0.45rem;
  border-radius: 999px;
  background: var(--color-brand-600);
}
.ip__label {
  margin-top: 1rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.ip__pattern {
  margin-top: 0.3rem;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-ink);
}
.ip__fix {
  margin-top: 0.35rem;
  padding: 0.7rem 0.85rem;
  border-radius: var(--radius-card);
  background: var(--color-brand-50);
  border-left: 2px solid var(--color-brand-300);
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-ink);
}
.ip__tested {
  display: flex;
  align-items: flex-start;
  gap: 0.4rem;
  margin-top: 0.85rem;
  font-size: 0.82rem;
  line-height: 1.45;
  color: var(--color-muted);
}
.ip__tested svg {
  width: 0.9rem;
  height: 0.9rem;
  flex-shrink: 0;
  margin-top: 0.1rem;
  color: var(--color-brand-600);
}
.ip__btns {
  display: flex;
  gap: 0.5rem;
  margin-top: 1.1rem;
}
.ip__btn {
  flex: 1;
  padding: 0.55rem;
  text-align: center;
  border-radius: var(--radius-card);
  font-size: 0.85rem;
  font-weight: 600;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  color: var(--color-ink);
}
.ip__btn--ok {
  background: var(--color-brand-600);
  border-color: var(--color-brand-600);
  color: var(--color-inverse);
}
.improve__foot {
  margin-top: 2.5rem;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 1rem;
  text-align: center;
}
.improve__trust {
  font-family: var(--font-display);
  font-size: clamp(1.25rem, 1.1rem + 0.7vw, 1.6rem);
  line-height: 1.3;
  color: var(--color-ink);
  max-width: 24ch;
}
.improve__note {
  font-size: 0.85rem;
  color: var(--color-muted);
}
.revenue {
  background: var(--color-surface-soft);
}
.roi {
  padding: clamp(1.3rem, 1rem + 1.2vw, 1.8rem);
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-card);
}
.roi__row {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
}
.roi__label {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-ink);
}
.roi__fee {
  font-family: var(--font-display);
  font-size: 1.6rem;
  font-weight: 600;
  color: var(--color-brand-700);
  font-variant-numeric: tabular-nums;
}
.roi__slider {
  width: 100%;
  margin-top: 0.9rem;
  accent-color: var(--color-brand-600);
  cursor: pointer;
}
.roi__scale {
  display: flex;
  justify-content: space-between;
  margin-top: 0.35rem;
  font-size: 0.78rem;
  color: var(--color-muted);
}
.roi__result {
  margin-top: 1.4rem;
  padding-top: 1.4rem;
  border-top: 1px solid var(--color-line);
  text-align: center;
}
.roi__lead {
  font-size: 0.95rem;
  color: var(--color-muted);
}
.roi__big {
  margin-top: 0.15rem;
  font-family: var(--font-display);
  font-size: clamp(2.4rem, 1.7rem + 2.8vw, 3.2rem);
  font-weight: 600;
  line-height: 1.05;
  letter-spacing: -0.02em;
  color: var(--color-brand-600);
}
.roi__big output {
  font-variant-numeric: tabular-nums;
}
.roi__sub {
  margin-top: 0.3rem;
  font-size: 0.95rem;
  color: var(--color-muted);
}
.roi__compare {
  margin-top: 1.4rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.roi__bar-row {
  display: flex;
  align-items: center;
  gap: 0.75rem;
}
.roi__bar-name {
  width: 6.4rem;
  flex-shrink: 0;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-ink);
}
.roi__track {
  flex: 1;
  height: 0.7rem;
  border-radius: 999px;
  background: var(--color-surface-soft);
  overflow: hidden;
}
.roi__fill {
  display: block;
  height: 100%;
  width: 100%;
  border-radius: 999px;
  background: var(--color-brand-600);
}
.roi__fill--cost {
  background: var(--color-brand-300);
}
.roi__bar-val {
  width: 4.3rem;
  flex-shrink: 0;
  text-align: right;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--color-ink);
  font-variant-numeric: tabular-nums;
}
.roi__keep {
  margin-top: 1.3rem;
  padding-top: 1.2rem;
  border-top: 1px solid var(--color-line);
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-muted);
}
@media (prefers-reduced-motion: no-preference) {
  .roi__fill {
    transition: width 0.25s cubic-bezier(0.22, 1, 0.36, 1);
  }
}
.pricing {
  background: var(--color-surface);
}
.pricing__intro {
  max-width: 40rem;
  margin-inline: auto;
  text-align: center;
}
.pricing__compare {
  max-width: 34rem;
  margin: 2.5rem auto 0;
  padding: 1.5rem 1.75rem;
  background: var(--color-surface);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.pricing__compare-head {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--color-ink);
}
.pricing__compare-list {
  list-style: none;
  margin: 1rem 0 0;
  padding: 0;
  display: flex;
  flex-wrap: wrap;
  gap: 0.7rem 1.4rem;
}
.pricing__compare-item {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.92rem;
  color: var(--color-muted);
}
.pricing__compare-item svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
}
.pricing__compare-item s {
  text-decoration-color: var(--color-line);
}
.pricing__compare-foot {
  margin-top: 1rem;
  padding-top: 1rem;
  border-top: 1px solid var(--color-line);
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-ink);
}
.pricing__billing {
  width: fit-content;
  margin: 2rem auto 0;
  display: flex;
  gap: 0.25rem;
  padding: 0.25rem;
  background: var(--color-surface-soft);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-pill);
}
.pricing__billing-opt {
  display: inline-flex;
  align-items: center;
  gap: 0.45rem;
  padding: 0.5rem 1.15rem;
  border: 0;
  border-radius: var(--radius-pill);
  background: transparent;
  font-family: inherit;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--color-muted);
  cursor: pointer;
  transition: background-color 0.15s ease, color 0.15s ease;
}
.pricing__billing-opt:hover {
  color: var(--color-ink);
}
.pricing__billing-opt.is-active {
  background: var(--color-surface-raised);
  color: var(--color-ink);
  box-shadow: var(--shadow-card);
}
.pricing__billing-badge {
  padding: 0.1rem 0.45rem;
  border-radius: var(--radius-pill);
  background: var(--color-brand-50);
  font-size: 0.65rem;
  font-weight: 700;
  letter-spacing: 0.03em;
  text-transform: uppercase;
  color: var(--color-brand-700);
}
.pricing__plans {
  margin: 1.5rem auto 0;
  display: grid;
  gap: 1.5rem;
  max-width: 26rem;
}
@media (min-width: 1000px) {
  .pricing__plans {
    grid-template-columns: repeat(3, 1fr);
    max-width: none;
  }
}
.pricing__plan {
  display: flex;
  flex-direction: column;
  padding: 2rem;
  background: var(--color-surface-raised);
  border: 1px solid var(--color-line);
  border-radius: var(--radius-lg);
}
.pricing__plan--featured {
  border: 1.5px solid var(--color-brand-600);
  box-shadow: var(--shadow-pop);
}
.pricing__plan-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
}
.pricing__plan-name {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--color-ink);
}
.pricing__plan-tag {
  flex-shrink: 0;
  padding: 0.25rem 0.65rem;
  border-radius: 999px;
  background: var(--color-brand-50);
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  text-transform: uppercase;
  color: var(--color-brand-700);
}
.pricing__price-wrap {
  margin-top: 0.9rem;
}
.pricing__price {
  display: flex;
  align-items: baseline;
  gap: 0.35rem;
}
.pricing__price--annual {
  display: none;
}
.pricing[data-billing="annual"] .pricing__price--monthly {
  display: none;
}
.pricing[data-billing="annual"] .pricing__price--annual {
  display: flex;
}
.pricing__amount {
  font-family: var(--font-display);
  font-size: clamp(2.6rem, 2rem + 2.4vw, 3.4rem);
  font-weight: 600;
  line-height: 1;
  letter-spacing: -0.02em;
  color: var(--color-ink);
}
.pricing__period {
  font-size: 1.05rem;
  color: var(--color-muted);
}
.pricing__price-note {
  display: none;
  margin-top: 0.5rem;
  font-size: 0.85rem;
  color: var(--color-muted);
}
.pricing[data-billing="annual"] .pricing__price-note {
  display: block;
}
.pricing__plan-summary {
  margin-top: 0.7rem;
  font-size: 0.92rem;
  line-height: 1.5;
  color: var(--color-muted);
}
.pricing__cta {
  margin-top: 1.5rem;
}
.pricing__plan-note {
  margin-top: 0.9rem;
  font-size: 0.85rem;
  text-align: center;
  color: var(--color-muted);
}
.pricing__includes-label {
  margin-top: 1.6rem;
  padding-top: 1.3rem;
  border-top: 1px solid var(--color-line);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.pricing__includes {
  list-style: none;
  margin: 0.9rem 0 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.65rem;
}
.pricing__includes li {
  display: flex;
  align-items: center;
  gap: 0.55rem;
  font-size: 0.95rem;
  color: var(--color-body);
}
.pricing__includes svg {
  width: 1rem;
  height: 1rem;
  flex-shrink: 0;
  color: var(--color-brand-600);
}
.pricing__faq {
  max-width: 44rem;
  margin: 3.5rem auto 0;
}
.pricing__faq-head {
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.pricing__faq-list {
  margin-top: 1rem;
  border-top: 1px solid var(--color-line);
}
.pricing__faq-item {
  border-bottom: 1px solid var(--color-line);
}
.pricing__faq-q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 0;
  font-weight: 600;
  color: var(--color-ink);
  cursor: pointer;
  list-style: none;
}
.pricing__faq-q::-webkit-details-marker {
  display: none;
}
.pricing__faq-q::after {
  content: "";
  flex: none;
  width: 0.58rem;
  height: 0.58rem;
  border-right: 2px solid var(--color-muted);
  border-bottom: 2px solid var(--color-muted);
  transform: rotate(45deg);
  transition: transform 0.2s ease;
}
.pricing__faq-item[open] .pricing__faq-q::after {
  transform: rotate(-135deg);
}
.pricing__faq-a {
  padding: 0 0 1.2rem;
  max-width: 62ch;
  color: var(--color-muted);
}
.faq {
  background: var(--color-surface-soft);
}
.faq__inner {
  max-width: 44rem;
  margin-inline: auto;
}
.faq__heading {
  margin-top: 0.7rem;
}
.faq__list {
  margin-top: 2rem;
  border-top: 1px solid var(--color-line);
}
.faq__item {
  border-bottom: 1px solid var(--color-line);
}
.faq__q {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  padding: 1.1rem 0;
  font-weight: 600;
  color: var(--color-ink);
  cursor: pointer;
  list-style: none;
}
.faq__q::-webkit-details-marker {
  display: none;
}
.faq__q::after {
  content: "";
  flex: none;
  width: 0.58rem;
  height: 0.58rem;
  border-right: 2px solid var(--color-muted);
  border-bottom: 2px solid var(--color-muted);
  transform: rotate(45deg);
  transition: transform .2s ease;
}
.faq__item[open] .faq__q::after {
  transform: rotate(-135deg);
}
.faq__a {
  padding: 0 0 1.2rem;
  max-width: 62ch;
  color: var(--color-muted);
}
.faq__final {
  margin-top: 4rem;
  padding-top: 3rem;
  border-top: 1px solid var(--color-line);
  text-align: center;
}
.faq__final .btn-primary {
  margin-top: 1.75rem;
}
.book-kicker {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  margin: 0;
  font-size: 0.74rem;
  font-weight: 600;
  letter-spacing: 0.15em;
  text-transform: uppercase;
  color: var(--color-brand-600);
}
.book-kicker::before {
  content: "";
  width: 1.75rem;
  height: 2px;
  background: var(--color-brand-600);
}
.book-crumb {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.book-crumb a {
  color: var(--color-muted);
  transition: color 0.15s ease;
}
.book-crumb a:hover {
  color: var(--color-brand-600);
}
.book-crumb__sep {
  color: var(--color-line);
}
.book-crumb [aria-current] {
  color: var(--color-ink);
}
.book-library {
  max-width: 66rem;
  margin-inline: auto;
  padding: clamp(2.75rem, 6vw, 5rem) 1.5rem clamp(4rem, 8vw, 7rem);
  background: radial-gradient(58% 15rem at 50% -1rem, var(--color-brand-100), transparent 72%) no-repeat;
  @supports (color: color-mix(in lab, red, red)) {
    background: radial-gradient(58% 15rem at 50% -1rem, color-mix(in srgb, var(--color-brand-100) 52%, transparent), transparent 72%) no-repeat;
  }
}
.book-library__head {
  padding-bottom: 1.5rem;
  border-bottom: 1px solid var(--color-line);
}
.book-library__title {
  margin-top: 0.85rem;
  font-size: clamp(2.7rem, 1.6rem + 4.4vw, 4.2rem);
  line-height: 0.98;
  letter-spacing: -0.028em;
  font-weight: 540;
}
.book-library__dek {
  margin-top: 1rem;
  max-width: 34rem;
  font-size: 1.12rem;
  line-height: 1.6;
  color: var(--color-muted);
}
.book-library__dek p {
  margin: 0;
}
.book-shelf {
  list-style: none;
  margin: 3rem 0 0;
  padding: 0;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(14.5rem, 1fr));
  gap: 3rem 2rem;
}
.book-card {
  margin: 0;
}
.book-card__cover-link {
  position: relative;
  display: block;
  border-radius: 3px 9px 9px 3px;
}
.book-card__cover-link::after {
  content: "";
  position: absolute;
  left: 9%;
  right: 5%;
  bottom: -13px;
  height: 24px;
  z-index: -1;
  background: radial-gradient(ellipse 50% 50% at 50% 50%, rgba(14, 37, 29, 0.36), transparent 73%);
  filter: blur(4px);
  transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1), opacity 0.34s ease;
}
.book-cover {
  position: relative;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  gap: 0.6rem;
  aspect-ratio: 5 / 7;
  padding: 1.4rem 1.3rem 1.3rem 1.75rem;
  border-radius: 3px 9px 9px 3px;
  color: #f4efe1;
  background: repeating-linear-gradient(0deg, rgba(255, 255, 255, 0.045) 0 1px, transparent 1px 3px), repeating-linear-gradient(90deg, rgba(0, 0, 0, 0.07) 0 1px, transparent 1px 3px), radial-gradient(120% 68% at 24% 0%, rgba(255, 255, 255, 0.11), transparent 46%), linear-gradient(165deg, var(--color-brand-600), var(--color-brand-900) 92%);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.16), inset 0 0 0 1px rgba(255, 255, 255, 0.05), 0 14px 24px -14px rgba(14, 37, 29, 0.7);
  transition: transform 0.34s cubic-bezier(0.22, 1, 0.36, 1), box-shadow 0.34s ease;
}
.book-cover__spine {
  position: absolute;
  inset: 0 auto 0 0;
  width: 13px;
  border-radius: 3px 0 0 3px;
  background: linear-gradient(90deg, rgba(0, 0, 0, 0.36) 0%, rgba(0, 0, 0, 0.1) 62%, rgba(255, 255, 255, 0.07) 100%);
}
.book-cover__edge {
  position: absolute;
  inset: 6% 0 6% auto;
  width: 4px;
  border-radius: 0 2px 2px 0;
  background: repeating-linear-gradient(0deg, #efe7d2 0 2px, #cabf9d 2px 3px);
}
.book-cover__head {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.5rem;
}
.book-cover__label, .book-cover__vol, .book-cover__count {
  font-size: 0.6rem;
  font-weight: 600;
  letter-spacing: 0.18em;
  text-transform: uppercase;
  color: var(--color-brand-100);
}
.book-cover__vol {
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.1em;
}
.book-cover__title {
  font-family: var(--font-display);
  font-weight: 540;
  font-size: clamp(1.4rem, 1.2rem + 0.7vw, 1.72rem);
  line-height: 1.08;
  letter-spacing: -0.018em;
  text-wrap: balance;
  text-shadow: 0 1px 1px rgba(0, 0, 0, 0.35);
}
.book-cover__foot {
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.book-cover__flourish {
  width: 1.6rem;
  height: 1px;
  background: currentColor;
  opacity: 0.45;
}
.book-card__meta {
  margin-top: 1.5rem;
  display: flex;
  flex-direction: column;
  gap: 0.6rem;
}
.book-card__desc {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--color-muted);
}
.book-card__open {
  font-size: 0.82rem;
  font-weight: 600;
  letter-spacing: 0.01em;
  color: var(--color-brand-600);
}
.book-card__open span {
  display: inline-block;
  transition: transform 0.18s ease;
}
.book-card:hover .book-cover {
  transform: translateY(-10px) rotate(-1.1deg);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.18), inset 0 0 0 1px rgba(255, 255, 255, 0.06), 0 30px 44px -20px rgba(14, 37, 29, 0.8);
}
.book-card:hover .book-card__cover-link::after {
  transform: translateY(9px) scaleX(1.06);
  opacity: 0.8;
}
.book-card:hover .book-card__open span {
  transform: translateX(4px);
}
.book-empty {
  list-style: none;
  grid-column: 1 / -1;
  color: var(--color-muted);
}
.book-landing {
  max-width: 52rem;
  margin-inline: auto;
  padding: clamp(2.25rem, 5vw, 3.5rem) 1.5rem clamp(4rem, 8vw, 6rem);
  background: radial-gradient(64% 13rem at 50% -1rem, var(--color-brand-100), transparent 74%) no-repeat;
  @supports (color: color-mix(in lab, red, red)) {
    background: radial-gradient(64% 13rem at 50% -1rem, color-mix(in srgb, var(--color-brand-100) 46%, transparent), transparent 74%) no-repeat;
  }
}
.book-landing__head {
  margin-top: 1.5rem;
}
.book-landing__title {
  margin-top: 0.7rem;
  font-size: clamp(2.4rem, 1.5rem + 3.6vw, 3.5rem);
  line-height: 1.02;
  letter-spacing: -0.026em;
  font-weight: 540;
  text-wrap: balance;
}
.book-landing__dek {
  margin-top: 1rem;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: clamp(1.2rem, 1.05rem + 0.6vw, 1.4rem);
  line-height: 1.45;
  color: var(--color-muted);
  max-width: 36rem;
}
.book-landing__intro {
  margin-top: 1.5rem;
}
.book-contents {
  margin-top: clamp(2.5rem, 5vw, 3.75rem);
}
.book-contents__label {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 1rem;
  margin: 0;
  padding-bottom: 0.7rem;
  border-bottom: 2px solid var(--color-ink);
  font-size: 0.78rem;
  font-weight: 600;
  letter-spacing: 0.16em;
  text-transform: uppercase;
  color: var(--color-ink);
}
.book-contents__count {
  color: var(--color-muted);
  letter-spacing: 0.08em;
  font-variant-numeric: tabular-nums;
}
.book-chapter-row {
  border-bottom: 1px solid var(--color-line);
}
.book-chapter-row::marker, .book-chapter-row > summary::marker, .book-chapter-row > summary::-webkit-details-marker {
  display: none;
}
.book-chapter-row__summary {
  display: grid;
  grid-template-columns: 3.4rem 1fr auto;
  align-items: center;
  gap: 0.4rem 1.4rem;
  padding: clamp(1.5rem, 3vw, 2.1rem) 0;
  cursor: pointer;
  list-style: none;
  transition: background-color 0.18s ease, padding-inline 0.18s ease, margin-inline 0.18s ease, border-radius 0.18s ease;
}
.book-chapter-row__summary::after {
  content: "";
  width: 0.55rem;
  height: 0.55rem;
  border-right: 2px solid var(--color-muted);
  border-bottom: 2px solid var(--color-muted);
  transform: rotate(-45deg);
  transition: transform 0.2s ease, border-color 0.15s ease;
  margin-right: 0.25rem;
}
.book-chapter-row[open] > .book-chapter-row__summary::after {
  transform: rotate(45deg);
}
.book-chapter-row__summary:hover {
  background: var(--color-surface-soft);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-soft) 60%, transparent);
  }
  margin-inline: -0.75rem;
  padding-inline: 0.75rem;
  border-radius: 8px;
}
.book-chapter-row__summary:hover::after {
  border-color: var(--color-brand-600);
}
.book-chapter-row__num {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.9rem, 1.5rem + 1vw, 2.4rem);
  font-weight: 500;
  line-height: 1;
  font-variant-numeric: tabular-nums;
  color: var(--color-brand-600);
}
.book-chapter-row__title {
  margin: 0;
  font-family: var(--font-display);
  font-size: clamp(1.3rem, 1.15rem + 0.6vw, 1.55rem);
  font-weight: 540;
  line-height: 1.18;
  letter-spacing: -0.012em;
}
.book-chapter-row__summary:hover .book-chapter-row__title {
  color: var(--color-brand-600);
}
.book-chapter-row__body {
  padding: 0.25rem 0 clamp(1.5rem, 3vw, 2rem) calc(3.4rem + 1.4rem);
}
.book-index {
  list-style: none;
  margin: 1.1rem 0 0;
  padding: 0;
  counter-reset: bidx;
}
.book-index__item {
  counter-increment: bidx;
}
.book-index__link {
  display: grid;
  grid-template-columns: 2.3rem 1fr auto;
  align-items: baseline;
  gap: 0.2rem 0.8rem;
  padding: 0.62rem 0.55rem;
  margin-inline: -0.55rem;
  border-radius: 7px;
  border-top: 1px solid var(--color-line);
  transition: background-color 0.15s ease;
}
.book-index__item:last-child .book-index__link {
  border-bottom: 1px solid var(--color-line);
}
.book-index__link::before {
  content: counter(bidx, decimal-leading-zero);
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.05em;
  font-variant-numeric: tabular-nums;
  color: var(--color-brand-300);
  transition: color 0.15s ease;
}
.book-index__title {
  font-size: 0.96rem;
  line-height: 1.45;
  color: var(--color-body);
  transition: color 0.15s ease;
}
.book-index__arrow {
  color: var(--color-brand-300);
  opacity: 0.6;
  transition: color 0.16s ease, transform 0.16s ease, opacity 0.16s ease;
}
.book-index__link:hover {
  background: var(--color-surface-soft);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-soft) 72%, transparent);
  }
}
.book-index__link:hover::before {
  color: var(--color-brand-600);
}
.book-index__link:hover .book-index__title {
  color: var(--color-ink);
}
.book-index__link:hover .book-index__arrow {
  color: var(--color-brand-600);
  opacity: 1;
  transform: translateX(3px);
}
.book-layout {
  max-width: 72rem;
  margin-inline: auto;
  padding: clamp(1.75rem, 4vw, 3rem) 1.5rem clamp(3.5rem, 7vw, 5.5rem);
  display: grid;
  gap: clamp(2rem, 5vw, 3.5rem);
}
@media (min-width: 1024px) {
  .book-layout {
    grid-template-columns: 15.5rem minmax(0, 1fr);
  }
}
.book-main {
  min-width: 0;
  max-width: 46rem;
}
.book-main--article {
  max-width: 44rem;
}
.book-head {
  margin-top: 1.25rem;
}
.book-head .book-kicker {
  margin-bottom: 0.75rem;
}
.book-head__title {
  margin: 0;
  font-size: clamp(1.85rem, 1.4rem + 1.9vw, 2.55rem);
  line-height: 1.08;
  letter-spacing: -0.022em;
  font-weight: 540;
  text-wrap: balance;
}
.book-aside {
  align-self: start;
}
@media (min-width: 1024px) {
  .book-aside {
    position: sticky;
    top: 5.25rem;
    max-height: calc(100vh - 7rem);
    overflow-y: auto;
    padding-right: 0.4rem;
    scrollbar-width: thin;
    scrollbar-color: var(--color-line) transparent;
  }
  .book-aside::-webkit-scrollbar {
    width: 6px;
  }
  .book-aside::-webkit-scrollbar-thumb {
    background: var(--color-line);
    border-radius: 999px;
  }
}
.book-nav {
  font-size: 0.9rem;
  counter-reset: bnav;
}
.book-nav__chapter {
  counter-increment: bnav;
}
.book-nav__chapter > summary::before {
  content: counter(bnav, decimal-leading-zero);
  font-family: var(--font-mono);
  font-size: 0.65rem;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  letter-spacing: 0.04em;
  color: var(--color-brand-300);
  flex: none;
}
.book-nav__home {
  display: block;
  padding-bottom: 0.75rem;
  margin-bottom: 0.3rem;
  font-family: var(--font-display);
  font-size: 1.08rem;
  font-weight: 560;
  letter-spacing: -0.01em;
  color: var(--color-ink);
  border-bottom: 2px solid var(--color-ink);
  transition: color 0.15s ease;
}
.book-nav__home:hover {
  color: var(--color-brand-600);
}
.book-nav__chapter {
  border-bottom: 1px solid var(--color-line);
}
.book-nav__chapter > summary {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.6rem;
  padding: 0.62rem 0;
  cursor: pointer;
  list-style: none;
  font-size: 0.86rem;
  font-weight: 600;
  color: var(--color-ink);
}
.book-nav__chapter > summary::-webkit-details-marker {
  display: none;
}
.book-nav__chapter > summary::after {
  content: "+";
  display: grid;
  place-items: center;
  width: 1.05rem;
  height: 1.05rem;
  flex: none;
  font-weight: 600;
  color: var(--color-brand-600);
  background: var(--color-surface-soft);
  border-radius: 5px;
  transition: background-color 0.15s ease;
}
.book-nav__chapter[open] > summary::after {
  content: "\2212";
}
.book-nav__chapter > summary:hover::after {
  background: var(--color-brand-50);
}
.book-nav__list {
  list-style: none;
  margin: 0;
  padding: 0.1rem 0 0.7rem;
}
.book-nav__list a {
  display: block;
  padding: 0.34rem 0 0.34rem 0.9rem;
  color: var(--color-muted);
  border-left: 2px solid var(--color-line);
  transition: color 0.15s ease, border-color 0.15s ease;
}
.book-nav__list a:hover {
  color: var(--color-ink);
  border-left-color: var(--color-brand-300);
}
.book-nav__list a.is-active {
  font-weight: 600;
  color: var(--color-brand-600);
  border-left-color: var(--color-brand-600);
}
.book-toc-box {
  margin: 1.5rem 0 0.5rem;
  padding: 0.5rem 1rem 0.75rem;
  border: 1px solid var(--color-line);
  border-left: 2px solid var(--color-brand-300);
  border-radius: 0 var(--radius-card) var(--radius-card) 0;
  background: var(--color-surface-soft);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-surface-soft) 58%, transparent);
  }
}
.book-toc-box > summary {
  cursor: pointer;
  list-style: none;
  padding: 0.25rem 0;
  font-size: 0.72rem;
  font-weight: 600;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.book-toc-box > summary::-webkit-details-marker {
  display: none;
}
.book-toc-box #TableOfContents ul {
  margin: 0;
  padding-left: 1rem;
  list-style: none;
}
.book-toc-box #TableOfContents > ul {
  padding-left: 0;
}
.book-toc-box #TableOfContents li {
  margin: 0.28rem 0;
}
.book-toc-box #TableOfContents a {
  font-size: 0.88rem;
  color: var(--color-muted);
  transition: color 0.15s ease;
}
.book-toc-box #TableOfContents a:hover {
  color: var(--color-brand-600);
}
.book-prose {
  --tw-prose-body: var(--color-body);
  --tw-prose-headings: var(--color-ink);
  --tw-prose-links: var(--color-brand-700);
  --tw-prose-bold: var(--color-ink);
  --tw-prose-counters: var(--color-brand-600);
  --tw-prose-bullets: var(--color-brand-300);
  --tw-prose-hr: var(--color-line);
  --tw-prose-quotes: var(--color-ink);
  --tw-prose-quote-borders: var(--color-brand-200);
  --tw-prose-captions: var(--color-muted);
  --tw-prose-code: var(--color-ink);
  --tw-prose-pre-code: #e9e3d4;
  --tw-prose-pre-bg: var(--color-brand-900);
  --tw-prose-th-borders: var(--color-line);
  --tw-prose-td-borders: var(--color-line);
  max-width: none;
  margin-top: 1.5rem;
  font-size: 1.06rem;
  line-height: 1.72;
}
.book-prose :is(h2, h3, h4) {
  font-family: var(--font-display);
  letter-spacing: -0.015em;
  scroll-margin-top: 6rem;
}
.book-prose h2 {
  font-weight: 540;
}
.book-prose > p:first-child {
  font-size: 1.16rem;
  line-height: 1.6;
  color: var(--color-ink);
}
.book-prose a {
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
}
.book-prose img {
  border: 1px solid var(--color-line);
  border-radius: 10px;
  background: #fff;
  padding: 6px;
  box-shadow: var(--shadow-card);
  margin-inline: auto;
  margin-block: 1.7rem;
}
.book-prose--intro {
  margin-top: 1rem;
  font-size: 1rem;
}
.book-prose--intro > p:first-child {
  font-size: 1rem;
  color: var(--color-body);
}
@media (min-width: 640px) {
  .book-prose:not(.book-prose--intro) > p:first-child::first-letter {
    font-family: var(--font-display);
    font-size: 3.5em;
    font-weight: 540;
    line-height: 0.82;
    float: left;
    margin: 0.05em 0.14em 0 0;
    color: var(--color-brand-600);
    text-shadow: 0 1px 0 var(--color-brand-600);
    @supports (color: color-mix(in lab, red, red)) {
      text-shadow: 0 1px 0 color-mix(in srgb, var(--color-brand-600) 20%, transparent);
    }
  }
}
.book-pager {
  margin-top: clamp(2.5rem, 5vw, 3.5rem);
  padding-top: 1.6rem;
  border-top: 1px solid var(--color-line);
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem 1.5rem;
}
.book-pager__link {
  display: flex;
  flex-direction: column;
  gap: 0.3rem;
}
.book-pager__link--next {
  text-align: right;
}
.book-pager__dir {
  font-size: 0.7rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  color: var(--color-muted);
}
.book-pager__title {
  font-family: var(--font-display);
  font-size: 1.05rem;
  font-weight: 540;
  line-height: 1.25;
  color: var(--color-ink);
  transition: color 0.16s ease;
  text-wrap: balance;
}
.book-pager__link:hover .book-pager__title {
  color: var(--color-brand-600);
}
.book-pager__arrow {
  display: inline-block;
  transition: transform 0.16s ease;
}
.book-pager__link--prev:hover .book-pager__arrow {
  transform: translateX(-3px);
}
.book-pager__link--next:hover .book-pager__arrow {
  transform: translateX(3px);
}
.book-prose .faq-section {
  margin-top: clamp(2.4rem, 4vw, 3.5rem);
  margin-bottom: 0;
}
.book-prose .faq-section__title {
  font-size: clamp(1.6rem, 1.3rem + 1.2vw, 1.95rem);
  font-weight: 540;
  font-family: var(--font-display);
  letter-spacing: -0.015em;
  margin-bottom: 1.6rem;
  color: var(--color-ink);
  animation: none;
}
.book-prose .faq-item {
  border-bottom: 1px solid var(--color-line);
  transition: background-color 0.2s ease, box-shadow 0.2s ease;
}
.book-prose .faq-item:first-child {
  border-top: 1px solid var(--color-line);
}
.book-prose .faq-item > summary {
  padding: 1rem 0;
  font-size: 1.04rem;
  font-weight: 600;
  color: var(--color-ink);
  transition: color 0.2s ease;
}
.book-prose .faq-item > summary::before {
  font-family: var(--font-display);
  font-size: 1.2rem;
  font-weight: 300;
  color: var(--color-brand-700);
  padding: 0.12rem 0 0 0.06rem;
}
.book-prose .faq-item > summary:hover {
  color: var(--color-brand-700);
}
.book-prose .faq-item > summary:hover::before {
  color: var(--color-brand-800);
}
.book-prose .faq-item[open] {
  background: var(--color-brand-100);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--color-brand-100) 8%, transparent);
  }
  box-shadow: inset 0 1px 2px rgba(74, 107, 77, 0.06);
}
.book-prose .faq-answer {
  padding: 0 0 1.1rem 3rem;
  font-size: 1.02rem;
  color: var(--color-body);
  line-height: 1.7;
}
.book-prose .faq-answer p {
  margin: 0;
}
.book-prose .faq-answer p + p {
  margin-top: 0.85rem;
}
.book-prose .faq-answer a {
  color: var(--color-brand-700);
  text-decoration: underline;
  text-underline-offset: 2px;
  text-decoration-thickness: 1px;
  transition: color 0.2s ease;
}
.book-prose .faq-answer a:hover {
  color: var(--color-brand-800);
}
@media (max-width: 768px) {
  .book-prose .faq-section__title {
    margin-bottom: 1.3rem;
  }
  .book-prose .faq-item > summary {
    padding: 0.92rem 0;
    font-size: 1rem;
  }
  .book-prose .faq-answer {
    padding: 0 0 0.95rem 2.8rem;
    font-size: 1rem;
  }
}
@media (max-width: 640px) {
  .book-prose .faq-section {
    margin-top: 2rem;
  }
  .book-prose .faq-section__title {
    font-size: 1.4rem;
    margin-bottom: 1.1rem;
  }
  .book-prose .faq-item > summary {
    padding: 0.8rem 0;
    font-size: 0.98rem;
  }
  .book-prose .faq-item > summary::before {
    font-size: 1.05rem;
    width: 1rem;
    height: 1rem;
  }
  .book-prose .faq-answer {
    padding: 0 0 0.8rem 2.2rem;
    font-size: 0.98rem;
    line-height: 1.65;
  }
  .book-prose .faq-answer p + p {
    margin-top: 0.6rem;
  }
}
.book-prose .sc-button {
  display: inline-flex;
  align-items: center;
  gap: 0.5rem;
  margin-top: 2.25rem;
  padding: 0.82rem 1.55rem;
  border-radius: var(--radius-pill);
  font-family: var(--font-sans);
  font-size: 0.98rem;
  font-weight: 600;
  text-decoration: none;
  transition: background-color 0.16s ease, transform 0.16s ease, box-shadow 0.16s ease;
}
.book-prose .sc-button--primary {
  background: var(--color-brand-600);
  color: var(--color-inverse);
  box-shadow: var(--shadow-card);
}
.book-prose .sc-button--primary:hover {
  background: var(--color-brand-700);
  transform: translateY(-2px);
  box-shadow: var(--shadow-pop);
}
.book-prose .sc-button--notice {
  background: var(--color-surface-soft);
  color: var(--color-ink);
  border: 1px solid var(--color-line);
}
.book-prose .sc-button--success {
  background: var(--color-accent);
  color: var(--color-inverse);
}
.book-prose .sc-button__icon {
  transition: transform 0.16s ease;
}
.book-prose .sc-button:hover .sc-button__icon {
  transform: translateX(3px);
}
@media (prefers-reduced-motion: no-preference) {
  @keyframes book-rise {
    from {
      opacity: 0;
      transform: translateY(16px);
    }
    to {
      opacity: 1;
      transform: none;
    }
  }
  .book-card {
    animation: book-rise 0.66s cubic-bezier(0.22, 1, 0.36, 1) backwards;
    animation-delay: calc(var(--i, 0) * 0.09s + 0.05s);
  }
  .book-library__head, .book-landing__head, .book-head {
    animation: book-rise 0.6s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  }
  .book-chapter-row {
    animation: book-rise 0.6s cubic-bezier(0.22, 1, 0.36, 1) backwards;
  }
  details[open].book-chapter-row > .book-chapter-row__body {
    animation: book-rise 0.22s cubic-bezier(0.22, 1, 0.36, 1);
  }
  .book-chapter-row:nth-child(2) {
    animation-delay: 0.04s;
  }
  .book-chapter-row:nth-child(3) {
    animation-delay: 0.08s;
  }
  .book-chapter-row:nth-child(4) {
    animation-delay: 0.12s;
  }
  .book-chapter-row:nth-child(5) {
    animation-delay: 0.16s;
  }
  .book-chapter-row:nth-child(n + 6) {
    animation-delay: 0.2s;
  }
}
@media (prefers-reduced-motion: reduce) {
  .book-card:hover .book-cover {
    transform: none;
  }
}
@media (max-width: 640px) {
  .book-shelf {
    grid-template-columns: repeat(auto-fill, minmax(11.5rem, 1fr));
    gap: 2.4rem 1.3rem;
  }
  .book-chapter-row__summary {
    grid-template-columns: 2.6rem 1fr auto;
    gap: 0.3rem 1rem;
  }
  .book-chapter-row__body {
    padding-left: calc(2.6rem + 1rem);
  }
  .book-pager {
    grid-template-columns: 1fr;
  }
  .book-pager__link--next {
    text-align: left;
  }
}
body.section-articles {
  --paper: var(--color-surface);
  --paper-soft: var(--color-surface-soft);
  --ink: var(--color-ink);
  --ink-soft: var(--color-muted);
  --rule: var(--color-line);
  --accent: var(--color-brand-600);
  background-color: var(--paper);
  color: var(--ink);
}
body.section-articles::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='150' height='150'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='2' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)' opacity='0.04'/%3E%3C/svg%3E");
}
.dispatch, .essay {
  margin-inline: auto;
  padding-inline: 1.5rem;
}
.dispatch {
  max-width: 64rem;
  padding-block: clamp(2.5rem, 6vw, 4.5rem);
}
.essay {
  max-width: 41rem;
  padding-block: clamp(2.5rem, 6vw, 4.5rem);
}
body.section-articles .mono {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  font-weight: 500;
  letter-spacing: 0.13em;
  text-transform: uppercase;
}
.dispatch-topline {
  display: flex;
  justify-content: space-between;
  gap: 1rem;
  color: var(--accent);
}
.dispatch-topline span:last-child {
  color: var(--ink-soft);
}
.dispatch-title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-variation-settings: "opsz" 144;
  font-weight: 600;
  font-size: clamp(2.9rem, 8vw, 4.6rem);
  line-height: 0.98;
  letter-spacing: -0.025em;
  margin: 0.7rem 0 0;
  color: var(--ink);
}
.dispatch-dek {
  margin-top: 1rem;
  font-size: 1.12rem;
  line-height: 1.6;
  color: var(--ink-soft);
  max-width: 34rem;
  text-wrap: pretty;
}
.dispatch-dek p {
  margin: 0;
}
.dispatch-masthead {
  padding-bottom: 1.75rem;
  border-bottom: 2px solid var(--ink);
}
.lead {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 2.5rem;
  align-items: center;
  margin-top: 2.5rem;
  padding-bottom: 2.75rem;
  border-bottom: 1px solid var(--rule);
}
.lead-figure {
  aspect-ratio: 16 / 11;
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper-soft);
}
.lead-figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.lead:hover .lead-figure img {
  transform: scale(1.04);
}
.lead-kicker {
  margin: 0;
  color: var(--accent);
}
.lead-title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-variation-settings: "opsz" 144;
  font-weight: 580;
  font-size: clamp(1.9rem, 3.2vw, 2.7rem);
  line-height: 1.06;
  letter-spacing: -0.025em;
  margin: 0.55rem 0 0;
  color: var(--ink);
  text-wrap: balance;
  transition: color 0.18s ease;
}
.lead:hover .lead-title {
  color: var(--accent);
}
.lead-dek {
  margin: 0.85rem 0 0;
  font-size: 1.04rem;
  line-height: 1.6;
  color: var(--ink-soft);
  text-wrap: pretty;
}
.lead-meta {
  margin: 1.1rem 0 0;
  color: var(--ink-soft);
}
.article-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(15.5rem, 1fr));
  gap: 2.5rem 1.75rem;
  margin-top: 2.5rem;
}
.article-card {
  display: flex;
  flex-direction: column;
}
.article-card__figure {
  aspect-ratio: 3 / 2;
  overflow: hidden;
  border: 1px solid var(--rule);
  background: var(--paper-soft);
}
.article-card__figure img {
  display: block;
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform 0.6s cubic-bezier(0.22, 1, 0.36, 1);
}
.article-card:hover .article-card__figure img {
  transform: scale(1.04);
}
.article-card__body {
  display: flex;
  flex: 1;
  flex-direction: column;
  gap: 0.4rem;
  padding-top: 0.95rem;
}
.article-card__kicker {
  margin: 0;
  color: var(--accent);
}
.article-card__title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-weight: 560;
  font-size: 1.18rem;
  line-height: 1.22;
  letter-spacing: -0.015em;
  margin: 0;
  color: var(--ink);
  text-wrap: balance;
  transition: color 0.18s ease;
}
.article-card:hover .article-card__title {
  color: var(--accent);
}
.article-card__dek {
  margin: 0;
  font-size: 0.92rem;
  line-height: 1.55;
  color: var(--ink-soft);
  text-wrap: pretty;
  display: -webkit-box;
  -webkit-box-orient: vertical;
  -webkit-line-clamp: 3;
  line-clamp: 3;
  overflow: hidden;
}
.article-card__meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5ch;
  margin-top: auto;
  padding-top: 0.85rem;
  color: var(--ink-soft);
}
.article-card__meta span {
  color: var(--accent);
}
@media (max-width: 720px) {
  .lead {
    grid-template-columns: 1fr;
    gap: 1.5rem;
  }
}
.essay-breadcrumb a {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink-soft);
}
.essay-breadcrumb a:hover {
  color: var(--accent);
}
.essay-kicker {
  margin: 1.5rem 0 0;
  color: var(--accent);
}
.essay-title {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-variation-settings: "opsz" 144;
  font-weight: 580;
  font-size: clamp(2.3rem, 5.6vw, 3.5rem);
  line-height: 1.04;
  letter-spacing: -0.025em;
  margin: 0.6rem 0 0;
  color: var(--ink);
  text-wrap: balance;
}
.essay-standfirst {
  margin: 1.1rem 0 0;
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.35rem;
  line-height: 1.45;
  color: var(--ink-soft);
}
.essay-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem 1rem;
  margin: 1.5rem 0 0;
  padding-bottom: 1.75rem;
  border-bottom: 2px solid var(--ink);
  color: var(--ink-soft);
}
.essay-meta span {
  display: inline-flex;
  align-items: center;
  gap: 0.4ch;
}
.essay-meta span + span::before {
  content: "";
  width: 4px;
  height: 4px;
  border-radius: 50%;
  background: var(--accent);
}
.essay-figure {
  width: 100%;
  margin: 2rem 0 0;
  border: 1px solid var(--rule);
}
.essay-tldr {
  margin: 2rem 0 0;
  padding-left: 1.25rem;
  border-left: 3px solid var(--accent);
}
.essay-tldr-label {
  margin: 0 0 0.35rem;
  color: var(--accent);
}
.essay-tldr p:not(.essay-tldr-label) {
  margin: 0;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--ink);
}
.essay-toc {
  margin: 2rem 0 0;
  padding: 1rem 1.25rem;
  background: var(--ink);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--ink) 3%, transparent);
  }
  border: 1px solid var(--rule);
}
.essay-toc summary {
  font-family: var(--font-mono);
  font-size: 0.72rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--ink-soft);
  cursor: pointer;
}
.essay-toc nav {
  margin-top: 0.6rem;
  font-size: 0.95rem;
}
.essay-toc ul {
  margin: 0;
  padding-left: 1rem;
}
.essay-toc a {
  color: var(--ink-soft);
}
.essay-toc a:hover, .essay-toc a.active {
  color: var(--accent);
}
.article-body {
  --bleed: clamp(0rem, calc((100vw - 43rem) / 2), 3.75rem);
  margin-top: 2.25rem;
  font-size: 1.13rem;
  line-height: 1.78;
  --tw-prose-body: var(--color-body);
  --tw-prose-headings: var(--ink);
  --tw-prose-bold: var(--ink);
  --tw-prose-links: var(--accent);
  --tw-prose-bullets: var(--rule);
  --tw-prose-hr: var(--rule);
  --tw-prose-quotes: var(--ink);
}
.article-body :is(h2, h3) {
  font-family: var(--font-display);
  font-optical-sizing: auto;
  font-weight: 560;
  letter-spacing: -0.02em;
}
.article-body h2 {
  font-size: 1.7rem;
  margin-top: 3rem;
  padding-top: 1.4rem;
  border-top: 1px solid var(--rule);
}
.article-body h3 {
  font-size: 1.3rem;
  margin-top: 2.3rem;
}
.article-body > p:first-of-type::first-letter {
  font-family: var(--font-display);
  font-weight: 600;
  font-size: 3.7em;
  line-height: 0.74;
  float: left;
  margin: 0.06em 0.1em 0 0;
  color: var(--accent);
}
.article-body blockquote {
  margin: 2.5rem 0;
  padding: 1.3rem 0;
  border: 0;
  border-top: 2px solid var(--ink);
  border-bottom: 2px solid var(--ink);
  font-family: var(--font-display);
  font-style: italic;
  font-weight: 400;
  font-size: 1.5rem;
  line-height: 1.4;
  color: var(--ink);
}
.article-body blockquote p {
  margin: 0;
}
.article-body a {
  text-decoration-thickness: 1px;
  text-underline-offset: 3px;
}
.article-body p:has(img), .article-body table {
  width: calc(100% + 2 * var(--bleed));
  margin-block: 2.4rem;
  margin-inline: calc(-1 * var(--bleed));
}
.article-body img {
  display: block;
  width: 100%;
  height: auto;
  border: 1px solid var(--rule);
  background: var(--paper-soft);
}
.article-body table {
  border-collapse: collapse;
  font-size: 0.95rem;
  line-height: 1.5;
}
.article-body thead th {
  font-family: var(--font-mono);
  font-size: 0.66rem;
  font-weight: 600;
  letter-spacing: 0.11em;
  text-transform: uppercase;
  text-align: left;
  color: var(--ink);
  padding: 0.7rem 0.95rem;
  border-bottom: 2px solid var(--ink);
}
.article-body tbody td {
  padding: 0.62rem 0.95rem;
  border-bottom: 1px solid var(--rule);
  vertical-align: top;
}
.article-body tbody tr:nth-child(even) {
  background: var(--ink);
  @supports (color: color-mix(in lab, red, red)) {
    background: color-mix(in srgb, var(--ink) 3%, transparent);
  }
}
.article-body thead th:nth-child(n + 2), .article-body tbody td:nth-child(n + 2) {
  text-align: center;
}
.article-body tbody tr:has(td:empty) td {
  background: var(--ink);
  color: var(--paper);
  font-family: var(--font-mono);
  font-size: 0.64rem;
  font-weight: 600;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  border-bottom: 0;
  padding-block: 0.5rem;
}
.article-body tbody tr:has(td:empty) td strong {
  color: inherit;
  font-weight: 600;
}
@media (max-width: 640px) {
  .article-body table {
    display: block;
    overflow-x: auto;
  }
}
.essay-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 0.5rem;
  margin-top: 2.5rem;
}
.essay-tags span {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.1em;
  text-transform: uppercase;
  color: var(--ink-soft);
  padding: 0.3rem 0.6rem;
  border: 1px solid var(--rule);
}
.essay-nav {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1.5rem;
  margin-top: 3rem;
  padding-top: 1.75rem;
  border-top: 2px solid var(--ink);
}
.essay-nav-next {
  text-align: right;
}
.essay-nav a {
  display: inline-flex;
  flex-direction: column;
  gap: 0.3rem;
}
.essay-nav-dir {
  font-family: var(--font-mono);
  font-size: 0.7rem;
  letter-spacing: 0.13em;
  text-transform: uppercase;
  color: var(--accent);
}
.essay-nav-title {
  font-family: var(--font-display);
  font-weight: 540;
  font-size: 1.1rem;
  line-height: 1.2;
  color: var(--ink);
  transition: color 0.18s ease;
}
.essay-nav a:hover .essay-nav-title {
  color: var(--accent);
}
body.section-articles .post-card {
  background: transparent;
  border: 0;
  border-top: 1px solid var(--rule);
  border-radius: 0;
  box-shadow: none;
}
body.section-articles .post-card:hover {
  transform: none;
  box-shadow: none;
}
body.section-articles .post-card h3 {
  font-family: var(--font-display);
  font-weight: 560;
  color: var(--ink);
}
body.section-articles .post-card p {
  color: var(--ink-soft);
}
.dispatch > *, .essay > * {
  animation: fdc-rise 0.7s cubic-bezier(0.22, 1, 0.36, 1) backwards;
}
.dispatch > *:nth-child(2), .essay > *:nth-child(2) {
  animation-delay: 0.06s;
}
.dispatch > *:nth-child(3), .essay > *:nth-child(3) {
  animation-delay: 0.12s;
}
.dispatch > *:nth-child(4), .essay > *:nth-child(4) {
  animation-delay: 0.18s;
}
.dispatch > *:nth-child(n + 5), .essay > *:nth-child(n + 5) {
  animation-delay: 0.24s;
}
@media (prefers-reduced-motion: reduce) {
  .dispatch > *, .essay > * {
    animation: none;
  }
}
@property --tw-rotate-x {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-y {
  syntax: "*";
  inherits: false;
}
@property --tw-rotate-z {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-x {
  syntax: "*";
  inherits: false;
}
@property --tw-skew-y {
  syntax: "*";
  inherits: false;
}
@property --tw-space-y-reverse {
  syntax: "*";
  inherits: false;
  initial-value: 0;
}
@property --tw-border-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-leading {
  syntax: "*";
  inherits: false;
}
@property --tw-font-weight {
  syntax: "*";
  inherits: false;
}
@property --tw-tracking {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-inset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-inset-ring-color {
  syntax: "*";
  inherits: false;
}
@property --tw-inset-ring-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-ring-inset {
  syntax: "*";
  inherits: false;
}
@property --tw-ring-offset-width {
  syntax: "<length>";
  inherits: false;
  initial-value: 0px;
}
@property --tw-ring-offset-color {
  syntax: "*";
  inherits: false;
  initial-value: #fff;
}
@property --tw-ring-offset-shadow {
  syntax: "*";
  inherits: false;
  initial-value: 0 0 #0000;
}
@property --tw-outline-style {
  syntax: "*";
  inherits: false;
  initial-value: solid;
}
@property --tw-blur {
  syntax: "*";
  inherits: false;
}
@property --tw-brightness {
  syntax: "*";
  inherits: false;
}
@property --tw-contrast {
  syntax: "*";
  inherits: false;
}
@property --tw-grayscale {
  syntax: "*";
  inherits: false;
}
@property --tw-hue-rotate {
  syntax: "*";
  inherits: false;
}
@property --tw-invert {
  syntax: "*";
  inherits: false;
}
@property --tw-opacity {
  syntax: "*";
  inherits: false;
}
@property --tw-saturate {
  syntax: "*";
  inherits: false;
}
@property --tw-sepia {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-color {
  syntax: "*";
  inherits: false;
}
@property --tw-drop-shadow-alpha {
  syntax: "<percentage>";
  inherits: false;
  initial-value: 100%;
}
@property --tw-drop-shadow-size {
  syntax: "*";
  inherits: false;
}
@layer properties {
  @supports ((-webkit-hyphens: none) and (not (margin-trim: inline))) or ((-moz-orient: inline) and (not (color:rgb(from red r g b)))) {
    *, ::before, ::after, ::backdrop {
      --tw-rotate-x: initial;
      --tw-rotate-y: initial;
      --tw-rotate-z: initial;
      --tw-skew-x: initial;
      --tw-skew-y: initial;
      --tw-space-y-reverse: 0;
      --tw-border-style: solid;
      --tw-leading: initial;
      --tw-font-weight: initial;
      --tw-tracking: initial;
      --tw-shadow: 0 0 #0000;
      --tw-shadow-color: initial;
      --tw-shadow-alpha: 100%;
      --tw-inset-shadow: 0 0 #0000;
      --tw-inset-shadow-color: initial;
      --tw-inset-shadow-alpha: 100%;
      --tw-ring-color: initial;
      --tw-ring-shadow: 0 0 #0000;
      --tw-inset-ring-color: initial;
      --tw-inset-ring-shadow: 0 0 #0000;
      --tw-ring-inset: initial;
      --tw-ring-offset-width: 0px;
      --tw-ring-offset-color: #fff;
      --tw-ring-offset-shadow: 0 0 #0000;
      --tw-outline-style: solid;
      --tw-blur: initial;
      --tw-brightness: initial;
      --tw-contrast: initial;
      --tw-grayscale: initial;
      --tw-hue-rotate: initial;
      --tw-invert: initial;
      --tw-opacity: initial;
      --tw-saturate: initial;
      --tw-sepia: initial;
      --tw-drop-shadow: initial;
      --tw-drop-shadow-color: initial;
      --tw-drop-shadow-alpha: 100%;
      --tw-drop-shadow-size: initial;
    }
  }
}

