/* extracted stylesheet */

    *, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }
    :root {
      --bg-dark: #1a1a2e; --bg-mid: #16213e; --bg-card: #0f3460;
      --accent: #e94560; --accent2: #3498db;
      --text-light: #eaeaea; --text-muted: #a0a0b0;
      --sidebar-w: 280px; --border-r: 10px;
    }
    body { font-family:'Segoe UI',sans-serif; background:var(--bg-dark); color:var(--text-light); display:flex; height:100vh; overflow:hidden; }

    /* SIDEBAR */
    #sidebar { width:var(--sidebar-w); min-width:var(--sidebar-w); background:var(--bg-mid); display:flex; flex-direction:column; border-right:1px solid rgba(255,255,255,0.07); overflow-y:auto; }
    #sidebar-header { padding:16px 14px 10px; border-bottom:1px solid rgba(255,255,255,0.07); }
    #sidebar-header h1 { font-size:1.05rem; color:var(--accent); margin-bottom:2px; }
    #sidebar-header p  { font-size:0.72rem; color:var(--text-muted); }
    #header-actions { display:flex; gap:6px; margin-top:10px; }
    .hdr-btn { flex:1; padding:5px 4px; font-size:0.68rem; border:1px solid rgba(255,255,255,0.15); background:rgba(255,255,255,0.05); color:var(--text-light); border-radius:6px; cursor:pointer; transition:background 0.2s; text-align:center; }
    .hdr-btn:hover { background:rgba(255,255,255,0.12); }
    .hdr-btn.primary { background:var(--accent); border-color:var(--accent); }
    .hdr-btn.primary:hover { background:#c73652; }
    #sidebar-tabs { display:flex; border-bottom:1px solid rgba(255,255,255,0.07); }
    .sidebar-tab { flex:1; padding:10px 4px; text-align:center; font-size:0.68rem; cursor:pointer; color:var(--text-muted); transition:all 0.2s; border-bottom:2px solid transparent; }
    .sidebar-tab:hover { color:var(--text-light); }
    .sidebar-tab.active { color:var(--accent); border-bottom-color:var(--accent); }
    .sidebar-panel { display:none; padding:8px 0; }
    .sidebar-panel.active { display:block; }
    .act-block { margin:4px 8px; border-radius:var(--border-r); overflow:hidden; }
    .act-header { display:flex; align-items:center; justify-content:space-between; padding:9px 12px; cursor:pointer; font-size:0.8rem; font-weight:600; transition:filter 0.2s; }
    .act-header:hover { filter:brightness(1.2); }
    .act-header .chevron { transition:transform 0.3s; font-size:0.65rem; }
    .act-header.open .chevron { transform:rotate(90deg); }
    .act-scenes { display:none; background:rgba(0,0,0,0.2); }
    .act-scenes.open { display:block; }
    .scene-item { padding:7px 16px; font-size:0.77rem; color:var(--text-muted); cursor:pointer; border-left:2px solid transparent; transition:all 0.2s; }
    .scene-item:hover { color:var(--text-light); background:rgba(255,255,255,0.04); }
    .scene-item.active { color:var(--text-light); border-left-color:var(--accent); background:rgba(255,255,255,0.06); }
    .sidebar-list-item { display:flex; align-items:center; gap:10px; padding:7px 12px; cursor:pointer; font-size:0.78rem; transition:background 0.2s; border-radius:6px; margin:2px 8px; }
    .sidebar-list-item:hover { background:rgba(255,255,255,0.06); }
    .sidebar-list-item.active { background:rgba(233,69,96,0.15); }
    .sidebar-avatar { width:32px; height:32px; border-radius:50%; background:var(--bg-card); display:flex; align-items:center; justify-content:center; font-size:1rem; flex-shrink:0; overflow:hidden; }
    .sidebar-avatar img { width:100%; height:100%; object-fit:cover; }
    .sidebar-list-label { display:flex; flex-direction:column; }
    .sidebar-list-label span { font-size:0.63rem; color:var(--text-muted); }
    .sidebar-add-btn { margin:6px 10px; padding:7px; background:rgba(255,255,255,0.04); border:1px dashed rgba(255,255,255,0.15); border-radius:8px; color:var(--text-muted); font-size:0.75rem; cursor:pointer; text-align:center; transition:all 0.2s; }
    .sidebar-add-btn:hover { background:rgba(233,69,96,0.1); border-color:var(--accent); color:var(--accent); }
    .section-title { font-size:0.68rem; text-transform:uppercase; letter-spacing:1.5px; color:var(--text-muted); padding:10px 14px 4px; }

    /* MAIN */
    #main { flex:1; overflow-y:auto; padding:24px 28px; }
    #breadcrumb { font-size:0.73rem; color:var(--text-muted); margin-bottom:18px; }
    #breadcrumb span { color:var(--accent); }
    .detail-card { background:var(--bg-mid); border-radius:var(--border-r); padding:22px; margin-bottom:18px; }
    .detail-card h2 { font-size:1.35rem; margin-bottom:6px; }
    .meta-badge { display:inline-block; padding:2px 10px; border-radius:20px; font-size:0.68rem; margin-bottom:12px; background:var(--bg-card); }
    .detail-card p { color:var(--text-muted); line-height:1.7; font-size:0.88rem; }
    .image-section { display:flex; gap:20px; align-items:flex-start; flex-wrap:wrap; }
    .image-upload-box { width:170px; height:170px; border:2px dashed rgba(255,255,255,0.2); border-radius:var(--border-r); display:flex; flex-direction:column; align-items:center; justify-content:center; cursor:pointer; transition:border-color 0.2s; flex-shrink:0; overflow:hidden; position:relative; }
    .image-upload-box:hover { border-color:var(--accent); }
    .image-upload-box img { position:absolute; inset:0; width:100%; height:100%; object-fit:cover; }
    .upload-hint { font-size:0.73rem; color:var(--text-muted); text-align:center; padding:10px; pointer-events:none; position:relative; z-index:1; }
    .upload-hint .icon { font-size:2rem; display:block; margin-bottom:6px; }
    .image-upload-box input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; z-index:2; }
    .tag-grid { display:flex; flex-wrap:wrap; gap:8px; margin-top:10px; }
    .tag { padding:4px 12px; border-radius:20px; font-size:0.73rem; background:var(--bg-card); cursor:pointer; transition:background 0.2s; border-left:3px solid transparent; }
    .tag:hover { background:var(--accent); }
    .cards-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(190px,1fr)); gap:14px; margin-top:14px; }
    .mini-card { background:var(--bg-card); border-radius:var(--border-r); padding:13px; cursor:pointer; transition:transform 0.2s,box-shadow 0.2s; display:flex; align-items:center; gap:11px; }
    .mini-card:hover { transform:translateY(-2px); box-shadow:0 6px 20px rgba(0,0,0,0.3); }
    .mini-card-avatar { width:42px; height:42px; border-radius:50%; background:var(--bg-mid); display:flex; align-items:center; justify-content:center; font-size:1.3rem; flex-shrink:0; overflow:hidden; }
    .mini-card-avatar img { width:100%; height:100%; object-fit:cover; }
    .mini-card-info h4 { font-size:0.83rem; margin-bottom:2px; }
    .mini-card-info span { font-size:0.68rem; color:var(--text-muted); }

    /* GRAPH */
    #graph-section { background:var(--bg-mid); border-radius:var(--border-r); padding:18px; margin-bottom:18px; }
    #graph-section h3 { margin-bottom:12px; font-size:0.95rem; }
    #graph-hint { font-size:0.68rem; color:var(--text-muted); margin-bottom:8px; }
    #connection-canvas { width:100%; height:360px; background:rgba(0,0,0,0.25); border-radius:8px; display:block; cursor:grab; }
    #connection-canvas:active { cursor:grabbing; }

    /* FORMS */
    .edit-form { display:flex; flex-direction:column; gap:12px; margin-top:16px; }
    .edit-form label { font-size:0.72rem; color:var(--text-muted); margin-bottom:3px; display:block; }
    .edit-form input,.edit-form textarea,.edit-form select { width:100%; padding:8px 12px; background:var(--bg-card); border:1px solid rgba(255,255,255,0.1); border-radius:6px; color:var(--text-light); font-size:0.85rem; font-family:inherit; transition:border-color 0.2s; resize:vertical; }
    .edit-form input:focus,.edit-form textarea:focus,.edit-form select:focus { outline:none; border-color:var(--accent); }
    .edit-form textarea { min-height:80px; }
    .form-row { display:grid; grid-template-columns:1fr 1fr; gap:12px; }
    .edit-actions { display:flex; gap:10px; margin-top:6px; flex-wrap:wrap; }
    .btn { padding:8px 18px; border-radius:6px; font-size:0.82rem; cursor:pointer; border:none; transition:background 0.2s,transform 0.1s; }
    .btn:active { transform:scale(0.97); }
    .btn-primary { background:var(--accent); color:#fff; }
    .btn-primary:hover { background:#c73652; }
    .btn-secondary { background:rgba(255,255,255,0.08); color:var(--text-light); }
    .btn-secondary:hover { background:rgba(255,255,255,0.14); }
    .btn-danger { background:rgba(231,76,60,0.2); color:#e74c3c; }
    .btn-danger:hover { background:rgba(231,76,60,0.35); }
    .divider { height:1px; background:rgba(255,255,255,0.07); margin:14px 0; }
    .edit-toggle-btn { font-size:0.75rem; color:var(--accent); cursor:pointer; display:inline-flex; align-items:center; gap:5px; padding:4px 0; background:none; border:none; margin-top:10px; }
    .edit-toggle-btn:hover { text-decoration:underline; }
    .edit-section { display:none; margin-top:10px; }
    .edit-section.open { display:block; }
    .multi-check-list { display:flex; flex-direction:column; gap:6px; max-height:140px; overflow-y:auto; padding:8px; background:var(--bg-card); border-radius:6px; border:1px solid rgba(255,255,255,0.1); }
    .multi-check-item { display:flex; align-items:center; gap:8px; font-size:0.8rem; }
    .multi-check-item input[type="checkbox"] { accent-color:var(--accent); }

    /* MODAL */
    #modal-overlay { display:none; position:fixed; inset:0; background:rgba(0,0,0,0.6); z-index:1000; align-items:center; justify-content:center; }
    #modal-overlay.open { display:flex; }
    #modal-box { background:var(--bg-mid); border-radius:var(--border-r); padding:28px; width:440px; max-width:90vw; }
    #modal-box h3 { margin-bottom:12px; }
    #modal-box p { color:var(--text-muted); font-size:0.85rem; margin-bottom:18px; line-height:1.6; }

    /* TOAST */
    #toast { position:fixed; bottom:24px; right:24px; background:var(--bg-card); color:var(--text-light); padding:12px 20px; border-radius:8px; font-size:0.82rem; border-left:3px solid var(--accent); opacity:0; transform:translateY(10px); transition:all 0.3s; z-index:999; pointer-events:none; }
    #toast.show { opacity:1; transform:translateY(0); }

    /* WELCOME */
    #welcome { display:flex; flex-direction:column; align-items:center; justify-content:center; height:60vh; text-align:center; gap:10px; }
    #welcome h1 { font-size:2.1rem; color:var(--accent); }
    #welcome p { color:var(--text-muted); max-width:400px; line-height:1.6; }
    ::-webkit-scrollbar { width:5px; }
    ::-webkit-scrollbar-track { background:transparent; }
    ::-webkit-scrollbar-thumb { background:rgba(255,255,255,0.1); border-radius:5px; }

        .act-edit-btn {
      background: none;
      border: none;
      cursor: pointer;
      font-size: 0.75rem;
      padding: 2px 5px;
      border-radius: 4px;
      margin-left: auto;
      opacity: 0.5;
      transition: opacity 0.2s;
    }
    .act-edit-btn:hover { opacity: 1; }

    .btn-danger {
      background: #c0392b;
      color: #fff;
      border: none;
      padding: 8px 18px;
      border-radius: 8px;
      cursor: pointer;
      font-size: 0.85rem;
      transition: background 0.2s;
    }
    .btn-danger:hover { background: #e74c3c; }
    /* ── KAMPAGNEN-SWITCHER ── */
    .campaign-switcher {
      border-bottom: 1px solid rgba(255,255,255,0.08);
      margin-bottom: 10px;
      padding-bottom: 10px;
    }

    .campaign-switcher-header {
      display: flex;
      justify-content: space-between;
      align-items: center;
      padding: 8px 12px;
      cursor: pointer;
      border-radius: 8px;
      font-size: 0.85rem;
      font-weight: 600;
      color: var(--text-secondary);
      transition: background 0.2s;
    }

    .campaign-switcher-header:hover {
      background: rgba(255,255,255,0.06);
    }

    .campaign-switcher-list {
      display: none;
      flex-direction: column;
      gap: 4px;
      padding: 4px 0;
      max-height: 220px;
      overflow-y: auto;
    }

    .campaign-switcher-list.open {
      display: flex;
    }

    .campaign-switcher-item {
      padding: 8px 12px;
      border-radius: 8px;
      cursor: pointer;
      font-size: 0.82rem;
      color: var(--text-primary);
      transition: background 0.2s;
      white-space: nowrap;
      overflow: hidden;
      text-overflow: ellipsis;
    }

    .campaign-switcher-item:hover {
      background: rgba(255,255,255,0.08);
    }

    .campaign-switcher-item.active {
      background: rgba(233,69,96,0.2);
      color: var(--accent);
      font-weight: 600;
    }

    .campaign-switcher-loading {
      padding: 8px 12px;
      font-size: 0.8rem;
      color: var(--text-secondary);
    }

    .campaign-switcher-actions {
      padding: 6px 4px 2px;
    }

    .btn-sm {
      padding: 5px 10px;
      font-size: 0.78rem;
      width: 100%;
    }


  /* ── CFG PANEL ── */
  .cfg-row { margin: 14px 0; display: flex; flex-direction: column; gap: 6px; }
  .cfg-row label { font-size: 0.75rem; color: var(--text-muted); text-transform: uppercase; letter-spacing: 0.05em; }
  .cfg-row input { background: var(--bg-card); border: 1px solid rgba(255,255,255,0.1); border-radius: 6px; padding: 8px 10px; color: var(--text-light); font-size: 0.9rem; outline: none; transition: border-color 0.2s; }
  .cfg-row input:focus { border-color: var(--accent); }
  .cfg-save-btn { margin-top: 8px; width: 100%; padding: 10px; background: var(--accent); border: none; border-radius: 8px; color: #fff; font-size: 0.9rem; cursor: pointer; transition: opacity 0.2s; }
  .cfg-save-btn:hover { opacity: 0.85; }
  