: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);border-bottom:1px solid var(--border)}.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:2.5rem 3rem}.catalogue-title{font-family:var(--font-base);font-size:clamp(1.8rem,4vw,2.75rem);font-weight:700;color:var(--white);margin:0 0 2.5rem}.video-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.75rem}.video-card{background:var(--bg-card);border:2px solid transparent;border-radius:10px;overflow:hidden;cursor:pointer;transition:border-color .15s,transform .15s,box-shadow .15s;outline:none}.video-card:hover,.video-card--focused{border-color:var(--white);transform:scale(1.03);box-shadow:0 8px 32px #0009}.video-thumbnail{position:relative;aspect-ratio:16 / 9;background:#111;overflow:hidden}.video-thumbnail img{width:100%;height:100%;object-fit:cover}.thumbnail-placeholder{width:100%;height:100%;background:linear-gradient(135deg,#1a1a2e,#16213e);display:flex;align-items:center;justify-content:center}.thumbnail-year{font-family:var(--font-base);font-size:3rem;font-weight:900;color:#ffffff26}.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}.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-info{padding:1.1rem 1.25rem 1.25rem}.video-title{font-size:1.2rem;font-weight:700;color:var(--white);margin:0 0 .4rem}.video-description{font-size:.95rem;color:var(--gray);margin:0 0 .9rem;line-height:1.4}.video-action{font-size:.9rem;font-weight:600}.action-play{color:#22c55e}.action-restore{color:#60a5fa;cursor:pointer}.action-restoring{color:#ffad00}.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}.table-actions{display:flex;gap:.5rem;flex-wrap:wrap}.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}.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}}
