*{margin:0;padding:0;box-sizing:border-box}html,body,#root{width:100%;height:100%;overflow:hidden}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.scroll-container{width:100%;height:100vh;height:100dvh;overflow-y:scroll;scroll-snap-type:y mandatory;scroll-behavior:smooth}.scroll-container::-webkit-scrollbar{display:none}.scroll-container{-ms-overflow-style:none;scrollbar-width:none}.season-view{width:100%;height:100vh;height:100dvh;position:relative;scroll-snap-align:start;background:#2a2a2a;overflow:hidden}.cast-container{position:relative;width:100%;height:100%}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;display:flex;align-items:center;justify-content:center;z-index:1000;animation:fadeIn .2s ease}.modal-content{background:#2a2a2a;border-radius:12px;max-width:500px;width:90%;max-height:80vh;overflow-y:auto;position:relative;animation:slideUp .3s ease}.modal-close{position:absolute;top:16px;right:16px;background:none;border:none;color:#b8b8b8;font-size:32px;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;transition:color .2s}.modal-close:hover{color:#fff}.modal-header{padding:32px;display:flex;gap:20px;align-items:center;border-bottom:1px solid #3a3a3a}.modal-photo{border-radius:50%;border:2px solid;flex-shrink:0}.modal-photo.no-photo{background-color:#444;background-image:none;width:120px;height:120px}.modal-title h2{margin:0;font-size:28px;color:#fff;font-weight:700}.modal-subtitle{margin:8px 0 0;font-size:14px;color:#a0a0a0}.modal-body{padding:32px}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #3a3a3a}.info-row:last-of-type{border-bottom:none}.info-label{font-size:14px;color:#a0a0a0;font-weight:500}.info-value{font-size:14px;color:#fff;font-weight:600}.bio-section{margin-bottom:16px}.bio-section h3{font-size:18px;color:#fff;margin-bottom:12px}.bio-section p{font-size:14px;line-height:1.6;color:#ccc}.archive-link{display:inline-block;margin-top:24px;color:#4a9eff;text-decoration:none;font-size:14px;font-weight:600;transition:color .2s}.archive-link:hover{color:#6eb4ff}.scroll-indicator{position:fixed;bottom:60px;left:50%;transform:translate(-50%);z-index:20;display:flex;flex-direction:column;align-items:center;pointer-events:none;transition:opacity .3s ease-out}.scroll-indicator-arrow{color:#fff9;animation:bounce 2s ease-in-out infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(10px)}}@media (max-width: 767px){.scroll-indicator{bottom:40px}.scroll-indicator-arrow svg{width:20px;height:20px}}.season-info-button{width:36px;height:36px;border:none;background:#ffffff1a;color:#ffffffb3;border-radius:50%;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;transition:all .2s ease;flex-shrink:0}.season-info-button:hover{background:#fff3;color:#ffffffe6;transform:scale(1.05)}.season-info-button:active{transform:scale(.95)}@media (max-width: 767px){.season-info-button{width:28px;height:28px;margin-left:8px}.season-info-button svg{width:18px;height:18px}}.season-info-modal-backdrop{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:10000;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.season-info-modal{background:#1a1a1a;border-radius:16px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;position:relative;animation:slideUp .3s ease-out;box-shadow:0 20px 60px #00000080}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.season-info-modal-close{position:absolute;top:20px;right:20px;width:36px;height:36px;border:none;background:#ffffff1a;color:#ffffffb3;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:1}.season-info-modal-close:hover{background:#fff3;color:#fff}.season-info-modal-content{padding:40px;overflow-y:auto;max-height:80vh}.season-info-modal-header{margin-bottom:32px}.season-info-modal-header h2{font-size:36px;font-weight:700;color:#fff;margin:0 0 8px;letter-spacing:-1px}.season-info-modal-year{font-size:18px;font-weight:300;color:#a0a0a0;margin:0;letter-spacing:.5px}.season-info-summary{margin-bottom:32px}.season-info-summary p{font-size:15px;line-height:1.7;color:#ccc;margin:0}.season-info-modal-sections{display:flex;flex-direction:column;gap:32px}.season-info-section h3{font-size:16px;font-weight:600;color:#fff;margin:0 0 16px;text-transform:uppercase;letter-spacing:1px;opacity:.8}.season-info-grid{display:flex;flex-wrap:wrap;gap:12px}.season-info-item{font-size:14px;color:#ccc;background:#ffffff0d;padding:8px 12px;border-radius:6px;transition:background .2s ease}.season-info-item:hover{background:#ffffff1a}.season-info-modal-content::-webkit-scrollbar{width:8px}.season-info-modal-content::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.season-info-modal-content::-webkit-scrollbar-thumb{background:#fff3;border-radius:4px}.season-info-modal-content::-webkit-scrollbar-thumb:hover{background:#ffffff4d}@media (max-width: 767px){.season-info-modal-backdrop{padding:0}.season-info-modal{max-width:100%;max-height:100vh;border-radius:0}.season-info-modal-content{padding:24px}.season-info-modal-header h2{font-size:28px}.season-info-modal-year{font-size:16px}.season-info-summary{margin-bottom:24px}.season-info-summary p{font-size:14px;line-height:1.6}.season-info-section h3{font-size:14px}.season-info-item{font-size:13px;padding:6px 10px}}.cast-member{position:absolute;transform:translate(-50%,-50%);pointer-events:none}.cast-member-photo{border-radius:50%;border:1px solid;box-shadow:0 4px 12px #0006;pointer-events:auto;touch-action:auto;position:relative;transition:transform .2s ease,box-shadow .2s ease;cursor:pointer}.cast-member-photo:hover{transform:scale(1.05);box-shadow:0 6px 16px #0009}.cast-member-photo:active{transform:scale(.98)}.cast-member-name-svg-text{font-size:12px;font-weight:600;fill:#fff;paint-order:stroke fill}.cast-member-photo.no-photo{background-color:#444;background-image:none;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.cast-member-name-text{color:#fff;font-size:10px;font-weight:600;-webkit-user-select:none;user-select:none;pointer-events:none;text-align:center;padding:4px;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;max-width:100%}@media (max-width: 767px){.cast-member{pointer-events:auto}.cast-member-photo{border-width:2px;pointer-events:auto;touch-action:pan-y}.cast-member-photo.no-photo{width:60px;height:60px}.cast-member-name-text{font-size:8px;padding:2px}.cast-member-name-svg-text{font-size:10px}}.all-cast-view{position:fixed;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:5}.timeline{position:fixed;left:20px;top:calc(81px + 50vh);transform:translateY(-50%);height:80vh;max-height:600px;z-index:1000;display:flex;align-items:center;pointer-events:none}.timeline-track{position:relative;width:40px;height:100%;background:transparent;cursor:pointer;pointer-events:auto}.timeline-tick{position:absolute;left:0;transform:translateY(-50%);height:1px;background:#ffffff80;pointer-events:none}.timeline-tick.minor{width:6px}.timeline-tick.major{width:12px;height:2px;background:#ffffffb3}.timeline-hover-tick{position:absolute;left:0;transform:translateY(-50%);width:30px;height:2px;background:#ffffffe6;pointer-events:none}.timeline-year-label{position:absolute;left:35px;transform:translateY(-50%);color:#fff;font-size:14px;font-weight:400;pointer-events:none;white-space:nowrap}@media (max-width: 767px){.timeline{left:10px;top:calc(49px + 50vh);height:70vh;max-height:500px}.timeline-track{width:30px}.timeline-tick.minor{width:4px}.timeline-tick.major{width:8px}.timeline-hover-tick{width:20px}.timeline-year-label{left:25px;font-size:12px}}.timeline-track.dragging{user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.app{width:100%;height:100%;background:#2a2a2a;color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}.fixed-season-info{position:fixed;top:60px;left:60px;z-index:10}.season-number{display:flex;align-items:center;font-size:48px;font-weight:700;color:#fff;margin-bottom:8px;letter-spacing:-1px;white-space:nowrap;height:58px}.season-label{display:inline-block}.season-number-container{position:relative;display:inline-block;overflow:hidden;height:58px;min-width:65px;margin-left:8px}.season-number-value{position:absolute;top:0;left:0;font-size:48px;font-weight:700;line-height:58px;will-change:transform,opacity}.season-year-container{position:relative;height:36px;overflow:hidden}.season-year{position:absolute;top:0;left:0;font-size:24px;font-weight:300;color:#a0a0a0;letter-spacing:1px;will-change:transform,opacity}@media (max-width: 767px){.fixed-season-info{top:30px;left:30px}.season-number{font-size:32px;height:40px;margin-bottom:4px}.season-number-container{height:40px;min-width:45px;margin-left:6px}.season-number-value{font-size:32px;line-height:40px}.season-year-container{height:24px}.season-year{font-size:16px}}
