/* ═══════════════════════════════════════════════════════════════════════════
   MediaHub — Plugin CSS
   Utilise les variables Bootstrap / Flatboard pour une intégration transparente
   ═══════════════════════════════════════════════════════════════════════════ */

/* ── Card principale ─────────────────────────────────────────────────────── */
.mediahub-card {
    border: 1px solid var(--bs-border-color);
    border-radius: 0.75rem;
    overflow: hidden;
    background: var(--bs-body-bg);
    box-shadow: 0 2px 12px rgba(0,0,0,.08);
    container-type: inline-size;
}

/* ── Backdrop ────────────────────────────────────────────────────────────── */
.mediahub-backdrop {
    height: 200px;
    background-size: cover;
    background-position: center 30%;
    position: relative;
}

@container (min-width: 600px) {
    .mediahub-backdrop { height: 260px; }
}

.mediahub-backdrop-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to bottom, rgba(0,0,0,.1) 0%, rgba(0,0,0,.55) 100%);
}

/* ── Corps ───────────────────────────────────────────────────────────────── */
.mediahub-body {
    padding: 1.25rem;
}

.mediahub-body--has-backdrop {
    margin-top: -3rem;
    position: relative;
    z-index: 1;
}

/* ── Ligne affiche + infos ───────────────────────────────────────────────── */
.mediahub-header-row {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
    margin-bottom: 1.5rem;
}

/* ── Affiche ─────────────────────────────────────────────────────────────── */
.mediahub-poster-wrap {
    position: relative;
    flex-shrink: 0;
    width: 120px;
}

@container (min-width: 480px) {
    .mediahub-poster-wrap { width: 160px; }
}
@container (min-width: 720px) {
    .mediahub-poster-wrap { width: 200px; }
}

.mediahub-poster {
    width: 100%;
    height: auto;
    border-radius: 0.5rem;
    display: block;
    box-shadow: 0 4px 20px rgba(0,0,0,.25);
    object-fit: cover;
    aspect-ratio: 2/3;
}

/* ── Badge de note ───────────────────────────────────────────────────────── */
.mediahub-rating-badge {
    position: absolute;
    bottom: -10px;
    right: -10px;
    background: var(--bs-warning);
    color: #000;
    border-radius: 50%;
    width: 48px;
    height: 48px;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    line-height: 1;
    box-shadow: 0 2px 8px rgba(0,0,0,.3);
    border: 2px solid var(--bs-body-bg);
}

.mediahub-rating-badge--mc {
    background: #ffcc00;
}

.mediahub-rating-score {
    font-size: .85rem;
    font-weight: 700;
}

.mediahub-rating-max {
    font-size: .55rem;
    opacity: .75;
}

/* ── Infos ───────────────────────────────────────────────────────────────── */
.mediahub-info {
    flex: 1;
    min-width: 0;
}

.mediahub-type-badge {
    display: inline-block;
    font-size: .7rem;
    font-weight: 600;
    text-transform: uppercase;
    letter-spacing: .06em;
    color: var(--bs-primary);
    background: rgba(var(--bs-primary-rgb), .1);
    padding: .2em .6em;
    border-radius: 2rem;
    margin-bottom: .4rem;
}

.mediahub-title {
    font-size: 1.35rem;
    font-weight: 700;
    line-height: 1.2;
    margin-bottom: .3rem;
    color: var(--bs-emphasis-color);
}

.mediahub-year {
    font-size: .85em;
    color: var(--bs-secondary-color);
    font-weight: 400;
}

.mediahub-tagline {
    font-style: italic;
    color: var(--bs-secondary-color);
    font-size: .9rem;
    margin-bottom: .6rem;
}

/* ── Genres ──────────────────────────────────────────────────────────────── */
.mediahub-genre-badge {
    display: inline-block;
    font-size: .72rem;
    padding: .2em .6em;
    background: var(--bs-secondary-bg);
    color: var(--bs-secondary-color);
    border: 1px solid var(--bs-border-color);
    border-radius: 2rem;
    margin-right: .3rem;
    margin-bottom: .3rem;
}

/* ── Faits techniques ────────────────────────────────────────────────────── */
.mediahub-quick-facts {
    display: grid;
    grid-template-columns: 1fr;
    gap: .25rem;
    margin: .75rem 0;
}

@container (min-width: 400px) {
    .mediahub-quick-facts {
        grid-template-columns: 1fr 1fr;
    }
}

.mediahub-fact-row {
    display: flex;
    gap: .4rem;
    font-size: .82rem;
    line-height: 1.4;
}

.mediahub-fact-row dt {
    color: var(--bs-secondary-color);
    white-space: nowrap;
    font-weight: 500;
    min-width: 80px;
}

.mediahub-fact-row dt::after { content: ' :'; }

.mediahub-fact-row dd {
    margin: 0;
    color: var(--bs-body-color);
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
}

/* ── Liens externes ──────────────────────────────────────────────────────── */
.mediahub-ext-links {
    display: flex;
    flex-wrap: wrap;
    gap: .4rem;
}

.mediahub-ext-link {
    display: inline-flex;
    align-items: center;
    font-size: .78rem;
    padding: .25em .7em;
    border-radius: .4rem;
    text-decoration: none;
    background: var(--bs-secondary-bg);
    color: var(--bs-body-color);
    border: 1px solid var(--bs-border-color);
    transition: background .15s, color .15s;
}

.mediahub-ext-link:hover {
    background: var(--bs-primary);
    color: #fff;
    border-color: var(--bs-primary);
}

.mediahub-ext-link--imdb  { background: #f5c518; color: #000; border-color: #f5c518; }
.mediahub-ext-link--imdb:hover { background: #d4aa15; }

.mediahub-ext-link--steam { background: #1b2838; color: #c6d4df; border-color: #1b2838; }
.mediahub-ext-link--steam:hover { background: #2a475e; }

.mediahub-ext-link--mc    { background: #ffcc00; color: #000; border-color: #ffcc00; }

/* ── Sections ────────────────────────────────────────────────────────────── */
.mediahub-section {
    border-top: 1px solid var(--bs-border-color);
    padding-top: 1.25rem;
    margin-top: 1.25rem;
}

.mediahub-section-title {
    font-size: 1rem;
    font-weight: 700;
    color: var(--bs-emphasis-color);
    margin-bottom: .85rem;
    display: flex;
    align-items: center;
}

/* ── Synopsis ────────────────────────────────────────────────────────────── */
.mediahub-synopsis {
    color: var(--bs-secondary-color);
    line-height: 1.7;
    font-size: .95rem;
    margin: 0;
}

/* ── Casting grid ────────────────────────────────────────────────────────── */
.mediahub-cast-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(90px, 1fr));
    gap: .75rem;
}

@container (min-width: 480px) {
    .mediahub-cast-grid {
        grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    }
}

.mediahub-cast-card {
    text-align: center;
    font-size: .78rem;
}

.mediahub-cast-photo {
    width: 100%;
    aspect-ratio: 1/1.4;
    object-fit: cover;
    border-radius: .4rem;
    display: block;
    margin-bottom: .35rem;
    background: var(--bs-secondary-bg);
}

.mediahub-cast-no-photo {
    width: 100%;
    aspect-ratio: 1/1.4;
    border-radius: .4rem;
    background: var(--bs-secondary-bg);
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: 1.5rem;
    color: var(--bs-secondary-color);
    margin-bottom: .35rem;
}

.mediahub-cast-name {
    display: block;
    font-weight: 600;
    line-height: 1.2;
    color: var(--bs-body-color);
}

.mediahub-cast-role {
    display: block;
    color: var(--bs-secondary-color);
    line-height: 1.2;
    margin-top: .1rem;
    font-style: italic;
    overflow: hidden;
    text-overflow: ellipsis;
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
}

/* ── Bande-annonce ───────────────────────────────────────────────────────── */
.mediahub-trailer-wrap {
    border-radius: .5rem;
    overflow: hidden;
    background: #000;
}

.mediahub-trailer-thumb {
    position: relative;
    display: block;
    line-height: 0;
}

.mediahub-trailer-img {
    width: 100%;
    height: auto;
    display: block;
    opacity: .85;
    transition: opacity .2s;
}

.mediahub-trailer-thumb:hover .mediahub-trailer-img {
    opacity: 1;
}

.mediahub-trailer-play {
    position: absolute;
    inset: 0;
    display: flex;
    align-items: center;
    justify-content: center;
    font-size: clamp(2.5rem, 8cqi, 5rem);
    color: #ff0000;
    text-shadow: 0 0 30px rgba(0,0,0,.6);
    transition: transform .2s;
    pointer-events: none;
}

.mediahub-trailer-thumb:hover .mediahub-trailer-play {
    transform: scale(1.12);
}

.mediahub-trailer-iframe {
    width: 100%;
    aspect-ratio: 16/9;
    display: block;
    border: 0;
}

.mediahub-trailer-video {
    width: 100%;
    display: block;
}

/* ── Screenshots ─────────────────────────────────────────────────────────── */
.mediahub-screenshots {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
    gap: .5rem;
}

@container (min-width: 600px) {
    .mediahub-screenshots {
        grid-template-columns: repeat(auto-fill, minmax(220px, 1fr));
    }
}

.mediahub-screenshot-thumb {
    display: block;
    overflow: hidden;
    border-radius: .35rem;
    line-height: 0;
    background: var(--bs-secondary-bg);
    aspect-ratio: 16/9;
}

.mediahub-screenshot-thumb img {
    width: 100%;
    height: 100%;
    object-fit: cover;
    transition: transform .3s, opacity .2s;
    opacity: .9;
}

.mediahub-screenshot-thumb:hover img {
    transform: scale(1.04);
    opacity: 1;
}

/* ── Widget formulaire ───────────────────────────────────────────────────── */
.mediahub-widget {
    transition: opacity .25s;
}

.mediahub-widget[aria-hidden="true"] {
    display: none !important;
}

/* ── Dark mode ───────────────────────────────────────────────────────────── */
[data-bs-theme="dark"] .mediahub-card,
html[data-theme="dark"] .mediahub-card {
    box-shadow: 0 2px 12px rgba(0,0,0,.35);
}

[data-bs-theme="dark"] .mediahub-rating-badge,
html[data-theme="dark"] .mediahub-rating-badge {
    background: #e6b800;
}

[data-bs-theme="dark"] .mediahub-ext-link--imdb,
html[data-theme="dark"] .mediahub-ext-link--imdb {
    background: #c9a20e;
}
