/* =====================================================================
   Le Mag d'OkCroisiere - Podcasts
   Design epure / "luxueux" : bleu marine, blanc, touches dorees.
   Portee scoping sous .mag pour ne pas impacter le reste du site.
   ===================================================================== */
.mag {
    --mag-navy: #0b1f3a;
    --mag-navy-2: #13315c;
    --mag-gold: #c9a24b;
    --mag-gold-soft: #e7d6a8;
    --mag-ink: #1c2531;
    --mag-muted: #5d6b7e;
    --mag-line: #e6e9ef;
    --mag-bg: #f7f8fb;
    color: var(--mag-ink);
    font-family: 'Inter', system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
}

/* ---------- Hero / en-tete de section ---------- */
.mag-hero {
    background: linear-gradient(135deg, var(--mag-navy) 0%, var(--mag-navy-2) 100%);
    color: #fff;
    padding: 4rem 0 3.25rem;
    position: relative;
    overflow: hidden;
}
.mag-hero::after {
    content: "";
    position: absolute; inset: auto 0 0 0; height: 3px;
    background: linear-gradient(90deg, transparent, var(--mag-gold), transparent);
}
.mag-hero .mag-eyebrow {
    display: inline-flex; align-items: center; gap: .5rem;
    letter-spacing: .18em; text-transform: uppercase; font-size: .72rem; font-weight: 700;
    color: var(--mag-gold-soft); margin-bottom: .9rem;
}
.mag-hero .mag-eyebrow::before { content: ""; width: 26px; height: 1px; background: var(--mag-gold); }
.mag-hero h1 { font-size: clamp(1.7rem, 3.4vw, 2.6rem); font-weight: 800; line-height: 1.12; margin: 0 0 1rem; }
.mag-hero p { color: #cdd6e4; max-width: 720px; font-size: 1.05rem; line-height: 1.65; margin: 0; }

/* ---------- Fil d'Ariane ---------- */
.mag-breadcrumb { font-size: .82rem; color: var(--mag-muted); padding: 1rem 0; }
.mag-breadcrumb a { color: var(--mag-muted); text-decoration: none; }
.mag-breadcrumb a:hover { color: var(--mag-navy); }
.mag-breadcrumb .sep { margin: 0 .45rem; color: #b9c0cc; }

/* ---------- Grille de podcasts (listing) ---------- */
.mag-section { padding: 2.5rem 0 3.5rem; background: var(--mag-bg); }
.mag-grid { display: grid; grid-template-columns: repeat(auto-fill, minmax(320px, 1fr)); gap: 1.75rem; }
.mag-card {
    background: #fff; border: 1px solid var(--mag-line); border-radius: 16px; overflow: hidden;
    display: flex; flex-direction: column; text-decoration: none; color: inherit;
    transition: transform .25s ease, box-shadow .25s ease, border-color .25s ease;
}
.mag-card:hover { transform: translateY(-4px); box-shadow: 0 18px 40px rgba(11,31,58,.14); border-color: var(--mag-gold-soft); }
.mag-card-media { position: relative; aspect-ratio: 16/9; background: #0b1f3a; overflow: hidden; }
.mag-card-media img { width: 100%; height: 100%; object-fit: cover; display: block; transition: transform .4s ease; }
.mag-card:hover .mag-card-media img { transform: scale(1.05); }
.mag-card-play {
    position: absolute; inset: 0; display: flex; align-items: center; justify-content: center;
    background: linear-gradient(180deg, rgba(11,31,58,.05), rgba(11,31,58,.45));
}
.mag-card-play i {
    width: 58px; height: 58px; border-radius: 50%; background: rgba(255,255,255,.92); color: var(--mag-navy);
    display: flex; align-items: center; justify-content: center; font-size: 1.15rem;
    box-shadow: 0 6px 18px rgba(0,0,0,.25); transition: transform .2s ease, background .2s ease;
}
.mag-card:hover .mag-card-play i { transform: scale(1.08); background: var(--mag-gold); color: #fff; }
.mag-card-duration {
    position: absolute; bottom: 10px; right: 10px; background: rgba(11,31,58,.85); color: #fff;
    font-size: .72rem; font-weight: 600; padding: 3px 9px; border-radius: 20px;
}
.mag-card-body { padding: 1.15rem 1.25rem 1.35rem; display: flex; flex-direction: column; gap: .55rem; flex: 1; }
.mag-card-tags { display: flex; flex-wrap: wrap; gap: .4rem; }
.mag-chip {
    font-size: .68rem; font-weight: 700; letter-spacing: .04em; text-transform: uppercase;
    color: var(--mag-navy); background: #eef2f8; border-radius: 20px; padding: 3px 10px;
}
.mag-chip.gold { color: #8a6d1f; background: #f6edd6; }
.mag-card-title { font-size: 1.12rem; font-weight: 700; line-height: 1.3; margin: 0; }
.mag-card-excerpt { font-size: .9rem; color: var(--mag-muted); line-height: 1.55; margin: 0; }
.mag-card-foot { margin-top: auto; padding-top: .6rem; display: flex; align-items: center; gap: .5rem; font-size: .82rem; color: var(--mag-navy); font-weight: 600; }
.mag-card-foot i { color: var(--mag-gold); }

/* ---------- Page detail episode ---------- */
.mag-detail { background: #fff; }
.mag-article { padding: 2.25rem 0 3rem; }
.mag-article h1 { font-size: clamp(1.5rem, 3vw, 2.25rem); font-weight: 800; line-height: 1.15; color: var(--mag-navy); margin: 0 0 1rem; }
.mag-meta { display: flex; flex-wrap: wrap; gap: 1.1rem; align-items: center; color: var(--mag-muted); font-size: .88rem; margin-bottom: 1.5rem; }
.mag-meta .mag-meta-item { display: inline-flex; align-items: center; gap: .45rem; }
.mag-meta .mag-meta-item i { color: var(--mag-gold); }

/* lecteur video responsive */
.mag-embed { position: relative; width: 100%; aspect-ratio: 16/9; border-radius: 14px; overflow: hidden; background: #000; box-shadow: 0 14px 38px rgba(11,31,58,.22); }
.mag-embed iframe { position: absolute; inset: 0; width: 100%; height: 100%; border: 0; }

.mag-intro { font-size: 1.08rem; line-height: 1.7; color: var(--mag-ink); margin: 1.75rem 0; }
.mag-intro p:first-child { margin-top: 0; }

/* Points cles / sommaire */
.mag-keypoints { background: var(--mag-bg); border: 1px solid var(--mag-line); border-radius: 16px; padding: 1.5rem 1.6rem; margin: 2rem 0; }
.mag-keypoints h2 { font-size: 1.15rem; font-weight: 800; color: var(--mag-navy); margin: 0 0 1.1rem; display: flex; align-items: center; gap: .55rem; }
.mag-keypoints h2 i { color: var(--mag-gold); }
.mag-kp-list { list-style: none; margin: 0; padding: 0; display: flex; flex-direction: column; gap: .9rem; }
.mag-kp { display: flex; gap: .9rem; align-items: flex-start; }
.mag-kp-time {
    flex: 0 0 auto; min-width: 54px; text-align: center; font-variant-numeric: tabular-nums; font-weight: 700; font-size: .82rem;
    color: var(--mag-navy); background: #fff; border: 1px solid var(--mag-line); border-radius: 8px; padding: 4px 8px; cursor: pointer; text-decoration: none;
    transition: background .2s ease, color .2s ease, border-color .2s ease;
}
a.mag-kp-time:hover { background: var(--mag-gold); color: #fff; border-color: var(--mag-gold); }
.mag-kp-time.is-static { background: transparent; border-color: transparent; color: var(--mag-gold); min-width: 0; padding: 4px 0; }
.mag-kp-body strong { color: var(--mag-navy); }
.mag-kp-body { font-size: .94rem; line-height: 1.55; color: var(--mag-ink); }

.mag-richtext { font-size: 1.02rem; line-height: 1.75; color: var(--mag-ink); }
.mag-richtext h2 { font-size: 1.4rem; font-weight: 800; color: var(--mag-navy); margin: 2.25rem 0 1rem; padding-bottom: .5rem; border-bottom: 2px solid var(--mag-gold-soft); }
.mag-richtext h3 { font-size: 1.12rem; font-weight: 800; color: var(--mag-navy-2); margin: 1.6rem 0 .55rem; }
.mag-richtext p { margin: 0 0 1rem; }
.mag-richtext ul { padding-left: 1.25rem; margin: .6rem 0 1.2rem; }
.mag-richtext li { margin: .35rem 0; }
.mag-richtext a { color: var(--mag-navy-2); font-weight: 600; }

/* tableau comparatif */
.mag-table { overflow-x: auto; margin: 1.4rem 0; border-radius: 12px; border: 1px solid var(--mag-line); }
.mag-richtext table { width: 100%; border-collapse: collapse; font-size: .93rem; min-width: 560px; }
.mag-richtext thead th { background: var(--mag-navy); color: #fff; text-align: left; padding: .85rem .95rem; font-weight: 700; }
.mag-richtext tbody td { padding: .8rem .95rem; border-top: 1px solid var(--mag-line); vertical-align: top; }
.mag-richtext tbody tr:nth-child(even) { background: var(--mag-bg); }
.mag-richtext tbody td:first-child { color: var(--mag-navy); white-space: nowrap; }

/* encadre "avis de l'expert" */
.mag-expert { background: #fbf6e9; border-left: 4px solid var(--mag-gold); border-radius: 10px; padding: 1.05rem 1.25rem; margin: 1.5rem 0; line-height: 1.65; }
.mag-expert strong { color: var(--mag-navy); }

/* CTA lateral / reservation */
.mag-cta {
    background: linear-gradient(135deg, var(--mag-navy) 0%, var(--mag-navy-2) 100%); color: #fff;
    border-radius: 16px; padding: 1.6rem 1.5rem; position: sticky; top: 90px;
}
.mag-cta .mag-cta-eyebrow { letter-spacing: .14em; text-transform: uppercase; font-size: .68rem; font-weight: 700; color: var(--mag-gold-soft); }
.mag-cta h3 { font-size: 1.2rem; font-weight: 800; margin: .5rem 0 .35rem; line-height: 1.25; }
.mag-cta p { color: #c6d0df; font-size: .9rem; line-height: 1.55; margin: 0 0 1.1rem; }
.mag-btn {
    display: inline-flex; align-items: center; justify-content: center; gap: .5rem; width: 100%;
    background: var(--mag-gold); color: #1a1305; font-weight: 700; text-decoration: none;
    padding: .8rem 1rem; border-radius: 10px; transition: filter .2s ease, transform .2s ease;
}
.mag-btn:hover { filter: brightness(1.06); transform: translateY(-1px); color: #1a1305; }
.mag-btn.ghost { background: transparent; border: 1px solid rgba(255,255,255,.35); color: #fff; margin-top: .6rem; }
.mag-btn.ghost:hover { background: rgba(255,255,255,.08); color: #fff; }

/* CTA abonnement YouTube */
.mag-subscribe { display: inline-flex; align-items: center; gap: .55rem; background: #ff0000; color: #fff; font-weight: 700; text-decoration: none; padding: .65rem 1.15rem; border-radius: 10px; }
.mag-subscribe:hover { color: #fff; filter: brightness(1.05); }

@media (max-width: 991px) {
    .mag-cta { position: static; margin-top: 2rem; }
}
@media (max-width: 575px) {
    .mag-hero { padding: 2.75rem 0 2.25rem; }
    .mag-grid { grid-template-columns: 1fr; }
}
