/* =========================================================
   PRAXELYS — Design system
   Palette : ivoire / bleu nuit · or mat · vert sauge · bleu profond
   ========================================================= */

:root {
  /* Light */
  --bg:            #FBF8F3;       /* ivoire */
  --bg-elev:       #FFFFFFEE;     /* cartes */
  --bg-soft:       #F3EEE4;       /* zones douces */
  --ink:           #1A1F2C;       /* texte principal */
  --ink-soft:      #5B6473;       /* texte secondaire */
  --ink-mute:      #8B93A1;       /* hints */
  --line:          #E8E2D4;       /* séparateurs neutres */
  --line-strong:   #D9D2C0;

  --gold:          #C9A961;       /* or mat — accents premium */
  --gold-soft:     #E4D4A6;
  --gold-deep:     #9E8442;

  --green:         #6B8E5A;       /* vert sauge — séparateurs / OK */
  --green-soft:    #C5D4B8;

  --blue:          #2C5F7C;       /* bleu profond — liens / en cours */
  --blue-soft:     #BFD3DE;

  --warn:          #C97B3D;

  --red:           #C0484A;       /* rouge — dossier refusé */
  --amber:         #D6953A;       /* jaune ambré — dossier en attente */
  --amber-deep:    #9C6A1E;

  --shadow-sm:     0 1px 2px rgba(26,31,44,.04), 0 1px 3px rgba(26,31,44,.04);
  --shadow-md:     0 6px 24px rgba(26,31,44,.06), 0 2px 6px rgba(26,31,44,.04);
  --shadow-lg:     0 20px 50px rgba(26,31,44,.08);

  --radius:        14px;
  --radius-sm:     10px;
  --radius-xs:     8px;

  --font-serif:    "Cormorant Garamond", "Playfair Display", Georgia, serif;
  --font-sans:     "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
}

[data-theme="dark"] {
  --bg:            #0E1420;       /* bleu nuit très profond */
  --bg-elev:       #161E2D;
  --bg-soft:       #1B2535;
  --ink:           #F1EBDC;       /* ivoire chaud sur sombre */
  --ink-soft:      #A6AFC1;
  --ink-mute:      #6A7388;
  --line:          #232E42;
  --line-strong:   #2E3B55;

  --gold:          #D9B872;
  --gold-soft:     #5C4A24;
  --gold-deep:     #F0CE85;

  --green:         #8FB377;
  --green-soft:    #2F4429;

  --blue:          #6FA3C2;
  --blue-soft:     #1F3A4C;

  --warn:          #E2956A;

  --red:           #E07577;       /* rouge — dossier refusé */
  --amber:         #E6B25A;       /* jaune ambré — dossier en attente */
  --amber-deep:    #F0C880;

  --shadow-sm:     0 1px 2px rgba(0,0,0,.4);
  --shadow-md:     0 8px 28px rgba(0,0,0,.35);
  --shadow-lg:     0 24px 60px rgba(0,0,0,.5);
}

* { box-sizing: border-box; }
html, body { margin: 0; padding: 0; }
body {
  font-family: var(--font-sans);
  background: var(--bg);
  color: var(--ink);
  font-size: 14.5px;
  line-height: 1.5;
  -webkit-font-smoothing: antialiased;
  display: grid;
  grid-template-columns: 280px 1fr;
  min-height: 100vh;
  transition: background .35s ease, color .35s ease;
}

/* subtle ivory texture */
body::before {
  content: "";
  position: fixed; inset: 0;
  pointer-events: none;
  background-image:
    radial-gradient(circle at 20% 0%, rgba(201,169,97,.06), transparent 40%),
    radial-gradient(circle at 100% 100%, rgba(107,142,90,.05), transparent 40%);
  z-index: 0;
}
[data-theme="dark"] body::before {
  background-image:
    radial-gradient(circle at 20% 0%, rgba(217,184,114,.06), transparent 40%),
    radial-gradient(circle at 100% 100%, rgba(111,163,194,.07), transparent 40%);
}

/* =========================================================
   SIDEBAR
========================================================= */
.sidebar {
  position: sticky; top: 0;
  height: 100vh;
  padding: 28px 18px 20px;
  background: var(--bg-elev);
  border-right: 1px solid var(--line);
  display: flex; flex-direction: column;
  z-index: 2;
  backdrop-filter: blur(8px);
}

.brand {
  display: flex; align-items: center; gap: 12px;
  padding: 4px 8px 24px;
  border-bottom: 1px solid var(--green);
  margin-bottom: 22px;
}
.brand-mark {
  width: 42px; height: 42px;
  display: grid; place-items: center;
  border: 1.5px solid var(--gold);
  border-radius: 10px;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 22px;
  color: var(--gold-deep);
  background: linear-gradient(180deg, transparent, rgba(201,169,97,.08));
  letter-spacing: .5px;
}
[data-theme="dark"] .brand-mark { color: var(--gold-deep); }
.brand-name {
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 19px;
  letter-spacing: 2.5px;
  color: var(--ink);
}
.brand-sub {
  font-size: 11px;
  color: var(--ink-mute);
  letter-spacing: 1px;
  text-transform: uppercase;
}

.nav { display: flex; flex-direction: column; gap: 2px; }
.nav-item {
  display: flex; align-items: center; gap: 12px;
  padding: 10px 12px;
  border-radius: var(--radius-sm);
  color: var(--ink-soft);
  text-decoration: none;
  font-size: 14px;
  font-weight: 500;
  transition: all .2s ease;
  position: relative;
}
.nav-item svg { width: 18px; height: 18px; flex-shrink: 0; opacity: .85; }
.nav-item:hover { background: var(--bg-soft); color: var(--ink); }
.nav-item.active {
  background: linear-gradient(90deg, rgba(201,169,97,.12), rgba(201,169,97,.02));
  color: var(--ink);
}
.nav-item.active::before {
  content: ""; position: absolute; left: -18px; top: 8px; bottom: 8px;
  width: 3px; background: var(--gold); border-radius: 0 2px 2px 0;
}

.nav-divider {
  height: 1px;
  background: var(--green);
  opacity: .35;
  margin: 22px 6px 18px;
}

.user-card {
  margin-top: auto;
  display: flex; align-items: center; gap: 12px;
  padding: 12px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--bg-soft);
}
.user-avatar {
  width: 36px; height: 36px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold) 0%, var(--gold-deep) 100%);
  display: grid; place-items: center;
  color: #fff; font-weight: 600; font-size: 13px;
  letter-spacing: .5px;
}
.user-name { font-weight: 600; font-size: 13.5px; }
.user-role { font-size: 11.5px; color: var(--ink-mute); }

/* =========================================================
   MAIN
========================================================= */
.main {
  padding: 36px 44px 60px;
  max-width: 1400px;
  position: relative;
  z-index: 1;
}

.topbar {
  display: flex; justify-content: space-between; align-items: flex-end;
  gap: 24px;
  margin-bottom: 36px;
}
.eyebrow {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.page-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 38px;
  margin: 0 0 6px;
  letter-spacing: -.5px;
}
.page-sub { color: var(--ink-soft); font-size: 14.5px; margin: 0; }

.topbar-actions {
  display: flex; align-items: center; gap: 12px;
}

.search {
  display: flex; align-items: center; gap: 10px;
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 9px 14px;
  width: 320px;
  transition: border-color .2s;
}
.search:focus-within { border-color: var(--gold); }
.search svg { width: 16px; height: 16px; color: var(--ink-mute); }
.search input {
  border: 0; background: transparent; outline: none;
  font-size: 13.5px; color: var(--ink);
  flex: 1; font-family: inherit;
}
.search input::placeholder { color: var(--ink-mute); }
.search kbd {
  font-family: inherit; font-size: 11px;
  padding: 2px 6px; border-radius: 4px;
  background: var(--bg-soft);
  color: var(--ink-mute);
  border: 1px solid var(--line);
}

.icon-btn {
  width: 38px; height: 38px;
  border: 1px solid var(--line);
  background: var(--bg-elev);
  border-radius: var(--radius-sm);
  cursor: pointer;
  display: grid; place-items: center;
  color: var(--ink-soft);
  transition: all .2s;
}
.icon-btn:hover { color: var(--gold); border-color: var(--gold); }
.icon-btn svg { width: 18px; height: 18px; }
.ic-moon { display: none; }
[data-theme="dark"] .ic-sun { display: none; }
[data-theme="dark"] .ic-moon { display: block; }

.btn-primary {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  border: 1px solid var(--gold);
  background: linear-gradient(180deg, var(--gold) 0%, var(--gold-deep) 100%);
  color: #fff;
  font-family: inherit;
  font-weight: 600;
  font-size: 13.5px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  letter-spacing: .3px;
  transition: transform .15s, box-shadow .15s, filter .15s;
  box-shadow: 0 1px 3px rgba(201,169,97,.3), inset 0 1px 0 rgba(255,255,255,.2);
}
.btn-primary:hover { transform: translateY(-1px); filter: brightness(1.05); box-shadow: 0 6px 18px rgba(201,169,97,.35); }
.btn-primary svg { width: 15px; height: 15px; }

.btn-ghost {
  display: inline-flex; align-items: center; gap: 8px;
  padding: 10px 18px;
  border: 1px solid var(--line-strong);
  background: var(--bg-elev);
  color: var(--ink);
  font-family: inherit;
  font-weight: 500;
  font-size: 13.5px;
  border-radius: var(--radius-sm);
  cursor: pointer;
  transition: all .2s;
}
.btn-ghost:hover { border-color: var(--gold); color: var(--gold-deep); }

/* =========================================================
   STATS
========================================================= */
.stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 18px;
  margin-bottom: 32px;
}
.stat-card {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px 22px;
  position: relative;
  transition: transform .2s, box-shadow .2s, border-color .2s;
  box-shadow: var(--shadow-sm);
}
.stat-card:hover {
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
  border-color: var(--line-strong);
}
.stat-card.accent-gold {
  border: 1.5px solid var(--gold);
  background:
    linear-gradient(180deg, rgba(201,169,97,.06), transparent 70%),
    var(--bg-elev);
}
.stat-label {
  font-size: 11.5px;
  text-transform: uppercase;
  letter-spacing: 1.2px;
  color: var(--ink-mute);
  margin-bottom: 8px;
}
.stat-value {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 38px;
  line-height: 1;
  letter-spacing: -.5px;
}
.stat-trend {
  margin-top: 10px;
  font-size: 12px;
  color: var(--ink-soft);
}
.stat-trend.up { color: var(--green); }
.stat-trend.warn { color: var(--warn); font-weight: 500; }

/* =========================================================
   PANELS
========================================================= */
.panel {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 24px 26px;
  margin-bottom: 28px;
  box-shadow: var(--shadow-sm);
}
.panel-head {
  display: flex; justify-content: space-between; align-items: flex-start;
  gap: 16px;
  margin-bottom: 22px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--green);
  border-image: linear-gradient(90deg, var(--green) 0%, transparent 40%) 1;
}
.panel-title {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 22px;
  margin: 0 0 4px;
  letter-spacing: -.2px;
}
.panel-sub { font-size: 13px; color: var(--ink-soft); margin: 0; }

.filters { display: flex; gap: 8px; }
.chip {
  border: 1px solid var(--line-strong);
  background: transparent;
  color: var(--ink-soft);
  padding: 6px 14px;
  border-radius: 999px;
  font-family: inherit;
  font-size: 12.5px;
  cursor: pointer;
  transition: all .2s;
}
.chip:hover { color: var(--ink); border-color: var(--gold); }
.chip.active {
  background: var(--ink);
  color: var(--bg);
  border-color: var(--ink);
}
[data-theme="dark"] .chip.active { background: var(--gold); color: #1A1F2C; border-color: var(--gold); }

/* =========================================================
   FILE CARDS
========================================================= */
.files {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 18px;
}
.file-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 20px 22px;
  background: var(--bg);
  transition: all .25s ease;
  position: relative;
  overflow: hidden;
}
.file-card::before {
  content: "";
  position: absolute; top: 0; left: 0; right: 0; height: 2px;
  background: linear-gradient(90deg, transparent, var(--gold), transparent);
  opacity: 0; transition: opacity .25s;
}
.file-card:hover {
  border-color: var(--gold);
  transform: translateY(-2px);
  box-shadow: var(--shadow-md);
}
.file-card:hover::before { opacity: 1; }

.file-head {
  display: flex; align-items: center; gap: 14px;
  margin-bottom: 16px;
}
.file-icon {
  width: 42px; height: 42px;
  border-radius: 10px;
  border: 1.5px solid var(--gold);
  background: linear-gradient(135deg, rgba(201,169,97,.1), rgba(201,169,97,.02));
  display: grid; place-items: center;
  font-family: var(--font-serif);
  font-weight: 600;
  font-size: 16px;
  color: var(--gold-deep);
  letter-spacing: .5px;
  flex-shrink: 0;
}
[data-theme="dark"] .file-icon { color: var(--gold-deep); }
.file-title { flex: 1; min-width: 0; }
.file-title h3 {
  font-family: var(--font-serif);
  font-weight: 500;
  font-size: 18px;
  margin: 0 0 2px;
  letter-spacing: -.1px;
}
.file-meta {
  font-size: 12px;
  color: var(--ink-mute);
}

.badge {
  font-size: 10.5px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 4px 10px;
  border-radius: 999px;
  white-space: nowrap;
}
.badge-gold { background: rgba(201,169,97,.15); color: var(--gold-deep); border: 1px solid rgba(201,169,97,.4); }
.badge-blue { background: rgba(44,95,124,.12); color: var(--blue); border: 1px solid rgba(44,95,124,.3); }
.badge-green { background: rgba(107,142,90,.13); color: var(--green); border: 1px solid rgba(107,142,90,.35); }
.badge-red { background: rgba(192,72,74,.12); color: var(--red); border: 1px solid rgba(192,72,74,.34); }
.badge-amber { background: rgba(214,149,58,.14); color: var(--amber-deep); border: 1px solid rgba(214,149,58,.36); }
.badge-soft { background: var(--bg-soft); color: var(--ink-soft); border: 1px solid var(--line); }
[data-theme="dark"] .badge-gold { color: var(--gold-deep); }

.file-body {
  border-top: 1px solid var(--green);
  border-bottom: 1px solid var(--green);
  border-image: linear-gradient(90deg, transparent, var(--green-soft), transparent) 1;
  padding: 12px 0;
  margin-bottom: 14px;
}
.kv {
  display: flex; justify-content: space-between;
  padding: 4px 0;
  font-size: 13px;
}
.k { color: var(--ink-mute); }
.v { color: var(--ink); font-weight: 500; }

.file-foot {
  display: flex; justify-content: space-between; align-items: center;
}
.status { display: flex; align-items: center; gap: 8px; font-size: 12.5px; color: var(--ink-soft); }
.dot {
  width: 8px; height: 8px; border-radius: 50%;
  background: var(--ink-mute);
  box-shadow: 0 0 0 3px rgba(0,0,0,.03);
}
.dot-green { background: var(--green); box-shadow: 0 0 0 3px rgba(107,142,90,.18); }
.dot-blue { background: var(--blue); box-shadow: 0 0 0 3px rgba(44,95,124,.18); }
.dot-warn { background: var(--warn); box-shadow: 0 0 0 3px rgba(201,123,61,.18); }
.dot-red { background: var(--red); box-shadow: 0 0 0 3px rgba(192,72,74,.20); }
.dot-amber { background: var(--amber); box-shadow: 0 0 0 3px rgba(214,149,58,.20); }

/* Pastille d'état bien visible à côté du nom du dossier */
.status-dot {
  display: inline-block;
  width: 11px; height: 11px;
  border-radius: 50%;
  flex: 0 0 auto;
  background: var(--ink-mute);
}
.status-dot.dot-green { background: var(--green); box-shadow: 0 0 0 3px rgba(107,142,90,.20); }
.status-dot.dot-red { background: var(--red); box-shadow: 0 0 0 3px rgba(192,72,74,.22); }
.status-dot.dot-amber { background: var(--amber); box-shadow: 0 0 0 3px rgba(214,149,58,.22); }

.link-gold {
  color: var(--gold-deep);
  font-weight: 600;
  font-size: 13px;
  text-decoration: none;
  transition: gap .2s;
  letter-spacing: .2px;
}
.link-gold:hover { color: var(--gold); }
[data-theme="dark"] .link-gold { color: var(--gold-deep); }

/* =========================================================
   TWO COLS (activity + claude)
========================================================= */
.two-cols {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 24px;
}

/* Timeline */
.timeline { list-style: none; padding: 0; margin: 0; }
.timeline li {
  display: flex; gap: 14px;
  padding: 12px 0;
  border-bottom: 1px solid var(--line);
}
.timeline li:last-child { border-bottom: 0; }
.t-dot {
  width: 10px; height: 10px;
  border-radius: 50%;
  background: var(--ink-mute);
  margin-top: 6px;
  flex-shrink: 0;
}
.t-gold { background: var(--gold); box-shadow: 0 0 0 4px rgba(201,169,97,.15); }
.t-green { background: var(--green); box-shadow: 0 0 0 4px rgba(107,142,90,.15); }
.t-blue { background: var(--blue); box-shadow: 0 0 0 4px rgba(44,95,124,.15); }
.t-title { font-size: 13.5px; color: var(--ink); }
.t-title em { font-style: normal; color: var(--gold-deep); font-weight: 600; }
.t-time { font-size: 11.5px; color: var(--ink-mute); margin-top: 2px; }

/* Claude */
.claude-panel { background: linear-gradient(180deg, var(--bg-elev), var(--bg-soft)); }
.claude-input textarea {
  width: 100%;
  min-height: 110px;
  padding: 14px 16px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  color: var(--ink);
  border-radius: var(--radius-sm);
  font-family: inherit;
  font-size: 13.5px;
  resize: vertical;
  outline: none;
  transition: border-color .2s;
  line-height: 1.55;
}
.claude-input textarea:focus { border-color: var(--gold); }
.claude-actions {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 12px;
}
.claude-hint { font-size: 12px; color: var(--ink-mute); }
.suggestions {
  display: flex; flex-wrap: wrap; gap: 8px;
  margin-top: 16px;
}
.suggestion {
  background: var(--bg);
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  padding: 8px 14px;
  font-size: 12.5px;
  color: var(--ink-soft);
  cursor: pointer;
  font-family: inherit;
  transition: all .2s;
}
.suggestion:hover { border-color: var(--gold); color: var(--ink); }

/* =========================================================
   FOOTER
========================================================= */
.footer {
  margin-top: 40px;
  padding-top: 22px;
  border-top: 1px solid var(--green);
  border-image: linear-gradient(90deg, transparent, var(--green), transparent) 1;
  text-align: center;
  font-size: 12px;
  color: var(--ink-mute);
  letter-spacing: .5px;
}

/* =========================================================
   BRIEF FORM PAGE
========================================================= */
.brief-wrap { max-width: 920px; }
.brief-section {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 28px 32px;
  margin-bottom: 22px;
  box-shadow: var(--shadow-sm);
}
.brief-section-title {
  font-family: var(--font-serif);
  font-size: 22px;
  font-weight: 500;
  margin: 0 0 4px;
  display: flex; align-items: center; gap: 12px;
}
.brief-section-title .num {
  width: 30px; height: 30px;
  border: 1.5px solid var(--gold);
  border-radius: 50%;
  display: grid; place-items: center;
  font-size: 13px;
  color: var(--gold-deep);
  font-family: var(--font-sans);
  font-weight: 600;
}
.brief-section-sub {
  color: var(--ink-soft);
  font-size: 13.5px;
  margin: 0 0 22px;
  padding-left: 42px;
}

.field-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px 20px;
}
.field { display: flex; flex-direction: column; }
.field.full { grid-column: 1 / -1; }
.field label {
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--ink-mute);
  margin-bottom: 6px;
  font-weight: 500;
}
.field label .req { color: var(--gold-deep); }
.field input, .field select, .field textarea {
  font-family: inherit;
  font-size: 14px;
  padding: 11px 14px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  color: var(--ink);
  border-radius: var(--radius-sm);
  outline: none;
  transition: border-color .2s, box-shadow .2s;
}
.field input:focus, .field select:focus, .field textarea:focus {
  border-color: var(--gold);
  box-shadow: 0 0 0 3px rgba(201,169,97,.15);
}
.field textarea { min-height: 90px; resize: vertical; line-height: 1.5; }
.field-hint { font-size: 11.5px; color: var(--ink-mute); margin-top: 4px; }

.checkgroup {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(220px, 1fr));
  gap: 10px;
}
.checkitem {
  display: flex; align-items: center; gap: 10px;
  padding: 10px 14px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--bg);
  cursor: pointer;
  font-size: 13.5px;
  transition: all .2s;
}
.checkitem:hover { border-color: var(--gold); }
.checkitem input { accent-color: var(--gold); }
.checkitem.checked { border-color: var(--gold); background: rgba(201,169,97,.06); }

.brief-bar {
  display: flex; justify-content: space-between; align-items: center;
  margin-top: 24px;
}
.brief-progress {
  display: flex; align-items: center; gap: 12px;
  font-size: 13px; color: var(--ink-soft);
}
.bar {
  width: 180px; height: 6px;
  background: var(--bg-soft);
  border-radius: 4px;
  overflow: hidden;
}
.bar-fill { height: 100%; background: linear-gradient(90deg, var(--green), var(--gold)); width: 60%; }

/* =========================================================
   RESPONSIVE
========================================================= */
@media (max-width: 1100px) {
  body { grid-template-columns: 1fr; }
  .sidebar {
    position: relative; height: auto;
    flex-direction: row; flex-wrap: wrap;
    padding: 16px 20px;
    gap: 8px;
  }
  .brand { border: 0; padding: 0; margin: 0 16px 0 0; }
  .nav { flex-direction: row; flex-wrap: wrap; gap: 4px; }
  .nav-item span { display: none; }
  .nav-item.active::before { display: none; }
  .nav-divider { display: none; }
  .user-card { margin-left: auto; margin-top: 0; }
  .main { padding: 24px 22px 40px; }
  .stats { grid-template-columns: repeat(2, 1fr); }
  .files { grid-template-columns: 1fr; }
  .two-cols { grid-template-columns: 1fr; }
}

@media (max-width: 640px) {
  .topbar { flex-direction: column; align-items: stretch; }
  .topbar-actions { flex-wrap: wrap; }
  .search { width: 100%; }
  .page-title { font-size: 30px; }
  .stats { grid-template-columns: 1fr 1fr; gap: 12px; }
  .stat-value { font-size: 30px; }
  .field-grid { grid-template-columns: 1fr; }
  .filters { flex-wrap: wrap; }
  .user-info { display: none; }
}


/* =========================================================
   BREADCRUMB
========================================================= */
.breadcrumb {
  display: flex; align-items: center; gap: 8px;
  font-size: 12px; color: var(--ink-mute);
  margin-bottom: 10px;
  letter-spacing: .3px;
}
.breadcrumb a {
  color: var(--ink-mute);
  text-decoration: none;
  transition: color .15s;
}
.breadcrumb a:hover { color: var(--gold-deep); }
.breadcrumb .sep { color: var(--line-strong); }
.breadcrumb .current { color: var(--ink); font-weight: 500; }

/* file-card now an <a> */
a.file-card { text-decoration: none; color: inherit; display: block; }

/* =========================================================
   FOLDER PAGE — info grid + doc list
========================================================= */
.info-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px 28px;
}
.info-cell { padding: 6px 0; border-bottom: 1px solid var(--green); border-image: linear-gradient(90deg, var(--green-soft), transparent) 1; }
.info-cell .k { font-size: 11px; text-transform: uppercase; letter-spacing: 1px; color: var(--ink-mute); margin-bottom: 4px; }
.info-cell .v { font-size: 14.5px; color: var(--ink); font-weight: 500; }

.doc-list { display: flex; flex-direction: column; gap: 10px; }
.doc-row {
  display: grid;
  grid-template-columns: 36px 40px 1fr auto auto;
  align-items: center;
  gap: 16px;
  padding: 14px 18px;
  border: 1px solid var(--line);
  border-radius: var(--radius-sm);
  background: var(--bg);
  text-decoration: none;
  color: inherit;
  transition: all .2s ease;
}
.doc-row:hover {
  border-color: var(--gold);
  transform: translateX(2px);
  box-shadow: var(--shadow-sm);
}
.doc-row.featured { border-color: var(--gold); background: linear-gradient(90deg, rgba(201,169,97,.06), transparent 60%); }
.doc-num {
  font-family: var(--font-serif);
  font-size: 18px;
  color: var(--gold-deep);
  font-weight: 500;
  text-align: center;
}
.doc-icon {
  width: 40px; height: 40px;
  border: 1px solid var(--green);
  border-radius: 8px;
  display: grid; place-items: center;
  color: var(--green);
  background: rgba(107,142,90,.05);
}
.doc-icon svg { width: 18px; height: 18px; }
.doc-info { min-width: 0; }
.doc-title { font-weight: 600; font-size: 14.5px; color: var(--ink); margin-bottom: 2px; }
.doc-meta { font-size: 12px; color: var(--ink-mute); }
.doc-actions .link-gold { font-size: 13px; }

/* =========================================================
   DOCUMENT VIEWER
========================================================= */
.viewer-body { background: var(--bg-soft); }
[data-theme="dark"] .viewer-body { background: #08101D; }

.viewer-layout {
  display: grid;
  grid-template-columns: 1fr 320px;
  gap: 28px;
  align-items: flex-start;
}

.page-wrap { display: flex; justify-content: center; }

/* === Bichromie du document (or + bleu par défaut, modifiable) === */
.doc-page {
  /* PRIMARY  — cadres, filets, info-row, "ET" */
  --doc-accent:        #C9A961;
  --doc-accent-deep:   #9E8442;
  --doc-accent-rgb:    201,169,97;
  /* SECONDARY — logo, sous-titre, italiques, labels, signatures */
  --doc-accent-2:      #2C5F7C;
  --doc-accent-2-deep: #1E4660;
  --doc-accent-2-rgb:  44,95,124;
  /* Filet d'en-tête / h2 = couleur primaire par défaut */
  --doc-rule:          var(--doc-accent);

  background: #FFFFFF;
  color: #1A1F2C;
  width: 100%;
  max-width: 820px;
  padding: 56px 64px 48px;
  border-radius: 4px;
  box-shadow: var(--shadow-lg);
  font-family: "Cormorant Garamond", Georgia, serif;
  font-size: 15px;
  line-height: 1.6;
  border-top: 4px solid var(--doc-accent);
}

/* ——— Duos prêts ——— */
/* Or & Bleu = défaut (déjà déclaré ci-dessus) */

.doc-page[data-duo="bleu-or"] {
  --doc-accent:        #2C5F7C;
  --doc-accent-deep:   #1E4660;
  --doc-accent-rgb:    44,95,124;
  --doc-accent-2:      #C9A961;
  --doc-accent-2-deep: #9E8442;
  --doc-accent-2-rgb:  201,169,97;
}
.doc-page[data-duo="or-emeraude"] {
  --doc-accent:        #C9A961;
  --doc-accent-deep:   #9E8442;
  --doc-accent-rgb:    201,169,97;
  --doc-accent-2:      #2F6B4F;
  --doc-accent-2-deep: #1F4A36;
  --doc-accent-2-rgb:  47,107,79;
}
.doc-page[data-duo="bordeaux-or"] {
  --doc-accent:        #7A2E3A;
  --doc-accent-deep:   #5C1F29;
  --doc-accent-rgb:    122,46,58;
  --doc-accent-2:      #C9A961;
  --doc-accent-2-deep: #9E8442;
  --doc-accent-2-rgb:  201,169,97;
}
.doc-page[data-duo="bleu-anthracite"] {
  --doc-accent:        #2C5F7C;
  --doc-accent-deep:   #1E4660;
  --doc-accent-rgb:    44,95,124;
  --doc-accent-2:      #3D4350;
  --doc-accent-2-deep: #25292F;
  --doc-accent-2-rgb:  61,67,80;
}
.doc-page[data-duo="or-uni"] {
  --doc-accent:        #C9A961;
  --doc-accent-deep:   #9E8442;
  --doc-accent-rgb:    201,169,97;
  --doc-accent-2:      #9E8442;
  --doc-accent-2-deep: #6B5A2D;
  --doc-accent-2-rgb:  158,132,66;
}
.doc-page[data-duo="bleu-uni"] {
  --doc-accent:        #2C5F7C;
  --doc-accent-deep:   #1E4660;
  --doc-accent-rgb:    44,95,124;
  --doc-accent-2:      #1E4660;
  --doc-accent-2-deep: #14313F;
  --doc-accent-2-rgb:  30,70,96;
}

[data-theme="dark"] .doc-page {
  background: #F8F4EA;
  color: #1A1F2C;
}

.doc-header {
  display: flex; justify-content: space-between; align-items: baseline;
  padding-bottom: 14px;
  border-bottom: 1.5px solid var(--doc-rule);
  margin-bottom: 32px;
}
.doc-logo {
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  font-weight: 600;
  letter-spacing: 4px;
  color: var(--doc-accent-2-deep);
}
.doc-ref { font-family: "Inter", sans-serif; font-size: 11px; color: #5B6473; letter-spacing: 1px; text-transform: uppercase; }

.doc-h1 {
  font-family: "Cormorant Garamond", serif;
  font-size: 30px;
  font-weight: 600;
  text-align: center;
  margin: 0 0 6px;
  letter-spacing: 1px;
  color: #1A1F2C;
}
.doc-subtitle {
  text-align: center;
  font-family: "Inter", sans-serif;
  font-size: 12px;
  text-transform: uppercase;
  letter-spacing: 3px;
  color: var(--doc-accent-2-deep);
  margin-bottom: 36px;
}

.doc-gold-frame {
  border: 1.5px solid var(--doc-accent);
  border-radius: 2px;
  padding: 24px 28px;
  margin-bottom: 36px;
  background: linear-gradient(180deg, rgba(var(--doc-accent-rgb),.05), transparent);
  position: relative;
}
.doc-gold-frame::before, .doc-gold-frame::after {
  content: ""; position: absolute;
  width: 14px; height: 14px;
  border: 1.5px solid var(--doc-accent);
}
.doc-gold-frame::before { top: -7px; left: -7px; border-right: 0; border-bottom: 0; }
.doc-gold-frame::after { bottom: -7px; right: -7px; border-left: 0; border-top: 0; }

.doc-frame-row {
  display: grid;
  grid-template-columns: 1fr auto 1fr;
  gap: 24px;
  align-items: center;
}
.doc-frame-label {
  font-family: "Inter", sans-serif;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--doc-accent-2);
  margin-bottom: 4px;
}
.doc-frame-name {
  font-size: 19px;
  font-weight: 600;
  color: #1A1F2C;
  margin-bottom: 6px;
}
.doc-frame-line { font-family: "Inter", sans-serif; font-size: 12.5px; color: #5B6473; line-height: 1.5; }
.doc-frame-tag {
  font-family: "Inter", sans-serif;
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--doc-accent-2-deep);
  margin-top: 8px;
  font-style: italic;
}
.doc-frame-sep {
  font-family: "Cormorant Garamond", serif;
  font-size: 22px;
  color: var(--doc-accent);
  font-style: italic;
  text-align: center;
}

.doc-h2 {
  font-family: "Cormorant Garamond", serif;
  font-size: 18px;
  font-weight: 600;
  color: #1A1F2C;
  margin: 28px 0 10px;
  padding-bottom: 6px;
  border-bottom: 1px solid var(--doc-rule);
  letter-spacing: .3px;
}
.doc-p { font-family: "Inter", sans-serif; font-size: 13px; line-height: 1.7; color: #2A3142; margin: 0 0 10px; }
.doc-ul { font-family: "Inter", sans-serif; font-size: 13px; line-height: 1.7; color: #2A3142; margin: 0 0 12px; padding-left: 20px; }
.doc-ul li { margin-bottom: 4px; }
.doc-p em, .doc-ul em { color: var(--doc-accent-2-deep); font-style: italic; font-weight: 500; }

.doc-info-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 18px;
  padding: 14px 18px;
  background: rgba(var(--doc-accent-rgb),.06);
  border-left: 3px solid var(--doc-accent);
  margin: 10px 0 16px;
}
.doc-info-row .k { font-family: "Inter", sans-serif; font-size: 10.5px; text-transform: uppercase; letter-spacing: 1.5px; color: var(--doc-accent-2); margin-bottom: 4px; }
.doc-info-row .v { font-family: "Cormorant Garamond", serif; font-size: 18px; font-weight: 500; color: #1A1F2C; }
.doc-info-row .v.placeholder {
  color: #C97B3D;
  font-family: "Inter", sans-serif;
  font-size: 13px;
  font-style: italic;
  background: rgba(201,123,61,.1);
  padding: 2px 8px;
  border-radius: 4px;
  display: inline-block;
}

.doc-signatures {
  display: grid; grid-template-columns: 1fr 1fr; gap: 40px;
  margin-top: 48px;
  padding-top: 24px;
  border-top: 1px solid #E8E2D4;
}
.sig-block { display: flex; flex-direction: column; }
.sig-label {
  font-family: "Inter", sans-serif;
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 2px;
  color: var(--doc-accent-2-deep);
  margin-bottom: 4px;
}
.sig-name { font-size: 16px; font-weight: 600; color: #1A1F2C; margin-bottom: 60px; }
.sig-line { height: 1px; background: #1A1F2C; margin-bottom: 8px; }
.sig-meta { font-family: "Inter", sans-serif; font-size: 11px; color: #5B6473; }

.doc-footer {
  display: flex; justify-content: space-between;
  margin-top: 40px;
  padding-top: 14px;
  border-top: 1px solid #E8E2D4;
  font-family: "Inter", sans-serif;
  font-size: 10.5px;
  letter-spacing: 1px;
  color: #8B93A1;
  text-transform: uppercase;
}

/* Right viewer side */
.viewer-side { display: flex; flex-direction: column; gap: 18px; position: sticky; top: 30px; }
.side-panel {
  background: var(--bg-elev);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  padding: 18px 20px;
  box-shadow: var(--shadow-sm);
}
.side-panel.warn { border-color: rgba(201,123,61,.4); background: linear-gradient(180deg, rgba(201,123,61,.05), var(--bg-elev)); }
.side-title {
  font-family: var(--font-serif);
  font-size: 16px;
  font-weight: 500;
  margin: 0 0 14px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--green);
  color: var(--ink);
}
.side-grid { display: grid; grid-template-columns: 1fr 1fr; gap: 12px 16px; }
.side-grid .k { font-size: 10.5px; text-transform: uppercase; letter-spacing: 1px; color: var(--ink-mute); margin-bottom: 2px; }
.side-grid .v { font-size: 13px; color: var(--ink); font-weight: 500; display: flex; align-items: center; gap: 6px; }

.todo { list-style: none; padding: 0; margin: 0; display: flex; flex-direction: column; gap: 8px; }
.todo li { display: flex; align-items: flex-start; gap: 10px; font-size: 13px; color: var(--ink-soft); }
.todo-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--warn); margin-top: 7px; flex-shrink: 0; }

.pager { display: flex; align-items: center; justify-content: space-between; gap: 8px; }
.pager-btn {
  font-family: inherit;
  font-size: 12px;
  padding: 7px 12px;
  border: 1px solid var(--line);
  background: var(--bg);
  color: var(--ink-soft);
  border-radius: 6px;
  cursor: pointer;
  transition: all .2s;
}
.pager-btn:hover { border-color: var(--gold); color: var(--ink); }
.pager-info { font-size: 12px; color: var(--ink-mute); }

.side-textarea {
  width: 100%;
  min-height: 80px;
  padding: 10px 12px;
  border: 1px solid var(--line-strong);
  background: var(--bg);
  color: var(--ink);
  border-radius: 8px;
  font-family: inherit;
  font-size: 13px;
  resize: vertical;
  outline: none;
  box-sizing: border-box;
}
.side-textarea:focus { border-color: var(--gold); }

/* === Sélecteur de couleur du document (duos bichromes) === */
.accent-swatches { display: flex; flex-wrap: wrap; gap: 10px; }
.accent-swatch {
  width: 38px; height: 38px;
  border-radius: 50%;
  cursor: pointer;
  border: 2px solid var(--bg-elev);
  box-shadow: 0 0 0 1px var(--line-strong), inset 0 1px 2px rgba(0,0,0,.15);
  transition: transform .18s ease, box-shadow .18s ease;
  position: relative;
  padding: 0;
  overflow: hidden;
  /* split bichrome : moitié gauche = primaire, moitié droite = secondaire */
  background: linear-gradient(90deg, var(--sw-1, #C9A961) 0 50%, var(--sw-2, #2C5F7C) 50% 100%);
}
.accent-swatch:hover { transform: translateY(-2px); }
.accent-swatch.is-active { box-shadow: 0 0 0 2px var(--ink), 0 0 0 4px var(--bg-elev); }
.accent-swatch.is-active::after {
  content: ""; position: absolute; inset: 50% 0 0 50%;
  width: 10px; height: 6px;
  border-left: 2px solid #fff; border-bottom: 2px solid #fff;
  transform: translate(-50%, -80%) rotate(-45deg);
  pointer-events: none;
  filter: drop-shadow(0 0 1px rgba(0,0,0,.4));
}
.accent-label {
  font-family: "Inter", sans-serif;
  font-size: 11.5px;
  color: var(--ink-soft);
  margin-top: 12px;
  letter-spacing: .3px;
}
.accent-label strong { color: var(--ink); font-weight: 600; }

/* === Impression : couleurs exactes + masque l'UI === */
@media print {
  body, .viewer-body { background: #FFFFFF !important; }
  .sidebar, .topbar, .viewer-side, .footer { display: none !important; }
  .main, .viewer-main, .viewer-layout { display: block !important; margin: 0 !important; padding: 0 !important; }
  .page-wrap { display: block !important; }
  .doc-page {
    box-shadow: none !important;
    max-width: 100% !important;
    padding: 24mm 22mm !important;
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
    color-adjust: exact;
  }
  .doc-page * {
    -webkit-print-color-adjust: exact;
    print-color-adjust: exact;
  }
}

@media (max-width: 1100px) {
  .viewer-layout { grid-template-columns: 1fr; }
  .viewer-side { position: static; }
  .doc-page { padding: 36px 28px; }
  .info-grid { grid-template-columns: 1fr 1fr; }
  .doc-row { grid-template-columns: 30px 36px 1fr auto; }
  .doc-row .doc-actions { display: none; }
}
@media (max-width: 640px) {
  .doc-page { padding: 24px 18px; font-size: 13px; }
  .doc-h1 { font-size: 22px; }
  .doc-frame-row { grid-template-columns: 1fr; gap: 16px; }
  .doc-frame-sep { display: none; }
  .doc-signatures { grid-template-columns: 1fr; gap: 24px; }
  .info-grid { grid-template-columns: 1fr; }
  .doc-info-row { grid-template-columns: 1fr; }
}


/* === Brief form — texte saisi en bleu profond pour s'accorder au doré === */
.field input, .field select, .field textarea {
  color: var(--blue);
  font-weight: 500;
}
.field input::placeholder, .field textarea::placeholder {
  color: var(--ink-mute);
  font-weight: 400;
}
[data-theme="dark"] .field input,
[data-theme="dark"] .field select,
[data-theme="dark"] .field textarea {
  color: var(--blue);
}

/* Toast */
.toast{position:fixed;bottom:24px;left:50%;transform:translateX(-50%) translateY(20px);background:var(--ink,#0E1420);color:#FBF8F3;padding:12px 22px;border-radius:10px;font-size:14px;font-family:'Inter',sans-serif;box-shadow:0 12px 36px rgba(0,0,0,.28);border:1px solid rgba(201,169,97,.35);opacity:0;pointer-events:none;transition:opacity .25s ease,transform .25s ease;z-index:9999;max-width:480px;text-align:center}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0)}
.saved-badge{display:inline-block;margin-left:12px;font-size:12.5px;font-weight:600;color:var(--green,#3a8a4f);background:rgba(58,138,79,.10);border:1px solid rgba(58,138,79,.30);border-radius:999px;padding:2px 10px;vertical-align:middle;opacity:0;transform:translateY(-2px);transition:opacity .3s ease,transform .3s ease}
.saved-badge.saved-badge-show{opacity:1;transform:translateY(0)}


.claude-chat{display:flex;flex-direction:column;gap:8px;max-height:340px;overflow-y:auto;padding:14px;margin-bottom:14px;background:rgba(201,169,97,.06);border:1px solid rgba(201,169,97,.18);border-radius:12px}
.claude-msg{padding:10px 14px;border-radius:12px;font-size:14px;line-height:1.45;max-width:88%;font-family:'Inter',sans-serif}
.claude-msg.user{align-self:flex-end;background:#0E1420;color:#FBF8F3;border-bottom-right-radius:4px}
.claude-msg.bot{align-self:flex-start;background:#FBF8F3;color:#0E1420;border:1px solid rgba(14,20,32,.08);border-bottom-left-radius:4px}
[data-theme='dark'] .claude-msg.bot{background:#1B2230;color:#FBF8F3;border-color:rgba(201,169,97,.18)}
.claude-msg.thinking{font-style:italic;opacity:.7}

/* === Modal g�n�rique === */
.modal-overlay{position:fixed;inset:0;background:rgba(15,20,30,.55);display:flex;align-items:center;justify-content:center;z-index:10000;opacity:0;transition:opacity .18s ease;padding:20px;}
.modal-overlay.open{opacity:1;}
.modal-card{background:var(--bg-elev);border-radius:14px;border:1px solid var(--line);box-shadow:0 24px 60px rgba(0,0,0,.35);width:100%;max-width:520px;max-height:92vh;overflow:auto;font-family:'Inter',sans-serif;color:var(--ink);}
.modal-head{display:flex;justify-content:space-between;align-items:center;padding:18px 22px;border-bottom:1px solid var(--line);}
.modal-head h3{margin:0;font-family:'Cormorant Garamond',serif;font-size:20px;font-weight:600;color:var(--ink);}
.modal-x{background:none;border:none;font-size:24px;line-height:1;cursor:pointer;color:var(--ink-mute);padding:0 6px;}
.modal-x:hover{color:var(--ink);}
.modal-body{padding:20px 22px;}
.modal-field{margin-bottom:14px;}
.modal-field label{display:block;font-size:12px;color:var(--ink-soft);margin-bottom:6px;letter-spacing:.3px;}
.modal-field input,.modal-field select,.modal-field textarea{width:100%;padding:10px 12px;border:1px solid var(--line-strong);background:var(--bg);color:var(--ink);border-radius:8px;font-family:inherit;font-size:13.5px;box-sizing:border-box;outline:none;}
.modal-field input:focus,.modal-field select:focus,.modal-field textarea:focus{border-color:var(--gold);}
.modal-field textarea{resize:vertical;min-height:80px;font-family:inherit;}
.modal-hint{font-size:12px;color:var(--ink-mute);margin-top:4px;}
.modal-foot{display:flex;justify-content:flex-end;gap:10px;padding:14px 22px 18px;border-top:1px solid var(--line);}
.toast.show{opacity:1;transform:translateX(-50%) translateY(0);pointer-events:auto;}

/* ===== États vides (site vierge) ===== */
.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:56px 24px;color:var(--ink-soft);}
.empty-state .empty-icon{width:64px;height:64px;border-radius:16px;border:1.5px solid var(--line-strong);display:flex;align-items:center;justify-content:center;margin-bottom:18px;color:var(--gold);}
.empty-state .empty-icon svg{width:30px;height:30px;}
.empty-state h3{font-family:var(--font-serif);font-size:22px;color:var(--ink);margin:0 0 8px;font-weight:500;}
.empty-state p{font-size:14.5px;color:var(--ink-soft);margin:0 0 22px;max-width:380px;line-height:1.55;}
.empty-state .btn-primary{display:inline-flex;align-items:center;gap:8px;text-decoration:none;}
.timeline-empty{opacity:.7;}
.timeline-empty .t-title{color:var(--ink-soft);font-style:italic;}
