/* ═══════════════════════════════════════════════════════════════
   Formation LMS — Frontend CSS  |  Design Premium aligné admin
   ═══════════════════════════════════════════════════════════════ */

/* ── Variables (identiques à l'admin) ── */
.flms-front-wrap {
  --f-blue-dark:  #0f172a;
  --f-blue-mid:   #1e3a5f;
  --f-primary:    #1a73e8;
  --f-accent:     #6c63ff;
  --f-success:    #10b981;
  --f-warning:    #f59e0b;
  --f-danger:     #ef4444;
  --f-purple:     #a855f7;
  --f-bg:         #f1f5f9;
  --f-card:       #ffffff;
  --f-border:     #e2e8f0;
  --f-text:       #1e293b;
  --f-muted:      #64748b;
  --f-radius:     12px;
  --f-radius-sm:  8px;
  --f-shadow:     0 1px 3px rgba(0,0,0,.07), 0 4px 12px rgba(0,0,0,.05);
  --f-shadow-md:  0 6px 20px rgba(0,0,0,.1);
  --f-shadow-hover: 0 10px 28px rgba(26,115,232,.18);
  --f-grad-main:  linear-gradient(135deg, #0f172a 0%, #1e3a5f 60%, #1a73e8 100%);
  --f-grad-blue:  linear-gradient(135deg, #1a73e8, #6c63ff);
  --f-grad-green: linear-gradient(135deg, #10b981, #059669);
  --f-grad-orange:linear-gradient(135deg, #f59e0b, #ef4444);
  --f-grad-purple:linear-gradient(135deg, #6c63ff, #a855f7);
  --f-cols: 2;

  font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif;
  color: var(--f-text);
  background: var(--f-bg);
  border-radius: var(--f-radius);
  overflow: hidden;
  box-shadow: 0 8px 40px rgba(0,0,0,.12);
  margin: 0 auto;
  max-width: 1080px;
}

/* ══════════════════════════════════════════════════════════════
   TOPBAR — dégradé sombre comme la sidebar admin
   ══════════════════════════════════════════════════════════════ */
.flms-front-topbar {
  background: var(--f-grad-main);
  padding: 14px 20px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 14px;
  flex-wrap: wrap;
  position: relative;
  overflow: hidden;
}
.flms-front-topbar::after {
  content: '';
  position: absolute; inset: 0;
  background: url("data:image/svg+xml,%3Csvg width='60' height='60' viewBox='0 0 60 60' xmlns='http://www.w3.org/2000/svg'%3E%3Cg fill='%23ffffff' fill-opacity='0.03'%3E%3Ccircle cx='30' cy='30' r='28'/%3E%3C/g%3E%3C/svg%3E") repeat;
  pointer-events: none;
}

/* Brand */
.flms-front-brand {
  display: flex; align-items: center; gap: 9px;
  position: relative; z-index: 1;
}
.flms-front-brand-icon {
  color: #4f9cf9;
  font-size: 22px !important; height: 22px !important; width: 22px !important;
  filter: drop-shadow(0 0 8px rgba(79,156,249,.5));
}
.flms-front-brand-name {
  font-size: 15px; font-weight: 700;
  color: #fff; letter-spacing: .3px;
}
.flms-front-brand-badge {
  font-size: 9px; font-weight: 800;
  background: var(--f-grad-blue); color: #fff;
  padding: 2px 7px; border-radius: 20px;
  letter-spacing: .6px; text-transform: uppercase;
}

/* Droite topbar */
.flms-front-topbar-right {
  display: flex; align-items: center; gap: 10px;
  position: relative; z-index: 1; flex-wrap: wrap;
}

/* Recherche */
.flms-front-search-wrap {
  position: relative;
}
.flms-front-search-icon {
  position: absolute; left: 11px; top: 50%;
  transform: translateY(-50%);
  color: rgba(255,255,255,.5) !important;
  font-size: 15px !important; height: 15px !important; width: 15px !important;
  pointer-events: none;
}
.flms-front-search {
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: 30px;
  padding: 8px 14px 8px 34px;
  font-size: 13px; color: #fff;
  outline: none;
  transition: .2s;
  width: 220px;
}
.flms-front-search::placeholder { color: rgba(255,255,255,.4); }
.flms-front-search:focus {
  background: rgba(255,255,255,.16);
  border-color: #4f9cf9;
  box-shadow: 0 0 0 3px rgba(79,156,249,.2);
  width: 260px;
}

/* Toggle layout */
.flms-front-layout-toggle { display: flex; gap: 4px; }
.flms-lt-btn {
  background: rgba(255,255,255,.1);
  border: 1.5px solid rgba(255,255,255,.18);
  border-radius: 8px;
  width: 34px; height: 34px;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  color: rgba(255,255,255,.6);
  transition: .2s;
}
.flms-lt-btn .dashicons { font-size: 15px !important; height: 15px !important; width: 15px !important; }
.flms-lt-btn.active {
  background: var(--f-grad-blue); border-color: transparent;
  color: #fff;
  box-shadow: 0 2px 8px rgba(26,115,232,.4);
}
.flms-lt-btn:hover:not(.active) { background: rgba(255,255,255,.18); color: #fff; }

/* ══════════════════════════════════════════════════════════════
   STATS — identiques aux cartes stat de l'admin
   ══════════════════════════════════════════════════════════════ */
.flms-front-stats {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 0;
}
.flms-front-stat {
  padding: 18px 16px;
  text-align: center;
  color: #fff;
  position: relative; overflow: hidden;
  border-right: 1px solid rgba(255,255,255,.1);
}
.flms-front-stat:last-child { border-right: none; }
.flms-front-stat--blue   { background: var(--f-grad-blue); }
.flms-front-stat--green  { background: var(--f-grad-green); }
.flms-front-stat--orange { background: var(--f-grad-orange); }
.flms-front-stat--purple { background: var(--f-grad-purple); }
.flms-front-stat::before {
  content: '';
  position: absolute; top: -20px; right: -20px;
  width: 72px; height: 72px; border-radius: 50%;
  background: rgba(255,255,255,.1);
}
.flms-front-stat::after {
  content: '';
  position: absolute; bottom: -28px; left: -8px;
  width: 72px; height: 72px; border-radius: 50%;
  background: rgba(255,255,255,.06);
}
.flms-front-stat-val {
  display: block;
  font-size: 28px; font-weight: 800;
  line-height: 1; color: #fff;
  text-shadow: 0 2px 8px rgba(0,0,0,.15);
  position: relative; z-index: 1;
}
.flms-front-stat-lbl {
  display: block;
  font-size: 10px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .7px;
  color: rgba(255,255,255,.8);
  margin-top: 5px;
  position: relative; z-index: 1;
}

/* ══════════════════════════════════════════════════════════════
   FIL D'ARIANE
   ══════════════════════════════════════════════════════════════ */
.flms-front-breadcrumb {
  display: flex; align-items: center; flex-wrap: wrap;
  gap: 6px;
  padding: 10px 20px;
  background: var(--f-card);
  border-bottom: 1px solid var(--f-border);
  font-size: 13px; color: var(--f-muted);
}
.flms-front-bc-icon {
  color: var(--f-primary) !important;
  font-size: 15px !important; height: 15px !important; width: 15px !important;
}
.flms-front-bc-home, .flms-front-bc-link {
  cursor: pointer; color: var(--f-primary);
  font-weight: 600; transition: color .15s;
}
.flms-front-bc-home:hover, .flms-front-bc-link:hover { color: #1557b0; }
.flms-front-bc-sep { color: var(--f-border); }
.flms-front-bc-current { font-weight: 700; color: var(--f-text); }

/* ══════════════════════════════════════════════════════════════
   CONTENU PRINCIPAL
   ══════════════════════════════════════════════════════════════ */
.flms-front-view { padding: 20px; }

/* Spinner */
.flms-front-loader {
  display: flex; justify-content: center; align-items: center;
  padding: 60px; gap: 12px;
  color: var(--f-muted); font-size: 13px; font-weight: 500;
}
.flms-front-spinner {
  width: 28px; height: 28px;
  border: 3px solid var(--f-border);
  border-top-color: var(--f-primary);
  border-radius: 50%;
  animation: flms-spin .7s linear infinite;
}
@keyframes flms-spin { to { transform: rotate(360deg); } }

/* ── En-tête de section ── */
.flms-front-section-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 14px;
}
.flms-front-section-icon {
  color: var(--f-primary) !important;
  font-size: 17px !important; height: 17px !important; width: 17px !important;
}
.flms-front-section-label {
  font-size: 14px; font-weight: 700; color: var(--f-text);
}
.flms-front-section-count {
  font-size: 11px; font-weight: 700;
  background: var(--f-bg); color: var(--f-muted);
  padding: 2px 8px; border-radius: 20px;
  border: 1px solid var(--f-border);
}

/* ── En-tête de vue (dept / section) ── */
.flms-front-view-header {
  display: flex; align-items: center; gap: 14px;
  background: var(--f-card);
  border-radius: var(--f-radius);
  padding: 16px 20px;
  margin-bottom: 18px;
  box-shadow: var(--f-shadow);
  border-left: 4px solid var(--f-primary);
}
.flms-front-view-dept-icon {
  font-size: 26px !important; height: 26px !important; width: 26px !important;
  flex-shrink: 0;
}
.flms-front-view-header-text { flex: 1; }
.flms-front-view-dept-name {
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .6px;
  color: var(--f-muted); margin: 0 0 3px;
}
.flms-front-view-title {
  font-size: 19px; font-weight: 800;
  color: var(--f-text); margin: 0;
}
.flms-front-view-sub {
  font-size: 13px; color: var(--f-muted);
  margin: 4px 0 0;
}

/* ══════════════════════════════════════════════════════════════
   CARTES DÉPARTEMENT — style identique admin
   ══════════════════════════════════════════════════════════════ */
.flms-front-dept-grid {
  display: grid; gap: 14px;
}
.flms-front-grid { grid-template-columns: repeat(var(--f-cols, 2), 1fr); }
.flms-front-list { grid-template-columns: 1fr; }

.flms-front-dept-card {
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow .22s, transform .18s;
  box-shadow: var(--f-shadow);
}
.flms-front-dept-card:hover {
  box-shadow: var(--f-shadow-hover);
  transform: translateY(-3px);
}

/* Barre d'accent colorée (exactement comme admin) */
.flms-front-dept-accent {
  height: 5px;
  background: var(--f-grad-blue);
}

.flms-front-dept-body { padding: 16px 18px; }

.flms-front-dept-head {
  display: flex; align-items: flex-start;
  justify-content: space-between; gap: 10px;
  margin-bottom: 5px;
}
.flms-front-dept-name {
  font-size: 14px; font-weight: 700;
  color: var(--f-text); margin: 0; line-height: 1.3;
  text-transform: uppercase; letter-spacing: .2px;
}
.flms-front-dept-badge {
  font-size: 11px; font-weight: 600;
  background: var(--f-bg); color: var(--f-muted);
  padding: 2px 9px; border-radius: 20px;
  border: 1px solid var(--f-border);
  white-space: nowrap; flex-shrink: 0;
}
.flms-front-dept-code {
  font-size: 12px; color: var(--f-muted);
  margin-bottom: 5px;
}
.flms-front-dept-desc {
  font-size: 12px; color: var(--f-muted);
  margin: 0 0 12px; line-height: 1.5;
}

.flms-front-dept-footer {
  display: flex; align-items: center; gap: 12px;
  padding-top: 10px;
  border-top: 1px solid var(--f-border);
  margin-top: 10px;
}
.flms-front-dept-meta-item {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 12px; color: var(--f-muted);
}
.flms-front-dept-meta-item .dashicons {
  font-size: 13px !important; height: 13px !important; width: 13px !important;
  color: var(--f-primary);
}
.flms-front-dept-arrow {
  margin-left: auto;
  color: var(--f-muted);
  transition: transform .2s, color .15s;
}
.flms-front-dept-arrow .dashicons {
  font-size: 16px !important; height: 16px !important; width: 16px !important;
}
.flms-front-dept-card:hover .flms-front-dept-arrow {
  transform: translateX(4px); color: var(--f-primary);
}

/* ══════════════════════════════════════════════════════════════
   CARTES SECTION — style identique admin
   ══════════════════════════════════════════════════════════════ */
.flms-front-section-list { display: flex; flex-direction: column; gap: 10px; }

.flms-front-section-card {
  display: flex; align-items: stretch;
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  overflow: hidden;
  cursor: pointer;
  transition: box-shadow .22s, transform .15s;
  box-shadow: var(--f-shadow);
}
.flms-front-section-card:hover {
  box-shadow: var(--f-shadow-hover);
  transform: translateX(3px);
}

/* Bandeau coloré gauche */
.flms-front-section-left {
  width: 52px; flex-shrink: 0;
  background: var(--f-grad-blue);
  display: flex; align-items: center; justify-content: center;
}
.flms-front-section-left .dashicons {
  color: rgba(255,255,255,.85) !important;
  font-size: 20px !important; height: 20px !important; width: 20px !important;
}

.flms-front-section-body {
  flex: 1; padding: 14px 16px; min-width: 0;
}
.flms-front-section-row {
  display: flex; align-items: center;
  justify-content: space-between; gap: 10px;
  margin-bottom: 5px;
}
.flms-front-section-name {
  font-size: 14px; font-weight: 700; color: var(--f-text);
  margin: 0; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flms-front-section-mod-count {
  font-size: 11px; font-weight: 600;
  background: var(--f-bg); color: var(--f-muted);
  padding: 2px 9px; border-radius: 20px;
  border: 1px solid var(--f-border);
  white-space: nowrap; flex-shrink: 0;
}
.flms-front-section-obj {
  font-size: 12px; color: var(--f-muted);
  margin: 0 0 8px; line-height: 1.5;
}
.flms-front-section-tags { display: flex; flex-wrap: wrap; gap: 6px; }

.flms-front-section-arrow {
  display: flex; align-items: center;
  padding: 0 14px;
  color: var(--f-muted);
  transition: transform .2s, color .15s;
  flex-shrink: 0;
}
.flms-front-section-arrow .dashicons {
  font-size: 16px !important; height: 16px !important; width: 16px !important;
}
.flms-front-section-card:hover .flms-front-section-arrow {
  transform: translateX(4px); color: var(--f-primary);
}

/* ══════════════════════════════════════════════════════════════
   TAGS
   ══════════════════════════════════════════════════════════════ */
.flms-front-tag {
  display: inline-flex; align-items: center; gap: 3px;
  padding: 3px 9px; border-radius: 20px;
  font-size: 11px; font-weight: 600;
  background: var(--f-bg); color: var(--f-muted);
  white-space: nowrap;
}
.flms-front-tag.flms-tag-done {
  background: linear-gradient(135deg,#d1fae5,#a7f3d0);
  color: #065f46;
}
.flms-front-tag.flms-tag-done .dashicons {
  font-size: 12px !important; height: 12px !important; width: 12px !important;
}
.flms-front-tag.flms-tag-desc { max-width: 160px; overflow: hidden; text-overflow: ellipsis; }

/* Badge type de module */
.flms-front-type-badge {
  display: inline-flex; align-items: center;
  padding: 3px 9px; border-radius: 20px;
  font-size: 10px; font-weight: 800;
  text-transform: uppercase; letter-spacing: .4px;
}

/* ══════════════════════════════════════════════════════════════
   MODULES — style identique admin
   ══════════════════════════════════════════════════════════════ */
.flms-front-module-list { display: flex; flex-direction: column; gap: 10px; }

.flms-front-module-row {
  display: flex; align-items: center; gap: 14px;
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  padding: 14px 16px;
  cursor: pointer;
  transition: box-shadow .22s, transform .15s;
  box-shadow: var(--f-shadow);
  position: relative; overflow: hidden;
}
.flms-front-module-row::before {
  content: '';
  position: absolute; left: 0; top: 0; bottom: 0;
  width: 4px; background: var(--f-grad-blue);
  opacity: 0; transition: opacity .2s;
}
.flms-front-module-row:hover {
  box-shadow: var(--f-shadow-hover);
  transform: translateX(3px);
}
.flms-front-module-row:hover::before { opacity: 1; }
.flms-front-module-row.flms-done { border-left: 4px solid var(--f-success); }
.flms-front-module-row.flms-done::before { opacity: 1; background: var(--f-grad-green); }

/* Icône type */
.flms-front-mod-icon-wrap {
  width: 46px; height: 46px; border-radius: 10px;
  display: flex; align-items: center; justify-content: center;
  flex-shrink: 0;
  transition: transform .2s;
}
.flms-front-module-row:hover .flms-front-mod-icon-wrap { transform: scale(1.08); }
.flms-front-mod-icon-wrap .dashicons {
  font-size: 20px !important; height: 20px !important; width: 20px !important;
}

.flms-front-mod-body { flex: 1; min-width: 0; }
.flms-front-mod-top {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 5px; flex-wrap: wrap;
}
.flms-front-mod-title {
  font-size: 14px; font-weight: 700; color: var(--f-text);
  flex: 1; white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flms-front-mod-tags { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 4px; }

/* Barre de progression */
.flms-front-prog-wrap {
  display: flex; align-items: center; gap: 8px; margin-top: 5px;
}
.flms-front-prog-bar {
  flex: 1; height: 5px; background: var(--f-bg);
  border-radius: 3px; overflow: hidden;
}
.flms-front-prog-fill {
  height: 100%; background: var(--f-grad-blue);
  border-radius: 3px; transition: width .5s ease;
}
.flms-front-prog-pct {
  font-size: 11px; font-weight: 700;
  color: var(--f-muted); flex-shrink: 0;
  min-width: 28px; text-align: right;
}

/* Flèche module */
.flms-front-mod-arrow {
  color: var(--f-muted); flex-shrink: 0;
  transition: transform .2s, color .15s;
}
.flms-front-mod-arrow .dashicons {
  font-size: 16px !important; height: 16px !important; width: 16px !important;
}
.flms-front-module-row:hover .flms-front-mod-arrow {
  transform: translateX(4px); color: var(--f-primary);
}

/* ══════════════════════════════════════════════════════════════
   LECTEUR
   ══════════════════════════════════════════════════════════════ */
.flms-front-player-inner {
  background: var(--f-card);
  border-radius: var(--f-radius);
  overflow: hidden;
  box-shadow: var(--f-shadow-md);
}
.flms-front-player-inner iframe { width: 100%; height: 540px; border: none; display: block; }
.flms-front-player-inner video  { width: 100%; max-height: 540px; display: block; background: #000; }
.flms-front-link-module {
  display: flex; flex-direction: column; align-items: center;
  justify-content: center; padding: 60px 24px; gap: 16px; text-align: center;
  background: linear-gradient(135deg, #f8faff, #f5f3ff);
}
.flms-front-link-module p { font-size: 16px; font-weight: 600; color: var(--f-text); margin: 0; }
.flms-front-link-module a {
  display: inline-flex; align-items: center; gap: 8px;
  background: var(--f-grad-blue); color: #fff;
  padding: 13px 28px; border-radius: 40px;
  text-decoration: none; font-weight: 700;
  box-shadow: 0 4px 16px rgba(26,115,232,.4);
  transition: transform .15s, box-shadow .15s;
}
.flms-front-link-module a:hover { transform: translateY(-2px); box-shadow: 0 8px 24px rgba(26,115,232,.5); color: #fff; }

/* ── Marquer terminé ── */
.flms-front-mark-done {
  margin-top: 12px;
  padding: 14px 18px;
  background: var(--f-card);
  border-radius: var(--f-radius);
  box-shadow: var(--f-shadow);
}
.flms-front-check-label {
  display: flex; align-items: center; gap: 10px;
  cursor: pointer;
}
.flms-front-check-label input { width: 18px; height: 18px; accent-color: var(--f-primary); cursor: pointer; }
.flms-front-check-text { font-size: 13px; font-weight: 600; color: var(--f-text); }

/* Toast points */
.flms-front-points-toast {
  position: fixed; bottom: 24px; right: 24px;
  background: var(--f-grad-green); color: #fff;
  padding: 12px 20px; border-radius: 10px;
  font-weight: 700; font-size: 14px;
  box-shadow: 0 6px 20px rgba(16,185,129,.35);
  opacity: 0; transform: translateY(12px);
  transition: opacity .3s, transform .3s; z-index: 9999;
}
.flms-front-points-toast.show { opacity: 1; transform: translateY(0); }

/* ── Bouton retour ── */
.flms-front-back-btn {
  display: inline-flex; align-items: center; gap: 6px;
  margin-bottom: 14px;
  background: var(--f-card);
  border: 1.5px solid var(--f-border);
  border-radius: 8px;
  padding: 8px 14px;
  font-size: 13px; font-weight: 600;
  color: var(--f-primary);
  cursor: pointer;
  transition: background .18s, box-shadow .18s, transform .15s;
  box-shadow: var(--f-shadow);
}
.flms-front-back-btn:hover {
  background: var(--f-bg);
  box-shadow: var(--f-shadow-md);
  transform: translateX(-2px);
}
.flms-front-back-btn .dashicons {
  font-size: 14px !important; height: 14px !important; width: 14px !important;
}

/* ── Badge modules amélioré ── */
.flms-front-section-mod-badge {
  display: inline-flex; align-items: center; gap: 4px;
  font-size: 11px; font-weight: 700;
  background: var(--f-bg);
  color: var(--f-text);
  padding: 3px 10px;
  border-radius: 20px;
  border: 1.5px solid var(--f-border);
  white-space: nowrap; flex-shrink: 0;
  letter-spacing: .2px;
}

/* Empty */
.flms-front-empty {
  text-align: center; padding: 48px 20px; color: var(--f-muted);
}
.flms-front-empty .dashicons {
  font-size: 48px !important; height: 48px !important; width: 48px !important;
  display: block; margin: 0 auto 12px; opacity: .3;
}
.flms-front-empty p { font-size: 14px; margin: 0; }

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Tablette (≤ 860px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 860px) {
  .flms-front-wrap { --f-cols: 2; }
  .flms-front-stats { grid-template-columns: repeat(2, 1fr); }
  .flms-front-stat { border-bottom: 1px solid rgba(255,255,255,.1); }
  .flms-front-search { width: 180px; }
  .flms-front-search:focus { width: 200px; }
  .flms-front-player-inner iframe,
  .flms-front-player-inner video { height: 360px; }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Mobile (≤ 640px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 640px) {
  .flms-front-wrap { --f-cols: 1; }

  /* Topbar */
  .flms-front-topbar { padding: 12px 14px; }
  .flms-front-topbar-right { width: 100%; }
  .flms-front-search { width: 100%; }
  .flms-front-search:focus { width: 100%; }
  .flms-front-brand-name { font-size: 14px; }

  /* Stats 2×2 */
  .flms-front-stats { grid-template-columns: repeat(2, 1fr); }
  .flms-front-stat { padding: 14px 10px; }
  .flms-front-stat-val { font-size: 22px; }

  /* Fil d'ariane */
  .flms-front-breadcrumb { padding: 8px 14px; font-size: 12px; }

  /* Contenu */
  .flms-front-view { padding: 14px; }

  /* Cartes dept */
  .flms-front-dept-grid { grid-template-columns: 1fr !important; }
  .flms-front-dept-name { font-size: 13px; }

  /* Sections */
  .flms-front-section-left { width: 40px; }
  .flms-front-section-name { font-size: 13px; }

  /* Modules */
  .flms-front-mod-icon-wrap { width: 40px; height: 40px; }
  .flms-front-mod-title { font-size: 13px; }
  .flms-front-module-row { padding: 12px 12px; gap: 10px; }

  /* Lecteur */
  .flms-front-player-inner iframe,
  .flms-front-player-inner video { height: 220px; }
  .flms-front-link-module { padding: 40px 16px; }

  /* Toast */
  .flms-front-points-toast { bottom: 14px; right: 14px; left: 14px; }
}

/* ══════════════════════════════════════════════════════════════
   RESPONSIVE — Très petit (≤ 380px)
   ══════════════════════════════════════════════════════════════ */
@media (max-width: 380px) {
  .flms-front-layout-toggle { display: none; }
  .flms-front-stat-val { font-size: 18px; }
  .flms-front-stat-lbl { font-size: 9px; }
  .flms-front-brand-badge { display: none; }
}

/* ══════════════════════════════════════════════════════════════
   DIRECTION — chips & cards
   ══════════════════════════════════════════════════════════════ */
.flms-front-dir-chips {
  display: flex; flex-wrap: wrap; gap: 5px;
  margin: 8px 0 10px;
}
.flms-front-dir-chip {
  font-size: 10px; font-weight: 600;
  padding: 2px 8px; border-radius: 20px;
  white-space: nowrap;
}
.flms-front-dir-chip--svc {
  background: rgba(108,99,255,.1); color: #6c63ff;
  border: 1px solid rgba(108,99,255,.25);
}
.flms-front-dir-chip--more {
  background: var(--f-bg); color: var(--f-muted);
  border: 1px solid var(--f-border);
}

/* ══════════════════════════════════════════════════════════════
   FICHIERS — liste inline (dans vue direction)
   ══════════════════════════════════════════════════════════════ */
.flms-front-files-block {
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  padding: 14px 16px;
  margin-bottom: 16px;
  box-shadow: var(--f-shadow);
}
.flms-front-files-title {
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--f-muted);
  display: flex; align-items: center; gap: 6px;
  margin-bottom: 10px;
}
.flms-front-files-list {
  display: flex; flex-direction: column; gap: 6px;
}
.flms-front-file-item {
  display: flex; align-items: center; gap: 10px;
  padding: 8px 12px;
  background: var(--f-bg);
  border: 1px solid var(--f-border);
  border-radius: 8px;
  text-decoration: none;
  color: var(--f-text);
  transition: box-shadow .15s, transform .12s;
}
.flms-front-file-item:hover {
  box-shadow: var(--f-shadow-md); transform: translateX(2px);
  color: var(--f-primary);
}
.flms-front-file-icon {
  color: var(--f-primary) !important;
  font-size: 18px !important; height: 18px !important; width: 18px !important;
  flex-shrink: 0;
}
.flms-front-file-name {
  flex: 1; font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flms-front-file-size {
  font-size: 11px; color: var(--f-muted); flex-shrink: 0;
}
.flms-front-file-dl {
  color: var(--f-muted) !important;
  font-size: 14px !important; height: 14px !important; width: 14px !important;
  flex-shrink: 0; transition: color .15s;
}
.flms-front-file-item:hover .flms-front-file-dl { color: var(--f-primary) !important; }

/* ══════════════════════════════════════════════════════════════
   FICHIERS — grille (dans vue service)
   ══════════════════════════════════════════════════════════════ */
.flms-front-files-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
  gap: 10px;
  margin-top: 4px;
}
.flms-front-file-card {
  display: flex; align-items: center; gap: 10px;
  padding: 12px 14px;
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  text-decoration: none; color: var(--f-text);
  box-shadow: var(--f-shadow);
  transition: box-shadow .2s, transform .15s;
}
.flms-front-file-card:hover {
  box-shadow: var(--f-shadow-hover); transform: translateY(-2px);
  color: var(--f-primary);
}
.flms-front-file-card-icon {
  color: var(--f-primary) !important;
  font-size: 24px !important; height: 24px !important; width: 24px !important;
  flex-shrink: 0;
}
.flms-front-file-card-body { flex: 1; min-width: 0; }
.flms-front-file-card-name {
  display: block; font-size: 13px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flms-front-file-card-meta { font-size: 11px; color: var(--f-muted); margin-top: 2px; display: block; }
.flms-front-file-card-dl {
  color: var(--f-muted) !important;
  font-size: 16px !important; height: 16px !important; width: 16px !important;
  flex-shrink: 0;
}
.flms-front-file-card:hover .flms-front-file-card-dl { color: var(--f-primary) !important; }

/* ══════════════════════════════════════════════════════════════
   SERVICE — bloc description
   ══════════════════════════════════════════════════════════════ */
.flms-front-svc-desc-block {
  background: linear-gradient(135deg, #f8faff, #f5f3ff);
  border: 1px solid rgba(108,99,255,.15);
  border-radius: var(--f-radius);
  padding: 14px 18px;
  margin-bottom: 16px;
  font-size: 13px;
  line-height: 1.7;
  color: var(--f-text);
}

@media (max-width: 640px) {
  .flms-front-files-grid { grid-template-columns: 1fr; }
}

/* ══════════════════════════════════════════════════════════════
   CARTE DIRECTION — style image 2 (bandeau coloré + corps blanc)
   ══════════════════════════════════════════════════════════════ */
.flms-front-dir-card {
  border-radius: var(--f-radius) !important;
  overflow: hidden;
  border: 2px solid transparent !important;
  transition: box-shadow .22s, transform .18s, border-color .2s !important;
}
.flms-front-dir-card:hover {
  border-color: rgba(0,0,0,.08) !important;
  transform: translateY(-3px) !important;
  box-shadow: 0 12px 32px rgba(0,0,0,.13) !important;
}

/* Bandeau coloré avec le nom — imite image 2 */
.flms-front-dir-banner {
  display: flex; align-items: center; gap: 10px;
  padding: 13px 16px;
  color: #fff;
  position: relative;
}
.flms-front-dir-banner-icon {
  font-size: 18px !important; height: 18px !important; width: 18px !important;
  opacity: .85; flex-shrink: 0;
}
.flms-front-dir-banner-name {
  font-size: 14px; font-weight: 700;
  letter-spacing: .1px; flex: 1;
  line-height: 1.3;
}
.flms-front-dir-banner-badge {
  font-size: 10px; font-weight: 800;
  background: rgba(255,255,255,.22);
  padding: 2px 9px; border-radius: 20px;
  letter-spacing: .4px; flex-shrink: 0;
}

/* Corps blanc de la carte */
.flms-front-dir-body {
  background: var(--f-card);
  padding: var(--card-pad, 14px) 16px 14px;
  min-height: 60px;
}

/* ── Stat hover (cliquables) ── */
.flms-front-stat-clickable {
  transition: filter .18s, transform .15s;
}
.flms-front-stat-clickable:hover {
  filter: brightness(1.1);
  transform: scaleY(1.03);
}
.flms-front-stat-clickable:active { transform: scaleY(.97); }

/* ══════════════════════════════════════════════════════════════
   VUES AGRÉGÉES (depuis les stats)
   ══════════════════════════════════════════════════════════════ */
.flms-front-agg-header {
  display: flex; align-items: center; gap: 8px;
  margin-bottom: 16px;
}
.flms-front-agg-group {
  margin-bottom: 18px;
}
.flms-front-agg-group-title {
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--f-muted);
  padding: 6px 12px;
  margin-bottom: 8px;
  display: flex; align-items: center; gap: 6px;
  background: var(--f-bg);
  border-radius: 6px;
}
.flms-front-agg-group-title .dashicons {
  font-size: 14px !important; height: 14px !important; width: 14px !important;
}

/* ══════════════════════════════════════════════════════════════
   SECTIONS ACCORDION
   ══════════════════════════════════════════════════════════════ */
.flms-front-sect-block {
  border: 1px solid var(--f-border);
  border-radius: var(--f-radius);
  margin-bottom: 10px;
  background: var(--f-card);
  box-shadow: var(--f-shadow);
  overflow: hidden;
  transition: box-shadow .2s;
}
.flms-front-sect-block:hover { box-shadow: var(--f-shadow-md); }

.flms-front-sect-header {
  display: flex; align-items: center; justify-content: space-between;
  padding: 14px 16px; cursor: pointer;
  gap: 12px;
  transition: background .15s;
}
.flms-front-sect-header:hover { background: var(--f-bg); }

.flms-front-sect-header-left { display: flex; align-items: center; gap: 12px; flex: 1; min-width: 0; }

.flms-front-sect-icon {
  width: 36px; height: 36px; border-radius: 8px;
  display: flex; align-items: center; justify-content: center; flex-shrink: 0;
}
.flms-front-sect-icon .dashicons { color: #fff; font-size: 16px !important; height: 16px !important; width: 16px !important; }

.flms-front-sect-meta { flex: 1; min-width: 0; }

.flms-front-sect-tags { display: flex; flex-wrap: wrap; gap: 5px; margin-top: 4px; }

.flms-front-sect-chevron {
  color: var(--f-muted) !important;
  font-size: 14px !important; height: 14px !important; width: 14px !important;
  transition: transform .25s; flex-shrink: 0;
}
.flms-front-sect-chevron.open { transform: rotate(180deg); }

.flms-front-sect-body {
  border-top: 1px solid var(--f-border);
  padding: 16px;
  background: var(--f-bg);
}
.flms-front-sect-obj {
  font-size: 13px; color: var(--f-muted);
  margin: 0 0 14px; line-height: 1.6;
}

/* ══════════════════════════════════════════════════════════════
   COURS
   ══════════════════════════════════════════════════════════════ */
.flms-front-courses-header {
  display: flex; align-items: center; gap: 6px;
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--f-muted);
  margin-bottom: 10px;
}
.flms-front-courses-header .dashicons { font-size: 14px !important; height: 14px !important; width: 14px !important; }

.flms-front-courses-list { display: flex; flex-direction: column; gap: 10px; }

.flms-front-course-card {
  background: var(--f-card);
  border: 1px solid var(--f-border);
  border-radius: calc(var(--f-radius) - 2px);
  overflow: hidden;
  box-shadow: 0 1px 3px rgba(0,0,0,.05);
}

.flms-front-course-head {
  display: flex; gap: 12px; align-items: flex-start;
  padding: 12px 14px;
}
.flms-front-course-icon {
  width: 32px; height: 32px; border-radius: 7px; flex-shrink: 0;
  display: flex; align-items: center; justify-content: center;
}
.flms-front-course-icon .dashicons { color: #fff !important; font-size: 15px !important; height: 15px !important; width: 15px !important; }
.flms-front-course-info { flex: 1; min-width: 0; }
.flms-front-course-title { font-size: 13px; font-weight: 700; color: var(--f-text); }
.flms-front-course-meta {
  display: flex; flex-wrap: wrap; gap: 8px;
  font-size: 11px; color: var(--f-muted);
  margin-top: 3px;
}
.flms-front-course-meta span { display: flex; align-items: center; gap: 3px; }
.flms-front-course-desc { font-size: 12px; color: var(--f-muted); margin: 4px 0 0; line-height: 1.5; }

/* ── Syllabus ── */
.flms-front-syllabus-list {
  border-top: 1px solid var(--f-border);
  padding: 8px 14px;
  display: flex; flex-direction: column; gap: 5px;
}
.flms-front-syllabus-item {
  display: flex; align-items: center; gap: 8px;
  padding: 7px 10px;
  border-radius: 7px;
  background: var(--f-bg);
  text-decoration: none; color: var(--f-text);
  border: 1px solid var(--f-border);
  transition: box-shadow .15s, transform .12s;
}
.flms-front-syllabus-item:hover {
  box-shadow: var(--f-shadow-md);
  transform: translateX(2px);
  color: var(--f-primary);
}
.flms-front-syllabus-icon {
  color: #ef4444 !important; flex-shrink: 0;
  font-size: 18px !important; height: 18px !important; width: 18px !important;
}
.flms-front-syllabus-name { flex: 1; font-size: 12px; font-weight: 600; white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.flms-front-syllabus-meta { font-size: 10px; color: var(--f-muted); flex-shrink: 0; }
.flms-front-syllabus-dl {
  color: var(--f-muted) !important; flex-shrink: 0;
  font-size: 14px !important; height: 14px !important; width: 14px !important;
}
.flms-front-syllabus-item:hover .flms-front-syllabus-dl { color: var(--f-primary) !important; }
.flms-front-syllabus-empty { font-size: 11px; color: var(--f-muted); padding: 6px 14px; margin: 0; border-top: 1px solid var(--f-border); }

/* Bouton voir modules */
.flms-front-sect-footer { padding: 10px 14px; border-top: 1px solid var(--f-border); }
.flms-front-sect-modules-btn {
  display: inline-flex; align-items: center; gap: 6px;
  background: var(--f-primary); color: #fff;
  border: none; border-radius: 8px;
  padding: 8px 16px; font-size: 13px; font-weight: 600;
  cursor: pointer; transition: filter .15s, transform .12s;
}
.flms-front-sect-modules-btn:hover { filter: brightness(1.1); transform: translateY(-1px); }
.flms-front-sect-modules-btn .dashicons { font-size: 14px !important; height: 14px !important; width: 14px !important; }

/* Tag cours */
.flms-tag-courses { color: #7c3aed; background: #ede9fe; border-color: #c4b5fd; }

@media (max-width: 640px) {
  .flms-front-sect-header { padding: 10px 12px; }
  .flms-front-course-head { padding: 10px 12px; }
}

/* ══ COURSES SECTION HEADER ══════════════════════════════════════════════ */
.flms-front-courses-section {
  margin-top: 6px;
}
.flms-front-courses-header {
  display: flex; align-items: center; gap: 7px;
  font-size: 12px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .5px;
  color: var(--f-muted);
  margin-bottom: 10px; padding-bottom: 6px;
  border-bottom: 1px solid var(--f-border);
}
.flms-front-courses-header .dashicons {
  color: #7c3aed !important;
  font-size: 15px !important; height: 15px !important; width: 15px !important;
}
.flms-front-courses-count {
  background: #ede9fe; color: #7c3aed;
  font-size: 11px; font-weight: 800;
  padding: 1px 7px; border-radius: 20px;
  margin-left: 2px;
}

/* ══ COURSE OBJECTIVE TEXT ════════════════════════════════════════════════ */
.flms-front-course-obj-txt {
  font-size: 11px; color: var(--f-muted);
  margin: 3px 0 0; line-height: 1.5;
}

/* ══ SYLLABUS ZONE (dans chaque cours) ════════════════════════════════════ */
.flms-front-syllabus-zone {
  border-top: 1px dashed var(--f-border);
  margin-top: 8px;
  padding-top: 8px;
}
.flms-front-syllabus-title {
  display: flex; align-items: center; gap: 6px;
  font-size: 11px; font-weight: 700;
  text-transform: uppercase; letter-spacing: .4px;
  color: var(--f-muted);
  margin-bottom: 7px;
}
.flms-front-syllabus-title .dashicons {
  color: #ef4444 !important;
  font-size: 13px !important; height: 13px !important; width: 13px !important;
}
.flms-front-syllabus-count {
  background: #fee2e2; color: #ef4444;
  font-size: 10px; font-weight: 800;
  padding: 1px 6px; border-radius: 20px;
}
.flms-front-syllabus-list {
  display: flex; flex-direction: column; gap: 6px;
}
.flms-front-syllabus-item {
  display: flex; align-items: center; gap: 9px;
  padding: 8px 11px;
  background: var(--f-bg);
  border: 1px solid var(--f-border);
  border-radius: 7px;
  text-decoration: none; color: var(--f-text);
  transition: box-shadow .15s, transform .12s, border-color .15s;
}
.flms-front-syllabus-item:hover {
  box-shadow: 0 2px 10px rgba(0,0,0,.08);
  transform: translateX(2px);
  border-color: #ef4444;
  color: var(--f-primary);
}
.flms-front-syllabus-icon {
  color: #ef4444 !important;
  font-size: 20px !important; height: 20px !important; width: 20px !important;
  flex-shrink: 0;
}
.flms-front-syllabus-info {
  flex: 1; min-width: 0;
}
.flms-front-syllabus-name {
  display: block; font-size: 12px; font-weight: 600;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.flms-front-syllabus-meta {
  display: block; font-size: 10px; color: var(--f-muted); margin-top: 1px;
}
.flms-front-syllabus-dl {
  color: var(--f-muted) !important;
  font-size: 15px !important; height: 15px !important; width: 15px !important;
  flex-shrink: 0; transition: color .15s;
}
.flms-front-syllabus-item:hover .flms-front-syllabus-dl {
  color: var(--f-primary) !important;
}
.flms-front-syllabus-empty {
  font-size: 11px; color: var(--f-muted);
  font-style: italic; margin: 0; padding: 4px 0;
}
