/* =========================================================
   Notebook / Papier — esthétique carnet de notes
   ========================================================= */

:root {
  --paper:      #f4ede0;     /* fond crème principal */
  --paper-soft: #ebe2cf;     /* zones secondaires */
  --paper-deep: #e0d4ba;     /* élévation, hovers */
  --ink:        #1a1612;     /* texte principal */
  --ink-soft:   #5a4f3f;     /* texte secondaire */
  --ink-faint:  #8b7d68;     /* annotations */
  --rule:       #d4c8ad;     /* lignes/réglures */
  --rule-soft:  #e1d6bd;     /* séparateurs fins */
  --brick:      #b85c3c;     /* accent principal */
  --brick-deep: #963f23;     /* accent hover */
  --brick-soft: #d68b6f;     /* tints */
  --olive:      #6e7a3c;     /* secondaire (favori) */
  --moss:       #4a6b3d;     /* succès */
  --ochre:      #c89f4a;     /* avertissement / épingle */
  --berry:      #8a3a52;     /* danger */
  --shadow-soft: 0 1px 0 rgba(26, 22, 18, 0.04), 0 2px 8px rgba(26, 22, 18, 0.06);
  --shadow-card: 0 1px 0 rgba(26, 22, 18, 0.05), 0 4px 14px rgba(26, 22, 18, 0.08);
}

@import url('https://fonts.googleapis.com/css2?family=Lora:ital,wght@0,400;0,500;0,600;0,700;1,400&family=Source+Sans+3:wght@400;500;600;700&family=JetBrains+Mono:wght@400;500&display=swap');

* { box-sizing: border-box; }
html, body {
  margin: 0; padding: 0;
  height: 100%;
  overflow: hidden;
  font-family: 'Source Sans 3', system-ui, sans-serif;
  font-size: 15px; line-height: 1.55;
  color: var(--ink);
  background: var(--paper);
  background-image:
    radial-gradient(circle at 25% 30%, rgba(184, 92, 60, 0.025) 0, transparent 40%),
    radial-gradient(circle at 75% 70%, rgba(110, 122, 60, 0.02) 0, transparent 40%);
}

/* Texture papier subtile (grain SVG inline) */
body::before {
  content: ''; position: fixed; inset: 0; pointer-events: none; z-index: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 200 200' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='n'%3E%3CfeTurbulence baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/%3E%3CfeColorMatrix values='0 0 0 0 0.4 0 0 0 0 0.3 0 0 0 0 0.2 0 0 0 0.04 0'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23n)'/%3E%3C/svg%3E");
  opacity: 0.6; mix-blend-mode: multiply;
}

h1, h2, h3, h4 { font-family: 'Lora', Georgia, serif; font-weight: 600; color: var(--ink); letter-spacing: -0.01em; }
button, input, select, textarea { font-family: inherit; color: var(--ink); }
button { cursor: pointer; }
a { color: var(--brick); }
code, kbd, .mono { font-family: 'JetBrains Mono', monospace; font-size: 0.88em; }

kbd {
  display: inline-block;
  padding: 1px 6px;
  font-size: 11px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-bottom-width: 2px;
  border-radius: 3px;
  color: var(--ink-soft);
}

.hidden { display: none !important; }
.muted { color: var(--ink-faint); font-size: 13px; font-style: italic; }

/* ---------------- Login ---------------- */
.login-screen {
  position: relative; z-index: 1;
  display: flex; align-items: center; justify-content: center;
  height: 100vh;
  overflow: auto;
}
.login-card {
  background: var(--paper);
  padding: 44px 38px;
  width: min(380px, 90%);
  display: flex; flex-direction: column; gap: 16px;
  border: 1px solid var(--rule);
  box-shadow: var(--shadow-card);
  position: relative;
}
.login-card::before {
  content: ''; position: absolute; top: 0; bottom: 0; left: 38px;
  width: 1px; background: var(--brick-soft); opacity: 0.5;
}
.login-card h1 { margin: 0; font-size: 32px; font-style: italic; }
.login-card .sub { color: var(--ink-faint); font-size: 14px; margin-top: -4px; }
.login-card input {
  padding: 11px 14px; background: transparent;
  border: 1px solid var(--rule);
  font-size: 15px;
  transition: border-color 0.15s;
}
.login-card input:focus { outline: none; border-color: var(--brick); }
.login-card button {
  padding: 11px;
  background: var(--ink); color: var(--paper);
  border: none;
  font-weight: 600; font-size: 14px;
  letter-spacing: 0.02em;
}
.login-card button:hover { background: var(--brick); }
.error { color: var(--berry); font-size: 13px; font-style: italic; }

/* ---------------- App layout ---------------- */
.app {
  display: grid;
  grid-template-columns: 240px 1fr;
  height: 100vh;
  overflow: hidden;
  position: relative; z-index: 1;
}

.sidebar {
  background: var(--paper-soft);
  border-right: 1px solid var(--rule);
  padding: 26px 18px 26px 26px;
  overflow-y: auto;
  display: flex; flex-direction: column; gap: 22px;
  position: relative;
}
.sidebar::before {
  /* marge rouge type carnet d'école */
  content: ''; position: absolute; left: 18px; top: 0; bottom: 0;
  width: 1px; background: var(--brick-soft); opacity: 0.55;
}

.brand { display: flex; align-items: baseline; justify-content: space-between; padding-left: 4px; }
.brand h1 {
  margin: 0;
  font-size: 24px;
  font-style: italic;
  font-weight: 500;
}
.brand .stamp {
  font-family: 'JetBrains Mono', monospace;
  font-size: 9px;
  color: var(--ink-faint);
  letter-spacing: 0.1em;
  text-transform: uppercase;
}

.nav { display: flex; flex-direction: column; gap: 1px; padding-left: 4px; }
.nav-btn {
  background: transparent; color: var(--ink-soft); border: none;
  padding: 7px 10px 7px 4px; text-align: left;
  font-size: 14px;
  border-bottom: 1px dotted transparent;
  display: flex; align-items: center; gap: 8px;
}
.nav-btn:hover { color: var(--ink); border-bottom-color: var(--rule); }
.nav-btn.active {
  color: var(--brick);
  font-weight: 600;
  border-bottom-color: var(--brick-soft);
}
.nav-btn .nav-num {
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  color: var(--ink-faint);
  width: 16px;
}

.sidebar-section { padding-left: 4px; }
.section-header {
  display: flex; align-items: center; justify-content: space-between;
  font-family: 'Lora', serif;
  font-size: 13px; font-style: italic;
  color: var(--ink-faint);
  margin-bottom: 6px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--rule);
}

.filter-list { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 1px; }
.filter-list li {
  padding: 5px 8px 5px 0;
  font-size: 13.5px;
  cursor: pointer;
  display: flex; align-items: center; gap: 8px;
  color: var(--ink-soft);
  transition: color 0.15s;
}
.filter-list li:hover { color: var(--ink); }
.filter-list li.active {
  color: var(--ink);
  font-weight: 600;
}
.filter-list li.active::before {
  content: '→'; color: var(--brick); margin-right: -4px;
  font-family: 'Lora', serif;
}
.filter-list .swatch { width: 8px; height: 8px; border-radius: 50%; flex-shrink: 0; }
.filter-list .count { color: var(--ink-faint); font-size: 11px; margin-left: auto; font-family: 'JetBrains Mono', monospace; }

.tag-cloud { list-style: none; padding: 0; margin: 0; display: flex; flex-wrap: wrap; gap: 5px; }
.tag-cloud li {
  padding: 2px 8px;
  background: transparent;
  border: 1px solid var(--rule);
  font-size: 11.5px;
  cursor: pointer;
  color: var(--ink-soft);
  transition: all 0.15s;
}
.tag-cloud li:hover { border-color: var(--ink-soft); color: var(--ink); }
.tag-cloud li.active { background: var(--ink); color: var(--paper); border-color: var(--ink); }

.tiny-btn {
  background: transparent; color: var(--ink-soft);
  border: 1px solid var(--rule);
  padding: 2px 7px; font-size: 12px;
  transition: all 0.15s;
}
.tiny-btn:hover { background: var(--ink); color: var(--paper); border-color: var(--ink); }

/* ---------------- Main ---------------- */
.main {
  padding: 28px 36px 60px;
  overflow-y: auto;
  height: 100vh;
}
.view { display: flex; flex-direction: column; gap: 22px; }

.page-header { display: flex; align-items: baseline; gap: 14px; margin-bottom: -8px; }
.page-header h2 { margin: 0; font-size: 26px; font-style: italic; font-weight: 500; }
.page-header .annotation {
  font-family: 'Lora', serif; font-style: italic;
  color: var(--ink-faint); font-size: 14px;
}

.toolbar {
  display: flex; gap: 10px; flex-wrap: wrap; align-items: center;
  padding-bottom: 14px;
  border-bottom: 1px dashed var(--rule);
}
.search {
  flex: 1; min-width: 240px;
  padding: 9px 14px 9px 38px;
  background: transparent;
  border: 1px solid var(--rule);
  font-size: 14px;
  background-image: url("data:image/svg+xml,%3Csvg width='14' height='14' viewBox='0 0 24 24' fill='none' stroke='%238b7d68' stroke-width='2' xmlns='http://www.w3.org/2000/svg'%3E%3Ccircle cx='11' cy='11' r='8'/%3E%3Cline x1='21' y1='21' x2='16.65' y2='16.65'/%3E%3C/svg%3E");
  background-repeat: no-repeat; background-position: 14px center;
}
.search:focus { outline: none; border-color: var(--brick); }
.search-shortcut { color: var(--ink-faint); font-size: 11px; margin-left: -50px; pointer-events: none; }

select, .filter-input {
  padding: 7px 12px;
  background: transparent;
  border: 1px solid var(--rule);
  font-size: 13px;
  color: var(--ink);
}
select:focus { outline: none; border-color: var(--brick); }
.checkbox { display: flex; align-items: center; gap: 6px; font-size: 13px; color: var(--ink-soft); cursor: pointer; }
.checkbox input { accent-color: var(--brick); }

.view-switch {
  display: inline-flex;
  border: 1px solid var(--rule);
}
.view-switch button {
  background: transparent;
  border: none;
  padding: 6px 10px;
  color: var(--ink-faint);
  font-size: 13px;
  border-right: 1px solid var(--rule);
}
.view-switch button:last-child { border-right: none; }
.view-switch button.active {
  background: var(--ink); color: var(--paper);
}

.primary-btn, .secondary-btn, .danger-btn {
  padding: 8px 16px;
  font-weight: 600; font-size: 13px;
  border-radius: 0;
  transition: all 0.15s;
}
.primary-btn {
  background: var(--ink); color: var(--paper);
  border: 1px solid var(--ink);
}
.primary-btn:hover { background: var(--brick); border-color: var(--brick); }
.secondary-btn {
  background: transparent; color: var(--ink);
  border: 1px solid var(--ink);
}
.secondary-btn:hover { background: var(--ink); color: var(--paper); }
.danger-btn {
  background: transparent; color: var(--berry);
  border: 1px solid var(--berry);
}
.danger-btn:hover { background: var(--berry); color: var(--paper); }
.icon-btn {
  background: transparent; color: var(--ink-soft); border: none;
  padding: 4px 8px; font-size: 18px; line-height: 1;
}
.icon-btn:hover { color: var(--brick); }

/* ---------------- Prompt grid ---------------- */
.prompt-grid { display: grid; gap: 16px; }
.prompt-grid.view-card { grid-template-columns: repeat(auto-fill, minmax(310px, 1fr)); }
.prompt-grid.view-compact { grid-template-columns: repeat(auto-fill, minmax(220px, 1fr)); gap: 10px; }
.prompt-grid.view-list { grid-template-columns: 1fr; gap: 0; }

.prompt-card {
  position: relative;
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 16px 18px;
  cursor: pointer;
  transition: border-color 0.15s, transform 0.15s, box-shadow 0.15s;
  display: flex; flex-direction: column; gap: 10px;
}
.prompt-card:hover {
  border-color: var(--ink);
  box-shadow: var(--shadow-card);
}
.prompt-card.pinned {
  background: linear-gradient(135deg, var(--paper) 0%, #f8f1d8 100%);
  border-color: var(--ochre);
}
.prompt-card.pinned::before {
  content: '📎';
  position: absolute; top: -10px; right: 12px;
  font-size: 18px;
  transform: rotate(15deg);
  filter: sepia(0.3);
}

.prompt-card .card-header {
  display: flex; justify-content: space-between; align-items: flex-start; gap: 10px;
}
.prompt-card h3 {
  margin: 0;
  font-size: 17px;
  font-weight: 600;
  font-family: 'Lora', serif;
  line-height: 1.3;
  flex: 1;
}
.prompt-card .star-group { display: flex; gap: 4px; align-items: center; }
.prompt-card .star, .prompt-card .pin {
  background: transparent; border: none;
  font-size: 16px;
  cursor: pointer;
  padding: 2px 4px;
  color: var(--ink-faint);
  line-height: 1;
}
.prompt-card .star.active { color: var(--olive); }
.prompt-card .star.active::before { content: '✦'; }
.prompt-card .star::before { content: '✧'; }
.prompt-card .pin.active { color: var(--ochre); }
.prompt-card .desc {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 13.5px;
  color: var(--ink-soft);
  margin: 0;
  min-height: 1em;
  line-height: 1.45;
}
.prompt-card .preview {
  font-family: 'JetBrains Mono', monospace;
  font-size: 11.5px;
  color: var(--ink-soft);
  background: var(--paper-soft);
  border-left: 2px solid var(--rule);
  padding: 8px 10px;
  max-height: 80px;
  overflow: hidden;
  white-space: pre-wrap;
  word-break: break-word;
  position: relative;
}
.prompt-card .preview::after {
  content: ''; position: absolute; bottom: 0; left: 0; right: 0; height: 24px;
  background: linear-gradient(transparent, var(--paper-soft));
}
.prompt-card .preview .var {
  background: rgba(184, 92, 60, 0.12);
  color: var(--brick-deep);
  padding: 0 2px;
  border-radius: 2px;
}
.prompt-card .meta {
  display: flex; gap: 6px; flex-wrap: wrap; align-items: center;
  font-size: 11px; color: var(--ink-faint);
}
.prompt-card .badge {
  padding: 1px 8px;
  border-radius: 10px;
  font-weight: 500;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10px;
  letter-spacing: 0.03em;
}
.prompt-card .badge-cat { color: var(--paper); }
.prompt-card .badge-model { background: var(--paper-soft); border: 1px solid var(--rule); color: var(--ink-soft); }
.prompt-card .usage { color: var(--ink-faint); font-family: 'JetBrains Mono', monospace; font-size: 10.5px; }
.prompt-card .tag-chip { background: transparent; border: 1px solid var(--rule); padding: 0 6px; font-size: 10.5px; color: var(--ink-soft); }
.prompt-card .actions { display: flex; gap: 6px; margin-top: 2px; }
.prompt-card .actions button { flex: 1; padding: 6px 8px; font-size: 12px; }

/* Vue compact */
.view-compact .prompt-card { padding: 10px 12px; gap: 6px; }
.view-compact .prompt-card .preview,
.view-compact .prompt-card .desc,
.view-compact .prompt-card .actions { display: none; }
.view-compact .prompt-card h3 { font-size: 14.5px; }

/* Vue list (table-like) */
.view-list .prompt-card {
  flex-direction: row; align-items: center;
  padding: 10px 16px; gap: 14px;
  border-top: none;
}
.view-list .prompt-card + .prompt-card { border-top: 1px solid var(--rule); }
.view-list .prompt-card { border: 1px solid var(--rule); border-bottom-color: var(--rule); }
.view-list .prompt-card .preview,
.view-list .prompt-card .desc,
.view-list .prompt-card .actions { display: none; }
.view-list .prompt-card .card-header { flex: 1; }
.view-list .prompt-card .meta { margin-left: auto; }

.empty {
  text-align: center; padding: 80px 20px;
  color: var(--ink-faint);
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 16px;
}
.empty .doodle { font-size: 32px; margin-bottom: 12px; opacity: 0.5; }

/* ---------------- Workflows ---------------- */
.workflow-list { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 16px; }
.workflow-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 16px 18px;
  cursor: pointer;
  transition: border-color 0.15s;
}
.workflow-card:hover { border-color: var(--ink); box-shadow: var(--shadow-card); }
.workflow-card h3 { margin: 0 0 4px 0; font-size: 17px; font-family: 'Lora', serif; }
.workflow-card p { margin: 0 0 10px 0; font-size: 13px; color: var(--ink-soft); font-family: 'Lora', serif; font-style: italic; }
.workflow-card .step-count { font-size: 11px; color: var(--brick); font-family: 'JetBrains Mono', monospace; }

.wf-steps { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.wf-step {
  display: flex; gap: 10px; align-items: center;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 8px 10px;
}
.wf-step .step-num {
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 17px;
  color: var(--brick);
  width: 24px;
  text-align: center;
}
.wf-step select { flex: 1; background: var(--paper); }
.wf-step input { flex: 2; padding: 6px 8px; background: var(--paper); border: 1px solid var(--rule); font-size: 12px; }
.wf-step .remove { background: transparent; color: var(--berry); border: none; cursor: pointer; padding: 4px 8px; font-size: 18px; }

/* ---------------- Stats ---------------- */
.stats-grid { display: grid; grid-template-columns: repeat(auto-fit, minmax(170px, 1fr)); gap: 14px; }
.stat-card {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 18px 20px;
}
.stat-card .value {
  font-family: 'Lora', serif;
  font-size: 38px;
  font-weight: 600;
  color: var(--brick);
  line-height: 1;
}
.stat-card .label {
  font-size: 12.5px;
  color: var(--ink-faint);
  margin-top: 6px;
  font-family: 'Lora', serif;
  font-style: italic;
  letter-spacing: 0.02em;
}
.top-used { padding-left: 24px; font-family: 'Lora', serif; }
.top-used li { padding: 6px 0; border-bottom: 1px dashed var(--rule); cursor: pointer; font-size: 15px; }
.top-used li:hover { color: var(--brick); }
.top-used .count { color: var(--ink-faint); font-size: 12px; margin-left: 8px; font-family: 'JetBrains Mono', monospace; font-style: normal; }

/* ---------------- Manage ---------------- */
.manage-section {
  background: var(--paper);
  padding: 22px;
  border: 1px solid var(--rule);
  margin-bottom: 18px;
}
.manage-section h3 {
  margin: 0 0 14px 0;
  font-family: 'Lora', serif; font-style: italic;
  font-size: 18px;
}
.categories-manage { display: flex; flex-direction: column; gap: 6px; }
.cat-row {
  display: flex; align-items: center; gap: 12px;
  padding: 9px 12px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
}
.cat-row .swatch { width: 14px; height: 14px; border-radius: 2px; border: 1px solid rgba(0,0,0,0.1); }
.cat-row .name { flex: 1; font-weight: 600; }
.cat-row .count { color: var(--ink-faint); font-size: 12px; font-family: 'JetBrains Mono', monospace; }
.manage-actions { display: flex; gap: 10px; flex-wrap: wrap; }
.file-label { display: inline-flex; align-items: center; cursor: pointer; }

/* ---------------- Generator (forge) ---------------- */
.gen-section-label {
  font-family: 'Lora', serif;
  font-style: italic;
  color: var(--ink-faint);
  font-size: 13px;
  margin: 16px 0 8px 0;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--rule);
}

.gen-templates {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(180px, 1fr));
  gap: 8px;
}
.gen-template {
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 10px 12px;
  cursor: pointer;
  transition: all 0.15s;
  display: flex; flex-direction: column; gap: 3px;
}
.gen-template:hover {
  background: var(--paper);
  border-color: var(--brick);
  transform: translateY(-1px);
}
.gen-template .t-icon {
  font-size: 18px;
  line-height: 1;
}
.gen-template .t-title {
  font-family: 'Lora', serif;
  font-weight: 600;
  font-size: 13.5px;
}
.gen-template .t-hint {
  font-size: 11px;
  color: var(--ink-faint);
  line-height: 1.3;
}

.gen-variant-chooser {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(190px, 1fr));
  gap: 8px;
}
.vchoice {
  display: flex; align-items: center; gap: 10px;
  padding: 9px 12px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  cursor: pointer;
  transition: all 0.15s;
}
.vchoice:hover { border-color: var(--ink-soft); }
.vchoice input { accent-color: var(--brick); width: 16px; height: 16px; flex-shrink: 0; }
.vchoice input:checked + span b { color: var(--brick); }
.vchoice span { display: flex; flex-direction: column; gap: 1px; }
.vchoice b { font-size: 13.5px; font-family: 'Lora', serif; font-weight: 600; }
.vchoice em { font-style: italic; font-size: 10.5px; color: var(--ink-faint); }

.gen-mode-switch {
  display: inline-flex;
  border: 1px solid var(--rule);
  margin-bottom: 18px;
}
.gen-mode-btn {
  background: transparent;
  border: none;
  padding: 9px 18px;
  color: var(--ink-soft);
  font-family: 'Lora', serif;
  font-style: italic;
  font-size: 14px;
  border-right: 1px solid var(--rule);
}
.gen-mode-btn:last-child { border-right: none; }
.gen-mode-btn.active {
  background: var(--ink);
  color: var(--paper);
}

.gen-results {
  display: grid;
  gap: 20px;
  margin-top: 8px;
}
.gen-variant {
  background: var(--paper);
  border: 1px solid var(--rule);
  border-left: 3px solid var(--brick);
  padding: 20px 24px;
  position: relative;
}
.gen-variant.type-concise { border-left-color: var(--moss); }
.gen-variant.type-detailed { border-left-color: var(--brick); }
.gen-variant.type-roleplay { border-left-color: var(--ochre); }
.gen-variant.type-cot { border-left-color: #7a4e8e; }
.gen-variant.type-fewshot { border-left-color: #3d7a8e; }
.gen-variant.type-json { border-left-color: #5a5a5a; }

.gen-variant .v-type-label {
  position: absolute;
  top: -10px; left: 18px;
  background: var(--paper);
  padding: 2px 10px;
  font-family: 'JetBrains Mono', monospace;
  font-size: 10.5px;
  letter-spacing: 0.08em;
  text-transform: uppercase;
  color: var(--ink-faint);
  border: 1px solid var(--rule);
}
.gen-variant h3 {
  margin: 4px 0 6px 0;
  font-size: 19px;
  font-style: italic;
}
.gen-variant .v-desc {
  font-family: 'Lora', serif;
  font-style: italic;
  color: var(--ink-soft);
  font-size: 14px;
  margin: 0 0 12px 0;
}
.gen-variant .v-content {
  font-family: 'JetBrains Mono', monospace;
  font-size: 12.5px;
  line-height: 1.6;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  padding: 12px 14px;
  white-space: pre-wrap;
  word-break: break-word;
  margin-bottom: 12px;
  max-height: 280px;
  overflow-y: auto;
}
.gen-variant .v-content .var {
  background: rgba(184, 92, 60, 0.15);
  color: var(--brick-deep);
  padding: 0 3px;
  border-radius: 2px;
}
.gen-variant .v-tags {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin-bottom: 12px;
}
.gen-variant .v-tags .tag-chip {
  background: transparent;
  border: 1px solid var(--rule);
  padding: 1px 7px;
  font-size: 11px;
  color: var(--ink-soft);
}
.gen-variant .v-actions {
  display: flex; gap: 10px;
}
.gen-loader {
  display: inline-block;
  width: 14px; height: 14px;
  border: 2px solid var(--rule);
  border-top-color: var(--brick);
  border-radius: 50%;
  animation: spin 0.7s linear infinite;
  vertical-align: middle;
  margin-right: 8px;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ---------------- Modals ---------------- */
.modal {
  position: fixed; inset: 0;
  background: rgba(26, 22, 18, 0.5);
  display: flex; align-items: center; justify-content: center;
  z-index: 100; padding: 20px;
  backdrop-filter: blur(2px);
}
.modal-content {
  background: var(--paper);
  width: min(580px, 100%); max-height: 92vh;
  display: flex; flex-direction: column;
  border: 1px solid var(--rule);
  box-shadow: 0 8px 32px rgba(26, 22, 18, 0.2);
  position: relative;
}
.modal-content::before {
  content: ''; position: absolute; top: 0; bottom: 0; left: 24px;
  width: 1px; background: var(--brick-soft); opacity: 0.4;
  pointer-events: none;
}
.modal-large { width: min(840px, 100%); }
.modal-content header {
  padding: 18px 24px; border-bottom: 1px solid var(--rule);
  display: flex; align-items: center; justify-content: space-between;
}
.modal-content header h2 {
  margin: 0; font-size: 22px;
  font-style: italic;
  font-weight: 500;
}
.modal-body { padding: 22px 24px; overflow-y: auto; flex: 1; }
.modal-content footer {
  padding: 14px 24px;
  border-top: 1px solid var(--rule);
  display: flex; gap: 10px; align-items: center;
}
.spacer { flex: 1; }

.form-row { margin-bottom: 14px; }
.form-row label {
  display: flex; flex-direction: column; gap: 6px;
  font-size: 13px; color: var(--ink-soft);
  font-family: 'Lora', serif; font-style: italic;
}
.form-row input[type=text], .form-row input[type=password], .form-row textarea, .form-row select {
  padding: 9px 12px;
  background: transparent;
  border: 1px solid var(--rule);
  font-size: 14.5px;
  color: var(--ink);
  font-family: 'Source Sans 3', sans-serif;
  font-style: normal;
  width: 100%;
}
.form-row input:focus, .form-row textarea:focus, .form-row select:focus {
  outline: none; border-color: var(--brick);
}
.form-row textarea {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13.5px;
  line-height: 1.55;
  resize: vertical;
}
.form-row.split { display: grid; grid-template-columns: 1fr 1fr auto; gap: 14px; align-items: end; }
.form-row code { background: var(--paper-soft); padding: 1px 5px; border-radius: 2px; font-size: 11.5px; }
.checkbox-block { display: flex; align-items: center; gap: 8px; padding-bottom: 9px; font-family: 'Source Sans 3', sans-serif; font-style: normal; }

/* Variables détectées (badges live) */
.detected-vars {
  display: flex; flex-wrap: wrap; gap: 6px;
  margin-top: 8px;
  padding: 8px 10px;
  background: var(--paper-soft);
  border: 1px dashed var(--rule);
  min-height: 36px;
  font-style: normal;
}
.detected-vars .var-pill {
  background: var(--paper);
  border: 1px solid var(--rule);
  padding: 2px 8px;
  font-size: 11.5px;
  font-family: 'JetBrains Mono', monospace;
  display: inline-flex; align-items: center; gap: 6px;
}
.detected-vars .var-pill .type { color: var(--brick); font-size: 10px; }
.detected-vars .empty-hint { color: var(--ink-faint); font-size: 12px; font-style: italic; }

/* Use prompt modal */
.var-row {
  display: flex; flex-direction: column; gap: 4px;
  margin-bottom: 14px;
}
.var-row .var-label {
  font-size: 13px; color: var(--ink-soft);
  display: flex; align-items: center; gap: 8px;
}
.var-row .var-name {
  font-family: 'JetBrains Mono', monospace;
  color: var(--brick); font-size: 12px;
}
.var-row .var-type {
  font-size: 10.5px; color: var(--ink-faint);
  font-style: italic; font-family: 'Lora', serif;
}
.var-row input, .var-row textarea, .var-row select {
  padding: 8px 11px;
  background: transparent;
  border: 1px solid var(--rule);
  font-size: 14px;
  color: var(--ink);
  width: 100%;
  font-family: 'Source Sans 3', sans-serif;
}
.var-row input:focus, .var-row textarea:focus, .var-row select:focus { outline: none; border-color: var(--brick); }
.var-row textarea { resize: vertical; min-height: 60px; }

.preview-block { margin-top: 18px; padding-top: 14px; border-top: 1px dashed var(--rule); }
.preview-block .preview-label {
  font-family: 'Lora', serif; font-style: italic;
  color: var(--ink-faint); font-size: 13px;
  margin-bottom: 8px;
}
.preview-block textarea {
  font-family: 'JetBrains Mono', monospace;
  font-size: 13.5px;
  background: var(--paper-soft);
  border: 1px solid var(--rule);
  border-left: 2px solid var(--brick-soft);
  padding: 12px 14px;
  color: var(--ink);
  resize: vertical;
  width: 100%;
  line-height: 1.6;
}

.versions-list { list-style: none; padding: 0; margin: 0; }
.versions-list li {
  padding: 14px 16px;
  border: 1px solid var(--rule);
  margin-bottom: 10px;
  background: var(--paper-soft);
  position: relative;
}
.versions-list .ts { font-size: 12px; color: var(--ink-faint); font-family: 'JetBrains Mono', monospace; margin-bottom: 6px; }
.versions-list .v-title { font-family: 'Lora', serif; font-weight: 600; font-size: 15px; margin-bottom: 8px; }
.versions-list pre {
  margin: 0; max-height: 200px; overflow: auto;
  white-space: pre-wrap; word-break: break-word;
  font-family: 'JetBrains Mono', monospace; font-size: 12px;
  color: var(--ink-soft);
}

/* ---------------- Command palette (⌘K) ---------------- */
.palette {
  position: fixed; inset: 0;
  background: rgba(26, 22, 18, 0.45);
  z-index: 200;
  display: flex; align-items: flex-start; justify-content: center;
  padding-top: 12vh;
  backdrop-filter: blur(2px);
}
.palette-box {
  background: var(--paper);
  width: min(580px, 92%);
  border: 1px solid var(--rule);
  box-shadow: 0 12px 36px rgba(26, 22, 18, 0.25);
}
.palette-input {
  width: 100%;
  padding: 16px 20px;
  background: transparent;
  border: none;
  border-bottom: 1px solid var(--rule);
  font-size: 17px;
  color: var(--ink);
  font-family: 'Source Sans 3', sans-serif;
}
.palette-input:focus { outline: none; }
.palette-input::placeholder { color: var(--ink-faint); font-style: italic; }
.palette-results { max-height: 50vh; overflow-y: auto; padding: 6px 0; }
.palette-item {
  padding: 9px 20px;
  cursor: pointer;
  display: flex; align-items: center; gap: 12px;
  font-size: 14px;
}
.palette-item:hover, .palette-item.selected {
  background: var(--paper-soft);
}
.palette-item .p-title { flex: 1; font-family: 'Lora', serif; }
.palette-item .p-cat {
  font-size: 11px; color: var(--ink-faint);
  font-family: 'JetBrains Mono', monospace;
}
.palette-empty {
  padding: 24px; text-align: center;
  color: var(--ink-faint); font-style: italic;
  font-family: 'Lora', serif;
}
.palette-hint {
  border-top: 1px solid var(--rule);
  padding: 8px 20px;
  font-size: 11px;
  color: var(--ink-faint);
  display: flex; gap: 16px; flex-wrap: wrap;
}

/* ---------------- Toast ---------------- */
.toast {
  position: fixed; bottom: 28px; left: 50%; transform: translateX(-50%);
  background: var(--ink); color: var(--paper);
  padding: 11px 22px;
  font-size: 14px;
  font-family: 'Lora', serif; font-style: italic;
  box-shadow: 0 4px 16px rgba(0,0,0,0.25);
  z-index: 300;
  letter-spacing: 0.01em;
}
.toast.error { background: var(--berry); }

/* ---------------- Helpers ---------------- */
.scribble { position: relative; display: inline-block; }
.scribble::after {
  content: ''; position: absolute; left: 0; right: 0; bottom: -2px;
  height: 6px;
  background: url("data:image/svg+xml,%3Csvg viewBox='0 0 100 6' xmlns='http://www.w3.org/2000/svg' preserveAspectRatio='none'%3E%3Cpath d='M0 3 Q 25 0, 50 3 T 100 3' stroke='%23b85c3c' stroke-width='1.2' fill='none' opacity='0.6'/%3E%3C/svg%3E") no-repeat;
  background-size: 100% 100%;
}

@media (max-width: 800px) {
  .app { grid-template-columns: 1fr; }
  .sidebar { border-right: none; border-bottom: 1px solid var(--rule); padding: 18px; }
  .sidebar::before { display: none; }
  .form-row.split { grid-template-columns: 1fr; }
  .main { padding: 18px; }
}
