:root{--bg: #0a0a0a;--bg-card: #1a1a1a;--bg-card-hover: #242424;--bg-header: rgba(0, 0, 0, .92);--red: #e50914;--red-dark: #b8070f;--white: #ffffff;--gray-light: #cccccc;--gray: #888888;--gray-dark: #444444;--border: #2a2a2a;--focus-ring: #e50914;--font-base: "Georgia", serif;--font-ui: system-ui, "Segoe UI", sans-serif;font-size:18px;line-height:1.5;color:var(--white);background:var(--bg);font-family:var(--font-ui);-webkit-font-smoothing:antialiased;color-scheme:dark}*,*:before,*:after{box-sizing:border-box}body{margin:0;background:var(--bg);min-height:100svh}#root{min-height:100svh;display:flex;flex-direction:column}*:focus-visible{outline:3px solid var(--focus-ring);outline-offset:3px}.loading-screen{min-height:100svh;display:flex;align-items:center;justify-content:center;background:var(--bg)}.loading-spinner{width:52px;height:52px;border:4px solid var(--gray-dark);border-top-color:var(--red);border-radius:50%;animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.page-layout{min-height:100svh;display:flex;flex-direction:column}.app-header{position:sticky;top:0;z-index:100;display:flex;align-items:center;justify-content:space-between;padding:0 3rem;height:80px;background:var(--bg-header);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);transition:background .4s ease,backdrop-filter .4s ease}.app-header.app-header--top{background:linear-gradient(to bottom,rgba(0,0,0,.65) 0%,transparent 100%);-webkit-backdrop-filter:none;backdrop-filter:none;border-color:transparent;box-shadow:none}.header-logo{font-family:var(--font-base);font-size:2rem;font-weight:900;-webkit-user-select:none;user-select:none;display:flex;align-items:center;gap:.1em}.header-logo-img{height:36px;width:auto;display:block;mix-blend-mode:screen}.login-logo{text-align:center;margin-bottom:2.5rem}.login-logo-img{width:clamp(200px,40vw,340px);height:auto;mix-blend-mode:screen}.intro-logo-img{mix-blend-mode:screen}.admin-badge{margin-left:.75rem;font-family:var(--font-ui);font-size:.65rem;font-weight:700;letter-spacing:.12em;text-transform:uppercase;color:var(--red);border:1.5px solid var(--red);padding:2px 7px;border-radius:4px;align-self:center}.header-nav{display:flex;align-items:center;gap:1.5rem}.header-user{font-size:1rem;color:var(--gray-light)}button{font-family:var(--font-ui);cursor:pointer;border:none}.btn-primary{background:var(--red);color:var(--white);font-size:1.1rem;font-weight:700;padding:.75rem 1.75rem;border-radius:6px;transition:background .15s;min-height:52px;min-width:160px}.btn-primary:hover,.btn-primary:focus-visible{background:var(--red-dark)}.btn-primary:disabled{background:var(--gray-dark);color:var(--gray);cursor:not-allowed}.btn-large{width:100%;font-size:1.25rem;padding:1rem 2rem;min-height:60px}.btn-secondary{background:var(--bg-card);color:var(--gray-light);font-size:1.1rem;padding:.75rem 1.75rem;border-radius:6px;border:1px solid var(--border);min-height:52px;transition:background .15s}.btn-secondary:hover,.btn-secondary:focus-visible{background:var(--bg-card-hover)}.nav-btn{background:transparent;color:var(--gray-light);font-size:1.05rem;padding:.5rem 1rem;border-radius:4px;border:1px solid transparent;transition:color .15s,border-color .15s;min-height:48px;min-width:80px}.nav-btn:hover,.nav-btn:focus-visible{color:var(--white);border-color:var(--gray-dark)}.btn-sm{background:var(--bg-card);color:var(--gray-light);font-size:.9rem;padding:.4rem .9rem;border-radius:4px;border:1px solid var(--border);min-height:40px;transition:background .15s}.btn-sm:hover,.btn-sm:focus-visible{background:var(--bg-card-hover)}.btn-danger{color:#ff6b6b;border-color:#552020}.btn-danger:hover,.btn-danger:focus-visible{background:#2a0f0f}.form-group{display:flex;flex-direction:column;gap:.5rem;flex:1}.form-group label{font-size:1rem;font-weight:600;color:var(--gray-light);letter-spacing:.02em}.form-group input,.form-group select,.form-group textarea{background:var(--bg-card);border:1.5px solid var(--border);color:var(--white);font-size:1.1rem;font-family:var(--font-ui);padding:.7rem 1rem;border-radius:6px;min-height:52px;transition:border-color .15s}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--red)}.form-group textarea{resize:vertical;min-height:90px}.form-row{display:flex;gap:1.25rem;flex-wrap:wrap}.form-actions{display:flex;gap:1rem;margin-top:.5rem}.login-page{min-height:100svh;background:var(--bg);display:flex;align-items:center;justify-content:center;padding:2rem}.login-container{width:100%;max-width:480px}.login-form{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:2.5rem;display:flex;flex-direction:column;gap:1.5rem}.login-title{font-size:1.75rem;font-weight:700;color:var(--white);margin:0}.login-subtitle{color:var(--gray-light);font-size:1rem;margin:0}.login-error{background:#e509141f;border:1px solid rgba(229,9,20,.4);color:#ff8080;padding:.75rem 1rem;border-radius:6px;font-size:1rem}.catalogue-main{flex:1;padding:0 0 4rem}.catalogue-section{margin-bottom:2.5rem}.catalogue-section--over-hero{position:relative;z-index:10;margin-top:-230px}.section-title{font-size:1.4rem;font-weight:800;color:var(--white);margin:0 0 .75rem;padding:0 3rem;letter-spacing:.01em}.cards-row{display:flex;gap:8px;overflow-x:auto;padding:.5rem 3rem 1rem;scrollbar-width:none;-webkit-overflow-scrolling:touch;scroll-behavior:smooth}.cards-row::-webkit-scrollbar{display:none}.hcard{flex:0 0 260px;height:146px;position:relative;border-radius:6px;overflow:hidden;cursor:pointer;outline:none;transition:transform .18s ease,box-shadow .18s ease;background:#111}.hcard:hover,.hcard--focused{transform:scale(1.07);box-shadow:0 0 0 3px var(--white),0 12px 40px #000c;z-index:10}.hcard--collection:hover,.hcard--collection.hcard--focused{box-shadow:0 0 0 3px var(--red),0 12px 40px #e5091466}.hcard-img{width:100%;height:100%;object-fit:cover;display:block}.hcard-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;font-size:2rem;color:#fff3}.hcard-bottom-badge{position:absolute;bottom:0;left:50%;transform:translate(-50%);width:auto;max-width:85%;background:var(--red);color:#fff;font-size:.72rem;font-weight:800;text-align:center;padding:5px 10px;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap;border-radius:3px 3px 0 0}.hcard-bottom-badge--restoring{background:#b45309}.hcard-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .3s ease;pointer-events:none}.hcard-video--visible{opacity:1}.hcard-img--hidden{opacity:0;transition:opacity .3s ease}.action-play{color:#22c55e}.action-restore{color:#60a5fa}.action-restoring{color:#ffad00;font-size:.72rem}.status-archived{background:#000000b3;color:var(--gray);border:1px solid var(--gray-dark)}.status-restoring{background:#ffa50026;color:#ffad00;border:1px solid #ffad0055}.status-available{background:#22c55e26;color:#22c55e;border:1px solid #22c55e55}.video-status{position:absolute;top:.6rem;right:.6rem;font-size:.75rem;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em}.action-label{font-size:.9rem;font-weight:600}.thumbnail-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center}.thumbnail-year{font-size:3rem;font-weight:900;color:#ffffff26}.player-page{min-height:100svh;background:#000;display:flex;flex-direction:column;padding:1.5rem 2rem}.player-back{background:transparent;color:var(--gray-light);font-size:1.1rem;padding:.5rem 1rem;border-radius:4px;border:1px solid var(--border);align-self:flex-start;margin-bottom:1rem;min-height:48px;transition:color .15s}.player-back:hover,.player-back:focus-visible{color:var(--white)}.player-container{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1rem}.player-video{width:100%;max-height:calc(100svh - 160px);background:#000;border-radius:6px}.player-loading,.player-error{text-align:center;font-size:1.25rem;color:var(--gray-light)}.player-error{display:flex;flex-direction:column;align-items:center;gap:1.5rem;color:var(--gray)}.player-controls{width:100%;display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#000c;border-radius:8px}.player-btn-play{background:var(--red);color:var(--white);font-size:1.5rem;width:56px;height:56px;border-radius:50%;border:none;display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:background .15s}.player-btn-play:hover,.player-btn-play:focus-visible{background:var(--red-dark)}.player-progress-bar{flex:1;height:8px;background:var(--gray-dark);border-radius:4px;cursor:pointer;min-height:24px;display:flex;align-items:center}.player-progress-fill{height:8px;background:var(--red);border-radius:4px;pointer-events:none;transition:width .1s linear}.player-time{font-size:1rem;color:var(--gray-light);white-space:nowrap;min-width:90px;text-align:right}.admin-main{flex:1;padding:2.5rem 3rem}.admin-tabs{display:flex;gap:.5rem;border-bottom:2px solid var(--border);margin-bottom:2rem;flex-wrap:wrap}.admin-tab{background:transparent;color:var(--gray);font-size:1.05rem;padding:.75rem 1.5rem;border-radius:6px 6px 0 0;border:none;border-bottom:3px solid transparent;margin-bottom:-2px;transition:color .15s,border-color .15s;min-height:52px}.admin-tab:hover,.admin-tab:focus-visible{color:var(--gray-light)}.admin-tab--active{color:var(--white);border-bottom-color:var(--red);font-weight:700}.admin-content{background:var(--bg-card);border:1px solid var(--border);border-radius:10px;padding:2rem}.admin-section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.75rem;flex-wrap:wrap;gap:1rem}.admin-section-header h2{font-size:1.5rem;font-weight:700;color:var(--white);margin:0}.admin-message{background:#22c55e1a;border:1px solid rgba(34,197,94,.3);color:#86efac;padding:.75rem 1rem;border-radius:6px;margin-bottom:1.5rem;font-size:1rem}.admin-form{background:#ffffff08;border:1px solid var(--border);border-radius:8px;padding:1.5rem;margin-bottom:2rem;display:flex;flex-direction:column;gap:1.25rem}.admin-form h3{margin:0;font-size:1.2rem;font-weight:700;color:var(--white)}.admin-table{width:100%;border-collapse:collapse;font-size:1rem}.admin-table th{text-align:left;padding:.75rem 1rem;color:var(--gray);font-weight:600;font-size:.85rem;text-transform:uppercase;letter-spacing:.07em;border-bottom:1px solid var(--border)}.admin-table td{padding:1rem;color:var(--gray-light);border-bottom:1px solid rgba(255,255,255,.04);vertical-align:middle}.admin-table tr:last-child td{border-bottom:none}.admin-table tr:hover td{background:#ffffff06}.admin-table tr.row-editing td{background:#e5091412;border-bottom-color:#e509144d}.table-actions{display:flex;gap:.5rem;flex-wrap:wrap}.vignette-upload-area{display:flex;flex-direction:column;gap:.75rem}.vignette-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.4rem;padding:1.5rem;border:2px dashed rgba(255,255,255,.2);border-radius:8px;cursor:pointer;color:var(--gray);transition:border-color .2s,background .2s}.vignette-dropzone:hover{border-color:var(--red);background:#e509140d;color:#fff}.vignette-dropzone span{font-size:1rem}.vignette-dropzone small{font-size:.8rem;opacity:.6}.vignette-preview-wrap{display:flex;align-items:center;gap:1rem}.vignette-preview{width:120px;height:75px;object-fit:cover;border-radius:6px;border:1px solid rgba(255,255,255,.1)}.archive-id{font-family:monospace;font-size:.85rem;color:var(--gray);background:#ffffff0d;padding:2px 6px;border-radius:3px}.role-badge{font-size:.8rem;font-weight:700;padding:3px 9px;border-radius:4px;text-transform:uppercase;letter-spacing:.06em}.role-admin{background:#e5091426;color:var(--red);border:1px solid rgba(229,9,20,.3)}.role-famille{background:#60a5fa1f;color:#60a5fa;border:1px solid rgba(96,165,250,.3)}.status-badge{font-size:.85rem;font-weight:600;padding:3px 9px;border-radius:4px}.status-badge.status-archived{color:var(--gray)}.status-badge.status-restoring{color:#ffad00}.status-badge.status-available{color:#22c55e}.status-ok{color:#22c55e;font-size:.9rem}.status-pending{color:#ffad00;font-size:.9rem}.event-badge{font-size:.85rem;font-weight:600}.event-badge.event-lecture{color:#22c55e}.event-badge.event-demande-restauration{color:#60a5fa}.count-badge{background:#ffa50026;color:#ffad00;font-size:.85rem;font-weight:700;padding:4px 10px;border-radius:20px;border:1px solid rgba(255,165,0,.3)}.filter-group{display:flex;align-items:center;gap:.75rem;font-size:1rem;color:var(--gray-light)}.filter-group select{background:var(--bg-card);border:1px solid var(--border);color:var(--white);font-size:1rem;padding:.4rem .75rem;border-radius:4px;min-height:40px}.collection-badges{position:absolute;top:8px;left:8px;display:flex;flex-direction:column;gap:4px}.badge{font-size:.72rem;font-weight:700;padding:3px 8px;border-radius:4px;text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.badge-new{background:var(--red);color:#fff}.badge-new-ep{background:#2563eb;color:#fff}.collection-episode-count{color:#999;font-size:.9rem}.collection-main{max-width:1100px;margin:0 auto;padding:2rem 1.5rem 4rem}.collection-hero{display:flex;gap:2rem;align-items:flex-start;margin-bottom:3rem;padding:2rem;background:var(--bg-card);border-radius:12px;border:1px solid var(--border)}.collection-hero-img{width:220px;height:140px;object-fit:cover;border-radius:8px;flex-shrink:0}.collection-hero-info{flex:1}.collection-hero-title{font-size:2rem;font-weight:800;margin:0 0 .5rem;color:#fff}.collection-hero-desc{color:var(--gray);font-size:1rem;margin:0 0 1rem;line-height:1.5}.collection-meta{font-size:.95rem;color:var(--gray);margin-bottom:1.25rem}.meta-available{color:#22c55e}.meta-archived{color:var(--gray)}.btn-restore-all{background:var(--red);color:#fff;border:none;border-radius:6px;padding:.6rem 1.4rem;font-size:1rem;font-weight:700;cursor:pointer;transition:background .2s,transform .1s}.btn-restore-all:hover{background:#c00}.btn-restore-all:disabled{opacity:.6;cursor:not-allowed}.episodes-list{display:flex;flex-direction:column;gap:.75rem}.episode-row{display:flex;align-items:center;gap:1.25rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border);border-radius:10px;cursor:pointer;transition:border-color .2s,background .2s;outline:none}.episode-row:hover,.episode-row--focused{border-color:var(--red);background:#e509140f}.episode-row--available:hover,.episode-row--available.episode-row--focused{border-color:#22c55e;background:#22c55e0f}.episode-thumb{width:120px;height:75px;object-fit:cover;border-radius:6px;flex-shrink:0}.episode-thumb--placeholder{background:#ffffff0d;display:flex;align-items:center;justify-content:center;color:var(--gray);font-size:1rem}.episode-info{flex:1}.episode-number{font-size:.8rem;color:var(--gray);margin-bottom:.2rem}.episode-title{font-size:1.1rem;font-weight:700;color:#fff;margin-bottom:.25rem}.episode-desc{font-size:.9rem;color:var(--gray);line-height:1.4}.episode-right{display:flex;flex-direction:column;align-items:flex-end;gap:.5rem;flex-shrink:0}.trailer-preview-wrap{display:flex;align-items:flex-start;gap:.75rem;flex-wrap:wrap}.trailer-preview{width:240px;height:135px;object-fit:cover;border-radius:6px;border:1px solid var(--border);background:#000}.trailer-progress-wrap{display:flex;align-items:center;gap:.75rem}.trailer-progress-bar{flex:1;height:8px;background:var(--border);border-radius:4px;overflow:hidden}.trailer-progress-fill{height:100%;background:var(--red);border-radius:4px;transition:width .2s ease}.trailer-progress-label{font-size:.9rem;color:var(--gray-light);min-width:3rem;text-align:right}.hero-banner{position:relative;width:100%;height:100svh;overflow:hidden;background:#000;margin-top:-80px;margin-bottom:2rem}.hero-bg{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;object-position:center 20%;transition:opacity .8s ease}.hero-bg--hidden{opacity:0}.hero-bg--dark{background:#111}.hero-video{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .8s ease}.hero-video--visible{opacity:1}.hero-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(to right,rgba(0,0,0,.78) 0%,rgba(0,0,0,.3) 55%,transparent 80%),linear-gradient(to top,rgba(10,10,10,1) 0%,rgba(10,10,10,.4) 20%,transparent 50%);z-index:1}.hero-content{position:absolute;bottom:22%;left:4%;z-index:2;max-width:580px}.hero-title{font-size:clamp(1.8rem,4vw,3.2rem);font-weight:900;color:#fff;margin:0 0 .75rem;line-height:1.1;text-shadow:0 2px 12px rgba(0,0,0,.6)}.hero-desc{font-size:1.05rem;color:#ffffffd9;margin:0 0 1.5rem;line-height:1.55;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-shadow:0 1px 6px rgba(0,0,0,.5)}.hero-actions{display:flex;gap:.875rem;flex-wrap:wrap}.hero-btn{display:inline-flex;align-items:center;gap:.5rem;padding:.65rem 1.75rem;border-radius:5px;font-size:1.05rem;font-weight:700;cursor:pointer;border:none;min-height:50px;font-family:var(--font-ui);transition:opacity .15s,background .15s}.hero-btn--play{background:#fff;color:#000}.hero-btn--play:hover{background:#ffffffc7}.hero-btn--info{background:#6d6d6ea6;color:#fff;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.hero-btn--info:hover{background:#6d6d6e66}.hero-mute-btn{position:absolute;bottom:22%;right:4%;z-index:2;background:transparent;border:2px solid rgba(255,255,255,.55);border-radius:50%;width:40px;height:40px;font-size:1.1rem;color:#fff;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:border-color .15s;padding:0;line-height:1}.hero-mute-btn:hover{border-color:#fff}.hcard-panel{position:fixed;z-index:200;border-radius:10px;overflow:hidden;background:#1c1c1c;box-shadow:0 8px 48px #000000e6,0 0 0 1px #ffffff14;cursor:pointer;transition:opacity .18s ease;animation:panelIn .18s ease forwards}@keyframes panelIn{0%{transform:scale(.94);opacity:0}to{transform:scale(1);opacity:1}}.hcard-panel-media{position:relative;width:100%;aspect-ratio:16 / 9;background:#000;overflow:hidden}.hcard-panel-video,.hcard-panel-img{width:100%;height:100%;object-fit:cover;display:block}.hcard-panel-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center;font-size:2.5rem;color:#fff3}.hcard-panel-info{padding:14px 16px 18px;display:flex;flex-direction:column;gap:10px}.hcard-panel-title{font-size:1.05rem;font-weight:700;color:#fff;line-height:1.3}.hcard-panel-meta{font-size:.85rem;color:var(--gray)}.hcard-panel-btn{background:var(--red);color:#fff;border:none;border-radius:5px;padding:8px 16px;font-size:.95rem;font-weight:700;cursor:pointer;align-self:flex-start;min-height:38px;transition:background .15s;font-family:var(--font-ui)}.hcard-panel-btn:hover{background:var(--red-dark)}.hcard-panel-mute{position:absolute;bottom:8px;right:8px;background:#000000a6;border:1.5px solid rgba(255,255,255,.35);border-radius:50%;width:34px;height:34px;display:flex;align-items:center;justify-content:center;font-size:1rem;cursor:pointer;transition:background .15s,border-color .15s;z-index:2;padding:0;line-height:1}.hcard-panel-mute:hover{background:#000000d9;border-color:#ffffffb3}.intro-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;align-items:center;justify-content:center;z-index:9999;transition:opacity .7s ease}.intro-screen.intro-fadeout{opacity:0;pointer-events:none}.intro-logo-wrap{text-align:center;transform:scale(.7);opacity:0;animation:introZoom .6s cubic-bezier(.22,1,.36,1) .1s forwards}@keyframes introZoom{to{transform:scale(1);opacity:1}}.intro-logo-img-wrap{position:relative;display:inline-block;overflow:hidden}.intro-logo-img{display:block;width:clamp(280px,50vw,600px);height:auto}.intro-shine-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:linear-gradient(105deg,transparent 30%,rgba(255,255,255,.55) 48%,rgba(255,220,180,.35) 52%,transparent 70%);background-size:250% 100%;background-position:200% center;opacity:0;pointer-events:none}.intro-screen.intro-shine .intro-shine-overlay{opacity:1;animation:introShine 1.8s ease-in-out forwards}@keyframes introShine{0%{background-position:200% center}to{background-position:-50% center}}.intro-tagline{margin-top:1rem;color:#aaa;font-size:clamp(1rem,2.5vw,1.6rem);letter-spacing:.25em;text-transform:uppercase;opacity:0;animation:introFadeIn .5s ease .5s forwards}@keyframes introFadeIn{to{opacity:1}}
