/* ============================================================
   UNANGREIFBAR — Member Portal
   Design System: Burgund / Sand / Ink / Salbei
   ============================================================ */

@import url('https://fonts.googleapis.com/css2?family=Source+Serif+4:opsz,wght@8..60,300;8..60,400;8..60,500;8..60,600;8..60,700&family=JetBrains+Mono:wght@400;500&display=swap');

/* ============================================================
   DESIGN TOKENS
   ============================================================ */
:root {
  /* Burgund — die Stärke */
  --burgundy-50:  #fbf3f1;
  --burgundy-100: #f3dcd6;
  --burgundy-200: #e3b3a8;
  --burgundy-300: #c87f70;
  --burgundy-400: #a8503e;
  --burgundy-500: #7a2a1d;
  --burgundy-600: #5e1f15;
  --burgundy-700: #43150e;
  --burgundy-800: #2d0d08;

  /* Sand — die Erdung */
  --sand-50:  #fbf7f1;
  --sand-100: #f3ebdc;
  --sand-200: #e7d9bf;
  --sand-300: #d4be96;
  --sand-400: #b89a6a;
  --sand-500: #8f7547;

  /* Ink — warmes Schwarz */
  --ink-900: #181311;
  --ink-700: #3a302b;
  --ink-500: #6b5d56;
  --ink-300: #a89b92;
  --ink-200: #cdc1b6;
  --ink-100: #e5dcd0;

  /* Salbei — Heilung & Fortschritt */
  --sage-100: #e3e6dc;
  --sage-300: #a3ad94;
  --sage-500: #5d6b4f;
  --sage-700: #3a4530;

  /* Gold — sparsam einsetzen */
  --gold-300: #d9b66a;
  --gold-500: #a88636;

  /* Semantische Farben */
  --bg:          var(--sand-50);
  --bg-elevated: #ffffff;
  --bg-card:     var(--sand-100);
  --bg-inverse:  var(--ink-900);
  --bg-brand:    var(--burgundy-500);
  --fg-1:        var(--ink-900);
  --fg-2:        var(--ink-700);
  --fg-3:        var(--ink-500);
  --fg-4:        var(--ink-300);
  --fg-brand:    var(--burgundy-500);
  --fg-on-brand: var(--sand-50);
  --border:      var(--ink-200);
  --border-soft: var(--ink-100);

  /* Schriften */
  --font-serif: 'Source Serif 4', 'Iowan Old Style', 'Georgia', serif;
  --font-mono:  'JetBrains Mono', ui-monospace, 'Menlo', monospace;

  /* Typografische Skala */
  --text-xs:  13px;
  --text-sm:  15px;
  --text-md:  17px;
  --text-lg:  20px;
  --text-xl:  24px;
  --text-2xl: 30px;
  --text-3xl: 38px;
  --text-4xl: 48px;

  /* Zeilenhöhen */
  --lh-tight:   1.08;
  --lh-snug:    1.18;
  --lh-normal:  1.45;
  --lh-relaxed: 1.65;

  /* Zeichenabstand */
  --tracking-tight:   -0.022em;
  --tracking-eyebrow:  0.18em;

  /* Abstände (4px Basis) */
  --space-1:  4px;
  --space-2:  8px;
  --space-3:  12px;
  --space-4:  16px;
  --space-5:  20px;
  --space-6:  24px;
  --space-8:  32px;
  --space-10: 40px;
  --space-12: 48px;
  --space-16: 64px;
  --space-20: 80px;

  /* Radien */
  --radius-sm:   6px;
  --radius-md:   10px;
  --radius-lg:   16px;
  --radius-xl:   24px;
  --radius-pill: 999px;

  /* Schatten — warm, burgund-getönt */
  --shadow-xs:    0 1px 2px rgba(43, 24, 18, 0.06);
  --shadow-sm:    0 2px 6px rgba(43, 24, 18, 0.07), 0 1px 2px rgba(43, 24, 18, 0.05);
  --shadow-md:    0 8px 20px rgba(43, 24, 18, 0.09), 0 2px 4px rgba(43, 24, 18, 0.05);
  --shadow-lg:    0 24px 48px rgba(43, 24, 18, 0.14), 0 4px 8px rgba(43, 24, 18, 0.06);
  --shadow-inset: inset 0 1px 0 rgba(255,255,255,0.4), inset 0 -1px 0 rgba(43,24,18,0.06);

  /* Bewegung */
  --ease-out: cubic-bezier(0.22, 1, 0.36, 1);
  --dur-fast: 140ms;
  --dur-base: 220ms;
  --dur-slow: 420ms;
}

/* ============================================================
   RESET & BASIS
   ============================================================ */
*, *::before, *::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  font-size: 16px;
  scroll-behavior: smooth;
}

body {
  font-family: var(--font-serif);
  font-size: var(--text-md);
  line-height: var(--lh-relaxed);
  color: var(--fg-2);
  background: var(--bg);
  -webkit-font-smoothing: antialiased;
  font-feature-settings: 'kern', 'liga', 'onum';
  text-rendering: optimizeLegibility;
  min-height: 100vh;
}

::selection {
  background: var(--burgundy-500);
  color: var(--sand-50);
}

a { color: inherit; text-decoration: none; }
img { max-width: 100%; height: auto; display: block; }
ul, ol { list-style: none; }
button { font-family: inherit; }

/* ============================================================
   TYPOGRAFIE
   ============================================================ */
h1, .h1 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: var(--text-4xl);
  line-height: var(--lh-tight);
  letter-spacing: var(--tracking-tight);
  color: var(--fg-1);
  text-wrap: balance;
}

h2, .h2 {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: var(--text-2xl);
  line-height: var(--lh-snug);
  letter-spacing: var(--tracking-tight);
  color: var(--fg-1);
  text-wrap: balance;
}

h3, .h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: var(--text-xl);
  line-height: var(--lh-snug);
  color: var(--fg-1);
}

h4, .h4 {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: var(--text-md);
  line-height: var(--lh-normal);
  color: var(--fg-1);
}

p { text-wrap: pretty; }

.eyebrow {
  font-family: var(--font-mono);
  font-weight: 500;
  font-size: 12px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-3);
}

.lead {
  font-size: var(--text-lg);
  line-height: var(--lh-relaxed);
  color: var(--fg-2);
}

.text-muted  { color: var(--fg-3); }
.text-brand  { color: var(--fg-brand); }
.text-sm     { font-size: var(--text-sm); }
.text-xs     { font-size: var(--text-xs); }

/* ============================================================
   LAYOUT
   ============================================================ */
.container {
  width: 100%;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.container--narrow { max-width: 720px; }

main {
  min-height: calc(100vh - 68px - 72px);
  padding: var(--space-12) 0 var(--space-16);
}

/* ============================================================
   NAVIGATION — Mitglieder
   ============================================================ */
.site-nav {
  position: sticky;
  top: 0;
  z-index: 100;
  background: rgba(251, 247, 241, 0.92);
  border-bottom: 1px solid var(--border-soft);
  backdrop-filter: blur(12px) saturate(1.05);
  -webkit-backdrop-filter: blur(12px) saturate(1.05);
}

.site-nav__inner {
  display: flex;
  align-items: center;
  gap: var(--space-8);
  height: 68px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.site-nav__logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex-shrink: 0;
}

.site-nav__wordmark {
  font-family: var(--font-serif);
  font-size: 20px;
  font-weight: 500;
  color: var(--fg-1);
  letter-spacing: var(--tracking-tight);
}

.site-nav__links {
  display: flex;
  align-items: center;
  gap: var(--space-5);
}

.site-nav__links a {
  font-size: var(--text-sm);
  color: var(--fg-3);
  transition: color var(--dur-fast) var(--ease-out);
  padding: var(--space-2) var(--space-1);
  border-bottom: 1.5px solid transparent;
}

.site-nav__links a:hover { color: var(--fg-1); }
.site-nav__links a.active {
  color: var(--fg-1);
  border-bottom-color: var(--burgundy-500);
}

.site-nav__right {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  margin-left: auto;
}

.site-nav__user {
  font-size: var(--text-sm);
  color: var(--fg-3);
}

/* ============================================================
   BUTTONS
   ============================================================ */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-2);
  padding: var(--space-3) var(--space-5);
  font-family: var(--font-serif);
  font-size: var(--text-sm);
  font-weight: 500;
  line-height: 1.4;
  border-radius: var(--radius-md);
  border: 1px solid transparent;
  cursor: pointer;
  transition: all var(--dur-fast) var(--ease-out);
  text-decoration: none;
  white-space: nowrap;
  -webkit-appearance: none;
  appearance: none;
}

.btn--primary {
  background: var(--burgundy-500);
  color: var(--sand-50);
  border-color: var(--burgundy-600);
  box-shadow: var(--shadow-xs);
}
.btn--primary:hover  { background: var(--burgundy-600); box-shadow: var(--shadow-sm); }
.btn--primary:active { transform: translateY(1px); box-shadow: none; }

.btn--secondary {
  background: var(--bg-elevated);
  color: var(--fg-2);
  border-color: var(--border);
  box-shadow: var(--shadow-xs);
}
.btn--secondary:hover { border-color: var(--ink-500); box-shadow: var(--shadow-sm); }

.btn--ghost {
  background: transparent;
  color: var(--fg-3);
  border-color: transparent;
}
.btn--ghost:hover { background: var(--sand-100); color: var(--fg-2); }

.btn--danger {
  background: transparent;
  color: var(--burgundy-500);
  border-color: var(--burgundy-200);
}
.btn--danger:hover { background: var(--burgundy-50); border-color: var(--burgundy-300); }

.btn--sm  { padding: var(--space-2) var(--space-3); font-size: var(--text-xs); }
.btn--lg  { padding: var(--space-4) var(--space-8); font-size: var(--text-md); }
.btn--full { width: 100%; }

/* ============================================================
   FORMULARE
   ============================================================ */
.form-stack { display: flex; flex-direction: column; gap: var(--space-5); }

.form-group { display: flex; flex-direction: column; gap: var(--space-2); }

.form-label {
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--fg-2);
}

.form-input,
.form-textarea,
.form-select {
  width: 100%;
  padding: var(--space-3) var(--space-4);
  font-family: var(--font-serif);
  font-size: var(--text-md);
  color: var(--fg-1);
  background: var(--bg-elevated);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  box-shadow: var(--shadow-inset);
  transition: border-color var(--dur-fast) var(--ease-out),
              box-shadow    var(--dur-fast) var(--ease-out);
  -webkit-appearance: none;
  appearance: none;
}

.form-input:focus,
.form-textarea:focus,
.form-select:focus {
  outline: none;
  border-color: var(--burgundy-400);
  box-shadow: var(--shadow-inset), 0 0 0 3px rgba(122, 42, 29, 0.12);
}

.form-input::placeholder,
.form-textarea::placeholder { color: var(--fg-4); }

.form-textarea  { min-height: 120px; resize: vertical; line-height: var(--lh-relaxed); }

.form-select {
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%236b5d56' stroke-width='1.5'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat;
  background-position: right var(--space-3) center;
  background-size: 20px;
  padding-right: var(--space-10);
}

.form-hint  { font-size: var(--text-xs); color: var(--fg-3); }
.form-error { font-size: var(--text-xs); color: var(--burgundy-500); }

.form-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: var(--space-5);
}

/* ============================================================
   ALERTS
   ============================================================ */
.alert {
  padding: var(--space-3) var(--space-4);
  border-radius: var(--radius-md);
  font-size: var(--text-sm);
  line-height: var(--lh-normal);
}

.alert--error   { background: var(--burgundy-50); color: var(--burgundy-600); border: 1px solid var(--burgundy-100); }
.alert--success { background: var(--sage-100);    color: var(--sage-700);     border: 1px solid var(--sage-300); }
.alert--info    { background: var(--sand-100);    color: var(--ink-500);      border: 1px solid var(--border-soft); }

/* ============================================================
   AUTH SEITEN
   ============================================================ */
.auth-page {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--bg);
  padding: var(--space-8) var(--space-6);
}

.auth-box { width: 100%; max-width: 440px; }

.auth-logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  margin-bottom: var(--space-10);
}

.auth-logo__wordmark {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  color: var(--fg-1);
  letter-spacing: var(--tracking-tight);
}

.auth-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-xl);
  padding: var(--space-10);
  box-shadow: var(--shadow-lg);
}

.auth-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: var(--text-2xl);
  color: var(--fg-1);
  margin-bottom: var(--space-2);
  letter-spacing: var(--tracking-tight);
}

.auth-subtitle {
  font-size: var(--text-sm);
  color: var(--fg-3);
  margin-bottom: var(--space-8);
  line-height: var(--lh-normal);
}

.auth-divider {
  border: none;
  border-top: 1px solid var(--border-soft);
  margin: var(--space-6) 0;
}

.auth-link-text {
  text-align: center;
  font-size: var(--text-sm);
  color: var(--fg-3);
}

.auth-link-text a {
  color: var(--burgundy-500);
  border-bottom: 1px solid transparent;
  transition: border-color var(--dur-fast);
}
.auth-link-text a:hover { border-color: var(--burgundy-500); }

/* ============================================================
   DASHBOARD
   ============================================================ */
.dashboard-welcome {
  padding: var(--space-10) 0 var(--space-8);
  border-bottom: 1px solid var(--border-soft);
  margin-bottom: var(--space-8);
}

.dashboard-welcome .eyebrow { margin-bottom: var(--space-3); }
.dashboard-welcome h1 { font-size: var(--text-3xl); margin-bottom: var(--space-2); }

.stats-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-10);
}

.stat-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
}

.stat-card__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-3);
  margin-bottom: var(--space-2);
}

.stat-card__value {
  font-size: var(--text-3xl);
  font-weight: 300;
  color: var(--fg-1);
  line-height: 1;
}

.stat-card__sub {
  font-size: var(--text-xs);
  color: var(--fg-3);
  margin-top: var(--space-1);
}

.section-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  margin-bottom: var(--space-6);
}

.section-header h2 { font-size: var(--text-xl); }

/* ============================================================
   FORTSCHRITTSBALKEN
   ============================================================ */
.progress {
  height: 4px;
  background: var(--sand-200);
  border-radius: var(--radius-pill);
  overflow: hidden;
}

.progress--lg { height: 8px; }

.progress__fill {
  height: 100%;
  background: var(--sage-500);
  border-radius: var(--radius-pill);
  transition: width var(--dur-slow) var(--ease-out);
  min-width: 2px;
}

.progress-meta {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: var(--space-2);
}

.progress-meta__text { font-size: var(--text-xs); color: var(--fg-3); }

.progress-meta__pct {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--sage-500);
  font-weight: 500;
}

/* ============================================================
   KURSÜBERSICHT — Grid
   ============================================================ */
.courses-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-6);
}

.course-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
  text-decoration: none;
  color: inherit;
  display: flex;
  flex-direction: column;
  transition: box-shadow var(--dur-base) var(--ease-out),
              transform   var(--dur-slow) var(--ease-out);
}

.course-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-1px);
}

.course-card__thumb {
  width: 100%;
  aspect-ratio: 16/9;
  overflow: hidden;
  background: var(--sand-100);
  flex-shrink: 0;
}

.course-card__thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  transition: transform var(--dur-slow) var(--ease-out);
}

.course-card:hover .course-card__thumb img { transform: scale(1.02); }

.course-card__thumb-placeholder {
  width: 100%;
  height: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-300);
}

.course-card__body {
  padding: var(--space-5) var(--space-6) var(--space-6);
  display: flex;
  flex-direction: column;
  flex: 1;
}

.course-card__title {
  font-size: var(--text-lg);
  font-weight: 500;
  color: var(--fg-1);
  margin-bottom: var(--space-2);
  line-height: var(--lh-snug);
}

.course-card__desc {
  font-size: var(--text-sm);
  color: var(--fg-3);
  line-height: var(--lh-relaxed);
  flex: 1;
  margin-bottom: var(--space-4);
}

.course-card__footer { margin-top: auto; }

.course-card__progress { margin-bottom: var(--space-4); }

.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px var(--space-2);
  border-radius: var(--radius-pill);
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  letter-spacing: 0.04em;
}

.badge--done     { background: var(--sage-100);    color: var(--sage-700); }
.badge--wip      { background: var(--burgundy-50); color: var(--burgundy-500); }
.badge--new      { background: var(--sand-100);    color: var(--ink-500); }
.badge--published { background: var(--sage-100);   color: var(--sage-700); }
.badge--draft    { background: var(--sand-100);    color: var(--ink-500); }
.badge--active   { background: var(--sage-100);    color: var(--sage-700); }
.badge--inactive { background: var(--sand-100);    color: var(--fg-3); }

/* ============================================================
   KURS-DETAILSEITE
   ============================================================ */
.course-hero {
  padding: var(--space-10) 0;
  border-bottom: 1px solid var(--border-soft);
  margin-bottom: var(--space-8);
}

.course-hero .eyebrow { margin-bottom: var(--space-3); }
.course-hero h1 { margin-bottom: var(--space-4); }
.course-hero__desc { max-width: 640px; margin-bottom: var(--space-6); color: var(--fg-2); }

.course-layout {
  display: grid;
  grid-template-columns: 1fr 300px;
  gap: var(--space-8);
  align-items: start;
}

.lesson-list { display: flex; flex-direction: column; gap: var(--space-1); }

.lesson-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-4);
  border-radius: var(--radius-md);
  text-decoration: none;
  color: inherit;
  transition: background var(--dur-fast) var(--ease-out);
  border: 1px solid transparent;
}

.lesson-item:hover      { background: var(--sand-100); border-color: var(--border-soft); }
.lesson-item.is-active  { background: var(--sand-100); border-color: var(--border); }

.lesson-item__num {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--fg-4);
  min-width: 20px;
  flex-shrink: 0;
}

.lesson-item__check {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  border: 1.5px solid var(--border);
  flex-shrink: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all var(--dur-fast) var(--ease-out);
  flex-shrink: 0;
}

.lesson-item.is-done .lesson-item__check {
  background: var(--sage-500);
  border-color: var(--sage-500);
  color: #fff;
}

.lesson-item__title {
  flex: 1;
  font-size: var(--text-sm);
  color: var(--fg-2);
  line-height: var(--lh-normal);
}

.lesson-item.is-done .lesson-item__title { color: var(--fg-3); }

.course-sidebar-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  box-shadow: var(--shadow-sm);
  position: sticky;
  top: 84px;
}

.course-sidebar-card h3 { font-size: var(--text-md); margin-bottom: var(--space-5); }

/* ============================================================
   LEKTIONS-ANSICHT
   ============================================================ */
.lesson-page {
  max-width: 820px;
  margin: 0 auto;
}

.video-wrapper {
  position: relative;
  padding-bottom: 56.25%;
  height: 0;
  overflow: hidden;
  border-radius: var(--radius-lg);
  background: var(--ink-900);
  margin-bottom: var(--space-8);
  box-shadow: var(--shadow-md);
}

.video-wrapper iframe {
  position: absolute;
  top: 0; left: 0;
  width: 100%; height: 100%;
  border: none;
}

.lesson-content { padding-bottom: var(--space-12); }
.lesson-content .eyebrow { margin-bottom: var(--space-3); }

.lesson-content h1 {
  font-size: var(--text-2xl);
  margin-bottom: var(--space-6);
}

.lesson-content__body {
  font-size: var(--text-md);
  line-height: var(--lh-relaxed);
  color: var(--fg-2);
  margin-bottom: var(--space-8);
}

.lesson-materials {
  background: var(--sand-100);
  border-radius: var(--radius-lg);
  padding: var(--space-6);
  margin-bottom: var(--space-8);
  border: 1px solid var(--border-soft);
}

.lesson-materials h3 {
  font-size: var(--text-md);
  margin-bottom: var(--space-4);
}

.lesson-materials__content {
  font-size: var(--text-sm);
  color: var(--fg-2);
  line-height: var(--lh-relaxed);
  white-space: pre-wrap;
}

.lesson-complete-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: var(--space-3);
  width: 100%;
  padding: var(--space-4) var(--space-6);
  border-radius: var(--radius-md);
  border: 1.5px solid var(--border);
  background: var(--bg-elevated);
  cursor: pointer;
  font-family: var(--font-serif);
  font-size: var(--text-sm);
  font-weight: 500;
  color: var(--fg-2);
  transition: all var(--dur-fast) var(--ease-out);
  margin-bottom: var(--space-8);
  box-shadow: var(--shadow-xs);
}

.lesson-complete-btn:hover {
  border-color: var(--sage-300);
  background: var(--sage-100);
  color: var(--sage-700);
}

.lesson-complete-btn.is-done {
  background: var(--sage-500);
  border-color: var(--sage-700);
  color: #fff;
  box-shadow: var(--shadow-sm);
}

.lesson-complete-btn.is-done:hover {
  background: var(--sage-700);
}

.lesson-complete-btn__circle {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 1.5px solid currentColor;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all var(--dur-fast) var(--ease-out);
}

.lesson-complete-btn.is-done .lesson-complete-btn__circle {
  background: rgba(255,255,255,0.2);
  border-color: rgba(255,255,255,0.5);
}

.lesson-nav {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding-top: var(--space-8);
  border-top: 1px solid var(--border-soft);
  gap: var(--space-4);
}

/* ============================================================
   FOOTER — Mitglieder
   ============================================================ */
.site-footer {
  border-top: 1px solid var(--border-soft);
  padding: var(--space-6) 0;
}

.site-footer__inner {
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: var(--space-4);
}

.site-footer__copy {
  font-size: var(--text-xs);
  color: var(--fg-4);
}

/* ============================================================
   ADMIN — Navigation
   ============================================================ */
.admin-body { background: var(--sand-50); }

.admin-nav {
  background: var(--ink-900);
  border-bottom: 1px solid rgba(255,255,255,0.06);
  position: sticky;
  top: 0;
  z-index: 100;
}

.admin-nav__inner {
  display: flex;
  align-items: center;
  gap: var(--space-6);
  height: 60px;
  max-width: 1200px;
  margin: 0 auto;
  padding: 0 var(--space-6);
}

.admin-nav__logo {
  display: flex;
  align-items: center;
  gap: var(--space-3);
  text-decoration: none;
  flex-shrink: 0;
}

.admin-nav__wordmark {
  font-family: var(--font-serif);
  font-size: 18px;
  font-weight: 500;
  color: var(--sand-50);
  letter-spacing: var(--tracking-tight);
}

.admin-badge {
  font-family: var(--font-mono);
  font-size: 10px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  background: var(--burgundy-500);
  color: var(--sand-50);
  padding: 2px 8px;
  border-radius: var(--radius-pill);
}

.admin-nav__links {
  display: flex;
  gap: var(--space-1);
}

.admin-nav__links a {
  font-size: var(--text-sm);
  color: rgba(251,247,241,0.5);
  text-decoration: none;
  padding: var(--space-2) var(--space-3);
  border-radius: var(--radius-sm);
  transition: all var(--dur-fast) var(--ease-out);
}

.admin-nav__links a:hover,
.admin-nav__links a.active {
  color: var(--sand-50);
  background: rgba(255,255,255,0.08);
}

.admin-nav__right { margin-left: auto; }

/* ============================================================
   ADMIN — Layout
   ============================================================ */
.admin-main {
  max-width: 1200px;
  margin: 0 auto;
  padding: var(--space-10) var(--space-6) var(--space-16);
}

.admin-page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: var(--space-8);
  padding-bottom: var(--space-6);
  border-bottom: 1px solid var(--border-soft);
}

.admin-page-title {
  font-family: var(--font-serif);
  font-weight: 400;
  font-size: var(--text-2xl);
  color: var(--fg-1);
}

.admin-page-subtitle {
  font-size: var(--text-sm);
  color: var(--fg-3);
  margin-top: var(--space-1);
}

/* ============================================================
   ADMIN — Statistiken
   ============================================================ */
.admin-stats {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: var(--space-4);
  margin-bottom: var(--space-10);
}

.admin-stat {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  padding: var(--space-6) var(--space-6) var(--space-5);
  box-shadow: var(--shadow-sm);
}

.admin-stat__num {
  font-size: var(--text-4xl);
  font-weight: 300;
  color: var(--fg-1);
  line-height: 1;
  margin-bottom: var(--space-2);
}

.admin-stat__label {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-3);
}

/* ============================================================
   ADMIN — Datentabelle
   ============================================================ */
.table-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  box-shadow: var(--shadow-sm);
  overflow: hidden;
}

.data-table {
  width: 100%;
  border-collapse: collapse;
}

.data-table th {
  font-family: var(--font-mono);
  font-size: 11px;
  letter-spacing: var(--tracking-eyebrow);
  text-transform: uppercase;
  color: var(--fg-3);
  padding: var(--space-4) var(--space-5);
  text-align: left;
  background: var(--sand-50);
  border-bottom: 1px solid var(--border-soft);
  font-weight: 500;
  white-space: nowrap;
}

.data-table td {
  padding: var(--space-4) var(--space-5);
  border-bottom: 1px solid var(--border-soft);
  font-size: var(--text-sm);
  color: var(--fg-2);
  vertical-align: middle;
}

.data-table tr:last-child td { border-bottom: none; }
.data-table tbody tr:hover td { background: var(--sand-50); }

.table-actions { display: flex; gap: var(--space-2); align-items: center; }

.thumb-preview {
  width: 80px;
  height: 45px;
  object-fit: cover;
  border-radius: var(--radius-sm);
  display: block;
}

.thumb-placeholder {
  width: 80px;
  height: 45px;
  border-radius: var(--radius-sm);
  background: var(--sand-100);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ink-300);
}

/* ============================================================
   ADMIN — Formular-Karte
   ============================================================ */
.admin-form-card {
  background: var(--bg-elevated);
  border-radius: var(--radius-lg);
  padding: var(--space-8);
  box-shadow: var(--shadow-sm);
  max-width: 720px;
}

.admin-form-card .form-stack { gap: var(--space-6); }

/* ============================================================
   ADMIN — Lektionen Reihenfolge
   ============================================================ */
.reorder-list { display: flex; flex-direction: column; gap: var(--space-2); }

.reorder-item {
  display: flex;
  align-items: center;
  gap: var(--space-4);
  padding: var(--space-4) var(--space-5);
  background: var(--bg-elevated);
  border: 1px solid var(--border-soft);
  border-radius: var(--radius-md);
  cursor: grab;
  transition: box-shadow var(--dur-fast) var(--ease-out),
              border-color var(--dur-fast) var(--ease-out);
  user-select: none;
}

.reorder-item:active { cursor: grabbing; box-shadow: var(--shadow-md); }
.reorder-item.dragging { opacity: 0.4; }
.reorder-item.drag-over { border-color: var(--burgundy-300); background: var(--burgundy-50); }

.drag-handle { color: var(--fg-4); flex-shrink: 0; }

.reorder-item__num {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--fg-4);
  min-width: 24px;
}

.reorder-item__title { flex: 1; font-size: var(--text-sm); color: var(--fg-2); }

/* ============================================================
   LEER-ZUSTAND
   ============================================================ */
.empty-state {
  text-align: center;
  padding: var(--space-16) var(--space-8);
  color: var(--fg-3);
}

.empty-state__icon { margin: 0 auto var(--space-4); color: var(--ink-300); }
.empty-state h3  { font-size: var(--text-lg); color: var(--fg-2); margin-bottom: var(--space-2); }
.empty-state p   { font-size: var(--text-sm); margin-bottom: var(--space-6); }

/* ============================================================
   HILFSMITTEL
   ============================================================ */
.flex            { display: flex; }
.flex-col        { flex-direction: column; }
.items-center    { align-items: center; }
.justify-between { justify-content: space-between; }
.gap-2   { gap: var(--space-2); }
.gap-4   { gap: var(--space-4); }
.gap-6   { gap: var(--space-6); }
.mt-4    { margin-top: var(--space-4); }
.mt-6    { margin-top: var(--space-6); }
.mt-8    { margin-top: var(--space-8); }
.mb-4    { margin-bottom: var(--space-4); }
.mb-6    { margin-bottom: var(--space-6); }
.mb-8    { margin-bottom: var(--space-8); }
.w-full  { width: 100%; }
.sr-only { position: absolute; width: 1px; height: 1px; overflow: hidden; clip: rect(0,0,0,0); }

/* ============================================================
   RESPONSIV
   ============================================================ */
@media (max-width: 1024px) {
  .courses-grid     { grid-template-columns: repeat(2, 1fr); }
  .course-layout    { grid-template-columns: 1fr; }
  .course-sidebar-card { position: static; }
  .stats-row, .admin-stats { grid-template-columns: repeat(2, 1fr); }
  h1, .h1 { font-size: var(--text-3xl); }
}

@media (max-width: 768px) {
  main { padding: var(--space-8) 0 var(--space-12); }
  .courses-grid  { grid-template-columns: 1fr; }
  .stats-row, .admin-stats { grid-template-columns: 1fr; }
  .site-nav__links { display: none; }
  .admin-nav__links { display: none; }
  .auth-card { padding: var(--space-8) var(--space-6); }
  .admin-page-header { flex-direction: column; align-items: flex-start; gap: var(--space-4); }
  .lesson-nav { flex-direction: column; }
  .form-row { grid-template-columns: 1fr; }
  h1, .h1 { font-size: var(--text-2xl); }
  h2, .h2 { font-size: var(--text-xl); }
}

@media (max-width: 480px) {
  .container    { padding: 0 var(--space-4); }
  .auth-card    { padding: var(--space-6); border-radius: var(--radius-lg); }
  .admin-form-card { padding: var(--space-6); }
}
