/* Moncine — styles de base (thème sombre « cinéma ») */

:root {
    color-scheme: dark;
    --bg: #0f0f12;
    --surface: #1a1a22;
    --surface-muted: #22222e;
    --text: #f2f2f5;
    --muted: #b4b4c4;
    /* Accent par domaine média (surchargé sur body) */
    --media-accent: #adb5bd;
    --media-accent-hover: #ced4da;
    --media-accent-muted: #2d3038;
    --media-bar-bg: #16161a;
    --media-header-tint: #1a1a1f;
    --media-body-tint: #0f0f12;
    --accent: var(--media-accent);
    --accent-hover: var(--media-accent-hover);
    --border: #2e2e3a;
    --success: #4ade80;
    --warning: #fbbf24;
    /* Liens : tons clairs lisibles sur fond sombre (évite bleu/violet navigateur) */
    --link: #f5d76e;
    --link-hover: #fff0b8;
    --link-visited: #e8d4a8;
    --link-admin: #c5e8ff;
    --link-secondary: #d4c4ff;
    --on-accent: #0a0a0e;
}

* {
    box-sizing: border-box;
}

body {
    margin: 0;
    font-family: system-ui, -apple-system, "Segoe UI", Roboto, sans-serif;
    background: var(--media-body-tint, var(--bg));
    color: var(--text);
    line-height: 1.5;
    min-height: 100vh;
    transition: background-color 0.35s ease;
}

/* ── Onglets domaine média : une couleur par type ── */
.media-domain-tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    padding: 0.55rem 1rem 0.65rem;
    background: var(--media-bar-bg, var(--surface-muted));
    border-bottom: 3px solid var(--media-accent);
    justify-content: center;
    transition: background-color 0.35s ease, border-color 0.35s ease;
}

.media-domain-tabs__tab {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    padding: 0.4rem 0.9rem;
    border-radius: 999px;
    border: 2px solid var(--border);
    background: var(--surface);
    color: var(--muted);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    transition: background 0.2s ease, border-color 0.2s ease, color 0.2s ease, box-shadow 0.2s ease, transform 0.15s ease;
}

/* Pastille de couleur propre à chaque onglet */
.media-domain-tabs__dot {
    width: 0.55rem;
    height: 0.55rem;
    border-radius: 50%;
    background: var(--tab-accent);
    flex-shrink: 0;
    box-shadow: 0 0 6px color-mix(in srgb, var(--tab-accent) 55%, transparent);
}

.media-domain-tabs__tab:hover {
    color: var(--tab-accent);
    border-color: color-mix(in srgb, var(--tab-accent) 65%, var(--border));
    background: color-mix(in srgb, var(--tab-accent-muted) 45%, var(--surface));
}

.media-domain-tabs__tab--active {
    background: color-mix(in srgb, var(--tab-accent) 18%, var(--surface));
    border-color: var(--tab-accent);
    color: var(--tab-accent);
    font-weight: 700;
    box-shadow:
        0 0 0 1px color-mix(in srgb, var(--tab-accent) 35%, transparent),
        0 3px 14px color-mix(in srgb, var(--tab-accent) 28%, transparent);
    transform: translateY(-1px);
}

.media-domain-tabs__tab--active .media-domain-tabs__dot {
    box-shadow: 0 0 10px var(--tab-accent);
}

.media-domain-soon {
    max-width: 36rem;
    margin: 2rem auto;
    text-align: center;
}

/* En-tête et pied : teinte du domaine actif */
.site-header {
    transition: background 0.35s ease, border-color 0.35s ease;
}

body[data-media-domain] .site-header {
    background: linear-gradient(180deg, var(--media-header-tint) 0%, var(--surface) 72%);
    border-bottom: 2px solid color-mix(in srgb, var(--media-accent) 55%, var(--border));
}

body[data-media-domain] .site-nav a[aria-current="page"] {
    color: var(--media-accent);
    font-weight: 600;
}

body[data-media-domain] .site-footer {
    border-top: 1px solid color-mix(in srgb, var(--media-accent) 35%, var(--border));
    transition: border-color 0.35s ease;
}

/* Liens de lecture (zones ciblées — pas de sélecteur :not() géant sur tout main) */
.lead a,
.hint a:not(.btn):not(.ui-pill):not(.ui-pill-bar__item),
.collection-page__footer-links a,
.alert a,
.account-page a:not(.btn):not(.ui-pill),
.social-page a:not(.btn):not(.ui-pill),
.notifications-page a:not(.btn):not(.ui-pill) {
    color: var(--link);
    text-decoration: underline;
    text-underline-offset: 0.15em;
    text-decoration-thickness: 1px;
}

.lead a:visited,
.hint a:visited,
.collection-page__footer-links a:visited,
.alert a:visited {
    color: var(--link-visited);
}

.lead a:hover,
.hint a:hover,
.collection-page__footer-links a:hover,
.alert a:hover {
    color: var(--link-hover);
}

/* Pilules de navigation (filtres, onglets) — style autonome, indépendant des liens de contenu */
.ui-pill-nav {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin: 0 0 1.25rem;
}

a.ui-pill,
button.ui-pill {
    display: inline-block;
    padding: 0.4rem 0.85rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    text-decoration: none;
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

a.ui-pill:link,
a.ui-pill:visited {
    color: var(--text);
    text-decoration: none;
}

a.ui-pill:hover,
button.ui-pill:hover {
    border-color: var(--accent);
}

a.ui-pill.ui-pill--active,
a.ui-pill.ui-pill--active:link,
a.ui-pill.ui-pill--active:visited,
a.ui-pill.ui-pill--active:hover,
a.ui-pill.ui-pill--active:focus-visible,
button.ui-pill.ui-pill--active {
    background: var(--accent);
    border-color: var(--accent-hover);
    color: var(--on-accent);
    font-weight: 700;
    box-shadow: 0 1px 3px rgba(0, 0, 0, 0.35);
    text-decoration: none;
}

a.ui-pill.ui-pill--outline-accent,
a.ui-pill.ui-pill--outline-accent:link,
a.ui-pill.ui-pill--outline-accent:visited {
    margin-left: 0.15rem;
    border-color: rgba(232, 185, 35, 0.45);
    color: var(--accent);
}

a.ui-pill.ui-pill--outline-accent:hover {
    background: rgba(232, 185, 35, 0.12);
    color: var(--text);
}

.ui-pill-bar {
    display: inline-flex;
    gap: 0;
    margin: 0.75rem 0 0;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
}

a.ui-pill-bar__item {
    padding: 0.4rem 0.85rem;
    font-size: 0.9rem;
    color: var(--muted);
    text-decoration: none;
    background: var(--bg);
    border-right: 1px solid var(--border);
    transition: background 0.15s, color 0.15s;
}

a.ui-pill-bar__item:last-child {
    border-right: none;
}

a.ui-pill-bar__item:link,
a.ui-pill-bar__item:visited {
    color: var(--muted);
    text-decoration: none;
}

a.ui-pill-bar__item:hover {
    color: var(--text);
    background: rgba(255, 255, 255, 0.06);
}

a.ui-pill-bar__item.ui-pill--active,
a.ui-pill-bar__item.ui-pill--active:link,
a.ui-pill-bar__item.ui-pill--active:visited,
a.ui-pill-bar__item.ui-pill--active:hover,
a.ui-pill-bar__item.ui-pill--active:focus-visible {
    color: var(--on-accent);
    font-weight: 700;
    background: var(--accent);
}

/* Liens « titre » (films, tableaux) : jaune doré, sans soulignement par défaut */
.film-link,
.films-table--sortable th a,
.breadcrumb a,
a.saga-link,
.sagas-list__link,
a.personne-link,
a.support-link,
.collection-grid-sort__link,
.stats-ranked-list__link,
.support-chart__link,
.add-film-choice-intro__title {
    color: var(--link);
    text-decoration: none;
}

.film-link:hover,
.films-table--sortable th a:hover,
.breadcrumb a:hover,
a.saga-link:hover,
.sagas-list__link:hover,
a.personne-link:hover,
a.support-link:hover,
.collection-grid-sort__link:hover,
.stats-ranked-list__link:hover,
.support-chart__link:hover {
    color: var(--link-hover);
    text-decoration: underline;
}

.films-table--sortable th.sorted a {
    color: var(--link-hover);
    font-weight: 600;
}

.container {
    max-width: 720px;
    margin: 0 auto;
    padding: 1rem 1.25rem;
}

.site-header {
    border-bottom: 1px solid var(--border);
    background: var(--surface);
}

.site-header .container {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 1rem;
}

.logo {
    display: inline-flex;
    align-items: center;
    text-decoration: none;
    line-height: 0;
    flex-shrink: 0;
}

.logo__img {
    display: block;
    width: 3.5rem;
    height: 3.5rem;
    object-fit: contain;
    filter: drop-shadow(0 0 8px rgba(232, 185, 35, 0.45));
}

.logo:hover .logo__img {
    filter: drop-shadow(0 0 12px rgba(245, 204, 74, 0.65));
}

.site-header__brand {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
    flex-shrink: 0;
}

.header-profile {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border-radius: 8px;
    color: var(--muted);
    text-decoration: none;
    line-height: 0;
}

.header-profile:hover,
.header-profile:focus-visible,
.header-profile--current {
    color: var(--accent);
    background: rgba(232, 185, 35, 0.12);
}

.header-profile__icon {
    display: block;
}

.header-notifications {
    position: relative;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 2.25rem;
    height: 2.25rem;
    padding: 0;
    border-radius: 8px;
    color: var(--muted);
    text-decoration: none;
    line-height: 0;
}

.header-notifications:hover,
.header-notifications:focus-visible,
.header-notifications--current {
    color: var(--accent);
    background: rgba(232, 185, 35, 0.12);
}

.header-notifications__icon {
    display: block;
}

.header-notifications__badge {
    position: absolute;
    top: 0;
    right: 0;
    min-width: 1.1rem;
    height: 1.1rem;
    padding: 0 0.2rem;
    border-radius: 999px;
    background: var(--accent);
    color: var(--bg);
    font-size: 0.65rem;
    font-weight: 700;
    line-height: 1.1rem;
    text-align: center;
}

/* Liens de navigation : styles détaillés dans responsive.css (.site-nav) */
.site-header .site-nav a {
    color: var(--muted);
    text-decoration: none;
}

.hero h1 {
    font-size: 1.75rem;
    margin-bottom: 0.5rem;
}

.lead {
    color: var(--muted);
    font-size: 1.05rem;
}

.stats {
    color: var(--muted);
    font-size: 0.95rem;
}

.hero-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin-top: 1.5rem;
}

.btn {
    display: inline-block;
    padding: 0.55rem 1.1rem;
    border-radius: 8px;
    border: none;
    font-size: 1rem;
    cursor: pointer;
    text-decoration: none;
    text-align: center;
}

.btn-primary {
    background: var(--accent);
    color: #1a1a10;
    font-weight: 600;
}

.btn-primary:hover {
    background: var(--accent-hover);
}

.btn-secondary {
    background: var(--surface);
    color: var(--text);
    border: 1px solid var(--border);
}

.btn-ghost {
    background: transparent;
    color: var(--muted);
    border: 1px solid var(--border);
}

.btn-danger {
    background: #b91c1c;
    color: #fff;
    font-weight: 600;
}

.btn-danger:hover {
    background: #dc2626;
}

.btn-lg {
    padding: 0.75rem 1.5rem;
    font-size: 1.05rem;
}

fieldset {
    border: 1px solid var(--border);
    border-radius: 10px;
    padding: 1rem 1.25rem;
    margin-bottom: 1.25rem;
    background: var(--surface);
}

legend {
    font-weight: 600;
    padding: 0 0.35rem;
}

label {
    display: block;
    margin-top: 0.75rem;
}

input[type="text"],
input[type="url"],
input[type="number"],
input[type="file"],
select,
textarea {
    width: 100%;
    max-width: 100%;
    padding: 0.5rem 0.65rem;
    margin-top: 0.35rem;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
    color: var(--text);
}

.checkbox-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(140px, 1fr));
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.checkbox,
.radio {
    display: flex;
    align-items: center;
    gap: 0.5rem;
    margin-top: 0.5rem;
}

.checkbox input,
.radio input {
    width: auto;
    margin: 0;
}

.hint {
    color: var(--muted);
    font-size: 0.9rem;
}

.alert {
    padding: 1rem;
    border-radius: 8px;
    margin: 1rem 0;
}

.alert-info {
    background: #1e293b;
    border: 1px solid #334155;
    color: var(--text);
}

.alert-info a {
    color: var(--link-hover);
}

.alert-success {
    background: #14532d33;
    border: 1px solid var(--success);
}

.alert-warning {
    background: #78350f33;
    border: 1px solid var(--warning);
}

.film-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.5rem;
    margin: 1rem 0;
}

.film-card--featured {
    border-color: var(--accent);
}

.film-card h2 {
    margin-top: 0;
    color: var(--accent);
}

.film-details {
    list-style: none;
    padding: 0;
    color: var(--muted);
}

.film-details li {
    margin: 0.25rem 0;
}

.meta {
    color: var(--muted);
}

.result-actions {
    display: flex;
    gap: 0.75rem;
    flex-wrap: wrap;
    align-items: center;
    margin-top: 1rem;
}

.result-actions .inline-form {
    margin: 0;
}

.result-proposal-toolbar {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem 1rem;
    align-items: center;
    margin-bottom: 1.25rem;
    padding-bottom: 1rem;
    border-bottom: 1px solid var(--border);
}

.result-proposal-toolbar .rating-block {
    margin: 0;
    padding: 0;
    background: transparent;
    border: none;
    flex: 1 1 12rem;
}

.result-proposal-toolbar__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-left: auto;
}

.result-proposal-toolbar__actions .inline-form {
    margin: 0;
}

@media (max-width: 640px) {
    .result-proposal-toolbar__actions {
        margin-left: 0;
        width: 100%;
    }
}

.hint.recap {
    margin-bottom: 1rem;
    padding: 0.75rem 1rem;
    background: var(--surface);
    border-radius: 8px;
    border-left: 3px solid var(--accent);
}

.meilleurs-cta {
    margin: 0 0 1rem;
}

.btn-accent {
    background: var(--accent);
    color: #1a1a10;
    font-weight: 600;
}

.btn-accent:hover {
    background: var(--accent-hover);
}

.form-actions--split {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
    align-items: center;
    margin-top: 1rem;
}

.form-actions__hint {
    flex: 1 1 100%;
    margin: 0.25rem 0 0;
}

/* —— Connexion / premier compte —— */

.auth-layout {
    min-height: 100vh;
    display: flex;
    align-items: center;
}

.container--narrow {
    max-width: 28rem;
    margin: 0 auto;
    padding-top: 2rem;
    padding-bottom: 2rem;
}

.auth-page h1 {
    margin-top: 0;
}

.auth-form {
    max-width: 100%;
}

.users-admin-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.5rem;
    align-items: center;
}

.users-admin-page__action-form {
    margin: 0;
}

.users-admin-page__action-form .btn-sm {
    margin-top: 0;
}

.site-nav__user {
    flex: 1 1 100%;
    font-size: 0.9rem;
    opacity: 0.85;
    color: inherit;
    text-decoration: none;
}

.site-nav__user:hover {
    opacity: 1;
    text-decoration: underline;
}

.site-nav__logout-form {
    display: inline;
    margin: 0;
}

.site-nav__logout-form .btn-link {
    font: inherit;
    color: inherit;
    text-decoration: none;
    background: none;
    border: none;
    padding: 0;
    cursor: pointer;
    opacity: 0.9;
}

.site-nav__logout-form .btn-link:hover {
    opacity: 1;
    text-decoration: underline;
}

.btn-sm {
    padding: 0.35rem 0.75rem;
    font-size: 0.9rem;
    margin-top: 0.5rem;
}

.rating-block {
    margin: 1.25rem 0;
    padding: 1rem;
    background: var(--bg);
    border-radius: 10px;
    border: 1px solid var(--border);
}

.rating-title {
    margin: 0 0 0.5rem;
    font-weight: 600;
    font-size: 0.95rem;
}

.rating-current {
    margin: 0 0 0.75rem;
    color: var(--muted);
    font-size: 0.9rem;
}

.rating-buttons {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
}

.rating-btn {
    padding: 0.45rem 0.65rem;
    border-radius: 999px;
    border: 1px solid var(--border);
    background: var(--surface);
    color: var(--text);
    font-size: 0.85rem;
    cursor: pointer;
    transition: background 0.15s, border-color 0.15s;
}

.rating-btn:hover {
    border-color: var(--accent);
}

.rating-btn--active {
    border-color: var(--accent);
    background: #3d3520;
    color: var(--accent);
    font-weight: 600;
}

.rating-btn--genial.rating-btn--active {
    border-color: #4ade80;
    color: #4ade80;
    background: #14532d44;
}

.rating-btn--non.rating-btn--active {
    border-color: #f87171;
    color: #f87171;
    background: #450a0a44;
}

.marquer-vu-panel {
    margin-top: 1.5rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
}

.marquer-vu-panel__title {
    margin-top: 0;
    font-size: 1.1rem;
}

.marquer-vu-form {
    margin-top: 0.5rem;
    max-width: 28rem;
}

.marquer-vu-form__row {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.5rem;
}

.marquer-vu-form__date {
    flex: 1 1 10rem;
    min-width: 8rem;
}

.marquer-vu-form__note {
    max-width: 10rem;
}

.marquer-vu-form--compact {
    margin-top: 1rem;
    max-width: 100%;
}

.marquer-vu-form--compact .marquer-vu-form__row {
    margin-bottom: 0.75rem;
}

.viewings-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1rem;
}

.viewings-list__item {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}

.viewings-list__info {
    flex: 1 1 auto;
}

.viewings-list__delete {
    flex: 0 0 auto;
}

.btn-icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    padding: 0.35rem;
    border: none;
    border-radius: 6px;
    background: transparent;
    cursor: pointer;
    line-height: 0;
}

.btn-danger-text {
    color: #f87171;
}

.btn-danger-text:hover {
    color: #fca5a5;
    background: rgba(248, 113, 113, 0.12);
}

.icon-trash {
    display: block;
}

.film-note--small {
    font-size: 0.85rem;
    margin-left: 0.35rem;
}

.rated-list {
    list-style: none;
    padding: 0;
    margin: 0;
}

.rated-item {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    padding: 1.25rem;
    margin-bottom: 1rem;
}

.rated-item--top {
    border-color: var(--accent);
    box-shadow: 0 0 0 1px #e8b92333;
}

.rated-item h2 {
    margin: 0.5rem 0 0.25rem;
    font-size: 1.2rem;
}

.rated-item__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
}

.rating-badge {
    display: inline-block;
    padding: 0.2rem 0.6rem;
    border-radius: 6px;
    font-size: 0.85rem;
    font-weight: 600;
    background: var(--bg);
}

.rating-badge--genial {
    color: #4ade80;
    border: 1px solid #4ade80;
}

.rating-badge--pas_mal {
    color: #b8dcff;
    border: 1px solid #7eb8e8;
}

.rating-badge--pourquoi_pas {
    color: var(--muted);
}

.rating-badge--bof,
.rating-badge--non {
    color: #f87171;
}

.tag--top {
    color: var(--accent);
    font-size: 0.8rem;
    font-weight: 600;
}

.film-note {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    font-size: 1rem;
    font-weight: 700;
    color: var(--accent);
    background: rgba(232, 185, 35, 0.15);
    border-radius: 6px;
}

.film-note--foyer {
    color: #0f766e;
    background: rgba(15, 118, 110, 0.12);
}

.film-ratings {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.35rem 0.65rem;
    align-items: center;
}

.film-ratings--stacked {
    flex-direction: column;
    align-items: flex-start;
    gap: 0.25rem;
}

.film-ratings--inline {
    flex-direction: row;
}

.film-ratings--detail {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.65rem;
    margin: 0 0 0.35rem;
}

.film-ratings--detail:last-child {
    margin-bottom: 0;
}

.film-ratings__item {
    display: inline-flex;
    align-items: center;
    gap: 0.35rem;
}

.film-ratings__label {
    font-size: 0.75rem;
    font-weight: 600;
    color: var(--text-muted);
    text-transform: uppercase;
    letter-spacing: 0.03em;
}

.tag--role {
    display: inline-block;
    margin: 0 0.25rem 0.25rem 0;
    padding: 0.15rem 0.45rem;
    font-size: 0.75rem;
    background: rgba(232, 185, 35, 0.15);
    border-radius: 4px;
    color: var(--accent);
}

.personnes-page .personnes-search {
    max-width: 32rem;
    margin-bottom: 1.5rem;
}

.collection-page .collection-search {
    max-width: 36rem;
    margin-bottom: 1.25rem;
}

.collection-search__row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin-top: 0.35rem;
}

.collection-search__row input[type="search"] {
    flex: 1 1 12rem;
    min-width: 0;
}

.collection-search__add {
    margin-top: 0.65rem;
}

.collection-page__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    margin-bottom: 0.5rem;
}

.collection-page__head h1 {
    margin: 0;
}

.collection-page__head-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
}

.share-link-list {
    list-style: none;
    padding: 0;
    margin: 1rem 0;
}

.share-link-list__item {
    margin-bottom: 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border-subtle, #333);
}

.share-visitor-page__badge {
    margin-bottom: 1rem;
}

.share-visitor-page__head.collection-page__head {
    margin-bottom: 0.25rem;
}

.collection-grid__support {
    font-size: 0.85rem;
    opacity: 0.9;
}

.collection-page__hint {
    margin-bottom: 0.75rem;
}

.add-film-choice-intro {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1rem;
    align-items: start;
    margin: 1rem 0 0.5rem;
    padding: 1rem 1.15rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
}

.add-film-choice-intro--with-poster {
    grid-template-columns: 140px 1fr;
}

.add-film-choice-intro__poster {
    width: 100%;
    max-width: 140px;
    margin: 0 auto;
}

.add-film-choice-intro__poster-placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    max-width: 140px;
    margin: 0 auto;
    aspect-ratio: 2 / 3;
    border-radius: 8px;
    border: 1px dashed var(--border);
    background: var(--bg);
    color: var(--muted);
    font-size: 0.85rem;
    text-align: center;
}

.add-film-choice-intro__title {
    margin: 0 0 0.35rem;
    font-size: 1.35rem;
    font-weight: 600;
    color: var(--accent);
    line-height: 1.3;
}

.add-film-choice-intro__meta {
    margin: 0 0 0.25rem;
    color: var(--muted);
    font-size: 0.95rem;
}

.add-film-choice-intro__lead {
    margin: 0.75rem 0 0;
}

@media (min-width: 520px) {
    .add-film-choice-intro--with-poster {
        grid-template-columns: 160px 1fr;
    }

    .add-film-choice-intro__poster,
    .add-film-choice-intro__poster-placeholder {
        max-width: 160px;
        margin: 0;
    }
}

.add-film-choice {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(14rem, 1fr));
    gap: 1rem;
    margin: 1.5rem 0;
}

.add-film-choice__card {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
    padding: 1.25rem 1.35rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 12px;
    text-decoration: none;
    color: var(--text);
    transition: border-color 0.15s, box-shadow 0.15s;
}

.add-film-choice__form {
    margin: 0;
    padding: 0;
    border: none;
    background: transparent;
}

.add-film-choice__form.add-film-choice__card {
    padding: 0;
    border: 1px solid var(--border);
    background: var(--surface);
}

.add-film-choice__submit {
    display: flex;
    flex-direction: column;
    align-items: flex-start;
    gap: 0.5rem;
    width: 100%;
    margin: 0;
    padding: 1.25rem 1.35rem;
    border: none;
    border-radius: 12px;
    background: transparent;
    color: inherit;
    font: inherit;
    text-align: left;
    cursor: pointer;
    transition: border-color 0.15s, box-shadow 0.15s, background 0.15s;
}

.add-film-choice__card:hover,
.add-film-choice__form:hover,
.add-film-choice__submit:hover {
    border-color: var(--accent);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.add-film-choice__card--wishlist:hover,
.add-film-choice__card--wishlist .add-film-choice__submit:hover {
    border-color: var(--link-secondary);
}

.add-film-choice__form:focus-within {
    border-color: var(--accent);
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
}

.add-film-choice__title {
    font-size: 1.15rem;
    font-weight: 600;
    color: var(--accent);
}

.add-film-choice__hint {
    font-size: 0.9rem;
    color: var(--muted);
    line-height: 1.45;
}

.add-film-page .film-edit-form {
    max-width: 40rem;
}

.catalog-title-autocomplete {
    position: relative;
}

.catalog-title-autocomplete__input {
    width: 100%;
}

.catalog-title-autocomplete__list {
    position: absolute;
    z-index: 50;
    left: 0;
    right: 0;
    max-height: 16rem;
    margin: 0.25rem 0 0;
    padding: 0.35rem 0;
    list-style: none;
    overflow-y: auto;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
}

.catalog-title-autocomplete__option {
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    padding: 0.55rem 0.75rem;
    cursor: pointer;
    border-bottom: 1px solid var(--border);
}

.catalog-title-autocomplete__option:last-child {
    border-bottom: none;
}

.catalog-title-autocomplete__option:hover,
.catalog-title-autocomplete__option.is-active {
    background: rgba(232, 185, 35, 0.12);
}

.catalog-title-autocomplete__option-label {
    font-weight: 500;
    color: var(--text);
    line-height: 1.35;
}

.catalog-title-autocomplete__badge {
    font-size: 0.78rem;
    color: var(--muted);
}

.catalog-title-autocomplete__hint {
    margin-top: 0.35rem;
}

/* —— Administration catalogue —— */

.catalog-admin-page__head {
    display: flex;
    flex-direction: column;
    gap: 0.75rem;
    margin-bottom: 1.25rem;
}

.catalog-admin-page__badge {
    margin: 0;
    padding: 0.5rem 0.75rem;
    border: 1px dashed var(--border);
    border-radius: 8px;
    background: rgba(232, 185, 35, 0.08);
}

/* Barre de navigation discrète (fiches film, pagination catalogue) */
.list-pager {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem 0.85rem;
    margin: 0.35rem 0 0.85rem;
    padding: 0.35rem 0;
    font-size: 0.9rem;
    color: var(--muted);
    border-bottom: 1px solid var(--border);
}

.film-list-pager {
    justify-content: center;
}

/* Ancre + barre Préc./Suiv. : visible sous l’en-tête au changement de fiche */
#film-list-nav {
    scroll-margin-top: 5.5rem;
}

.film-list-nav-anchor {
    position: sticky;
    top: 4.75rem;
    z-index: 90;
    margin: 0.35rem 0 0.85rem;
    padding: 0.15rem 0 0.35rem;
    background: var(--bg);
    box-shadow: 0 6px 12px -8px rgba(0, 0, 0, 0.65);
}

.film-list-nav-anchor .film-list-pager {
    margin: 0;
    border-bottom: 1px solid var(--border);
}

.film-detail__body > .film-list-pager {
    margin-top: 1.25rem;
}

.catalog-list-pager {
    justify-content: space-between;
}

.list-pager__group {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.5rem;
}

.list-pager__status {
    color: var(--muted);
    white-space: nowrap;
}

.list-pager__status-meta {
    opacity: 0.85;
}

.list-pager__link {
    color: var(--link);
    text-decoration: none;
    padding: 0.15rem 0;
}

.list-pager__link:hover,
.list-pager__link:focus-visible {
    text-decoration: underline;
    color: var(--link-hover);
}

.list-pager__link.is-disabled {
    opacity: 0.4;
    cursor: default;
}

.list-pager__sep {
    opacity: 0.45;
    user-select: none;
}

.list-pager__goto {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.45rem;
    margin: 0;
    margin-left: auto;
}

.list-pager__goto-label {
    font-size: 0.85rem;
    color: var(--muted);
}

.list-pager__goto-input {
    width: 3.25rem;
    min-height: 1.85rem;
    padding: 0.2rem 0.4rem;
    border: 1px solid var(--border);
    border-radius: 4px;
    background: var(--bg);
    color: var(--text);
    font-size: 0.9rem;
}

.list-pager__goto-btn {
    font: inherit;
    font-size: 0.85rem;
    color: var(--link);
    background: none;
    border: none;
    padding: 0.15rem 0.35rem;
    cursor: pointer;
    text-decoration: underline;
}

.list-pager__goto-btn:hover,
.list-pager__goto-btn:focus-visible {
    color: var(--link-hover);
}

#film-detail,
#catalogue-list {
    scroll-margin-top: 5.5rem;
}

#catalog-list-nav,
#catalog-oeuvre-nav {
    scroll-margin-top: 5.5rem;
}

.catalog-list-nav-anchor,
.catalog-oeuvre-nav-anchor {
    position: sticky;
    top: 4.75rem;
    z-index: 90;
    margin: 0.35rem 0 0.85rem;
    padding: 0.15rem 0 0.35rem;
    background: var(--bg);
    box-shadow: 0 6px 12px -8px rgba(0, 0, 0, 0.65);
}

.catalog-list-nav-anchor .catalog-list-pager,
.catalog-oeuvre-nav-anchor .catalog-oeuvre-pager {
    margin: 0;
    border-bottom: 1px solid var(--border);
}

.catalog-oeuvre-pager {
    justify-content: center;
}

.film-detail__body > .catalog-oeuvre-pager {
    margin-top: 1.25rem;
}

.catalog-admin-table__actions .btn-icon {
    min-width: 2.25rem;
    min-height: 2.25rem;
}

.site-nav__admin {
    color: var(--link-admin);
}

.site-nav__menu--gestion .site-nav__menu-summary,
.site-nav__submenu .site-nav__admin {
    color: var(--link-admin);
}

.site-nav__settings {
    color: var(--text);
}

.site-nav__menu {
    position: relative;
    margin: 0;
}

.site-nav__menu-summary {
    list-style: none;
    cursor: pointer;
    color: var(--muted);
    font-size: inherit;
    font-family: inherit;
    padding: 0.65rem 0.5rem;
    border-radius: 6px;
    min-height: var(--touch-min, 44px);
    display: flex;
    align-items: center;
    user-select: none;
}

.site-nav__menu-summary::-webkit-details-marker {
    display: none;
}

.site-nav__menu-summary::after {
    content: " ▾";
    font-size: 0.75em;
    opacity: 0.75;
}

.site-nav__menu[open] .site-nav__menu-summary::after {
    content: " ▴";
}

.site-nav__menu-summary:hover,
.site-nav__menu-summary:focus-visible {
    color: var(--text);
    background: rgba(255, 255, 255, 0.05);
}

.site-nav__submenu {
    display: flex;
    flex-direction: column;
    gap: 0.1rem;
    margin: 0 0 0.35rem;
    padding: 0.25rem 0 0.35rem 0.75rem;
    border-left: 2px solid var(--border);
}

.site-nav__submenu a {
    margin: 0;
    padding: 0.5rem 0.5rem;
    font-size: 0.95rem;
}

@media (min-width: 900px) {
    .site-nav__menu-summary {
        padding: 0.4rem 0.65rem;
        min-height: auto;
        white-space: nowrap;
    }

    .site-nav__submenu {
        position: absolute;
        top: calc(100% + 0.2rem);
        right: 0;
        z-index: 200;
        min-width: 11rem;
        margin: 0;
        padding: 0.35rem 0;
        border: 1px solid var(--border);
        border-left: 1px solid var(--border);
        border-radius: 8px;
        background: var(--surface);
        box-shadow: 0 8px 24px rgba(0, 0, 0, 0.35);
    }

    .site-nav__submenu a {
        padding: 0.45rem 0.85rem;
        border-radius: 0;
    }

    .site-nav__submenu a:hover,
    .site-nav__submenu a:focus-visible {
        background: rgba(255, 255, 255, 0.06);
    }
}

.catalog-admin-panel {
    margin-bottom: 1.5rem;
    border: 1px solid var(--border);
    border-radius: 10px;
    background: var(--surface);
}

.catalog-admin-panel__summary {
    padding: 0.85rem 1rem;
    font-weight: 600;
    cursor: pointer;
    list-style: none;
}

.catalog-admin-panel__body {
    padding: 0 1rem 1rem;
    border-top: 1px solid var(--border);
}

.catalog-admin-form {
    max-width: 40rem;
}

.catalog-admin-form__more {
    margin: 0.75rem 0;
}

.catalog-admin-form__more summary {
    cursor: pointer;
    color: var(--accent);
    margin-bottom: 0.5rem;
}

.catalog-admin-list h2 {
    font-size: 1.2rem;
    margin: 0 0 1rem;
}

.catalog-admin-table__actions {
    white-space: nowrap;
}

.catalog-admin-table__title {
    font-weight: 600;
}

.oeuvre-catalog-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
}

.oeuvre-catalog-page__library {
    margin-top: 1.25rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
}

.oeuvre-catalog-page__library h2 {
    font-size: 1.1rem;
    margin: 0 0 0.5rem;
}

@media (max-width: 899px) {
    .catalog-list-pager {
        flex-direction: column;
        align-items: flex-start;
    }

    .list-pager__goto {
        margin-left: 0;
    }
}

.visually-hidden {
    position: absolute;
    width: 1px;
    height: 1px;
    padding: 0;
    margin: -1px;
    overflow: hidden;
    clip: rect(0, 0, 0, 0);
    white-space: nowrap;
    border: 0;
}

.catalog-maintenance-stats__grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(9rem, 1fr));
    gap: 0.75rem;
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.catalog-maintenance-stat {
    padding: 0.85rem 1rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 10px;
    text-align: center;
}

.catalog-maintenance-stat--warn {
    border-color: var(--accent);
}

.catalog-maintenance-stat__value {
    display: block;
    font-size: 1.5rem;
    font-weight: 700;
    color: var(--accent);
}

.catalog-maintenance-stat__label {
    display: block;
    font-size: 0.8rem;
    color: var(--muted);
    margin-top: 0.25rem;
}

.catalog-maintenance-panel {
    margin-bottom: 2rem;
    padding-bottom: 1.5rem;
    border-bottom: 1px solid var(--border);
}

.catalog-maintenance-panel h2 {
    margin-top: 0;
}

.catalog-maintenance-panel--danger {
    padding: 1.25rem;
    border: 1px solid rgba(220, 80, 80, 0.45);
    border-radius: var(--radius);
    background: rgba(220, 80, 80, 0.06);
}

.catalog-maintenance-db-backup {
    display: grid;
    gap: 1.5rem;
    margin-top: 1rem;
}

@media (min-width: 720px) {
    .catalog-maintenance-db-backup {
        grid-template-columns: 1fr 1fr;
    }
}

.catalog-maintenance-db-backup__block h3 {
    margin: 0 0 0.5rem;
    font-size: 1rem;
}

.catalog-maintenance-db-form {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.65rem;
    max-width: 28rem;
}

.catalog-maintenance-db-form label {
    margin: 0;
}

.catalog-maintenance-db-confirm {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    font-size: 0.88rem;
    line-height: 1.4;
}

.catalog-maintenance-db-confirm input {
    margin-top: 0.2rem;
}

.catalog-maintenance-duplicate {
    margin: 1rem 0;
    padding: 1rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
}

.catalog-maintenance-duplicate h3 {
    margin: 0 0 0.5rem;
    font-size: 1rem;
}

.catalog-maintenance-merge-form {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.75rem;
    margin-top: 0.75rem;
}

.catalog-maintenance-merge-form label {
    margin: 0;
}

.catalog-maintenance-orphans {
    columns: 2;
    margin: 0 0 1rem;
    padding-left: 1.25rem;
    font-size: 0.9rem;
}

.collection-toolbar {
    margin: 0 0 1rem;
    padding: 0.85rem 1rem;
    background: var(--surface);
    border: 1px solid var(--accent);
    border-radius: 10px;
    box-shadow: 0 4px 20px rgba(0, 0, 0, 0.15);
}

.collection-toolbar[hidden] {
    display: none !important;
}

.collection-toolbar__head {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.5rem 1rem;
    margin-bottom: 0.75rem;
    padding-bottom: 0.65rem;
    border-bottom: 1px solid var(--border);
}

.collection-toolbar__count {
    margin: 0;
    font-weight: 600;
    color: var(--accent);
}

.collection-toolbar__count-plural {
    display: none;
}

.collection-toolbar.is-multiple .collection-toolbar__count-plural {
    display: inline;
}

.collection-toolbar__tabs {
    display: flex;
    flex-wrap: wrap;
    gap: 0.35rem;
    margin-bottom: 0.75rem;
}

.collection-toolbar__tab {
    padding: 0.4rem 0.85rem;
    border: 1px solid var(--border);
    border-radius: 999px;
    background: transparent;
    color: var(--muted);
    font-size: 0.9rem;
    font-weight: 500;
    cursor: pointer;
    transition: background 0.15s, color 0.15s, border-color 0.15s;
}

.collection-toolbar__tab:hover {
    color: var(--text);
    border-color: var(--muted);
}

.collection-toolbar__tab.is-active {
    background: var(--accent);
    border-color: var(--accent);
    color: #1a1a10;
}

.collection-toolbar__tab--danger.is-active {
    background: #b91c1c;
    border-color: #b91c1c;
    color: #fff;
}

.collection-toolbar__tab--danger:not(.is-active) {
    color: #f87171;
    border-color: rgba(248, 113, 113, 0.35);
}

.collection-toolbar__panels {
    min-height: 0;
}

.collection-toolbar__panel {
    display: none;
}

.collection-toolbar__panel.is-active {
    display: block;
}

.collection-toolbar__panel[hidden] {
    display: none !important;
}

.collection-toolbar__panel-intro {
    margin: 0 0 0.65rem;
    font-size: 0.9rem;
    color: var(--muted);
}

.collection-toolbar__fields {
    display: grid;
    grid-template-columns: repeat(auto-fit, minmax(10rem, 1fr));
    gap: 0.65rem 0.85rem;
    margin-bottom: 0.75rem;
    max-width: 42rem;
}

.collection-toolbar__fields--inline {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.65rem 0.85rem;
}

.collection-toolbar__field-narrow {
    max-width: 7rem;
}

.collection-toolbar__panel .btn-sm {
    margin-top: 0.15rem;
}

.collection-toolbar__panel--danger .collection-toolbar__panel-intro {
    color: #fca5a5;
}

.collection-bulk-panel,
.collection-saga-panel {
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
}

.collection-bulk-panel__summary,
.collection-saga-panel__summary {
    cursor: pointer;
    padding: 0.65rem 0.85rem;
    font-weight: 600;
    list-style-position: inside;
}

.collection-bulk-panel__body,
.collection-saga-panel__body {
    padding: 0 0.85rem 0.85rem;
    max-width: 28rem;
}

.film-delete-panel {
    margin-top: 2rem;
    padding-top: 1.25rem;
    border-top: 1px solid rgba(248, 113, 113, 0.25);
}

.film-delete-panel__title {
    margin: 0 0 0.5rem;
    font-size: 1.1rem;
    color: #fca5a5;
}

.film-detail-page__toolbar {
    margin: 0 0 1rem;
}

.film-wishlist-badge {
    padding: 0.5rem 0.75rem;
    background: rgba(212, 175, 55, 0.12);
    border-radius: 8px;
    border-left: 3px solid var(--accent);
}

.film-promote-panel {
    margin-top: 1.5rem;
    padding: 1rem;
    border: 1px solid var(--accent);
    border-radius: 10px;
    background: rgba(212, 175, 55, 0.06);
}

.film-promote-panel__title {
    margin: 0 0 0.5rem;
    font-size: 1.1rem;
}

.wishlist-actions .wishlist-promote-form {
    display: flex;
    flex-direction: column;
    align-items: stretch;
    gap: 0.35rem;
    min-width: 10rem;
}

.wishlist-actions .wishlist-promote-form select {
    max-width: 100%;
    font-size: 0.85rem;
}

/* Mes envies : version + support + bouton sur une ligne compacte */
.wishlist-actions .wishlist-promote-form--compact {
    flex-direction: row;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.3rem;
    min-width: 0;
}

.wishlist-actions .wishlist-promote-form--compact .film-promote-form__target-select,
.wishlist-actions .wishlist-promote-form--compact select[name="support_physique"] {
    flex: 1 1 8.5rem;
    min-width: 7rem;
    max-width: 14rem;
    font-size: 0.8rem;
    padding: 0.2rem 0.35rem;
}

.wishlist-actions .wishlist-promote-form--compact .btn {
    flex: 0 0 auto;
    white-space: nowrap;
}

.film-promote-form .film-promote-form__target-select {
    max-width: 100%;
}

.wishlist-targets-readonly {
    margin: 0;
    padding-left: 1.1rem;
    font-size: 0.9rem;
    line-height: 1.45;
}

.wishlist-targets-readonly li + li {
    margin-top: 0.35rem;
}

.collection-grid__targets {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.72rem;
    line-height: 1.3;
}

.films-table--selectable .col-select {
    width: 2.25rem;
    text-align: center;
    vertical-align: middle;
}

.films-table--selectable .col-select input[type="checkbox"] {
    width: 1rem;
    height: 1rem;
    cursor: pointer;
}

.films-table .col-poster {
    width: 3.25rem;
    padding: 0.35rem 0.5rem 0.35rem 0;
    vertical-align: middle;
}

.films-table__poster-link {
    display: block;
    line-height: 0;
    border-radius: 6px;
    overflow: hidden;
    transition: box-shadow 0.15s ease, transform 0.15s ease;
}

.films-table__poster-link:hover {
    box-shadow: 0 2px 10px rgba(0, 0, 0, 0.2);
    transform: scale(1.03);
}

.films-table__poster {
    display: block;
    width: 44px;
    height: 66px;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
}

.films-table__poster--empty {
    background: linear-gradient(145deg, var(--bg) 0%, var(--border) 100%);
}

.collection-grid-bar {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    justify-content: space-between;
    gap: 0.75rem 1rem;
    margin-bottom: 1rem;
}

.collection-grid-bar__select-all {
    display: inline-flex;
    align-items: center;
    gap: 0.45rem;
    margin: 0;
    font-size: 0.9rem;
    cursor: pointer;
}

.collection-grid-sort {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.35rem 0.65rem;
    font-size: 0.85rem;
}

.collection-grid-sort__label {
    color: var(--muted);
    margin-right: 0.15rem;
}

.collection-grid-sort__link {
    color: var(--muted);
    text-decoration: none;
    padding: 0.2rem 0.35rem;
    border-radius: 4px;
}

.collection-grid-sort__link:hover {
    color: var(--accent);
}

.collection-grid-sort__link.is-active {
    color: var(--accent);
    font-weight: 600;
}

.collection-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(118px, 1fr));
    gap: 1rem 0.85rem;
    list-style: none;
    margin: 0;
    padding: 0;
}

@media (min-width: 640px) {
    .collection-grid {
        grid-template-columns: repeat(auto-fill, minmax(130px, 1fr));
        gap: 1.15rem 1rem;
    }
}

.collection-grid__item {
    margin: 0;
}

.collection-grid__card {
    position: relative;
    height: 100%;
}

.collection-grid__check {
    position: absolute;
    top: 0.4rem;
    left: 0.4rem;
    z-index: 2;
    display: flex;
    align-items: center;
    justify-content: center;
    width: 1.35rem;
    height: 1.35rem;
    margin: 0;
    padding: 0;
    background: rgba(255, 255, 255, 0.92);
    border-radius: 4px;
    box-shadow: 0 1px 4px rgba(0, 0, 0, 0.15);
    cursor: pointer;
}

.collection-grid__check input {
    width: 1rem;
    height: 1rem;
    margin: 0;
    cursor: pointer;
}

.collection-grid__link {
    display: block;
    color: inherit;
    text-decoration: none;
    border-radius: 10px;
    overflow: hidden;
    border: 1px solid var(--border);
    background: var(--card, var(--bg));
    transition: box-shadow 0.15s ease, transform 0.15s ease;
}

.collection-grid__link:hover {
    box-shadow: 0 4px 16px rgba(0, 0, 0, 0.12);
    transform: translateY(-2px);
}

.collection-grid__poster-wrap {
    line-height: 0;
    background: var(--bg);
}

.collection-grid__poster {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    background: var(--bg);
}

.collection-grid__poster--empty {
    min-height: 160px;
    background: linear-gradient(160deg, var(--bg) 0%, var(--border) 100%);
}

.collection-grid__title {
    margin: 0;
    padding: 0.5rem 0.45rem 0.25rem;
    font-size: 0.82rem;
    font-weight: 600;
    line-height: 1.3;
    color: var(--accent);
    display: -webkit-box;
    -webkit-line-clamp: 2;
    -webkit-box-orient: vertical;
    overflow: hidden;
}

.collection-grid__meta {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.25rem 0.4rem;
    margin: 0;
    padding: 0 0.45rem 0.5rem;
    font-size: 0.75rem;
    color: var(--muted);
}

.collection-grid__meta .tag {
    margin-left: 0;
    font-size: 0.7rem;
}

.collection-grid__year,
.collection-grid__note {
    white-space: nowrap;
}

.collection-select-all {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    margin: 0;
    cursor: pointer;
}

.collection-page__footer-links {
    margin-top: 1.25rem;
}

a.saga-link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
}

a.saga-link:hover {
    text-decoration: underline;
}

.saga-ordre {
    margin-right: 0.15rem;
    opacity: 0.85;
}

.sagas-page .lead {
    margin-bottom: 1rem;
}

.sagas-list {
    list-style: none;
    padding: 0;
    margin: 0 0 1.5rem;
}

.sagas-list li {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.75rem;
    padding: 0.5rem 0;
    border-bottom: 1px solid var(--border);
}

.sagas-list__link {
    font-weight: 600;
    color: var(--accent);
    text-decoration: none;
}

.sagas-list__link:hover {
    text-decoration: underline;
}

.sagas-list__count {
    color: var(--muted);
    font-size: 0.9rem;
}

.sagas-page__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-top: 1.5rem;
}

.sagas-rename-panel {
    margin: 0 0 1.25rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
    max-width: 28rem;
}

.sagas-rename-panel__summary {
    cursor: pointer;
    padding: 0.65rem 0.85rem;
    font-weight: 600;
    list-style-position: inside;
}

.sagas-rename-form {
    padding: 0 0.85rem 0.85rem;
}

.tag--presence-collection {
    background: rgba(80, 180, 120, 0.2);
    border-color: rgba(80, 180, 120, 0.45);
    color: #8fd4a8;
}

.tag--presence-wishlist {
    background: rgba(100, 160, 220, 0.2);
    border-color: rgba(100, 160, 220, 0.45);
    color: #9ec8ef;
}

.tag--presence-none {
    background: rgba(140, 140, 140, 0.15);
    border-color: var(--border);
    color: var(--muted);
}

.personnes-results .tag--role {
    white-space: nowrap;
}

a.personne-link {
    color: var(--accent);
    text-decoration: none;
}

a.personne-link:hover {
    text-decoration: underline;
}

a.support-link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
}

a.support-link:hover {
    text-decoration: underline;
}

.support-filters {
    margin: 1rem 0 1.25rem;
}

.export-panel,
.enrich-panel,
.omdb-panel {
    margin-top: 2.5rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

.export-panel h2,
.enrich-panel h2 {
    margin-top: 0;
}

.enrich-actions {
    margin-top: 1rem;
}

.enrich-key-update {
    margin: 0.5rem 0 1rem;
}

.enrich-key-update input[type="password"] {
    max-width: 16rem;
}

.enrich-film-panel {
    margin-top: 1.5rem;
    padding: 1rem;
    border: 1px solid var(--border);
    border-radius: 8px;
    background: var(--surface);
}

.enrich-film-panel__title {
    margin-top: 0;
    font-size: 1.1rem;
}

.enrich-tmdb-correct {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px dashed var(--border);
}

.enrich-tmdb-form input[type="text"] {
    max-width: 20rem;
}

.export-actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.75rem;
    margin: 1rem 0;
}

.omdb-panel h2 {
    margin-top: 0;
}

.omdb-actions {
    margin-top: 1rem;
}

.omdb-key-update {
    margin-top: 1rem;
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 0.5rem;
}

.omdb-key-update input[type="password"] {
    flex: 1;
    min-width: 200px;
}

.omdb-film-panel {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

.omdb-film-panel__title {
    margin: 0 0 0.75rem;
    font-size: 1.1rem;
}

.omdb-imdb-fallback,
.omdb-tmdb-correct {
    margin-top: 1rem;
    padding-top: 1rem;
    border-top: 1px dashed var(--border);
}

.omdb-imdb-form input[type="text"] {
    max-width: 280px;
}

.film-year {
    font-weight: 400;
    color: var(--muted);
    font-size: 0.85em;
}

.film-detail__heading {
    margin-bottom: 1rem;
}

.film-original-title {
    margin: 0.35rem 0 0;
    font-size: 1.05rem;
    font-weight: 500;
    font-style: italic;
    color: var(--accent);
    line-height: 1.35;
    opacity: 0.92;
}

.film-edit-panel {
    margin: 1.5rem 0;
    padding: 1rem 1.25rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

.film-edit-panel__summary {
    cursor: pointer;
    font-weight: 600;
    font-size: 1.05rem;
    list-style: none;
}

.film-edit-panel__summary::-webkit-details-marker {
    display: none;
}

.film-edit-panel__summary::before {
    content: "▸ ";
    display: inline-block;
    transition: transform 0.15s ease;
}

.film-edit-panel[open] .film-edit-panel__summary::before {
    transform: rotate(90deg);
}

.film-edit-form fieldset {
    margin-top: 1rem;
}

.film-edit-form .required {
    color: var(--accent);
}

textarea {
    resize: vertical;
    min-height: 6rem;
    font-family: inherit;
    line-height: 1.5;
}

.tmdb-panel {
    margin-top: 1.5rem;
    padding-top: 1.25rem;
    border-top: 1px dashed var(--border);
}

.tmdb-panel h3 {
    margin: 0 0 0.5rem;
    font-size: 1.05rem;
}

.film-card--with-poster {
    display: grid;
    grid-template-columns: 120px 1fr;
    gap: 1.25rem;
    align-items: start;
}

.film-poster {
    width: 100%;
    border-radius: 8px;
    border: 1px solid var(--border);
    aspect-ratio: 2 / 3;
    object-fit: cover;
    background: var(--bg);
}

.film-synopsis {
    color: var(--muted);
    font-size: 0.95rem;
    line-height: 1.55;
    margin: 1rem 0 0;
}

@media (max-width: 520px) {
    .film-card--with-poster {
        grid-template-columns: 1fr;
    }

    .film-poster {
        max-width: 160px;
        margin: 0 auto;
    }
}

.film-list {
    padding-left: 1.25rem;
    color: var(--muted);
}

.tag {
    font-size: 0.85rem;
    margin-left: 0.5rem;
    opacity: 0.85;
}

.films-table {
    width: 100%;
    border-collapse: collapse;
    font-size: 0.9rem;
}

.films-table th,
.films-table td {
    border-bottom: 1px solid var(--border);
    padding: 0.5rem 0.35rem;
    text-align: left;
}

.films-table th {
    color: var(--muted);
    font-weight: 500;
}

.films-table--sortable th a {
    color: inherit;
    text-decoration: none;
    white-space: nowrap;
}

.films-table--sortable th a:hover {
    color: var(--accent);
}

.films-table--sortable th.sorted a {
    color: var(--accent);
    font-weight: 600;
}

.film-link {
    font-weight: 500;
}

.breadcrumb {
    color: var(--muted);
    font-size: 0.9rem;
    margin-bottom: 1rem;
}

.film-detail {
    display: grid;
    grid-template-columns: 1fr;
    gap: 1.5rem;
    align-items: start;
}

.film-detail--with-poster {
    grid-template-columns: 200px 1fr;
}

.film-poster--large {
    width: 100%;
    max-width: 200px;
}

.film-detail h1 {
    margin-top: 0;
    color: var(--accent);
}

.film-facts {
    display: grid;
    grid-template-columns: auto 1fr;
    gap: 0.35rem 1.25rem;
    margin: 1rem 0;
    font-size: 0.95rem;
}

.film-facts dt {
    color: var(--muted);
    font-weight: 500;
}

.film-facts dd {
    margin: 0;
}

.film-detail h2 {
    font-size: 1.1rem;
    margin: 1.25rem 0 0.5rem;
}

@media (max-width: 600px) {
    .film-detail--with-poster {
        grid-template-columns: 1fr;
    }

    .film-poster--large {
        margin: 0 auto;
    }
}

.site-footer {
    margin-top: 3rem;
    padding-top: 1rem;
    border-top: 1px solid var(--border);
    color: var(--muted);
    font-size: 0.85rem;
}

@media (max-width: 480px) {
    .films-table {
        font-size: 0.8rem;
    }
}

/* —— Page statistiques —— */

.container--wide {
    max-width: 920px;
}

/* Magazines : utiliser davantage la largeur sur écran PC */
body.media-domain--magazine.page-wide .container--wide {
    max-width: min(1240px, calc(100vw - 2.5rem));
}

.stats-page h1 {
    margin-bottom: 0.35rem;
}

.stats-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(10.5rem, 1fr));
    gap: 0.85rem;
    margin: 1.5rem 0 2rem;
}

.stat-card {
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    padding: 1rem 1.1rem;
    text-align: center;
}

.stat-card--highlight {
    border-color: rgba(232, 185, 35, 0.45);
    background: rgba(232, 185, 35, 0.08);
}

.stat-card__value {
    margin: 0;
    font-size: 1.85rem;
    font-weight: 700;
    color: var(--accent);
    line-height: 1.15;
}

.stat-card__value--duration {
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

.stat-card__label {
    margin: 0.4rem 0 0;
    font-size: 0.82rem;
    color: var(--muted);
    line-height: 1.35;
}

.stat-card__label--with-info {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    gap: 0.35rem;
    flex-wrap: wrap;
}

.info-tooltip {
    position: relative;
    display: inline-flex;
    vertical-align: middle;
}

.info-tooltip__icon {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    width: 1rem;
    height: 1rem;
    font-size: 0.65rem;
    font-weight: 700;
    font-style: italic;
    font-family: Georgia, "Times New Roman", serif;
    color: var(--muted);
    border: 1px solid var(--border);
    border-radius: 50%;
    cursor: help;
    line-height: 1;
    transition: color 0.15s ease, border-color 0.15s ease;
}

.info-tooltip:hover .info-tooltip__icon,
.info-tooltip:focus-within .info-tooltip__icon {
    color: var(--accent);
    border-color: rgba(232, 185, 35, 0.5);
}

.info-tooltip__popup {
    position: absolute;
    bottom: calc(100% + 0.4rem);
    left: 50%;
    transform: translateX(-50%);
    width: max(14rem, 220px);
    max-width: min(17.5rem, 88vw);
    padding: 0.55rem 0.7rem;
    font-size: 0.72rem;
    font-weight: 400;
    font-style: normal;
    font-family: var(--font);
    line-height: 1.45;
    text-align: left;
    color: var(--text);
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
    box-shadow: 0 4px 14px rgba(0, 0, 0, 0.28);
    opacity: 0;
    visibility: hidden;
    pointer-events: none;
    z-index: 20;
    transition: opacity 0.15s ease, visibility 0.15s ease;
}

.info-tooltip__popup::after {
    content: "";
    position: absolute;
    top: 100%;
    left: 50%;
    transform: translateX(-50%);
    border: 5px solid transparent;
    border-top-color: var(--border);
}

.info-tooltip:hover .info-tooltip__popup,
.info-tooltip:focus-within .info-tooltip__popup {
    opacity: 1;
    visibility: visible;
}

.stat-card__hint {
    margin: 0.35rem 0 0;
    font-size: 0.75rem;
    color: var(--muted);
}

.stats-panel {
    margin-bottom: 2rem;
    padding: 1.25rem 1.35rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: var(--radius);
}

.stats-panel h2 {
    margin: 0 0 0.75rem;
    font-size: 1.2rem;
    color: var(--accent);
}

.stats-subtitle {
    margin: 1.25rem 0 0.65rem;
    font-size: 1rem;
    font-weight: 600;
}

.stats-notes-summary {
    display: flex;
    flex-wrap: wrap;
    gap: 1rem 1.5rem;
    align-items: flex-start;
}

.stat-inline {
    min-width: 9rem;
}

.stat-inline__value {
    display: block;
    font-size: 1.65rem;
    font-weight: 700;
    color: var(--text);
}

.stat-inline__label {
    display: block;
    font-size: 0.88rem;
    color: var(--muted);
}

.stat-inline__hint,
.stat-inline__aside {
    display: block;
    font-size: 0.8rem;
    color: var(--muted);
    margin-top: 0.2rem;
}

.note-chart {
    display: flex;
    flex-direction: column;
    gap: 0.45rem;
    margin-top: 0.5rem;
}

.note-chart__row {
    display: grid;
    grid-template-columns: 1.5rem 1fr 2.5rem;
    align-items: center;
    gap: 0.5rem;
}

.note-chart__label {
    font-weight: 600;
    color: var(--muted);
    text-align: right;
}

.note-chart__bar-wrap {
    height: 1.1rem;
    background: rgba(255, 255, 255, 0.06);
    border-radius: 4px;
    overflow: hidden;
}

.note-chart__bar {
    display: block;
    height: 100%;
    min-width: 2px;
    background: linear-gradient(90deg, rgba(232, 185, 35, 0.55), var(--accent));
    border-radius: 4px;
    transition: width 0.3s ease;
}

.note-chart__count {
    font-size: 0.85rem;
    color: var(--muted);
    text-align: right;
}

.support-chart__row {
    grid-template-columns: 6.5rem 1fr 4.5rem;
}

.support-chart__label {
    text-align: left;
    font-weight: 500;
    color: var(--text);
}

.support-chart__link {
    color: var(--accent);
    text-decoration: none;
}

.support-chart__link:hover {
    text-decoration: underline;
}

.support-chart__bar {
    background: linear-gradient(90deg, rgba(232, 185, 35, 0.45), rgba(245, 204, 74, 0.85));
}

.support-chart__pct {
    display: block;
    font-size: 0.72rem;
    opacity: 0.85;
}

.year-chart {
    display: flex;
    align-items: flex-end;
    gap: 0.5rem;
    min-height: 9rem;
    padding: 0.5rem 0 0;
    overflow-x: auto;
}

.year-chart__item {
    flex: 1 1 2.5rem;
    min-width: 2.25rem;
    display: flex;
    flex-direction: column;
    align-items: center;
    gap: 0.35rem;
}

.year-chart__bar-wrap {
    width: 100%;
    height: 7rem;
    display: flex;
    align-items: flex-end;
    justify-content: center;
}

.year-chart__bar {
    width: 70%;
    max-width: 2.5rem;
    min-height: 4px;
    background: linear-gradient(180deg, var(--accent), rgba(232, 185, 35, 0.45));
    border-radius: 4px 4px 0 0;
}

.year-chart__year {
    font-size: 0.78rem;
    font-weight: 600;
    color: var(--muted);
}

.year-chart__meta {
    font-size: 0.72rem;
    color: var(--muted);
}

.year-chart__meta-extra {
    opacity: 0.75;
    font-size: 0.68rem;
}

.stats-ranked-list {
    margin: 0;
    padding-left: 1.35rem;
}

.stats-ranked-list li {
    margin-bottom: 0.55rem;
}

.stats-ranked-list__link {
    color: var(--accent);
    text-decoration: none;
    font-weight: 500;
}

.stats-ranked-list__link:hover {
    text-decoration: underline;
}

.stats-ranked-list__meta {
    color: var(--muted);
    font-size: 0.9rem;
}

.tag--note {
    margin-left: 0.35rem;
    background: rgba(232, 185, 35, 0.2);
    color: var(--accent);
}

.is-hidden {
    display: none !important;
}

.tag--kind {
    display: inline-block;
    padding: 0.15rem 0.5rem;
    font-size: 0.8rem;
    border-radius: 4px;
    background: rgba(232, 185, 35, 0.12);
    color: var(--text);
    white-space: nowrap;
}

.tag--kind-serie {
    background: rgba(184, 220, 255, 0.15);
}

.tag--kind-documentaire {
    background: rgba(234, 179, 8, 0.18);
}

.tag--kind-spectacle {
    background: rgba(244, 114, 182, 0.15);
}

.film-ean {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.5rem 1rem;
}

.film-ean__code {
    font-variant-numeric: tabular-nums;
    letter-spacing: 0.02em;
}

.btn-sm {
    padding: 0.35rem 0.75rem;
    font-size: 0.9rem;
}

/* Propositions catalogue (phase 5) */
.catalog-submission-page .lead,
.catalog-submission-admin .lead {
    max-width: 42rem;
}

.submission-badge {
    display: inline-block;
    padding: 0.2rem 0.55rem;
    border-radius: 4px;
    font-size: 0.85rem;
    font-weight: 600;
}

.submission-badge--pending {
    background: rgba(251, 191, 36, 0.2);
    color: #fde68a;
}

.submission-badge--approved {
    background: rgba(74, 222, 128, 0.15);
    color: #86efac;
}

.submission-badge--rejected {
    background: rgba(248, 113, 113, 0.15);
    color: #fca5a5;
}

.submission-user-note {
    margin: 1rem 0;
    padding: 0.75rem 1rem;
    border-left: 3px solid var(--accent);
    background: var(--surface-muted);
}

.form-actions--stack {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem 0.75rem;
    align-items: center;
}

.catalog-submission-table td {
    vertical-align: top;
}

.wishlist-vote-badge {
    display: inline-flex;
    align-items: center;
    justify-content: center;
    min-width: 1.75rem;
    height: 1.75rem;
    padding: 0 0.4rem;
    border-radius: 999px;
    background: var(--accent);
    color: var(--bg);
    font-weight: 700;
    font-size: 0.9rem;
}

.wishlist-voters {
    font-size: 0.9rem;
    color: var(--muted);
    max-width: 14rem;
}

/* Notifications */
.notifications-page__mark-all {
    margin-bottom: 1rem;
}

.notification-list {
    list-style: none;
    margin: 0;
    padding: 0;
}

.notification-list__item {
    border-bottom: 1px solid var(--border);
}

.notification-list__item--unread {
    background: var(--surface-muted);
}

.notification-list__link {
    display: block;
    padding: 0.85rem 0.5rem;
    text-decoration: none;
    color: inherit;
}

.notification-list__link:hover {
    background: rgba(255, 255, 255, 0.04);
}

.notification-list__link .notification-list__title {
    color: var(--link);
}

.notification-list__link:hover .notification-list__title {
    color: var(--link-hover);
}

.notification-list__title {
    display: block;
    font-weight: 600;
}

.notification-list__body {
    display: block;
    margin-top: 0.25rem;
    font-size: 0.95rem;
    color: var(--muted);
    white-space: pre-line;
}

.notification-list__date {
    display: block;
    margin-top: 0.35rem;
    font-size: 0.85rem;
}

.user-search-results {
    list-style: none;
    margin: 1.25rem 0 0;
    padding: 0;
}

.user-search-results__item {
    display: flex;
    flex-wrap: wrap;
    align-items: baseline;
    gap: 0.35rem 0.75rem;
    padding: 0.75rem 0;
    border-bottom: 1px solid var(--border);
}

.user-search-results__name {
    font-weight: 600;
}

.user-search-results__meta {
    color: var(--muted);
    font-size: 0.95rem;
}

.checkbox-label {
    display: flex;
    align-items: flex-start;
    gap: 0.5rem;
    margin: 0.75rem 0 0;
    cursor: pointer;
}

.checkbox-label input[type="checkbox"] {
    margin-top: 0.2rem;
    flex-shrink: 0;
}

@media (max-width: 520px) {
    .stats-grid {
        grid-template-columns: repeat(2, 1fr);
    }

    .stat-card__value {
        font-size: 1.45rem;
    }

}

/* Profil public (amis / groupe) */
.user-profile-link {
    color: var(--accent);
    font-weight: 600;
    text-decoration: none;
}

.user-profile-link:hover {
    text-decoration: underline;
}

.social-profile-header__ville {
    margin: 0.25rem 0 0;
    color: var(--muted);
}

.social-profile-stats__list {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
    gap: 1rem 1.5rem;
    margin: 0;
}

.social-profile-stats__list > div {
    margin: 0;
}

.social-profile-stats__list dt {
    margin: 0 0 0.25rem;
    font-size: 0.85rem;
    color: var(--muted);
}

.social-profile-stats__list dd {
    margin: 0;
    font-size: 1.35rem;
    font-weight: 700;
}

.social-profile-stats__list dd a {
    color: var(--accent);
    text-decoration: none;
}

.social-profile-stats__list dd a:hover {
    text-decoration: underline;
}

.social-profile-section {
    margin-top: 2rem;
}

.social-poster-strip {
    display: flex;
    flex-wrap: wrap;
    gap: 0.85rem;
    list-style: none;
    margin: 0.75rem 0 0;
    padding: 0;
}

.social-poster-strip__item {
    width: 6.5rem;
    flex: 0 0 auto;
}

.social-poster-strip__card {
    margin: 0;
}

.social-poster-strip__poster {
    display: block;
    width: 100%;
    aspect-ratio: 2 / 3;
    object-fit: cover;
    border-radius: 6px;
    border: 1px solid var(--border);
    background: var(--bg);
}

.social-poster-strip__placeholder {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    aspect-ratio: 2 / 3;
    border-radius: 6px;
    border: 1px dashed var(--border);
    color: var(--muted);
    font-size: 1.5rem;
}

.social-poster-strip__caption {
    margin-top: 0.35rem;
    font-size: 0.72rem;
    line-height: 1.25;
}

.social-poster-strip__title {
    display: block;
    font-weight: 600;
    color: var(--text);
}

.social-poster-strip__year {
    color: var(--muted);
}

.social-poster-strip__link {
    display: block;
    color: inherit;
    text-decoration: none;
}

.social-poster-strip__link:hover .social-poster-strip__poster,
.social-poster-strip__link:focus-visible .social-poster-strip__poster {
    border-color: rgba(232, 185, 35, 0.55);
    box-shadow: 0 0 0 2px rgba(232, 185, 35, 0.2);
}

.home-dashboard {
    margin: 2.5rem 0 1rem;
    padding-top: 1.5rem;
    border-top: 1px solid var(--border);
}

.home-dashboard__title {
    margin: 0 0 0.5rem;
    font-size: 1.25rem;
}

.home-dashboard .social-profile-section h2 {
    margin-top: 0;
    font-size: 1rem;
}

.home-dashboard__more {
    margin: 0.5rem 0 0;
    font-size: 0.85rem;
}

.share-manage__new-link h2 {
    margin-top: 0;
    font-size: 1.05rem;
}

.share-delivery {
    margin-top: 0.75rem;
}

.share-delivery__url {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    align-items: center;
    margin: 0 0 0.75rem;
}

.share-delivery__input {
    flex: 1 1 12rem;
    min-width: 0;
    font-size: 0.82rem;
}

.share-delivery__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.5rem;
    margin-bottom: 0.75rem;
}

.share-delivery__email-form {
    margin-top: 0.5rem;
    padding-top: 0.75rem;
    border-top: 1px dashed var(--border);
}

.share-link-list__delivery {
    margin: 0.75rem 0;
    padding: 0.75rem;
    background: var(--surface);
    border: 1px solid var(--border);
    border-radius: 8px;
}

.share-link-list__no-url {
    margin: 0.5rem 0;
}

.social-profile-list-sort {
    margin: 0.75rem 0 1rem;
}

.social-profile-grid__card {
    cursor: default;
}

.social-viewings-table__film {
    display: flex;
    align-items: center;
    gap: 0.65rem;
    min-width: 12rem;
}

.social-viewings-table__poster {
    flex-shrink: 0;
    border-radius: 4px;
    border: 1px solid var(--border);
    object-fit: cover;
}

/* Magazines — séries et numéros (format couverture A4 portrait : 210 × 297 mm) */
.magazine-cover {
    display: block;
    aspect-ratio: 210 / 297;
    object-fit: cover;
    object-position: center top;
    border-radius: 4px;
    border: 1px solid var(--border);
    background: var(--surface, #1a1a1f);
}

.magazine-cover--thumb {
    width: 3rem;
    max-width: 3rem;
}

.magazine-cover--card {
    width: 100%;
}

.magazine-cover--header {
    width: 8rem;
    max-width: 8rem;
    flex-shrink: 0;
}

.magazine-cover--empty {
    background: var(--border);
}

.magazine-issues-table th:first-child,
.magazine-issues-table td:first-child {
    width: 1%;
    white-space: nowrap;
    vertical-align: middle;
}

.magazine-issues-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(6.25rem, 7rem));
    gap: 0.75rem 0.85rem;
    justify-content: start;
    margin-top: 0.5rem;
}

.magazine-issue-card {
    display: flex;
    flex-direction: column;
    max-width: 7rem;
    border: 1px solid var(--border);
    border-radius: 6px;
    overflow: hidden;
    background: var(--surface, #1a1a1f);
}

.magazine-issue-card__cover-link {
    display: block;
    text-decoration: none;
}

.magazine-issue-card__cover-link:hover .magazine-cover {
    border-color: var(--media-accent, var(--accent));
}

.magazine-issue-card__body {
    padding: 0.45rem 0.5rem 0.55rem;
    display: flex;
    flex-direction: column;
    gap: 0.2rem;
    flex: 1;
}

.magazine-issue-card__title {
    font-size: 0.8125rem;
    margin: 0;
    line-height: 1.25;
}

.magazine-issue-card__meta {
    margin: 0;
    font-size: 0.75rem;
    line-height: 1.3;
}

.magazine-issue-card__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.3rem;
    margin-top: auto;
    padding-top: 0.25rem;
}

.magazine-issue-card__actions .btn-sm {
    font-size: 0.75rem;
    padding: 0.2rem 0.45rem;
}

.magazine-support-tags {
    display: inline-flex;
    flex-wrap: wrap;
    gap: 0.25rem;
    margin-left: 0.15rem;
    vertical-align: middle;
}

.magazine-tag {
    display: inline-block;
    font-size: 0.7rem;
    font-weight: 600;
    line-height: 1.2;
    padding: 0.12rem 0.4rem;
    border-radius: 4px;
    border: 1px solid var(--border);
    text-transform: uppercase;
    letter-spacing: 0.02em;
}

.magazine-tag--pdf {
    border-color: rgba(46, 160, 220, 0.55);
    background: rgba(46, 160, 220, 0.15);
    color: #9cd4ff;
}

.magazine-tag--papier {
    border-color: rgba(180, 140, 80, 0.55);
    background: rgba(180, 140, 80, 0.12);
    color: #e8c88a;
}

.magazine-support-fieldset {
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.65rem 0.85rem;
    margin: 0.75rem 0;
}

.magazine-support-fieldset legend {
    padding: 0 0.35rem;
    font-weight: 600;
    font-size: 0.9rem;
}

.magazine-issues-search.collection-search {
    max-width: none;
}

.magazine-issues-search {
    max-width: none;
    margin: 0.85rem 0 0.65rem;
}

.magazine-issues-search__bar {
    margin-bottom: 0.35rem;
}

.magazine-issues-search__label {
    display: block;
    font-weight: 600;
    font-size: 0.9rem;
    margin-bottom: 0.35rem;
}

.magazine-issues-search__bar-row {
    display: flex;
    flex-wrap: wrap;
    gap: 0.45rem;
    align-items: center;
}

.magazine-issues-search__input {
    flex: 1 1 16rem;
    min-width: 0;
    max-width: none;
    font-size: 0.9rem;
    padding: 0.4rem 0.55rem;
}

.magazine-issues-search__hint {
    margin: 0.25rem 0 0;
    font-size: 0.85rem;
}

.magazine-issues-reindex {
    display: flex;
    flex-wrap: wrap;
    align-items: center;
    gap: 0.5rem;
    margin-bottom: 0.65rem;
}

@media (min-width: 720px) {
    .magazine-issues-search__bar-row {
        max-width: 52rem;
    }

    .magazine-issues-search__input {
        flex: 1 1 24rem;
    }
}

/* Ancien formulaire détaillé (conservé si réutilisé ailleurs) */
.magazine-issues-search__fields {
    border: 1px solid var(--border);
    border-radius: 6px;
    padding: 0.55rem 0.65rem;
    margin: 0;
}

.magazine-issues-search__fields legend {
    padding: 0 0.35rem;
    font-weight: 600;
    font-size: 0.9rem;
}

.magazine-issues-search__grid {
    display: flex;
    flex-direction: column;
    gap: 0.5rem;
}

.magazine-issues-search__row {
    display: flex;
    flex-direction: column;
    gap: 0.15rem;
    min-width: 0;
}

.magazine-issues-search__row label {
    font-size: 0.8125rem;
}

.magazine-issues-search__row input[type="search"] {
    font-size: 0.875rem;
    padding: 0.35rem 0.5rem;
}

.magazine-issues-search__actions {
    display: flex;
    flex-wrap: wrap;
    gap: 0.4rem;
    align-items: center;
}

@media (min-width: 720px) {
    .magazine-issues-search__fields {
        display: grid;
        grid-template-columns: auto minmax(5rem, 7.5rem) minmax(6.5rem, 9rem) minmax(7rem, 1fr) auto;
        gap: 0.4rem 0.6rem;
        align-items: end;
        padding: 0.4rem 0.65rem 0.45rem;
    }

    .magazine-issues-search__grid {
        display: contents;
    }

    .magazine-issues-search__fields legend {
        margin: 0;
        padding: 0 0.35rem 0 0;
        line-height: 1.9rem;
        white-space: nowrap;
    }
}

@media (min-width: 900px) {
    .magazine-issues-grid {
        grid-template-columns: repeat(auto-fill, minmax(6.5rem, 7.25rem));
        gap: 0.85rem 1rem;
    }

    .magazine-issue-card {
        max-width: 7.25rem;
    }
}

@media (min-width: 1100px) {
    .magazine-issues-grid {
        grid-template-columns: repeat(auto-fill, minmax(6.75rem, 7.5rem));
    }

    .magazine-issue-card {
        max-width: 7.5rem;
    }
}

.magazine-series-grid {
    display: grid;
    grid-template-columns: repeat(auto-fill, minmax(11rem, 1fr));
    gap: 1rem;
    margin-top: 1rem;
}

.magazine-series-card {
    display: flex;
    flex-direction: column;
    border: 1px solid var(--border);
    border-radius: 8px;
    overflow: hidden;
    text-decoration: none;
    color: inherit;
    background: var(--surface, #1a1a1f);
}

.magazine-series-card:hover {
    border-color: var(--media-accent, var(--accent));
}

.magazine-series-card__cover {
    width: 100%;
    aspect-ratio: 210 / 297;
    object-fit: cover;
    object-position: center top;
}

.magazine-series-card__cover--empty {
    background: var(--border);
    min-height: 8rem;
}

.magazine-series-card__body {
    padding: 0.65rem 0.75rem;
}

.magazine-series-card__title {
    font-size: 1rem;
    margin: 0 0 0.35rem;
}

.magazine-series-header__main {
    display: flex;
    gap: 1.25rem;
    align-items: flex-start;
    margin: 1rem 0;
}

.magazine-issue-layout__cover .magazine-cover {
    width: 100%;
}

.magazine-issue-layout {
    display: grid;
    grid-template-columns: minmax(8rem, 12rem) 1fr;
    gap: 1.5rem;
    margin-top: 1rem;
}

.magazine-sommaire__body {
    white-space: pre-wrap;
    line-height: 1.5;
}

@media (max-width: 640px) {
    .magazine-issue-layout {
        grid-template-columns: 1fr;
    }
}
