:root {
  color-scheme: light;
}

html {
  scroll-behavior: smooth;
}

html.dark {
  color-scheme: dark;
}

/* Contain fixed-position components (e.g. flash, flash_group) within their
   example preview box instead of escaping to the viewport. */
[data-slot="preview"] .fixed {
  position: relative;
}

pre[data-slot="code-block"], [data-slot="code-block"] {
  white-space: pre-wrap;
  word-break: break-word;
}

pre code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  line-height: inherit;
}

/*
--------------------------------------------------------------------------------
MARK: Syntax Highlighting
--------------------------------------------------------------------------------
*/

.code-highlight {
  font-family: inherit;
  line-height: inherit;
}

.code-highlight .tok-tag {
  color: color-mix(in oklab, var(--chart-6) 78%, var(--foreground));
  font-weight: 600;
}

.code-highlight .tok-attr {
  color: color-mix(in oklab, var(--chart-2) 78%, var(--foreground));
}

.code-highlight .tok-string {
  color: color-mix(in oklab, var(--chart-4) 85%, var(--foreground));
}

.code-highlight .tok-expr {
  color: color-mix(in oklab, var(--chart-5) 88%, var(--foreground));
}

.code-highlight .tok-atom {
  color: color-mix(in oklab, var(--chart-5) 85%, var(--foreground));
}

.code-highlight .tok-keyword {
  color: color-mix(in oklab, var(--chart-1) 80%, var(--foreground));
  font-weight: 600;
}

.code-highlight .tok-number {
  color: color-mix(in oklab, var(--chart-3) 82%, var(--foreground));
}

.code-highlight .tok-operator,
.code-highlight .tok-punct {
  color: color-mix(in oklab, var(--muted-foreground) 78%, var(--foreground));
}

.code-highlight .tok-ident,
.code-highlight .tok-text {
  color: var(--foreground);
}

.code-highlight .tok-comment {
  color: var(--muted-foreground);
  font-style: italic;
}

/*
--------------------------------------------------------------------------------
MARK: Home Page
--------------------------------------------------------------------------------
*/

:root {
  --ember-glow: oklch(0.82 0.11 340);
  --ember-glow-strong: oklch(0.78 0.14 305);
  --ember-core: oklch(0.95 0.05 78);
  --ember-deep: oklch(0.8 0.09 240);
}

html.dark,
[data-theme="dark"] {
  --ember-glow: oklch(0.54 0.16 55);
  --ember-glow-strong: oklch(0.62 0.22 38);
  --ember-core: oklch(0.74 0.14 78);
  --ember-deep: oklch(0.46 0.2 24);
}

/* Subtle noise texture overlay */
body.home-page::before {
  content: "";
  position: fixed;
  inset: 0;
  z-index: -1;
  pointer-events: none;
  opacity: 0.03;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  background-repeat: repeat;
  background-size: 256px 256px;
}

body.home-page {
  overflow-x: clip;
}

[data-theme="dark"] body.home-page::before {
  opacity: 0.04;
}

/* Hero radial glow */
.hero-section {
  position: relative;
  isolation: isolate;
  overflow-x: clip;
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-section::before {
  content: "";
  position: absolute;
  inset: 1.5rem 12% 0;
  z-index: -1;
  border-radius: 999px;
  background:
    radial-gradient(
      ellipse at 50% 24%,
      color-mix(in oklab, var(--ember-core) 14%, white) 0%,
      color-mix(in oklab, var(--ember-glow) 12%, transparent) 24%,
      color-mix(in oklab, var(--ember-deep) 6%, transparent) 46%,
      transparent 74%
    );
  filter: blur(18px);
  opacity: 0.7;
  pointer-events: none;
}

html:not(.dark):not([data-theme="dark"]) body.home-page {
  background:
    radial-gradient(circle at 50% 18%, color-mix(in oklab, var(--ember-core) 18%, white) 0%, transparent 28%),
    linear-gradient(180deg, color-mix(in oklab, var(--ember-deep) 5%, white) 0%, white 22%);
}

.hero-backdrop {
  position: absolute;
  inset: 0 0 -10rem;
  overflow: visible;
  pointer-events: none;
  z-index: -2;
}

.hero-glow {
  position: absolute;
  top: 40%;
  left: 50%;
  transform: translate(-50%, -50%);
  width: min(82vw, 980px);
  height: min(58vw, 640px);
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, color-mix(in oklab, var(--ember-core) 32%, transparent) 0%, color-mix(in oklab, var(--ember-glow-strong) 26%, transparent) 20%, color-mix(in oklab, var(--ember-glow) 20%, transparent) 42%, color-mix(in oklab, var(--ember-deep) 12%, transparent) 58%, transparent 76%);
  opacity: 0.42;
  filter: blur(26px);
  animation: hero-glow-breathe 11s ease-in-out infinite alternate;
}

[data-theme="dark"] .hero-glow {
  opacity: 0.34;
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-glow {
  width: min(64vw, 760px);
  height: min(42vw, 460px);
  background:
    radial-gradient(
      ellipse at center,
      color-mix(in oklab, var(--ember-core) 20%, white) 0%,
      color-mix(in oklab, var(--ember-glow-strong) 15%, transparent) 20%,
      color-mix(in oklab, var(--ember-glow) 11%, transparent) 38%,
      color-mix(in oklab, var(--ember-deep) 7%, transparent) 54%,
      transparent 72%
    );
  opacity: 0.24;
  filter: blur(18px);
}

.hero-heat {
  position: absolute;
  inset: 4% 22% 0;
  background:
    radial-gradient(circle at 50% 46%, color-mix(in oklab, var(--ember-core) 22%, transparent) 0%, color-mix(in oklab, var(--ember-glow-strong) 18%, transparent) 16%, color-mix(in oklab, var(--ember-glow) 14%, transparent) 30%, color-mix(in oklab, var(--ember-deep) 10%, transparent) 48%, transparent 70%);
  filter: blur(42px);
  opacity: 0.72;
  animation: hero-heat-shift 9s ease-in-out infinite alternate;
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-heat {
  inset: 10% 28% 10%;
  background:
    radial-gradient(
      circle at 50% 40%,
      color-mix(in oklab, var(--ember-core) 14%, transparent) 0%,
      color-mix(in oklab, var(--ember-glow-strong) 11%, transparent) 18%,
      color-mix(in oklab, var(--ember-glow) 8%, transparent) 30%,
      color-mix(in oklab, var(--ember-deep) 5%, transparent) 44%,
      transparent 66%
    );
  filter: blur(28px);
  opacity: 0.42;
}

.hero-embers {
  position: absolute;
  inset: -6% 8% -10%;
  overflow: hidden;
  opacity: 0.96;
  mask-image: radial-gradient(ellipse at 50% 42%, black 0%, black 56%, transparent 88%);
}

.hero-embers::before,
.hero-embers::after {
  content: "";
  position: absolute;
  inset: 0;
  pointer-events: none;
}

.hero-embers::before {
  background:
    radial-gradient(circle at 28% 78%, color-mix(in oklab, var(--ember-glow) 10%, transparent) 0%, transparent 20%),
    radial-gradient(circle at 52% 70%, color-mix(in oklab, var(--ember-core) 12%, transparent) 0%, transparent 24%),
    radial-gradient(circle at 74% 76%, color-mix(in oklab, var(--ember-deep) 12%, transparent) 0%, transparent 18%);
  filter: blur(20px);
  opacity: 0.5;
  animation: hero-embers-haze 12s ease-in-out infinite alternate;
}

.hero-embers::after {
  background:
    linear-gradient(180deg, transparent 0%, color-mix(in oklab, var(--ember-glow) 4%, transparent) 50%, transparent 100%),
    radial-gradient(circle at 50% 86%, color-mix(in oklab, var(--ember-glow-strong) 7%, transparent) 0%, transparent 32%);
  filter: blur(30px);
  opacity: 0.36;
  animation: hero-embers-current 16s linear infinite;
}

.hero-ember {
  position: absolute;
  left: var(--ember-x);
  bottom: var(--ember-y);
  width: calc(var(--ember-size) * 0.72);
  height: calc(var(--ember-size) * 0.72);
  border-radius: 999px;
  background:
    radial-gradient(
      circle at 35% 35%,
      color-mix(in oklab, white 88%, var(--ember-core)) 0%,
      var(--ember-core) 24%,
      var(--ember-glow) 56%,
      color-mix(in oklab, var(--ember-deep) 92%, transparent) 100%
    );
  box-shadow:
    0 0 8px color-mix(in oklab, var(--ember-core) 44%, transparent),
    0 0 18px color-mix(in oklab, var(--ember-glow-strong) 28%, transparent),
    0 0 30px color-mix(in oklab, var(--ember-deep) 16%, transparent);
  filter: blur(var(--ember-blur));
  mix-blend-mode: screen;
  opacity: 0;
  will-change: transform, opacity;
  animation:
    hero-ember-rise var(--ember-duration) linear infinite,
    hero-ember-flicker calc(var(--ember-duration) * 0.32) ease-in-out infinite alternate;
  animation-delay: var(--ember-delay), var(--ember-delay);
}

.hero-falloff {
  position: absolute;
  left: 50%;
  bottom: -9rem;
  width: min(96vw, 1220px);
  height: 22rem;
  transform: translateX(-50%);
  border-radius: 50%;
  background:
    radial-gradient(ellipse at center, color-mix(in oklab, var(--ember-glow) 18%, transparent) 0%, color-mix(in oklab, var(--ember-glow-strong) 12%, transparent) 24%, color-mix(in oklab, var(--ember-deep) 8%, transparent) 42%, transparent 72%);
  opacity: 0.54;
  filter: blur(44px);
  animation: hero-falloff-breathe 14s ease-in-out infinite alternate;
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-falloff {
  width: min(82vw, 980px);
  height: 16rem;
  background:
    radial-gradient(
      ellipse at center,
      color-mix(in oklab, var(--ember-glow) 10%, transparent) 0%,
      color-mix(in oklab, var(--ember-glow-strong) 7%, transparent) 26%,
      color-mix(in oklab, var(--ember-deep) 4%, transparent) 42%,
      transparent 70%
    );
  opacity: 0.24;
  filter: blur(32px);
}

.hero-beam {
  position: absolute;
  top: -22%;
  width: 26rem;
  height: 145%;
  filter: blur(42px);
  opacity: 0.32;
  background: linear-gradient(180deg, transparent 0%, color-mix(in oklab, var(--ember-core) 8%, transparent) 18%, color-mix(in oklab, var(--ember-glow-strong) 14%, transparent) 36%, color-mix(in oklab, var(--ember-deep) 10%, transparent) 58%, transparent 100%);
  mix-blend-mode: screen;
}

.hero-beam-left {
  left: 16%;
  transform: rotate(12deg);
  animation: hero-beam-sway-left 18s ease-in-out infinite;
}

.hero-beam-right {
  right: 14%;
  transform: rotate(-14deg);
  animation: hero-beam-sway-right 21s ease-in-out infinite;
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-beam {
  opacity: 0.12;
  filter: blur(34px);
}

.hero-content {
  position: relative;
  z-index: 1;
  text-shadow: 0 10px 32px color-mix(in oklab, black 22%, transparent);
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-content {
  text-shadow: none;
}

.hero-heading {
  position: relative;
  background-size: 140% 140%;
  background-position: 24% 50%;
  filter:
    drop-shadow(0 2px 4px rgba(0, 0, 0, 0.5))
    drop-shadow(0 10px 34px color-mix(in oklab, black 30%, transparent))
    drop-shadow(0 0 16px color-mix(in oklab, var(--ember-glow-strong) 9%, transparent));
}

.hero-heading::before {
  content: attr(data-text);
  position: absolute;
  display: block;
  inset: 0;
  color: color-mix(in oklab, white 78%, var(--ember-core));
  -webkit-text-fill-color: color-mix(in oklab, white 78%, var(--ember-core));
  opacity: 0.18;
  white-space: normal;
  text-shadow: 0 -1px 0 rgba(255, 248, 232, 0.2);
  pointer-events: none;
}

html:not(.dark):not([data-theme="dark"]) .hero-heading {
  filter: drop-shadow(0 1px 0 rgba(255, 255, 255, 0.9));
}

html:not(.dark):not([data-theme="dark"]) .hero-heading::before {
  display: none;
}

html:not(.dark):not([data-theme="dark"]) .heading-gradient {
  background: linear-gradient(118deg, oklch(0.72 0.11 255) 0%, oklch(0.83 0.1 315) 26%, oklch(0.9 0.18 12) 54%, oklch(0.8 0.12 335) 78%, oklch(0.74 0.1 265) 100%);
  -webkit-background-clip: text;
  background-clip: text;
}

.hero-copy {
  text-shadow:
    0 1px 2px rgba(0, 0, 0, 0.5),
    0 2px 20px color-mix(in oklab, black 34%, transparent),
    0 0 18px color-mix(in oklab, var(--ember-deep) 8%, transparent);
}

html:not(.dark):not([data-theme="dark"]) .hero-copy {
  color: color-mix(in oklab, var(--foreground) 68%, var(--muted-foreground));
  text-shadow: 0 1px 2px rgba(255, 255, 255, 0.8);
}

.hero-pill {
  background: color-mix(in oklab, var(--card) 74%, transparent);
  box-shadow:
    0 10px 28px color-mix(in oklab, black 16%, transparent),
    0 0 18px color-mix(in oklab, var(--ember-glow) 8%, transparent),
    inset 0 1px 0 color-mix(in oklab, white 12%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

html:not(.dark):not([data-theme="dark"]) .hero-pill {
  background: color-mix(in oklab, white 84%, var(--card));
  border-color: color-mix(in oklab, var(--ember-glow) 20%, var(--border));
  box-shadow:
    0 1px 0 color-mix(in oklab, white 70%, transparent),
    0 6px 14px color-mix(in oklab, black 8%, transparent);
}

.hero-button {
  box-shadow:
    0 10px 30px color-mix(in oklab, black 18%, transparent),
    0 0 0 1px color-mix(in oklab, white 5%, transparent);
}

.hero-button-primary {
  position: relative;
  box-shadow:
    0 12px 32px color-mix(in oklab, black 22%, transparent),
    0 0 24px color-mix(in oklab, var(--ember-glow-strong) 16%, transparent),
    0 0 54px color-mix(in oklab, var(--ember-deep) 14%, transparent);
}

.hero-button-primary::before {
  content: "";
  position: absolute;
  inset: -0.35rem;
  border-radius: inherit;
  background:
    radial-gradient(circle at 30% 50%, color-mix(in oklab, var(--ember-core) 26%, transparent), transparent 58%),
    radial-gradient(circle at 70% 55%, color-mix(in oklab, var(--ember-glow-strong) 22%, transparent), transparent 62%);
  filter: blur(12px);
  opacity: 0.55;
  z-index: -1;
  animation: hero-button-glow 3.4s ease-in-out infinite alternate;
  pointer-events: none;
}

.hero-button-outline {
  background: color-mix(in oklab, var(--card) 72%, transparent);
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-button {
  box-shadow: 0 1px 0 rgba(255, 255, 255, 0.8);
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-button-primary {
  box-shadow:
    0 10px 22px color-mix(in oklab, black 12%, transparent),
    0 0 18px color-mix(in oklab, var(--ember-glow-strong) 8%, transparent);
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-button-primary::before {
  opacity: 0.32;
  filter: blur(10px);
}

html:not(.dark):not([data-theme="dark"]) .home-page .hero-button-outline {
  background: color-mix(in oklab, white 88%, var(--card));
  border-color: color-mix(in oklab, var(--ember-glow) 18%, var(--border));
}

@keyframes hero-glow-breathe {
  0% {
    transform: translate(-50%, -50%) scale(0.96);
    opacity: 0.24;
  }

  100% {
    transform: translate(-49%, -47%) scale(1.05);
    opacity: 0.4;
  }
}

@keyframes hero-heat-shift {
  0% {
    transform: translateY(0) scale(0.97);
  }

  100% {
    transform: translateY(-0.85rem) scale(1.05);
  }
}

@keyframes hero-embers-haze {
  0% {
    transform: translate3d(-0.6rem, 0.8rem, 0) scale(0.98);
    opacity: 0.38;
  }

  100% {
    transform: translate3d(0.9rem, -0.7rem, 0) scale(1.04);
    opacity: 0.6;
  }
}

@keyframes hero-embers-current {
  0% {
    transform: translate3d(0, 0, 0);
  }

  50% {
    transform: translate3d(-1.2rem, -0.8rem, 0);
  }

  100% {
    transform: translate3d(1rem, -1.6rem, 0);
  }
}

@keyframes hero-ember-rise {
  0% {
    transform: translate3d(0, 0, 0) scale(0.7);
    opacity: 0;
  }

  10% {
    opacity: calc(var(--ember-opacity) * 0.96);
  }

  32% {
    transform:
      translate3d(
        calc(var(--ember-drift) * 0.2 + var(--ember-sway) * -0.2),
        calc(var(--ember-rise) * -0.28),
        0
      )
      scale(1.02);
    opacity: var(--ember-opacity);
  }

  54% {
    transform:
      translate3d(
        calc(var(--ember-drift) * 0.44 + var(--ember-sway) * 0.12),
        calc(var(--ember-rise) * -0.54),
        0
      )
      scale(0.99);
    opacity: var(--ember-opacity);
  }

  72% {
    transform:
      translate3d(
        calc(var(--ember-drift) * 0.66 + var(--ember-sway) * 0.28),
        calc(var(--ember-rise) * -0.7),
        0
      )
      scale(0.96);
    opacity: var(--ember-opacity);
  }

  84% {
    transform:
      translate3d(
        calc(var(--ember-drift) * 0.84 + var(--ember-sway) * 0.22),
        calc(var(--ember-rise) * -0.86),
        0
      )
      scale(0.96);
    opacity: var(--ember-opacity);
  }

  100% {
    transform:
      translate3d(var(--ember-drift), calc(var(--ember-rise) * -1), 0)
      scale(0.78);
    opacity: 0;
  }
}

@keyframes hero-ember-flicker {
  0% {
    filter: blur(var(--ember-blur)) brightness(0.96);
  }

  50% {
    filter: blur(calc(var(--ember-blur) + 0.25px)) brightness(1.22);
  }

  100% {
    filter: blur(var(--ember-blur)) brightness(0.9);
  }
}

@keyframes hero-button-glow {
  0% {
    opacity: 0.42;
    transform: scale(0.98);
  }

  100% {
    opacity: 0.74;
    transform: scale(1.04);
  }
}

@keyframes hero-falloff-breathe {
  from {
    transform: translateX(-50%) scaleX(0.95);
    opacity: 0.42;
  }

  to {
    transform: translateX(-50%) scaleX(1.03);
    opacity: 0.62;
  }
}

@keyframes hero-beam-sway-left {
  0%, 100% {
    transform: translateX(0) rotate(12deg);
    opacity: 0.22;
  }

  50% {
    transform: translateX(1.6rem) rotate(15deg);
    opacity: 0.36;
  }
}

@keyframes hero-beam-sway-right {
  0%, 100% {
    transform: translateX(0) rotate(-14deg);
    opacity: 0.2;
  }

  50% {
    transform: translateX(-1.3rem) rotate(-10deg);
    opacity: 0.34;
  }
}

/* Glass-morphism cards */
.glass-card {
  position: relative;
  background: color-mix(in oklab, var(--card) 80%, transparent);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  border-color: color-mix(in oklab, var(--border) 50%, transparent);
  transition: border-color 0.3s ease;
}

html:not(.dark):not([data-theme="dark"]) .home-page .marketing-surface {
  background: color-mix(in oklab, white 94%, var(--card));
  border-color: color-mix(in oklab, var(--border) 68%, white);
  box-shadow: none;
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
}

html:not(.dark):not([data-theme="dark"]) .home-page .marketing-surface [data-slot="preview"] {
  background: color-mix(in oklab, white 82%, var(--muted));
}

html:not(.dark):not([data-theme="dark"]) .home-page .marketing-surface [data-slot="code"] {
  background: color-mix(in oklab, white 88%, var(--card));
}

.site-topbar::after {
  content: "";
  position: absolute;
  left: 10%;
  right: 10%;
  bottom: -1px;
  height: 1px;
  background:
    linear-gradient(
      90deg,
      transparent 0%,
      color-mix(in oklab, var(--ember-deep) 18%, transparent) 18%,
      color-mix(in oklab, var(--ember-glow) 48%, transparent) 40%,
      color-mix(in oklab, var(--ember-core) 62%, transparent) 50%,
      color-mix(in oklab, var(--ember-glow) 48%, transparent) 60%,
      color-mix(in oklab, var(--ember-deep) 18%, transparent) 82%,
      transparent 100%
    );
  box-shadow:
    0 0 10px color-mix(in oklab, var(--ember-glow-strong) 18%, transparent),
    0 2px 18px color-mix(in oklab, var(--ember-deep) 12%, transparent);
  pointer-events: none;
  opacity: 0.5;
}

/* Staggered grid for component examples */
@media (min-width: 768px) {
  .staggered-grid {
    display: grid;
    grid-template-columns: repeat(2, minmax(0, 1fr));
    justify-items: center;
    align-items: start;
    gap: 1.5rem;
  }

  .staggered-grid > * {
    min-width: 0;
  }

  .staggered-grid > :nth-child(even) {
    transform: translateY(2rem);
  }
}

@media (max-width: 767px) {
  .staggered-grid {
    display: flex;
    flex-direction: column;
    gap: 1.5rem;
  }
}

/* Hero heading gradient */
.heading-gradient {
  background: linear-gradient(120deg, color-mix(in oklab, white 96%, var(--foreground)) 0%, color-mix(in oklab, var(--ember-core) 28%, white) 42%, color-mix(in oklab, var(--ember-glow-strong) 78%, color-mix(in oklab, white 90%, var(--foreground))) 70%, color-mix(in oklab, var(--ember-deep) 38%, var(--ember-glow-strong)) 100%);
  -webkit-background-clip: text;
  background-clip: text;
  -webkit-text-fill-color: transparent;
}

@media (prefers-reduced-motion: reduce) {
  .hero-glow,
  .hero-heat,
  .hero-embers,
  .hero-embers::before,
  .hero-embers::after,
  .hero-ember,
  .hero-falloff,
  .hero-beam,
  .hero-button-primary::before {
    animation: none !important;
  }

  .hero-ember {
    opacity: calc(var(--ember-opacity) * 0.35);
    transform: translate3d(0, calc(var(--ember-rise) * -0.08), 0);
  }
}

/* Install code blocks warm tint in dark mode */
[data-theme="dark"] .install-code-block {
  background: color-mix(in oklab, var(--ember-glow) 8%, var(--muted));
  border-color: color-mix(in oklab, var(--ember-glow) 15%, var(--border));
}

.site-theme-toggle [data-site-theme][data-active="true"] {
  background: var(--accent);
  color: var(--accent-foreground);
  border-color: var(--border);
}

.theme-mode-btn[data-active="true"] {
  background: var(--accent);
  color: var(--accent-foreground);
  border-color: var(--border);
}

.sidebar-section-link {
  color: var(--foreground);
}

.sidebar-section-link:hover {
  color: var(--foreground);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

summary::-webkit-details-marker {
  display: none;
}

summary::marker {
  content: "";
}

summary:not([data-slot])::after {
  content: "▾";
  float: right;
  color: var(--muted-foreground);
}

details[open] > summary:not([data-slot])::after {
  content: "▴";
}

.inline-code {
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  border-radius: 0.35rem;
  background: color-mix(in oklab, var(--muted) 30%, transparent);
  color: var(--foreground);
  padding: 0.1rem 0.3rem;
  font-size: 0.9em;
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
}

/*
--------------------------------------------------------------------------------
MARK: Markdown
--------------------------------------------------------------------------------
*/

.docs-markdown {
  color: var(--muted-foreground);
  line-height: 1.7;
}

.docs-markdown > * + * {
  margin-top: 0.9rem;
}

.docs-markdown h1,
.docs-markdown h2,
.docs-markdown h3,
.docs-markdown h4 {
  color: var(--foreground);
  font-weight: 600;
  line-height: 1.3;
  margin-top: 1.4rem;
}

.docs-markdown h1 {
  font-size: 1.35rem;
}

.docs-markdown h2 {
  font-size: 1.2rem;
}

.docs-markdown h3 {
  font-size: 1.05rem;
}

.docs-markdown ul,
.docs-markdown ol {
  margin-left: 1.25rem;
}

.docs-markdown ul {
  list-style: disc;
}

.docs-markdown ol {
  list-style: decimal;
}

.docs-markdown li + li {
  margin-top: 0.3rem;
}

.docs-markdown a {
  color: var(--foreground);
  text-decoration: underline;
  text-underline-offset: 0.2em;
}

.docs-markdown pre {
  overflow: auto;
  border: 1px solid color-mix(in oklab, var(--border) 70%, transparent);
  border-radius: 0.5rem;
  background: color-mix(in oklab, var(--muted) 40%, transparent);
  padding: 0.75rem;
  line-height: 1.45;
}

.docs-markdown code {
  border: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
  border-radius: 0.35rem;
  background: color-mix(in oklab, var(--muted) 30%, transparent);
  color: var(--foreground);
  padding: 0.1rem 0.3rem;
  font-size: 0.9em;
}

.docs-markdown pre code {
  border: 0;
  background: transparent;
  padding: 0;
  font-size: 0.95em;
}

.docs-markdown blockquote {
  margin: 0.8rem 0;
  border-left: 3px solid color-mix(in oklab, var(--primary) 45%, var(--border));
  background: color-mix(in oklab, var(--muted) 28%, transparent);
  padding: 0.6rem 0.8rem;
  border-radius: 0 0.4rem 0.4rem 0;
  color: var(--foreground);
}

.docs-markdown blockquote h1,
.docs-markdown blockquote h2,
.docs-markdown blockquote h3,
.docs-markdown blockquote h4 {
  margin-top: 0;
}

.docs-k {
  position: fixed;
  inset: 0;
  z-index: 80;
  display: flex;
  align-items: flex-start;
  justify-content: center;
  padding: 10vh 1rem 1rem;
}

.docs-k.hidden {
  display: none;
}

.docs-k-backdrop {
  position: absolute;
  inset: 0;
  background: color-mix(in oklab, black 22%, transparent);
  backdrop-filter: blur(1.5px);
}

.docs-k-panel {
  position: relative;
  width: min(42rem, 100%);
  border: 1px solid var(--border);
  border-radius: 0.75rem;
  background: var(--card);
  color: var(--card-foreground);
  box-shadow:
    0 16px 40px color-mix(in oklab, black 30%, transparent),
    0 4px 12px color-mix(in oklab, black 22%, transparent);
  overflow: hidden;
}

.docs-k-input-row {
  display: flex;
  align-items: center;
  gap: 0.5rem;
  padding: 0.75rem;
  border-bottom: 1px solid color-mix(in oklab, var(--border) 75%, transparent);
}

.docs-k-input {
  width: 100%;
  border: 1px solid transparent;
  border-radius: 0.5rem;
  background: color-mix(in oklab, var(--muted) 45%, transparent);
  color: var(--foreground);
  font-size: 0.9rem;
  line-height: 1.25rem;
  padding: 0.5rem 0.625rem;
}

.docs-k-input:focus {
  outline: none;
  border-color: color-mix(in oklab, var(--ring) 40%, var(--border));
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--ring) 28%, transparent);
}

.docs-k-hint {
  font-family: ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", monospace;
  font-size: 0.7rem;
  border: 1px solid var(--border);
  border-radius: 0.35rem;
  padding: 0.2rem 0.35rem;
  color: var(--muted-foreground);
  background: color-mix(in oklab, var(--muted) 35%, transparent);
}

.docs-k-list {
  margin: 0;
  padding: 0.4rem;
  list-style: none;
  max-height: min(60vh, 28rem);
  overflow: auto;
}

.docs-k-item {
  width: 100%;
  text-align: left;
  border: 0;
  border-radius: 0.45rem;
  background: transparent;
  color: var(--foreground);
  display: flex;
  flex-direction: column;
  gap: 0.05rem;
  padding: 0.5rem 0.6rem;
  font-size: 0.86rem;
  line-height: 1.2rem;
  cursor: pointer;
}

.docs-k-item-label {
  color: inherit;
  font-weight: 500;
}

.docs-k-item-meta {
  color: var(--muted-foreground);
  font-size: 0.75rem;
  line-height: 1rem;
}

.docs-k-item:hover,
.docs-k-item[data-active="true"] {
  background: color-mix(in oklab, var(--accent) 80%, transparent);
  color: var(--accent-foreground);
}

.docs-k-empty {
  padding: 0.65rem 0.7rem;
  color: var(--muted-foreground);
  font-size: 0.83rem;
}
