/* ═══════════════════════════════════════════════
   CONTENT MACHINE — Design System
   Mode (light/dark) × Theme (accent color)
═══════════════════════════════════════════════ */

/* ── Base: light mode defaults ────────────────────── */
:root {
  --bg:          #f4f6fb;
  --bg-2:        #ffffff;
  --bg-3:        #eef1f7;
  --border:      #d1d9e6;
  --border-2:    #b8c4d8;
  --accent:      #3b6ef5;
  --accent-dim:  #3b6ef512;
  --accent-hover:#2558e0;
  --success:     #16a34a;
  --warning:     #d97706;
  --danger:      #dc2626;
  --text:        #0f172a;
  --text-2:      #475569;
  --text-3:      #94a3b8;
  --surface:     #ffffff;
  --surface-2:   #eef1f7;
  --logo-color:  var(--text);
  --font-mono:   'JetBrains Mono', 'Fira Code', monospace;
  --radius:      10px;
  --radius-sm:   6px;
  --sidebar-w:   220px;
  --sidebar-w-collapsed: 56px;
  --transition:  0.2s cubic-bezier(.4,0,.2,1);
}

/* ── Dark mode ────────────────────────────────────── */
[data-mode="dark"] {
  --bg:          #0d0f14;
  --bg-2:        #131720;
  --bg-3:        #1a2030;
  --border:      #232a3a;
  --border-2:    #2e3748;
  --accent:      #4f7cff;
  --accent-dim:  #4f7cff22;
  --accent-hover:#6b93ff;
  --success:     #22c55e;
  --warning:     #f59e0b;
  --danger:      #ef4444;
  --text:        #e2e8f0;
  --text-2:      #94a3b8;
  --text-3:      #4a5568;
  --surface:     #131720;
  --surface-2:   #1a2030;
}

/* ── Theme accents (work in both light & dark) ────── */
[data-theme="edge"]      { --accent: #fc4138; --accent-dim: #fc413822; --accent-hover: #ff6b63; --logo-color: #fc4138; --danger: #a83220; }
[data-theme="forest"]    { --accent: #22c55e; --accent-dim: #22c55e22; --accent-hover: #4ade80; --logo-color: #22c55e; }
/* ── Cyberpunk ──────────────────────────────────────
   Neon city: magenta/cyan/yellow on near-black,
   glowing borders, flickering, scanlines
──────────────────────────────────────────────────── */
[data-theme="cyberpunk"] {
  --accent: #ff00ff; --accent-dim: #ff00ff12; --accent-hover: #ff66ff; --logo-color: #00fff2;
  --success: #00ff88; --warning: #ffe600; --danger: #ff2255;
}
[data-mode="dark"][data-theme="cyberpunk"] {
  --bg: #05050f; --bg-2: #0a0a1a; --bg-3: #12122a;
  --border: #1a1a3a; --border-2: #2a2a4a;
  --text: #e0e0ff; --text-2: #8888bb; --text-3: #4444aa;
  --surface: #0a0a1a; --surface-2: #12122a;
}
[data-theme="cyberpunk"]:not([data-mode="dark"]) {
  --bg: #f4f0ff; --bg-2: #fff; --bg-3: #eae4ff;
  --border: #c8c0e8; --border-2: #b0a0d8;
  --text: #1a0030; --text-2: #4a3060; --text-3: #8070a0;
  --surface: #fff; --surface-2: #eae4ff;
}
/* Cyberpunk light: neon on light bg with flicker + scanlines */
[data-theme="cyberpunk"]:not([data-mode="dark"]) .btn-primary {
  background: transparent; color: #aa00cc;
  border: 1px solid #aa00cc;
  box-shadow: 0 0 6px #cc00cc44, 0 0 16px #cc00cc22;
  animation: neonPulse 3s ease-in-out infinite;
}
[data-theme="cyberpunk"]:not([data-mode="dark"]) .btn-primary:hover {
  background: #cc00cc15;
  box-shadow: 0 0 10px #cc00cc66, 0 0 25px #cc00cc33;
}
[data-theme="cyberpunk"]:not([data-mode="dark"]) .nav-item.active {
  color: #aa00cc; background: #cc00cc08;
  border: 1px solid #cc00cc33;
  text-shadow: 0 0 4px #cc00cc66;
}
[data-theme="cyberpunk"]:not([data-mode="dark"]) .bp-card:hover { border-color: #00aabb; box-shadow: 0 0 8px #00bcd422; }
[data-theme="cyberpunk"]:not([data-mode="dark"]) .view-title {
  color: #7b00b5;
  text-shadow: 0 0 12px #cc00cc33, 0 0 30px #cc00cc11;
  animation: neonFlicker 4s linear infinite;
}
[data-theme="cyberpunk"]:not([data-mode="dark"]) ::selection { background: #cc00cc; color: #fff; }
/* Scanlines on light too */
[data-theme="cyberpunk"]:not([data-mode="dark"]) body::after {
  content: '';
  position: fixed; inset: 0;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(100,0,150,.03) 2px, rgba(100,0,150,.03) 4px);
  pointer-events: none; z-index: 9999;
}
/* Neon flicker animation */
@keyframes neonFlicker {
  0%, 19%, 21%, 23%, 25%, 54%, 56%, 100% { opacity: 1; }
  20%, 24%, 55% { opacity: .6; }
}
@keyframes neonPulse {
  0%, 100% { box-shadow: 0 0 5px #ff00ff44, 0 0 15px #ff00ff22; }
  50% { box-shadow: 0 0 10px #ff00ff88, 0 0 30px #ff00ff44, 0 0 50px #ff00ff22; }
}
/* Glowing neon buttons */
[data-mode="dark"][data-theme="cyberpunk"] .btn-primary {
  background: transparent; color: #ff00ff;
  border: 1px solid #ff00ff;
  box-shadow: 0 0 8px #ff00ff66, 0 0 20px #ff00ff33, inset 0 0 8px #ff00ff22;
  text-shadow: 0 0 8px #ff00ff;
  animation: neonPulse 3s ease-in-out infinite;
}
[data-mode="dark"][data-theme="cyberpunk"] .btn-primary:hover {
  background: #ff00ff22;
  box-shadow: 0 0 15px #ff00ffaa, 0 0 40px #ff00ff55, inset 0 0 12px #ff00ff33;
}
/* Cards with neon border glow on hover */
[data-mode="dark"][data-theme="cyberpunk"] .bp-card,
[data-mode="dark"][data-theme="cyberpunk"] .preset-card,
[data-mode="dark"][data-theme="cyberpunk"] .card,
[data-mode="dark"][data-theme="cyberpunk"] .active-run-card {
  border: 1px solid #1a1a3a;
}
[data-mode="dark"][data-theme="cyberpunk"] .bp-card:hover {
  border-color: #00fff2; box-shadow: 0 0 15px #00fff233, 0 0 4px #00fff255;
}
[data-mode="dark"][data-theme="cyberpunk"] .preset-card:hover {
  border-color: #ff00ff; box-shadow: 0 0 15px #ff00ff33;
}
/* Scanlines overlay */
[data-mode="dark"][data-theme="cyberpunk"] body::after {
  content: '';
  position: fixed; inset: 0;
  background: repeating-linear-gradient(0deg, transparent, transparent 2px, rgba(0,0,0,.1) 2px, rgba(0,0,0,.1) 4px);
  pointer-events: none; z-index: 9999;
}
/* Sidebar: cyan glow line */
[data-mode="dark"][data-theme="cyberpunk"] .sidebar {
  border-right: 1px solid #00fff244;
  box-shadow: 1px 0 20px #00fff222;
}
/* Active nav: neon underline */
[data-mode="dark"][data-theme="cyberpunk"] .nav-item.active {
  color: #00fff2;
  text-shadow: 0 0 8px #00fff2;
  background: #00fff208;
  border: 1px solid #00fff233;
}
/* Glowing view titles — with flicker */
[data-mode="dark"][data-theme="cyberpunk"] .view-title {
  color: #00fff2;
  text-shadow: 0 0 10px #00fff288, 0 0 30px #00fff244, 0 0 60px #00fff222;
  animation: neonFlicker 4s linear infinite;
}
/* Modal: dual-color neon border */
[data-mode="dark"][data-theme="cyberpunk"] .modal {
  border: 1px solid #ff00ff55;
  box-shadow: 0 0 20px #ff00ff22, 0 0 40px #00fff211, 0 20px 60px #00000080;
}
/* Badges: neon colors */
[data-mode="dark"][data-theme="cyberpunk"] .badge-published { color: #00ff88; border-color: #00ff8844; background: #00ff8812; }
[data-mode="dark"][data-theme="cyberpunk"] .badge-auto { color: #ffe600; border-color: #ffe60044; background: #ffe60012; }
[data-mode="dark"][data-theme="cyberpunk"] .badge-draft { color: #00fff2; border-color: #00fff233; background: #00fff208; }
/* Form inputs: subtle glow on focus */
[data-mode="dark"][data-theme="cyberpunk"] .search-input:focus,
[data-mode="dark"][data-theme="cyberpunk"] select:focus,
[data-mode="dark"][data-theme="cyberpunk"] textarea:focus {
  border-color: #ff00ff88;
  box-shadow: 0 0 8px #ff00ff44;
}
/* Selection */
[data-mode="dark"][data-theme="cyberpunk"] ::selection { background: #ff00ff; color: #fff; }
/* Collapsible headers: neon accent */
[data-mode="dark"][data-theme="cyberpunk"] .collapsible-header { border-color: #1a1a3a; }
[data-mode="dark"][data-theme="cyberpunk"] .collapsible-header:hover { border-color: #ff00ff44; }
[data-mode="dark"][data-theme="cyberpunk"] .collapsible-header.open .collapsible-arrow { color: #00fff2; border-color: #00fff244; background: #00fff212; }

/* ══════════════════════════════════════════════════════
   SPECIAL SKINS — Glass, Mono, Bold, Editorial, Atelier
   (verwijder een heel [data-theme="X"] blok om een skin te verwijderen)
══════════════════════════════════════════════════════ */

/* ── Mono ──────────────────────────────────────────
   True black & white, maximum contrast
──────────────────────────────────────────────────── */
[data-theme="mono"] {
  --accent: #888; --accent-dim: #88888818; --accent-hover: #aaa; --logo-color: var(--text);
}
[data-mode="dark"][data-theme="mono"] {
  --bg: #000000; --bg-2: #0a0a0a; --bg-3: #141414;
  --border: #222; --border-2: #333;
  --text: #ffffff; --text-2: #999; --text-3: #555;
  --surface: #0a0a0a; --surface-2: #141414;
  --accent: #fff; --accent-dim: #ffffff15; --accent-hover: #ccc;
  --success: #4ade80; --warning: #facc15; --danger: #f87171;
}
[data-theme="mono"]:not([data-mode="dark"]) {
  --bg: #ffffff; --bg-2: #fafafa; --bg-3: #f0f0f0;
  --border: #ddd; --border-2: #ccc;
  --text: #000000; --text-2: #555; --text-3: #999;
  --surface: #fafafa; --surface-2: #f0f0f0;
  --accent: #222; --accent-dim: #22222210; --accent-hover: #444;
  --success: #16a34a; --warning: #ca8a04; --danger: #dc2626;
}
[data-theme="mono"] .bp-card,
[data-theme="mono"] .preset-card,
[data-theme="mono"] .card { border-width: 1px; }
[data-theme="mono"] .btn-primary { font-weight: 700; letter-spacing: .3px; }
/* Ensure btn-primary text is always visible against accent bg */
[data-mode="dark"][data-theme="mono"] .btn-primary { color: #000; }
[data-theme="mono"]:not([data-mode="dark"]) .btn-primary { color: #fff; }

/* ── Bold ──────────────────────────────────────────
   Neo-brutalist: vivid color blocks, thick borders,
   Space Grotesk font, playful & graphic
──────────────────────────────────────────────────── */
[data-theme="bold"] {
  --accent: #ff5722; --accent-dim: #ff572225; --accent-hover: #ff7a50;
  --logo-color: #ff5722;
  --success: #00c853; --warning: #ffd600; --danger: #d50000;
  --radius: 0px; --radius-sm: 0px;
}
[data-theme="bold"],
[data-theme="bold"] * { font-family: 'Space Grotesk', system-ui, sans-serif; }
[data-mode="dark"][data-theme="bold"] {
  --bg: #1a1a2e; --bg-2: #16213e; --bg-3: #0f3460;
  --border: #000; --border-2: #000;
  --text: #eee; --text-2: #bbb; --text-3: #888;
  --surface: #16213e; --surface-2: #0f3460;
}
[data-theme="bold"]:not([data-mode="dark"]) {
  --bg: #fef3c7; --bg-2: #ffffff; --bg-3: #fde68a;
  --border: #000; --border-2: #000;
  --text: #000; --text-2: #333; --text-3: #666;
  --surface: #fff; --surface-2: #fde68a;
}
[data-theme="bold"] .sidebar {
  border-right: 3px solid #000;
}
[data-theme="bold"] .bp-card,
[data-theme="bold"] .preset-card,
[data-theme="bold"] .card,
[data-theme="bold"] .active-run-card {
  border: 3px solid #000;
  box-shadow: 5px 5px 0px #000;
  transition: all var(--transition);
}
[data-theme="bold"] .bp-card:hover,
[data-theme="bold"] .preset-card:hover {
  transform: translate(-2px, -2px);
  box-shadow: 7px 7px 0px #000;
}
[data-theme="bold"] .btn-primary {
  border: 3px solid #000;
  box-shadow: 3px 3px 0px #000;
  text-transform: uppercase;
  font-weight: 700;
  letter-spacing: .5px;
}
[data-theme="bold"] .btn-primary:hover {
  transform: translate(-1px, -1px);
  box-shadow: 4px 4px 0px #000;
}
[data-theme="bold"] .btn-secondary,
[data-theme="bold"] .btn-ghost {
  border: 2px solid #000;
}
[data-theme="bold"] .badge {
  border: 2px solid #000; border-radius: 0; font-weight: 700; text-transform: uppercase; letter-spacing: .5px;
}
[data-theme="bold"] .nav-item.active {
  background: var(--accent); color: #fff;
  border: 2px solid #000;
  box-shadow: 2px 2px 0px #000;
}
[data-theme="bold"] .form-section-title {
  background: #000; color: #fff; padding: 6px 12px; border-bottom: none;
  display: inline-block; margin-bottom: 14px; font-size: 12px;
}
[data-theme="bold"] .collapsible-header {
  border: 2px solid #000; box-shadow: 3px 3px 0px #000;
}
[data-theme="bold"] .collapsible-body.open {
  border: 2px solid #000; border-top: none;
}
[data-theme="bold"] .view-title { font-size: 28px; font-weight: 700; text-transform: uppercase; letter-spacing: 1px; }
[data-theme="bold"] .modal { border: 3px solid #000; box-shadow: 8px 8px 0px #000; border-radius: 0; }


/* ── Atelier ──────────────────────────────────────
   Elegant minimalist: lots of whitespace, refined
   typography, subtle touches, museum/gallery vibe
──────────────────────────────────────────────────── */
[data-theme="atelier"] {
  --accent: #8b7355; --accent-dim: #8b735510; --accent-hover: #a6896a;
  --logo-color: #8b7355;
  --success: #5a7a5a; --warning: #b8976a; --danger: #a04040;
  --radius: 0px; --radius-sm: 0px;
}
[data-mode="dark"][data-theme="atelier"] {
  --bg: #141210; --bg-2: #1c1a17; --bg-3: #24221e;
  --border: #302e28; --border-2: #3e3c35;
  --text: #e8e4dc; --text-2: #a09888; --text-3: #605848;
  --surface: #1c1a17; --surface-2: #24221e;
}
[data-theme="atelier"]:not([data-mode="dark"]) {
  --bg: #f8f6f2; --bg-2: #ffffff; --bg-3: #f0ece6;
  --border: #e0dcd4; --border-2: #d0cbc0;
  --text: #2c2824; --text-2: #70685c; --text-3: #a8a090;
  --surface: #fff; --surface-2: #f0ece6;
}
/* Refined typography */
[data-theme="atelier"] .view-title {
  font-weight: 300; font-size: 26px; letter-spacing: 2px; text-transform: uppercase;
}
[data-theme="atelier"] .view-sub { font-style: italic; letter-spacing: .5px; }
/* Hairline borders, maximum restraint */
[data-theme="atelier"] .sidebar { border-right: 1px solid var(--border); }
[data-theme="atelier"] .bp-card,
[data-theme="atelier"] .preset-card,
[data-theme="atelier"] .card {
  border: none; border-bottom: 1px solid var(--border);
  border-radius: 0;
  box-shadow: none;
}
[data-theme="atelier"] .bp-card:hover,
[data-theme="atelier"] .preset-card:hover {
  transform: none;
  box-shadow: none;
  background: var(--bg-3);
}
/* Understated buttons */
[data-theme="atelier"] .btn-primary {
  background: var(--text); color: var(--bg);
  border-radius: 0;
  text-transform: uppercase; letter-spacing: 2px; font-size: 11px; font-weight: 400;
  padding: 10px 24px;
}
[data-theme="atelier"] .btn-primary:hover {
  background: var(--accent); transform: none;
}
[data-theme="atelier"] .btn-secondary,
[data-theme="atelier"] .btn-ghost {
  border-radius: 0; letter-spacing: .5px;
}
/* Navigation: barely-there active state */
[data-theme="atelier"] .nav-item { font-weight: 400; letter-spacing: .3px; }
[data-theme="atelier"] .nav-item.active {
  background: none;
  color: var(--text);
  font-weight: 600;
  border-bottom: 1px solid var(--text);
  border-radius: 0;
}
/* Section titles: thin, spaced */
[data-theme="atelier"] .form-section-title {
  font-weight: 300; letter-spacing: 3px; font-size: 10px;
  border-bottom: 1px solid var(--border);
}
/* Collapsible: minimal */
[data-theme="atelier"] .collapsible-header {
  background: none; border: none; border-bottom: 1px solid var(--border);
  border-radius: 0; padding: 12px 0;
}
[data-theme="atelier"] .collapsible-header:hover { background: none; }
[data-theme="atelier"] .collapsible-body.open {
  border: none; background: none; padding: 16px 0;
}
[data-theme="atelier"] .collapsible-arrow { background: none; border: none; }
/* Badges: refined */
[data-theme="atelier"] .badge {
  border-radius: 0; font-weight: 400; letter-spacing: 1px; text-transform: uppercase; font-size: 9px;
}
[data-theme="atelier"] .modal { border-radius: 0; border: 1px solid var(--border); box-shadow: 0 20px 60px rgba(0,0,0,.08); }
/* Search input */
[data-theme="atelier"] .search-input { border-radius: 0; border: none; border-bottom: 1px solid var(--border); background: transparent; }

/* ── End special skins ──────────────────────────── */

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

html { font-size: 15px; }

body {
  background: var(--bg);
  color: var(--text);
  font-family: 'Inter', system-ui, sans-serif;
  line-height: 1.6;
  display: flex;
  min-height: 100vh;
  overflow-x: hidden;
}

/* ── Scrollbar ─────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg-2); }
::-webkit-scrollbar-thumb { background: var(--border-2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--text-3); }

/* ── Sidebar ────────────────────────────────────── */
.sidebar {
  width: var(--sidebar-w);
  min-height: 100vh;
  background: var(--bg-2);
  border-right: 1px solid var(--border);
  display: flex;
  flex-direction: column;
  padding: 20px 0;
  position: fixed;
  top: 0; left: 0; bottom: 0;
  z-index: 100;
  transition: width var(--transition);
}

/* ── Sidebar collapse toggle ──────────────────────── */
.sidebar-collapse-btn {
  position: absolute; top: 12px; right: -12px;
  width: 24px; height: 24px;
  border-radius: 50%;
  background: var(--bg-2);
  border: 1px solid var(--border);
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  z-index: 101;
  color: var(--text-3);
  transition: all var(--transition);
  padding: 0;
}
.sidebar-collapse-btn:hover { color: var(--text); background: var(--bg-3); }
.sidebar-collapse-btn svg { width: 14px; height: 14px; transition: transform var(--transition); }

/* ── Collapsed state ──────────────────────────────── */
.sidebar.collapsed { width: var(--sidebar-w-collapsed); }
.sidebar.collapsed .logo-text,
.sidebar.collapsed .nav-item span,
.sidebar.collapsed .profile-name,
.sidebar.collapsed .profile-sub,
.sidebar.collapsed .status-text,
.sidebar.collapsed .runs-tab-badge { display: none; }
.sidebar.collapsed .sidebar-logo { padding: 0 12px 16px; justify-content: center; }
.sidebar.collapsed .logo-mark { width: 32px; height: 24px; }
.sidebar.collapsed .sidebar-nav { padding: 0 6px; }
.sidebar.collapsed .nav-item { justify-content: center; padding: 10px; }
.sidebar.collapsed .sidebar-footer { padding: 8px 6px; }
.sidebar.collapsed .profile-btn { justify-content: center; padding: 8px; }
.sidebar.collapsed .profile-avatar { width: 24px; height: 24px; }
.sidebar.collapsed .status-indicator { justify-content: center; }
.sidebar.collapsed .sidebar-collapse-btn svg { transform: rotate(180deg); }
.sidebar.collapsed + .main {
  margin-left: var(--sidebar-w-collapsed);
  width: calc(100% - var(--sidebar-w-collapsed));
}

.sidebar-logo {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 0 18px 24px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
}
.logo-mark {
  width: 64px; height: 44px;
  flex-shrink: 0;
}
.logo-icon {
  width: 100%; height: 100%;
  background-color: var(--logo-color);
  -webkit-mask-image: url(/img/logo-white.svg);
  mask-image: url(/img/logo-white.svg);
  -webkit-mask-size: contain;
  mask-size: contain;
  -webkit-mask-repeat: no-repeat;
  mask-repeat: no-repeat;
  -webkit-mask-position: center;
  mask-position: center;
  transition: background-color var(--transition);
}
.logo-text { font-size: 13px; font-weight: 600; color: var(--text); }

.sidebar-nav { flex: 1; padding: 0 10px; display: flex; flex-direction: column; gap: 2px; }

.nav-item {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 10px;
  border-radius: var(--radius-sm);
  color: var(--text-2);
  text-decoration: none;
  font-size: 13px; font-weight: 500;
  transition: all var(--transition);
  cursor: pointer;
}
.nav-item svg { width: 16px; height: 16px; flex-shrink: 0; }
.nav-item:hover { background: var(--bg-3); color: var(--text); }
.nav-item.active { background: var(--accent-dim); color: var(--accent); }

.sidebar-footer {
  padding: 12px 10px;
  border-top: 1px solid var(--border);
  margin-top: auto;
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.status-indicator { display: flex; align-items: center; gap: 8px; padding: 0 8px; }
.dot { width: 7px; height: 7px; border-radius: 50%; background: var(--success); animation: pulse 2s ease infinite; }
@keyframes pulse { 0%,100%{opacity:1} 50%{opacity:.4} }
.dot.error { background: var(--danger); animation: none; }
.status-text { font-size: 11px; color: var(--text-3); }

/* ── Profile button in sidebar ─────────────────────── */
.profile-btn {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 10px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: background var(--transition);
  border: none; background: transparent;
  width: 100%; text-align: left; font-family: inherit;
  color: var(--text-2);
}
.profile-btn:hover { background: var(--bg-3); color: var(--text); }
.profile-avatar {
  width: 28px; height: 28px;
  flex-shrink: 0; border-radius: 50%; overflow: hidden;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg-3); border: 1px solid var(--border);
}
.profile-avatar .sett-photo-placeholder { font-size: 14px; opacity: .4; line-height: 1; }
.profile-avatar img {
  width: 100%; height: 100%; object-fit: cover; border-radius: 50%;
}
.profile-avatar.has-photo .sett-photo-placeholder { display: none; }
/* Profile photo preview in settings */
.sett-photo-preview {
  width: 56px; height: 56px; border-radius: 50%; overflow: hidden;
  background: var(--bg-3); display: flex; align-items: center; justify-content: center;
  border: 2px solid var(--border); flex-shrink: 0;
}
.sett-photo-preview img { width: 100%; height: 100%; object-fit: cover; }
.sett-photo-placeholder { font-size: 24px; opacity: .3; }
.profile-name { font-size: 12px; font-weight: 500; line-height: 1.3; }
.profile-sub  { font-size: 10px; color: var(--text-3); line-height: 1.3; }

/* ── Settings popover ──────────────────────────────── */
.settings-popover {
  position: fixed;
  bottom: calc(var(--sidebar-w) * 0); /* positioned via JS */
  left: 10px;
  width: 200px;
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 32px #00000060;
  padding: 12px;
  z-index: 200;
  display: none;
  animation: fadeIn .15s ease;
}
.settings-popover.open { display: block; }
.settings-popover-title {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .7px; color: var(--text-3);
  margin-bottom: 10px; padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.settings-row {
  display: flex; align-items: center; justify-content: space-between;
  padding: 6px 0;
  font-size: 12px; color: var(--text-2);
}
.settings-row + .settings-row {
  border-top: 1px solid var(--border);
}

/* ── Main ──────────────────────────────────────── */
.main {
  flex: 1;
  margin-left: var(--sidebar-w);
  padding: 32px 36px;
  min-height: 100vh;
  width: calc(100% - var(--sidebar-w));
  min-width: 0; /* prevent overflow in flex context */
  transition: margin-left var(--transition), width var(--transition);
}

/* ── Views ─────────────────────────────────────── */
.view { display: none; }
.view.active { display: block; }
@keyframes fadeIn { from{opacity:0;transform:translateY(8px)} to{opacity:1;transform:translateY(0)} }

/* ── Scroll-to-top button ─────────────────────────── */
.scroll-top-btn {
  position: fixed; bottom: 24px; right: 24px;
  width: 40px; height: 40px;
  border-radius: 50%;
  background: var(--bg-2);
  border: 1px solid var(--border);
  color: var(--text-2);
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  opacity: 0; visibility: hidden;
  transform: translateY(8px);
  transition: opacity .25s ease, visibility .25s ease, transform .25s ease, background .15s ease, color .15s ease;
  z-index: 50;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
}
.scroll-top-btn.visible { opacity: 1; visibility: visible; transform: translateY(0); }
.scroll-top-btn:hover { background: var(--accent); color: #fff; border-color: var(--accent); }
.scroll-top-btn svg { width: 18px; height: 18px; }

.view-header {
  display: flex; align-items: flex-start; justify-content: space-between;
  margin-bottom: 28px; gap: 16px;
}
.view-title { font-size: 22px; font-weight: 700; letter-spacing: -.3px; }
.view-sub { font-size: 13px; color: var(--text-2); margin-top: 3px; }

/* ── Buttons ────────────────────────────────────── */
.btn {
  display: inline-flex; align-items: center; gap: 7px;
  padding: 8px 16px;
  border-radius: var(--radius-sm);
  border: none; cursor: pointer;
  font-size: 13px; font-weight: 500;
  font-family: inherit;
  transition: all var(--transition);
  white-space: nowrap;
}
.btn svg { width: 14px; height: 14px; flex-shrink: 0; }
.btn-primary { background: var(--accent); color: #fff; }
.btn-primary:hover { background: var(--accent-hover); transform: translateY(-1px); }
.btn-secondary { background: var(--bg-3); color: var(--text); border: 1px solid var(--border); }
.btn-secondary:hover { background: var(--border); }
.btn-ghost { background: transparent; color: var(--text-2); }
.btn-ghost:hover { color: var(--text); background: var(--bg-3); }
.btn-danger { background: transparent; color: var(--danger); border: 1px solid var(--danger)22; }
.btn-danger:hover { background: var(--danger)11; }
.btn-success { background: var(--success)22; color: var(--success); border: 1px solid var(--success)33; }
.btn-back { padding: 6px 12px; }
.btn:disabled { opacity: .4; cursor: not-allowed; pointer-events: none; }
.btn-sm { padding: 5px 10px; font-size: 12px; }
.btn-icon { padding: 7px; }

/* ── Filter bar ─────────────────────────────────── */
.filter-bar {
  display: flex; align-items: center; gap: 10px;
  margin-bottom: 24px; flex-wrap: wrap;
}
.search-wrap {
  flex: 1; min-width: 220px;
  position: relative;
}
.search-wrap svg {
  display: none;
}
.search-input {
  width: 100%; padding: 8px 12px;
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius-sm); color: var(--text);
  font-size: 13px; font-family: inherit;
  transition: border-color var(--transition);
}
.search-input:focus { outline: none; border-color: var(--accent); }
.search-input::placeholder { color: var(--text-3); }
.filters { display: flex; gap: 8px; flex-wrap: wrap; }

/* ── Form elements ──────────────────────────────── */
.select-filter, select, .input, input[type="text"], input[type="number"], input[type="url"], textarea {
  background: var(--bg-2);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  color: var(--text);
  font-size: 13px;
  font-family: inherit;
  padding: 7px 11px;
  transition: border-color var(--transition);
}
.select-filter, select { cursor: pointer; padding-right: 28px; appearance: none;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%2364748b' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: right 8px center; background-size: 14px;
}
select:focus, input:focus, textarea:focus { outline: none; border-color: var(--accent); }
textarea { resize: vertical; min-height: 80px; line-height: 1.5; }
input[type="text"], input[type="number"], input[type="url"] { width: 100%; }

.form-row { display: flex; flex-direction: column; gap: 6px; margin-bottom: 18px; }
.form-row label { font-size: 12px; font-weight: 500; color: var(--text-2); }
.form-row .hint { font-size: 11px; color: var(--text-3); margin-top: 3px; }
.form-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 0 20px; }
.form-section { margin-bottom: 28px; }
.form-section-title {
  font-size: 11px; font-weight: 600; text-transform: uppercase;
  letter-spacing: .8px; color: var(--text-3);
  margin-bottom: 14px; padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}

/* ── Cards / Panels ─────────────────────────────── */
.card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
}
.card + .card { margin-top: 10px; }
.panel {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); overflow: hidden;
}

/* ── Blogpost grid ──────────────────────────────── */
.bp-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(280px, 1fr));
  gap: 14px;
}
.bp-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
  cursor: pointer; transition: all var(--transition);
  display: flex; flex-direction: column; gap: 10px;
}
.bp-card:hover { border-color: var(--accent); transform: translateY(-2px); box-shadow: 0 8px 24px #00000040; }
.bp-card-title { font-size: 14px; font-weight: 600; line-height: 1.4; color: var(--text); }
.bp-card-meta { font-size: 12px; color: var(--text-3); display: flex; gap: 10px; flex-wrap: wrap; align-items: center; }
.bp-card-meta span { display: flex; align-items: center; gap: 4px; }
.bp-card-excerpt { font-size: 12px; color: var(--text-2); line-height: 1.5; 
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.bp-card-tags { display: flex; flex-wrap: wrap; gap: 5px; }

/* ── Cover badge in card ────────────────────────── */
.bp-cover-badge {
  background: var(--bg-3);
  border: 1px solid var(--border);
  color: var(--text-2);
  padding: 2px 5px;
  font-size: 10px;
}

/* ── Cover mode cards ───────────────────────────── */
.bp-card-cover {
  padding: 0;
  overflow: hidden;
}
.bp-card-cover-img {
  width: 100%;
  aspect-ratio: 16/9;
  background-size: cover;
  background-position: center;
  background-color: var(--bg-3);
  position: relative;
}
.bp-card-cover-badges {
  position: absolute;
  top: 8px; left: 8px;
  display: flex; gap: 5px; flex-wrap: wrap;
  /* Ensure badges are readable over any image */
}
.bp-card-cover-badges .badge {
  backdrop-filter: blur(4px);
  background: #00000066 !important;
  color: #fff !important;
  border-color: transparent !important;
}
.bp-card-cover-body {
  padding: 12px 14px;
}
.bp-card-cover .bp-card-title {
  font-size: 13px;
}

/* ── Cover toggle button ────────────────────────── */
.lib-cover-toggle {
  border: 1px solid var(--border);
  gap: 5px;
}
.lib-cover-toggle.active {
  background: var(--accent-dim);
  color: var(--accent);
  border-color: var(--accent)44;
}

/* ── Status badges ──────────────────────────────── */
.badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 2px 8px; border-radius: 20px;
  font-size: 11px; font-weight: 500; white-space: nowrap;
  border: 1px solid transparent;
}
.badge-draft    { background: var(--bg-3); color: var(--text-2); border-color: var(--border); }
.badge-published{ background: color-mix(in srgb, var(--success) 12%, transparent); color: var(--success); border-color: color-mix(in srgb, var(--success) 20%, transparent); }
.badge-archived { background: color-mix(in srgb, var(--text-3) 12%, transparent); color: var(--text-3); border-color: color-mix(in srgb, var(--text-3) 20%, transparent); }
.badge-auto     { background: color-mix(in srgb, var(--warning) 12%, transparent); color: var(--warning); border-color: color-mix(in srgb, var(--warning) 20%, transparent); }
[data-theme="edge"] .badge-auto { background: #b8860b22; color: #d4a017; border-color: #d4a01733; }
.badge-manual   { background: var(--accent-dim); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 20%, transparent); }
.tag { background: var(--bg-3); color: var(--text-2); border: 1px solid var(--border); padding: 2px 7px; border-radius: 4px; font-size: 11px; }
.tag.cat-tag { background: var(--accent-dim); color: var(--accent); border-color: var(--accent)33; }

/* ── Wizard ─────────────────────────────────────── */
.wizard-header {
  display: flex; align-items: center; gap: 20px;
  margin-bottom: 32px;
}
.step-indicator {
  display: flex; align-items: center; gap: 0;
  flex: 1;
}
.step {
  display: flex; align-items: center; gap: 8px;
  font-size: 13px; font-weight: 500; color: var(--text-3);
}
.step.active { color: var(--accent); }
.step.done { color: var(--success); }
.step-num {
  width: 26px; height: 26px;
  border-radius: 50%; border: 2px solid currentColor;
  display: flex; align-items: center; justify-content: center;
  font-size: 12px; font-weight: 600; flex-shrink: 0;
  transition: all var(--transition);
}
.step.active .step-num { background: var(--accent); border-color: var(--accent); color: #fff; }
.step.done .step-num { background: var(--success); border-color: var(--success); color: #fff; }
.step-line { flex: 1; height: 1px; background: var(--border); margin: 0 10px; }

.step-panel { max-width: 100%; }
.step-title { font-size: 18px; font-weight: 700; margin-bottom: 6px; }
.step-desc { font-size: 13px; color: var(--text-2); margin-bottom: 28px; }
.step-actions { display: flex; justify-content: flex-end; gap: 10px; margin-top: 32px; padding-top: 20px; border-top: 1px solid var(--border); }

/* ── Presets layout ─────────────────────────────── */
.presets-layout { display: grid; grid-template-columns: clamp(240px, 22%, 340px) 1fr; gap: 20px; }
.presets-list { display: flex; flex-direction: column; gap: 8px; max-height: calc(100vh - 160px); overflow-y: auto; }
.preset-item {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 16px;
  cursor: pointer; transition: all var(--transition);
}
.preset-item:hover { border-color: var(--border-2); }
.preset-item.active { border-color: var(--accent); background: var(--accent-dim); }
.preset-item-name { font-size: 13px; font-weight: 600; }
.preset-item-desc { font-size: 12px; color: var(--text-2); margin-top: 3px; }
.preset-editor { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 24px 28px; overflow-y: auto; max-height: calc(100vh - 160px); }

/* ── Toggle / Switch ────────────────────────────── */
.toggle-row { display: flex; align-items: center; justify-content: space-between; padding: 10px 0; }
.toggle-row + .toggle-row { border-top: 1px solid var(--border); }
.toggle-label { font-size: 13px; font-weight: 500; }
.toggle-hint { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.switch { position: relative; width: 40px; height: 22px; flex-shrink: 0; }
.switch input { display: none; }
.switch-track {
  position: absolute; inset: 0;
  background: var(--bg-3); border: 1px solid var(--border-2);
  border-radius: 11px; cursor: pointer; transition: all var(--transition);
}
.switch-track::after {
  content: ''; position: absolute;
  width: 16px; height: 16px; border-radius: 50%;
  background: var(--text-3); top: 2px; left: 2px;
  transition: all var(--transition);
}
.switch input:checked + .switch-track { background: var(--accent); border-color: var(--accent); }
.switch input:checked + .switch-track::after { transform: translateX(18px); background: #fff; }

/* ── Tag input / pill list ──────────────────────── */
.pill-input-wrap { display: flex; flex-wrap: wrap; gap: 6px; padding: 7px; background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius-sm); min-height: 38px; cursor: text; }
.pill-input-wrap:focus-within { border-color: var(--accent); }
.pill-input-wrap input { border: none; background: transparent; color: var(--text); font-size: 13px; font-family: inherit; outline: none; min-width: 120px; flex: 1; }
/* Hint label naast pill-input labels: "— druk ↵ Enter om toe te voegen" — altijd zichtbaar zodat user niet vergeet Enter (ook als placeholder verdwenen is omdat veld content heeft) */
.pill-hint-label { font-size: 11px; color: var(--text-3); font-weight: 400; }
.pill { display: inline-flex; align-items: center; gap: 5px; background: var(--accent-dim); color: var(--accent); border: 1px solid var(--accent)33; border-radius: 4px; padding: 2px 8px; font-size: 12px; }
.pill button { background: none; border: none; cursor: pointer; color: currentColor; padding: 0; font-size: 14px; line-height: 1; opacity: .7; }
.pill button:hover { opacity: 1; }
.pill-source-badge { display: inline-block; font-size: 9px; font-weight: 700; letter-spacing: 0.4px; text-transform: uppercase; padding: 1px 4px; border-radius: 3px; opacity: .85; margin-right: 2px; }

/* ── Lengte controle waarschuwing — pulse animation als de tekst out of range is ── */
@keyframes len-check-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(239, 68, 68, 0.6); border-color: rgba(239, 68, 68, 0.8); }
  50%      { box-shadow: 0 0 0 6px rgba(239, 68, 68, 0); border-color: rgba(239, 68, 68, 1); }
}
.btn.len-check-out-of-range {
  animation: len-check-pulse 1.4s ease-in-out infinite;
  border: 1px solid rgba(239, 68, 68, 0.8);
  color: #fca5a5;
  background: rgba(239, 68, 68, 0.08);
}
.btn.len-check-out-of-range:hover {
  background: rgba(239, 68, 68, 0.18);
  color: #fecaca;
}
/* AI/algo pills — light mode standaard (donkere tekst voor contrast op witte bg) */
.pill.pill-ai   { background: rgba(59, 130, 246, 0.12); color: #1d4ed8; border-color: rgba(59, 130, 246, 0.35); }
.pill.pill-ai   .pill-source-badge { background: rgba(59, 130, 246, 0.22); color: #1e3a8a; }
.pill.pill-algo { background: rgba(34, 197, 94, 0.12); color: #15803d; border-color: rgba(34, 197, 94, 0.35); }
.pill.pill-algo .pill-source-badge { background: rgba(34, 197, 94, 0.22); color: #14532d; }
/* Dark mode — lichtere tekst tegen donkere bg */
[data-mode="dark"] .pill.pill-ai   { background: rgba(96, 165, 250, 0.15); color: #93c5fd; border-color: rgba(96, 165, 250, 0.35); }
[data-mode="dark"] .pill.pill-ai   .pill-source-badge { background: rgba(96, 165, 250, 0.25); color: #bfdbfe; }
[data-mode="dark"] .pill.pill-algo { background: rgba(34, 197, 94, 0.15); color: #86efac; border-color: rgba(34, 197, 94, 0.35); }
[data-mode="dark"] .pill.pill-algo .pill-source-badge { background: rgba(34, 197, 94, 0.25); color: #bbf7d0; }

/* ── Model selector ─────────────────────────────── */
.model-row {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); margin-bottom: 8px;
  background: var(--bg-2);
}
.model-row-info { flex: 1; }
.model-row-name { font-size: 13px; font-weight: 500; }
.model-row-provider { font-size: 11px; color: var(--text-3); }
.model-count { width: 60px; text-align: center; }
.model-remove { color: var(--text-3); cursor: pointer; background: none; border: none; font-size: 16px; padding: 2px 6px; transition: color var(--transition); }
.model-remove:hover { color: var(--danger); }

/* ── Schedules ──────────────────────────────────── */
.schedule-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
  margin-bottom: 10px; display: flex; align-items: center; gap: 16px;
}
.schedule-info { flex: 1; }
.schedule-name { font-size: 14px; font-weight: 600; }
.schedule-meta { font-size: 12px; color: var(--text-2); margin-top: 4px; }
.schedule-actions { display: flex; gap: 8px; }

/* ── Blogpost detail ────────────────────────────── */
.bp-detail { max-width: 800px; }
.bp-detail-header { margin-bottom: 24px; }
.bp-detail-title { font-size: 24px; font-weight: 700; line-height: 1.3; margin-bottom: 10px; }
.bp-detail-meta { display: flex; flex-wrap: wrap; gap: 10px; align-items: center; font-size: 12px; color: var(--text-2); }
.view-toggle {
  display: flex; background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 3px; gap: 3px; margin-bottom: 20px;
}
.view-toggle button {
  padding: 5px 14px; border-radius: 5px; font-size: 12px; font-weight: 500;
  background: none; border: none; color: var(--text-2); cursor: pointer;
  transition: all var(--transition);
}
.view-toggle button.active { background: var(--bg-2); color: var(--text); border: 1px solid var(--border); }
.bp-content-styled { line-height: 1.8; }
.bp-content-styled h1,.bp-content-styled h2,.bp-content-styled h3 { margin: 1.5em 0 .5em; font-weight: 700; }
.bp-content-styled p { margin: .8em 0; }
.bp-content-styled ul,.bp-content-styled ol { padding-left: 1.6em; margin: .8em 0; }
.bp-content-styled li { margin: .3em 0; }
.bp-content-raw { font-family: 'JetBrains Mono', monospace; font-size: 12px; line-height: 1.7; background: var(--bg-3); padding: 16px; border-radius: var(--radius); overflow-x: auto; white-space: pre-wrap; color: var(--text-2); }

/* ── Run results ─────────────────────────────────── */
.result-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); margin-bottom: 14px; overflow: hidden;
}
.result-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; border-bottom: 1px solid var(--border);
  cursor: pointer;
}
.result-card-body { padding: 18px 20px; }
.result-model { font-size: 11px; font-weight: 600; color: var(--accent); font-family: 'JetBrains Mono', monospace; }
.result-title { font-size: 14px; font-weight: 600; margin-top: 3px; }

/* ── Loading / spinner ──────────────────────────── */
.spinner { display: inline-block; width: 18px; height: 18px; border: 2px solid var(--border); border-top-color: var(--accent); border-radius: 50%; animation: spin .7s linear infinite; }
@keyframes spin { to { transform: rotate(360deg); } }
.loading-state { display: flex; flex-direction: column; align-items: center; justify-content: center; gap: 14px; padding: 60px 20px; color: var(--text-2); }
.loading-state .spinner { width: 32px; height: 32px; border-width: 3px; }

/* ── Progress / pipeline steps ──────────────────── */
.pipeline-progress { background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius); padding: 20px 24px; }
.pipeline-step { display: flex; align-items: center; gap: 12px; padding: 8px 0; }
.pipeline-step + .pipeline-step { border-top: 1px solid var(--border); }
.step-icon { width: 22px; height: 22px; border-radius: 50%; display: flex; align-items: center; justify-content: center; font-size: 11px; flex-shrink: 0; }
.step-icon.pending { background: var(--bg-3); color: var(--text-3); border: 1px solid var(--border); }
.step-icon.running { background: var(--accent-dim); color: var(--accent); }
.step-icon.done    { background: var(--success)22; color: var(--success); }
.step-icon.error   { background: var(--danger)22;  color: var(--danger); }
.step-name { font-size: 13px; font-weight: 500; flex: 1; }
.step-time { font-size: 11px; color: var(--text-3); font-family: 'JetBrains Mono', monospace; }

/* ── Empty state ─────────────────────────────────── */
.empty-state { text-align: center; padding: 60px 20px; color: var(--text-2); }
.empty-icon { font-size: 40px; margin-bottom: 14px; }
.empty-state h3 { font-size: 16px; font-weight: 600; color: var(--text); margin-bottom: 6px; }
.empty-state p { font-size: 13px; color: var(--text-2); margin-bottom: 20px; }

/* ── Toast ───────────────────────────────────────── */
#toast-container { position: fixed; bottom: 24px; right: 24px; display: flex; flex-direction: column; gap: 8px; z-index: 9999; }
.toast {
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 12px 16px;
  font-size: 13px; color: var(--text);
  box-shadow: 0 8px 24px #00000050;
  animation: slideIn .25s ease; max-width: 320px;
}
.toast.success { border-left: 3px solid var(--success); }
.toast.error   { border-left: 3px solid var(--danger); }
.toast.info    { border-left: 3px solid var(--accent); }
.toast.warning { border-left: 3px solid #f59e0b; }
@keyframes slideIn { from{opacity:0;transform:translateX(20px)} to{opacity:1;transform:translateX(0)} }

/* ── Modal ───────────────────────────────────────── */
.modal-overlay { position: fixed; inset: 0; background: #00000070; backdrop-filter: blur(2px); z-index: 200; }
.modal {
  position: fixed; top: 50%; left: 50%; transform: translate(-50%,-50%);
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); z-index: 201; width: 90%; max-width: 560px;
  max-height: 85vh; overflow-y: auto;
  box-shadow: 0 20px 60px #00000060;
}
.modal-header { display: flex; align-items: center; justify-content: space-between; padding: 18px 22px; border-bottom: 1px solid var(--border); }
.modal-header h3 { font-size: 15px; font-weight: 600; }
.modal-close { background: none; border: none; cursor: pointer; color: var(--text-2); font-size: 18px; padding: 2px 6px; border-radius: 4px; }
.modal-close:hover { background: var(--bg-3); color: var(--text); }
#modal-body { padding: 22px; }
.hidden { display: none !important; }

/* ── Inline collapsible section ──────────────────── */
.collapsible-header {
  display: flex; align-items: center; justify-content: space-between;
  cursor: pointer; user-select: none;
  padding: 10px 14px;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: var(--radius-sm);
  transition: all var(--transition);
  margin-bottom: 2px;
}
.collapsible-header:hover { background: color-mix(in srgb, var(--accent) 8%, var(--bg-3)); border-color: color-mix(in srgb, var(--accent) 25%, var(--border)); }
.collapsible-header.open { border-radius: var(--radius-sm) var(--radius-sm) 0 0; margin-bottom: 0; border-bottom-color: transparent; }
.collapsible-header h4 { font-size: 13px; font-weight: 600; }
.collapsible-arrow {
  transition: transform var(--transition);
  color: var(--text-3); font-size: 10px;
  width: 20px; height: 20px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  background: var(--bg-2);
  border: 1px solid var(--border);
  flex-shrink: 0;
}
.collapsible-header.open .collapsible-arrow { transform: rotate(180deg); background: var(--accent-dim); color: var(--accent); border-color: color-mix(in srgb, var(--accent) 30%, transparent); }
.collapsible-body { display: none; }
.collapsible-body.open { display: block; padding: 14px; border: 1px solid var(--border); border-top: none; border-radius: 0 0 var(--radius-sm) var(--radius-sm); background: color-mix(in srgb, var(--bg-3) 30%, var(--bg)); }

/* Nested/inline collapsibles stay minimal */
.collapsible-header[style*="padding:0"],
.collapsible-header[style*="padding:4px"],
.collapsible-header[style*="padding:8px"] {
  background: none !important; border: none !important; border-radius: 0 !important; margin-bottom: 0 !important;
}
.collapsible-header[style*="padding:0"] + .collapsible-body.open,
.collapsible-header[style*="padding:4px"] + .collapsible-body.open,
.collapsible-header[style*="padding:8px"] + .collapsible-body.open {
  border: none; background: none; padding: 8px 0 0 0;
}

/* ── Preset selection grid (run wizard step 1) ───── */
.preset-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(240px, 1fr));
  gap: 12px;
  margin-bottom: 28px;
}
.preset-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 18px 20px;
  cursor: pointer; transition: all var(--transition);
}
.preset-card:hover { border-color: var(--border-2); transform: translateY(-1px); }
.preset-card.selected { border-color: var(--accent); background: var(--accent-dim); }
.preset-card-name { font-size: 14px; font-weight: 600; margin-bottom: 4px; }
.preset-card-desc { font-size: 12px; color: var(--text-2); margin-bottom: 10px; line-height: 1.4;
  display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.preset-card-meta { display: flex; flex-wrap: wrap; gap: 6px; }
.preset-card-meta span {
  font-size: 11px; color: var(--text-3); background: var(--bg-3);
  border: 1px solid var(--border); border-radius: 4px; padding: 2px 7px;
}
.preset-card.selected .preset-card-meta span { background: var(--accent-dim); color: var(--accent); border-color: var(--accent)33; }

/* ── Spinner inline (for run status) ────────────── */
.spinner-inline {
  display: inline-block; width: 14px; height: 14px;
  border: 2px solid var(--border-2); border-top-color: var(--accent);
  border-radius: 50%; animation: spin .7s linear infinite; vertical-align: middle;
}

/* ── Review panel ────────────────────────────────── */
.review-panel {
  border: 1px solid var(--warning) !important;
  background: var(--bg-3);
  padding: 20px;
  border-radius: var(--radius);
}

/* ── Lang status rows ────────────────────────────── */
.lang-status-row {
  transition: border-color var(--transition);
}

/* ── Result card ─────────────────────────────────── */
.result-card {
  background: var(--surface, var(--bg-3));
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: 16px;
  overflow: hidden;
}
.result-card-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 18px; cursor: pointer;
  border-bottom: 1px solid var(--border);
}
.result-card-header:hover { background: var(--bg-2); }
.result-model { font-size: 11px; color: var(--text-3); margin-bottom: 4px; font-family: var(--font-mono); }
.result-title { font-size: 14px; font-weight: 600; }
.result-card-body { padding: 18px; }
.result-card-body.open { display: block; }

/* ── Runs Tab Badge ──────────────────────────────── */
.runs-tab-badge {
  display: inline-flex; align-items: center; justify-content: center;
  min-width: 18px; height: 18px; padding: 0 5px;
  background: var(--accent); color: #fff;
  font-size: 10px; font-weight: 700; border-radius: 9px;
  margin-left: auto; line-height: 1; pointer-events: none;
}
.runs-tab-badge.has-review {
  background: var(--warning); color: #000;
  animation: pulse-badge 1.5s ease-in-out infinite;
}
@keyframes pulse-badge {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.8; transform: scale(1.15); }
}

/* ── Active run cards ────────────────────────────── */
.active-run-card {
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 14px 18px;
  margin-bottom: 12px; transition: border-color var(--transition);
}
.active-run-card.needs-review { border-color: var(--warning); }
.active-run-header {
  display: flex; align-items: center; justify-content: space-between;
}
.active-run-meta { display: flex; align-items: center; gap: 8px; }
.active-run-lang {
  font-size: 13px; font-weight: 700;
  background: var(--bg-3); border: 1px solid var(--border-2);
  border-radius: 4px; padding: 2px 8px;
}
.active-run-preset { font-size: 12px; color: var(--text-2); }
.active-run-id     { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); }
.active-run-elapsed { font-size: 11px; color: var(--text-3); font-family: var(--font-mono); }
.run-error-note    { font-size: 12px; color: var(--danger); margin-top: 8px; padding: 8px 10px; background: rgba(239,68,68,0.06); border: 1px solid rgba(239,68,68,0.2); border-radius: 6px; line-height: 1.5; word-break: break-word; overflow-wrap: break-word; }
.runs-empty-active { font-size: 13px; color: var(--text-3); padding: 8px 0; }

/* ── Run status chips ────────────────────────────── */
.run-status-chip {
  display: inline-flex; align-items: center; gap: 5px;
  font-size: 11px; font-weight: 600; border-radius: 4px;
  padding: 3px 8px;
}
.run-status-chip.running  { background: var(--accent-dim);  color: var(--accent); }
.run-status-chip.review   { background: #f59e0b22; color: var(--warning); border: 1px solid var(--warning); }
.run-status-chip.done     { background: #22c55e22; color: var(--success); }
.run-status-chip.failed   { background: #ef444422; color: var(--danger); }
.run-status-chip.pending  { background: var(--bg-3); color: var(--text-3); }

/* ── Inline review panel (in Runs tab) ───────────── */
.inline-review-panel {
  margin-top: 14px; padding-top: 14px;
  border-top: 1px solid var(--border);
}
.review-panel-title {
  font-size: 13px; font-weight: 600; margin-bottom: 12px;
  color: var(--warning);
}
.kw-post-row {
  background: var(--bg-3); border: 1px solid var(--border);
  border-radius: 8px; padding: 12px; margin-bottom: 10px;
}
.kw-post-title { font-size: 13px; font-weight: 600; margin-bottom: 8px; }

/* ── Manual content paste (failed scrapes) ───────── */
.rv-manual-textarea { transition: border-color 0.2s; }
.rv-manual-textarea:focus { border-color: var(--accent); outline: none; }
.rv-manual-toggle:hover { background: rgba(79, 124, 255, 0.08) !important; }

/* ── Instellingen pagina ─────────────────────────── */
/* Settings menu */
.sett-menu { display: flex; flex-direction: column; gap: 2px; }
.sett-menu-item {
  display: flex; align-items: center; gap: 12px; padding: 12px 14px;
  border-radius: var(--radius); cursor: pointer; transition: background .15s;
  background: var(--bg-2); border: 1px solid var(--border);
}
.sett-menu-item:hover { background: var(--bg-3); }
.sett-menu-icon { font-size: 20px; width: 28px; text-align: center; flex-shrink: 0; }
.sett-menu-text { flex: 1; min-width: 0; }
.sett-menu-label { font-size: 13px; font-weight: 600; color: var(--text); }
.sett-menu-desc { font-size: 11px; color: var(--text-3); margin-top: 1px; }
.sett-menu-status { font-size: 11px; color: var(--text-2); white-space: nowrap; }
.sett-menu-arrow { width: 16px; height: 16px; color: var(--text-3); flex-shrink: 0; }
/* Settings sub-page */
.sett-back-btn {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--text-3); background: none; border: none;
  cursor: pointer; padding: 0; margin-bottom: 4px; transition: color .15s;
}
.sett-back-btn:hover { color: var(--accent); }
.sett-page-title { font-size: 18px; font-weight: 700; color: var(--text); margin-bottom: 16px; }
/* Settings shared */
.settings-section { margin-bottom: 32px; }
.settings-section-title { font-size: 16px; font-weight: 700; margin-bottom: 12px; color: var(--text); transition: color .15s; }
.settings-group {
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius);
  overflow: hidden; margin-bottom: 10px;
}
.settings-group-header {
  display: flex; align-items: center; gap: 8px;
  padding: 10px 14px; font-size: 13px; font-weight: 600; color: var(--text);
}
.sett-provider-links { display: flex; gap: 6px; margin-left: auto; }
.sett-provider-link {
  font-size: 10px; color: var(--text-3); text-decoration: none;
  padding: 2px 6px; border: 1px solid var(--border); border-radius: 4px;
  transition: all .15s; white-space: nowrap;
}
.sett-provider-link:hover { color: var(--accent); border-color: var(--accent); background: var(--accent-dim); }
.settings-group-name { flex: 1; }
.sett-dot { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.sett-dot-ok { background: var(--success); }
.sett-dot-none { background: var(--text-3); opacity: .4; }
.sett-dot-partial { background: #f59e0b; }
.settings-key-row {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  padding: 8px 14px; min-height: 40px;
}
.settings-key-label { font-size: 12px; color: var(--text-2); white-space: nowrap; }
.settings-key-actions { display: flex; align-items: center; gap: 8px; }
.settings-key-value {
  font-size: 12px; font-family: var(--font-mono); color: var(--text);
  max-width: 220px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap;
}
.settings-key-empty { color: var(--text-3); font-style: italic; font-family: var(--font); }
.settings-input {
  font-size: 12px; padding: 6px 10px; border: 1px solid var(--border);
  border-radius: var(--radius-sm); background: var(--bg); color: var(--text);
  font-family: var(--font-mono); transition: border-color 0.2s; width: 100%;
}
.settings-input:focus { border-color: var(--accent); outline: none; }

/* WordPress site cards */
.wp-site-card {
  background: var(--bg-2); border: 1px solid var(--border); border-radius: var(--radius);
  padding: 12px 16px; margin-bottom: 8px;
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
}
.wp-site-card-editing { flex-direction: column; align-items: stretch; }
.wp-site-name { font-size: 13px; font-weight: 600; color: var(--text); }
.wp-site-url { font-size: 11px; font-family: var(--font-mono); color: var(--accent); margin-top: 2px; }
.wp-site-meta { font-size: 11px; color: var(--text-3); margin-top: 4px; }
.wp-site-actions { display: flex; gap: 4px; flex-shrink: 0; }
.wp-site-form { display: flex; flex-direction: column; gap: 8px; }
.form-row-inline { display: flex; align-items: center; gap: 8px; }
.form-row-inline label { font-size: 12px; color: var(--text-2); width: 100px; flex-shrink: 0; }
.form-row-inline .settings-input { flex: 1; }

/* ── URL preview list ────────────────────────────── */
.url-preview-list {
  display: flex; flex-direction: column; gap: 3px;
  margin-bottom: 6px; max-height: 120px; overflow-y: auto;
}
.url-preview-empty { color: var(--text-3); font-size: 11px; padding: 4px 0; }
.url-preview-link {
  font-size: 11px; color: var(--accent); font-family: var(--font-mono);
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
  display: block; text-decoration: none;
}
.url-preview-link:hover { text-decoration: underline; }

/* ── Notifications ───────────────────────────────── */
.notif-header {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 8px;
}
.notif-item {
  display: flex; align-items: flex-start; gap: 10px;
  background: #f59e0b11; border: 1px solid #f59e0b44;
  border-radius: 8px; padding: 10px 12px; margin-bottom: 8px;
}
.notif-dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--warning); margin-top: 3px; flex-shrink: 0;
}
.notif-body { flex: 1; min-width: 0; }
.notif-msg  { font-size: 13px; font-weight: 500; }
.notif-time { font-size: 11px; color: var(--text-3); margin-top: 2px; }
.notif-dismiss {
  background: none; border: none; color: var(--text-3);
  cursor: pointer; font-size: 14px; padding: 0 2px; flex-shrink: 0;
}
.notif-dismiss:hover { color: var(--text); }

/* ── Recent runs list ────────────────────────────── */
.recent-run-row {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 14px; background: var(--bg-2);
  border: 1px solid var(--border); border-radius: 8px;
  margin-bottom: 8px; cursor: pointer;
  transition: border-color var(--transition);
}
.recent-run-row:hover { border-color: var(--border-2); }

/* ── Section title ───────────────────────────────── */
.section-title {
  font-size: 12px; font-weight: 600; color: var(--text-3);
  text-transform: uppercase; letter-spacing: 0.08em;
  margin-bottom: 12px;
}

/* ── btn-warning ─────────────────────────────────── */
.btn-warning {
  background: var(--warning); color: #000; font-weight: 600;
}
.btn-warning:hover { background: #fbbf24; }

/* ── Responsive ──────────────────────────────────── */
@media (max-width: 900px) {
  :root { --sidebar-w: 60px; }
  .logo-text, .nav-item span, .sidebar-footer .status-text { display: none; }
  .nav-item { justify-content: center; padding: 10px; }
  .sidebar-logo { justify-content: center; padding: 0 0 18px; }
  .main { padding: 20px 16px; }
  .presets-layout { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .bp-grid { grid-template-columns: 1fr; }
}

/* ── Cover image grid ─────────────────────────────────────────────────────── */

.cover-img-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 10px;
  margin-top: 8px;
}

.lib-cover-grid {
  grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

.cover-img-thumb {
  position: relative;
  border-radius: 8px;
  overflow: hidden;
  cursor: pointer;
  border: 2px solid var(--border);
  transition: border-color var(--transition), transform var(--transition);
  aspect-ratio: 16/9;
  background: var(--bg-3);
}

.cover-img-thumb:hover {
  border-color: var(--accent);
  transform: scale(1.02);
}

.cover-img-thumb.selected {
  border-color: var(--success);
  box-shadow: 0 0 0 2px var(--success);
}

.cover-img-thumb img {
  width: 100%;
  height: 100%;
  object-fit: cover;
  display: block;
}

.cover-img-check {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 22px;
  height: 22px;
  border-radius: 50%;
  background: var(--success);
  color: white;
  font-size: 12px;
  display: flex;
  align-items: center;
  justify-content: center;
  opacity: 0;
  transition: opacity var(--transition);
}

.cover-img-thumb.selected .cover-img-check {
  opacity: 1;
}

.cover-img-thumb.generating {
  cursor: default;
  border-color: var(--border);
  animation: pulse-border 1.4s ease-in-out infinite;
}

/* Edit/zoom knoppen op thumbnails — alleen zichtbaar bij hover */
.cover-img-thumb .cover-img-zoom,
.cover-img-thumb .cover-img-edit {
  opacity: 0;
  transition: opacity var(--transition), transform var(--transition);
}
.cover-img-thumb:hover .cover-img-zoom,
.cover-img-thumb:hover .cover-img-edit {
  opacity: 1;
}
.cover-img-thumb .cover-img-edit:hover,
.cover-img-thumb .cover-img-zoom:hover {
  transform: scale(1.1);
  background: rgba(0,0,0,0.75) !important;
}

/* ── "Toevoegen" knop hint pulse ───────────────────────────────────────────── */
@keyframes btn-hint-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(var(--primary-rgb, 59,130,246), 0.5); }
  50%      { box-shadow: 0 0 8px 3px rgba(var(--primary-rgb, 59,130,246), 0.35); }
}
.btn-add-hint {
  animation: btn-hint-pulse 1.5s ease-in-out infinite;
  border-color: var(--primary) !important;
  color: var(--primary) !important;
}

/* ── Inline image drag & drop ──────────────────────────────────────────────── */
.il-preview-img-block {
  cursor: grab;
  transition: opacity .15s, box-shadow .15s;
}
.il-preview-img-block:active { cursor: grabbing; }
.il-preview-img-block.il-dragging {
  opacity: 0.35;
  box-shadow: none;
}
.il-drop-zone {
  height: 0;
  margin: 0;
  border-radius: 4px;
  transition: height .15s ease, background .15s ease, margin .15s ease, padding .15s ease;
  pointer-events: all;
}
.il-drop-zone.il-drag-over {
  height: 8px;
  margin: 8px 0;
  background: var(--primary);
  box-shadow: 0 0 8px rgba(var(--primary-rgb, 59,130,246), 0.4);
}
.il-drag-handle {
  display: inline-flex;
  align-items: center;
  cursor: grab;
  font-size: 14px;
  color: var(--text-3);
  padding: 0 4px;
  user-select: none;
  letter-spacing: 1px;
}
.il-drag-handle:active { cursor: grabbing; }

/* ── Internal linking preview ──────────────────────────────────────────────── */
.il-content-preview a[href] {
  color: var(--accent, #3b82f6);
  text-decoration: underline;
  background: rgba(59,130,246,.08);
  border-radius: 2px;
  padding: 1px 3px;
  position: relative;
  cursor: default;
}
.il-content-preview a[href]:hover {
  background: rgba(59,130,246,.2);
}
.il-content-preview .il-remove-btn {
  position: absolute;
  top: -10px;
  right: -10px;
  background: var(--danger, #ef4444);
  color: #fff;
  border: none;
  border-radius: 50%;
  width: 18px;
  height: 18px;
  font-size: 11px;
  line-height: 18px;
  text-align: center;
  cursor: pointer;
  display: none;
  z-index: 5;
  padding: 0;
}
.il-content-preview a[href]:hover .il-remove-btn {
  display: block;
}

.cover-img-thumb.generating:hover {
  transform: none;
  border-color: var(--border);
}

.cover-img-generating-label {
  position: absolute;
  inset: 0;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  font-size: 12px;
  color: var(--text-2);
  background: var(--bg-3);
}

@keyframes pulse-border {
  0%, 100% { border-color: var(--border); }
  50%       { border-color: var(--accent); }
}

/* ── Cover post section in review panel ─────────────────────────────────── */
.cover-post-section {
  padding: 14px 0;
  border-bottom: 1px solid var(--border);
}

.cover-post-section:last-of-type {
  border-bottom: none;
}

/* ── Tool config rows in preset editor ──────────────────────────────────── */
.tool-config-row {
  background: var(--bg-3);
  transition: border-color var(--transition);
}

.tool-config-row:hover {
  border-color: var(--border-2) !important;
}

/* ── Tiptap rich text editor ─────────────────────────────────────────────── */
.tiptap-toolbar {
  display: flex;
  gap: 4px;
  padding: 6px 8px;
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-bottom: none;
  border-radius: 6px 6px 0 0;
  flex-wrap: wrap;
}

.tiptap-toolbar button {
  background: var(--surface-2);
  border: 1px solid var(--border);
  color: var(--text-2);
  border-radius: 4px;
  padding: 3px 8px;
  font-size: 12px;
  cursor: pointer;
  transition: background var(--transition), color var(--transition);
  min-width: 28px;
}

.tiptap-toolbar button:hover {
  background: var(--accent-dim);
  color: var(--accent);
  border-color: var(--accent);
}

.tiptap-editor {
  background: var(--bg-3);
  border: 1px solid var(--border);
  border-radius: 0 0 6px 6px;
  padding: 12px 14px;
  min-height: 300px;
  max-height: 600px;
  overflow-y: auto;
  font-size: 14px;
  line-height: 1.7;
  color: var(--text);
  cursor: text;
}

.tiptap-editor .tiptap {
  outline: none;
  min-height: 280px;
}

.tiptap-editor .tiptap h2 { font-size: 1.3em; font-weight: 700; margin: 1em 0 .4em; }
.tiptap-editor .tiptap h3 { font-size: 1.1em; font-weight: 600; margin: .8em 0 .3em; }
.tiptap-editor .tiptap p  { margin-bottom: .5em; }
.tiptap-editor .tiptap ul,
.tiptap-editor .tiptap ol { margin: .4em 0 .4em 1.4em; }
.tiptap-editor .tiptap strong { font-weight: 700; }
.tiptap-editor .tiptap em    { font-style: italic; }

.text-edit-panel { max-width: 100%; }

/* ═══════════════════════════════════════════════════════════════
   RESPONSIVE — Full mobile/tablet/desktop system
   Breakpoints:
     xs:  < 480px   (small phones)
     sm:  < 640px   (phones)
     md:  < 900px   (tablets, small laptops)
     lg:  < 1200px  (laptops)
     xl:  ≥ 1200px  (desktops)
═══════════════════════════════════════════════════════════════ */

/* ── Mobile top bar (hidden on desktop) ─────────── */
.mobile-topbar {
  display: none;
  position: fixed; top: 0; left: 0; right: 0;
  height: 52px; z-index: 150;
  background: var(--bg-2);
  border-bottom: 1px solid var(--border);
  align-items: center;
  padding: 0 14px;
  gap: 12px;
}
.mobile-logo {
  flex: 1;
  font-size: 14px; font-weight: 700; color: var(--text);
}
.hamburger {
  display: flex; flex-direction: column; justify-content: center; gap: 5px;
  width: 36px; height: 36px; padding: 6px;
  background: none; border: none; cursor: pointer; border-radius: 6px;
}
.hamburger span {
  display: block; width: 20px; height: 2px;
  background: var(--text-2); border-radius: 2px;
  transition: all var(--transition);
}
.hamburger.open span:nth-child(1) { transform: translateY(7px) rotate(45deg); }
.hamburger.open span:nth-child(2) { opacity: 0; }
.hamburger.open span:nth-child(3) { transform: translateY(-7px) rotate(-45deg); }

.mobile-nav-overlay {
  display: none; position: fixed; inset: 0;
  background: #00000060; z-index: 149;
}
.mobile-nav-overlay.open { display: block; }

/* ── Medium screens: icon-only sidebar ──────────── */
@media (max-width: 900px) {
  :root { --sidebar-w: 60px; }

  .logo-text, .nav-item span, .sidebar-footer .status-text,
  .profile-name, .profile-sub { display: none; }

  .nav-item { justify-content: center; padding: 11px; }
  .nav-item svg { width: 18px; height: 18px; }
  .sidebar-logo { justify-content: center; padding: 0 0 18px; }
  .sidebar-footer { padding: 10px 6px; }
  .profile-btn { justify-content: center; padding: 8px; }
  .profile-avatar { width: 32px; height: 32px; font-size: 13px; }

  .main { padding: 24px 20px; }
  .presets-layout { grid-template-columns: 1fr; }
  .form-grid { grid-template-columns: 1fr; }
  .bp-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
  .schedule-card { flex-wrap: wrap; }
  .schedule-actions { flex-wrap: wrap; }
}

/* ── Small screens: full mobile layout ─────────── */
@media (max-width: 640px) {
  /* Show mobile topbar, hide sidebar by default */
  .mobile-topbar { display: flex; }

  .sidebar {
    position: fixed;
    width: 260px !important;
    top: 0; left: -260px; bottom: 0;
    z-index: 160;
    transition: left var(--transition);
    padding-top: 60px; /* below topbar */
    overflow-y: auto;
  }
  .sidebar.mobile-open { left: 0; }

  /* Show labels again in mobile nav */
  .logo-text, .nav-item span,
  .sidebar-footer .status-text,
  .profile-name, .profile-sub { display: block; }
  .nav-item { justify-content: flex-start; padding: 11px 14px; }
  .nav-item svg { width: 16px; height: 16px; }
  .sidebar-logo { justify-content: flex-start; padding: 0 18px 18px; }
  .profile-btn { justify-content: flex-start; padding: 8px 10px; }

  /* Main: full width, below topbar */
  .main {
    margin-left: 0 !important;
    padding: 72px 14px 24px;
    max-width: 100%;
  }

  /* View headers */
  .view-header {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    margin-bottom: 18px;
  }
  .view-header .btn { width: 100%; justify-content: center; }
  .view-title { font-size: 18px; }

  /* Filter bar */
  .filter-bar { flex-direction: column; align-items: stretch; }
  .search-wrap { min-width: unset; }
  .filters { flex-direction: column; }
  .filters select { width: 100%; }

  /* BP Grid */
  .bp-grid { grid-template-columns: 1fr; gap: 10px; }
  .bp-card { padding: 14px 16px; }

  /* Preset layout */
  .presets-layout { grid-template-columns: 1fr; gap: 14px; }
  .presets-list { max-height: 260px; }
  .preset-editor { padding: 16px 14px; max-height: none; }

  /* Wizard */
  .wizard-header { margin-bottom: 20px; }
  .step { font-size: 11px; gap: 5px; }
  .step-num { width: 22px; height: 22px; font-size: 10px; }
  .step-line { margin: 0 6px; }
  .step-panel { max-width: 100%; }
  .step-title { font-size: 16px; }
  .step-actions { flex-direction: column; }
  .step-actions .btn { width: 100%; justify-content: center; }

  /* Preset grid */
  .preset-grid { grid-template-columns: 1fr; gap: 10px; }

  /* Forms */
  .form-grid { grid-template-columns: 1fr; }
  .form-section { margin-bottom: 20px; }

  /* Buttons in forms */
  .form-row .btn { width: 100%; justify-content: center; }

  /* Modal */
  .modal {
    width: 100% !important;
    max-width: 100% !important;
    max-height: 92vh;
    top: auto; bottom: 0;
    left: 0; right: 0;
    transform: none;
    border-radius: var(--radius) var(--radius) 0 0;
  }
  #modal-body { padding: 16px; }
  .modal-header { padding: 14px 16px; }

  /* Schedule cards */
  .schedule-card {
    flex-direction: column;
    align-items: flex-start;
    gap: 10px;
    padding: 14px 16px;
  }
  .schedule-actions { flex-wrap: wrap; gap: 6px; width: 100%; }
  .schedule-actions .btn { flex: 1; justify-content: center; min-width: 60px; }

  /* Active run cards */
  .active-run-header { flex-wrap: wrap; gap: 8px; }
  .active-run-meta { flex-wrap: wrap; }

  /* Cover image grid */
  .cover-img-grid { grid-template-columns: repeat(2, 1fr); }
  .lib-cover-grid { grid-template-columns: repeat(2, 1fr); }

  /* BP detail */
  .bp-detail { max-width: 100%; }
  .bp-detail-title { font-size: 20px; }

  /* Collapsible cron builder grids */
  .cron-builder > div[style*="grid"] { display: flex !important; flex-direction: column !important; }

  /* Model rows */
  .model-row { flex-wrap: wrap; gap: 8px; }

  /* Toast */
  #toast-container { bottom: 16px; right: 12px; left: 12px; }
  .toast { max-width: 100%; }

  /* Settings popover */
  .settings-popover {
    left: 10px; right: 10px; width: auto;
    bottom: 60px;
  }

  /* Tiptap editor */
  .tiptap-editor { min-height: 200px; max-height: 400px; }
  .tiptap-toolbar { padding: 4px 6px; gap: 3px; }
  .tiptap-toolbar button { padding: 3px 6px; font-size: 11px; }

  /* Run wizard step 2 collapsibles */
  .collapsible-header h4 { font-size: 12px; }

  /* Trusted sources rows */
  #pe-trusted-sources-list > div > div,
  #pe-trusted-yt-list > div > div {
    flex-direction: column !important;
  }

  /* Review inline panel */
  .inline-review-panel { padding-top: 10px; margin-top: 10px; }

  /* Kw review post row */
  .kw-post-row { padding: 10px; }
}

/* ── Extra small phones ──────────────────────────── */
@media (max-width: 380px) {
  .main { padding: 68px 10px 20px; }
  .view-title { font-size: 16px; }
  .btn { font-size: 12px; padding: 7px 12px; }
  .btn-sm { font-size: 11px; padding: 4px 8px; }
  .bp-card { padding: 12px 14px; }
  .cover-img-grid { grid-template-columns: 1fr; }
  .lib-cover-grid { grid-template-columns: 1fr; }
  .step-title { font-size: 14px; }
}

/* ── Tablet (641–900px): 2-col where useful ──────── */
@media (min-width: 641px) and (max-width: 900px) {
  .main { padding: 28px 22px; }
  .bp-grid { grid-template-columns: repeat(2, 1fr); }
  .preset-grid { grid-template-columns: repeat(2, 1fr); }
  .presets-layout { grid-template-columns: 1fr; }
  .step-panel { max-width: 100%; }
  .view-header { flex-wrap: wrap; }
}

/* ── Large desktop (1400px+) ─────────────────────── */
@media (min-width: 1400px) {
  .main { padding: 36px 48px; }
  .bp-grid { grid-template-columns: repeat(auto-fill, minmax(300px, 1fr)); }
  .preset-grid { grid-template-columns: repeat(auto-fill, minmax(260px, 1fr)); }
}

/* ── Extra large (1800px+) ───────────────────────── */
@media (min-width: 1800px) {
  .main { padding: 40px 56px; }
  .bp-grid { grid-template-columns: repeat(auto-fill, minmax(280px, 1fr)); }
  .presets-layout { grid-template-columns: 320px 1fr; }
}

/* ── Touch: bigger hit targets ────────────────────── */
@media (hover: none) and (pointer: coarse) {
  .nav-item     { min-height: 44px; }
  .btn          { min-height: 42px; }
  .btn-sm       { min-height: 36px; }
  .preset-card  { padding: 20px; }
  .bp-card      { padding: 18px; }
  .cover-img-thumb { border-width: 3px; }
  select, input[type="text"], input[type="number"], input[type="url"] {
    min-height: 42px; font-size: 16px; /* prevent iOS zoom */
  }
  textarea { font-size: 16px; }
  .search-input { min-height: 42px; font-size: 16px; }
}

/* ── Library Picker Modal ──────────────────────── */
.lib-picker-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,.6);
  z-index: 9999; display: flex; align-items: center; justify-content: center;
}
.lib-picker-modal {
  background: #fff; border-radius: 12px;
  width: 90vw; max-width: 900px; max-height: 85vh;
  display: flex; flex-direction: column;
  box-shadow: 0 20px 60px rgba(0,0,0,.3);
}
[data-theme="dark"] .lib-picker-modal { background: var(--bg-1); }
.lib-picker-grid {
  display: grid; grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
  grid-auto-rows: min-content;
  gap: 8px; overflow-y: auto; padding: 12px; flex: 1;
  min-height: 200px;
}
.lib-picker-item {
  cursor: pointer; border-radius: 6px; overflow: hidden;
  border: 2px solid transparent; transition: border-color .15s;
  background: var(--bg-3); position: relative; flex-shrink: 0;
}
.lib-picker-item:hover { border-color: var(--primary); }
.lib-picker-item img {
  width: 100%; aspect-ratio: 16/9; object-fit: cover; display: block;
}
.lib-picker-item-info {
  padding: 4px 6px; font-size: 10px; color: var(--text-3);
}
/* ── Blogpost preview in cover tool ─────────────── */
.blogpost-preview-content h1, .blogpost-preview-content h2, .blogpost-preview-content h3,
.blogpost-preview-content h4, .blogpost-preview-content h5 {
  font-size: 13px; font-weight: 600; margin: 10px 0 4px; color: var(--text-1);
}
.blogpost-preview-content h1 { font-size: 15px; }
.blogpost-preview-content h2 { font-size: 14px; }
.blogpost-preview-content p { margin: 4px 0; }
.blogpost-preview-content ul, .blogpost-preview-content ol { margin: 4px 0; padding-left: 20px; }
.blogpost-preview-content li { margin: 2px 0; }
.blogpost-preview-content strong { font-weight: 600; color: var(--text-1); }
.blogpost-preview-content a { color: var(--primary); }
.blogpost-preview-content img { max-width: 100%; border-radius: 4px; margin: 6px 0; }

.lib-picker-item .lib-picker-zoom {
  position: absolute; top: 4px; right: 4px;
  background: rgba(0,0,0,.55); border: none; border-radius: 4px;
  cursor: pointer; color: #fff; font-size: 13px; padding: 2px 5px;
  line-height: 1; z-index: 2; opacity: 0; transition: opacity .15s;
}
.lib-picker-item:hover .lib-picker-zoom { opacity: 1; }

/* ── Pillar tree (preset editor) ────────────── */
.pillar-node {
  background: var(--bg-3); border: 1px solid var(--border); border-radius: 8px;
  padding: 10px 12px; margin-bottom: 6px;
}
.pillar-node .pillar-header {
  display: flex; align-items: center; gap: 8px;
}
.pillar-node .pillar-name {
  flex: 1; background: transparent; border: 1px solid var(--border); border-radius: 4px;
  padding: 5px 8px; color: var(--text-1); font-size: 13px; font-family: inherit;
}
.pillar-node .pillar-name:focus { border-color: var(--accent); outline: none; }
.pillar-node .pillar-delete {
  background: none; border: none; color: var(--text-3); cursor: pointer;
  font-size: 16px; padding: 2px 6px; opacity: .6; line-height: 1;
}
.pillar-node .pillar-delete:hover { color: var(--danger); opacity: 1; }
.pillar-node .pillar-context {
  margin-top: 6px;
}
.pillar-node .pillar-context textarea {
  width: 100%; font-size: 12px; resize: vertical; min-height: 36px;
}
.pillar-children {
  margin-left: 16px; margin-top: 8px; padding-left: 12px;
  border-left: 2px solid var(--border);
}
.pillar-add-btn {
  font-size: 11px; margin-top: 4px; padding: 3px 8px;
  background: none; border: 1px dashed var(--border); border-radius: 4px;
  color: var(--text-3); cursor: pointer; transition: all var(--transition);
}
.pillar-add-btn:hover { border-color: var(--accent); color: var(--accent); }

/* ── Login gate ───────────────────────────────────── */
.login-gate {
  position: fixed; inset: 0; z-index: 200000;
  display: flex; align-items: center; justify-content: center;
  background: var(--bg);
  padding: 24px;
}
.login-gate.hidden { display: none !important; }
.login-card {
  width: 100%; max-width: 400px;
  background: var(--bg-2); border: 1px solid var(--border);
  border-radius: var(--radius); padding: 28px 26px;
  box-shadow: 0 12px 40px rgba(15, 23, 42, 0.08);
}
[data-mode="dark"] .login-card { box-shadow: 0 12px 40px rgba(0, 0, 0, 0.35); }
.login-brand {
  font-family: 'Space Grotesk', var(--font-sans, system-ui), sans-serif;
  font-size: 22px; font-weight: 700; color: var(--text); margin-bottom: 4px;
}
.login-sub { font-size: 13px; color: var(--text-2); margin: 0 0 18px; }
.login-gate .form-row { margin-bottom: 12px; }
.login-gate .form-row label { display: block; font-size: 12px; color: var(--text-2); margin-bottom: 4px; }
.login-error { color: var(--danger); font-size: 12px; margin-top: 10px; text-align: center; }
.login-error.hidden { display: none; }
body.cm-login-mode .sidebar,
body.cm-login-mode #main,
body.cm-login-mode .mobile-topbar,
body.cm-login-mode .scroll-top-btn,
body.cm-login-mode .settings-popover { display: none !important; }
