/* =========================================================================
   Prix CST — Frontend CSS — Design dark/or cinématographique
   ========================================================================= */

:root {
    --pcst-bg:           #07111e;
    --pcst-bg-card:      #0d1e30;
    --pcst-bg-card-hover:#122438;
    --pcst-gold:         #c9a94c;
    --pcst-gold-light:   #e8cc7e;
    --pcst-gold-dim:     rgba(201,169,76,.15);
    --pcst-gold-border:  rgba(201,169,76,.25);
    --pcst-text:         #f0ece4;
    --pcst-text-muted:   rgba(240,236,228,.55);
    --pcst-upcoming:     #c9a94c;
    --pcst-recent:       rgba(240,236,228,.4);
    --pcst-radius:       10px;
    --pcst-shadow:       0 4px 24px rgba(0,0,0,.45);
    --pcst-transition:   .22s ease;
}

/* ---- Wrapper ---- */
#pcst-films-wrapper {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    color: var(--pcst-text);
    max-width: 1280px;
    margin: 0 auto;
    padding: 0 20px 60px;
}

/* =========================================================================
   FILTRES
   ========================================================================= */
.pcst-filters {
    background: var(--pcst-bg-card);
    border: 1px solid var(--pcst-gold-border);
    border-radius: var(--pcst-radius);
    padding: 20px 24px;
    margin-bottom: 20px;
}

.pcst-filters-inner {
    display: flex;
    flex-wrap: wrap;
    align-items: flex-end;
    gap: 16px;
}

.pcst-filter-group {
    display: flex;
    flex-direction: column;
    gap: 6px;
    min-width: 160px;
}

.pcst-filter-group label {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 10px;
    font-weight: 700;
    letter-spacing: .12em;
    text-transform: uppercase;
    color: var(--pcst-gold);
    display: flex;
    align-items: center;
    gap: 5px;
}

.pcst-filter-group select,
.pcst-filter-group input[type="text"] {
    background: rgba(7,17,30,.8) !important;
    border: 1px solid var(--pcst-gold-border);
    border-radius: 6px;
    color: #f0ece4 !important;
    -webkit-text-fill-color: #f0ece4 !important;
    padding: 9px 12px;
    font-size: 13px;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    outline: none;
    transition: border-color var(--pcst-transition);
}
.pcst-filter-group select:focus,
.pcst-filter-group input[type="text"]:focus {
    border-color: var(--pcst-gold);
    box-shadow: 0 0 0 3px var(--pcst-gold-dim);
    color: #f0ece4 !important;
    -webkit-text-fill-color: #f0ece4 !important;
    background: rgba(7,17,30,.8) !important;
}
.pcst-filter-group input[type="text"]::placeholder {
    color: rgba(240,236,228,.45) !important;
    -webkit-text-fill-color: rgba(240,236,228,.45) !important;
    opacity: 1 !important;
}

.pcst-filter-group select:focus,
.pcst-filter-group input[type="text"]:focus {
    border-color: var(--pcst-gold);
    box-shadow: 0 0 0 3px var(--pcst-gold-dim);
}

.pcst-filter-group select option { background: #0d1e30; }

.pcst-search-group { flex: 1; min-width: 220px; }

.pcst-search-wrap { position: relative; }
.pcst-search-wrap input { width: 100%; padding-right: 36px; box-sizing: border-box; }
.pcst-search-icon {
    position: absolute; right: 11px; top: 50%;
    transform: translateY(-50%);
    color: var(--pcst-gold); font-size: 13px; pointer-events: none;
}

.pcst-btn-reset {
    background: transparent;
    border: 1px solid rgba(240,236,228,.2);
    color: var(--pcst-text-muted);
    border-radius: 6px;
    padding: 9px 14px;
    font-size: 12px;
    cursor: pointer;
    display: flex; align-items: center; gap: 6px;
    transition: all var(--pcst-transition);
    align-self: flex-end;
    height: 38px;
    font-family: 'Helvetica Neue', Arial, sans-serif;
}
.pcst-btn-reset:hover { border-color: var(--pcst-gold); color: var(--pcst-gold); }

/* =========================================================================
   BARRE LÉGENDE / COMPTEUR
   ========================================================================= */
.pcst-bar {
    display: flex; align-items: center; justify-content: flex-end;
    margin-bottom: 16px; padding: 0 4px;
}

.pcst-count {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px; color: #1a202c; font-weight: 600;
}
#pcst-count-display { color: #1a202c !important; font-weight: 700; }

/* =========================================================================
   GRILLE DE FILMS
   ========================================================================= */
.pcst-films-grid {
    display: grid;
    grid-template-columns: repeat(3, 1fr);
    gap: 22px;
}

/* Loader */
.pcst-loader-wrap {
    grid-column: 1 / -1;
    display: flex; justify-content: center; align-items: center;
    padding: 80px 0;
}
.pcst-loader {
    display: flex; flex-direction: column; align-items: center; gap: 14px;
    color: var(--pcst-gold);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px;
}
.pcst-loader i { font-size: 28px; }

/* No results */
.pcst-no-results {
    grid-column: 1 / -1;
    display: flex; flex-direction: column; align-items: center;
    padding: 60px 24px; gap: 16px;
    color: var(--pcst-text);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    background: var(--pcst-bg-card);
    border: 1px solid var(--pcst-gold-border);
    border-radius: var(--pcst-radius);
    font-size: 14px;
    text-align: center;
}
.pcst-no-results i { font-size: 36px; color: var(--pcst-gold); }
.pcst-no-results p { margin: 0; color: var(--pcst-text); }

/* =========================================================================
   CARTE FILM
   ========================================================================= */
.pcst-film-card {
    background: var(--pcst-bg-card);
    border: 1px solid var(--pcst-gold-border);
    border-radius: var(--pcst-radius);
    overflow: hidden;
    display: flex; flex-direction: column;
    transition: transform var(--pcst-transition), box-shadow var(--pcst-transition), border-color var(--pcst-transition);
    position: relative;
}
.pcst-film-card:hover {
    transform: translateY(-4px);
    box-shadow: var(--pcst-shadow);
    border-color: var(--pcst-gold);
}

/* Bande dorée sur le côté gauche pour "à venir" */
.pcst-film-card.is-upcoming::before {
    content: '';
    position: absolute; left: 0; top: 0; bottom: 0;
    width: 3px;
    background: linear-gradient(to bottom, var(--pcst-gold), rgba(201,169,76,.2));
    border-radius: 3px 0 0 3px;
}

/* Poster */
.pcst-card-poster {
    position: relative;
    height: 200px;
    overflow: hidden;
    background: rgba(7,17,30,.6);
    flex-shrink: 0;
}
.pcst-card-poster img {
    width: 100%; height: 100%;
    object-fit: cover;
    display: block;
    transition: transform .4s ease;
}
.pcst-film-card:hover .pcst-card-poster img {
    transform: scale(1.04);
}

.pcst-poster-empty {
    width: 100%; height: 100%;
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 10px;
    color: var(--pcst-gold-border);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 12px;
}
.pcst-poster-empty i { font-size: 36px; }

/* Type badge sur le poster */
.pcst-type-badge {
    position: absolute; bottom: 8px; left: 8px;
    background: rgba(7,17,30,.85);
    border: 1px solid var(--pcst-gold-border);
    color: var(--pcst-text-muted);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 10px; letter-spacing: .06em;
    padding: 3px 8px; border-radius: 4px;
    backdrop-filter: blur(4px);
}

/* Year pill sur le poster */
.pcst-year-pill {
    position: absolute; top: 10px; right: 10px;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 12px; font-weight: 800;
    padding: 4px 10px; border-radius: 20px;
}
.pcst-year-pill.upcoming {
    background: var(--pcst-gold);
    color: #07111e;
}
.pcst-year-pill.recent {
    background: rgba(7,17,30,.8);
    color: var(--pcst-text);
    border: 1px solid rgba(240,236,228,.2);
}
.pcst-year-pill.past {
    background: rgba(7,17,30,.6);
    color: var(--pcst-text-muted);
    border: 1px solid rgba(240,236,228,.1);
}

/* Body */

/* Date de sortie sur la carte */
.pcst-card-date {
    display: flex; align-items: center; gap: 5px;
    font-size: 11px; font-weight: 700;
    letter-spacing: .05em; text-transform: uppercase;
    color: var(--pcst-gold);
    margin-bottom: 2px;
}
.pcst-cal-icon { flex-shrink: 0; opacity: .85; }
.pcst-card-body {
    padding: 16px;
    display: flex; flex-direction: column; gap: 10px;
    flex: 1;
}

.pcst-card-title {
    font-size: 15px; font-weight: 700;
    color: var(--pcst-text);
    margin: 0; line-height: 1.35;
    font-family: 'Helvetica Neue', Arial, sans-serif;
}

/* Lauréats dans la carte */
.pcst-card-laureats {
    display: flex; flex-direction: column; gap: 8px;
}

.pcst-laureat-line {
    background: var(--pcst-gold-dim);
    border: 1px solid var(--pcst-gold-border);
    border-radius: 6px;
    padding: 8px 10px;
}

.pcst-laureat-name {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 12px; font-weight: 700;
    color: var(--pcst-gold-light);
    display: flex; align-items: center; gap: 5px;
}
.pcst-laureat-name i { font-size: 10px; opacity: .7; }

.pcst-laureat-meta {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 11px; color: var(--pcst-text-muted);
    margin-top: 2px; line-height: 1.4;
}

.pcst-prix-badge {
    display: inline-block;
    background: rgba(201,169,76,.08);
    border: 1px solid rgba(201,169,76,.2);
    color: var(--pcst-gold);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 9px; letter-spacing: .08em;
    font-weight: 700; text-transform: uppercase;
    padding: 2px 6px; border-radius: 3px;
    margin-top: 4px; display: inline-block;
}

/* Bouton IMDb */
.pcst-imdb-btn {
    display: flex; align-items: center; justify-content: center; gap: 7px;
    background: transparent;
    border: 1px solid var(--pcst-gold-border);
    color: var(--pcst-gold);
    border-radius: 6px;
    padding: 8px 12px;
    text-decoration: none;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 12px; font-weight: 600;
    transition: all var(--pcst-transition);
    margin-top: auto;
}
.pcst-imdb-btn:hover {
    background: var(--pcst-gold);
    color: #07111e;
    border-color: var(--pcst-gold);
    text-decoration: none;
}
.pcst-imdb-logo {
    background: var(--pcst-gold);
    color: #07111e;
    font-weight: 900; font-size: 10px;
    padding: 2px 5px; border-radius: 3px;
    transition: background var(--pcst-transition), color var(--pcst-transition);
}
.pcst-imdb-btn:hover .pcst-imdb-logo {
    background: #07111e;
    color: var(--pcst-gold);
}

/* =========================================================================
   RESPONSIVE
   ========================================================================= */
@media (max-width: 768px) {
    .pcst-films-grid { grid-template-columns: repeat(2, 1fr); gap: 14px; }
    .pcst-filters-inner { flex-direction: column; }
    .pcst-filter-group { min-width: 100%; }
    .pcst-bar { flex-direction: column; align-items: flex-start; gap: 10px; }
}

@media (max-width: 480px) {
    .pcst-films-grid { grid-template-columns: 1fr; gap: 14px; }
    #pcst-films-wrapper { padding: 0 12px 40px; }
}


/* =========================================================================
   MODAL LAURÉAT
   ========================================================================= */
.pcst-laureate-modal-overlay {
    display: flex;
    visibility: hidden;
    opacity: 0;
    pointer-events: none;
    position: fixed; inset: 0;
    background: rgba(7,17,30,.75);
    backdrop-filter: blur(6px);
    z-index: 999999;
    align-items: center;
    justify-content: center;
    padding: 20px;
    transition: opacity .2s ease, visibility .2s ease;
}
.pcst-laureate-modal-overlay.pcst-modal-visible {
    visibility: visible;
    opacity: 1;
    pointer-events: auto;
}

.pcst-laureate-modal {
    background: #0d1e30;
    border: 1px solid var(--pcst-gold-border);
    border-radius: 14px;
    box-shadow: 0 24px 80px rgba(0,0,0,.6);
    width: 720px; max-width: 95vw;
    max-height: 88vh;
    display: flex; flex-direction: column;
    overflow: hidden;
    animation: pcst-modal-in .22s ease;
    position: relative;
}
@keyframes pcst-modal-in {
    from { transform: translateY(24px) scale(.97); opacity: 0; }
    to   { transform: none; opacity: 1; }
}

.pcst-laureate-modal-close {
    position: absolute; top: 14px; right: 14px;
    background: rgba(240,236,228,.08);
    border: 1px solid rgba(240,236,228,.15);
    border-radius: 50%;
    width: 34px; height: 34px;
    display: flex; align-items: center; justify-content: center;
    color: var(--pcst-text-muted); cursor: pointer;
    font-size: 14px; transition: all .2s;
    z-index: 2;
}
.pcst-laureate-modal-close:hover {
    background: rgba(201,169,76,.15);
    border-color: var(--pcst-gold-border);
    color: var(--pcst-gold);
}

.pcst-laureate-modal-body {
    overflow-y: auto;
    flex: 1;
    padding: 28px;
}
.pcst-laureate-modal-body::-webkit-scrollbar { width: 4px; }
.pcst-laureate-modal-body::-webkit-scrollbar-track { background: transparent; }
.pcst-laureate-modal-body::-webkit-scrollbar-thumb { background: var(--pcst-gold-border); border-radius: 4px; }

/* Loader & erreur */
.pcst-laureate-modal-loading,
.pcst-laureate-modal-error {
    display: flex; flex-direction: column;
    align-items: center; justify-content: center;
    gap: 14px; padding: 60px 20px;
    color: var(--pcst-gold);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px;
}
.pcst-laureate-modal-loading i { font-size: 28px; }
.pcst-laureate-modal-error { color: var(--pcst-text-muted); }
.pcst-laureate-modal-error i { font-size: 32px; color: rgba(201,169,76,.4); }

/* En-tête modal */
.pcst-laureate-modal-header {
    display: flex; gap: 24px; align-items: flex-start;
    margin-bottom: 28px;
    padding-bottom: 24px;
    border-bottom: 1px solid rgba(201,169,76,.2);
}

.pcst-laureate-photo-wrap { flex-shrink: 0; }
.pcst-laureate-photo {
    width: 110px; height: 150px;
    object-fit: cover;
    border-radius: 8px;
    border: 2px solid var(--pcst-gold-border);
    display: block;
}
.pcst-laureate-photo-placeholder {
    width: 110px; height: 150px;
    border-radius: 8px;
    border: 2px solid var(--pcst-gold-border);
    background: rgba(7,17,30,.6);
    display: flex; align-items: center; justify-content: center;
    color: var(--pcst-gold-border); font-size: 40px;
}

.pcst-laureate-header-info {
    flex: 1; display: flex; flex-direction: column; gap: 10px;
    min-width: 0;
}

.pcst-laureate-name {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 22px; font-weight: 800;
    color: var(--pcst-text);
    margin: 0; line-height: 1.2;
}

.pcst-laureate-poste {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px; color: var(--pcst-text-muted);
    margin: 0;
}

.pcst-laureate-prix-list {
    display: flex; flex-direction: column; gap: 6px;
}
.pcst-laureate-prix-badge {
    display: inline-block;
    background: rgba(201,169,76,.1);
    border: 1px solid var(--pcst-gold-border);
    color: var(--pcst-gold);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 11px; font-weight: 600;
    padding: 4px 10px; border-radius: 4px;
    line-height: 1.4;
}
.pcst-laureate-prix-badge em { font-style: italic; opacity: .8; }

.pcst-laureate-imdb-btn {
    display: inline-flex; align-items: center; gap: 8px;
    background: transparent;
    border: 1px solid var(--pcst-gold-border);
    color: var(--pcst-gold);
    border-radius: 6px;
    padding: 8px 14px;
    text-decoration: none;
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 12px; font-weight: 600;
    transition: all .2s;
    align-self: flex-start;
    margin-top: 4px;
}
.pcst-laureate-imdb-btn:hover {
    background: var(--pcst-gold);
    color: #07111e;
    text-decoration: none;
}
.pcst-laureate-imdb-btn:hover .pcst-imdb-logo {
    background: #07111e; color: var(--pcst-gold);
}

/* Filmographie */
.pcst-laureate-filmo-section {}
.pcst-laureate-filmo-title {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px; font-weight: 700;
    text-transform: uppercase; letter-spacing: .08em;
    color: var(--pcst-gold);
    margin: 0 0 14px;
    display: flex; align-items: center; gap: 8px;
}

.pcst-laureate-filmo-list {
    display: flex; flex-direction: column; gap: 10px;
}

.pcst-filmo-item {
    display: flex; gap: 12px; align-items: center;
    background: rgba(7,17,30,.5);
    border: 1px solid rgba(240,236,228,.06);
    border-radius: 8px;
    padding: 10px 12px;
    transition: border-color .15s;
}
.pcst-filmo-item:hover { border-color: var(--pcst-gold-border); }

.pcst-filmo-poster {
    width: 36px; height: 52px;
    object-fit: cover;
    border-radius: 4px;
    flex-shrink: 0;
}
.pcst-filmo-poster-empty {
    width: 36px; height: 52px;
    border-radius: 4px;
    background: rgba(201,169,76,.08);
    display: flex; align-items: center; justify-content: center;
    color: var(--pcst-gold-border); font-size: 14px;
    flex-shrink: 0;
}

.pcst-filmo-info { flex: 1; min-width: 0; }
.pcst-filmo-title {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px; font-weight: 700;
    color: var(--pcst-text);
    white-space: nowrap; overflow: hidden; text-overflow: ellipsis;
}
.pcst-filmo-meta {
    display: flex; flex-wrap: wrap; gap: 6px;
    margin-top: 4px;
}
.pcst-filmo-year {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 11px; font-weight: 700;
    color: var(--pcst-gold); background: var(--pcst-gold-dim);
    padding: 1px 6px; border-radius: 3px;
}
.pcst-filmo-type, .pcst-filmo-role {
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 11px; color: var(--pcst-text-muted);
}
.pcst-filmo-type::before { content: '·'; margin-right: 4px; }

/* Lauréat cliquable */
.pcst-laureate-clickable {
    cursor: pointer;
    transition: background .15s, border-color .15s;
}
.pcst-laureate-clickable:hover {
    background: rgba(201,169,76,.2) !important;
    border-color: var(--pcst-gold) !important;
}
.pcst-laureate-icon { color: var(--pcst-gold); font-size: 10px; }
.pcst-laureate-arrow {
    margin-left: auto;
    font-size: 9px;
    opacity: .5;
    transition: opacity .15s, transform .15s;
}
.pcst-laureate-clickable:hover .pcst-laureate-arrow {
    opacity: 1; transform: translateX(2px);
}

body.pcst-modal-open { overflow: hidden; }

@media (max-width: 600px) {
    .pcst-laureate-modal-header { flex-direction: column; align-items: center; text-align: center; }
    .pcst-laureate-prix-list { align-items: center; }
    .pcst-laureate-imdb-btn { align-self: center; }
}

/* ---- Loader infinite scroll ---- */
.pcst-scroll-loader {
    display: flex;
    align-items: center;
    justify-content: center;
    gap: 10px;
    padding: 32px 0;
    color: var(--pcst-gold);
    font-family: 'Helvetica Neue', Arial, sans-serif;
    font-size: 13px;
    letter-spacing: .06em;
}
.pcst-scroll-loader i {
    font-size: 18px;
}
.pcst-end-message {
    text-align: center;
    padding: 32px 0 16px;
    color: var(--pcst-text-muted);
    font-size: 12px;
    letter-spacing: .08em;
    font-family: 'Helvetica Neue', Arial, sans-serif;
}

#pcst-count-display { color: #1a202c !important; font-weight: 700; }
