:root{--bg-dark: #14181c;--surface-dark: #1b2127;--surface-light: #2c3440;--text-primary: #ffffff;--text-secondary: #99aabb;--accent-green: #00e054;--accent-orange: #ff8000;--accent-blue: #40bcf4;--border-color: #445566;--font-primary: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif;--font-mono: "JetBrains Mono", "Roboto Mono", monospace;--max-width: 1000px;--border-radius: 4px;--header-height: 70px;font-family:var(--font-primary);line-height:1.5;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-dark);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;display:flex;place-items:start;justify-content:center;min-width:320px;min-height:100vh;background-color:var(--bg-dark);color:var(--text-primary)}#root{width:100%;max-width:var(--max-width);margin:0 auto;padding:0 1rem}a{color:var(--accent-blue);text-decoration:none;transition:color .2s}a:hover{color:#fff}.App{width:100%;padding-top:2rem}header{margin-bottom:3rem;text-align:center;border-bottom:1px solid var(--surface-light);padding-bottom:2rem}header h1{font-size:2rem;font-weight:800;margin-bottom:.5rem;color:var(--text-primary);letter-spacing:-.02em;text-transform:uppercase}header p{color:var(--text-secondary);font-size:1rem;font-family:var(--font-mono)}.username-form{display:flex;gap:.5rem;justify-content:center;margin-bottom:3rem}.username-form input{padding:.75rem 1rem;font-size:1rem;border:1px solid transparent;border-radius:3px;background:var(--surface-light);color:var(--text-primary);min-width:300px;transition:all .2s;font-family:var(--font-primary)}.username-form input:focus{outline:none;background:#fff;color:#000}.username-form button{padding:.75rem 1.5rem;font-size:.9rem;font-weight:700;border:none;border-radius:3px;background:var(--accent-green);color:#fff;cursor:pointer;text-transform:uppercase;letter-spacing:.05em;transition:filter .2s}.username-form button:hover:not(:disabled){filter:brightness(1.1)}.username-form button:disabled{opacity:.6;cursor:not-allowed;filter:grayscale(.5)}.results{margin-top:3rem}.results h2{margin-bottom:1.5rem;font-size:1.2rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color);padding-bottom:.5rem;font-weight:400;color:var(--text-secondary)}.error-message{background:#ff80001a;border:1px solid var(--accent-orange);border-radius:4px;padding:1.5rem;margin:2rem auto;max-width:600px;text-align:center}.error-message h3{color:var(--accent-orange);margin:0 0 .5rem;font-size:1.2rem}.error-message p{color:var(--text-secondary);margin:0;font-size:.95rem}.filter-info{text-align:center;padding:.75rem;margin:1rem 0 2rem;background:var(--surface-dark);border:1px solid var(--border-color);border-radius:3px;color:var(--text-secondary);font-size:.9rem}@media(max-width:768px){.App{padding:1rem}header h1{font-size:1.5rem}.username-form{flex-direction:column;align-items:stretch}.username-form input{min-width:auto}}.progress-bar-container{width:100%;margin:.75rem 0}.progress-bar-info{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem;font-size:.85rem;font-family:var(--font-mono)}.progress-text{color:var(--text-secondary)}.progress-percentage{font-weight:600;color:var(--accent-green);font-size:.9rem}.progress-bar-track{width:100%;height:8px;background:var(--surface-light);border-radius:4px;overflow:hidden;position:relative}.progress-bar-fill{height:100%;background:var(--accent-green);border-radius:4px;transition:width .8s ease-out;position:relative;overflow:hidden}.progress-bar-shine{position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,#fff0,#fff3,#fff0);animation:shine 2s infinite}@keyframes shine{0%{left:-100%}50%,to{left:100%}}.director-card{background:var(--surface-dark);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem;margin-bottom:1.5rem;transition:transform .2s,box-shadow .2s}.director-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0003;border-color:var(--text-secondary)}.director-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.director-info{display:flex;align-items:center;gap:1rem;flex:1}.director-avatar{width:60px;height:60px;border-radius:50%;object-fit:cover;border:1px solid var(--border-color)}.director-avatar-placeholder{width:60px;height:60px;border-radius:50%;background:var(--surface-light);display:flex;align-items:center;justify-content:center;font-size:1.5rem;font-weight:700;color:var(--text-secondary);border:1px solid var(--border-color)}.director-name-section{flex:1}.director-name{font-size:1.3rem;margin:0 0 .25rem;color:var(--text-primary);font-weight:700}.director-name-link{color:var(--text-primary);text-decoration:none;transition:color .2s}.director-name-link:hover{color:var(--accent-blue)}.director-stats-summary{margin:0;color:var(--text-secondary);font-size:.9rem;font-family:var(--font-mono)}.completionist-badge{color:var(--accent-orange);font-weight:600;font-size:.85rem;letter-spacing:.5px;text-transform:uppercase}.details-toggle{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary);padding:.5rem 1rem;border-radius:3px;cursor:pointer;font-size:.9rem;transition:all .2s;font-family:var(--font-primary);text-transform:uppercase;letter-spacing:.05em}.details-toggle:hover{border-color:var(--text-primary);color:var(--text-primary);background:var(--surface-light)}.director-details{margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.films-section{margin-bottom:1.5rem}.films-section:last-child{margin-bottom:0}.films-section-title{font-size:.9rem;margin:0 0 .75rem;color:var(--accent-green);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.films-list{display:flex;flex-direction:column;gap:1px;background:var(--border-color);border:1px solid var(--border-color);border-radius:4px;overflow:hidden}.film-item{padding:.75rem 1rem;background:var(--surface-dark);font-size:.95rem;display:flex;justify-content:space-between;align-items:center}.film-item.film-link{text-decoration:none;transition:background .2s;cursor:pointer}.film-item.film-link:hover{background:var(--surface-light)}.film-item.watched{border-left:3px solid var(--accent-green)}.film-item.watched .film-title{color:var(--text-primary)}.film-item.unwatched{border-left:3px solid var(--border-color);opacity:.8}.film-title{flex:1;color:var(--text-primary);font-weight:500}.film-year{color:var(--text-secondary);font-size:.85rem;margin-left:.5rem;font-family:var(--font-mono)}@media(max-width:768px){.director-card{padding:1rem}.director-avatar,.director-avatar-placeholder{width:50px;height:50px}.director-name{font-size:1.1rem}}.completion-grouping{background:var(--surface-dark);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem;margin-bottom:2rem}.grouping-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.grouping-title{font-size:1rem;margin:0;color:var(--text-primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.quick-hits-button{padding:.4rem .75rem;font-size:.75rem;font-weight:700;border:none;border-radius:4px;background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;cursor:pointer;transition:transform .2s,box-shadow .2s;text-transform:uppercase;letter-spacing:.05em}.quick-hits-button:before{content:"🍿 "}.quick-hits-button:hover{transform:translateY(-1px);box-shadow:0 2px 8px #ff6b3566}.grouping-bar{display:flex;width:100%;height:50px;border-radius:4px;overflow:hidden;margin-bottom:1rem;box-shadow:0 2px 8px #0003}.grouping-segment{display:flex;align-items:center;justify-content:center;transition:all .2s;cursor:pointer;position:relative;min-width:40px;border:2px solid transparent}.grouping-segment:hover{filter:brightness(1.1);transform:translateY(-1px);z-index:1}.grouping-segment.selected{border:2px solid #fff;box-shadow:0 0 12px #ffffff4d;z-index:2}.grouping-bar.has-selection .grouping-segment:not(.selected){opacity:.4;filter:grayscale(.6)}.grouping-segment-content{display:flex;flex-direction:column;align-items:center;padding:.5rem;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3)}.grouping-count{font-size:1.2rem;font-weight:700;line-height:1}.grouping-label{font-size:.65rem;font-weight:600;margin-top:.2rem;opacity:.9;text-transform:uppercase;letter-spacing:.5px}.grouping-legend{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;padding-top:.5rem}.legend-item{display:flex;align-items:center;gap:.5rem;font-size:.9rem;cursor:pointer;padding:.25rem .5rem;border-radius:3px;transition:background-color .2s}.legend-item:hover{background-color:var(--surface-light)}.legend-item.selected{background-color:var(--surface-light);outline:1px solid var(--accent-blue)}.legend-color{width:14px;height:14px;border-radius:3px;box-shadow:0 1px 3px #0003}.legend-text{color:var(--text-secondary)}.legend-text strong{color:var(--text-primary);font-weight:600}@media(max-width:768px){.completion-grouping{padding:1rem}.grouping-title{font-size:.9rem}.grouping-bar{height:40px}.grouping-count{font-size:1rem}.grouping-label{font-size:.55rem}.grouping-legend{gap:.75rem}.legend-item{font-size:.85rem}}.sort-controls{display:flex;align-items:center;gap:.5rem;padding:1rem 0;font-size:.9rem;color:#666}.sort-label{font-weight:500;margin-right:.25rem}.sort-option{background:none;border:none;padding:.4rem .75rem;cursor:pointer;color:#888;font-size:.9rem;border-radius:4px;transition:all .2s;display:flex;align-items:center;gap:.3rem}.sort-option:hover{background:#667eea1a;color:#667eea}.sort-option.active{color:#667eea;font-weight:600;background:#667eea26}.sort-arrow{font-size:1rem;line-height:1;margin-left:.1rem}.leaderboard{width:100%;max-width:900px;margin:2rem auto}.leaderboard-header{text-align:center;margin-bottom:2rem}.leaderboard-header h2{font-size:1.5rem;margin:0 0 .5rem;color:var(--text-primary);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.leaderboard-subtitle{color:var(--text-secondary);font-size:.95rem;margin:0}.leaderboard-list{display:flex;flex-direction:column}.leaderboard-empty{text-align:center;padding:3rem 2rem;color:var(--text-secondary);background:var(--surface-dark);border-radius:4px;border:1px solid var(--border-color)}.leaderboard-empty p{font-size:1rem;margin:0}@media(max-width:768px){.leaderboard{padding:0 1rem}.leaderboard-header h2{font-size:1.25rem}.leaderboard-subtitle{font-size:.9rem}}.filter-controls{background:var(--surface-dark);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem;margin:2rem auto;max-width:600px}.filter-title{margin:0 0 1rem;font-size:1rem;color:var(--text-primary);font-weight:600;text-transform:uppercase;letter-spacing:.05em}.filter-options{display:flex;flex-direction:column;gap:1rem}.filter-option{display:flex;align-items:center;gap:.75rem;cursor:pointer;-webkit-user-select:none;user-select:none}.filter-option-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.filter-option-inline{display:flex;align-items:center;gap:.5rem;margin-left:.5rem}.filter-option input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--accent-green);border:1px solid var(--border-color);border-radius:2px}.filter-label{color:var(--text-secondary);font-size:.95rem}.filter-label-inline{color:var(--text-secondary);font-size:.9rem}.filter-option-detail{display:flex;align-items:center;gap:1rem;padding-left:2rem;margin-top:.5rem}.runtime-input{width:60px;padding:.4rem;background:var(--surface-light);border:1px solid var(--border-color);border-radius:3px;color:var(--text-primary);font-size:.95rem;text-align:center;font-family:var(--font-mono)}.runtime-input:focus{outline:none;border-color:var(--accent-blue);background:var(--surface-dark)}@media(max-width:768px){.filter-controls{margin:1rem;padding:1rem}.filter-option-row{flex-direction:column;align-items:flex-start;gap:.5rem}.filter-option-inline{margin-left:2rem}.filter-option-detail{flex-direction:column;align-items:flex-start;gap:.5rem}}.loading-spinner{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:2rem}.loading-steps{display:flex;flex-direction:column;gap:1.5rem;width:100%;max-width:500px}.loading-step{display:flex;align-items:center;gap:1rem;transition:opacity .3s ease}.loading-step-pending{opacity:.4}.loading-step-active{opacity:1}.loading-step-completed{opacity:.7}.step-indicator{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.step-spinner{width:24px;height:24px;border:2px solid var(--surface-light);border-top:2px solid var(--accent-green);border-radius:50%;animation:spin 1s linear infinite}.step-checkmark{width:28px;height:28px;border-radius:50%;background:var(--accent-green);color:#fff;display:flex;align-items:center;justify-content:center;font-size:18px;font-weight:700}.step-dot{width:10px;height:10px;border-radius:50%;background:var(--border-color)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.step-label{color:var(--text-primary);font-size:1rem;flex:1}.loading-step-pending .step-label,.loading-step-completed .step-label{color:var(--text-secondary)}.progress-container{width:100%;max-width:500px;display:flex;flex-direction:column;gap:.75rem}.progress-bar-bg{width:100%;height:12px;background:var(--surface-light);border-radius:4px;overflow:hidden;box-shadow:inset 0 1px 2px #0003}.progress-bar-fill{height:100%;background:var(--accent-green);border-radius:4px;transition:width .3s ease;position:relative;overflow:hidden}.progress-bar-fill:after{content:"";position:absolute;top:0;left:0;bottom:0;right:0;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{transform:translate(-100%)}to{transform:translate(100%)}}.progress-text{text-align:center;color:var(--text-secondary);font-size:.9rem;font-weight:500;font-family:var(--font-mono)}.quick-hits-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.quick-hits-modal{background:var(--surface-dark);border:1px solid var(--border-color);border-radius:8px;max-width:600px;width:100%;max-height:80vh;overflow:hidden;display:flex;flex-direction:column}.quick-hits-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color)}.quick-hits-title-row{display:flex;align-items:center;gap:.5rem}.quick-hits-header h2{margin:0;font-size:1.25rem;color:var(--text-primary);font-weight:700}.quick-hits-help-btn{width:1.25rem;height:1.25rem;border-radius:50%;border:1px solid var(--text-secondary);background:transparent;color:var(--text-secondary);font-size:.75rem;font-weight:700;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;padding:0}.quick-hits-help-btn:hover{border-color:var(--text-primary);color:var(--text-primary);background:var(--surface-light)}.quick-hits-help{padding:1rem 1.5rem;background:var(--surface-light);border-bottom:1px solid var(--border-color);font-size:.85rem;line-height:1.5}.help-section{margin-bottom:.5rem;color:var(--text-secondary)}.help-section strong{color:var(--text-primary)}.help-section:last-of-type{margin-bottom:.75rem}.help-dismiss{font-size:.75rem;color:var(--text-secondary);opacity:.6;font-style:italic}.quick-hits-close{background:none;border:none;color:var(--text-secondary);font-size:1.75rem;cursor:pointer;padding:0;line-height:1;transition:color .2s}.quick-hits-close:hover{color:var(--text-primary)}.quick-hits-subtitle{padding:.75rem 1.5rem;margin:0;font-size:.85rem;color:var(--text-secondary);border-bottom:1px solid var(--border-color)}.quick-hits-toggle{display:flex;gap:0;padding:0 1.5rem 1rem}.toggle-button{flex:1;padding:.5rem 1rem;font-size:.85rem;font-weight:600;border:1px solid var(--border-color);background:var(--surface-dark);color:var(--text-secondary);cursor:pointer;transition:all .2s}.toggle-button:first-child{border-radius:4px 0 0 4px}.toggle-button:last-child{border-radius:0 4px 4px 0;border-left:none}.toggle-button:hover:not(.active){background:var(--surface-light);color:var(--text-primary)}.toggle-button.active{background:linear-gradient(135deg,#ff6b35,#f7931e);color:#fff;border-color:transparent}.quick-hits-empty{padding:2rem 1.5rem;text-align:center;color:var(--text-secondary)}.quick-hits-list{overflow-y:auto;flex:1}.quick-hit-item{display:flex;gap:1rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background .2s;align-items:flex-start}.quick-hit-item:last-child{border-bottom:none}.quick-hit-item:hover{background:var(--surface-light)}.quick-hit-dismiss{background:none;border:none;color:var(--text-secondary);font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;line-height:1;opacity:.4;transition:opacity .2s,color .2s;margin-left:auto;flex-shrink:0}.quick-hit-dismiss:hover{opacity:1;color:#f44336}.quick-hit-rank{font-size:1rem;font-weight:700;color:var(--text-secondary);min-width:2rem;padding-top:.1rem}.quick-hit-content{flex:1;min-width:0}.quick-hit-film{display:flex;flex-wrap:wrap;align-items:baseline;gap:.5rem;margin-bottom:.25rem}.quick-hit-title{font-weight:600;color:var(--text-primary);text-decoration:none;transition:color .2s}.quick-hit-title:hover{color:var(--accent-blue)}.quick-hit-meta{font-size:.85rem;color:var(--text-secondary)}.quick-hit-director{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem;font-size:.9rem;margin-bottom:.5rem}.quick-hit-director a{color:var(--text-secondary);text-decoration:none;transition:color .2s}.quick-hit-director a:hover{color:var(--accent-blue)}.quick-hit-remaining{font-size:.8rem;color:var(--text-secondary);opacity:.7}.quick-hit-remaining:before{content:"·";margin-right:.5rem}.quick-hit-impact{display:flex;flex-wrap:wrap;gap:.5rem;align-items:center}.impact-badge{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-weight:600;background:var(--accent-green);color:#fff;border-radius:3px}.completion-badge{display:inline-block;padding:.2rem .5rem;font-size:.75rem;font-weight:600;background:var(--accent-orange);color:#fff;border-radius:3px}@media(max-width:600px){.quick-hits-modal{max-height:90vh}.quick-hits-header{padding:1rem}.quick-hits-header h2{font-size:1.1rem}.quick-hits-subtitle{padding:.5rem 1rem;font-size:.8rem}.quick-hit-item{padding:.75rem 1rem;gap:.75rem}.quick-hit-rank{font-size:.9rem;min-width:1.75rem}}
