/* ============================================================
   PAPYRUS – Design System (X-Style Pure Black)
   ============================================================ */

:root {
  --font: 'Inter', sans-serif;
  --radius: 14px;
  --radius-sm: 8px;
  --radius-lg: 20px;
  --transition: 0.22s cubic-bezier(0.4, 0, 0.2, 1);
  --shadow: 0 4px 24px rgba(0, 0, 0, 0.18);
  --shadow-lg: 0 8px 40px rgba(0, 0, 0, 0.28);
  --sidebar-width: 240px;
}

/* Papyrus Studio cinematic integration - SCREENSHOT MATCH */
.papyrus-studio-home {
  position: relative;
  isolation: isolate;
  margin: -24px;
  padding: 40px;
  min-height: calc(100vh - 40px);
  background: #0a0a0a;
  overflow-y: auto;
  overflow-x: hidden;
}

.papyrus-studio-hero {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 40px;
  align-items: center;
  min-height: 480px;
  border: 1px solid rgba(255, 255, 255, 0.08);
  border-radius: 28px;
  padding: 60px;
  background: rgba(18, 18, 18, 0.6);
  backdrop-filter: blur(20px);
  box-shadow: 0 40px 100px rgba(0,0,0,0.5);
  margin-bottom: 40px;
}

.papyrus-kicker {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  border-radius: 100px;
  background: rgba(20, 184, 166, 0.15);
  color: #14b8a6;
  font-weight: 800;
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  margin-bottom: 24px;
  border: 1px solid rgba(20, 184, 166, 0.2);
}

.papyrus-studio-copy h1 {
  font-size: clamp(3rem, 6vw, 4.8rem);
  font-weight: 800;
  line-height: 1.1;
  color: #fff;
  margin-bottom: 24px;
}

.papyrus-studio-copy p {
  max-width: 580px;
  color: rgba(255, 255, 255, 0.6);
  font-size: 1.05rem;
  line-height: 1.6;
  margin-bottom: 32px;
}

.papyrus-studio-actions {
  display: flex;
  gap: 12px;
}

.papyrus-studio-actions .btn {
  padding: 14px 28px;
  border-radius: 12px;
  font-weight: 700;
  font-size: 0.95rem;
}

.papyrus-studio-actions .btn-primary {
  background: #14b8a6;
  color: #000;
  box-shadow: 0 10px 25px rgba(20, 184, 166, 0.2);
}

.papyrus-studio-actions .btn-secondary {
  background: rgba(255, 255, 255, 0.04);
  color: #fff;
  border: 1px solid rgba(255, 255, 255, 0.1);
}

/* Hero Preview Mockup */
.papyrus-studio-preview {
  background: #0f0f0f;
  border: 1px solid rgba(255,255,255,0.1);
  border-radius: 20px;
  aspect-ratio: 16/10;
  position: relative;
  overflow: hidden;
  box-shadow: 0 30px 60px rgba(0,0,0,0.4);
}

.papyrus-preview-top {
  height: 40px;
  background: rgba(255,255,255,0.02);
  border-bottom: 1px solid rgba(255,255,255,0.05);
  display: flex;
  align-items: center;
  padding: 0 16px;
  gap: 6px;
}

.papyrus-preview-top span {
  width: 8px; height: 8px; border-radius: 50%; background: rgba(255,255,255,0.1);
}

.papyrus-preview-top i {
  margin-left: auto; color: #d4a753; font-size: 0.8rem;
}

.papyrus-preview-tools {
  position: absolute;
  left: 12px;
  top: 55px;
  bottom: 12px;
  width: 44px;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 12px 0;
  gap: 15px;
}

.papyrus-preview-tools i {
  color: rgba(255,255,255,0.4);
  font-size: 0.9rem;
}

.papyrus-preview-paper {
  position: absolute;
  left: 68px;
  top: 55px;
  right: 12px;
  bottom: 12px;
  background: #fdf6e3;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
}

/* Notebook Cards */
.papyrus-nb-card {
  background: rgba(18, 18, 18, 0.6);
  border: 1px solid rgba(255,255,255,0.05);
  border-radius: 20px;
  overflow: hidden;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
  cursor: pointer;
}

.papyrus-nb-card:hover {
  transform: translateY(-5px);
  border-color: rgba(20, 184, 166, 0.3);
  box-shadow: 0 20px 40px rgba(0,0,0,0.3);
}

.papyrus-nb-cover {
  height: 180px;
  background: #d4a753;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 3.5rem;
  color: rgba(0,0,0,0.15);
  position: relative;
}

.papyrus-nb-cover::after {
  content: "";
  position: absolute;
  left: 0; top: 0; bottom: 0; width: 15px;
  background: linear-gradient(to right, rgba(0,0,0,0.1), transparent);
}

.papyrus-nb-body {
  padding: 16px;
}

.papyrus-nb-title {
  font-weight: 700;
  font-size: 0.95rem;
  color: #fff;
  margin-bottom: 4px;
}

.papyrus-nb-meta {
  font-size: 0.75rem;
  color: rgba(255,255,255,0.4);
}

/* Search Bar */
.papyrus-dash-bar {
  display: flex;
  align-items: center;
  gap: 20px;
  margin-bottom: 32px;
  flex-wrap: wrap;
}

.papyrus-search-wrap {
  flex: 1;
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  border-radius: 100px;
  padding: 10px 20px;
  display: flex;
  align-items: center;
  gap: 12px;
}

.papyrus-search {
  background: transparent;
  border: none;
  color: #fff;
  font-size: 0.9rem;
  width: 100%;
  outline: none;
}

.folder-chip {
  padding: 6px 16px;
  border-radius: 100px;
  background: rgba(255,255,255,0.03);
  color: rgba(255,255,255,0.5);
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid transparent;
}

.folder-chip.active {
  background: rgba(20, 184, 166, 0.1);
  color: #14b8a6;
  border-color: rgba(20, 184, 166, 0.3);
}
  box-shadow: 0 24px 70px rgba(0, 0, 0, .48), 0 0 48px rgba(216, 166, 79, .12);
}

.papyrus-preview-top {
  height: 44px;
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 0 14px;
  color: #f1c36e;
  border-bottom: 1px solid rgba(255, 255, 255, .08);
}

.papyrus-preview-top span {
  width: 9px;
  height: 9px;
  border-radius: 50%;
  background: rgba(255, 255, 255, .24);
}

.papyrus-preview-top i { margin-left: auto; }

.papyrus-preview-tools {
  position: absolute;
  left: 18px;
  top: 70px;
  display: grid;
  gap: 10px;
  z-index: 2;
}

.papyrus-preview-tools i,
.papyrus-floating-ai button,
.papyrus-paper-switch .papyrus-tool-btn,
.papyrus-export-btn {
  width: 38px;
  height: 38px;
  border-radius: 10px;
  display: grid;
  place-items: center;
  color: #f7e7c8;
  background: rgba(255, 255, 255, .08);
  border: 1px solid rgba(255, 255, 255, .12);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .1);
}

.papyrus-preview-paper {
  position: absolute;
  inset: 66px 22px 22px 78px;
  border-radius: 10px;
  background:
    radial-gradient(circle at 18% 12%, rgba(255, 255, 255, .6), transparent 18%),
    linear-gradient(135deg, #f6ecd9, #d8c39d);
  box-shadow: 0 28px 46px rgba(0, 0, 0, .38), inset 0 0 40px rgba(92, 58, 16, .14);
}

.papyrus-preview-paper svg {
  width: 100%;
  height: 100%;
}

.papyrus-search-wrap {
  flex: 1;
  min-width: min(360px, 100%);
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 14px;
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 12px;
  background: rgba(255, 255, 255, .06);
  color: rgba(255, 255, 255, .62);
}

.papyrus-search-wrap .papyrus-search {
  min-width: 0;
  border: 0;
  background: transparent;
  box-shadow: none;
}

.papyrus-loading {
  grid-column: 1 / -1;
  padding: 34px;
  text-align: center;
  color: rgba(255, 255, 255, .6);
}

.papyrus-studio-home .papyrus-nb-card,
.papyrus-documents-panel {
  background: rgba(255, 255, 255, .07);
  border-color: rgba(255, 255, 255, .13);
  box-shadow: 0 18px 45px rgba(0, 0, 0, .28);
  backdrop-filter: blur(14px);
}

.papyrus-studio-shell {
  display: grid;
  grid-template-columns: 280px minmax(0, 1fr);
  gap: 16px;
  margin-top: 18px;
}

.papyrus-folder-panel {
  border: 1px solid rgba(255, 255, 255, .12);
  border-radius: 14px;
  background: rgba(255, 255, 255, .06);
  box-shadow: 0 18px 45px rgba(0, 0, 0, .26);
  backdrop-filter: blur(14px);
  overflow: hidden;
  min-height: 420px;
  display: flex;
  flex-direction: column;
}

.papyrus-folder-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 14px;
  border-bottom: 1px solid rgba(255, 255, 255, .10);
  background: rgba(0, 0, 0, .18);
}

.papyrus-folder-head-actions {
  display: flex;
  gap: 8px;
  align-items: center;
}

.papyrus-folder-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-weight: 900;
  letter-spacing: 0;
  color: rgba(255, 247, 232, .92);
}

.papyrus-folder-add {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .08);
  color: rgba(255, 247, 232, .9);
  cursor: pointer;
}
.papyrus-folder-add:hover { background: rgba(255, 255, 255, .12); }

.papyrus-folder-list {
  padding: 10px;
  display: grid;
  gap: 8px;
  overflow: auto;
}

.papyrus-folder-row-wrap {
  display: grid;
  grid-template-columns: 1fr 36px;
  gap: 8px;
  align-items: center;
}

.papyrus-folder-row {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid rgba(255, 255, 255, .10);
  background: rgba(255, 255, 255, .05);
  color: rgba(255, 247, 232, .86);
  cursor: pointer;
  text-align: left;
}
.papyrus-folder-row:active { transform: translateY(1px); }
.papyrus-folder-row.drag-over {
  outline: 2px solid rgba(216, 166, 79, .35);
  box-shadow: 0 0 0 3px rgba(216, 166, 79, .14);
}
.papyrus-folder-row:hover { background: rgba(255, 255, 255, .08); }
.papyrus-folder-row.active {
  border-color: rgba(216, 166, 79, .35);
  background: rgba(216, 166, 79, .14);
  color: #ffe0b1;
}

.papyrus-folder-name {
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.papyrus-folder-count {
  font-size: .74rem;
  font-weight: 900;
  color: rgba(255, 255, 255, .68);
  background: rgba(255, 255, 255, .08);
  padding: 3px 8px;
  border-radius: 999px;
}

.papyrus-folder-more {
  width: 36px;
  height: 36px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, .10);
  background: rgba(255, 255, 255, .06);
  color: rgba(255, 247, 232, .82);
  cursor: pointer;
}
.papyrus-folder-more:hover { background: rgba(255, 255, 255, .10); }

.papyrus-studio-main {
  min-width: 0;
}

.papyrus-nb-cover {
  position: relative;
  min-height: 132px;
}

.papyrus-nb-cover::before {
  content: "";
  position: absolute;
  inset: 13px;
  border: 1px solid rgba(255, 255, 255, .22);
  border-radius: 10px;
  background:
    linear-gradient(90deg, rgba(255, 255, 255, .12), transparent 22%),
    linear-gradient(180deg, transparent, rgba(0, 0, 0, .18));
}

.papyrus-editor-overlay {
  background:
    radial-gradient(900px 500px at 72% -10%, rgba(216, 150, 52, .24), transparent 64%),
    radial-gradient(640px 380px at 14% 12%, rgba(86, 209, 255, .1), transparent 62%),
    #05070a;
  color: #f8f3e9;
}

.papyrus-editor-topbar {
  min-height: 64px;
  padding: 10px 16px;
  background: rgba(8, 10, 14, .76);
  border-bottom-color: rgba(255, 255, 255, .1);
  backdrop-filter: blur(18px) saturate(150%);
}

.papyrus-editor-title {
  flex: 0 1 210px;
  color: #fff5df;
}

.papyrus-toolbar,
.papyrus-paper-switch {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 5px;
  border-radius: 14px;
  background: rgba(255, 255, 255, .07);
  border: 1px solid rgba(255, 255, 255, .12);
  box-shadow: 0 18px 38px rgba(0, 0, 0, .22);
}

.papyrus-zoom-pill {
  min-width: 64px;
  height: 40px;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 0 12px;
  border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .12);
  background: rgba(255, 255, 255, .06);
  color: rgba(255, 247, 232, .85);
  font-size: 0.78rem;
  font-weight: 800;
  letter-spacing: 0;
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, .08);
}

.papyrus-tool-btn,
.papyrus-size-btn {
  border-radius: 10px;
  color: rgba(248, 243, 233, .76);
}

.papyrus-tool-btn:hover,
.papyrus-size-btn:hover {
  background: rgba(255, 255, 255, .12);
  color: #fff7e8;
  transform: translateY(-1px);
}

.papyrus-tool-btn.active,
.papyrus-size-btn.active,
.papyrus-ai-tool {
  color: #ffd68c;
  background: rgba(216, 166, 79, .18);
  box-shadow: 0 0 0 1px rgba(216, 166, 79, .26), 0 8px 24px rgba(216, 166, 79, .12);
}

.papyrus-color-swatch {
  width: 24px;
  height: 24px;
  border-radius: 8px;
}

.papyrus-canvas-wrap {
  background:
    radial-gradient(720px 380px at 50% 24%, rgba(216, 166, 79, .11), transparent 70%),
    linear-gradient(135deg, rgba(255, 255, 255, .04), transparent),
    #090b10;
}

.papyrus-canvas-frame {
  border-radius: 8px;
  box-shadow: 0 40px 90px rgba(0, 0, 0, .52), 0 0 0 1px rgba(255, 255, 255, .1), inset 0 0 55px rgba(92, 58, 16, .08);
}

.papyrus-page-sidebar,
.papyrus-status-bar {
  background: rgba(8, 10, 14, .8);
  border-color: rgba(255, 255, 255, .1);
}

.papyrus-floating-ai {
  position: absolute;
  right: 22px;
  bottom: 42px;
  display: grid;
  gap: 10px;
  z-index: 12;
}

.papyrus-floating-ai button {
  border: 0;
  cursor: pointer;
  color: #1a1206;
  background: linear-gradient(135deg, #ffd98c, #c9892e);
}

@keyframes papyrusGlow {
  from { transform: translate3d(-1%, -1%, 0) scale(1); opacity: .82; }
  to { transform: translate3d(1.5%, 1%, 0) scale(1.03); opacity: 1; }
}

@media (max-width: 980px) {
  .papyrus-studio-home {
    margin: -16px;
    padding: 18px;
  }

  .papyrus-studio-hero {
    grid-template-columns: 1fr;
  }

  .papyrus-studio-shell {
    grid-template-columns: 1fr;
  }

  .papyrus-studio-preview {
    min-height: 260px;
  }

  .papyrus-editor-title {
    flex-basis: 100%;
  }
}

[data-theme="dark"] {
  /* Reines Schwarz-Theme — kein Blau-Tint mehr */
  --bg: #000000;
  --bg2: #050505;
  --surface: #0a0a0a;
  --card: #111111;
  --card2: #161616;
  --border: rgba(255, 255, 255, 0.08);
  --border2: rgba(255, 255, 255, 0.05);
  --text: #f5f5f5;
  --text2: #a3a3a3;
  --text3: #6b6b6b;
  --input-bg: #0a0a0a;
  --modal-bg: rgba(0, 0, 0, 0.85);
  --scrollbar: #1a1a1a;
}

[data-theme="light"] {
  --bg: #eef2ff;
  --bg2: #e1e8ff;
  --surface: #f5f7ff;
  --card: #ffffff;
  --card2: #f0f4ff;
  --border: rgba(37, 99, 235, 0.14);
  --border2: rgba(0, 0, 0, 0.06);
  --text: #0f172a;
  --text2: #475569;
  --text3: #94a3b8;
  --input-bg: #f0f4ff;
  --modal-bg: rgba(30, 50, 100, 0.45);
  --scrollbar: #c7d2fe;
}

[data-color="mono"] {
  /* Papyrus-Studio-Look: warmes Teal als Akzent */
  --accent: #14b8a6;
  --accent2: #0d9488;
  --accent-glow: rgba(20, 184, 166, 0.18);
  --accent-text: #0a0a0a;
}

/* ═══════════════════════════════════════════════════════════════
   PAPYRUS-STUDIO-DESIGN — global angewendet
   Pure schwarz · weiche Cards mit Backdrop-Blur · Teal-Akzent ·
   Pill-Buttons · große bold Headlines · ruhige Sekundärtexte.
   ═══════════════════════════════════════════════════════════════ */
[data-theme="dark"] {
  --bg: #0a0a0a;
  --bg2: #0a0a0a;
  --surface: #121212;
  --card: #121212;
  --card2: #1a1a1a;
  --border: rgba(255, 255, 255, 0.12);   /* etwas stärker für mehr Trennung */
  --border2: rgba(255, 255, 255, 0.08);
  --text: #ffffff;
  --text2: rgba(255, 255, 255, 0.82);    /* WAR 0.6 — jetzt deutlich heller */
  --text3: rgba(255, 255, 255, 0.62);    /* WAR 0.4 — jetzt noch gut lesbar */
  --input-bg: #1a1a1a;                   /* nicht mehr fast-schwarz */
  --modal-bg: rgba(0, 0, 0, 0.75);
  --scrollbar: #1a1a1a;
}

[data-theme="dark"] body,
[data-theme="dark"] html { background: #0a0a0a !important; }

/* — Cards im Papyrus-Studio-Stil — */
[data-theme="dark"] .card,
[data-theme="dark"] .pricing-card {
  background: rgba(18, 18, 18, 0.6) !important;
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.08) !important;
  border-radius: 24px !important;
  box-shadow: 0 20px 60px rgba(0, 0, 0, 0.35) !important;
}
[data-theme="dark"] .pricing-popular {
  border-color: rgba(20, 184, 166, 0.45) !important;
  box-shadow: 0 30px 80px rgba(20, 184, 166, 0.08), 0 20px 60px rgba(0, 0, 0, 0.4) !important;
}

/* — Buttons: Pill-Style überall — */
.btn,
[data-color="mono"] .btn,
[data-color="mono"] .btn-primary,
[data-color="mono"] .btn-secondary {
  border-radius: 9999px !important;
  font-weight: 700 !important;
  letter-spacing: 0.01em;
  transition: all 0.18s ease;
}

[data-color="mono"] .btn-primary {
  background: #14b8a6 !important;
  color: #0a0a0a !important;
  border: none;
  box-shadow: 0 10px 28px rgba(20, 184, 166, 0.22) !important;
}
[data-color="mono"] .btn-primary:hover {
  background: #0d9488 !important;
  transform: translateY(-1px);
  box-shadow: 0 14px 36px rgba(20, 184, 166, 0.32) !important;
}

[data-color="mono"] .btn-secondary,
[data-color="mono"] .btn-ghost {
  background: rgba(255, 255, 255, 0.04) !important;
  color: #fff !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  box-shadow: none !important;
}
[data-color="mono"] .btn-secondary:hover,
[data-color="mono"] .btn-ghost:hover {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: rgba(255, 255, 255, 0.3) !important;
}

/* — Inputs: schwarz mit dezenter Border, Teal beim Fokus — */
[data-theme="dark"] .form-input,
[data-theme="dark"] input:not([type="checkbox"]):not([type="radio"]),
[data-theme="dark"] textarea,
[data-theme="dark"] select {
  background: rgba(255, 255, 255, 0.03) !important;
  border: 1px solid rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
  border-radius: 12px !important;
}
[data-theme="dark"] .form-input:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus {
  border-color: #14b8a6 !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.12) !important;
}

/* — Sidebar pure schwarz — */
[data-theme="dark"] .sidebar,
[data-theme="dark"] aside {
  background: #0a0a0a !important;
  border-color: rgba(255, 255, 255, 0.06) !important;
}
[data-theme="dark"] .nav-item:hover {
  background: rgba(255, 255, 255, 0.05) !important;
}
[data-theme="dark"] .nav-item.active {
  background: rgba(20, 184, 166, 0.12) !important;
  color: #14b8a6 !important;
}

/* — Topbar / Header — */
[data-theme="dark"] .topbar,
[data-theme="dark"] header {
  background: rgba(10, 10, 10, 0.7) !important;
  backdrop-filter: blur(14px);
  border-color: rgba(255, 255, 255, 0.06) !important;
}

/* — Headlines im Papyrus-Studio-Stil — */
[data-theme="dark"] h1,
[data-theme="dark"] .page-title,
[data-theme="dark"] .pricing-title {
  color: #fff !important;
  font-weight: 800 !important;
  letter-spacing: -0.02em;
}

/* — Pills / Badges / Kicker (Papyrus-Studio-Look) — */
[data-color="mono"] .papyrus-ai-chip,
[data-color="mono"] .pricing-badge,
[data-color="mono"] .quiz-pill-on,
[data-color="mono"] .free-limit-badge,
[data-color="mono"] .pro-badge {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
  border: 1px solid rgba(20, 184, 166, 0.2) !important;
  font-weight: 700;
  letter-spacing: 0.06em;
}

/* — Sämtliche Cyan/Blau/Violett-Inline-Gradients zähmen → Teal — */
[data-theme="dark"] [style*="linear-gradient(135deg, #22d3ee"],
[data-theme="dark"] [style*="linear-gradient(135deg, #6366f1"],
[data-theme="dark"] [style*="linear-gradient(135deg, #3b82f6"],
[data-theme="dark"] [style*="linear-gradient(135deg,#22d3ee"],
[data-theme="dark"] [style*="linear-gradient(135deg, rgba(34, 211, 238"],
[data-theme="dark"] [style*="linear-gradient(135deg, rgba(99, 102, 241"] {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
}

/* — Papyrus AI / Write: monochrom + teal Akzente — */
[data-color="mono"] .papyrus-ai-avatar.ai,
[data-color="mono"] .papyrus-ai-hero-logo,
[data-color="mono"] .papyrus-ai-logo {
  background: #14b8a6 !important;
  color: #0a0a0a !important;
  box-shadow: 0 8px 24px rgba(20, 184, 166, 0.25);
}
[data-color="mono"] .papyrus-ai-avatar.user,
[data-color="mono"] .papyrus-ai-source-num {
  background: rgba(255, 255, 255, 0.1) !important;
  color: #fff !important;
  box-shadow: none;
}

[data-color="mono"] .papyrus-ai-hero-grad,
[data-color="mono"] .papyrus-write-aifb-head i.fa-wand-magic-sparkles {
  background: none !important;
  -webkit-background-clip: initial !important;
  background-clip: initial !important;
  color: #14b8a6 !important;
}

[data-color="mono"] .papyrus-ai-user-bubble,
[data-color="mono"] .papyrus-ai-message.user .papyrus-ai-bubble {
  background: rgba(20, 184, 166, 0.1) !important;
  border: 1px solid rgba(20, 184, 166, 0.25) !important;
  color: #fff !important;
}

[data-color="mono"] .papyrus-ai-tab.active {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
  box-shadow: none !important;
}

/* — Toggle-Switch im Teal — */
[data-color="mono"] .switch input:checked + .slider {
  background: #14b8a6 !important;
}

/* — Setup-Wizard — */
[data-color="mono"] .setup-step.active .setup-step-num {
  background: #14b8a6 !important;
  color: #0a0a0a !important;
  border-color: transparent !important;
  box-shadow: 0 0 0 4px rgba(20, 184, 166, 0.15) !important;
}
[data-color="mono"] .setup-step.done .setup-step-num {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
  border-color: rgba(20, 184, 166, 0.3) !important;
}
[data-color="mono"] .setup-type-card.active {
  border-color: #14b8a6 !important;
  background: rgba(20, 184, 166, 0.08) !important;
  box-shadow: 0 0 0 1px rgba(20, 184, 166, 0.3) !important;
}
[data-color="mono"] .setup-step-line.done {
  background: linear-gradient(to right, #14b8a6, rgba(20, 184, 166, 0.4)) !important;
}

/* — Action-Buttons / Toggle-Pills im Chat — */
[data-color="mono"] #papyrus-ai-web-btn.active,
[data-color="mono"] .papyrus-ai-actions button.active {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
  box-shadow: none !important;
}

/* — Quellen-Hover — */
[data-color="mono"] .papyrus-ai-source-chip:hover,
[data-color="mono"] .papyrus-ai-sources-btn:hover {
  background: rgba(20, 184, 166, 0.1) !important;
  border-color: #14b8a6 !important;
  color: #fff !important;
}

[data-color="mono"] .papyrus-ai-image-card:hover {
  border-color: #14b8a6 !important;
}

[data-color="mono"] .papyrus-ai-searching {
  background: rgba(20, 184, 166, 0.1) !important;
  border-color: rgba(20, 184, 166, 0.3) !important;
  color: #14b8a6 !important;
}

[data-color="mono"] .papyrus-ai-thread-icon {
  background: rgba(255, 255, 255, 0.05) !important;
  color: rgba(255, 255, 255, 0.6) !important;
}
[data-color="mono"] .papyrus-ai-thread.active .papyrus-ai-thread-icon {
  background: rgba(20, 184, 166, 0.15) !important;
  color: #14b8a6 !important;
}

/* — Scrollbars dezent grau — */
[data-theme="dark"] ::-webkit-scrollbar { width: 8px; height: 8px; }
[data-theme="dark"] ::-webkit-scrollbar-track { background: transparent; }
[data-theme="dark"] ::-webkit-scrollbar-thumb {
  background: rgba(255, 255, 255, 0.1);
  border-radius: 999px;
}
[data-theme="dark"] ::-webkit-scrollbar-thumb:hover {
  background: rgba(255, 255, 255, 0.2);
}

/* ═══════════════════════════════════════════════════════════════
   SCHUL-PROFIL (X-Style)
   ═══════════════════════════════════════════════════════════════ */
.school-profile {
  max-width: 820px;
  margin: 0 auto;
}
.sch-banner {
  height: 180px;
  border-radius: 20px 20px 0 0;
  position: relative;
  overflow: hidden;
}
.sch-header {
  position: relative;
  display: flex;
  justify-content: space-between;
  align-items: flex-end;
  padding: 0 24px;
  margin-top: -56px;
  z-index: 2;
}
.sch-logo {
  width: 112px;
  height: 112px;
  border-radius: 50%;
  background: #16181c;
  border: 4px solid #000;
  display: grid;
  place-items: center;
  overflow: hidden;
  flex-shrink: 0;
  box-shadow: 0 8px 24px rgba(0,0,0,0.4);
}
.sch-logo img { width: 100%; height: 100%; object-fit: cover; }
.sch-logo-initial {
  font-size: 3rem;
  font-weight: 900;
  color: #14b8a6;
}
.sch-edit-btn {
  margin-bottom: 12px;
}

.sch-info {
  padding: 18px 24px 14px;
}
.sch-name {
  margin: 0;
  font-size: 1.7rem;
  font-weight: 900;
  color: #fff;
  letter-spacing: -0.02em;
}
.sch-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 14px;
  margin-top: 10px;
  font-size: 0.86rem;
  color: var(--text2);
}
.sch-meta span { display: inline-flex; align-items: center; gap: 5px; }
.sch-meta i { color: var(--text3); }
.sch-bio {
  margin: 14px 0 0;
  line-height: 1.6;
  color: #fff;
  font-size: 0.96rem;
}
.sch-bio-empty { color: var(--text3); font-style: italic; }
.sch-socials {
  display: flex;
  gap: 8px;
  margin-top: 14px;
}
.sch-social {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  border: 1px solid var(--border);
  display: grid;
  place-items: center;
  color: var(--text2);
  text-decoration: none;
  transition: all 0.15s;
}
.sch-social:hover {
  background: rgba(20, 184, 166, 0.12);
  border-color: #14b8a6;
  color: #14b8a6;
  transform: translateY(-1px);
}

.sch-tabs {
  display: flex;
  border-bottom: 1px solid var(--border);
  padding: 0 24px;
  margin-top: 8px;
}
.sch-tab {
  background: transparent;
  border: 0;
  color: var(--text2);
  padding: 14px 18px;
  font-size: 0.92rem;
  font-weight: 700;
  cursor: pointer;
  position: relative;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  font-family: inherit;
  transition: color 0.15s;
}
.sch-tab:hover { color: #fff; background: rgba(255,255,255,0.03); }
.sch-tab.active { color: #fff; }
.sch-tab.active::after {
  content: '';
  position: absolute;
  left: 18px; right: 18px;
  bottom: -1px;
  height: 3px;
  background: #14b8a6;
  border-radius: 3px 3px 0 0;
}
.sch-tab-count {
  background: rgba(255,255,255,0.1);
  color: var(--text2);
  font-size: 0.72rem;
  padding: 1px 8px;
  border-radius: 999px;
}

.sch-tab-content {
  padding: 18px 24px 60px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

/* Composer */
.sch-composer { padding: 16px; }
.sch-composer-row { display: flex; gap: 12px; align-items: flex-start; }
.sch-composer textarea {
  flex: 1;
  background: transparent !important;
  border: 0 !important;
  outline: 0;
  color: #fff !important;
  font-size: 1rem !important;
  padding: 8px 0 !important;
  resize: none;
  min-height: 48px;
  font-family: inherit;
}
.sch-composer textarea::placeholder { color: var(--text3); }
.sch-composer-actions {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-top: 8px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}
.sch-compose-tool {
  background: transparent;
  border: 0;
  color: #14b8a6;
  width: 36px; height: 36px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 1.05rem;
  transition: background 0.15s;
}
.sch-compose-tool:hover { background: rgba(20,184,166,0.12); }
.sch-post-img-preview {
  display: flex; gap: 8px; align-items: center;
}
.sch-post-img-preview img { width: 60px; height: 60px; object-fit: cover; border-radius: 10px; }
.sch-post-img-preview button {
  width: 22px; height: 22px;
  border-radius: 50%;
  background: rgba(0,0,0,0.7);
  border: 0; color: #fff;
  cursor: pointer;
  font-size: 0.7rem;
}

/* Posts */
.sch-post { padding: 16px; }
.sch-post-head { display: flex; align-items: flex-start; gap: 12px; margin-bottom: 10px; }
.sch-post-author { font-weight: 700; color: #fff; }
.sch-post-time { font-size: 0.78rem; color: var(--text3); }
.sch-post-menu {
  background: transparent;
  border: 0;
  color: var(--text3);
  width: 32px; height: 32px;
  border-radius: 50%;
  cursor: pointer;
  transition: all 0.15s;
}
.sch-post-menu:hover { background: rgba(244,63,94,0.12); color: #f87171; }
.sch-post-body {
  font-size: 0.98rem;
  line-height: 1.55;
  color: #fff;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.sch-post-img {
  margin-top: 10px;
  border-radius: 14px;
  overflow: hidden;
  border: 1px solid var(--border);
}
.sch-post-img img { width: 100%; max-height: 520px; object-fit: cover; display: block; }
.sch-post-actions {
  display: flex; gap: 18px;
  margin-top: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--border);
}
.sch-post-actions button {
  background: transparent;
  border: 0;
  color: var(--text2);
  cursor: pointer;
  font-size: 0.86rem;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 6px 10px;
  border-radius: 999px;
  transition: all 0.15s;
  font-family: inherit;
}
.sch-post-actions button:hover { background: rgba(20,184,166,0.1); color: #14b8a6; }
.sch-post-actions button.liked { color: #f43f5e; }
.sch-post-actions button.liked:hover { background: rgba(244,63,94,0.1); }

/* About */
.sch-data-list { display: grid; gap: 4px; }
.sch-data-list > div {
  display: grid;
  grid-template-columns: 140px 1fr;
  gap: 12px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  font-size: 0.92rem;
}
.sch-data-list > div:last-child { border-bottom: 0; }
.sch-data-list strong { color: var(--text2); font-weight: 600; }
.sch-data-list span, .sch-data-list a { color: #fff; }
.sch-data-list a { text-decoration: none; }
.sch-data-list a:hover { color: #14b8a6; text-decoration: underline; }
.sch-data-list code {
  background: rgba(20,184,166,0.12);
  color: #14b8a6;
  padding: 2px 8px;
  border-radius: 6px;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.88em;
  letter-spacing: 0.05em;
}

/* Settings tab */
.sch-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 10px;
  margin-bottom: 18px;
}
.sch-setting-card {
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  border-radius: 14px;
  padding: 16px;
  text-align: left;
  cursor: pointer;
  transition: all 0.15s;
  display: flex;
  flex-direction: column;
  gap: 4px;
  color: #fff;
  font-family: inherit;
}
.sch-setting-card:hover {
  background: rgba(20,184,166,0.08);
  border-color: #14b8a6;
  transform: translateY(-1px);
}
.sch-setting-icon {
  width: 40px; height: 40px;
  border-radius: 12px;
  background: rgba(20,184,166,0.15);
  color: #14b8a6;
  display: grid;
  place-items: center;
  font-size: 1.05rem;
  margin-bottom: 6px;
}
.sch-setting-card strong { color: #fff; font-size: 0.95rem; }
.sch-setting-card small { color: var(--text2); font-size: 0.78rem; }

.sch-mode-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 14px;
  border-radius: 12px;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all 0.15s;
}
.sch-mode-row:hover { background: rgba(255,255,255,0.03); }
.sch-mode-row.on { background: rgba(20,184,166,0.08); border-color: #14b8a6; }
.sch-mode-row input { accent-color: #14b8a6; }
.sch-mode-row i { color: var(--text2); width: 18px; }
.sch-mode-row.on i { color: #14b8a6; }

/* Modal generic */
.modal-backdrop {
  position: fixed; inset: 0;
  background: rgba(0,0,0,0.75);
  z-index: 10000;
  display: grid;
  place-items: center;
  padding: 20px;
  backdrop-filter: blur(8px);
}
.modal {
  background: #16181c;
  border: 1px solid var(--border);
  border-radius: 22px;
  max-width: 560px;
  width: 100%;
  max-height: 90vh;
  overflow: hidden;
  display: flex;
  flex-direction: column;
}
.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 22px;
  border-bottom: 1px solid var(--border);
}
.modal-header h3 { margin: 0; font-size: 1.1rem; color: #fff; }
.modal-header button {
  background: transparent;
  border: 0;
  color: var(--text2);
  width: 32px; height: 32px;
  border-radius: 50%;
  cursor: pointer;
}
.modal-header button:hover { background: rgba(255,255,255,0.06); color: #fff; }
.modal-body { padding: 22px; overflow: auto; }
.modal-body h4 { color: #fff; font-size: 0.95rem; margin: 0 0 8px; }
.modal-footer {
  display: flex; gap: 10px;
  justify-content: flex-end;
  padding: 14px 22px;
  border-top: 1px solid var(--border);
}

@media (max-width: 680px) {
  .sch-meta { font-size: 0.8rem; gap: 10px; }
  .sch-name { font-size: 1.4rem; }
  .sch-logo { width: 88px; height: 88px; }
  .sch-header { margin-top: -44px; padding: 0 16px; }
  .sch-info, .sch-tab-content { padding-left: 16px; padding-right: 16px; }
  .sch-tabs { padding: 0 16px; }
}

/* ═══════════════════════════════════════════════════════════════
   ANWESENHEITS-CODE / QR / CHECK-IN
   ═══════════════════════════════════════════════════════════════ */
.att-code-box {
  background: rgba(20, 184, 166, 0.06);
  border: 1px solid rgba(20, 184, 166, 0.25);
  border-radius: 18px;
  padding: 16px 18px;
  margin-bottom: 12px;
}
.att-code-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  margin-bottom: 14px;
}
.att-code-label {
  font-weight: 700;
  color: #14b8a6;
  font-size: 0.94rem;
  margin-bottom: 4px;
}
.att-code-label i { margin-right: 6px; }
.att-code-help {
  color: var(--text2);
  font-size: 0.82rem;
}
.att-code-body {
  display: flex;
  gap: 22px;
  align-items: center;
  flex-wrap: wrap;
}
.att-code-qr {
  width: 200px;
  height: 200px;
  background: #000;
  border-radius: 14px;
  overflow: hidden;
  padding: 8px;
  flex-shrink: 0;
}
.att-code-qr img {
  width: 100%; height: 100%;
  display: block;
  border-radius: 8px;
}
.att-code-number {
  flex: 1;
  min-width: 180px;
}
.att-code-big {
  font-size: 3.4rem;
  font-weight: 900;
  letter-spacing: 0.18em;
  color: #fff;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  line-height: 1.1;
  text-shadow: 0 0 24px rgba(20, 184, 166, 0.5);
}
.att-code-meta {
  color: var(--text2);
  font-size: 0.86rem;
  margin-top: 8px;
}

/* Schüler-Checkin-Seite */
.checkin-page {
  display: flex;
  justify-content: center;
  padding: 40px 20px;
}
.checkin-card {
  max-width: 440px;
  width: 100%;
  padding: 32px;
}
.checkin-icon {
  width: 80px;
  height: 80px;
  margin: 0 auto 20px;
  border-radius: 24px;
  background: linear-gradient(135deg, rgba(20,184,166,0.2), rgba(20,184,166,0.05));
  display: grid;
  place-items: center;
  font-size: 2.4rem;
  color: #14b8a6;
  box-shadow: 0 12px 40px rgba(20,184,166,0.15);
}
.checkin-input {
  width: 100%;
  background: rgba(255,255,255,0.04);
  border: 2px solid rgba(255,255,255,0.1);
  border-radius: 16px;
  padding: 22px 16px;
  font-size: 2.2rem;
  font-weight: 800;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  letter-spacing: 0.4em;
  text-align: center;
  color: #fff;
  transition: all 0.2s;
}
.checkin-input:focus {
  outline: none;
  border-color: #14b8a6;
  background: rgba(20,184,166,0.06);
  box-shadow: 0 0 0 4px rgba(20,184,166,0.15);
}
.checkin-input::placeholder { color: rgba(255,255,255,0.2); letter-spacing: 0.4em; }

@media (max-width: 560px) {
  .att-code-body { justify-content: center; text-align: center; }
  .att-code-number { text-align: center; }
  .att-code-big { font-size: 2.6rem; letter-spacing: 0.14em; }
}

/* Check-in-Badge in der Manual-Liste */
.att-checkin-badge {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  margin-top: 4px;
  padding: 3px 9px;
  border-radius: 999px;
  background: rgba(20, 184, 166, 0.15);
  color: #14b8a6;
  border: 1px solid rgba(20, 184, 166, 0.3);
  font-size: 0.74rem;
  font-weight: 600;
  width: fit-content;
}
.att-checkin-badge i { font-size: 0.7rem; }

.student-row.has-checkin {
  background: rgba(20, 184, 166, 0.04) !important;
  border-left: 3px solid #14b8a6;
  padding-left: calc(var(--space, 12px) + 2px) !important;
}

/* Live-Liste im Code-Only-Modus */
.att-checkin-list {
  background: rgba(255, 255, 255, 0.02);
  border: 1px solid var(--border);
  border-radius: 14px;
  margin-top: 14px;
  overflow: hidden;
}
.att-checkin-list-head {
  padding: 10px 14px;
  border-bottom: 1px solid var(--border);
  font-size: 0.86rem;
  color: var(--text2);
}
.att-checkin-list-head i { color: #14b8a6; margin-right: 4px; }
.att-checkin-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--border2);
  transition: background 0.2s;
}
.att-checkin-row:last-child { border-bottom: 0; }
.att-checkin-row.checked {
  background: rgba(20, 184, 166, 0.06);
}
.att-checkin-name {
  flex: 1;
  font-weight: 600;
  color: var(--text);
}
.att-checkin-status-ok {
  color: #14b8a6;
  font-size: 0.85rem;
  font-weight: 600;
  display: inline-flex;
  align-items: center;
  gap: 5px;
}
.att-checkin-status-pending {
  color: var(--text3);
  font-size: 0.82rem;
  font-style: italic;
}

/* Schüler-Selbstbewertung: Button-Grid */
.checkin-rating-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(78px, 1fr));
  gap: 8px;
  margin-top: 6px;
}
.checkin-rating-btn {
  background: rgba(255, 255, 255, 0.04);
  border: 2px solid rgba(255, 255, 255, 0.12);
  border-radius: 12px;
  padding: 12px 8px;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 4px;
  cursor: pointer;
  transition: all 0.15s ease;
  color: var(--text);
  font-family: inherit;
}
.checkin-rating-btn:hover {
  border-color: var(--c, #14b8a6);
  background: rgba(255, 255, 255, 0.06);
  transform: translateY(-1px);
}
.checkin-rating-btn.on {
  border-color: var(--c, #14b8a6);
  background: color-mix(in srgb, var(--c, #14b8a6) 12%, transparent);
  box-shadow: 0 0 0 1px var(--c, #14b8a6);
}
.checkin-rating-btn .cr-val {
  font-size: 1.4rem;
  font-weight: 800;
  color: var(--c, #fff);
  line-height: 1;
}
.checkin-rating-btn .cr-label {
  font-size: 0.7rem;
  color: var(--text2);
  text-align: center;
  line-height: 1.2;
}

/* Attach-Menü-Buttons (Papyrus AI File-Picker) */
.attach-source-btn {
  display: flex;
  align-items: center;
  gap: 14px;
  width: 100%;
  padding: 14px 16px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.12);
  border-radius: 14px;
  cursor: pointer;
  text-align: left;
  transition: all 0.15s ease;
  color: #fff;
  font-family: inherit;
  margin-bottom: 6px;
}
.attach-source-btn:hover {
  background: rgba(20, 184, 166, 0.1);
  border-color: rgba(20, 184, 166, 0.4);
  transform: translateY(-1px);
}
.attach-source-btn > div {
  flex: 1;
  min-width: 0;
}
.attach-source-btn strong {
  display: block;
  color: #fff;
  font-size: 0.95rem;
  margin-bottom: 2px;
}
.attach-source-btn small {
  display: block;
  color: var(--text2);
  font-size: 0.78rem;
}
.attach-source-btn > i:first-child {
  font-size: 1.2rem;
  flex-shrink: 0;
  width: 22px;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   AVV — Auftragsverarbeitungsvertrag Anzeige
   ═══════════════════════════════════════════════════════════════ */
.avv-page {
  max-width: 820px;
  margin: 24px auto;
  padding: 56px 60px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 18px;
  color: rgba(255, 255, 255, 0.92);
  line-height: 1.65;
  font-size: 0.96rem;
}

.avv-header { text-align: center; border-bottom: 2px solid rgba(255, 255, 255, 0.18); padding-bottom: 20px; margin-bottom: 28px; }
.avv-meta { display: flex; justify-content: space-between; font-size: 0.78rem; color: var(--text-3); margin-bottom: 16px; }
.avv-title { font-size: 2rem; font-weight: 800; letter-spacing: -0.02em; color: #fff; margin: 0 0 8px; }
.avv-subtitle { color: var(--text-2); font-size: 0.95rem; }

.avv-parties {
  display: grid; grid-template-columns: 1fr 1fr; gap: 18px;
  margin: 24px 0 36px;
}
.avv-party {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 12px;
  padding: 16px 18px;
}
.avv-party-label { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-3); margin-bottom: 6px; font-weight: 600; }
.avv-party-name { font-weight: 700; color: #fff; margin-bottom: 6px; font-size: 1.02rem; }
.avv-party-addr { font-size: 0.88rem; color: rgba(255, 255, 255, 0.78); line-height: 1.5; }
.avv-party-role { font-style: italic; color: var(--text-3); font-size: 0.82rem; margin-top: 8px; }

.avv-h {
  font-size: 1.15rem;
  font-weight: 700;
  margin: 28px 0 12px;
  color: #fff;
  padding-bottom: 6px;
  border-bottom: 1px solid rgba(255, 255, 255, 0.12);
}
.avv-page p { margin: 0 0 12px; color: rgba(255, 255, 255, 0.85); }
.avv-page ul { margin: 0 0 16px; padding-left: 24px; }
.avv-page li { margin: 5px 0; color: rgba(255, 255, 255, 0.85); }
.avv-page strong { color: #fff; }

.avv-table {
  width: 100%;
  border-collapse: collapse;
  margin: 14px 0 24px;
  font-size: 0.9rem;
}
.avv-table th, .avv-table td {
  border: 1px solid rgba(255, 255, 255, 0.12);
  padding: 10px 12px;
  text-align: left;
}
.avv-table th { background: rgba(255, 255, 255, 0.05); color: #fff; font-weight: 700; }
.avv-table td { color: rgba(255, 255, 255, 0.85); }

.avv-signatures {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
  margin-top: 60px; padding-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.12);
}
.avv-sig-line { height: 1px; background: rgba(255, 255, 255, 0.4); margin-bottom: 8px; }
.avv-sig-role { font-size: 0.72rem; text-transform: uppercase; letter-spacing: 0.08em; color: var(--text-3); font-weight: 700; }
.avv-sig-name { font-weight: 600; color: #fff; margin: 4px 0 14px; }
.avv-sig-date { font-size: 0.88rem; color: rgba(255, 255, 255, 0.7); }

.avv-footer {
  margin-top: 32px;
  padding-top: 16px;
  border-top: 1px solid rgba(255, 255, 255, 0.1);
  display: flex; justify-content: space-between;
  font-size: 0.78rem; color: var(--text-3);
  flex-wrap: wrap; gap: 8px;
}

@media (max-width: 720px) {
  .avv-page { padding: 32px 24px; }
  .avv-parties, .avv-signatures { grid-template-columns: 1fr; }
}

/* Pro-Nag-Banner (für Schüler/Lehrer wenn sie selbst Pro kaufen müssen) */
.pro-nag-banner {
  margin: 14px 18px 8px;
  padding: 14px 18px;
  border-radius: 14px;
  background: linear-gradient(135deg, rgba(251, 191, 36, 0.12), rgba(244, 63, 94, 0.06));
  border: 1px solid rgba(251, 191, 36, 0.3);
  display: flex; align-items: center; gap: 14px;
}
.pro-nag-icon {
  width: 44px; height: 44px;
  border-radius: 12px;
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  color: #0a0a0a;
  display: grid; place-items: center;
  font-size: 1.15rem;
  flex-shrink: 0;
}
.pro-nag-text { flex: 1; min-width: 0; }
.pro-nag-text strong { display: block; color: #fff; font-size: 0.96rem; }
.pro-nag-text span { display: block; color: rgba(255,255,255,0.75); font-size: 0.84rem; margin-top: 2px; }
.pro-nag-actions { display: flex; align-items: center; gap: 8px; flex-shrink: 0; }
.pro-nag-close {
  background: transparent;
  border: 0;
  color: rgba(255,255,255,0.5);
  width: 32px; height: 32px;
  border-radius: 8px;
  cursor: pointer;
  font-size: 14px;
}
.pro-nag-close:hover { background: rgba(255,255,255,0.08); color: #fff; }
@media (max-width: 720px) {
  .pro-nag-banner { flex-direction: column; align-items: stretch; }
}

/* ═══════════════════════════════════════════════════════════════
   SPEICHER-WIDGET
   ═══════════════════════════════════════════════════════════════ */
.storage-widget {
  padding: 18px 20px;
}
.storage-widget-locked {
  display: flex;
  align-items: center;
  gap: 8px;
  color: var(--text2);
  font-size: 0.9rem;
  padding: 16px 20px;
}
.storage-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-weight: 600;
  margin-bottom: 10px;
  font-size: 0.95rem;
}
.storage-size {
  font-size: 0.85rem;
  font-weight: 400;
}
.storage-bar-bg {
  height: 8px;
  background: var(--bg3, rgba(255,255,255,0.07));
  border-radius: 99px;
  overflow: hidden;
  margin-bottom: 8px;
}
.storage-bar-fill {
  height: 100%;
  border-radius: 99px;
  transition: width 0.4s ease;
}
.storage-info {
  display: flex;
  justify-content: space-between;
  font-size: 0.83rem;
  color: var(--text2);
  margin-bottom: 4px;
  flex-wrap: wrap;
  gap: 4px;
}
.storage-addon-info {
  font-size: 0.82rem;
  color: var(--text2);
  margin-top: 6px;
  display: flex;
  align-items: center;
  gap: 5px;
}
.mt-8 { margin-top: 8px; }

/* ═══════════════════════════════════════════════════════════════
   LOGIN-MODUS-TABS (Passwort / Code)
   ═══════════════════════════════════════════════════════════════ */
.login-mode-tabs {
  display: flex;
  gap: 6px;
  margin-bottom: 18px;
  padding: 4px;
  background: var(--bg2, rgba(255,255,255,0.04));
  border-radius: 10px;
}
.login-mode-tab {
  flex: 1;
  padding: 10px 8px;
  background: transparent;
  border: 0;
  border-radius: 8px;
  color: var(--text2);
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 7px;
  transition: all 0.2s;
}
.login-mode-tab:hover {
  background: rgba(255,255,255,0.04);
  color: var(--text1);
}
.login-mode-tab.active {
  background: var(--accent);
  color: #000;
}
.login-code-input {
  font-size: 1.5rem !important;
  letter-spacing: 0.4em !important;
  text-align: center;
  font-family: ui-monospace, Menlo, Consolas, monospace !important;
  font-weight: 700;
}

/* ═══════════════════════════════════════════════════════════════
   DATEI-VIEWER (openFilePreview)
   ═══════════════════════════════════════════════════════════════ */
.fpv-body {
  padding: 0 !important;
  min-height: 300px;
  display: flex;
  flex-direction: column;
}
.fpv-loading {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px;
  gap: 12px;
  color: var(--text2);
}
/* Bilder */
.fpv-image-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--bg2);
  padding: 16px;
  overflow: auto;
}
.fpv-image {
  max-width: 100%;
  max-height: 82vh;
  width: auto;
  height: auto;
  object-fit: contain;
  border-radius: 6px;
  cursor: zoom-in;
  transition: transform 0.25s ease, max-height 0.25s ease;
  display: block;
  margin: 0 auto;
}
.fpv-image.fpv-image-zoom {
  max-width: none;
  max-height: none;
  cursor: zoom-out;
  transform: scale(1);
}
.fpv-image-wrap {
  overflow: auto;
}
.fpv-hint {
  margin-top: 8px;
  font-size: 0.78rem;
  color: var(--text3);
}
/* PDF / Office iframe */
.fpv-embed {
  width: 100%;
  height: 78vh;
  border: none;
  display: block;
  border-radius: 0 0 var(--radius) var(--radius);
}
/* Eigener PDF-Viewer (pdf.js) – keine native Browser-Leiste */
.fpv-pdf-scroll {
  width: 100%;
  height: 78vh;
  overflow: auto;
  background: #1f232b;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 16px;
  padding: 20px;
}
.fpv-pdf-page {
  width: 100%;
  max-width: 780px;
  height: auto;
  background: #fff;
  box-shadow: 0 8px 28px rgba(0, 0, 0, .45);
  border-radius: 2px;
}
/* DOCX HTML-Inhalt */
.fpv-docx {
  padding: 24px 32px;
  max-width: 800px;
  margin: 0 auto;
  width: 100%;
  line-height: 1.65;
  font-size: 0.95rem;
  color: var(--text1);
  overflow-y: auto;
  max-height: 75vh;
}
.fpv-docx h1, .fpv-docx h2, .fpv-docx h3 {
  margin: 1.2em 0 0.5em;
  color: var(--text1);
}
.fpv-docx p { margin: 0.5em 0; }
.fpv-docx table {
  border-collapse: collapse;
  width: 100%;
  margin: 12px 0;
  font-size: 0.88rem;
}
.fpv-docx td, .fpv-docx th {
  border: 1px solid var(--border);
  padding: 6px 10px;
}
.fpv-docx th { background: var(--bg2); font-weight: 700; }
/* Text */
.fpv-text {
  padding: 20px 24px;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.85rem;
  line-height: 1.6;
  color: var(--text1);
  white-space: pre-wrap;
  word-break: break-word;
  overflow-y: auto;
  max-height: 75vh;
  margin: 0;
  background: var(--bg2);
}
/* Video */
.fpv-media-wrap {
  flex: 1;
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000;
  padding: 12px;
}
.fpv-video {
  max-width: 100%;
  max-height: 72vh;
  border-radius: 6px;
}
/* Audio */
.fpv-audio-wrap {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  text-align: center;
}
/* Fallback / Office-Karte */
.fpv-fallback {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 40px 20px;
  text-align: center;
}
.fpv-fallback h3 {
  margin: 0 0 8px;
  font-size: 1.05rem;
}
.viewer-icon {
  font-size: 1.1rem;
  flex-shrink: 0;
}

.admin-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 8px;
  border-radius: 999px;
  background: rgba(251, 191, 36, 0.15);
  color: #fbbf24;
  border: 1px solid rgba(251, 191, 36, 0.3);
  font-size: 0.68rem;
  font-weight: 700;
  letter-spacing: 0.04em;
  text-transform: uppercase;
}
.admin-pill i { font-size: 0.7rem; }

/* ═══════════════════════════════════════════════════════════════
   LEGAL-SEITEN (Impressum, Datenschutz, AGB, Widerruf, Lizenz)
   ═══════════════════════════════════════════════════════════════ */
.legal-page {
  max-width: 820px;
  padding: 16px 4px 60px;
  line-height: 1.7;
  color: rgba(255, 255, 255, 0.78);
}
.legal-page h2 {
  font-size: 1.35rem;
  font-weight: 800;
  color: #fff;
  margin: 32px 0 12px;
  letter-spacing: -0.01em;
}
.legal-page h2:first-child { margin-top: 0; }
.legal-page h3 {
  font-size: 1.05rem;
  font-weight: 700;
  color: #fff;
  margin: 24px 0 8px;
}
.legal-page p { margin: 0 0 12px; }
.legal-page ul { margin: 0 0 16px; padding-left: 22px; }
.legal-page li { margin: 6px 0; }
.legal-page a { color: #14b8a6; text-decoration: none; transition: color 0.15s; }
.legal-page a:hover { color: #2dd4bf; text-decoration: underline; }
.legal-page strong { color: #fff; }
.legal-page code {
  background: rgba(255, 255, 255, 0.06);
  padding: 1px 6px;
  border-radius: 4px;
  font-size: 0.88em;
}
.legal-intro {
  background: rgba(20, 184, 166, 0.08);
  border-left: 3px solid #14b8a6;
  padding: 14px 16px;
  border-radius: 0 12px 12px 0;
  margin-bottom: 24px !important;
  color: #fff;
}

/* ── Global Footer mit Legal-Links (Login / Register / Landing) ── */
.legal-footer {
  width: 100%;
  margin-top: 40px;
  padding: 18px 20px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.legal-footer-inner {
  max-width: 820px;
  margin: 0 auto;
  display: flex;
  justify-content: space-between;
  align-items: center;
  flex-wrap: wrap;
  gap: 14px;
  font-size: 0.8rem;
  color: rgba(255, 255, 255, 0.4);
}
.legal-footer-nav {
  display: flex;
  gap: 18px;
  flex-wrap: wrap;
}
.legal-footer-nav a {
  color: rgba(255, 255, 255, 0.55);
  cursor: pointer;
  text-decoration: none;
  transition: color 0.15s;
}
.legal-footer-nav a:hover {
  color: #14b8a6;
}

/* ── Mini-Legal-Links in der Sidebar ── */
.sidebar-legal-links {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  padding: 10px 14px 4px;
  font-size: 0.72rem;
  border-top: 1px solid rgba(255, 255, 255, 0.05);
  margin-top: 8px;
}
.sidebar-legal-links a {
  color: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  text-decoration: none;
}
.sidebar-legal-links a:hover { color: #14b8a6; }

/* ═══════════════════════════════════════════════════════════════
   COOKIE-BANNER
   ═══════════════════════════════════════════════════════════════ */
#cookie-banner {
  position: fixed;
  bottom: 16px;
  left: 50%;
  transform: translateX(-50%);
  z-index: 9999;
  max-width: 720px;
  width: calc(100% - 32px);
  background: rgba(18, 18, 18, 0.95);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 20px;
  padding: 16px 20px;
  box-shadow: 0 30px 80px rgba(0, 0, 0, 0.6);
  display: flex;
  align-items: center;
  gap: 18px;
  animation: cookie-slide-up 0.4s ease;
}
@keyframes cookie-slide-up {
  from { opacity: 0; transform: translate(-50%, 40px); }
  to   { opacity: 1; transform: translate(-50%, 0); }
}
.cookie-banner-text {
  flex: 1;
  font-size: 0.88rem;
  line-height: 1.5;
  color: rgba(255, 255, 255, 0.78);
}
.cookie-banner-text a {
  color: #14b8a6;
  cursor: pointer;
  text-decoration: none;
}
.cookie-banner-text a:hover { text-decoration: underline; }
.cookie-banner-text strong { color: #fff; }

@media (max-width: 600px) {
  #cookie-banner { flex-direction: column; align-items: stretch; text-align: center; }
}

[data-color="blue"] {
  --accent: #3b82f6;
  --accent2: #1d4ed8;
  --accent-glow: rgba(59, 130, 246, 0.22);
}

[data-color="purple"] {
  --accent: #8b5cf6;
  --accent2: #6d28d9;
  --accent-glow: rgba(139, 92, 246, 0.22);
}

[data-color="green"] {
  --accent: #10b981;
  --accent2: #047857;
  --accent-glow: rgba(16, 185, 129, 0.22);
}

[data-color="red"] {
  --accent: #ef4444;
  --accent2: #b91c1c;
  --accent-glow: rgba(239, 68, 68, 0.22);
}

[data-color="orange"] {
  --accent: #f97316;
  --accent2: #c2410c;
  --accent-glow: rgba(249, 115, 22, 0.22);
}

[data-color="cyan"] {
  --accent: #06b6d4;
  --accent2: #0e7490;
  --accent-glow: rgba(6, 182, 212, 0.22);
}

[data-color="pink"] {
  --accent: #ec4899;
  --accent2: #be185d;
  --accent-glow: rgba(236, 72, 153, 0.22);
}

[data-color="teal"] {
  --accent: #14b8a6;
  --accent2: #0f766e;
  --accent-glow: rgba(20, 184, 166, 0.22);
}

[data-color="indigo"] {
  --accent: #6366f1;
  --accent2: #4338ca;
  --accent-glow: rgba(99, 102, 241, 0.22);
}

[data-color="amber"] {
  --accent: #f59e0b;
  --accent2: #b45309;
  --accent-glow: rgba(245, 158, 11, 0.22);
}

*,
*::before,
*::after {
  box-sizing: border-box;
  margin: 0;
  padding: 0;
}

html {
  height: 100%;
}

body {
  font-family: var(--font);
  background: var(--bg, var(--bg));
  color: var(--text);
  min-height: 100%;
  -webkit-font-smoothing: antialiased;
}

#app {
  min-height: 100vh;
}

a {
  color: var(--accent);
  text-decoration: none;
}

button {
  font-family: var(--font);
  cursor: pointer;
  border: none;
  outline: none;
}

input,
textarea,
select {
  font-family: var(--font);
}

/* Dropdown-Optionen lesbar machen (sonst weiß-auf-weiß und unleserlich) */
select option,
.form-input option {
  background-color: #141a2e;
  color: #ffffff;
}
[data-theme="light"] select option,
[data-theme="light"] .form-input option {
  background-color: #ffffff;
  color: #111111;
}

ul {
  list-style: none;
}

::-webkit-scrollbar {
  width: 6px;
  height: 6px;
}

::-webkit-scrollbar-track {
  background: transparent;
}

::-webkit-scrollbar-thumb {
  background: var(--scrollbar);
  border-radius: 10px;
}

/* ── Music Wave Animation ────────────────── */
.nav-item-player {
  background: rgba(255,255,255,0.03);
  border: 1px solid rgba(255,255,255,0.06);
  margin: 8px 0;
  transition: all 0.3s ease;
}
.nav-item-player:hover {
  background: rgba(255,255,255,0.08);
  border-color: var(--accent);
}
.music-wave {
  display: inline-flex;
  align-items: flex-end;
  gap: 3px;
  height: 24px;
  margin-left: auto;
  padding: 4px 6px;
  border-radius: 6px;
  cursor: pointer;
  transition: all 0.2s ease;
}
.music-wave:hover {
  background: rgba(255,255,255,0.1);
  transform: scale(1.1);
}
.music-wave span {
  width: 3px;
  background: var(--accent);
  border-radius: 3px;
  height: 25%;
  box-shadow: 0 0 10px var(--accent-glow);
  transition: height 0.12s cubic-bezier(0.175, 0.885, 0.32, 1.275);
}
.music-wave span:nth-child(1) { height: var(--h1, 40%); background: #3b82f6; }
.music-wave span:nth-child(2) { height: var(--h2, 80%); background: #8b5cf6; }
.music-wave span:nth-child(3) { height: var(--h3, 30%); background: #06b6d4; }
.music-wave span:nth-child(4) { height: var(--h4, 60%); background: #10b981; }
.music-wave span:nth-child(5) { height: var(--h5, 50%); background: #ec4899; }
@keyframes musicWaveStatic {
  0% { transform: scaleY(0.9); }
  100% { transform: scaleY(1.1); }
}

/* ── Marketplace Store ───────────────────────── */
.mp-coin-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(245, 158, 11, 0.1);
  color: #f59e0b;
  padding: 6px 12px;
  border-radius: 20px;
  font-weight: 700;
  font-size: 0.9rem;
  border: 1px solid rgba(245, 158, 11, 0.2);
  box-shadow: 0 0 15px rgba(245, 158, 11, 0.1);
}
.mp-price {
  font-weight: 800;
  color: #f59e0b;
  display: flex;
  align-items: center;
  gap: 4px;
}
.mp-card.owned {
  border: 1px solid #10b98155;
  background: rgba(16, 185, 129, 0.02);
}
.mp-publish-btn {
  background: linear-gradient(135deg, var(--accent), #8b5cf6);
  color: white;
  border: none;
  padding: 8px 16px;
  border-radius: 8px;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 8px;
  transition: transform 0.2s, box-shadow 0.2s;
}
.mp-publish-btn:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 15px var(--accent-glow);
}


/* ── Splash ──────────────────────────────────── */
.splash {
  position: fixed;
  inset: 0;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 32px;
  background: var(--bg);
  z-index: 9999;
  animation: splashFade 0.4s ease 1.5s forwards;
}

.splash-logo {
  display: flex;
  align-items: center;
  gap: 14px;
  font-size: 2.4rem;
  font-weight: 800;
  letter-spacing: -1px;
  color: var(--text);
  animation: scaleIn 0.6s cubic-bezier(0.34, 1.56, 0.64, 1) both;
}

.splash-dots {
  display: flex;
  gap: 8px;
}

.splash-dots span {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.3;
  animation: dotPulse 1.2s ease-in-out infinite;
}

.splash-dots span:nth-child(2) {
  animation-delay: 0.2s;
}

.splash-dots span:nth-child(3) {
  animation-delay: 0.4s;
}

/* ── Auth ────────────────────────────────────── */
.auth-page {
  min-height: 100vh;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 24px;
  background: var(--bg);
  position: relative;
  overflow: hidden;
}
/* Footer im Auth-Layout drückt die Karte nicht mehr zur Seite */
.auth-page > .legal-footer {
  width: 100%;
  margin-top: auto;
  padding-top: 30px;
  border-top: 1px solid rgba(255, 255, 255, 0.06);
}
.auth-page > .auth-card {
  margin: auto;
}

.auth-bg-orb {
  position: absolute;
  border-radius: 50%;
  filter: blur(80px);
  pointer-events: none;
  animation: orbFloat 8s ease-in-out infinite alternate;
}

.auth-bg-orb-1 {
  width: 500px;
  height: 500px;
  top: -200px;
  right: -150px;
  background: var(--accent-glow);
}

.auth-bg-orb-2 {
  width: 350px;
  height: 350px;
  bottom: -100px;
  left: -100px;
  background: var(--accent-glow);
  animation-delay: -4s;
}

.auth-card {
  width: 100%;
  max-width: 440px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 40px;
  position: relative;
  z-index: 1;
  box-shadow: var(--shadow-lg);
  animation: slideUp 0.5s cubic-bezier(0.4, 0, 0.2, 1) both;
}

.auth-logo {
  display: flex;
  align-items: center;
  gap: 12px;
  font-size: 1.6rem;
  font-weight: 800;
  letter-spacing: -0.5px;
  color: var(--text);
  margin-bottom: 32px;
}

.auth-title {
  font-size: 1.5rem;
  font-weight: 700;
  margin-bottom: 6px;
}

.auth-sub {
  color: var(--text2);
  font-size: 0.9rem;
  margin-bottom: 28px;
}

.role-cards {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 24px;
}

.role-card {
  background: var(--card);
  border: 2px solid var(--border2);
  border-radius: var(--radius);
  padding: 16px 10px;
  text-align: center;
  cursor: pointer;
  transition: var(--transition);
}

.role-card:hover {
  border-color: var(--accent);
  transform: translateY(-2px);
}

.role-card.active {
  border-color: var(--accent);
  background: var(--accent-glow);
  box-shadow: 0 0 0 4px var(--accent-glow);
}

.role-card .role-icon {
  font-size: 1.6rem;
  margin-bottom: 8px;
}

.role-card .role-label {
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text2);
}

.role-card.active .role-label {
  color: var(--accent);
}

/* ── Register Wizard ── */

/* Step indicator */
.reg-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 28px;
}

.reg-step-dot {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.72rem;
  font-weight: 800;
  border: 2px solid var(--border2);
  color: var(--text3);
  background: var(--card);
  transition: all 0.3s ease;
  flex-shrink: 0;
}

.reg-step-dot.active {
  border-color: var(--accent);
  color: #fff;
  background: var(--accent);
  box-shadow: 0 0 0 4px var(--accent-glow), 0 0 16px var(--accent-glow);
}

.reg-step-dot.done {
  border-color: var(--accent);
  background: var(--accent);
  color: #fff;
}

.reg-step-line {
  flex: 1;
  height: 2px;
  background: var(--border);
  margin: 0 8px;
  max-width: 60px;
  transition: background 0.3s;
}

.reg-step-line.done {
  background: var(--accent);
}

/* Selection cards */
.reg-big-cards {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 10px;
  margin: 20px 0 14px;
}

.reg-big-card {
  position: relative;
  background: var(--card);
  border: 2px solid var(--border2);
  border-radius: 16px;
  padding: 22px 8px 18px;
  text-align: center;
  cursor: pointer;
  transition: all 0.2s cubic-bezier(0.4, 0, 0.2, 1);
  user-select: none;
}

.reg-big-card:hover {
  border-color: var(--accent);
  background: var(--card2);
  transform: translateY(-3px);
  box-shadow: 0 10px 28px rgba(0, 0, 0, 0.22);
}

.reg-big-card.active {
  border-color: var(--accent);
  background: var(--accent-glow);
  transform: translateY(-2px);
  box-shadow: 0 0 0 3px var(--accent-glow), 0 8px 20px rgba(0, 0, 0, 0.18);
}

/* Selection indicator ring */
.reg-big-card::before {
  content: '';
  position: absolute;
  top: 8px;
  right: 8px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  border: 2px solid var(--border2);
  background: var(--bg2);
  transition: all 0.2s;
}

.reg-big-card.active::before {
  background: var(--accent);
  border-color: var(--accent);
  box-shadow: 0 0 8px var(--accent-glow);
}

/* Checkmark inside ring */
.reg-big-card.active::after {
  content: '';
  position: absolute;
  top: 12px;
  right: 13px;
  width: 4px;
  height: 7px;
  border-right: 2px solid #fff;
  border-bottom: 2px solid #fff;
  transform: rotate(45deg);
}

.reg-big-icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
  line-height: 1;
  display: block;
  transition: transform 0.2s;
}

.reg-big-card:hover .reg-big-icon {
  transform: scale(1.12);
}

.reg-big-card.active .reg-big-icon {
  transform: scale(1.06);
}

.reg-big-name {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
  letter-spacing: 0.01em;
  transition: color 0.2s;
}

.reg-big-card.active .reg-big-name {
  color: var(--accent);
}

.reg-step-sub {
  color: var(--text2);
  font-size: 0.85rem;
  margin-bottom: 22px;
  margin-top: 2px;
}

/* Back button */
.btn-back {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: none;
  border: none;
  color: var(--text2);
  font-size: 0.84rem;
  font-family: var(--font);
  cursor: pointer;
  padding: 8px 0;
  margin-top: 6px;
  transition: color 0.2s;
  width: 100%;
  justify-content: center;
}

.btn-back:hover {
  color: var(--text);
}

/* Context badge in sidebar */
.ctx-badge {
  display: inline-block;
  font-size: 0.65rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
  background: var(--accent-glow);
  color: var(--accent);
  border: 1px solid var(--accent);
  margin-left: 6px;
  vertical-align: middle;
  letter-spacing: 0.04em;
}

/* ── Pricing Page ── */
.pricing-page {
  max-width: 1100px;
  margin: 0 auto;
  padding: 8px 0 48px;
}

.pricing-hero {
  text-align: center;
  padding: 32px 24px 24px;
}

.pricing-logo {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  font-size: 1.3rem;
  font-weight: 800;
  margin-bottom: 20px;
}

.pricing-title {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  margin-bottom: 12px;
}

.pricing-sub {
  color: var(--text2);
  font-size: 1rem;
  line-height: 1.6;
  max-width: 520px;
  margin: 0 auto;
}

.pricing-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(230px, 1fr));
  gap: 18px;
  padding: 8px 0 24px;
}

.pricing-card {
  position: relative;
  background: var(--card);
  border: 1.5px solid var(--border);
  border-radius: 20px;
  padding: 28px 22px 24px;
  display: flex;
  flex-direction: column;
  gap: 0;
  transition: transform 0.2s, box-shadow 0.2s;
}

.pricing-card:hover {
  transform: translateY(-4px);
  box-shadow: 0 16px 40px rgba(0, 0, 0, 0.22);
}

.pricing-popular {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow), 0 12px 36px rgba(0, 0, 0, 0.2);
  background: linear-gradient(160deg, var(--card) 60%, var(--accent-glow) 100%);
}

.pricing-badge {
  position: absolute;
  top: -13px;
  left: 50%;
  transform: translateX(-50%);
  background: var(--accent);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 800;
  padding: 4px 14px;
  border-radius: 20px;
  white-space: nowrap;
  letter-spacing: 0.04em;
  box-shadow: 0 4px 14px var(--accent-glow);
}

.pricing-icon {
  font-size: 2.2rem;
  margin-bottom: 10px;
}

.pricing-name {
  font-size: 1.2rem;
  font-weight: 800;
  margin-bottom: 4px;
}

.pricing-for {
  font-size: 0.78rem;
  color: var(--text2);
  margin-bottom: 18px;
  line-height: 1.4;
}

.pricing-price {
  margin-bottom: 18px;
}

.pricing-amount {
  font-size: 2.6rem;
  font-weight: 900;
  letter-spacing: -0.04em;
}

.pricing-period {
  font-size: 0.82rem;
  color: var(--text2);
  margin-left: 4px;
}

.pricing-divider {
  height: 1px;
  background: var(--border);
  margin-bottom: 18px;
}

.pricing-features {
  list-style: none;
  padding: 0;
  margin: 0 0 24px;
  display: flex;
  flex-direction: column;
  gap: 9px;
  flex: 1;
}

.pricing-feat {
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 0.83rem;
  color: var(--text);
}

.pricing-feat i {
  width: 14px;
  flex-shrink: 0;
}

.pricing-feat-no {
  color: var(--text3);
}

.pricing-footer {
  text-align: center;
  color: var(--text3);
  font-size: 0.78rem;
  margin-top: 8px;
}

.ai-hero-card {
  background: linear-gradient(145deg, var(--card) 10%, rgba(59, 130, 246, 0.12) 100%);
}

.ramses-hero-card {
  height: calc(100vh - 110px);
  grid-template-columns: minmax(0, 1fr);
  padding: 18px;
  background: #ffffff !important;
  border-radius: 8px;
  border: 2px solid rgba(0,0,0,0.12) !important;
  box-shadow: none !important;
  line-height: 1.65;
  margin-bottom: 14px;
}
  display: none !important;
  width: 0 !important;
  min-width: 0 !important;
  margin-bottom: 10px;
}

  min-height: calc(100vh - 146px) !important;
  background: #ffffff !important;
  color: #000000 !important;
  border-radius: 8px !important;
  overflow: visible !important;
  border: 2px solid rgba(0,0,0,0.12) !important;
  position: relative !important;
  z-index: 10000 !important;

.ai-hero-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.14);
  border: 1px solid rgba(59, 130, 246, 0.28);
}

.ramses-badge {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  padding: 6px 10px;
  border-radius: 999px;
  font-size: 0.76rem;
  font-weight: 800;
  color: #93c5fd;
  background: rgba(59, 130, 246, 0.12);
  border: 1px solid rgba(59, 130, 246, 0.25);
}

.ai-provider-grid,
.ai-task-grid {
  display: grid;
  gap: 14px;
}

.ai-provider-grid {
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
}

.ai-task-grid {
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
}

.ai-provider-card,
.ai-task-card {
  background: var(--card2);
  border: 1px solid var(--border2);
  border-radius: 16px;
  padding: 16px;
}

.ai-provider-name {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 1rem;
  font-weight: 800;
  margin-bottom: 6px;
}

.ai-provider-desc,
.ai-task-desc,
.ai-task-meta {
  color: var(--text2);
  font-size: 0.84rem;
  line-height: 1.55;
}

.ai-task-head {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 10px;
  margin-bottom: 10px;
}

.ai-task-title {
  font-size: 0.95rem;
  font-weight: 800;
  margin-bottom: 4px;
}

.ai-task-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 12px;
  margin-bottom: 10px;
}

.ai-pill,
.ai-chip {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 999px;
  font-size: 0.74rem;
  font-weight: 700;
}

.ai-pill {
  padding: 6px 10px;
  border: 1px solid var(--border2);
  white-space: nowrap;
}

.ai-chip-row {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.ai-chip {
  padding: 5px 9px;
  color: var(--text2);
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid var(--border2);
}

.ai-config-card .settings-title {
  margin-bottom: 6px;
}

.ai-step-list {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.ai-step {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  color: var(--text);
  line-height: 1.55;
}

.ai-step span {
  width: 28px;
  height: 28px;
  flex-shrink: 0;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border-radius: 50%;
  background: var(--card2);
  border: 1px solid var(--border2);
  font-weight: 800;
  color: var(--accent);
}

@media (max-width: 900px) {
  .ai-task-head {
    flex-direction: column;
  }
}

.form-group {
  margin-bottom: 16px;
}

.form-label {
  display: block;
  font-size: 0.82rem;
  font-weight: 600;
  color: var(--text2);
  margin-bottom: 6px;
}

.form-input {
  width: 100%;
  padding: 11px 14px;
  background: var(--input-bg);
  border: 1.5px solid var(--border2);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 0.92rem;
  transition: var(--transition);
}

.form-input:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.form-input::placeholder {
  color: var(--text3);
}

select.form-input {
  cursor: pointer;
}

textarea.form-input {
  resize: vertical;
}

/* ── Buttons ──────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 11px 20px;
  border-radius: var(--radius-sm);
  font-size: 0.9rem;
  font-weight: 600;
  transition: var(--transition);
  cursor: pointer;
  border: none;
  position: relative;
  overflow: hidden;
  --mouse-x: 50%;
  --mouse-y: 50%;
}

/* Maus-Follow-Glow – gilt für ALLE Buttons */
.btn::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: radial-gradient(circle 70px at var(--mouse-x) var(--mouse-y), rgba(255, 255, 255, 0.22), transparent 68%);
  opacity: 0;
  transition: opacity 0.3s ease;
  pointer-events: none;
  z-index: 0;
}

.btn:hover::before {
  opacity: 1;
}

/* Obere Glanzlinie – gilt für ALLE Buttons */
.btn::after {
  content: '';
  position: absolute;
  top: 0;
  left: 15%;
  right: 15%;
  height: 1px;
  background: linear-gradient(90deg, transparent, rgba(255, 255, 255, 0.3), transparent);
  pointer-events: none;
  z-index: 0;
}

.btn>* {
  position: relative;
  z-index: 1;
}

.btn-primary {
  background: var(--accent);
  color: var(--accent-text, #fff);
  box-shadow: 0 0 18px var(--accent-glow), 0 4px 16px var(--accent-glow);
}

.btn-primary:hover {
  background: var(--accent2);
  transform: translateY(-2px);
  box-shadow: 0 0 32px var(--accent-glow), 0 0 60px color-mix(in srgb, var(--accent) 40%, transparent), 0 6px 24px var(--accent-glow);
}

.btn:active {
  transform: translateY(0) scale(0.975) !important;
}

.btn-secondary:hover {
  background: var(--card2);
  border-color: var(--accent);
  box-shadow: 0 0 14px rgba(255, 255, 255, 0.04);
}

.btn-ghost:hover {
  background: var(--card);
  color: var(--text);
  box-shadow: 0 0 12px rgba(255, 255, 255, 0.04);
}

/* Ripple-Element (per JS eingefügt) */
.btn-ripple {
  position: absolute;
  border-radius: 50%;
  width: 6px;
  height: 6px;
  margin-left: -3px;
  margin-top: -3px;
  pointer-events: none;
  z-index: 2;
  background: radial-gradient(circle, rgba(255, 255, 255, 1) 0%, rgba(255, 255, 255, 0.75) 20%, rgba(255, 255, 255, 0.2) 55%, transparent 75%);
  transform: scale(0);
  animation: btnRipple 0.65s cubic-bezier(0.18, 0.89, 0.4, 0.98) forwards;
}

@keyframes btnRipple {
  0% {
    transform: scale(0);
    opacity: 1;
  }

  100% {
    transform: scale(55);
    opacity: 0;
  }
}

.btn-secondary {
  background: var(--card);
  color: var(--text);
  border: 1.5px solid var(--border2);
}

.btn-secondary:hover {
  background: var(--card2);
  border-color: var(--accent);
}

.btn-ghost {
  background: transparent;
  color: var(--text2);
}

.btn-ghost:hover {
  background: var(--card);
  color: var(--text);
}

.btn-danger {
  background: #ef4444;
  color: #fff;
}

.btn-danger:hover {
  background: #dc2626;
}

.btn-warning {
  background: #f59e0b22;
  color: #f59e0b;
  border-color: #f59e0b66;
}

.btn-warning:hover {
  background: #f59e0b33;
}

.btn-sm {
  padding: 7px 14px;
  font-size: 0.82rem;
}

.btn-full {
  width: 100%;
}

.btn-icon {
  padding: 9px;
  border-radius: var(--radius-sm);
}

.auth-switch {
  text-align: center;
  margin-top: 20px;
  font-size: 0.86rem;
  color: var(--text2);
}

.auth-switch a {
  color: var(--accent);
  font-weight: 600;
  cursor: pointer;
}

.auth-switch a:hover {
  text-decoration: underline;
}

/* ── Shell ────────────────────────────────────── */
.shell {
  display: flex;
  min-height: 100vh;
  animation: fadeIn 0.35s ease both;
}

.sidebar {
  width: var(--sidebar-width);
  background: var(--surface);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  position: fixed;
  top: 0;
  left: 0;
  bottom: 0;
  z-index: 100;
  overflow: hidden;
  transition: width 0.28s cubic-bezier(.4, 0, .2, 1);
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 24px 20px 18px;
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: -0.5px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 8px;
}

.sidebar-close-btn {
  display: none;
  margin-left: auto;
  background: none;
  border: none;
  color: var(--text2);
  font-size: 1rem;
  cursor: pointer;
  padding: 4px 6px;
  border-radius: 6px;
  line-height: 1;
}

.sidebar-close-btn:hover {
  background: var(--card2);
  color: var(--text);
}

@media (max-width: 900px) {
  .sidebar-close-btn {
    display: block;
  }
}

.sidebar-role-badge {
  margin: 0 16px 14px;
  padding: 5px 12px;
  border-radius: 20px;
  background: var(--accent-glow);
  color: var(--accent);
  font-size: 0.72rem;
  font-weight: 700;
  text-align: center;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}

.sidebar-nav {
  flex: 1;
  padding: 0 10px;
  overflow-y: auto;
}

.nav-section-label {
  font-size: 0.66rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
  padding: 12px 10px 5px;
}

.nav-item {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  color: var(--text2);
  font-size: 0.88rem;
  font-weight: 500;
  cursor: pointer;
  transition: var(--transition);
  margin-bottom: 2px;
  position: relative;
}

.nav-item:hover {
  background: var(--card);
  color: var(--text);
}

.nav-item.active {
  background: var(--accent-glow);
  color: var(--accent);
  font-weight: 600;
}

.nav-item.active::before {
  content: '';
  position: absolute;
  left: 0;
  top: 50%;
  transform: translateY(-50%);
  width: 3px;
  height: 60%;
  border-radius: 2px;
  background: var(--accent);
}

.nav-item i {
  width: 18px;
  text-align: center;
  font-size: 0.9rem;
}

.nav-badge {
  margin-left: auto;
  background: var(--accent);
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 10px;
}

.sidebar-footer {
  padding: 16px;
  border-top: 1px solid var(--border);
}

.sidebar-user {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: var(--transition);
}

.sidebar-user:hover {
  background: var(--card);
}

.avatar {
  width: 36px;
  height: 36px;
  border-radius: 50%;
  background: var(--accent-glow);
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-weight: 700;
  font-size: 0.88rem;
  flex-shrink: 0;
  border: 2px solid var(--accent);
  overflow: hidden;
}

.avatar-lg {
  width: 56px;
  height: 56px;
  font-size: 1.2rem;
}

.avatar img {
  width: 100%;
  height: 100%;
  object-fit: cover;
}

.sidebar-user-info {
  flex: 1;
  min-width: 0;
}

.sidebar-user-name {
  font-size: 0.85rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-user-role {
  font-size: 0.72rem;
  color: var(--text2);
}

.main-content {
  margin-left: var(--sidebar-width);
  flex: 1;
  padding: 28px;
  min-height: 100vh;
  background: var(--bg);
}

.topbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 24px;
}

.page-title {
  font-size: 1.5rem;
  font-weight: 800;
  letter-spacing: -0.5px;
}

.page-sub {
  font-size: 0.85rem;
  color: var(--text2);
  margin-top: 2px;
}

.topbar-actions {
  display: flex;
  gap: 10px;
  align-items: center;
}

/* ── Cards ────────────────────────────────────── */
.card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 20px;
}

.card-sm {
  padding: 14px 16px;
}

.card-hover {
  transition: var(--transition);
  cursor: pointer;
}

.card-hover:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 8px 24px var(--accent-glow);
}

.stats-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 14px;
  margin-bottom: 24px;
}

.stat-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 20px;
}

.stat-icon {
  width: 40px;
  height: 40px;
  border-radius: 10px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  margin-bottom: 12px;
}

.stat-value {
  font-size: 1.8rem;
  font-weight: 800;
  letter-spacing: -1px;
}

.stat-label {
  font-size: 0.78rem;
  color: var(--text2);
  margin-top: 2px;
  font-weight: 500;
}

.grid-2 {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 16px;
}

.grid-3 {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 16px;
}

.grid-auto {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 16px;
}

/* ── Weekly Calendar ──────────────────────────── */
.week-nav {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 14px;
}

.week-label {
  font-size: 0.95rem;
  font-weight: 700;
  flex: 1;
  text-align: center;
}

.day-ann-dot {
  font-size: 0.68rem;
  display: block;
  margin-top: 2px;
}

.week-grid {
  display: grid;
  grid-template-columns: 54px repeat(5, 1fr);
  gap: 1px;
  background: var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  min-width: 580px;
}

.week-header {
  background: var(--surface);
  padding: 10px 6px;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
  line-height: 1.4;
}

.week-header.today-col {
  color: var(--accent);
}

.week-time-label {
  background: var(--surface);
  padding: 6px 6px;
  font-size: 0.66rem;
  font-weight: 600;
  color: var(--text3);
  text-align: right;
  display: flex;
  align-items: center;
  justify-content: flex-end;
}

.week-cell {
  background: var(--card);
  min-height: 48px;
  position: relative;
  transition: var(--transition);
}

.week-cell.has-subject {
  cursor: pointer;
}

.week-cell.has-subject:hover {
  background: var(--card2);
}

/* Editor empty cell */
.week-cell.editor-empty {
  cursor: pointer;
}

.week-cell.editor-empty:hover {
  background: var(--accent-glow);
}

.week-cell.editor-empty:hover .editor-add-btn {
  opacity: 1;
}

.editor-add-btn {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.1rem;
  color: var(--accent);
  opacity: 0;
  transition: var(--transition);
}

.subject-block {
  position: absolute;
  inset: 3px;
  border-radius: 8px;
  padding: 5px 7px;
  font-size: 0.74rem;
  font-weight: 600;
  border-left: 3px solid;
  transition: var(--transition);
  overflow: hidden;
  display: flex;
  flex-direction: column;
  justify-content: center;
  gap: 1px;
}

.week-cell.has-subject:hover .subject-block {
  filter: brightness(1.1);
  transform: scale(1.015);
}

.subj-name {
  font-weight: 700;
  font-size: 0.76rem;
  line-height: 1.2;
}

.subj-time {
  font-size: 0.62rem;
  opacity: 0.75;
}

.subj-edit-icon {
  color: var(--accent);
  opacity: 0.7;
}

.subj-indicators {
  display: flex;
  gap: 3px;
  margin-top: 2px;
  font-size: 0.7rem;
  line-height: 1;
}

.subj-indicator {
  font-size: 0.7rem;
}

.color-0 {
  background: rgba(59, 130, 246, 0.18);
  border-color: #3b82f6;
  color: #93c5fd;
}

.color-1 {
  background: rgba(139, 92, 246, 0.18);
  border-color: #8b5cf6;
  color: #c4b5fd;
}

.color-2 {
  background: rgba(16, 185, 129, 0.18);
  border-color: #10b981;
  color: #6ee7b7;
}

.color-3 {
  background: rgba(245, 158, 11, 0.18);
  border-color: #f59e0b;
  color: #fcd34d;
}

.color-4 {
  background: rgba(239, 68, 68, 0.18);
  border-color: #ef4444;
  color: #fca5a5;
}

.color-5 {
  background: rgba(236, 72, 153, 0.18);
  border-color: #ec4899;
  color: #f9a8d4;
}

[data-theme="light"] .color-0 {
  background: rgba(59, 130, 246, 0.1);
  color: #1d4ed8;
}

[data-theme="light"] .color-1 {
  background: rgba(139, 92, 246, 0.1);
  color: #5b21b6;
}

[data-theme="light"] .color-2 {
  background: rgba(16, 185, 129, 0.1);
  color: #065f46;
}

[data-theme="light"] .color-3 {
  background: rgba(245, 158, 11, 0.1);
  color: #92400e;
}

[data-theme="light"] .color-4 {
  background: rgba(239, 68, 68, 0.1);
  color: #991b1b;
}

[data-theme="light"] .color-5 {
  background: rgba(236, 72, 153, 0.1);
  color: #9d174d;
}

/* ── Attendance student row ───────────────────── */
.student-attendance-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.student-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  background: var(--card2);
  border-radius: var(--radius-sm);
  border: 1px solid var(--border2);
  flex-wrap: wrap;
}

.student-row .student-name {
  font-weight: 600;
  font-size: 0.86rem;
  min-width: 110px;
}

.status-btns {
  display: flex;
  gap: 5px;
}

.status-btn {
  padding: 4px 9px;
  border-radius: 6px;
  font-size: 0.7rem;
  font-weight: 700;
  border: 1.5px solid transparent;
  transition: var(--transition);
  cursor: pointer;
  background: var(--card);
  color: var(--text2);
}

.status-btn.present.active {
  background: rgba(16, 185, 129, 0.2);
  border-color: #10b981;
  color: #10b981;
}

.status-btn.absent.active {
  background: rgba(239, 68, 68, 0.2);
  border-color: #ef4444;
  color: #ef4444;
}

.status-btn.late.active {
  background: rgba(245, 158, 11, 0.2);
  border-color: #f59e0b;
  color: #f59e0b;
}

.feedback-select {
  padding: 4px 7px;
  background: var(--card);
  border: 1.5px solid var(--border2);
  border-radius: 6px;
  color: var(--text);
  font-size: 0.76rem;
  font-weight: 600;
  cursor: pointer;
}

.feedback-select:focus {
  border-color: var(--accent);
  outline: none;
}

.note-input {
  flex: 1;
  padding: 4px 9px;
  background: var(--card);
  border: 1.5px solid var(--border2);
  border-radius: 6px;
  color: var(--text);
  font-size: 0.78rem;
  min-width: 80px;
}

.note-input:focus {
  border-color: var(--accent);
  outline: none;
}

.note-input::placeholder {
  color: var(--text3);
}

/* Homework section in attendance modal */
.hw-section {
  background: var(--card2);
  border: 1.5px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  margin-bottom: 16px;
}

.hw-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
}

.hw-toggle input[type="checkbox"] {
  width: 16px;
  height: 16px;
  accent-color: var(--accent);
  cursor: pointer;
}

.hw-toggle label {
  font-weight: 600;
  font-size: 0.88rem;
  cursor: pointer;
}

/* ── Badges ───────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 3px 9px;
  border-radius: 20px;
  font-size: 0.72rem;
  font-weight: 700;
}

.badge-present {
  background: rgba(16, 185, 129, 0.15);
  color: #10b981;
}

.badge-absent {
  background: rgba(239, 68, 68, 0.15);
  color: #ef4444;
}

.badge-late {
  background: rgba(245, 158, 11, 0.15);
  color: #f59e0b;
}

.badge-excused {
  background: rgba(139, 92, 246, 0.15);
  color: #8b5cf6;
}

.badge-blue {
  background: var(--accent-glow);
  color: var(--accent);
}

.badge-gray {
  background: var(--card2);
  color: var(--text2);
}

.fb {
  padding: 2px 8px;
  border-radius: 6px;
  font-size: 0.78rem;
  font-weight: 800;
}

.fb-pp {
  background: rgba(16, 185, 129, 0.2);
  color: #10b981;
}

.fb-p {
  background: rgba(59, 130, 246, 0.2);
  color: #60a5fa;
}

.fb-m {
  background: rgba(245, 158, 11, 0.2);
  color: #f59e0b;
}

.fb-mm {
  background: rgba(239, 68, 68, 0.2);
  color: #ef4444;
}

/* ── Modal ────────────────────────────────────── */
.modal-overlay {
  position: fixed;
  inset: 0;
  background: var(--modal-bg);
  backdrop-filter: blur(6px);
  z-index: 1000;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 20px;
  animation: fadeIn 0.2s ease both;
}

.modal {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  width: 100%;
  max-width: 620px;
  max-height: 88vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--shadow-lg);
  animation: modalIn 0.3s cubic-bezier(0.34, 1.4, 0.64, 1) both;
}

.modal-xl {
  max-width: 1100px;
}

.modal-lg {
  max-width: 800px;
}

.modal-md {
  max-width: 600px;
}

.modal-sm {
  max-width: 420px;
}

.modal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 18px 24px 14px;
  border-bottom: 1px solid var(--border);
  flex-shrink: 0;
}

.modal-title {
  font-size: 1.05rem;
  font-weight: 700;
}

.modal-body {
  padding: 18px 24px;
  overflow-y: auto;
  flex: 1;
}

.modal-footer {
  padding: 14px 24px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 10px;
  justify-content: flex-end;
  flex-shrink: 0;
}

.modal-close {
  background: var(--card2);
  border: none;
  width: 32px;
  height: 32px;
  border-radius: 8px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--text2);
  cursor: pointer;
  font-size: 1.1rem;
  transition: var(--transition);
}

.modal-close:hover {
  background: var(--card);
  color: var(--text);
}

/* ── Tables ───────────────────────────────────── */
.table-wrap {
  overflow-x: auto;
  border-radius: var(--radius);
}

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

thead th {
  background: var(--surface);
  padding: 10px 14px;
  text-align: left;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--text2);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  border-bottom: 1px solid var(--border);
}

tbody tr {
  border-bottom: 1px solid var(--border2);
  transition: var(--transition);
}

tbody tr:last-child {
  border-bottom: none;
}

tbody tr:hover {
  background: var(--card2);
}

tbody td {
  padding: 11px 14px;
  font-size: 0.85rem;
}

tbody td .name-cell {
  font-weight: 600;
}

/* ── Profile ──────────────────────────────────── */
.profile-header {
  display: flex;
  align-items: center;
  gap: 18px;
  margin-bottom: 20px;
}

.profile-info .pname {
  font-size: 1.3rem;
  font-weight: 700;
}

.profile-info .pemail {
  color: var(--text2);
  font-size: 0.85rem;
  margin-top: 2px;
}

.profile-stats {
  display: flex;
  gap: 20px;
  margin-top: 14px;
  padding: 12px 16px;
  background: var(--card2);
  border-radius: var(--radius-sm);
  flex-wrap: wrap;
}

.profile-stat .pval {
  font-size: 1.4rem;
  font-weight: 800;
}

.profile-stat .plbl {
  font-size: 0.72rem;
  color: var(--text2);
  font-weight: 500;
}

/* Profile pic upload */
.pic-upload-wrap {
  position: relative;
  display: inline-block;
  cursor: pointer;
}

.pic-upload-wrap input[type="file"] {
  display: none;
}

.pic-upload-overlay {
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: rgba(0, 0, 0, 0.5);
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  opacity: 0;
  transition: var(--transition);
  font-size: 0.8rem;
}

.pic-upload-wrap:hover .pic-upload-overlay {
  opacity: 1;
}

/* ── Chat ─────────────────────────────────────── */
.chat-layout {
  display: grid;
  grid-template-columns: 275px 1fr;
  gap: 0;
  height: calc(100vh - 110px);
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  overflow: hidden;
}

.chat-list {
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

.chat-list-header {
  padding: 16px;
  border-bottom: 1px solid var(--border);
  font-weight: 700;
}

.chat-search {
  padding: 10px;
  border-bottom: 1px solid var(--border);
}

.chat-contacts {
  flex: 1;
  overflow-y: auto;
}

.chat-contact {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 16px;
  cursor: pointer;
  transition: var(--transition);
  border-bottom: 1px solid var(--border2);
}

.chat-contact:hover {
  background: var(--card2);
}

.chat-contact.active {
  background: var(--accent-glow);
}

.chat-contact-info {
  flex: 1;
  min-width: 0;
}

.chat-contact-name {
  font-size: 0.87rem;
  font-weight: 600;
}

.chat-contact-preview {
  font-size: 0.75rem;
  color: var(--text2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.chat-contact-time {
  font-size: 0.68rem;
  color: var(--text3);
}

.unread-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--accent);
  flex-shrink: 0;
}

.chat-window {
  display: flex;
  flex-direction: column;
}

.chat-window-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 14px 18px;
  border-bottom: 1px solid var(--border);
}

.chat-messages {
  flex: 1;
  padding: 18px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.chat-empty {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  color: var(--text3);
  gap: 10px;
}

.chat-empty i {
  font-size: 2.5rem;
}

.msg {
  display: flex;
  gap: 10px;
  max-width: 76%;
}

.msg.own {
  flex-direction: row-reverse;
  align-self: flex-end;
}

.msg-bubble {
  padding: 9px 13px;
  border-radius: 14px;
  font-size: 0.85rem;
  line-height: 1.5;
}

.msg .msg-bubble {
  background: var(--card2);
  border-radius: 4px 14px 14px 14px;
}

.msg.own .msg-bubble {
  background: var(--accent);
  color: #fff;
  border-radius: 14px 4px 14px 14px;
}

.msg-time {
  font-size: 0.64rem;
  color: var(--text3);
  margin-top: 3px;
}

.msg.own .msg-time {
  text-align: right;
}

.chat-input-area {
  padding: 12px 18px;
  border-top: 1px solid var(--border);
  display: flex;
  gap: 10px;
  align-items: flex-end;
}

.chat-input {
  flex: 1;
  padding: 10px 13px;
  background: var(--input-bg);
  border: 1.5px solid var(--border2);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 0.9rem;
  resize: none;
  max-height: 100px;
}

.chat-input:focus {
  outline: none;
  border-color: var(--accent);
}

.ramses-layout {
  height: calc(100vh - 110px);
  grid-template-columns: minmax(0, 1fr);
  padding: 18px;
  background: rgba(255, 255, 255, 0.95);
  border-radius: 28px;
  border: 2px solid red;
  box-shadow: 0 40px 120px rgba(0, 0, 0, 0.22);
}

.ramses-layout .ramses-sidepanel {
  display: none;
  width: 0;
  min-width: 0;
}

.ramses-layout .chat-window {
  min-height: calc(100vh - 146px);
  background: #ffffff;
  border-radius: 24px;
  overflow: hidden;
  border: 2px solid blue;
}

.ramses-sidepanel {
  background:
    linear-gradient(180deg, rgba(59, 130, 246, 0.08), rgba(59, 130, 246, 0.02) 22%, transparent 55%),
    var(--surface);
  border-right: 1px solid var(--border);
}

.ramses-shell-header {
  padding: 16px 14px 12px;
}

.ramses-new-chat-btn {
  width: 100%;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 10px;
  padding: 12px 14px;
  border-radius: 14px;
  border: 1px solid rgba(59, 130, 246, 0.2);
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.12), rgba(59, 130, 246, 0.06));
  color: var(--text);
  font-weight: 700;
  cursor: pointer;
  transition: var(--transition);
}

.ramses-new-chat-btn:hover {
  transform: translateY(-1px);
  border-color: rgba(59, 130, 246, 0.4);
  background: rgba(59, 130, 246, 0.18);
}

.ramses-side-body {
  padding: 14px;
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow-y: auto;
}

.ramses-policy-box {
  padding: 16px;
  border-radius: 18px;
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: 0 12px 30px rgba(0, 0, 0, 0.2);
}

.ramses-thread-card {
  padding: 16px;
  border-radius: 18px;
  background: var(--card2);
  color: var(--text);
  border: 1px solid rgba(59, 130, 246, 0.15);
}

.ramses-thread-title {
  font-size: 0.98rem;
  font-weight: 700;
  margin-top: 10px;
  color: var(--text);
}

.ramses-thread-preview {
  margin-top: 8px;
  font-size: 0.84rem;
  line-height: 1.55;
  color: var(--text2);
}

.ramses-thread-meta {
  margin-top: 12px;
  display: flex;
  justify-content: space-between;
  gap: 8px;
  font-size: 0.73rem;
  color: var(--text3);
}

.ramses-quick-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ramses-quick-btn {
  text-align: left;
  padding: 11px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  transition: var(--transition);
}

.ramses-quick-btn:hover {
  border-color: var(--accent);
  background: var(--card2);
  transform: translateX(2px);
}

.ramses-window-header {
  padding: 18px 22px;
  background: #fffdc4;
  border-bottom: 3px solid orange;
}

.ramses-messages {
  background: #ffffff;
  border-bottom: 3px solid orange;
}

.ramses-main-avatar {
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff;
  box-shadow: 0 14px 30px var(--accent-glow);
}

.ramses-messages {
  background:
    radial-gradient(ellipse 60% 40% at 10% 0%, rgba(59, 130, 246, 0.06), transparent 60%),
    linear-gradient(180deg, var(--bg), var(--bg2));
}

.ramses-messages.is-fresh {
  justify-content: center;
  padding: 28px;
}

.ramses-messages.has-conversation {
  padding: 24px 24px 32px;
  gap: 18px;
}

.ramses-hero {
  width: min(900px, 100%);
  margin: 0 auto;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  gap: 14px;
}

.ramses-hero-mark {
  width: 68px;
  height: 68px;
  border-radius: 20px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 1.5rem;
  color: #fff;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  box-shadow: 0 18px 45px var(--accent-glow);
}

.ramses-hero-title {
  font-size: clamp(1.8rem, 3vw, 2.6rem);
  font-weight: 800;
  line-height: 1.08;
  color: var(--text);
}

.ramses-hero-sub {
  max-width: 700px;
  color: var(--text2);
  font-size: 0.98rem;
  line-height: 1.7;
}

.ramses-hero-grid {
  width: 100%;
  margin-top: 10px;
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}

.ramses-hero-card {
  padding: 16px 18px;
  border-radius: 18px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  transition: var(--transition);
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  text-align: left;
  font-size: 0.93rem;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.15);
}

.ramses-hero-card:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 16px 36px var(--accent-glow);
}

.ramses-msg-stack {
  min-width: 0;
}

.ramses-msg-role {
  margin-bottom: 6px;
  font-size: 0.76rem;
  font-weight: 700;
  color: var(--text3);
  letter-spacing: 0.02em;
}

.ramses-user-avatar {
  width: 32px;
  height: 32px;
  font-size: 0.72rem;
  background: var(--accent);
  color: #fff;
}

.ramses-bubble {
  background: var(--card) !important;
  border: 1px solid var(--border);
  color: var(--text) !important;
  box-shadow: 0 10px 24px rgba(0, 0, 0, 0.12);
}

.ramses-user-bubble {
  background: linear-gradient(135deg, var(--accent), var(--accent2)) !important;
  color: #fff !important;
  box-shadow: 0 14px 30px var(--accent-glow);
}

.ramses-mini-avatar {
  width: 32px;
  height: 32px;
  font-size: 0.82rem;
  background: linear-gradient(135deg, var(--accent), var(--accent2));
  color: #fff;
}

.ramses-composer-wrap {
  padding: 18px 22px 22px;
  background: linear-gradient(180deg, rgba(10, 18, 32, 0.4), var(--surface));
  border-top: 1px solid var(--border);
}

.ramses-composer {
  width: min(880px, 100%);
  margin: 0 auto;
  padding: 14px;
  border-radius: 22px;
  background: var(--card);
  border: 1px solid var(--border);
  box-shadow: 0 16px 36px rgba(0, 0, 0, 0.2);
}

.ramses-composer-input {
  min-height: 58px;
  max-height: 180px;
  border: none;
  background: transparent;
  padding: 4px 2px 12px;
  font-size: 0.96rem;
  color: var(--text);
}

.ramses-composer-input:focus {
  border: none;
  outline: none;
}

.ramses-composer-footer {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  border-top: 1px solid var(--border);
  padding-top: 12px;
}

.ramses-composer-hint {
  font-size: 0.76rem;
  color: var(--text3);
}

.ramses-send-btn {
  min-width: 118px;
  justify-content: center;
}

.ramses-composer-row {
  display: flex;
  align-items: flex-end;
  gap: 8px;
}

.ai-upload-btn {
  display: flex;
  align-items: center;
  justify-content: center;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  cursor: pointer;
  color: var(--text2);
  background: rgba(59, 130, 246, 0.08);
  border: 1px solid var(--border);
  transition: var(--transition);
  flex-shrink: 0;
  margin-bottom: 8px;
}

.ai-upload-btn:hover {
  background: rgba(59, 130, 246, 0.18);
  color: var(--accent);
  border-color: var(--accent);
}

.ai-file-preview {
  padding: 8px 0 4px;
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}

.ai-file-chip {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: rgba(59, 130, 246, 0.12);
  color: var(--accent);
  border: 1px solid rgba(59, 130, 246, 0.25);
  border-radius: 8px;
  padding: 4px 10px;
  font-size: 0.82rem;
  font-weight: 500;
}

.ai-file-remove {
  background: none;
  border: none;
  color: var(--text3);
  cursor: pointer;
  padding: 0 2px;
  font-size: 0.75rem;
  transition: var(--transition);
}

.ai-file-remove:hover {
  color: #ef4444;
}

.ai-msg-file {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  background: rgba(59, 130, 246, 0.1);
  color: var(--accent);
  border-radius: 6px;
  padding: 3px 8px;
  font-size: 0.78rem;
  margin-bottom: 4px;
}

.ai-loading {
  opacity: 0.7;
  animation: aiPulse 1.5s ease-in-out infinite;
}

@keyframes aiPulse {

  0%,
  100% {
    opacity: 0.7
  }

  50% {
    opacity: 0.4
  }
}

/* ── Announcements ────────────────────────────── */
.announce-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  margin-bottom: 10px;
  border-left: 4px solid;
  transition: var(--transition);
}

.announce-card:hover {
  transform: translateX(3px);
}

.announce-card.test {
  border-color: #ef4444;
}

.announce-card.trip {
  border-color: #10b981;
}

.announce-card.project {
  border-color: #8b5cf6;
}

.announce-card.other {
  border-color: var(--accent);
}

.announce-title {
  font-weight: 700;
  margin-bottom: 4px;
}

.announce-meta {
  font-size: 0.77rem;
  color: var(--text2);
  display: flex;
  gap: 14px;
  margin-top: 6px;
  flex-wrap: wrap;
}

.announce-meta i {
  width: 14px;
}

/* ── Timeline ─────────────────────────────────── */
.timeline {
  display: flex;
  flex-direction: column;
}

.timeline-item {
  display: flex;
  gap: 14px;
  padding: 0 0 18px;
  position: relative;
}

.timeline-item::before {
  content: '';
  position: absolute;
  left: 15px;
  top: 32px;
  bottom: 0;
  width: 2px;
  background: var(--border2);
}

.timeline-item:last-child::before {
  display: none;
}

.timeline-dot {
  width: 30px;
  height: 30px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.75rem;
  flex-shrink: 0;
  position: relative;
  z-index: 1;
}

.timeline-content {
  flex: 1;
}

.timeline-title {
  font-weight: 600;
  font-size: 0.87rem;
}

.timeline-sub {
  font-size: 0.75rem;
  color: var(--text2);
  margin-top: 3px;
}

.timeline-date {
  font-size: 0.7rem;
  color: var(--text3);
  margin-top: 3px;
}

/* ── Settings ─────────────────────────────────── */
.settings-section {
  margin-bottom: 26px;
}

.settings-title {
  font-size: 0.7rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text2);
  margin-bottom: 12px;
}

.settings-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 13px 16px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
}

.settings-row-info .srt {
  font-weight: 600;
  font-size: 0.88rem;
}

.settings-row-info .srs {
  font-size: 0.77rem;
  color: var(--text2);
  margin-top: 2px;
}

.toggle {
  position: relative;
  width: 44px;
  height: 24px;
  display: inline-flex;
  align-items: center;
}

.toggle input {
  opacity: 0;
  width: 0;
  height: 0;
}

.toggle-track {
  position: absolute;
  inset: 0;
  border-radius: 12px;
  background: var(--card2);
  cursor: pointer;
  transition: var(--transition);
  border: 1.5px solid var(--border2);
}

.toggle input:checked+.toggle-track {
  background: var(--accent);
  border-color: var(--accent);
}

.toggle-thumb {
  position: absolute;
  left: 4px;
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: var(--text2);
  transition: var(--transition);
  pointer-events: none;
}

.toggle input:checked~.toggle-thumb {
  left: 24px;
  background: #fff;
}

.color-picker {
  display: flex;
  gap: 8px;
}

.color-dot {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  transition: var(--transition);
  border: 2.5px solid transparent;
}

.color-dot:hover {
  transform: scale(1.15);
}

.color-dot.active {
  border-color: var(--text);
  box-shadow: 0 0 0 2px var(--bg);
}

.color-dot.blue {
  background: #3b82f6
}

.color-dot.purple {
  background: #8b5cf6
}

.color-dot.green {
  background: #10b981
}

.color-dot.red {
  background: #ef4444
}

.color-dot.orange {
  background: #f97316
}

.color-dot.cyan {
  background: #06b6d4
}

.color-dot.pink {
  background: #ec4899
}

.color-dot.teal {
  background: #14b8a6
}

.color-dot.indigo {
  background: #6366f1
}

.color-dot.amber {
  background: #f59e0b
}

/* ── Misc ─────────────────────────────────────── */
.empty-state {
  text-align: center;
  padding: 44px 20px;
  color: var(--text2);
}

.empty-state i {
  font-size: 3rem;
  opacity: 0.28;
  margin-bottom: 14px;
  display: block;
}

.empty-state h3 {
  font-size: 1rem;
  font-weight: 600;
  margin-bottom: 6px;
}

.empty-state p {
  font-size: 0.84rem;
  color: var(--text3);
}

.divider {
  height: 1px;
  background: var(--border2);
  margin: 14px 0;
}

.code-box {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 8px 16px;
  background: var(--card2);
  border: 1.5px dashed var(--accent);
  border-radius: 8px;
  font-family: monospace;
  font-size: 1.2rem;
  font-weight: 800;
  letter-spacing: 4px;
  color: var(--accent);
}

.code-box button {
  background: none;
  border: none;
  color: var(--text2);
  font-size: 0.85rem;
  cursor: pointer;
  padding: 2px 6px;
  border-radius: 4px;
  transition: var(--transition);
}

.code-box button:hover {
  background: var(--card);
  color: var(--accent);
}

.tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 18px;
  background: var(--surface);
  padding: 4px;
  border-radius: 10px;
  width: fit-content;
}

.tab {
  padding: 7px 16px;
  border-radius: 8px;
  font-size: 0.83rem;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  transition: var(--transition);
  border: none;
  background: transparent;
}

.tab.active {
  background: var(--card);
  color: var(--text);
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.1);
}

.tab:hover:not(.active) {
  color: var(--text);
}

.progress-bar {
  height: 6px;
  background: var(--card2);
  border-radius: 10px;
  overflow: hidden;
}

.progress-fill {
  height: 100%;
  border-radius: 10px;
  background: var(--accent);
  transition: width 0.5s ease;
}

.subj-more-menu.show {
  display: block !important;
}

/* Utility classes */
.text-accent {
  color: var(--accent)
}

.text-muted {
  color: var(--text2)
}

.text-sm {
  font-size: 0.82rem
}

.text-xs {
  font-size: 0.72rem
}

.fw-600 {
  font-weight: 600
}

.fw-700 {
  font-weight: 700
}

.mt-4 {
  margin-top: 4px
}

.mt-8 {
  margin-top: 8px
}

.mt-12 {
  margin-top: 12px
}

.mt-16 {
  margin-top: 16px
}

.mt-24 {
  margin-top: 24px
}

.mb-8 {
  margin-bottom: 8px
}

.mb-12 {
  margin-bottom: 12px
}

.mb-14 {
  margin-bottom: 14px
}

.mb-16 {
  margin-bottom: 16px
}

.mb-24 {
  margin-bottom: 24px
}

.flex {
  display: flex
}

.flex-center {
  display: flex;
  align-items: center
}

.flex-between {
  display: flex;
  align-items: center;
  justify-content: space-between
}

.gap-8 {
  gap: 8px
}

.gap-10 {
  gap: 10px
}

.gap-12 {
  gap: 12px
}

.gap-16 {
  gap: 16px
}

/* Toast */
#toast-root {
  position: fixed;
  bottom: 24px;
  right: 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
  z-index: 9999;
}

.toast {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 11px 16px;
  font-size: 0.85rem;
  font-weight: 500;
  box-shadow: var(--shadow);
  display: flex;
  align-items: center;
  gap: 10px;
  animation: toastIn 0.3s ease both;
  min-width: 230px;
  transition: opacity 0.3s ease, transform 0.3s ease;
}

.toast.success {
  border-left: 4px solid #10b981
}

.toast.error {
  border-left: 4px solid #ef4444
}

.toast.info {
  border-left: 4px solid var(--accent)
}

.toast.success i {
  color: #10b981
}

.toast.error i {
  color: #ef4444
}

.toast.info i {
  color: var(--accent)
}

/* ── Week Events Banner ───────────────────────── */
.week-events-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
}

.week-event-pill {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 14px;
  background: var(--card);
  border: 1.5px solid;
  border-radius: 20px;
  font-size: 0.8rem;
  animation: slideUp 0.3s ease both;
}

/* Editable day header in editor mode */
.week-header-editable {
  cursor: pointer;
  transition: var(--transition);
}

.week-header-editable:hover {
  background: var(--accent-glow);
  color: var(--accent);
}

/* Substitute cell */
.week-cell.sub-cell {
  opacity: 0.9;
}

/* Student attendance badge in schedule */
.subj-att-badge {
  position: absolute;
  top: 4px;
  right: 4px;
  font-size: 0.58rem;
  font-weight: 700;
  padding: 2px 5px;
  border-radius: 6px;
  line-height: 1.2;
}

.subj-att-badge.att-present {
  background: rgba(16, 185, 129, 0.2);
  color: #10b981;
}

.subj-att-badge.att-late {
  background: rgba(245, 158, 11, 0.2);
  color: #f59e0b;
}

.subj-att-badge.att-absent {
  background: rgba(239, 68, 68, 0.2);
  color: #ef4444;
}

.subj-vert-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 14px;
  height: 14px;
  border-radius: 4px;
  background: rgba(245, 158, 11, 0.2);
  color: #f59e0b;
  font-size: 0.6rem;
  font-weight: 800;
  flex-shrink: 0;
}

/* ── Subject Detail Modal ─────────────────────── */
.sd-section {
  background: var(--card2);
  border-radius: var(--radius-sm);
  padding: 14px 16px;
  border: 1px solid var(--border2);
}

.sd-section-hw {
  border-color: rgba(245, 158, 11, 0.3);
  background: rgba(245, 158, 11, 0.07);
}

.sd-section-test {
  border-color: rgba(239, 68, 68, 0.3);
  background: rgba(239, 68, 68, 0.06);
}

.sd-section-title {
  font-weight: 700;
  font-size: 0.88rem;
  margin-bottom: 10px;
  color: var(--text1);
}

.hw-desc-box {
  font-size: 0.9rem;
  line-height: 1.65;
  padding: 10px 14px;
  background: var(--card);
  border-radius: var(--radius-sm);
  border-left: 3px solid #f59e0b;
  margin-bottom: 12px;
  color: var(--text1);
  white-space: pre-wrap;
}

.hw-done-toggle {
  display: flex;
  align-items: center;
  gap: 10px;
  cursor: pointer;
  user-select: none;
  padding: 8px 0;
}

.hw-done-toggle input {
  display: none;
}

.hw-done-toggle-track {
  width: 36px;
  height: 20px;
  border-radius: 10px;
  flex-shrink: 0;
  background: var(--border2);
  position: relative;
  transition: var(--transition);
}

.hw-done-toggle input:checked~.hw-done-toggle-track {
  background: #10b981;
}

.hw-done-toggle-track::after {
  content: '';
  position: absolute;
  top: 3px;
  left: 3px;
  width: 14px;
  height: 14px;
  border-radius: 50%;
  background: #fff;
  transition: var(--transition);
}

.hw-done-toggle input:checked~.hw-done-toggle-track::after {
  transform: translateX(16px);
}

.test-info-card {
  background: var(--card);
  border-radius: var(--radius-sm);
  padding: 10px 14px;
  margin-bottom: 8px;
  border-left: 3px solid #ef4444;
}

/* ── Student home subject rows ────────────────── */
.subj-home-row {
  padding: 10px 0;
  border-bottom: 1px solid var(--border2);
  cursor: pointer;
  transition: background var(--transition);
  border-radius: 6px;
  margin: 0 -6px;
  padding-left: 6px;
  padding-right: 6px;
}

.subj-home-row:hover {
  background: var(--accent-glow);
}

/* ── Homework overview list ───────────────────── */
.hw-overview-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  margin-bottom: 8px;
  cursor: pointer;
  background: var(--card2);
  border: 1px solid var(--border2);
  transition: var(--transition);
}

.hw-overview-item:hover {
  border-color: var(--accent);
  background: var(--accent-glow);
}

.hw-overview-item.hw-done {
  opacity: 0.55;
}

.hw-overview-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  flex-shrink: 0;
  margin-top: 5px;
}

.line-through {
  text-decoration: line-through;
}

/* ── Animations ───────────────────────────────── */
@keyframes fadeIn {
  from {
    opacity: 0
  }

  to {
    opacity: 1
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateY(28px)
  }

  to {
    opacity: 1;
    transform: translateY(0)
  }
}

@keyframes scaleIn {
  from {
    opacity: 0;
    transform: scale(0.85)
  }

  to {
    opacity: 1;
    transform: scale(1)
  }
}

@keyframes modalIn {
  from {
    opacity: 0;
    transform: scale(0.92) translateY(16px)
  }

  to {
    opacity: 1;
    transform: scale(1) translateY(0)
  }
}

@keyframes splashFade {
  to {
    opacity: 0;
    pointer-events: none
  }
}

@keyframes dotPulse {

  0%,
  100% {
    opacity: 0.3;
    transform: scale(1)
  }

  50% {
    opacity: 1;
    transform: scale(1.3)
  }
}

@keyframes orbFloat {
  from {
    transform: translate(0, 0) scale(1)
  }

  to {
    transform: translate(20px, -20px) scale(1.05)
  }
}

@keyframes toastIn {
  from {
    opacity: 0;
    transform: translateX(100%)
  }

  to {
    opacity: 1;
    transform: translateX(0)
  }
}

@keyframes slideUp {
  from {
    opacity: 0;
    transform: translateX(-50%) translateY(24px)
  }

  to {
    opacity: 1;
    transform: translateX(-50%) translateY(0)
  }
}

/* PWA standalone mode adjustments (mobile app feel) */
@media (display-mode: standalone) {
  body {
    padding-top: env(safe-area-inset-top);
    padding-bottom: env(safe-area-inset-bottom);
  }

  #pwa-banner {
    display: none !important;
  }
}

@keyframes spin {
  to {
    transform: rotate(360deg)
  }
}

.spin {
  animation: spin 1s linear infinite;
}

/* ── Hamburger + Backdrop ────────────────────────────────── */
.hamburger-btn {
  display: none;
  position: fixed;
  top: 14px;
  left: 14px;
  z-index: 301;
  width: 38px;
  height: 38px;
  border-radius: 10px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  font-size: 1rem;
  cursor: pointer;
  align-items: center;
  justify-content: center;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.18);
  transition: background var(--transition);
}

.hamburger-btn:hover {
  background: var(--card2);
}

.sidebar-backdrop {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(0, 0, 0, 0.5);
  z-index: 299;
  backdrop-filter: blur(2px);
}

.sidebar-backdrop.active {
  display: block;
}

@media (max-width: 900px) {
  :root {
    --sidebar-width: 0px;
  }

  .hamburger-btn {
    display: flex;
  }

  .sidebar {
    z-index: 300;
  }

  .sidebar.open {
    width: 240px;
  }

  .main-content {
    margin-left: 0;
    padding: 16px 14px 80px;
  }

  /* Topbar: wrap actions below title on small screens */
  .topbar {
    flex-wrap: wrap;
    gap: 10px;
    padding-top: 52px;
    /* room for hamburger */
  }

  .topbar-actions {
    flex-wrap: wrap;
    gap: 6px;
  }

  /* Grids → 1 column */
  .chat-layout {
    grid-template-columns: 1fr;
  }

  .ramses-layout {
    height: auto;
    min-height: calc(100vh - 110px);
  }

  .ramses-sidepanel {
    border-right: none;
    border-bottom: 1px solid var(--border);
  }

  .ramses-hero-grid {
    grid-template-columns: 1fr;
  }

  .msg {
    max-width: 100%;
  }

  .ramses-composer-footer {
    flex-direction: column;
    align-items: stretch;
  }

  .ramses-send-btn {
    width: 100%;
  }

  .grid-2,
  .grid-3 {
    grid-template-columns: 1fr;
  }

  .subj-cards-grid {
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  }

  .res-grid {
    grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
  }

  .cover-gradient-grid {
    grid-template-columns: repeat(6, 1fr);
  }

  /* Karten */
  .subj-cover-banner {
    height: 120px;
  }

  .subj-cover-title {
    font-size: 1.2rem;
  }

  /* Stats */
  .stats-kpi-row {
    grid-template-columns: repeat(2, 1fr);
  }

  .stats-charts-grid {
    grid-template-columns: 1fr;
  }

  /* Modals: fast full-screen */
  .modal-box {
    width: calc(100vw - 24px);
    max-height: 90vh;
    margin: 12px;
  }

  .modal-box.lg {
    width: calc(100vw - 24px);
  }
}

/* ============================================================
   RGB-RAHMEN: Stundenplan (TV-Backlight-Effekt)
============================================================ */
.schedule-rgb-frame {
  position: relative;
  border-radius: calc(var(--radius) + 4px);
  z-index: 0;
}

/* Ecke oben-rechts */
.schedule-rgb-frame::before {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  top: -40px;
  right: -40px;
  background: radial-gradient(circle, var(--corner1, #38bdf8) 0%, transparent 68%);
  filter: blur(22px);
  z-index: -1;
  opacity: 0.6;
  pointer-events: none;
  border-radius: 50%;
}

/* Ecke unten-links */
.schedule-rgb-frame::after {
  content: '';
  position: absolute;
  width: 220px;
  height: 220px;
  bottom: -40px;
  left: -40px;
  background: radial-gradient(circle, var(--corner2, #a855f7) 0%, transparent 68%);
  filter: blur(22px);
  z-index: -1;
  opacity: 0.6;
  pointer-events: none;
  border-radius: 50%;
}

/* Code-Aktivierungsumschalter */
.code-active-toggle {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 5px 14px;
  border-radius: 20px;
  font-size: 0.75rem;
  font-weight: 700;
  cursor: pointer;
  border: 1.5px solid;
  transition: var(--transition);
  letter-spacing: 0.04em;
}

.code-active-toggle.active {
  background: rgba(16, 185, 129, 0.15);
  border-color: #10b981;
  color: #10b981;
}

.code-active-toggle.inactive {
  background: rgba(239, 68, 68, 0.12);
  border-color: #ef4444;
  color: #ef4444;
}

/* ============================================================
   LANDING-PAGE-DESIGN: Partikel-Hintergrund
============================================================ */
#particle-canvas {
  position: fixed;
  inset: 0;
  width: 100%;
  height: 100%;
  pointer-events: none;
  z-index: 0;
}

.bg-grid {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background-image:
    linear-gradient(rgba(56, 189, 248, 0.022) 1px, transparent 1px),
    linear-gradient(90deg, rgba(56, 189, 248, 0.022) 1px, transparent 1px);
  background-size: 60px 60px;
  -webkit-mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
  mask-image: radial-gradient(ellipse 80% 80% at 50% 50%, black 30%, transparent 100%);
}

.bg-ambient {
  position: fixed;
  inset: 0;
  pointer-events: none;
  z-index: 0;
  background:
    radial-gradient(ellipse 60% 40% at 15% 5%, rgba(56, 189, 248, 0.055) 0%, transparent 65%),
    radial-gradient(ellipse 50% 35% at 85% 95%, rgba(139, 92, 246, 0.055) 0%, transparent 65%),
    radial-gradient(ellipse 35% 25% at 50% 50%, rgba(56, 189, 248, 0.022) 0%, transparent 70%);
}

/* All content layers above the canvas */
.splash {
  z-index: 9999;
}

#app {
  position: relative;
  z-index: 1;
}

#toast-root {
  z-index: 9999;
}

/* ============================================================
   GLASSMORPHISM SIDEBAR
============================================================ */
[data-theme="dark"] .sidebar {
  background: rgba(10, 18, 32, 0.82);
  backdrop-filter: blur(18px);
  -webkit-backdrop-filter: blur(18px);
  border-right: 1px solid rgba(56, 189, 248, 0.1);
}

[data-theme="dark"] .sidebar-logo {
  border-bottom: 1px solid rgba(56, 189, 248, 0.1);
}

/* Active nav item glow */
[data-theme="dark"] .nav-item.active {
  background: rgba(56, 189, 248, 0.1);
  box-shadow: inset 3px 0 0 var(--accent), 0 0 16px rgba(56, 189, 248, 0.08);
}

/* ============================================================
   MAIN CONTENT: leicht transparent damit Partikel durchscheinen
============================================================ */
[data-theme="dark"] .main-content {
  background: transparent;
}

[data-theme="dark"] .shell {
  background: transparent;
}

/* ============================================================
   GLOW AUF CARDS & INTERAKTIVEN ELEMENTEN
============================================================ */
[data-theme="dark"] .card {
  background: rgba(13, 24, 41, 0.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(56, 189, 248, 0.1);
}

[data-theme="dark"] .card-hover:hover {
  border-color: rgba(56, 189, 248, 0.35);
  box-shadow:
    0 8px 32px rgba(0, 0, 0, 0.4),
    0 0 24px rgba(56, 189, 248, 0.1);
  transform: translateY(-2px);
}

[data-theme="dark"] .stat-card {
  background: rgba(13, 24, 41, 0.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(56, 189, 248, 0.1);
  transition: var(--transition);
}

[data-theme="dark"] .stat-card:hover {
  border-color: rgba(56, 189, 248, 0.3);
  box-shadow: 0 0 20px rgba(56, 189, 248, 0.08);
}

/* ============================================================
   ENHANCED BUTTONS
============================================================ */
[data-theme="dark"] .btn-primary {
  box-shadow: 0 0 18px var(--accent-glow), 0 4px 16px var(--accent-glow);
  transition: var(--transition);
}

[data-theme="dark"] .btn-primary:hover {
  box-shadow: 0 0 32px var(--accent-glow), 0 6px 20px var(--accent-glow);
  transform: translateY(-1px);
}

/* ============================================================
   AUTH PAGE GLASSMORPHISM
============================================================ */
[data-theme="dark"] .auth-page {
  background: transparent;
}

[data-theme="dark"] .auth-card {
  background: rgba(12, 20, 36, 0.8);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(56, 189, 248, 0.15);
  box-shadow:
    0 0 0 1px rgba(56, 189, 248, 0.06),
    0 32px 80px rgba(0, 0, 0, 0.6);
}

/* ============================================================
   MODAL GLASSMORPHISM
============================================================ */
[data-theme="dark"] .modal {
  background: rgba(10, 18, 32, 0.9);
  backdrop-filter: blur(20px);
  -webkit-backdrop-filter: blur(20px);
  border: 1px solid rgba(56, 189, 248, 0.14);
  box-shadow: 0 32px 80px rgba(0, 0, 0, 0.6), 0 0 40px rgba(56, 189, 248, 0.06);
}

/* ============================================================
   TOAST GLASSMORPHISM
============================================================ */
[data-theme="dark"] .toast {
  background: rgba(10, 18, 32, 0.9);
  backdrop-filter: blur(12px);
  border: 1px solid rgba(56, 189, 248, 0.14);
}

/* ============================================================
   CHAT LAYOUT
============================================================ */
[data-theme="dark"] .chat-layout {
  background: rgba(13, 24, 41, 0.75);
  backdrop-filter: blur(8px);
  border: 1px solid rgba(56, 189, 248, 0.1);
}

/* ============================================================
   FORM INPUTS GLOW
============================================================ */
[data-theme="dark"] .form-input:focus {
  border-color: rgba(56, 189, 248, 0.6);
  box-shadow: 0 0 0 3px rgba(56, 189, 248, 0.12), 0 0 16px rgba(56, 189, 248, 0.08);
}

/* ============================================================
   ANNOUNCE CARDS
============================================================ */
[data-theme="dark"] .announce-card {
  background: rgba(13, 24, 41, 0.75);
  backdrop-filter: blur(8px);
}

/* ============================================================
   TIME-PROPORTIONAL TIMETABLE
============================================================ */
.tg-outer {
  display: grid;
  gap: 1px;
  background: var(--border);
  border-radius: var(--radius);
  overflow: hidden;
  min-width: 560px;
}

.tg-header {
  background: var(--surface);
  padding: 10px 6px;
  text-align: center;
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
  line-height: 1.4;
}

.tg-header.today-col {
  color: var(--accent);
}

.tg-time-col {
  position: relative;
  background: var(--surface);
}

.tg-time-label {
  position: absolute;
  right: 6px;
  font-size: 0.60rem;
  font-weight: 600;
  color: var(--text3);
  transform: translateY(-50%);
  white-space: nowrap;
  line-height: 1;
  pointer-events: none;
}

.tg-day-col {
  position: relative;
  background: var(--card);
  transition: background 0.15s;
}

.tg-day-col.tg-today {
  border-top: 2px solid var(--accent);
}

.tg-block {
  position: absolute;
  left: 3px;
  right: 3px;
  border-radius: 7px;
  padding: 4px 7px;
  font-size: 0.74rem;
  font-weight: 600;
  border-left: 3px solid;
  overflow: hidden;
  cursor: pointer;
  transition: filter 0.15s, transform 0.15s;
  display: flex;
  flex-direction: column;
  gap: 1px;
  box-sizing: border-box;
}

.tg-block:hover {
  filter: brightness(1.13);
  transform: scaleX(0.97);
}

.tg-block-sub {
  border-style: dashed;
}

.tg-gap {
  position: absolute;
  left: 0;
  right: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  cursor: pointer;
  z-index: 1;
  box-sizing: border-box;
  border-top: 1px dashed var(--border2);
  border-bottom: 1px dashed var(--border2);
  transition: background 0.15s;
}

.tg-gap:hover {
  background: var(--accent-glow);
}

.tg-gap-label {
  font-size: 0.63rem;
  color: var(--text2);
  background: var(--card2);
  padding: 2px 10px;
  border-radius: 20px;
  border: 1px solid var(--border);
}

.tg-gap-add {
  font-size: 0.75rem;
  color: var(--border);
  opacity: 0;
  transition: opacity 0.15s;
}

.tg-gap:hover .tg-gap-add {
  opacity: 1;
  color: var(--accent);
}

.tg-editor-add {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--accent);
  font-size: 1.3rem;
  opacity: 0.25;
  transition: opacity 0.15s;
  pointer-events: none;
}

.tg-day-col.tg-editor-empty {
  cursor: pointer;
}

.tg-day-col.tg-editor-empty:hover {
  background: var(--accent-glow);
}

.tg-day-col.tg-editor-empty:hover .tg-editor-add {
  opacity: 1;
}

/* ============================================================
   PRO SYSTEM
============================================================ */
.pro-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: linear-gradient(135deg, #f59e0b 0%, #f97316 100%);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
}

.studio-beta-tag {
  display: inline-flex;
  align-items: center;
  background: rgba(20, 184, 166, 0.16);
  color: var(--accent, #14b8a6);
  border: 1px solid rgba(20, 184, 166, 0.4);
  font-size: 0.56rem;
  font-weight: 800;
  padding: 1px 7px;
  border-radius: 20px;
  letter-spacing: 0.12em;
  text-transform: uppercase;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
}

.free-limit-badge {
  display: inline-block;
  font-size: 0.73rem;
  color: var(--text3);
  background: var(--card2);
  border: 1px solid var(--border);
  padding: 1px 9px;
  border-radius: 20px;
  font-weight: 600;
}

.pro-locked {
  opacity: 0.75;
}

/* KI thinking dots */
.ai-thinking {
  display: inline-flex;
  gap: 4px;
  margin-right: 8px;
  vertical-align: middle;
}

.ai-thinking span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--accent);
  opacity: 0.4;
  animation: aiDot 1.2s ease-in-out infinite;
}

.ai-thinking span:nth-child(2) {
  animation-delay: 0.2s;
}

.ai-thinking span:nth-child(3) {
  animation-delay: 0.4s;
}

@keyframes aiDot {

  0%,
  80%,
  100% {
    opacity: 0.15;
    transform: scale(0.8)
  }

  40% {
    opacity: 1;
    transform: scale(1.2)
  }
}

.admin-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  background: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);
  color: #fff;
  font-size: 0.62rem;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  white-space: nowrap;
  flex-shrink: 0;
  margin-left: auto;
}

.pro-gate-price {
  font-size: 2.6rem;
  font-weight: 900;
  letter-spacing: -0.04em;
  margin-bottom: 4px;
  color: var(--text);
}

.pro-gate-price span {
  font-size: 0.9rem;
  font-weight: 500;
  color: var(--text2);
  margin-left: 3px;
}

/* ── Statistiken ──────────────────────────────────────────── */
.stats-kpi-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 20px;
}

@media (max-width: 700px) {
  .stats-kpi-row {
    grid-template-columns: repeat(2, 1fr);
  }
}

.stats-kpi {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 16px;
  text-align: center;
}

.stats-kpi-val {
  font-size: 2rem;
  font-weight: 800;
  letter-spacing: -0.03em;
  line-height: 1;
  margin-bottom: 6px;
}

.stats-kpi-label {
  font-size: 0.75rem;
  color: var(--text2);
  font-weight: 500;
}

.stats-charts-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
}

@media (max-width: 768px) {
  .stats-charts-grid {
    grid-template-columns: 1fr;
  }
}

.stats-chart-card {
  padding: 20px;
}

.nav-item-locked {
  opacity: 0.7;
}

/* ── Ressourcen-Manager ───────────────────────────────────── */
.res-breadcrumb {
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 2px;
}

.res-crumb {
  color: var(--accent);
  cursor: pointer;
}

.res-crumb:hover {
  text-decoration: underline;
}

.res-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  gap: 12px;
  padding: 4px 0;
}

.res-item {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 12px 12px;
  display: flex;
  flex-direction: column;
  align-items: center;
  text-align: center;
  position: relative;
  transition: border-color var(--transition), transform var(--transition);
}

.res-item:hover {
  border-color: var(--accent);
}

.res-folder {
  cursor: pointer;
}

.res-folder:hover {
  transform: translateY(-2px);
}

.res-icon {
  font-size: 2.4rem;
  margin-bottom: 8px;
  color: var(--accent);
}

.res-folder .res-icon {
  color: #f59e0b;
}

.res-file .res-icon {
  color: var(--accent);
}

.res-name {
  font-size: 0.8rem;
  font-weight: 600;
  word-break: break-word;
  color: var(--text);
  margin-bottom: 4px;
}

.res-size {
  font-size: 0.7rem;
  color: var(--text3);
  margin-bottom: 2px;
}

.res-del {
  position: absolute;
  top: 6px;
  right: 6px;
  background: none;
  border: none;
  cursor: pointer;
  color: var(--text3);
  font-size: 0.75rem;
  padding: 4px;
  opacity: 0;
  transition: opacity 0.15s;
}

.res-item:hover .res-del {
  opacity: 1;
}

.res-del:hover {
  color: #f87171;
}

.res-item.res-hidden {
  opacity: 0.55;
  border-style: dashed;
}

.res-hidden-badge {
  position: absolute;
  top: 6px;
  left: 6px;
  background: rgba(0, 0, 0, 0.55);
  color: #fff;
  font-size: 0.65rem;
  padding: 2px 6px;
  border-radius: 6px;
  display: flex;
  align-items: center;
  gap: 4px;
  pointer-events: none;
}

/* ── Fach-Seiten ──────────────────────────────────────────── */
.subj-group-label {
  font-size: 0.78rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.07em;
  color: var(--text2);
  margin: 20px 0 10px;
}

.subj-cards-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 12px;
  margin-bottom: 8px;
}

.subj-page-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--transition), border-color var(--transition);
}

.subj-page-card:hover {
  transform: translateY(-2px);
  border-color: var(--subj-col, var(--accent));
}

.spc-accent {
  width: 5px;
  align-self: stretch;
  background: var(--subj-col, var(--accent));
  flex-shrink: 0;
}

.spc-body {
  flex: 1;
  padding: 12px 14px;
  min-width: 0;
}

.spc-name {
  font-weight: 700;
  font-size: 0.95rem;
  margin-bottom: 3px;
}

.spc-class {
  font-size: 0.75rem;
  color: var(--text2);
  margin-bottom: 8px;
}

.spc-meta {
  display: flex;
  gap: 14px;
  font-size: 0.72rem;
  color: var(--text3);
}

.spc-meta i {
  margin-right: 4px;
}

.spc-arrow {
  padding: 0 16px;
  color: var(--text3);
  font-size: 0.75rem;
}

.subj-dot {
  width: 12px;
  height: 12px;
  border-radius: 50%;
  display: inline-block;
  flex-shrink: 0;
}

.subj-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 20px;
  border-bottom: 1px solid var(--border);
  padding-bottom: 0;
}

.subj-tab {
  padding: 8px 18px;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  transition: color var(--transition), border-color var(--transition);
  display: flex;
  align-items: center;
  gap: 6px;
}

.subj-tab:hover {
  color: var(--text);
}

.subj-tab.active {
  color: var(--accent);
  border-bottom-color: var(--accent);
}

.subj-feed {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-width: 740px;
}

.subj-post-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 18px 20px;
}

.spost-header {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-bottom: 12px;
}

.spost-meta {
  flex: 1;
}

.spost-title {
  font-weight: 700;
  font-size: 1rem;
  margin-bottom: 8px;
}

.spost-content {
  font-size: 0.88rem;
  line-height: 1.7;
  color: var(--text);
  white-space: pre-wrap;
}

/* ── Demo-Zugänge auf Login-Seite ─────────────────────────── */
.demo-accounts {
  margin-top: 20px;
  padding-top: 16px;
  border-top: 1px solid var(--border2);
}

.demo-accounts-label {
  font-size: 0.72rem;
  color: var(--text3);
  text-align: center;
  margin-bottom: 10px;
  font-weight: 500;
  letter-spacing: 0.03em;
}

.demo-chips {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  justify-content: center;
}

.demo-chip {
  background: var(--card2);
  border: 1px solid var(--border);
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 0.75rem;
  font-weight: 600;
  color: var(--text2);
  cursor: pointer;
  transition: background var(--transition), color var(--transition), border-color var(--transition);
  font-family: var(--font);
}

.demo-chip:hover {
  background: var(--accent);
  border-color: var(--accent);
  color: #fff;
}

.demo-account-list {
  margin-top: 10px;
  display: grid;
  gap: 8px;
}

.demo-account-row {
  width: 100%;
  display: grid;
  grid-template-columns: minmax(120px, 1.2fr) 1fr;
  gap: 4px 10px;
  text-align: left;
  padding: 10px 12px;
  border-radius: 12px;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  cursor: pointer;
  transition: border-color .2s ease, transform .2s ease, background .2s ease;
}

.demo-account-row:hover {
  border-color: var(--accent);
  background: var(--card2);
  transform: translateY(-1px);
}

.demo-account-role {
  font-size: .8rem;
  font-weight: 700;
}

.demo-account-cred {
  font-size: .74rem;
  color: var(--text2);
  font-family: ui-monospace, SFMono-Regular, Consolas, monospace;
}

.papyrus-page {
  display: grid;
  gap: 22px;
}

.papyrus-hero,
.papyrus-panel,
.papyrus-mode-card {
  border: 1px solid var(--border);
  background: linear-gradient(180deg, var(--surface), var(--card));
  border-radius: 20px;
  box-shadow: var(--shadow-md);
}

.papyrus-hero {
  padding: 26px;
  display: grid;
  grid-template-columns: 1.6fr 1fr;
  gap: 20px;
  align-items: center;
}

.papyrus-kicker {
  display: inline-flex;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--accent-glow);
  color: var(--accent);
  font-size: .74rem;
  font-weight: 800;
  letter-spacing: .04em;
  text-transform: uppercase;
}

.papyrus-hero-copy h1 {
  margin: 12px 0 10px;
  font-size: 2rem;
  line-height: 1.08;
  letter-spacing: -.04em;
}

.papyrus-hero-copy p {
  color: var(--text2);
  line-height: 1.7;
  max-width: 720px;
}

.papyrus-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  justify-content: flex-end;
  align-items: center;
}

.papyrus-mode-grid,
.papyrus-split-grid {
  display: grid;
  gap: 18px;
}

.papyrus-mode-grid {
  grid-template-columns: repeat(2, minmax(0, 1fr));
}

.papyrus-split-grid {
  grid-template-columns: 1.2fr .9fr;
}

.papyrus-mode-card {
  padding: 24px;
}

.papyrus-mode-icon {
  width: 52px;
  height: 52px;
  border-radius: 16px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--card2);
  color: var(--accent);
  font-size: 1.35rem;
  margin-bottom: 14px;
}

.papyrus-mode-card h3,
.papyrus-panel-head h2 {
  margin: 0 0 8px;
  font-size: 1.18rem;
}

.papyrus-mode-card p,
.papyrus-panel-head p {
  color: var(--text2);
  line-height: 1.65;
  margin: 0;
}

.papyrus-list {
  margin: 16px 0 0;
  padding-left: 18px;
  color: var(--text2);
  line-height: 1.65;
}

.papyrus-list li+li {
  margin-top: 8px;
}

.papyrus-mode-actions {
  margin-top: 18px;
}

.papyrus-panel {
  padding: 22px;
}

.papyrus-file-list,
.papyrus-mini-stack {
  display: grid;
  gap: 10px;
  margin-top: 16px;
}

.papyrus-file-row {
  width: 100%;
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--text);
  border-radius: 16px;
  padding: 14px;
  display: grid;
  grid-template-columns: 42px 1fr auto;
  gap: 12px;
  text-align: left;
  cursor: pointer;
  transition: transform .18s ease, border-color .18s ease, background .18s ease;
}

.papyrus-file-row:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
  background: var(--card2);
}

.papyrus-file-row-icon {
  width: 42px;
  height: 42px;
  border-radius: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: var(--accent-glow);
  color: var(--accent);
}

.papyrus-file-row-title {
  font-size: .92rem;
  font-weight: 700;
}

.papyrus-file-row-meta {
  margin-top: 4px;
  font-size: .76rem;
  color: var(--text3);
}

.papyrus-file-row-tag {
  align-self: center;
  padding: 6px 10px;
  border-radius: 999px;
  background: var(--card2);
  color: var(--text2);
  font-size: .72rem;
  font-weight: 700;
}

.papyrus-mini-card {
  border: 1px solid var(--border);
  background: var(--card);
  border-radius: 16px;
  padding: 14px 16px;
  display: grid;
  gap: 6px;
}

.papyrus-mini-card strong {
  font-size: .9rem;
}

.papyrus-mini-card span {
  color: var(--text2);
  line-height: 1.6;
  font-size: .82rem;
}

.papyrus-editor-shell {
  display: grid;
  gap: 16px;
}

.papyrus-editor-meta {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 10px;
}

.papyrus-editor-meta>div {
  border: 1px solid var(--border);
  background: var(--card2);
  border-radius: 14px;
  padding: 12px;
  display: grid;
  gap: 4px;
}

.papyrus-editor-meta strong {
  font-size: .74rem;
  color: var(--text3);
  text-transform: uppercase;
  letter-spacing: .04em;
}

.papyrus-editor-meta span {
  font-size: .84rem;
  color: var(--text);
}

.papyrus-note-callout {
  display: flex;
  gap: 10px;
  align-items: flex-start;
  border: 1px solid var(--border);
  background: var(--accent-glow);
  border-radius: 14px;
  padding: 14px;
  color: var(--text2);
  line-height: 1.65;
}

.papyrus-note-callout i {
  color: var(--accent);
  margin-top: 3px;
}

.papyrus-doc-area {
  min-height: 320px;
  font-family: Georgia, "Times New Roman", serif;
  line-height: 1.8;
}

.papyrus-empty {
  padding: 24px 16px;
}

@media (max-width: 920px) {

  .papyrus-hero,
  .papyrus-mode-grid,
  .papyrus-split-grid,
  .papyrus-editor-meta {
    grid-template-columns: 1fr;
  }

  .papyrus-hero-actions {
    justify-content: flex-start;
  }
}

/* Papyrus AI */
.papyrus-ai-page {
  position: relative;
  height: 100vh;
  height: 100dvh;
  background:
    linear-gradient(rgba(35, 211, 194, 0.035) 1px, transparent 1px),
    linear-gradient(90deg, rgba(35, 211, 194, 0.035) 1px, transparent 1px),
    radial-gradient(circle at 78% 8%, rgba(37, 99, 235, 0.18), transparent 34rem),
    radial-gradient(circle at 12% 85%, rgba(20, 184, 166, 0.12), transparent 28rem),
    #080d14;
  background-size: 56px 56px, 56px 56px, auto, auto, auto;
  color: #f8fbff;
  overflow: hidden;
  display: grid;
  grid-template-columns: minmax(230px, 280px) minmax(0, 1fr);
  transition: grid-template-columns 0.28s ease;
}

/* Sidebar eingeklappt */
.papyrus-ai-page.sidebar-collapsed {
  grid-template-columns: 0 minmax(0, 1fr);
}
.papyrus-ai-page.sidebar-collapsed .papyrus-ai-rail {
  transform: translateX(-100%);
  opacity: 0;
  pointer-events: none;
  border-right: 0;
}
.papyrus-ai-rail {
  transition: transform 0.28s ease, opacity 0.2s ease;
}

/* Header-Buttons links gruppieren */
.papyrus-ai-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
}

/* — Schul-Setup-Wizard — */
.setup-steps {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 0;
  margin: 20px 0 30px;
}
.setup-step {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 8px;
  opacity: 0.45;
  transition: opacity 0.2s ease;
}
.setup-step.active,
.setup-step.done { opacity: 1; }
.setup-step-num {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(148, 163, 184, 0.18);
  color: #94a3b8;
  display: grid;
  place-items: center;
  font-weight: 800;
  font-size: 1rem;
  border: 2px solid transparent;
  transition: all 0.2s ease;
}
.setup-step.active .setup-step-num {
  background: linear-gradient(135deg, #22d3ee, #6366f1);
  color: white;
  border-color: rgba(125, 211, 252, 0.4);
  box-shadow: 0 0 0 4px rgba(34, 211, 238, 0.15);
}
.setup-step.done .setup-step-num {
  background: rgba(52, 211, 153, 0.2);
  color: #34d399;
  border-color: rgba(52, 211, 153, 0.4);
}
.setup-step-label {
  font-size: 0.82rem;
  color: var(--text2);
  font-weight: 600;
}
.setup-step-line {
  width: 80px;
  height: 2px;
  background: rgba(148, 163, 184, 0.18);
  margin: 0 12px;
  margin-bottom: 26px;
  transition: background 0.3s ease;
}
.setup-step-line.done {
  background: linear-gradient(to right, rgba(52, 211, 153, 0.6), rgba(34, 211, 238, 0.6));
}

.setup-type-card {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 6px;
  padding: 14px;
  border: 2px solid rgba(148, 163, 184, 0.18);
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.5);
  color: var(--text);
  cursor: pointer;
  text-align: center;
  font-size: 0.86rem;
  transition: all 0.15s ease;
  font-family: inherit;
}
.setup-type-card:hover {
  border-color: rgba(34, 211, 238, 0.4);
  background: rgba(34, 211, 238, 0.06);
  transform: translateY(-1px);
}
.setup-type-card.active {
  border-color: var(--accent, #22d3ee);
  background: rgba(34, 211, 238, 0.12);
  box-shadow: 0 0 0 1px rgba(34, 211, 238, 0.3);
}

/* ── Noten-Karten-Editor (Drag & Drop) ── */
.grade-cards {
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 4px;
  background: rgba(0, 0, 0, 0.2);
  border-radius: 14px;
  min-height: 80px;
}
.grade-card {
  display: grid;
  grid-template-columns: 28px 38px 1fr auto 32px;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  transition: all 0.18s ease;
  cursor: grab;
}
.grade-card:hover { background: rgba(255, 255, 255, 0.06); border-color: rgba(20, 184, 166, 0.3); }
.grade-card.dragging { opacity: 0.4; cursor: grabbing; }
.grade-card.drag-over {
  border-color: #14b8a6;
  background: rgba(20, 184, 166, 0.12);
  transform: scale(1.01);
}
.grade-card-handle {
  color: var(--text3);
  cursor: grab;
  text-align: center;
  font-size: 1rem;
}
.grade-card-handle:active { cursor: grabbing; }
.grade-card-rank {
  width: 30px;
  height: 30px;
  border-radius: 8px;
  display: grid;
  place-items: center;
  color: #0a0a0a;
  font-weight: 800;
  font-size: 0.92rem;
}
.grade-card-value {
  background: transparent;
  border: 1px solid transparent;
  color: #fff;
  font-weight: 700;
  font-size: 1.05rem;
  padding: 6px 10px;
  border-radius: 8px;
  outline: none;
  font-family: inherit;
  min-width: 0;
}
.grade-card-value:focus {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(20, 184, 166, 0.4);
}
.grade-card-threshold {
  display: flex;
  align-items: center;
  gap: 4px;
}
.grade-card-pct {
  width: 64px;
  background: rgba(255, 255, 255, 0.05);
  border: 1px solid rgba(255, 255, 255, 0.1);
  border-radius: 8px;
  color: #fff;
  padding: 6px 8px;
  font-weight: 600;
  text-align: right;
  outline: none;
  font-family: inherit;
}
.grade-card-pct:focus { border-color: #14b8a6; }

/* Rating-Karte: weniger Spalten, Label-Input zwischen Value und Delete */
.rating-card {
  grid-template-columns: 28px 38px 90px 1fr 32px;
}
.grade-card-label {
  background: transparent;
  border: 1px solid transparent;
  color: var(--text2);
  font-size: 0.92rem;
  padding: 6px 10px;
  border-radius: 8px;
  outline: none;
  font-family: inherit;
  min-width: 0;
}
.grade-card-label:focus {
  background: rgba(255, 255, 255, 0.05);
  border-color: rgba(20, 184, 166, 0.4);
  color: #fff;
}
.grade-card-label::placeholder { color: var(--text3); font-style: italic; }

@media (max-width: 560px) {
  .rating-card {
    grid-template-columns: 24px 32px 1fr 28px;
    grid-template-rows: auto auto;
  }
  .grade-card-label {
    grid-column: 1 / -1;
    padding-left: 64px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   LESBARKEITS-BOOST (Global Override)
   Macht alle Texte, Inputs, Labels, Placeholder gut sichtbar
   ═══════════════════════════════════════════════════════════════ */

[data-theme="dark"] body,
[data-theme="dark"] {
  color: #f5f5f5;
}

/* Labels überall fett + hell */
[data-theme="dark"] .form-label,
[data-theme="dark"] label {
  color: #e5e5e5 !important;
  font-weight: 600 !important;
  font-size: 0.92rem;
}

/* Inputs / Textareas / Selects — hellerer Background + voller Kontrast */
[data-theme="dark"] .form-input,
[data-theme="dark"] input:not([type="checkbox"]):not([type="radio"]):not([type="range"]):not([type="color"]),
[data-theme="dark"] textarea,
[data-theme="dark"] select {
  background: rgba(255, 255, 255, 0.06) !important;
  border: 1px solid rgba(255, 255, 255, 0.16) !important;
  color: #ffffff !important;
  border-radius: 10px;
}
[data-theme="dark"] .form-input:focus,
[data-theme="dark"] input:focus,
[data-theme="dark"] textarea:focus,
[data-theme="dark"] select:focus {
  background: rgba(255, 255, 255, 0.08) !important;
  border-color: #14b8a6 !important;
  box-shadow: 0 0 0 3px rgba(20, 184, 166, 0.18) !important;
}

/* Placeholder besser sichtbar (war oft kaum erkennbar) */
[data-theme="dark"] input::placeholder,
[data-theme="dark"] textarea::placeholder,
[data-theme="dark"] .form-input::placeholder {
  color: rgba(255, 255, 255, 0.5) !important;
  opacity: 1 !important;
}

/* Disabled-Selects (z.B. in Vorschauen) trotzdem lesbar */
[data-theme="dark"] select:disabled,
[data-theme="dark"] input:disabled,
[data-theme="dark"] textarea:disabled {
  color: #d0d0d0 !important;
  opacity: 0.85 !important;
  -webkit-text-fill-color: #d0d0d0 !important;
}

/* Sekundär-Texte überall heller (war 0.6 → jetzt 0.82) */
[data-theme="dark"] .text-muted,
[data-theme="dark"] .text-sm.text-muted,
[data-theme="dark"] .page-sub,
[data-theme="dark"] small {
  color: rgba(255, 255, 255, 0.78) !important;
}

/* Hilfstext unter Inputs */
[data-theme="dark"] .form-help,
[data-theme="dark"] .text-xs {
  color: rgba(255, 255, 255, 0.7) !important;
}

/* Grade-Card Inputs — bei mir vorher zu dunkel */
.grade-card-value {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.05) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
}
.grade-card-value:focus {
  background: rgba(20, 184, 166, 0.1) !important;
  border-color: #14b8a6 !important;
}
.grade-card-label {
  color: rgba(255, 255, 255, 0.85) !important;
  background: rgba(255, 255, 255, 0.03) !important;
  border-color: rgba(255, 255, 255, 0.1) !important;
}
.grade-card-label::placeholder {
  color: rgba(255, 255, 255, 0.5) !important;
  font-style: normal !important;
}
.grade-card-pct {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.06) !important;
  border-color: rgba(255, 255, 255, 0.14) !important;
}

/* Setup-Type-Cards (Schul-Art / Presets) */
.setup-type-card {
  color: #f0f0f0 !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border-color: rgba(255, 255, 255, 0.12) !important;
}
.setup-type-card:hover {
  background: rgba(20, 184, 166, 0.1) !important;
  border-color: rgba(20, 184, 166, 0.5) !important;
  color: #ffffff !important;
}
.setup-type-card.active {
  background: rgba(20, 184, 166, 0.16) !important;
  border-color: #14b8a6 !important;
  color: #ffffff !important;
}

/* Karten-Headings durchgehend hell */
[data-theme="dark"] .card h1,
[data-theme="dark"] .card h2,
[data-theme="dark"] .card h3,
[data-theme="dark"] .card h4,
[data-theme="dark"] .card strong,
[data-theme="dark"] .card b {
  color: #ffffff !important;
}

/* Buttons im Allgemeinen — keine fast-unsichtbaren Ghosts */
[data-theme="dark"] .btn-ghost {
  color: #ffffff !important;
  background: rgba(255, 255, 255, 0.04) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}
[data-theme="dark"] .btn-ghost:hover {
  background: rgba(20, 184, 166, 0.12) !important;
  border-color: rgba(20, 184, 166, 0.4) !important;
  color: #ffffff !important;
}

/* Sch-Mode-Rows (Anwesenheits-Modus & Selfrating-Text) */
.sch-mode-row {
  color: #f0f0f0 !important;
}
.sch-mode-row strong { color: #ffffff !important; }
.sch-mode-row div[style*="font-size:0.8rem"] { color: rgba(255,255,255,0.75) !important; }

/* Modal-Texte */
[data-theme="dark"] .modal-title,
[data-theme="dark"] .modal-header h3,
[data-theme="dark"] .modal-body strong,
[data-theme="dark"] .modal-body label {
  color: #ffffff !important;
}

/* Empty-States — Headlines weiß, Text gut lesbar */
[data-theme="dark"] .empty-state h3 { color: #ffffff !important; }
[data-theme="dark"] .empty-state p { color: rgba(255, 255, 255, 0.78) !important; }
[data-theme="dark"] .empty-state i { color: #14b8a6 !important; }

/* Pricing-Karten Features */
[data-theme="dark"] .pricing-feat,
[data-theme="dark"] .pricing-for { color: rgba(255, 255, 255, 0.85) !important; }
[data-theme="dark"] .pricing-feat-no { color: rgba(255, 255, 255, 0.5) !important; }
[data-theme="dark"] .pricing-name,
[data-theme="dark"] .pricing-amount,
[data-theme="dark"] .pricing-title { color: #ffffff !important; }

/* Legal-Seiten — falls die wo angezeigt werden */
.legal-page,
.legal-page p,
.legal-page li {
  color: rgba(255, 255, 255, 0.85) !important;
}
.legal-page h2, .legal-page h3, .legal-page strong { color: #ffffff !important; }
.legal-page a { color: #34d399 !important; font-weight: 500; }

/* Schul-Profil */
.sch-meta { color: rgba(255, 255, 255, 0.78) !important; }
.sch-meta i { color: rgba(255, 255, 255, 0.55) !important; }
.sch-bio { color: rgba(255, 255, 255, 0.92) !important; }
.sch-bio-empty { color: rgba(255, 255, 255, 0.55) !important; }
.sch-post-time { color: rgba(255, 255, 255, 0.55) !important; }
.sch-post-body { color: #f5f5f5 !important; }

/* Tabs aktiv — deutlich hervorheben */
[data-theme="dark"] .sch-tab { color: rgba(255, 255, 255, 0.7) !important; }
[data-theme="dark"] .sch-tab.active { color: #ffffff !important; }

/* Composer */
.sch-composer textarea { color: #ffffff !important; }
.sch-composer textarea::placeholder { color: rgba(255, 255, 255, 0.5) !important; }

/* Anwesenheits-Modal */
.student-name { color: #ffffff !important; }
.feedback-select option { background: #1a1a1a; color: #ffffff; }
.note-input { color: #ffffff !important; }

/* Auth-Seiten */
[data-theme="dark"] .auth-title { color: #ffffff !important; }
[data-theme="dark"] .auth-sub { color: rgba(255, 255, 255, 0.78) !important; }
[data-theme="dark"] .auth-switch { color: rgba(255, 255, 255, 0.7) !important; }
[data-theme="dark"] .auth-switch a { color: #14b8a6 !important; font-weight: 600; }
[data-theme="dark"] .demo-accounts-label { color: rgba(255, 255, 255, 0.65) !important; }
[data-theme="dark"] .demo-chip {
  background: rgba(255, 255, 255, 0.05) !important;
  color: rgba(255, 255, 255, 0.9) !important;
  border: 1px solid rgba(255, 255, 255, 0.12) !important;
}
[data-theme="dark"] .demo-chip:hover {
  background: rgba(20, 184, 166, 0.12) !important;
  border-color: rgba(20, 184, 166, 0.4) !important;
  color: #ffffff !important;
}
.grade-card-del {
  background: transparent;
  border: 0;
  color: var(--text3);
  width: 32px;
  height: 32px;
  border-radius: 8px;
  cursor: pointer;
  transition: all 0.15s;
}
.grade-card-del:hover {
  background: rgba(244, 63, 94, 0.12);
  color: #f87171;
}

@media (max-width: 560px) {
  .grade-card {
    grid-template-columns: 24px 32px 1fr 28px;
    grid-template-rows: auto auto;
    gap: 8px;
  }
  .grade-card-threshold {
    grid-column: 1 / -1;
    justify-content: flex-start;
    padding-left: 64px;
  }
}

/* — Toggle-Switch (für Schul-Einstellungen) — */
.switch {
  position: relative;
  display: inline-block;
  width: 46px;
  height: 26px;
  flex-shrink: 0;
}
.switch input { opacity: 0; width: 0; height: 0; }
.switch .slider {
  position: absolute;
  cursor: pointer;
  top: 0; left: 0; right: 0; bottom: 0;
  background: rgba(148, 163, 184, 0.3);
  border-radius: 999px;
  transition: 0.25s ease;
}
.switch .slider::before {
  content: '';
  position: absolute;
  height: 20px;
  width: 20px;
  left: 3px;
  top: 3px;
  background: white;
  border-radius: 50%;
  transition: 0.25s ease;
  box-shadow: 0 2px 6px rgba(0,0,0,0.3);
}
.switch input:checked + .slider {
  background: linear-gradient(135deg, #22d3ee, #6366f1);
}
.switch input:checked + .slider::before {
  transform: translateX(20px);
}

/* — Tabs (Chat | Papyrus Write) — */
.papyrus-ai-tabs {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 4px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(148, 163, 184, 0.14);
}
.papyrus-ai-tab {
  border: 0;
  background: transparent;
  color: #aabbd2;
  padding: 7px 14px;
  border-radius: 9px;
  font-size: 0.86rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 7px;
  font-family: inherit;
  transition: background 0.15s ease, color 0.15s ease;
}
.papyrus-ai-tab:hover { color: #f0faff; }
.papyrus-ai-tab.active {
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.22), rgba(99, 102, 241, 0.22));
  color: #f0faff;
  box-shadow: 0 0 0 1px rgba(125, 211, 252, 0.3);
}

/* — Papyrus Write Editor — */
.papyrus-ai-console.write-mode {
  padding: 0;
}
.papyrus-write-toolbar {
  flex: 0 0 auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
  padding: 16px clamp(20px, 6vw, 80px);
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
  background: rgba(10, 16, 27, 0.5);
  backdrop-filter: blur(12px);
}
.papyrus-write-title {
  width: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  color: #f8fbff;
  font-size: 1.35rem;
  font-weight: 700;
  padding: 4px 0;
  font-family: inherit;
}
.papyrus-write-title::placeholder { color: #4d6178; }

.papyrus-write-tools {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.papyrus-write-tools button {
  border: 1px solid rgba(148, 163, 184, 0.18);
  background: rgba(15, 23, 42, 0.7);
  color: #c8d6ec;
  padding: 7px 12px;
  border-radius: 999px;
  font-size: 0.82rem;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background 0.15s ease, color 0.15s ease, border-color 0.15s ease, transform 0.12s ease;
  font-family: inherit;
}
.papyrus-write-tools button:hover {
  background: rgba(34, 211, 238, 0.12);
  border-color: rgba(34, 211, 238, 0.4);
  color: #f0faff;
  transform: translateY(-1px);
}
.papyrus-write-tools button i { font-size: 0.78rem; }
.papyrus-write-tools .papyrus-write-custom {
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.18), rgba(99, 102, 241, 0.22));
  border-color: rgba(125, 211, 252, 0.35);
  color: #f0faff;
}
.papyrus-write-tools .papyrus-write-delete {
  margin-left: auto;
  color: #fda4af;
  border-color: rgba(244, 63, 94, 0.25);
}
.papyrus-write-tools .papyrus-write-delete:hover {
  background: rgba(244, 63, 94, 0.18);
  border-color: rgba(244, 63, 94, 0.55);
  color: #ffe4e6;
}

.papyrus-write-split {
  flex: 1;
  min-height: 0;
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(280px, 340px);
  overflow: hidden;
}

.papyrus-write-editor-wrap {
  min-height: 0;
  overflow: auto;
  padding: 30px clamp(20px, 6vw, 80px);
  display: flex;
  justify-content: center;
  border-right: 1px solid rgba(148, 163, 184, 0.08);
}
.papyrus-write-editor {
  width: 100%;
  max-width: 820px;
  min-height: 100%;
  background: transparent;
  border: 0;
  outline: 0;
  color: #eaf2ff;
  font-size: 1.02rem;
  line-height: 1.75;
  font-family: 'Inter', ui-sans-serif, system-ui, sans-serif;
  padding: 0;
  white-space: pre-wrap;
  word-wrap: break-word;
}
.papyrus-write-editor:empty::before {
  content: attr(data-placeholder);
  color: #5b6f88;
  pointer-events: none;
}

/* Fehler-Markierungen */
.lt-err-spell {
  text-decoration: underline wavy #f87171;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  cursor: help;
}
.lt-err-grammar {
  text-decoration: underline wavy #60a5fa;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  cursor: help;
}
.lt-err-style {
  text-decoration: underline wavy #fbbf24;
  text-decoration-thickness: 2px;
  text-underline-offset: 3px;
  cursor: help;
}

/* Feedback-Panel rechts */
.papyrus-write-feedback {
  min-width: 0;
  overflow: auto;
  padding: 22px 18px;
  background: rgba(8, 13, 20, 0.55);
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.lt-loading { color: #8da2c0; font-size: 0.88rem; }

.lt-panel-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.82rem;
  color: #aabbd2;
}
.lt-lang { display: inline-flex; align-items: center; gap: 6px; color: #67e8f9; font-weight: 600; }
.lt-lang small { color: #5b7090; font-weight: 500; }

.lt-overall {
  text-align: center;
  padding: 14px;
  background: rgba(15, 23, 42, 0.6);
  border: 1px solid rgba(148, 163, 184, 0.12);
  border-radius: 14px;
}
.lt-overall-num {
  font-size: 2.5rem;
  font-weight: 800;
  color: var(--c, #34d399);
  line-height: 1;
}
.lt-overall-num::after { content: '%'; font-size: 1.2rem; font-weight: 600; margin-left: 2px; opacity: 0.7; }
.lt-overall-label { font-size: 0.78rem; color: #8da2c0; margin-top: 4px; text-transform: uppercase; letter-spacing: 0.06em; }

.lt-scores { display: flex; flex-direction: column; gap: 12px; }
.lt-score-row { display: flex; flex-direction: column; gap: 4px; }
.lt-score-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.84rem;
  color: #c8d6ec;
}
.lt-score-top i { margin-right: 6px; color: #7dd3fc; }
.lt-score-top strong { color: #f0faff; }
.lt-bar {
  height: 6px;
  border-radius: 999px;
  background: rgba(148, 163, 184, 0.14);
  overflow: hidden;
}
.lt-bar span {
  display: block;
  height: 100%;
  border-radius: 999px;
  transition: width 0.35s ease;
}
.lt-score-row small { font-size: 0.72rem; color: #6c7e96; }

/* KI-Feedback-Sektion */
.papyrus-write-aifb {
  border-top: 1px solid rgba(148, 163, 184, 0.1);
  padding-top: 14px;
  display: flex;
  flex-direction: column;
  gap: 10px;
}
.papyrus-write-aifb-head {
  display: flex;
  justify-content: space-between;
  align-items: center;
  font-size: 0.78rem;
  color: #c7d2fe;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
}
.papyrus-write-aifb-head i.fa-wand-magic-sparkles {
  background: linear-gradient(135deg, #22d3ee, #a78bfa);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
  margin-right: 4px;
}
.papyrus-write-aifb-btn {
  border: 0;
  background: rgba(99, 102, 241, 0.18);
  color: #c7d2fe;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.78rem;
  transition: background 0.15s ease, transform 0.18s ease;
}
.papyrus-write-aifb-btn:hover {
  background: rgba(99, 102, 241, 0.35);
  transform: rotate(180deg);
}

.papyrus-write-aifb-body {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

.aifb-meta {
  display: flex;
  gap: 8px;
}
.aifb-chip {
  flex: 1;
  padding: 8px 10px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(148, 163, 184, 0.14);
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.aifb-chip span {
  font-size: 0.66rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: #8da2c0;
  font-weight: 600;
}
.aifb-chip strong {
  font-size: 0.92rem;
  color: #f0faff;
}

.aifb-impression {
  font-style: italic;
  color: #cbd5e1;
  font-size: 0.88rem;
  padding: 10px 12px;
  border-left: 3px solid #a78bfa;
  background: rgba(167, 139, 250, 0.06);
  border-radius: 0 8px 8px 0;
  line-height: 1.5;
}

.aifb-section {
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.55);
  border: 1px solid rgba(148, 163, 184, 0.1);
}
.aifb-section-title {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  font-weight: 700;
  color: #c8d6ec;
  margin-bottom: 6px;
}
.aifb-section ul {
  margin: 0;
  padding-left: 18px;
  color: #dbe7f6;
  font-size: 0.84rem;
  line-height: 1.5;
}
.aifb-section li { margin: 3px 0; }

.lt-issues-head {
  font-size: 0.78rem;
  color: #8da2c0;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  border-top: 1px solid rgba(148, 163, 184, 0.1);
  padding-top: 12px;
}

.lt-empty {
  padding: 14px;
  border-radius: 12px;
  background: rgba(52, 211, 153, 0.12);
  border: 1px solid rgba(52, 211, 153, 0.3);
  color: #6ee7b7;
  font-size: 0.86rem;
  text-align: center;
}
.lt-empty i { margin-right: 6px; }

.lt-issues { display: flex; flex-direction: column; gap: 8px; }
.lt-issue {
  padding: 10px 12px;
  border-radius: 10px;
  background: rgba(15, 23, 42, 0.65);
  border-left: 3px solid #f87171;
  font-size: 0.82rem;
}
.lt-issue.lt-err-grammar { border-left-color: #60a5fa; }
.lt-issue.lt-err-style { border-left-color: #fbbf24; }
.lt-issue-head { display: flex; align-items: center; gap: 8px; margin-bottom: 4px; }
.lt-issue-badge {
  font-size: 0.7rem;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  padding: 2px 7px;
  border-radius: 999px;
  background: rgba(248, 113, 113, 0.18);
  color: #fecaca;
  font-weight: 700;
}
.lt-issue.lt-err-grammar .lt-issue-badge { background: rgba(96, 165, 250, 0.18); color: #bfdbfe; }
.lt-issue.lt-err-style .lt-issue-badge { background: rgba(251, 191, 36, 0.18); color: #fde68a; }
.lt-issue-word {
  font-family: ui-monospace, Menlo, Consolas, monospace;
  color: #f0faff;
  font-size: 0.84rem;
}
.lt-issue-msg { color: #c8d6ec; line-height: 1.45; }
.lt-issue-repls { margin-top: 6px; font-size: 0.78rem; color: #8da2c0; }
.lt-issue-repls code {
  background: rgba(34, 211, 238, 0.1);
  border: 1px solid rgba(34, 211, 238, 0.25);
  color: #a7f3d0;
  padding: 1px 6px;
  border-radius: 5px;
  font-family: ui-monospace, Menlo, Consolas, monospace;
  font-size: 0.78rem;
}

/* Legende in der Statusleiste */
.papyrus-write-hint .lt-spell { color: #f87171; text-decoration: underline wavy #f87171; text-underline-offset: 2px; }
.papyrus-write-hint .lt-grammar { color: #60a5fa; text-decoration: underline wavy #60a5fa; text-underline-offset: 2px; }
.papyrus-write-hint .lt-style { color: #fbbf24; text-decoration: underline wavy #fbbf24; text-underline-offset: 2px; }

@media (max-width: 1100px) {
  .papyrus-write-split { grid-template-columns: 1fr; }
  .papyrus-write-feedback { display: none; }
}

.papyrus-write-status {
  flex: 0 0 auto;
  padding: 10px clamp(20px, 6vw, 80px);
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  font-size: 0.78rem;
  color: #8da2c0;
  background: rgba(8, 13, 20, 0.7);
  border-top: 1px solid rgba(148, 163, 184, 0.08);
  backdrop-filter: blur(10px);
}
.papyrus-write-hint i { color: #fbbf24; margin-right: 4px; }

@media (max-width: 700px) {
  .papyrus-write-tools button .papyrus-write-label,
  .papyrus-write-status .papyrus-write-hint { display: none; }
}

.main-content:has(.papyrus-ai-page) {
  padding: 0;
  background: #080d14;
  height: 100vh;
  height: 100dvh;
  overflow: hidden;
}

.papyrus-ai-gradient {
  position: absolute;
  pointer-events: none;
  filter: blur(52px);
  opacity: 0.5;
  transform: rotate(-20deg) skew(-35deg);
}

.papyrus-ai-gradient::before,
.papyrus-ai-gradient::after {
  content: '';
  position: absolute;
  width: 8rem;
  height: 26rem;
  background: linear-gradient(90deg, rgba(255,255,255,0.85), rgba(125, 211, 252, 0.75));
}

.papyrus-ai-gradient::after {
  left: 12rem;
}

.papyrus-ai-gradient-a {
  top: -25rem;
  right: -16rem;
  width: 32rem;
  height: 40rem;
}

.papyrus-ai-gradient-b {
  top: -34rem;
  right: 5rem;
  width: 26rem;
  height: 36rem;
  opacity: 0.32;
}

.papyrus-ai-rail,
.papyrus-ai-main {
  position: relative;
  z-index: 1;
}

.papyrus-ai-rail {
  height: 100vh;
  height: 100dvh;
  padding: 22px 16px;
  border-right: 1px solid rgba(148, 163, 184, 0.12);
  background: rgba(7, 12, 20, 0.74);
  backdrop-filter: blur(18px);
  display: flex;
  flex-direction: column;
  gap: 14px;
  overflow: hidden;
}

.papyrus-ai-brand {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 8px 4px 14px;
}

.papyrus-ai-logo {
  width: 42px;
  height: 42px;
  border-radius: 14px;
  background: linear-gradient(135deg, #22d3ee, #8b5cf6);
  display: grid;
  place-items: center;
  color: white;
  box-shadow: 0 16px 34px rgba(34, 211, 238, 0.18);
}

.papyrus-ai-brand strong,
.papyrus-ai-brand span {
  display: block;
}

.papyrus-ai-brand strong {
  font-size: 1rem;
  letter-spacing: 0;
}

.papyrus-ai-brand span {
  margin-top: 3px;
  color: #8da2c0;
  font-size: 0.78rem;
}

.papyrus-ai-new,
.papyrus-ai-small-btn,
.papyrus-ai-back,
.papyrus-ai-chat-actions button,
.papyrus-ai-prompt button,
.papyrus-ai-suggestions button {
  border: 0;
  cursor: pointer;
  transition: transform 0.18s ease, background 0.18s ease, border-color 0.18s ease;
}

.papyrus-ai-new {
  width: 100%;
  border-radius: 14px;
  padding: 12px 14px;
  background: #f8fafc;
  color: #08111f;
  font-weight: 800;
}

.papyrus-ai-new:hover,
.papyrus-ai-small-btn:hover,
.papyrus-ai-back:hover,
.papyrus-ai-chat-actions button:hover,
.papyrus-ai-prompt button:hover,
.papyrus-ai-suggestions button:hover {
  transform: translateY(-1px);
}

.papyrus-ai-thread-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  overflow: auto;
  min-height: 0;
  flex: 1;
  padding-right: 2px;
}

.papyrus-ai-thread {
  width: 100%;
  min-height: 58px;
  border: 1px solid transparent;
  border-radius: 14px;
  padding: 9px;
  background: transparent;
  color: #d8e4f4;
  display: flex;
  gap: 10px;
  text-align: left;
}

.papyrus-ai-thread:hover,
.papyrus-ai-thread.active {
  background: rgba(24, 36, 56, 0.86);
  border-color: rgba(45, 212, 191, 0.18);
}

.papyrus-ai-thread-icon {
  width: 34px;
  height: 34px;
  border-radius: 11px;
  display: grid;
  place-items: center;
  background: rgba(15, 23, 42, 0.95);
  color: #67e8f9;
  flex: 0 0 auto;
}

.papyrus-ai-thread-copy {
  min-width: 0;
}

.papyrus-ai-thread-copy strong,
.papyrus-ai-thread-copy small {
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.papyrus-ai-thread-copy strong {
  font-size: 0.88rem;
}

.papyrus-ai-thread-copy small {
  margin-top: 4px;
  color: #7f93ad;
  font-size: 0.75rem;
}

.papyrus-ai-local-card {
  border: 1px solid rgba(45, 212, 191, 0.2);
  border-radius: 16px;
  padding: 13px;
  background: rgba(14, 28, 43, 0.78);
  display: flex;
  gap: 10px;
  align-items: center;
}

.papyrus-ai-local-card strong,
.papyrus-ai-local-card small {
  display: block;
}

.papyrus-ai-local-card strong {
  font-size: 0.84rem;
}

.papyrus-ai-local-card small {
  margin-top: 3px;
  color: #8da2c0;
  font-size: 0.74rem;
}

.papyrus-ai-pulse {
  width: 10px;
  height: 10px;
  border-radius: 50%;
  background: #2dd4bf;
  box-shadow: 0 0 0 7px rgba(45, 212, 191, 0.12);
}

.papyrus-ai-main {
  min-width: 0;
  height: 100vh;
  height: 100dvh;
  padding: 0;
  display: flex;
  flex-direction: column;
  overflow: hidden;
}

/* Oberer Header (Back, Chip, Neu) — fest oben */
.papyrus-ai-header {
  flex: 0 0 auto;
  padding: 14px clamp(14px, 2vw, 28px);
  background: rgba(8, 13, 20, 0.6);
  backdrop-filter: blur(14px);
  border-bottom: 1px solid rgba(148, 163, 184, 0.06);
  z-index: 5;
}

.papyrus-ai-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
}

.papyrus-ai-back,
.papyrus-ai-small-btn,
.papyrus-ai-chip {
  height: 40px;
  border-radius: 999px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
}

.papyrus-ai-back,
.papyrus-ai-small-btn {
  background: rgba(15, 23, 42, 0.76);
  color: #dbeafe;
  padding: 0 14px;
  border: 1px solid rgba(148, 163, 184, 0.16);
}

.papyrus-ai-chip {
  padding: 0 15px;
  color: #b9c9df;
  background: rgba(19, 30, 49, 0.68);
  border: 1px solid rgba(148, 163, 184, 0.14);
  font-size: 0.84rem;
}

.papyrus-ai-hero {
  text-align: center;
  margin: 0 auto;
  padding: clamp(30px, 8vh, 80px) 20px 20px;
  max-width: 820px;
  flex: 0 0 auto;
}

.papyrus-ai-kicker {
  display: flex;
  justify-content: center;
  margin-bottom: 18px;
}

.papyrus-ai-kicker span {
  border-radius: 999px;
  padding: 8px 14px;
  background: rgba(28, 21, 40, 0.9);
  color: #d9e8ff;
  font-size: 0.78rem;
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.papyrus-ai-hero h1 {
  margin: 0;
  font-size: clamp(1.8rem, 4vw, 2.6rem);
  line-height: 1.15;
  letter-spacing: -0.02em;
  font-weight: 700;
  color: #f8fbff;
}

.papyrus-ai-hero p {
  margin: 10px auto 0;
  color: #aabbd2;
  font-size: 1rem;
  max-width: 520px;
}

.papyrus-ai-console {
  width: 100%;
  margin: 0;
  border: none;
  border-radius: 0;
  background: transparent;
  box-shadow: none;
  backdrop-filter: none;
  overflow: hidden;
  flex: 1;
  min-height: 0;
  display: flex;
  flex-direction: column;
}

.papyrus-ai-chat-head {
  display: flex;
  justify-content: space-between;
  gap: 14px;
  padding: 14px clamp(20px, 8vw, 120px);
  border-bottom: 1px solid rgba(148, 163, 184, 0.08);
  background: rgba(10, 16, 27, 0.4);
  backdrop-filter: blur(12px);
  flex: 0 0 auto;
}

.papyrus-ai-chat-head strong,
.papyrus-ai-chat-head span {
  display: block;
}

.papyrus-ai-chat-head span {
  margin-top: 4px;
  color: #8193ab;
  font-size: 0.82rem;
}

.papyrus-ai-chat-actions {
  display: flex;
  gap: 8px;
}

.papyrus-ai-chat-actions button {
  width: 34px;
  height: 34px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.8);
  color: #bdd0e8;
}

.papyrus-ai-messages {
  flex: 1;
  min-height: 0;
  overflow: auto;
  padding: 24px clamp(20px, 8vw, 120px) 28px;
  display: flex;
  flex-direction: column;
  gap: 26px;
  width: 100%;
  max-width: 100%;
  overflow-anchor: none;
}

/* Innere Begrenzung der Nachrichten, damit Text nicht ultraweit wird */
.papyrus-ai-message {
  max-width: 880px;
  width: 100%;
  margin-left: auto;
  margin-right: auto;
}

.papyrus-ai-message {
  width: 100%;
  display: flex;
  gap: 14px;
  align-items: flex-start;
  line-height: 1.65;
  color: #eaf2ff;
  animation: papyrus-ai-fade-in 0.22s ease;
}

.papyrus-ai-message.user {
  justify-content: flex-end;
}

.papyrus-ai-user-wrap {
  max-width: 78%;
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 6px;
}

.papyrus-ai-user-bubble {
  border-radius: 20px;
  border-bottom-right-radius: 6px;
  padding: 12px 16px;
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.18), rgba(99, 102, 241, 0.22));
  border: 1px solid rgba(125, 211, 252, 0.28);
  color: #f4faff;
  font-size: 0.97rem;
  word-wrap: break-word;
  overflow-wrap: anywhere;
}

.papyrus-ai-ai-wrap {
  flex: 1;
  min-width: 0;
}

.papyrus-ai-message.assistant .papyrus-ai-message-body {
  color: #e6eefb;
  font-size: 0.98rem;
}

.papyrus-ai-message.pending { opacity: 0.95; }

.papyrus-ai-avatar {
  flex: 0 0 36px;
  width: 36px;
  height: 36px;
  border-radius: 50%;
  display: grid;
  place-items: center;
  color: #fff;
  font-size: 0.9rem;
  box-shadow: 0 6px 18px rgba(0,0,0,0.35);
}

.papyrus-ai-avatar.ai {
  background: linear-gradient(135deg, #22d3ee 0%, #6366f1 55%, #d946ef 100%);
}

.papyrus-ai-avatar.user {
  background: linear-gradient(135deg, #14b8a6, #0ea5e9);
}

.papyrus-ai-searching {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  padding: 6px 12px;
  border-radius: 999px;
  background: rgba(34, 211, 238, 0.1);
  border: 1px solid rgba(34, 211, 238, 0.25);
  color: #7dd3fc;
  font-size: 0.85rem;
}
.papyrus-ai-searching i { animation: papyrus-ai-spin 2s linear infinite; }
@keyframes papyrus-ai-spin { to { transform: rotate(360deg); } }

/* Web image grid */
.papyrus-ai-image-grid {
  margin: 14px 0 4px;
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
}
.papyrus-ai-image-card {
  display: block;
  border-radius: 14px;
  overflow: hidden;
  background: rgba(15, 23, 42, 0.6);
  border: 1px solid rgba(148, 163, 184, 0.14);
  text-decoration: none;
  color: inherit;
  transition: transform 0.18s ease, border-color 0.18s ease;
}
.papyrus-ai-image-card:hover {
  transform: translateY(-2px);
  border-color: rgba(125, 211, 252, 0.4);
}
.papyrus-ai-image-wrap {
  aspect-ratio: 4/3;
  background: #0b1220;
  overflow: hidden;
}
.papyrus-ai-image-wrap img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}
.papyrus-ai-image-cap {
  padding: 8px 10px;
  font-size: 0.78rem;
  color: #aabbd2;
  line-height: 1.35;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* Quellen — Grok-style: zugeklappt zeigt nur Button mit Favicon-Stack */
.papyrus-ai-sources {
  margin-top: 14px;
}

.papyrus-ai-sources-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 7px 12px 7px 8px;
  border-radius: 999px;
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(148, 163, 184, 0.18);
  color: #c8d6ec;
  font-size: 0.84rem;
  cursor: pointer;
  transition: background 0.18s ease, border-color 0.18s ease, transform 0.18s ease;
  font-family: inherit;
}
.papyrus-ai-sources-btn:hover {
  background: rgba(34, 211, 238, 0.1);
  border-color: rgba(34, 211, 238, 0.35);
  color: #f0faff;
}

.papyrus-ai-fav-stack {
  display: inline-flex;
  align-items: center;
}
.papyrus-ai-fav-stack-img {
  width: 20px;
  height: 20px;
  border-radius: 50%;
  background: #0b1220;
  border: 2px solid #0b1220;
  margin-left: -6px;
  object-fit: cover;
  box-shadow: 0 1px 2px rgba(0,0,0,0.4);
}
.papyrus-ai-fav-stack-img:first-child { margin-left: 0; }

.papyrus-ai-sources-label {
  font-weight: 600;
}

.papyrus-ai-sources-chev {
  font-size: 0.7rem;
  color: #8da2c0;
  transition: transform 0.22s ease;
}
.papyrus-ai-sources-btn.open .papyrus-ai-sources-chev,
.papyrus-ai-sources.open .papyrus-ai-sources-chev {
  transform: rotate(180deg);
}

.papyrus-ai-sources-list {
  display: none;
  flex-direction: column;
  gap: 8px;
  margin-top: 12px;
  padding: 12px;
  border-radius: 14px;
  background: rgba(10, 16, 27, 0.55);
  border: 1px solid rgba(148, 163, 184, 0.12);
  animation: papyrus-ai-fade-in 0.2s ease;
}
.papyrus-ai-sources.open .papyrus-ai-sources-list {
  display: flex;
}

.papyrus-ai-source-chip {
  display: grid;
  grid-template-columns: 22px 24px 1fr;
  align-items: center;
  gap: 10px;
  padding: 10px 12px;
  border-radius: 12px;
  background: rgba(15, 23, 42, 0.75);
  border: 1px solid rgba(148, 163, 184, 0.14);
  color: #dbe7f6;
  font-size: 0.85rem;
  text-decoration: none;
  transition: border-color 0.18s ease, background 0.18s ease, transform 0.18s ease;
}
.papyrus-ai-source-chip:hover {
  background: rgba(34, 211, 238, 0.08);
  border-color: rgba(34, 211, 238, 0.4);
  transform: translateX(2px);
}
.papyrus-ai-source-num {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: linear-gradient(135deg, #22d3ee, #6366f1);
  color: #fff;
  font-size: 0.72rem;
  font-weight: 700;
  display: grid;
  place-items: center;
  flex: 0 0 auto;
}
.papyrus-ai-source-fav {
  width: 24px;
  height: 24px;
  border-radius: 6px;
  background: #0b1220;
  object-fit: cover;
}
.papyrus-ai-source-text {
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.papyrus-ai-source-title {
  font-weight: 600;
  color: #f0faff;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.papyrus-ai-source-domain {
  font-size: 0.74rem;
  color: #8da2c0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Action toolbar (thumbs / regen / copy) */
.papyrus-ai-actions {
  margin-top: 12px;
  display: flex;
  gap: 4px;
  opacity: 0;
  transition: opacity 0.2s ease;
}
.papyrus-ai-message:hover .papyrus-ai-actions { opacity: 1; }
.papyrus-ai-actions button {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: 0;
  background: transparent;
  color: #8da2c0;
  cursor: pointer;
  font-size: 0.85rem;
  transition: background 0.15s ease, color 0.15s ease;
}
.papyrus-ai-actions button:hover {
  background: rgba(148, 163, 184, 0.12);
  color: #f0faff;
}
.papyrus-ai-actions button.active {
  background: rgba(34, 211, 238, 0.18);
  color: #7dd3fc;
}

/* Web search toggle button — distinct active state */
#papyrus-ai-web-btn.active {
  background: linear-gradient(135deg, rgba(34, 211, 238, 0.25), rgba(99, 102, 241, 0.28)) !important;
  color: #f0faff !important;
  box-shadow: 0 0 0 1px rgba(125, 211, 252, 0.45);
}

.papyrus-ai-message-body > *:first-child { margin-top: 0; }
.papyrus-ai-message-body > *:last-child { margin-bottom: 0; }
.papyrus-ai-message-body p { margin: 0 0 8px; }
.papyrus-ai-message-body p:last-child { margin-bottom: 0; }

.papyrus-ai-h {
  margin: 12px 0 6px;
  font-weight: 700;
  color: #f8fbff;
  line-height: 1.3;
}
.papyrus-ai-message-body h2.papyrus-ai-h { font-size: 1.1rem; }
.papyrus-ai-message-body h3.papyrus-ai-h { font-size: 1.02rem; }
.papyrus-ai-message-body h4.papyrus-ai-h { font-size: 0.95rem; color: #c8d6ec; }

.papyrus-ai-list {
  margin: 4px 0 10px;
  padding-left: 22px;
}
.papyrus-ai-list li { margin: 3px 0; }

.papyrus-ai-inline-code {
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 0.88em;
  padding: 2px 6px;
  border-radius: 6px;
  background: rgba(15, 23, 42, 0.7);
  border: 1px solid rgba(148, 163, 184, 0.16);
  color: #f0abfc;
}

.papyrus-ai-code {
  position: relative;
  margin: 10px 0;
  padding: 14px 14px 12px;
  border-radius: 12px;
  background: #0b1220;
  border: 1px solid rgba(148, 163, 184, 0.14);
  font-family: ui-monospace, 'SF Mono', Menlo, Consolas, monospace;
  font-size: 0.86rem;
  color: #d8e4f4;
  overflow-x: auto;
  white-space: pre;
}

.papyrus-ai-code code {
  background: transparent;
  padding: 0;
  border: 0;
  color: inherit;
  font-family: inherit;
}

.papyrus-ai-code-lang {
  position: absolute;
  top: 6px;
  right: 10px;
  font-size: 0.68rem;
  letter-spacing: 0.06em;
  text-transform: uppercase;
  color: #7dd3fc;
  font-family: inherit;
}

.papyrus-ai-typing {
  display: inline-flex;
  gap: 5px;
  padding: 4px 2px;
  align-items: center;
}

.papyrus-ai-typing span {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: #94a3b8;
  animation: papyrus-ai-bounce 1.2s infinite ease-in-out both;
}

.papyrus-ai-typing span:nth-child(1) { animation-delay: -0.32s; }
.papyrus-ai-typing span:nth-child(2) { animation-delay: -0.16s; }

@keyframes papyrus-ai-bounce {
  0%, 80%, 100% { transform: scale(0.6); opacity: 0.5; }
  40% { transform: scale(1); opacity: 1; }
}

@keyframes papyrus-ai-fade-in {
  from { opacity: 0; transform: translateY(4px); }
  to { opacity: 1; transform: translateY(0); }
}

.papyrus-ai-hero-logo {
  width: 64px;
  height: 64px;
  margin: 0 auto 18px;
  border-radius: 22px;
  display: grid;
  place-items: center;
  font-size: 1.5rem;
  color: #fff;
  background: linear-gradient(135deg, #22d3ee 0%, #6366f1 55%, #d946ef 100%);
  box-shadow: 0 18px 44px rgba(99, 102, 241, 0.4);
}

.papyrus-ai-hero-grad {
  background: linear-gradient(135deg, #22d3ee, #6366f1, #d946ef);
  -webkit-background-clip: text;
  background-clip: text;
  color: transparent;
}

.papyrus-ai-message-file {
  width: fit-content;
  max-width: 100%;
  margin-bottom: 8px;
  border: 1px solid rgba(45, 212, 191, 0.22);
  border-radius: 999px;
  padding: 6px 10px;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #c8f8f1;
  background: rgba(20, 184, 166, 0.08);
  font-size: 0.8rem;
}

.papyrus-ai-empty {
  min-height: 150px;
  display: grid;
  place-items: center;
  align-content: center;
  gap: 8px;
  color: #92a4bb;
  text-align: center;
}

.papyrus-ai-empty i {
  color: #67e8f9;
  font-size: 1.5rem;
}

.papyrus-ai-empty strong {
  color: #edf6ff;
}

.papyrus-ai-prompt-wrap {
  padding: 12px clamp(20px, 8vw, 120px) 22px;
  flex: 0 0 auto;
  background: linear-gradient(to top, rgba(8, 13, 20, 0.95) 60%, rgba(8, 13, 20, 0));
}
.papyrus-ai-prompt-wrap > * {
  max-width: 880px;
  margin-left: auto;
  margin-right: auto;
}

.papyrus-ai-file-preview {
  min-height: 0;
  display: flex;
  justify-content: center;
  margin-bottom: 10px;
}

.papyrus-ai-file-pill {
  max-width: min(100%, 520px);
  border: 1px solid rgba(45, 212, 191, 0.22);
  border-radius: 999px;
  padding: 8px 9px 8px 12px;
  background: rgba(20, 184, 166, 0.09);
  color: #dffbf7;
  display: flex;
  align-items: center;
  gap: 9px;
  font-size: 0.84rem;
}

.papyrus-ai-file-pill span {
  min-width: 0;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

.papyrus-ai-file-pill small {
  color: #8fb6c3;
  font-size: 0.74rem;
}

.papyrus-ai-file-pill button {
  width: 26px;
  height: 26px;
  border: 0;
  border-radius: 50%;
  background: rgba(15, 23, 42, 0.7);
  color: #dffbf7;
  cursor: pointer;
}

.papyrus-ai-suggestions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  justify-content: center;
  margin-bottom: 13px;
}

.papyrus-ai-suggestions button {
  border-radius: 999px;
  padding: 9px 13px;
  background: rgba(28, 21, 40, 0.9);
  color: #c9d6e8;
  font-size: 0.82rem;
  border: 1px solid rgba(148, 163, 184, 0.12);
}

.papyrus-ai-suggestions button:hover {
  background: rgba(42, 31, 61, 0.95);
  color: white;
}

.papyrus-ai-prompt {
  min-height: 66px;
  border-radius: 999px;
  background: #1c1528;
  border: 1px solid rgba(148, 163, 184, 0.13);
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 9px 10px;
}

.papyrus-ai-prompt textarea {
  flex: 1;
  min-width: 0;
  height: 40px;
  max-height: 120px;
  border: 0;
  outline: 0;
  resize: none;
  background: transparent;
  color: #edf6ff;
  padding: 10px 12px;
  font: inherit;
}

.papyrus-ai-prompt textarea::placeholder {
  color: #75869d;
}

.papyrus-ai-prompt button {
  width: 42px;
  height: 42px;
  border-radius: 50%;
  background: transparent;
  color: #9caec7;
}

.papyrus-ai-prompt button:hover {
  background: #2a1f3d;
  color: white;
}

.papyrus-ai-prompt .papyrus-ai-send {
  background: #f8fafc;
  color: #0f172a;
}

@media (max-width: 900px) {
  .papyrus-ai-page {
    margin-left: 0;
    grid-template-columns: 1fr;
  }

  .papyrus-ai-page.sidebar-collapsed {
    grid-template-columns: 1fr;
  }
  .papyrus-ai-page.sidebar-collapsed .papyrus-ai-rail {
    display: none;
  }

  .papyrus-ai-rail {
    min-height: auto;
    height: auto;
    border-right: 0;
    border-bottom: 1px solid rgba(148, 163, 184, 0.12);
  }

  .papyrus-ai-thread-list {
    max-height: 170px;
  }

  .papyrus-ai-main {
    padding: 18px 14px 28px;
  }

  .papyrus-ai-prompt {
    border-radius: 22px;
    align-items: flex-end;
  }

  .papyrus-ai-message {
    max-width: 92%;
  }
}

/* ── Papyrus Notebook Dashboard ──────────────────────────── */
.papyrus-dash-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-bottom: 18px;
}

.papyrus-search {
  flex: 1;
  min-width: 180px;
  padding: 10px 14px;
  border-radius: 12px;
  background: var(--input-bg);
  border: 1.5px solid var(--border2);
  color: var(--text);
  font-size: .88rem;
}

.papyrus-search:focus {
  outline: none;
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

.papyrus-search::placeholder {
  color: var(--text3);
}

.papyrus-nb-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 16px;
}

.papyrus-nb-card {
  position: relative;
  border-radius: 18px;
  overflow: hidden;
  border: 1.5px solid var(--border);
  background: var(--card);
  cursor: pointer;
  transition: transform .2s ease, border-color .2s ease, box-shadow .2s ease;
}

.papyrus-nb-card:hover {
  transform: translateY(-4px);
  border-color: var(--accent);
  box-shadow: 0 12px 32px rgba(0, 0, 0, .22);
}

.papyrus-nb-cover {
  height: 120px;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 2.4rem;
  color: rgba(255, 255, 255, .85);
  background: linear-gradient(135deg, #c9a96e, #e8d5a3);
}

.papyrus-nb-cover[data-cover="blue"] {
  background: linear-gradient(135deg, #3b82f6, #1d4ed8);
}

.papyrus-nb-cover[data-cover="purple"] {
  background: linear-gradient(135deg, #8b5cf6, #6d28d9);
}

.papyrus-nb-cover[data-cover="green"] {
  background: linear-gradient(135deg, #10b981, #047857);
}

.papyrus-nb-cover[data-cover="red"] {
  background: linear-gradient(135deg, #ef4444, #b91c1c);
}

.papyrus-nb-cover[data-cover="gold"] {
  background: linear-gradient(135deg, #c9a96e, #8b6914);
}

.papyrus-nb-cover[data-cover="cream"] {
  background: linear-gradient(135deg, #fdf6e3, #f5e6c8);
  color: #8b6914;
}

.papyrus-nb-cover[data-cover="dark"] {
  background: linear-gradient(135deg, #1e293b, #0f172a);
}

.papyrus-nb-body {
  padding: 14px;
}

.papyrus-nb-title {
  font-size: .92rem;
  font-weight: 700;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.papyrus-nb-meta {
  font-size: .74rem;
  color: var(--text3);
  margin-top: 4px;
}

.papyrus-nb-actions {
  position: absolute;
  top: 8px;
  right: 8px;
  display: flex;
  gap: 4px;
  opacity: 0;
  transition: opacity .18s;
}

.papyrus-nb-card:hover .papyrus-nb-actions {
  opacity: 1;
}

.papyrus-nb-actions button {
  width: 28px;
  height: 28px;
  border-radius: 8px;
  border: none;
  background: rgba(0, 0, 0, .55);
  color: #fff;
  font-size: .72rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  backdrop-filter: blur(6px);
}

.papyrus-nb-actions button:hover {
  background: rgba(0, 0, 0, .75);
}

.papyrus-folder-chips {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}

.papyrus-folder-chip {
  padding: 6px 14px;
  border-radius: 999px;
  font-size: .78rem;
  font-weight: 600;
  background: var(--card);
  border: 1.5px solid var(--border2);
  color: var(--text2);
  cursor: pointer;
  transition: var(--transition);
}

.papyrus-folder-chip:hover {
  border-color: var(--accent);
  color: var(--text);
}

.papyrus-folder-chip.active {
  background: var(--accent-glow);
  border-color: var(--accent);
  color: var(--accent);
}

/* ── Papyrus Full-Screen Canvas Editor ───────────────────── */
.papyrus-editor-overlay {
  position: fixed;
  inset: 0;
  z-index: 600;
  display: flex;
  flex-direction: column;
  color: #eef1f7;
  background:
    radial-gradient(1100px 620px at 78% -12%, rgba(124, 92, 246, .18), transparent 60%),
    radial-gradient(820px 520px at 12% 8%, rgba(20, 184, 166, .14), transparent 62%),
    linear-gradient(180deg, #0b0e16 0%, #080a11 100%);
  animation: fadeIn .25s ease both;
}

.papyrus-editor-topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 16px;
  background: rgba(12, 15, 23, .72);
  border-bottom: 1px solid rgba(255, 255, 255, .06);
  backdrop-filter: blur(20px) saturate(160%);
  -webkit-backdrop-filter: blur(20px) saturate(160%);
  flex-shrink: 0;
  z-index: 10;
}

.papyrus-editor-title {
  font-size: .95rem;
  font-weight: 800;
  letter-spacing: .01em;
  flex: 0 1 200px;
  min-width: 0;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  color: #f4f6fb;
}

.papyrus-toolbar {
  display: flex;
  align-items: center;
  gap: 4px;
  padding: 6px 10px;
  border-radius: 18px;
  background: rgba(20, 24, 34, .9);
  border: 1px solid rgba(255, 255, 255, .07);
  box-shadow: 0 10px 34px rgba(0, 0, 0, .45), inset 0 1px 0 rgba(255, 255, 255, .04);
  flex-wrap: wrap;
}

.papyrus-tool-btn {
  width: 38px;
  height: 38px;
  border-radius: 12px;
  border: none;
  background: transparent;
  color: #aeb6c6;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: .92rem;
  transition: all .15s ease;
  position: relative;
}

.papyrus-tool-btn:hover {
  background: rgba(255, 255, 255, .07);
  color: #fff;
}

.papyrus-tool-btn.active {
  background: linear-gradient(180deg, rgba(20, 184, 166, .28), rgba(20, 184, 166, .14));
  color: #5eead4;
  box-shadow: 0 0 0 1px rgba(20, 184, 166, .55), 0 4px 14px rgba(20, 184, 166, .28);
}

.papyrus-ai-tool { color: #c4b5fd !important; }
.papyrus-ai-tool:hover { background: rgba(124, 92, 246, .16) !important; color: #ddd6fe !important; }

/* Verschiebbare / orientierbare schwebende Werkzeugleiste */
.papyrus-toolbar.floating {
  position: fixed;
  z-index: 40;
  max-width: 94vw;
  flex-wrap: wrap;
  transition: width .22s ease, height .22s ease, padding .2s ease, border-radius .2s ease, background .2s ease;
}
/* kleinere Buttons in der schwebenden Leiste */
.papyrus-toolbar.floating .papyrus-tool-btn { width: 32px; height: 32px; border-radius: 9px; font-size: .82rem; }
.papyrus-toolbar.floating .papyrus-tool-sep { height: 20px; margin: 0 3px; }

/* senkrecht (links/rechts angedockt) */
.papyrus-toolbar.vertical { flex-direction: column; flex-wrap: nowrap; max-width: none; }
.papyrus-toolbar.vertical .papyrus-tool-sep { width: 22px; height: 1px; margin: 3px auto; }
.papyrus-toolbar.vertical .papyrus-tb-grip { width: 32px; height: 18px; margin: 0 auto 2px; }
.papyrus-toolbar.vertical .papyrus-tb-grip i { transform: rotate(90deg); }

.papyrus-tb-grip {
  display: flex; align-items: center; justify-content: center;
  width: 22px; height: 32px; margin-right: 2px; flex-shrink: 0;
  color: #6b7488; cursor: grab; border-radius: 8px;
  touch-action: none;
}
.papyrus-tb-grip:hover { color: #cdd3df; background: rgba(255, 255, 255, .06); }

/* Eingeklappt → nur kleiner runder Button (Apple-Style) */
.papyrus-tb-expand {
  display: none; width: 46px; height: 46px; border-radius: 50%; border: none; cursor: grab;
  align-items: center; justify-content: center; font-size: 1rem; color: #04201c; touch-action: none;
  background: linear-gradient(135deg, #5eead4, #14b8a6); box-shadow: 0 8px 22px rgba(20, 184, 166, .45);
}
.papyrus-toolbar.collapsed { padding: 0 !important; background: transparent !important; border: none !important; box-shadow: none !important; flex-wrap: nowrap; }
.papyrus-toolbar.collapsed > *:not(.papyrus-tb-expand) { display: none !important; }
.papyrus-toolbar.collapsed .papyrus-tb-expand { display: flex; animation: ppPop .22s cubic-bezier(.34,1.56,.64,1) both; }
@keyframes ppPop { from { transform: scale(.5); opacity: 0; } to { transform: scale(1); opacity: 1; } }

.papyrus-tool-sep {
  width: 1px;
  height: 24px;
  background: rgba(255, 255, 255, .1);
  margin: 0 5px;
  flex-shrink: 0;
}

.papyrus-color-swatch {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  cursor: pointer;
  transition: transform 0.15s, box-shadow 0.15s;
  border: 1px solid rgba(255, 255, 255, 0.18);
  box-shadow: inset 0 1px 2px rgba(255, 255, 255, .25);
}

.papyrus-color-swatch:hover {
  transform: scale(1.18);
}

.papyrus-color-swatch.active {
  box-shadow: 0 0 0 2px #14181f, 0 0 0 4px #5eead4;
}

.papyrus-color-picker {
  cursor: pointer;
  padding: 0;
  border: none;
  background: transparent;
  width: 24px;
  height: 24px;
  border-radius: 4px;
  overflow: hidden;
}

.papyrus-color-picker::-webkit-color-swatch-wrapper {
  padding: 0;
}

.papyrus-color-picker::-webkit-color-swatch {
  border: 1px solid var(--border2);
  border-radius: 4px;
}

.papyrus-size-btn {
  width: 32px;
  height: 32px;
  border-radius: 8px;
  border: none;
  background: transparent;
  color: var(--text2);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s ease;
}

.papyrus-size-btn:hover {
  background: rgba(255, 255, 255, .07);
  color: #fff;
}

.papyrus-size-btn.active {
  background: linear-gradient(180deg, rgba(20, 184, 166, .28), rgba(20, 184, 166, .14));
  color: #5eead4;
}

/* Editor body layout */
.papyrus-editor-body {
  flex: 1;
  display: flex;
  overflow: hidden;
}

.papyrus-page-sidebar {
  width: 132px;
  flex-shrink: 0;
  overflow-y: auto;
  background: rgba(11, 14, 22, .6);
  border-right: 1px solid rgba(255, 255, 255, .06);
  padding: 14px 12px;
  display: flex;
  flex-direction: column;
  gap: 12px;
}

.papyrus-page-sidebar::before {
  content: "Seiten";
  font-size: .68rem;
  font-weight: 800;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: #6b7488;
  padding: 0 2px 2px;
}

.papyrus-page-thumb {
  position: relative;
  border-radius: 10px;
  overflow: hidden;
  border: 2px solid rgba(255, 255, 255, .08);
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s, transform .12s;
  aspect-ratio: 3/4;
  background: #fdf6e3;
  box-shadow: 0 6px 18px rgba(0, 0, 0, .4);
}

.papyrus-page-thumb:hover {
  border-color: rgba(94, 234, 212, .6);
  transform: translateY(-2px);
}

.papyrus-page-thumb.active {
  border-color: #5eead4;
  box-shadow: 0 0 0 3px rgba(20, 184, 166, .3), 0 6px 18px rgba(0, 0, 0, .4);
}

.papyrus-page-thumb canvas {
  width: 100%;
  height: 100%;
  display: block;
}

.papyrus-page-num {
  position: absolute;
  bottom: 2px;
  right: 4px;
  font-size: .6rem;
  font-weight: 700;
  color: var(--text3);
  background: rgba(255, 255, 255, .7);
  padding: 1px 4px;
  border-radius: 4px;
}

.papyrus-page-thumb-del {
  position: absolute;
  top: 2px;
  right: 2px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  border: none;
  background: rgba(239, 68, 68, .85);
  color: #fff;
  font-size: .55rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity .15s;
}

.papyrus-page-thumb:hover .papyrus-page-thumb-del {
  opacity: 1;
}

.papyrus-add-page-btn {
  width: 100%;
  aspect-ratio: 3/4;
  border-radius: 8px;
  border: 2px dashed var(--border2);
  background: transparent;
  color: var(--text3);
  font-size: 1.2rem;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: border-color .15s, color .15s;
}

.papyrus-add-page-btn:hover {
  border-color: var(--accent);
  color: var(--accent);
}

/* Canvas container */
.papyrus-canvas-wrap {
  flex: 1;
  display: block;
  text-align: center;
  overflow: auto;
  padding: 32px 20px;
  background:
    radial-gradient(ellipse 70% 50% at 50% 30%, rgba(124, 92, 246, .07), transparent 70%),
    radial-gradient(circle at center, rgba(255, 255, 255, .035) 1px, transparent 1px) 0 0 / 22px 22px,
    linear-gradient(180deg, #0a0d14 0%, #070910 100%);
}

.papyrus-canvas-frame {
  position: relative;
  display: inline-block;
  vertical-align: top;
  box-shadow: 0 18px 50px rgba(0, 0, 0, .55);
  border-radius: 0;
  overflow: hidden;
}

/* Zoom-Steuerung */
.papyrus-zoom-group {
  display: flex; align-items: center; gap: 2px; padding: 3px;
  border-radius: 12px; background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .1);
}
.papyrus-zoom-btn {
  width: 28px; height: 30px; border: none; background: transparent; color: #aeb6c6;
  cursor: pointer; border-radius: 8px; font-size: .8rem;
}
.papyrus-zoom-btn:hover { background: rgba(255, 255, 255, .1); color: #fff; }
.papyrus-zoom-pill {
  min-width: 54px; height: 30px; display: flex; align-items: center; justify-content: center;
  padding: 0 8px; border-radius: 8px; color: #e8ebf2; font-size: .8rem; font-weight: 700; cursor: pointer;
}
.papyrus-zoom-pill:hover { background: rgba(255, 255, 255, .08); }

.papyrus-canvas-frame canvas {
  display: block;
  cursor: crosshair;
  touch-action: none;
}

/* Lasso cursor */
.papyrus-canvas-frame canvas.lasso-mode {
  cursor: default;
}

/* Text cursor */
.papyrus-canvas-frame canvas.text-mode {
  cursor: text;
}

/* Eraser cursor */
.papyrus-canvas-frame canvas.eraser-mode {
  cursor: cell;
}

/* Lasso selection box */
.papyrus-lasso-selection {
  position: absolute;
  border: 2px dashed var(--accent);
  background: rgba(59, 130, 246, .08);
  pointer-events: none;
  border-radius: 2px;
}

/* Text overlay input */
.papyrus-text-input {
  position: absolute;
  background: transparent;
  border: 1.5px dashed var(--accent);
  color: #222;
  font-family: 'Inter', sans-serif;
  font-size: 16px;
  padding: 4px 6px;
  min-width: 80px;
  min-height: 24px;
  outline: none;
  border-radius: 2px;
  resize: both;
  z-index: 5;
}

/* Paper pattern overlays */
.papyrus-paper-lined {
  background-image: repeating-linear-gradient(transparent, transparent 31px, #dbe4f0 31px, #dbe4f0 32px);
  background-position: 0 36px;
}

.papyrus-paper-grid {
  background-image:
    repeating-linear-gradient(transparent, transparent 31px, #e5e7eb 31px, #e5e7eb 32px),
    repeating-linear-gradient(90deg, transparent, transparent 31px, #e5e7eb 31px, #e5e7eb 32px);
}

.papyrus-paper-dots {
  background-image: radial-gradient(circle, #d1d5db 1.2px, transparent 1.2px);
  background-size: 24px 24px;
}

/* Status bar */
.papyrus-status-bar {
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 6px 16px;
  background: rgba(11, 14, 22, .72);
  border-top: 1px solid rgba(255, 255, 255, .06);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  font-size: .72rem;
  color: #7d8699;
  flex-shrink: 0;
}

.papyrus-status-bar span {
  display: flex;
  align-items: center;
  gap: 4px;
}

/* Cover picker in modal */
.papyrus-cover-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(54px, 1fr));
  gap: 8px;
  margin-top: 8px;
}

.papyrus-cover-opt {
  width: 54px;
  height: 68px;
  border-radius: 10px;
  border: 3px solid transparent;
  cursor: pointer;
  transition: border-color .15s, transform .12s;
}

.papyrus-cover-opt:hover {
  transform: scale(1.08);
}

.papyrus-cover-opt.active {
  border-color: var(--accent);
  box-shadow: 0 0 0 3px var(--accent-glow);
}

/* Paper picker buttons */
.papyrus-paper-grid-pick {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-top: 8px;
}

.papyrus-paper-opt {
  padding: 10px 8px;
  border-radius: 10px;
  border: 2px solid var(--border2);
  background: var(--card);
  color: var(--text2);
  font-size: .78rem;
  font-weight: 600;
  text-align: center;
  cursor: pointer;
  transition: all .15s;
}

.papyrus-paper-opt:hover {
  border-color: var(--accent);
}

.papyrus-paper-opt.active {
  border-color: var(--accent);
  background: var(--accent-glow);
  color: var(--accent);
}

/* ── Stifte & Werkzeuge (Pen-Settings-Popover) ── */
.papyrus-pen-panel {
  position: absolute;
  top: 64px;
  left: 50%;
  transform: translateX(-50%) translateY(-8px);
  width: 300px;
  z-index: 40;
  background: rgba(17, 21, 31, .97);
  border: 1px solid rgba(255, 255, 255, .09);
  border-radius: 18px;
  padding: 16px 18px;
  box-shadow: 0 26px 70px rgba(0, 0, 0, .6), inset 0 1px 0 rgba(255, 255, 255, .05);
  backdrop-filter: blur(22px) saturate(160%);
  -webkit-backdrop-filter: blur(22px) saturate(160%);
  color: #e8ebf2;
  opacity: 0;
  pointer-events: none;
  transition: opacity .16s ease, transform .16s ease;
}
.papyrus-pen-panel.open {
  opacity: 1;
  pointer-events: auto;
  transform: translateX(-50%) translateY(0);
}
.papyrus-pen-panel h4 {
  margin: 0 0 12px;
  font-size: .82rem;
  font-weight: 800;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: #8b93a7;
  display: flex;
  align-items: center;
  gap: 8px;
}
.papyrus-pen-preview {
  height: 64px;
  border-radius: 12px;
  background: radial-gradient(circle at 30% 30%, rgba(255, 255, 255, .06), rgba(255, 255, 255, .02));
  border: 1px solid rgba(255, 255, 255, .06);
  display: flex;
  align-items: center;
  justify-content: center;
  margin-bottom: 14px;
  overflow: hidden;
}
.papyrus-pen-preview svg { width: 90%; height: 70%; }
.papyrus-pen-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 10px;
  margin: 12px 0;
  font-size: .86rem;
  color: #c8cedb;
}
.papyrus-pen-row .pp-val { color: #5eead4; font-weight: 700; font-size: .82rem; }
.papyrus-pen-slider {
  -webkit-appearance: none;
  appearance: none;
  width: 100%;
  height: 6px;
  border-radius: 999px;
  background: linear-gradient(90deg, #14b8a6, #7c5cf6);
  outline: none;
  margin: 6px 0 2px;
}
.papyrus-pen-slider::-webkit-slider-thumb {
  -webkit-appearance: none;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #14b8a6;
  cursor: pointer;
  box-shadow: 0 2px 8px rgba(0, 0, 0, .5);
}
.papyrus-pen-slider::-moz-range-thumb {
  width: 16px;
  height: 16px;
  border-radius: 50%;
  background: #fff;
  border: 3px solid #14b8a6;
  cursor: pointer;
}
/* iOS-style toggle */
.pp-toggle {
  position: relative;
  width: 42px;
  height: 24px;
  border-radius: 999px;
  background: rgba(255, 255, 255, .14);
  border: none;
  cursor: pointer;
  transition: background .18s ease;
  flex-shrink: 0;
}
.pp-toggle::after {
  content: "";
  position: absolute;
  top: 3px;
  left: 3px;
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: #fff;
  transition: transform .18s ease;
  box-shadow: 0 1px 3px rgba(0, 0, 0, .4);
}
.pp-toggle.on {
  background: linear-gradient(90deg, #14b8a6, #2dd4bf);
}
.pp-toggle.on::after { transform: translateX(18px); }
.papyrus-pen-colors {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 10px;
  padding-top: 12px;
  border-top: 1px solid rgba(255, 255, 255, .07);
}
.papyrus-pen-colors .pp-c {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  cursor: pointer;
  border: 1px solid rgba(255, 255, 255, .18);
  transition: transform .14s;
}
.papyrus-pen-colors .pp-c:hover { transform: scale(1.18); }
.papyrus-pen-colors .pp-c.active { box-shadow: 0 0 0 2px #14181f, 0 0 0 4px #5eead4; }

/* ════════════════════════════════════════════════
   PAPYRUS STUDIO – STARTSEITE (Notes+ Premium-Look)
════════════════════════════════════════════════ */
.main-content:has(.papyrus-home) { padding: 0 !important; margin-left: 0 !important; }
body:has(.papyrus-home) .sidebar,
body:has(.papyrus-home) .mobile-topbar,
body:has(.papyrus-home) .sidebar-overlay { display: none !important; }
.papyrus-home {
  display: flex;
  height: 100vh;
  overflow: hidden;
  color: #e8ebf2;
  font-family: Inter, system-ui, -apple-system, sans-serif;
  background:
    radial-gradient(900px 600px at 82% -12%, rgba(124, 92, 246, .12), transparent 60%),
    radial-gradient(700px 500px at 6% 6%, rgba(20, 184, 166, .08), transparent 62%),
    linear-gradient(180deg, #0a0d15 0%, #07090f 100%);
}
html.papyrus-native .papyrus-home { height: calc(100vh - 40px); }

/* Sidebar */
.ps-sidebar {
  width: 266px;
  flex-shrink: 0;
  display: flex;
  flex-direction: column;
  gap: 14px;
  padding: 18px 14px;
  background: rgba(12, 15, 23, .62);
  border-right: 1px solid rgba(255, 255, 255, .06);
  backdrop-filter: blur(18px) saturate(150%);
  -webkit-backdrop-filter: blur(18px) saturate(150%);
  overflow: hidden;
}
.ps-brand { display: flex; align-items: center; gap: 10px; padding: 2px 4px 2px; }
.ps-brand-logo {
  width: 34px; height: 34px; border-radius: 10px; display: grid; place-items: center;
  color: #04201c; font-size: 1rem;
  background: linear-gradient(135deg, #5eead4, #14b8a6);
  box-shadow: 0 6px 16px rgba(20, 184, 166, .35);
}
.ps-brand-name { font-weight: 800; font-size: 1.02rem; flex: 1; color: #f4f6fb; white-space: nowrap; }
.ps-brand-name span { color: #7c8aa3; font-weight: 600; }
.ps-brand-avatar {
  width: 30px; height: 30px; border-radius: 50%; display: grid; place-items: center;
  font-size: .8rem; font-weight: 700; color: #fff;
  background: linear-gradient(135deg, #7c5cf6, #a855f7);
}
.ps-search-wrap {
  display: flex; align-items: center; gap: 9px; padding: 9px 12px; border-radius: 11px;
  background: rgba(255, 255, 255, .05); border: 1px solid rgba(255, 255, 255, .08); color: #8b93a7;
}
.ps-search-wrap i { font-size: .82rem; }
.ps-search-input { flex: 1; background: transparent; border: none; outline: none; color: #e8ebf2; font-size: .9rem; }
.ps-search-input::placeholder { color: #6b7488; }

.ps-nav { display: flex; flex-direction: column; gap: 2px; }
.ps-nav-item {
  display: flex; align-items: center; gap: 12px; padding: 10px 12px; border: none;
  background: transparent; color: #aab2c4; font-size: .92rem; font-weight: 600;
  border-radius: 10px; cursor: pointer; text-align: left; position: relative;
  transition: background .14s, color .14s;
}
.ps-nav-item i { width: 20px; text-align: center; font-size: .95rem; }
.ps-nav-item:hover { background: rgba(255, 255, 255, .05); color: #fff; }
.ps-nav-item.active { background: rgba(20, 184, 166, .12); color: #5eead4; }
.ps-nav-item.active::before {
  content: ""; position: absolute; left: 0; top: 8px; bottom: 8px; width: 3px;
  border-radius: 3px; background: #14b8a6;
}

.ps-folders { flex: 1; min-height: 0; display: flex; flex-direction: column; }
.ps-folders-head {
  display: flex; align-items: center; justify-content: space-between; padding: 8px 8px 5px;
  font-size: .7rem; font-weight: 800; letter-spacing: .12em; text-transform: uppercase; color: #6b7488;
}
.ps-folder-add {
  width: 22px; height: 22px; border-radius: 7px; border: none; cursor: pointer;
  background: rgba(255, 255, 255, .06); color: #aab2c4; display: grid; place-items: center; font-size: .72rem;
}
.ps-folder-add:hover { background: rgba(20, 184, 166, .18); color: #5eead4; }
.ps-folder-list { overflow-y: auto; display: flex; flex-direction: column; gap: 2px; padding-right: 2px; }
.ps-folder-list .papyrus-folder-row-wrap { display: flex; align-items: center; }
.ps-folder-list .papyrus-folder-row {
  flex: 1; display: flex; align-items: center; gap: 11px; padding: 9px 12px; border: none;
  background: transparent; color: #aab2c4; font-size: .9rem; font-weight: 600; border-radius: 9px;
  cursor: pointer; text-align: left; min-width: 0;
}
.ps-folder-list .papyrus-folder-row i { width: 18px; text-align: center; color: #8b93a7; }
.ps-folder-list .papyrus-folder-row:hover { background: rgba(255, 255, 255, .05); color: #fff; }
.ps-folder-list .papyrus-folder-row.active { background: rgba(255, 255, 255, .07); color: #fff; }
.ps-folder-list .papyrus-folder-name { flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ps-folder-list .papyrus-folder-count { font-size: .74rem; color: #6b7488; font-weight: 700; }
.ps-folder-list .papyrus-folder-more {
  border: none; background: transparent; color: #6b7488; cursor: pointer; padding: 6px 8px;
  border-radius: 8px; opacity: 0; transition: opacity .14s;
}
.ps-folder-list .papyrus-folder-row-wrap:hover .papyrus-folder-more { opacity: 1; }

.ps-storage { border-radius: 14px; padding: 14px; background: rgba(255, 255, 255, .04); border: 1px solid rgba(255, 255, 255, .07); }
.ps-storage-top { display: flex; align-items: center; gap: 8px; font-size: .82rem; font-weight: 700; color: #cdd3df; }
.ps-storage-pct { margin-left: auto; font-size: .72rem; color: #8b93a7; font-weight: 600; }
.ps-storage-bar { height: 7px; border-radius: 999px; background: rgba(255, 255, 255, .1); margin: 10px 0 6px; overflow: hidden; }
.ps-storage-fill { height: 100%; border-radius: 999px; background: linear-gradient(90deg, #14b8a6, #7c5cf6); }
.ps-storage-sub { font-size: .74rem; color: #6b7488; }
.ps-storage-sync { font-size: .72rem; color: #8b93a7; margin-top: 8px; display: flex; align-items: center; gap: 6px; }

/* ── Live-Zusammenarbeit ── */
#collab-bar {
  position: absolute; top: 14px; right: 18px; z-index: 30; display: flex; align-items: center; gap: 8px;
  padding: 6px 12px; border-radius: 999px; background: rgba(20, 24, 34, .92);
  border: 1px solid rgba(52, 211, 153, .4); color: #d1fae5; font-size: .78rem; font-weight: 700;
  box-shadow: 0 8px 24px rgba(0, 0, 0, .45); backdrop-filter: blur(10px);
}
#collab-bar button { border: none; background: rgba(255, 255, 255, .12); color: #fff; width: 26px; height: 26px; border-radius: 50%; cursor: pointer; display: grid; place-items: center; }
#collab-bar button:hover { background: rgba(255, 255, 255, .22); }
.collab-avas { display: flex; gap: 4px; }
.collab-ava { display: inline-grid; place-items: center; width: 24px; height: 24px; border-radius: 50%; color: #fff; font-size: .72rem; font-weight: 800; border: 2px solid rgba(0, 0, 0, .35); }
.ps-share-btn { color: #5eead4 !important; }
#papyrus-rec-btn.recording { color: #fff !important; background: #ef4444 !important; animation: papyrusRecPulse 1.1s ease-in-out infinite; }
@keyframes papyrusRecPulse { 0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, .5); } 50% { box-shadow: 0 0 0 6px rgba(239, 68, 68, 0); } }
#collab-cursors { position: absolute; inset: 0; pointer-events: none; z-index: 20; }

/* Seiten-Thumb: Duplizieren-Button + Drag-Sortierung */
.papyrus-page-thumb-dup {
  position: absolute; top: 2px; left: 2px; width: 18px; height: 18px; border-radius: 50%;
  border: none; background: rgba(20, 184, 166, .9); color: #042b27; font-size: .55rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center; opacity: 0; transition: opacity .15s;
}
.papyrus-page-thumb:hover .papyrus-page-thumb-dup { opacity: 1; }
.papyrus-page-thumb.drag-over { border-color: #5eead4 !important; box-shadow: 0 0 0 3px rgba(20, 184, 166, .4); }

/* Lasso-Aktionsmenü */
#papyrus-lasso-menu {
  position: absolute; top: 14px; left: 50%; transform: translateX(-50%); z-index: 32;
  display: flex; gap: 4px; padding: 6px; border-radius: 14px;
  background: rgba(20, 24, 34, .96); border: 1px solid rgba(255, 255, 255, .1);
  box-shadow: 0 12px 34px rgba(0, 0, 0, .5); backdrop-filter: blur(12px);
}
#papyrus-lasso-menu button {
  width: 38px; height: 38px; border: none; border-radius: 10px; cursor: pointer;
  background: transparent; color: #cdd3df; font-size: .95rem;
}
#papyrus-lasso-menu button:hover { background: rgba(255, 255, 255, .1); color: #fff; }
#papyrus-lasso-menu button:last-child:hover { background: rgba(239, 68, 68, .2); color: #fca5a5; }

/* Main */
.ps-main { flex: 1; min-width: 0; display: flex; flex-direction: column; overflow: hidden; }
.ps-main-head { display: flex; align-items: center; gap: 14px; padding: 18px 22px; border-bottom: 1px solid rgba(255, 255, 255, .06); }
.ps-main-title { font-size: 1.15rem; font-weight: 800; color: #f4f6fb; display: flex; align-items: center; gap: 10px; }
.ps-main-title i { color: #5eead4; }
.ps-main-actions { margin-left: auto; display: flex; align-items: center; gap: 12px; }
.ps-main-actions .papyrus-folder-chips { display: flex; gap: 6px; flex-wrap: nowrap; max-width: 420px; overflow-x: auto; }
.ps-main-actions .papyrus-folder-chip {
  padding: 5px 12px; border-radius: 999px; border: 1px solid rgba(255, 255, 255, .1);
  background: rgba(255, 255, 255, .04); color: #aab2c4; font-size: .78rem; font-weight: 600;
  cursor: pointer; white-space: nowrap;
}
.ps-main-actions .papyrus-folder-chip.active { background: rgba(20, 184, 166, .16); border-color: rgba(20, 184, 166, .5); color: #5eead4; }
.ps-new-btn {
  display: flex; align-items: center; gap: 8px; padding: 9px 16px; border: none; border-radius: 11px;
  cursor: pointer; font-weight: 700; font-size: .88rem; color: #04201c; white-space: nowrap;
  background: linear-gradient(135deg, #5eead4, #14b8a6); box-shadow: 0 8px 20px rgba(20, 184, 166, .3);
}
.ps-new-btn:hover { filter: brightness(1.06); }
.ps-import-btn {
  display: flex; align-items: center; gap: 8px; padding: 9px 15px; border-radius: 11px; cursor: pointer;
  font-weight: 700; font-size: .88rem; white-space: nowrap; color: #cdd3df;
  background: rgba(255, 255, 255, .06); border: 1px solid rgba(255, 255, 255, .12);
}
.ps-import-btn:hover { background: rgba(255, 255, 255, .1); color: #fff; }

.ps-grid {
  flex: 1; overflow-y: auto; padding: 22px;
  display: grid; grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 18px; align-content: start;
}
.ps-grid .papyrus-empty { grid-column: 1 / -1; }

/* Notebook cards */
.ps-grid .papyrus-nb-card {
  background: rgba(18, 22, 32, .85); border: 1px solid rgba(255, 255, 255, .07); border-radius: 16px;
  overflow: hidden; cursor: pointer; display: flex; flex-direction: column; position: relative;
  box-shadow: 0 10px 30px rgba(0, 0, 0, .35); transition: transform .15s, box-shadow .15s, border-color .15s;
}
.ps-grid .papyrus-nb-card:hover { transform: translateY(-4px); border-color: rgba(94, 234, 212, .4); box-shadow: 0 18px 44px rgba(0, 0, 0, .5); }
.ps-grid .papyrus-nb-cover {
  height: 130px; position: relative; display: grid; place-items: center;
  color: rgba(255, 255, 255, .55); font-size: 1.6rem; background: linear-gradient(135deg, #2a2f45, #171b2a);
}
.ps-grid .papyrus-nb-cover[data-cover="gold"] { background: linear-gradient(135deg, #caa451, #7a5a1e); }
.ps-grid .papyrus-nb-cover[data-cover="blue"] { background: linear-gradient(135deg, #3b82f6, #1e3a8a); }
.ps-grid .papyrus-nb-cover[data-cover="purple"] { background: linear-gradient(135deg, #a855f7, #6d28d9); }
.ps-grid .papyrus-nb-cover[data-cover="green"] { background: linear-gradient(135deg, #34d399, #065f46); }
.ps-grid .papyrus-nb-cover[data-cover="red"] { background: linear-gradient(135deg, #f87171, #991b1b); }
.ps-grid .papyrus-nb-cover[data-cover="cream"] { background: linear-gradient(135deg, #e7d9b8, #a98e58); }
.ps-grid .papyrus-nb-cover[data-cover="dark"] { background: linear-gradient(135deg, #374151, #111827); }
.ps-grid .papyrus-nb-body { padding: 12px 14px; }
.ps-grid .papyrus-nb-title { font-weight: 700; font-size: .95rem; color: #f1f4fa; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.ps-grid .papyrus-nb-meta { font-size: .74rem; color: #7d8699; margin-top: 3px; }
.ps-grid .papyrus-nb-actions { position: absolute; top: 8px; right: 8px; display: flex; gap: 5px; opacity: 0; transition: opacity .14s; }
.ps-grid .papyrus-nb-card:hover .papyrus-nb-actions { opacity: 1; }
.ps-grid .papyrus-nb-actions button {
  width: 28px; height: 28px; border-radius: 8px; border: none; cursor: pointer;
  background: rgba(0, 0, 0, .5); color: #e8ebf2; backdrop-filter: blur(6px);
}
.ps-grid .papyrus-nb-actions button:hover { background: rgba(0, 0, 0, .78); }
.papyrus-nb-fav {
  position: absolute; left: 8px; top: 8px; width: 28px; height: 28px; border-radius: 8px; border: none;
  cursor: pointer; background: rgba(0, 0, 0, .4); color: rgba(255, 255, 255, .55); backdrop-filter: blur(6px);
}
.papyrus-nb-fav.on { color: #fbbf24; }
.papyrus-nb-fav:hover { background: rgba(0, 0, 0, .7); }

@media (max-width: 760px) {
  .ps-sidebar { width: 76px; }
  .ps-brand-name, .ps-search-input, .ps-nav-item span, .ps-folders, .ps-storage { display: none; }
  .ps-nav-item { justify-content: center; }
}

/* ── Editor: Dokument-Tabs + Seitenanzeige (Notes+ Look) ── */
.ps-ed-tabs {
  display: flex; align-items: flex-end; gap: 6px; padding: 8px 12px 0;
  background: rgba(9, 12, 19, .9); border-bottom: 1px solid rgba(255, 255, 255, .05);
  overflow-x: auto; flex-shrink: 0;
}
.ps-ed-tab {
  display: flex; align-items: center; gap: 9px; max-width: 200px; padding: 9px 14px;
  border: 1px solid transparent; border-bottom: none; border-radius: 11px 11px 0 0;
  background: transparent; color: #8b93a7; font-size: .85rem; font-weight: 600; cursor: pointer;
  white-space: nowrap; flex-shrink: 0;
}
.ps-ed-tab span { overflow: hidden; text-overflow: ellipsis; }
.ps-ed-tab:hover { color: #cdd3df; background: rgba(255, 255, 255, .04); }
.ps-ed-tab.active { background: rgba(20, 24, 34, .96); color: #f4f6fb; border-color: rgba(255, 255, 255, .08); }
.ps-ed-tab-x { font-size: .8rem; color: #6b7488; padding: 2px; border-radius: 5px; }
.ps-ed-tab-x:hover { color: #fff; background: rgba(255, 255, 255, .14); }
.ps-ed-tab-add { width: 32px; height: 32px; border-radius: 8px; border: none; background: transparent; color: #8b93a7; cursor: pointer; flex-shrink: 0; margin-bottom: 4px; }
.ps-ed-tab-add:hover { background: rgba(255, 255, 255, .06); color: #5eead4; }
.ps-ed-top-actions { margin-left: auto; display: flex; align-items: center; gap: 4px; flex-shrink: 0; padding-bottom: 4px; }

.papyrus-editor-title { display: none !important; }
.papyrus-ed-back { flex-shrink: 0; color: #aab2c4 !important; }

.papyrus-editor-body { position: relative; }
.ps-addpage-fab {
  position: absolute; right: 18px; bottom: 56px; z-index: 14;
  display: flex; align-items: center; gap: 7px; padding: 8px 14px; border-radius: 999px;
  border: 1px solid rgba(255, 255, 255, .12); background: rgba(20, 24, 34, .92); color: #cdd3df;
  font-size: .8rem; font-weight: 700; cursor: pointer; box-shadow: 0 8px 24px rgba(0, 0, 0, .45);
}
.ps-addpage-fab:hover { background: rgba(20, 184, 166, .18); color: #5eead4; }
.ps-page-indicator {
  position: absolute; right: 18px; bottom: 16px; z-index: 14;
  padding: 6px 14px; border-radius: 999px; font-size: .78rem; font-weight: 700; color: #cdd3df;
  background: rgba(20, 24, 34, .92); border: 1px solid rgba(255, 255, 255, .1);
  box-shadow: 0 8px 24px rgba(0, 0, 0, .45); pointer-events: none;
}
/* Floating-AI nach links, damit es die Seitenanzeige nicht überdeckt */
.papyrus-editor-body .papyrus-floating-ai { left: 22px; right: auto; bottom: 22px; }

/* Responsive */
@media (max-width: 700px) {
  .papyrus-page-sidebar {
    width: 70px;
    padding: 6px 4px;
  }

  .papyrus-editor-topbar {
    padding: 6px 10px;
    flex-wrap: wrap;
  }

  .papyrus-toolbar {
    flex-wrap: wrap;
  }

  .papyrus-canvas-wrap {
    padding: 8px;
  }

  .papyrus-nb-grid {
    grid-template-columns: repeat(auto-fill, minmax(150px, 1fr));
  }
}

/* ── Chat: neue Elemente ──────────────────────────────────── */
.chat-list-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 14px 16px 10px;
  font-weight: 700;
  font-size: 0.88rem;
  color: var(--text);
}

.chat-add-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition);
}

.chat-add-row:hover {
  background: var(--card2);
}

/* ── Fach-Cover (Karten + Seiten-Banner) ─────────────────── */
.spc-cover {
  width: 100%;
  height: 96px;
  border-radius: var(--radius) var(--radius) 0 0;
  position: relative;
  overflow: hidden;
  flex-shrink: 0;
}

.spc-cover-name {
  position: absolute;
  bottom: 10px;
  left: 14px;
  right: 14px;
  font-size: 1rem;
  font-weight: 700;
  color: #fff;
  text-shadow: 0 1px 6px rgba(0, 0, 0, 0.55);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.subj-cover-banner {
  width: 100%;
  height: 160px;
  position: relative;
  overflow: hidden;
  border-radius: var(--radius) var(--radius) 0 0;
  margin-bottom: 0;
}

.subj-cover-overlay {
  position: absolute;
  inset: 0;
  background: linear-gradient(to top, rgba(0, 0, 0, 0.65) 0%, rgba(0, 0, 0, 0.1) 100%);
  display: flex;
  flex-direction: column;
  justify-content: flex-end;
  padding: 18px 22px;
}

.subj-cover-title {
  font-size: 1.55rem;
  font-weight: 800;
  color: #fff;
  text-shadow: 0 2px 8px rgba(0, 0, 0, 0.5);
  line-height: 1.2;
}

.subj-cover-sub {
  font-size: 0.85rem;
  font-weight: 500;
  color: rgba(255, 255, 255, 0.82);
  margin-top: 3px;
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

.subj-cover-edit-btn {
  position: absolute;
  top: 12px;
  right: 14px;
  background: rgba(0, 0, 0, 0.45);
  border: 1px solid rgba(255, 255, 255, 0.25);
  color: #fff;
  border-radius: 20px;
  padding: 5px 12px;
  font-size: 0.76rem;
  font-weight: 600;
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 5px;
  transition: background 0.18s;
  font-family: var(--font);
}

.subj-cover-edit-btn:hover {
  background: rgba(0, 0, 0, 0.68);
}

/* Cover-Modal: Gradient-Auswahl */
.cover-gradient-grid {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}

.cover-gradient-swatch {
  width: 100%;
  aspect-ratio: 1;
  border-radius: 8px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform 0.15s, border-color 0.15s;
}

.cover-gradient-swatch:hover {
  transform: scale(1.08);
}

.cover-gradient-swatch.selected {
  border-color: #fff;
  box-shadow: 0 0 0 2px var(--accent);
  transform: scale(1.08);
}

/* Cover-Vorschau im Modal */
.cover-preview {
  width: 100%;
  height: 80px;
  border-radius: var(--radius-sm);
  margin-bottom: 14px;
  position: relative;
  overflow: hidden;
  transition: background 0.25s;
}

.cover-preview-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.8rem;
  font-weight: 600;
  color: rgba(255, 255, 255, 0.7);
  text-shadow: 0 1px 4px rgba(0, 0, 0, 0.4);
}

/* ── Upload-Modal Tabs ────────────────────────────────────── */
.upload-tabs {
  display: flex;
  gap: 4px;
  background: var(--card2);
  border-radius: var(--radius-sm);
  padding: 4px;
  margin-bottom: 16px;
}

.upload-tab {
  flex: 1;
  padding: 7px 12px;
  border: none;
  border-radius: calc(var(--radius-sm) - 2px);
  background: transparent;
  color: var(--text2);
  font-size: 0.82rem;
  font-weight: 600;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  font-family: var(--font);
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 6px;
}

.upload-tab.active {
  background: var(--card);
  color: var(--accent);
  box-shadow: 0 1px 4px rgba(0, 0, 0, 0.1);
}

/* ── Video-Karte im Ressourcen-Grid ───────────────────────── */
.res-item.res-video {
  cursor: pointer;
  position: relative;
  padding: 0;
  overflow: hidden;
}

.res-video-thumb {
  width: 100%;
  height: 90px;
  background: var(--card2);
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.res-video-play {
  width: 38px;
  height: 38px;
  background: rgba(239, 68, 68, 0.92);
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  color: #fff;
  font-size: 13px;
  padding-left: 3px;
  box-shadow: 0 2px 8px rgba(0, 0, 0, 0.3);
}

.res-item.res-video:hover .res-video-play {
  background: #ef4444;
  transform: scale(1.1);
}

.res-video-badge {
  position: absolute;
  bottom: 6px;
  left: 6px;
  background: rgba(0, 0, 0, 0.65);
  color: #fff;
  font-size: 0.65rem;
  font-weight: 700;
  border-radius: 4px;
  padding: 2px 6px;
  letter-spacing: 0.03em;
}

.res-item.res-video .res-name {
  padding: 8px 10px 4px;
  font-size: 0.78rem;
}

/* ══════════════════════════════════════════════════════════════
   FEATURE CARDS: Aufgaben, Quiz, Forum, Lernpfade
   ══════════════════════════════════════════════════════════════ */

/* ── Assign card (orange left border) ───────────────────────── */
.assign-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid #f97316;
  border-radius: var(--radius);
  padding: 16px 18px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.assign-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(249, 115, 22, 0.14);
  border-color: #f97316;
}

.assign-count-badge {
  background: rgba(249, 115, 22, 0.12);
  color: #f97316;
  font-size: 0.72rem;
  font-weight: 700;
  padding: 3px 10px;
  border-radius: 20px;
  white-space: nowrap;
}

/* ── Quiz card (purple left border) ─────────────────────────── */
.quiz-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-left: 4px solid #8b5cf6;
  border-radius: var(--radius);
  padding: 16px 18px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.quiz-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(139, 92, 246, 0.14);
  border-color: #8b5cf6;
}

/* ── Forum thread card ───────────────────────────────────────── */
.forum-thread-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.forum-thread-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(56, 189, 248, 0.1);
  border-color: var(--accent);
}

/* ── Path card ───────────────────────────────────────────────── */
.path-card {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 16px 18px;
  cursor: pointer;
  transition: transform var(--transition), box-shadow var(--transition), border-color var(--transition);
}

.path-card:hover {
  transform: translateY(-2px);
  box-shadow: 0 4px 20px rgba(16, 185, 129, 0.1);
  border-color: #10b981;
}

/* ── Stepper / Learning Path steps ──────────────────────────── */
.step-item {
  display: flex;
  gap: 0;
  margin-bottom: 0;
}

.step-connector {
  display: flex;
  flex-direction: column;
  align-items: center;
  margin-right: 14px;
  flex-shrink: 0;
}

.step-dot {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  border: 2px solid var(--border2);
  background: var(--card2);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: background var(--transition), border-color var(--transition);
  z-index: 1;
}

.step-line {
  width: 2px;
  flex: 1;
  min-height: 24px;
  background: var(--border2);
  margin: 4px 0;
}

.step-content {
  flex: 1;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 14px 16px;
  margin-bottom: 12px;
  min-width: 0;
  transition: border-color var(--transition), opacity var(--transition);
}

.step-content-done {
  opacity: 0.75;
  border-color: rgba(16, 185, 129, 0.3);
  background: rgba(16, 185, 129, 0.04);
}

.step-done .step-dot {
  background: #10b981;
  border-color: #10b981;
}

.step-done .step-line {
  background: rgba(16, 185, 129, 0.4);
}

/* btn-warning and btn-danger are defined earlier in the base button styles */

/* ── Unified Content List ────────────────────────────────────── */
.content-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin-top: 8px;
}

.content-card {
  display: flex;
  align-items: center;
  gap: 14px;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  padding: 12px 14px;
  cursor: pointer;
  position: relative;
  transition: border-color var(--transition), transform var(--transition), box-shadow var(--transition);
}

.content-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.content-card-icon {
  font-size: 1.5rem;
  flex-shrink: 0;
  width: 36px;
  text-align: center;
}

.content-card-body {
  flex: 1;
  min-width: 0;
}

.content-card-title {
  font-size: 0.88rem;
  font-weight: 600;
  color: var(--text);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.content-card-meta {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 3px;
  font-size: 0.72rem;
  color: var(--text3);
}

.content-card-meta span {
  display: flex;
  align-items: center;
  gap: 4px;
}

.content-card-meta .avatar {
  flex-shrink: 0;
}

.content-card-preview {
  font-size: 0.75rem;
  color: var(--text3);
  margin-top: 3px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.content-card-actions {
  display: flex;
  gap: 4px;
  flex-shrink: 0;
}

.planner-done {
  opacity: 0.55;
}

.planner-done .content-card-title {
  text-decoration: line-through;
}

/* Type-specific left borders */
.content-folder {
  border-left: 3px solid #f59e0b;
}

.content-assignment {
  border-left: 3px solid #f97316;
}

.content-quiz {
  border-left: 3px solid #a855f7;
}

.content-discussion {
  border-left: 3px solid #3b82f6;
}

.content-text {
  border-left: 3px solid #10b981;
}

.content-file {
  border-left: 3px solid var(--accent);
}

.content-video {
  border-left: 3px solid #ef4444;
}

.content-folder:hover {
  border-color: #f59e0b;
  box-shadow: 0 4px 16px rgba(245, 158, 11, 0.12);
}

.content-assignment:hover {
  border-color: #f97316;
  box-shadow: 0 4px 16px rgba(249, 115, 22, 0.12);
}

.content-quiz:hover {
  border-color: #a855f7;
  box-shadow: 0 4px 16px rgba(168, 85, 247, 0.12);
}

.content-discussion:hover {
  border-color: #3b82f6;
  box-shadow: 0 4px 16px rgba(59, 130, 246, 0.12);
}

.content-text:hover {
  border-color: #10b981;
  box-shadow: 0 4px 16px rgba(16, 185, 129, 0.12);
}

/* Add Content picker grid */
.add-content-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.add-content-btn {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  gap: 8px;
  padding: 16px 8px;
  border-radius: var(--radius-sm);
  background: var(--card2);
  border: 1px solid var(--border);
  cursor: pointer;
  font-size: 0.78rem;
  font-weight: 600;
  color: var(--text2);
  transition: var(--transition);
}

.add-content-btn:hover {
  background: var(--card);
  border-color: var(--accent);
  color: var(--text);
  transform: translateY(-2px);
}

.add-content-btn i {
  font-size: 1.6rem;
}

@media (max-width: 900px) {
  .add-content-grid {
    grid-template-columns: repeat(4, 1fr);
  }

  .add-content-btn {
    padding: 12px 4px;
    font-size: 0.68rem;
  }

  .add-content-btn i {
    font-size: 1.3rem;
  }
}

/* ============================================================
   iOS-Style Wheel-Picker (Apple-Clock-App-Look)
   ============================================================ */
.wheel-picker {
  position: relative;
  padding: 12px 0;
  user-select: none;
  -webkit-user-select: none;
  background: rgba(0, 0, 0, 0.12);
  border-radius: 14px;
}

.wheel-picker-cols {
  display: flex;
  justify-content: center;
  align-items: center;
  position: relative;
  z-index: 1;
}

.wheel-unit {
  position: relative;
  display: flex;
  align-items: center;
}

.wheel-col {
  width: 52px;
  height: 200px;
  overflow-y: scroll;
  scroll-snap-type: y mandatory;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-overflow-scrolling: touch;
  mask-image: linear-gradient(to bottom,
      transparent 0%,
      rgba(0, 0, 0, 0.4) 20%,
      rgba(0, 0, 0, 1) 42%,
      rgba(0, 0, 0, 1) 58%,
      rgba(0, 0, 0, 0.4) 80%,
      transparent 100%);
  -webkit-mask-image: linear-gradient(to bottom,
      transparent 0%,
      rgba(0, 0, 0, 0.4) 20%,
      rgba(0, 0, 0, 1) 42%,
      rgba(0, 0, 0, 1) 58%,
      rgba(0, 0, 0, 0.4) 80%,
      transparent 100%);
}

.wheel-col::-webkit-scrollbar {
  display: none;
}

.wheel-spacer {
  height: 40px;
  scroll-snap-align: none;
}

.wheel-item {
  height: 40px;
  line-height: 40px;
  text-align: right;
  padding-right: 2px;
  font-size: 1.5rem;
  font-weight: 500;
  font-variant-numeric: tabular-nums;
  color: var(--text);
  scroll-snap-align: center;
  scroll-snap-stop: always;
  transition: opacity 0.15s ease;
  cursor: grab;
  opacity: 0.35;
}

.wheel-item.selected {
  opacity: 1;
  font-weight: 600;
}

.wheel-unit-label {
  font-size: 0.95rem;
  font-weight: 600;
  color: var(--text);
  padding: 0 14px 0 4px;
  pointer-events: none;
  z-index: 2;
  white-space: nowrap;
}

.wheel-unit:last-child .wheel-unit-label {
  padding-right: 4px;
}

.wheel-highlight {
  position: absolute;
  left: 8px;
  right: 8px;
  top: 50%;
  transform: translateY(-50%);
  height: 44px;
  background: rgba(255, 255, 255, 0.06);
  border-radius: 10px;
  pointer-events: none;
  z-index: 0;
}

[data-theme="light"] .wheel-picker {
  background: rgba(0, 0, 0, 0.04);
}

[data-theme="light"] .wheel-highlight {
  background: rgba(0, 0, 0, 0.05);
}

/* ═══════════════════════════════════════════════════════════════
   Feature 8: Quiz 2.0 + Marketplace
   ═══════════════════════════════════════════════════════════════ */

/* Nav-Badge (z.B. "Bewerten (3)") */
.nav-badge {
  margin-left: auto;
  background: #f59e0b;
  color: #fff;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 20px;
  min-width: 20px;
  text-align: center;
  line-height: 1.3;
}

/* Countdown-Pulse bei <10s */
@keyframes pulse {

  0%,
  100% {
    opacity: 1;
    transform: scale(1);
  }

  50% {
    opacity: 0.55;
    transform: scale(1.08);
  }
}

/* Marketplace */
.mp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(260px, 1fr));
  gap: 14px;
}

.mp-card {
  background: var(--card);
  border: 1px solid var(--border2);
  border-radius: var(--radius-sm);
  display: flex;
  flex-direction: column;
  overflow: hidden;
  transition: transform 0.15s ease, border-color 0.15s ease, box-shadow 0.2s ease;
}

.mp-card:hover {
  transform: translateY(-2px);
  border-color: var(--accent);
  box-shadow: 0 8px 24px rgba(0, 0, 0, 0.15);
}

.mp-card-head {
  padding: 14px 14px 8px;
  border-bottom: 1px solid var(--border2);
}

.mp-title {
  font-weight: 700;
  font-size: 0.98rem;
  line-height: 1.3;
  color: var(--text);
}

.mp-card-body {
  padding: 10px 14px;
  flex: 1;
}

.mp-card-foot {
  padding: 10px 14px;
  background: var(--card2);
  display: flex;
  gap: 8px;
  justify-content: flex-end;
}

.mp-lang {
  background: rgba(59, 130, 246, 0.15);
  color: #3b82f6;
  font-size: 0.68rem;
  font-weight: 700;
  padding: 2px 8px;
  border-radius: 20px;
  letter-spacing: 0.04em;
}

.mp-chip {
  background: var(--card2);
  color: var(--text2);
  font-size: 0.68rem;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
}

/* Quiz-Card Hover + Test-Badge-Glow */
.quiz-card {
  cursor: pointer;
  transition: transform 0.12s ease, border-color 0.12s ease;
}

.quiz-card:hover {
  transform: translateY(-1px);
  border-color: var(--accent);
}

/* ══ Quiz — neue Fragetypen ══ */
/* Fill-Text inline inputs */
input[id^="q-fill-"] {
  border: 2px solid var(--border2);
  border-radius: 6px;
  transition: border-color 0.15s ease, background 0.15s ease;
}

input[id^="q-fill-"]:focus {
  border-color: var(--accent);
  background: var(--card);
  outline: none;
}

/* Match-Select */
select[id^="q-match-"] {
  padding: 6px 10px;
  font-size: 0.88rem;
}

/* Draw canvas */
#q-draw-canvas {
  cursor: crosshair;
  user-select: none;
}

/* Quiz-Type-Badge (im Modal) */
.quiz-type-badge {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  font-size: 0.72rem;
  background: var(--card2);
  border: 1px solid var(--border2);
  padding: 3px 9px;
  border-radius: 20px;
  color: var(--text2);
}

.quiz-type-badge .auto {
  color: #10b981;
}

.quiz-type-badge .manual {
  color: #f59e0b;
}

/* ── Match Drag & Drop ── */
.match-pool {
  background: var(--card2);
  border: 2px dashed var(--border2);
  border-radius: 10px;
  padding: 12px;
  transition: border-color .15s, background .15s;
}

.match-pool.drag-over {
  border-color: var(--accent);
  background: rgba(59, 130, 246, 0.08);
}

.match-pool-label {
  font-size: 0.78rem;
  font-weight: 700;
  color: var(--text2);
  margin-bottom: 8px;
  display: flex;
  align-items: center;
}

.match-pool-items {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  min-height: 44px;
}

.match-targets {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(170px, 1fr));
  gap: 10px;
  margin-top: 12px;
}

.match-box {
  background: var(--card2);
  border: 2px solid var(--border2);
  border-radius: 10px;
  padding: 10px;
  min-height: 92px;
  transition: border-color .15s, background .15s, transform .1s;
  cursor: pointer;
}

.match-box.drag-over {
  border-color: #10b981;
  background: rgba(16, 185, 129, 0.10);
  transform: scale(1.02);
}

.match-box-label {
  font-size: 0.82rem;
  font-weight: 700;
  color: var(--text1);
  margin-bottom: 6px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--border2);
}

.match-box-items {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  min-height: 36px;
}

.match-tile {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.18), rgba(99, 102, 241, 0.18));
  border: 1px solid rgba(59, 130, 246, 0.45);
  color: var(--text1);
  padding: 8px 12px;
  border-radius: 7px;
  font-size: 0.88rem;
  font-weight: 600;
  cursor: grab;
  user-select: none;
  transition: transform .1s, box-shadow .15s, border-color .15s;
  display: inline-flex;
  align-items: center;
  touch-action: none;
}

.match-tile:hover {
  transform: translateY(-1px);
  box-shadow: 0 4px 10px rgba(0, 0, 0, 0.15);
  border-color: var(--accent);
}

.match-tile:active,
.match-tile.dragging {
  cursor: grabbing;
  opacity: 0.5;
  transform: scale(0.97);
}

.match-tile.selected {
  border-color: #10b981;
  background: linear-gradient(135deg, rgba(16, 185, 129, 0.22), rgba(5, 150, 105, 0.22));
  box-shadow: 0 0 0 2px rgba(16, 185, 129, 0.35);
}

.match-empty {
  font-size: 0.74rem;
  color: var(--text3);
  font-style: italic;
  padding: 6px 2px;
}

/* ── Music Player Drawer ─────────────────────── */
.music-drawer {
  position: fixed;
  top: 0;
  left: -420px;
  width: 400px;
  height: 100vh;
  background: rgba(13, 24, 41, 0.85);
  backdrop-filter: blur(25px) saturate(180%);
  -webkit-backdrop-filter: blur(25px) saturate(180%);
  border-right: 1px solid rgba(255, 255, 255, 0.12);
  z-index: 400;
  transition: transform 0.45s cubic-bezier(0.16, 1, 0.3, 1);
  display: flex;
  flex-direction: column;
  box-shadow: 25px 0 60px rgba(0, 0, 0, 0.4);
}

.music-drawer.active {
  transform: translateX(420px);
}

.music-drawer-header {
  padding: 24px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  background: rgba(0, 0, 0, 0.2);
}

.music-drawer-title {
  font-size: 1.3rem;
  font-weight: 800;
  display: flex;
  align-items: center;
  gap: 12px;
  color: #fff;
}

.music-platform-selector {
  padding: 12px 20px;
  display: flex;
  gap: 12px;
  overflow-x: auto;
  scrollbar-width: none;
  background: rgba(0, 0, 0, 0.1);
}

.music-platform-selector::-webkit-scrollbar {
  display: none;
}

.music-platform-btn {
  flex-shrink: 0;
  width: 48px;
  height: 48px;
  border-radius: 14px;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.06);
  border: 1px solid rgba(255, 255, 255, 0.1);
  cursor: pointer;
  transition: all 0.25s cubic-bezier(0.4, 0, 0.2, 1);
  color: #fff;
  font-size: 1.4rem;
}

.music-platform-btn:hover {
  background: rgba(255, 255, 255, 0.15);
  transform: translateY(-3px) scale(1.05);
  border-color: rgba(255, 255, 255, 0.3);
}

.music-platform-btn.active {
  background: var(--accent);
  border-color: #fff;
  box-shadow: 0 8px 20px var(--accent-glow);
  transform: scale(1.1);
}

.music-platform-btn#mp-spotify.active {
  color: #1DB954;
  border-color: #1DB954;
  background: rgba(29, 185, 84, 0.1);
}

.music-platform-btn#mp-soundcloud.active {
  color: #FF5500;
  border-color: #FF5500;
  background: rgba(255, 85, 0, 0.1);
}

.music-platform-btn#mp-apple.active {
  color: #FA243C;
  border-color: #FA243C;
  background: rgba(250, 36, 60, 0.1);
}

.music-platform-btn#mp-youtube.active {
  color: #FF0000;
  border-color: #FF0000;
  background: rgba(255, 0, 0, 0.1);
}

.music-player-container {
  flex: 1;
  background: #000;
  position: relative;
  overflow: hidden;
}

.music-player-container iframe {
  display: block;
  width: 100%;
  height: 100%;
  border: none;
  opacity: 0;
  transition: opacity 0.5s ease;
}

.music-player-container iframe.loaded {
  opacity: 1;
}

/* Vom Spotify-API erzeugtes iframe (innerhalb #spotify-wrap) sichtbar machen */
.music-player-container #spotify-wrap,
.music-player-container #spotify-wrap iframe {
  width: 100%;
  height: 100%;
  border: none;
  opacity: 1 !important;
}

/* Gutschein: Fach-Auswahl (Radio-Optionen) */
.voucher-subj-opt {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px; border-radius: 11px; cursor: pointer;
  background: var(--card2, rgba(255,255,255,0.04));
  border: 1px solid var(--border2, rgba(255,255,255,0.12));
  transition: border-color 0.15s, background 0.15s;
}
.voucher-subj-opt:hover { border-color: var(--accent); }
.voucher-subj-opt:has(input:checked) { border-color: var(--accent); background: rgba(99,102,241,0.12); }
.voucher-subj-opt input { width: 18px; height: 18px; accent-color: var(--accent); }

/* Musik-Launcher: Plattform-Startseiten zum Stöbern öffnen */
.music-launcher {
  position: absolute; inset: 0;
  display: flex; flex-direction: column;
  align-items: center; justify-content: center;
  text-align: center; gap: 10px; padding: 24px;
}
.music-launcher-title { font-weight: 800; font-size: 1.05rem; color: var(--text); }
.music-launcher-sub { font-size: 0.84rem; color: var(--text2); max-width: 280px; line-height: 1.5; margin-bottom: 8px; }
.music-launcher-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 10px; width: 100%; max-width: 320px; }
.music-launcher-grid button {
  display: flex; flex-direction: column; align-items: center; gap: 8px;
  padding: 16px 10px; border-radius: 14px; cursor: pointer;
  background: var(--card2, rgba(255,255,255,0.05));
  border: 1px solid var(--border2, rgba(255,255,255,0.12));
  color: var(--text, #fff); font-weight: 600; font-size: 0.82rem;
  transition: transform 0.15s, border-color 0.15s, background 0.15s;
}
.music-launcher-grid button i { font-size: 1.6rem; }
.music-launcher-grid button:hover { transform: translateY(-2px); border-color: var(--accent); background: rgba(255,255,255,0.08); }

.music-drawer-close {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  background: rgba(255, 255, 255, 0.08);
  border: none;
  color: #fff;
  cursor: pointer;
  transition: background 0.2s;
}

.music-drawer-close:hover {
  background: rgba(255, 255, 255, 0.2);
}

.nav-item-player {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.15), rgba(139, 92, 246, 0.15)) !important;
  border: 1.5px solid rgba(59, 130, 246, 0.3) !important;
  margin-top: 15px !important;
  box-shadow: 0 4px 12px rgba(59, 130, 246, 0.1);
}

.nav-item-player:hover {
  background: linear-gradient(135deg, rgba(59, 130, 246, 0.25), rgba(139, 92, 246, 0.25)) !important;
  border-color: var(--accent) !important;
  transform: scale(1.02);
}

@media (max-width: 600px) {
  .music-drawer {
    width: 100%;
    left: -100%;
  }

  .music-drawer.active {
    transform: translateX(100%);
  }
}

/* --- PAPYRUS STUDIO PRO EDITOR STYLES --- */
.papyrus-pro-editor {
  box-shadow: 0 50px 120px rgba(0,0,0,0.8);
  font-family: 'Segoe UI', system-ui, -apple-system, sans-serif;
}

.wb-tool-btn {
  width: 48px;
  height: 48px;
  border-radius: 14px;
  border: 1px solid transparent;
  background: rgba(255, 255, 255, 0.03);
  color: rgba(255, 255, 255, 0.4);
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1);
}

.wb-tool-btn:hover, .wb-tool-btn.active {
  background: rgba(20, 184, 166, 0.15);
  border-color: #14b8a6;
  color: #14b8a6;
  box-shadow: 0 0 20px rgba(20, 184, 166, 0.2);
  transform: translateY(-2px);
}

.btn-editor-top {
  background: rgba(255, 255, 255, 0.04);
  border: 1px solid rgba(255, 255, 255, 0.08);
  color: #fff;
  padding: 8px 18px;
  border-radius: 100px;
  font-size: 0.8rem;
  font-weight: 700;
  cursor: pointer;
  transition: all 0.2s;
  display: flex;
  align-items: center;
  gap: 8px;
}

.btn-editor-top:hover {
  background: rgba(255, 255, 255, 0.1);
  border-color: rgba(255, 255, 255, 0.2);
  transform: translateY(-2px);
}

.paper-swatch {
  width: 28px;
  height: 28px;
  border-radius: 6px;
  cursor: pointer;
  border: 2px solid transparent;
  transition: transform 0.2s;
}

.paper-swatch:hover { transform: scale(1.15); }
.paper-swatch.active { border-color: #14b8a6; transform: scale(1.15); }

.paper-lined { 
  background: #fff; 
  background-image: linear-gradient(#eee 1px, transparent 1px); 
  background-size: 100% 6px; 
  border: 1px solid #ccc; 
}

.paper-grid { 
  background: #fff; 
  background-image: linear-gradient(#eee 1px, transparent 1px), linear-gradient(90deg, #eee 1px, transparent 1px); 
  background-size: 6px 6px; 
  border: 1px solid #ccc; 
}

.btn-prop {
  width: 34px;
  height: 34px;
  border-radius: 10px;
  border: 1px solid rgba(255, 255, 255, 0.1);
  background: rgba(255, 255, 255, 0.05);
  color: #fff;
  cursor: pointer;
  display: grid;
  place-items: center;
  transition: 0.2s;
}

.btn-prop:hover {
  background: rgba(255, 255, 255, 0.12);
  border-color: #14b8a6;
}

/* Gemini Wave Animation */
@keyframes wavePulse {
  0% { transform: scale(0.85); filter: blur(6px); opacity: 0.6; }
  100% { transform: scale(1.2); filter: blur(12px); opacity: 0.9; }
}

.gemini-icon {
  animation: wavePulse 3s infinite alternate;
}

/* Context Panel Scrollbar */
#wb-pro-ai-chat::-webkit-scrollbar { width: 6px; }
#wb-pro-ai-chat::-webkit-scrollbar-track { background: transparent; }
#wb-pro-ai-chat::-webkit-scrollbar-thumb { background: rgba(255,255,255,0.1); border-radius: 10px; }
#wb-pro-ai-chat::-webkit-scrollbar-thumb:hover { background: rgba(255,255,255,0.2); }

/* ── Pro-Kauf: schwebende Auswahl-Leiste (Mitglieder verwalten) ── */
.pro-checkout-bar {
  position: fixed;
  right: 24px;
  bottom: 24px;
  z-index: 6000;
  display: flex;
  align-items: center;
  gap: 14px;
  padding: 14px 16px 14px 20px;
  border-radius: 18px;
  background: linear-gradient(135deg, #0ea5e9, #6366f1);
  color: #fff;
  box-shadow: 0 16px 48px rgba(0, 0, 0, 0.45);
  animation: proBarIn 0.28s cubic-bezier(0.16, 1, 0.3, 1);
  max-width: calc(100vw - 48px);
}
@keyframes proBarIn {
  from { transform: translateY(24px); opacity: 0; }
  to   { transform: translateY(0);    opacity: 1; }
}
.pro-checkout-info { line-height: 1.25; min-width: 0; }
.pro-checkout-title { font-weight: 800; font-size: 0.95rem; }
.pro-checkout-sub { font-size: 0.8rem; opacity: 0.85; }
.pro-checkout-hint { font-size: 0.72rem; opacity: 0.8; margin-top: 3px; }
/* "Verlängern"-Button bei bereits aktiven Pro-Mitgliedern */
.pro-extend-btn {
  background: var(--card2, rgba(99,102,241,0.1));
  border: 1px solid var(--border2, rgba(99,102,241,0.3));
  color: var(--accent, #6366f1);
  padding: 6px 11px; border-radius: 9px; cursor: pointer;
  font-weight: 700; font-size: 0.78rem; white-space: nowrap;
  display: inline-flex; align-items: center; gap: 5px;
  transition: background 0.15s, color 0.15s;
}
.pro-extend-btn:hover { background: rgba(99, 102, 241, 0.18); }
.pro-extend-btn.active {
  background: linear-gradient(135deg, #0ea5e9, #6366f1);
  border-color: transparent; color: #fff;
}
.pro-checkout-duration {
  display: flex; gap: 4px; flex-shrink: 0;
  background: rgba(255, 255, 255, 0.14);
  padding: 4px; border-radius: 12px;
}
.pro-dur-btn {
  background: transparent; border: none; color: #fff;
  padding: 7px 11px; border-radius: 9px; cursor: pointer;
  font-weight: 700; font-size: 0.82rem; white-space: nowrap;
  transition: background 0.15s;
}
.pro-dur-btn:hover { background: rgba(255, 255, 255, 0.18); }
.pro-dur-btn.active { background: #fff; color: #0f172a; }
.pro-checkout-clear {
  background: rgba(255, 255, 255, 0.16);
  border: none; color: #fff;
  width: 36px; height: 36px;
  border-radius: 11px; cursor: pointer;
  font-size: 0.95rem; flex-shrink: 0;
}
.pro-checkout-clear:hover { background: rgba(255, 255, 255, 0.28); }
.pro-checkout-buy {
  background: #fff; color: #0f172a;
  border: none; padding: 11px 18px;
  border-radius: 11px; font-weight: 800;
  cursor: pointer; white-space: nowrap; flex-shrink: 0;
}
.pro-checkout-buy:hover { background: #e2e8f0; }
@media (max-width: 560px) {
  .pro-checkout-bar { left: 16px; right: 16px; bottom: 16px; flex-wrap: wrap; }
  .pro-checkout-duration { order: 3; width: 100%; justify-content: space-between; }
  .pro-dur-btn { flex: 1; }
}

/* ── Speicher-Kauf-Modal: GB-Auswahl + Zahler ── */
.storage-gb-grid { display: grid; grid-template-columns: repeat(3, 1fr); gap: 8px; margin-bottom: 12px; }
.storage-gb-btn {
  background: var(--card2, rgba(255,255,255,0.04));
  border: 1px solid var(--border2, rgba(255,255,255,0.12));
  color: var(--text, #fff); padding: 12px 8px; border-radius: 11px;
  cursor: pointer; font-weight: 700; font-size: 0.92rem; transition: all 0.15s;
}
.storage-gb-btn:hover { border-color: var(--accent); }
.storage-gb-btn.active {
  background: linear-gradient(135deg, #0ea5e9, #6366f1);
  border-color: transparent; color: #fff;
}
.storage-gb-custom { display: flex; flex-direction: column; gap: 4px; margin-bottom: 4px; }
.storage-gb-custom .form-input { max-width: 160px; }
.storage-payer-row { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.storage-payer-btn {
  display: flex; align-items: center; gap: 10px; text-align: left;
  background: var(--card2, rgba(255,255,255,0.04));
  border: 1px solid var(--border2, rgba(255,255,255,0.12));
  color: var(--text, #fff); padding: 12px; border-radius: 11px; cursor: pointer;
  transition: all 0.15s;
}
.storage-payer-btn i { font-size: 1.2rem; color: var(--accent); flex-shrink: 0; }
.storage-payer-btn:hover { border-color: var(--accent); }
.storage-payer-btn.active { border-color: var(--accent); background: rgba(99, 102, 241, 0.12); }
@media (max-width: 480px) {
  .storage-gb-grid { grid-template-columns: repeat(2, 1fr); }
  .storage-payer-row { grid-template-columns: 1fr; }
}

/* ════ Korrektur-Modus (Klassenarbeiten in Papyrus Studio) ════ */
#corr-ui { position: absolute; inset: 0; pointer-events: none; z-index: 60; }
.corr-panel {
  position: absolute; top: 96px; right: 18px; width: 232px;
  pointer-events: auto;
  background: rgba(20, 22, 28, 0.92); backdrop-filter: blur(16px);
  border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 18px;
  padding: 14px; color: #f4f6fb;
  box-shadow: 0 18px 50px rgba(0, 0, 0, 0.55);
  display: flex; flex-direction: column; gap: 12px;
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  animation: corrIn 0.22s cubic-bezier(0.2, 0.9, 0.3, 1);
}
@keyframes corrIn { from { opacity: 0; transform: translateY(-8px) scale(0.97); } to { opacity: 1; transform: none; } }
.corr-head { font-weight: 700; font-size: 0.92rem; display: flex; align-items: center; gap: 8px; }
.corr-head i { color: #5eead4; }
.corr-sub { color: #9aa3b2; font-weight: 500; font-size: 0.8rem; margin-left: auto; max-width: 110px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
.corr-score { background: rgba(255, 255, 255, 0.05); border-radius: 12px; padding: 10px 12px; text-align: center; }
.corr-score-pts { font-size: 1.5rem; font-weight: 800; letter-spacing: -0.5px; }
.corr-score-pts #corr-sum { color: #5eead4; }
.corr-score-grade { font-size: 0.78rem; color: #9aa3b2; margin-top: 2px; }
.corr-score-grade b { color: #fbbf24; font-size: 0.95rem; }
.corr-tools { display: grid; grid-template-columns: repeat(3, 1fr); gap: 7px; }
.corr-t {
  height: 42px; border: 1px solid rgba(255, 255, 255, 0.1); border-radius: 11px;
  background: rgba(255, 255, 255, 0.04); color: #f4f6fb; cursor: pointer;
  font-size: 1.05rem; display: flex; align-items: center; justify-content: center;
  transition: transform 0.12s, border-color 0.12s, background 0.12s;
}
.corr-t:hover { background: rgba(255, 255, 255, 0.1); transform: translateY(-1px); }
.corr-t.active { border-color: #5eead4; background: rgba(94, 234, 212, 0.16); box-shadow: 0 0 0 2px rgba(94, 234, 212, 0.25); }
.corr-hint { font-size: 0.7rem; color: #8b93a3; line-height: 1.45; }
.corr-ai {
  width: 100%; border: none; border-radius: 12px; cursor: pointer;
  padding: 11px; font-weight: 700; font-size: 0.88rem; color: #1a1205;
  background: linear-gradient(135deg, #fbbf24, #f59e0b);
  display: flex; align-items: center; justify-content: center; gap: 8px;
  transition: filter 0.12s, transform 0.12s;
}
.corr-ai:hover { filter: brightness(1.06); transform: translateY(-1px); }
.corr-ai:disabled { opacity: 0.7; cursor: progress; }
.corr-actions { display: flex; gap: 8px; }
.corr-actions .btn { flex: 1; justify-content: center; }

/* ════ Adobe-Acrobat-Stil Kommentar-Popup ════ */
.pp-note-pop {
  position: fixed; z-index: 1200; width: 300px;
  background: #ffffff; color: #1f2329;
  border: 1px solid #e3e6ea; border-radius: 10px;
  box-shadow: 0 12px 40px rgba(0,0,0,.20), 0 2px 8px rgba(0,0,0,.08);
  font-family: Inter, system-ui, -apple-system, Segoe UI, sans-serif;
  overflow: hidden; animation: ppNoteIn .14s ease;
}
@keyframes ppNoteIn { from { opacity:0; transform: translateY(-5px) scale(.98); } to { opacity:1; transform:none; } }
.pp-note-head { display:flex; align-items:center; gap:9px; padding:11px 12px 7px; }
.pp-note-av { width:28px; height:28px; border-radius:50%; flex-shrink:0; display:flex; align-items:center; justify-content:center;
  background:linear-gradient(135deg,#6366f1,#8b5cf6); color:#fff; font-size:.74rem; font-weight:700; letter-spacing:.3px; }
.pp-note-name { font-weight:600; font-size:.86rem; color:#1f2329; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; max-width:120px; }
.pp-note-time { font-size:.74rem; color:#8a9099; margin-left:2px; }
.pp-note-icn { background:none; border:none; color:#9aa0a8; cursor:pointer; font-size:.85rem; padding:5px 6px; border-radius:6px; margin-left:auto; }
.pp-note-icn + .pp-note-icn { margin-left:0; }
.pp-note-icn:hover { background:#f1f3f5; color:#4b5159; }
.pp-note-icn.pp-note-del:hover { background:#fef2f2; color:#dc2626; }
.pp-note-body { padding:0 12px; }
.pp-note-ta { width:100%; min-height:64px; max-height:220px; border:none !important; outline:none !important; resize:none;
  padding:2px 0 8px; font-size:.9rem; line-height:1.45; font-family:inherit;
  color:#1f2329 !important; -webkit-text-fill-color:#1f2329 !important; caret-color:#1473e6;
  background:#fff !important; box-shadow:none !important; box-sizing:border-box; }
.pp-note-ta:focus { border:none !important; outline:none !important; box-shadow:none !important; }
.pp-note-ta::placeholder { color:#a8aeb6 !important; -webkit-text-fill-color:#a8aeb6 !important; }
.pp-note-foot { display:flex; align-items:center; gap:8px; padding:8px 12px; border-top:1px solid #eef0f3; }
.pp-note-at { background:none; border:none; color:#8a9099; cursor:pointer; font-size:.95rem; padding:5px 7px; border-radius:6px; }
.pp-note-at:hover { background:#f1f3f5; color:#4b5159; }
.pp-note-cancel { background:none; border:none; color:#4b5159; cursor:pointer; padding:7px 12px; border-radius:18px; font-weight:600; font-size:.84rem; }
.pp-note-cancel:hover { background:#f1f3f5; }
.pp-note-save { background:#1473e6; border:none; color:#fff; cursor:pointer; padding:7px 16px; border-radius:18px; font-weight:600; font-size:.84rem; transition:background .12s; }
.pp-note-save:hover:not(:disabled) { background:#0d66d0; }
.pp-note-save:disabled { background:#cfd4da; cursor:default; }
