/* ==============================================================
 * MON OFFRE ET PAUL — styles natifs (2026-06-09)
 * CSS autonome scoped sur .mop-* (no leak vers Up-me).
 * Pattern compact 80-120px max sur les heros.
 * ============================================================== */

/* ── Mode IMMERSIF FULLSCREEN ─────────────────────────────── */
body.mon-offre-paul-fullscreen #page-topbar,
body.mon-offre-paul-fullscreen .app-menu,
body.mon-offre-paul-fullscreen .navbar-menu {
  display: none !important;
}
body.mon-offre-paul-fullscreen .main-content {
  margin-left: 0 !important;
  padding-top: 0 !important;
  margin-top: 0 !important;
}
body.mon-offre-paul-fullscreen .page-content,
body.mon-offre-paul-fullscreen .container-fluid {
  padding: 0 !important;
  max-width: 100% !important;
}

/* View host */
#view-mon-offre-paul { padding: 0 !important; }
#mon-offre-paul-host {
  width: 100%;
  min-height: 100vh;
  background: var(--vz-body-bg, #f3f6f9);
  font-family: var(--vz-font-sans-serif, -apple-system, BlinkMacSystemFont, "Inter", "Segoe UI", sans-serif);
  color: var(--vz-body-color, #212529);
}

/* Shell ────────────────────────────────────────────────── */
/* Largeur calée sur Bootstrap container-xxl (1320px) — évite l'étalement sur écrans larges */
.mop-shell { padding: 0 24px 80px; max-width: 1320px; margin: 0 auto; }
.mop-topbar { position: sticky; top: 0; z-index: 50; background: var(--vz-body-bg, #f3f6f9); }

/* Patch Velzon : focus form-control a un box-shadow invalide (`0 0 1 .25rem`),
   on rétablit un focus net. Et card a un `box-shadow:none!important` qui aplatit
   l'UI — on rend du relief uniquement dans le module. */
#mon-offre-paul-host .form-control:focus,
#mon-offre-paul-host .form-select:focus {
  border-color: var(--vz-primary, #405189);
  box-shadow: 0 0 0 0.2rem rgba(var(--vz-primary-rgb, 64,81,137), .2);
}
#mon-offre-paul-host .card {
  box-shadow: 0 1px 2px rgba(56,65,74,.1) !important;
  border: 1px solid var(--vz-border-color, #e9ebec);
}
#mon-offre-paul-host .card-animate:hover {
  box-shadow: 0 4px 12px rgba(56,65,74,.18) !important;
  border-color: var(--vz-primary-border-subtle, #b3b9d0);
}
/* Chapter tabs en pattern nav-pills (style aligné sur le module Dosage) :
   - onglet actif : pill rempli --vz-primary, texte blanc, ombre douce, radius 8px
   - onglet inactif : transparent, texte secondary
   - hover : fond primary soft + texte primary
   - sticky sous la topbar, scroll horizontal invisible au repos / fin au hover
   - molette verticale → scroll horizontal géré par _bindHorizontalWheel (JS) */
#mon-offre-paul-host .mop-chapter-tabs {
  position: sticky;
  top: 56px;
  z-index: 49;
  background: var(--vz-card-bg, #fff);
  border-bottom: 1px solid var(--vz-border-color, #e9ebec);
  overflow-x: auto; overflow-y: hidden;
  margin-left: -24px; margin-right: -24px; padding: 10px 24px;
  gap: 4px;
  scrollbar-width: thin;
  scrollbar-color: transparent transparent;
  transition: scrollbar-color .2s ease;
}
#mon-offre-paul-host .mop-chapter-tabs::-webkit-scrollbar { height: 6px; }
#mon-offre-paul-host .mop-chapter-tabs::-webkit-scrollbar-track { background: transparent; }
#mon-offre-paul-host .mop-chapter-tabs::-webkit-scrollbar-thumb {
  background: transparent;
  border-radius: 3px;
  transition: background .2s ease;
}
#mon-offre-paul-host .mop-chapter-tabs:hover { scrollbar-color: rgba(64,81,137,.45) transparent; }
#mon-offre-paul-host .mop-chapter-tabs:hover::-webkit-scrollbar-thumb { background: rgba(64,81,137,.45); }
#mon-offre-paul-host .mop-chapter-tabs::-webkit-scrollbar-thumb:hover { background: rgba(64,81,137,.65); }
#mon-offre-paul-host .mop-chapter-tabs .nav-item { flex-shrink: 0; }
#mon-offre-paul-host .mop-chapter-tabs .nav-link {
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 14px;
  font-weight: 500;
  color: var(--vz-secondary-color, #6c757d);
  display: inline-flex; align-items: center; gap: 6px;
  white-space: nowrap;
  border: 1px solid transparent;
  background: transparent;
  transition: background .15s ease, color .15s ease, box-shadow .15s ease;
}
#mon-offre-paul-host .mop-chapter-tabs .nav-link:hover {
  background: var(--vz-primary-bg-subtle, #e2e5ed);
  color: var(--vz-primary, #405189);
}
#mon-offre-paul-host .mop-chapter-tabs .nav-link.active {
  background: var(--vz-primary, #405189);
  color: #fff;
  font-weight: 600;
  box-shadow: 0 4px 12px rgba(64,81,137,.25);
}
#mon-offre-paul-host .mop-chapter-tabs .nav-link.active .badge {
  background: rgba(255,255,255,.2) !important;
  color: #fff !important;
}
#mon-offre-paul-host .mop-chapter-tabs .nav-link i { font-size: 16px; }
#mon-offre-paul-host .form-label { color: var(--vz-secondary-color, #495057); }

/* Card "form de création" : border dashed pour signaler "zone de saisie" vs "donnée". */
#mon-offre-paul-host .mop-form-create {
  border: 1.5px dashed var(--vz-primary-border-subtle, #b3b9d0) !important;
  background: var(--vz-card-bg, #fff);
}
#mon-offre-paul-host .mop-form-create .card-header {
  border-bottom: 1px dashed var(--vz-primary-border-subtle, #b3b9d0) !important;
}

/* ── Content area ─────────────────────────────────────────── */
.mop-content { padding: 0; }

/* Chapitre + Forms : 100% classes Velzon natives (card, nav nav-pills, form-control, badge, alert, btn-soft-*). */

/* Toast (animation Velzon n'en a pas embarqué — on garde l'anim custom locale) */
@keyframes mopToastSlide {
  from { opacity: 0; transform: translateY(10px); }
  to { opacity: 1; transform: translateY(0); }
}

/* Loading / error states */
.mop-loading {
  padding: 40px; text-align: center; color: var(--vz-tertiary-color, #878a99);
  font-size: 14px;
}
.mop-error {
  padding: 20px; background: var(--vz-danger-bg-subtle, #fce0db);
  border-left: 3px solid var(--vz-danger, #f06548);
  color: var(--vz-danger-text-emphasis, #783228); border-radius: 4px;
}

/* Modals, dropdowns, ws switcher, toasts : tout en classes Velzon natives
   (modal, modal-dialog, dropdown-menu, btn-soft-*, toast, toast-container). */
