/* ============================================================
   Lexicore landing — Linear/Vercel-inspired premium dark.
   Crimson accent, subtle gradients, bento grid, mono accents.
   ============================================================ */

:root {
  /* surfaces */
  --bg:           #0a0b0f;
  --bg-elev:      #0e1018;
  --bg-card:      #11141d;
  --bg-card-hi:   #161a25;
  --border:       #1d2230;
  --border-strong:#2b3346;
  /* text */
  --text:         #f1f3f8;
  --text-dim:     #a6adbe;
  --text-mute:    #6c7488;
  /* accent (crimson) */
  --accent:       #d63b2e;
  --accent-hot:   #ec5444;
  --accent-soft:  rgba(214, 59, 46, 0.12);
  --accent-glow:  rgba(236, 84, 68, 0.35);
  /* misc */
  --radius:       12px;
  --radius-lg:    18px;
  --font:         "Inter", system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
  --font-mono:    "JetBrains Mono", ui-monospace, Consolas, monospace;
  --max:          1200px;
  --max-narrow:   720px;
  --shadow-card:  0 1px 0 rgba(255,255,255,0.04) inset, 0 12px 28px rgba(0,0,0,0.3);
}

*, *::before, *::after { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: var(--font);
  font-size: 16px;
  line-height: 1.55;
  -webkit-font-smoothing: antialiased;
  text-rendering: optimizeLegibility;
}
img { max-width: 100%; height: auto; display: block; }
a { color: var(--accent-hot); text-decoration: none; transition: color 0.15s; }
a:hover { color: var(--text); }
code, .mono {
  font-family: var(--font-mono);
  font-size: 0.88em;
  padding: 0.1em 0.4em;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 5px;
  color: var(--text);
}
strong { font-weight: 600; }

/* ============ NAV ============ */
.topbar {
  position: sticky; top: 0; z-index: 50;
  background: rgba(10, 11, 15, 0.75);
  backdrop-filter: blur(14px) saturate(140%);
  -webkit-backdrop-filter: blur(14px) saturate(140%);
  border-bottom: 1px solid var(--border);
}
.topbar-inner {
  max-width: var(--max);
  margin: 0 auto;
  padding: 14px 24px;
  display: flex; align-items: center; justify-content: space-between;
}
.brand {
  display: inline-flex; align-items: center; gap: 10px;
  color: var(--text); font-weight: 600;
  font-size: 0.98rem;
  letter-spacing: -0.1px;
}
.nav { display: flex; align-items: center; gap: 26px; }
/* Support-Button verlässt den nav-flow und sitzt absolut am rechten
   Viewport-Rand. Der Rest der Topbar bleibt im zentrierten 1200px-Container. */
.nav-support {
  position: absolute;
  right: 24px;
  top: 50%;
  transform: translateY(-50%);
}
.nav a {
  color: var(--text-dim);
  font-weight: 500;
  font-size: 0.92rem;
}
.nav a:hover { color: var(--text); }

/* nav action buttons — Download (primary) + Support (heart) */
.nav-cta, .nav-support {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 13px;
  border-radius: 8px;
  font-size: 0.85rem;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid transparent;
  white-space: nowrap;
  transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.12s;
}
.nav-cta {
  background: var(--accent-soft);
  color: var(--accent-hot);
  border-color: rgba(214, 59, 46, 0.45);
}
.nav-cta:hover {
  background: var(--accent);
  color: #fff;
  border-color: var(--accent);
  transform: translateY(-1px);
}
.nav-cta-current {
  background: transparent;
  color: var(--text-dim);
  border-color: var(--border-strong);
  pointer-events: none;
}
.nav-cta-current:hover {
  background: transparent;
  color: var(--text-dim);
  border-color: var(--border-strong);
  transform: none;
}

.nav-support {
  background: transparent;
  color: var(--text-dim);
  border-color: var(--border-strong);
}
.nav-support svg { color: #ec5b8b; transition: transform 0.15s; }
.nav-support:hover {
  color: var(--text);
  border-color: #ec5b8b;
}
.nav-support:hover svg { transform: scale(1.15); }

.lang-switch {
  display: inline-flex;
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  overflow: hidden;
  padding: 2px;
  margin-left: 8px;
}
.lang-switch button {
  background: transparent;
  border: 0;
  color: var(--text-dim);
  padding: 4px 10px;
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  letter-spacing: 0.5px;
  border-radius: 999px;
}
.lang-switch button.active {
  background: var(--accent);
  color: #fff;
}
.lang-switch button:hover:not(.active) { color: var(--text); }

/* ============ HERO ============ */
.hero {
  position: relative;
  padding: 90px 24px 110px;
  overflow: hidden;
}
.hero-bg {
  position: absolute; inset: 0;
  pointer-events: none;
  z-index: 0;
}
.hero-grid {
  position: absolute; inset: 0;
  background-image:
    linear-gradient(rgba(255, 255, 255, 0.025) 1px, transparent 1px),
    linear-gradient(90deg, rgba(255, 255, 255, 0.025) 1px, transparent 1px);
  background-size: 56px 56px;
  mask-image: radial-gradient(ellipse at 50% 0%, black 30%, transparent 75%);
  -webkit-mask-image: radial-gradient(ellipse at 50% 0%, black 30%, transparent 75%);
}
.hero-glow {
  position: absolute;
  top: -260px;
  left: 50%;
  transform: translateX(-50%);
  width: 1100px; height: 700px;
  background: radial-gradient(ellipse at center, var(--accent-glow) 0%, transparent 62%);
  filter: blur(40px);
  opacity: 0.55;
}

.hero-inner {
  position: relative;
  z-index: 1;
  max-width: var(--max);
  margin: 0 auto;
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 56px;
  align-items: center;
}
.hero-text { max-width: 540px; }

.badge {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 6px 12px 6px 10px;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 500;
  color: var(--text-dim);
  margin-bottom: 26px;
  transition: border-color 0.15s, color 0.15s;
}
.badge:hover { border-color: var(--accent); color: var(--text); }
.badge-dot {
  width: 6px; height: 6px;
  background: var(--accent-hot);
  border-radius: 50%;
  box-shadow: 0 0 0 3px var(--accent-soft);
  animation: pulse 2.5s ease-in-out infinite;
}
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%      { opacity: 0.4; }
}
.badge-version {
  font-family: var(--font-mono);
  color: var(--text);
  font-weight: 600;
}

.hero h1 {
  font-size: clamp(2.1rem, 4.8vw, 3.6rem);
  line-height: 1.05;
  letter-spacing: -1.5px;
  margin: 0 0 22px;
  font-weight: 700;
}
.hero h1 .accent {
  background: linear-gradient(135deg, var(--accent-hot), var(--accent));
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.hero-sub {
  font-size: 1.12rem;
  color: var(--text-dim);
  margin: 0 0 32px;
  max-width: 480px;
}

.cta-row {
  display: flex; gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 36px;
}
.btn {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 12px 20px;
  border-radius: var(--radius);
  font-weight: 600;
  font-size: 0.95rem;
  cursor: pointer;
  border: 1px solid transparent;
  transition: transform 0.12s, background 0.15s, border-color 0.15s, color 0.15s, box-shadow 0.2s;
  text-decoration: none;
}
.btn-primary {
  background: var(--accent);
  color: #fff;
  box-shadow: 0 8px 24px -8px var(--accent-glow);
}
.btn-primary:hover {
  background: var(--accent-hot);
  color: #fff;
  transform: translateY(-1px);
  box-shadow: 0 12px 32px -8px var(--accent-glow);
}
.btn-ghost {
  background: var(--bg-card);
  color: var(--text);
  border-color: var(--border-strong);
}
.btn-ghost:hover {
  border-color: var(--accent);
}

.hero-trust {
  list-style: none;
  margin: 0; padding: 0;
  display: flex; gap: 36px;
  flex-wrap: wrap;
}
.hero-trust li {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.hero-trust strong {
  color: var(--text);
  font-size: 0.95rem;
  font-weight: 600;
}
.hero-trust span {
  color: var(--text-mute);
  font-size: 0.82rem;
}

.hero-visual {
  position: relative;
}
.hero-shot {
  position: relative;
  border-radius: var(--radius-lg);
  overflow: hidden;
  border: 1px solid var(--border-strong);
  background: var(--bg-elev);
  box-shadow:
    0 30px 80px -20px rgba(0, 0, 0, 0.6),
    0 0 60px -20px var(--accent-glow);
  transform: perspective(1500px) rotateY(-3deg) rotateX(2deg);
  transition: transform 0.5s ease;
}
.hero-shot:hover {
  transform: perspective(1500px) rotateY(0deg) rotateX(0deg);
}
.hero-shot::before {
  content: "";
  position: absolute; inset: 0;
  border-radius: var(--radius-lg);
  background: linear-gradient(135deg, rgba(255, 255, 255, 0.06), transparent 40%);
  pointer-events: none;
}
.hero-shot img { display: block; width: 100%; }

/* ============ SECTION BASE ============ */
.section { padding: 100px 24px; position: relative; }
.section-alt {
  background:
    linear-gradient(180deg, transparent, var(--bg-elev) 12%, var(--bg-elev) 88%, transparent),
    var(--bg);
}
.container { max-width: var(--max); margin: 0 auto; }
.container-narrow { max-width: var(--max-narrow); margin: 0 auto; }

.section-head {
  text-align: center;
  max-width: 720px;
  margin: 0 auto 60px;
}
.eyebrow {
  display: inline-block;
  font-size: 0.75rem;
  font-weight: 700;
  letter-spacing: 1.5px;
  text-transform: uppercase;
  color: var(--accent-hot);
  margin: 0 0 14px;
  padding: 5px 12px;
  background: var(--accent-soft);
  border-radius: 999px;
}
.section-head h2 {
  font-size: clamp(1.8rem, 3.6vw, 2.6rem);
  letter-spacing: -0.8px;
  line-height: 1.12;
  margin: 0 0 16px;
  font-weight: 700;
}
.section-lead {
  color: var(--text-dim);
  font-size: 1.05rem;
  margin: 0;
}

/* ============ BENTO GRID ============ */
.bento {
  display: grid;
  grid-template-columns: repeat(12, 1fr);
  gap: 16px;
}
.bento-cell {
  grid-column: span 4;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 28px;
  display: flex;
  flex-direction: column;
  gap: 20px;
  transition: border-color 0.2s, transform 0.2s, background 0.2s;
  box-shadow: var(--shadow-card);
}
.bento-cell:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
  background: var(--bg-card-hi);
}
.bento-lead { grid-column: span 8; }
.bento-wide { grid-column: span 8; }
.bento-tall {
  grid-column: span 4;
  grid-row: span 2;
}

.cell-text h3 {
  font-size: 1.15rem;
  font-weight: 600;
  margin: 0 0 8px;
  letter-spacing: -0.2px;
}
.cell-text p {
  margin: 0;
  color: var(--text-dim);
  font-size: 0.95rem;
}

/* ---- demo: vorher/nachher ---- */
.demo-compare {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 16px;
  align-items: center;
}
.demo-side {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.demo-tag {
  font-size: 0.7rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  padding: 3px 8px;
  border-radius: 4px;
  align-self: flex-start;
}
.demo-tag-mute {
  background: var(--bg-elev);
  color: var(--text-mute);
  border: 1px solid var(--border);
}
.demo-tag-accent {
  background: var(--accent-soft);
  color: var(--accent-hot);
  border: 1px solid var(--accent-soft);
}
.demo-arrow { color: var(--text-mute); }
.demo-code {
  font-family: var(--font-mono);
  font-size: 0.85rem;
  display: flex;
  flex-direction: column;
  gap: 6px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px;
}
.demo-code-dim { color: var(--text-mute); }
.demo-code-inline {
  background: var(--bg-elev);
}
.dc-line em {
  color: var(--accent-hot);
  font-style: normal;
  font-weight: 500;
}
.demo-code-dim .dc-line em { color: var(--text-mute); }

/* ---- demo: missions ---- */
.demo-missions {
  list-style: none;
  margin: 0; padding: 0;
  display: flex;
  flex-direction: column;
  gap: 10px;
  flex: 1;
}
.demo-missions li {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 11px 14px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: 0.92rem;
}
.mission-tag {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 700;
  padding: 2px 6px;
  border-radius: 4px;
  flex-shrink: 0;
}
.mission-tag-fresh   { background: var(--accent-soft); color: var(--accent-hot); }
.mission-tag-partial { background: rgba(245, 158, 11, 0.15); color: #fbbf24; }
.mission-tag-done    { background: rgba(34, 197, 94, 0.15);  color: #4ade80; }

/* ---- demo: pills (channels) ---- */
.demo-pills {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}
.pill {
  font-family: var(--font-mono);
  font-size: 0.78rem;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 5px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  color: var(--text-dim);
}
.pill-live {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-hot);
}

/* ---- demo: swatches (themes) ---- */
.demo-swatches {
  display: flex;
  gap: 10px;
}
.swatch {
  width: 36px; height: 36px;
  border-radius: 10px;
  border: 2px solid var(--border-strong);
  transition: transform 0.15s, border-color 0.15s;
  cursor: default;
}
.swatch:hover { transform: scale(1.1); border-color: var(--accent); }
.sw-dark    { background: linear-gradient(135deg, #1f2740 0%, #283256 100%); border-color: #4a5fbe; }
.sw-light   { background: linear-gradient(135deg, #f0f2f7 0%, #d6dce8 100%); }
.sw-crimson { background: linear-gradient(135deg, #c0392b 0%, #1a0608 100%); border-color: #d63b2e; }
.sw-ignis   { background: linear-gradient(135deg, #1a0e08 0%, #4a2510 100%); border-color: #e67e22; }
.sw-umbra   { background: linear-gradient(135deg, #14122a 0%, #2a1f5e 100%); border-color: #8a5cf7; }

/* ---- demo: watcher status ---- */
.demo-watcher {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-family: var(--font-mono);
  font-size: 0.85rem;
  color: var(--text-dim);
}
.dw-dot {
  width: 10px; height: 10px;
  background: #4ade80;
  border-radius: 50%;
  box-shadow: 0 0 0 4px rgba(74, 222, 128, 0.18);
  animation: pulse 2s ease-in-out infinite;
}

/* ---- demo: update ---- */
.demo-update {
  display: flex;
  align-items: center;
  gap: 12px;
}
.du-tag {
  font-family: var(--font-mono);
  font-weight: 600;
  font-size: 0.85rem;
  padding: 6px 12px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: 6px;
  color: var(--text-dim);
}
.du-tag-new {
  background: var(--accent-soft);
  border-color: var(--accent);
  color: var(--accent-hot);
}
.du-arrow { color: var(--text-mute); }

/* ---- demo: stepper ---- */
.demo-stepper {
  display: flex;
  align-items: center;
  gap: 6px;
}
.step-dot {
  width: 14px; height: 14px;
  border-radius: 50%;
  background: var(--bg-elev);
  border: 2px solid var(--border-strong);
}
.step-dot.step-active {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-soft);
}
.step-line {
  flex: 1;
  height: 2px;
  background: var(--border-strong);
  border-radius: 1px;
}

/* ============ SCREENSHOTS ============ */
.tabs {
  display: inline-flex;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  border-radius: 999px;
  padding: 4px;
  margin-top: 20px;
}
.tab {
  background: transparent;
  border: 0;
  padding: 8px 18px;
  font-size: 0.9rem;
  font-weight: 600;
  color: var(--text-dim);
  border-radius: 999px;
  cursor: pointer;
  transition: color 0.15s, background 0.15s;
}
.tab:hover { color: var(--text); }
.tab.active {
  background: var(--accent);
  color: #fff;
}

.tab-panel { display: none; }
.tab-panel.active { display: block; }

.shot-hero {
  margin: 0 0 16px;
}
.shot-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 16px;
}
.shot {
  margin: 0;
  border-radius: var(--radius);
  overflow: hidden;
  border: 1px solid var(--border);
  background: var(--bg-card);
  box-shadow: var(--shadow-card);
  transition: border-color 0.15s, transform 0.15s;
}
.shot:hover {
  border-color: var(--border-strong);
  transform: translateY(-2px);
}
.shot img { display: block; width: 100%; cursor: zoom-in; }
.shot figcaption {
  padding: 12px 16px;
  font-size: 0.85rem;
  color: var(--text-dim);
  border-top: 1px solid var(--border);
  background: var(--bg-elev);
}

/* ============ LIGHTBOX ============ */
.lightbox {
  position: fixed; inset: 0;
  z-index: 100;
  background: rgba(5, 6, 10, 0.94);
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
  display: none;
  align-items: center;
  justify-content: center;
  padding: 60px 80px;
  opacity: 0;
  transition: opacity 0.18s ease;
}
.lightbox.open {
  display: flex;
  opacity: 1;
}
.lightbox-figure {
  margin: 0;
  display: flex;
  flex-direction: column;
  gap: 12px;
  align-items: center;
  max-width: 100%;
  max-height: 100%;
}
.lightbox-figure img {
  max-width: min(1400px, 90vw);
  max-height: 80vh;
  width: auto;
  height: auto;
  border-radius: var(--radius);
  border: 1px solid var(--border-strong);
  background: var(--bg-card);
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.7);
}
.lightbox-figure figcaption {
  color: var(--text-dim);
  font-size: 0.92rem;
  text-align: center;
  max-width: 720px;
}
.lightbox-figure figcaption:empty { display: none; }

.lightbox-close {
  position: absolute;
  top: 22px; right: 22px;
  width: 44px; height: 44px;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  color: var(--text);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
}
.lightbox-close:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.lightbox-nav {
  position: absolute;
  top: 50%;
  transform: translateY(-50%);
  width: 56px; height: 56px;
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  color: var(--text);
  border-radius: 50%;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: background 0.15s, border-color 0.15s, color 0.15s, transform 0.15s;
  z-index: 1;
}
.lightbox-nav:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.lightbox-prev { left: 22px; }
.lightbox-next { right: 22px; }
.lightbox-prev:hover { transform: translateY(-50%) translateX(-3px); }
.lightbox-next:hover { transform: translateY(-50%) translateX(3px); }
.lightbox-nav[hidden] { display: none; }

.lightbox-counter {
  position: absolute;
  bottom: 22px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--bg-card);
  border: 1px solid var(--border-strong);
  color: var(--text-dim);
  padding: 6px 14px;
  border-radius: 999px;
  font-family: var(--font-mono);
  font-size: 0.82rem;
  font-weight: 600;
}

@media (max-width: 720px) {
  .lightbox { padding: 50px 12px; }
  .lightbox-figure img { max-height: 70vh; }
  .lightbox-nav { width: 44px; height: 44px; }
  .lightbox-prev { left: 10px; }
  .lightbox-next { right: 10px; }
  .lightbox-close { top: 14px; right: 14px; width: 38px; height: 38px; }
}

body.lb-open { overflow: hidden; }

/* ============ INSTALL ============ */
.install-steps {
  counter-reset: step;
  list-style: none;
  padding: 0;
  margin: 0 0 32px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}
.install-steps li {
  position: relative;
  padding: 18px 20px 18px 64px;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-dim);
  font-size: 0.98rem;
  line-height: 1.5;
}
.install-steps li::before {
  counter-increment: step;
  content: counter(step);
  position: absolute;
  left: 20px; top: 50%;
  transform: translateY(-50%);
  width: 30px; height: 30px;
  background: var(--accent);
  color: #fff;
  border-radius: 8px;
  display: flex; align-items: center; justify-content: center;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.9rem;
}
.disclaimer {
  text-align: center;
  color: var(--text-mute);
  font-size: 0.85rem;
  margin: 0;
}

/* ============ FOOTER ============ */
.footer {
  border-top: 1px solid var(--border);
  padding: 50px 24px 36px;
}
.footer-inner {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 22px;
  text-align: center;
}
.footer-brand {
  display: flex;
  align-items: center;
  gap: 12px;
}
.footer-brand div {
  display: flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 1px;
  line-height: 1.3;
}
.footer-brand strong {
  font-weight: 600;
  font-size: 1rem;
}
.footer-brand .muted {
  font-size: 0.82rem;
  color: var(--text-mute);
}
.muted { color: var(--text-mute); font-size: 0.88rem; }
.footer-links {
  display: flex; gap: 22px;
  flex-wrap: wrap; justify-content: center;
}
.footer-links a {
  color: var(--text-dim);
  font-size: 0.92rem;
  font-weight: 500;
}
.footer-links a:hover { color: var(--text); }
.footer-credits {
  margin-top: 8px;
  font-size: 0.82rem;
}

/* ============ LEGAL PAGES (Impressum, Datenschutz) ============ */
.legal {
  padding: 70px 24px 90px;
}
.legal h1 {
  font-size: clamp(1.8rem, 3.6vw, 2.4rem);
  letter-spacing: -0.6px;
  margin: 8px 0 14px;
  font-weight: 700;
}
.legal h2 {
  font-size: 1.2rem;
  margin: 36px 0 12px;
  font-weight: 600;
  letter-spacing: -0.2px;
  color: var(--text);
}
.legal h3 {
  font-size: 1rem;
  margin: 24px 0 10px;
  font-weight: 600;
  color: var(--text);
}
.legal p, .legal ul {
  margin: 0 0 14px;
  color: var(--text-dim);
  font-size: 0.96rem;
  line-height: 1.65;
}
.legal ul { padding-left: 22px; }
.legal ul li { margin-bottom: 4px; }
.legal a { color: var(--accent-hot); }
.legal a:hover { color: var(--text); }
.legal .muted { font-size: 0.9rem; margin-bottom: 32px; }
.legal-back {
  margin-top: 50px;
  padding-top: 24px;
  border-top: 1px solid var(--border);
  font-size: 0.95rem;
}

.footer-legal {
  font-size: 0.82rem;
  opacity: 0.85;
}
.footer-legal a { color: var(--text-mute); }
.footer-legal a:hover { color: var(--text); }

/* ============ DOWNLOAD PAGE ============ */
.dl-page { padding: 70px 24px 90px; }
/* Page-spezifischer Container: breiter als container-narrow (720) aber
   nicht so weit wie der Index-Container (1200) — sweet spot für eine
   Download-Page mit File-Meta-Card. */
.dl-container { max-width: 960px; margin: 0 auto; }
.dl-page h1 {
  font-size: clamp(2rem, 4vw, 2.8rem);
  letter-spacing: -1px;
  margin: 6px 0 14px;
  font-weight: 700;
}
.dl-intro {
  color: var(--text-dim);
  font-size: 1.08rem;
  margin: 0 0 44px;
  max-width: 680px;
  line-height: 1.6;
}

/* file meta card */
.dl-card {
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 36px 40px;
  box-shadow: var(--shadow-card);
  margin-bottom: 60px;
}
.dl-card-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 20px;
  flex-wrap: wrap;
  margin-bottom: 28px;
}
.dl-filename {
  font-size: 1.05rem;
  color: var(--text);
  margin: 0 0 6px;
  word-break: break-all;
}
.dl-version-line {
  margin: 0;
  color: var(--text-dim);
  font-size: 0.9rem;
}
.dl-version { color: var(--text); font-weight: 600; }
.dl-sep { margin: 0 6px; color: var(--text-mute); }

.vt-badge {
  display: inline-flex;
  align-items: center;
  gap: 7px;
  padding: 7px 12px;
  background: rgba(58, 192, 88, 0.12);
  border: 1px solid rgba(58, 192, 88, 0.35);
  color: #5cd47b;
  border-radius: 999px;
  font-size: 0.82rem;
  font-weight: 600;
  text-decoration: none;
}
.vt-badge:hover {
  background: rgba(58, 192, 88, 0.2);
  color: #fff;
}

.dl-meta {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(200px, 1fr));
  gap: 0;
  margin: 0 0 28px;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--bg-elev);
}
.dl-meta > div {
  padding: 18px 22px;
  border-right: 1px solid var(--border);
}
.dl-meta > div:last-child { border-right: 0; }
.dl-meta dt {
  font-size: 0.72rem;
  font-weight: 700;
  letter-spacing: 1px;
  text-transform: uppercase;
  color: var(--text-mute);
  margin: 0 0 4px;
}
.dl-meta dd {
  margin: 0;
  font-size: 0.92rem;
  color: var(--text);
}
.dl-sha {
  font-size: 0.75rem;
  word-break: break-all;
  line-height: 1.4;
  color: var(--text-dim);
}

/* eula gate */
.eula-gate {
  display: flex;
  flex-direction: column;
  gap: 18px;
  padding-top: 22px;
  border-top: 1px solid var(--border);
}
.eula-check {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  cursor: pointer;
  user-select: none;
}
.eula-check input { position: absolute; opacity: 0; pointer-events: none; }
.eula-box {
  flex-shrink: 0;
  width: 22px; height: 22px;
  border-radius: 6px;
  border: 1.5px solid var(--border-strong);
  background: var(--bg-elev);
  display: flex;
  align-items: center;
  justify-content: center;
  color: transparent;
  transition: background 0.15s, border-color 0.15s, color 0.15s;
  margin-top: 1px;
}
.eula-box svg { width: 14px; height: 14px; }
.eula-check input:checked + .eula-box {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}
.eula-check input:focus-visible + .eula-box {
  box-shadow: 0 0 0 3px var(--accent-soft);
}
.eula-label {
  color: var(--text-dim);
  font-size: 0.95rem;
  line-height: 1.5;
}
.eula-label a { color: var(--accent-hot); }

.dl-btn {
  justify-content: center;
  padding: 14px 22px;
  font-size: 1rem;
}
.dl-btn[aria-disabled="true"] {
  background: var(--bg-elev);
  color: var(--text-mute);
  border: 1px solid var(--border);
  box-shadow: none;
  cursor: not-allowed;
  pointer-events: none;
}

.dl-hint {
  color: var(--text-mute);
  font-size: 0.85rem;
  margin: 14px 0 0;
  text-align: center;
}

/* dl sections */
.dl-section {
  margin-top: 64px;
}
.dl-section h2 {
  font-size: 1.4rem;
  font-weight: 600;
  letter-spacing: -0.3px;
  margin: 0 0 16px;
}
.dl-section p {
  color: var(--text-dim);
  font-size: 0.98rem;
  line-height: 1.65;
  margin: 0 0 16px;
  max-width: 760px;
}
.dl-section-lead {
  color: var(--text-dim);
  font-size: 0.92rem;
  margin: 0 0 16px;
}
.dl-section .dim {
  color: var(--text-mute);
  font-size: 0.88rem;
}
.dl-callout {
  background: var(--accent-soft);
  border-left: 3px solid var(--accent);
  border-radius: 6px;
  padding: 12px 16px;
  margin: 16px 0 0 !important;
  color: var(--text) !important;
  font-size: 0.92rem !important;
}

.step-list {
  list-style: none;
  counter-reset: dlstep;
  padding: 0;
  margin: 0 0 16px;
  max-width: 760px;
}
.step-list li {
  position: relative;
  padding: 14px 18px 14px 52px;
  margin-bottom: 10px;
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text-dim);
  font-size: 0.96rem;
}
.step-list li::before {
  counter-increment: dlstep;
  content: counter(dlstep);
  position: absolute;
  left: 16px; top: 50%;
  transform: translateY(-50%);
  width: 26px; height: 26px;
  background: var(--accent);
  color: #fff;
  border-radius: 7px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-family: var(--font-mono);
  font-weight: 700;
  font-size: 0.82rem;
}

.code-block {
  background: var(--bg-elev);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 20px;
  margin: 0 0 12px;
  max-width: 760px;
  overflow-x: auto;
  font-family: var(--font-mono);
  font-size: 0.88rem;
  color: var(--text);
}
.code-block code {
  background: transparent;
  border: 0;
  padding: 0;
  font-size: inherit;
  color: inherit;
}

/* alert section */
.dl-section-alert {
  display: flex;
  gap: 18px;
  background: rgba(214, 59, 46, 0.08);
  border: 1px solid rgba(214, 59, 46, 0.3);
  border-radius: var(--radius-lg);
  padding: 26px 30px;
  margin-top: 64px;
}
.dl-section-alert h2 { margin: 0 0 8px; font-size: 1.15rem; }
.dl-section-alert p { margin: 0; font-size: 0.95rem; max-width: none; }
.alert-icon {
  color: var(--accent-hot);
  flex-shrink: 0;
  padding-top: 1px;
}

/* EULA — scrollable container (kompakte Höhe, eigener Scroll). */
.eula-body {
  position: relative;
  background: var(--bg-card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 24px 28px;
  font-size: 0.92rem;
  line-height: 1.65;
  color: var(--text-dim);
  max-height: 380px;
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--border-strong) transparent;
}
/* Webkit (Chrome/Edge/Safari) custom scrollbar */
.eula-body::-webkit-scrollbar { width: 10px; }
.eula-body::-webkit-scrollbar-track { background: transparent; }
.eula-body::-webkit-scrollbar-thumb {
  background: var(--border-strong);
  border-radius: 999px;
  border: 2px solid var(--bg-card);
}
.eula-body::-webkit-scrollbar-thumb:hover { background: var(--accent); }
.eula-body h1, .eula-body h2, .eula-body h3 {
  color: var(--text);
  font-weight: 600;
  letter-spacing: -0.2px;
}
.eula-body h1 { font-size: 1.3rem; margin: 28px 0 12px; }
.eula-body h1:first-child { margin-top: 0; }
.eula-body h2 { font-size: 1.1rem; margin: 24px 0 10px; }
.eula-body h3 { font-size: 1rem;   margin: 18px 0 8px; }
.eula-body p { margin: 0 0 12px; max-width: none; }
.eula-body ul, .eula-body ol { padding-left: 22px; margin: 0 0 12px; }
.eula-body ul li, .eula-body ol li { margin-bottom: 4px; }
.eula-body a { color: var(--accent-hot); }
.eula-body hr {
  border: 0;
  border-top: 1px solid var(--border);
  margin: 24px 0;
}
.eula-body blockquote {
  border-left: 3px solid var(--accent);
  background: var(--accent-soft);
  margin: 16px 0;
  padding: 10px 16px;
  border-radius: 4px;
  color: var(--text);
  font-size: 0.92rem;
}

/* Download gate section — highlighted, "go" button block */
.dl-gate-section {
  background: var(--bg-card);
  border: 1px solid var(--accent);
  border-radius: var(--radius-lg);
  padding: 32px 36px;
  margin-top: 36px;
  box-shadow: 0 0 0 1px var(--accent-soft), 0 12px 32px -12px var(--accent-glow);
}
.dl-gate-section .eula-gate { border-top: 0; padding-top: 0; }
.dl-gate-section .dl-hint { margin-top: 18px; }

.dl-meta-hint {
  color: var(--text-mute);
  font-size: 0.88rem;
  margin: 0;
  font-style: italic;
}

.dl-changelog {
  text-align: center;
  margin-top: 50px;
  font-size: 0.95rem;
}

/* ============ RESPONSIVE ============ */
@media (max-width: 980px) {
  .hero { padding: 60px 24px 80px; }
  .hero-inner {
    grid-template-columns: 1fr;
    gap: 40px;
  }
  .hero-text { max-width: 100%; }
  .hero-shot {
    transform: perspective(1500px) rotateY(0deg) rotateX(0deg);
  }
  .bento-lead, .bento-wide { grid-column: span 12; }
  .bento-cell { grid-column: span 6; }
  .bento-tall { grid-row: span 1; }
}

@media (max-width: 720px) {
  .topbar-inner { padding: 12px 16px; }
  .nav { gap: 16px; }
  .nav a { font-size: 0.85rem; }
  .section { padding: 70px 20px; }
  .hero h1 { letter-spacing: -0.8px; }
  .bento { gap: 12px; }
  .bento-cell { grid-column: span 12; padding: 22px; }
  .shot-row { grid-template-columns: 1fr; }
  .cta-row { flex-direction: column; align-items: stretch; }
  .btn { justify-content: center; }
  .hero-trust { gap: 22px; }
  .demo-compare {
    grid-template-columns: 1fr;
  }
  .demo-arrow { transform: rotate(90deg); justify-self: center; }
  /* download page mobile */
  .dl-page { padding: 50px 16px 70px; }
  .dl-card { padding: 24px 20px; }
  .dl-section-alert { padding: 22px 20px; flex-direction: column; gap: 12px; }
  .dl-section h2 { font-size: 1.2rem; }
}

@media (max-width: 720px) {
  /* Support folgt dem schmaleren Topbar-Padding auf Mobile */
  .nav-support { right: 16px; }
}

@media (max-width: 480px) {
  /* Verstecke text-only nav-Links; CTA (Download) bleibt sichtbar. */
  .nav > a:not(.nav-cta) { display: none; }
  /* Support button → nur Icon (Heart spricht für sich) */
  .nav-support span { display: none; }
  .nav-support { padding: 7px 10px; }
}

/* ============ AUTH (login button + profile pill + dropdown) ============ */
.auth-slot { position: relative; display: inline-flex; align-items: center; }

.auth-login-btn {
  display: inline-flex; align-items: center;
  padding: 6px 14px;
  background: transparent; color: var(--text-dim);
  border: 1px solid var(--border-strong); border-radius: 8px;
  font-size: 0.85rem; font-weight: 500;
  letter-spacing: 0.01em;
  transition: background 0.15s, color 0.15s, border-color 0.15s;
}
.auth-login-btn:hover { color: var(--text); border-color: var(--accent); background: var(--accent-soft); }

/* Premium minimal pill — matches the dim/clean look of the nav links.
   The avatar is a 22px circle with a subtle ring; no chevron, no fill.
   Hover hits the same accent treatment as the rest of the topbar. */
.auth-pill {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 3px 12px 3px 3px;
  background: transparent; color: var(--text-dim);
  border: 1px solid var(--border-strong); border-radius: 999px;
  font-family: inherit; font-size: 0.82rem; font-weight: 500;
  letter-spacing: 0.01em;
  cursor: pointer;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
}
.auth-pill:hover { color: var(--text); border-color: var(--accent); background: var(--accent-soft); }
.auth-pill img {
  width: 22px; height: 22px;
  border-radius: 50% !important;
  display: block;
  object-fit: cover;
  background: var(--bg-elev);
  border: 1px solid var(--border);
}
.auth-pill-name { max-width: 140px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.auth-pill-chev { display: none; }

.auth-menu {
  position: absolute; top: calc(100% + 8px); right: 0;
  min-width: 200px;
  background: var(--bg-card); border: 1px solid var(--border-strong); border-radius: 10px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
  padding: 6px;
  z-index: 60;
  animation: authMenuIn 0.12s ease-out;
}
@keyframes authMenuIn { from { opacity: 0; transform: translateY(-4px); } to { opacity: 1; transform: translateY(0); } }
.auth-menu-item {
  display: block; width: 100%;
  text-align: left;
  background: transparent; color: var(--text); border: 0;
  padding: 9px 12px; border-radius: 6px;
  font-size: 0.9rem; font-family: inherit; font-weight: 500;
  cursor: pointer;
  text-decoration: none;
  transition: background 0.1s;
}
.auth-menu-item:hover { background: var(--bg-card-hi); color: var(--text); }
.auth-menu-item-danger { color: #e26a5e; }
.auth-menu-item-danger:hover { background: rgba(214, 59, 46, 0.12); color: #ec5444; }
.auth-menu-div { height: 1px; background: var(--border); margin: 4px 6px; }

/* On narrow viewports the pill collapses to just the avatar. */
@media (max-width: 480px) {
  .auth-pill-name, .auth-pill-chev { display: none; }
  .auth-pill { padding: 3px; }
}

/* ============ TOAST ============ */
.lex-toast-container {
  position: fixed; top: 80px; right: 20px;
  display: flex; flex-direction: column; gap: 10px;
  z-index: 100;
  pointer-events: none;
}
.lex-toast {
  display: inline-flex; align-items: center; gap: 14px;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: 10px; padding: 12px 14px 12px 16px;
  box-shadow: 0 10px 30px rgba(0,0,0,0.4);
  font-size: 0.9rem;
  pointer-events: auto;
  max-width: 380px;
  animation: lexToastIn 0.22s ease-out;
}
.lex-toast-success { border-left: 3px solid #22c55e; }
.lex-toast-error   { border-left: 3px solid var(--accent); }
.lex-toast-msg     { flex: 1; line-height: 1.4; color: var(--text); }
.lex-toast-close {
  background: transparent; border: 0;
  color: var(--text-mute); cursor: pointer;
  font-size: 1.4rem; line-height: 1;
  padding: 0 4px;
}
.lex-toast-close:hover { color: var(--text); }
.lex-toast-leaving { animation: lexToastOut 0.18s ease-in forwards; }
@keyframes lexToastIn  { from { opacity: 0; transform: translateX(20px); } to { opacity: 1; transform: translateX(0); } }
@keyframes lexToastOut { from { opacity: 1; transform: translateX(0); } to { opacity: 0; transform: translateX(20px); } }

@media (max-width: 480px) {
  .lex-toast-container { top: 70px; right: 12px; left: 12px; }
  .lex-toast { max-width: none; }
}

/* ============ ADMIN ============ */
.admin-shell {
  min-height: 70vh;
  padding: 32px 24px 60px;
  display: grid;
  grid-template-columns: 220px minmax(0, 1fr);
  gap: 28px;
  max-width: 1400px;
  margin: 0 auto;
}
.admin-content { min-width: 0; }
.admin-sidebar {
  position: sticky; top: 24px; align-self: start;
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 14px 10px;
}
.admin-sidebar h2 {
  font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.7px;
  color: var(--text-mute); margin: 4px 12px 10px; font-weight: 600;
}
.admin-sidebar ul { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 2px; }
.admin-sidebar a, .admin-sidebar .stub {
  display: block; padding: 9px 12px;
  border-radius: var(--radius);
  color: var(--text-dim); text-decoration: none; font-size: 0.92rem;
  border-left: 3px solid transparent;
  transition: background 0.12s, color 0.12s, border-color 0.12s;
}
.admin-sidebar a:hover { background: var(--bg-card-hi); color: var(--text); }
.admin-sidebar a.is-active {
  background: var(--accent-soft); color: var(--accent-hot);
  border-left-color: var(--accent); font-weight: 600;
}
.admin-sidebar .stub { color: var(--text-mute); cursor: not-allowed; font-size: 0.85rem; font-style: italic; }
@media (max-width: 820px) {
  .admin-shell { grid-template-columns: 1fr; padding: 16px 12px 40px; gap: 16px; }
  .admin-sidebar { position: static; }
  .admin-sidebar ul { flex-direction: row; flex-wrap: wrap; }
  .admin-sidebar a, .admin-sidebar .stub { border-left: 0; border-bottom: 2px solid transparent; }
  .admin-sidebar a.is-active { border-left-color: transparent; border-bottom-color: var(--accent); }
}

.admin-wrap  { max-width: 720px; margin: 0 auto; }
.admin-wrap-wide { max-width: 1100px; }
.admin-wrap h1 { font-size: 1.8rem; margin: 0 0 8px; letter-spacing: -0.4px; }
.admin-wrap .lead { color: var(--text-dim); margin: 0 0 32px; }
.admin-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 28px; margin-bottom: 20px; }
.admin-card h2 { font-size: 1.1rem; margin: 0 0 16px; font-weight: 600; }
.admin-stub { color: var(--text-dim); font-size: 0.95rem; }
.perm-list { display: flex; flex-wrap: wrap; gap: 6px; margin-top: 12px; }
.perm-chip { font-family: var(--font-mono); font-size: 0.75rem; padding: 3px 10px; background: var(--accent-soft); color: var(--accent-hot); border-radius: 999px; }
.perm-empty { color: var(--text-mute); font-size: 0.85rem; }

.stats-grid {
  display: grid; gap: 12px;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
}
.stat-tile {
  display: flex; flex-direction: column; gap: 4px;
  padding: 18px 16px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
}
.stat-num { font-size: 1.6rem; font-weight: 600; color: var(--text); line-height: 1.1; font-variant-numeric: tabular-nums; }
.stat-lbl { font-size: 0.78rem; color: var(--text-dim); text-transform: uppercase; letter-spacing: 0.5px; }
.stats-error { color: var(--danger, #e74c3c); font-size: 0.9rem; margin: 12px 0 0; }

.version-bars { display: flex; flex-direction: column; gap: 6px; }
.version-row {
  display: grid; grid-template-columns: minmax(70px, auto) 1fr minmax(40px, auto);
  align-items: center; gap: 10px;
}
.version-tag { font-family: var(--font-mono); font-size: 0.82rem; color: var(--text); }
.version-bar { height: 8px; background: var(--bg-elev); border-radius: 999px; overflow: hidden; }
.version-fill { display: block; height: 100%; background: var(--accent); border-radius: 999px; }
.version-num { font-size: 0.82rem; color: var(--text-dim); font-variant-numeric: tabular-nums; text-align: right; }

.admin-nav { list-style: none; padding: 0; margin: 0; display: grid; gap: 10px; }
.admin-nav li { margin: 0; }
.admin-nav a,
.admin-nav-stub {
  display: flex; flex-direction: column; gap: 4px;
  padding: 16px 18px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  color: var(--text); text-decoration: none;
  transition: background 0.12s, border-color 0.12s, transform 0.12s;
}
.admin-nav a:hover { background: var(--bg-card-hi); border-color: var(--accent); transform: translateY(-1px); }
.admin-nav-stub { color: var(--text-mute); cursor: not-allowed; }
.admin-nav-label { font-weight: 600; font-size: 1rem; color: var(--text); }
.admin-nav-stub .admin-nav-label { color: var(--text-dim); }
.admin-nav-desc  { font-size: 0.85rem; color: var(--text-dim); }
.admin-nav-stub .admin-nav-desc { color: var(--text-mute); }

/* User list table */
.userlist-toolbar { display: flex; gap: 12px; align-items: center; margin-bottom: 16px; flex-wrap: wrap; }
.userlist-search {
  flex: 1; min-width: 220px;
  padding: 10px 14px;
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 8px;
  font-family: inherit; font-size: 0.92rem;
}
.userlist-search:focus { outline: none; border-color: var(--accent); background: var(--bg-card-hi); }
.userlist-meta { font-size: 0.82rem; color: var(--text-mute); white-space: nowrap; }

.userlist-table-wrap { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); overflow: hidden; }
.userlist-table { width: 100%; border-collapse: collapse; font-size: 0.9rem; }
.userlist-table th,
.userlist-table td { padding: 12px 14px; text-align: left; vertical-align: middle; }
.userlist-table th {
  background: var(--bg-elev); color: var(--text-dim);
  font-size: 0.72rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  border-bottom: 1px solid var(--border-strong);
}
.userlist-table tbody tr { border-top: 1px solid var(--border); }
.userlist-table tbody tr:hover { background: var(--bg-elev); }

.userlist-user { display: flex; align-items: center; gap: 10px; }
.userlist-user img { width: 32px; height: 32px; border-radius: 50%; border: 1px solid var(--border); }
.userlist-user .nm { font-weight: 500; }
.userlist-user .handle { font-size: 0.78rem; color: var(--text-mute); }
.userlist-id { font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-mute); }
.userlist-roles { display: flex; flex-wrap: wrap; gap: 4px; }
.userlist-role  { font-family: var(--font-mono); font-size: 0.7rem; padding: 2px 8px; background: var(--accent-soft); color: var(--accent-hot); border-radius: 999px; }
.userlist-role-empty { color: var(--text-mute); font-size: 0.78rem; font-style: italic; }
.userlist-date { color: var(--text-dim); font-size: 0.82rem; white-space: nowrap; }

.userlist-empty { padding: 40px 20px; text-align: center; color: var(--text-mute); }
.userlist-loading { padding: 40px 20px; text-align: center; color: var(--text-mute); }

.userlist-pager { display: flex; gap: 10px; align-items: center; justify-content: center; margin-top: 18px; }
.userlist-pager button {
  background: transparent; color: var(--text-dim);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 7px 14px; font-size: 0.85rem; cursor: pointer;
  font-family: inherit;
}
.userlist-pager button:hover:not(:disabled) { color: var(--text); border-color: var(--accent); }
.userlist-pager button:disabled { opacity: 0.4; cursor: not-allowed; }
.userlist-pager .page-info { font-size: 0.82rem; color: var(--text-mute); }

/* Linkable rows in /admin/users/ list */
.userlist-table tbody tr.is-link { cursor: pointer; }
.userlist-table tbody tr.is-link:hover { background: var(--bg-card-hi); }

/* User detail meta (created / last login) */
.user-meta { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 22px; padding-top: 18px; border-top: 1px solid var(--border); }
.user-meta .label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mute); margin-bottom: 4px; }
.user-meta .value { font-size: 0.92rem; color: var(--text); }
@media (max-width: 480px) { .user-meta { grid-template-columns: 1fr; } }

/* Role editor list */
.role-list { display: grid; gap: 10px; margin-top: 14px; }
.role-item {
  display: grid; grid-template-columns: auto 1fr; gap: 14px;
  padding: 14px 16px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}
.role-item:hover { background: var(--bg-card-hi); border-color: var(--border-strong); }
.role-item.is-checked { border-color: var(--accent); background: var(--accent-soft); }
.role-item.is-system { cursor: not-allowed; opacity: 0.78; }
.role-item.is-system:hover { background: var(--bg-elev); border-color: var(--border); }
.role-item input[type=checkbox] { margin-top: 4px; width: 18px; height: 18px; accent-color: var(--accent); }
.role-item input[type=checkbox]:disabled { cursor: not-allowed; }
.role-info { display: flex; flex-direction: column; gap: 4px; }
.role-head { display: flex; align-items: center; gap: 8px; }
.role-name { font-size: 0.95rem; font-weight: 600; color: var(--text); letter-spacing: -0.2px; }
.role-slug { font-family: var(--font-mono); font-size: 0.7rem; color: var(--text-mute); padding: 1px 8px; background: var(--bg-card); border: 1px solid var(--border); border-radius: 999px; }
.role-badge {
  font-size: 0.65rem; font-weight: 600; letter-spacing: 0.04em; text-transform: uppercase;
  padding: 2px 8px; background: rgba(214, 59, 46, 0.18); color: var(--accent-hot);
  border-radius: 999px;
}
.role-desc  { font-size: 0.85rem; color: var(--text-dim); }
.role-perms-label {
  font-size: 0.7rem; font-weight: 600; letter-spacing: 0.06em; text-transform: uppercase;
  color: var(--text-mute); margin-top: 6px;
}
.role-perms { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 4px; }
.perm-pill  {
  display: inline-flex; align-items: center;
  font-size: 0.78rem;
  padding: 2px 9px;
  background: var(--bg-card); border: 1px solid var(--border-strong);
  color: var(--text-dim);
  border-radius: 999px;
  cursor: help;
}
.role-item.is-checked .perm-pill { border-color: rgba(214, 59, 46, 0.35); color: var(--text); }

.role-actions { display: flex; gap: 10px; margin-top: 22px; flex-wrap: wrap; }

/* Per-user permission editor — checkbox grid */
.perm-editor { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; margin-top: 14px; }
@media (max-width: 720px) { .perm-editor { grid-template-columns: 1fr; } }
.perm-item {
  display: grid; grid-template-columns: auto 1fr; gap: 12px;
  padding: 10px 14px;
  background: var(--bg-elev); border: 1px solid var(--border); border-radius: var(--radius);
  cursor: pointer;
  transition: background 0.12s, border-color 0.12s;
}
.perm-item:hover { background: var(--bg-card-hi); border-color: var(--border-strong); }
.perm-item.is-checked { border-color: var(--accent); background: var(--accent-soft); }
.perm-item.is-disabled { cursor: not-allowed; opacity: 0.45; }
.perm-item.is-disabled:hover { background: var(--bg-elev); border-color: var(--border); }
.perm-item input[type=checkbox] { margin-top: 3px; width: 16px; height: 16px; accent-color: var(--accent); }
.perm-item input[type=checkbox]:disabled { cursor: not-allowed; }
.perm-info { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.perm-name { font-size: 0.88rem; color: var(--text); font-weight: 500; }
.perm-code { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-mute); overflow: hidden; text-overflow: ellipsis; }

/* Roles list page */
.role-list-head { display: flex; justify-content: space-between; align-items: flex-end; gap: 16px; margin-bottom: 24px; flex-wrap: wrap; }
.role-list-head h1 { margin: 0 0 6px; }
.role-list-head .lead { margin: 0; }

.role-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); gap: 12px; }
.role-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 18px 20px;
  transition: background 0.12s, border-color 0.12s, transform 0.12s;
}
.role-card.is-link { cursor: pointer; }
.role-card.is-link:hover { background: var(--bg-card-hi); border-color: var(--accent); transform: translateY(-1px); }
.role-card.is-system { border-style: dashed; }
.role-card a, .role-card > div { color: inherit; text-decoration: none; display: flex; flex-direction: column; gap: 8px; }
.role-card-head { display: flex; align-items: center; gap: 8px; }
.role-card-name  { font-family: var(--font-mono); font-weight: 600; color: var(--text); font-size: 0.95rem; }
.role-card-label { font-weight: 600; color: var(--text); font-size: 1rem; letter-spacing: -0.2px; }
.role-card-slug  { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-mute); }
.role-card-desc { font-size: 0.85rem; color: var(--text-dim); }
.role-card-meta { display: flex; gap: 6px; margin-top: 4px; flex-wrap: wrap; }
.meta-chip {
  font-size: 0.72rem;
  padding: 2px 10px;
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  color: var(--text-dim); border-radius: 999px;
}

/* Role-edit form */
.role-form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.role-form-row:last-child { margin-bottom: 0; }
.role-form-label { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mute); font-weight: 600; }
.role-form-input {
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 10px 14px;
  font-family: inherit; font-size: 0.92rem;
  resize: vertical;
}
.role-form-input:focus { outline: none; border-color: var(--accent); background: var(--bg-card-hi); }
.role-form-input:read-only,
.role-form-input:disabled { color: var(--text-mute); background: var(--bg); cursor: not-allowed; }
.role-form-hint { font-size: 0.78rem; color: var(--text-mute); }

/* News admin list */
.newslist-title { font-weight: 500; color: var(--text); }
.newslist-id    { font-family: var(--font-mono); font-size: 0.72rem; color: var(--text-mute); margin-top: 2px; }
.news-cat {
  font-size: 0.72rem; padding: 2px 10px;
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  color: var(--text-dim); border-radius: 999px;
}
.news-form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
@media (max-width: 600px) { .news-form-grid { grid-template-columns: 1fr; } }

/* News editor meta-row: ID + date + category in one line on desktop */
.news-meta-row { display: grid; grid-template-columns: 2fr 1fr 1fr; gap: 14px; }
@media (max-width: 720px) { .news-meta-row { grid-template-columns: 1fr; } }
.role-form-input.mono { font-family: var(--font-mono); font-size: 0.85rem; }

/* Date + Time pair — date picker takes 60% of the row, time the rest.
   Browsers' native date/time controls then each show only their domain,
   so the time picker isn't hidden behind a calendar icon. */
.news-dt-pair { display: grid; grid-template-columns: 1.6fr 1fr; gap: 8px; }
@media (max-width: 480px) { .news-dt-pair { grid-template-columns: 1fr; } }

/* Body editor toolbar */
.news-body-head { display: flex; flex-direction: column; gap: 8px; margin-bottom: 0; }
.news-body-head > .role-form-label { margin-bottom: 2px; }

/* Template controls row above the body toolbar */
.news-body-label-row { display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap; }
.news-tpl-controls { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }
.news-tpl-select { max-width: 220px; font-size: 0.85rem; padding: 7px 12px; }
.btn-tpl-save, .btn-tpl-manage { font-size: 0.82rem; padding: 7px 12px; }
.news-toolbar {
  display: flex; align-items: center; gap: 2px;
  background: var(--bg-elev); border: 1px solid var(--border-strong);
  border-radius: 8px 8px 0 0;
  border-bottom: 0;
  padding: 6px 8px;
  flex-wrap: wrap;
}
/* When toolbar sits directly on top of the editor, drop the editor's
   top-rounded corners + top border so they read as one piece. */
.news-toolbar + .news-editor,
.news-toolbar + .news-editor-code {
  border-top-left-radius: 0; border-top-right-radius: 0;
}
.tbbtn {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 28px; height: 28px;
  background: transparent; color: var(--text-dim);
  border: 0; border-radius: 6px;
  font-family: inherit; font-size: 0.8rem; font-weight: 500;
  cursor: pointer; padding: 0 8px;
  transition: background 0.1s, color 0.1s;
}
.tbbtn:hover { background: var(--bg-card-hi); color: var(--text); }
.tbbtn.is-active { background: var(--accent-soft); color: var(--accent-hot); }
.tbbtn strong, .tbbtn em, .tbbtn u { font-style: inherit; font-weight: inherit; }
.tbbtn strong { font-weight: 700; }
.tbbtn em     { font-style: italic; }
.tbbtn u      { text-decoration: underline; }
.tbsep { width: 1px; height: 18px; background: var(--border); margin: 0 4px; }
.tbsep-grow { width: 100%; height: 0; background: transparent; margin: 0; }
.tbbtn-toggle { color: var(--text); }

/* Contenteditable surface */
.news-editor {
  min-height: 320px;
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 18px 22px;
  font-size: 0.92rem; line-height: 1.55;
  overflow-y: auto;
  resize: vertical;
}
.news-editor:focus { outline: none; border-color: var(--accent); background: var(--bg-card-hi); }
.news-editor h1 { font-size: 1.3rem; margin: 6px 0 8px; color: var(--accent); border-bottom: 1px solid var(--border); padding-bottom: 4px; }
.news-editor h2 { font-size: 1.05rem; margin: 14px 0 4px; }
.news-editor h3 { font-size: 0.95rem; margin: 12px 0 4px; color: var(--text-dim); }
.news-editor p  { margin: 4px 0; }
.news-editor ul, .news-editor ol { margin: 6px 0; padding-left: 20px; }
.news-editor li { margin: 2px 0; }
.news-editor hr { border: 0; border-top: 1px solid var(--border); margin: 18px 0; }
.news-editor code { background: var(--bg-card); padding: 1px 6px; border-radius: 4px; font-family: var(--font-mono); font-size: 0.85em; }
.news-editor a { color: var(--accent-hot); text-decoration: underline; word-break: break-all; }

.news-editor-code {
  min-height: 320px;
  background: var(--bg); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 14px 16px;
  width: 100%;
  font-family: var(--font-mono); font-size: 0.85rem; line-height: 1.55;
  resize: vertical;
}
.news-editor-code:focus { outline: none; border-color: var(--accent); }

/* Color picker popover — App-style swatch grid + native fallback */
.tbcolor-wrap { position: relative; display: inline-flex; }
.tbcolor-dot {
  display: inline-block; width: 14px; height: 14px;
  background: currentColor;
  border-radius: 4px;
  border: 1px solid var(--border-strong);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4) inset;
  vertical-align: middle;
}
.tbcolor-pop {
  position: absolute; top: calc(100% + 8px); left: 0;
  background: var(--bg-card); border: 1px solid var(--border-strong); border-radius: 12px;
  padding: 14px;
  box-shadow: 0 16px 40px rgba(0,0,0,0.5), 0 0 0 1px rgba(255,255,255,0.04) inset;
  z-index: 70;
  width: 252px;
  animation: authMenuIn 0.12s ease-out;
}
.tbcolor-grid {
  display: grid; grid-template-columns: repeat(6, 1fr); gap: 5px;
  margin-bottom: 10px;
}
.tbcolor-sw {
  width: 30px; height: 30px;
  border: 0; border-radius: 7px;
  cursor: pointer; padding: 0;
  position: relative;
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.35) inset,
    0 0 0 1px var(--border) ;
  transition: transform 0.1s ease-out, box-shadow 0.1s;
}
.tbcolor-sw:hover {
  transform: scale(1.12);
  box-shadow:
    0 0 0 1px rgba(0,0,0,0.35) inset,
    0 0 0 2px var(--accent),
    0 4px 12px rgba(0,0,0,0.4);
  z-index: 1;
}
.tbcolor-more {
  display: inline-flex; width: 100%; align-items: center; justify-content: center; gap: 6px;
  background: var(--bg-elev); color: var(--text-dim);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 7px 10px;
  font-family: inherit; font-size: 0.78rem; font-weight: 500;
  cursor: pointer;
  transition: background 0.1s, color 0.1s, border-color 0.1s;
}
.tbcolor-more:hover { background: var(--bg-card-hi); color: var(--text); border-color: var(--accent); }

/* HSV picker: 2-D saturation/value square + hue slider + hex input. */
.tbcolor-pop { width: 280px; }
.tbcolor-sv {
  position: relative;
  height: 140px;
  border-radius: 8px; overflow: hidden;
  cursor: crosshair;
  margin-bottom: 10px;
  user-select: none;
}
.tbcolor-sv-bg { position: absolute; inset: 0; }
.tbcolor-sv-marker, .tbcolor-hue-marker {
  position: absolute;
  width: 14px; height: 14px;
  border: 2px solid #fff; border-radius: 50%;
  transform: translate(-50%, -50%);
  box-shadow: 0 0 0 1px rgba(0,0,0,0.6), 0 1px 4px rgba(0,0,0,0.5);
  pointer-events: none;
  z-index: 1;
}
.tbcolor-hue {
  position: relative;
  height: 14px; border-radius: 7px;
  margin-bottom: 12px;
  cursor: pointer;
  user-select: none;
  background: linear-gradient(to right, #f00, #ff0, #0f0, #0ff, #00f, #f0f, #f00);
}
.tbcolor-hue-marker { top: 50%; }
.tbcolor-hex-row {
  display: flex; gap: 6px; align-items: center;
  margin-bottom: 10px;
}
.tbcolor-preview {
  width: 32px; height: 32px;
  border-radius: 6px;
  border: 1px solid var(--border-strong);
  background: #fff;
  box-shadow: 0 0 0 1px rgba(0,0,0,0.4) inset;
  flex: none;
}
.tbcolor-hex-input {
  flex: 1; min-width: 0;
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 6px;
  padding: 7px 10px;
  font-family: var(--font-mono); font-size: 0.82rem;
  letter-spacing: 0.04em;
}
.tbcolor-hex-input:focus { outline: none; border-color: var(--accent); }
.tbcolor-apply {
  background: var(--accent); color: #fff;
  border: 0; border-radius: 6px;
  padding: 7px 14px;
  font-family: inherit; font-size: 0.82rem; font-weight: 600;
  cursor: pointer;
  transition: background 0.1s;
}
.tbcolor-apply:hover { background: var(--accent-hot); }

/* Resolved checkbox row */
.news-resolved-row {
  margin-top: 12px;
  padding: 14px 16px;
  background: var(--bg-elev);
  border: 1px solid var(--border-strong);
  border-radius: var(--radius);
}
.news-resolved-label {
  display: flex; align-items: center; gap: 10px;
  font-size: 0.92rem; color: var(--text);
  cursor: pointer;
}
.news-resolved-label input[type=checkbox] { width: 18px; height: 18px; accent-color: var(--accent); cursor: pointer; }
.news-resolved-row .role-form-hint { margin-top: 6px; margin-left: 28px; }

/* Action row: draft button left, publish button next — primary draws the
   eye to the destructive/public action. */
.news-actions .btn-ghost#save-draft-btn {
  border-color: rgba(230, 126, 34, 0.45);
  color: #f3a05c;
}
.news-actions .btn-ghost#save-draft-btn:hover {
  background: rgba(230, 126, 34, 0.1);
  border-color: #e67e22;
  color: #f3a05c;
}

/* Inline autosave indicator next to action buttons */
.news-autosave-status {
  font-size: 0.78rem; color: var(--text-mute);
  margin-left: 8px; align-self: center;
  font-style: italic;
}
.news-autosave-status.is-warn { color: #f3a05c; font-style: normal; }

/* Draft badge in the admin news list */
.news-draft-badge {
  display: inline-block;
  margin-left: 8px;
  font-size: 0.65rem; font-weight: 600; letter-spacing: 0.05em; text-transform: uppercase;
  padding: 2px 8px;
  background: rgba(230, 126, 34, 0.18);
  color: #f3a05c;
  border-radius: 999px;
  vertical-align: middle;
}
.userlist-table tr.is-draft { background: rgba(230, 126, 34, 0.04); }
.userlist-table tr.is-draft .newslist-title { color: var(--text-dim); }

/* Link insertion dialog */
.link-dialog-backdrop {
  position: fixed; inset: 0; background: rgba(0,0,0,0.6); z-index: 200;
  animation: lexToastIn 0.15s ease-out;
}
.link-dialog {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%, -50%);
  width: 440px; max-width: calc(100vw - 32px);
  background: var(--bg-card); border: 1px solid var(--border-strong);
  border-radius: var(--radius-lg);
  padding: 24px 26px;
  box-shadow: 0 20px 60px rgba(0,0,0,0.5);
  z-index: 201;
  animation: lexToastIn 0.18s ease-out;
}
.link-dialog h3 { margin: 0 0 18px; font-size: 1.1rem; }
.link-dialog-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 14px; }
.link-dialog-row span { font-size: 0.78rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mute); font-weight: 600; }
.link-dialog-row input {
  background: var(--bg-elev); color: var(--text);
  border: 1px solid var(--border-strong); border-radius: 8px;
  padding: 10px 14px;
  font-family: inherit; font-size: 0.92rem;
}
.link-dialog-row input:focus { outline: none; border-color: var(--accent); }
.link-dialog-actions { display: flex; gap: 10px; justify-content: flex-end; margin-top: 6px; }

.btn-danger-ghost {
  background: transparent; color: #c0392b; border: 1px solid #c0392b;
  padding: 10px 18px; border-radius: var(--radius);
  font-size: 0.92rem; font-weight: 500; cursor: pointer;
  font-family: inherit;
  margin-left: auto; /* push to the right of the action row */
  transition: background 0.15s, color 0.15s;
}
.btn-danger-ghost:hover { background: #c0392b; color: #fff; }

@media (max-width: 640px) {
  .userlist-table th.col-hide-sm,
  .userlist-table td.col-hide-sm { display: none; }
  .userlist-table th, .userlist-table td { padding: 10px 8px; }
}

/* ============ ORGA LIST (/admin/orgas/) ============ */
.orga-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(340px, 1fr)); gap: 16px; margin-top: 4px; }
.orga-card { background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg); padding: 20px 22px; }
.orga-card-header { margin-bottom: 14px; }
.orga-card-title { font-size: 1rem; font-weight: 600; color: var(--text); margin: 0 0 4px; }
.orga-card-meta { font-size: 0.8rem; color: var(--text-mute); }
.orga-member-list { display: flex; flex-direction: column; gap: 8px; }
.orga-member { display: flex; align-items: center; gap: 10px; }
.orga-member img { width: 30px; height: 30px; border-radius: 50%; flex-shrink: 0; }
.orga-member-info { flex: 1; min-width: 0; }
.orga-member-name { font-size: 0.88rem; font-weight: 500; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.orga-member-handle { font-size: 0.78rem; color: var(--text-mute); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.orga-badge { flex-shrink: 0; font-size: 0.7rem; font-weight: 600; padding: 2px 8px; border-radius: 999px; text-transform: uppercase; letter-spacing: 0.04em; }
.orga-badge-main   { background: var(--accent-soft); color: var(--accent-hot); border: 1px solid var(--accent); }
.orga-badge-affil  { background: var(--bg-elev); color: var(--text-mute); border: 1px solid var(--border); }
.orga-empty { color: var(--text-dim); padding: 32px 0; text-align: center; }

/* ============ ACCOUNT PAGE ============ */
.account-shell { min-height: 70vh; padding: 60px 24px; }
.account-wrap  { max-width: 720px; margin: 0 auto; }
.account-wrap h1 { font-size: 1.8rem; margin: 0 0 8px; letter-spacing: -0.4px; }
.account-wrap .lead { color: var(--text-dim); margin: 0 0 32px; }

.account-card {
  background: var(--bg-card); border: 1px solid var(--border); border-radius: var(--radius-lg);
  padding: 28px; margin-bottom: 20px;
}
.account-card h2 { font-size: 1.1rem; margin: 0 0 16px; font-weight: 600; }
.account-card .label { font-size: 0.75rem; text-transform: uppercase; letter-spacing: 0.06em; color: var(--text-mute); margin-bottom: 4px; }
.account-card .value { font-size: 0.95rem; color: var(--text); margin-bottom: 18px; word-break: break-all; }
.account-card .value:last-child { margin-bottom: 0; }
.account-card .value.mono { font-family: var(--font-mono); font-size: 0.85rem; }

.account-head { display: flex; align-items: center; gap: 18px; }
.account-head img {
  width: 64px; height: 64px; border-radius: 50%;
  border: 1px solid var(--border-strong);
}
.account-head .nm     { font-size: 1.2rem; font-weight: 600; line-height: 1.2; }
.account-head .handle { font-size: 0.85rem; color: var(--text-dim); margin-top: 2px; }
.account-head .id     { font-family: var(--font-mono); font-size: 0.78rem; color: var(--text-mute); margin-top: 4px; }

.account-roles { display: flex; flex-wrap: wrap; gap: 6px; }
.account-role  { font-family: var(--font-mono); font-size: 0.75rem; padding: 3px 10px; background: var(--accent-soft); color: var(--accent-hot); border-radius: 999px; }
.account-roles-empty { color: var(--text-mute); font-size: 0.85rem; }

.account-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.btn-danger {
  background: transparent; color: #c0392b; border: 1px solid #c0392b;
  padding: 10px 18px; border-radius: var(--radius);
  font-size: 0.92rem; font-weight: 500; cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.btn-danger:hover { background: #c0392b; color: #fff; }

@media (prefers-reduced-motion: reduce) {
  *, *::before, *::after {
    animation-duration: 0.01ms !important;
    transition-duration: 0.01ms !important;
  }
}

/* RSI Verification (account page) ----------------------------- */
#rsi-verify-card .rsi-row {
  display: flex; gap: 8px; align-items: center; flex-wrap: wrap;
  margin: 10px 0;
}
#rsi-verify-card .rsi-row input {
  flex: 1 1 220px;
  background: var(--bg-elev-2); border: 1px solid var(--border);
  color: var(--text); border-radius: var(--radius-sm);
  padding: 8px 10px; font: inherit; font-family: var(--font-mono);
}
#rsi-verify-card .rsi-code-box {
  display: inline-flex; align-items: center; gap: 12px;
  background: var(--bg-elev-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 10px 14px; margin: 8px 0;
}
#rsi-verify-card .rsi-code-box code {
  font-size: 1.15rem; letter-spacing: 0.5px; color: var(--accent);
}
#rsi-verify-card .rsi-expiry { font-size: 0.85rem; color: var(--text-mute); margin: 4px 0 14px; }
#rsi-verify-card .rsi-steps { color: var(--text-dim); font-size: 0.92rem; line-height: 1.6; padding-left: 20px; }
#rsi-verify-card .rsi-actions { display: flex; gap: 10px; flex-wrap: wrap; margin: 14px 0 6px; }
#rsi-verify-card .rsi-status strong { color: var(--ok, #2ecc71); }
#rsi-verify-card .rsi-meta { display: grid; grid-template-columns: max-content 1fr; gap: 4px 14px; margin: 10px 0; }
#rsi-verify-card .rsi-meta dt { color: var(--text-mute); font-size: 0.85rem; }
#rsi-verify-card .rsi-meta dd { margin: 0; color: var(--text); }
#rsi-verify-card .rsi-orgs ul { list-style: none; padding: 0; margin: 6px 0; display: flex; flex-wrap: wrap; gap: 6px; }
#rsi-verify-card .rsi-orgs li {
  background: var(--bg-elev); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: var(--radius-pill);
  font-size: 0.85rem; color: var(--text);
}
#rsi-verify-card .rsi-orgs li[data-main="1"] { border-color: var(--accent); color: var(--accent); }
#rsi-verify-card .rsi-error {
  color: var(--danger, #e74c3c); font-size: 0.9rem;
  background: rgba(231, 76, 60, 0.08); border: 1px solid var(--danger, #e74c3c);
  border-radius: var(--radius-sm); padding: 8px 10px; margin: 10px 0;
}
#rsi-verify-card .rsi-stale {
  color: var(--warn, #e67e22); font-size: 0.9rem;
  background: rgba(230, 126, 34, 0.08); border: 1px solid var(--warn, #e67e22);
  border-radius: var(--radius-sm); padding: 8px 10px; margin: 10px 0;
}

/* RSI verification (admin user-edit) ----------------------- */
.admin-rsi-meta {
  display: grid; grid-template-columns: max-content 1fr;
  gap: 4px 14px; margin: 10px 0;
}
.admin-rsi-meta dt { color: var(--text-mute); font-size: 0.85rem; }
.admin-rsi-meta dd { margin: 0; color: var(--text); }
.admin-rsi-orgs {
  list-style: none; padding: 0; margin: 0;
  display: flex; flex-wrap: wrap; gap: 6px;
}
.admin-rsi-orgs li {
  background: var(--bg-elev); border: 1px solid var(--border);
  padding: 3px 10px; border-radius: var(--radius-pill);
  font-size: 0.85rem; color: var(--text);
}
.admin-rsi-orgs li[data-main="1"] {
  border-color: var(--accent); color: var(--accent);
}
/* /orga/* pages (Overview + Blueprints) ----------------------- */
.orga-list { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-direction: column; gap: 6px; }
.orga-list li {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--bg-elev); border: 1px solid var(--border);
  padding: 6px 12px; border-radius: var(--radius-pill);
  font-size: 0.92rem;
}
.orga-list li[data-main="1"] { border-color: var(--accent); color: var(--accent); }
.orga-badge {
  font-size: 0.75rem; color: var(--text-mute);
  background: var(--bg-elev-2);
  padding: 1px 8px; border-radius: var(--radius-pill);
  margin-left: 6px;
}
.orga-shares { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-direction: column; gap: 4px; font-family: var(--font-mono); font-size: 0.9rem; }
.orga-channel-orgas { list-style: none; padding: 0; margin: 8px 0; display: flex; flex-direction: column; gap: 6px; }
.orga-channel-orgas li { display: inline-flex; align-items: center; gap: 10px; padding: 4px 0; }
.orga-channel-orgas label { flex: 1; cursor: pointer; }
.orga-share-status { color: var(--text-mute); font-size: 0.85rem; }

/* /orga/blueprints/ pool browse + manage modal --------------- */
.pool-header { display: flex; align-items: center; gap: 14px; margin-bottom: 12px; flex-wrap: wrap; }
.pool-picker { display: inline-flex; align-items: center; gap: 6px; font-size: 0.92rem; }
.pool-picker select {
  background: var(--bg-elev-2); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 4px 8px;
}
.pool-summary { color: var(--text-mute); font-size: 0.9rem; flex: 1; }
.pool-search {
  width: 100%;
  background: var(--bg-elev-2); color: var(--text); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 6px 10px; font: inherit;
  margin: 8px 0 12px;
}
.pool-list { list-style: none; padding: 0; margin: 16px 0 0; }
.pool-state-msg { margin: 16px 0 0; text-align: center; padding: 12px; }
.pool-list li { display: flex; justify-content: space-between; align-items: center; padding: 8px 10px; border-bottom: 1px solid var(--border); }
.pool-list .bp-name { font-size: 0.95rem; }
.pool-list .owners { display: inline-flex; align-items: center; gap: 4px; }
.pool-list .owner-avatar { width: 22px; height: 22px; border-radius: 50%; border: 1px solid var(--border); }
.pool-list .owner-avatar.main { border-color: var(--accent); }
.pool-list .owner-more { font-size: 0.8rem; color: var(--text-mute); margin-left: 6px; }

.manage-modal-overlay {
  position: fixed; inset: 0; z-index: 1000;
  background: rgba(0,0,0,0.6);
  display: flex; align-items: center; justify-content: center;
}
.manage-modal-overlay[hidden] { display: none; }
.manage-modal-dialog {
  background: var(--bg); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 20px; min-width: 380px; max-width: 560px; max-height: 80vh; overflow-y: auto;
}
.manage-modal-head { display: flex; justify-content: space-between; align-items: center; margin-bottom: 8px; }
.manage-modal-head h2 { margin: 0; font-size: 1.1rem; }
.manage-modal-head .close-btn { background: none; border: none; color: var(--text); font-size: 1.5rem; cursor: pointer; line-height: 1; }
.manage-channel { margin-top: 14px; }
.manage-channel h3 { margin: 0 0 6px; font-size: 0.95rem; color: var(--text-mute); }
.manage-channel ul { list-style: none; padding: 0; margin: 0; }
.manage-channel li { display: flex; align-items: center; gap: 8px; padding: 4px 0; }
.manage-channel label { flex: 1; cursor: pointer; }
.manage-status { color: var(--text-mute); font-size: 0.85rem; }
.btn-small { padding: 4px 10px; font-size: 0.85rem; }

/* Toggle-switch UI for the orga manage modal --------------- */
.manage-channel li.toggle-row {
  display: flex; align-items: center; justify-content: space-between;
  gap: 12px; padding: 6px 0; border-bottom: 1px solid var(--border);
}
.manage-channel li.toggle-row:last-child { border-bottom: none; }
.toggle-label { flex: 1; cursor: default; font-size: 0.92rem; color: var(--text); }
.manage-status { color: var(--text-mute); font-size: 0.82rem; margin-right: 6px; }

.toggle-switch {
  position: relative; display: inline-block;
  width: 42px; height: 22px; flex-shrink: 0;
  cursor: pointer;
}
.toggle-switch input { opacity: 0; width: 0; height: 0; position: absolute; }
.toggle-switch .slider {
  position: absolute; inset: 0;
  background: var(--bg-elev-2); border: 1px solid var(--border);
  border-radius: 999px; transition: background 0.18s, border-color 0.18s;
}
.toggle-switch .slider::before {
  content: ""; position: absolute;
  left: 2px; top: 2px;
  height: 16px; width: 16px;
  background: var(--text-mute);
  border-radius: 50%;
  transition: transform 0.18s, background 0.18s;
}
.toggle-switch input:checked + .slider {
  background: var(--accent);
  border-color: var(--accent);
}
.toggle-switch input:checked + .slider::before {
  background: #fff;
  transform: translateX(18px);
}
.toggle-switch input:disabled + .slider { opacity: 0.5; cursor: wait; }

/* Polished Manage-sharing header button + pool-header layout */
.pool-header {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 12px; flex-wrap: wrap;
}
.pool-header .btn-ghost {
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border-strong, var(--border));
  border-radius: var(--radius);
  padding: 6px 14px;
  font-size: 0.88rem; font-weight: 500;
  cursor: pointer;
  transition: border-color 0.15s, color 0.15s, background 0.15s;
}
.pool-header .btn-ghost:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* Tighten the locked-state copy + manage-link */
#pool-locked {
  background: rgba(255, 165, 0, 0.06);
  border: 1px solid rgba(255, 165, 0, 0.25);
  border-radius: var(--radius);
  padding: 10px 12px;
  margin: 12px 0 0;
  font-size: 0.9rem;
}
#pool-locked a { color: var(--accent); font-weight: 500; }

/* /orga/blueprints/ pool filter row + self-avatar marker -- */
.pool-filters {
  display: flex; align-items: center; gap: 14px;
  margin: 8px 0 12px; flex-wrap: wrap;
}
.pool-filters .pool-search { flex: 1; min-width: 200px; margin: 0; }
.pool-missing-toggle {
  display: inline-flex; align-items: center; gap: 6px;
  font-size: 0.9rem; color: var(--text-mute); cursor: pointer;
}
.pool-missing-toggle input { accent-color: var(--accent); }
.pool-list .owner-avatar.self {
  box-shadow: 0 0 0 2px var(--accent);
}

/* Singleton bottom-right toast used by /orga/blueprints/ for 401
   recovery + save errors — separate from the .lex-toast-container
   stack pattern. Persistent variant stays until reload (used for
   actionable session-expired prompts). */
#lex-toast {
  position: fixed;
  right: 16px; bottom: 16px;
  max-width: 360px;
  padding: 12px 14px;
  background: var(--card-bg, #14161c);
  border: 1px solid var(--border, #2a2d36);
  border-radius: 6px;
  color: var(--text, #e5e7eb);
  font-size: 0.9rem; line-height: 1.4;
  box-shadow: 0 12px 32px rgba(0,0,0,0.35);
  opacity: 0; transform: translateY(8px);
  transition: opacity 0.18s ease, transform 0.18s ease;
  pointer-events: none;
  z-index: 9999;
}
#lex-toast.show { opacity: 1; transform: translateY(0); pointer-events: auto; }
#lex-toast.lex-toast-error { border-left: 3px solid var(--accent, #c44d4d); }
#lex-toast a { color: var(--accent, #c44d4d); font-weight: 500; }

/* Inline "Share this channel" button rendered into the empty pool
   state — looks like a link, behaves like a button. */
.btn-link {
  background: none; border: 0; padding: 0; margin: 0;
  color: var(--accent, #c44d4d); font: inherit; cursor: pointer;
  text-decoration: underline;
}
.btn-link:hover { opacity: 0.85; }
.btn-link[disabled] { opacity: 0.5; cursor: default; }
