/* ================================================================
   JC Formation WP — Public CSS v2.1 — Design SaaS Premium
================================================================ */
.jcf-formation-single *,.jcf-grid *,.jcf-filter-bar *{box-sizing:border-box}

/* ── BOUTON ──────────────────────────────────────────────────── */
.jcf-btn{display:inline-flex;align-items:center;gap:7px;padding:13px 28px;background:var(--jcf-btn-bg);border:var(--jcf-btn-border);color:var(--jcf-btn-color);border-radius:10px;font-weight:700;font-size:15px;text-decoration:none;cursor:pointer;transition:opacity .2s,transform .15s,box-shadow .2s;white-space:nowrap;letter-spacing:.2px;line-height:1}
.jcf-btn:hover{opacity:.88;transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.16);text-decoration:none;color:var(--jcf-btn-hover-col)}
.jcf-btn-sm{padding:9px 18px;font-size:13px;border-radius:8px}
.jcf-btn-full{width:100%;justify-content:center;padding:16px 24px;font-size:16px}

/* ── FILTRE ──────────────────────────────────────────────────── */
.jcf-filter-bar{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:32px}
.jcf-filter-btn{padding:8px 20px;border:2px solid #e2e8f0;background:#fff;color:#6b7280;border-radius:50px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;line-height:1}
.jcf-filter-btn:hover,.jcf-filter-btn.active{background:var(--jcf-primary);border-color:var(--jcf-primary);color:#fff}

/* ── GRILLE ──────────────────────────────────────────────────── */
.jcf-grid{display:grid;gap:24px;margin:20px 0 40px}
.jcf-grid-1{grid-template-columns:1fr}
.jcf-grid-2{grid-template-columns:repeat(2,1fr)}
.jcf-grid-3{grid-template-columns:repeat(3,1fr)}
.jcf-grid-4{grid-template-columns:repeat(4,1fr)}

/* ── CARD ────────────────────────────────────────────────────── */
.jcf-card{background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 2px 8px rgba(0,0,0,.06);border:1px solid #f1f5f9;display:flex;flex-direction:column;transition:transform .25s,box-shadow .25s;position:relative}
.jcf-card::before{content:'';position:absolute;top:0;left:0;right:0;height:3px;background:var(--jcf-card-accent);opacity:0;transition:opacity .25s;z-index:1}
.jcf-card:hover{transform:translateY(-6px);box-shadow:0 20px 48px rgba(0,0,0,.12)}
.jcf-card:hover::before{opacity:1}
.jcf-card-media-link{display:block;overflow:hidden}
.jcf-card-media{position:relative;height:200px;overflow:hidden;background:#f8fafc}
.jcf-card-img{width:100%;height:100%;object-fit:cover;display:block;transition:transform .4s}
.jcf-card:hover .jcf-card-img{transform:scale(1.06)}
.jcf-card-img-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:52px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0)}
.jcf-card-badge{position:absolute;top:12px;left:12px;background:var(--jcf-primary);color:#fff;padding:4px 11px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.jcf-card-closed{position:absolute;top:12px;right:12px;background:rgba(239,68,68,.9);color:#fff;padding:4px 11px;border-radius:50px;font-size:11px;font-weight:700}
.jcf-card-body{padding:18px 20px;display:flex;flex-direction:column;flex:1;gap:10px}
.jcf-card-top-meta{display:flex;align-items:center;justify-content:space-between;gap:8px;flex-wrap:wrap}
.jcf-card-level{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;padding:4px 10px;border-radius:50px}
.level-beginner{background:#dcfce7;color:#166534}
.level-intermediate{background:#fef3c7;color:#92400e}
.level-advanced{background:#ede9fe;color:#4c1d95}
.jcf-card-rating{font-size:12px;color:#f59e0b;font-weight:700;display:flex;align-items:center;gap:4px}
.jcf-rating-count{color:#9ca3af;font-weight:400}
.jcf-card-title{margin:0;font-size:16px;font-weight:700;line-height:1.4}
.jcf-card-title a{color:#0f172a;text-decoration:none;transition:color .2s}
.jcf-card-title a:hover{color:var(--jcf-primary)}
.jcf-card-excerpt{margin:0;font-size:13px;color:#64748b;line-height:1.6;flex:1}
.jcf-card-meta{display:flex;flex-wrap:wrap;gap:12px}
.jcf-meta-item{display:flex;align-items:center;gap:5px;font-size:12px;color:#94a3b8;font-weight:500}
.jcf-meta-item svg{color:#cbd5e1}
.jcf-card-footer{display:flex;align-items:center;justify-content:space-between;padding-top:12px;border-top:1px solid #f1f5f9;margin-top:auto;gap:10px;flex-wrap:wrap}
.jcf-card-prices{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.jcf-price-old{font-size:13px;color:#9ca3af;text-decoration:line-through;font-weight:500}
.jcf-card-price{font-size:19px;font-weight:800;color:var(--jcf-primary);letter-spacing:-.3px}
.jcf-no-results{text-align:center;padding:48px;color:#94a3b8;font-size:16px}
.jcf-card.jcf-hidden{display:none}

/* ── HERO ────────────────────────────────────────────────────── */
.jcf-formation-single{background:#f8fafc;min-height:100vh}
.jcf-hero{background:linear-gradient(135deg,#0f172a 0%,#1e293b 50%,#0f172a 100%);padding:56px 0 36px;position:relative;overflow:hidden}
.jcf-hero::before{content:'';position:absolute;inset:0;background:radial-gradient(ellipse at 70% 50%,rgba(99,102,241,.18) 0%,transparent 70%)}
.jcf-hero-inner{max-width:1160px;margin:0 auto;padding:0 24px;position:relative;display:grid;grid-template-columns:1fr 360px;gap:48px;align-items:start}
.jcf-hero-content{color:#fff}
.jcf-hero-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:18px}
.jcf-hero-badge{padding:5px 13px;border-radius:50px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px}
.jcf-badge-cat{background:var(--jcf-primary);color:#fff}
.jcf-badge-level{background:rgba(255,255,255,.12);color:#e2e8f0;border:1px solid rgba(255,255,255,.18)}
.jcf-hero-title{font-size:clamp(24px,3vw,40px);font-weight:800;line-height:1.2;margin:0 0 16px;color:#fff;letter-spacing:-.4px}
.jcf-hero-excerpt{font-size:16px;color:#94a3b8;line-height:1.7;margin:0 0 24px}
.jcf-hero-meta{display:flex;flex-wrap:wrap;gap:20px;padding-top:20px;border-top:1px solid rgba(255,255,255,.1)}
.jcf-hero-meta-item{display:flex;align-items:center;gap:7px;font-size:14px;color:#94a3b8}
.jcf-hero-meta-item svg{color:var(--jcf-primary)}
.jcf-hero-meta-item strong{color:#e2e8f0;font-weight:600}
.jcf-hero-instructor{display:flex;align-items:center;gap:10px;margin-top:20px;padding:13px 16px;background:rgba(255,255,255,.06);border-radius:12px;border:1px solid rgba(255,255,255,.1);backdrop-filter:blur(8px)}
.jcf-instructor-avatar{width:42px;height:42px;border-radius:50%;background:var(--jcf-primary);display:flex;align-items:center;justify-content:center;font-size:17px;font-weight:800;color:#fff;flex-shrink:0}
.jcf-instructor-name{font-weight:700;color:#f1f5f9;font-size:14px}
.jcf-instructor-label{font-size:12px;color:#64748b}

/* ── HERO CARD ───────────────────────────────────────────────── */
.jcf-hero-card{background:#fff;border-radius:20px;overflow:hidden;box-shadow:0 24px 64px rgba(0,0,0,.28);position:sticky;top:24px}
.jcf-hero-card-thumb{position:relative;height:190px;overflow:hidden;background:#f1f5f9}
.jcf-hero-card-thumb img{width:100%;height:100%;object-fit:cover}
.jcf-hero-card-body{padding:22px}
.jcf-hero-prices{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.jcf-hero-price{font-size:36px;font-weight:900;color:#0f172a;letter-spacing:-1px;line-height:1}
.jcf-hero-old-price{font-size:18px;color:#9ca3af;text-decoration:line-through;font-weight:500}
.jcf-closed-msg{background:#fef2f2;border:1px solid #fecaca;border-radius:10px;padding:13px 16px;color:#dc2626;font-size:13px;font-weight:600;text-align:center;margin-bottom:14px;display:flex;align-items:center;justify-content:center;gap:8px}
.jcf-card-guarantees{margin-top:16px;padding-top:16px;border-top:1px solid #f1f5f9;display:flex;flex-direction:column;gap:9px}
.jcf-guarantee-item{display:flex;align-items:center;gap:9px;font-size:13px;color:#475569}
.jcf-guarantee-item svg{color:var(--jcf-primary);flex-shrink:0}

/* ── MAIN LAYOUT ─────────────────────────────────────────────── */
.jcf-single-main{max-width:1160px;margin:0 auto;padding:40px 24px;display:grid;grid-template-columns:1fr 360px;gap:36px;align-items:start}
.jcf-content-area{min-width:0}
.jcf-sidebar-area{position:sticky;top:24px}

/* ── ACCORDION MODULES ───────────────────────────────────────── */
.jcf-modules-section{margin-bottom:8px}
.jcf-modules-header{margin-bottom:20px}
.jcf-modules-header h2{font-size:20px;font-weight:800;color:#0f172a;margin:0 0 4px}
.jcf-modules-header p{font-size:14px;color:#64748b;margin:0}
.jcf-accordion{display:flex;flex-direction:column;gap:8px}
.jcf-acc-item{background:#fff;border:1.5px solid #e2e8f0;border-radius:12px;overflow:hidden;transition:border-color .2s,box-shadow .2s}
.jcf-acc-item.open{border-color:var(--jcf-primary);box-shadow:0 4px 16px rgba(99,102,241,.12)}
.jcf-acc-header{display:flex;align-items:center;gap:14px;padding:16px 20px;cursor:pointer;user-select:none;background:#fff;transition:background .2s}
.jcf-acc-item.open .jcf-acc-header{background:linear-gradient(135deg,rgba(99,102,241,.04),rgba(139,92,246,.03))}
.jcf-acc-num{width:36px;height:36px;border-radius:9px;background:linear-gradient(135deg,var(--jcf-primary),var(--jcf-accent));color:#fff;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;flex-shrink:0;letter-spacing:.3px}
.jcf-acc-title{flex:1;font-size:15px;font-weight:600;color:#1e293b;line-height:1.4}
.jcf-acc-chevron{width:20px;height:20px;color:#94a3b8;transition:transform .3s,color .2s;flex-shrink:0}
.jcf-acc-item.open .jcf-acc-chevron{transform:rotate(180deg);color:var(--jcf-primary)}
.jcf-acc-body{max-height:0;overflow:hidden;transition:max-height .35s ease,padding .35s ease}
.jcf-acc-item.open .jcf-acc-body{max-height:400px}
.jcf-acc-content{padding:0 20px 18px 70px;font-size:14px;color:#475569;line-height:1.75}
.jcf-acc-empty{text-align:center;padding:48px 24px;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0;color:#94a3b8;font-size:15px}

/* ── SIDEBAR BOXES ───────────────────────────────────────────── */
.jcf-sidebar-box{background:#fff;border-radius:14px;padding:22px;margin-bottom:18px;box-shadow:0 2px 10px rgba(0,0,0,.06);border:1px solid #f1f5f9}
.jcf-sidebar-box h3{margin:0 0 16px;font-size:15px;font-weight:700;color:#0f172a;display:flex;align-items:center;gap:8px}
.jcf-sidebar-box h3 svg{color:var(--jcf-primary)}
.jcf-includes-list{list-style:none;padding:0;margin:0;display:flex;flex-direction:column;gap:10px}
.jcf-includes-list li{display:flex;align-items:flex-start;gap:10px;font-size:13.5px;color:#475569;line-height:1.5}
.jcf-includes-list li svg{color:#10b981;flex-shrink:0;margin-top:2px}
.jcf-details-list{display:flex;flex-direction:column;gap:10px}
.jcf-detail-row{display:flex;align-items:center;gap:11px;padding-bottom:10px;border-bottom:1px solid #f8fafc}
.jcf-detail-row:last-child{border-bottom:none;padding-bottom:0}
.jcf-detail-row svg{color:var(--jcf-primary);flex-shrink:0}
.jcf-detail-label{font-size:11px;color:#94a3b8;text-transform:uppercase;letter-spacing:.5px}
.jcf-detail-value{color:#0f172a;font-weight:600;font-size:14px}
.jcf-sidebar-prices{display:flex;align-items:baseline;gap:10px;margin-bottom:16px;flex-wrap:wrap}
.jcf-sidebar-old-price{font-size:15px;color:#9ca3af;text-decoration:line-through}
.jcf-sidebar-price{font-size:32px;font-weight:900;color:#0f172a;letter-spacing:-.5px}

/* ── AVIS GOOGLE STYLE ───────────────────────────────────────── */
.jcf-reviews-section{margin-top:48px;padding-top:40px;border-top:2px solid #f1f5f9}
.jcf-reviews-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px;flex-wrap:wrap;gap:12px}
.jcf-reviews-section-header h2{font-size:22px;font-weight:800;color:#0f172a;margin:0;display:flex;align-items:center;gap:10px}
.jcf-global-rating{display:flex;align-items:center;gap:10px;background:#fff;padding:14px 20px;border-radius:12px;box-shadow:0 2px 10px rgba(0,0,0,.06);border:1px solid #f1f5f9}
.jcf-global-score{font-size:36px;font-weight:900;color:#0f172a;letter-spacing:-1px;line-height:1}
.jcf-global-stars{display:flex;gap:3px;margin-bottom:2px}
.jcf-global-star{font-size:18px;line-height:1}
.jcf-global-star.filled{color:#f59e0b}
.jcf-global-star.empty{color:#d1d5db}
.jcf-global-count{font-size:13px;color:#64748b}
.jcf-reviews-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}
.jcf-review-card{background:#fff;border-radius:14px;padding:20px;box-shadow:0 2px 10px rgba(0,0,0,.06);border:1px solid #f1f5f9;transition:transform .2s,box-shadow .2s}
.jcf-review-card:hover{transform:translateY(-3px);box-shadow:0 8px 24px rgba(0,0,0,.1)}
.jcf-review-card-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:10px}
.jcf-review-author{display:flex;align-items:center;gap:10px}
.jcf-review-avatar{width:40px;height:40px;border-radius:50%;background:var(--jcf-primary);color:#fff;display:flex;align-items:center;justify-content:center;font-size:15px;font-weight:800;flex-shrink:0}
.jcf-review-name{font-weight:700;color:#0f172a;font-size:14px}
.jcf-review-date{font-size:12px;color:#94a3b8;margin-top:1px}
.jcf-google-g{width:24px;height:24px;flex-shrink:0;opacity:.6}
.jcf-review-stars{display:flex;gap:3px;margin-bottom:10px}
.jcf-review-star{font-size:15px;line-height:1}
.jcf-review-star.filled{color:#f59e0b}
.jcf-review-star.empty{color:#d1d5db}
.jcf-review-text{font-size:14px;color:#475569;line-height:1.7;margin:0}
.jcf-no-reviews{text-align:center;padding:40px 24px;background:#f8fafc;border-radius:12px;border:2px dashed #e2e8f0;color:#94a3b8;font-size:15px}

/* ── ARCHIVE ─────────────────────────────────────────────────── */
.jcf-archive{max-width:1160px;margin:0 auto;padding:48px 24px}
.jcf-archive-header{text-align:center;margin-bottom:44px}
.jcf-archive-title{font-size:clamp(26px,4vw,42px);font-weight:800;color:#0f172a;margin:0 0 10px;letter-spacing:-.5px}
.jcf-archive-desc{color:#64748b;font-size:16px;max-width:540px;margin:0 auto;line-height:1.6}

/* ── RESPONSIVE ──────────────────────────────────────────────── */
@media(max-width:1024px){.jcf-grid-4,.jcf-grid-3{grid-template-columns:repeat(2,1fr)}}
@media(max-width:768px){
    .jcf-hero-inner,.jcf-single-main{grid-template-columns:1fr}
    .jcf-hero-card{position:relative;top:0;order:-1}
    .jcf-sidebar-area{position:relative;top:0}
    .jcf-grid-2,.jcf-grid-3,.jcf-grid-4{grid-template-columns:1fr}
    .jcf-hero{padding:36px 0 24px}
    .jcf-hero-title{font-size:24px}
    .jcf-reviews-grid{grid-template-columns:1fr}
}
@media(max-width:480px){
    .jcf-filter-btn{font-size:13px;padding:7px 14px}
    .jcf-acc-content{padding-left:20px}
}

/* ================================================================
   AVIS — SECTION PLEINE LARGEUR (v2.2)
================================================================ */
.jcf-reviews-fullwidth {
    background: #f8fafc;
    padding: 56px 24px;
    margin-top: 0;
    width: 100%;
}
.jcf-reviews-wrap {
    max-width: 1280px;
    margin: 0 auto;
}
.jcf-reviews-fw-header {
    display: flex;
    flex-direction: column;
    align-items: center;
    text-align: center;
    gap: 8px;
    margin-bottom: 40px;
}
.jcf-reviews-fw-title {
    font-size: 28px;
    font-weight: 800;
    color: #0f172a;
    margin: 0;
    letter-spacing: -.4px;
}
.jcf-reviews-fw-sub {
    font-size: 15px;
    color: #64748b;
}
.jcf-global-rating {
    display: flex;
    align-items: center;
    gap: 14px;
    background: #fff;
    padding: 16px 22px;
    border-radius: 14px;
    box-shadow: 0 2px 10px rgba(0,0,0,.07);
}
.jcf-global-score {
    font-size: 44px;
    font-weight: 900;
    color: #0f172a;
    letter-spacing: -2px;
    line-height: 1;
}
.jcf-global-stars { display:flex;gap:4px;margin-bottom:4px; }
.jcf-global-star   { font-size:20px;line-height:1; }
.jcf-global-star.filled { color:#f59e0b; }
.jcf-global-star.empty  { color:#d1d5db; }
.jcf-global-count { font-size:13px;color:#64748b; }

/* ── Grid 4 colonnes ─────────────────────────────────────────── */
.jcf-reviews-grid-fw {
    display: grid;
    grid-template-columns: repeat(4, 1fr);
    gap: 16px;
    margin-bottom: 32px;
}

/* ── Card avis ───────────────────────────────────────────────── */
.jcf-review-card {
    background: #fff;
    border-radius: 14px;
    padding: 20px;
    box-shadow: 0 2px 8px rgba(0,0,0,.06);
    border: 1px solid #f1f5f9;
    transition: transform .2s, box-shadow .2s;
    display: flex;
    flex-direction: column;
    gap: 10px;
}
.jcf-review-card:hover {
    transform: translateY(-3px);
    box-shadow: 0 8px 24px rgba(0,0,0,.1);
}
.jcf-review-card-header {
    display: flex;
    align-items: flex-start;
    justify-content: space-between;
    gap: 10px;
}
.jcf-review-author { display:flex;align-items:center;gap:10px; }
.jcf-review-avatar {
    width: 40px;height: 40px;border-radius: 50%;
    background: linear-gradient(135deg, var(--jcf-primary), var(--jcf-accent));
    color: #fff;display:flex;align-items:center;justify-content:center;
    font-size:15px;font-weight:800;flex-shrink:0;
}
.jcf-review-name  { font-weight:700;color:#0f172a;font-size:14px; }
.jcf-review-date  { font-size:11px;color:#94a3b8;margin-top:1px; }

/* Badge Certifié */
.jcf-review-certified {
    display: inline-flex;
    align-items: center;
    gap: 4px;
    background: #f0fdf4;
    border: 1px solid #bbf7d0;
    border-radius: 50px;
    padding: 3px 9px;
    font-size: 11px;
    font-weight: 700;
    color: #16a34a;
    white-space: nowrap;
    flex-shrink: 0;
}
.jcf-review-certified svg { color: #16a34a; }

.jcf-review-stars { display:flex;gap:3px; }
.jcf-review-star  { font-size:15px;line-height:1; }
.jcf-review-star.filled { color:#f59e0b; }
.jcf-review-star.empty  { color:#d1d5db; }

/* Texte tronqué 2 lignes */
.jcf-review-text {
    font-size: 13.5px;
    color: #475569;
    line-height: 1.65;
    margin: 0;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
    transition: none;
    flex: 1;
}
.jcf-review-text.expanded {
    display: block;
    -webkit-line-clamp: unset;
    overflow: visible;
}
.jcf-voir-plus {
    background: none;
    border: none;
    color: var(--jcf-primary);
    font-size: 12px;
    font-weight: 700;
    cursor: pointer;
    padding: 0;
    margin-top: 2px;
    text-decoration: underline;
    text-underline-offset: 2px;
    align-self: flex-start;
}
.jcf-voir-plus:hover { opacity: .75; }

/* ── Pagination avis ─────────────────────────────────────────── */
.jcf-reviews-pagination {
    display: flex;
    justify-content: center;
    align-items: center;
    gap: 8px;
    flex-wrap: wrap;
}
.jcf-pag-btn {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 38px;height: 38px;
    border-radius: 9px;
    border: 1.5px solid #e2e8f0;
    background: #fff;
    color: #374151;
    font-weight: 600;
    font-size: 14px;
    cursor: pointer;
    transition: all .15s;
}
.jcf-pag-btn:hover { border-color: var(--jcf-primary); color: var(--jcf-primary); }
.jcf-pag-btn.active { background: var(--jcf-primary); border-color: var(--jcf-primary); color: #fff; }
.jcf-pag-btn:disabled { opacity: .4; cursor: default; }
.jcf-pag-arrow { font-size: 18px; width: 42px; }

/* ── Empty reviews ───────────────────────────────────────────── */
.jcf-no-reviews {
    text-align:center;padding:48px 24px;
    background:#fff;border-radius:16px;
    border:2px dashed #e2e8f0;color:#94a3b8;
    font-size:15px;grid-column:1/-1;
}

/* ── Responsive reviews ──────────────────────────────────────── */
@media(max-width:1024px){ .jcf-reviews-grid-fw{grid-template-columns:repeat(2,1fr);} }
@media(max-width:600px) { .jcf-reviews-grid-fw{grid-template-columns:1fr;} }
