@layer theme {

  :root,
  :host {
    --font-sans: ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";
    --font-mono: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;
    --spacing: .25rem;
    --default-transition-duration: .15s;
    --default-transition-timing-function: cubic-bezier(.4, 0, .2, 1);
    --default-font-family: var(--font-sans);
    --default-mono-font-family: var(--font-mono)
  }
}

@layer base {

  *,
  :after,
  :before,
  ::backdrop {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0
  }

  ::file-selector-button {
    box-sizing: border-box;
    border: 0 solid;
    margin: 0;
    padding: 0
  }

  html,
  :host {
    -webkit-text-size-adjust: 100%;
    tab-size: 4;
    line-height: 1.5;
    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 {
    vertical-align: baseline;
    font-size: 75%;
    line-height: 0;
    position: relative
  }

  sub {
    bottom: -.25em
  }

  sup {
    top: -.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 {
    vertical-align: middle;
    display: block
  }

  img,
  video {
    max-width: 100%;
    height: auto
  }

  button,
  input,
  select,
  optgroup,
  textarea {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0
  }

  ::file-selector-button {
    font: inherit;
    font-feature-settings: inherit;
    font-variation-settings: inherit;
    letter-spacing: inherit;
    color: inherit;
    opacity: 1;
    background-color: #0000;
    border-radius: 0
  }

  :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)) {
      ::placeholder {
        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 {
    padding-block: 0
  }

  ::-webkit-datetime-edit-year-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-month-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-day-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-hour-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-minute-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-second-field {
    padding-block: 0
  }

  ::-webkit-datetime-edit-millisecond-field {
    padding-block: 0
  }

  ::-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]) {
    appearance: button
  }

  ::file-selector-button {
    appearance: button
  }

  ::-webkit-inner-spin-button {
    height: auto
  }

  ::-webkit-outer-spin-button {
    height: auto
  }

  [hidden]:where(:not([hidden=until-found])) {
    display: none !important
  }
}

@layer components;

@layer utilities {
  .start {
    inset-inline-start: var(--spacing)
  }

  .end {
    inset-inline-end: var(--spacing)
  }

  .top-3 {
    top: calc(var(--spacing) * 3)
  }

  .inline-flex {
    display: inline-flex
  }

  .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))
  }
}

:root {
  --auo-brand: #1a1a1a;
  --auo-accent: #5b6cff;
  --auo-accent-2: #00d4a3;
  --auo-accent-soft: #eef0ff;
  --auo-pos: #0fae6e;
  --auo-neg: #d4453a;
  --auo-bg: #fafaf7;
  --auo-bg-alt: #fff;
  --auo-bg-deep: #f3f3ee;
  --auo-surface: #fff;
  --auo-surface-2: #fafaf7;
  --auo-fg: #0d0d0e;
  --auo-fg-2: #45464a;
  --auo-fg-3: #76777b;
  --auo-fg-4: #a8a9ad;
  --auo-line: #0d0d0e14;
  --auo-line-strong: #0d0d0e29;
  --auo-r-sm: 8px;
  --auo-r-md: 12px;
  --auo-r-lg: 18px;
  --auo-r-xl: 24px;
  --auo-r-pill: 999px;
  --auo-sh-1: 0 1px 2px #0d0d0e0d, 0 0 0 1px #0d0d0e0a;
  --auo-sh-2: 0 1px 2px #0d0d0e0f, 0 8px 24px #0d0d0e0f;
  --auo-sh-3: 0 12px 40px #0d0d0e1a, 0 2px 6px #0d0d0e0d;
  --auo-container: 1200px;
  --auo-pad-x: clamp(20px, 4vw, 56px);
  --auo-font: "Geist", -apple-system, BlinkMacSystemFont, "SF Pro Text", "Inter", system-ui, sans-serif;
  --auo-font-mono: "Geist Mono", "JetBrains Mono", "SF Mono", ui-monospace, monospace;
  --auo-font-display: "Geist", -apple-system, system-ui, sans-serif;
}

[data-theme=dark] {
  --auo-brand: #f5f5f3;
  --auo-accent: #8a96ff;
  --auo-accent-soft: #1c1f3a;
  --auo-pos: #2dcb88;
  --auo-neg: #ff6b5e;
  --auo-bg: #0a0a0b;
  --auo-bg-alt: #0f0f10;
  --auo-bg-deep: #060607;
  --auo-surface: #131315;
  --auo-surface-2: #0f0f10;
  --auo-fg: #fafaf7;
  --auo-fg-2: #c2c2c5;
  --auo-fg-3: #88898d;
  --auo-fg-4: #54555a;
  --auo-line: #ffffff14;
  --auo-line-strong: #ffffff2e;
  --auo-sh-1: 0 1px 2px #0006, 0 0 0 1px #ffffff0d;
  --auo-sh-2: 0 1px 2px #0006, 0 8px 24px #0006;
  --auo-sh-3: 0 12px 40px #0009, 0 2px 6px #0006;
}

*,
:before,
:after {
  box-sizing: border-box
}

html,
body {
  margin: 0;
  padding: 0
}

body {
  font-family: var(--auo-font);
  background: var(--auo-bg);
  color: var(--auo-fg);
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizelegibility;
  font-feature-settings: "cv11", "ss01", "ss03";
  letter-spacing: -.005em;
  font-size: 16px;
  line-height: 1.55;
  transition: background-color .25s, color .25s
}

img {
  max-width: 100%;
  display: block
}

a {
  color: inherit;
  text-decoration: none
}

button {
  cursor: pointer;
  font-family: inherit
}

::selection {
  background: var(--auo-accent);
  color: #fff
}

h1,
h2,
h3,
h4 {
  font-family: var(--auo-font-display);
  letter-spacing: -.025em;
  text-wrap: balance;
  margin: 0
}

h1 {
  font-weight: 600;
  line-height: 1.02
}

h2 {
  font-weight: 600;
  line-height: 1.05
}

h3 {
  font-weight: 600;
  line-height: 1.2
}

p {
  text-wrap: pretty;
  margin: 0
}

.auo-container {
  max-width: var(--auo-container);
  padding-left: var(--auo-pad-x);
  padding-right: var(--auo-pad-x);
  margin: 0 auto
}

.auo-section {
  padding: clamp(48px, 6vw, 80px) 0;
  position: relative
}

.auo-section--tight {
  padding: clamp(36px, 4.5vw, 60px) 0
}

.auo-eyebrow {
  border-radius: var(--auo-r-pill);
  background: var(--auo-surface);
  border: 1px solid var(--auo-line);
  color: var(--auo-fg-2);
  letter-spacing: .005em;
  align-items: center;
  gap: 6px;
  padding: 6px 12px;
  font-size: 12.5px;
  font-weight: 500;
  display: inline-flex
}

.auo-eyebrow>svg {
  color: var(--auo-accent)
}

.auo-btn {
  letter-spacing: -.005em;
  border-radius: var(--auo-r-pill);
  white-space: nowrap;
  border: 1px solid #0000;
  justify-content: center;
  align-items: center;
  gap: 8px;
  font-family: inherit;
  font-weight: 500;
  transition: background-color .15s, color .15s, border-color .15s, transform .15s, box-shadow .15s;
  display: inline-flex
}

.auo-btn--sm {
  padding: 7px 14px;
  font-size: 13.5px
}

.auo-btn--md {
  padding: 10px 18px;
  font-size: 14.5px
}

.auo-btn--lg {
  padding: 14px 22px;
  font-size: 15.5px
}

.auo-btn--primary {
  background: var(--auo-fg);
  color: var(--auo-bg)
}

.auo-btn--primary:hover {
  box-shadow: var(--auo-sh-2);
  transform: translateY(-1px)
}

.auo-btn--primary:active {
  transform: translateY(0)
}

.auo-btn--secondary {
  background: var(--auo-surface);
  color: var(--auo-fg);
  border-color: var(--auo-line)
}

.auo-btn--secondary:hover {
  background: var(--auo-surface-2);
  border-color: var(--auo-line-strong)
}

.auo-btn--ghost {
  color: var(--auo-fg);
  background: 0 0
}

.auo-btn--ghost:hover {
  background: var(--auo-surface)
}

.auo-btn--accent {
  background: var(--auo-accent);
  color: #fff
}

.auo-btn--accent:hover {
  box-shadow: 0 8px 24px -8px var(--auo-accent);
  transform: translateY(-1px)
}

.auo-badge {
  border-radius: var(--auo-r-pill);
  letter-spacing: .01em;
  border: 1px solid var(--auo-line);
  align-items: center;
  gap: 6px;
  padding: 3px 10px;
  font-size: 11.5px;
  font-weight: 500;
  display: inline-flex
}

.auo-badge--neutral {
  background: var(--auo-surface);
  color: var(--auo-fg-2)
}

.auo-badge--accent {
  background: var(--auo-accent-soft);
  color: var(--auo-accent);
  border-color: #0000
}

.auo-badge--positive {
  background: var(--auo-pos)
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-badge--positive {
    background: color-mix(in oklab, var(--auo-pos) 12%, transparent)
  }
}

.auo-badge--positive {
  color: var(--auo-pos);
  border-color: #0000
}

.auo-badge--dot:before {
  content: "";
  background: var(--auo-pos);
  border-radius: 50%;
  width: 6px;
  height: 6px;
  display: inline-block
}

.auo-card {
  background: var(--auo-surface);
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-lg);
  padding: 24px
}

.auo-tabs {
  background: var(--auo-surface);
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-pill);
  align-items: center;
  gap: 4px;
  padding: 5px;
  display: inline-flex
}

.auo-tab {
  color: var(--auo-fg-3);
  border-radius: var(--auo-r-pill);
  background: 0 0;
  border: 0;
  padding: 8px 14px;
  font-size: 13.5px;
  font-weight: 500;
  transition: color .15s;
  position: relative
}

.auo-tab.is-active {
  color: var(--auo-fg)
}

.auo-tab:hover:not(.is-active) {
  color: var(--auo-fg-2)
}

.auo-tab-content {
  z-index: 1;
  align-items: center;
  gap: 6px;
  display: inline-flex;
  position: relative
}

.auo-tab-indicator {
  background: var(--auo-bg);
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-pill);
  box-shadow: var(--auo-sh-1);
  position: absolute;
  inset: 0
}

.auo-nav {
  z-index: 50;
  background: var(--auo-bg);
  position: sticky;
  top: 0
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-nav {
    background: color-mix(in oklab, var(--auo-bg) 80%, transparent)
  }
}

.auo-nav {
  -webkit-backdrop-filter: saturate(180%)blur(14px);
  backdrop-filter: saturate(180%)blur(14px);
  border-bottom: 1px solid var(--auo-line)
}

.auo-nav__inner {
  justify-content: space-between;
  align-items: center;
  gap: 32px;
  height: 64px;
  display: flex
}

.auo-nav__logo {
  letter-spacing: -.02em;
  color: var(--auo-fg);
  align-items: center;
  gap: 8px;
  font-size: 17px;
  font-weight: 600;
  display: inline-flex
}

.auo-nav__logo>svg {
  color: var(--auo-accent)
}

.auo-nav__links {
  color: var(--auo-fg-2);
  align-items: center;
  gap: 28px;
  font-size: 14px;
  display: flex
}

.auo-nav__links a {
  transition: color .15s
}

.auo-nav__links a:hover {
  color: var(--auo-fg)
}

.auo-nav__actions {
  align-items: center;
  gap: 12px;
  display: flex
}

@media(max-width:880px) {
  .auo-nav__links {
    display: none
  }
}

.auo-hero {
  padding: clamp(56px, 8vw, 96px) 0 clamp(40px, 5vw, 72px);
  position: relative;
  overflow: hidden
}

.auo-hero__bg {
  pointer-events: none;
  z-index: 0;
  position: absolute;
  inset: 0
}

.auo-hero__grid {
  background-image: linear-gradient(var(--auo-line) 1px, transparent 1px), linear-gradient(90deg, var(--auo-line) 1px, transparent 1px);
  opacity: .55;
  background-size: 56px 56px;
  position: absolute;
  inset: -1px;
  -webkit-mask-image: radial-gradient(70% 60% at 50% 0, #000 30%, #0000 75%);
  mask-image: radial-gradient(70% 60% at 50% 0, #000 30%, #0000 75%)
}

.auo-hero__glow {
  background: radial-gradient(ellipse 50% 50% at 50% 50%, var(--auo-accent), transparent 70%);
  width: 1100px;
  height: 700px;
  position: absolute;
  top: -10%;
  left: 50%;
  transform: translate(-50%)
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-hero__glow {
    background: radial-gradient(ellipse 50% 50% at 50% 50%, color-mix(in oklab, var(--auo-accent) 22%, transparent), transparent 70%)
  }
}

.auo-hero__glow {
  filter: blur(40px);
  opacity: .6
}

[data-theme=dark] .auo-hero__glow {
  opacity: .45
}

.auo-hero__inner {
  z-index: 1;
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: 28px;
  display: flex;
  position: relative
}

.auo-hero__title {
  letter-spacing: -.035em;
  max-width: 24ch;
  margin-top: 8px;
  font-size: clamp(36px, 5.2vw, 66px);
  font-weight: 600;
  line-height: 1.02
}

.auo-hero__title-em {
  display: inline-block;
  padding-right: .12em;
  background: linear-gradient(180deg, var(--auo-fg-2), var(--auo-fg-3));
  color: #0000;
  -webkit-background-clip: text;
  background-clip: text;
  font-style: italic;
  font-weight: 500
}

.auo-section--alt {
  background: var(--auo-bg-alt);
  border-top: 1px solid var(--auo-line);
  border-bottom: 1px solid var(--auo-line)
}

.auo-section__head {
  text-align: center;
  flex-direction: column;
  align-items: center;
  gap: 18px;
  margin-bottom: 64px;
  display: flex
}

.auo-stats {
  border-top: 1px solid var(--auo-line);
  border-bottom: 1px solid var(--auo-line);
  background: var(--auo-bg-deep);
  padding: clamp(60px, 8vw, 100px) 0
}

.auo-stats__grid {
  grid-template-columns: repeat(4, 1fr);
  gap: 24px;
  display: grid
}

.auo-stat {
  padding: 8px 0
}

.auo-stat__num {
  font-family: var(--auo-font-display);
  letter-spacing: -.04em;
  margin-bottom: 8px;
  font-size: clamp(36px, 5vw, 64px);
  font-weight: 600;
  line-height: 1;
  text-align: center
}

.auo-stat__label {
  color: var(--auo-fg-3);
  font-size: 14px;
  text-align: center
}

@media(max-width:900px) {
  .auo-stats__grid {
    grid-template-columns: repeat(2, 1fr);
    gap: 32px
  }
}

.auo-tier {
  background: var(--auo-bg);
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-lg);
  flex-direction: column;
  height: 100%;
  padding: 32px;
  display: flex;
  position: relative
}

.auo-tier.is-highlight {
  background: var(--auo-fg);
  color: var(--auo-bg);
  border-color: var(--auo-fg);
  box-shadow: var(--auo-sh-3);
  transform: translateY(-8px)
}

.auo-tier__badge {
  background: var(--auo-accent);
  color: #fff;
  border-radius: var(--auo-r-pill);
  letter-spacing: .02em;
  padding: 4px 12px;
  font-size: 11.5px;
  font-weight: 600;
  position: absolute;
  top: -12px;
  left: 32px
}

.auo-tier__name {
  opacity: .85;
  margin-bottom: 16px;
  font-size: 14px;
  font-weight: 500
}

.auo-tier__price {
  font-family: var(--auo-font-display);
  align-items: baseline;
  gap: 4px;
  margin-bottom: 6px;
  display: flex
}

.auo-tier__currency {
  font-size: 22px;
  font-weight: 500
}

.auo-tier__amount {
  letter-spacing: -.04em;
  font-variant-numeric: tabular-nums;
  font-size: 56px;
  font-weight: 600;
  line-height: 1
}

.auo-tier__per {
  color: var(--auo-fg-3);
  margin-left: 4px;
  font-size: 14px
}

.auo-tier.is-highlight .auo-tier__per {
  color: var(--auo-bg)
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-tier.is-highlight .auo-tier__per {
    color: color-mix(in oklab, var(--auo-bg) 60%, transparent)
  }
}

.auo-tier__blurb {
  color: var(--auo-fg-2);
  min-height: 42px;
  margin-bottom: 24px;
  font-size: 14px
}

.auo-tier.is-highlight .auo-tier__blurb {
  color: var(--auo-bg)
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-tier.is-highlight .auo-tier__blurb {
    color: color-mix(in oklab, var(--auo-bg) 80%, transparent)
  }
}

.auo-tier__cta {
  width: 100%;
  margin-bottom: 24px
}

.auo-tier.is-highlight .auo-btn--primary {
  background: var(--auo-bg);
  color: var(--auo-fg)
}

.auo-tier__feats {
  flex-direction: column;
  gap: 10px;
  margin: 0;
  padding: 0;
  font-size: 14px;
  list-style: none;
  display: flex
}

.auo-tier__feats li {
  align-items: flex-start;
  gap: 10px;
  display: flex
}

.auo-tier__check {
  background: var(--auo-accent-soft);
  width: 18px;
  height: 18px;
  color: var(--auo-accent);
  border-radius: 50%;
  flex-shrink: 0;
  justify-content: center;
  align-items: center;
  margin-top: 1px;
  display: inline-flex
}

.auo-tier.is-highlight .auo-tier__check {
  background: var(--auo-bg)
}

@supports (color:color-mix(in lab, red, red)) {
  .auo-tier.is-highlight .auo-tier__check {
    background: color-mix(in oklab, var(--auo-bg) 18%, transparent)
  }
}

.auo-tier.is-highlight .auo-tier__check {
  color: var(--auo-bg)
}

@media(max-width:900px) {
  .auo-pricing {
    grid-template-columns: 1fr
  }

  .auo-tier.is-highlight {
    transform: none
  }
}

.auo-table {
  border-collapse: collapse;
  width: 100%;
  font-size: 13.5px
}

.auo-table th {
  text-align: left;
  color: var(--auo-fg-3);
  border-bottom: 1px solid var(--auo-line);
  text-transform: uppercase;
  letter-spacing: .06em;
  padding: 10px 12px;
  font-size: 12px;
  font-weight: 500
}

.auo-table td {
  border-bottom: 1px solid var(--auo-line);
  color: var(--auo-fg);
  padding: 14px 12px
}

.auo-table tr:last-child td {
  border-bottom: 0
}

.auo-table .ralign {
  text-align: right;
  font-variant-numeric: tabular-nums;
  font-weight: 500
}

.auo-table .pos {
  color: var(--auo-pos)
}

.auo-table .neg {
  color: var(--auo-fg)
}

.auo-table .mute {
  color: var(--auo-fg-3)
}

/* browser-chrome mockup frame */
.auo-mock {
  background: var(--auo-surface);
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-lg);
  box-shadow: var(--auo-sh-2);
  overflow: hidden
}

.auo-mock__bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 16px;
  border-bottom: 1px solid var(--auo-line);
  color: var(--auo-fg-3);
  font-family: var(--auo-font-mono);
  font-size: 12.5px
}

.auo-mock__dots {
  display: inline-flex;
  gap: 6px
}

.auo-mock__dots i {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: var(--auo-line-strong);
  display: inline-block
}

.auo-mock__body {
  padding: 20px
}

/* JSON/code block */
.auo-code {
  font-family: var(--auo-font-mono);
  font-size: 13px;
  line-height: 1.6;
  color: var(--auo-fg);
  white-space: pre;
  overflow-x: auto;
  margin: 0
}

.auo-code .k {
  color: var(--auo-accent)
}

/* key */
.auo-code .s {
  color: var(--auo-pos)
}

/* string/source */
.auo-code .m {
  color: var(--auo-fg-3)
}

/* muted */
/* tab panels: hidden unless active */
.auo-panel {
  display: none
}

.auo-panel.is-active {
  display: block
}

/* feature grid with hairline dividers */
.auo-features {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  border-top: 1px solid var(--auo-line);
  border-left: 1px solid var(--auo-line)
}

.auo-feature {
  padding: 28px 24px;
  border-right: 1px solid var(--auo-line);
  border-bottom: 1px solid var(--auo-line)
}

.auo-feature__icon {
  width: 38px;
  height: 38px;
  border-radius: var(--auo-r-md);
  background: var(--auo-accent-soft);
  color: var(--auo-accent);
  display: inline-flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 16px
}

.auo-feature h3 {
  font-size: 16px;
  font-weight: 600;
  margin: 0 0 8px
}

.auo-feature p {
  color: var(--auo-fg-2);
  font-size: 14px;
  margin: 0
}

@media(max-width:900px) {
  .auo-features {
    grid-template-columns: 1fr
  }
}

.auo-footer {
  border-top: 1px solid var(--auo-line);
  background: var(--auo-bg);
  padding: 64px 0 40px
}

.auo-footer__grid {
  display: grid;
  grid-template-columns: 2fr 1fr 1fr 1fr 1fr;
  gap: 32px
}

.auo-footer__brand p {
  color: var(--auo-fg-3);
  font-size: 13.5px;
  max-width: 34ch;
  margin: 12px 0 0
}

.auo-footer__col h4 {
  font-size: 12.5px;
  text-transform: uppercase;
  letter-spacing: .06em;
  color: var(--auo-fg-3);
  margin: 0 0 12px
}

.auo-footer__col a {
  display: block;
  color: var(--auo-fg-2);
  font-size: 14px;
  padding: 4px 0;
  transition: color .15s
}

.auo-footer__col a:hover {
  color: var(--auo-fg)
}

.auo-footer__base {
  display: flex;
  justify-content: space-between;
  align-items: center;
  gap: 16px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid var(--auo-line);
  color: var(--auo-fg-3);
  font-size: 13px
}

.auo-main {
  min-height: 60vh
}

@media(max-width:900px) {
  .auo-footer__grid {
    grid-template-columns: 1fr 1fr
  }
}

.auo-hero__sub {
  color: var(--auo-fg-2);
  font-size: 18px;
  max-width: 52ch;
  margin: 0 auto;
  text-align: center;
  line-height: 1.5
}

.auo-hero__cta {
  display: flex;
  gap: 12px;
  justify-content: center;
  flex-wrap: wrap
}

.auo-hero__note {
  color: var(--auo-fg-3);
  font-size: 13.5px;
  display: inline-flex;
  align-items: center;
  gap: 8px
}

.auo-hero__mock {
  width: 100%;
  max-width: 860px;
  margin-top: 16px;
  text-align: left
}

.auo-sources__label {
  text-align: center;
  color: var(--auo-fg-3);
  font-size: 13px;
  margin: 0 0 20px
}

.auo-sources__row {
  display: flex;
  flex-wrap: wrap;
  justify-content: center;
  gap: 16px 40px;
  color: var(--auo-fg-3);
  font-family: var(--auo-font-mono);
  font-size: 18px;
  letter-spacing: -.01em
}

.auo-section__head h2 {
  font-size: clamp(28px, 4vw, 44px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.05;
  margin: 0;
  max-width: 20ch
}

.auo-section__head p {
  color: var(--auo-fg-2);
  font-size: 16px;
  max-width: 52ch;
  margin: 0
}

.auo-mock__note {
  color: var(--auo-fg-3);
  font-size: 13px;
  margin: 14px 0 0
}

.auo-stats__grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 24px
}

.auo-stat__num {
  font-family: var(--auo-font-display);
  font-size: clamp(40px, 5vw, 64px);
  font-weight: 600;
  letter-spacing: -.04em;
  line-height: 1;
  font-variant-numeric: tabular-nums
}

.auo-stat__label {
  color: var(--auo-fg-3);
  font-size: 14px;
  margin-top: 8px
}

.auo-boundaries {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 16px
}

.auo-boundaries h3 {
  font-size: 15px;
  font-weight: 600;
  margin: 0 0 8px
}

.auo-boundaries p {
  color: var(--auo-fg-2);
  font-size: 14px;
  margin: 0
}

.auo-tiers {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 20px;
  align-items: start
}

.auo-faq {
  display: grid;
  grid-template-columns: 1fr 1.4fr;
  gap: 48px;
  align-items: start
}

.auo-faq__head h2 {
  font-size: clamp(26px, 3.5vw, 38px);
  font-weight: 600;
  letter-spacing: -.03em;
  margin: 0
}

.auo-faq__head p {
  color: var(--auo-fg-3);
  font-size: 15px
}

.auo-faq__list details {
  border-bottom: 1px solid var(--auo-line);
  padding: 16px 0
}

.auo-faq__list summary {
  font-weight: 500;
  cursor: pointer;
  list-style: none;
  font-size: 15.5px
}

.auo-faq__list summary::-webkit-details-marker {
  display: none
}

.auo-faq__list p {
  color: var(--auo-fg-2);
  font-size: 14.5px;
  margin: 10px 0 0
}

.auo-cta {
  background: var(--auo-fg);
  color: var(--auo-bg);
  margin: 0 var(--auo-pad-x) 64px;
  border-radius: var(--auo-r-xl);
  padding: clamp(48px, 7vw, 88px) 24px;
  text-align: center
}

.auo-cta__inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 24px
}

.auo-cta h2 {
  font-size: clamp(28px, 4vw, 46px);
  font-weight: 600;
  letter-spacing: -.03em;
  margin: 0
}

@media(max-width:900px) {

  .auo-stats__grid,
  .auo-boundaries,
  .auo-tiers {
    grid-template-columns: 1fr 1fr
  }

  .auo-faq {
    grid-template-columns: 1fr
  }
}

.auo-tier__list {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  flex: 1
}

.auo-tier__list li {
  color: var(--auo-fg-2);
  font-size: 14px;
  padding: 6px 0 6px 22px;
  position: relative
}

.auo-tier__list li:before {
  content: "";
  position: absolute;
  left: 0;
  top: 11px;
  width: 12px;
  height: 8px;
  border-left: 2px solid var(--auo-accent);
  border-bottom: 2px solid var(--auo-accent);
  transform: rotate(-45deg)
}

.auo-tier.is-highlight .auo-tier__list li {
  color: color-mix(in oklab, var(--auo-bg) 80%, transparent)
}

.auo-tier.is-highlight .auo-tier__list li:before {
  border-color: var(--auo-bg)
}

/* prose */
.auo-prose {
  max-width: 720px
}

.auo-prose h1 {
  font-size: clamp(28px, 4vw, 40px);
  font-weight: 600;
  letter-spacing: -.03em;
  line-height: 1.1
}

.auo-prose h2 {
  font-size: 22px;
  font-weight: 600;
  margin-top: 32px
}

.auo-prose p {
  color: var(--auo-fg-2);
  font-size: 16px;
  line-height: 1.7
}

.auo-prose code {
  font-family: var(--auo-font-mono);
  font-size: 13.5px;
  background: var(--auo-bg-deep);
  padding: 2px 6px;
  border-radius: 6px
}

.auo-blog-date {
  color: var(--auo-fg-3);
  font-family: var(--auo-font-mono);
  font-size: 13px
}

.auo-blog-list a {
  text-decoration: none;
  color: inherit
}

.auo-blog-list .auo-card {
  margin-bottom: 16px
}

.auo-blog-list h3 {
  font-size: 18px;
  font-weight: 600;
  margin: 0 0 6px
}

.auo-blog-list p {
  color: var(--auo-fg-2);
  font-size: 14.5px;
  margin: 0
}

/* form */
.auo-form label {
  display: block;
  font-size: 13.5px;
  font-weight: 500;
  margin: 14px 0 6px
}

.auo-form input,
.auo-form textarea {
  width: 100%;
  padding: 10px 12px;
  border: 1px solid var(--auo-line);
  border-radius: var(--auo-r-md);
  background: var(--auo-bg);
  color: var(--auo-fg);
  font-family: inherit;
  font-size: 14.5px
}

.auo-form input:focus,
.auo-form textarea:focus {
  outline: none;
  border-color: var(--auo-accent)
}

.form-error {
  color: var(--auo-neg);
  font-size: 14px;
  margin: 0 0 12px
}

.hp {
  position: absolute;
  left: -9999px;
  width: 1px;
  height: 1px;
  overflow: hidden
}

/* ===== Mobile / responsive ===== */
/* Hamburger button: hidden on desktop, shown below the nav breakpoint. */
.auo-nav__toggle {
  display: none;
  flex-direction: column;
  justify-content: center;
  gap: 5px;
  width: 40px;
  height: 40px;
  padding: 0;
  background: 0 0;
  border: 0;
  cursor: pointer
}

.auo-nav__toggle span {
  display: block;
  width: 20px;
  height: 2px;
  background: var(--auo-fg);
  border-radius: 2px;
  transition: transform .2s, opacity .2s;
  margin: 0 auto
}

.auo-nav__toggle.is-open span:nth-child(1) {
  transform: translateY(7px) rotate(45deg)
}

.auo-nav__toggle.is-open span:nth-child(2) {
  opacity: 0
}

.auo-nav__toggle.is-open span:nth-child(3) {
  transform: translateY(-7px) rotate(-45deg)
}

/* Hero/preview code blocks: keep horizontal scroll INSIDE the box, never widen the page. */
.auo-code {
  max-width: 100%
}

.auo-mock,
.auo-hero__mock {
  max-width: 100% !important
}

@media(max-width:760px) {

  /* Nav collapses to a hamburger + dropdown. */
  .auo-nav__toggle {
    display: flex
  }

  .auo-nav__links {
    position: absolute;
    top: 64px;
    left: 0;
    right: 0;
    flex-direction: column;
    align-items: stretch;
    gap: 0;
    background: var(--auo-bg);
    border-bottom: 1px solid var(--auo-line);
    box-shadow: var(--auo-sh-2);
    padding: 8px 0;
    display: none
  }

  .auo-nav__links.is-open {
    display: flex
  }

  .auo-nav__links a {
    padding: 12px var(--auo-pad-x);
    font-size: 15px
  }

  .auo-nav__links a.auo-btn {
    margin: 8px var(--auo-pad-x);
    justify-content: center
  }

  .auo-nav__inner {
    position: relative
  }

  /* Hero: smaller type, full-width CTAs, tighter. */
  .auo-hero__title {
    font-size: clamp(30px, 9vw, 44px);
    max-width: 100%
  }

  .auo-hero__sub {
    font-size: 16px
  }

  .auo-hero__cta {
    width: 100%;
    flex-direction: column
  }

  .auo-hero__cta .auo-btn {
    width: 100%;
    justify-content: center
  }

  /* Section heads + CTA band: rein in width + type on small screens. */
  .auo-section__head h2,
  .auo-faq__head h2,
  .auo-cta h2 {
    font-size: clamp(24px, 7vw, 32px)
  }

  .auo-cta {
    margin-left: 16px;
    margin-right: 16px
  }

  .auo-cta__inner .auo-hero__cta {
    max-width: 320px
  }

  /* Sources row wraps comfortably. */
  .auo-sources__row {
    gap: 12px 24px;
    font-size: 15px
  }

  /* Footer stacks to one column. */
  .auo-footer__grid {
    grid-template-columns: 1fr !important;
    gap: 24px
  }

  .auo-footer__base {
    flex-direction: column;
    align-items: flex-start;
    gap: 8px
  }

  /* Content grids collapse to a SINGLE column on phones (the 900px rule only took
     them to 2 columns, which still overflows a narrow screen). */
  .auo-tiers,
  .auo-stats__grid,
  .auo-boundaries,
  .auo-features {
    grid-template-columns: 1fr !important
  }

  /* The "most popular" tier lift looks odd stacked; flatten it on mobile. */
  .auo-tier.is-highlight {
    transform: none
  }
}

@media(max-width:420px) {
  .auo-tabs {
    flex-wrap: wrap
  }

  .auo-section {
    padding: clamp(36px, 10vw, 56px) 0
  }
}