/* FormationPro — Styles widgets Elementor (front-end) */

/* ── Badges ─────────────────────────────────────────────────────────────── */
.fp-el-badge {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    padding: 3px 10px;
    border-radius: 99px;
    font-size: 12px;
    font-weight: 600;
    white-space: nowrap;
    line-height: 1.4;
}
.fp-el-badge--free   { background: #dcfce7; color: #15803d; }
.fp-el-badge--paid   { background: #dbeafe; color: #1d4ed8; }
.fp-el-badge--done   { background: #dcfce7; color: #15803d; }
.fp-el-badge--open   { background: #dbeafe; color: #1d4ed8; }
.fp-el-badge--locked { background: #f3f4f6; color: #6b7280; }

/* ── Boutons ─────────────────────────────────────────────────────────────── */
.fp-el-btn {
    display: inline-block;
    padding: 11px 22px;
    font-weight: var(--fp-btn-font-weight, 600);
    font-size: var(--fp-btn-font-size, 15px);
    text-decoration: none;
    cursor: pointer;
    border: none;
    transition: opacity .15s, filter .15s;
    line-height: 1.3;
    color: var(--fp-btn-color, #ffffff) !important;
    border-radius: var(--fp-btn-radius, 8px);
}
.fp-el-btn:hover { opacity: .88; color: var(--fp-btn-color-hover, #fff) !important; }
.fp-el-btn--complete { cursor: pointer; }

/* ── Carte webinaire ─────────────────────────────────────────────────────── */
.fp-el-webinar-card { overflow: hidden; }
.fp-el-webinar-card__thumb { position: relative; }
.fp-el-webinar-card__thumb img { width: 100%; display: block; }
.fp-el-webinar-card__thumb .fp-el-badge {
    position: absolute;
    top: 12px;
    left: 12px;
    font-size: 13px;
    padding: 4px 12px;
}
.fp-el-webinar-card__body    { padding: 20px; }
.fp-el-webinar-card__title   { margin: 0 0 10px; }
.fp-el-webinar-card__date    { display: flex; align-items: center; gap: 6px; font-size: 13px; color: #6b7280; margin-bottom: 10px; }
.fp-el-webinar-card__desc    { font-size: 14px; color: #374151; margin: 0 0 16px; line-height: 1.6; }
.fp-el-webinar-card__action  { margin-top: 4px; }

/* ── Lecteur vidéo ───────────────────────────────────────────────────────── */
.fp-el-video-player { overflow: hidden; }
.fp-el-video-player__title { margin: 0 0 14px; }
.fp-el-video-player__embed iframe,
.fp-el-video-player__embed video { display: block; width: 100%; }

.fp-el-locked-overlay {
    display: flex;
    align-items: center;
    justify-content: center;
    background: #1f2937;
    min-height: 280px;
}
.fp-el-locked-overlay__inner { text-align: center; padding: 32px; }
.fp-el-lock-icon { display: block; margin: 0 auto 16px; color: #9ca3af; }
.fp-el-locked-overlay__msg   { color: #d1d5db; margin: 0 0 12px; font-size: 15px; }
.fp-el-countdown-badge        { display: inline-block; background: rgba(255,255,255,0.15); color: #fff; padding: 6px 16px; border-radius: 99px; font-weight: 700; font-size: 18px; }

/* ── Dashboard formations ────────────────────────────────────────────────── */
.fp-el-dashboard { display: flex; flex-direction: column; gap: 24px; }

.fp-el-pack-card { overflow: hidden; }
.fp-el-pack-card__header {
    display: flex;
    align-items: center;
    gap: 16px;
    padding: 20px;
}
.fp-el-pack-card__thumb img { width: 72px; height: 72px; object-fit: cover; border-radius: 8px; }
.fp-el-pack-card__meta { flex: 1; }
.fp-el-pack-card__title { margin: 0 0 10px; font-size: 17px; }

.fp-el-progress__bar  { height: 8px; background: #e5e7eb; border-radius: 99px; overflow: hidden; }
.fp-el-progress__fill { height: 100%; border-radius: 99px; transition: width .4s ease; }
.fp-el-progress__label { font-size: 12px; color: #6b7280; margin-top: 4px; display: block; }

/* ── Module items ────────────────────────────────────────────────────────── */
.fp-el-modules--list { display: flex; flex-direction: column; }
.fp-el-modules--grid { display: grid; grid-template-columns: repeat(3,1fr); gap: 12px; padding: 16px; }

.fp-el-module {
    display: flex;
    align-items: center;
    gap: 14px;
    padding: 13px 20px;
    border-top: 1px solid rgba(0,0,0,0.06);
    transition: background .1s;
}
.fp-el-module--open:hover { background: #eff6ff; }

.fp-el-module__num {
    width: 28px; height: 28px;
    border-radius: 50%;
    background: #e5e7eb;
    color: #6b7280;
    font-size: 12px; font-weight: 700;
    display: flex; align-items: center; justify-content: center;
    flex-shrink: 0;
}
.fp-el-module--done .fp-el-module__num  { background: #bbf7d0; color: #15803d; }
.fp-el-module--open .fp-el-module__num  { background: #bfdbfe; color: #1d4ed8; }

.fp-el-module__body { flex: 1; display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.fp-el-module__title { font-weight: 500; }
a.fp-el-module__title { color: #2563eb; text-decoration: none; }
a.fp-el-module__title:hover { text-decoration: underline; }

.fp-el-module__icon { margin-left: auto; flex-shrink: 0; }
.fp-el-module__icon--done   { color: #16a34a; }
.fp-el-module__icon--open   { color: #2563eb; }
.fp-el-module__icon--locked { color: #9ca3af; }

/* ── Grille modules (widget dédié) ──────────────────────────────────────── */
.fp-el-module-card { overflow: hidden; transition: box-shadow .15s; }
.fp-el-module-card:hover { box-shadow: 0 4px 16px rgba(0,0,0,0.08); }
.fp-el-module-card__title { font-size: 15px; font-weight: 600; display: block; }
a.fp-el-module-card__title { color: #2563eb; text-decoration: none; }
a.fp-el-module-card__title:hover { text-decoration: underline; }

/* ── Pack pricing card ───────────────────────────────────────────────────── */
.fp-el-pack-pricing { transition: transform .15s; }
.fp-el-pack-pricing:hover { transform: translateY(-2px); }
.fp-el-pack-pricing__modules,
.fp-el-pack-pricing__features { margin: 0; padding: 0; list-style: none; }

/* ── Vide / non connecté ─────────────────────────────────────────────────── */
.fp-el-empty { padding: 32px; text-align: center; background: #f9fafb; border-radius: 12px; color: #6b7280; }

/* ── Responsive ──────────────────────────────────────────────────────────── */
@media (max-width: 768px) {
    .fp-el-modules--grid { grid-template-columns: 1fr 1fr; }
    .fp-el-pack-card__header { flex-direction: column; align-items: flex-start; }
}
@media (max-width: 480px) {
    .fp-el-modules--grid { grid-template-columns: 1fr; }
}
