/* ═══════════════════════════════════════════════════════════
   Budozen Product Cards — front
   ─────────────────────────────────────────────────────────── */

/* ───── 1. SINGLE HORIZONTAL ───── */
.bjj-card{border:.5px solid #e5e5e5;border-radius:14px;background:#fff;display:flex;overflow:hidden;font-family:inherit;margin:28px 0}
.bjj-card-img{width:170px;min-width:170px;overflow:hidden}
.bjj-card-img img{width:100%;height:100%;object-fit:cover;display:block}
.bjj-card-body{padding:22px 24px;flex:1;display:flex;flex-direction:column;gap:10px;min-width:0}
.bjj-brand{font-size:11px;color:#888;text-transform:uppercase;letter-spacing:.08em;font-weight:500}
.bjj-name{font-size:15.5px;font-weight:600;color:#111;margin:0;line-height:1.35}
.bjj-stars{font-size:12px;color:#C9A84C}
.bjj-desc{font-size:12.5px;color:#555;line-height:1.6;margin:0}
.bjj-promo{display:flex;align-items:center;gap:8px;background:#FFF8E7;border:.5px solid #C9A84C;border-radius:8px;padding:8px 13px;flex-wrap:wrap;width:fit-content}
.bjj-promo-text{font-size:12px;color:#633806}
.bjj-code{background:#C9A84C;color:#000;font-weight:700;font-size:11.5px;padding:3px 9px;border-radius:4px;letter-spacing:.05em;white-space:nowrap}
.bjj-footer{display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap;padding-top:4px}
.bjj-prices{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.bjj-old{font-size:13px;color:#bbb;text-decoration:line-through}
.bjj-new{font-size:21px;font-weight:700;color:#111}
.bjj-save{font-size:11px;color:#1a6640;background:#E8F7EF;padding:3px 7px;border-radius:4px;font-weight:500}
.bjj-cta{background:#1A1A2E;color:#fff!important;font-size:13px;font-weight:600;padding:11px 18px;border-radius:8px;text-decoration:none!important;white-space:nowrap;display:inline-block}
@media(max-width:500px){
.bjj-card{flex-direction:column}
.bjj-card-img{width:100%!important;min-width:unset!important;height:180px}
.bjj-card-body{padding:18px}
.bjj-footer{flex-direction:column;align-items:flex-start}
.bjj-cta{width:100%;text-align:center;box-sizing:border-box}
}

/* ───── 2. SINGLE VERTICAL ───── */
.bdz-vcard{max-width:340px;margin:28px auto;border:.5px solid #e5e5e5;border-radius:14px;background:#fff;overflow:hidden;font-family:inherit}
.bdz-vcard-img{width:100%;height:240px;overflow:hidden;background:#f5f5f5}
.bdz-vcard-img img{width:100%;height:100%;object-fit:cover;display:block}
.bdz-vcard-body{padding:20px;display:flex;flex-direction:column;gap:10px}

/* ───── 3. MINI CARD ───── */
.bdz-mini{display:flex;align-items:center;gap:12px;padding:10px 14px;border:1px solid #eee;border-radius:10px;background:#fff;text-decoration:none!important;color:#111!important;margin:14px 0;transition:background .15s,transform .15s;font-family:inherit}
.bdz-mini:hover{background:#fafafa;transform:translateY(-1px)}
.bdz-mini-img{width:48px;height:48px;border-radius:8px;object-fit:cover;border:1px solid #eee;flex-shrink:0;background:#f5f5f5}
.bdz-mini-body{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}
.bdz-mini-name{font-weight:600;font-size:14px;color:#111;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.bdz-mini-badge{font-size:10.5px;color:#7B5CF0;font-weight:600;text-transform:uppercase;letter-spacing:.05em}
.bdz-mini-price{font-weight:800;font-size:15px;color:#111;white-space:nowrap}
.bdz-mini-arrow{color:#888;font-size:18px;margin-left:4px}

/* ───── 4. HERO CARD ───── */
.bdz-hero{border-radius:18px;overflow:hidden;background:#fff;box-shadow:0 8px 32px rgba(0,0,0,.10);margin:36px 0;font-family:inherit;max-width:560px}
.bdz-hero-img{position:relative;width:100%;aspect-ratio:16/10;background:#f5f5f5;overflow:hidden}
.bdz-hero-img img{width:100%;height:100%;object-fit:cover;display:block}
.bdz-hero-badge{position:absolute;top:14px;left:14px;background:#C9A84C;color:#000;font-weight:700;font-size:11px;padding:6px 12px;border-radius:20px;letter-spacing:.05em;text-transform:uppercase}
.bdz-hero-body{padding:26px 28px 28px;display:flex;flex-direction:column;gap:12px}
.bdz-hero-name{font-size:22px;font-weight:700;color:#111;margin:0;line-height:1.25}
.bdz-hero-desc{font-size:14px;color:#444;line-height:1.55;margin:0}
.bdz-hero-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding-top:8px;border-top:1px solid #f0f0f0;margin-top:6px}
.bdz-hero-cta{background:#1A1A2E;color:#fff!important;font-size:14px;font-weight:700;padding:13px 22px;border-radius:10px;text-decoration:none!important;white-space:nowrap;display:inline-block;transition:background .15s}
.bdz-hero-cta:hover{background:#2a2a4a}
@media(max-width:500px){
.bdz-hero-body{padding:20px}
.bdz-hero-name{font-size:18px}
.bdz-hero-footer{flex-direction:column;align-items:stretch}
.bdz-hero-cta{text-align:center}
}

/* ───── 5. TABLE COMPARATIVE ───── */
.wbjj{font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',sans-serif;margin:1.5rem 0}
.wbjj-thumb{width:60px;height:60px;object-fit:cover;border-radius:10px;flex-shrink:0;border:1px solid #eee;display:block;background:#f5f5f5}
.wbjj-name a{font-weight:700;color:#111;text-decoration:none;font-size:.88rem;line-height:1.3;display:block}
.wbjj-name a:hover{color:#7B5CF0}
.wbjj-badge{display:inline-block;background:#f3f0ff;color:#7B5CF0;font-size:.68rem;font-weight:600;padding:.15rem .5rem;border-radius:20px;margin-top:.2rem}
.wbjj-prix{font-weight:800;color:#111;font-size:1rem;display:block}
.wbjj-barre{display:block;color:#aaa;font-size:.75rem;text-decoration:line-through}
.wbjj-promo{display:inline-block;background:#C8A84B;color:#fff;font-size:.65rem;font-weight:700;padding:.1rem .35rem;border-radius:4px;margin-top:.2rem}
.wbjj-avis{font-size:.82rem;color:#444;line-height:1.4}
.wbjj-btn{display:inline-block;background:#C8A84B;color:#fff!important;font-size:.75rem;font-weight:700;padding:.5rem 1rem;border-radius:8px;text-decoration:none!important;letter-spacing:.04em;transition:background .15s;white-space:nowrap}
.wbjj-btn:hover{background:#b8943e}
.wbjj-desktop{display:block}
.wbjj-mobile{display:none}
.wbjj-table{width:100%;border-collapse:collapse;background:#fff;border-radius:16px;overflow:hidden;box-shadow:0 4px 24px rgba(0,0,0,.08)}
.wbjj-table thead tr{background:#7B5CF0}
.wbjj-table thead th{color:#fff;font-size:.72rem;font-weight:700;letter-spacing:.1em;text-transform:uppercase;padding:1rem 1.2rem;text-align:left;white-space:nowrap}
.wbjj-table tbody tr{border-bottom:1px solid #f0f0f0;transition:background .15s}
.wbjj-table tbody tr:last-child{border-bottom:none}
.wbjj-table tbody tr:hover{background:#faf8ff}
.wbjj-table td{padding:1rem 1.2rem;font-size:.88rem;color:#222;vertical-align:middle}
.wbjj-td-nom{display:flex;align-items:center;gap:.75rem}
.wbjj-ibjjf{text-align:center;font-size:1.1rem}
@media(max-width:640px){
.wbjj-desktop{display:none}
.wbjj-mobile{display:flex;flex-direction:column;gap:1rem}
.wbjj-card{background:#fff;border-radius:14px;box-shadow:0 2px 16px rgba(0,0,0,.09);overflow:hidden}
.wbjj-card-top{display:flex;align-items:center;gap:.75rem;padding:.9rem 1rem;border-bottom:1px solid #f2f2f2}
.wbjj-card-avis{padding:.65rem 1rem .4rem;font-size:.82rem;color:#555;line-height:1.4}
.wbjj-card-row{display:flex;align-items:center;justify-content:space-between;padding:.4rem 1rem .65rem}
.wbjj-card-ibjjf{font-size:.82rem;color:#555}
.wbjj-card-cta{padding:.75rem 1rem;border-top:1px solid #f2f2f2}
.wbjj-btn-full{display:block;width:100%;text-align:center;background:#C8A84B;color:#fff!important;font-size:.9rem;font-weight:700;padding:.75rem;border-radius:8px;text-decoration:none!important;box-sizing:border-box}
}

/* ───── Bandeau "code promo applicable" (compare + top3) ───── */
.wbjj-promo-banner{display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:6px;margin-top:14px;padding:10px 16px;background:#FFF8E7;border:.5px solid #C9A84C;border-radius:8px;font-size:.85rem;color:#633806}
.wbjj-promo-banner strong{color:#111}
.wbjj-promo-banner-code{display:inline-block;background:#C9A84C;color:#000;font-weight:700;font-size:.8rem;padding:3px 10px;border-radius:4px;letter-spacing:.05em}

/* ───── 7. CLUB — Bloc partenaire violet ───── */
.bdz-clubpro{margin:36px 0;border-radius:22px;overflow:hidden;background:#fff;box-shadow:0 8px 32px rgba(0,0,0,.10);font-family:-apple-system,BlinkMacSystemFont,'Segoe UI',Inter,sans-serif}

/* Header violet */
.bdz-clubpro-header{background:linear-gradient(135deg,#7B5CF0 0%,#6B47E8 100%);padding:38px 44px 40px;color:#fff;position:relative}
.bdz-clubpro-pills{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:22px}
.bdz-clubpro-pill{display:inline-flex;align-items:center;gap:7px;padding:6px 14px;background:rgba(255,255,255,.12);border:1px solid rgba(255,255,255,.18);border-radius:24px;font-size:12.5px;font-weight:500;color:#fff;backdrop-filter:blur(6px)}
.bdz-clubpro-pill-expire{background:transparent;border-color:rgba(255,255,255,.28)}
.bdz-clubpro-dot{width:7px;height:7px;border-radius:50%;background:#C9A84C}
.bdz-clubpro-title{font-size:38px;font-weight:800;color:#fff;line-height:1.1;margin:0 0 14px;letter-spacing:-.02em}
.bdz-clubpro-subtitle{font-size:14.5px;color:rgba(255,255,255,.78);line-height:1.55;margin:0;max-width:720px}

/* Grid 3 produits */
.bdz-clubpro-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;padding:22px}
.bdz-clubpro-card{display:flex;flex-direction:column;background:#fff;border:1px solid #eaeaf0;border-radius:14px;overflow:hidden;text-decoration:none!important;color:#111!important;transition:border-color .18s,transform .18s,box-shadow .18s}
.bdz-clubpro-card:hover{border-color:#7B5CF0;transform:translateY(-3px);box-shadow:0 8px 24px rgba(123,92,240,.15)}
.bdz-clubpro-img{width:100%;aspect-ratio:1/1;background:#f3f1fa;overflow:hidden}
.bdz-clubpro-img img{width:100%;height:100%;object-fit:cover;display:block}
.bdz-clubpro-cardbody{padding:14px 16px 16px;display:flex;flex-direction:column;gap:5px}
.bdz-clubpro-brand{font-size:10.5px;font-weight:700;color:#7B5CF0;text-transform:uppercase;letter-spacing:.08em}
.bdz-clubpro-name{font-size:14px;font-weight:600;color:#111;line-height:1.35;margin-bottom:4px}
.bdz-clubpro-price{display:flex;align-items:baseline;gap:8px;flex-wrap:wrap}
.bdz-clubpro-price .wbjj-prix{font-size:17px;font-weight:800;color:#111;display:inline}
.bdz-clubpro-price .wbjj-barre{font-size:13px;color:#aaa;display:inline;text-decoration:line-through;font-weight:500}
.bdz-clubpro-price .wbjj-promo{display:none}

/* Footer code promo + CTA */
.bdz-clubpro-footer{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:22px 28px 26px;border-top:1px solid #f0f0f1;flex-wrap:wrap}
.bdz-clubpro-footer-left{display:flex;flex-direction:column;gap:8px;min-width:0}
.bdz-clubpro-codelabel{font-size:12.5px;color:#666}
.bdz-clubpro-codeline{display:flex;align-items:center;gap:10px;flex-wrap:wrap}
.bdz-clubpro-code{display:inline-block;background:#C9A84C;color:#000;font-weight:800;font-size:14px;padding:7px 14px;border-radius:8px;letter-spacing:.05em;font-family:ui-monospace,Menlo,monospace}
.bdz-clubpro-codetag{display:inline-block;background:#E8F7EF;color:#1a6640;font-size:12px;font-weight:600;padding:5px 11px;border-radius:6px}
.bdz-clubpro-cta{display:inline-flex;align-items:center;justify-content:center;background:#7B5CF0;color:#fff!important;font-size:15px;font-weight:700;padding:14px 26px;border-radius:12px;text-decoration:none!important;white-space:nowrap;transition:background .15s,transform .15s;box-shadow:0 4px 14px rgba(123,92,240,.32)}
.bdz-clubpro-cta:hover{background:#6B47E8;transform:translateY(-1px)}

@media(max-width:780px){
.bdz-clubpro-header{padding:30px 24px 32px}
.bdz-clubpro-title{font-size:28px}
.bdz-clubpro-grid{grid-template-columns:1fr;gap:14px;padding:18px}
.bdz-clubpro-card{flex-direction:row}
.bdz-clubpro-img{width:110px;height:110px;aspect-ratio:auto;flex-shrink:0}
.bdz-clubpro-cardbody{flex:1;padding:12px 14px;justify-content:center}
.bdz-clubpro-footer{flex-direction:column;align-items:stretch;padding:18px 22px 22px}
.bdz-clubpro-cta{width:100%;text-align:center}
}

/* ───── 6. TOP 3 PODIUM ───── */
.bdz-top3{display:grid;grid-template-columns:repeat(3,1fr);gap:18px;margin:28px 0;font-family:inherit}
.bdz-top3-card{position:relative;background:#fff;border-radius:14px;box-shadow:0 4px 20px rgba(0,0,0,.08);overflow:hidden;display:flex;flex-direction:column;border:1px solid #eee}
.bdz-top3-rank-1{box-shadow:0 6px 28px rgba(201,168,76,.25);border-color:#C9A84C}
.bdz-top3-medal{position:absolute;top:10px;left:10px;font-size:28px;z-index:2;filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}
.bdz-top3-img{width:100%;aspect-ratio:1/1;overflow:hidden;background:#f5f5f5}
.bdz-top3-img img{width:100%;height:100%;object-fit:cover;display:block}
.bdz-top3-body{padding:14px 14px 16px;display:flex;flex-direction:column;gap:6px;flex:1}
.bdz-top3-badge{display:inline-block;background:#f3f0ff;color:#7B5CF0;font-size:10px;font-weight:600;padding:2px 8px;border-radius:12px;width:fit-content;text-transform:uppercase;letter-spacing:.04em}
.bdz-top3-name{font-size:14px;font-weight:700;color:#111;margin:0;line-height:1.3}
.bdz-top3-avis{font-size:12px;color:#555;line-height:1.45;margin:0;flex:1}
.bdz-top3-bottom{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-top:8px;padding-top:10px;border-top:1px solid #f0f0f0;flex-wrap:wrap}
.bdz-top3-cta{background:#1A1A2E;color:#fff!important;font-size:12px;font-weight:700;padding:7px 12px;border-radius:6px;text-decoration:none!important;white-space:nowrap}
@media(max-width:640px){
.bdz-top3{grid-template-columns:1fr;gap:14px}
}
