/* =============================================
   TOOBEEB — Ordonnancier Médecin
   ============================================= */

.doctor-body {
  background-color: #F4F6FB;
  background-image:
    radial-gradient(900px 600px at 8% -6%,  rgba(4, 97, 207, 0.10) 0%, transparent 60%),
    radial-gradient(720px 520px at 95% 4%,  rgba(0, 168, 159, 0.09) 0%, transparent 60%),
    radial-gradient(820px 600px at 50% 110%, rgba(99, 102, 241, 0.08) 0%, transparent 60%);
  background-attachment: fixed;
  min-height: 100vh;
}

/* ── Nav Liquid Glass flottante ─────────────── */
.doc-nav {
  position: sticky;
  top: 12px;
  z-index: 100;
  margin: 12px 16px 0;
  padding: 14px 24px;
  background: var(--glass-tint);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  backdrop-filter:        blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border: 1px solid var(--glass-border);
  border-radius: var(--glass-radius-lg);
  box-shadow: var(--glass-rim), var(--glass-shadow);
  isolation: isolate;
}
.doc-nav::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--glass-highlight);
  pointer-events: none;
  mix-blend-mode: screen;
}
.doc-nav > * { position: relative; z-index: 1; }
.doc-nav-inner {
  max-width: 1200px;
  margin: 0 auto;
  display: flex;
  align-items: center;
  gap: 16px;
}
.doc-nav-title {
  font-size: 15px;
  font-weight: 700;
  color: var(--brand);
  margin-left: 8px;
  padding-left: 16px;
  border-left: 2px solid #E8EBF0;
}
.doc-nav-badge {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  font-weight: 600;
  color: #16a34a;
  background: #f0fdf4;
  padding: 6px 12px;
  border-radius: 50px;
  border: 1px solid #bbf7d0;
}

/* ── Main ─────────────────────────────────── */
.doc-main { padding: 32px 24px 80px; }
.doc-container { max-width: 1200px; margin: 0 auto; }

/* ── Login ────────────────────────────────── */
.doc-login-section {
  display: flex;
  justify-content: center;
  padding-top: 80px;
}
.doc-login-card {
  position: relative;
  background: var(--glass-tint-strong);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  backdrop-filter:        blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border-radius: var(--glass-radius-xl);
  padding: 48px;
  max-width: 520px;
  width: 100%;
  text-align: center;
  border: 1px solid var(--glass-border-strong);
  box-shadow: var(--glass-rim-lg), var(--glass-shadow-lg);
  isolation: isolate;
}
.doc-login-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--glass-highlight);
  pointer-events: none;
  mix-blend-mode: screen;
  z-index: 0;
}
.doc-login-card > * { position: relative; z-index: 1; }
.doc-login-icon { margin-bottom: 20px; }
.doc-login-card h1 {
  font-size: 24px;
  font-weight: 800;
  color: #0B1120;
  margin-bottom: 8px;
}
.doc-login-card > p {
  font-size: 15px;
  color: var(--gray-500);
  margin-bottom: 28px;
}
.doc-login-form { text-align: left; }
.doc-login-form label {
  font-size: 13px;
  font-weight: 700;
  color: #334155;
  display: block;
  margin-bottom: 6px;
}
.doc-input-row {
  display: flex;
  gap: 10px;
}
.doc-input-row input {
  flex: 1;
  padding: 13px 16px;
  border: 2px solid var(--gray-200);
  border-radius: 12px;
  font-size: 16px;
  font-family: var(--font);
  outline: none;
  transition: border-color .15s;
}
.doc-input-row input:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(4,97,207,.1);
}
.doc-login-hint {
  font-size: 13px;
  color: #dc2626;
  margin-top: 8px;
  min-height: 20px;
}
.doc-login-demo {
  text-align: center;
  margin-top: 16px;
  font-size: 13px;
  color: var(--gray-500);
}
.doc-link-btn {
  background: none;
  border: none;
  color: var(--brand);
  font-weight: 700;
  cursor: pointer;
  text-decoration: underline;
  font-family: inherit;
  font-size: inherit;
}

/* ── Doctor header ────────────────────────── */
.doc-header-card {
  position: relative;
  background: linear-gradient(135deg, var(--brand) 0%, #1D4ED8 55%, #4338CA 100%);
  border-radius: var(--glass-radius-lg);
  padding: 24px 28px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 20px;
  margin-bottom: 24px;
  color: #fff;
  flex-wrap: wrap;
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,0.35),
    inset 0 -1.5px 0 rgba(0,0,0,0.18),
    0 20px 48px -10px rgba(4,97,207,0.42);
  isolation: isolate;
  overflow: hidden;
}
.doc-header-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.22) 0%, rgba(255,255,255,0) 45%);
  pointer-events: none;
}
.doc-header-card > * { position: relative; z-index: 1; }
.doc-header-left {
  display: flex;
  align-items: center;
  gap: 16px;
}
.doc-header-avatar {
  width: 56px;
  height: 56px;
  border-radius: 50%;
  background: rgba(255,255,255,.18);
  border: 2px solid rgba(255,255,255,.3);
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 18px;
  font-weight: 900;
  flex-shrink: 0;
}
.doc-header-card h2 {
  font-size: 18px;
  font-weight: 800;
  margin-bottom: 2px;
}
.doc-spec {
  font-size: 14px;
  opacity: .85;
}
.doc-address {
  font-size: 12px;
  opacity: .65;
  margin-top: 2px;
}
.doc-header-right {
  display: flex;
  align-items: center;
  gap: 20px;
}
.doc-rpps-block {
  text-align: center;
}
.doc-rpps-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  opacity: .7;
  display: block;
}
.doc-rpps-value {
  font-size: 15px;
  font-weight: 800;
  font-family: 'Courier New', monospace;
  display: block;
  margin: 2px 0 4px;
}
#rpps-barcode {
  display: block;
  border-radius: 4px;
  background: #fff;
  padding: 4px;
}

/* ── Grid ─────────────────────────────────── */
.doc-grid {
  display: grid;
  grid-template-columns: 1fr 340px;
  gap: 24px;
  align-items: start;
}

/* ── Cards — Liquid Glass ─────────────────── */
.doc-card {
  position: relative;
  background: var(--glass-tint-strong);
  -webkit-backdrop-filter: blur(var(--glass-blur)) saturate(var(--glass-saturate));
  backdrop-filter:        blur(var(--glass-blur)) saturate(var(--glass-saturate));
  border-radius: var(--glass-radius-lg);
  padding: 24px;
  border: 1px solid var(--glass-border);
  box-shadow: var(--glass-rim), var(--glass-shadow);
  margin-bottom: 20px;
  isolation: isolate;
}
.doc-card::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: var(--glass-highlight);
  pointer-events: none;
  mix-blend-mode: screen;
  z-index: 0;
}
.doc-card > * { position: relative; z-index: 1; }
.doc-card-title {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 16px;
  font-weight: 800;
  color: #0B1120;
  margin-bottom: 18px;
}
.doc-card-subtitle {
  font-size: 12px;
  font-weight: 500;
  color: var(--gray-500);
  letter-spacing: 0;
  margin-left: 4px;
}

/* Carte Recommandations — variant légèrement teintée pour la
   distinguer comme zone "personnalisation médecin" en bas d'ordo. */
.doc-card-recos textarea#instructions {
  width: 100%;
  min-height: 160px;
  padding: 14px 16px;
  border: 1.5px solid var(--gray-200);
  border-radius: 12px;
  font-family: var(--font);
  font-size: 14.5px;
  line-height: 1.55;
  color: var(--gray-800);
  background: #fff;
  outline: none;
  resize: vertical;
  transition: border-color .15s, box-shadow .15s;
}
.doc-card-recos textarea#instructions:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 4px rgba(4, 97, 207, 0.10);
}
.doc-card-recos textarea#instructions::placeholder {
  color: #94a3b8;
  font-style: italic;
  font-size: 13.5px;
  line-height: 1.7;
}
.doc-card-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  margin-top: 10px;
  font-size: 12px;
  color: var(--gray-500);
  font-style: italic;
}
.doc-sticky {
  position: sticky;
  top: 80px;
}

/* ── Form ─────────────────────────────────── */
.doc-form-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 14px;
}
.doc-field label {
  display: block;
  font-size: 12px;
  font-weight: 700;
  color: #334155;
  margin-bottom: 5px;
}
.doc-field input,
.doc-field select,
.doc-workspace textarea {
  width: 100%;
  padding: 11px 14px;
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  font-size: 15px;
  font-family: var(--font);
  color: #0B1120;
  outline: none;
  transition: border-color .15s;
  background: #fff;
}
.doc-field input:focus,
.doc-field select:focus,
.doc-workspace textarea:focus {
  border-color: var(--brand);
  box-shadow: 0 0 0 3px rgba(4,97,207,.08);
}
.doc-workspace textarea {
  resize: vertical;
  min-height: 80px;
}

/* ── Medication row — design pharmaceutique ─── */
.med-row {
  border: 1.5px solid #E8EBF0;
  border-radius: 14px;
  padding: 14px 16px;
  margin-bottom: 12px;
  position: relative;
  transition: border-color .15s;
}
.med-row:focus-within { border-color: var(--brand); }

/* TOP : numéro · input nom · bouton "+" croix verte · supprimer */
.med-row-top {
  display: flex;
  align-items: center;
  gap: 10px;
  margin-bottom: 10px;
}
.med-row-num {
  width: 28px; height: 28px; border-radius: 8px;
  background: var(--brand-light); color: var(--brand);
  font-size: 13px; font-weight: 800;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.med-name-wrap { flex: 1; position: relative; min-width: 0; }
.med-name-input {
  width: 100%; padding: 11px 16px;
  border: 1.5px solid var(--gray-200); border-radius: 10px;
  font-size: 15px; font-family: var(--font); outline: none;
  background: #fff;
}
.med-name-input:focus { border-color: var(--brand); }
.med-autocomplete {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: #fff; border: 1.5px solid var(--gray-200);
  border-radius: 10px; max-height: 320px; overflow-y: auto;
  z-index: 50; box-shadow: 0 12px 32px rgba(0,0,0,.12);
  display: none;
}
.med-autocomplete.open { display: block; }
.med-ac-item {
  padding: 9px 14px; font-size: 14px; cursor: pointer;
  border-bottom: 1px solid #f1f5f9;
  transition: background .1s;
}
.med-ac-item:hover { background: var(--brand-light); }
.med-ac-item:last-child { border-bottom: none; }
.med-ac-name {
  font-weight: 600; color: var(--gray-800);
  font-size: 14px; line-height: 1.3;
}
.med-ac-meta {
  display: flex; flex-wrap: wrap; gap: 4px 10px;
  margin-top: 3px; align-items: center;
  font-size: 11.5px;
}
.med-ac-dci {
  color: #1F4459; font-weight: 600;
  background: #DDE9F0; padding: 1px 8px; border-radius: 6px;
}
.med-ac-lab {
  color: #6B7280; font-style: italic;
}
.med-ac-cip {
  margin-left: auto;
  color: #C76B4A; font-weight: 700;
  background: #F5DDD2; padding: 1px 8px; border-radius: 6px;
  font-family: 'JetBrains Mono', 'Courier New', monospace;
  font-size: 10.5px; letter-spacing: 0.02em;
}
.med-ac-item small {
  display: block; font-size: 11px; color: #94a3b8; margin-top: 2px;
}

/* Bouton "+" CROIX PHARMACIE VERTE — sur la même ligne que la
   prescription, ne masque plus l'autocomplete (qui descend
   sous l'input). */
.med-add-cross {
  flex-shrink: 0;
  width: 38px; height: 38px;
  border-radius: 10px;
  background: linear-gradient(180deg, #2BB673 0%, #16A34A 60%, #117A38 100%);
  border: none;
  display: flex; align-items: center; justify-content: center;
  cursor: pointer;
  box-shadow:
    inset 0 1px 0 rgba(255,255,255,0.35),
    inset 0 -1px 0 rgba(0,0,0,0.18),
    0 4px 12px rgba(22,163,74,0.32);
  transition: transform .15s var(--ease-spring,cubic-bezier(.34,1.56,.64,1)), filter .15s;
}
.med-add-cross:hover { transform: translateY(-1px) scale(1.04); filter: brightness(1.06); }
.med-add-cross:active { transform: translateY(0) scale(0.96); }

/* Bouton remove (croix rouge) — déplacé sur la même ligne au lieu
   du coin abso, pour cohérence. */
.med-remove {
  position: static;
  flex-shrink: 0;
  width: 32px; height: 32px;
  border-radius: 8px;
  background: #fef2f2;
  border: 1px solid #fecaca;
  color: #dc2626;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  font-family: inherit;
  transition: background .15s;
}
.med-remove:hover { background: #fee2e2; }

/* POSO : 4 bulles côte à côte (matin / midi / soir / durée) */
.med-row-poso {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: stretch;
  margin-bottom: 10px;
}

.poso-bubble {
  display: grid;
  grid-template-columns: auto 1fr auto;
  grid-template-rows: auto auto;
  align-items: center;
  gap: 0 6px;
  padding: 8px 12px;
  border-radius: 16px;
  background: #F0FDF4;
  border: 1.5px solid #BBF7D0;
  min-width: 110px;
  flex: 1;
}
.poso-bubble .poso-label {
  grid-column: 1 / -1;
  font-size: 11px; font-weight: 700;
  color: #15803D; text-transform: uppercase; letter-spacing: 0.05em;
  text-align: center;
  margin-bottom: 2px;
}
.poso-bubble .poso-up   { grid-column: 1; grid-row: 2; }
.poso-bubble .poso-qty  { grid-column: 2; grid-row: 2; }
.poso-bubble .poso-down { grid-column: 3; grid-row: 2; }

.poso-step {
  width: 26px; height: 26px;
  border: 1px solid #BBF7D0;
  background: #fff;
  color: #15803D;
  border-radius: 8px;
  font-size: 11px; font-weight: 800;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background .12s, transform .12s;
}
.poso-step:hover { background: #DCFCE7; }
.poso-step:active { transform: scale(0.92); }
.poso-qty {
  width: 100%;
  border: none; outline: none; background: transparent;
  text-align: center;
  font-family: var(--font);
  font-size: 17px; font-weight: 800;
  color: #14532D;
  padding: 4px 0;
}

/* Bloc DURÉE (QSP X jour/semaine/mois) */
.duree-block {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px 8px 14px;
  border-radius: 16px;
  background: #EFF6FF;
  border: 1.5px solid #BFDBFE;
  flex: 1.6;
  min-width: 240px;
}
.duree-prefix {
  font-size: 12px; font-weight: 800;
  color: var(--brand);
  letter-spacing: 0.04em;
}
.duree-qty {
  width: 56px;
  border: 1.5px solid #BFDBFE;
  border-radius: 8px;
  background: #fff;
  text-align: center;
  font-family: var(--font);
  font-size: 17px; font-weight: 800;
  color: var(--gray-800);
  padding: 6px 4px;
  outline: none;
}
.duree-qty:focus { border-color: var(--brand); }

/* Sélecteur pays / base médicamenteuse — placé dans le titre Prescription */
.meds-country-select {
  position: relative;
  margin-left: auto;     /* pousse à droite du titre h3 */
}
.meds-country-btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  background: #fff;
  border: 1.5px solid #DDE3EE;
  padding: 6px 10px;
  border-radius: 10px;
  font-family: var(--font);
  font-size: 12.5px;
  font-weight: 600;
  color: #1F4459;
  cursor: pointer;
  transition: border-color .12s, box-shadow .12s;
}
.meds-country-btn:hover { border-color: #1F4459; }
.meds-country-btn .mc-flag { font-size: 16px; line-height: 1; }
.meds-country-btn svg { opacity: 0.55; margin-left: 2px; }

.meds-country-menu {
  position: absolute;
  top: calc(100% + 4px);
  right: 0;
  min-width: 280px;
  background: #fff;
  border: 1.5px solid #DDE3EE;
  border-radius: 12px;
  box-shadow: 0 12px 32px rgba(31, 68, 89, 0.12);
  padding: 6px;
  z-index: 50;
  display: none;
}
.meds-country-menu[data-open="true"] { display: block; }
.meds-country-menu .mc-item {
  display: flex;
  align-items: center;
  gap: 10px;
  width: 100%;
  padding: 9px 12px;
  background: none;
  border: none;
  border-radius: 8px;
  font-family: var(--font);
  font-size: 13.5px;
  font-weight: 600;
  color: #1F4459;
  text-align: left;
  cursor: pointer;
  transition: background .1s;
}
.meds-country-menu .mc-item:hover { background: #F0F4F8; }
.meds-country-menu .mc-item .mc-flag { font-size: 18px; }
.meds-country-menu .mc-item small {
  margin-left: auto;
  font-weight: 400;
  font-size: 11px;
  color: #6B7280;
  font-style: italic;
}

/* Steppers durée ▲/▼ — même look que les steppers posologie */
.duree-step {
  border: 1.5px solid #BFDBFE;
  background: #fff;
  color: var(--brand);
  width: 28px; height: 28px;
  border-radius: 8px;
  font-size: 14px; font-weight: 700;
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  transition: background .12s, transform .08s;
  padding: 0;
}
.duree-step:hover { background: #DBEAFE; }
.duree-step:active { transform: scale(0.92); }

/* Toggle ALD (pill cliquable, devient orange si coché) */
.ald-toggle {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
  user-select: none;
  flex: 0 0 auto;
}
.ald-toggle input { display: none; }
.ald-pill {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 6px 12px;
  border-radius: 14px;
  background: #F3F4F6;
  color: #6B7280;
  font-size: 12px; font-weight: 700;
  letter-spacing: 0.02em;
  border: 1.5px solid #E5E7EB;
  transition: background .15s, color .15s, border-color .15s;
}
.ald-pill strong { font-weight: 800; }
.ald-toggle input:checked + .ald-pill {
  background: #C76B4A;       /* terracotta = signal ALD */
  color: #fff;
  border-color: #A85332;
  box-shadow: 0 2px 8px rgba(199, 107, 74, 0.25);
}
.ald-toggle:hover .ald-pill { border-color: #C76B4A; color: #A85332; }
.ald-toggle input:checked ~ .ald-pill,
.ald-toggle:hover input:checked + .ald-pill { color: #fff; }

/* Médicament marqué ALD : liseré gauche terracotta sur la row */
.med-row--ald {
  border-left: 3px solid #C76B4A;
  padding-left: 8px;
  background: linear-gradient(90deg, rgba(199,107,74,0.04), transparent 30%);
}

.duree-units {
  display: flex;
  background: #fff;
  border: 1.5px solid #BFDBFE;
  border-radius: 10px;
  padding: 2px;
  gap: 2px;
}
.duree-unit {
  border: none; background: transparent;
  padding: 6px 12px;
  font-family: var(--font);
  font-size: 12.5px; font-weight: 700;
  color: var(--gray-600);
  border-radius: 7px;
  cursor: pointer;
  transition: background .12s, color .12s;
}
.duree-unit:hover { background: #DBEAFE; color: var(--brand); }
.duree-unit.active {
  background: var(--brand); color: #fff;
  box-shadow: inset 0 1px 0 rgba(255,255,255,0.25);
}

/* Instructions (1 ligne sous les bulles) */
.med-row-instr input {
  width: 100%;
  padding: 10px 14px;
  border: 1.5px solid var(--gray-200);
  border-radius: 10px;
  font-size: 14px; font-family: var(--font);
  outline: none;
  background: #fff;
}
.med-row-instr input:focus { border-color: var(--brand); }

/* Le bouton "Ajouter un médicament" hors-ligne (en bas) reste
   utile en backup. On l'allège pour éviter qu'il fasse doublon
   visuel avec les croix vertes inline. */
#btn-add-med { opacity: 0.85; }

/* Responsive : sur mobile, les bulles passent en colonne */
@media (max-width: 720px) {
  .med-row-poso { flex-direction: column; }
  .duree-block { min-width: 0; }
  .duree-units { flex-wrap: wrap; }
}

/* ── Buttons — iOS 26 Liquid Glass ─────────── */
.doc-btn-primary {
  position: relative;
  background: linear-gradient(180deg, var(--brand-mid) 0%, var(--brand) 55%, var(--brand-dark) 100%);
  color: #fff;
  border: none;
  border-radius: 14px;
  padding: 13px 22px;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform var(--t-spring), filter var(--t-damped), box-shadow var(--t-damped);
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,0.55),
    inset 0 -1.5px 0 rgba(0,0,0,0.18),
    0 8px 22px rgba(4, 97, 207, 0.38);
  isolation: isolate;
}
.doc-btn-primary::before {
  content: "";
  position: absolute;
  inset: 0;
  border-radius: inherit;
  background: linear-gradient(180deg, rgba(255,255,255,0.35) 0%, rgba(255,255,255,0) 45%);
  pointer-events: none;
}
.doc-btn-primary:hover {
  filter: brightness(1.06);
  transform: translateY(-1px);
  box-shadow:
    inset 0 1.5px 0 rgba(255,255,255,0.65),
    inset 0 -1.5px 0 rgba(0,0,0,0.18),
    0 12px 28px rgba(4, 97, 207, 0.46);
}
.doc-btn-primary:active { transform: translateY(0) scale(0.98); }

.doc-btn-secondary {
  position: relative;
  background: var(--glass-tint-strong);
  color: var(--brand);
  border: 1px solid var(--gray-200);
  border-radius: 14px;
  padding: 13px 22px;
  font-size: 15px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  transition: transform var(--t-spring), background var(--t-damped), border-color var(--t-damped);
  box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.8);
}
.doc-btn-secondary:hover {
  background: #fff;
  border-color: rgba(4, 97, 207, 0.4);
  transform: translateY(-1px);
}
.doc-btn-ghost {
  background: transparent;
  color: rgba(255,255,255,.85);
  border: 1.5px solid rgba(255,255,255,.25);
  border-radius: 10px;
  padding: 8px 14px;
  font-size: 13px;
  font-weight: 600;
  font-family: var(--font);
  cursor: pointer;
  display: inline-flex;
  align-items: center;
  gap: 6px;
  transition: background .15s;
}
.doc-btn-ghost:hover { background: rgba(255,255,255,.1); }
.doc-btn-full { width: 100%; justify-content: center; }
.doc-btn-add {
  width: 100%;
  padding: 14px;
  background: #f8fafc;
  border: 2px dashed var(--gray-200);
  border-radius: 12px;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font);
  color: var(--brand);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: background .15s, border-color .15s;
}
.doc-btn-add:hover { background: var(--brand-light); border-color: #93c5fd; }

/* ── Actions sidebar ─────────────────────── */
.doc-actions {
  display: flex;
  flex-direction: column;
  gap: 10px;
  margin-bottom: 16px;
}
.doc-actions .doc-btn-ghost {
  color: var(--gray-500);
  border-color: var(--gray-200);
}
.doc-actions .doc-btn-ghost:hover {
  background: #f8fafc;
  color: #0B1120;
}
.doc-privacy-note {
  display: flex;
  align-items: flex-start;
  gap: 8px;
  font-size: 12px;
  color: #16a34a;
  background: #f0fdf4;
  border: 1px solid #bbf7d0;
  border-radius: 10px;
  padding: 12px;
  line-height: 1.5;
}
.doc-privacy-note svg { flex-shrink: 0; margin-top: 1px; }

/* ── Profil médecin ──────────────────────── */
.doc-profile-card {
  margin-bottom: 24px;
}
.doc-profile-card.collapsed .doc-profile-body {
  display: none;
}
.doc-card-title-row {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 4px;
}
.doc-profile-card.collapsed .doc-card-title-row {
  margin-bottom: 0;
}
.doc-btn-toggle {
  background: var(--brand-light);
  color: var(--brand);
  border: 1px solid rgba(4,97,207,.15);
  border-radius: 8px;
  padding: 7px 14px;
  font-size: 13px;
  font-weight: 700;
  font-family: var(--font);
  cursor: pointer;
  transition: background .15s;
}
.doc-btn-toggle:hover { background: #d4e9ff; }
.doc-profile-body {
  padding-top: 14px;
}
.doc-form-3col {
  grid-template-columns: 1fr 1fr 1fr;
}
.doc-field-full {
  grid-column: 1 / -1;
}
.doc-field-span2 {
  grid-column: span 2;
}
.doc-profile-hint {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 12px;
  color: #16a34a;
  margin-top: 18px;
}

/* ── Responsive ──────────────────────────── */
@media (max-width: 900px) {
  .doc-grid { grid-template-columns: 1fr; }
  .doc-sticky { position: static; }
  .doc-header-card { flex-direction: column; align-items: flex-start; }
  .doc-header-right { width: 100%; justify-content: space-between; }
  .med-details { grid-template-columns: 1fr; }
  .doc-form-grid { grid-template-columns: 1fr; }
  .doc-form-3col { grid-template-columns: 1fr; }
  .doc-field-span2 { grid-column: span 1; }
}
@media (max-width: 520px) {
  .doc-login-card { padding: 28px 20px; }
  .doc-input-row { flex-direction: column; }
  .doc-nav-badge { display: none; }
}

/* ════════════════════════════════════════════════════════════════════
   INBOX MÉDECIN — filtre × cartes poker
   ════════════════════════════════════════════════════════════════════ */

/* Compteur global à droite du titre */
.dem-totalbox {
  display: inline-flex;
  align-items: baseline;
  gap: 6px;
  padding: 6px 14px;
  background: linear-gradient(135deg, #0461CF 0%, #0351AE 100%);
  color: #fff;
  border-radius: 999px;
  margin-left: auto;
  font-family: 'Figtree', sans-serif;
}
.dem-total-num { font-size: 18px; font-weight: 800; }
.dem-total-lbl { font-size: 12px; opacity: .85; }

/* Barre de filtres (2 lignes) */
.dem-filters {
  display: flex;
  flex-direction: column;
  gap: 8px;
  margin: 18px 0 20px;
  padding: 14px;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 12px;
}
.dem-filter-group {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
}
.dem-filter {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 8px 14px;
  background: #fff;
  border: 1.5px solid #e2e8f0;
  border-radius: 999px;
  font-size: 13px;
  font-weight: 600;
  color: #475569;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
}
.dem-filter:hover { border-color: #94a3b8; }
.dem-filter.active {
  background: #0461CF;
  color: #fff;
  border-color: #0461CF;
  box-shadow: 0 4px 12px rgba(4,97,207,.25);
}
.dem-filter.active .dem-filter-count { background: rgba(255,255,255,.2); color: #fff; }
.dem-filter-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  display: inline-block;
}
.dem-filter-count {
  display: inline-block;
  min-width: 22px;
  padding: 1px 7px;
  background: #e2e8f0;
  color: #475569;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  text-align: center;
}
.dem-icon { font-size: 14px; }

/* Stack vertical de cartes "poker" */
.dem-stack {
  display: flex;
  flex-direction: column;
  gap: 14px;
  max-height: 70vh;
  overflow-y: auto;
  padding: 4px;
  scroll-behavior: smooth;
  /* scrollbar discrète */
  scrollbar-width: thin;
  scrollbar-color: #cbd5e1 transparent;
}
.dem-stack::-webkit-scrollbar { width: 8px; }
.dem-stack::-webkit-scrollbar-thumb { background: #cbd5e1; border-radius: 4px; }
.dem-stack::-webkit-scrollbar-track { background: transparent; }

/* Carte individuelle façon poker — élargie, ombre profonde, tilt léger au hover */
.dem-card {
  position: relative;
  background: #fff;
  border: 1px solid #e2e8f0;
  border-radius: 16px;
  padding: 18px 20px 16px;
  box-shadow:
    0 1px 2px rgba(11,17,32,.05),
    0 4px 12px rgba(11,17,32,.04);
  transition: transform .2s ease, box-shadow .2s ease, border-color .2s ease;
}
.dem-card:hover {
  transform: translateY(-2px) rotate(-.3deg);
  box-shadow:
    0 4px 8px rgba(11,17,32,.08),
    0 12px 32px rgba(11,17,32,.10);
  border-color: #cbd5e1;
}
.dem-card.collapsed { padding: 12px 18px; }
.dem-card.collapsed .dem-card-body,
.dem-card.collapsed .dem-card-actions { display: none; }
.dem-card.refused { background: linear-gradient(180deg, #fff 0%, #fef2f2 100%); border-color: #fecaca; }
.dem-card.signed { background: linear-gradient(180deg, #fff 0%, #f0fdf4 100%); border-color: #bbf7d0; }
.dem-card.redflag { box-shadow: 0 0 0 2px #ef4444, 0 4px 12px rgba(239,68,68,.18); }

/* Header carte : icône produit + titre + status pill */
.dem-card-header {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 10px;
  margin-bottom: 8px;
}
.dem-card-product {
  font-size: 22px;
  line-height: 1;
  flex-shrink: 0;
}
.dem-card-title {
  flex: 1;
  min-width: 0;
}
.dem-card-acte {
  font-size: 15px;
  font-weight: 700;
  color: #0B1120;
  margin: 0 0 2px;
}
.dem-card-meta {
  font-size: 12px;
  color: #64748b;
  display: flex;
  flex-wrap: wrap;
  gap: 6px 10px;
}
.dem-card-meta strong { color: #334155; font-weight: 600; }

/* Status pill (en haut à droite) — voyant fait/en attente */
.dem-status {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 4px 10px;
  border-radius: 999px;
  font-size: 11px;
  font-weight: 700;
  letter-spacing: .3px;
  text-transform: uppercase;
  flex-shrink: 0;
}
.dem-status-dot {
  width: 7px;
  height: 7px;
  border-radius: 50%;
}
.dem-status.pending { background: #fef3c7; color: #92400e; }
.dem-status.pending .dem-status-dot { background: #f59e0b; box-shadow: 0 0 0 3px rgba(245,158,11,.18); animation: dem-pulse 1.6s infinite; }
.dem-status.signed  { background: #dcfce7; color: #166534; }
.dem-status.signed .dem-status-dot { background: #22c55e; }
.dem-status.refused { background: #fee2e2; color: #991b1b; }
.dem-status.refused .dem-status-dot { background: #ef4444; }
@keyframes dem-pulse {
  0%, 100% { box-shadow: 0 0 0 3px rgba(245,158,11,.18); }
  50%      { box-shadow: 0 0 0 6px rgba(245,158,11,0); }
}

/* Body : aperçu dossier + redflag */
.dem-card-body { margin: 6px 0 12px; }
.dem-card-redflag {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 8px 12px;
  background: #fef2f2;
  border: 1px solid #fca5a5;
  border-radius: 8px;
  margin-bottom: 10px;
  font-size: 12px;
  color: #991b1b;
  font-weight: 700;
}
.dem-dossier-preview {
  max-height: 140px;
  overflow-y: auto;
  background: #f8fafc;
  border: 1px solid #e2e8f0;
  border-radius: 8px;
  padding: 10px 12px;
  font-size: 12px;
  color: #334155;
  line-height: 1.5;
  white-space: pre-wrap;
  font-family: inherit;
}

/* Footer actions */
.dem-card-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-top: 12px;
}
.dem-card-actions .doc-btn-primary,
.dem-card-actions .doc-btn-ghost {
  flex: 1 1 140px;
  padding: 9px 14px;
  font-size: 13px;
}

/* Boutons icône en haut à droite : collapse + delete */
.dem-card-tools {
  position: absolute;
  top: 10px;
  right: 10px;
  display: flex;
  gap: 4px;
  z-index: 2;
}
.dem-tool {
  width: 26px;
  height: 26px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  background: transparent;
  border: 1px solid transparent;
  border-radius: 6px;
  color: #94a3b8;
  cursor: pointer;
  transition: all .15s;
  font-family: inherit;
}
.dem-tool:hover { background: #f1f5f9; color: #475569; border-color: #e2e8f0; }
.dem-tool.dem-tool-delete:hover { background: #fee2e2; color: #dc2626; border-color: #fca5a5; }

/* Empty state */
.dem-empty {
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  padding: 48px 20px;
  background: #f8fafc;
  border: 2px dashed #e2e8f0;
  border-radius: 12px;
  text-align: center;
}
.dem-empty p { margin: 12px 0 0; color: #64748b; font-size: 14px; }

/* Responsive */
@media (max-width: 700px) {
  .dem-filter-group { gap: 4px; }
  .dem-filter { padding: 7px 10px; font-size: 12px; }
  .dem-card { padding: 14px 14px 12px; }
  .dem-card-actions .doc-btn-primary,
  .dem-card-actions .doc-btn-ghost { flex: 1 1 100%; }
}

/* Header de section avec titre + compteur global aligné à droite */
.doc-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 8px;
  flex-wrap: wrap;
}
.doc-section-header h2 {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0;
  font-size: 18px;
  font-weight: 800;
  color: #0B1120;
  letter-spacing: -.3px;
}

/* Bloc droit du header inbox : médecin connecté + total */
.dem-header-right {
  display: flex;
  align-items: center;
  gap: 12px;
  margin-left: auto;
  flex-wrap: wrap;
}
.dem-whoami {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 5px 12px;
  background: #f1f5f9;
  border: 1px solid #cbd5e1;
  border-radius: 999px;
  color: #334155;
  font-size: 12px;
  font-weight: 600;
}
.dem-whoami svg { color: #64748b; }

/* Trace de signature/refus sur les cartes non-pending */
.dem-trace {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  margin-top: 8px;
  padding: 5px 10px;
  background: rgba(255,255,255,.6);
  border: 1px dashed #cbd5e1;
  border-radius: 6px;
  font-size: 11.5px;
  color: #475569;
  font-style: italic;
}
.dem-trace svg { color: #64748b; flex-shrink: 0; }
