/* ═══════════════════════════════════════════════════════════
   VHS STREAMING — Premium OTT · Style Netflix cinématique
   Noir profond + rouge signature + or IMDb
   ═══════════════════════════════════════════════════════════ */
:root {
    --bg:        #0A0A0C;
    --bg2:       #111113;
    --bg3:       #18181B;
    --bg-elev:   #202024;
    --border:    rgba(255,255,255,0.08);
    --border-hi: rgba(255,255,255,0.18);
    --accent:    #E50914;
    --accent-hi: #F6121D;
    --accent-soft: rgba(229,9,20,0.16);
    --gold:      #F5C518;
    --danger:    #EF4444;
    --text:      #F8FAFC;
    --muted:     #9CA3AF;
    --card-w:    210px;
    --poster-w:  150px;
    --radius:    6px;
    --radius-lg: 12px;
    --nav-h:     96px;            /* topbar 32 + navbar 64 */
    --dur-1:     150ms;
    --dur-2:     280ms;
    --dur-3:     450ms;
    --ease-out:  cubic-bezier(0.16, 1, 0.3, 1);
    --font:      'Inter', -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif;
    --shadow-card: 0 16px 40px -12px rgba(0,0,0,0.85);
    --shadow-pop:  0 30px 70px -18px rgba(0,0,0,0.95);
    --focus:     0 0 0 2px var(--bg), 0 0 0 4px var(--accent);
    color-scheme: dark;
}
*,*::before,*::after{box-sizing:border-box;margin:0;padding:0}
html{scroll-behavior:smooth}
body{
    background:var(--bg);color:var(--text);
    font-family:var(--font);font-size:16px;line-height:1.6;
    min-height:100vh;overflow-x:hidden;
    -webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;
}
a{color:inherit;text-decoration:none}
a,button,input[type="submit"]{touch-action:manipulation}
img{display:block;max-width:100%}
::selection{background:var(--accent-soft);color:#fff}
::-webkit-scrollbar{width:8px;height:6px}
::-webkit-scrollbar-track{background:transparent}
::-webkit-scrollbar-thumb{background:#2A2A31;border-radius:4px;border:2px solid var(--bg)}
::-webkit-scrollbar-thumb:hover{background:#3A3A44}
:focus-visible{outline:none;box-shadow:var(--focus);border-radius:4px}

/* ── TOPBAR ── */
.topbar{
    position:fixed;top:0;left:0;right:0;z-index:400;
    height:32px;background:rgba(8,8,10,0.92);
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    border-bottom:1px solid var(--border);
    display:flex;align-items:center;justify-content:flex-end;
    padding:0 4%;gap:16px;
}
.topbar-msg{color:var(--muted);font-size:0.75em;letter-spacing:0.02em}
.topbar-link{
    color:var(--muted);font-size:0.75em;font-weight:500;
    padding:3px 12px;border-radius:99px;border:1px solid var(--border);
    transition:color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out);
}
.topbar-link:hover{color:#fff;border-color:var(--accent);background:var(--accent-soft)}

/* ── NAVBAR — transparente sur le billboard, opaque au scroll ── */
.navbar{
    position:fixed;top:32px;left:0;right:0;z-index:300;
    height:64px;
    background:linear-gradient(to bottom, rgba(8,8,10,0.85) 0%, rgba(8,8,10,0.35) 60%, transparent 100%);
    display:flex;align-items:center;padding:0 4%;gap:0;
    transition:background var(--dur-3) ease;
}
.navbar.scrolled{
    background:rgba(10,10,12,0.92);
    -webkit-backdrop-filter:blur(20px) saturate(160%);backdrop-filter:blur(20px) saturate(160%);
    border-bottom:1px solid var(--border);
    box-shadow:0 12px 30px -18px rgba(0,0,0,0.9);
}
.navbar-logo{flex-shrink:0;margin-right:30px;display:flex;align-items:center}
.navbar-logo img{height:32px;width:auto;filter:drop-shadow(0 2px 8px rgba(0,0,0,0.6));transition:transform var(--dur-2) var(--ease-out)}
.navbar-logo a:hover img{transform:scale(1.06)}
.navbar-links{display:flex;align-items:center;gap:2px;flex:1;overflow-x:auto;scrollbar-width:none}
.navbar-links::-webkit-scrollbar{display:none}
.navbar-links a{
    position:relative;color:#D7DBE0;font-size:0.85em;font-weight:500;
    padding:11px 13px;border-radius:6px;white-space:nowrap;
    text-shadow:0 1px 4px rgba(0,0,0,0.6);
    transition:color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out);
}
.navbar-links a::after{
    content:"";position:absolute;left:13px;right:13px;bottom:4px;height:2px;
    background:var(--accent);border-radius:2px;
    transform:scaleX(0);transform-origin:center;
    transition:transform var(--dur-2) var(--ease-out);
}
.navbar-links a:hover,.navbar-links a:focus-visible{color:#fff;background:rgba(255,255,255,0.06)}
.navbar-links a.active{color:#fff;font-weight:600}
.navbar-links a.active::after{transform:scaleX(1)}
.navbar-search{margin-left:auto;flex-shrink:0;padding-left:16px}

/* Recherche */
#frm1{display:flex!important;width:215px!important;padding:0!important;gap:0;position:relative}
#searchtool{
    flex:1;height:38px!important;font-size:0.85em!important;font-family:var(--font);
    padding:0 38px 0 14px!important;border-radius:99px!important;
    border:1px solid var(--border-hi)!important;
    background:rgba(10,10,12,0.55)!important;background-image:none!important;
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    color:#fff!important;outline:none!important;width:auto!important;float:none!important;
    margin:0!important;line-height:normal!important;
    transition:border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out);
}
#searchtool:focus{border-color:var(--accent)!important;background:rgba(10,10,12,0.85)!important}
#searchtool::placeholder{color:var(--muted)}
#frm1 button[type="submit"]{
    position:absolute;right:3px;top:3px;
    display:flex;align-items:center;justify-content:center;
    width:32px;height:32px;border-radius:99px;
    background:transparent;border:none;cursor:pointer;
    color:var(--muted);margin:0;flex-shrink:0;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out);
}
#frm1 button[type="submit"]:hover{background:var(--accent);color:#fff}

/* ── STRUCTURE ── */
.body-wrap{display:flex;flex-direction:column;min-height:100vh;padding-top:var(--nav-h)}
.page-wrap{flex:1;padding-bottom:48px}

.section-header{display:flex;align-items:center;gap:10px;padding:28px 4% 6px}
.section-header h2{font-size:1.4em;font-weight:700;letter-spacing:-0.01em;color:var(--text)}
.section-header::before{content:"";width:4px;height:1.25em;background:var(--accent);border-radius:2px}

/* ── BILLBOARD — film à la une ── */
.billboard{
    position:relative;overflow:hidden;
    margin-top:calc(-1 * var(--nav-h));
    min-height:min(82vh, 760px);
    display:flex;align-items:flex-end;
    background:var(--bg2);
}
.billboard-bg{
    position:absolute;inset:0;
    background-size:cover;background-position:center 20%;
    animation:billboard-in 1.6s var(--ease-out) both;
    will-change:transform,opacity;
}
@keyframes billboard-in{
    from{opacity:0;transform:scale(1.06)}
    to  {opacity:1;transform:scale(1)}
}
.billboard-grad{
    position:absolute;inset:0;pointer-events:none;
    background:
        linear-gradient(to top, var(--bg) 0%, rgba(10,10,12,0.55) 28%, rgba(10,10,12,0.1) 55%, rgba(10,10,12,0.35) 100%),
        linear-gradient(to right, rgba(10,10,12,0.92) 0%, rgba(10,10,12,0.45) 42%, transparent 68%);
}
.billboard-content{
    position:relative;z-index:1;
    max-width:640px;
    padding:0 4% 9vh;
    animation:billboard-rise 0.9s var(--ease-out) 0.25s both;
}
@keyframes billboard-rise{
    from{opacity:0;transform:translateY(26px)}
    to  {opacity:1;transform:none}
}
.billboard-eyebrow{
    display:flex;align-items:center;gap:10px;
    color:#D7DBE0;font-size:0.74em;font-weight:700;
    letter-spacing:0.3em;text-transform:uppercase;margin-bottom:16px;
}
.brand-mark{
    color:var(--accent);font-weight:800;font-style:italic;
    font-size:1.35em;letter-spacing:0.05em;
    text-shadow:0 2px 14px rgba(229,9,20,0.5);
}
.billboard-title{
    font-size:clamp(2.1em, 5.2vw, 3.8em);font-weight:800;letter-spacing:-0.025em;
    color:#fff;line-height:1.05;margin-bottom:18px;
    text-shadow:0 4px 30px rgba(0,0,0,0.7);
    text-wrap:balance;
}
.billboard-meta{
    display:flex;align-items:center;flex-wrap:wrap;gap:14px;
    margin-bottom:16px;font-size:0.9em;
}
.billboard-meta .meta-rating{
    color:var(--gold);font-weight:700;
    display:inline-flex;align-items:center;gap:5px;
}
.billboard-meta .meta-year{color:#D7DBE0;font-weight:600;font-variant-numeric:tabular-nums}
.billboard-meta .meta-genre{
    color:#C9D2DC;
    padding:3px 12px;border:1px solid var(--border-hi);border-radius:99px;
    font-size:0.82em;font-weight:500;text-transform:capitalize;
    transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out);
}
.billboard-meta .meta-genre:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.billboard-overview{
    color:rgba(248,250,252,0.82);font-size:1em;line-height:1.65;
    margin-bottom:26px;max-width:54ch;
    display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
    text-shadow:0 1px 10px rgba(0,0,0,0.6);
}
.billboard-actions{display:flex;gap:12px;flex-wrap:wrap}
.btn-play{
    display:inline-flex;align-items:center;gap:10px;
    min-height:50px;padding:13px 32px;
    background:#fff;color:#0A0A0C;font-weight:700;font-size:1em;
    border-radius:var(--radius);
    transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out),box-shadow var(--dur-2) var(--ease-out);
    box-shadow:0 10px 36px -10px rgba(0,0,0,0.8);
}
.btn-play svg{width:22px;height:22px}
.btn-play:hover{background:rgba(255,255,255,0.82)}
.btn-play:active{transform:scale(0.97)}
.btn-more{
    display:inline-flex;align-items:center;gap:10px;
    min-height:50px;padding:13px 28px;
    background:rgba(109,109,110,0.45);color:#fff;font-weight:600;font-size:0.95em;
    border-radius:var(--radius);
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out);
}
.btn-more:hover{background:rgba(109,109,110,0.65)}
.btn-more:active{transform:scale(0.97)}

/* ── HERO statique (repli sans backdrop + pages secondaires) ── */
.hero{
    position:relative;overflow:hidden;
    margin-top:calc(-1 * var(--nav-h));
    min-height:380px;
    background:#0B0B10;
    display:flex;align-items:flex-end;padding:0 4% 7vh;
}
.hero::before{
    content:"";position:absolute;inset:-40%;
    background:
        radial-gradient(ellipse 42% 38% at 28% 55%, rgba(229,9,20,0.20) 0%, transparent 70%),
        radial-gradient(ellipse 36% 34% at 72% 30%, rgba(49,46,129,0.45) 0%, transparent 70%),
        radial-gradient(ellipse 30% 30% at 60% 80%, rgba(245,197,24,0.06) 0%, transparent 70%);
    animation:hero-drift 26s ease-in-out infinite alternate;
    will-change:transform;pointer-events:none;
}
.hero::after{
    content:"";position:absolute;inset:0;
    background:linear-gradient(to top, var(--bg) 0%, transparent 45%);
    pointer-events:none;
}
@keyframes hero-drift{
    from{transform:translate3d(-3%, -2%, 0) scale(1)}
    to  {transform:translate3d( 3%,  3%, 0) scale(1.07)}
}
.hero-content{position:relative;z-index:1;max-width:620px}
.hero-eyebrow{
    display:flex;align-items:center;gap:10px;
    color:#D7DBE0;font-size:0.74em;font-weight:700;
    letter-spacing:0.3em;text-transform:uppercase;margin-bottom:14px;
}
.hero h1{
    font-size:clamp(1.9em, 4.5vw, 3em);font-weight:800;letter-spacing:-0.02em;
    color:#fff;line-height:1.1;margin-bottom:14px;
}
.hero p{color:rgba(248,250,252,0.7);font-size:1em;line-height:1.6;margin-bottom:24px;max-width:46ch}
.hero-btn{
    display:inline-flex;align-items:center;gap:8px;
    min-height:48px;padding:12px 28px;
    background:var(--accent);color:#fff;font-weight:600;font-size:0.95em;
    border-radius:var(--radius);
    transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out),box-shadow var(--dur-2) var(--ease-out);
    box-shadow:0 10px 30px -8px rgba(229,9,20,0.55);
}
.hero-btn::after{content:"›";font-size:1.2em;line-height:1;transition:transform var(--dur-1) var(--ease-out)}
.hero-btn:hover{background:var(--accent-hi);box-shadow:0 14px 36px -8px rgba(229,9,20,0.7)}
.hero-btn:hover::after{transform:translateX(3px)}
.hero-btn:active{transform:scale(0.97)}
.hero-fade{position:absolute;right:0;top:0;bottom:0;width:34%;background:linear-gradient(to left,rgba(10,10,12,0.85),transparent);pointer-events:none}

/* ── RANGÉES ── */
.row{margin-bottom:4px;position:relative;content-visibility:auto;contain-intrinsic-size:auto 200px}
.billboard + .page-wrap .row:first-child,
.billboard ~ .page-wrap > .row:first-child{margin-top:-40px;z-index:5}
.row-header{display:flex;align-items:baseline;padding:24px 4% 10px;gap:8px}
.row-title{
    font-size:1.12em;font-weight:700;letter-spacing:-0.01em;color:#E5E9EE;flex:1;
    display:flex;align-items:center;gap:10px;
}
.row-title::before{content:"";width:4px;height:1.1em;background:var(--accent);border-radius:2px;flex-shrink:0}
.row-more{
    color:var(--muted);font-size:0.8em;font-weight:500;white-space:nowrap;
    padding:6px 0;
    transition:color var(--dur-1) var(--ease-out);
}
.row-more:hover{color:#fff}
.row-strip{
    display:flex;gap:10px;overflow-x:auto;
    padding:8px 4% 22px;
    scroll-snap-type:x proximity;scroll-padding:0 4%;-webkit-overflow-scrolling:touch;
    scrollbar-width:none;
}
.row-strip::-webkit-scrollbar{display:none}

/* Flèches de défilement (desktop) */
.row-arrow{
    position:absolute;top:50%;z-index:30;
    width:44px;height:70px;margin-top:-18px;
    display:flex;align-items:center;justify-content:center;
    background:rgba(10,10,12,0.72);color:#fff;
    border:1px solid var(--border);border-radius:var(--radius);
    cursor:pointer;opacity:0;
    -webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);
    transition:opacity var(--dur-2) var(--ease-out),background var(--dur-1) var(--ease-out);
}
.row-arrow svg{width:20px;height:20px}
.row-arrow:hover{background:rgba(229,9,20,0.85)}
.row-arrow.prev{left:10px}
.row-arrow.next{right:10px}
@media(hover:hover) and (pointer:fine){
    .row:hover .row-arrow,.row-arrow:focus-visible{opacity:1}
}

/* ── TOP 10 — gros numéros façon Netflix ── */
.top10-strip{align-items:flex-end}
.top10-item{
    display:flex;align-items:flex-end;flex-shrink:0;
    scroll-snap-align:start;
}
.top10-num{
    font-size:clamp(96px, 10.5vw, 170px);font-weight:800;line-height:0.95;
    letter-spacing:-0.06em;
    color:var(--bg);
    -webkit-text-stroke:4px #797985;
    text-stroke:4px #797985;
    margin-right:-0.07em;
    margin-bottom:-0.12em;
    user-select:none;pointer-events:none;
    font-variant-numeric:tabular-nums;
    transition:-webkit-text-stroke-color var(--dur-2) ease;
}
.top10-item:hover .top10-num{-webkit-text-stroke-color:var(--accent)}
.top10-item .card{width:var(--poster-w)}

/* ── GRILLE ── */
.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(var(--card-w),1fr));gap:12px;padding:14px 4% 24px}

/* ── SAGAS & TRILOGIES ── */
.saga-strip{gap:12px}
.saga-card{
    flex:0 0 auto;width:230px;height:104px;
    display:flex;flex-direction:column;justify-content:space-between;
    padding:14px 16px;border-radius:var(--radius-lg);
    background:linear-gradient(135deg,var(--bg3),var(--bg2));
    box-shadow:0 0 0 1px var(--border);text-decoration:none;color:var(--text);
    transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out);
}
.saga-card:hover{transform:translateY(-3px);box-shadow:0 0 0 1px var(--border-hi),var(--shadow-card)}
.saga-card:focus-visible{box-shadow:var(--focus)}
.saga-card-tag{
    align-self:flex-start;font-size:0.66em;font-weight:700;letter-spacing:0.04em;text-transform:uppercase;
    padding:3px 9px;border-radius:20px;background:var(--accent-soft);color:var(--accent-hi);
}
.saga-card-tag.tri{background:rgba(245,197,24,0.16);color:var(--gold)}
.saga-card-name{font-size:1.05em;font-weight:700;line-height:1.15;
    display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.saga-card-count{font-size:0.72em;color:var(--muted)}

/* badge saga/trilogie sur les cartes film */
.card-saga-badge{
    position:absolute;top:8px;left:8px;z-index:3;
    font-size:0.6em;font-weight:700;letter-spacing:0.03em;text-transform:uppercase;
    padding:3px 7px;border-radius:6px;cursor:pointer;
    background:rgba(10,10,12,0.78);color:var(--gold);box-shadow:0 0 0 1px var(--border-hi);
    backdrop-filter:blur(4px);transition:background var(--dur-1),color var(--dur-1)}
.card-saga-badge:hover{background:var(--accent);color:#fff}

/* numéro d'ordre (page collection) */
.card-order{
    position:absolute;top:8px;left:8px;z-index:3;
    width:26px;height:26px;border-radius:50%;
    background:var(--accent);color:#fff;font-size:0.8em;font-weight:700;
    display:flex;align-items:center;justify-content:center;box-shadow:0 2px 8px rgba(0,0,0,0.6)}

/* hero de la page collection */
.collection-hero{padding:36px 4% 22px;background:linear-gradient(180deg,var(--bg2),var(--bg))}
.collection-hero .ch-tag{
    display:inline-block;font-size:0.72em;font-weight:700;letter-spacing:0.05em;text-transform:uppercase;
    padding:4px 12px;border-radius:20px;margin-bottom:12px;
    background:rgba(245,197,24,0.16);color:var(--gold)}
.collection-hero .ch-tag.saga{background:var(--accent-soft);color:var(--accent-hi)}
.collection-hero h1{font-size:2em;font-weight:800;letter-spacing:-0.02em;margin-bottom:8px}
.collection-hero .ch-sub{color:var(--muted);margin-bottom:18px;font-variant-numeric:tabular-nums}
.collection-hero .ch-play{
    display:inline-flex;align-items:center;gap:9px;
    background:var(--accent);color:#fff;font-weight:700;
    padding:11px 24px;border-radius:8px;text-decoration:none;
    transition:background var(--dur-1)}
.collection-hero .ch-play:hover{background:var(--accent-hi)}
.collection-hero .ch-play svg{width:20px;height:20px;fill:currentColor}
.ch-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}

/* ── PAGE FILM DÉDIÉE ── */
.detail-hero{position:relative;min-height:62vh;display:flex;align-items:flex-end;padding:48px 4% 34px;overflow:hidden}
.detail-hero::before{content:"";position:absolute;inset:0;z-index:0;background:var(--bd) center 18%/cover no-repeat}
.detail-bg{position:absolute;inset:0;z-index:1;width:100%;height:100%;object-fit:cover;background:#000}
.detail-hero::after{content:"";position:absolute;inset:0;z-index:2;background:
    linear-gradient(90deg,rgba(10,10,12,0.94) 0%,rgba(10,10,12,0.62) 44%,rgba(10,10,12,0.20) 100%),
    linear-gradient(0deg,var(--bg) 1%,rgba(10,10,12,0.10) 48%,transparent 72%)}
.detail-mute{position:absolute;top:18px;right:4%;z-index:4;width:42px;height:42px;border-radius:50%;
    border:1px solid rgba(255,255,255,0.5);background:rgba(0,0,0,0.45);color:#fff;cursor:pointer;
    display:flex;align-items:center;justify-content:center;backdrop-filter:blur(4px);transition:background var(--dur-1)}
.detail-mute:hover{background:rgba(0,0,0,0.72)}
.detail-mute svg{width:20px;height:20px;fill:currentColor}
.detail-hero-inner{position:relative;z-index:3;display:flex;gap:32px;align-items:flex-end;max-width:1180px;margin:0 auto;width:100%}
.detail-poster{flex:0 0 auto;width:220px;border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-card),0 0 0 1px var(--border-hi)}
.detail-poster img{width:100%;display:block}
.detail-meta{flex:1;min-width:0;max-width:820px;text-shadow:0 1px 12px rgba(0,0,0,0.6)}
.detail-logo{max-width:min(64%,460px);max-height:190px;width:auto;height:auto;margin-bottom:18px;filter:drop-shadow(0 6px 18px rgba(0,0,0,0.7))}
.detail-title{font-size:2.7em;font-weight:800;letter-spacing:-0.02em;line-height:1.04;margin-bottom:14px}
.detail-tags{display:flex;flex-wrap:wrap;gap:8px;align-items:center;margin-bottom:14px;color:var(--muted);font-size:0.92em;font-variant-numeric:tabular-nums}
.detail-tags .dt-rating{color:var(--gold)}
.detail-tags .dt-badge{background:var(--accent-soft);color:var(--accent-hi);padding:2px 8px;border-radius:4px;font-size:0.85em;font-weight:700}
.detail-tags .dt-genre{color:var(--muted);text-decoration:none;border:1px solid var(--border);padding:2px 9px;border-radius:20px;transition:border-color var(--dur-1),color var(--dur-1)}
.detail-tags .dt-genre:hover{color:#fff;border-color:var(--border-hi)}
.detail-director{color:var(--muted);margin-bottom:12px;font-size:0.92em}
.detail-director strong{color:var(--text);font-weight:600}
.detail-overview{max-width:660px;color:#e7eaf0;line-height:1.6;margin-bottom:22px}
.detail-actions{display:flex;flex-wrap:wrap;gap:12px;align-items:center}
.dt-play{display:inline-flex;align-items:center;gap:9px;text-decoration:none;font-weight:700;padding:12px 26px;border-radius:8px;transition:background var(--dur-1),box-shadow var(--dur-1)}
.dt-play svg{width:20px;height:20px;fill:currentColor}
.dt-resume{background:var(--accent);color:#fff}
.dt-resume:hover{background:var(--accent-hi)}
.dt-start{background:var(--bg-elev);color:var(--text);box-shadow:0 0 0 1px var(--border)}
.dt-start:hover{box-shadow:0 0 0 1px var(--border-hi)}
.dt-progress{display:flex;align-items:center;gap:10px;width:100%;max-width:420px;margin-top:4px}
.dt-progress-bar{flex:1;height:5px;background:var(--bg-elev);border-radius:3px;overflow:hidden}
.dt-progress-bar i{display:block;height:100%;background:var(--accent)}
.dt-progress-txt{font-size:0.8em;color:var(--muted);white-space:nowrap}

/* distribution (acteurs) */
.detail-cast .row-strip{padding-top:6px}
.cast-card{flex:0 0 auto;width:104px;text-align:center}
.cast-photo{width:104px;height:104px;border-radius:50%;background:var(--bg3) center/cover no-repeat;box-shadow:0 0 0 1px var(--border);display:flex;align-items:center;justify-content:center;margin:0 auto 8px}
.cast-photo span{font-size:2em;font-weight:700;color:var(--muted)}
.cast-name{font-size:0.8em;font-weight:600;line-height:1.2}
.cast-role{font-size:0.72em;color:var(--muted);line-height:1.2;margin-top:2px}

/* barre de progression sur les cartes (page collection) */
.card-thumb{position:relative}
.card-progress{position:absolute;left:0;right:0;bottom:0;height:4px;background:rgba(0,0,0,0.55);z-index:3}
.card-progress i{display:block;height:100%;background:var(--accent)}

@media(max-width:640px){
    .detail-hero{min-height:46vh;padding:28px 5% 22px}
    .detail-hero-inner{flex-direction:column;align-items:flex-start;gap:18px}
    .detail-logo{max-height:110px;max-width:78%}
    .detail-title{font-size:1.7em}
}

/* ── CARTE ── */
.card{
    flex-shrink:0;width:var(--card-w);
    position:relative;border-radius:var(--radius);overflow:hidden;
    cursor:pointer;scroll-snap-align:start;
    background:var(--bg3);
    box-shadow:0 0 0 1px var(--border);
    transition:transform var(--dur-2) var(--ease-out),box-shadow var(--dur-2) var(--ease-out);
}
.grid .card{width:auto}
.card a{display:block;color:inherit}
.card:hover,.card:focus-within{
    transform:translateY(-5px) scale(1.05);
    z-index:20;
    box-shadow:0 0 0 1px var(--border-hi),var(--shadow-pop);
}
.card:active{transform:translateY(-2px) scale(1.01)}
.card a:focus-visible{box-shadow:var(--focus);display:block;border-radius:var(--radius)}

/* Apparition (classe posée par tv-nav.js — sans JS tout reste visible) */
.card.will-reveal{opacity:0;transform:translateY(14px)}
.card.revealed{
    opacity:1;transform:none;
    transition:opacity var(--dur-3) var(--ease-out),transform var(--dur-3) var(--ease-out),box-shadow var(--dur-2) var(--ease-out);
}

/* Miniature 16:9 — et variante affiche portrait 2:3 */
.card-thumb{
    position:relative;width:100%;
    aspect-ratio:16/9;overflow:hidden;background:var(--bg3);
}
.card--poster .card-thumb{aspect-ratio:2/3}
.card-thumb img{
    position:absolute;inset:0;width:100%;height:100%;
    object-fit:cover;object-position:center;
    transition:opacity var(--dur-3) ease,transform var(--dur-3) var(--ease-out);
    opacity:0;
}
.card-thumb img.loaded{opacity:1}
.card:hover .card-thumb img{transform:scale(1.07)}

/* Squelette shimmer quand pas encore d'image */
.card-placeholder{
    position:absolute;inset:0;
    display:flex;align-items:flex-end;padding:10px;
    background:linear-gradient(160deg,#1A1A1F 0%,#101014 100%);
    transition:opacity var(--dur-3) ease;
    overflow:hidden;
}
.card-placeholder::before{
    content:"";position:absolute;inset:0;
    background:linear-gradient(105deg,transparent 38%,rgba(255,255,255,0.045) 50%,transparent 62%);
    transform:translateX(-100%);
    animation:shimmer 1.8s ease-in-out infinite;
}
@keyframes shimmer{to{transform:translateX(100%)}}
.card-placeholder span{
    position:relative;color:#6B7684;font-size:0.72em;font-weight:600;letter-spacing:0.01em;
    line-height:1.3;display:-webkit-box;
    -webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;
}
.card-thumb img.loaded + .card-placeholder{opacity:0;pointer-events:none}
.card-thumb img.loaded + .card-placeholder::before{animation:none}

/* Overlay : dégradé bas + lecture */
.card-overlay{
    position:absolute;inset:0;
    display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;
    background:linear-gradient(to top,rgba(5,5,8,0.94) 0%,rgba(5,5,8,0.35) 55%,rgba(5,5,8,0.15) 100%);
    opacity:0;transition:opacity var(--dur-2) var(--ease-out);
}
.card:hover .card-overlay,.card:focus-within .card-overlay{opacity:1}
.card-play{
    display:flex;align-items:center;justify-content:center;
    width:46px;height:46px;border-radius:99px;
    background:rgba(255,255,255,0.16);color:#fff;
    -webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);
    border:1px solid rgba(255,255,255,0.3);
    font-size:1em;
    transform:scale(0.85);
    transition:transform var(--dur-2) var(--ease-out),background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out);
}
.card-play svg{width:18px;height:18px;margin-left:2px}
.card:hover .card-play{transform:scale(1);background:var(--accent);border-color:var(--accent)}
.card-info{text-align:center;padding:0 10px}
.card-info strong{display:block;font-size:0.78em;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}
.card-info em{display:block;font-size:0.68em;color:var(--muted);font-style:normal;font-variant-numeric:tabular-nums}
.card-rating{color:var(--gold)!important}

/* Barre de progression */
.progress-bar{position:absolute;bottom:0;left:0;right:0;height:3px;background:rgba(255,255,255,0.14);z-index:5}
.progress-bar span{display:block;height:100%;background:var(--accent);border-radius:0 2px 2px 0}

/* Badge */
.badge-new{
    position:absolute;top:8px;left:8px;z-index:5;
    background:var(--accent);color:#fff;
    font-size:0.56em;font-weight:700;letter-spacing:0.08em;text-transform:uppercase;
    padding:3px 8px;border-radius:3px;
}

/* ── LECTEUR ── */
.player-wrap{width:100%}
.player-video,.player-iframe{background:#000}
.player-video video,.player-iframe iframe{
    width:100%;max-height:74vh;min-height:56vh;display:block;background:#000;border:none;
}
.player-video video:focus-visible{box-shadow:var(--focus)}
/* Lecteur magnétoscope (lecteur-video-final.php) : la vidéo est dimensionnée par .vp-screen (ratio 16/9),
   on retire donc les contraintes du <video> natif qui créaient une bande noire. */
.player-video:has(.vp){background:transparent;padding:18px 0}
/* lecteur plafonné en largeur et centré (confortable sans plein écran) */
.player-video .vp{margin:0 auto;max-width:900px}
.player-video .vp-screen{min-height:200px;display:flex;align-items:center;justify-content:center}
.player-video .vp-screen video{width:100%;height:auto;min-height:0;max-height:none}
/* plein écran : on lève le plafond 900px (style inline -> !important) et la vidéo remplit l'écran en gardant son ratio */
.vp:fullscreen{max-width:none!important;width:100vw;height:100vh;background:#000}
.vp:-webkit-full-screen{max-width:none!important;width:100vw;height:100vh;background:#000}
.vp:fullscreen .vp-screen{height:100%;min-height:0}
.vp:-webkit-full-screen .vp-screen{height:100%;min-height:0}
.vp:fullscreen .vp-screen video{width:100%;height:100%;object-fit:contain}
.vp:-webkit-full-screen .vp-screen video{width:100%;height:100%;object-fit:contain}

/* Infos film */
.movie-info{position:relative;overflow:hidden;background:var(--bg2)}
.movie-info[style]{background:transparent}
.movie-info::before{
    content:"";position:absolute;inset:0;
    background-image:var(--backdrop);
    background-size:cover;background-position:center 25%;
    filter:blur(8px) brightness(0.28) saturate(1.2);
    transform:scale(1.06);
    z-index:0;
}
.movie-info::after{
    content:"";position:absolute;inset:0;z-index:0;
    background:linear-gradient(to right,rgba(10,10,12,0.9) 0%,rgba(10,10,12,0.55) 55%,rgba(10,10,12,0.78) 100%);
}
.movie-info-inner{
    position:relative;z-index:1;
    display:flex;gap:28px;padding:36px 4%;flex-wrap:wrap;align-items:flex-start;
    max-width:1320px;
}
.movie-poster img{
    width:140px;border-radius:10px;
    box-shadow:0 20px 50px rgba(0,0,0,0.85),0 0 0 1px var(--border);
    flex-shrink:0;
}
.movie-meta{flex:1;min-width:240px}
.movie-title{
    font-size:2em;font-weight:800;letter-spacing:-0.02em;
    color:#fff;margin-bottom:12px;line-height:1.12;
}
.dl-btn{
    font-size:0.38em;letter-spacing:0;
    background:rgba(255,255,255,0.07);border:1px solid var(--border-hi);
    padding:7px 16px;border-radius:99px;color:var(--muted);
    vertical-align:middle;margin-left:14px;font-weight:500;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out);
}
.dl-btn:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.movie-tags{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:16px}
.tag-year,.tag-rating,.tag-genre{
    display:inline-flex;align-items:center;
    padding:6px 14px;border-radius:99px;font-size:0.78em;font-weight:500;
    font-variant-numeric:tabular-nums;
}
.tag-year{background:rgba(255,255,255,0.06);color:var(--muted);border:1px solid var(--border)}
.tag-rating{background:rgba(245,197,24,0.12);color:var(--gold);font-weight:700;border:1px solid rgba(245,197,24,0.3)}
.tag-genre{
    background:rgba(255,255,255,0.06);border:1px solid var(--border);color:#C9D2DC;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out);
}
.tag-genre:hover{background:var(--accent);color:#fff;border-color:var(--accent)}
.movie-overview{color:rgba(248,250,252,0.75);font-size:0.92em;line-height:1.7;margin-bottom:20px;max-width:64ch}

/* Sources / Saisons / Épisodes */
.source-btns,.seasons,.episodes{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:14px}
.src-btn,.season-btn,.ep-btn{
    display:inline-flex;align-items:center;justify-content:center;
    min-height:40px;padding:8px 18px;
    background:rgba(255,255,255,0.05);border:1px solid var(--border);border-radius:99px;
    font-size:0.82em;font-weight:500;color:#C9D2DC;cursor:pointer;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out);
}
.src-btn:active,.season-btn:active,.ep-btn:active{transform:scale(0.96)}
.src-btn:hover,.src-btn.active,.season-btn:hover,.season-btn.active{background:var(--accent);border-color:var(--accent);color:#fff;font-weight:600}
.ep-btn:hover,.ep-btn.active{background:var(--accent-soft);border-color:var(--accent);color:#FF6B72}

/* Films liés */
.related{margin-top:8px;position:relative}

/* ── RÉSULTATS DE RECHERCHE ── */
.main-wrap{padding-top:var(--nav-h)}
.results-header{display:flex;align-items:baseline;gap:10px;padding:28px 4% 6px}
.results-header h2{font-size:1.4em;font-weight:700;letter-spacing:-0.01em}
.results-header .results-count{color:var(--muted);font-size:0.85em}
.results-empty{padding:48px 4%;color:var(--muted);text-align:center}
.results-empty strong{display:block;color:var(--text);font-size:1.1em;margin-bottom:6px}
.err{padding:80px 4%;text-align:center;color:var(--muted)}
.err h4{color:#fff}

/* ── PAGINATION ── */
#pageswitch{text-align:center;padding:28px 4%}
#pageswitch ul{display:inline-flex!important;flex-wrap:wrap;justify-content:center;gap:6px;list-style:none;width:auto!important;background:none!important;box-shadow:none!important;padding:0;margin:0}
#pageswitch li{
    min-width:44px;height:44px;padding:0;
    display:inline-flex;align-items:center;justify-content:center;
    background:var(--bg3);border:1px solid var(--border);border-radius:var(--radius);
    font-size:0.88em;font-variant-numeric:tabular-nums;
    transition:background var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out);
}
#pageswitch li.active{background:var(--accent);border-color:var(--accent)}
#pageswitch li.active a{color:#fff;font-weight:600}
#pageswitch li.disabled{opacity:0.3;pointer-events:none}
#pageswitch a{color:var(--text);width:100%;height:100%;display:flex;align-items:center;justify-content:center;padding:0 12px}
#pageswitch li:not(.active):not(.disabled):hover{background:var(--bg-elev);border-color:var(--border-hi)}

/* ── DEMANDES ── */
.blocrequest{min-height:50vh;display:flex;align-items:center;justify-content:center;text-align:center;padding:40px 4%}
.request-ok{
    display:inline-block;margin-bottom:18px;padding:10px 20px;border-radius:99px;
    background:rgba(34,197,94,0.12);border:1px solid rgba(34,197,94,0.3);
    color:#4ADE80;font-size:0.85em;font-weight:500;
}
.blocrequest form{display:flex;gap:10px;flex-wrap:wrap;justify-content:center}
.blocrequest input[type="text"]{
    height:48px!important;width:min(420px,80vw)!important;
    border-radius:99px!important;border:1px solid var(--border-hi);
    background:rgba(255,255,255,0.05);color:#fff;padding:0 20px;
    font-family:var(--font);font-size:0.95em;outline:none;
    transition:border-color var(--dur-1) var(--ease-out);
}
.blocrequest input[type="text"]:focus{border-color:var(--accent)}
.blocrequest input[type="submit"]{
    height:48px!important;padding:0 28px;border:none;border-radius:99px!important;
    background:var(--accent)!important;color:#fff;font-weight:600;font-size:0.9em;
    cursor:pointer;font-family:var(--font);
    transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out);
}
.blocrequest input[type="submit"]:hover{background:var(--accent-hi)!important}
.blocrequest input[type="submit"]:active{transform:scale(0.97)}

/* ── FOOTER ── */
.site-footer{background:var(--bg2);border-top:1px solid var(--border);padding:36px 4% 26px;margin-top:auto}
.footer-genres{display:flex;flex-wrap:wrap;gap:8px;justify-content:center;margin-bottom:18px}
.footer-genres a{
    padding:8px 16px;background:rgba(255,255,255,0.04);border:1px solid var(--border);
    border-radius:99px;color:var(--muted);font-size:0.75em;font-weight:500;
    text-transform:uppercase;letter-spacing:0.06em;
    transition:background var(--dur-1) var(--ease-out),color var(--dur-1) var(--ease-out),border-color var(--dur-1) var(--ease-out);
}
.footer-genres a:hover{background:var(--accent);border-color:var(--accent);color:#fff}
.footer-copy{text-align:center;color:var(--muted);font-size:0.75em;letter-spacing:0.02em}

/* ── LOGIN ── */
.content_connect{
    min-height:88vh;display:flex!important;align-items:center;justify-content:center;
    padding:40px 24px!important;width:100%!important;
    background:
        radial-gradient(ellipse 50% 40% at 30% 30%, rgba(229,9,20,0.10) 0%, transparent 70%),
        radial-gradient(ellipse 40% 40% at 75% 70%, rgba(49,46,129,0.20) 0%, transparent 70%),
        var(--bg)!important;
}
.log{
    background:rgba(18,18,22,0.88);
    -webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);
    border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;
    width:380px;box-shadow:0 32px 80px rgba(0,0,0,0.85);
}
.log nav{background:transparent!important;border-radius:0!important;box-shadow:none!important;border:none!important;border-bottom:1px solid var(--border)!important;padding:20px 26px!important;width:100%!important}
.log nav b{font-size:1em!important;color:var(--accent)!important;font-weight:800;letter-spacing:0.12em}
#formulaire{width:100%!important;background:none!important;position:static!important;margin:0!important;padding:26px!important}
.userpass{border:none!important;padding:0 0 16px 0!important;margin:0}
.userpass label{display:block;color:var(--muted);font-size:0.72em;font-weight:600;text-transform:uppercase;letter-spacing:0.1em;margin-bottom:6px}
.userpass input[name="username"],.userpass input[name="password"]{
    width:100%!important;min-height:44px;padding:11px 14px!important;
    background:rgba(255,255,255,0.04)!important;border:1px solid var(--border-hi)!important;
    border-radius:var(--radius)!important;color:var(--text)!important;
    font-size:0.95em!important;font-family:var(--font);margin:0!important;
    transition:border-color var(--dur-1) var(--ease-out),background var(--dur-1) var(--ease-out);
}
.userpass input[name="username"]:focus,.userpass input[name="password"]:focus{border-color:var(--accent)!important;box-shadow:none!important;outline:none!important;background:rgba(255,255,255,0.07)!important}
.userpass input[type="submit"]{
    width:100%!important;height:48px!important;
    background:var(--accent)!important;color:#fff!important;
    border:none!important;border-radius:var(--radius)!important;
    font-size:0.95em!important;font-weight:700!important;font-family:var(--font);
    cursor:pointer!important;margin:10px 0 0!important;letter-spacing:0.04em;
    transition:background var(--dur-1) var(--ease-out),transform var(--dur-1) var(--ease-out)!important;
}
.userpass input[type="submit"]:hover{background:var(--accent-hi)!important}
.userpass input[type="submit"]:active{transform:scale(0.98)}
.userpass .checkbox{color:var(--muted)!important;font-size:0.82em}
.log .error{color:var(--danger);font-size:0.82em;padding:0 26px 12px;text-align:center}

/* ── MOBILE ── */
@media(max-width:768px){
    :root{--card-w:155px;--poster-w:112px;--nav-h:88px}
    .topbar{padding:0 14px}
    .navbar{padding:0 14px;height:56px;top:32px}
    .navbar-logo{margin-right:12px}
    .navbar-logo img{height:26px}
    #frm1{width:150px!important}
    .billboard{min-height:64vh}
    .billboard-content{padding-bottom:7vh}
    .billboard-overview{font-size:0.9em;-webkit-line-clamp:2}
    .btn-play,.btn-more{min-height:44px;padding:10px 22px;font-size:0.9em}
    .hero{min-height:300px}
    .hero p{font-size:0.92em}
    .top10-num{font-size:80px;-webkit-text-stroke-width:2px}
    .movie-poster img{width:100px}
    .movie-title{font-size:1.5em}
    .player-video video,.player-iframe iframe{min-height:32vh;max-height:60vh}
    .row-arrow{display:none}
}

/* ── TV / GRANDS ÉCRANS ── */
@media(min-width:1280px){
    :root{--card-w:235px;--poster-w:165px}
    .player-video video{min-height:64vh}
}
@media(min-width:1920px){
    :root{--card-w:275px;--poster-w:190px}
    body{font-size:17px}
}

/* ── ACCESSIBILITÉ : mouvement réduit ── */
@media(prefers-reduced-motion:reduce){
    html{scroll-behavior:auto}
    *,*::before,*::after{
        animation-duration:0.01ms!important;
        animation-iteration-count:1!important;
        transition-duration:0.01ms!important;
    }
    .card.will-reveal{opacity:1;transform:none}
    .hero::before{animation:none}
    .billboard-bg,.billboard-content{animation:none}
    .card-placeholder::before{animation:none}
}
