/* ── Imports ─────────────────────────────────────────── */
@import url('https://fonts.googleapis.com/css2?family=Fraunces:ital,opsz,wght@0,9..144,300;0,9..144,400;1,9..144,300;1,9..144,400;1,9..144,500&family=Playfair+Display:ital,wght@0,400;0,600;0,700;1,400;1,600&family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;1,9..40,300;1,9..40,400&family=DM+Mono:wght@400;500&display=swap');

/* ── Design Tokens ───────────────────────────────────── */
:root {
  /* Palette — Papier & Ambre */
  --cream:     #f7f3ec;
  --cream2:    #f0ead8;
  --ink:       #1e1a15;
  --ink2:      #3a342c;
  --ink3:      #6b6055;
  --ink4:      #a39080;
  --ink5:      #c8bfb2;

  /* Legacy aliases — keep JS/CSS working */
  --charcoal:  #1e1a15;
  --charcoal2: #3a342c;
  --charcoal3: #6b6055;
  --ivory:     #f7f3ec;
  --ivory2:    #f0ead8;
  --ivory3:    #ede7dc;
  --paper:     #ede7dc;
  --mist:      #a39080;
  --mist2:     #c8bfb2;
  --smoke:     #ddd5c8;

  /* Accent — ambre chaud */
  --gold:      #b8843a;
  --gold-deep: #8a6020;
  --gold-pale: #f5ecd8;
  --gold-glow: rgba(184,132,58,.18);
  --amber:     #b8843a;

  /* Status colours */
  --rust:      #b54a3a;
  --sage:      #4a7a55;
  --blue:      #3a5a8a;

  /* Priority borders */
  --prio-urgent:  #b54a3a;
  --prio-waiting: #b8843a;
  --prio-info:    #3a5a8a;

  /* Spacing */
  --r-sm: 6px;
  --r:    10px;
  --r-lg: 14px;
  --r-xl: 20px;

  /* Shadows — light */
  --s-card:   0 0.5px 0 rgba(0,0,0,.06), 0 2px 12px rgba(0,0,0,.06);
  --s-lifted: 0 1px 0 rgba(0,0,0,.08), 0 8px 28px rgba(0,0,0,.1);
  --s-modal:  0 0 0 0.5px rgba(0,0,0,.1), 0 16px 48px rgba(0,0,0,.18);

  /* Sidebar — icon strip */
  --sidebar-w: 44px;
  --sidebar-expanded: 220px;

  /* Aliases génériques utilisés dans composants dynamiques */
  --surface2:   #f0ead8;
  --border:     #ddd5c8;
  --text:       #1e1a15;
  --text-muted: #a39080;
  --success:    #4a7a55;
}

/* ── Reset & Base ────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

html { scroll-behavior: smooth; }

body {
  font-family: 'DM Sans', sans-serif;
  font-size: 14px;
  line-height: 1.6;
  background: #e8e2d8;
  color: var(--ink);
  -webkit-font-smoothing: antialiased;
  overflow: hidden;
  height: 100vh;
}

/* Paper texture overlay */
body::before {
  content: '';
  position: fixed;
  inset: 0;
  background-image: url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)' opacity='0.025'/%3E%3C/svg%3E");
  pointer-events: none;
  z-index: 9999;
  opacity: .6;
}

input, textarea, select, button { font-family: 'DM Sans', sans-serif; }
button { cursor: pointer; border: none; background: none; color: inherit; }
a { color: inherit; text-decoration: none; }

/* ── Scrollbar ───────────────────────────────────────── */
::-webkit-scrollbar { width: 4px; height: 4px; }
::-webkit-scrollbar-track { background: transparent; }
::-webkit-scrollbar-thumb { background: var(--smoke); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: var(--mist2); }

/* ══════════════════════════════════════════════════════
   AUTH SCREEN
══════════════════════════════════════════════════════ */
#auth-screen {
  min-height: 100vh;
  display: flex;
  align-items: center;
  justify-content: center;
  padding: 24px;
  position: relative;
  overflow: hidden;
  background: var(--charcoal);
}

/* Decorative background */
#auth-screen::before {
  content: '';
  position: absolute;
  inset: 0;
  background:
    radial-gradient(ellipse 80% 60% at 20% 40%, rgba(200,169,110,.08) 0%, transparent 60%),
    radial-gradient(ellipse 60% 80% at 80% 70%, rgba(200,169,110,.05) 0%, transparent 60%);
}

#auth-screen::after {
  content: '';
  position: absolute;
  top: -40%;
  right: -20%;
  width: 700px;
  height: 700px;
  border-radius: 50%;
  border: 1px solid rgba(200,169,110,.08);
  pointer-events: none;
}

.auth-decorative-ring {
  position: absolute;
  top: -60%;
  right: -30%;
  width: 900px;
  height: 900px;
  border-radius: 50%;
  border: 1px solid rgba(200,169,110,.04);
  pointer-events: none;
}

.auth-card {
  background: var(--paper);
  border-radius: var(--r-xl);
  padding: 48px 44px;
  width: 100%;
  max-width: 420px;
  box-shadow: var(--s-modal);
  position: relative;
  z-index: 2;
  animation: authFadeUp .5s ease both;
}

@keyframes authFadeUp {
  from { opacity: 0; transform: translateY(20px); }
  to   { opacity: 1; transform: translateY(0); }
}

/* Claire monogram seal */
.auth-seal {
  width: 72px;
  height: 72px;
  margin: 0 auto 20px;
  position: relative;
  display: flex;
  align-items: center;
  justify-content: center;
}

.auth-seal::before {
  content: '';
  position: absolute;
  inset: 0;
  border-radius: 50%;
  background: radial-gradient(circle, var(--gold-pale) 0%, rgba(200,169,110,.15) 100%);
  animation: sealPulse 3s ease-in-out infinite;
}

@keyframes sealPulse {
  0%, 100% { transform: scale(1); opacity: 1; }
  50%       { transform: scale(1.08); opacity: .7; }
}

.auth-seal-inner {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: var(--charcoal);
  display: flex;
  align-items: center;
  justify-content: center;
  position: relative;
  z-index: 1;
  box-shadow: 0 0 0 2px var(--gold), 0 4px 20px rgba(200,169,110,.3);
}

.auth-seal-letter {
  font-family: 'Playfair Display', serif;
  font-size: 26px;
  font-style: italic;
  color: var(--gold);
  line-height: 1;
  margin-top: -2px;
}

.auth-title {
  font-family: 'Playfair Display', serif;
  font-size: 32px;
  font-weight: 700;
  text-align: center;
  color: var(--charcoal);
  letter-spacing: -.02em;
  line-height: 1.1;
}

.auth-ai-badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: var(--charcoal);
  color: var(--gold);
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  padding: 5px 12px;
  border-radius: 20px;
  margin: 10px auto 8px;
}

.auth-ai-badge .badge-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
  animation: badgeBlink 2s ease-in-out infinite;
}

@keyframes badgeBlink {
  0%, 100% { opacity: 1; }
  50%       { opacity: .3; }
}

.auth-subtitle {
  text-align: center;
  color: var(--mist);
  font-size: 13px;
  margin-bottom: 28px;
  line-height: 1.5;
}

/* Tab row */
.tab-row {
  display: flex;
  gap: 0;
  background: var(--ivory2);
  border-radius: var(--r-sm);
  padding: 3px;
  margin-bottom: 22px;
  border: 1px solid var(--smoke);
}

.tab-btn {
  flex: 1;
  padding: 8px;
  border-radius: 4px;
  color: var(--mist);
  font-size: 13px;
  font-weight: 500;
  transition: all .2s;
}

.tab-btn.active {
  background: var(--paper);
  color: var(--charcoal);
  font-weight: 600;
  box-shadow: 0 1px 4px rgba(0,0,0,.08);
}

/* Form inputs */
.auth-card input[type="text"],
.auth-card input[type="password"] {
  display: block;
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  margin-bottom: 10px;
  background: var(--ivory);
  color: var(--ink);
  font-size: 14px;
  transition: border-color .2s, background .2s;
}

.auth-card input:focus {
  outline: none;
  border-color: var(--gold);
  background: var(--paper);
}

.auth-card input::placeholder { color: var(--mist2); }

/* ── Password toggle (œil) ──────────────────────────── */
.pwd-wrap {
  position: relative;
  margin-bottom: 10px;
}
.pwd-wrap input[type="password"],
.pwd-wrap input[type="text"] {
  margin-bottom: 0;
  padding-right: 42px;
  width: 100%;
}
.pwd-eye {
  position: absolute;
  right: 0;
  top: 0;
  height: 100%;
  width: 40px;
  background: none;
  border: none;
  cursor: pointer;
  font-size: 15px;
  color: var(--ink3);
  opacity: 0.6;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: opacity .15s;
}
.pwd-eye:hover { opacity: 1; }

/* ── Remember me ────────────────────────────────────── */
.remember-me {
  display: flex;
  align-items: center;
  gap: 7px;
  font-size: 0.84rem;
  color: var(--ink3);
  cursor: pointer;
  margin: 4px 0 10px;
  user-select: none;
}
.remember-me input[type="checkbox"] {
  width: 15px;
  height: 15px;
  accent-color: var(--gold-deep, #8a6020);
  cursor: pointer;
  margin: 0;
}

/* ── Buttons ─────────────────────────────────────────── */
.btn-primary {
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  width: 100%;
  padding: 12px;
  background: var(--charcoal);
  color: var(--gold);
  border-radius: var(--r-sm);
  font-weight: 600;
  font-size: 14px;
  letter-spacing: .01em;
  transition: all .2s;
  border: 1px solid transparent;
  margin-top: 4px;
}

.btn-primary:hover {
  background: var(--charcoal2);
  box-shadow: 0 4px 20px rgba(0,0,0,.2);
}

.btn-action {
  padding: 8px 16px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  color: var(--ink);
  background: var(--paper);
  font-size: 13px;
  transition: all .18s;
}

.btn-action:hover {
  border-color: var(--gold);
  color: var(--gold-deep);
  background: var(--gold-pale);
}

.btn-action.btn-primary {
  background: var(--charcoal);
  color: var(--gold);
  border-color: var(--charcoal);
}

.btn-action.btn-primary:hover {
  background: var(--charcoal2);
}

.btn-logout {
  padding: 5px 10px;
  border: 1px solid rgba(255,255,255,.1);
  border-radius: var(--r-sm);
  color: var(--mist);
  font-size: 12px;
  transition: all .2s;
}

.btn-logout:hover { color: var(--rust); border-color: var(--rust); }

.btn-small {
  padding: 4px 10px;
  border: 1px solid var(--gold);
  border-radius: var(--r-sm);
  color: var(--gold-deep);
  font-size: 12px;
  background: var(--gold-pale);
  font-weight: 500;
  transition: all .15s;
}

.btn-small:hover { background: var(--charcoal); color: var(--gold); }

.btn-send {
  width: 44px;
  height: 44px;
  background: var(--charcoal);
  color: var(--gold);
  border-radius: var(--r);
  font-size: 17px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .2s;
}

.btn-send:hover {
  background: var(--charcoal2);
  box-shadow: 0 4px 16px rgba(0,0,0,.2);
}

/* ══════════════════════════════════════════════════════
   APP LAYOUT
══════════════════════════════════════════════════════ */
#app-screen {
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
  position: relative;
  background: var(--cream);
}

/* ══════════════════════════════════════════════════════
   SIDEBAR
══════════════════════════════════════════════════════ */
#sidebar {
  width: var(--sidebar-w);
  background: #130f0a;
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  z-index: 300;
  transition: width .28s cubic-bezier(.4,0,.2,1), box-shadow .28s;
  position: absolute;
  top: 0; left: 0; bottom: 0;
  overflow: hidden;
}

#sidebar:hover, #sidebar.open {
  width: var(--sidebar-expanded);
  box-shadow: 6px 0 40px rgba(0,0,0,.6);
}

/* Spacer so main doesn't go under sidebar */
#app-screen::before {
  content: '';
  width: var(--sidebar-w);
  grid-column: 1;
  grid-row: 1;
}

/* Sidebar subtle gradient */
#sidebar::before {
  content: '';
  position: absolute;
  bottom: 0;
  left: 0;
  right: 0;
  height: 200px;
  background: linear-gradient(to top, rgba(200,169,110,.04), transparent);
  pointer-events: none;
}

.sidebar-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 18px 0 14px;
  border-bottom: 1px solid rgba(255,255,255,.06);
  justify-content: center;
  flex-shrink: 0;
}

#sidebar:hover .sidebar-header, #sidebar.open .sidebar-header {
  padding: 18px 18px 14px;
  justify-content: flex-start;
}

.sidebar-brand {
  display: flex;
  align-items: center;
  gap: 10px;
  flex: 1;
}

/* Small seal in sidebar */
.sidebar-seal {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--charcoal2);
  border: 1.5px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  box-shadow: 0 0 12px var(--gold-glow);
}

.sidebar-seal-letter {
  font-family: 'Playfair Display', serif;
  font-size: 13px;
  font-style: italic;
  color: var(--gold);
  line-height: 1;
}

.sidebar-brand-text { display: flex; flex-direction: column; gap: 1px; }

.sidebar-title {
  font-family: 'Playfair Display', serif;
  font-size: 15px;
  font-weight: 700;
  color: rgba(255,255,255,.9);
  letter-spacing: -.01em;
  line-height: 1;
  white-space: nowrap;
  opacity: 0;
  transition: opacity .2s .05s;
}

#sidebar:hover .sidebar-title, #sidebar.open .sidebar-title {
  opacity: 1;
}

.ai-tag {
  display: inline-block;
  background: var(--gold);
  color: var(--charcoal);
  font-size: 8px;
  font-weight: 800;
  letter-spacing: .1em;
  padding: 1px 5px;
  border-radius: 3px;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  vertical-align: middle;
  margin-left: 4px;
}

.sidebar-subtitle {
  font-size: 10px;
  color: var(--gold);
  letter-spacing: .08em;
  text-transform: uppercase;
  opacity: .7;
  font-family: 'DM Mono', monospace;
}

.sidebar-close {
  display: none;
  color: var(--mist);
  font-size: 18px;
  padding: 4px;
  line-height: 1;
}

/* Sections */
.sidebar-section {
  padding: 16px 0;
  border-bottom: 1px solid rgba(255,255,255,.06);
}

.sidebar-label {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .12em;
  text-transform: uppercase;
  color: rgba(255,255,255,.45);
  padding: 0 18px;
  margin-bottom: 6px;
  font-family: 'DM Mono', monospace;
  white-space: nowrap;
  opacity: 0;
  height: 0;
  overflow: hidden;
  transition: opacity .15s, height .15s;
}

#sidebar:hover .sidebar-label, #sidebar.open .sidebar-label {
  opacity: 1;
  height: auto;
}

/* Account items */
.account-item {
  display: flex;
  align-items: center;
  gap: 9px;
  padding: 9px 18px;
  cursor: pointer;
  transition: background .15s;
  margin: 1px 0;
}

.account-item:hover { background: rgba(255,255,255,.05); }
.account-item.active { background: rgba(200,169,110,.12); }

.account-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
  background: var(--sage);
  flex-shrink: 0;
  box-shadow: 0 0 6px rgba(90,122,92,.6);
}

.account-name {
  flex: 1;
  font-size: 13px;
  color: rgba(255,255,255,.65);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: 0;
  transition: opacity .15s;
}

#sidebar:hover .account-name, #sidebar.open .account-name { opacity: 1; }

.account-item.active .account-name { color: var(--gold); }

.account-edit {
  opacity: 0;
  font-size: 12px;
  color: rgba(200,169,110,.7);
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px 3px;
  transition: opacity .15s;
  flex-shrink: 0;
}
.account-item:hover .account-edit { opacity: 1; }

.account-delete {
  opacity: 0;
  font-size: 13px;
  color: rgba(255,255,255,.3);
  padding: 2px;
  transition: opacity .15s;
}

.account-item:hover .account-delete { opacity: 1; }

.sidebar-add {
  width: 100%;
  text-align: left;
  padding: 8px 18px;
  color: rgba(200,169,110,.5);
  font-size: 12px;
  margin-top: 2px;
  transition: color .15s, opacity .15s;
  letter-spacing: .01em;
  white-space: nowrap;
  opacity: 0;
}

#sidebar:hover .sidebar-add, #sidebar.open .sidebar-add { opacity: 1; }
.sidebar-add:hover { color: var(--gold); }

/* Nav items */
.nav-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  text-align: left;
  padding: 10px 0;
  border-radius: 0;
  font-size: 13px;
  color: rgba(255,255,255,.4);
  transition: all .15s;
  white-space: nowrap;
  overflow: hidden;
  justify-content: center;
}

#sidebar:hover .nav-item, #sidebar.open .nav-item {
  padding: 10px 18px;
  justify-content: flex-start;
}

.nav-item:hover { color: rgba(255,255,255,.75); background: rgba(255,255,255,.04); }

.nav-item.active {
  color: var(--gold);
  background: rgba(200,169,110,.08);
  border-right: 2px solid var(--gold);
  font-weight: 500;
}

/* Sidebar footer */
.sidebar-footer {
  padding: 12px 0;
  margin-top: auto;
  display: flex;
  align-items: center;
  gap: 10px;
  border-top: 1px solid rgba(255,255,255,.05);
  overflow: hidden;
  justify-content: center;
}

#sidebar:hover .sidebar-footer, #sidebar.open .sidebar-footer {
  padding: 12px 18px;
  justify-content: flex-start;
}

.sidebar-user-icon {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: var(--charcoal3);
  border: 1px solid rgba(255,255,255,.1);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  color: var(--mist2);
  flex-shrink: 0;
}

#username-display {
  flex: 1;
  font-size: 12px;
  font-weight: 500;
  color: rgba(255,255,255,.35);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  opacity: 0;
  transition: opacity .15s;
}

#sidebar:hover #username-display, #sidebar.open #username-display { opacity: 1; }

/* ══════════════════════════════════════════════════════
   MAIN
══════════════════════════════════════════════════════ */
#main {
  display: flex;
  flex-direction: column;
  overflow: hidden;
  background: var(--ivory);
  min-width: 0;
  min-height: 0;
}

/* Top bar */
.topbar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 0 20px;
  background: #130f0a;
  border-bottom: 1px solid rgba(255,255,255,.05);
  height: 52px;
  flex-shrink: 0;
}

.topbar h2 {
  flex: 1;
  font-family: 'Playfair Display', serif;
  font-size: 16px;
  font-style: italic;
  font-weight: 400;
  color: rgba(255,255,255,.5);
  letter-spacing: .01em;
}

.hamburger {
  display: none;
  font-size: 19px;
  color: var(--mist);
  width: 34px;
  height: 34px;
  align-items: center;
  justify-content: center;
  border-radius: var(--r-sm);
}

.hamburger:hover { background: var(--ivory2); }

.btn-refresh {
  font-size: 18px;
  color: var(--mist);
  width: 34px;
  height: 34px;
  border-radius: var(--r-sm);
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .2s;
}

.btn-refresh:hover { background: var(--ivory2); color: var(--gold-deep); transform: rotate(20deg); }

/* ── View ────────────────────────────────────────────── */
.view { flex: 1; overflow: hidden; display: flex; flex-direction: column; }

/* ══════════════════════════════════════════════════════
   JOURNAL DES ÉCHANGES (ex-Inbox)
══════════════════════════════════════════════════════ */
.journal-container {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
  max-width: 900px;
  margin: 0 auto;
  width: 100%;
}
.journal-header {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  margin-bottom: 20px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--smoke);
}
.journal-title {
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--ink);
  font-family: var(--font-serif);
}
.journal-stats {
  font-size: .78rem;
  color: var(--mist);
  margin-top: 4px;
}
.journal-loading {
  padding: 32px 0;
  color: var(--mist);
  font-style: italic;
  text-align: center;
}
.sync-indicator {
  padding: 6px 12px;
  font-size: .75rem;
  color: var(--smoke);
  font-style: italic;
  text-align: center;
  border-top: 1px solid var(--cream);
  margin-top: 8px;
}
.sync-indicator.sync-error {
  color: var(--gold);
}
.journal-content {
  font-size: .88rem;
  color: var(--ink);
}
.journal-content p { margin: 0 0 1em; }

/* Fix 01 — inbox tabs */
.inbox-tabs {
  display: flex;
  gap: 4px;
  margin-bottom: 16px;
  border-bottom: 2px solid var(--cream);
  padding-bottom: 0;
}
.inbox-tab {
  background: none;
  border: none;
  font-size: .82rem;
  font-weight: 600;
  color: var(--smoke);
  padding: 6px 14px 8px;
  cursor: pointer;
  border-bottom: 2px solid transparent;
  margin-bottom: -2px;
  letter-spacing: .02em;
}
.inbox-tab.active {
  color: var(--ink);
  border-bottom-color: var(--gold);
}
.inbox-tab:hover:not(.active) { color: var(--ink3); }

/* Fix 01 — triage rows */
.triage-list { display: flex; flex-direction: column; gap: 1px; margin-bottom: 8px; }
.triage-row {
  padding: 10px 12px;
  border-radius: 5px;
  cursor: pointer;
  border: 1px solid transparent;
}
.triage-row:hover { background: var(--paper); border-color: var(--cream); }
.triage-row-header { display: flex; justify-content: space-between; align-items: baseline; }
.triage-name  { font-weight: 600; font-size: .84rem; color: var(--ink); }
.triage-date  { font-size: .72rem; color: var(--smoke); }
.triage-subject { font-size: .82rem; color: var(--ink3); margin-top: 2px; }
.triage-summary { font-size: .76rem; color: var(--ink4); margin-top: 3px; font-style: italic; overflow: hidden; white-space: nowrap; text-overflow: ellipsis; }

/* section titles in triage panel */
#inbox-panel-traiter .recap-section-title {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink3);
  padding: 12px 0 4px;
  border-bottom: 2px solid var(--cream);
  margin-bottom: 4px;
}

.recap-line {
  font-size: .88rem;
  color: var(--ink);
  line-height: 1.6;
  margin: 0 0 6px;
  padding: 5px 0;
  border-bottom: 1px solid var(--cream);
}

/* Titres de sections du journal des échanges */
#recap-content .recap-section-title {
  font-size: .7rem;
  font-weight: 700;
  letter-spacing: .1em;
  text-transform: uppercase;
  color: var(--ink3);
  padding: 16px 0 4px;
  border-bottom: 2px solid var(--cream);
  margin-bottom: 0;
}
#recap-content .recap-section-title:first-child { padding-top: 4px; }
#recap-content .recap-section-services { color: var(--ink4); border-color: var(--cream); margin-top: 20px; }
.recap-table-services .recap-name { color: var(--ink3); }

/* Tableau récap contacts */
.recap-table {
  width: 100%;
  border-collapse: collapse;
  font-size: .84rem;
}
.recap-table thead th {
  text-align: left;
  font-size: .7rem;
  font-weight: 700;
  color: var(--smoke);
  text-transform: uppercase;
  letter-spacing: .05em;
  padding: 6px 12px 8px;
  border-bottom: 2px solid var(--smoke);
}
.recap-row { border-bottom: 1px solid var(--cream); }
.recap-row:hover { background: var(--paper); }
.recap-table td { padding: 9px 12px; vertical-align: top; }
.recap-td-name { width: 160px; }
.recap-td-quoi { width: 220px; }
.recap-td-ctx { }
.recap-name { font-weight: 600; color: var(--ink); font-size: .84rem; }
.recap-meta { font-size: .72rem; color: var(--smoke); margin-top: 2px; }
.recap-subject {
  display: inline-block;
  background: var(--cream);
  border-radius: 3px;
  padding: 2px 7px;
  margin: 2px 3px 2px 0;
  font-size: .74rem;
  color: var(--ink4);
  max-width: 200px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  vertical-align: middle;
}
.recap-quoi-text {
  font-size: .82rem;
  color: var(--ink);
  line-height: 1.5;
}
.recap-empty-quoi {
  font-size: .76rem;
  color: var(--smoke);
  font-style: italic;
}
.recap-context {
  font-size: .82rem;
  color: var(--ink4);
  line-height: 1.5;
  font-style: italic;
}

/* Fix 02 + Fix 09 — triage badges in journal */
.jrnl-badge {
  display: inline-block;
  font-size: .62rem;
  font-weight: 700;
  letter-spacing: .04em;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 5px;
  vertical-align: middle;
  text-transform: uppercase;
}
.jrnl-badge-action  { background: rgba(181,74,58,.12); color: var(--rust); border: 1px solid rgba(181,74,58,.25); }
.jrnl-badge-waiting { background: rgba(184,132,58,.1); color: var(--gold); border: 1px solid rgba(184,132,58,.25); }
.jrnl-badge-info    { background: rgba(55,138,221,.1); color: #378ADD; border: 1px solid rgba(55,138,221,.25); }
.jrnl-badge-bruit   { background: var(--cream); color: var(--smoke); border: 1px solid var(--cream); }

/* Fix 10 — journal filter bar (Tous / Famille) */
.journal-filter-bar {
  display: flex;
  gap: 6px;
  padding: 6px 0 10px;
}
.journal-filter-btn {
  background: var(--cream);
  border: 1px solid var(--rule);
  border-radius: 12px;
  padding: 3px 12px;
  font-size: .72rem;
  font-family: var(--font-ui);
  color: var(--ink3);
  cursor: pointer;
  letter-spacing: .03em;
  transition: background .15s, color .15s;
}
.journal-filter-btn.active {
  background: var(--gold);
  border-color: var(--gold);
  color: #fff;
}
.journal-filter-btn:hover:not(.active) { color: var(--ink); background: var(--fog); }

/* ══════════════════════════════════════════════════════
   EMAIL LAYOUT
══════════════════════════════════════════════════════ */
#email-layout {
  display: flex;
  flex: 1;
  overflow: hidden;
}

/* LIST PANEL */
#email-list-panel {
  width: 320px;
  flex-shrink: 0;
  border-right: 1px solid var(--smoke);
  display: flex;
  flex-direction: column;
  background: var(--paper);
}

.panel-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--smoke);
  background: var(--ivory);
}

#account-selector {
  flex: 1;
  padding: 7px 10px;
  border: 1px solid var(--smoke);
  border-radius: var(--r-sm);
  background: var(--paper);
  color: var(--ink);
  font-size: 13px;
  appearance: none;
  cursor: pointer;
}

#account-selector:focus { outline: none; border-color: var(--gold); }

.btn-ai-classify {
  padding: 6px 10px;
  background: var(--charcoal);
  color: var(--gold);
  border-radius: var(--r-sm);
  font-size: 11px;
  font-weight: 600;
  white-space: nowrap;
  letter-spacing: .02em;
  transition: all .15s;
  border: 1px solid var(--charcoal);
}

.btn-ai-classify:hover { background: var(--charcoal2); }

#email-list { flex: 1; overflow-y: auto; }

/* Email items */
.email-item {
  padding: 14px 16px;
  border-bottom: 1px solid var(--ivory2);
  cursor: pointer;
  transition: background .12s;
  position: relative;
}

.email-item:hover { background: var(--ivory); }

.email-item.active {
  background: var(--gold-pale);
  border-left: 3px solid var(--gold);
}

.email-item.active .email-item-from { color: var(--gold-deep); }

.email-item-header {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 8px;
  margin-bottom: 3px;
}

.email-item-from {
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 170px;
}

.email-item.unread .email-item-from { color: var(--charcoal); }

.email-item-date {
  font-size: 11px;
  color: var(--mist2);
  flex-shrink: 0;
  font-family: 'DM Mono', monospace;
}

.email-item-subject {
  font-size: 13px;
  color: var(--charcoal2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 2px;
}

.email-item.unread .email-item-subject { font-weight: 600; }

.email-item-preview {
  font-size: 12px;
  color: var(--mist);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

/* Unread indicator */
.email-item.unread::before {
  content: '';
  position: absolute;
  left: 5px;
  top: 50%;
  transform: translateY(-50%);
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--gold);
}

/* Urgency tags */
.urgency-dot {
  position: absolute;
  right: 12px;
  top: 14px;
  width: 6px;
  height: 6px;
  border-radius: 50%;
}

.urgency-urgent   { background: var(--rust); box-shadow: 0 0 6px rgba(192,80,58,.4); }
.urgency-important { background: var(--amber); }
.urgency-spam     { background: var(--mist2); opacity: .4; }

/* DETAIL PANEL */
#email-detail-panel {
  flex: 1;
  display: flex;
  flex-direction: column;
  background: var(--paper);
  overflow: hidden;
}

.detail-header {
  padding: 22px 28px 16px;
  border-bottom: 1px solid var(--smoke);
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  gap: 12px;
  background: var(--paper);
}

.detail-header h3 {
  font-family: 'Playfair Display', serif;
  font-size: 17px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 6px;
  letter-spacing: -.01em;
  line-height: 1.3;
}

.detail-meta { display: flex; flex-direction: column; gap: 2px; }
.detail-meta span { font-size: 12px; color: var(--mist); }

.detail-close-mobile {
  display: none;
  font-size: 16px;
  color: var(--mist);
  padding: 4px;
}

/* Claire's AI box */
.ai-box {
  margin: 14px 28px;
  background: var(--gold-pale);
  border: 1px solid rgba(200,169,110,.35);
  border-left: 3px solid var(--gold);
  border-radius: var(--r-sm);
  padding: 12px 16px;
  position: relative;
  overflow: hidden;
}

.ai-box::before {
  content: '';
  position: absolute;
  top: -20px; right: -20px;
  width: 80px; height: 80px;
  border-radius: 50%;
  background: radial-gradient(circle, rgba(200,169,110,.15), transparent 70%);
  pointer-events: none;
}

.ai-box-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 11px;
  font-weight: 700;
  color: var(--gold-deep);
  letter-spacing: .08em;
  text-transform: uppercase;
  margin-bottom: 6px;
  font-family: 'DM Mono', monospace;
}

.ai-box-label::before {
  content: '';
  width: 18px;
  height: 18px;
  border-radius: 50%;
  background: var(--charcoal);
  border: 1px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 18 18'%3E%3Ctext x='4' y='14' font-family='Georgia' font-style='italic' font-size='11' fill='%23c8a96e'%3EC%3C/text%3E%3C/svg%3E");
  background-size: contain;
  background-repeat: no-repeat;
  flex-shrink: 0;
}

#ai-summary-text {
  font-size: 13px;
  color: var(--charcoal2);
  line-height: 1.65;
}

/* Email body */
.email-body {
  flex: 1;
  padding: 18px 28px;
  overflow-y: auto;
}

.email-body-html {
  font-size: 14px;
  line-height: 1.75;
  color: var(--charcoal2);
}

.email-body-text {
  font-size: 13px;
  color: var(--charcoal2);
  white-space: pre-wrap;
  line-height: 1.75;
  font-family: inherit;
}

/* Action bar */
.detail-actions {
  padding: 12px 24px;
  border-top: 1px solid var(--smoke);
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  background: var(--ivory);
}

/* Draft panel */
#draft-panel .draft-panel-inner { padding: 0; }

.draft-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 10px;
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
}

#draft-instruction {
  padding: 9px 12px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  font-size: 13px;
  background: var(--paper);
  color: var(--ink);
  transition: border .18s;
}

#draft-instruction:focus { outline: none; border-color: var(--gold); }
#draft-instruction::placeholder { color: var(--mist2); }

#draft-body {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  resize: vertical;
  font-size: 13px;
  background: var(--paper);
  color: var(--ink);
  line-height: 1.65;
  transition: border .18s;
}

#draft-body:focus { outline: none; border-color: var(--gold); }

.draft-actions {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  justify-content: flex-end;
}

/* ══════════════════════════════════════════════════════
   CHAT VIEW
══════════════════════════════════════════════════════ */
.chat-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  background: var(--ivory);
}

.chat-messages {
  flex: 1;
  overflow-y: auto;
  padding: 24px 20px;
  display: flex;
  flex-direction: column;
  gap: 14px;
}

.chat-msg { display: flex; align-items: flex-end; gap: 8px; }
.chat-msg.user { justify-content: flex-end; }
.chat-msg.assistant { justify-content: flex-start; }

/* Claire's chat avatar */
.chat-avatar {
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: var(--charcoal);
  border: 1.5px solid var(--gold);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 13px;
  color: var(--gold);
  box-shadow: 0 0 10px var(--gold-glow);
  margin-bottom: 2px;
}

.chat-bubble {
  max-width: 72%;
  padding: 12px 16px;
  border-radius: var(--r);
  line-height: 1.65;
  font-size: 14px;
}

.chat-msg.user .chat-bubble {
  background: var(--charcoal);
  color: rgba(255,255,255,.9);
  border-bottom-right-radius: 4px;
}

.chat-msg.assistant .chat-bubble {
  background: var(--paper);
  border: 1px solid var(--smoke);
  border-bottom-left-radius: 4px;
  color: var(--charcoal2);
  box-shadow: 0 1px 4px rgba(0,0,0,.05);
}

.chat-input-row {
  display: flex;
  gap: 8px;
  padding: 14px 20px;
  background: var(--paper);
  border-top: 1px solid var(--smoke);
  align-items: flex-end;
}

#chat-input {
  flex: 1;
  padding: 10px 14px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r);
  resize: none;
  max-height: 120px;
  background: var(--ivory);
  color: var(--ink);
  font-size: 14px;
  line-height: 1.5;
  transition: border .18s;
}

#chat-input:focus { outline: none; border-color: var(--gold); background: var(--paper); }
#chat-input::placeholder { color: var(--mist2); }

/* ══════════════════════════════════════════════════════
   MODAL
══════════════════════════════════════════════════════ */
#modal-overlay {
  position: fixed;
  inset: 0;
  background: rgba(26,22,20,.55);
  backdrop-filter: blur(4px);
  z-index: 1000;
}

.modal {
  position: fixed;
  top: 50%;
  left: 50%;
  transform: translate(-50%, -50%);
  background: var(--paper);
  border-radius: var(--r-lg);
  width: 90%;
  max-width: 520px;
  z-index: 1010;
  max-height: 90vh;
  display: flex;
  flex-direction: column;
  box-shadow: var(--s-modal);
  animation: modalIn .25s cubic-bezier(.34,1.56,.64,1) both;
}

@keyframes modalIn {
  from { opacity: 0; transform: translate(-50%, -48%) scale(.97); }
  to   { opacity: 1; transform: translate(-50%, -50%) scale(1); }
}

.modal-header {
  padding: 18px 22px;
  border-bottom: 1px solid var(--smoke);
  display: flex;
  justify-content: space-between;
  align-items: center;
}

.modal-header h3 {
  font-family: 'Playfair Display', serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
}

.modal-header button {
  font-size: 19px;
  color: var(--mist);
  line-height: 1;
  padding: 2px;
  border-radius: 4px;
  transition: color .15s;
}

.modal-header button:hover { color: var(--ink); }

.modal-body {
  padding: 20px 22px;
  overflow-y: auto;
  flex: 1;
}

.modal-body label {
  display: block;
  font-size: 11px;
  font-weight: 600;
  color: var(--mist);
  margin-bottom: 6px;
  margin-top: 16px;
  text-transform: uppercase;
  letter-spacing: .07em;
  font-family: 'DM Mono', monospace;
}

.modal-body label:first-child { margin-top: 0; }

.modal-body input[type="text"],
.modal-body input[type="email"],
.modal-body input[type="password"],
.modal-body input[type="number"],
.modal-body select {
  width: 100%;
  padding: 10px 12px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  background: var(--ivory);
  color: var(--ink);
  font-size: 14px;
  transition: border .18s;
}

.modal-body input:focus,
.modal-body select:focus {
  outline: none;
  border-color: var(--gold);
  background: var(--paper);
}

.modal-body input::placeholder { color: var(--mist2); }

.row-2col {
  display: grid;
  grid-template-columns: 1fr 110px;
  gap: 10px;
}

.note-box {
  background: #fffbeb;
  border: 1px solid #fde68a;
  border-radius: var(--r-sm);
  padding: 10px 14px;
  font-size: 12px;
  color: #92400e;
  margin-top: 14px;
  line-height: 1.55;
}

.modal-footer {
  padding: 14px 22px;
  border-top: 1px solid var(--smoke);
  display: flex;
  justify-content: flex-end;
  gap: 8px;
  background: var(--ivory);
  border-radius: 0 0 var(--r-lg) var(--r-lg);
}

/* ══════════════════════════════════════════════════════
   MISC
══════════════════════════════════════════════════════ */
.empty-state {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  height: 100%;
  gap: 14px;
  color: var(--mist);
  padding: 48px;
  text-align: center;
}

.empty-icon { font-size: 44px; opacity: .5; }
.empty-state p { font-size: 14px; color: var(--mist); max-width: 240px; line-height: 1.6; }

.error-msg { color: var(--rust); font-size: 13px; margin-top: 8px; min-height: 20px; }

.loading-spinner {
  padding: 20px;
  text-align: center;
  color: var(--mist2);
  font-size: 13px;
  animation: spinnerPulse 1.4s ease-in-out infinite;
}
@keyframes spinnerPulse {
  0%, 100% { opacity: 1; }
  50% { opacity: .35; }
}

.testing-msg {
  padding: 10px;
  text-align: center;
  color: var(--gold-deep);
  font-size: 13px;
}

/* Toast */
.toast {
  position: fixed;
  bottom: 24px;
  right: 24px;
  padding: 12px 18px;
  background: var(--charcoal);
  color: rgba(255,255,255,.9);
  border-radius: var(--r);
  font-size: 13px;
  opacity: 0;
  transform: translateY(10px);
  transition: all .3s cubic-bezier(.34,1.56,.64,1);
  pointer-events: none;
  z-index: 999;
  max-width: 320px;
  border-left: 3px solid var(--gold);
  box-shadow: var(--s-lifted);
}

.toast.show { opacity: 1; transform: translateY(0); }
.toast.success { border-left-color: var(--sage); }
.toast.error { border-left-color: var(--rust); }
.toast.info { border-left-color: var(--amber); }

/* ══════════════════════════════════════════════════════
   DASHBOARD — Tableau de bord secrétaire
══════════════════════════════════════════════════════ */

/* Briefing card — rapport de Claire */
.briefing-card {
  background: var(--charcoal);
  border-radius: var(--r-lg);
  overflow: hidden;
  box-shadow: var(--s-lifted);
}

.briefing-header {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 16px 20px;
  border-bottom: 1px solid rgba(200,169,110,.15);
}

.briefing-avatar {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  background: rgba(200,169,110,.1);
  border: 1.5px solid var(--gold);
  display: flex; align-items: center; justify-content: center;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 15px;
  color: var(--gold);
  flex-shrink: 0;
  box-shadow: 0 0 14px var(--gold-glow);
}

.briefing-title {
  font-family: 'Playfair Display', serif;
  font-size: 14px;
  font-weight: 600;
  color: var(--paper);
  line-height: 1.2;
}

.briefing-time {
  font-size: 11px;
  color: rgba(255,255,255,.35);
  font-family: 'DM Mono', monospace;
  margin-top: 2px;
}

.briefing-refresh {
  margin-left: auto;
  padding: 5px 10px;
  background: rgba(200,169,110,.1);
  border: 1px solid rgba(200,169,110,.2);
  color: var(--gold);
  border-radius: 6px;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  white-space: nowrap;
  transition: all .15s;
}

.briefing-refresh:hover { background: rgba(200,169,110,.2); }

.briefing-body {
  padding: 16px 20px;
  font-size: 14px;
  color: rgba(255,255,255,.75);
  line-height: 1.75;
}

.briefing-body strong { color: var(--paper); }

/* Stats row */
.stats-row {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 10px;
}

.stat-card {
  background: var(--paper);
  border-radius: var(--r);
  padding: 14px 16px;
  box-shadow: var(--s-card);
  border-top: 3px solid var(--smoke);
  text-align: center;
}

.stat-card.urgent   { border-top-color: var(--rust); }
.stat-card.important { border-top-color: var(--amber); }
.stat-card.normal   { border-top-color: var(--sage); }
.stat-card.info     { border-top-color: var(--mist2); }

.stat-num {
  font-family: 'Playfair Display', serif;
  font-size: 28px;
  font-weight: 700;
  color: var(--charcoal);
  line-height: 1;
  margin-bottom: 4px;
}

.stat-label {
  font-size: 11px;
  color: var(--mist);
  text-transform: uppercase;
  letter-spacing: .06em;
  font-family: 'DM Mono', monospace;
}

/* Section header */
.section-header {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
}

.section-title {
  font-family: 'Playfair Display', serif;
  font-size: 16px;
  font-weight: 600;
  color: var(--charcoal);
  flex: 1;
}

.section-actions {
  display: flex;
  align-items: center;
  gap: 8px;
}

.section-select {
  padding: 6px 10px;
  border: 1px solid var(--smoke);
  border-radius: var(--r-sm);
  background: var(--paper);
  font-size: 12px;
  color: var(--charcoal);
}

/* Email cards grid */
.email-cards {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(340px, 1fr));
  gap: 12px;
}

/* Individual email card */
.ecard {
  background: var(--paper);
  border-radius: var(--r);
  box-shadow: var(--s-card);
  overflow: hidden;
  cursor: pointer;
  transition: all .18s;
  display: flex;
  border: 1px solid var(--smoke);
}

.ecard:hover {
  box-shadow: var(--s-lifted);
  transform: translateY(-2px);
}

.ecard-urgency-bar {
  width: 4px;
  flex-shrink: 0;
  background: var(--smoke);
}

.ecard-urgent .ecard-urgency-bar   { background: var(--rust); }
.ecard-important .ecard-urgency-bar { background: var(--amber); }
.ecard-spam .ecard-urgency-bar     { background: var(--ivory3); }

.ecard-content { flex: 1; padding: 14px 16px; }

.ecard-top {
  display: flex;
  justify-content: space-between;
  align-items: center;
  margin-bottom: 8px;
}

.ecard-badge {
  font-size: 11px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  font-family: 'DM Mono', monospace;
  letter-spacing: .03em;
}

.badge-urgent   { background: #fff1f0; color: var(--rust); }
.badge-important { background: #fffbeb; color: var(--amber); }
.badge-normal   { background: #f0fdf4; color: var(--sage); }
.badge-spam     { background: var(--ivory2); color: var(--mist); }

.ecard-date {
  font-size: 11px;
  color: var(--mist2);
  font-family: 'DM Mono', monospace;
}

.ecard-from {
  font-size: 13px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ecard-subject {
  font-size: 13px;
  color: var(--charcoal2);
  margin-bottom: 8px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.ecard-summary {
  font-size: 12.5px;
  color: var(--mist);
  line-height: 1.6;
  margin-bottom: 12px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

.ecard-spam .ecard-from,
.ecard-spam .ecard-subject { opacity: .55; }

.ecard-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.ecard-btn {
  padding: 5px 10px;
  border-radius: var(--r-sm);
  font-size: 12px;
  font-weight: 500;
  border: 1.5px solid var(--charcoal);
  background: var(--charcoal);
  color: var(--gold);
  transition: all .15s;
}

.ecard-btn:hover { background: var(--charcoal2); }

.ecard-btn-ghost {
  background: transparent;
  color: var(--mist);
  border-color: var(--smoke);
}

.ecard-btn-ghost:hover { border-color: var(--gold); color: var(--gold-deep); background: var(--gold-pale); }

/* ── Email card detail (fiche) ── */
.email-card-detail {
  background: var(--paper);
  border-radius: var(--r-lg);
  box-shadow: var(--s-card);
  padding: 24px;
  margin-bottom: 16px;
  border: 1px solid var(--smoke);
}

.ecd-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}

.ecd-badge { font-size: 12px; font-weight: 600; padding: 3px 10px; border-radius: 20px; font-family: 'DM Mono', monospace; }

.ecd-date { font-size: 12px; color: var(--mist); font-family: 'DM Mono', monospace; }

.ecd-subject {
  font-family: 'Playfair Display', serif;
  font-size: 20px;
  font-weight: 600;
  color: var(--charcoal);
  line-height: 1.3;
  margin-bottom: 8px;
}

.ecd-meta { margin-bottom: 0; }
.ecd-from { font-size: 13px; color: var(--mist); }

.ecd-open {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-top: 16px;
  padding-top: 16px;
  border-top: 1px solid var(--smoke);
  gap: 12px;
  flex-wrap: wrap;
}

.ecd-open-text { font-size: 12.5px; color: var(--mist); flex: 1; }

/* Draft card */
.draft-card {
  background: var(--paper);
  border-radius: var(--r-lg);
  box-shadow: var(--s-card);
  padding: 20px 24px;
  border: 1px solid var(--smoke);
}

.draft-card-header { margin-bottom: 14px; }
.draft-card-title { font-family: 'Playfair Display', serif; font-size: 16px; font-weight: 600; color: var(--charcoal); margin-bottom: 4px; }
.draft-card-to { font-size: 12px; color: var(--mist); }

.draft-instruction-row {
  display: flex;
  gap: 8px;
  margin-bottom: 10px;
  align-items: center;
}

.draft-instruction-row input {
  flex: 1;
  padding: 9px 12px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  font-size: 13px;
  background: var(--ivory);
  color: var(--ink);
  transition: border .18s;
}

.draft-instruction-row input:focus { outline: none; border-color: var(--gold); background: var(--paper); }

/* ══════════════════════════════════════════════════════
   RESPONSIVE — MOBILE
══════════════════════════════════════════════════════ */
@media (max-width: 900px) {
  .stats-row { grid-template-columns: repeat(2, 1fr); }
  .email-cards { grid-template-columns: 1fr; }
}

@media (max-width: 768px) {
  .hamburger { display: flex; }
  .sidebar-close { display: block; }

  #sidebar {
    position: fixed;
    top: 0; left: 0; bottom: 0;
    transform: translateX(-110%);
    box-shadow: var(--s-modal);
  }

  #sidebar.open { transform: translateX(0); }

  #email-layout { flex-direction: column; }
  #email-list-panel {
    width: 100%;
    border-right: none;
    border-bottom: 1px solid var(--smoke);
    max-height: 45vh;
  }
  #email-detail-panel { max-height: 55vh; }

  .detail-close-mobile { display: block; }
  .detail-header { padding: 14px 16px 12px; }
  .email-body { padding: 14px 16px; }
  .ai-box { margin: 10px 16px; }
  .detail-actions { padding: 10px 14px; }

  #email-detail-panel.mobile-full {
    position: fixed; inset: 0; z-index: 150;
    max-height: 100vh; overflow-y: auto;
  }
  .mobile-full { position: fixed !important; inset: 0 !important; z-index: 500 !important; border-radius: 0 !important; }

  .chat-bubble { max-width: 88%; }
  .chat-messages { padding: 16px 14px; }
  .chat-input-row { padding: 10px 14px; }

  .modal { width: 95%; max-height: 95vh; }
  .auth-card { padding: 32px 22px; }
}

@media (max-width: 480px) {
  .panel-toolbar { flex-wrap: wrap; }
  .topbar h2 { font-size: 15px; }
  .chat-bubble { max-width: 93%; font-size: 13px; }
}

/* ══════════════════════════════════════════════════════
   VOICE INPUT
══════════════════════════════════════════════════════ */
.btn-voice {
  width: 44px;
  height: 44px;
  background: var(--ivory2);
  border: 1.5px solid var(--smoke);
  color: var(--mist);
  border-radius: var(--r);
  font-size: 18px;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  transition: all .2s;
}

.btn-voice:hover { border-color: var(--gold); color: var(--gold-deep); }

.btn-voice.listening {
  background: #fff1f0;
  border-color: var(--rust);
  color: var(--rust);
  animation: pulse-red 1s ease-in-out infinite;
}

@keyframes pulse-red {
  0%, 100% { box-shadow: 0 0 0 0 rgba(192,80,58,.3); }
  50%       { box-shadow: 0 0 0 8px rgba(192,80,58,.0); }
}

/* ══════════════════════════════════════════════════════
   CALENDAR VIEW
══════════════════════════════════════════════════════ */

.calendar-toolbar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 12px 20px;
  background: var(--paper);
  border-bottom: 1px solid var(--smoke);
  flex-shrink: 0;
}

#calendar-list {
  flex: 1;
  overflow-y: auto;
  padding: 20px;
  display: flex;
  flex-direction: column;
  gap: 16px;
}

.cal-day-group {
  background: var(--paper);
  border-radius: var(--r);
  box-shadow: var(--s-card);
  border: 1px solid var(--smoke);
  overflow: hidden;
}

.cal-day-group.cal-today { border-color: var(--gold); }

.cal-day-header {
  padding: 10px 16px;
  background: var(--ivory2);
  font-size: 12px;
  font-weight: 600;
  color: var(--mist);
  letter-spacing: .07em;
  text-transform: capitalize;
  font-family: 'DM Mono', monospace;
}

.cal-day-group.cal-today .cal-day-header {
  background: var(--gold-pale);
  color: var(--gold-deep);
}

.cal-event-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 12px 16px;
  border-top: 1px solid var(--ivory2);
  cursor: pointer;
  transition: background .12s;
}

.cal-event-item:hover { background: var(--ivory); }

.cal-event-time {
  font-family: 'DM Mono', monospace;
  font-size: 12px;
  color: var(--mist);
  white-space: nowrap;
  flex-shrink: 0;
  padding-top: 2px;
  min-width: 90px;
}

.cal-event-body { flex: 1; }

.cal-event-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 2px;
}

.cal-event-location {
  font-size: 12px;
  color: var(--mist);
  margin-bottom: 2px;
}

.cal-event-desc {
  font-size: 12px;
  color: var(--mist2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: min(90%, 400px);
}

.cal-event-source {
  font-size: 10px;
  font-weight: 600;
  letter-spacing: .06em;
  padding: 2px 7px;
  border-radius: 10px;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  flex-shrink: 0;
  align-self: center;
}

.cal-source-manual { background: var(--ivory2); color: var(--mist); }
.cal-source-email  { background: var(--gold-pale); color: var(--gold-deep); }
.cal-source-chat   { background: rgba(90,122,92,.1); color: var(--sage); }

/* ── Sidebar mini-calendar ─────────────────────────── */
.sidebar-calendar-mini {
  flex-shrink: 0;
  overflow: hidden;
  opacity: 0;
  max-height: 0;
  transition: opacity .2s, max-height .2s;
}

#sidebar:hover .sidebar-calendar-mini, #sidebar.open .sidebar-calendar-mini {
  opacity: 1;
  max-height: 300px;
}

.sidebar-today-list {
  padding: 0 10px 4px;
}

.sidebar-today-item {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 6px 8px;
  border-radius: var(--r-sm);
  cursor: pointer;
  transition: background .12s;
}

.sidebar-today-item:hover { background: rgba(255,255,255,.06); }

.sidebar-today-time {
  font-family: 'DM Mono', monospace;
  font-size: 10px;
  color: var(--gold);
  flex-shrink: 0;
  min-width: 38px;
}

.sidebar-today-title {
  font-size: 12px;
  color: rgba(255,255,255,.65);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.sidebar-today-empty {
  font-size: 12px;
  color: rgba(255,255,255,.2);
  padding: 6px 8px;
  font-style: italic;
}

@media (max-width: 768px) {
  .cal-event-time { min-width: 70px; }
  .cal-event-desc { max-width: 200px; }
  #calendar-list { padding: 12px; }
}

/* ── Tasks View ────────────────────────────────────── */
#view-tasks {
  flex-direction: column;
  overflow: hidden;
}

.tasks-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.tasks-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px 12px;
  border-bottom: 1px solid var(--smoke);
  background: var(--paper);
  flex-shrink: 0;
  gap: 12px;
  flex-wrap: wrap;
}

.tasks-filters {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.task-filter-btn {
  padding: 6px 14px;
  border-radius: 20px;
  border: 1.5px solid var(--smoke);
  background: transparent;
  color: var(--mist);
  font-size: 12px;
  font-weight: 500;
  cursor: pointer;
  transition: all .15s;
  font-family: 'DM Sans', sans-serif;
}

.task-filter-btn:hover {
  border-color: var(--gold);
  color: var(--gold-deep);
}

.task-filter-btn.active {
  background: var(--gold-pale);
  border-color: var(--gold);
  color: var(--gold-deep);
  font-weight: 600;
}

.tasks-list {
  flex: 1;
  overflow-y: auto;
  padding: 16px 24px;
  display: flex;
  flex-direction: column;
  gap: 8px;
}

/* ── Task Item ─────────────────────────────────────── */
.task-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  background: var(--paper);
  border: 1.5px solid var(--smoke);
  border-radius: var(--r);
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s;
}

.task-item:hover {
  border-color: var(--gold);
  box-shadow: var(--s-card);
}

.task-item-left {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.task-check {
  width: 22px;
  height: 22px;
  border-radius: 50%;
  border: 2px solid var(--smoke);
  background: transparent;
  cursor: pointer;
  font-size: 12px;
  color: var(--mist);
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  margin-top: 2px;
  transition: all .15s;
  padding: 0;
}

.task-check:hover {
  border-color: var(--sage);
  color: var(--sage);
}

.task-check.checked {
  background: var(--sage);
  border-color: var(--sage);
  color: white;
}

.task-item-body {
  flex: 1;
  min-width: 0;
}

.task-item-title {
  font-size: 14px;
  font-weight: 500;
  color: var(--charcoal);
  margin-bottom: 3px;
}

.task-item-desc {
  font-size: 12px;
  color: var(--mist);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.task-item-meta {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  font-size: 11px;
}

.task-meta-date, .task-meta-contact, .task-meta-followup {
  color: var(--mist2);
  font-family: 'DM Mono', monospace;
}

.task-meta-overdue {
  color: var(--rust) !important;
  font-weight: 600;
}

/* Priority badges */
.task-priority-badge {
  font-size: 10px;
  font-weight: 700;
  letter-spacing: .06em;
  padding: 3px 9px;
  border-radius: 10px;
  text-transform: uppercase;
  font-family: 'DM Mono', monospace;
  flex-shrink: 0;
  align-self: center;
}

.task-priority-urgent  { background: rgba(192,80,58,.12); color: var(--rust); border: 1px solid rgba(192,80,58,.25); }
.task-priority-high    { background: rgba(200,126,42,.12); color: var(--amber); border: 1px solid rgba(200,126,42,.25); }
.task-priority-normal  { background: rgba(90,122,92,.1); color: var(--sage); border: 1px solid rgba(90,122,92,.2); }
.task-priority-low     { background: var(--ivory2); color: var(--mist2); border: 1px solid var(--smoke); }

/* Overdue state */
.task-overdue {
  background: rgba(192,80,58,.04);
  border-color: rgba(192,80,58,.25);
}

.task-overdue:hover {
  border-color: var(--rust);
}

/* Done state */
.task-done {
  opacity: .55;
}

.task-done .task-item-title {
  text-decoration: line-through;
  color: var(--mist2);
}

/* Priority dot in sidebar */
.task-priority-dot {
  font-size: 10px;
  min-width: 16px;
}
.task-priority-dot-urgent { color: var(--rust); }
.task-priority-dot-high   { color: var(--amber); }
.task-priority-dot-normal { color: var(--sage); }
.task-priority-dot-low    { color: var(--mist2); }

/* ── Sidebar Tasks Mini ─────────────────────────────── */
.sidebar-tasks-mini {
  flex-shrink: 0;
  overflow: hidden;
  opacity: 0;
  max-height: 0;
  transition: opacity .2s, max-height .2s;
}

#sidebar:hover .sidebar-tasks-mini, #sidebar.open .sidebar-tasks-mini {
  opacity: 1;
  max-height: 300px;
}

@media (max-width: 768px) {
  .tasks-toolbar { padding: 12px 16px; }
  .tasks-list { padding: 12px 16px; }
  .task-item { padding: 12px 12px; }
}

/* ── Gardien View ────────────────────────────────────── */
#view-gardien {
  flex-direction: column;
  overflow: hidden;
}

.gardien-container {
  display: flex;
  flex-direction: column;
  height: 100%;
  overflow: hidden;
}

.gardien-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 24px;
  border-bottom: 1px solid var(--smoke);
  gap: 12px;
  flex-shrink: 0;
  background: var(--paper);
}

.gardien-filters {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.gardien-filter-btn {
  font-family: 'DM Sans', sans-serif;
  font-size: 13px;
  font-weight: 500;
  padding: 6px 14px;
  border-radius: 20px;
  border: 1.5px solid var(--smoke);
  background: var(--paper);
  color: var(--mist);
  cursor: pointer;
  transition: all .15s;
}

.gardien-filter-btn:hover { border-color: var(--gold); color: var(--charcoal); }
.gardien-filter-btn.active { background: var(--charcoal); border-color: var(--charcoal); color: var(--ivory); }

.gardien-list {
  flex: 1;
  overflow-y: auto;
  padding: 20px 24px;
}

.gardien-group {
  margin-bottom: 28px;
}

.gardien-group-header {
  font-family: 'DM Mono', monospace;
  font-size: 11px;
  font-weight: 600;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--mist);
  padding: 0 0 10px;
  border-bottom: 1px solid var(--smoke);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 8px;
}

.gardien-group-count {
  background: var(--gold-pale);
  color: var(--gold-deep);
  font-size: 10px;
  padding: 1px 7px;
  border-radius: 10px;
}

.gardien-item {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 12px;
  padding: 14px 16px;
  background: var(--paper);
  border: 1.5px solid var(--smoke);
  border-radius: var(--r);
  margin-bottom: 8px;
  cursor: pointer;
  transition: border-color .15s, box-shadow .15s, transform .1s;
}

.gardien-item:hover {
  border-color: var(--gold);
  box-shadow: var(--s-card);
  transform: translateY(-1px);
}

.gardien-overdue {
  background: rgba(192,80,58,.03);
  border-color: rgba(192,80,58,.25);
}

.gardien-overdue:hover {
  border-color: var(--rust);
}

.gardien-item-left {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  flex: 1;
  min-width: 0;
}

.gardien-item-icon {
  font-size: 22px;
  flex-shrink: 0;
  line-height: 1;
  padding-top: 2px;
}

.gardien-item-body {
  flex: 1;
  min-width: 0;
}

.gardien-item-title {
  font-size: 14px;
  font-weight: 600;
  color: var(--charcoal);
  margin-bottom: 2px;
}

.gardien-item-filename {
  font-size: 11px;
  font-family: 'DM Mono', monospace;
  color: var(--mist);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.gardien-item-notes {
  font-size: 12px;
  color: var(--mist);
  margin-bottom: 4px;
  line-height: 1.4;
}

.gardien-item-meta {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 11px;
  font-family: 'DM Mono', monospace;
}

.gardien-meta-date { color: var(--mist2); }
.gardien-meta-overdue { color: var(--rust) !important; font-weight: 700; }
.gardien-meta-source { color: var(--mist2); }

.gardien-item-right {
  display: flex;
  flex-direction: column;
  align-items: flex-end;
  gap: 8px;
  flex-shrink: 0;
}

.gardien-done-btn {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  border: 1.5px solid var(--smoke);
  background: var(--paper);
  color: var(--mist);
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all .15s;
}

.gardien-done-btn:hover {
  background: var(--sage);
  border-color: var(--sage);
  color: white;
}

/* File drop zone */
.doc-file-zone {
  border: 1.5px dashed var(--smoke);
  border-radius: var(--r);
  padding: 14px 16px;
  cursor: pointer;
  text-align: center;
  font-size: 13px;
  color: var(--mist);
  transition: border-color .15s, background .15s;
  background: var(--ivory);
}

.doc-file-zone:hover {
  border-color: var(--gold);
  background: var(--gold-pale);
  color: var(--charcoal);
}

@media (max-width: 768px) {
  .gardien-toolbar { padding: 12px 16px; }
  .gardien-list { padding: 12px 16px; }
  .gardien-item { padding: 12px; }
}

/* ══════════════════════════════════════════════════════
   BRIEFING — Structure IPCRA
══════════════════════════════════════════════════════ */
#view-briefing {
  flex-direction: column;
  overflow: hidden;
  padding: 0;
  background: var(--ivory);
  min-height: 0;
  display: flex;
}

/* ── Bandeau Claire (sticky top) ── */
.brief-banner {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 16px 24px 14px;
  background: var(--paper);
  border-bottom: 2px solid var(--smoke);
  flex-shrink: 0;
}

.brief-banner-left {
  display: flex;
  flex-direction: column;
  flex-shrink: 0;
  min-width: 140px;
}

.brief-banner-greeting {
  font-family: 'Playfair Display', serif;
  font-size: 1.1rem;
  font-weight: 700;
  color: var(--ink);
  line-height: 1.2;
}

.brief-banner-date {
  font-size: 0.65rem;
  font-family: 'DM Mono', monospace;
  color: var(--mist);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-top: 4px;
}

.brief-banner-claire {
  flex: 1;
  min-width: 0;
  display: flex;
  gap: 10px;
  align-items: flex-start;
  background: var(--gold-pale);
  border: 1px solid rgba(200,169,110,.28);
  border-radius: 12px;
  padding: 10px 14px;
  /* Cap height so long AI text never crushes the layout below */
  max-height: 220px;
  overflow: hidden;
  position: relative;
}

/* Fade gradient when text overflows */
.brief-banner-claire.is-clamped::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 36px;
  background: linear-gradient(to bottom, transparent, var(--gold-pale));
  pointer-events: none;
  border-radius: 0 0 12px 12px;
}

/* Expanded state */
.brief-banner-claire.expanded {
  max-height: none;
  overflow: visible;
}
.brief-banner-claire.expanded::after { display: none; }

/* Voir plus button */
.brief-expand-btn {
  position: absolute;
  bottom: 6px;
  right: 10px;
  font-size: 0.7rem;
  color: var(--gold-deep);
  font-weight: 600;
  background: none;
  border: none;
  cursor: pointer;
  padding: 2px 6px;
  z-index: 1;
}
.brief-expand-btn:hover { text-decoration: underline; }

.brief-banner-claire-label {
  font-size: 0.95rem;
  flex-shrink: 0;
  margin-top: 2px;
}

.brief-banner-claire-text {
  font-size: 0.855rem;
  color: var(--charcoal);
  line-height: 1.65;
  flex: 1;
}

.brief-banner-claire-text strong { color: var(--ink); font-weight: 600; }

.brief-loading-text {
  color: var(--mist);
  font-style: italic;
}

.brief-banner-refresh {
  background: none;
  border: 1.5px solid var(--smoke);
  color: var(--mist);
  font-size: 1rem;
  width: 30px; height: 30px;
  border-radius: 8px;
  cursor: pointer;
  flex-shrink: 0;
  transition: all .15s;
  display: flex; align-items: center; justify-content: center;
}
.brief-banner-refresh:hover { border-color: var(--gold); color: var(--gold-deep); }

/* ── Layout 2 colonnes ── */
.brief-layout {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 0;
  flex: 1;
  min-height: 0;
  overflow: hidden;
}

.brief-col-main {
  padding: 16px 18px 20px 20px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 20px;
  border-right: 2px solid var(--smoke);
  min-height: 0;
  background: var(--ivory);
}

.brief-col-side {
  padding: 16px 18px 20px 16px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 16px;
  background: var(--ivory2);
  min-height: 0;
}

@media (max-width: 768px) {
  .brief-layout {
    grid-template-columns: 1fr;
    overflow-y: auto;
    overflow-x: hidden;
  }
  .brief-col-main, .brief-col-side {
    overflow-y: visible;
    min-height: unset;
  }
  .brief-col-main { border-right: none; padding: 12px 12px 0; }
  .brief-col-side { padding: 0 12px 16px; }
}

/* ── Section ── */
.brief-section {
  /* Conteneur neutre — le titre est toujours affiché,
     le contenu peut être soit des cartes libres soit une liste encadrée */
}

.brief-section-title {
  display: flex;
  align-items: center;
  gap: 7px;
  padding: 2px 2px 7px;
  font-size: 0.7rem;
  font-weight: 700;
  color: var(--mist);
  letter-spacing: .08em;
  text-transform: uppercase;
}

.brief-section-title > span:nth-child(2) { flex: 1; }

/* Sections avec contenu liste (events, tasks, info, waiting)
   → encadrées comme une card */
#brief-events,
#brief-tasks,
#brief-info,
#brief-waiting {
  background: var(--paper);
  border: 1.5px solid var(--smoke);
  border-radius: 12px;
  overflow: hidden;
  box-shadow: 0 1px 4px rgba(0,0,0,.04);
}

/* Section emails (situation-cards) → cartes libres, pas de wrapper */
#brief-emails {
  display: flex;
  flex-direction: column;
  gap: 0;
}

/* Misc section (Gardien/Drafts/Relances) */
.brief-section-misc {
  background: var(--paper);
  border: 1.5px solid var(--smoke);
  border-radius: 12px;
  overflow: hidden;
}

.brief-misc-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 9px 16px;
  border-bottom: 1px solid var(--smoke);
  font-size: 0.8rem;
  color: var(--ink);
  transition: background .1s;
}
.brief-misc-row:last-child { border-bottom: none; }
.brief-misc-row:hover { background: var(--ivory3); }
.brief-misc-row > span:first-child { color: var(--charcoal2); font-size: 0.76rem; font-weight: 500; }
.brief-misc-row > span:last-child  { font-weight: 600; color: var(--charcoal); font-size: 0.8rem; }

/* IPCRA tags */
.ipcra-tag {
  display: inline-flex; align-items: center; justify-content: center;
  width: 18px; height: 18px; border-radius: 4px;
  font-size: 0.65rem; font-family: 'DM Mono', monospace; font-weight: 700;
  flex-shrink: 0;
}
.ipcra-i { background: rgba(192,80,58,.15); color: var(--rust); }
.ipcra-p { background: rgba(168,136,61,.2); color: var(--gold-deep); }
.ipcra-r { background: rgba(90,122,92,.15); color: var(--sage); }
.ipcra-a { background: var(--smoke); color: var(--mist); }

/* Shared utilities */
.brief-see-all {
  background: none; border: 1px solid var(--smoke); cursor: pointer;
  color: var(--mist); font-size: 0.72rem;
  padding: 2px 7px; border-radius: 5px;
  white-space: nowrap; transition: all .12s;
}
.brief-see-all:hover { border-color: var(--gold); color: var(--gold-deep); background: var(--gold-pale); }

.brief-add-btn {
  background: var(--ink); border: none; cursor: pointer;
  color: white; font-size: 0.7rem;
  padding: 3px 9px; border-radius: 5px; font-weight: 600;
  transition: background .12s;
}
.brief-add-btn:hover { background: var(--gold-deep); }

.brief-add-link { background: none; border: none; cursor: pointer; color: var(--gold-deep); font-size: 0.75rem; padding: 0; text-decoration: underline; }

.brief-badge {
  background: var(--rust); color: white;
  font-size: 0.62rem; font-family: 'DM Mono', monospace;
  padding: 2px 6px; border-radius: 20px; font-weight: 700;
}

.brief-empty {
  padding: 24px 16px; color: var(--mist);
  font-size: 0.82rem; text-align: center; line-height: 1.7;
}

.brief-loading {
  padding: 18px; color: var(--mist); font-size: 0.82rem; text-align: center;
  animation: spinnerPulse 1.4s ease-in-out infinite;
}

/* ── Brief situation cards (section I — À décider) ────────────────────────── */
.brief-email-item {
  padding: 11px 14px;
  border-bottom: 1px solid var(--smoke);
  cursor: pointer;
  transition: background .12s;
}
.brief-email-item:last-child { border-bottom: none; }
.brief-email-item:hover { background: var(--ivory); }
.brief-email-from {
  font-weight: 600;
  font-size: .84rem;
  color: var(--charcoal);
  display: flex;
  align-items: center;
  flex-wrap: wrap;
  gap: 4px;
  margin-bottom: 2px;
}
.brief-email-subject {
  font-size: .77rem;
  color: var(--charcoal2);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.brief-email-summary {
  font-size: .73rem;
  color: var(--mist);
  margin-top: 3px;
  line-height: 1.5;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}

/* ── Brief waiting items (section P — En attente) ─────────────────────────── */
.brief-waiting-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--smoke);
}
.brief-waiting-item:last-child { border-bottom: none; }

/* ── Chat panel context label (relance / email courant) ──────────────────── */
.chat-panel-context-label {
  display: inline-block;
  font-size: .7rem;
  font-weight: 400;
  color: var(--mist);
  margin-left: 7px;
  font-style: italic;
  max-width: 160px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
  vertical-align: middle;
}

.brief-pending {
  font-size: 0.74rem; color: var(--amber);
  padding: 5px 16px 5px 16px; background: rgba(200,126,42,.06);
  border-left: 3px solid rgba(200,126,42,.3);
  margin: 6px 10px 0; border-radius: 0 6px 6px 0; font-style: italic;
}

/* ── Age indicators ── */
.bmail-age {
  display: inline-block;
  font-size: 0.62rem;
  font-family: 'DM Mono', monospace;
  padding: 1px 5px;
  border-radius: 3px;
  margin-left: 4px;
  font-weight: 700;
  letter-spacing: .02em;
}
.bmail-age-ok     { background: rgba(21,128,61,.1);  color: #15803d; }
.bmail-age-orange { background: rgba(194,65,12,.1);  color: #c2410c; }
.bmail-age-red    { background: rgba(192,80,58,.12); color: var(--rust); }

.brief-archive-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--mist2);
  font-size: 0.78rem;
  padding: 2px 6px;
  opacity: 0.7;
  transition: opacity .12s, color .12s;
}
.brief-archive-btn:hover { opacity: 1; color: var(--rust); }

/* ── Mail items ── */
.bmail-item {
  padding: 14px 18px 12px;
  border-bottom: 1px solid var(--smoke);
  transition: background .1s;
  cursor: default;
}
.bmail-item:last-child { border-bottom: none; }
.bmail-item:hover { background: var(--ivory); }

.bmail-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 6px;
}

.bmail-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--charcoal2) 0%, var(--charcoal3) 100%);
  color: var(--gold);
  font-size: 0.78rem;
  font-weight: 700;
  display: flex;
  align-items: center;
  justify-content: center;
  flex-shrink: 0;
  font-family: 'DM Mono', monospace;
  letter-spacing: -.02em;
}

.bmail-meta {
  flex: 1;
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  min-width: 0;
  gap: 6px;
}

.bmail-from {
  font-size: 0.84rem;
  color: var(--charcoal);
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  max-width: 170px;
}

.bmail-time {
  font-size: 0.68rem;
  font-family: 'DM Mono', monospace;
  color: var(--mist2);
  flex-shrink: 0;
}

.bmail-unread .bmail-from { color: var(--charcoal); }
.bmail-unread .bmail-subject { color: var(--charcoal); font-weight: 700; }
.bmail-thread-count {
  display: inline-flex; align-items: center; justify-content: center;
  background: var(--charcoal3); color: var(--mist2);
  font-size: 0.62rem; font-family: 'DM Mono', monospace; font-weight: 700;
  padding: 1px 5px; border-radius: 10px; margin-left: 5px;
  vertical-align: middle;
}

.bmail-subject {
  font-size: 0.83rem;
  color: var(--charcoal);
  margin-bottom: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  font-weight: 500;
}

.bmail-preview {
  font-size: 0.75rem;
  color: var(--mist);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: 9px;
  line-height: 1.5;
}

.bmail-summary {
  color: var(--charcoal);
  white-space: normal;
  font-size: 0.82rem;
  background: var(--ivory);
  padding: 8px 12px;
  border-radius: 8px;
  border-left: 3px solid var(--gold);
  line-height: 1.6;
  margin: 4px 0 10px;
}

.bmail-actions {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  margin-top: 2px;
}

.bmail-btn {
  font-size: 0.72rem;
  padding: 5px 11px;
  border-radius: 7px;
  border: 1px solid var(--ivory3);
  background: var(--ivory);
  cursor: pointer;
  color: var(--charcoal3);
  transition: all .12s;
  white-space: nowrap;
  font-weight: 500;
  letter-spacing: .01em;
}
.bmail-btn:hover {
  background: var(--ivory2);
  border-color: var(--smoke);
}
.bmail-btn-ai:hover { background: var(--gold-pale); border-color: rgba(200,169,110,.4); color: var(--gold-deep); }
.bmail-btn-reply:hover { background: #eff6ff; border-color: #bfdbfe; color: #1d4ed8; }
.bmail-btn-done:hover  { background: #f0fdf4; border-color: #bbf7d0; color: #15803d; }
.bmail-btn-delete { opacity: .55; }
.bmail-btn-delete:hover { background: #fff5f5; border-color: #fecaca; color: var(--rust); opacity: 1; }

/* Inline expand zone */
.bmail-inline {
  margin-top: 12px;
  border-top: 1px solid var(--ivory3);
  padding-top: 12px;
}
.bmail-inline-loading {
  font-size: 0.81rem;
  color: var(--mist);
  font-style: italic;
  padding: 2px 0;
}
.bmail-inline-result {
  background: var(--ivory);
  border-radius: 10px;
  padding: 13px 15px;
  border: 1px solid var(--ivory3);
}
.bmail-inline-label {
  font-size: 0.65rem;
  font-family: 'DM Mono', monospace;
  color: var(--gold);
  text-transform: uppercase;
  letter-spacing: .08em;
  margin-bottom: 7px;
  font-weight: 600;
}
.bmail-inline-text {
  font-size: 0.83rem;
  color: var(--charcoal);
  line-height: 1.65;
}

.bmail-draft-area {
  width: 100%;
  box-sizing: border-box;
  border: 1.5px solid var(--ivory3);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 0.82rem;
  line-height: 1.6;
  resize: vertical;
  min-height: 110px;
  font-family: inherit;
  color: var(--charcoal);
  background: white;
  transition: border-color .12s;
}
.bmail-draft-area:focus { border-color: var(--gold); outline: none; box-shadow: 0 0 0 3px rgba(200,169,110,.1); }

/* ── Events ── */
.bevent-item {
  display: flex;
  align-items: flex-start;
  gap: 12px;
  padding: 11px 18px;
  border-bottom: 1px solid var(--smoke);
}
.bevent-item:last-of-type { border-bottom: none; }
.bevent-item:hover { background: var(--ivory); }

.bevent-time {
  font-size: 0.7rem;
  font-family: 'DM Mono', monospace;
  color: var(--charcoal);
  background: var(--gold-pale);
  border: 1px solid rgba(200,169,110,.3);
  padding: 3px 8px;
  border-radius: 6px;
  flex-shrink: 0;
  margin-top: 1px;
  min-width: 44px;
  text-align: center;
  font-weight: 600;
}

.bevent-body { flex: 1; min-width: 0; }
.bevent-title {
  font-size: 0.85rem;
  color: var(--charcoal);
  font-weight: 500;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.bevent-loc {
  font-size: 0.73rem;
  color: var(--mist);
  margin-top: 2px;
}
.bevent-actions { display: flex; gap: 4px; }

/* ── Tasks ── */
.btask-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 16px 11px 18px;
  border-bottom: 1px solid var(--smoke);
  position: relative;
}
.btask-item::before {
  content: '';
  position: absolute;
  left: 0;
  top: 8px;
  bottom: 8px;
  width: 3px;
  border-radius: 0 2px 2px 0;
  background: var(--ivory3);
}
.btask-item:last-child { border-bottom: none; }
.btask-urgent::before     { background: var(--rust); width: 4px; }
.btask-urgent             { background: rgba(181,74,58,.05); }
.btask-high::before       { background: var(--amber); }
.btask-high               { background: rgba(184,132,58,.04); }
.btask-normal::before     { background: var(--ivory3); }
.btask-normal .btask-title { color: var(--ink3); }
.btask-commitment::before { background: var(--gold); }
.btask-commitment .btask-title::after {
  content: 'engagement';
  font-size: .68rem;
  font-weight: 600;
  letter-spacing: .03em;
  color: var(--gold-deep);
  background: var(--gold-pale);
  border-radius: 3px;
  padding: 1px 5px;
  margin-left: 6px;
  vertical-align: middle;
}
.btask-body { flex: 1; min-width: 0; }
.btask-title {
  font-size: 0.84rem;
  color: var(--charcoal);
  font-weight: 500;
  line-height: 1.4;
}
.btask-date {
  font-size: 0.72rem;
  font-family: 'DM Mono', monospace;
  color: var(--mist);
  margin-top: 3px;
}
.btask-overdue { color: var(--rust); font-weight: 700; }

/* ── Info items ── */
.brief-info-item {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 10px 18px;
  border-bottom: 1px solid var(--smoke);
}
.brief-info-item:last-child { border-bottom: none; }
.brief-info-item:hover { background: var(--ivory); }
.brief-info-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
  margin-top: 6px;
}
.brief-info-text {
  flex: 1;
  font-size: 0.81rem;
  color: var(--charcoal2);
  line-height: 1.55;
}

.brief-unread { font-weight: 700; }
.text-danger  { color: var(--rust); }

/* Pending analysis note */
.brief-pending {
  font-size: 0.75rem;
  color: rgba(200,169,110,.7);
  padding: 6px 12px 6px 18px;
  background: rgba(200,169,110,.05);
  border-left: 2px solid rgba(200,169,110,.2);
  margin: 8px 10px 0;
  border-radius: 0 6px 6px 0;
  font-style: italic;
}

/* ── Chat FAB + Panel ─────────────────────────────────────────────────────── */
#chat-fab {
  display: none; /* hidden on desktop — shown via media query when chat-col is hidden */
  position: fixed; bottom: 24px; right: 24px;
  width: 52px; height: 52px; border-radius: 50%;
  background: var(--gold); color: white;
  border: none; cursor: pointer; font-size: 1.3rem;
  box-shadow: 0 4px 18px rgba(0,0,0,0.18);
  z-index: 900; transition: transform .15s, background .15s;
}
#chat-fab:hover { transform: scale(1.07); background: var(--gold-dark, #b8952a); }

#chat-panel-overlay {
  position: fixed; inset: 0; background: rgba(0,0,0,0.25); z-index: 950;
  display: none;
  opacity: 0; pointer-events: none;
  transition: opacity .25s ease;
}
#chat-panel-overlay.visible {
  display: block;
  opacity: 1; pointer-events: all;
}
#chat-panel {
  position: fixed; bottom: 0; right: 0;
  width: 380px; max-width: 100vw;
  height: 500px; max-height: 80vh;
  background: white; border-radius: 16px 16px 0 0;
  box-shadow: 0 -4px 30px rgba(0,0,0,0.14);
  z-index: 960; flex-direction: column;
}
.chat-panel-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 12px 16px;
  background: var(--charcoal); color: white;
  border-radius: 16px 16px 0 0;
  font-size: 0.88rem; font-weight: 600;
}
.chat-panel-header button {
  background: none; border: none; color: white; cursor: pointer; font-size: 1rem;
}

@media (max-width: 768px) {
  .brief-grid { grid-template-columns: 1fr; }
  .brief-card-emails { grid-column: 1; }
  #chat-panel { width: 100%; border-radius: 16px 16px 0 0; }
}

/* ══════════════════════════════════════════════════════
   CHAT COLUMN (permanent right panel)
══════════════════════════════════════════════════════ */
#chat-col {
  display: flex;
  flex-direction: column;
  background: var(--ivory2);
  border-left: 2px solid var(--smoke);
  overflow: hidden;
  position: relative;
  z-index: 100;
}

.chatcol-header {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 15px 18px 13px;
  border-bottom: 1.5px solid var(--smoke);
  background: var(--paper);
  flex-shrink: 0;
}

.chatcol-logo {
  font-size: 1.05rem;
}

.chatcol-title {
  font-family: 'Playfair Display', serif;
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--ink);
  letter-spacing: .01em;
  flex: 1;
}

.chatcol-messages {
  flex: 1;
  overflow-y: auto;
  padding: 14px 14px 8px;
  display: flex;
  flex-direction: column;
  gap: 10px;
  min-height: 0;
}

.chatcol-msg { display: flex; }
.chatcol-msg.user { justify-content: flex-end; }
.chatcol-msg.assistant { justify-content: flex-start; }

.chatcol-bubble {
  max-width: 88%;
  padding: 9px 13px;
  border-radius: 14px;
  font-size: 0.835rem;
  line-height: 1.55;
}

.chatcol-msg.user .chatcol-bubble {
  background: var(--gold-deep);
  color: #fff;
  border-radius: 14px 14px 4px 14px;
}

.chatcol-msg.assistant .chatcol-bubble {
  background: var(--paper);
  color: var(--charcoal);
  border: 1.5px solid var(--smoke);
  border-radius: 14px 14px 14px 4px;
}

.chatcol-typing { opacity: 0.75; }
.chatcol-typing .chatcol-bubble::after {
  content: '…';
  animation: blink 1s infinite;
}

.chatcol-input-area {
  border-top: 1.5px solid var(--smoke);
  padding: 10px 12px 12px;
  flex-shrink: 0;
  background: var(--paper);
}

#chatcol-input {
  width: 100%;
  background: var(--ivory);
  border: 1.5px solid var(--smoke);
  border-radius: 10px;
  color: var(--ink);
  padding: 8px 12px;
  font-size: 0.825rem;
  line-height: 1.5;
  resize: none;
  outline: none;
  transition: border-color .15s;
}
#chatcol-input::placeholder { color: var(--mist); }
#chatcol-input:focus { border-color: var(--gold); box-shadow: 0 0 0 3px rgba(200,169,110,.1); }

.chatcol-input-row {
  display: flex;
  justify-content: flex-end;
  gap: 6px;
  margin-top: 6px;
}

.chatcol-send {
  background: var(--ink);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 6px 14px;
  font-size: 0.8rem;
  font-weight: 600;
  cursor: pointer;
  transition: background .15s;
}
.chatcol-send:hover { background: var(--gold-deep); }

/* ── Situation cards (briefing I section) ─── */
.situation-card {
  background: var(--paper);
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-lg);
  padding: 14px 16px;
  margin-bottom: 8px;
  transition: box-shadow .15s, border-color .15s;
  box-shadow: 0 1px 3px rgba(0,0,0,.05), 0 4px 12px rgba(0,0,0,.06);
}
.situation-card:last-child { margin-bottom: 0; }
.situation-card:hover { box-shadow: 0 2px 8px rgba(0,0,0,.08), 0 8px 24px rgba(0,0,0,.1); border-color: var(--mist2); }

/* ── Claire memory hint ── */
.claire-memory-hint {
  font-size: .76rem;
  color: var(--gold-deep);
  background: var(--gold-pale);
  border-left: 2px solid var(--gold);
  border-radius: 0 var(--r-sm) var(--r-sm) 0;
  padding: 5px 10px;
  margin: 6px 0 8px;
  line-height: 1.5;
  font-style: italic;
}
.claire-memory-hint-sm {
  font-size: .72rem;
  color: var(--gold-deep);
  background: var(--gold-pale);
  border-radius: var(--r-sm);
  padding: 3px 8px;
  margin-top: 4px;
  font-style: italic;
  display: inline-block;
}

.situation-card-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 8px;
}

.situation-avatar {
  width: 34px;
  height: 34px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--gold-deep), var(--gold));
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.9rem;
  font-weight: 700;
  flex-shrink: 0;
}

.situation-meta {
  flex: 1;
  min-width: 0;
}

.situation-from {
  font-weight: 600;
  font-size: 0.88rem;
  color: var(--ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.situation-from.unread { color: var(--charcoal); }

.situation-age {
  font-size: 0.74rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 4px;
}
.situation-age.age-ok  { background: #e8f4e8; color: #4a7a4c; }
.situation-age.age-warn { background: #fef3e2; color: #b87020; }
.situation-age.age-late { background: #fdecea; color: var(--rust); }

.situation-summary {
  font-size: 0.845rem;
  color: var(--charcoal);
  line-height: 1.55;
  margin-bottom: 10px;
}

.situation-actions {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
}

.sit-btn {
  padding: 5px 11px;
  border-radius: 7px;
  font-size: 0.78rem;
  font-weight: 600;
  border: 1.5px solid var(--ivory3);
  background: var(--ivory2);
  color: var(--charcoal);
  cursor: pointer;
  transition: background .12s, border-color .12s, color .12s;
}
.sit-btn:hover { background: var(--smoke); border-color: var(--mist2); color: var(--ink); }
.sit-btn.primary { background: var(--gold-pale); border-color: rgba(200,169,110,.4); color: var(--gold-deep); }
.sit-btn.primary:hover { background: rgba(200,169,110,.2); border-color: var(--gold); }
.sit-btn.archive { background: #f0f7f0; border-color: #c0dac0; color: var(--sage); }
.sit-btn.archive:hover { background: #e0f0e0; }
.sit-btn.draft-ready { background: var(--charcoal); color: var(--gold); border-color: var(--charcoal2); }
.sit-btn.draft-ready:hover { background: var(--charcoal2); }

/* Draft inline (in situation card) */
.sit-draft-box {
  margin-top: 10px;
  background: var(--ivory);
  border: 1.5px solid var(--smoke);
  border-radius: 10px;
  padding: 12px;
}
.sit-draft-label {
  font-size: 0.75rem;
  font-weight: 700;
  color: var(--charcoal2);
  text-transform: uppercase;
  letter-spacing: .06em;
  margin-bottom: 6px;
}
.sit-draft-area {
  width: 100%;
  min-height: 100px;
  background: var(--paper);
  border: 1px solid var(--smoke);
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 0.83rem;
  line-height: 1.55;
  resize: vertical;
  color: var(--ink);
  outline: none;
}
.sit-draft-area:focus { border-color: var(--gold); }
.sit-draft-row {
  display: flex;
  gap: 8px;
  margin-top: 8px;
  flex-wrap: wrap;
}

/* Waiting replies (P section) — compact list inside card container */
.wait-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--smoke);
  background: transparent;
}
.wait-item:last-child { border-bottom: none; }
.wait-avatar {
  width: 28px;
  height: 28px;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--sage), #3d5e3f);
  color: #fff;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 0.78rem;
  font-weight: 700;
  flex-shrink: 0;
}
.wait-body { flex: 1; min-width: 0; }
.wait-from { font-size: 0.83rem; font-weight: 600; color: var(--ink); }
.wait-summary { font-size: 0.78rem; color: var(--mist); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.wait-age { font-size: 0.72rem; font-weight: 600; color: var(--mist2); }
.wait-actions { display: flex; gap: 5px; }

/* Info items (R section) — ultra-compact list inside card container */
.info-item {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  padding: 8px 14px;
  border-bottom: 1px solid var(--smoke);
  font-size: 0.81rem;
  color: var(--charcoal2);
}
.info-item:last-child { border-bottom: none; }
.info-dot { width: 6px; height: 6px; border-radius: 50%; background: var(--mist2); flex-shrink: 0; margin-top: 5px; }
.info-text { flex: 1; line-height: 1.45; }
.info-archive-btn {
  background: none;
  border: none;
  cursor: pointer;
  color: var(--mist2);
  font-size: 0.8rem;
  padding: 0 2px;
  flex-shrink: 0;
}
.info-archive-btn:hover { color: var(--sage); }
/* Event proposal card (détection RDV dans infos) */
.event-proposal-card {
  margin: 6px 0;
  padding: 11px 14px 10px;
  background: rgba(201,168,76,.07);
  border: 1px solid rgba(201,168,76,.28);
  border-radius: 10px;
}
.evprop-source {
  font-size: 0.74rem;
  color: var(--charcoal2);
  margin-bottom: 7px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.evprop-body {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  margin-bottom: 9px;
}
.evprop-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.evprop-details { flex: 1; }
.evprop-title { font-size: 0.85rem; font-weight: 600; color: var(--charcoal); line-height: 1.3; }
.evprop-date { font-size: 0.78rem; color: var(--charcoal2); margin-top: 2px; }
.evprop-actions { display: flex; gap: 7px; flex-wrap: wrap; }
.evprop-btn-add {
  padding: 5px 12px;
  border-radius: 7px;
  font-size: 0.78rem;
  font-weight: 600;
  border: 1.5px solid rgba(201,168,76,.5);
  background: var(--charcoal);
  color: var(--gold);
  cursor: pointer;
  transition: background .12s;
}
.evprop-btn-add:hover { background: #1a1a1a; }
.evprop-btn-add:disabled { opacity: .5; cursor: default; }
.evprop-btn-ignore {
  padding: 5px 12px;
  border-radius: 7px;
  font-size: 0.78rem;
  font-weight: 500;
  border: 1px solid var(--smoke);
  background: transparent;
  color: var(--charcoal2);
  cursor: pointer;
  transition: background .12s, color .12s;
}
.evprop-btn-ignore:hover { background: var(--smoke); color: var(--charcoal); }
.event-proposal-card.evprop-confirmed {
  background: #f0f7f0;
  border-color: #b8d8b8;
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 38px;
}
.evprop-confirm-msg { font-size: 0.82rem; font-weight: 600; color: var(--sage); }
.evprop-warning { font-size: 0.8rem; color: var(--rust); margin-bottom: 7px; line-height: 1.5; }
.evprop-warning strong { color: var(--ink2); }
.evprop-warning-actions { display: flex; gap: 7px; flex-wrap: wrap; }

/* Event proposal card dans le chat */
.chat-event-proposal {
  margin: 6px 12px 6px auto;
  max-width: 88%;
  padding: 10px 13px;
  background: rgba(201,168,76,.07);
  border: 1px solid rgba(201,168,76,.3);
  border-radius: 10px;
}

/* Mobile: hide chat-col, show FAB */
@media (max-width: 1024px) {
  #app-screen {
    grid-template-columns: var(--sidebar-w) 1fr;
  }
  #chat-col { display: none; }
  #chat-fab { display: flex; }
}

/* ── Onboarding Wizard ─────────────────────────────────────────────────────── */
.onboarding-modal {
  max-width: 560px;
  overflow: hidden;
}

.onboarding-steps {
  width: 100%;
  flex: 1;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  min-height: 0;
}

.onboard-step {
  flex-direction: column;
  align-items: center;
  text-align: center;
  padding: 36px 32px;
  gap: 14px;
  flex: 1;
  overflow: hidden;
  min-height: 0;
}

.onboard-step[style*="flex"] { display: flex !important; }
.onboard-step:not([style*="none"]) { display: flex; }

.onboard-icon {
  font-size: 3rem;
  margin-bottom: 8px;
}

.onboard-step h2 {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 1.4rem;
  color: var(--ink);
  margin: 0;
}

.onboard-step p {
  color: var(--ink3);
  font-size: 0.88rem;
  line-height: 1.65;
  max-width: 400px;
  margin: 0;
}

.onboard-step label {
  text-align: left;
  width: 100%;
  display: block;
  font-size: 0.8rem;
  color: var(--ink3);
  font-weight: 500;
  margin: 8px 0 4px;
}

.onboard-step input, .onboard-step select {
  width: 100%;
  box-sizing: border-box;
  padding: 10px 12px;
  border: 1.5px solid var(--smoke);
  border-radius: var(--r-sm);
  background: var(--ivory);
  color: var(--ink);
  font-size: 14px;
  font-family: inherit;
  transition: border-color .15s;
}
.onboard-step input:focus, .onboard-step select:focus {
  border-color: var(--gold);
  outline: none;
  box-shadow: 0 0 0 3px rgba(184,132,58,.12);
}
.onboard-step input::placeholder { color: var(--mist2); }

#onboard-provider-section, #onboard-cal-section, #onboard-profile-section {
  width: 100%;
  text-align: left;
  flex: 1;
  overflow-y: auto;
  -webkit-overflow-scrolling: touch;
  min-height: 0;
}

.onboard-footer {
  display: flex;
  justify-content: space-between;
  align-items: center;
  width: 100%;
  margin-top: 12px;
  gap: 10px;
  flex-shrink: 0;
}

.onboard-footer .btn-action {
  font-size: 0.8rem;
  color: var(--ink4);
  border-color: var(--smoke);
}


/* ── Delta Banner ──────────────────────────────────── */
.brief-delta-banner {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: linear-gradient(135deg, rgba(200,169,110,.12), rgba(200,169,110,.06));
  border: 1px solid rgba(200,169,110,.3);
  border-radius: var(--r);
  padding: 12px 16px;
  margin-bottom: 12px;
  font-size: 0.88rem;
  color: var(--ink3);
  line-height: 1.5;
}
.brief-delta-icon { font-size: 1.1rem; flex-shrink: 0; margin-top: 1px; }
.brief-delta-close { background: none; border: none; color: var(--mist); cursor: pointer; margin-left: auto; font-size: 1rem; padding: 0 4px; flex-shrink: 0; }

/* ── Memory Confirm Banner ─────────────────────────── */
.memory-confirm-banner {
  background: rgba(200,169,110,.1);
  border: 1px solid rgba(200,169,110,.25);
  border-radius: var(--r);
  padding: 12px 16px;
  margin-bottom: 12px;
}
.memory-confirm-title { font-size: 0.82rem; color: var(--gold); font-weight: 600; margin-bottom: 8px; }
.memory-confirm-item { display: flex; align-items: center; gap: 8px; padding: 6px 0; font-size: 0.85rem; border-bottom: 1px solid rgba(255,255,255,.06); }
.memory-confirm-item:last-child { border-bottom: none; }
.memory-confirm-item span { flex: 1; color: var(--ivory2); }

/* ── Memory View ───────────────────────────────────── */
.memory-container { padding: 16px; max-width: 800px; }
.memory-toolbar { display: flex; justify-content: space-between; align-items: center; margin-bottom: 16px; gap: 12px; flex-wrap: wrap; }
.memory-filters { display: flex; gap: 6px; flex-wrap: wrap; }
.memory-filter-btn { background: var(--charcoal2); border: 1.5px solid var(--charcoal3); color: var(--mist2); border-radius: 20px; padding: 5px 14px; font-size: 0.8rem; cursor: pointer; transition: all .15s; }
.memory-filter-btn.active { background: var(--gold-glow); border-color: var(--gold); color: var(--gold); }
.memory-section-title { font-size: 0.75rem; font-weight: 600; letter-spacing: .08em; color: var(--mist); text-transform: uppercase; margin: 12px 0 6px; }
.memory-pending-section { background: rgba(200,169,110,.06); border: 1px solid rgba(200,169,110,.2); border-radius: var(--r); padding: 12px; margin-bottom: 12px; }
.memory-onboard-card { display: flex; flex-direction: column; align-items: center; gap: 12px; padding: 28px 20px; background: var(--paper); border: 1px solid rgba(201,168,76,.2); border-radius: var(--r); text-align: center; }
.memory-onboard-icon { font-size: 2.2rem; }
.memory-onboard-text { font-size: 0.88rem; color: var(--ivory2); line-height: 1.6; }
.memory-onboard-text strong { color: var(--ivory); }
.memory-group { margin-bottom: 16px; }
.memory-group-title { font-size: 0.78rem; font-weight: 600; color: var(--gold); margin-bottom: 6px; }
.memory-item-pending { border: 1px dashed rgba(200,169,110,.3); }
.memory-tag { font-size: 0.68rem; padding: 2px 8px; border-radius: 10px; font-weight: 600; flex-shrink: 0; }
.memory-tag-user { background: rgba(100,160,255,.15); color: #7eb3ff; }
.memory-tag-contact { background: rgba(100,220,160,.15); color: #6ddba0; }
.memory-tag-dossier { background: rgba(200,169,110,.15); color: var(--gold); }
.memory-ref { font-size: 0.75rem; color: var(--mist); flex-shrink: 0; }
.memory-content { flex: 1; color: var(--ivory2); outline: none; }
.memory-content[contenteditable="true"] { background: var(--charcoal3); border-radius: 4px; padding: 2px 6px; }
.memory-actions { display: flex; gap: 4px; flex-shrink: 0; }
.btn-success { background: rgba(100,220,100,.15); border-color: rgba(100,220,100,.3); color: #6ddc6d; }
.btn-danger  { background: rgba(220,80,80,.12);  border-color: rgba(220,80,80,.25);  color: #e07070; }
/* Fix 06/07/08/09 — memory enhancements */
.memory-item { display: flex; flex-direction: column; gap: 4px; padding: 8px 12px; background: var(--charcoal2); border-radius: var(--r); margin-bottom: 6px; font-size: 0.85rem; }
.memory-item-contextual { opacity: .82; }
.memory-contextual { font-size: .8rem; color: var(--mist); }
.memory-sensitive { display: block; }
.memory-sensitive-hint { font-size: .78rem; color: var(--mist); font-style: italic; }
.memory-item-footer { display: flex; align-items: center; justify-content: space-between; margin-top: 2px; }
.memory-age { font-size: .68rem; color: var(--mist); }
.memory-pending-more { font-size: .74rem; color: var(--mist); font-style: italic; padding: 4px 12px; }
.memory-show-more { background: none; border: none; color: var(--gold); font-size: .74rem; cursor: pointer; padding: 4px 0 8px; display: block; }
.memory-show-more:hover { text-decoration: underline; }
.memory-toolbar-bottom { padding: 10px 0 4px; border-top: 1px solid rgba(255,255,255,.08); margin-top: 8px; }
.memory-dedup-btn { font-size: .78rem; }
/* Fix 01 — panel fusion contacts doublons */
.memory-dedup-panel { background: rgba(200,169,110,.07); border: 1px solid rgba(200,169,110,.25); border-radius: var(--r); padding: 12px; margin-bottom: 14px; }
.memory-dedup-group { margin-bottom: 12px; padding-bottom: 10px; border-bottom: 1px solid rgba(255,255,255,.07); }
.memory-dedup-group:last-child { border-bottom: none; margin-bottom: 0; padding-bottom: 0; }
.memory-dedup-name { font-size: .8rem; font-weight: 600; color: var(--gold); margin-bottom: 6px; }
.memory-dedup-entry { display: flex; align-items: baseline; gap: 8px; font-size: .8rem; padding: 3px 0; cursor: pointer; }
.memory-dedup-entry input[type="radio"] { flex-shrink: 0; }
.memory-dedup-actions { display: flex; gap: 6px; margin-top: 8px; }

/* ── Draft saved note ──────────────────────────────── */
.draft-saved-note { font-size: 0.82rem; color: #6ddc6d; background: rgba(100,220,100,.08); border: 1px solid rgba(100,220,100,.2); border-radius: var(--r); padding: 10px 14px; margin-top: 10px; }

/* ══════════════════════════════════════════════════════
   ── POLISH ──────────────────────────────────────────
   High-impact visual improvements — appended 2026-03-18
══════════════════════════════════════════════════════ */

/* ── 1. Brief banner — luxury concierge card ──────── */
.brief-banner {
  background: linear-gradient(135deg, var(--charcoal) 0%, #2d2a2a 60%, #353030 100%) !important;
  border-bottom: none !important;
  position: relative;
  padding: 20px 26px 18px !important;
  gap: 20px !important;
}

/* Gold shimmer line at bottom */
.brief-banner::after {
  content: '';
  position: absolute;
  bottom: 0; left: 0; right: 0;
  height: 2px;
  background: linear-gradient(90deg,
    transparent 0%,
    rgba(200,169,110,.25) 20%,
    rgba(200,169,110,.7) 50%,
    rgba(200,169,110,.25) 80%,
    transparent 100%);
}

.brief-banner-greeting {
  font-size: 1.35rem !important;
  color: var(--ivory) !important;
  font-weight: 700 !important;
  letter-spacing: -.01em;
}

.brief-banner-date {
  color: rgba(200,169,110,.6) !important;
  margin-top: 5px !important;
}

.brief-banner-claire {
  background: rgba(200,169,110,.1) !important;
  border: 1px solid rgba(200,169,110,.3) !important;
  border-radius: 14px !important;
  padding: 12px 16px !important;
  box-shadow: inset 0 1px 0 rgba(200,169,110,.1), 0 2px 12px rgba(0,0,0,.2);
}

.brief-banner-claire-label {
  font-size: 1.25rem !important;
}

.brief-banner-claire-text {
  color: var(--ivory2) !important;
  font-size: 0.88rem !important;
  line-height: 1.7 !important;
}

.brief-banner-claire-text strong {
  color: var(--gold) !important;
}

.brief-loading-text {
  color: rgba(200,169,110,.65) !important;
  font-style: italic;
}

.brief-banner-refresh {
  border-color: rgba(200,169,110,.3) !important;
  color: rgba(200,169,110,.6) !important;
}
.brief-banner-refresh:hover {
  border-color: var(--gold) !important;
  color: var(--gold) !important;
  background: rgba(200,169,110,.1) !important;
}

/* ── 2. Situation cards — urgency visual ─────────── */

/* Age-class left border accents */
.situation-card.age-ok {
  border-left: 3px solid #5a9a5c !important;
}
.situation-card.age-warn {
  border-left: 3px solid var(--amber) !important;
}
.situation-card.age-late {
  border-left: 3px solid var(--rust) !important;
  background: rgba(192,80,58,.03) !important;
}

/* Enhanced hover */
.situation-card:hover {
  transform: translateY(-1px);
  box-shadow: 0 3px 12px rgba(0,0,0,.09), 0 10px 30px rgba(0,0,0,.12) !important;
  border-color: rgba(200,169,110,.4) !important;
}

/* Pulsing unread dot */
.situation-unread-dot {
  display: inline-block;
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--gold);
  flex-shrink: 0;
  animation: pulse-dot 2s ease-in-out infinite;
}

@keyframes pulse-dot {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: .55; transform: scale(.75); }
}

/* ── 3. FAB — inviting on mobile ─────────────────── */
#chat-fab {
  width: 60px !important;
  height: 60px !important;
  background: linear-gradient(145deg, var(--gold) 0%, var(--gold-deep) 100%) !important;
  box-shadow: 0 6px 24px rgba(200,169,110,.4), 0 2px 8px rgba(0,0,0,.2) !important;
  font-size: 1.5rem !important;
  animation: fab-idle-glow 3.5s ease-in-out infinite;
}

#chat-fab:hover {
  transform: scale(1.08) !important;
  animation: none;
  box-shadow: 0 8px 32px rgba(200,169,110,.55), 0 2px 8px rgba(0,0,0,.25) !important;
}

@keyframes fab-idle-glow {
  0%, 100% { box-shadow: 0 6px 24px rgba(200,169,110,.4), 0 2px 8px rgba(0,0,0,.2); }
  50%       { box-shadow: 0 6px 32px rgba(200,169,110,.65), 0 2px 8px rgba(0,0,0,.2); }
}

/* Claire parle — indicateur TTS actif */
#chat-fab.speaking {
  animation: fab-speaking 0.9s ease-in-out infinite !important;
}

@keyframes fab-speaking {
  0%, 100% { opacity: 1; transform: scale(1); }
  50%       { opacity: 0.65; transform: scale(0.94); }
}

/* FAB label */
#chat-fab-label {
  position: fixed;
  bottom: 90px;
  right: 20px;
  font-family: 'Playfair Display', serif;
  font-style: italic;
  font-size: 0.78rem;
  color: var(--gold-deep);
  background: var(--paper);
  padding: 3px 10px;
  border-radius: 10px;
  box-shadow: 0 2px 8px rgba(0,0,0,.12);
  border: 1px solid rgba(200,169,110,.25);
  pointer-events: none;
  opacity: 0;
  transform: translateY(6px);
  transition: opacity .4s ease, transform .4s ease;
  display: none;
}
#chat-fab-label.visible {
  display: block;
  opacity: 1;
  transform: translateY(0);
}

/* ── 4. Card entrance animations ─────────────────── */
@keyframes slide-up-in {
  from { opacity: 0; transform: translateY(14px); }
  to   { opacity: 1; transform: translateY(0); }
}

.situation-card {
  animation: slide-up-in .38s ease both;
}
.situation-card:nth-child(1) { animation-delay: 0ms; }
.situation-card:nth-child(2) { animation-delay: 60ms; }
.situation-card:nth-child(3) { animation-delay: 120ms; }
.situation-card:nth-child(4) { animation-delay: 180ms; }
.situation-card:nth-child(5) { animation-delay: 240ms; }

/* ── 5. Chat bubbles — warmer and more personal ──── */

/* Panel chat — assistant bubble */
.chat-msg.assistant .chat-bubble {
  background: var(--gold-pale) !important;
  border: 1px solid rgba(200,169,110,.25) !important;
  border-left: 3px solid rgba(200,169,110,.55) !important;
  color: var(--charcoal) !important;
  box-shadow: 0 1px 6px rgba(0,0,0,.06) !important;
}

/* First sentence italic on first assistant message */
.chat-msg.assistant:first-child .chat-bubble {
  font-style: italic;
}

/* Chat column — assistant bubble */
.chatcol-msg.assistant .chatcol-bubble {
  background: var(--gold-pale) !important;
  border: 1.5px solid rgba(200,169,110,.25) !important;
  border-left: 3px solid rgba(200,169,110,.5) !important;
  color: var(--charcoal) !important;
}

/* Typing indicator text */
.claire-typing-text {
  color: var(--mist);
  font-style: italic;
  font-size: 0.82rem;
}

@keyframes dots-blink {
  0%, 20%  { content: '.'; }
  40%      { content: '..'; }
  60%, 100% { content: '...'; }
}

.claire-typing-dots::after {
  content: '.';
  animation: dots-blink .9s steps(1) infinite;
}

/* ── 6. Chatcol typing — animated "réfléchit" ─────
   (the ::after is already defined — we add a richer class) */
.chatcol-typing .chatcol-bubble {
  font-style: italic;
  color: var(--mist) !important;
}
.chatcol-typing .chatcol-bubble::after {
  content: '' !important; /* reset — handled by JS innerHTML */
}

/* ── 7. Section headers — bolder ──────────────────── */
.brief-section-title {
  border-left: 3px solid rgba(200,169,110,.45) !important;
  padding-left: 8px !important;
  font-size: 0.72rem !important;
}

/* ── 8. Empty states — Claire speaking ───────────── */
.brief-empty {
  text-align: center;
  padding: 20px 16px;
  font-size: 0.82rem;
  color: var(--mist);
  font-style: italic;
  line-height: 1.6;
}

/* ══════════════════════════════════════════════════════
   RESPONSIVE — MOBILE (≤768px)
══════════════════════════════════════════════════════ */
@media (max-width: 768px) {

  /* Touch: remove 300ms delay on all interactive elements */
  button, a, input, textarea, select { touch-action: manipulation; }

  /* Grid: sidebar is fixed/offscreen → only 1 column needed */
  #app-screen {
    grid-template-columns: 1fr !important;
  }

  /* Brief banner: stack vertically on mobile */
  .brief-banner {
    flex-direction: column;
    gap: 10px;
    padding: 12px 14px 10px;
    align-items: stretch;
  }
  .brief-banner-left {
    flex-direction: row;
    align-items: center;
    gap: 12px;
    min-width: unset;
  }
  .brief-banner-greeting { font-size: 1rem; }
  .brief-banner-date { margin-top: 0; }
  .brief-banner-claire { flex: unset; }
  .brief-banner-refresh { align-self: flex-end; }

  /* Brief layout: tighter paddings */
  .brief-col-main { padding: 10px 12px 16px; gap: 14px; }
  .brief-col-side  { padding: 0 12px 16px; gap: 12px; }

  /* Situation cards: more compact */
  .situation-card { padding: 12px 14px; border-radius: var(--r); }
  .situation-actions { gap: 5px; }

  /* Action buttons: bigger tap targets for fingers */
  .sit-btn {
    padding: 8px 12px;
    font-size: 0.82rem;
    min-height: 38px;
  }

  /* Draft area: smaller on mobile */
  .sit-draft-area { min-height: 80px; }
  .sit-draft-row { gap: 6px; }

  /* Brief section containers */
  #brief-events, #brief-tasks, #brief-info, #brief-waiting {
    border-radius: var(--r);
  }

  /* Topbar: tighter */
  .topbar { padding: 10px 14px; }

  /* Delta banner */
  .brief-delta-banner { padding: 10px 14px; font-size: 0.82rem; }

  /* Memory confirm banner */
  .memory-confirm-banner { padding: 12px 14px; }

  /* Modals: near full screen */
  .modal { width: 96%; max-height: 92vh; }

  /* Onboarding: compact */
  .onboard-step { padding: 24px 18px; }
  .onboarding-modal { max-width: 100%; }
}

/* ── Very small screens (≤430px) ─────────────────── */
@media (max-width: 430px) {

  body { font-size: 13px; }

  .topbar h2 { font-size: 14px; }

  /* Banner: more compact */
  .brief-banner { padding: 10px 12px 8px; }
  .brief-banner-greeting { font-size: 0.92rem; }

  /* Cards */
  .situation-card { padding: 10px 12px; }
  .situation-from { font-size: 0.84rem; }
  .situation-summary { font-size: 0.80rem; }
  .sit-btn { padding: 7px 10px; font-size: 0.80rem; }

  /* Compact section titles */
  .brief-section-title { font-size: 0.67rem !important; }

  /* Wait/info items */
  .wait-item, .info-item { padding: 8px 12px; }

  /* Chat FAB: slightly smaller */
  #chat-fab { width: 50px; height: 50px; font-size: 1.2rem; bottom: 18px; right: 16px; }

  /* Auth */
  .auth-card { padding: 28px 18px; }
}

/* ══════════════════════════════════════════════════════
   PAPIER & AMBRE — Thème complet
   Interface crème, Fraunces, cartes blanches
══════════════════════════════════════════════════════ */

/* ── App layout ── */
#app-screen {
  background: var(--cream) !important;
  flex-direction: row !important;
  align-items: stretch !important;
  grid-template-columns: unset !important;
}
/* Kill pseudo-element spacer from old CSS */
#app-screen::before { content: none !important; display: none !important; width: 0 !important; }
/* Kill old grid at tablet breakpoint */
@media (max-width: 1024px) {
  #app-screen { display: flex !important; flex-direction: row !important; grid-template-columns: unset !important; }
}

/* ── Sidebar: icon strip 44px, collapsible ── */
#sidebar {
  position: static !important;
  width: 44px !important;
  flex-shrink: 0 !important;
  background: var(--cream) !important;
  border-right: 0.5px solid var(--smoke) !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  padding: 10px 0 8px !important;
  gap: 2px !important;
  overflow: hidden !important;
  box-shadow: none !important;
  transition: width .22s cubic-bezier(.4,0,.2,1) !important;
  height: auto !important;
  top: auto !important; left: auto !important; bottom: auto !important;
  z-index: 100 !important;
}
#sidebar:hover { width: 44px !important; box-shadow: none !important; }

/* Prevent old :hover expansion */
#sidebar:hover { width: 44px !important; box-shadow: none !important; }
/* Prevent old .open expansion on desktop */
@media (min-width: 769px) {
  #sidebar.open { width: 44px !important; box-shadow: none !important; }
}

/* Collapsed state */
#sidebar.collapsed {
  width: 0 !important;
  border-right: none !important;
  padding: 0 !important;
}

/* Hide all text labels — icons only */
.sidebar-label, .sidebar-brand-text, .sidebar-title, .sidebar-subtitle,
.sidebar-add, #username-display, .account-name, .account-edit, .account-delete,
.sidebar-calendar-mini, .sidebar-tasks-mini, .sidebar-footer,
.sidebar-header { display: none !important; }

/*
  Nav items: boutons 44px large — overflow hidden côté droit
  L'emoji est au début du texte "🏠 Récap du jour"
  On affiche seulement l'emoji en clippant le texte à droite
*/
.nav-item {
  width: 44px !important;
  height: 34px !important;
  padding: 0 0 0 13px !important; /* emoji visible à ~13px du bord */
  border-radius: 0 !important;
  justify-content: flex-start !important;
  align-items: center !important;
  font-size: 15px !important;
  color: var(--ink3) !important;
  background: none !important;
  border: none !important;
  border-left: 2px solid transparent !important;
  transition: background .1s, color .1s !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
  white-space: nowrap !important;
  text-align: left !important;
}
.nav-item:hover { background: var(--paper) !important; color: var(--ink2) !important; }
.nav-item.active {
  background: var(--gold-pale) !important;
  color: var(--gold) !important;
  border-left-color: var(--gold) !important;
}

/* Account circles */
.account-item {
  width: 28px !important; height: 28px !important;
  padding: 0 !important;
  border-radius: 50% !important;
  justify-content: center !important;
  align-items: center !important;
  font-size: 10px !important;
  flex-shrink: 0 !important;
  overflow: hidden !important;
}

/* Sidebar section: full width, no extra padding */
.sidebar-section {
  display: flex !important;
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 1px !important;
  width: 100% !important;
  padding: 0 !important;
}

/* Thin separator between sections */
.sidebar-section + .sidebar-section::before {
  content: '' !important;
  display: block !important;
  width: 20px !important;
  height: 0.5px !important;
  background: var(--smoke) !important;
  margin: 4px auto !important;
  margin: 4px 0 !important;
}

/* ── Main ── */
#main {
  flex: 1 !important;
  height: 100vh !important;
  background: var(--cream) !important;
  display: flex !important;
  flex-direction: column !important;
  overflow: hidden !important;
  padding-left: 0 !important;
  min-width: 0 !important;
}

/* ── Topbar ── */
.topbar {
  background: var(--cream) !important;
  border-bottom: 0.5px solid var(--smoke) !important;
  height: 52px !important;
  padding: 0 20px !important;
  display: flex !important;
  align-items: center !important;
  gap: 12px !important;
}
.topbar h2 {
  flex: 1 !important;
  font-family: 'DM Sans', sans-serif !important;
  font-size: 11px !important;
  font-style: normal !important;
  font-weight: 400 !important;
  color: var(--ink4) !important;
  letter-spacing: .02em !important;
  text-align: center !important;
}
/* Hamburger = vrai toggle, discret */
.hamburger {
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  width: 30px !important; height: 30px !important;
  font-size: 16px !important;
  background: none !important;
  border: 0.5px solid transparent !important;
  border-radius: 7px !important;
  color: var(--ink4) !important;
  cursor: pointer !important;
  pointer-events: auto !important;
  flex-shrink: 0 !important;
  transition: background .12s, color .12s !important;
}
.hamburger:hover { background: var(--paper) !important; color: var(--ink2) !important; border-color: var(--smoke) !important; }
.hamburger::before, .hamburger::after { display: none !important; }

/* Brand "Claire" dans la topbar */
.topbar-brand {
  font-family: 'Fraunces', serif !important;
  font-size: 18px !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--ink) !important;
  letter-spacing: -.02em !important;
  flex-shrink: 0 !important;
  display: flex !important;
  align-items: center !important;
  gap: 3px !important;
}
.topbar-dot {
  display: inline-block !important;
  width: 5px !important; height: 5px !important;
  border-radius: 50% !important;
  background: var(--gold) !important;
  margin-bottom: 3px !important;
  flex-shrink: 0 !important;
}

/* Refresh button */
.btn-refresh {
  color: var(--ink4) !important;
  border: 0.5px solid transparent !important;
  border-radius: 7px !important;
  width: 30px !important; height: 30px !important;
  background: none !important;
}
.btn-refresh:hover { background: var(--paper) !important; border-color: var(--smoke) !important; color: var(--ink3) !important; transform: none !important; }

/* ── Brief banner — briefing text block ── */
.brief-banner {
  background: var(--paper) !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: var(--r-lg) !important;
  padding: 15px 18px !important;
  margin: 14px 16px 4px !important;
  flex-shrink: 0 !important;
  max-height: 150px !important;
  overflow: hidden !important;
  box-shadow: var(--s-card) !important;
  position: relative !important;
  gap: 0 !important;
  flex-direction: column !important;
  transition: max-height .3s ease !important;
}
/* Quand le texte est développé — lever la contrainte */
.brief-banner.claire-expanded {
  max-height: 800px !important;
  overflow: visible !important;
}
.brief-banner::after { display: none !important; }

.brief-banner-left {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  min-width: unset !important;
  margin-bottom: 8px !important;
  flex-direction: row !important;
  gap: 0 !important;
}
.brief-banner-greeting {
  font-family: 'Fraunces', serif !important;
  font-size: 11px !important;
  font-style: italic !important;
  font-weight: 400 !important;
  color: var(--gold) !important;
  letter-spacing: .03em !important;
}
.brief-banner-date {
  font-size: 10px !important;
  color: var(--ink4) !important;
  font-style: normal !important;
  margin-top: 0 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
  font-family: 'DM Sans', sans-serif !important;
}
.brief-banner-claire {
  background: none !important;
  border: none !important;
  padding: 0 !important;
  box-shadow: none !important;
  border-radius: 0 !important;
  flex: unset !important;
  max-height: unset !important;
}
.brief-banner-claire.is-clamped::after { display: none !important; }
.brief-banner-claire-label { display: none !important; }
.brief-banner-claire-text {
  font-family: 'Fraunces', serif !important;
  font-size: 13.5px !important;
  font-style: italic !important;
  font-weight: 300 !important;
  color: var(--ink2) !important;
  line-height: 1.75 !important;
}
.brief-banner-claire-text strong {
  font-weight: 400 !important;
  font-style: normal !important;
  color: var(--ink) !important;
}
.brief-loading-text {
  font-family: 'Fraunces', serif !important;
  font-style: italic !important;
  color: var(--ink4) !important;
}
.brief-banner-refresh {
  position: absolute !important;
  top: 10px !important; right: 12px !important;
  border: none !important;
  background: none !important;
  color: var(--ink4) !important;
  width: 22px !important; height: 22px !important;
  font-size: 13px !important;
}
.brief-expand-btn { color: var(--gold) !important; }

/* ── Brief layout: single scrollable column ── */
.brief-layout {
  grid-template-columns: 1fr !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  flex: 1 !important;
  min-height: 0 !important;
}
.brief-col-main {
  overflow-y: visible !important;
  min-height: unset !important;
  border-right: none !important;
  background: transparent !important;
  padding: 12px 16px 80px !important;
  gap: 0 !important;
}
.brief-col-side {
  overflow-y: visible !important;
  min-height: unset !important;
  background: transparent !important;
  padding: 0 16px 24px !important;
  gap: 0 !important;
}

/* ── Section labels (horizontal rule style) ── */
.brief-section { margin-bottom: 0 !important; }
.brief-section-title {
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  margin: 16px 0 10px !important;
  padding: 0 !important;
  border-left: none !important;
  border: none !important;
}
.brief-section-title > span:not(.ipcra-tag):not(.brief-badge) {
  font-size: 10px !important;
  font-weight: 500 !important;
  letter-spacing: .12em !important;
  text-transform: uppercase !important;
  color: var(--ink4) !important;
  white-space: nowrap !important;
}
.brief-section-title::after {
  content: '' !important;
  flex: 1 !important;
  height: 0.5px !important;
  background: var(--smoke) !important;
  display: block !important;
}
.ipcra-tag { display: none !important; }

/* Section containers: plain (no card wrapper) */
#brief-events, #brief-tasks, #brief-info, #brief-waiting {
  background: none !important;
  border: none !important;
  border-radius: 0 !important;
  overflow: visible !important;
}

/* ── Situation cards — white, left border ── */
.situation-card {
  background: #ffffff !important;
  border: 0.5px solid var(--smoke) !important;
  border-left: 2px solid var(--prio-waiting) !important;
  border-radius: var(--r-lg) !important;
  padding: 12px 14px !important;
  margin-bottom: 8px !important;
  box-shadow: var(--s-card) !important;
}
.situation-card.age-ok   { border-left: 2px solid var(--prio-waiting) !important; }
.situation-card.age-warn { border-left: 2px solid var(--amber) !important; }
.situation-card.age-late { border-left: 2px solid var(--prio-urgent) !important; background: #fefcfc !important; }
.situation-card:hover { border-color: var(--smoke) !important; background: #fefcf9 !important; box-shadow: var(--s-lifted) !important; transform: none !important; }

.situation-from { font-size: 13px !important; font-weight: 500 !important; color: var(--ink) !important; }
.situation-summary { font-size: 11.5px !important; line-height: 1.5 !important; color: var(--ink4) !important; margin-bottom: 8px !important; }
.situation-age.age-ok   { background: #eaf2ec !important; color: #4a7a55 !important; }
.situation-age.age-warn { background: #f5ecd8 !important; color: #8a6020 !important; }
.situation-age.age-late { background: #f7ebe8 !important; color: #b54a3a !important; }
.situation-avatar { background: var(--paper) !important; color: var(--ink3) !important; border: 0.5px solid var(--smoke) !important; font-family: 'Fraunces', serif !important; }

/* ── Action buttons — light cream ── */
.sit-btn {
  font-size: 10px !important;
  font-weight: 400 !important;
  padding: 4px 11px !important;
  border-radius: 6px !important;
  border: 0.5px solid var(--smoke) !important;
  background: var(--cream) !important;
  color: var(--ink3) !important;
  min-height: unset !important;
}
.sit-btn:hover { background: var(--paper) !important; color: var(--ink) !important; border-color: var(--ink5) !important; }
.sit-btn.primary { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.4) !important; color: var(--gold) !important; }
.sit-btn.primary:hover { background: #f0e2c5 !important; }
.sit-btn.archive { background: #eaf2ec !important; border-color: rgba(74,122,85,.25) !important; color: var(--sage) !important; }
.sit-btn.archive:hover { background: #d8ecda !important; }
.sit-btn.draft-ready { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.4) !important; color: var(--gold) !important; }

/* ── Draft box ── */
.sit-draft-box { background: var(--cream) !important; border: 0.5px solid rgba(184,132,58,.3) !important; }
.sit-draft-label { color: var(--gold) !important; }
.sit-draft-area { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; color: var(--ink) !important; font-family: 'Fraunces', serif !important; font-style: italic !important; font-weight: 300 !important; }
.sit-draft-area:focus { border-color: var(--gold) !important; }

/* ── Wait + info items ── */
.wait-item { border-left: 2px solid var(--prio-waiting) !important; background: transparent !important; border-bottom: 0.5px solid var(--smoke) !important; }
.wait-from { color: var(--ink3) !important; font-weight: 500 !important; }
.info-item { border-left: 2px solid var(--prio-info) !important; background: transparent !important; border-bottom: 0.5px solid var(--smoke) !important; }
.info-archive-btn { color: var(--ink4) !important; }

/* ── Chat panel — right overlay ── */
/* ── Chat FAB ── */
#chat-fab {
  display: flex !important;
  position: fixed !important;
  bottom: 22px !important; right: 22px !important;
  width: 48px !important; height: 48px !important;
  border-radius: 50% !important;
  background: var(--ink) !important;
  color: #fff !important;
  font-size: 1.2rem !important;
  box-shadow: 0 4px 18px rgba(30,26,21,.28) !important;
  animation: none !important;
  border: none !important;
  cursor: pointer !important;
  align-items: center !important; justify-content: center !important;
  z-index: 900 !important;
  transition: background .15s, transform .15s, box-shadow .15s !important;
}
#chat-fab:hover {
  background: var(--ink2) !important;
  transform: scale(1.06) !important;
  box-shadow: 0 6px 24px rgba(30,26,21,.35) !important;
}

/* ── Chat overlay ── */
#chat-panel-overlay.visible {
  background: rgba(30,26,21,.18) !important;
  backdrop-filter: blur(1px) !important;
}

/* ── Chat panel — right-side drawer, full height ── */
/* Toujours en flex, caché via translateX pour que display:none JS ne soit pas écrasé */
#chat-panel {
  position: fixed !important;
  top: 0 !important; right: 0 !important; bottom: 0 !important;
  width: 360px !important; max-width: 100vw !important;
  height: 100vh !important; max-height: 100vh !important;
  background: #fdfaf6 !important;
  border-radius: 0 !important;
  border-left: 0.5px solid var(--smoke) !important;
  box-shadow: -8px 0 40px rgba(30,26,21,.12) !important;
  display: flex !important;
  flex-direction: column !important;
  z-index: 960 !important;
  overflow: hidden !important;
  transform: translateX(100%) !important;
  transition: transform .25s cubic-bezier(.4,0,.2,1) !important;
  pointer-events: none !important;
}
#chat-panel.open {
  transform: translateX(0) !important;
  pointer-events: all !important;
}

/* ── Header ── */
.chat-panel-header {
  background: var(--paper) !important;
  border-bottom: 0.5px solid var(--smoke) !important;
  border-radius: 0 !important;
  height: 52px !important;
  padding: 0 16px !important;
  display: flex !important;
  align-items: center !important;
  gap: 10px !important;
  flex-shrink: 0 !important;
}
.chat-panel-header span {
  flex: 1 !important;
  font-family: 'Fraunces', serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: 17px !important;
  color: var(--ink) !important;
  letter-spacing: -.01em !important;
}
/* Amber dot after "Claire" */
.chat-panel-header span::after {
  content: '' !important;
  display: inline-block !important;
  width: 5px !important; height: 5px !important;
  border-radius: 50% !important;
  background: var(--gold) !important;
  margin-left: 4px !important;
  margin-bottom: 2px !important;
  vertical-align: middle !important;
}
.chat-panel-header button {
  background: none !important;
  border: 0.5px solid transparent !important;
  color: var(--ink4) !important;
  font-size: 14px !important;
  cursor: pointer !important;
  width: 28px !important; height: 28px !important;
  border-radius: 6px !important;
  display: flex !important;
  align-items: center !important; justify-content: center !important;
  transition: background .1s, border-color .1s !important;
}
.chat-panel-header button:hover { background: var(--smoke) !important; color: var(--ink) !important; }
.chat-panel-header .btn-tts.tts-active {
  background: var(--gold-pale) !important;
  border-color: rgba(184,132,58,.4) !important;
  color: var(--gold) !important;
}

/* ── Messages area ── */
#chat-panel-messages, .chat-messages {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 20px 16px 12px !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 14px !important;
  background: #fdfaf6 !important;
}
#chat-panel-messages::-webkit-scrollbar { width: 4px !important; }
#chat-panel-messages::-webkit-scrollbar-thumb { background: var(--smoke) !important; border-radius: 2px !important; }

/* ── Bubbles ── */
.chat-msg {
  display: flex !important;
  align-items: flex-start !important;
  gap: 8px !important;
}
.chat-msg.user { justify-content: flex-end !important; }
.chat-msg.assistant { justify-content: flex-start !important; }

/* Claire's bubble — warm card */
.chat-msg.assistant .chat-bubble {
  background: #ffffff !important;
  border: 0.5px solid var(--smoke) !important;
  border-left: 2px solid var(--gold-pale) !important;
  border-radius: 2px 12px 12px 12px !important;
  color: var(--ink2) !important;
  font-family: 'Fraunces', serif !important;
  font-style: italic !important;
  font-weight: 300 !important;
  font-size: 13.5px !important;
  line-height: 1.75 !important;
  padding: 12px 14px !important;
  max-width: 88% !important;
  box-shadow: 0 1px 4px rgba(30,26,21,.05) !important;
}
.chat-msg.assistant .chat-bubble strong {
  font-weight: 500 !important;
  font-style: normal !important;
  color: var(--ink) !important;
}

/* User bubble — compact ink */
.chat-msg.user .chat-bubble {
  background: var(--ink) !important;
  color: rgba(255,255,255,.92) !important;
  border: none !important;
  border-radius: 12px 2px 12px 12px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-style: normal !important;
  font-size: 13px !important;
  line-height: 1.55 !important;
  padding: 10px 14px !important;
  max-width: 78% !important;
  box-shadow: none !important;
}

/* Typing indicator */
.claire-typing-text { color: var(--ink4) !important; font-size: 12px !important; font-style: italic !important; }
.claire-typing-dots { color: var(--gold) !important; }

/* Draft bubbles */
.sit-draft-box {
  background: var(--paper) !important;
  border: 0.5px solid var(--smoke) !important;
  border-left: 2px solid var(--gold) !important;
  border-radius: 4px !important;
  padding: 12px 14px !important;
  font-size: 13px !important;
  color: var(--ink2) !important;
  line-height: 1.6 !important;
}
.draft-bubble-actions { gap: 6px !important; margin-top: 10px !important; }

/* ── Input area ── */
.chat-input-row {
  background: var(--cream) !important;
  border-top: 0.5px solid var(--smoke) !important;
  padding: 12px 14px !important;
  gap: 8px !important;
  align-items: flex-end !important;
  flex-shrink: 0 !important;
}
#chat-panel-input, #chat-input {
  background: #ffffff !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 8px !important;
  color: var(--ink) !important;
  font-size: 13px !important;
  padding: 10px 12px !important;
  line-height: 1.5 !important;
  resize: none !important;
  font-family: 'DM Sans', sans-serif !important;
  transition: border-color .15s !important;
}
#chat-panel-input:focus, #chat-input:focus {
  outline: none !important;
  border-color: var(--gold) !important;
  box-shadow: 0 0 0 2px var(--gold-pale) !important;
}
#chat-panel-input::placeholder, #chat-input::placeholder { color: var(--ink5) !important; font-style: italic !important; }

/* Send button */
.btn-send {
  background: var(--ink) !important;
  color: #fff !important;
  border: none !important;
  border-radius: 8px !important;
  width: 36px !important; height: 36px !important;
  font-size: 14px !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important; justify-content: center !important;
  flex-shrink: 0 !important;
  transition: background .12s !important;
}
.btn-send:hover { background: var(--ink2) !important; }

/* Voice button */
.btn-voice {
  background: none !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 8px !important;
  color: var(--ink4) !important;
  width: 36px !important; height: 36px !important;
  font-size: 14px !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important; justify-content: center !important;
  flex-shrink: 0 !important;
  transition: border-color .15s, color .15s, background .15s !important;
}
.btn-voice:hover { border-color: var(--gold) !important; color: var(--gold) !important; }
.btn-voice.listening {
  background: rgba(181,74,58,.08) !important;
  border-color: var(--rust) !important;
  color: var(--rust) !important;
  animation: voice-pulse 1.2s ease-in-out infinite !important;
}
@keyframes voice-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(181,74,58,.25) !important; }
  50%       { box-shadow: 0 0 0 6px rgba(181,74,58,0) !important; }
}

/* TTS toggle */
.btn-tts {
  background: none !important;
  border: 0.5px solid transparent !important;
  border-radius: 7px !important;
  color: var(--ink4) !important;
  width: 28px !important; height: 28px !important;
  font-size: 13px !important;
  cursor: pointer !important;
  display: flex !important;
  align-items: center !important; justify-content: center !important;
  transition: background .15s, border-color .15s !important;
}
.btn-tts:hover { background: var(--gold-pale) !important; border-color: var(--smoke) !important; }
.btn-tts.tts-active {
  background: var(--gold-pale) !important;
  border-color: rgba(184,132,58,.4) !important;
  color: var(--gold) !important;
}

/* Chat panel header actions */
.chat-panel-header-actions {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
}

/* ── Voice Overlay ───────────────────────────────────────────────── */
.voice-overlay {
  position: fixed !important;
  inset: 0 !important;
  z-index: 2000 !important;
  background: rgba(30,26,21,.55) !important;
  backdrop-filter: blur(6px) !important;
  display: none !important;
  align-items: center !important;
  justify-content: center !important;
}
.voice-overlay.active {
  display: flex !important;
}
.voice-overlay-inner {
  background: #ffffff !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 20px !important;
  padding: 32px 40px !important;
  display: flex !important;
  flex-direction: column !important;
  align-items: center !important;
  gap: 16px !important;
  min-width: 280px !important;
  max-width: 380px !important;
  box-shadow: 0 20px 60px rgba(0,0,0,.2) !important;
  animation: overlayIn .2s cubic-bezier(.4,0,.2,1) !important;
}
@keyframes overlayIn {
  from { opacity: 0; transform: scale(.92) translateY(10px); }
  to   { opacity: 1; transform: scale(1) translateY(0); }
}

/* Waveform animée */
.voice-waves {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  height: 36px !important;
}
.voice-waves span {
  display: block !important;
  width: 4px !important;
  border-radius: 4px !important;
  background: var(--gold) !important;
  animation: wavebar 1s ease-in-out infinite !important;
}
.voice-waves span:nth-child(1) { height: 12px; animation-delay: 0s; }
.voice-waves span:nth-child(2) { height: 24px; animation-delay: .15s; }
.voice-waves span:nth-child(3) { height: 36px; animation-delay: .3s; }
.voice-waves span:nth-child(4) { height: 24px; animation-delay: .45s; }
.voice-waves span:nth-child(5) { height: 12px; animation-delay: .6s; }
@keyframes wavebar {
  0%, 100% { transform: scaleY(.5); opacity: .5; }
  50%       { transform: scaleY(1);  opacity: 1; }
}
.voice-transcript-live {
  font-family: 'Fraunces', serif !important;
  font-size: 1.1rem !important;
  font-style: italic !important;
  color: var(--ink) !important;
  text-align: center !important;
  min-height: 1.6em !important;
  max-width: 300px !important;
  line-height: 1.5 !important;
}
.voice-hint {
  font-size: 0.75rem !important;
  color: var(--ink4) !important;
  text-align: center !important;
}
.voice-cancel-btn {
  background: none !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 8px !important;
  color: var(--ink3) !important;
  padding: 7px 20px !important;
  font-size: 0.82rem !important;
  cursor: pointer !important;
  transition: background .15s !important;
}
.voice-cancel-btn:hover { background: var(--gold-pale) !important; border-color: var(--gold) !important; }

/* ── Chat col (permanent right panel — hidden in this theme) ── */
#chat-col { display: none !important; }

/* ── Modals — cream ── */
.modal { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; box-shadow: var(--s-modal) !important; }
.modal-header { background: var(--cream) !important; border-bottom: 0.5px solid var(--smoke) !important; }
.modal-header h3 { color: var(--ink) !important; font-family: 'Fraunces', serif !important; font-style: italic !important; font-weight: 400 !important; }
.modal-footer { border-top: 0.5px solid var(--smoke) !important; background: var(--cream) !important; }
.modal input, .modal textarea, .modal select { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; color: var(--ink) !important; }
.modal input:focus, .modal textarea:focus, .modal select:focus { border-color: var(--gold) !important; box-shadow: 0 0 0 2px var(--gold-pale) !important; }
.modal label { color: var(--ink3) !important; font-size: 0.8rem !important; }
.note-box { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.25) !important; color: var(--ink3) !important; }
#modal-overlay { background: rgba(30,26,21,.35) !important; }

/* ── Buttons ── */
.btn-primary { background: var(--gold) !important; color: #fff !important; font-weight: 500 !important; border: none !important; }
.btn-primary:hover { background: var(--gold-deep) !important; box-shadow: 0 2px 12px rgba(184,132,58,.35) !important; }
.btn-action { background: var(--cream) !important; border: 0.5px solid var(--smoke) !important; color: var(--ink3) !important; }
.btn-action:hover { background: var(--paper) !important; color: var(--ink) !important; }
.btn-logout { color: var(--ink4) !important; font-size: 11px !important; }
.btn-logout:hover { color: var(--rust) !important; }

/* ── Email list ── */
#email-list-panel { background: var(--cream) !important; border-right: 0.5px solid var(--smoke) !important; }
.panel-toolbar { background: var(--cream) !important; border-bottom: 0.5px solid var(--smoke) !important; }
#account-selector { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; color: var(--ink) !important; }
.email-item { border-bottom: 0.5px solid var(--ivory2) !important; }
.email-item:hover { background: var(--ivory2) !important; }
.email-item.active { background: var(--gold-pale) !important; border-left: 2px solid var(--gold) !important; }
.email-item-from { color: var(--ink2) !important; }

/* ── Tasks & Gardien ── */
.task-item { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; }
.task-title { color: var(--ink) !important; }
.tasks-toolbar, .gardien-toolbar { border-bottom: 0.5px solid var(--smoke) !important; background: transparent !important; }
.task-filter-btn.active, .gardien-filter-btn.active, .memory-filter-btn.active { background: var(--gold-pale) !important; color: var(--gold) !important; border-color: rgba(184,132,58,.3) !important; }
.gardien-item { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; }

/* ── Calendar ── */
#view-calendar {
  height: calc(100vh - 52px) !important;
  flex: none !important;
  flex-direction: column !important;
  overflow: hidden !important;
}
#view-calendar.view-active {
  display: flex !important;
}
.calendar-container {
  background: transparent;
  display: flex;
  flex-direction: column;
  flex: 1;
  min-height: 0;
  overflow: hidden;
  padding: 12px 16px 0;
}
.calendar-toolbar { background: transparent !important; border-bottom: none !important; padding-bottom: 10px !important; flex-shrink: 0 !important; }
#google-cal-status { flex-shrink: 0; }
.calendar-list { flex: 1 !important; overflow-y: auto !important; padding-bottom: 24px !important; display: flex !important; flex-direction: column !important; gap: 8px !important; }
/* Day groups: white card with border */
.cal-day-group { background: #ffffff !important; box-shadow: none !important; border: 0.5px solid var(--smoke) !important; border-radius: 8px !important; overflow: hidden !important; }
.cal-day-group.cal-today { border-color: var(--gold) !important; }
/* Day header */
.cal-day-header { background: var(--paper) !important; color: var(--ink4) !important; border-bottom: 0.5px solid var(--smoke) !important; }
.cal-day-group.cal-today .cal-day-header { background: var(--gold-pale) !important; color: var(--gold) !important; }
/* Event rows */
.cal-event-item { border-bottom: 0.5px solid var(--smoke) !important; }
.cal-event-item:last-child { border-bottom: none !important; }
.cal-event-item:hover { background: var(--cream) !important; }
.cal-event-time { color: var(--gold) !important; font-size: 11px !important; min-width: 70px !important; }
.cal-event-title { color: var(--ink2) !important; font-size: 13px !important; }
.cal-event-location { color: var(--ink4) !important; }
.cal-event-desc { color: var(--ink4) !important; }
.cal-event-source.cal-source-manual { background: var(--paper) !important; color: var(--ink4) !important; }
.cal-event-source.cal-source-email { background: var(--gold-pale) !important; color: var(--gold) !important; }
.cal-event-source.cal-source-chat { background: rgba(74,122,85,.1) !important; color: var(--sage) !important; }
.cal-day-label { color: var(--ink4) !important; font-size: 10px !important; text-transform: uppercase !important; letter-spacing: .08em !important; }
/* Cal empty/loading */
#calendar-loading { color: var(--ink4) !important; font-style: italic !important; font-size: 13px !important; }

/* ── Tasks ── */
.tasks-container { background: transparent !important; }
.tasks-toolbar { background: transparent !important; border-bottom: 0.5px solid var(--smoke) !important; }
.task-filter-btn { background: none !important; border: 0.5px solid var(--smoke) !important; color: var(--ink4) !important; }
.task-filter-btn:hover { border-color: var(--gold) !important; color: var(--gold) !important; }
.task-filter-btn.active { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.3) !important; color: var(--gold) !important; font-weight: 500 !important; }
.task-item { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; }
.task-item:hover { border-color: var(--gold) !important; box-shadow: none !important; }
.task-title, .task-item-title { color: var(--ink) !important; }
.task-item-desc { color: var(--ink4) !important; }
.task-meta-date, .task-meta-contact, .task-meta-followup { color: var(--ink4) !important; }
.task-meta-overdue { color: var(--rust) !important; }
.task-check { border-color: var(--smoke) !important; }
.task-check:hover { border-color: var(--sage) !important; color: var(--sage) !important; }
.task-check.checked { background: var(--sage) !important; border-color: var(--sage) !important; }
.task-priority-urgent { background: rgba(181,74,58,.08) !important; color: var(--rust) !important; border-color: rgba(181,74,58,.2) !important; }
.task-priority-high { background: rgba(184,132,58,.08) !important; color: var(--gold) !important; border-color: rgba(184,132,58,.2) !important; }
.task-priority-normal { background: rgba(74,122,85,.08) !important; color: var(--sage) !important; border-color: rgba(74,122,85,.2) !important; }
.task-priority-low { background: var(--paper) !important; color: var(--ink4) !important; border-color: var(--smoke) !important; }
.tasks-list { padding: 12px 16px !important; }

/* ── Gardien ── */
.gardien-container { background: transparent !important; }
.gardien-toolbar { background: transparent !important; border-bottom: 0.5px solid var(--smoke) !important; }
.gardien-filter-btn { background: none !important; border: 0.5px solid var(--smoke) !important; color: var(--ink4) !important; }
.gardien-filter-btn:hover { border-color: var(--gold) !important; color: var(--gold) !important; }
.gardien-filter-btn.active { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.3) !important; color: var(--gold) !important; }
.gardien-item { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; }
.gardien-item:hover { border-color: var(--gold) !important; box-shadow: none !important; transform: none !important; }
.gardien-item-title { color: var(--ink) !important; }
.gardien-item-filename { color: var(--ink4) !important; }
.gardien-item-notes { color: var(--ink3) !important; }
.gardien-meta-date, .gardien-meta-source { color: var(--ink4) !important; }
.gardien-meta-overdue { color: var(--rust) !important; }
.gardien-group-header { color: var(--ink4) !important; }
.gardien-group-count { background: var(--gold-pale) !important; color: var(--gold) !important; }
.gardien-overdue { background: rgba(181,74,58,.04) !important; border-color: rgba(181,74,58,.2) !important; }
.gardien-done-btn { border-color: var(--smoke) !important; }
.gardien-done-btn:hover { background: var(--sage) !important; border-color: var(--sage) !important; color: #fff !important; }

/* ── Mémoire ── */
.memory-container {
  background: transparent !important;
  max-width: 100% !important;
  flex: 1 !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  padding: 0 16px 32px !important;
  display: block !important;
}
.memory-toolbar {
  background: var(--cream) !important;
  position: sticky !important;
  top: 0 !important;
  z-index: 10 !important;
  padding: 12px 0 10px !important;
  border-bottom: 0.5px solid var(--smoke) !important;
  margin-bottom: 12px !important;
}
.memory-filter-btn { background: var(--paper) !important; border: 0.5px solid var(--smoke) !important; color: var(--ink3) !important; }
.memory-filter-btn:hover { border-color: var(--gold) !important; color: var(--gold) !important; }
.memory-filter-btn.active { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.3) !important; color: var(--gold) !important; }
.memory-section-title { color: var(--ink4) !important; }
.memory-group-title { color: var(--gold) !important; }
.memory-item { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; border-radius: 6px !important; }
.memory-item-pending { border: 0.5px dashed rgba(184,132,58,.4) !important; background: var(--gold-pale) !important; }
.memory-pending-section { background: rgba(184,132,58,.06) !important; border: 0.5px solid rgba(184,132,58,.25) !important; }
.memory-content { color: var(--ink2) !important; }
.memory-content[contenteditable="true"] { background: var(--paper) !important; }
.memory-ref { color: var(--ink4) !important; }
.memory-tag-user { background: rgba(58,90,138,.1) !important; color: var(--blue) !important; }
.memory-tag-contact { background: rgba(74,122,85,.1) !important; color: var(--sage) !important; }
.memory-tag-dossier { background: var(--gold-pale) !important; color: var(--gold) !important; }
.memory-item-contextual { opacity: .8 !important; }
.memory-contextual { color: var(--ink4) !important; font-size: .8rem !important; }
.memory-sensitive-hint { color: var(--smoke) !important; }
.memory-age { color: var(--smoke) !important; }
.memory-show-more { color: var(--gold) !important; }
.memory-toolbar-bottom { border-top-color: var(--rule) !important; }
.memory-pending-more { color: var(--smoke) !important; }
.memory-dedup-panel { background: var(--gold-pale) !important; border-color: rgba(184,132,58,.3) !important; }
.memory-dedup-group { border-bottom-color: var(--rule) !important; }
.memory-dedup-name { color: var(--gold) !important; }
.memory-dedup-entry { color: var(--ink2) !important; }

/* ── Inbox ── */
.panel-toolbar { background: var(--cream) !important; border-bottom: 0.5px solid var(--smoke) !important; }
#account-selector { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; color: var(--ink) !important; }
.email-item-from { color: var(--ink) !important; }
.email-item-subject { color: var(--ink2) !important; }
.email-item-preview { color: var(--ink4) !important; }
.email-item-date { color: var(--ink4) !important; }
.email-detail-panel { background: var(--cream) !important; }
.email-detail-header { background: var(--paper) !important; border-bottom: 0.5px solid var(--smoke) !important; }
.email-detail-from { color: var(--ink2) !important; }
.email-detail-subject { color: var(--ink) !important; }
.email-detail-body { color: var(--ink2) !important; background: #ffffff !important; }

/* ── Toast ── */
.toast { background: var(--ink) !important; color: #fff !important; border: none !important; border-radius: 99px !important; font-size: 11px !important; }
.toast.success { background: var(--sage) !important; }
.toast.error   { background: var(--rust) !important; }
.toast.info    { background: var(--amber) !important; }

/* ── Brief misc section ── */
.brief-section-misc { background: none !important; border: none !important; }
.brief-misc-row { color: var(--ink3) !important; border-bottom: 0.5px solid var(--smoke) !important; font-size: 12px !important; }

/* ── Brief events / tasks inside cards ── */
.brief-event-item { border-bottom: 0.5px solid var(--smoke) !important; }
.brief-event-time { color: var(--gold) !important; font-size: 11px !important; }
.brief-task-item { border-bottom: 0.5px solid var(--smoke) !important; }
.brief-badge { background: var(--gold-pale) !important; color: var(--gold) !important; border: 0.5px solid rgba(184,132,58,.3) !important; }
.brief-see-all, .brief-add-btn { color: var(--ink4) !important; font-size: 11px !important; }
.brief-see-all:hover, .brief-add-btn:hover { color: var(--gold) !important; }

/* ── Brief email items (situation cards — thème PAPIER) ── */
.brief-email-item { border-bottom: 0.5px solid var(--ivory2) !important; background: transparent !important; }
.brief-email-item:hover { background: var(--ivory) !important; }
.brief-email-from { color: var(--ink) !important; font-size: .84rem !important; font-weight: 600 !important; }
.brief-email-subject { color: var(--ink3) !important; font-size: .76rem !important; }
.brief-email-summary { color: var(--ink4) !important; font-size: .72rem !important; font-style: italic !important; }
.brief-waiting-item { border-bottom: 0.5px solid var(--ivory2) !important; }
.chat-panel-context-label { color: var(--ink4) !important; }

/* ── Deadlines détectées ─────────────────────────────────────────────────── */
.deadline-card {
  display: flex !important;
  align-items: flex-start !important;
  justify-content: space-between !important;
  gap: 12px !important;
  background: var(--paper) !important;
  border: 1px solid var(--smoke) !important;
  border-left: 3px solid var(--amber) !important;
  border-radius: 6px !important;
  padding: 8px 10px !important;
  margin-bottom: 8px !important;
}
.deadline-card-from {
  font-size: 0.78rem !important;
  color: var(--ink4) !important;
  font-weight: 600 !important;
}
.deadline-card-subj {
  font-size: 0.82rem !important;
  color: var(--ink) !important;
  margin-top: 2px !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
  max-width: 320px !important;
}
.deadline-card-carrier {
  margin-top: 3px !important;
}
.deadline-card-actions {
  display: flex !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}
#brief-deadlines-section .brief-section-title {
  font-size: 0.76rem !important;
  font-weight: 600 !important;
  color: var(--amber) !important;
  padding: 6px 0 8px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}

/* ── Clôtures proposées ──────────────────────────────────────────────────── */
.closure-card {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  gap: 12px !important;
  padding: 10px 14px !important;
  background: var(--paper) !important;
  border: 1px solid var(--ivory2) !important;
  border-left: 3px solid var(--gold) !important;
  border-radius: 6px !important;
  margin-bottom: 8px !important;
}
.closure-card-title {
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 600 !important;
  font-size: 0.82rem !important;
  color: var(--ink) !important;
}
.closure-card-signal {
  font-size: 0.74rem !important;
  color: var(--ink4) !important;
  margin-top: 2px !important;
}
.closure-card-actions {
  display: flex !important;
  gap: 6px !important;
  flex-shrink: 0 !important;
}
#brief-closures-section .brief-section-title {
  font-size: 0.76rem !important;
  font-weight: 600 !important;
  color: var(--charcoal2) !important;
  padding: 6px 0 8px !important;
  text-transform: uppercase !important;
  letter-spacing: 0.04em !important;
}
.brief-loading { color: var(--ink4) !important; font-size: 12px !important; font-style: italic !important; }
.brief-empty { color: var(--ink4) !important; font-family: 'Fraunces', serif !important; font-style: italic !important; }

/* ── Memory confirm banner ── */
.memory-confirm-banner { background: var(--gold-pale) !important; border: 0.5px solid rgba(184,132,58,.3) !important; }
.memory-confirm-item { border-bottom: 0.5px solid var(--smoke) !important; }
.memory-confirm-item span { color: var(--ink2) !important; }

/* ── Onboarding modal — corrections contrastes ── */
.onboarding-modal { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; }
.onboard-step h2 { color: var(--ink) !important; font-family: 'Fraunces', serif !important; font-style: italic !important; }
.onboard-step p { color: var(--ink3) !important; }
.onboard-step label { color: var(--ink3) !important; font-weight: 500 !important; }
.onboard-footer .btn-action { color: var(--ink4) !important; border-color: var(--smoke) !important; }
.onboard-step input, .onboard-step select {
  padding: 10px 12px !important;
  border: 1.5px solid var(--smoke) !important;
  border-radius: var(--r-sm) !important;
  background: var(--ivory) !important;
  color: var(--ink) !important;
  font-size: 14px !important;
}
.onboard-step input:focus, .onboard-step select:focus {
  border-color: var(--gold) !important;
  outline: none !important;
  box-shadow: 0 0 0 3px rgba(184,132,58,.12) !important;
}
.onboard-step input::placeholder { color: var(--mist2) !important; }
/* Memory onboard text (ivory2 = invisible sur fond clair) */
.memory-onboard-text { color: var(--ink3) !important; }
.memory-onboard-text strong { color: var(--ink2) !important; }
/* Event proposal — warning strong (ivory = invisible sur fond clair) */
.evprop-warning strong { color: var(--ink2) !important; }

/* ── Auth screen ── */
#auth-screen { background: #e8e2d8 !important; }
.auth-card { background: #ffffff !important; border: 0.5px solid var(--smoke) !important; box-shadow: var(--s-modal) !important; }
.auth-title { font-family: 'Fraunces', serif !important; font-style: italic !important; font-weight: 400 !important; color: var(--ink) !important; font-size: 2rem !important; }
.auth-logo { color: var(--gold) !important; }
.auth-ai-badge { background: var(--gold-pale) !important; color: var(--gold) !important; border: 0.5px solid rgba(184,132,58,.25) !important; }
.auth-subtitle { color: var(--ink4) !important; }

/* ── Sidebar section separator ── */
.lnav-sep {
  width: 20px; height: 0.5px;
  background: var(--smoke);
  margin: 4px auto;
}

/* ── Mobile: sidebar fixed overlay ── */
@media (max-width: 768px) {
  #sidebar {
    position: fixed !important;
    left: 0 !important; top: 0 !important; bottom: 0 !important;
    transform: translateX(-110%) !important;
    width: 240px !important;
    padding: 16px 0 !important;
    align-items: flex-start !important;
    z-index: 400 !important;
    transition: transform .25s cubic-bezier(.4,0,.2,1) !important;
  }
  /* On mobile, .open = visible (not .collapsed logic) */
  #sidebar.open {
    transform: translateX(0) !important;
    box-shadow: 4px 0 24px rgba(0,0,0,.15) !important;
    width: 240px !important;
  }
  #sidebar.open .sidebar-label, #sidebar.open .account-name,
  #sidebar.open .sidebar-add, #sidebar.open #username-display,
  #sidebar.open .sidebar-footer { display: block !important; }
  #sidebar.open .nav-item {
    width: 100% !important; height: auto !important;
    justify-content: flex-start !important;
    padding: 10px 18px !important;
    font-size: 13px !important;
  }
  /* topbar-brand hidden on mobile (title takes center) */
  .topbar-brand { display: none !important; }
  #main { padding-left: 0 !important; }
  .brief-banner { margin: 10px 12px 4px !important; }
  .brief-col-main { padding: 8px 12px 60px !important; }
}

/* ── Bilan hebdomadaire ─────────────────────────────────────── */
.weekly-report-card {
  margin: 0 0 16px 0 !important;
  background: var(--paper) !important;
  border-radius: var(--r) !important;
  border: 0.5px solid var(--smoke) !important;
  border-left: 3px solid var(--gold) !important;
  overflow: hidden !important;
}
.weekly-report-header {
  display: flex !important;
  align-items: center !important;
  justify-content: space-between !important;
  padding: 10px 14px !important;
  cursor: pointer !important;
}
.weekly-report-header:hover { background: var(--gold-pale) !important; }
.weekly-report-meta { display: flex !important; align-items: center !important; gap: 10px !important; }
.weekly-report-badge {
  font-size: 0.72rem !important;
  background: var(--smoke) !important;
  color: var(--ink4) !important;
  padding: 2px 8px !important;
  border-radius: 10px !important;
  white-space: nowrap !important;
}
.weekly-report-title {
  font-size: 0.82rem !important;
  font-weight: 600 !important;
  color: var(--gold) !important;
  letter-spacing: 0.02em !important;
}
.weekly-report-toggle {
  background: none !important;
  border: none !important;
  color: var(--ink4) !important;
  font-size: 0.9rem !important;
  cursor: pointer !important;
  padding: 2px 4px !important;
  line-height: 1 !important;
}
.weekly-report-toggle:hover { color: var(--ink2) !important; }
.weekly-report-body { padding: 0 14px 14px 14px !important; }
.weekly-report-text {
  font-size: 0.87rem !important;
  color: var(--ink2) !important;
  line-height: 1.7 !important;
  padding-top: 4px !important;
}

/* ── Section Finances dans le brief misc ── */
.brief-finance-alert {
  display: flex !important;
  align-items: center !important;
  gap: 6px !important;
}
.brief-finance-dot {
  width: 6px !important; height: 6px !important;
  border-radius: 50% !important;
  background: var(--rust) !important;
  flex-shrink: 0 !important;
}
.brief-finance-count {
  font-size: 11px !important;
  font-weight: 600 !important;
  color: var(--rust) !important;
}


/* ── Feature 4 — Situation card kb-active ── */
.situation-card.kb-active {
  outline: 2px solid var(--gold, #C9A84C);
  outline-offset: 2px;
}

/* ── Feature 4 — Bouton Géré ── */
.sit-btn.handled {
  background: transparent;
  color: var(--text-muted, #888);
  border: 1px solid var(--border, #ddd);
}
.sit-btn.handled:hover {
  background: var(--surface2, #f5f5f5);
  color: var(--text, #333);
}

/* ── Feature 2 — Gardien auto files ── */
.gardien-auto-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 6px;
  background: var(--surface2, #f5f5f5);
  margin-bottom: 6px;
}
.gardien-auto-icon { font-size: 1.4rem; }
.gardien-auto-name { font-size: .85rem; font-weight: 500; }
.gardien-auto-meta { font-size: .75rem; color: var(--text-muted, #888); }
.gardien-section-title {
  font-size: .8rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: .05em;
  color: var(--text-muted, #888);
  margin-bottom: 8px;
}

.gcal-connected-badge {
  font-size: .82rem;
  color: var(--success, #4caf50);
  font-weight: 500;
}


/* ── Pièces jointes sur les situation cards ─── */
.situation-att-badge {
  font-size: .8rem;
  opacity: .85;
  margin-left: 3px;
  cursor: default;
}
.situation-att-names {
  font-size: .72rem;
  color: var(--ink3, #a08c6e);
  margin: 2px 0 4px 0;
  padding: 3px 8px;
  background: rgba(0,0,0,.08);
  border-radius: 4px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.sit-btn.gardien {
  background: transparent;
  border: 1px solid var(--smoke, #ddd);
  color: var(--ink3, #888);
  font-size: .72rem;
}
.sit-btn.gardien:hover {
  background: var(--smoke, #eee);
  color: var(--ink2, #555);
}

.att-link {
  display: inline-block;
  font-size: .75rem;
  color: var(--gold, #b8843a);
  text-decoration: none;
  margin-right: 8px;
  padding: 2px 6px;
  border: 1px solid currentColor;
  border-radius: 4px;
  opacity: .85;
}
.att-link:hover {
  opacity: 1;
  background: rgba(201,168,76,.12);
}

/* ── Priority & deadline badges (briefing situation cards) ─────────────────── */
.brief-priority-badge, .brief-deadline-badge {
  display: inline-block;
  font-size: .68rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 6px;
  vertical-align: middle;
  white-space: nowrap;
}
.brief-priority-urgent {
  background: rgba(231,76,60,.15);
  color: #e74c3c;
  border: 1px solid rgba(231,76,60,.3);
}
.brief-priority-high {
  background: rgba(230,126,34,.12);
  color: #e67e22;
  border: 1px solid rgba(230,126,34,.25);
}
.brief-deadline-badge {
  background: rgba(201,168,76,.12);
  color: var(--gold, #C9A84C);
  border: 1px solid rgba(201,168,76,.25);
}

/* ── Waiting / Relance badges ──────────────────────────────────────────────── */
.brief-days-badge {
  display: inline-block;
  font-size: .67rem;
  font-weight: 600;
  padding: 1px 6px;
  border-radius: 8px;
  margin-left: 6px;
  vertical-align: middle;
  background: rgba(150,150,150,.12);
  color: var(--text-muted, #888);
  border: 1px solid rgba(150,150,150,.2);
}
.brief-days-overdue {
  background: rgba(231,76,60,.12);
  color: #e74c3c;
  border: 1px solid rgba(231,76,60,.25);
}
.brief-relance-btn {
  display: inline-block;
  margin-top: 6px;
  padding: 4px 12px;
  font-size: .75rem;
  font-weight: 600;
  background: rgba(201,168,76,.15);
  color: var(--gold, #C9A84C);
  border: 1px solid rgba(201,168,76,.35);
  border-radius: 6px;
  cursor: pointer;
  transition: background .15s;
}
.brief-relance-btn:hover {
  background: rgba(201,168,76,.28);
}

/* ── Calendar Views ────────────────────────────────────────────────────────── */
.calendar-toolbar { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; padding: 10px 16px; border-bottom: 1px solid var(--border); }
.cal-view-tabs { display: flex; gap: 4px; }
.cal-tab {
  padding: 5px 14px; border-radius: 6px; border: 1.5px solid var(--border);
  background: transparent; color: var(--text-muted); font-size: .82rem; cursor: pointer; transition: all .15s;
}
.cal-tab.active {
  background: var(--gold, #C9A84C); color: #fff; border-color: var(--gold, #C9A84C); font-weight: 600;
}
.cal-tab:hover:not(.active) { background: var(--surface2, #f5f5f5); }

.cal-nav { display: flex; align-items: center; gap: 8px; }
.cal-nav-btn {
  width: 28px; height: 28px; border-radius: 6px; border: 1.5px solid var(--border);
  background: transparent; color: var(--text, #222); font-size: 1.1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
}
.cal-nav-btn:hover { background: var(--surface2, #f5f5f5); }
.cal-nav-today {
  padding: 4px 10px; border-radius: 6px; border: 1.5px solid var(--border);
  background: transparent; color: var(--text-muted, #888); font-size: .78rem; cursor: pointer;
}
.cal-nav-today:hover { background: var(--surface2, #f5f5f5); color: var(--text, #222); }
.cal-period-label { font-size: .88rem; font-weight: 600; color: var(--text, #222); min-width: 180px; text-align: center; }
.cal-actions { display: flex; gap: 6px; margin-left: auto; }
.cal-grid-view { flex: 1; overflow: hidden; min-height: 0; display: flex; flex-direction: column; }

/* ── Semaine ──────────────────────────────────────────────────────────────── */
.cal-week-grid { display: flex; flex-direction: column; flex: 1; min-height: 0; overflow: hidden; }
.cal-week-header { display: grid; grid-template-columns: 52px repeat(7, 1fr); border-bottom: 1.5px solid var(--border); flex-shrink: 0; }
.cal-week-time-gutter { font-size: .68rem; color: var(--text-muted, #888); padding: 4px 6px; text-align: right; }
.cal-week-day-header {
  padding: 6px 4px; text-align: center; font-size: .78rem; font-weight: 600; color: var(--text-muted, #888);
  border-left: 1px solid var(--border);
}
.cal-today-header { color: var(--gold, #C9A84C) !important; }
.cal-week-day-count {
  display: inline-block; font-size: .65rem; background: var(--gold, #C9A84C); color: #fff;
  border-radius: 8px; padding: 1px 5px; margin-left: 4px;
}
.cal-week-allday-row { display: grid; grid-template-columns: 52px repeat(7, 1fr); border-bottom: 1px solid var(--border); flex-shrink: 0; }
.cal-week-allday-cell { border-left: 1px solid var(--border); padding: 2px 3px; min-height: 24px; }
.cal-week-body { flex: 1; overflow-y: auto; }
.cal-week-row { display: grid; grid-template-columns: 52px repeat(7, 1fr); border-bottom: 1px solid var(--border); min-height: 48px; }
.cal-week-cell { border-left: 1px solid var(--border); padding: 2px 3px; cursor: pointer; transition: background .1s; }
.cal-week-cell:hover { background: var(--surface2, #f5f5f5); }
.cal-today-cell { background: rgba(201,168,76,.04) !important; }

/* ── Mois ─────────────────────────────────────────────────────────────────── */
.cal-month-grid { display: flex; flex-direction: column; }
.cal-month-header-row { display: grid; grid-template-columns: repeat(7, 1fr); border-bottom: 1.5px solid var(--border); }
.cal-month-dow { padding: 6px; text-align: center; font-size: .75rem; font-weight: 700; color: var(--text-muted, #888); text-transform: uppercase; }
.cal-month-body { display: grid; grid-template-columns: repeat(7, 1fr); }
.cal-month-cell {
  border-right: 1px solid var(--border); border-bottom: 1px solid var(--border);
  min-height: 90px; padding: 4px; cursor: pointer; transition: background .1s; overflow: hidden;
}
.cal-month-cell:hover { background: var(--surface2, #f5f5f5); }
.cal-other-month { opacity: .4; }
.cal-month-cell.cal-today-cell { background: rgba(201,168,76,.06) !important; }
.cal-weekend { background: rgba(0,0,0,.01); }
.cal-month-day-num { font-size: .82rem; font-weight: 600; color: var(--text-muted, #888); margin-bottom: 3px; }
.cal-today-num {
  display: inline-flex; align-items: center; justify-content: center;
  width: 22px; height: 22px; border-radius: 50%; background: var(--gold, #C9A84C); color: #fff; font-weight: 700;
}
.cal-month-events { display: flex; flex-direction: column; gap: 1px; }

/* ── Jour ─────────────────────────────────────────────────────────────────── */
.cal-day-view { flex: 1; overflow-y: auto; }
.cal-day-allday { padding: 6px 12px; border-bottom: 1px solid var(--border); display: flex; flex-wrap: wrap; gap: 4px; }
.cal-day-row { display: grid; grid-template-columns: 52px 1fr; border-bottom: 1px solid var(--border); min-height: 52px; }
.cal-current-hour { background: rgba(201,168,76,.07); }
.cal-day-time { font-size: .7rem; color: var(--text-muted, #888); padding: 6px 8px 4px; text-align: right; }
.cal-day-slot { padding: 3px 8px; cursor: pointer; }
.cal-day-slot:hover { background: var(--surface2, #f5f5f5); }
.cal-day-slot-empty { min-height: 40px; }

/* ── Event pill ───────────────────────────────────────────────────────────── */
.cal-event-pill { transition: opacity .1s; }
.cal-event-pill:hover { opacity: .8; }

/* ── Liste (fallback) ─────────────────────────────────────────────────────── */
.cal-day-group { margin-bottom: 16px; }
.cal-day-header { font-size: .8rem; font-weight: 700; color: var(--text-muted, #888); text-transform: uppercase; padding: 4px 16px; border-bottom: 1px solid var(--border); margin-bottom: 4px; }
.cal-today .cal-day-header { color: var(--gold, #C9A84C); }
.cal-event-item { display: flex; align-items: flex-start; gap: 12px; padding: 8px 16px; cursor: pointer; }
.cal-event-item:hover { background: var(--surface2, #f5f5f5); }
.cal-event-time { font-size: .78rem; color: var(--text-muted, #888); min-width: 80px; flex-shrink: 0; }
.cal-event-body { flex: 1; }
.cal-event-title { font-weight: 600; font-size: .88rem; }
.cal-event-location { font-size: .75rem; color: var(--text-muted, #888); }
.cal-event-source { font-size: .68rem; padding: 2px 6px; border-radius: 8px; background: var(--surface2, #f5f5f5); color: var(--text-muted, #888); flex-shrink: 0; }

/* ── Agenda texte — vue conversationnelle ─────────────────────────────────── */
.calendar-list { display: flex; flex-direction: column; }

.agenda-text-view {
  padding: 24px 28px;
  display: flex;
  flex-direction: column;
  gap: 0;
  max-width: 680px;
}

/* ── Nouvelles classes agenda (10 fixes) ──────────────────────────────── */

/* Fix 06 — Bandeau semaine */
.cal-week-strip {
  display: flex;
  gap: 4px;
  padding: 10px 4px 12px;
  border-bottom: 1px solid var(--smoke);
  margin-bottom: 8px;
}
.cal-strip-day {
  flex: 1;
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 3px;
  padding: 6px 4px;
  border-radius: var(--r);
  cursor: pointer;
  transition: background .12s;
}
.cal-strip-day:hover { background: var(--cream); }
.cal-strip-today { background: var(--gold-pale); }
.cal-strip-today .cal-strip-date { color: var(--gold); font-weight: 700; }
.cal-strip-dow { font-size: .65rem; color: var(--ink4); text-transform: uppercase; }
.cal-strip-date { font-size: .9rem; font-weight: 600; color: var(--ink2); }
.cal-strip-dots { display: flex; gap: 3px; flex-wrap: wrap; justify-content: center; min-height: 8px; }
.cal-strip-dot { width: 6px; height: 6px; border-radius: 50%; }

/* Fix 08 — Filtre catégorie */
.cal-filter-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  padding: 4px 0 12px;
}
.cal-filter-btn {
  font-size: .72rem;
  padding: 3px 10px;
  border-radius: 12px;
  border: 1px solid var(--smoke);
  background: none;
  color: var(--ink3);
  cursor: pointer;
  transition: all .12s;
}
.cal-filter-btn:hover { background: var(--cream); color: var(--ink); }
.cal-filter-btn.active { background: var(--ink); color: #fff; border-color: var(--ink); }

/* Fix 02 — Section deadlines */
.cal-deadlines-section {
  background: rgba(192, 57, 43, .04);
  border: 1px solid rgba(192, 57, 43, .15);
  border-radius: var(--r);
  padding: 10px 14px;
  margin-bottom: 16px;
}
.cal-deadlines-title {
  font-size: .72rem;
  font-weight: 700;
  letter-spacing: .06em;
  text-transform: uppercase;
  color: #C0392B;
  margin-bottom: 8px;
}
.cal-deadline-item {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 5px 0;
  border-bottom: 1px solid rgba(192, 57, 43, .08);
  cursor: pointer;
}
.cal-deadline-item:last-child { border-bottom: none; }
.cal-deadline-date {
  font-size: .74rem;
  color: var(--ink4);
  min-width: 60px;
  flex-shrink: 0;
}
.cal-deadline-title { font-size: .84rem; color: var(--ink2); flex: 1; }
.cal-deadline-edit { font-size: .8rem; color: var(--ink4); cursor: pointer; padding: 2px 6px; }
.cal-deadline-edit:hover { color: var(--ink); }
.cal-deadline-urgent { background: rgba(192, 57, 43, .06); border-radius: var(--r-sm); padding: 5px 6px; }
.cal-deadline-soon .cal-deadline-date { color: #C0392B; font-weight: 600; }
.cal-day-dl-badge {
  font-size: .68rem;
  background: rgba(192, 57, 43, .12);
  color: #C0392B;
  padding: 1px 6px;
  border-radius: 10px;
  margin-left: 6px;
}

/* Fix 03 — Rappels */
.cal-reminders-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 6px 0 8px;
}
.cal-reminder-chip {
  font-size: .75rem;
  background: var(--cream);
  color: var(--ink3);
  padding: 3px 8px;
  border-radius: var(--r-sm);
  cursor: pointer;
  border: 1px solid var(--smoke);
}
.cal-reminder-chip:hover { background: var(--smoke); }
.cal-allday-chip {
  font-size: .75rem;
  background: var(--paper);
  color: var(--ink2);
  padding: 3px 8px;
  border-radius: var(--r-sm);
  cursor: pointer;
  border: 1px solid var(--ink4);
  font-style: italic;
}
.cal-allday-chip:hover { background: var(--cream); }

/* Fix 05 — Anniversaires */
.cal-birthday-row {
  font-size: .76rem;
  color: var(--ink4);
  padding: 6px 0 2px;
  cursor: pointer;
  border-top: 1px dashed var(--smoke);
  margin-top: 4px;
}
.cal-birthday-row:hover { color: var(--ink2); }

/* Fix 04/07/09 — Badges inline */
.cal-badge {
  display: inline-block;
  font-size: .65rem;
  padding: 1px 5px;
  border-radius: 4px;
  margin-left: 5px;
  vertical-align: middle;
  font-weight: 600;
  cursor: default;
}
.cal-badge-recurring { background: rgba(91,138,95,.12); color: #5B8A5F; }
.cal-badge-conflict  { background: rgba(192,57,43,.12);  color: #C0392B; cursor: pointer; }
.cal-badge-briefing  { background: rgba(200,169,110,.15); color: var(--gold-deep); cursor: pointer; }
.cal-badge-briefing:hover { background: var(--gold-pale); }

/* Fix 07 — Message conflit */
.cal-conflict-msg {
  font-size: .74rem;
  color: #C0392B;
  padding: 3px 12px;
  background: rgba(192,57,43,.06);
  border-radius: var(--r-sm);
  margin: -4px 0 6px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.cal-conflict-ask-btn {
  background: none;
  border: 1px solid rgba(192,57,43,.35);
  color: #C0392B;
  font-size: .7rem;
  padding: 1px 7px;
  border-radius: 10px;
  cursor: pointer;
  white-space: nowrap;
}
.cal-conflict-ask-btn:hover { background: rgba(192,57,43,.08); }
.cal-dedup-msg {
  font-size: .7rem;
  color: var(--ink4);
  padding: 2px 12px;
  margin-bottom: 4px;
  font-style: italic;
}

/* Fix 10 — Voir plus */
.cal-see-more {
  text-align: center;
  padding: 20px 0 8px;
}
.cal-see-more button {
  font-size: .8rem;
  color: var(--ink3);
  background: none;
  border: 1px solid var(--smoke);
  padding: 6px 16px;
  border-radius: var(--r);
  cursor: pointer;
}
.cal-see-more button:hover { background: var(--cream); color: var(--ink); }

.agenda-section {
  padding-bottom: 28px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border, #e8e0d0);
}
.agenda-section:last-child { border-bottom: none; }

.agenda-today-section {
  padding-bottom: 28px;
  margin-bottom: 4px;
  border-bottom: 1px solid var(--border, #e8e0d0);
}

.agenda-day-header {
  display: flex;
  align-items: baseline;
  gap: 12px;
  margin-bottom: 14px;
}

.agenda-day-name {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 20px;
  font-weight: 500;
  color: var(--ink, #2c2416);
  letter-spacing: -0.01em;
}

.agenda-today-name {
  color: var(--gold, #b8843a);
}

.agenda-day-date {
  font-size: 13px;
  color: var(--text-muted, #8a7560);
  font-weight: 400;
}

.agenda-empty-day {
  font-size: 13.5px;
  color: var(--text-muted, #9a8a76);
  font-style: italic;
  padding: 4px 0 8px;
  letter-spacing: 0.01em;
}

.agenda-nothing-more {
  padding: 20px 0 0;
  font-size: 13px;
  color: var(--text-muted, #9a8a76);
  font-style: italic;
}

.agenda-event {
  display: flex;
  align-items: flex-start;
  gap: 16px;
  padding: 10px 12px;
  margin: 0 -12px;
  border-radius: 8px;
  cursor: pointer;
  transition: background 0.15s;
}
.agenda-event:hover { background: var(--smoke, #ece3d0); }
.agenda-event:hover .agenda-event-edit { opacity: 1; }

.agenda-event-time {
  font-family: 'DM Mono', monospace;
  font-size: 12.5px;
  color: var(--gold, #b8843a);
  min-width: 120px;
  flex-shrink: 0;
  padding-top: 2px;
  letter-spacing: 0.01em;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.agenda-event-clock { white-space: nowrap; }

.agenda-event-duration {
  font-size: 10.5px;
  color: var(--text-muted, #9a8a76);
  letter-spacing: 0.02em;
}

.agenda-event-body { flex: 1; min-width: 0; }

.agenda-event-title {
  font-size: 15px;
  font-weight: 500;
  color: var(--ink, #2c2416);
  margin-bottom: 5px;
  line-height: 1.3;
}

/* Lieu mis en évidence */
.agenda-event-location {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 13px;
  font-weight: 500;
  color: var(--ink2, #4a3f2f);
  background: var(--smoke, #ece3d0);
  border: 1px solid var(--border, #ddd5c8);
  border-radius: 6px;
  padding: 3px 9px 3px 7px;
  margin-bottom: 5px;
  max-width: 100%;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}
.agenda-event-location span { overflow: hidden; text-overflow: ellipsis; }

.agenda-event-desc-text {
  font-size: 12px;
  color: var(--text-muted, #8a7560);
  line-height: 1.5;
}

.agenda-event-meta {
  font-size: 12px;
  color: var(--text-muted, #8a7560);
  line-height: 1.5;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.agenda-event-src {
  display: inline-block;
  margin-top: 4px;
  font-size: 10.5px;
  font-family: 'DM Mono', monospace;
  color: var(--text-muted, #8a7560);
  background: var(--paper, #f5ead2);
  border: 1px solid var(--border, #ddd5c8);
  border-radius: 4px;
  padding: 1px 6px;
  letter-spacing: 0.04em;
}

.agenda-event-edit {
  font-size: 14px;
  color: var(--text-muted, #9a8a76);
  opacity: 0;
  transition: opacity 0.15s;
  flex-shrink: 0;
  padding-top: 2px;
  cursor: pointer;
}

/* ── Badges de trajet ──────────────────────────────────────────────────────── */
.agenda-travel-row {
  margin: 2px 12px 2px 124px; /* aligné sous le titre, après la colonne heure */
  padding: 5px 0;
  font-size: 12px;
}

.agenda-travel-spinner {
  color: var(--text-muted, #9a8a76);
  font-style: italic;
  font-size: 11.5px;
}

.agenda-travel-info {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: var(--text-muted, #8a7560);
  background: var(--paper, #f5ead2);
  border: 1px solid var(--border, #ddd5c8);
  border-radius: 20px;
  padding: 3px 10px;
  line-height: 1.4;
}

.agenda-travel-ok { font-size: 11px; color: var(--text-muted, #9a8a76); }

.agenda-travel-tight {
  background: #fff5e6 !important;
  border-color: #e8a020 !important;
  color: #8a5a00 !important;
}

.agenda-travel-warning {
  font-size: 11px;
  font-weight: 500;
  color: #8a5a00;
}

.agenda-travel-unknown {
  font-style: italic;
  opacity: 0.6;
}

/* PAPIER overrides trajet */
.app-theme-papier .agenda-travel-info { background: var(--smoke) !important; border-color: var(--border) !important; }
.app-theme-papier .agenda-travel-tight { background: #fdf0dc !important; border-color: var(--gold) !important; color: var(--ink2) !important; }
.app-theme-papier .agenda-travel-warning { color: var(--ink2) !important; }
.app-theme-papier .agenda-event-location { background: var(--smoke) !important; border-color: var(--border) !important; color: var(--ink2) !important; }

/* Toolbar simplifié */
.agenda-toolbar-title {
  font-family: 'Fraunces', Georgia, serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--ink, #2c2416);
  letter-spacing: -0.01em;
  flex: 1;
}

/* PAPIER overrides agenda */
.app-theme-papier .agenda-day-name { color: var(--ink) !important; }
.app-theme-papier .agenda-today-name { color: var(--gold) !important; }
.app-theme-papier .agenda-event-time { color: var(--gold) !important; }
.app-theme-papier .agenda-event-title { color: var(--ink) !important; }
.app-theme-papier .agenda-event:hover { background: var(--smoke) !important; }

/* ── Dossiers en cours (briefing) ── */
.dossier-brief-item {
  padding: 10px 14px;
  border-bottom: 1px solid var(--smoke);
  cursor: pointer;
  transition: background .1s;
}
.dossier-brief-item:hover { background: var(--ivory); }
.dossier-brief-item:last-child { border-bottom: none; }
.dossier-brief-title { font-size: .88rem; font-weight: 600; color: var(--ink); margin-bottom: 2px; }
.dossier-brief-desc { font-size: .78rem; color: var(--mist); margin-bottom: 2px; }
.dossier-brief-meta { font-size: .72rem; color: var(--mist); }

/* ── Briefings pré-RDV ── */
.rdv-brief-card {
  background: var(--paper);
  border: 1.5px solid var(--gold);
  border-left: 4px solid var(--gold);
  border-radius: 10px;
  margin-bottom: 10px;
  overflow: hidden;
  box-shadow: 0 2px 8px rgba(0,0,0,.07);
}
.rdv-brief-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px 8px;
  background: linear-gradient(90deg, rgba(201,168,76,.12), transparent);
  border-bottom: 1px solid var(--smoke);
  flex-wrap: wrap;
}
.rdv-brief-time { font-size: .88rem; font-weight: 700; color: var(--gold); white-space: nowrap; }
.rdv-brief-title { font-size: .9rem; font-weight: 600; color: var(--ink); flex: 1; }
.rdv-brief-location { font-size: .78rem; color: var(--mist); white-space: nowrap; }
.rdv-brief-body { padding: 12px 14px; font-size: .83rem; color: var(--ink); line-height: 1.6; }
.rdv-brief-loading { color: var(--mist); font-style: italic; }
.rdv-brief-empty { color: var(--mist); font-style: italic; }
.rdv-brief-divider { font-weight: 700; color: var(--gold); font-size: .82rem; letter-spacing: .04em; margin-bottom: 6px; }
.rdv-brief-section-title { font-weight: 600; color: var(--ink); margin-top: 8px; margin-bottom: 2px; }

/* ── Récap du jour — narratif ── */
.recap-narrative {
  font-size: .88rem;
  line-height: 1.65;
  color: var(--ink);
}
.recap-header {
  font-size: .82rem;
  font-weight: 700;
  letter-spacing: .06em;
  color: var(--gold);
  text-transform: uppercase;
  padding: 8px 0 4px;
  border-bottom: 1px solid rgba(201,168,76,.3);
  margin-bottom: 8px;
}
.recap-opening {
  font-style: italic;
  color: rgba(255,255,255,.85);
  margin-bottom: 12px;
  padding-left: 2px;
}
.recap-section {
  margin-bottom: 12px;
}
.recap-section-title {
  font-size: .76rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: rgba(255,255,255,.5);
  margin-bottom: 5px;
}
.recap-section-body { padding-left: 2px; }
.recap-item {
  padding: 3px 0;
  display: flex;
  gap: 6px;
  align-items: baseline;
  color: rgba(255,255,255,.9);
}
.recap-item::before { content: '·'; color: var(--gold); flex-shrink: 0; }
.recap-event {
  padding: 2px 0;
  color: rgba(255,255,255,.8);
  font-variant-numeric: tabular-nums;
}
.recap-event::before { content: '📅 '; }
.recap-alert {
  background: rgba(220,70,50,.12);
  border-left: 3px solid #dc4632;
  padding: 4px 10px;
  border-radius: 4px;
  margin: 3px 0;
  color: #f08070;
}
.recap-line { padding: 2px 0; color: var(--ink); border-bottom: none; font-size: .85rem; line-height: 1.55; margin: 0; }
.recap-check { color: #5cb85c; font-weight: 700; }
.recap-up { color: #e8a040; }
.recap-warn { color: #dc4632; }
.recap-empty { color: var(--ink4); font-style: italic; }

/* Variantes selon heure */
.recap-morning .recap-header { color: var(--ink); }
.recap-midday .recap-header { color: var(--ink3); }
.recap-evening .recap-header { color: var(--ink3); }

/* ── Fix 03 — Analyse en cours ─────────────────────────────────────────── */
.brief-analyzing {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 14px 16px;
  background: var(--cream);
  border-radius: var(--r);
  font-size: .84rem;
  color: var(--ink3);
  font-style: italic;
}
.brief-analyzing-spin { animation: spin .8s linear infinite; display: inline-block; }
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Fix 07 — Hiérarchie visuelle situation cards ───────────────────────── */
.situation-card.sit-level-urgent {
  border-left: 3px solid var(--rust) !important;
  background: rgba(220, 70, 50, .03);
}
.situation-card.sit-level-high {
  border-left: 3px solid var(--amber) !important;
  background: rgba(232, 160, 64, .03);
}

/* ── Fix 04 — Section infos collapsible ─────────────────────────────────── */
.info-collapsed-row {
  display: flex;
  align-items: center;
  padding: 7px 12px;
  cursor: pointer;
  border-radius: var(--r);
  margin-top: 4px;
}
.info-collapsed-row:hover { background: var(--cream); }
.info-collapse-label {
  font-size: .78rem;
  color: var(--ink4);
  font-style: italic;
}
.info-bg-list { padding-top: 4px; }
.info-archive-all-btn {
  margin-top: 6px;
  font-size: .74rem;
  color: var(--ink4);
  background: var(--cream);
  border: none;
  padding: 4px 10px;
  border-radius: var(--r-sm);
  cursor: pointer;
}
.info-archive-all-btn:hover { background: var(--smoke); color: var(--ink2); }

/* ── Fix 08 — Brouillons avec contexte ──────────────────────────────────── */
.draft-count {
  font-size: .8rem;
  color: var(--amber);
  font-weight: 600;
  display: block;
}
.draft-list {
  display: flex;
  flex-direction: column;
  gap: 2px;
  margin-top: 3px;
}
.draft-mini {
  font-size: .76rem;
  color: var(--ink3);
  display: block;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

/* ── Fix 02 — Weekly report métriques ──────────────────────────────────── */
.wr-metrics {
  display: flex;
  gap: 12px;
  padding: 10px 14px;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--cream);
}
.wr-metric {
  display: flex;
  flex-direction: column;
  align-items: center;
  min-width: 52px;
}
.wr-metric-n {
  font-size: 1.3rem;
  font-weight: 700;
  color: var(--gold);
  line-height: 1.2;
}
.wr-metric-l {
  font-size: .68rem;
  color: var(--ink4);
  text-align: center;
  line-height: 1.3;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.wr-body {
  font-size: .84rem;
  color: var(--ink2);
  line-height: 1.65;
  padding-top: 6px;
}
.wr-body p { margin: 0 0 8px; }
.wr-expand-btn {
  background: none;
  border: none;
  color: var(--gold);
  font-size: .78rem;
  cursor: pointer;
  padding: 2px 0;
  margin-top: -4px;
}
.wr-expand-btn:hover { text-decoration: underline; }

/* ── Fix 02v3 — Weekly report grille 3 colonnes ──────────────────────────── */
.wr-metrics-3col {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 0;
  padding: 12px 14px;
  border-bottom: 1px solid var(--cream);
}
.wr-metrics-3col .wr-metric {
  min-width: 0;
  padding: 4px 0;
}
.wr-metrics-3col .wr-metric:not(:last-child) {
  border-right: 1px solid var(--cream);
}
.wr-secondary-line {
  font-size: .78rem;
  color: var(--ink3);
  padding: 6px 14px 0;
  margin: 0;
}

/* ── Fix 09 — Nav labels ────────────────────────────────────────────────── */
.nav-icon { font-size: 1.1rem; flex-shrink: 0; }
.nav-label {
  font-size: .75rem;
  font-weight: 500;
  letter-spacing: .02em;
  overflow: hidden;
  white-space: nowrap;
  opacity: 0;
  max-width: 0;
  transition: opacity .15s, max-width .15s;
}
#sidebar:hover .nav-label, #sidebar.open .nav-label {
  opacity: 1;
  max-width: 120px;
}
.nav-badge {
  margin-left: auto;
  background: var(--rust);
  color: #fff;
  font-size: .65rem;
  font-weight: 700;
  min-width: 16px;
  height: 16px;
  border-radius: 8px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  padding: 0 4px;
}

/* ══════════════════════════════════════════════════════
   REDESIGN — Home Feed colonne unique — 2026-03-20
══════════════════════════════════════════════════════ */

/* ── Topbar nouvelle structure ── */
.topbar-logo {
  font-family: 'Fraunces', serif !important;
  font-style: italic !important;
  font-weight: 400 !important;
  font-size: 16px !important;
  color: var(--ink) !important;
  letter-spacing: -.01em !important;
  flex-shrink: 0 !important;
}
.topbar-logo .topbar-dot {
  display: inline-block !important;
  width: 5px !important; height: 5px !important;
  background: var(--gold) !important;
  border-radius: 50% !important;
  vertical-align: middle !important;
  margin-left: 1px !important;
  margin-bottom: 2px !important;
}
.topbar-center {
  flex: 1 !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  min-width: 0 !important;
}
.topbar-status {
  display: flex !important;
  align-items: center !important;
  gap: 5px !important;
  font-size: 11.5px !important;
  color: var(--ink3) !important;
  font-family: 'DM Sans', sans-serif !important;
}
.topbar-status-dot {
  width: 6px !important; height: 6px !important;
  background: #5a9a5c !important;
  border-radius: 50% !important;
  flex-shrink: 0 !important;
}
.topbar-actions {
  display: flex !important;
  align-items: center !important;
  gap: 4px !important;
  flex-shrink: 0 !important;
}
.topbar-avatar {
  width: 26px !important; height: 26px !important;
  border-radius: 50% !important;
  background: var(--gold) !important;
  color: white !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 600 !important;
  font-size: 11px !important;
  display: flex !important;
  align-items: center !important;
  justify-content: center !important;
  flex-shrink: 0 !important;
  cursor: pointer !important;
}
.topbar-center #view-title {
  flex: unset !important;
  font-size: 11px !important;
  font-weight: 400 !important;
  text-align: center !important;
  color: var(--ink4) !important;
  letter-spacing: .02em !important;
}

/* ── Sidenav icones + labels ── */
.nav-separator {
  width: 20px !important;
  height: 0.5px !important;
  background: var(--smoke) !important;
  margin: 3px auto !important;
  flex-shrink: 0 !important;
  align-self: center !important;
}
.nav-item {
  flex-direction: column !important;
  height: 44px !important;
  padding: 5px 0 4px !important;
  gap: 2px !important;
  justify-content: center !important;
  overflow: visible !important;
  white-space: normal !important;
}
.nav-icon {
  font-size: 14px !important;
  line-height: 1 !important;
  flex-shrink: 0 !important;
}
.nav-label {
  font-size: 8px !important;
  text-transform: uppercase !important;
  letter-spacing: .05em !important;
  font-weight: 500 !important;
  color: var(--ink4) !important;
  opacity: 1 !important;
  max-width: unset !important;
  white-space: nowrap !important;
  line-height: 1 !important;
}
.nav-item.active .nav-label { color: var(--gold) !important; }
.nav-item:hover .nav-label { color: var(--ink2) !important; }
#sidebar:hover .nav-label, #sidebar.open .nav-label {
  opacity: 1 !important;
  max-width: unset !important;
}

/* ── Home feed ── */
.home-feed {
  flex: 1 !important;
  overflow-y: auto !important;
  padding: 14px 20px 80px !important;
  max-width: 700px !important;
  margin: 0 auto !important;
  width: 100% !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 10px !important;
}

/* ── Briefing card (section 1) ── */
.briefing-card {
  background: var(--paper) !important;
  border: none !important;
  border-top: 2px solid var(--gold) !important;
  border-radius: 14px !important;
  padding: 14px 18px !important;
}
.briefing-card-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 10px;
}
.briefing-day {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 400;
  font-size: 13.5px;
  color: var(--gold);
  flex: 1;
}
.briefing-update-time {
  font-size: 10.5px;
  color: var(--ink4);
  flex-shrink: 0;
}
.briefing-refresh {
  font-size: 13px;
  color: var(--ink4);
  width: 22px; height: 22px;
  display: flex; align-items: center; justify-content: center;
  border-radius: 50%;
  flex-shrink: 0;
  transition: all .2s;
}
.briefing-refresh:hover { color: var(--gold); background: rgba(184,132,58,.1); }
.briefing-divider {
  width: 20px;
  height: 2px;
  background: var(--gold);
  border-radius: 1px;
  margin-bottom: 11px;
}
.briefing-text {
  font-family: 'Fraunces', serif;
  font-style: italic;
  font-weight: 300;
  font-size: 13.5px;
  line-height: 1.75;
  color: var(--ink2);
}
.briefing-text .recap-narrative { font-family: 'Fraunces', serif !important; font-style: italic !important; color: var(--ink2) !important; }
.briefing-text .recap-section-title { font-size: 10px !important; text-transform: uppercase !important; letter-spacing: .06em !important; color: var(--ink3) !important; font-style: normal !important; font-family: 'DM Sans', sans-serif !important; margin: 10px 0 3px !important; }
.briefing-text .recap-alert { color: var(--rust) !important; }
/* Fix couleurs thème PAPIER — texte blanc invisible sur fond clair */
.briefing-text .recap-opening { color: var(--ink2) !important; font-style: italic !important; }
.briefing-text .recap-item { color: var(--ink) !important; }
.briefing-text .recap-item::before { color: var(--gold-deep) !important; }
.briefing-text .recap-line { color: var(--ink2) !important; }
.briefing-text .recap-header { color: var(--gold-deep) !important; border-bottom-color: rgba(180,140,60,.3) !important; }

/* ── Strip urgence (section 2) ── */
.urgency-strip {
  display: flex;
  align-items: center;
  gap: 10px;
  background: #f7ebe8;
  border-left: 2px solid var(--rust);
  border-radius: 0 10px 10px 0;
  padding: 10px 14px;
}
.urgency-badge {
  background: var(--rust);
  color: white;
  font-size: 9.5px;
  font-weight: 600;
  padding: 2px 8px;
  border-radius: 20px;
  white-space: nowrap;
  flex-shrink: 0;
  font-family: 'DM Sans', sans-serif;
  text-transform: uppercase;
  letter-spacing: .04em;
}
.urgency-text {
  flex: 1;
  font-size: 12px;
  color: var(--ink2);
  line-height: 1.5;
}
.urgency-btn {
  background: var(--rust) !important;
  color: white !important;
  font-size: 11px !important;
  padding: 5px 12px !important;
  border-radius: 6px !important;
  white-space: nowrap !important;
  flex-shrink: 0 !important;
}
.urgency-btn:hover { opacity: .85 !important; }

/* ── Home sections (3-7) ── */
.home-section {
  display: flex;
  flex-direction: column;
  gap: 7px;
}
.home-section-label {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ink3);
  padding-bottom: 6px;
  border-bottom: 0.5px solid var(--smoke);
}
.home-section-label .brief-badge {
  background: var(--rust) !important;
  color: white !important;
  font-size: 8.5px !important;
  padding: 1px 6px !important;
  border-radius: 20px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 700 !important;
  letter-spacing: 0 !important;
  text-transform: none !important;
}
.home-section-link {
  color: var(--gold) !important;
  font-size: 9.5px !important;
  font-weight: 500 !important;
  text-transform: none !important;
  letter-spacing: 0 !important;
  cursor: pointer !important;
  margin-left: auto !important;
}
.home-section-link + .home-section-link {
  margin-left: 0 !important;
}
.home-section-link:hover { text-decoration: underline !important; }

/* Collapse header */
.home-section-collapse {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 9.5px;
  font-weight: 600;
  letter-spacing: .07em;
  text-transform: uppercase;
  color: var(--ink3);
  padding-bottom: 6px;
  border-bottom: 0.5px solid var(--smoke);
  user-select: none;
}
.home-section-collapse:hover { color: var(--ink); }
.home-section-collapse .weekly-report-toggle {
  margin-left: auto !important;
  font-size: 12px !important;
  color: var(--ink4) !important;
  background: none !important;
  border: none !important;
  padding: 0 !important;
}
.home-section-collapse .weekly-report-badge {
  font-size: 8.5px !important;
  background: var(--paper) !important;
  color: var(--ink3) !important;
  border: 0.5px solid var(--smoke) !important;
  padding: 1px 7px !important;
  border-radius: 20px !important;
  font-family: 'DM Sans', sans-serif !important;
  font-weight: 500 !important;
  letter-spacing: .02em !important;
  text-transform: none !important;
}
.home-section-body {
  display: flex;
  flex-direction: column;
  gap: 6px;
}

/* Section 7 — bilan encadré */
.weekly-section {
  background: var(--paper) !important;
  border-radius: 12px !important;
  padding: 12px 16px !important;
  border: none !important;
}
.weekly-section .weekly-report-body { padding-top: 8px; }

/* ── RDV cards (section 3) ── */
.rdv-home-card {
  background: white;
  border: 0.5px solid var(--smoke);
  border-radius: 12px;
  padding: 12px 16px;
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.rdv-home-header { display: flex; align-items: center; gap: 10px; }
.rdv-home-time {
  font-family: 'Fraunces', serif;
  font-size: 18px;
  font-weight: 400;
  color: var(--ink);
  flex-shrink: 0;
  line-height: 1;
}
.rdv-home-title {
  font-size: 13.5px;
  font-weight: 500;
  color: var(--ink);
  flex: 1;
}
.rdv-home-duration {
  font-size: 9.5px;
  background: var(--paper);
  color: var(--ink3);
  padding: 2px 8px;
  border-radius: 20px;
  border: 0.5px solid var(--smoke);
  flex-shrink: 0;
}
.rdv-home-briefing {
  font-size: 11.5px;
  color: var(--ink);
  font-style: normal;
  line-height: 1.55;
}
.rdv-home-briefing.rdv-brief-loading {
  color: var(--gold);
  font-style: italic;
}
/* Masquer le séparateur — RDV HH:MM — dans la home card (redondant avec le header) */
.rdv-home-card .rdv-brief-divider { display: none; }
.rdv-home-actions { display: flex; gap: 8px; padding-top: 2px; }
.rdv-home-btn {
  font-size: 11px !important;
  padding: 5px 12px !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 6px !important;
  color: var(--ink2) !important;
  background: none !important;
  transition: all .2s !important;
}
.rdv-home-btn:hover { border-color: var(--gold) !important; color: var(--gold) !important; }

/* ── Dossiers (section 5) ── */
.dossier-brief-item {
  background: white !important;
  border: 0.5px solid var(--smoke) !important;
  border-radius: 10px !important;
  padding: 10px 14px !important;
  cursor: pointer !important;
  transition: all .15s !important;
  display: flex !important;
  flex-direction: column !important;
  gap: 3px !important;
}
.dossier-brief-item:hover { border-color: var(--gold) !important; box-shadow: 0 2px 8px rgba(0,0,0,.06) !important; }
.dossier-brief-title { font-size: 13px !important; font-weight: 500 !important; color: var(--ink) !important; }
.dossier-brief-desc { font-size: 11px !important; color: var(--ink3) !important; white-space: nowrap !important; overflow: hidden !important; text-overflow: ellipsis !important; }
.dossier-brief-meta { font-size: 10px !important; color: var(--ink4) !important; }

/* ── FAB — cercle noir 42px ── */
#chat-fab {
  width: 42px !important;
  height: 42px !important;
  background: #1e1a15 !important;
  box-shadow: 0 4px 14px rgba(0,0,0,.22) !important;
  font-size: 1.0rem !important;
  animation: none !important;
}
#chat-fab:hover {
  background: #3a342c !important;
  transform: scale(1.07) !important;
  box-shadow: 0 6px 20px rgba(0,0,0,.28) !important;
  animation: none !important;
}

/* ── Mobile ── */
@media (max-width: 768px) {
  .home-feed { padding: 10px 12px 70px !important; gap: 8px !important; }
  .briefing-card { padding: 12px 14px !important; }
  .home-section-label { font-size: 9px !important; }
}

/* ── Live notifications (relances, dossiers, deadlines) ── */
#live-notifications {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.live-notif-card {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  padding: 11px 14px;
  border-radius: 10px;
  border-left: 3px solid transparent;
  background: var(--ivory);
  animation: notif-in .3s ease;
}
@keyframes notif-in {
  from { opacity: 0; transform: translateY(-6px); }
  to   { opacity: 1; transform: translateY(0); }
}
.live-notif-card.relance  { background: #fdf5e8; border-color: var(--amber); }
.live-notif-card.dossier  { background: #eef5f0; border-color: var(--sage); }
.live-notif-card.deadline { background: #fdf0ed; border-color: var(--rust); }
.live-notif-icon { font-size: 16px; flex-shrink: 0; margin-top: 1px; }
.live-notif-body { flex: 1; min-width: 0; }
.live-notif-title {
  font-size: 12.5px;
  font-weight: 600;
  color: var(--ink2);
  font-family: 'Fraunces', serif;
  line-height: 1.4;
}
.live-notif-sub {
  font-size: 11px;
  color: var(--ink3);
  margin-top: 2px;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}
.live-notif-actions {
  display: flex;
  gap: 6px;
  margin-top: 7px;
  flex-wrap: wrap;
}
.live-notif-btn {
  font-size: 11px !important;
  padding: 4px 11px !important;
  border-radius: 6px !important;
  border: 1px solid var(--smoke) !important;
  background: white !important;
  color: var(--ink2) !important;
  cursor: pointer !important;
}
.live-notif-btn.primary {
  background: var(--ink2) !important;
  color: white !important;
  border-color: var(--ink2) !important;
}
.live-notif-btn:hover { opacity: .8 !important; }
.live-notif-dismiss {
  background: none;
  border: none;
  color: var(--ink5);
  font-size: 14px;
  cursor: pointer;
  padding: 0 2px;
  flex-shrink: 0;
  line-height: 1;
  margin-top: 1px;
}
.live-notif-dismiss:hover { color: var(--ink3); }

/* Correction 05+06 — Quoi / Contexte tabs */
.quoi-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 10px 13px;
  margin-bottom: 6px;
  cursor: pointer;
  position: relative;
}
.quoi-card:hover { background: var(--paper); }
.quoi-card-title { font-size: .88rem; font-weight: 600; color: var(--ink); margin-bottom: 3px; }
.quoi-card-desc  { font-size: .78rem; color: var(--ink3); margin-bottom: 3px; }
.quoi-card-meta  { font-size: .72rem; color: var(--smoke); }
.quoi-card-date  { position: absolute; top: 10px; right: 12px; font-size: .68rem; color: var(--smoke); }
.contexte-header { display: flex; justify-content: space-between; align-items: center; margin-bottom: 12px; }
.contexte-period { font-size: .75rem; color: var(--smoke); font-style: italic; }
.contexte-text   { font-family: var(--font-serif, Georgia, serif); font-size: .88rem; line-height: 1.7; color: var(--ink2); white-space: pre-wrap; }

/* ── Page Mon Compte ─────────────────────────────── */
#account-screen {
  display: none;
  flex-direction: column;
  background: var(--cream);
  height: 100dvh;
  overflow: hidden;
}
.account-topbar {
  display: flex;
  align-items: center;
  gap: 16px;
  padding: 16px 24px;
  background: var(--cream2);
  border-bottom: 1px solid var(--smoke);
  flex-shrink: 0;
}
.account-back-btn {
  background: none;
  border: none;
  font-family: var(--font-sans, 'DM Sans', sans-serif);
  font-size: .88rem;
  color: var(--gold);
  cursor: pointer;
  padding: 6px 12px;
  border-radius: 8px;
  transition: background .15s;
}
.account-back-btn:hover { background: var(--gold-pale); }
.account-title {
  font-family: var(--font-serif, 'Playfair Display', serif);
  font-size: 1.25rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0;
}
.account-body {
  flex: 1;
  overflow-y: auto;
  padding: 24px;
  display: flex;
  flex-direction: column;
  gap: 24px;
  max-width: 680px;
  width: 100%;
  margin: 0 auto;
}
.account-section {
  background: #fff;
  border-radius: 12px;
  padding: 24px;
  box-shadow: 0 1px 4px rgba(0,0,0,.06);
  display: flex;
  flex-direction: column;
  gap: 14px;
}
.account-section-title {
  font-family: var(--font-serif, 'Playfair Display', serif);
  font-size: 1rem;
  font-weight: 600;
  color: var(--ink);
  margin: 0 0 4px 0;
  padding-bottom: 10px;
  border-bottom: 1px solid var(--smoke);
}
.account-section-desc {
  font-size: .82rem;
  color: var(--ink3);
  margin: 0;
  line-height: 1.5;
}
.account-field {
  display: flex;
  flex-direction: column;
  gap: 6px;
}
.account-field label {
  font-size: .78rem;
  font-weight: 500;
  color: var(--ink3);
  text-transform: uppercase;
  letter-spacing: .05em;
}
.account-field input[type="text"],
.account-field input[type="email"] {
  border: 1px solid var(--smoke);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: .88rem;
  font-family: var(--font-sans, 'DM Sans', sans-serif);
  color: var(--ink);
  background: var(--cream);
  transition: border-color .15s;
  outline: none;
}
.account-field input:focus {
  border-color: var(--gold);
}
.account-readonly {
  font-size: .88rem;
  color: var(--ink3);
  padding: 9px 0;
}
.account-radio-group {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
}
.radio-chip {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border: 1.5px solid var(--smoke);
  border-radius: 20px;
  font-size: .82rem;
  color: var(--ink2);
  cursor: pointer;
  transition: border-color .15s, background .15s;
  user-select: none;
}
.radio-chip input[type="radio"] { display: none; }
.radio-chip:has(input:checked) {
  border-color: var(--gold);
  background: var(--gold-pale);
  color: var(--gold-deep);
  font-weight: 500;
}
.btn-account-save {
  background: var(--gold);
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 20px;
  font-size: .85rem;
  font-weight: 500;
  cursor: pointer;
  align-self: flex-start;
  transition: background .15s;
}
.btn-account-save:hover { background: var(--gold-deep); }
.btn-account-secondary {
  background: none;
  color: var(--gold);
  border: 1.5px solid var(--gold);
  border-radius: 8px;
  padding: 9px 18px;
  font-size: .84rem;
  font-weight: 500;
  cursor: pointer;
  align-self: flex-start;
  transition: background .15s;
}
.btn-account-secondary:hover { background: var(--gold-pale); }
.account-msg {
  font-size: .8rem;
  min-height: 18px;
  color: var(--gold-deep);
}
.account-msg.error { color: #c0392b; }
.account-password-section {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding-top: 8px;
  border-top: 1px solid var(--smoke);
  margin-top: 4px;
}
.password-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 12px;
  background: var(--cream);
  border-radius: 8px;
}
.password-form input {
  border: 1px solid var(--smoke);
  border-radius: 8px;
  padding: 9px 12px;
  font-size: .86rem;
  font-family: var(--font-sans, 'DM Sans', sans-serif);
  color: var(--ink);
  background: #fff;
  outline: none;
}
.password-form input:focus { border-color: var(--gold); }
/* Comptes mail list */
.acc-accounts-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}
.acc-account-item {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 14px;
  border: 1px solid var(--smoke);
  border-radius: 8px;
  background: var(--cream);
}
.acc-account-info { display: flex; flex-direction: column; gap: 2px; }
.acc-account-label { font-size: .88rem; font-weight: 500; color: var(--ink); }
.acc-account-email { font-size: .78rem; color: var(--ink3); }
.acc-account-status {
  font-size: .75rem;
  padding: 3px 8px;
  border-radius: 10px;
  font-weight: 500;
}
.acc-account-status.ok { background: #e8f5e9; color: #2e7d32; }
.acc-account-status.err { background: #fce4ec; color: #c62828; }
.acc-account-delete {
  background: none;
  border: none;
  color: var(--ink4);
  cursor: pointer;
  font-size: .82rem;
  padding: 4px 8px;
  border-radius: 6px;
  transition: color .15s, background .15s;
}
.acc-account-delete:hover { color: #c0392b; background: #fce4ec; }
/* Plan */
.account-plan-badge {
  display: inline-flex;
  align-items: center;
  padding: 6px 14px;
  background: var(--gold-pale);
  color: var(--gold-deep);
  border-radius: 20px;
  font-size: .85rem;
  font-weight: 600;
  align-self: flex-start;
}
.account-plan-expires { font-size: .78rem; color: var(--ink3); }
/* Danger zone */
.account-danger-zone { border: 1.5px solid #ffcdd2; }
.account-danger-title { color: #c62828 !important; }
.btn-account-danger {
  background: none;
  color: #c62828;
  border: 1.5px solid #e57373;
  border-radius: 8px;
  padding: 9px 18px;
  font-size: .84rem;
  font-weight: 500;
  cursor: pointer;
  align-self: flex-start;
  transition: background .15s;
}
.btn-account-danger:hover { background: #fce4ec; }
.delete-confirm-form {
  display: flex;
  flex-direction: column;
  gap: 10px;
  padding: 14px;
  background: #fff5f5;
  border-radius: 8px;
  border: 1px solid #ffcdd2;
}
.delete-confirm-text { font-size: .82rem; color: #c62828; margin: 0; }
.delete-confirm-form input {
  border: 1px solid #e57373;
  border-radius: 8px;
  padding: 9px 12px;
  font-size: .86rem;
  font-family: var(--font-sans, 'DM Sans', sans-serif);
  outline: none;
}
.btn-account-danger-confirm {
  background: #c62828;
  color: #fff;
  border: none;
  border-radius: 8px;
  padding: 10px 18px;
  font-size: .84rem;
  font-weight: 600;
  cursor: pointer;
  align-self: flex-start;
  transition: background .15s;
}
.btn-account-danger-confirm:hover { background: #b71c1c; }
.btn-account-cancel {
  background: none;
  border: 1.5px solid var(--smoke);
  border-radius: 8px;
  padding: 9px 16px;
  font-size: .82rem;
  cursor: pointer;
  align-self: flex-start;
  color: var(--ink3);
}
.topbar-avatar { cursor: pointer; transition: background .15s; }
.topbar-avatar:hover { background: var(--gold-pale); }
