/*
 * MTC Praticien — App fullscreen avec sidebar verticale
 *
 * Layout : sidebar fixe à gauche (260px) + main scrollable à droite.
 * Pas de header/footer du thème (template page-mtc-praticien-app.php
 * court-circuite le thème complètement).
 *
 * Mobile : sidebar slide-in via burger, overlay derrière.
 */

:root {
  --mtc-pra-red:        #9B1C1C;
  --mtc-pra-red-dark:   #6E1414;
  --mtc-pra-gold:       #B7882A;
  --mtc-pra-gold-soft:  #DBC07F;
  --mtc-pra-ivory:      #FAFAF7;
  --mtc-pra-paper:      #F5F1EA;
  --mtc-pra-cream:      #FBF7EF;
  --mtc-pra-ink:        #2A2520;
  --mtc-pra-ink-soft:   #4D4842;
  --mtc-pra-ink-mute:   #6B6862;
  --mtc-pra-line:       #E8E4DD;
  --mtc-pra-line-soft:  #F0EBE3;
  --mtc-pra-zh:         #5B2222;
  --mtc-pra-radius:     8px;
  --mtc-pra-radius-lg:  12px;
  --mtc-pra-shadow-sm:  0 1px 3px rgba(42, 37, 32, 0.06);
  --mtc-pra-shadow-md:  0 4px 12px rgba(42, 37, 32, 0.08);
  --mtc-pra-shadow-lg:  0 12px 32px rgba(42, 37, 32, 0.12);
  --mtc-pra-sidebar-w:  260px;
  --mtc-pra-topbar-h:   56px;
}

/* ═══════════════════════════════════════════════════════════════
   1. RESET & BODY (page entière dédiée à l'app)
   ═══════════════════════════════════════════════════════════════ */

body.mtc-pra-app-body {
  margin: 0;
  padding: 0;
  font-family: 'Inter', -apple-system, BlinkMacSystemFont, sans-serif;
  background: var(--mtc-pra-ivory);
  color: var(--mtc-pra-ink);
  -webkit-font-smoothing: antialiased;
  -moz-osx-font-smoothing: grayscale;
  overflow: hidden;
  height: 100vh;
}

body.mtc-pra-app-body * { box-sizing: border-box; }

.mtc-pra-app-shell { height: 100vh; }

/* ═══════════════════════════════════════════════════════════════
   2. LAYOUT PRINCIPAL : sidebar + main
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra--app {
  display: grid;
  grid-template-columns: var(--mtc-pra-sidebar-w) 1fr;
  height: 100vh;
  width: 100vw;
}

.mtc-pra-main-wrap {
  display: flex;
  flex-direction: column;
  min-width: 0;
  height: 100vh;
  overflow: hidden;
}

.mtc-pra-main {
  flex: 1;
  overflow-y: auto;
  padding: 2rem 2.5rem;
  background: var(--mtc-pra-ivory);
}

.mtc-pra-main > * {
  max-width: 1400px;
  margin-left: auto;
  margin-right: auto;
}

/* ═══════════════════════════════════════════════════════════════
   3. SIDEBAR
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-sidebar {
  background: #fff;
  border-right: 1px solid var(--mtc-pra-line);
  display: flex;
  flex-direction: column;
  height: 100vh;
  overflow: hidden;
  position: relative;
  z-index: 50;
}

.mtc-pra-sidebar-brand {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  padding: 1rem 1.25rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  flex-shrink: 0;
  min-height: var(--mtc-pra-topbar-h);
}

.mtc-pra-brand {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
}

.mtc-pra-brand-glyph {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  font-size: 1.75rem;
  color: var(--mtc-pra-red);
  line-height: 1;
}

.mtc-pra-brand-text {
  display: flex;
  flex-direction: column;
  line-height: 1.1;
}

.mtc-pra-brand-text strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 600;
}

.mtc-pra-brand-text small {
  font-size: 0.7rem;
  color: var(--mtc-pra-ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.08em;
  margin-top: 1px;
}

.mtc-pra-sidebar-close {
  display: none;
  background: transparent;
  border: none;
  font-size: 1.25rem;
  cursor: pointer;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  color: var(--mtc-pra-ink-soft);
}

.mtc-pra-sidebar-close:hover {
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-red);
}

.mtc-pra-sidebar-nav {
  flex: 1;
  overflow-y: auto;
  padding: 1rem 0;
  scrollbar-width: thin;
}

.mtc-pra-nav-group { margin-bottom: 1.5rem; }

.mtc-pra-nav-group-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.1em;
  color: var(--mtc-pra-ink-mute);
  padding: 0 1.25rem 0.5rem;
}

.mtc-pra-nav-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
}

.mtc-pra-side-link {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 1.25rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink-soft);
  font-size: 0.9rem;
  font-weight: 500;
  border-left: 3px solid transparent;
  transition: all 0.12s;
}

.mtc-pra-side-link:hover {
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-ink);
}

.mtc-pra-side-link.is-active {
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-red);
  border-left-color: var(--mtc-pra-red);
  font-weight: 600;
}

.mtc-pra-side-glyph {
  font-family: 'Noto Serif SC', serif;
  font-size: 1.15rem;
  width: 22px;
  text-align: center;
  flex-shrink: 0;
  color: var(--mtc-pra-red);
}

.mtc-pra-side-link.is-active .mtc-pra-side-glyph {
  color: var(--mtc-pra-red-dark);
}

.mtc-pra-side-label { flex: 1; min-width: 0; }

.mtc-pra-side-badge {
  background: var(--mtc-pra-gold);
  color: #fff;
  font-size: 0.7rem;
  font-weight: 600;
  padding: 1px 7px;
  border-radius: 999px;
  flex-shrink: 0;
}

.mtc-pra-side-ext {
  color: var(--mtc-pra-ink-mute);
  font-size: 0.8rem;
  flex-shrink: 0;
}

.mtc-pra-side-link.is-external {
  color: var(--mtc-pra-ink-mute);
}

.mtc-pra-sidebar-footer {
  border-top: 1px solid var(--mtc-pra-line);
  padding: 0.85rem 1.25rem;
  background: var(--mtc-pra-paper);
  flex-shrink: 0;
}

.mtc-pra-side-user {
  display: flex;
  align-items: center;
  gap: 0.65rem;
  margin-bottom: 0.65rem;
}

.mtc-pra-side-user-info {
  flex: 1;
  min-width: 0;
  line-height: 1.2;
}

.mtc-pra-side-user-info strong {
  display: block;
  font-size: 0.85rem;
  font-weight: 600;
  color: var(--mtc-pra-ink);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mtc-pra-side-user-info small {
  display: block;
  font-size: 0.7rem;
  color: var(--mtc-pra-ink-mute);
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mtc-pra-side-actions { display: flex; gap: 0.4rem; }

.mtc-pra-side-action {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 32px;
  height: 32px;
  border-radius: 50%;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  color: var(--mtc-pra-ink-soft);
  text-decoration: none !important;
  font-size: 0.85rem;
  transition: all 0.12s;
}

.mtc-pra-side-action:hover {
  background: var(--mtc-pra-red);
  border-color: var(--mtc-pra-red);
  color: #fff;
}

/* ═══════════════════════════════════════════════════════════════
   4. TOP BAR (mobile uniquement)
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-topbar {
  display: none;
  align-items: center;
  gap: 0.75rem;
  padding: 0 1rem;
  height: var(--mtc-pra-topbar-h);
  background: #fff;
  border-bottom: 1px solid var(--mtc-pra-line);
  flex-shrink: 0;
  z-index: 30;
}

.mtc-pra-burger {
  display: inline-flex;
  flex-direction: column;
  justify-content: center;
  gap: 4px;
  background: transparent;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  width: 40px;
  height: 36px;
  cursor: pointer;
  padding: 0 9px;
}

.mtc-pra-burger span {
  display: block;
  height: 2px;
  background: var(--mtc-pra-ink);
  border-radius: 1px;
}

.mtc-pra-topbar-brand {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  flex-shrink: 0;
}

.mtc-pra-topbar-brand strong {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
}

/* ═══════════════════════════════════════════════════════════════
   5. SEARCH
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-search {
  flex: 1;
  min-width: 0;
  position: relative;
}

.mtc-pra-search-input {
  width: 100%;
  padding: 0.45rem 2.25rem 0.45rem 0.85rem;
  font-size: 0.85rem;
  font-family: inherit;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 999px;
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-ink);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.mtc-pra-search-input:focus {
  outline: none;
  background: #fff;
  border-color: var(--mtc-pra-red);
  box-shadow: 0 0 0 3px rgba(155, 28, 28, 0.1);
}

.mtc-pra-search-btn {
  position: absolute;
  right: 4px;
  top: 50%;
  transform: translateY(-50%);
  background: transparent;
  border: none;
  width: 28px;
  height: 28px;
  border-radius: 50%;
  cursor: pointer;
  font-size: 0.9rem;
}

.mtc-pra-search-suggest {
  position: absolute;
  top: calc(100% + 6px);
  left: 0;
  right: 0;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  box-shadow: var(--mtc-pra-shadow-md);
  max-height: 320px;
  overflow-y: auto;
  z-index: 200;
}

.mtc-pra-suggest-item {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  padding: 0.6rem 0.85rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  border-bottom: 1px solid var(--mtc-pra-line);
}

.mtc-pra-suggest-item:last-child { border-bottom: none; }
.mtc-pra-suggest-item:hover,
.mtc-pra-suggest-item.is-active { background: var(--mtc-pra-paper); }

.mtc-pra-suggest-name { flex: 1; min-width: 0; }
.mtc-pra-suggest-name strong { display: block; font-size: 0.85rem; }
.mtc-pra-suggest-name small { color: var(--mtc-pra-ink-mute); font-size: 0.75rem; }

/* ═══════════════════════════════════════════════════════════════
   6. OVERLAY MOBILE
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-overlay {
  display: none;
  position: fixed;
  inset: 0;
  background: rgba(42, 37, 32, 0.5);
  z-index: 40;
  opacity: 0;
  transition: opacity 0.2s;
}

body.mtc-pra-sidebar-open .mtc-pra-overlay {
  display: block;
  opacity: 1;
}

/* ═══════════════════════════════════════════════════════════════
   7. RESPONSIVE
   ═══════════════════════════════════════════════════════════════ */

@media (max-width: 900px) {
  .mtc-pra--app {
    grid-template-columns: 1fr;
  }

  .mtc-pra-sidebar {
    position: fixed;
    top: 0;
    left: 0;
    bottom: 0;
    width: 280px;
    transform: translateX(-100%);
    transition: transform 0.25s cubic-bezier(0.4, 0, 0.2, 1);
    box-shadow: var(--mtc-pra-shadow-lg);
  }

  body.mtc-pra-sidebar-open .mtc-pra-sidebar {
    transform: translateX(0);
  }

  .mtc-pra-sidebar-close { display: inline-flex; }
  .mtc-pra-topbar { display: flex; }
  .mtc-pra-main { padding: 1.25rem 1rem; }
}

/* ═══════════════════════════════════════════════════════════════
   8. TYPOGRAPHIE
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-h1 {
  font-family: 'Cormorant Garamond', Georgia, serif;
  font-size: clamp(1.75rem, 3vw, 2.5rem);
  font-weight: 600;
  line-height: 1.1;
  margin: 0 0 0.25rem;
  color: var(--mtc-pra-ink);
}

.mtc-pra-eyebrow {
  display: block;
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.15em;
  color: var(--mtc-pra-gold);
  margin-bottom: 0.4rem;
}

.mtc-pra-section-zh {
  font-family: 'Noto Serif SC', serif;
  font-size: 0.85rem;
  color: var(--mtc-pra-zh);
  font-weight: 400;
  margin-left: 0.5rem;
}

/* ═══════════════════════════════════════════════════════════════
   9. HOME / STATS
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-greeting { margin: 0 0 1.5rem; }

.mtc-pra-greeting-sub {
  margin: 0;
  color: var(--mtc-pra-ink-mute);
  font-size: 0.9rem;
  text-transform: capitalize;
}

.mtc-pra-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.85rem;
  margin-bottom: 1.5rem;
}

.mtc-pra-stat {
  display: block;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  padding: 1.25rem;
  border-radius: var(--mtc-pra-radius);
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  transition: all 0.15s;
}

.mtc-pra-stat:hover {
  border-color: var(--mtc-pra-red);
  transform: translateY(-1px);
  box-shadow: var(--mtc-pra-shadow-sm);
}

.mtc-pra-stat--warning {
  background: #FFFBEB;
  border-color: var(--mtc-pra-gold);
}

.mtc-pra-stat-num {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 2.25rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
  line-height: 1;
}

.mtc-pra-stat--warning .mtc-pra-stat-num { color: var(--mtc-pra-gold); }

.mtc-pra-stat-label {
  display: block;
  font-size: 0.75rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-ink-mute);
  margin-top: 0.35rem;
}

/* ═══════════════════════════════════════════════════════════════
   10. SECTIONS / CARDS
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-section,
.mtc-pra-card {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  padding: 1.5rem;
  margin-bottom: 1rem;
}

.mtc-pra-card--info {
  background: #FFFBEB;
  border-left: 3px solid var(--mtc-pra-gold);
}

.mtc-pra-card--actions { background: var(--mtc-pra-paper); }

.mtc-pra-section-h {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
  padding-bottom: 0.75rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  flex-wrap: wrap;
}

.mtc-pra-section-h h2,
.mtc-pra-card-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.3rem;
  font-weight: 600;
  margin: 0;
  color: var(--mtc-pra-ink);
}

.mtc-pra-link {
  font-size: 0.85rem;
  color: var(--mtc-pra-red);
  text-decoration: none;
}

.mtc-pra-link:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════════
   11. AGENDA
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-agenda-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mtc-pra-agenda-day {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
  padding: 1rem 0 0.5rem;
  text-transform: capitalize;
  border-top: 1px solid var(--mtc-pra-line);
  margin-top: 0.5rem;
}

.mtc-pra-agenda-day:first-child { border-top: none; padding-top: 0; margin-top: 0; }

.mtc-pra-agenda-item {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.75rem 0;
  border-bottom: 1px solid var(--mtc-pra-line);
}

.mtc-pra-agenda-item:last-child { border-bottom: none; }

.mtc-pra-agenda-time {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.15rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
  flex-shrink: 0;
  width: 60px;
}

.mtc-pra-agenda-body {
  flex: 1;
  min-width: 0;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  display: flex;
  flex-direction: column;
}

.mtc-pra-agenda-body:hover { color: var(--mtc-pra-red); }
.mtc-pra-agenda-name { font-weight: 600; font-size: 0.95rem; }
.mtc-pra-agenda-name small { font-weight: 400; color: var(--mtc-pra-ink-mute); font-size: 0.8rem; }
.mtc-pra-agenda-motif { font-size: 0.85rem; color: var(--mtc-pra-ink-soft); margin-top: 2px; }

/* ═══════════════════════════════════════════════════════════════
   12. PATIENTS LIST
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-patient-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mtc-pra-patient-list--full {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  overflow: hidden;
}

.mtc-pra-patient-row { border-bottom: 1px solid var(--mtc-pra-line); }
.mtc-pra-patient-row:last-child { border-bottom: none; }

.mtc-pra-patient-link {
  display: flex;
  align-items: center;
  gap: 0.85rem;
  padding: 0.85rem 1rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  transition: background 0.1s;
}

.mtc-pra-patient-link:hover { background: var(--mtc-pra-paper); }

.mtc-pra-avatar {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 44px;
  height: 44px;
  border-radius: 50%;
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-red);
  font-family: 'Cormorant Garamond', serif;
  font-weight: 600;
  font-size: 1.1rem;
  flex-shrink: 0;
}

.mtc-pra-avatar--sm { width: 36px; height: 36px; font-size: 0.95rem; }
.mtc-pra-avatar--lg { width: 80px; height: 80px; font-size: 2rem; }

.mtc-pra-patient-info { flex: 1; min-width: 0; }
.mtc-pra-patient-info strong { display: block; font-weight: 600; }
.mtc-pra-patient-info small { display: block; color: var(--mtc-pra-ink-mute); font-size: 0.8rem; margin-top: 2px; }

.mtc-pra-zh-inline {
  font-family: 'Noto Serif SC', serif;
  font-weight: 400;
  color: var(--mtc-pra-zh);
  font-size: 0.95em;
}

.mtc-pra-lang-pill {
  display: inline-block;
  background: var(--mtc-pra-red);
  color: #fff;
  font-family: 'Noto Serif SC', serif;
  font-size: 0.7rem;
  padding: 1px 5px;
  border-radius: 3px;
  vertical-align: middle;
  margin-left: 4px;
}

.mtc-pra-patient-when {
  font-size: 0.75rem;
  color: var(--mtc-pra-ink-mute);
  flex-shrink: 0;
}

.mtc-pra-patient-arrow {
  color: var(--mtc-pra-ink-mute);
  font-size: 1.5rem;
  flex-shrink: 0;
}

/* ═══════════════════════════════════════════════════════════════
   13. PATIENT DETAIL
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-back {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0;
  color: var(--mtc-pra-red);
  font-size: 0.85rem;
  text-decoration: none;
  margin-bottom: 0.5rem;
}

.mtc-pra-back:hover { text-decoration: underline; }

.mtc-pra-patient-header {
  display: flex;
  align-items: center;
  gap: 1rem;
  padding: 1rem 0 1.5rem;
  flex-wrap: wrap;
  border-bottom: 1px solid var(--mtc-pra-line);
  margin-bottom: 1rem;
}

.mtc-pra-patient-identity { flex: 1; min-width: 200px; }

.mtc-pra-patient-sub {
  margin: 0.4rem 0 0;
  color: var(--mtc-pra-ink-mute);
  font-size: 0.9rem;
}

.mtc-pra-patient-sub code {
  background: rgba(155, 28, 28, 0.05);
  color: var(--mtc-pra-red);
  padding: 0.1em 0.5em;
  border-radius: 3px;
  font-size: 0.85em;
}

.mtc-pra-zh-block {
  display: block;
  font-family: 'Noto Serif SC', serif;
  font-size: 1.2rem;
  color: var(--mtc-pra-zh);
  font-weight: 400;
  margin-top: 0.25rem;
}

.mtc-pra-patient-cta { flex-shrink: 0; }

.mtc-pra-patient-stats {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.85rem;
  margin-bottom: 1rem;
}

.mtc-pra-pstat {
  background: var(--mtc-pra-paper);
  padding: 1rem 1.25rem;
  border-radius: var(--mtc-pra-radius);
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  display: block;
}

.mtc-pra-pstat:hover { background: var(--mtc-pra-cream); }

.mtc-pra-pstat--highlight {
  background: linear-gradient(135deg, #FCE9E9, var(--mtc-pra-paper));
  border: 1px solid rgba(155, 28, 28, 0.2);
}

.mtc-pra-pstat-num {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.85rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
  line-height: 1;
}

.mtc-pra-pstat-label {
  display: block;
  font-size: 0.75rem;
  color: var(--mtc-pra-ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
  margin-top: 0.3rem;
}

.mtc-pra-pstat-date {
  display: block;
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.1rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
  margin-top: 0.2rem;
}

/* ═══════════════════════════════════════════════════════════════
   14. DL
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-dl {
  display: grid;
  grid-template-columns: max-content 1fr;
  gap: 0.5rem 1.5rem;
  margin: 0;
}

@media (max-width: 480px) {
  .mtc-pra-dl { grid-template-columns: 1fr; gap: 0.25rem; }
  .mtc-pra-dl dt { margin-top: 0.5rem; }
}

.mtc-pra-dl dt {
  font-size: 0.75rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-ink-mute);
  padding: 0.15rem 0;
}

.mtc-pra-dl dd { margin: 0; padding: 0.15rem 0; }
.mtc-pra-dl a { color: var(--mtc-pra-red); text-decoration: none; }
.mtc-pra-dl a:hover { text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════════
   15. ACTIONS GRID
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-actions-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.5rem;
}

.mtc-pra-action {
  display: flex;
  flex-direction: column;
  align-items: center;
  gap: 0.5rem;
  padding: 1.25rem 0.75rem;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
  text-align: center;
  transition: all 0.15s;
}

.mtc-pra-action:hover {
  border-color: var(--mtc-pra-red);
  transform: translateY(-1px);
  box-shadow: var(--mtc-pra-shadow-sm);
}

.mtc-pra-action-icon {
  font-family: 'Noto Serif SC', serif;
  font-size: 1.65rem;
  color: var(--mtc-pra-red);
}

.mtc-pra-action-label { font-size: 0.8rem; font-weight: 500; }

/* ═══════════════════════════════════════════════════════════════
   16. SÉANCES LIST
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-seance-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.75rem;
}

.mtc-pra-seance-card {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  border-left: 3px solid var(--mtc-pra-gold);
  overflow: hidden;
  transition: box-shadow 0.15s;
}

.mtc-pra-seance-card:hover { box-shadow: var(--mtc-pra-shadow-sm); }

.mtc-pra-seance-card-link {
  display: block;
  padding: 1rem 1.25rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
}

.mtc-pra-seance-card-head {
  display: flex;
  align-items: center;
  gap: 0.75rem;
  flex-wrap: wrap;
  margin-bottom: 0.5rem;
}

.mtc-pra-seance-num {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--mtc-pra-red);
}

.mtc-pra-seance-date { font-size: 0.85rem; color: var(--mtc-pra-ink-mute); }
.mtc-pra-seance-motif,
.mtc-pra-seance-diag { font-size: 0.9rem; margin-top: 0.25rem; color: var(--mtc-pra-ink-soft); }
.mtc-pra-seance-meta { display: flex; gap: 0.75rem; font-size: 0.75rem; color: var(--mtc-pra-ink-mute); margin-top: 0.5rem; }

/* ═══════════════════════════════════════════════════════════════
   17. BADGES
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-badge {
  display: inline-block;
  padding: 2px 8px;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 999px;
  text-transform: uppercase;
  letter-spacing: 0.05em;
}

.mtc-pra-badge--scheduled { background: #FFFBEB; color: #B7882A; border: 1px solid #DBC07F; }
.mtc-pra-badge--ongoing   { background: #DBEAFE; color: #1E40AF; }
.mtc-pra-badge--closed    { background: #DCFCE7; color: #166534; }
.mtc-pra-badge--cancelled { background: #FEE2E2; color: #991B1B; }

/* ═══════════════════════════════════════════════════════════════
   18. TABS / PAGINATION / FILTERS
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-tabs {
  display: flex;
  gap: 0.25rem;
  margin-bottom: 1rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  overflow-x: auto;
}

.mtc-pra-tab {
  padding: 0.6rem 1rem;
  font-size: 0.85rem;
  font-weight: 500;
  color: var(--mtc-pra-ink-mute);
  text-decoration: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
}

.mtc-pra-tab:hover { color: var(--mtc-pra-red); }
.mtc-pra-tab.is-active { color: var(--mtc-pra-red); border-bottom-color: var(--mtc-pra-red); }

.mtc-pra-page-header {
  display: flex;
  align-items: baseline;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.mtc-pra-page-meta { font-size: 0.85rem; color: var(--mtc-pra-ink-mute); }

.mtc-pra-filterbar {
  display: flex;
  gap: 0.5rem;
  align-items: center;
  margin-bottom: 1rem;
  flex-wrap: wrap;
}

.mtc-pra-input {
  padding: 0.5rem 0.85rem;
  font-size: 0.9rem;
  font-family: inherit;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  background: #fff;
  color: var(--mtc-pra-ink);
  flex: 1;
  min-width: 0;
}

.mtc-pra-input:focus {
  outline: none;
  border-color: var(--mtc-pra-red);
  box-shadow: 0 0 0 3px rgba(155, 28, 28, 0.1);
}

.mtc-pra-input--sort { flex: 0 0 auto; min-width: 120px; }

.mtc-pra-pagination {
  display: flex;
  gap: 0.25rem;
  justify-content: center;
  margin-top: 1.5rem;
  flex-wrap: wrap;
}

.mtc-pra-page-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 36px;
  height: 36px;
  padding: 0 0.5rem;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius);
  text-decoration: none;
  color: var(--mtc-pra-ink-soft);
  font-size: 0.85rem;
  font-weight: 500;
  background: #fff;
}

.mtc-pra-page-num.is-active {
  background: var(--mtc-pra-red);
  border-color: var(--mtc-pra-red);
  color: #fff;
}

.mtc-pra-page-num:not(.is-active):hover {
  border-color: var(--mtc-pra-red);
  color: var(--mtc-pra-red);
}

.mtc-pra-result-count {
  margin: 0 0 1rem;
  font-size: 0.9rem;
  color: var(--mtc-pra-ink-mute);
}

/* ═══════════════════════════════════════════════════════════════
   19. BOUTONS
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-btn {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.6rem 1.1rem;
  font-size: 0.85rem;
  font-weight: 600;
  font-family: inherit;
  border-radius: 999px;
  border: 2px solid transparent;
  cursor: pointer;
  text-decoration: none !important;
  transition: all 0.15s;
  line-height: 1.2;
  white-space: nowrap;
}

.mtc-pra-btn--primary {
  background: var(--mtc-pra-red);
  color: #fff;
  border-color: var(--mtc-pra-red);
}

.mtc-pra-btn--primary:hover {
  background: var(--mtc-pra-red-dark);
  border-color: var(--mtc-pra-red-dark);
  color: #fff;
}

.mtc-pra-btn--ghost {
  background: transparent;
  color: var(--mtc-pra-ink);
  border-color: var(--mtc-pra-line);
}

.mtc-pra-btn--ghost:hover {
  border-color: var(--mtc-pra-ink);
  background: var(--mtc-pra-paper);
}

.mtc-pra-btn--small { padding: 0.4rem 0.85rem; font-size: 0.8rem; }

/* ═══════════════════════════════════════════════════════════════
   20. UTILITAIRES
   ═══════════════════════════════════════════════════════════════ */

.mtc-pra-empty {
  text-align: center;
  color: var(--mtc-pra-ink-mute);
  padding: 2.5rem 1rem;
  font-style: italic;
  background: var(--mtc-pra-paper);
  border-radius: var(--mtc-pra-radius);
}

.mtc-pra-error,
.mtc-pra-login-prompt {
  max-width: 540px;
  margin: 4rem auto;
  padding: 2.5rem 2rem;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: var(--mtc-pra-radius-lg);
  text-align: center;
}

.mtc-pra-error {
  background: #FCE9E9;
  border-left: 4px solid var(--mtc-pra-red);
  border-radius: 0 var(--mtc-pra-radius-lg) var(--mtc-pra-radius-lg) 0;
}

.mtc-pra-error h2,
.mtc-pra-login-prompt h2 {
  font-family: 'Cormorant Garamond', serif;
  margin: 0 0 0.5rem;
}

.mtc-pra-last-seance { margin: 0 0 0.75rem; line-height: 1.5; }

/* Scrollbars discrètes */
.mtc-pra-sidebar-nav::-webkit-scrollbar,
.mtc-pra-main::-webkit-scrollbar { width: 8px; }

.mtc-pra-sidebar-nav::-webkit-scrollbar-thumb,
.mtc-pra-main::-webkit-scrollbar-thumb {
  background: var(--mtc-pra-line);
  border-radius: 4px;
}

/* ═══════════════════════════════════════════════════════════════
   21. CONTRASTE RENFORCÉ (override de :root)
   ═══════════════════════════════════════════════════════════════ */
:root {
  --mtc-pra-ink:      #1F1B17;  /* plus foncé */
  --mtc-pra-ink-soft: #3A3530;  /* plus foncé */
  --mtc-pra-ink-mute: #5A5651;  /* plus foncé */
  --mtc-pra-ink-faint: #8A857F; /* nouveau — pour les "—" */
  --mtc-pra-line:     #DDD7CD;  /* plus marqué */
  --mtc-pra-line-strong: #C4BCAE;
  --mtc-pra-paper:    #F2EDE4;  /* plus contrasté avec ivory */
}

/* Sidebar : fond légèrement teinté pour différencier du main */
.mtc-pra-sidebar {
  background: #FBF9F5;
}

.mtc-pra-main {
  background: var(--mtc-pra-ivory);
}

/* ═══════════════════════════════════════════════════════════════
   22. TOGGLE LANGUE (FR/中文 dans sidebar footer)
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-lang-toggle {
  display: flex;
  gap: 0;
  margin-bottom: 0.85rem;
  background: #fff;
  border: 1px solid var(--mtc-pra-line-strong);
  border-radius: 999px;
  padding: 3px;
}

.mtc-pra-lang-btn {
  flex: 1;
  background: transparent;
  border: none;
  padding: 0.4rem 0.85rem;
  font-size: 0.8rem;
  font-weight: 600;
  font-family: inherit;
  color: var(--mtc-pra-ink-mute);
  cursor: pointer;
  border-radius: 999px;
  transition: all 0.15s;
}

.mtc-pra-lang-btn:hover {
  color: var(--mtc-pra-ink);
}

.mtc-pra-lang-btn.is-active {
  background: var(--mtc-pra-red);
  color: #fff;
  box-shadow: 0 1px 3px rgba(155, 28, 28, 0.3);
}

.mtc-pra-lang-btn[lang="zh"] {
  font-family: 'Noto Serif SC', serif;
}

/* ═══════════════════════════════════════════════════════════════
   23. TABLEAU DENSE (patients + référentiels)
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-table-wrap {
  background: #fff;
  border: 1px solid var(--mtc-pra-line-strong);
  border-radius: var(--mtc-pra-radius);
  overflow-x: auto;
  margin-bottom: 1rem;
}

.mtc-pra-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.875rem;
}

.mtc-pra-table thead {
  background: var(--mtc-pra-paper);
  border-bottom: 2px solid var(--mtc-pra-line-strong);
}

.mtc-pra-table th {
  text-align: left;
  padding: 0.7rem 0.85rem;
  font-size: 0.72rem;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--mtc-pra-ink-soft);
  white-space: nowrap;
}

.mtc-pra-table td {
  padding: 0.75rem 0.85rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  vertical-align: middle;
  color: var(--mtc-pra-ink);
}

.mtc-pra-table tbody tr:hover {
  background: var(--mtc-pra-paper);
}

.mtc-pra-table tbody tr:last-child td {
  border-bottom: none;
}

.mtc-pra-col-actions {
  text-align: right;
  white-space: nowrap;
}

/* Patients : cellule patient (avatar + nom) */
.mtc-pra-td-patient {
  min-width: 220px;
}

.mtc-pra-td-name {
  display: flex;
  align-items: center;
  gap: 0.6rem;
  text-decoration: none !important;
  color: var(--mtc-pra-ink);
}

.mtc-pra-td-name:hover { color: var(--mtc-pra-red); }

.mtc-pra-td-name-text {
  display: flex;
  flex-direction: column;
  min-width: 0;
}

.mtc-pra-td-name-text strong {
  font-weight: 600;
  font-size: 0.9rem;
  line-height: 1.2;
}

.mtc-pra-avatar--xs {
  width: 30px;
  height: 30px;
  font-size: 0.78rem;
}

.mtc-pra-code {
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-red);
  padding: 0.15em 0.5em;
  border-radius: 3px;
  font-family: 'SF Mono', Monaco, Consolas, monospace;
  font-size: 0.8rem;
  font-weight: 600;
}

.mtc-pra-tel {
  color: var(--mtc-pra-ink);
  text-decoration: none;
  font-variant-numeric: tabular-nums;
}

.mtc-pra-tel:hover { color: var(--mtc-pra-red); text-decoration: underline; }

/* ═══════════════════════════════════════════════════════════════
   24. BADGES STATUT PATIENT
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-pbadge {
  display: inline-block;
  padding: 3px 9px;
  font-size: 0.7rem;
  font-weight: 600;
  border-radius: 999px;
  white-space: nowrap;
  letter-spacing: 0.02em;
}

.mtc-pra-pbadge--active {
  background: #D7F0DA;
  color: #2C5F33;
  border: 1px solid #A8D9AF;
}

.mtc-pra-pbadge--dormant {
  background: var(--mtc-pra-paper);
  color: var(--mtc-pra-ink-mute);
  border: 1px solid var(--mtc-pra-line-strong);
}

.mtc-pra-pbadge--new {
  background: #FFF4D6;
  color: #8C6B12;
  border: 1px solid #DBC07F;
}

/* ═══════════════════════════════════════════════════════════════
   25. SNIPPETS LIST
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-snippet-list {
  list-style: none;
  margin: 0;
  padding: 0;
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.mtc-pra-snippet-item {
  background: var(--mtc-pra-cream);
  border: 1px solid var(--mtc-pra-line);
  border-left: 3px solid var(--mtc-pra-gold);
  border-radius: var(--mtc-pra-radius);
  padding: 0.85rem 1rem;
}

.mtc-pra-snippet-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.5rem;
  flex-wrap: wrap;
}

.mtc-pra-snippet-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.05rem;
  font-weight: 600;
  color: var(--mtc-pra-ink);
}

.mtc-pra-snippet-content {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  padding: 0.75rem;
  border-radius: 4px;
  font-family: 'SF Mono', Monaco, Consolas, monospace;
  font-size: 0.82rem;
  line-height: 1.5;
  color: var(--mtc-pra-ink);
  white-space: pre-wrap;
  word-wrap: break-word;
  margin: 0;
  max-height: 300px;
  overflow-y: auto;
}

.mtc-pra-snippet-zh {
  margin-top: 0.5rem;
  font-size: 0.85rem;
}

.mtc-pra-snippet-zh summary {
  cursor: pointer;
  color: var(--mtc-pra-zh);
  font-weight: 600;
  padding: 0.3rem 0;
}

.mtc-pra-snippet-zh pre {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  padding: 0.6rem;
  border-radius: 4px;
  font-family: 'Noto Serif SC', serif;
  font-size: 0.85rem;
  white-space: pre-wrap;
  margin-top: 0.4rem;
}

/* ═══════════════════════════════════════════════════════════════
   26. TRANSLATIONS LIST
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-translations-list {
  display: flex;
  flex-direction: column;
  gap: 0.85rem;
}

.mtc-pra-translation-card {
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-left: 3px solid var(--mtc-pra-line-strong);
  border-radius: var(--mtc-pra-radius);
  padding: 1rem 1.25rem;
}

.mtc-pra-translation-card--auto      { border-left-color: var(--mtc-pra-gold); background: #FFFBEF; }
.mtc-pra-translation-card--reviewed  { border-left-color: #4A7C1F; }
.mtc-pra-translation-card--corrected { border-left-color: #1E6CB8; }

.mtc-pra-translation-head {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 0.75rem;
  margin-bottom: 0.85rem;
  font-size: 0.78rem;
  flex-wrap: wrap;
}

.mtc-pra-translation-status {
  font-weight: 600;
  color: var(--mtc-pra-ink-soft);
}

.mtc-pra-translation-entity {
  color: var(--mtc-pra-ink-mute);
}

.mtc-pra-translation-head time {
  color: var(--mtc-pra-ink-mute);
  font-size: 0.72rem;
}

.mtc-pra-translation-body {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 1rem;
  margin-bottom: 0.5rem;
}

@media (max-width: 700px) {
  .mtc-pra-translation-body { grid-template-columns: 1fr; }
}

.mtc-pra-translation-label {
  font-size: 0.7rem;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.06em;
  color: var(--mtc-pra-ink-mute);
  margin-bottom: 0.3rem;
}

.mtc-pra-translation-text {
  font-size: 0.9rem;
  line-height: 1.5;
  color: var(--mtc-pra-ink);
  background: var(--mtc-pra-paper);
  padding: 0.65rem 0.85rem;
  border-radius: 4px;
}

.mtc-pra-translation-actions {
  margin-top: 0.5rem;
  text-align: right;
}

/* ═══════════════════════════════════════════════════════════════
   27. COMING SOON (placeholder)
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-coming-soon {
  text-align: center;
  padding: 4rem 2rem;
  background: #fff;
  border: 2px dashed var(--mtc-pra-line-strong);
  border-radius: var(--mtc-pra-radius-lg);
  margin: 2rem auto;
  max-width: 540px;
}

.mtc-pra-coming-glyph {
  display: block;
  font-family: 'Noto Serif SC', serif;
  font-size: 4rem;
  color: var(--mtc-pra-gold);
  margin-bottom: 1rem;
  opacity: 0.7;
}

.mtc-pra-coming-title {
  font-family: 'Cormorant Garamond', serif;
  font-size: 1.75rem;
  margin: 0 0 1rem;
  color: var(--mtc-pra-ink);
}

.mtc-pra-coming-text {
  color: var(--mtc-pra-ink-soft);
  line-height: 1.6;
  margin: 0 0 1.5rem;
  font-size: 0.95rem;
}

/* ═══════════════════════════════════════════════════════════════
   28. INTERFACE COMPACTÉE (densité + paddings réduits)
   ═══════════════════════════════════════════════════════════════ */

/* Main : padding réduit pour densifier */
.mtc-pra-main {
  padding: 1.25rem 1.5rem;
}

@media (max-width: 900px) {
  .mtc-pra-main { padding: 1rem 0.85rem; }
}

/* Cards et sections : padding réduit */
.mtc-pra-section,
.mtc-pra-card {
  padding: 1.1rem 1.25rem;
  margin-bottom: 0.75rem;
}

/* Stats grid : moins de padding */
.mtc-pra-stat {
  padding: 0.85rem 1rem;
}

.mtc-pra-stat-num {
  font-size: 1.85rem;
}

/* Patient stats compactes */
.mtc-pra-pstat {
  padding: 0.75rem 1rem;
}

.mtc-pra-pstat-num {
  font-size: 1.5rem;
}

/* Sidebar : padding compact */
.mtc-pra-side-link {
  padding: 0.5rem 1.1rem;
  font-size: 0.875rem;
}

.mtc-pra-nav-group {
  margin-bottom: 1rem;
}

.mtc-pra-nav-group-label {
  padding: 0 1.1rem 0.4rem;
  font-size: 0.68rem;
}

/* Page header compact */
.mtc-pra-page-header {
  margin-bottom: 0.75rem;
}

.mtc-pra-h1 {
  font-size: clamp(1.5rem, 2.5vw, 2rem);
}

/* Tableaux plus denses */
.mtc-pra-table th {
  padding: 0.55rem 0.75rem;
  font-size: 0.68rem;
}

.mtc-pra-table td {
  padding: 0.6rem 0.75rem;
  font-size: 0.85rem;
}

/* Filterbar plus compacte */
.mtc-pra-filterbar {
  margin-bottom: 0.75rem;
  gap: 0.4rem;
}

.mtc-pra-input {
  padding: 0.4rem 0.7rem;
  font-size: 0.85rem;
}

/* Boutons plus compacts */
.mtc-pra-btn--small {
  padding: 0.35rem 0.7rem;
  font-size: 0.78rem;
}

.mtc-pra-btn {
  padding: 0.5rem 1rem;
  font-size: 0.82rem;
}

/* Stats grid plus serrée */
.mtc-pra-stats {
  gap: 0.6rem;
  margin-bottom: 1rem;
}

/* Patients récents : items plus serrés */
.mtc-pra-patient-link {
  padding: 0.65rem 0.85rem;
}

/* Sidebar footer plus compact */
.mtc-pra-sidebar-footer {
  padding: 0.7rem 1rem;
}

.mtc-pra-side-user {
  margin-bottom: 0.5rem;
}

/* ═══════════════════════════════════════════════════════════════
   29. LANGUE UI : 3 modes (FR / Bilingue / 中文)
   ═══════════════════════════════════════════════════════════════
   Pattern aligné sur wp-admin (includes/ui-lang.php) :
   - Tous les labels sont rendus avec .mtc-fr-label + .mtc-zh-label
   - body.mtc-lang-bilingual (default) : les deux visibles côte-à-côte
   - body.mtc-lang-fr : cache .mtc-zh-label
   - body.mtc-lang-zh : cache .mtc-fr-label
   =============================================================== */

/* Espacement entre FR et ZH en mode bilingue */
.mtc-fr-label + .mtc-zh-label {
  margin-left: 0.45em;
}

/* Style du label ZH : un peu plus discret en mode bilingue */
.mtc-zh-label {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  color: var(--mtc-pra-zh);
  font-weight: 400;
  font-size: 0.92em;
  opacity: 0.85;
}

/* ─── MODE FR : cacher tous les labels chinois et leur préfixe espace ─── */
body.mtc-lang-fr .mtc-zh-label,
body.mtc-lang-fr .mtc-pra-zh-inline,
body.mtc-lang-fr .mtc-pra-zh-block,
body.mtc-lang-fr .mtc-pra-section-zh,
body.mtc-lang-fr .mtc-pra-zh-only {
  display: none !important;
}

/* ─── MODE ZH : cacher tous les labels français ─── */
body.mtc-lang-zh .mtc-fr-label,
body.mtc-lang-zh .mtc-pra-fr-only {
  display: none !important;
}

/* En mode ZH, supprimer le margin gauche des zh-label puisque le fr est caché */
body.mtc-lang-zh .mtc-zh-label {
  margin-left: 0 !important;
  opacity: 1;
  font-size: inherit;
}

/* Boutons du toggle langue : ne JAMAIS cacher (même en mode FR ou ZH) */
body.mtc-lang-fr .mtc-pra-lang-btn,
body.mtc-lang-zh .mtc-pra-lang-btn {
  display: inline-block !important;
}

body.mtc-lang-fr .mtc-pra-lang-btn .mtc-zh-label,
body.mtc-lang-fr .mtc-pra-lang-btn[lang="zh"],
body.mtc-lang-zh .mtc-pra-lang-btn .mtc-fr-label {
  display: inline !important;  /* dans le toggle, on laisse les labels visibles */
}

/* Le glyph (icône SC) doit rester visible dans tous les modes */
body.mtc-lang-fr .mtc-pra-brand-glyph,
body.mtc-lang-fr .mtc-pra-side-glyph,
body.mtc-lang-fr .mtc-pra-action-icon,
body.mtc-lang-fr .mtc-pra-coming-glyph,
body.mtc-lang-fr .mtc-pra-nav-icon {
  display: inline-flex !important;
}

/* ═══════════════════════════════════════════════════════════════
   30. SCROLLBAR sidebar visible (s'assurer que tout est accessible)
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-sidebar-nav {
  overflow-y: auto;
  scrollbar-width: thin;
  scrollbar-color: var(--mtc-pra-line-strong) transparent;
}

.mtc-pra-sidebar-nav::-webkit-scrollbar {
  width: 6px;
}

.mtc-pra-sidebar-nav::-webkit-scrollbar-thumb {
  background: var(--mtc-pra-line-strong);
  border-radius: 3px;
}

.mtc-pra-sidebar-nav::-webkit-scrollbar-thumb:hover {
  background: var(--mtc-pra-ink-mute);
}

/* ═══════════════════════════════════════════════════════════════
   31. FIX 0.10.4 : Chiffres en lining-nums (pas old-style figures)
   ═══════════════════════════════════════════════════════════════
   La police Cormorant Garamond rend les chiffres en old-style
   (1 ressemble à un I, 0 à un O). On force lining-nums partout
   où on affiche des chiffres dans des stats.
   =============================================================== */
.mtc-pra-pstat-num,
.mtc-pra-stat-num,
.mtc-pra-seance-num,
.mtc-pra-agenda-time,
.mtc-pra-coming-glyph,
.mtc-pra-h1,
.mtc-pra-card-title,
.mtc-pra-page-meta,
.mtc-pra-page-num,
.mtc-pra-table td,
.mtc-pra-stat-label,
.mtc-pra-pstat-label {
  font-variant-numeric: lining-nums tabular-nums;
  font-feature-settings: "lnum" 1, "tnum" 1;
}

/* ═══════════════════════════════════════════════════════════════
   32. FIX 0.10.4 : Toggle langue avec span.mtc-pra-lang-btn-text
   ═══════════════════════════════════════════════════════════════
   Le contenu textuel des boutons toggle utilise un span avec une
   classe spéciale qui empêche le système .mtc-fr-label /
   .mtc-zh-label de cacher quoi que ce soit.
   =============================================================== */

/* Le contenu des boutons toggle reste TOUJOURS intégralement visible */
.mtc-pra-lang-btn-text,
.mtc-pra-lang-btn-text * {
  display: inline !important;
  visibility: visible !important;
  opacity: 1 !important;
  font-size: inherit !important;
  color: inherit !important;
  font-family: inherit !important;
  margin: 0 !important;
}

/* Le span lang="zh" à l'intérieur du bouton bilingue garde sa font SC */
.mtc-pra-lang-btn-text [lang="zh"] {
  font-family: 'Noto Serif SC', 'Songti SC', serif !important;
}

/* Les boutons du toggle restent toujours en flex inline */
.mtc-pra-lang-btn {
  display: inline-block !important;
  flex: 1 1 auto;
  white-space: nowrap;
}

/* ═══════════════════════════════════════════════════════════════
   33. FIX 0.10.4 : .mtc-pra-empty-soft (placeholder pour cards vides)
   ═══════════════════════════════════════════════════════════════ */
.mtc-pra-empty-soft {
  margin: 0;
  padding: 0.5rem 0.25rem 0.25rem;
  color: var(--mtc-pra-ink-mute);
  font-style: italic;
  font-size: 0.9rem;
  text-align: center;
}

/* ═══════════════════════════════════════════════════════════════
   34. v0.10.8 — Onglets séance (.mtc-pra-seance-tabs)
   =============================================================== */
.mtc-pra-seance-tabs {
  display: flex;
  flex-wrap: wrap;
  gap: 0;
  border-bottom: 1px solid var(--mtc-pra-line);
  margin: 1.5rem 0 1.5rem;
  padding: 0;
}

.mtc-pra-seance-tabs .mtc-pra-tab {
  display: inline-flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.7rem 1.1rem;
  text-decoration: none;
  color: var(--mtc-pra-ink-mute);
  border-bottom: 2px solid transparent;
  margin-bottom: -1px;
  font-size: 0.92rem;
  font-weight: 500;
  transition: color 0.15s, border-color 0.15s, background 0.15s;
  border-radius: 4px 4px 0 0;
}

.mtc-pra-seance-tabs .mtc-pra-tab:hover {
  color: var(--mtc-pra-red);
  background: var(--mtc-pra-cream-alt);
}

.mtc-pra-seance-tabs .mtc-pra-tab.is-active {
  color: var(--mtc-pra-red);
  border-bottom-color: var(--mtc-pra-red);
  background: transparent;
  font-weight: 600;
}

.mtc-pra-seance-tabs .mtc-pra-tab-glyph {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  font-size: 1.05rem;
  color: var(--mtc-pra-red);
  opacity: 0.85;
}

.mtc-pra-seance-tabs .mtc-pra-tab.is-active .mtc-pra-tab-glyph {
  opacity: 1;
}

/* ─── Bloc d'examen avec gros idéogramme ─── */
.mtc-pra-examen-block .mtc-pra-card-title {
  display: flex;
  align-items: center;
  gap: 0.6rem;
}

.mtc-pra-examen-glyph {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 2.2rem;
  height: 2.2rem;
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  font-size: 1.4rem;
  color: var(--mtc-pra-red);
  background: var(--mtc-pra-cream-alt);
  border: 1px solid var(--mtc-pra-red-light);
  border-radius: 6px;
}

/* ─── DL spéciale examen (3 colonnes sur desktop) ─── */
.mtc-pra-dl--examen {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 0.4rem 1.5rem;
  align-items: start;
}

@media (max-width: 720px) {
  .mtc-pra-dl--examen {
    grid-template-columns: 1fr;
  }
}

.mtc-pra-dl--examen dt {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-ink-mute);
  font-weight: 500;
  padding-top: 0.4rem;
  border-top: 1px solid var(--mtc-pra-line);
  margin: 0;
}

.mtc-pra-dl--examen dd {
  font-size: 0.95rem;
  margin: 0;
  padding-top: 0.4rem;
  border-top: 1px solid var(--mtc-pra-line);
}

.mtc-pra-dl--examen dt:first-of-type,
.mtc-pra-dl--examen dd:first-of-type,
.mtc-pra-dl--examen dt:nth-of-type(2),
.mtc-pra-dl--examen dd:nth-of-type(2) {
  border-top: none;
  padding-top: 0;
}

/* ═══════════════════════════════════════════════════════════════
   35. v0.10.8 — SIDEBAR COMPACTÉE
   ═══════════════════════════════════════════════════════════════
   Réduction des espacements verticaux entre items, paddings, gap.
   =============================================================== */

/* Ré-écrase les paddings hérités des sections précédentes du CSS.
   Mettre TRÈS spécifique pour battre les règles existantes. */

.mtc-pra-sidebar .mtc-pra-side-link {
  padding: 0.32rem 1rem !important;
  gap: 0.55rem !important;
  font-size: 0.93rem;
  line-height: 1.25;
}

.mtc-pra-sidebar .mtc-pra-side-glyph {
  width: 1.1rem !important;
  font-size: 0.95rem !important;
}

.mtc-pra-sidebar .mtc-pra-nav-group {
  padding: 0 !important;
  margin-bottom: 0.4rem !important;
}

.mtc-pra-sidebar .mtc-pra-nav-group-label {
  padding: 0.5rem 1rem 0.2rem !important;
  margin: 0 !important;
  font-size: 0.7rem;
  letter-spacing: 0.08em;
}

.mtc-pra-sidebar .mtc-pra-nav-group ul,
.mtc-pra-sidebar .mtc-pra-nav-group ol {
  padding: 0 !important;
  margin: 0 !important;
  list-style: none;
}

.mtc-pra-sidebar .mtc-pra-nav-group li {
  margin: 0 !important;
  padding: 0 !important;
}

/* Header de la sidebar (logo + médecine chinoise) */
.mtc-pra-sidebar-brand {
  padding: 0.85rem 1rem 0.75rem !important;
}

.mtc-pra-sidebar-brand strong {
  font-size: 1.05rem !important;
}

.mtc-pra-sidebar-brand small {
  font-size: 0.66rem !important;
  letter-spacing: 0.06em;
}

/* Footer de la sidebar (toggle + admin info) */
.mtc-pra-sidebar-footer {
  padding: 0.6rem 0.8rem !important;
  gap: 0.5rem !important;
}

.mtc-pra-sidebar-footer .mtc-pra-side-user {
  padding: 0.4rem 0.5rem !important;
  font-size: 0.85rem !important;
}

/* Toggle langue : un peu plus compact */
.mtc-pra-lang-toggle {
  padding: 0.18rem !important;
}

.mtc-pra-lang-btn {
  padding: 0.3rem 0.55rem !important;
  font-size: 0.82rem !important;
}

/* Compacter les actions du footer (🏠 ⏻) */
.mtc-pra-side-actions {
  gap: 0.3rem !important;
  padding: 0.3rem 0 !important;
}

.mtc-pra-side-action {
  width: 1.8rem !important;
  height: 1.8rem !important;
  font-size: 0.95rem !important;
}

/* ═══════════════════════════════════════════════════════════════
   36. v0.10.9 — VUES COMPACTÉES + FORMS + SIDEBAR FOOTER VISIBLE
   =============================================================== */

/* ─── Cards plus compactes (vue principale) ─── */
.mtc-pra-card {
  padding: 0.85rem 1.1rem !important;
  margin-bottom: 0.8rem !important;
}

.mtc-pra-card-title {
  font-size: 1.05rem !important;
  margin: 0 0 0.55rem 0 !important;
  padding-bottom: 0.4rem !important;
}

/* ─── DL plus compactes ─── */
.mtc-pra-dl {
  margin: 0 !important;
  display: grid;
  grid-template-columns: minmax(8rem, max-content) 1fr;
  gap: 0.3rem 0.9rem !important;
  align-items: baseline;
}

.mtc-pra-dl dt {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0.78rem !important;
}

.mtc-pra-dl dd {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 0.93rem !important;
}

/* Page header espace réduit */
.mtc-pra-page-header,
.mtc-pra-patient-header {
  margin-bottom: 0.7rem !important;
  padding-bottom: 0.6rem !important;
  gap: 0.5rem !important;
}

/* Body main : padding réduit */
.mtc-pra-main {
  padding: 1rem 1.2rem !important;
}

/* H1 légèrement plus petit */
.mtc-pra-h1 {
  font-size: 1.7rem !important;
  margin: 0 0 0.2rem 0 !important;
}

/* ═══ SIDEBAR : footer toujours visible ═══ */
.mtc-pra-sidebar {
  display: flex !important;
  flex-direction: column !important;
  height: 100vh !important;
  position: sticky !important;
  top: 0 !important;
  overflow: hidden !important; /* le scroll est sur la zone milieu uniquement */
}

.mtc-pra-sidebar-brand {
  flex: 0 0 auto !important;
}

/* Zone du milieu : nav scrollable */
.mtc-pra-sidebar-nav,
.mtc-pra-sidebar > nav {
  flex: 1 1 auto !important;
  overflow-y: auto !important;
  min-height: 0 !important;  /* indispensable en flex pour que overflow marche */
}

/* Footer : reste collé en bas, toujours visible */
.mtc-pra-sidebar-footer {
  flex: 0 0 auto !important;
  border-top: 1px solid var(--mtc-pra-line);
  background: var(--mtc-pra-cream-alt);
  padding: 0.45rem 0.7rem !important;
  gap: 0.35rem !important;
  display: flex !important;
  flex-direction: column !important;
}

.mtc-pra-sidebar-footer .mtc-pra-side-user {
  padding: 0.3rem 0.5rem !important;
  font-size: 0.82rem !important;
  line-height: 1.2;
}

.mtc-pra-sidebar-footer .mtc-pra-side-user small {
  font-size: 0.72rem;
}

/* Toggle langue : encore plus compact */
.mtc-pra-lang-toggle {
  padding: 0.15rem !important;
  border-radius: 14px !important;
}

.mtc-pra-lang-btn {
  padding: 0.25rem 0.55rem !important;
  font-size: 0.78rem !important;
  border-radius: 11px !important;
}

/* Actions footer (🏠 ⏻) */
.mtc-pra-side-actions {
  gap: 0.25rem !important;
  padding: 0.2rem 0 !important;
  justify-content: flex-end;
}

.mtc-pra-side-action {
  width: 1.7rem !important;
  height: 1.7rem !important;
  font-size: 0.9rem !important;
  border-radius: 4px !important;
}

/* ═══ FORMS dans la vue séance ═══ */
.mtc-pra-seance-form {
  margin-top: 0.4rem;
}

.mtc-pra-form-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(160px, 1fr));
  gap: 0.6rem 0.9rem;
}

.mtc-pra-field {
  display: flex;
  flex-direction: column;
  gap: 0.25rem;
  margin-bottom: 0.65rem;
}

.mtc-pra-field-label {
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--mtc-pra-ink-mute);
  font-weight: 500;
}

.mtc-pra-field input[type="text"],
.mtc-pra-field input[type="datetime-local"],
.mtc-pra-field input[type="email"],
.mtc-pra-field input[type="tel"],
.mtc-pra-field select,
.mtc-pra-field textarea,
.mtc-pra-seance-form input[type="text"],
.mtc-pra-seance-form input[type="datetime-local"],
.mtc-pra-seance-form select,
.mtc-pra-seance-form textarea {
  width: 100%;
  padding: 0.45rem 0.6rem;
  font: inherit;
  font-size: 0.94rem;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 4px;
  color: var(--mtc-pra-ink);
  transition: border-color 0.15s, box-shadow 0.15s;
}

.mtc-pra-field input:focus,
.mtc-pra-field select:focus,
.mtc-pra-field textarea:focus,
.mtc-pra-seance-form input:focus,
.mtc-pra-seance-form select:focus,
.mtc-pra-seance-form textarea:focus {
  outline: none;
  border-color: var(--mtc-pra-red);
  box-shadow: 0 0 0 2px var(--mtc-pra-red-light);
}

.mtc-pra-field textarea,
.mtc-pra-seance-form textarea {
  resize: vertical;
  min-height: 4rem;
  font-family: inherit;
}

.mtc-pra-field input:disabled,
.mtc-pra-field select:disabled,
.mtc-pra-field textarea:disabled {
  background: var(--mtc-pra-cream-alt);
  color: var(--mtc-pra-ink-mute);
  cursor: not-allowed;
}

/* Bouton submit form */
.mtc-pra-form-submit {
  padding: 0.9rem 0;
  text-align: right;
  position: sticky;
  bottom: 0;
  background: linear-gradient(to bottom, transparent, var(--mtc-pra-cream) 30%);
  margin-top: 1rem;
}

/* Notice success / error */
.mtc-pra-notice {
  padding: 0.7rem 1rem;
  border-radius: 4px;
  margin: 0 0 0.8rem 0;
  font-size: 0.95rem;
  border: 1px solid;
}

.mtc-pra-notice--success {
  background: #f0f9eb;
  border-color: #a7c98e;
  color: #3d7a1a;
}

.mtc-pra-notice--error {
  background: #fdf2f2;
  border-color: #e58f8f;
  color: #b03030;
}

/* ═══════════════════════════════════════════════════════════════
   37. v0.10.10 — CONTRASTE ↑ + VUES RESSERRÉES + COMPOSANTS SYNDROME
   =============================================================== */

/* ─── Contraste : tons de gris plus francs ─── */
:root {
  --mtc-pra-ink-mute: #545454 !important;     /* avant : pâle */
  --mtc-pra-ink-soft: #757575 !important;
  --mtc-pra-line: #d4cdb5 !important;          /* lignes plus visibles */
  --mtc-pra-cream-alt: #f0e9d3 !important;     /* contraste vs cream */
}

/* ─── Cards encore + serrées (3e itération) ─── */
.mtc-pra-card {
  padding: 0.65rem 0.9rem !important;
  margin-bottom: 0.55rem !important;
  border: 1px solid var(--mtc-pra-line) !important;
}

.mtc-pra-card-title {
  font-size: 1rem !important;
  margin: 0 0 0.45rem 0 !important;
  padding-bottom: 0.3rem !important;
  font-weight: 600;
  color: var(--mtc-pra-ink) !important;
  border-bottom: 1px solid var(--mtc-pra-line);
}

/* ─── DL plus serrées + alignement rigoureux ─── */
.mtc-pra-dl {
  gap: 0.25rem 0.7rem !important;
}

.mtc-pra-dl dt {
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  color: var(--mtc-pra-ink-mute) !important;
  letter-spacing: 0.04em;
}

.mtc-pra-dl dd {
  font-size: 0.92rem !important;
  color: var(--mtc-pra-ink) !important;
}

/* ─── Headers de page resserrés ─── */
.mtc-pra-page-header,
.mtc-pra-patient-header {
  margin-bottom: 0.5rem !important;
  padding-bottom: 0.4rem !important;
  gap: 0.4rem !important;
}

.mtc-pra-h1 {
  font-size: 1.55rem !important;
  margin: 0 0 0.15rem 0 !important;
}

.mtc-pra-back {
  font-size: 0.88rem;
  margin-bottom: 0.3rem !important;
  display: inline-block;
}

.mtc-pra-main {
  padding: 0.8rem 1rem !important;
}

/* ─── Field labels plus contrasted ─── */
.mtc-pra-field-label {
  font-size: 0.74rem !important;
  font-weight: 600 !important;
  color: var(--mtc-pra-ink-mute) !important;
  letter-spacing: 0.04em !important;
  text-transform: uppercase;
}

.mtc-pra-field {
  margin-bottom: 0.5rem !important;
  gap: 0.2rem !important;
}

/* Form grid : items plus serrés */
.mtc-pra-form-grid {
  gap: 0.45rem 0.75rem !important;
}

/* Sub-section title (Pouls / Abdomen dans palpation) */
.mtc-pra-subsection-title {
  font-size: 0.85rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-red);
  font-weight: 600;
  margin: 0.7rem 0 0.4rem;
  padding-bottom: 0.2rem;
  border-bottom: 1px dashed var(--mtc-pra-line);
}

/* Tab content padding */
.mtc-pra-tab-content {
  padding: 0;
}

/* Tabs : un peu plus compactes */
.mtc-pra-seance-tabs .mtc-pra-tab {
  padding: 0.55rem 0.85rem !important;
  font-size: 0.88rem !important;
}

/* ═══ COMPOSANTS DE L'ONGLET SYNDROME ═══ */

/* Section num (A, B, C) */
.mtc-pra-section-num {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 1.5rem;
  height: 1.5rem;
  border-radius: 50%;
  background: var(--mtc-pra-red);
  color: #fff;
  font-size: 0.78rem;
  font-weight: 700;
  margin-right: 0.4rem;
  line-height: 1;
}

.mtc-pra-help-text {
  margin: 0 0 0.6rem 0;
  padding: 0.5rem 0.7rem;
  background: var(--mtc-pra-cream-alt);
  border-left: 3px solid var(--mtc-pra-red);
  font-size: 0.85rem;
  color: var(--mtc-pra-ink-mute);
  border-radius: 2px;
}

/* 8 principes : ligne par paire */
.mtc-pra-principe-row {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 0.8rem;
  padding: 0.5rem 0;
  border-top: 1px solid var(--mtc-pra-line);
}

.mtc-pra-principe-row:first-of-type {
  border-top: none;
}

.mtc-pra-principe-row > strong {
  flex: 0 0 auto;
  min-width: 11rem;
  font-size: 0.92rem;
  color: var(--mtc-pra-ink);
}

.mtc-pra-radio-group {
  display: flex;
  gap: 0.6rem;
  flex-wrap: wrap;
  flex: 1 1 auto;
}

.mtc-pra-radio-label {
  display: inline-flex;
  align-items: center;
  gap: 0.3rem;
  padding: 0.25rem 0.6rem;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 14px;
  background: #fff;
  font-size: 0.85rem;
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}

.mtc-pra-radio-label:has(input:checked) {
  background: var(--mtc-pra-red-light);
  border-color: var(--mtc-pra-red);
  color: var(--mtc-pra-red);
  font-weight: 600;
}

.mtc-pra-radio-label input[type="radio"] {
  margin: 0;
}

/* Zangfu : details par organe */
.mtc-pra-zangfu-row {
  border-top: 1px solid var(--mtc-pra-line);
  padding: 0.4rem 0;
}

.mtc-pra-zangfu-row:first-of-type {
  border-top: none;
}

.mtc-pra-zangfu-row > summary {
  cursor: pointer;
  display: flex;
  align-items: center;
  gap: 0.5rem;
  font-size: 0.9rem;
  padding: 0.25rem 0;
  list-style: none;
  user-select: none;
}

.mtc-pra-zangfu-row > summary::-webkit-details-marker {
  display: none;
}

.mtc-pra-zangfu-row > summary::before {
  content: '▸';
  font-size: 0.7rem;
  color: var(--mtc-pra-red);
  transition: transform 0.15s;
}

.mtc-pra-zangfu-row[open] > summary::before {
  transform: rotate(90deg);
}

.mtc-pra-zangfu-row > summary > strong {
  color: var(--mtc-pra-ink);
}

.mtc-pra-zangfu-row > summary > small {
  color: var(--mtc-pra-ink-mute);
  font-size: 0.78rem;
}

.mtc-pra-pattern-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(180px, 1fr));
  gap: 0.3rem 0.5rem;
  padding: 0.4rem 0 0.5rem 1.2rem;
}

.mtc-pra-pattern-label {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  font-size: 0.85rem;
  cursor: pointer;
  padding: 0.2rem 0;
}

.mtc-pra-pattern-label:has(input:checked) {
  color: var(--mtc-pra-red);
  font-weight: 500;
}

/* Notes details */
.mtc-pra-notes-details {
  margin-top: 0.5rem;
  border-top: 1px dashed var(--mtc-pra-line);
  padding-top: 0.3rem;
}

.mtc-pra-notes-details > summary {
  cursor: pointer;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-ink-mute);
  padding: 0.2rem 0;
  user-select: none;
}

/* Tech edit */
.mtc-pra-tech-edit {
  border-top: 1px solid var(--mtc-pra-line);
  padding-top: 0.5rem;
  margin-top: 0.5rem;
}

.mtc-pra-tech-edit:first-of-type {
  border-top: none;
  padding-top: 0;
  margin-top: 0;
}

/* Selects/inputs : padding réduit */
.mtc-pra-field input[type="text"],
.mtc-pra-field input[type="datetime-local"],
.mtc-pra-field input[type="number"],
.mtc-pra-field select,
.mtc-pra-field textarea,
.mtc-pra-seance-form input[type="text"],
.mtc-pra-seance-form input[type="datetime-local"],
.mtc-pra-seance-form input[type="number"],
.mtc-pra-seance-form select,
.mtc-pra-seance-form textarea {
  padding: 0.35rem 0.55rem !important;
  font-size: 0.92rem !important;
}

/* Sidebar nav links contrastés */
.mtc-pra-sidebar .mtc-pra-side-link {
  color: var(--mtc-pra-ink) !important;
}

.mtc-pra-sidebar .mtc-pra-side-link:hover {
  background: var(--mtc-pra-cream-alt);
  color: var(--mtc-pra-red) !important;
}

.mtc-pra-sidebar .mtc-pra-side-link.is-active {
  background: var(--mtc-pra-red-light);
  color: var(--mtc-pra-red) !important;
  font-weight: 600;
}

/* ═══════════════════════════════════════════════════════════════
   38. v0.10.11 — OVERRIDE FINAL AGRESSIF
   ═══════════════════════════════════════════════════════════════
   Surcharge TOUS les composants avec spécificité élevée et !important
   pour battre les règles précédentes. Compacte + augmente le contraste.
   =============================================================== */

/* ─── Variables de couleurs : contraste boosté ─── */
:root,
body {
  --mtc-pra-ink:        #1a1a1a !important;     /* texte principal noir */
  --mtc-pra-ink-mute:   #3a3a3a !important;     /* mute fortement contrasté */
  --mtc-pra-ink-soft:   #5a5a5a !important;
  --mtc-pra-line:       #c8b896 !important;     /* lignes plus marquées */
  --mtc-pra-cream-alt:  #ebe1c5 !important;     /* contraste vs cream */
  --mtc-pra-paper:      #fff !important;
}

/* ─── Stats cards (séances / ordonnances) ─── */
.mtc-pra-patient-stats .mtc-pra-pstat,
section.mtc-pra-patient-stats .mtc-pra-pstat,
a.mtc-pra-pstat {
  padding: 0.55rem 0.85rem !important;
  border-radius: 4px !important;
  background: #fff !important;
  border: 1px solid var(--mtc-pra-line) !important;
}

.mtc-pra-pstat-num,
a.mtc-pra-pstat .mtc-pra-pstat-num,
.mtc-pra-pstat .mtc-pra-pstat-num {
  font-size: 1.5rem !important;
  font-weight: 700 !important;
  color: #7a1414 !important;             /* rouge encore plus profond */
  line-height: 1.05 !important;
}

.mtc-pra-pstat-label,
a.mtc-pra-pstat .mtc-pra-pstat-label {
  font-size: 0.7rem !important;
  margin-top: 0.1rem !important;
  color: var(--mtc-pra-ink) !important;
  font-weight: 600 !important;
  letter-spacing: 0.05em !important;
}

/* ─── Action cards (boutons d'action) ─── */
.mtc-pra-actions-grid {
  gap: 0.4rem !important;
}

.mtc-pra-action,
a.mtc-pra-action {
  padding: 0.6rem 0.5rem !important;
  gap: 0.2rem !important;
  border: 1px solid var(--mtc-pra-line) !important;
  border-radius: 4px !important;
}

.mtc-pra-action-icon,
.mtc-pra-action .mtc-pra-action-icon,
a.mtc-pra-action .mtc-pra-action-icon {
  font-size: 1.15rem !important;
  color: var(--mtc-pra-red) !important;
}

.mtc-pra-action-label,
.mtc-pra-action .mtc-pra-action-label,
a.mtc-pra-action .mtc-pra-action-label {
  font-size: 0.75rem !important;
  font-weight: 500 !important;
  color: var(--mtc-pra-ink) !important;
}

/* ─── Cards génériques ─── */
section.mtc-pra-card,
.mtc-pra-card {
  padding: 0.6rem 0.85rem !important;
  margin-bottom: 0.5rem !important;
  background: #fff !important;
  border: 1px solid var(--mtc-pra-line) !important;
  border-radius: 4px !important;
}

section.mtc-pra-card .mtc-pra-card-title,
.mtc-pra-card .mtc-pra-card-title,
.mtc-pra-card-title {
  font-size: 0.95rem !important;
  margin: 0 0 0.4rem 0 !important;
  padding-bottom: 0.3rem !important;
  font-weight: 700 !important;
  color: var(--mtc-pra-ink) !important;
  border-bottom: 1px solid var(--mtc-pra-line) !important;
}

/* ─── Header patient (avatar, nom, code) ─── */
.mtc-pra-patient-header {
  margin-bottom: 0.45rem !important;
  padding-bottom: 0.35rem !important;
  gap: 0.4rem !important;
  border-bottom: 1px solid var(--mtc-pra-line) !important;
}

.mtc-pra-patient-avatar {
  width: 2.5rem !important;
  height: 2.5rem !important;
  font-size: 0.85rem !important;
}

.mtc-pra-h1 {
  font-size: 1.45rem !important;
  margin: 0 !important;
  line-height: 1.15 !important;
  color: var(--mtc-pra-ink) !important;
}

.mtc-pra-patient-meta {
  font-size: 0.85rem !important;
  margin-top: 0.1rem !important;
  color: var(--mtc-pra-ink) !important;
}

.mtc-pra-pcode {
  font-size: 0.78rem !important;
  padding: 0.1rem 0.35rem !important;
  background: var(--mtc-pra-cream-alt) !important;
  color: var(--mtc-pra-ink) !important;
  border-radius: 3px !important;
}

/* ─── Back link ─── */
.mtc-pra-back {
  font-size: 0.85rem !important;
  margin-bottom: 0.25rem !important;
  display: inline-block !important;
  color: var(--mtc-pra-red) !important;
  font-weight: 500 !important;
}

/* ─── Main padding réduit ─── */
.mtc-pra-main,
main.mtc-pra-main {
  padding: 0.7rem 0.95rem !important;
}

/* ─── Empty soft (message "Aucune coordonnée") ─── */
.mtc-pra-empty-soft {
  padding: 0.3rem !important;
  margin: 0 !important;
  font-size: 0.85rem !important;
  color: var(--mtc-pra-ink-mute) !important;
}

/* ─── DL : compacte sans rien rogner ─── */
.mtc-pra-card .mtc-pra-dl {
  gap: 0.25rem 0.7rem !important;
  margin: 0 !important;
}

.mtc-pra-card .mtc-pra-dl dt {
  font-size: 0.72rem !important;
  padding: 0 !important;
  font-weight: 600 !important;
  color: var(--mtc-pra-ink-mute) !important;
}

.mtc-pra-card .mtc-pra-dl dd {
  font-size: 0.9rem !important;
  padding: 0 !important;
  margin: 0 !important;
  color: var(--mtc-pra-ink) !important;
}

/* ─── Onglets séance ─── */
.mtc-pra-seance-tabs {
  margin: 0.55rem 0 0.55rem !important;
}

.mtc-pra-seance-tabs .mtc-pra-tab {
  padding: 0.45rem 0.75rem !important;
  font-size: 0.85rem !important;
}

/* ─── Form fields plus serrés ─── */
.mtc-pra-seance-form .mtc-pra-field,
.mtc-pra-seance-form label.mtc-pra-field {
  margin-bottom: 0.45rem !important;
  gap: 0.18rem !important;
}

.mtc-pra-seance-form input[type="text"],
.mtc-pra-seance-form input[type="datetime-local"],
.mtc-pra-seance-form input[type="number"],
.mtc-pra-seance-form select,
.mtc-pra-seance-form textarea {
  padding: 0.32rem 0.5rem !important;
  font-size: 0.9rem !important;
  background: #fff !important;
  color: var(--mtc-pra-ink) !important;
  border: 1px solid var(--mtc-pra-line) !important;
}

.mtc-pra-field-label {
  font-size: 0.7rem !important;
  font-weight: 700 !important;
  color: var(--mtc-pra-ink-mute) !important;
}

/* ─── Body fond plus contrasted ─── */
.mtc-pra-app,
body.mtc-pra-body,
.mtc-pra-body {
  background: var(--mtc-pra-cream) !important;
}

/* ─── Liens d'action sont vraiment sombres ─── */
.mtc-pra-action,
a.mtc-pra-action,
.mtc-pra-pstat,
a.mtc-pra-pstat {
  color: var(--mtc-pra-ink) !important;
}

/* ─── Notice success/error compactes ─── */
.mtc-pra-notice {
  padding: 0.45rem 0.7rem !important;
  margin-bottom: 0.55rem !important;
  font-size: 0.88rem !important;
}

/* ═══════════════════════════════════════════════════════════════
   39. v0.10.12 — RDV (agenda) + ordonnance lignes + tweaks
   =============================================================== */

.mtc-pra-rdv-list {
  list-style: none;
  margin: 0;
  padding: 0;
}

.mtc-pra-rdv-item {
  display: grid;
  grid-template-columns: 7.5rem 1fr auto;
  gap: 0.5rem;
  align-items: center;
  padding: 0.4rem 0;
  border-top: 1px solid var(--mtc-pra-line);
  font-size: 0.92rem;
}

.mtc-pra-rdv-item:first-child {
  border-top: none;
}

.mtc-pra-rdv-item time {
  font-family: 'Cormorant Garamond', serif;
  color: var(--mtc-pra-red);
  font-weight: 600;
  font-variant-numeric: lining-nums tabular-nums;
}

.mtc-pra-rdv-item small {
  font-size: 0.78rem;
  color: var(--mtc-pra-ink-mute);
  text-transform: uppercase;
  letter-spacing: 0.04em;
}

.mtc-pra-rdv-item--past {
  opacity: 0.7;
}

.mtc-pra-rdv-notes {
  grid-column: 1 / -1;
  margin: 0.2rem 0 0 7.5rem;
  font-size: 0.85rem;
  color: var(--mtc-pra-ink-mute);
  font-style: italic;
}

@media (max-width: 600px) {
  .mtc-pra-rdv-item {
    grid-template-columns: 1fr;
    gap: 0.15rem;
  }
  .mtc-pra-rdv-notes {
    margin-left: 0;
  }
}

/* Table lignes ordonnance */
.mtc-pra-ordo-lignes {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.mtc-pra-ordo-lignes th {
  text-align: left;
  padding: 0.3rem 0.4rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  font-size: 0.78rem;
  text-transform: uppercase;
  color: var(--mtc-pra-ink-mute);
}

.mtc-pra-ordo-lignes td {
  padding: 0.2rem;
  border-bottom: 1px solid var(--mtc-pra-line);
}

.mtc-pra-ordo-lignes input {
  width: 100%;
  padding: 0.25rem 0.4rem !important;
  border: 1px solid transparent !important;
  background: transparent !important;
  font-size: 0.9rem !important;
}

.mtc-pra-ordo-lignes input:focus {
  background: #fff !important;
  border-color: var(--mtc-pra-red) !important;
}

.mtc-pra-ordo-lignes td:nth-child(3) input {
  text-align: right;
  max-width: 80px;
}

/* ═══════════════════════════════════════════════════════════════
   40. v0.10.16 — Autocomplete dropdown herbes
   =============================================================== */

/* Le td doit être relative pour que le dropdown absolute se positionne dedans */
.mtc-pra-ordo-lignes tbody td {
  position: relative;
}

/* Dropdown */
.mtc-pra-ac-dropdown {
  list-style: none;
  margin: 0;
  padding: 0.25rem 0;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-top: 2px solid var(--mtc-pra-red);
  border-radius: 0 0 4px 4px;
  box-shadow: 0 6px 18px rgba(0, 0, 0, 0.12);
  max-height: 320px;
  overflow-y: auto;
  font-size: 0.88rem;
}

.mtc-pra-ac-dropdown--empty {
  padding: 0.5rem 0.75rem;
  font-style: italic;
  color: var(--mtc-pra-ink-mute);
  text-align: center;
}

.mtc-pra-ac-item {
  padding: 0.4rem 0.75rem;
  cursor: pointer;
  border-top: 1px solid var(--mtc-pra-cream-alt);
  line-height: 1.35;
  color: var(--mtc-pra-ink);
}

.mtc-pra-ac-item:first-child {
  border-top: none;
}

.mtc-pra-ac-item:hover,
.mtc-pra-ac-item.is-active {
  background: var(--mtc-pra-cream-alt);
  color: var(--mtc-pra-red);
}

.mtc-pra-ac-item strong {
  font-weight: 700;
  color: var(--mtc-pra-red);
}

.mtc-pra-ac-item .mtc-pra-ac-zh {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  font-size: 1rem;
  margin-left: 0.4rem;
  color: var(--mtc-pra-ink);
}

.mtc-pra-ac-item em {
  font-style: italic;
  color: var(--mtc-pra-ink-mute);
  margin-left: 0.4rem;
  font-size: 0.85rem;
}

.mtc-pra-ac-item small {
  color: var(--mtc-pra-ink-mute);
  font-size: 0.78rem;
  margin-left: 0.3rem;
}

.mtc-pra-ac-item .mtc-pra-ac-fr {
  display: inline-block;
  margin-top: 0.15rem;
  font-size: 0.82rem;
  color: var(--mtc-pra-ink-mute);
  font-style: italic;
}

/* Quand un item est focus/active, garder la couleur des sous-éléments */
.mtc-pra-ac-item.is-active strong,
.mtc-pra-ac-item:hover strong {
  color: var(--mtc-pra-red);
}

/* ═══════════════════════════════════════════════════════════════
   41. v0.10.18 — Référentiels MTC : table + pagination
   =============================================================== */

.mtc-pra-refs-table-card {
  padding: 0.7rem 0.5rem !important;
}

.mtc-pra-refs-meta {
  margin: 0 0 0.5rem 0;
  font-size: 0.82rem;
  color: var(--mtc-pra-ink-mute);
  padding: 0 0.4rem;
}

.mtc-pra-refs-tablewrap {
  overflow-x: auto;
}

.mtc-pra-refs-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 0.9rem;
}

.mtc-pra-refs-table thead {
  background: var(--mtc-pra-cream-alt);
}

.mtc-pra-refs-table th {
  text-align: left;
  padding: 0.45rem 0.6rem;
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  color: var(--mtc-pra-ink-mute);
  font-weight: 700;
  border-bottom: 2px solid var(--mtc-pra-line);
}

.mtc-pra-refs-table td {
  padding: 0.4rem 0.6rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  vertical-align: top;
}

.mtc-pra-refs-table tbody tr:hover {
  background: var(--mtc-pra-cream);
}

.mtc-pra-refs-zh {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  font-size: 0.95rem;
}

.mtc-pra-refs-loc {
  font-size: 0.82rem;
  color: var(--mtc-pra-ink-mute);
  max-width: 320px;
}

/* Pagination */
.mtc-pra-pagination {
  display: flex;
  flex-wrap: wrap;
  gap: 0.25rem;
  justify-content: center;
  align-items: center;
  margin-top: 0.8rem;
  padding: 0.6rem 0 0.2rem;
  border-top: 1px solid var(--mtc-pra-line);
}

.mtc-pra-pag-link {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 2rem;
  height: 2rem;
  padding: 0 0.55rem;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 4px;
  background: #fff;
  color: var(--mtc-pra-ink);
  text-decoration: none;
  font-size: 0.88rem;
  font-weight: 500;
  transition: background 0.15s, border-color 0.15s;
}

.mtc-pra-pag-link:hover:not(.is-current):not(.is-disabled) {
  background: var(--mtc-pra-cream-alt);
  border-color: var(--mtc-pra-red);
  color: var(--mtc-pra-red);
}

.mtc-pra-pag-link.is-current {
  background: var(--mtc-pra-red);
  border-color: var(--mtc-pra-red);
  color: #fff;
  cursor: default;
}

.mtc-pra-pag-link.is-disabled {
  color: var(--mtc-pra-ink-mute);
  opacity: 0.5;
  cursor: not-allowed;
}

.mtc-pra-pag-ellipsis {
  padding: 0 0.3rem;
  color: var(--mtc-pra-ink-mute);
  font-size: 0.88rem;
}

/* Mobile */
@media (max-width: 600px) {
  .mtc-pra-refs-table {
    font-size: 0.82rem;
  }
  .mtc-pra-refs-table th,
  .mtc-pra-refs-table td {
    padding: 0.3rem 0.4rem;
  }
  .mtc-pra-refs-loc {
    display: none;
  }
}

/* ═══════════════════════════════════════════════════════════════
   42. v0.10.20 — Onglet Traitement : 6 blocs interactifs
   =============================================================== */

.mtc-pra-tech-block {
  transition: opacity 0.2s, border-color 0.2s;
  opacity: 0.55;
  border-left: 3px solid var(--mtc-pra-line) !important;
}

.mtc-pra-tech-block.is-active {
  opacity: 1;
  border-left-color: var(--mtc-pra-red) !important;
  background: #fff !important;
}

/* En-tête : checkbox + nom de la technique */
.mtc-pra-tech-header {
  margin: 0 !important;
  padding: 0 !important;
  font-size: 1rem;
  border-bottom: none !important;
}

.mtc-pra-tech-toggle {
  display: flex;
  align-items: center;
  gap: 0.4rem;
  cursor: pointer;
  user-select: none;
  font-weight: 700;
  color: var(--mtc-pra-ink);
  padding: 0.2rem 0;
}

.mtc-pra-tech-toggle input[type="checkbox"] {
  width: 1.1rem;
  height: 1.1rem;
  cursor: pointer;
  margin: 0;
}

.mtc-pra-tech-emoji {
  font-size: 1.15rem;
}

.mtc-pra-tech-glyph {
  font-family: 'Noto Serif SC', 'Songti SC', serif;
  color: var(--mtc-pra-red);
  font-size: 1.05rem;
}

.mtc-pra-tech-block.is-active .mtc-pra-tech-glyph {
  color: var(--mtc-pra-red);
}

.mtc-pra-tech-label-fr {
  font-weight: 700;
}

.mtc-pra-tech-label-zh {
  font-family: 'Noto Serif SC', serif;
  color: var(--mtc-pra-ink);
  font-weight: 600;
}

.mtc-pra-tech-pinyin {
  font-style: italic;
  color: var(--mtc-pra-ink-mute);
  font-size: 0.82rem;
  font-weight: 400;
}

/* Corps : caché si non actif */
.mtc-pra-tech-body {
  margin-top: 0.5rem;
  padding-top: 0.5rem;
  border-top: 1px dashed var(--mtc-pra-line);
  display: none;
}

.mtc-pra-tech-block.is-active .mtc-pra-tech-body {
  display: block;
}

.mtc-pra-tech-meta {
  margin-top: 0.4rem;
}

/* Notes details : compactes */
.mtc-pra-tech-body details > summary {
  cursor: pointer;
  font-size: 0.78rem;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  color: var(--mtc-pra-ink-mute);
  padding: 0.3rem 0;
  user-select: none;
  margin-top: 0.4rem;
  border-top: 1px dashed var(--mtc-pra-line);
}

/* ═══════════════════════════════════════════════════════════════
   43. v0.10.24 — Vue Agenda : grille semaine 5/7 jours
   =============================================================== */

/* Toolbar */
.mtc-pra-agenda-toolbar {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 1rem;
  margin: 0.6rem 0 0.4rem;
  flex-wrap: wrap;
}

.mtc-pra-agenda-nav {
  display: flex;
  gap: 0.3rem;
}

.mtc-pra-agenda-week-label {
  font-weight: 700;
  color: var(--mtc-pra-ink);
  font-size: 0.95rem;
  text-align: center;
  flex: 1;
  min-width: 200px;
}

.mtc-pra-agenda-switch {
  display: flex;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 4px;
  overflow: hidden;
  background: #fff;
}

.mtc-pra-agenda-switch-btn {
  padding: 0.35rem 0.8rem;
  text-decoration: none;
  color: var(--mtc-pra-ink);
  font-size: 0.85rem;
  font-weight: 600;
  background: #fff;
  transition: background 0.15s;
}

.mtc-pra-agenda-switch-btn:not(:last-child) {
  border-right: 1px solid var(--mtc-pra-line);
}

.mtc-pra-agenda-switch-btn:hover {
  background: var(--mtc-pra-cream-alt);
}

.mtc-pra-agenda-switch-btn.is-active {
  background: var(--mtc-pra-red);
  color: #fff;
}

/* Légende */
.mtc-pra-agenda-legend {
  display: flex;
  gap: 1rem;
  font-size: 0.82rem;
  color: var(--mtc-pra-ink-mute);
  margin: 0.3rem 0 0.6rem;
  flex-wrap: wrap;
}

.mtc-pra-agenda-dot {
  display: inline-block;
  width: 10px;
  height: 10px;
  border-radius: 50%;
  vertical-align: middle;
  margin-right: 0.3rem;
}

.mtc-pra-agenda-dot--mtc { background: var(--mtc-pra-red); }
.mtc-pra-agenda-dot--gcal { background: #1a73e8; }

/* Grille principale */
.mtc-pra-agenda-grid {
  display: grid;
  grid-template-columns: 60px repeat(5, 1fr);
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 6px;
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0, 0, 0, 0.04);
}

.mtc-pra-agenda-grid[data-days="7"] {
  grid-template-columns: 60px repeat(7, 1fr);
}

.mtc-pra-agenda-col {
  display: flex;
  flex-direction: column;
  border-right: 1px solid var(--mtc-pra-line);
  min-width: 0;
}

.mtc-pra-agenda-col:last-child {
  border-right: none;
}

.mtc-pra-agenda-col-hours {
  background: var(--mtc-pra-cream-alt);
}

.mtc-pra-agenda-col-header {
  height: 50px;
  border-bottom: 2px solid var(--mtc-pra-line);
  display: flex;
  flex-direction: column;
  align-items: center;
  justify-content: center;
  background: var(--mtc-pra-cream-alt);
  padding: 0.3rem;
}

.mtc-pra-agenda-col.is-today .mtc-pra-agenda-col-header {
  background: var(--mtc-pra-red);
  color: #fff;
}

.mtc-pra-agenda-col-day {
  font-size: 0.74rem;
  text-transform: uppercase;
  letter-spacing: 0.05em;
  font-weight: 700;
  color: var(--mtc-pra-ink-mute);
}

.mtc-pra-agenda-col.is-today .mtc-pra-agenda-col-day {
  color: rgba(255,255,255,0.85);
}

.mtc-pra-agenda-col-date {
  font-size: 0.95rem;
  font-weight: 700;
  color: var(--mtc-pra-ink);
}

.mtc-pra-agenda-col.is-today .mtc-pra-agenda-col-date {
  color: #fff;
}

/* Heures (colonne gauche) */
.mtc-pra-agenda-hour-label {
  font-size: 0.72rem;
  color: var(--mtc-pra-ink-mute);
  text-align: right;
  padding: 0.15rem 0.4rem 0 0;
  border-bottom: 1px dashed var(--mtc-pra-line);
  box-sizing: border-box;
}

/* Body de chaque colonne jour */
.mtc-pra-agenda-col-body {
  position: relative;
  background: #fff;
}

.mtc-pra-agenda-col.is-today .mtc-pra-agenda-col-body {
  background: rgba(155, 28, 28, 0.02);
}

/* Lignes horaires */
.mtc-pra-agenda-hour-line {
  position: absolute;
  left: 0;
  right: 0;
  height: 1px;
  background: var(--mtc-pra-line);
  border-top: 1px dashed var(--mtc-pra-line);
  border-color: rgba(0,0,0,0.04);
  pointer-events: none;
}

/* Événement */
.mtc-pra-agenda-event {
  position: absolute;
  left: 2px;
  right: 2px;
  border-radius: 4px;
  padding: 0.2rem 0.4rem;
  font-size: 0.78rem;
  line-height: 1.25;
  cursor: pointer;
  text-decoration: none;
  overflow: hidden;
  display: flex;
  flex-direction: column;
  z-index: 2;
  transition: transform 0.1s, box-shadow 0.1s;
}

.mtc-pra-agenda-event:hover {
  z-index: 3;
  transform: translateX(-1px);
  box-shadow: 0 3px 8px rgba(0,0,0,0.15);
}

.mtc-pra-agenda-event--mtc {
  background: rgba(155, 28, 28, 0.12);
  border-left: 3px solid var(--mtc-pra-red);
  color: var(--mtc-pra-red);
}

.mtc-pra-agenda-event--mtc:hover {
  background: rgba(155, 28, 28, 0.2);
}

.mtc-pra-agenda-event--gcal {
  background: rgba(26, 115, 232, 0.12);
  border-left: 3px solid #1a73e8;
  color: #1558b8;
}

.mtc-pra-agenda-event--gcal:hover {
  background: rgba(26, 115, 232, 0.2);
}

.mtc-pra-agenda-event strong {
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
}

.mtc-pra-agenda-event-title {
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
}

.mtc-pra-agenda-event small {
  font-size: 0.7rem;
  opacity: 0.8;
  font-weight: 400;
}

.mtc-pra-agenda-event.is-allday {
  background: rgba(26, 115, 232, 0.18);
  border-left-style: dashed;
}

/* Mobile : pile vertical pour 5j, scroll horizontal pour 7j */
@media (max-width: 768px) {
  .mtc-pra-agenda-toolbar {
    flex-direction: column;
    gap: 0.5rem;
  }
  .mtc-pra-agenda-week-label {
    text-align: center;
  }
  .mtc-pra-agenda-grid {
    overflow-x: auto;
  }
  .mtc-pra-agenda-grid[data-days="5"],
  .mtc-pra-agenda-grid[data-days="7"] {
    grid-template-columns: 50px repeat(var(--mtc-days, 5), minmax(110px, 1fr));
    min-width: 600px;
  }
  .mtc-pra-agenda-grid[data-days="7"] {
    --mtc-days: 7;
    min-width: 800px;
  }
}

/* ═══════════════════════════════════════════════════════════════
   44. v0.10.25 — Saisie rapide RDV : toggle existant/nouveau
   =============================================================== */

.mtc-pra-rdv-mode-toggle {
  display: flex;
  gap: 0.5rem;
  margin-bottom: 0.8rem;
  padding: 0.4rem;
  background: var(--mtc-pra-cream-alt);
  border-radius: 6px;
}

.mtc-pra-rdv-mode-toggle label {
  flex: 1;
  display: flex;
  align-items: center;
  gap: 0.4rem;
  padding: 0.4rem 0.6rem;
  background: #fff;
  border: 1px solid var(--mtc-pra-line);
  border-radius: 4px;
  cursor: pointer;
  font-weight: 600;
  font-size: 0.88rem;
  transition: all 0.15s;
  user-select: none;
}

.mtc-pra-rdv-mode-toggle label:has(input:checked) {
  background: var(--mtc-pra-red);
  border-color: var(--mtc-pra-red);
  color: #fff;
}

.mtc-pra-rdv-mode-toggle label:has(input:checked) .mtc-zh-label,
.mtc-pra-rdv-mode-toggle label:has(input:checked) .mtc-fr-label {
  color: #fff;
}

.mtc-pra-rdv-mode-toggle input[type="radio"] {
  margin: 0;
  accent-color: var(--mtc-pra-red);
}

/* Fallback navigateurs sans :has() */
@supports not selector(:has(*)) {
  .mtc-pra-rdv-mode-toggle label {
    background: #fff;
  }
}

/* ═══════════════════════════════════════════════════════════════
   45. v0.10.26 — Dialog modal RDV + clic sur créneau agenda
   =============================================================== */

/* Indicateur visuel : la grille devient cliquable */
.mtc-pra-agenda-col-body[data-date] {
  cursor: cell;
}

/* Hover discret sur la zone d'un créneau */
.mtc-pra-agenda-col-body[data-date]:hover {
  background-image: linear-gradient(
    to bottom,
    transparent 0,
    transparent calc(50% - 1px),
    rgba(155, 28, 28, 0.06) calc(50% - 1px),
    rgba(155, 28, 28, 0.06) 50%,
    transparent 50%
  );
}

.mtc-pra-agenda-col.is-today .mtc-pra-agenda-col-body[data-date]:hover {
  background-color: rgba(155, 28, 28, 0.04);
}

/* Au-dessus des événements : curseur normal pour le lien */
.mtc-pra-agenda-event {
  cursor: pointer;
}

/* ───────── Dialog modal ───────── */
.mtc-pra-dialog {
  border: none;
  border-radius: 8px;
  padding: 0;
  width: min(640px, 92vw);
  max-height: 90vh;
  background: #fff;
  color: var(--mtc-pra-ink);
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.25);
  overflow: hidden;
  font-family: inherit;
}

.mtc-pra-dialog::backdrop {
  background: rgba(0, 0, 0, 0.45);
  backdrop-filter: blur(2px);
}

.mtc-pra-dialog[open] {
  display: flex;
  flex-direction: column;
}

.mtc-pra-dialog-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0.8rem 1rem;
  border-bottom: 1px solid var(--mtc-pra-line);
  background: var(--mtc-pra-cream-alt);
  flex-shrink: 0;
}

.mtc-pra-dialog-header h2 {
  margin: 0;
  font-size: 1.05rem;
  font-weight: 700;
  color: var(--mtc-pra-red);
  font-family: 'Cormorant Garamond', serif;
}

.mtc-pra-dialog-close {
  background: transparent;
  border: none;
  font-size: 1.6rem;
  line-height: 1;
  color: var(--mtc-pra-ink-mute);
  cursor: pointer;
  padding: 0.1rem 0.5rem;
  border-radius: 4px;
  transition: background 0.15s, color 0.15s;
}

.mtc-pra-dialog-close:hover {
  background: rgba(0, 0, 0, 0.06);
  color: var(--mtc-pra-red);
}

.mtc-pra-dialog form {
  padding: 0.9rem 1rem;
  overflow-y: auto;
  flex: 1;
}

/* Mobile : full screen */
@media (max-width: 600px) {
  .mtc-pra-dialog {
    width: 100vw;
    height: 100vh;
    max-height: 100vh;
    border-radius: 0;
  }
}

/* ═══════════════════════════════════════════════════════════════
   46. v0.10.27 — Hover slot + autocomplete patients
   =============================================================== */

/* Désactiver l'effet hover du gradient v0.10.26 — on a mieux maintenant */
.mtc-pra-agenda-col-body[data-date]:hover {
  background-image: none;
}

/* Overlay flottant qui suit la souris dans la grille (slot 30 min) */
.mtc-pra-agenda-slot-hover {
  position: absolute;
  left: 1px;
  right: 1px;
  background: rgba(155, 28, 28, 0.14);
  border: 1px dashed var(--mtc-pra-red);
  border-radius: 3px;
  pointer-events: none;
  z-index: 4;
  transition: top 0.06s linear, height 0.06s linear;
  /* Texte affiché dedans : l'heure ciblée */
  color: var(--mtc-pra-red);
  font-size: 0.72rem;
  font-weight: 700;
  font-variant-numeric: tabular-nums;
  display: flex;
  align-items: flex-start;
  justify-content: flex-start;
  padding: 0.15rem 0.3rem;
  box-sizing: border-box;
}

/* La colonne body doit être relative pour que l'overlay se place bien */
.mtc-pra-agenda-col-body { position: relative; }

/* ─── Combobox patient : champ avec autocomplete dans le dialog ─── */
.mtc-pra-field--ac {
  position: relative;
}

/* Le dropdown apparaît juste sous l'input dans le dialog. Le z-index doit être > backdrop. */
.mtc-pra-dialog .mtc-pra-ac-dropdown {
  /* Hérite du style global défini en 0.10.16 mais on s'assure de la lisibilité dans dialog */
  z-index: 1001 !important;
  background: #fff;
  max-height: 280px;
}

/* Sur mobile : empêcher le dropdown de déborder du dialog plein écran */
@media (max-width: 600px) {
  .mtc-pra-dialog .mtc-pra-ac-dropdown {
    max-width: calc(100vw - 2rem);
    width: 100%;
    left: 0 !important;
  }
}
