/* Laradocs — clean modern documentation theme.
 * Inter throughout, Laravel red accent, hairline borders, generous whitespace.
 * Tokens are CSS custom properties so consumers can override from config.
 */

:root {
  --dc-bg:            #ffffff;
  --dc-bg-elev:       #fafafa;
  --dc-paper:         #ffffff;
  --dc-fg:            #0a0a0a;
  --dc-muted:         #525252;
  --dc-subtle:        #a3a3a3;
  --dc-rule:          rgba(10, 10, 10, .08);
  --dc-rule-strong:   rgba(10, 10, 10, .14);
  --dc-sidebar-bg:    #ffffff;
  --dc-tabs-h:        0px;
  --dc-accent:        #ff2d20;
  --dc-accent-fg:     #ffffff;
  --dc-accent-soft:   color-mix(in srgb, var(--dc-accent) 8%, transparent);
  --dc-accent-line:   color-mix(in srgb, var(--dc-accent) 35%, transparent);
  --dc-code-bg:       #f5f5f5;
  --dc-code-fg:       #0a0a0a;
  --dc-selection:     color-mix(in srgb, var(--dc-accent) 22%, transparent);

  --dc-radius:        6px;
  --dc-radius-lg:     8px;
  --dc-header-h:      3.75rem;
  --dc-sidebar-w:     16rem;
  --dc-toc-w:         14rem;
  --dc-content-w:     46rem;

  --dc-shadow:        0 1px 0 rgba(10, 10, 10, .04);
  --dc-shadow-pop:    0 20px 50px -25px rgba(10, 10, 10, .15);

  --dc-font:    "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --dc-display: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Helvetica, Arial, sans-serif;
  --dc-mono:    "JetBrains Mono", ui-monospace, SFMono-Regular, "SF Mono", Menlo, Consolas, monospace;
}
:root:has(.laradocs-tabs) { --dc-tabs-h: 3.5rem; }

[data-theme="dark"] {
  --dc-bg:            #0a0a0a;
  --dc-bg-elev:       #141414;
  --dc-paper:         #0f0f0f;
  --dc-fg:            #fafafa;
  --dc-muted:         #a3a3a3;
  --dc-subtle:        #525252;
  --dc-rule:          rgba(250, 250, 250, .08);
  --dc-rule-strong:   rgba(250, 250, 250, .14);
  --dc-sidebar-bg:    #0a0a0a;
  --dc-accent:        #ff2d20;
  --dc-accent-fg:     #ffffff;
  --dc-code-bg:       #141414;
  --dc-code-fg:       #fafafa;
  --dc-shadow:        0 1px 0 rgba(0, 0, 0, .3);
  --dc-shadow-pop:    0 20px 50px -25px rgba(0, 0, 0, .6);
}
@media (prefers-color-scheme: dark) {
  :root:not([data-theme="light"]) {
    --dc-bg:            #0a0a0a;
    --dc-bg-elev:       #141414;
    --dc-paper:         #0f0f0f;
    --dc-fg:            #fafafa;
    --dc-muted:         #a3a3a3;
    --dc-subtle:        #525252;
    --dc-rule:          rgba(250, 250, 250, .08);
    --dc-rule-strong:   rgba(250, 250, 250, .14);
    --dc-sidebar-bg:    #0a0a0a;
    --dc-code-bg:       #141414;
    --dc-code-fg:       #fafafa;
    --dc-shadow:        0 1px 0 rgba(0, 0, 0, .3);
    --dc-shadow-pop:    0 20px 50px -25px rgba(0, 0, 0, .6);
  }
}

/* ─────────────────────── base ─────────────────────── */
*, *::before, *::after { box-sizing: border-box; }
html, body { margin: 0; }
html {
  scroll-behavior: smooth;
  -webkit-text-size-adjust: 100%;
}
::selection { background: var(--dc-selection); color: var(--dc-fg); }

body.laradocs {
  font-family: var(--dc-font);
  font-feature-settings: "cv02", "cv03", "cv04", "cv11", "ss01";
  color: var(--dc-fg);
  background: var(--dc-bg);
  line-height: 1.6;
  font-size: 16px;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}

.laradocs a {
  color: var(--dc-fg);
  text-decoration: none;
  transition: color .12s ease;
}
.laradocs a:hover { color: var(--dc-accent); }

/* Reading progress bar */
.laradocs-progress {
  position: fixed; top: 0; left: 0; right: 0; height: 2px;
  z-index: 30;
  background: transparent;
  pointer-events: none;
}
.laradocs-progress > span {
  display: block; height: 100%;
  width: var(--dc-progress, 0%);
  background: var(--dc-accent);
  transition: width .1s linear;
}

/* ─────────────────────── banner ─────────────────────── */
.laradocs-banner {
  display: flex; justify-content: center; align-items: center;
  padding: .5rem 1.25rem;
  font-size: .875rem; font-weight: 500; line-height: 1.4; text-align: center;
}
.laradocs-banner-inner { max-width: var(--dc-content-w); }
.laradocs-banner a { color: inherit; text-decoration: underline; }
.laradocs-banner a:hover { opacity: .8; }

.laradocs-banner-info   { background: #eff6ff; color: #1d4ed8; }
.laradocs-banner-alert  { background: #fffbeb; color: #92400e; }
.laradocs-banner-danger { background: #fff1f2; color: #be123c; }

[data-theme="dark"] .laradocs-banner-info   { background: #1e3a5f; color: #93c5fd; }
[data-theme="dark"] .laradocs-banner-alert  { background: #451a03; color: #fcd34d; }
[data-theme="dark"] .laradocs-banner-danger { background: #4c0519; color: #fca5a5; }

@media (prefers-color-scheme: dark) {
  :root:not([data-theme]) .laradocs-banner-info,
  :root[data-theme="auto"] .laradocs-banner-info   { background: #1e3a5f; color: #93c5fd; }
  :root:not([data-theme]) .laradocs-banner-alert,
  :root[data-theme="auto"] .laradocs-banner-alert  { background: #451a03; color: #fcd34d; }
  :root:not([data-theme]) .laradocs-banner-danger,
  :root[data-theme="auto"] .laradocs-banner-danger { background: #4c0519; color: #fca5a5; }
}

/* ─────────────────────── header ─────────────────────── */
.laradocs-header {
  position: sticky; top: 0; z-index: 10;
  display: flex; align-items: center; gap: 1rem;
  height: var(--dc-header-h);
  padding: 0 1.5rem;
  background: color-mix(in srgb, var(--dc-bg) 88%, transparent);
  backdrop-filter: saturate(180%) blur(12px);
  border-bottom: 1px solid var(--dc-rule);
}

.laradocs-brand {
  display: inline-flex; align-items: center; gap: .55rem;
  color: var(--dc-fg) !important;
  font-weight: 600;
  font-size: .95rem;
  letter-spacing: -.005em;
}
.laradocs-brand:hover { color: var(--dc-fg) !important; }
.laradocs-brand img { height: 1.5rem; width: auto; }
.laradocs-brand-mark {
  width: .65rem; height: .65rem;
  background: var(--dc-accent);
  border-radius: 2px;
}
.laradocs-brand-tag {
  display: none;
  font-family: var(--dc-mono);
  font-size: .65rem;
  padding: .15rem .4rem;
  border: 1px solid var(--dc-rule);
  border-radius: 3px;
  color: var(--dc-muted);
}
@media (min-width: 720px) { .laradocs-brand-tag { display: inline-flex; } }

.laradocs-header .laradocs-spacer { flex: 1; }

.laradocs-header-nav {
  display: none; align-items: center; gap: .25rem;
}
@media (min-width: 880px) { .laradocs-header-nav { display: inline-flex; } }
.laradocs-header-nav a {
  padding: .4rem .65rem;
  font-size: .87rem;
  color: var(--dc-muted) !important;
  border-radius: var(--dc-radius);
}
.laradocs-header-nav a:hover { color: var(--dc-fg) !important; background: var(--dc-bg-elev); }
.laradocs-header-nav .ext::after { content: " ↗"; opacity: .6; }

.laradocs-icon-btn {
  display: inline-flex; align-items: center; justify-content: center;
  width: 2rem; height: 2rem;
  border: 0;
  background: transparent;
  color: var(--dc-muted);
  cursor: pointer;
  border-radius: var(--dc-radius);
  transition: background .12s ease, color .12s ease;
}
.laradocs-icon-btn:hover { color: var(--dc-fg); background: var(--dc-bg-elev); }
.laradocs-icon-btn svg { width: 18px; height: 18px; }

.laradocs-menu-btn { display: none; }
@media (max-width: 1024px) { .laradocs-menu-btn { display: inline-flex; } }

[data-laradocs-theme-toggle] svg { display: none; }
[data-theme-state="auto"] .icon-auto,
[data-theme-state="light"] .icon-light,
[data-theme-state="dark"] .icon-dark { display: block; }
[data-laradocs-theme-toggle]:not([data-theme-state]) .icon-auto { display: block; }

/* palette trigger button — absolutely centered in the header on desktop */
@media (min-width: 768px) {
  .laradocs-palette-trigger {
    position: absolute;
    left: 50%;
    top: 50%;
    transform: translate(-50%, -50%);
  }
}
.laradocs-palette-trigger {
  display: inline-flex; align-items: center; gap: .6rem;
  padding: .4rem .55rem .4rem .65rem;
  border: 1px solid var(--dc-rule);
  background: var(--dc-bg-elev);
  color: var(--dc-muted);
  border-radius: var(--dc-radius);
  cursor: pointer;
  font: inherit;
  font-size: .82rem;
  min-width: 14rem;
  text-align: left;
  transition: border-color .12s ease, color .12s ease, background .12s ease;
}
.laradocs-palette-trigger:hover {
  border-color: var(--dc-rule-strong);
  color: var(--dc-fg);
  background: var(--dc-bg);
}
.laradocs-palette-trigger svg { width: 14px; height: 14px; flex-shrink: 0; }
.laradocs-palette-trigger > span { flex: 1; }
.laradocs-palette-trigger kbd {
  font-family: var(--dc-mono);
  font-size: .65rem;
  padding: .12rem .35rem;
  border: 1px solid var(--dc-rule);
  border-radius: 3px;
  background: var(--dc-paper);
  color: var(--dc-muted);
}

/* ─────────────────────── tabs strip ─────────────────────── */
.laradocs-tabs {
  position: sticky;
  top: var(--dc-header-h);
  z-index: 5;
  padding-top: .75rem;
  background: color-mix(in srgb, var(--dc-bg) 92%, transparent);
  backdrop-filter: saturate(180%) blur(8px);
  border-bottom: 1px solid var(--dc-rule);
}
.laradocs-tabs-inner {
  display: flex; gap: .15rem;
  max-width: calc(var(--dc-sidebar-w) + var(--dc-content-w) + var(--dc-toc-w) + 6rem);
  margin: 0 auto;
  padding: 0 1.5rem 0 calc(2.7rem - .85rem);
  overflow-x: auto;
  scrollbar-width: none;
}
.laradocs-tabs-inner::-webkit-scrollbar { display: none; }
.laradocs-tab {
  display: inline-flex; align-items: center;
  padding: .65rem .85rem;
  color: var(--dc-muted) !important;
  background: none !important;
  font-size: .87rem;
  font-weight: 500;
  white-space: nowrap;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color .12s ease, border-color .12s ease;
}
.laradocs-tab:hover { color: var(--dc-fg) !important; }
.laradocs-tab.is-active {
  color: var(--dc-fg) !important;
  border-bottom-color: var(--dc-accent);
}

/* ─────────────────────── shell layout ─────────────────────── */
.laradocs-shell {
  display: flex; align-items: stretch;
  max-width: calc(var(--dc-sidebar-w) + var(--dc-content-w) + var(--dc-toc-w) + 6rem);
  margin: 0 auto;
  position: relative;
}

.laradocs-backdrop {
  display: none;
  position: fixed; inset: var(--dc-header-h) 0 0 0;
  background: rgba(0, 0, 0, .35);
  z-index: 6;
  opacity: 0;
  transition: opacity .15s ease;
}
.laradocs-shell.nav-open .laradocs-backdrop {
  display: block;
  opacity: 1;
}

/* ─────────────────────── sidebar ─────────────────────── */
.laradocs-sidebar {
  width: var(--dc-sidebar-w);
  flex-shrink: 0;
  padding: 1.5rem 0 4rem 0;
  position: sticky;
  top: calc(var(--dc-header-h) + var(--dc-tabs-h));
  align-self: flex-start;
  height: calc(100vh - var(--dc-header-h) - var(--dc-tabs-h));
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--dc-rule-strong) transparent;
  background: var(--dc-sidebar-bg);
}
.laradocs-sidebar nav { padding: 0 .75rem 0 calc(2.7rem - .65rem); }
.laradocs-sidebar ul {
  list-style: none;
  margin: 0 0 1rem 0;
  padding: 0;
}
.laradocs-sidebar li { margin: 0; }
.laradocs-sidebar a {
  display: block;
  padding: .35rem .65rem;
  margin: .05rem 0;
  font-size: .87rem;
  color: var(--dc-muted) !important;
  border-radius: var(--dc-radius);
  line-height: 1.45;
}
.laradocs-sidebar a:hover {
  color: var(--dc-fg) !important;
  background: var(--dc-bg-elev) !important;
}
.laradocs-sidebar a.is-active {
  color: var(--dc-fg) !important;
  background: var(--dc-accent-soft) !important;
  font-weight: 500;
}
.laradocs-sidebar .laradocs-nav-group {
  display: flex;
  align-items: center;
  margin: 1.5rem .65rem .35rem;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--dc-fg);
}
.laradocs-sidebar .laradocs-nav-group > span { flex: 1; min-width: 0; }
.laradocs-sidebar .laradocs-nav-group[role="button"] {
  cursor: pointer;
  user-select: none;
}
.laradocs-sidebar .laradocs-nav-group[role="button"]:hover { color: var(--dc-accent); }

/* Chevron icon used in collapse toggles */
.laradocs-nav-toggle {
  width: 14px; height: 14px;
  flex-shrink: 0;
  color: var(--dc-subtle);
  transition: transform .15s ease;
}
.laradocs-nav-group[aria-expanded="false"] .laradocs-nav-toggle,
.laradocs-nav-children-toggle[aria-expanded="false"] .laradocs-nav-toggle {
  transform: rotate(-90deg);
}

/* Hide collapsed sections */
.laradocs-sidebar nav > .laradocs-nav-group[aria-expanded="false"] + ul { display: none; }
.laradocs-sidebar .laradocs-children.is-collapsed { display: none; }

/* Flex row wrapping a link and its children toggle button */
.laradocs-nav-link-row { display: flex; align-items: center; }
.laradocs-nav-link-row > a { flex: 1; min-width: 0; }
.laradocs-nav-children-toggle {
  flex-shrink: 0;
  display: inline-flex; align-items: center; justify-content: center;
  border: 0; background: transparent;
  padding: .25rem;
  margin: .05rem 0;
  color: var(--dc-subtle);
  cursor: pointer;
  border-radius: var(--dc-radius);
  transition: color .12s ease, background .12s ease;
}
.laradocs-nav-children-toggle:hover { color: var(--dc-fg); background: var(--dc-bg-elev); }

.laradocs-sidebar .laradocs-children {
  margin: .15rem 0 .15rem .65rem;
  padding-left: .6rem;
  border-left: 1px solid var(--dc-rule);
}
.laradocs-sidebar .laradocs-children a { font-size: .85rem; }
.laradocs-badge {
  display: inline-block;
  margin-left: .4rem;
  padding: .05rem .35rem;
  font-size: .65rem;
  font-weight: 600;
  background: var(--dc-accent-soft);
  color: var(--dc-accent);
  border-radius: 3px;
}

/* Desktop: fixed so the footer can't push the sidebar above the header */
@media (min-width: 1025px) {
  .laradocs-sidebar {
    position: fixed;
    top: calc(var(--dc-header-h) + var(--dc-tabs-h));
    left: max(0px, calc((100vw - var(--dc-sidebar-w) - var(--dc-content-w) - var(--dc-toc-w) - 6rem) / 2));
    height: calc(100vh - var(--dc-header-h) - var(--dc-tabs-h));
    z-index: 3;
  }
  .laradocs-shell {
    padding-left: var(--dc-sidebar-w);
  }
}

@media (max-width: 1024px) {
  .laradocs-sidebar {
    position: fixed;
    top: var(--dc-header-h);
    left: 0;
    bottom: 0;
    z-index: 7;
    transform: translateX(-100%);
    transition: transform .2s ease;
    border-right: 1px solid var(--dc-rule);
    box-shadow: var(--dc-shadow-pop);
  }
  .laradocs-shell.nav-open ~ .laradocs-sidebar { transform: translateX(0); }
}

/* ─────────────────────── main + content ─────────────────────── */
.laradocs-main {
  flex: 1;
  min-width: 0;
  display: flex;
  justify-content: center;
}
.laradocs-content {
  flex: 1;
  max-width: var(--dc-content-w);
  padding: 3rem 2.5rem 5rem;
  min-width: 0;
}

@media (max-width: 1180px) {
  :root { --dc-toc-w: 0px; }
  .laradocs-toc { display: none; }
}
@media (max-width: 1024px) {
  .laradocs-content { padding: 2.5rem 1.5rem 4rem; }
}

/* ─────────────────────── TOC (right) ─────────────────────── */
.laradocs-toc {
  width: var(--dc-toc-w);
  flex-shrink: 0;
  padding: 2.25rem 1.5rem 2rem 0;
  position: sticky;
  top: calc(var(--dc-header-h) + var(--dc-tabs-h));
  align-self: flex-start;
  height: calc(100vh - var(--dc-header-h) - var(--dc-tabs-h));
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: thin;
  scrollbar-color: var(--dc-rule-strong) transparent;
}
.laradocs-toc > strong {
  display: block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--dc-fg);
  margin-bottom: .65rem;
}
.laradocs-toc ul {
  list-style: none;
  margin: 0; padding: 0;
  border-left: 1px solid var(--dc-rule);
}
.laradocs-toc li { margin: 0; }
.laradocs-toc a {
  display: block;
  padding: .25rem 0 .25rem .85rem;
  margin-left: -1px;
  border-left: 1px solid transparent;
  font-size: .82rem;
  color: var(--dc-muted) !important;
  line-height: 1.5;
}
.laradocs-toc a:hover { color: var(--dc-fg) !important; }
.laradocs-toc a.is-active {
  color: var(--dc-accent) !important;
  border-left-color: var(--dc-accent);
}
.laradocs-toc .lvl-3 a { padding-left: 1.6rem; }

/* ─────────────────────── breadcrumbs + page header ─────────────────────── */
.laradocs-breadcrumbs {
  display: flex; align-items: center; gap: .35rem;
  font-size: .8rem;
  color: var(--dc-muted);
  margin-bottom: 1.5rem;
}
.laradocs-breadcrumbs a { color: var(--dc-muted) !important; }
.laradocs-breadcrumbs a:hover { color: var(--dc-fg) !important; }

.laradocs-page-header { margin: 0 0 2rem; }
.laradocs-page-eyebrow {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--dc-accent);
  margin-bottom: .65rem;
}
.laradocs-page-title {
  margin: 0;
  font-size: 2.25rem;
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.15;
  text-wrap: balance;
}
.laradocs-page-description {
  margin: .85rem 0 0;
  font-size: 1.05rem;
  line-height: 1.55;
  color: var(--dc-muted);
  max-width: 60ch;
  text-wrap: pretty;
}

/* ─────────────────────── pager ─────────────────────── */
.laradocs-pager {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-top: 4rem;
  padding-top: 2rem;
  border-top: 1px solid var(--dc-rule);
}
.laradocs-pager a {
  display: block;
  padding: 1rem 1.15rem;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  color: var(--dc-fg) !important;
  font-size: .95rem;
  font-weight: 500;
  transition: border-color .12s ease, background .12s ease;
}
.laradocs-pager a:hover {
  border-color: var(--dc-rule-strong);
  background: var(--dc-bg-elev);
}
.laradocs-pager a span {
  display: block;
  font-size: .7rem;
  font-weight: 500;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--dc-muted);
  margin-bottom: .35rem;
}
.laradocs-pager .next { text-align: right; }
.laradocs-pager .prev::before { content: "← "; color: var(--dc-muted); }
.laradocs-pager .next::after { content: " →"; color: var(--dc-muted); }

.laradocs-page-meta {
  display: flex; flex-wrap: wrap; align-items: center; gap: 1rem;
  margin-top: 2.5rem;
  padding-top: 1.25rem;
  border-top: 1px solid var(--dc-rule);
  font-size: .8rem;
  color: var(--dc-muted);
}
.laradocs-edit-link {
  display: inline-flex; align-items: center; gap: .35rem;
  color: var(--dc-muted) !important;
}
.laradocs-edit-link:hover { color: var(--dc-fg) !important; }

/* ─────────────────────── prose ─────────────────────── */
.laradocs-prose {
  font-size: 1rem;
  line-height: 1.75;
  color: var(--dc-fg);
}
.laradocs-prose > * + * { margin-top: 1.1rem; }
.laradocs-prose h1,
.laradocs-prose h2,
.laradocs-prose h3,
.laradocs-prose h4 {
  font-weight: 600;
  line-height: 1.25;
  letter-spacing: -.015em;
  scroll-margin-top: calc(var(--dc-header-h) + 5rem);
  color: var(--dc-fg);
  text-wrap: balance;
}
.laradocs-prose h1 { font-size: 1.95rem; margin-top: 0; }
.laradocs-prose h2 {
  font-size: 1.4rem;
  margin-top: 2.5rem;
  margin-bottom: .75rem;
}
.laradocs-prose h3 { font-size: 1.1rem; margin-top: 2rem; margin-bottom: .5rem; }
.laradocs-prose h4 { font-size: .95rem; margin-top: 1.5rem; }
.laradocs-prose p { margin: 0; }
.laradocs-prose ul, .laradocs-prose ol { margin: 0; padding-left: 1.5rem; }
.laradocs-prose li { margin: .35rem 0; }
.laradocs-prose li::marker { color: var(--dc-subtle); }
.laradocs-prose strong { font-weight: 600; }
.laradocs-prose a {
  color: var(--dc-accent);
  text-decoration: underline;
  text-decoration-color: var(--dc-accent-line);
  text-underline-offset: 3px;
}
.laradocs-prose a:hover { text-decoration-color: var(--dc-accent); }
.laradocs-prose hr {
  border: 0;
  height: 1px;
  background: var(--dc-rule);
  margin: 2.5rem 0;
}

.laradocs-prose .laradocs-heading { position: relative; }
.laradocs-prose .laradocs-anchor {
  opacity: 0;
  margin-right: .25rem;
  color: var(--dc-subtle) !important;
  text-decoration: none !important;
  font-weight: 400;
}
.laradocs-prose .laradocs-heading:hover .laradocs-anchor { opacity: 1; }
.laradocs-prose .laradocs-heading .laradocs-anchor:hover { color: var(--dc-accent) !important; }

.laradocs-prose blockquote {
  margin: 1.5rem 0;
  padding: .4rem 0 .4rem 1.25rem;
  border-left: 2px solid var(--dc-rule-strong);
  color: var(--dc-muted);
  font-size: 1rem;
}
.laradocs-prose blockquote p { margin: 0; }
.laradocs-prose blockquote * + * { margin-top: .6rem; }

.laradocs-prose img {
  max-width: 100%;
  border-radius: var(--dc-radius-lg);
  border: 1px solid var(--dc-rule);
}
.laradocs-prose img.laradocs-image { cursor: zoom-in; }
.laradocs-prose img.is-zoomed {
  position: fixed; inset: 5%;
  width: 90%; height: 90%;
  max-width: none; object-fit: contain;
  background: var(--dc-bg);
  z-index: 60; cursor: zoom-out;
  box-shadow: var(--dc-shadow-pop);
}
.laradocs-figure { margin: 1.75rem 0; }
.laradocs-figure figcaption {
  font-size: .85rem;
  color: var(--dc-muted);
  margin-top: .5rem;
}

.laradocs-prose table {
  width: 100%;
  margin: 1.5rem 0;
  border-collapse: collapse;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius);
  overflow: hidden;
  font-size: .92rem;
}
.laradocs-prose th {
  text-align: left;
  font-weight: 600;
  font-size: .8rem;
  letter-spacing: .02em;
  color: var(--dc-fg);
  background: var(--dc-bg-elev);
  padding: .65rem .9rem;
  border-bottom: 1px solid var(--dc-rule);
}
.laradocs-prose td {
  padding: .6rem .9rem;
  border-bottom: 1px solid var(--dc-rule);
}
.laradocs-prose tr:last-child td { border-bottom: 0; }

/* inline code */
.laradocs-prose code {
  font-family: var(--dc-mono);
  font-size: .87em;
  background: var(--dc-code-bg);
  color: var(--dc-code-fg);
  padding: .12rem .35rem;
  border-radius: 4px;
  border: 1px solid var(--dc-rule);
}
.laradocs-prose a code { color: var(--dc-accent); }

/* code block */
.laradocs-code {
  margin: 1.5rem 0;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  overflow: hidden;
  background: var(--dc-code-bg);
}
.laradocs-code-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: .5rem .85rem .5rem 1rem;
  border-bottom: 1px solid var(--dc-rule);
  background: color-mix(in srgb, var(--dc-bg-elev) 70%, transparent);
}
.laradocs-code-lang {
  font-size: .7rem;
  color: var(--dc-muted);
  font-family: var(--dc-mono);
}
.laradocs-code-copy {
  font-family: var(--dc-font);
  font-size: .7rem;
  font-weight: 500;
  cursor: pointer;
  border: 1px solid var(--dc-rule);
  background: var(--dc-paper);
  color: var(--dc-muted);
  padding: .2rem .55rem;
  border-radius: 4px;
  transition: color .12s, border-color .12s;
}
.laradocs-code-copy:hover {
  color: var(--dc-fg);
  border-color: var(--dc-rule-strong);
}
.laradocs-code pre {
  margin: 0; padding: 1rem 1.15rem;
  overflow-x: auto;
  font-size: .87rem;
  line-height: 1.6;
}
.laradocs-code pre code {
  background: none; border: 0; padding: 0;
  color: var(--dc-code-fg);
  font-size: inherit;
}

/* mermaid diagrams */
.laradocs-mermaid {
  margin: 1.5rem 0;
  text-align: center;
}
.laradocs-mermaid svg {
  max-width: 100%;
  height: auto;
}
/* No-JS / pre-render fallback: the raw graph source as a styled code block. */
.laradocs-mermaid-source {
  margin: 0;
  padding: 1rem 1.15rem;
  overflow-x: auto;
  text-align: left;
  font-family: var(--dc-mono);
  font-size: .87rem;
  line-height: 1.6;
  color: var(--dc-code-fg);
  background: var(--dc-code-bg);
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
}
/* While mermaid loads, hide the source so it doesn't flash before the SVG. */
.laradocs-mermaid.is-loading .laradocs-mermaid-source {
  visibility: hidden;
}
.laradocs-mermaid.is-loading {
  min-height: 2.5rem;
}
/* Once rendered, the source <pre> holds the SVG — drop its code-block chrome. */
.laradocs-mermaid.is-rendered .laradocs-mermaid-source {
  padding: 0;
  background: none;
  border: 0;
  overflow: visible;
}

/* katex math */
/* Math glyphs inherit currentColor, so light/dark follow --dc-fg for free. */
/* Inline math: KaTeX renders at 1.21em, oversized next to prose — pull it
   back so symbols sit at roughly text size on the line. */
.laradocs-katex-inline { color: var(--dc-fg); }
.laradocs-katex-inline .katex { font-size: 1.05em; }

/* Display (block) math — both <div> (multi-line) and <span> (single-line)
   variants. A subtle elevated card matching code blocks / callouts: centred,
   with horizontal scroll for equations wider than the column. */
.laradocs-katex-block {
  display: block;
  margin: 1.75rem 0;
  padding: 1.35rem 1.25rem;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  background: var(--dc-bg-elev);
  color: var(--dc-fg);
  text-align: center;
  overflow-x: auto;
  overflow-y: hidden;
}
/* KaTeX's display wrapper adds 1em vertical margin — the card's padding owns
   that spacing now, so flatten it. */
.laradocs-katex-block .katex-display { margin: 0; }
.laradocs-katex-block .katex { font-size: 1.3em; }

/* Before KaTeX renders (client-side), the raw LaTeX is briefly visible.
   Present it as muted monospace so it reads as a formula loading rather than
   broken markup. SSR'd math is already marked rendered. */
[data-laradocs-katex]:not([data-katex-rendered]) {
  font-family: var(--dc-mono);
  font-size: .87rem;
  font-style: normal;
  color: var(--dc-muted);
}

/* callouts */
.laradocs-callout {
  margin: 1.5rem 0;
  padding: .9rem 1.15rem;
  border: 1px solid var(--dc-rule);
  border-left: 3px solid var(--dc-callout-color, var(--dc-accent));
  border-radius: var(--dc-radius-lg);
  background: var(--dc-bg-elev);
}
.laradocs-callout-title {
  display: flex; align-items: center; gap: .5rem;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: var(--dc-callout-color, var(--dc-accent));
  margin: 0 0 .5rem;
}
.laradocs-callout-title::before {
  content: "";
  width: 14px; height: 14px;
  -webkit-mask: var(--dc-callout-icon, none) center / contain no-repeat;
          mask: var(--dc-callout-icon, none) center / contain no-repeat;
  background-color: var(--dc-callout-color, var(--dc-accent));
}
.laradocs-callout-body > * { margin: 0; }
.laradocs-callout-body > * + * { margin-top: .55rem; }

.laradocs-callout-note      { --dc-callout-color: #2563eb; --dc-callout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><path d='M12 16v-4'/><path d='M12 8h.01'/></svg>"); }
.laradocs-callout-tip       { --dc-callout-color: #10b981; --dc-callout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M9 18h6'/><path d='M10 22h4'/><path d='M12 2a7 7 0 0 0-4 12.7c.9.7 1.4 1.7 1.5 2.8h5c.1-1.1.6-2.1 1.5-2.8A7 7 0 0 0 12 2z'/></svg>"); }
.laradocs-callout-important { --dc-callout-color: #8b5cf6; --dc-callout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M21 11.5a8.38 8.38 0 0 1-.9 3.8 8.5 8.5 0 0 1-7.6 4.7 8.38 8.38 0 0 1-3.8-.9L3 21l1.9-5.7a8.38 8.38 0 0 1-.9-3.8 8.5 8.5 0 0 1 4.7-7.6 8.38 8.38 0 0 1 3.8-.9h.5a8.48 8.48 0 0 1 8 8z'/></svg>"); }
.laradocs-callout-warning   { --dc-callout-color: #f59e0b; --dc-callout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><path d='M10.29 3.86 1.82 18a2 2 0 0 0 1.71 3h16.94a2 2 0 0 0 1.71-3L13.71 3.86a2 2 0 0 0-3.42 0z'/><path d='M12 9v4'/><path d='M12 17h.01'/></svg>"); }
.laradocs-callout-danger,
.laradocs-callout-caution   { --dc-callout-color: #ef4444; --dc-callout-icon: url("data:image/svg+xml;utf8,<svg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='black' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'><circle cx='12' cy='12' r='10'/><path d='m4.9 4.9 14.2 14.2'/></svg>"); }

/* ─────────────────────── command palette ─────────────────────── */
.laradocs-palette {
  position: fixed; inset: 0; z-index: 100;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 12vh;
}
.laradocs-palette[hidden] { display: none !important; }
.laradocs-palette-backdrop {
  position: absolute; inset: 0;
  background: color-mix(in srgb, var(--dc-fg) 30%, transparent);
  backdrop-filter: blur(3px);
}
.laradocs-palette-panel {
  position: relative;
  width: min(38rem, 92vw);
  background: var(--dc-paper);
  border: 1px solid var(--dc-rule-strong);
  border-radius: var(--dc-radius-lg);
  box-shadow: var(--dc-shadow-pop);
  overflow: hidden;
}
.laradocs-palette-search {
  display: flex; align-items: center; gap: .65rem;
  padding: .85rem 1rem;
  border-bottom: 1px solid var(--dc-rule);
}
.laradocs-palette-search svg { width: 16px; height: 16px; color: var(--dc-muted); flex-shrink: 0; }
.laradocs-palette-search input {
  flex: 1;
  border: 0; outline: 0; background: transparent;
  font: inherit; color: var(--dc-fg);
  font-size: 1rem;
}
.laradocs-palette-search kbd {
  font-family: var(--dc-mono); font-size: .7rem;
  padding: .12rem .4rem;
  border: 1px solid var(--dc-rule);
  border-radius: 3px;
  color: var(--dc-muted);
}
.laradocs-palette-results {
  list-style: none; margin: 0; padding: .35rem 0;
  /* A stable floor + ceiling keeps the panel from resizing as the result list
     is swapped out on each query — no layout shift while results stream in. */
  min-height: 8rem;
  max-height: 50vh;
  overflow-y: auto;
  scrollbar-gutter: stable;
}
.laradocs-palette-results li { margin: 0; }
.laradocs-palette-section {
  padding: .5rem 1rem .2rem;
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .04em;
  text-transform: uppercase;
  color: var(--dc-muted);
}
.laradocs-palette-results a {
  display: flex; align-items: baseline; gap: .75rem; flex-wrap: wrap;
  padding: .55rem 1rem;
  color: var(--dc-fg) !important;
  font-size: .9rem;
}
.laradocs-palette-excerpt {
  flex: 0 0 100%;
  margin-top: .15rem;
  font-size: .72rem;
  line-height: 1.4;
  color: var(--dc-muted);
}
.laradocs-palette-empty {
  padding: .8rem 1rem;
  font-size: .85rem;
  color: var(--dc-muted);
}
.laradocs-palette-results a:hover,
.laradocs-palette-results a.is-active {
  background: var(--dc-bg-elev);
}
.laradocs-palette-results a.is-active { color: var(--dc-accent) !important; }
.laradocs-palette-title { flex: 1; }
.laradocs-palette-group,
.laradocs-palette-breadcrumb {
  font-size: .72rem;
  color: var(--dc-muted);
}
.laradocs-palette-mark {
  background: color-mix(in srgb, var(--dc-accent) 22%, transparent);
  color: inherit;
  border-radius: 2px;
  padding: 0 .1em;
}
.laradocs-palette-footer {
  display: flex; gap: 1rem;
  padding: .55rem 1rem;
  border-top: 1px solid var(--dc-rule);
  background: var(--dc-bg-elev);
  font-size: .7rem;
  color: var(--dc-muted);
}
.laradocs-palette-footer kbd {
  font-family: var(--dc-mono); font-size: .65rem;
  padding: .03rem .3rem;
  margin-right: .25rem;
  border: 1px solid var(--dc-rule);
  border-radius: 3px;
  background: var(--dc-paper);
}

/* ─────────────────────── empty page (no docs yet) ─────────────────────── */
.laradocs-empty {
  max-width: 38rem;
  margin: 5rem auto 6rem;
  padding: 0 2rem;
}
.laradocs-empty-eyebrow {
  display: inline-block;
  font-size: .72rem;
  font-weight: 600;
  letter-spacing: .05em;
  text-transform: uppercase;
  color: var(--dc-accent);
  margin-bottom: .85rem;
}
.laradocs-empty h1 {
  font-size: 2.25rem;
  font-weight: 600;
  letter-spacing: -.02em;
  line-height: 1.15;
  margin: 0 0 1rem;
  text-wrap: balance;
}
.laradocs-empty > p {
  margin: 0 0 2rem;
  font-size: 1.05rem;
  line-height: 1.6;
  color: var(--dc-muted);
}
.laradocs-empty-steps {
  display: grid;
  gap: .75rem;
  margin: 0 0 2rem;
}
.laradocs-empty-step {
  display: grid;
  grid-template-columns: 1.75rem 1fr;
  gap: 1rem;
  padding: 1rem 1.15rem;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  background: var(--dc-bg-elev);
}
.laradocs-empty-step .num {
  font-family: var(--dc-mono);
  font-size: .85rem;
  font-weight: 500;
  color: var(--dc-accent);
}
.laradocs-empty-step strong {
  display: block;
  font-weight: 600;
  font-size: .95rem;
  margin-bottom: .25rem;
}
.laradocs-empty-step code {
  font-family: var(--dc-mono);
  font-size: .85em;
  padding: .1rem .35rem;
  border-radius: 4px;
  background: var(--dc-code-bg);
  border: 1px solid var(--dc-rule);
}
.laradocs-button {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .55rem 1rem;
  background: var(--dc-accent);
  color: #fff !important;
  border-radius: var(--dc-radius);
  font-weight: 500;
  font-size: .9rem;
  transition: filter .12s ease;
}
.laradocs-button:hover { filter: brightness(1.08); color: #fff !important; }

/* ─────────────────────── footer ─────────────────────── */
.laradocs-footer {
  border-top: 1px solid var(--dc-rule);
  padding: 2rem 1.5rem;
  display: flex; align-items: center; justify-content: space-between;
  gap: 1rem;
  font-size: .82rem;
  color: var(--dc-muted);
  max-width: calc(var(--dc-sidebar-w) + var(--dc-content-w) + var(--dc-toc-w) + 6rem);
  margin: 0 auto;
}
.laradocs-footer-links { display: flex; gap: 1rem; }
.laradocs-footer-links a { color: var(--dc-muted) !important; }
.laradocs-footer-links a:hover { color: var(--dc-fg) !important; }
@media (min-width: 1025px) {
  .laradocs-footer { padding-left: calc(var(--dc-sidebar-w) + 1.5rem); }
}

/* ─────────────────────── mobile TOC disclosure ─────────────────────── */
.laradocs-toc-mobile {
  display: none;
  margin: 1.25rem 0 2rem;
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  background: var(--dc-bg-elev);
  overflow: hidden;
}
.laradocs-toc-mobile > summary {
  display: flex; align-items: center; gap: .65rem;
  padding: .75rem 1rem;
  cursor: pointer;
  list-style: none;
  font-size: .82rem;
  font-weight: 500;
  color: var(--dc-fg);
}
.laradocs-toc-mobile > summary::-webkit-details-marker { display: none; }
.laradocs-toc-mobile-label { flex: 1; }
.laradocs-toc-mobile-count {
  font-family: var(--dc-mono);
  font-size: .72rem;
  padding: .12rem .4rem;
  border: 1px solid var(--dc-rule);
  border-radius: 3px;
  background: var(--dc-paper);
  color: var(--dc-muted);
}
.laradocs-toc-mobile-caret {
  width: 16px; height: 16px;
  color: var(--dc-muted);
  transition: transform .15s ease;
}
.laradocs-toc-mobile[open] .laradocs-toc-mobile-caret { transform: rotate(180deg); }
.laradocs-toc-mobile ul {
  list-style: none; margin: 0; padding: .25rem 0 .65rem;
  border-top: 1px solid var(--dc-rule);
  max-height: 60vh;
  overflow-y: auto;
  overscroll-behavior: contain;
}
.laradocs-toc-mobile li { margin: 0; }
.laradocs-toc-mobile a {
  display: block;
  padding: .4rem 1rem;
  font-size: .87rem;
  color: var(--dc-muted) !important;
  text-decoration: none;
}
.laradocs-toc-mobile a:hover { color: var(--dc-fg) !important; background: var(--dc-bg); }
.laradocs-toc-mobile .lvl-3 a { padding-left: 2rem; font-size: .82rem; }

/* Show the inline disclosure only when the right-hand TOC is hidden. */
@media (max-width: 1180px) {
  .laradocs-toc-mobile { display: block; }
}

/* ─────────────────────── narrow viewport polish ─────────────────────── */
@media (max-width: 860px) {
  /* Sidebar hidden by default; the drawer appears via menu button. Tabs
     can now sit flush with the content's horizontal padding. */
  .laradocs-tabs-inner { padding: 0 1.25rem; }
  .laradocs-content { padding: 2rem 1.25rem 3.5rem; }

  /* Stack the prev/next pager and let it breathe. */
  .laradocs-pager { grid-template-columns: 1fr; gap: .65rem; margin-top: 3rem; }
  .laradocs-pager .next { text-align: left; }

  /* Header tightens up; theme toggle stays visible. */
  .laradocs-header { gap: .5rem; padding: 0 .9rem; }
  .laradocs-brand-tag { display: none; }
  .laradocs-brand-title { font-size: .92rem; }

  /* Page title scales slightly so it doesn't dominate small screens. */
  .laradocs-page-title { font-size: 1.85rem; }
  .laradocs-page-description { font-size: 1rem; }

  /* Footer stacks. */
  .laradocs-footer {
    flex-direction: column; align-items: flex-start; gap: .6rem;
    padding: 1.5rem 1.25rem;
  }
}

@media (max-width: 480px) {
  .laradocs-content { padding: 1.75rem 1rem 3rem; }
  .laradocs-tabs-inner { padding: 0 1rem; }
  .laradocs-page-title { font-size: 1.65rem; }
  .laradocs-empty { padding: 0 1rem; margin-top: 3rem; }
  .laradocs-empty h1 { font-size: 1.85rem; }
  .laradocs-callout { padding: .8rem .95rem; }
  .laradocs-code pre { padding: .85rem 1rem; }
}

/* Tables that exceed their container scroll horizontally on small
   screens rather than forcing the whole page to grow. */
@media (max-width: 860px) {
  .laradocs-prose table {
    display: block;
    overflow-x: auto;
    max-width: 100%;
  }
}

/* ─────────────────────── tag index pages ─────────────────────── */
.laradocs-tag-cloud {
  display: flex;
  flex-wrap: wrap;
  gap: .6rem;
  margin: 0;
  padding: 0;
  list-style: none;
}
.laradocs-tag-cloud li { margin: 0; }

.laradocs-tag-chip {
  display: inline-flex;
  align-items: center;
  gap: .45rem;
  padding: .3rem .7rem;
  font-size: .85rem;
  font-weight: 500;
  color: var(--dc-fg) !important;
  background: var(--dc-bg-elev);
  border: 1px solid var(--dc-rule);
  border-radius: 999px;
  text-decoration: none;
  transition: border-color .15s ease, color .15s ease, background .15s ease;
}
.laradocs-tag-chip:hover {
  color: var(--dc-accent) !important;
  border-color: var(--dc-accent-line);
  background: var(--dc-accent-soft);
}
.laradocs-tag-chip-count {
  min-width: 1.25rem;
  padding: 0 .35rem;
  font-size: .7rem;
  font-weight: 600;
  text-align: center;
  color: var(--dc-accent);
  background: var(--dc-accent-soft);
  border-radius: 999px;
}

.laradocs-tag-pages {
  margin: 0;
  padding: 0;
  list-style: none;
  display: grid;
  gap: .85rem;
}
.laradocs-tag-page {
  display: block;
  padding: 1rem 1.1rem;
  background: var(--dc-bg-elev);
  border: 1px solid var(--dc-rule);
  border-radius: var(--dc-radius-lg);
  text-decoration: none;
  transition: border-color .15s ease, background .15s ease;
}
.laradocs-tag-page:hover { border-color: var(--dc-accent-line); }
.laradocs-tag-page-title {
  display: block;
  font-weight: 600;
  color: var(--dc-fg);
}
.laradocs-tag-page:hover .laradocs-tag-page-title { color: var(--dc-accent); }
.laradocs-tag-page-desc {
  display: block;
  margin-top: .25rem;
  font-size: .9rem;
  color: var(--dc-muted);
}

.laradocs-tag-back { margin-top: 2rem; font-size: .9rem; }
.laradocs-tags-empty { color: var(--dc-muted); }

/* Tag list on an individual document page. */
.laradocs-page-tags {
  display: flex;
  flex-wrap: wrap;
  gap: .5rem;
  margin: 2rem 0 0;
}

/* ─────────────────────── reduced motion ─────────────────────── */
@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: .001ms !important;
    animation-iteration-count: 1 !important;
    transition-duration: .001ms !important;
  }
  html { scroll-behavior: auto; }
}
