/* Luma theme — plain CSS port of the React design system. */

:root {
  --radius: 1rem;

  --background: oklch(0.99 0.01 290);
  --foreground: oklch(0.22 0.04 285);
  --card: oklch(1 0 0);
  --card-foreground: oklch(0.22 0.04 285);

  --primary: oklch(0.55 0.24 295);
  --primary-foreground: oklch(0.99 0 0);
  --primary-dark: oklch(0.47 0.24 295);

  --muted: oklch(0.96 0.02 290);
  --muted-foreground: oklch(0.5 0.04 285);

  --accent: oklch(0.94 0.04 290);
  --accent-foreground: oklch(0.47 0.24 295);

  --border: oklch(0.92 0.02 290);
  --surface: oklch(0.97 0.025 290);
  --ink: oklch(0.18 0.04 285);
  --ink-soft: oklch(0.45 0.03 285);
  --success: oklch(0.68 0.16 155);

  --gradient-primary: linear-gradient(135deg, var(--primary), oklch(0.7 0.22 320));
  --shadow-elegant: 0 10px 30px -10px color-mix(in oklab, var(--primary) 30%, transparent);
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--background);
  color: var(--foreground);
  font: 16px/1.6 "Inter", system-ui, -apple-system, Segoe UI, Roboto, sans-serif;
  -webkit-font-smoothing: antialiased;
}
a { color: inherit; text-decoration: none; }
code, pre, .luma-mono { font-family: "JetBrains Mono", ui-monospace, monospace; }
main { display: block; }

/* ---------- Wordmark ---------- */
.luma-wordmark { display: inline-flex; align-items: center; gap: .5rem; }
.luma-wordmark__dot {
  position: relative; width: 1.25rem; height: 1.25rem; border-radius: 999px;
  background: var(--primary);
  box-shadow: 0 0 0 8px color-mix(in oklab, var(--primary) 20%, transparent);
}
.luma-wordmark__text { font-size: 1.25rem; font-weight: 700; letter-spacing: -.01em; }
.luma-wordmark__brand  { color: var(--primary); }
.luma-wordmark__sep    { color: color-mix(in oklab, var(--foreground) 70%, transparent); }
.luma-wordmark__suffix { color: var(--foreground); }

/* ---------- Navigation ---------- */
.luma-nav {
  position: sticky; top: 0; z-index: 50;
  border-bottom: 1px solid var(--border);
  background: color-mix(in oklab, var(--background) 80%, transparent);
  backdrop-filter: blur(10px);
}
.luma-nav__inner {
  max-width: 1200px; margin: 0 auto; padding: 0 1.5rem;
  height: 4rem; display: flex; align-items: center; justify-content: space-between;
}
.luma-nav__links { display: none; gap: 1.5rem; margin-left: 2rem; font-size: .875rem; font-weight: 500; color: var(--muted-foreground); }
.luma-nav__link { transition: color .15s; }
.luma-nav__link:hover, .luma-nav__link.is-active { color: var(--primary); }
.luma-nav__cta { display: flex; align-items: center; gap: .75rem; }
.luma-nav__meta {
  display: none;
  font: 600 10px/1 "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: .15em;
  color: var(--muted-foreground);
}
.luma-nav__github {
  display: none; font-size: .875rem; font-weight: 500; color: var(--muted-foreground);
}
.luma-nav__github:hover { color: var(--foreground); }
@media (min-width: 768px) {
  .luma-nav__links { display: flex; }
}
@media (min-width: 640px) {
  .luma-nav__github { display: inline; }
}
@media (min-width: 1024px) {
  .luma-nav__meta { display: inline; }
}

/* ---------- Buttons ---------- */
.luma-btn {
  display: inline-flex; align-items: center; gap: .5rem;
  padding: .5rem 1.25rem; border-radius: 999px;
  font-size: .875rem; font-weight: 600;
  transition: all .15s ease;
  border: 1px solid transparent; cursor: pointer;
}
.luma-btn--primary {
  background: var(--primary); color: var(--primary-foreground);
  box-shadow: 0 6px 18px -6px color-mix(in oklab, var(--primary) 50%, transparent);
}
.luma-btn--primary:hover { background: var(--primary-dark); }
.luma-btn--ghost {
  background: color-mix(in oklab, var(--background) 80%, transparent);
  color: var(--foreground); border-color: var(--border);
}
.luma-btn--ghost:hover { background: var(--surface); }
.luma-btn--lg {
  padding: 1rem 1.75rem; border-radius: .75rem; font-size: .875rem; font-weight: 700;
}

/* ---------- Sections ---------- */
.luma-section__inner {
  max-width: 1200px; margin: 0 auto; padding: 5rem 1.5rem;
}
.luma-section__inner--narrow { max-width: 760px; }
.luma-eyebrow {
  display: inline-block;
  font: 700 11px/1 "JetBrains Mono", monospace;
  letter-spacing: .2em; text-transform: uppercase;
  color: var(--primary);
  padding: .5rem .9rem; border-radius: 999px;
  background: color-mix(in oklab, var(--primary) 10%, transparent);
  margin-bottom: 1.5rem;
}
.luma-h1 {
  font-size: clamp(2.5rem, 5vw, 4rem);
  line-height: 1.05; letter-spacing: -.02em;
  margin: 0 0 1.5rem; font-weight: 800;
}
.luma-h1--sm { font-size: clamp(2rem, 3.5vw, 2.75rem); }
.luma-h2 {
  font-size: clamp(1.75rem, 3vw, 2.5rem); margin: 0 0 1rem;
  font-weight: 700; letter-spacing: -.02em;
}
.luma-grad {
  background: var(--gradient-primary);
  -webkit-background-clip: text; background-clip: text;
  -webkit-text-fill-color: transparent; color: transparent;
}
.luma-lead {
  font-size: 1.125rem; color: var(--muted-foreground);
  max-width: 36rem; margin: 0 0 2.25rem;
}
.luma-section__lead {
  color: var(--muted-foreground); font-size: 1.0625rem; margin: 0 0 2.5rem;
}
.luma-cta-row { display: flex; flex-wrap: wrap; gap: 1rem; }
.luma-cta-row--center { justify-content: center; margin-top: 2rem; }

/* ---------- Hero ---------- */
.luma-hero { position: relative; overflow: hidden; }
.luma-hero__bg {
  position: absolute; inset: 0;
  background:
    radial-gradient(60% 50% at 20% 0%, color-mix(in oklab, var(--primary) 22%, transparent), transparent 70%),
    radial-gradient(50% 40% at 90% 30%, color-mix(in oklab, var(--accent) 60%, transparent), transparent 75%),
    var(--background);
  pointer-events: none;
}
.luma-hero__inner {
  position: relative; max-width: 1200px; margin: 0 auto;
  padding: 5rem 1.5rem; display: grid; gap: 4rem;
  grid-template-columns: 1fr;
}
@media (min-width: 1024px) {
  .luma-hero__inner { grid-template-columns: 1.05fr 1fr; align-items: center; padding: 7rem 1.5rem; }
}
.luma-hero__stats {
  margin-top: 2rem; display: flex; gap: 1.25rem; align-items: center;
  font-size: .8125rem; color: var(--muted-foreground);
}

/* ---------- Features grid ---------- */
.luma-features { background: var(--surface); }
.luma-features__grid {
  display: grid; gap: 1.25rem;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}
.luma-feature {
  background: var(--card); border: 1px solid var(--border);
  border-radius: 1rem; padding: 1.75rem;
  transition: transform .15s, box-shadow .2s;
}
.luma-feature:hover {
  transform: translateY(-2px); box-shadow: var(--shadow-elegant);
}
.luma-feature h3 { margin: 0 0 .5rem; font-size: 1rem; font-weight: 700; }
.luma-feature p { margin: 0; color: var(--muted-foreground); font-size: .9375rem; }

/* ---------- Install / code block ---------- */
.luma-install { background: var(--background); text-align: center; }
.luma-install .luma-h2 { text-align: center; }
.luma-code {
  max-width: 760px; margin: 0 auto;
  background: oklch(0.18 0.04 285); color: oklch(0.94 0.02 285);
  border-radius: 1rem; padding: 1.5rem 1.75rem;
  font: 500 .875rem/1.7 "JetBrains Mono", monospace;
  text-align: left; overflow-x: auto;
}
.luma-code .luma-dim   { color: oklch(0.6 0.02 285); }
.luma-code .luma-green { color: var(--success); }

/* ---------- Footer ---------- */
.luma-footer { border-top: 1px solid var(--border); background: var(--surface); margin-top: 4rem; }
.luma-footer__inner { max-width: 1200px; margin: 0 auto; padding: 4rem 1.5rem; }
.luma-footer__grid { display: grid; gap: 2.5rem; grid-template-columns: repeat(2, 1fr); }
@media (min-width: 768px) { .luma-footer__grid { grid-template-columns: 2fr 1fr 1fr; } }
.luma-footer__brand { grid-column: 1 / -1; }
@media (min-width: 768px) { .luma-footer__brand { grid-column: auto; } }
.luma-footer__tagline {
  margin: 1rem 0 .75rem; max-width: 26rem;
  font-size: .875rem; line-height: 1.6; color: var(--muted-foreground);
}
.luma-footer__version {
  margin: 0; font: 600 10px/1 "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: .15em; color: var(--muted-foreground);
}
.luma-footer__heading {
  margin: 0 0 1rem; font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .12em; color: var(--muted-foreground);
}
.luma-footer__list { list-style: none; padding: 0; margin: 0; }
.luma-footer__list li { margin: .65rem 0; font-size: .9rem; }
.luma-footer__list a:hover { color: var(--primary); }
.luma-footer__legal {
  margin-top: 3rem; padding-top: 2rem; border-top: 1px solid var(--border);
  display: flex; flex-direction: column; gap: .75rem;
  font-size: .75rem; color: var(--muted-foreground);
}
@media (min-width: 768px) { .luma-footer__legal { flex-direction: row; justify-content: space-between; } }

/* ---------- Article / prose ---------- */
.luma-article__head { text-align: center; margin-bottom: 3rem; }
.luma-article__lead { color: var(--muted-foreground); font-size: 1.0625rem; }
.luma-prose h1, .luma-prose h2, .luma-prose h3 { letter-spacing: -.01em; }
.luma-prose h2 { margin-top: 2.5rem; font-size: 1.5rem; }
.luma-prose h3 { margin-top: 2rem; font-size: 1.125rem; }
.luma-prose p  { color: var(--ink-soft); }
.luma-prose a  { color: var(--primary); text-decoration: underline; text-decoration-thickness: 1px; text-underline-offset: 2px; }
.luma-prose code { background: var(--surface); padding: .15em .4em; border-radius: .4em; font-size: .9em; }
.luma-prose pre {
  background: oklch(0.18 0.04 285); color: oklch(0.94 0.02 285);
  padding: 1.25rem; border-radius: .75rem; overflow-x: auto;
  font-size: .85rem; line-height: 1.7;
}
.luma-prose pre code { background: transparent; padding: 0; color: inherit; }
.luma-prose ul { padding-left: 1.25rem; color: var(--ink-soft); }
.luma-prose li { margin: .35rem 0; }

/* ---------- Admin preview mock ---------- */
.luma-admin {
  background: #fff; border: 1px solid color-mix(in oklab, var(--border) 80%, transparent);
  border-radius: .75rem; box-shadow: 0 25px 50px -12px rgb(0 0 0 / .25); overflow: hidden;
  font-size: 12px;
}
.luma-admin__chrome {
  display: flex; align-items: center; gap: .375rem;
  padding: .75rem 1rem; border-bottom: 1px solid #f1f5f9; background: #f8fafc;
}
.luma-admin__dot { width: .625rem; height: .625rem; border-radius: 999px; }
.luma-admin__dot--red    { background: #f87171b3; }
.luma-admin__dot--amber  { background: #fbbf24b3; }
.luma-admin__dot--green  { background: #34d399b3; }
.luma-admin__path {
  margin-left: 1rem; font: 500 10px/1 "JetBrains Mono", monospace;
  text-transform: uppercase; letter-spacing: .1em; color: #94a3b8;
}
.luma-admin__body { display: grid; grid-template-columns: 3fr 5fr 4fr; }
.luma-admin__sidebar { border-right: 1px solid #f1f5f9; background: #f8fafc99; padding: 1rem; color: #64748b; }
.luma-admin__brand { display: flex; align-items: center; gap: .5rem; font: 700 11px/1 "Inter", sans-serif; color: #334155; margin-bottom: 1rem; }
.luma-admin__brand-dot { width: 1.5rem; height: 1.5rem; border-radius: .375rem; background: var(--primary); }
.luma-admin__sidebar nav div {
  padding: .375rem .5rem; border-radius: .375rem;
  font-size: 11px; margin-bottom: .1rem;
}
.luma-admin__sidebar nav .is-active {
  background: color-mix(in oklab, var(--primary) 10%, transparent);
  color: var(--primary); font-weight: 600;
}
.luma-admin__editor { padding: 1.25rem; border-right: 1px solid #f1f5f9; }
.luma-admin__tags { display: flex; align-items: center; gap: .5rem; margin-bottom: 1rem; }
.luma-tag  { background: #f1f5f9; color: #64748b; font: 500 9px/1 "JetBrains Mono", monospace; padding: .15rem .4rem; border-radius: .25rem; }
.luma-meta { color: #94a3b8; font-size: 10px; }
.luma-admin__source { font-family: "JetBrains Mono", monospace; font-size: 10.5px; line-height: 1.7; color: #334155; }
.luma-admin__source p { margin: 0; }
.luma-hash  { color: var(--primary); }
.luma-dim   { color: #94a3b8; }
.luma-green { color: #059669; }
.luma-admin__preview { padding: 1.25rem; }
.luma-admin__preview-head {
  display: flex; justify-content: space-between; align-items: center;
  font: 600 10px/1 "Inter", sans-serif; text-transform: uppercase; letter-spacing: .1em;
  color: #94a3b8; margin-bottom: .75rem;
}
.luma-synced { display: inline-flex; align-items: center; gap: .25rem; font-size: 9px; color: #94a3b8; text-transform: none; letter-spacing: 0; }
.luma-synced__dot { width: 6px; height: 6px; border-radius: 999px; background: var(--success); }
.luma-admin__preview h4 { margin: 0; font-size: 13px; color: #1e293b; }
.luma-admin__preview h5 { margin: .75rem 0 .25rem; font-size: 11px; color: #334155; }
.luma-admin__preview p  { margin: .25rem 0; font-size: 10px; color: #64748b; }
.luma-admin__preview ul { padding-left: .25rem; margin: .25rem 0 0; list-style: none; font-size: 10px; color: #475569; }
.luma-admin__preview li { margin: .15rem 0; }
.luma-admin__terminal {
  margin-top: .75rem; padding: .5rem; border-radius: .375rem;
  background: #0f172a; color: #6ee7b7;
  font: 500 9px/1.4 "JetBrains Mono", monospace;
}
@media (max-width: 640px) {
  .luma-admin { font-size: 10px; }
  .luma-admin__body { grid-template-columns: 1fr; }
  .luma-admin__sidebar, .luma-admin__editor { border-right: 0; border-bottom: 1px solid #f1f5f9; }
}

/* ===== Language switcher (segmented control) ===== */
.luma-langsw {
  display: inline-flex;
  align-items: stretch;
  padding: 3px;
  background: var(--muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  gap: 2px;
  position: relative;
}
.luma-langsw__opt {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2.25rem;
  padding: .25rem .65rem;
  font: 600 11px/1 "Inter", sans-serif;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted-foreground);
  border-radius: 999px;
  transition: color .15s ease, background .15s ease, box-shadow .15s ease, transform .15s ease;
  cursor: pointer;
}
.luma-langsw__opt:hover {
  color: var(--ink);
  background: color-mix(in oklab, var(--primary) 6%, transparent);
}
.luma-langsw__opt.is-active {
  background: var(--background);
  color: var(--primary);
  box-shadow:
    0 1px 2px color-mix(in oklab, var(--primary) 22%, transparent),
    0 0 0 1px color-mix(in oklab, var(--primary) 35%, transparent) inset;
}
.luma-langsw__opt.is-active::before {
  content: "";
  width: 6px; height: 6px;
  border-radius: 999px;
  background: var(--gradient-primary);
  margin-right: .35rem;
  box-shadow: 0 0 0 2px color-mix(in oklab, var(--primary) 25%, transparent);
}
.luma-langsw__opt:focus-visible {
  outline: 2px solid var(--primary);
  outline-offset: 2px;
}

/* Footer variant — slightly larger so it reads in a dense column */
.luma-langsw--footer { margin-top: .75rem; }
.luma-langsw--footer .luma-langsw__opt { padding: .35rem .85rem; font-size: 12px; }

/* Header variant — compact, tucked next to the CTA */
.luma-langsw--header { margin-right: .25rem; }
@media (max-width: 720px) {
  .luma-langsw--header { display: none; }
}


/* ===== Shared-hosting 1:1 route port additions ===== */
.luma-section__inner--page { max-width: 1120px; }
.luma-muted-title { color: var(--muted-foreground); }
.luma-page-intro { max-width: 760px; margin: -1rem auto 2.25rem; text-align: center; font-size: 1.075rem; color: var(--muted-foreground); }
.luma-page-section { margin: 3.5rem 0; }
.luma-page-section > h2 { margin-bottom: 1rem; font-size: clamp(1.5rem, 3vw, 2.25rem); }
.luma-card-grid, .luma-catalog-grid, .luma-pricing-grid, .luma-stat-grid { display: grid; gap: 1.25rem; }
.luma-card-grid { grid-template-columns: repeat(auto-fit, minmax(240px, 1fr)); }
.luma-catalog-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); }
.luma-pricing-grid { grid-template-columns: repeat(auto-fit, minmax(260px, 1fr)); align-items: stretch; margin: 2rem 0 3rem; }
.luma-stat-grid { grid-template-columns: repeat(auto-fit, minmax(180px, 1fr)); margin-top: 2rem; }
.luma-card, .luma-catalog-card, .luma-price-card, .luma-roadmap-item { border: 1px solid var(--border); background: var(--card); border-radius: 1.25rem; padding: 1.5rem; box-shadow: 0 16px 40px -28px color-mix(in oklab, var(--primary) 35%, transparent); }
.luma-card:hover, .luma-catalog-card:hover, .luma-price-card:hover { transform: translateY(-2px); border-color: color-mix(in oklab, var(--primary) 35%, var(--border)); transition: .18s ease; }
.luma-card__eyebrow { margin: 0 0 .65rem; color: var(--primary); font: 700 11px/1.3 "JetBrains Mono", ui-monospace, monospace; text-transform: uppercase; letter-spacing: .12em; }
.luma-card h3, .luma-catalog-card h3, .luma-price-card h3 { margin: 0 0 .65rem; font-size: 1.15rem; }
.luma-card p, .luma-catalog-card p, .luma-price-card p { color: var(--muted-foreground); }
.luma-card__link, .luma-card-actions a { display: inline-flex; margin-top: .75rem; color: var(--primary); font-weight: 700; text-decoration: none; }
.luma-card-actions { display: flex; gap: 1rem; flex-wrap: wrap; margin-top: 1rem; }
.luma-catalog-card ul, .luma-price-card ul { padding-left: 1.1rem; }
.luma-catalog-card li, .luma-price-card li { color: var(--ink-soft); font-size: .925rem; }
.luma-price-card.is-featured { border-color: color-mix(in oklab, var(--primary) 55%, var(--border)); box-shadow: 0 20px 60px -30px var(--primary); }
.luma-price { margin: .5rem 0 1rem; color: var(--muted-foreground); }
.luma-price span { color: var(--foreground); font-size: 2.4rem; font-weight: 800; letter-spacing: -.04em; margin-right: .25rem; }
.luma-table-wrap { overflow-x: auto; border: 1px solid var(--border); border-radius: 1rem; margin: 1rem 0 2rem; }
.luma-table-wrap table { width: 100%; border-collapse: collapse; min-width: 640px; }
.luma-table-wrap th, .luma-table-wrap td { padding: .9rem 1rem; border-bottom: 1px solid var(--border); text-align: left; }
.luma-table-wrap th { background: var(--surface); font-size: .8rem; text-transform: uppercase; letter-spacing: .08em; }
.luma-faq { display: grid; gap: .75rem; }
.luma-faq details { border: 1px solid var(--border); border-radius: .85rem; padding: 1rem 1.15rem; background: var(--card); }
.luma-faq summary { cursor: pointer; font-weight: 700; }
.luma-faq p { margin-bottom: 0; }
.luma-pill-list { display: flex; flex-wrap: wrap; gap: .6rem; }
.luma-pill-list a { display: inline-flex; padding: .45rem .75rem; border: 1px solid var(--border); border-radius: 999px; background: var(--surface); color: var(--foreground); text-decoration: none; font-size: .875rem; }
.luma-roadmap-item { margin: 1.25rem 0; }
.luma-roadmap-item h2 { margin-top: 0; }
.luma-stat-grid > div { border: 1px solid var(--border); background: var(--card); border-radius: 1rem; padding: 1.25rem; }
.luma-stat-grid strong { display: block; color: var(--primary); font-size: clamp(1.75rem,3vw,2.6rem); line-height: 1; }
.luma-stat-grid span { display: block; margin-top: .5rem; color: var(--muted-foreground); font-size: .9rem; }
.luma-preview-shell { border-radius: 1rem; background: var(--surface); padding: .75rem; box-shadow: 0 25px 70px -35px rgb(0 0 0 / .45); }
.luma-lighthouse { position: absolute; left: -1rem; bottom: -1rem; display: none; align-items: center; gap: .75rem; padding: 1rem; border: 1px solid var(--border); border-radius: 1rem; background: var(--background); box-shadow: 0 18px 42px -25px rgb(0 0 0 / .35); }
.luma-lighthouse strong { display: grid; place-items: center; width: 3rem; height: 3rem; border-radius: 999px; background: color-mix(in oklab, var(--success) 12%, transparent); color: var(--success); }
.luma-lighthouse span { font-size: .75rem; font-weight: 700; }
@media (min-width: 900px) { .luma-lighthouse { display: flex; } }
.luma-footer__grid--wide { grid-template-columns: repeat(2,1fr); }
@media (min-width: 900px) { .luma-footer__grid--wide { grid-template-columns: 2fr 1fr 1fr 1fr; } }
@media (max-width: 767px) { .luma-nav__inner { padding: 0 1rem; } .luma-nav__cta .luma-btn { padding: .45rem .75rem; } .luma-h1 { font-size: clamp(2.3rem, 11vw, 3.5rem); } }


/* ===== HR-only complete 1:1 additions ===== */
.luma-beta{border-bottom:1px solid color-mix(in oklab,var(--primary) 30%,var(--border));background:linear-gradient(90deg,color-mix(in oklab,var(--primary) 15%,transparent),color-mix(in oklab,var(--primary) 8%,transparent));}
.luma-beta>div{max-width:1200px;margin:0 auto;padding:.55rem 1.5rem;display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;font-size:.82rem}.luma-beta strong{border-radius:999px;background:color-mix(in oklab,var(--primary) 20%,transparent);color:var(--primary);padding:.2rem .55rem;font:700 10px/1 JetBrains Mono,monospace;text-transform:uppercase;letter-spacing:.12em}.luma-beta span{color:var(--ink)}.luma-beta a{font-weight:700;text-decoration:underline;text-underline-offset:2px}.luma-filterbar{display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin:0 auto 2rem;max-width:820px}.luma-filterbar label{font-weight:700;font-size:.85rem;color:var(--ink)}.luma-filterbar input,.luma-filterbar select,.luma-form input,.luma-form select,.luma-form textarea{width:100%;margin-top:.35rem;border:1px solid var(--border);border-radius:.75rem;background:var(--card);padding:.85rem 1rem;font:inherit;color:var(--foreground)}.luma-theme-thumb{border:1px solid var(--border);border-radius:1rem;background:var(--surface);overflow:hidden;margin-bottom:1rem}.luma-theme-thumb__bar{height:1.75rem;border-bottom:1px solid var(--border);background:var(--background);display:flex;gap:.25rem;align-items:center;padding:0 .75rem}.luma-theme-thumb__bar span{width:.45rem;height:.45rem;border-radius:999px;background:#cbd5e1}.luma-theme-thumb__body{height:9rem;padding:1rem;display:grid;gap:.65rem;grid-template-columns:repeat(3,1fr);align-content:start}.luma-theme-thumb__body i,.luma-theme-thumb__body b,.luma-theme-thumb__body em,.luma-theme-thumb__body strong{display:block;border-radius:.55rem;background:#e2e8f0;min-height:2rem}.luma-theme-thumb__body i{background:var(--theme-accent);grid-column:1/-1;height:2.5rem}.luma-theme-thumb--portfolio .luma-theme-thumb__body,.luma-theme-thumb--magazine .luma-theme-thumb__body{grid-template-columns:repeat(2,1fr)}.luma-theme-thumb--docs .luma-theme-thumb__body{grid-template-columns:1fr 2fr}.luma-theme-card,.luma-plugin-card{display:flex;flex-direction:column}.luma-theme-card .luma-card-actions,.luma-plugin-card .luma-card-actions{margin-top:auto}.luma-check-grid{display:grid;gap:.75rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.luma-check-grid label{display:flex;gap:.6rem;align-items:center;border:1px solid var(--border);background:var(--card);border-radius:.85rem;padding:.85rem 1rem;font-weight:600}.luma-signup-grid{display:grid;gap:2rem;grid-template-columns:1fr}@media(min-width:960px){.luma-signup-grid{grid-template-columns:.85fr 1.15fr}}.luma-signup-plans{display:grid;gap:1rem}.luma-mini-plan{border:1px solid var(--border);background:var(--card);border-radius:1rem;padding:1rem}.luma-mini-plan.is-featured{border-color:color-mix(in oklab,var(--primary) 55%,var(--border));box-shadow:0 18px 40px -30px var(--primary)}.luma-mini-plan h3{margin:0}.luma-mini-plan strong{display:inline-block;margin:.4rem .25rem .4rem 0;font-size:1.5rem}.luma-form{border:1px solid var(--border);background:var(--card);border-radius:1.25rem;padding:1.5rem;display:grid;gap:1rem}.luma-form label{font-weight:700}.luma-form small{font-weight:500;color:var(--muted-foreground)}.luma-demo-frame{border:1px solid var(--border);border-radius:1.5rem;background:var(--card);box-shadow:0 24px 70px -40px rgb(0 0 0 / .45);overflow:hidden}.luma-demo-frame header{display:flex;justify-content:space-between;gap:1rem;align-items:center;border-bottom:1px solid var(--border);padding:1rem 1.25rem;background:var(--surface)}.luma-demo-frame header span{font-weight:800;color:var(--theme-accent)}.luma-demo-frame nav{display:flex;gap:1rem;flex-wrap:wrap;font-size:.85rem;color:var(--muted-foreground)}.luma-demo-frame section{padding:3rem 1.5rem;background:linear-gradient(135deg,color-mix(in oklab,var(--theme-accent) 12%,transparent),transparent)}.luma-demo-frame section h2{font-size:clamp(2rem,5vw,4rem);line-height:1.05;max-width:850px}.luma-demo-frame section p{max-width:760px}.luma-demo-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;padding:1.5rem}.luma-demo-grid article{height:9rem;border-radius:1rem;background:linear-gradient(135deg,var(--theme-accent),#e2e8f0)}.luma-cookie{position:fixed;z-index:80;left:1rem;right:1rem;bottom:1rem;max-width:520px;border:1px solid var(--border);border-radius:1rem;background:color-mix(in oklab,var(--background) 96%,transparent);box-shadow:0 25px 70px -35px rgb(0 0 0 / .5);backdrop-filter:blur(10px);padding:1rem;display:flex;gap:1rem;align-items:flex-start}.luma-cookie[hidden]{display:none}.luma-cookie p{margin:.25rem 0;color:var(--muted-foreground);font-size:.85rem}.luma-cookie a{color:var(--primary);font-weight:700}.luma-cookie__actions{margin-left:auto;display:flex;gap:.5rem;flex-wrap:wrap}.luma-cookie button{border:1px solid var(--border);border-radius:999px;padding:.55rem .85rem;background:var(--card);font-weight:700;cursor:pointer}.luma-cookie button[data-consent="all"]{background:var(--primary);color:var(--primary-foreground);border-color:var(--primary)}

/* --------------------------------------------------------------------------
   Shared-hosting contrast compatibility patch
   Keeps the Luma visual system 1:1, but guarantees readable button text on
   browsers/hosting previews that do not fully support oklch() or color-mix().
---------------------------------------------------------------------------- */
@supports not (color: oklch(0.55 0.24 295)) {
  :root {
    --background: #fdfbff;
    --foreground: #241b2f;
    --card: #ffffff;
    --card-foreground: #241b2f;
    --primary: #7c3aed;
    --primary-foreground: #ffffff;
    --primary-dark: #6d28d9;
    --muted: #f6f2ff;
    --muted-foreground: #665f73;
    --accent: #f1eafe;
    --accent-foreground: #6d28d9;
    --border: #e8ddfb;
    --surface: #f8f4ff;
    --ink: #1f172a;
    --ink-soft: #5a5265;
    --success: #16a34a;
    --gradient-primary: linear-gradient(135deg, #7c3aed, #d946ef);
    --shadow-elegant: 0 10px 30px -10px rgba(124, 58, 237, .32);
  }
}

@supports not (background: color-mix(in oklab, white 50%, black)) {
  .luma-nav { background: rgba(253, 251, 255, .92); }
  .luma-wordmark__dot { box-shadow: 0 0 0 8px rgba(124, 58, 237, .16); }
  .luma-eyebrow { background: #f1eafe; }
  .luma-card,
  .luma-catalog-card,
  .luma-price-card,
  .luma-roadmap-item { box-shadow: 0 16px 40px -28px rgba(124, 58, 237, .32); }
  .luma-card:hover,
  .luma-catalog-card:hover,
  .luma-price-card:hover { border-color: #c4b5fd; }
  .luma-cookie { background: rgba(253, 251, 255, .98); }
  .luma-beta { background: linear-gradient(90deg, rgba(124, 58, 237, .13), rgba(124, 58, 237, .06)); }
  .luma-beta strong { background: #ede9fe; }
  .luma-demo-frame section { background: linear-gradient(135deg, rgba(124, 58, 237, .10), transparent); }
}

.luma-btn,
.luma-btn:link,
.luma-btn:visited,
.luma-btn:hover,
.luma-btn:focus,
.luma-btn:active {
  text-decoration: none;
  line-height: 1.15;
  white-space: nowrap;
}

.luma-btn *,
.luma-cookie button * {
  color: inherit;
}

.luma-btn--primary,
a.luma-btn--primary:link,
a.luma-btn--primary:visited,
button.luma-btn--primary,
input.luma-btn--primary {
  background: #7c3aed;
  border-color: #7c3aed;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff;
  text-shadow: 0 1px 1px rgba(31, 23, 42, .18);
}

.luma-btn--primary:hover,
a.luma-btn--primary:hover,
button.luma-btn--primary:hover,
input.luma-btn--primary:hover,
.luma-btn--primary:focus-visible {
  background: #6d28d9;
  border-color: #6d28d9;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff;
}

.luma-btn--ghost,
a.luma-btn--ghost:link,
a.luma-btn--ghost:visited,
button.luma-btn--ghost,
input.luma-btn--ghost {
  background: rgba(255, 255, 255, .92);
  border-color: #e8ddfb;
  color: #241b2f !important;
  -webkit-text-fill-color: #241b2f;
}

.luma-btn--ghost:hover,
a.luma-btn--ghost:hover,
button.luma-btn--ghost:hover,
input.luma-btn--ghost:hover,
.luma-btn--ghost:focus-visible {
  background: #f8f4ff;
  border-color: #c4b5fd;
  color: #1f172a !important;
  -webkit-text-fill-color: #1f172a;
}

.luma-price-card.is-featured .luma-btn--primary,
.luma-hero .luma-btn--primary,
.luma-nav__cta .luma-btn--primary,
.luma-card-actions .luma-btn--primary {
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff;
}

.luma-cookie button {
  background: #ffffff;
  border-color: #e8ddfb;
  color: #241b2f !important;
  -webkit-text-fill-color: #241b2f;
}

.luma-cookie button:hover,
.luma-cookie button:focus-visible {
  background: #f8f4ff;
  border-color: #c4b5fd;
  color: #1f172a !important;
  -webkit-text-fill-color: #1f172a;
}

.luma-cookie button[data-consent="all"] {
  background: #7c3aed;
  border-color: #7c3aed;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff;
}

.luma-cookie button[data-consent="all"]:hover,
.luma-cookie button[data-consent="all"]:focus-visible {
  background: #6d28d9;
  border-color: #6d28d9;
  color: #ffffff !important;
  -webkit-text-fill-color: #ffffff;
}

