/* ── RGD TMDB Section v2.1 ── */
/* ---- Variables ---- */
:root {
    --tmdb-red:    #E8000D;
    --tmdb-gold:   #C8A84B;
    --tmdb-dark:   #0A0A0A;
    --tmdb-card:   #111827;
    --tmdb-border: rgba(255,255,255,0.07);
    --tmdb-text:   #F0F0F0;
    --tmdb-muted:  #888;
}

/* ---- Wrap section ---- */
.rgd-tmdb2-wrap {
    margin: 0 0 48px;
    font-family: "Barlow Condensed", "Barlow", sans-serif;
    -webkit-font-smoothing: antialiased;
}
.rgd-tmdb2-header {
    display: flex;
    align-items: baseline;
    justify-content: space-between;
    margin-bottom: 18px;
    gap: 12px;
}
.rgd-tmdb2-title {
    font-size: 20px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    color: inherit;
    margin: 0;
}

/* ---- Grille responsive ---- */
.rgd-tmdb2-grid {
    display: grid;
    gap: 14px;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
}

/* ---- Carte film/série ---- */
.rgd-tmdb2-card {
    display: block;
    text-decoration: none !important;
    color: inherit !important;
    position: relative;
    cursor: pointer;
}
.rgd-tmdb2-card:hover { text-decoration: none !important; }

.rgd-tmdb2-poster {
    aspect-ratio: 2/3;
    background: #111 center/cover no-repeat;
    border-radius: 10px;
    overflow: hidden;
    position: relative;
    margin-bottom: 8px;
    transition: transform 0.25s ease, box-shadow 0.25s ease;
    box-shadow: 0 4px 12px rgba(0,0,0,0.3);
}
.rgd-tmdb2-card:hover .rgd-tmdb2-poster {
    transform: scale(1.03) translateY(-3px);
    box-shadow: 0 12px 32px rgba(0,0,0,0.6);
}

/* Overlay au hover style JustWatch */
.rgd-tmdb2-poster-overlay {
    position: absolute;
    inset: 0;
    background: linear-gradient(to top,
        rgba(0,0,0,0.88) 0%,
        rgba(0,0,0,0.4) 45%,
        rgba(0,0,0,0.1) 100%);
    opacity: 0;
    transition: opacity 0.22s;
    border-radius: 10px;
    display: flex;
    flex-direction: column;
    justify-content: flex-end;
    padding: 12px;
}
.rgd-tmdb2-card:hover .rgd-tmdb2-poster-overlay { opacity: 1; }

/* Bouton play au hover */
.rgd-tmdb2-play-hint {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 6px;
    background: rgba(232,0,13,0.9);
    color: #fff;
    font-family: "Barlow Condensed", sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 7px 12px;
    border-radius: 4px;
    margin-bottom: 6px;
    backdrop-filter: blur(4px);
}
.rgd-tmdb2-play-hint svg { width: 12px; height: 12px; flex-shrink: 0; }

/* Synopsis court au hover */
.rgd-tmdb2-hover-desc {
    font-size: 10px;
    color: rgba(255,255,255,0.75);
    line-height: 1.4;
    display: -webkit-box;
    -webkit-line-clamp: 3;
    -webkit-box-orient: vertical;
    overflow: hidden;
    font-family: "Barlow", sans-serif;
}

/* Badges */
.rgd-tmdb2-badge {
    position: absolute;
    top: 8px;
    left: 8px;
    background: rgba(0,0,0,0.65);
    color: rgba(255,255,255,0.8);
    font-size: 9px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    padding: 2px 6px;
    border-radius: 3px;
    backdrop-filter: blur(4px);
}
.rgd-tmdb2-score {
    position: absolute;
    top: 8px;
    right: 8px;
    background: rgba(0,0,0,0.7);
    color: #fbbf24;
    font-size: 11px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 3px;
}
.rgd-tmdb2-card-title {
    font-size: 12px;
    font-weight: 700;
    color: rgba(255,255,255,0.85);
    line-height: 1.3;
    margin-bottom: 2px;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}
.rgd-tmdb2-card-meta {
    font-size: 10px;
    color: rgba(255,255,255,0.4);
}

/* ---- Section prochainement ---- */
.rgd-tmdb2-timeline { display: flex; flex-direction: column; gap: 0; }
.rgd-tmdb2-month-label {
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.14em;
    text-transform: uppercase;
    color: #C8A84B;
    padding: 14px 0 8px;
    display: flex;
    align-items: center;
    gap: 10px;
}
.rgd-tmdb2-month-label::after {
    content: "";
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,0.08);
}
.rgd-tmdb2-upcoming-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
    margin-bottom: 8px;
}
.rgd-tmdb2-upcoming-card {
    display: block;
    text-decoration: none !important;
    color: inherit !important;
    transition: transform 0.2s;
}
.rgd-tmdb2-upcoming-card:hover { transform: translateY(-2px); }
.rgd-tmdb2-upcoming-poster {
    aspect-ratio: 2/3;
    background: #111 center/cover no-repeat;
    border-radius: 8px;
    position: relative;
    margin-bottom: 6px;
}
.rgd-tmdb2-release-date {
    position: absolute;
    bottom: 6px;
    left: 6px;
    background: rgba(232,0,13,0.9);
    color: #fff;
    font-size: 9px;
    font-weight: 700;
    padding: 2px 6px;
    border-radius: 3px;
}
.rgd-tmdb2-upcoming-title {
    font-size: 11px;
    font-weight: 700;
    color: rgba(255,255,255,0.8);
    line-height: 1.3;
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* ---- Tabs genres / plateformes ---- */
.rgd-tmdb2-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 6px;
    margin-bottom: 14px;
}
.rgd-tmdb2-tab {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    padding: 6px 14px;
    border-radius: 99px;
    border: 1px solid rgba(255,255,255,0.15);
    background: transparent;
    color: rgba(255,255,255,0.6);
    font-family: "Barlow Condensed", sans-serif;
    font-size: 12px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
    cursor: pointer;
    transition: all 0.18s;
    white-space: nowrap;
}
.rgd-tmdb2-tab:hover {
    border-color: rgba(255,255,255,0.35);
    color: #fff;
    background: rgba(255,255,255,0.06);
}
.rgd-tmdb2-tab.active {
    background: #E8000D;
    border-color: #E8000D;
    color: #fff;
}
.rgd-tmdb2-provider-dot {
    width: 8px;
    height: 8px;
    border-radius: 50%;
    flex-shrink: 0;
}

/* ---- Fiche detail ---- */
.rgd-tmdb2-detail {
    font-family: "Barlow", sans-serif;
    -webkit-font-smoothing: antialiased;
    color: var(--tmdb-text);
}
.rgd-tmdb2-detail-backdrop {
    position: relative;
    width: 100%;
    min-height: 420px;
    background: #0d0d0d center/cover no-repeat;
    overflow: hidden;
}
.rgd-tmdb2-detail-backdrop::after {
    content: "";
    position: absolute;
    inset: 0;
    background:
        linear-gradient(to right, rgba(0,0,0,0.92) 0%, rgba(0,0,0,0.55) 55%, rgba(0,0,0,0.15) 100%),
        linear-gradient(to top, rgba(0,0,0,0.85) 0%, transparent 40%);
}
.rgd-tmdb2-detail-inner {
    position: relative;
    z-index: 1;
    max-width: 1100px;
    margin: 0 auto;
    padding: 48px 28px;
    display: grid;
    grid-template-columns: 220px 1fr;
    gap: 36px;
    align-items: end;
    min-height: 420px;
}
.rgd-tmdb2-detail-poster-wrap {
    border-radius: 14px;
    overflow: hidden;
    box-shadow: 0 20px 50px rgba(0,0,0,0.6);
    align-self: center;
}
.rgd-tmdb2-detail-poster-wrap img {
    display: block;
    width: 100%;
    height: auto;
}
.rgd-tmdb2-detail-type {
    font-family: "Barlow Condensed", sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: #E8000D;
    margin-bottom: 6px;
}
.rgd-tmdb2-detail-title {
    font-family: "Barlow Condensed", sans-serif;
    font-size: clamp(28px, 4vw, 48px);
    font-weight: 800;
    letter-spacing: 0.02em;
    line-height: 1.05;
    color: #fff;
    margin: 0 0 8px;
}
.rgd-tmdb2-detail-tagline {
    font-style: italic;
    color: rgba(255,255,255,0.6);
    font-size: 15px;
    margin: 0 0 14px;
}
.rgd-tmdb2-detail-pills {
    display: flex;
    flex-wrap: wrap;
    gap: 8px;
    margin-bottom: 14px;
}
.rgd-tmdb2-detail-pill {
    padding: 5px 11px;
    border-radius: 99px;
    font-family: "Barlow Condensed", sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.06em;
    text-transform: uppercase;
}
.rgd-tmdb2-pill-score { background: #f97316; color: #fff; }
.rgd-tmdb2-pill-year  { background: rgba(255,255,255,0.1); color: rgba(255,255,255,0.75); }
.rgd-tmdb2-pill-genre { background: rgba(255,255,255,0.08); color: rgba(255,255,255,0.6); border: 1px solid rgba(255,255,255,0.1); }
.rgd-tmdb2-pill-dur   { background: rgba(255,255,255,0.06); color: rgba(255,255,255,0.45); border: 1px solid rgba(255,255,255,0.07); }
.rgd-tmdb2-detail-overview {
    font-size: 14px;
    line-height: 1.75;
    color: rgba(255,255,255,0.72);
    max-width: 640px;
    margin: 0 0 20px;
}
.rgd-tmdb2-detail-back {
    display: inline-flex;
    align-items: center;
    gap: 6px;
    font-family: "Barlow Condensed", sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.1em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.4);
    text-decoration: none;
    margin-bottom: 20px;
    transition: color 0.18s;
    display: block;
}
.rgd-tmdb2-detail-back:hover { color: rgba(255,255,255,0.8); }

/* Sections sous le backdrop */
.rgd-tmdb2-detail-sections {
    max-width: 1100px;
    margin: 0 auto;
    padding: 32px 28px 64px;
}
.rgd-tmdb2-detail-cols {
    display: grid;
    grid-template-columns: 1fr 280px;
    gap: 36px;
}
.rgd-tmdb2-section-label {
    font-family: "Barlow Condensed", sans-serif;
    font-size: 11px;
    font-weight: 700;
    letter-spacing: 0.16em;
    text-transform: uppercase;
    color: rgba(255,255,255,0.35);
    margin-bottom: 14px;
    display: flex;
    align-items: center;
    gap: 8px;
}
.rgd-tmdb2-section-label::after {
    content: "";
    flex: 1;
    height: 1px;
    background: rgba(255,255,255,0.07);
}

/* Où regarder */
.rgd-tmdb2-providers { display: flex; flex-direction: column; gap: 14px; margin-bottom: 24px; }
.rgd-tmdb2-provider-group-label {
    font-family: "Barlow Condensed", sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: 0.12em;
    text-transform: uppercase;
    color: var(--tmdb-gold);
    margin-bottom: 8px;
}
.rgd-tmdb2-provider-list { display: flex; flex-wrap: wrap; gap: 8px; }
.rgd-tmdb2-provider-item {
    display: flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.05);
    border: 1px solid rgba(255,255,255,0.08);
    border-radius: 8px;
    padding: 6px 10px;
    transition: background 0.18s;
}
.rgd-tmdb2-provider-item:hover { background: rgba(255,255,255,0.1); }
.rgd-tmdb2-provider-item img {
    width: 28px;
    height: 28px;
    border-radius: 6px;
    object-fit: cover;
}
.rgd-tmdb2-provider-name {
    font-size: 11px;
    font-weight: 600;
    color: rgba(255,255,255,0.7);
    white-space: nowrap;
}

/* Casting */
.rgd-tmdb2-cast-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(80px, 1fr));
    gap: 10px;
    margin-bottom: 28px;
}
.rgd-tmdb2-cast-card {
    text-align: center;
}
.rgd-tmdb2-cast-photo {
    width: 100%;
    aspect-ratio: 2/3;
    background: #1f2937 center/cover no-repeat;
    border-radius: 8px;
    margin-bottom: 5px;
}
.rgd-tmdb2-cast-name {
    font-size: 10px;
    font-weight: 700;
    color: rgba(255,255,255,0.75);
    line-height: 1.2;
    margin-bottom: 2px;
}
.rgd-tmdb2-cast-role {
    font-size: 9px;
    color: rgba(255,255,255,0.4);
    white-space: nowrap;
    overflow: hidden;
    text-overflow: ellipsis;
}

/* Recommandations */
.rgd-tmdb2-reco-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(110px, 1fr));
    gap: 10px;
    margin-bottom: 28px;
}

/* Trailer */
.rgd-tmdb2-trailer-link {
    display: inline-flex;
    align-items: center;
    gap: 8px;
    background: rgba(255,255,255,0.06);
    border: 1px solid rgba(255,255,255,0.1);
    color: rgba(255,255,255,0.75);
    padding: 10px 16px;
    border-radius: 6px;
    font-size: 12px;
    font-weight: 700;
    font-family: "Barlow Condensed", sans-serif;
    letter-spacing: 0.08em;
    text-transform: uppercase;
    text-decoration: none;
    transition: background 0.18s;
}
.rgd-tmdb2-trailer-link:hover { background: rgba(255,255,255,0.12); color: #fff; }
.rgd-tmdb2-trailer-link svg { width: 14px; height: 14px; color: #E8000D; }

/* Message vide */
.rgd-tmdb2-empty {
    padding: 24px;
    border: 1px dashed rgba(255,255,255,0.1);
    border-radius: 10px;
    text-align: center;
    color: rgba(255,255,255,0.3);
    font-size: 13px;
}

/* ---- Responsive ---- */
@media (max-width: 1024px) {
    .rgd-tmdb2-detail-cols { grid-template-columns: 1fr; }
}
@media (max-width: 768px) {
    .rgd-tmdb2-grid {
        grid-template-columns: repeat(3, 1fr);
        gap: 10px;
    }
    .rgd-tmdb2-upcoming-grid { grid-template-columns: repeat(4, 1fr); }
    .rgd-tmdb2-detail-inner {
        grid-template-columns: 140px 1fr;
        gap: 20px;
        padding: 32px 18px;
        min-height: 320px;
    }
    .rgd-tmdb2-detail-sections { padding: 20px 18px 40px; }
    .rgd-tmdb2-cast-grid { grid-template-columns: repeat(4, 1fr); }
}
@media (max-width: 480px) {
    .rgd-tmdb2-grid { grid-template-columns: repeat(3, 1fr); gap: 8px; }
    .rgd-tmdb2-detail-inner { grid-template-columns: 1fr; }
    .rgd-tmdb2-detail-poster-wrap { display: none; }
    .rgd-tmdb2-detail-title { font-size: 26px; }
    .rgd-tmdb2-tabs { gap: 4px; }
    .rgd-tmdb2-tab { padding: 5px 10px; font-size: 11px; }
}

/* =========================================
   Responsive polish v2.1.1.2
   ========================================= */

.rgd-tmdb2-section,
.rgd-tmdb2-wrap {
  width: 100%;
}

.rgd-tmdb2-grid,
.rgd-tmdb-grid,
.rgd-tmdb-cards,
.rgd-tmdb-row {
  align-items: stretch;
}

.rgd-tmdb2-card,
.rgd-tmdb-card,
.rgd-tmdb-item {
  height: 100%;
  min-width: 0;
}

.rgd-tmdb2-card img,
.rgd-tmdb-card img,
.rgd-tmdb-thumb img,
.rgd-tmdb-poster img {
  display: block;
  width: 100%;
  height: auto;
}

.rgd-tmdb2-title,
.rgd-tmdb-title,
.rgd-tmdb-card-title {
  word-break: break-word;
}

@media (max-width: 1024px) {
  .rgd-tmdb2-grid,
  .rgd-tmdb-grid,
  .rgd-tmdb-cards,
  .rgd-tmdb-row {
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 14px !important;
  }
}

@media (max-width: 767px) {
  .rgd-tmdb2-grid,
  .rgd-tmdb-grid,
  .rgd-tmdb-cards,
  .rgd-tmdb-row {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 12px !important;
  }

  .rgd-tmdb2-card,
  .rgd-tmdb-card,
  .rgd-tmdb-item {
    border-radius: 14px !important;
    overflow: hidden !important;
  }

  .rgd-tmdb2-poster,
  .rgd-tmdb-poster,
  .rgd-tmdb-thumb,
  .rgd-tmdb-thumb img,
  .rgd-tmdb-card img {
    width: 100% !important;
    aspect-ratio: 2 / 3 !important;
    object-fit: cover !important;
  }

  .rgd-tmdb2-content,
  .rgd-tmdb-content,
  .rgd-tmdb-meta-wrap,
  .rgd-tmdb-caption {
    padding: 10px !important;
  }

  .rgd-tmdb2-title,
  .rgd-tmdb-title,
  .rgd-tmdb-card-title {
    font-size: 15px !important;
    line-height: 1.25 !important;
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
    min-height: 2.5em !important;
    margin-bottom: 6px !important;
  }

  .rgd-tmdb2-meta,
  .rgd-tmdb-meta,
  .rgd-tmdb-subtitle,
  .rgd-tmdb-year,
  .rgd-tmdb-type {
    font-size: 12px !important;
    line-height: 1.2 !important;
  }

  .rgd-tmdb2-section-title,
  .rgd-tmdb-section-title,
  .rgd-tmdb-heading {
    font-size: 22px !important;
    line-height: 1.15 !important;
    margin-bottom: 12px !important;
  }

  .rgd-tmdb2-wrap,
  .rgd-tmdb-wrap,
  .rgd-tmdb2-section,
  .rgd-tmdb-section {
    margin-bottom: 20px !important;
  }
}

@media (max-width: 480px) {
  .rgd-tmdb2-grid,
  .rgd-tmdb-grid,
  .rgd-tmdb-cards,
  .rgd-tmdb-row {
    gap: 10px !important;
  }

  .rgd-tmdb2-content,
  .rgd-tmdb-content,
  .rgd-tmdb-meta-wrap,
  .rgd-tmdb-caption {
    padding: 8px !important;
  }

  .rgd-tmdb2-title,
  .rgd-tmdb-title,
  .rgd-tmdb-card-title {
    font-size: 14px !important;
  }

  .rgd-tmdb2-section-title,
  .rgd-tmdb-section-title,
  .rgd-tmdb-heading {
    font-size: 20px !important;
  }
}
