@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*{box-sizing:border-box;margin:0;padding:0}:root{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;--color-bg-primary: #0a0a0a;--color-bg-secondary: #111111;--color-bg-tertiary: #1a1a1a;--color-surface: rgba(255, 255, 255, .03);--color-surface-elevated: rgba(255, 255, 255, .06);--color-surface-glass: rgba(20, 20, 20, .85);--color-text-primary: #fafafa;--color-text-secondary: #a0a0a0;--color-text-tertiary: #666666;--color-grade-beginner: #2dd4bf;--color-grade-intermediate: #60a5fa;--color-grade-advanced: #c084fc;--color-grade-elite: #fb923c;--color-grade-pro: #f87171;--color-success: #22c55e;--color-error: #ef4444;--color-warning: #f59e0b;--color-info: #3b82f6;--border-subtle: rgba(255, 255, 255, .06);--border-default: rgba(255, 255, 255, .1);--border-strong: rgba(255, 255, 255, .2);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .2);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .4);--shadow-glow: 0 0 20px rgba(255, 255, 255, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--transition-spring: .4s cubic-bezier(.34, 1.56, .64, 1);--transition-bounce: .5s cubic-bezier(.68, -.55, .265, 1.55);--blur-sm: 8px;--blur-md: 16px;--blur-lg: 24px;--blur-xl: 40px}body{margin:0;min-width:320px;min-height:100vh;background:var(--color-bg-primary);color:var(--color-text-primary)}#root{width:100%;min-height:100vh}@keyframes fadeOut{0%{opacity:1}to{opacity:0}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInDown{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleOut{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.95)}}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.05)}}@keyframes glow{0%,to{box-shadow:0 0 5px currentColor}50%{box-shadow:0 0 20px currentColor,0 0 40px currentColor}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes countUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fadeIn{animation:fadeIn var(--transition-base) forwards}.animate-fadeInUp{animation:fadeInUp var(--transition-base) forwards}.animate-scaleIn{animation:scaleIn var(--transition-spring) forwards}.animate-slideUp{animation:slideUp var(--transition-spring) forwards}.animate-pulse{animation:pulse 2s ease-in-out infinite}.animate-shimmer{background:linear-gradient(90deg,#fff0,#ffffff0d,#fff0);background-size:200% 100%;animation:shimmer 2s infinite}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff40}::selection{background:#fff3;color:#fff}:focus-visible{outline:2px solid var(--color-text-secondary);outline-offset:2px}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.app-container{display:flex;flex-direction:column;width:100vw;height:100vh;background:var(--color-bg-primary);overflow:hidden;position:relative}.app-header{padding:var(--space-3) var(--space-5);background:#0a0a0ad9;-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border-bottom:1px solid var(--border-subtle);flex-shrink:0;display:flex;align-items:center;justify-content:space-between;z-index:100}.app-header h1{font-size:1.1rem;margin:0;font-weight:600;color:var(--color-text-primary);letter-spacing:-.3px;background:linear-gradient(135deg,var(--color-text-primary) 0%,var(--color-text-secondary) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.upload-button{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.upload-button:hover{background:#fff3;border-color:#fff6}.upload-button-text{display:inline}@media(max-width:480px){.upload-button-text{display:none}.upload-button{padding:.5rem}}.app-header__shortcut-hint{display:flex;align-items:center;gap:var(--space-2);font-size:.75rem;color:var(--color-text-tertiary)}.shortcut-key{display:inline-flex;align-items:center;justify-content:center;padding:3px 8px;background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.65rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;font-family:monospace}.app-header__actions{display:flex;align-items:center;gap:var(--space-3)}.help-button{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast);padding:0}.help-button:hover{background:var(--color-surface-elevated);border-color:var(--border-strong);color:var(--color-text-primary);transform:scale(1.1)}.help-button svg{width:18px;height:18px}.main-content{flex:1;display:flex;align-items:center;justify-content:center;overflow:hidden;background:var(--color-bg-primary);gap:0}.video-container{height:100%;flex:0 0 auto;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);position:relative;overflow:hidden}.video-container--transitioning{animation:videoFade .3s ease-in-out}@keyframes videoFade{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.video-transition-overlay{position:absolute;inset:0;background:linear-gradient(135deg,rgba(255,255,255,.03) 0%,transparent 50%,rgba(255,255,255,.03) 100%);pointer-events:none;animation:shimmer 1s ease-in-out}.controls-container{width:380px;height:100%;padding:var(--space-6) var(--space-5);padding-bottom:var(--space-8);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);border-left:1px solid var(--border-subtle);overflow-y:auto;flex-shrink:0;display:flex;flex-direction:column;justify-content:flex-start;animation:slideInRight .5s cubic-bezier(.34,1.56,.64,1);scroll-padding-bottom:100px}.controls-container--transitioning{animation:controlsFade .3s ease-in-out}@keyframes controlsFade{0%{opacity:1}50%{opacity:.7}to{opacity:1}}.stats-wrapper{display:flex;flex-direction:column;gap:var(--space-4);animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1) .1s both;margin-top:var(--space-4);padding-bottom:calc(var(--space-6) + 80px)}.next-button-container{text-align:center;margin-top:var(--space-4)}.next-button-container--sticky{position:sticky;bottom:0;margin-top:auto;margin-bottom:0;padding-top:var(--space-4);padding-bottom:var(--space-2);background:linear-gradient(to top,var(--color-surface-glass) 70%,transparent);z-index:10}.next-video-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4) var(--space-5);font-size:.95rem;font-weight:600;color:var(--color-bg-primary);background:var(--color-text-primary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:0 0 #fff0}.next-video-button--prominent{padding:var(--space-5) var(--space-6);font-size:1.1rem;background:linear-gradient(135deg,var(--color-text-primary) 0%,#e0e0e0 100%);box-shadow:0 4px 20px #fff3;animation:pulse-glow 2s ease-in-out infinite}@keyframes pulse-glow{0%,to{box-shadow:0 4px 20px #fff3}50%{box-shadow:0 4px 30px #ffffff59}}.next-video-button:hover{transform:translateY(-2px);box-shadow:0 6px 24px #ffffff40}.next-video-button:active{transform:translateY(0);box-shadow:0 2px 12px #ffffff26}.next-video-button svg{width:20px;height:20px;transition:transform var(--transition-fast)}.next-video-button--prominent svg{width:24px;height:24px}.next-video-button:hover svg{transform:translate(4px)}.mobile-vote-button,.close-menu-button{display:none}.error-state,.empty-state{display:flex;flex-direction:column;justify-content:center;align-items:center;width:100vw;height:100vh;color:var(--color-text-primary);text-align:center;padding:var(--space-8);animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1)}.error-state__icon,.empty-state__icon{width:64px;height:64px;color:var(--color-text-tertiary);margin-bottom:var(--space-5)}.error-state__icon svg,.empty-state__icon svg{width:100%;height:100%}.error-state__title,.empty-state__title{font-size:1.5rem;font-weight:600;margin-bottom:var(--space-2);color:var(--color-text-primary)}.error-state__message,.empty-state__message{font-size:1rem;color:var(--color-text-secondary);margin-bottom:var(--space-6);max-width:400px;line-height:1.6}.error-state__button{padding:var(--space-3) var(--space-6);font-size:.95rem;font-weight:600;color:var(--color-bg-primary);background:var(--color-text-primary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.error-state__button:hover{transform:translateY(-1px);box-shadow:0 4px 16px #ffffff26}@media(max-width:900px){.app-header{padding:var(--space-3) var(--space-4);min-height:56px}.app-header__actions{gap:var(--space-2)}.app-header__shortcut-hint{display:none}.help-button{width:36px;height:36px}.main-content{flex-direction:column}.video-container{flex:1;min-height:0}.controls-container{position:fixed;bottom:0;left:0;right:0;width:100%;height:85vh;max-height:none;z-index:1000;border-left:none;border-top:1px solid var(--border-subtle);transform:translateY(100%);transition:transform .4s cubic-bezier(.34,1.56,.64,1);padding:var(--space-6) var(--space-4) calc(100px + var(--space-6) + env(safe-area-inset-bottom));background:var(--color-surface-glass);-webkit-backdrop-filter:blur(40px);backdrop-filter:blur(40px);border-radius:var(--radius-xl) var(--radius-xl) 0 0;justify-content:flex-start;overflow-y:auto;box-shadow:0 -8px 32px #0006;scroll-padding-top:var(--space-6);scroll-padding-bottom:calc(100px + env(safe-area-inset-bottom))}.controls-container.open{transform:translateY(0)}.close-menu-button{display:flex;align-items:center;justify-content:center;align-self:flex-end;width:40px;height:40px;margin-bottom:var(--space-3);background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-fast)}.close-menu-button:hover{background:var(--color-surface-elevated);color:var(--color-text-primary)}.close-menu-button svg{width:20px;height:20px}.mobile-vote-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);position:fixed;bottom:calc(24px + env(safe-area-inset-bottom));right:24px;padding:var(--space-3) var(--space-5);font-size:.95rem;font-weight:600;color:var(--color-bg-primary);background:var(--color-text-primary);border:none;border-radius:var(--radius-full);cursor:pointer;z-index:999;transition:all var(--transition-spring);box-shadow:0 4px 20px #0006;animation:slideInUp .5s cubic-bezier(.34,1.56,.64,1) .3s both;min-height:48px}.mobile-vote-button svg{width:20px;height:20px}.mobile-vote-button:hover{transform:scale(1.05);box-shadow:0 6px 24px #ffffff40}.mobile-vote-button:active{transform:scale(.95)}.mobile-vote-button.hidden{transform:translateY(200%);opacity:0}.mobile-overlay{display:none;position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);z-index:998;opacity:0;transition:opacity .3s ease}.mobile-overlay.open{display:block;opacity:1}.stats-wrapper{gap:var(--space-4);padding-bottom:calc(80px + var(--space-4) + env(safe-area-inset-bottom))}.next-button-container{margin-top:var(--space-4);margin-bottom:0}.next-button-container--sticky{position:fixed;bottom:calc(var(--space-4) + env(safe-area-inset-bottom));left:var(--space-4);right:var(--space-4);margin:0;padding:0;background:none;z-index:100}.next-video-button--prominent{padding:var(--space-4) var(--space-5);font-size:1.05rem}.error-state,.empty-state{padding:var(--space-6) var(--space-4)}.error-state__icon,.empty-state__icon{width:56px;height:56px}.error-state__title,.empty-state__title{font-size:1.25rem}}@media(prefers-reduced-motion:reduce){.controls-container,.mobile-vote-button,.video-container--transitioning,.next-video-button{animation:none;transition:opacity .1s ease}}.video-player{height:100%;width:100%;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);position:relative;overflow:hidden}.video-player--loading,.video-player--error{background:var(--color-bg-secondary)}.video-player__error-content{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--color-text-secondary);text-align:center;padding:var(--space-6)}.video-player__error-icon{width:64px;height:64px;color:var(--color-error)}.video-player__error-icon svg{width:100%;height:100%}.video-player__error-text{font-size:1rem;font-weight:500;color:var(--color-text-secondary);margin:0}.video-player__retry-button{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-5);font-size:.9rem;font-weight:600;color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base)}.video-player__retry-button:hover{background:var(--color-surface-elevated);border-color:var(--border-strong);transform:translateY(-1px)}.video-player__retry-button:active{transform:translateY(0)}.video-player__retry-button svg{width:18px;height:18px}.video-element{height:100%;width:auto;max-width:none;object-fit:contain;display:block;transition:opacity .3s ease}.video-player__loader{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-4);color:var(--color-text-secondary)}.video-player__spinner{width:48px;height:48px;color:var(--color-text-secondary)}.video-player__spinner svg{width:100%;height:100%}.video-player__loading-text{font-size:.9rem;font-weight:500;color:var(--color-text-secondary);letter-spacing:.02em;margin:0}.video-player__loading-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);z-index:5}.video-player__error-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:var(--color-bg-primary);z-index:10}.video-player__error{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);color:var(--color-error)}.video-player__error svg{width:48px;height:48px}.video-player__error p{font-size:.9rem;font-weight:500;margin:0}.video-player__gradient{position:absolute;bottom:0;left:0;right:0;height:120px;background:linear-gradient(to top,rgba(10,10,10,.6) 0%,rgba(10,10,10,.2) 50%,transparent 100%);pointer-events:none;opacity:0;transition:opacity .3s ease}.video-player:hover .video-player__gradient{opacity:1}.video-player__play-overlay{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#0000004d;opacity:0;transition:opacity .3s ease;cursor:pointer;border:none;padding:0}.video-player__play-overlay.visible{opacity:1}.video-player__play-button{width:72px;height:72px;display:flex;align-items:center;justify-content:center;background:#ffffff26;-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);border:1px solid rgba(255,255,255,.2);border-radius:var(--radius-full);color:#fff;transition:all var(--transition-base);box-shadow:0 4px 24px #0000004d}.video-player__play-button svg{width:28px;height:28px;margin-left:4px}.video-player__play-overlay:hover .video-player__play-button{transform:scale(1.1);background:#ffffff40;box-shadow:0 6px 32px #0006}.video-player__play-overlay:active .video-player__play-button{transform:scale(.95)}.video-player__buffering{position:absolute;bottom:20px;right:20px;z-index:10}.video-player__spinner--small{width:24px;height:24px;color:var(--color-text-secondary)}@media(max-width:900px){.video-element{width:100%;height:auto;max-height:100%}.video-player__play-button{width:56px;height:56px}.video-player__play-button svg{width:22px;height:22px}.video-player__spinner{width:40px;height:40px}}@media(prefers-reduced-motion:reduce){.video-element,.video-player__play-overlay,.video-player__gradient,.video-player__play-button{transition:none;animation:none}}.voting-interface{width:100%;animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1)}.voting-interface__header{text-align:center;margin-bottom:var(--space-5)}.voting-interface h2{color:var(--color-text-primary);margin:0 0 var(--space-2);font-size:1.1rem;font-weight:600;letter-spacing:-.3px}.voting-interface__hint{color:var(--color-text-tertiary);font-size:.8rem;margin:0;display:flex;align-items:center;justify-content:center;gap:var(--space-1)}.voting-interface__hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:2px 6px;background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:monospace;color:var(--color-text-secondary)}.grade-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3);margin-bottom:var(--space-5)}.grade-button{position:relative;padding:var(--space-3) var(--space-2);font-size:.95rem;font-weight:600;border:1px solid var(--border-default);background:var(--color-surface);color:var(--color-text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-spring);display:flex;align-items:center;justify-content:center;min-height:52px;overflow:hidden}.grade-button:hover:not(.disabled){background:var(--color-surface-elevated);border-color:var(--border-strong);color:var(--color-text-primary);transform:translateY(-2px);box-shadow:0 4px 12px #0003}.grade-button:active:not(.disabled){transform:translateY(0) scale(.98)}.grade-button.selected{background:var(--grade-color);border-color:var(--grade-color);color:var(--color-bg-primary);transform:scale(1.02);box-shadow:0 0 8px var(--grade-color),0 4px 12px #0000004d}.grade-button.animating{animation:gradeBounce .3s cubic-bezier(.34,1.56,.64,1)}@keyframes gradeBounce{0%{transform:scale(1)}50%{transform:scale(1.08)}to{transform:scale(1.02)}}.grade-button__text{transition:transform var(--transition-fast)}.grade-button.selected .grade-button__text{transform:translate(-10px)}.grade-button__check{position:absolute;right:var(--space-2);width:16px;height:16px;animation:scaleIn .2s ease forwards}.grade-button__check svg{width:100%;height:100%}.grade-button.disabled{cursor:not-allowed;opacity:.4;pointer-events:none}.submit-vote-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-4);font-size:.95rem;font-weight:600;color:var(--color-text-primary);background:var(--color-surface-elevated);border:1px solid var(--border-default);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-spring)}.submit-vote-button:not(.disabled):not(.submitting){background:var(--selected-color);border-color:var(--selected-color);color:var(--color-bg-primary);box-shadow:0 0 0 0 var(--selected-color)}.submit-vote-button:not(.disabled):not(.submitting):hover{transform:translateY(-2px);box-shadow:0 4px 12px var(--selected-color)}.submit-vote-button:not(.disabled):not(.submitting):active{transform:translateY(0);box-shadow:0 2px 6px var(--selected-color)}.submit-vote-button.disabled{background:var(--color-surface);border-color:var(--border-subtle);color:var(--color-text-tertiary);cursor:not-allowed}.submit-vote-button.submitting{background:var(--color-surface);border-color:var(--border-default);color:var(--color-text-secondary);cursor:wait}.submit-vote-button__spinner{width:18px;height:18px;animation:spin 1s linear infinite}.submit-vote-button__spinner svg{width:100%;height:100%}.submit-vote-button__grade{display:inline-flex;align-items:center;justify-content:center;padding:2px 10px;background:#0003;border-radius:var(--radius-sm);font-size:.85rem;font-weight:700;margin-left:var(--space-1)}@media(max-width:900px){.voting-interface__header{margin-bottom:var(--space-3)}.voting-interface h2{font-size:1.1rem;margin-bottom:var(--space-1)}.voting-interface__hint{font-size:.75rem}.voting-interface__hint kbd{min-width:22px;padding:2px 5px;font-size:.7rem}.grade-grid{gap:var(--space-2);margin-bottom:var(--space-4);grid-template-columns:repeat(6,1fr)}.grade-button{padding:var(--space-2) var(--space-1);font-size:.8rem;min-height:44px;border-radius:var(--radius-sm)}.grade-button__check{width:14px;height:14px;right:var(--space-1)}.submit-vote-button{padding:var(--space-3) var(--space-4);font-size:1rem;min-height:48px}.submit-vote-button__grade{padding:2px 8px;font-size:.8rem}}@media(prefers-reduced-motion:reduce){.grade-button,.submit-vote-button{transition:opacity .1s ease;animation:none}.grade-button__check,.submit-vote-button__spinner{animation:none}}.stats-display{width:100%;opacity:0;transform:translateY(20px);transition:opacity .5s ease,transform .5s cubic-bezier(.34,1.56,.64,1)}.stats-display.visible{opacity:1;transform:translateY(0)}.stats-display__empty{text-align:center;padding:var(--space-8) var(--space-4);animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1)}.stats-display__empty-icon{width:56px;height:56px;margin:0 auto var(--space-4);color:var(--color-text-tertiary)}.stats-display__empty-icon svg{width:100%;height:100%}.stats-display__empty h3{color:var(--color-text-primary);font-size:1.1rem;font-weight:600;margin:0 0 var(--space-2)}.stats-display__empty p{color:var(--color-text-secondary);font-size:.9rem;margin:0}.stats-display__header{text-align:center;margin-bottom:var(--space-5)}.stats-display__header h2{color:var(--color-text-primary);font-size:1.1rem;font-weight:600;margin:0;letter-spacing:-.3px}.stats-display__summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3);margin-bottom:var(--space-6)}.stat-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);transition:all var(--transition-base);animation:fadeInUp .4s cubic-bezier(.34,1.56,.64,1) forwards;opacity:0;transform:translateY(10px)}.stat-card:nth-child(1){animation-delay:.1s}.stat-card:nth-child(2){animation-delay:.2s}.stat-card:nth-child(3){animation-delay:.3s}.stat-card:hover{background:var(--color-surface-elevated);border-color:var(--border-default);transform:translateY(-2px);box-shadow:0 4px 16px #0003}.stat-card__icon{width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary);border-radius:var(--radius-md);color:var(--color-text-secondary);flex-shrink:0}.stat-card__icon svg{width:20px;height:20px}.stat-card--consensus .stat-card__icon{color:var(--color-grade-intermediate)}.stat-card--actual{border-color:#22c55e4d;background:linear-gradient(135deg,rgba(34,197,94,.08) 0%,var(--color-surface) 100%)}.stat-card--actual .stat-card__icon{color:var(--color-success);background:#22c55e26}.stat-card--actual:hover{border-color:#22c55e80;box-shadow:0 4px 20px #22c55e26}.stat-card__content{display:flex;flex-direction:column;gap:2px}.stat-card__label{font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.8px;font-weight:600}.stat-card__value{font-size:1.6rem;font-weight:700;color:var(--color-text-primary);line-height:1}.stat-card__value--grade{color:var(--grade-color);text-shadow:0 0 20px var(--grade-color)}.view-distribution-button{width:100%;display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);margin:var(--space-4) 0 var(--space-2);font-size:.95rem;font-weight:600;color:var(--color-bg-primary);background:var(--color-text-primary);border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 16px #ffffff1a}.view-distribution-button:hover{transform:translateY(-1px);box-shadow:0 6px 20px #fff3}.view-distribution-button:active{transform:translateY(0);box-shadow:0 2px 8px #ffffff1a}.view-distribution-button svg{width:18px;height:18px;transition:transform var(--transition-fast)}.view-distribution-button:hover svg{transform:translate(2px)}.stats-display__distribution{margin-top:var(--space-2);max-height:0;overflow:hidden;opacity:0;transition:max-height .5s ease,opacity .3s ease,margin .3s ease}.stats-display__distribution.expanded{max-height:2000px;opacity:1;margin-top:var(--space-4)}.stats-display__distribution h3{color:var(--color-text-secondary);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:1px;margin:0 0 var(--space-4);opacity:.8}.distribution-chart{display:flex;flex-direction:column;gap:var(--space-3)}.distribution-row{display:grid;grid-template-columns:auto 1fr auto;gap:var(--space-3);align-items:center;padding:var(--space-2) 0;animation:fadeInUp .4s cubic-bezier(.34,1.56,.64,1) forwards;opacity:0;transform:translateY(10px)}.distribution-row:hover{background:var(--color-surface);border-radius:var(--radius-md);margin:0 calc(-1 * var(--space-2));padding:var(--space-2)}.distribution-row__label{display:flex;align-items:center;gap:var(--space-2);min-width:60px}.grade-badge{display:inline-flex;align-items:center;justify-content:center;min-width:42px;padding:4px 8px;font-size:.85rem;font-weight:600;color:var(--grade-color);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-sm)}.consensus-badge{width:16px;height:16px;display:flex;align-items:center;justify-content:center;background:var(--color-grade-beginner);border-radius:var(--radius-full);color:var(--color-bg-primary);animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.consensus-badge svg{width:10px;height:10px}.user-badge{font-size:.65rem;font-weight:600;color:var(--color-text-primary);background:var(--color-surface-elevated);border:1px solid var(--border-default);padding:2px 6px;border-radius:var(--radius-sm);text-transform:uppercase;letter-spacing:.5px}.distribution-row.user-vote{background:#ffffff08;border-radius:var(--radius-md);margin:0 calc(-1 * var(--space-2));padding:var(--space-2)}.distribution-row.user-vote .distribution-row__bar{box-shadow:0 0 12px #fff3}.distribution-row__bar-container{height:28px;background:var(--color-surface);border-radius:var(--radius-md);overflow:hidden;position:relative;border:1px solid var(--border-subtle)}.distribution-row__bar{height:100%;border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:flex-end;padding-right:var(--space-2);transition:width .8s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden}.distribution-row__bar:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.1) 50%,transparent 100%);animation:shimmer 2s infinite}.distribution-row__bar.consensus{box-shadow:0 0 16px var(--grade-color)}.distribution-row__percentage{color:#fff;font-size:.75rem;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.5);white-space:nowrap}.distribution-row__count{font-size:.75rem;color:var(--color-text-tertiary);font-weight:500;min-width:50px;text-align:right}@media(max-width:900px){.view-distribution-button{padding:var(--space-3);font-size:.9rem;margin:var(--space-3) 0 var(--space-2)}.view-distribution-button svg{width:16px;height:16px}.stats-display__summary{gap:var(--space-2);margin-bottom:var(--space-4);grid-template-columns:repeat(3,1fr)}.stat-card{padding:var(--space-3) var(--space-2);flex-direction:column;text-align:center;gap:var(--space-2)}.stat-card__icon{width:32px;height:32px}.stat-card__icon svg{width:16px;height:16px}.stat-card__label{font-size:.6rem}.stat-card__value{font-size:1.1rem}.stats-display__distribution h3{margin-bottom:var(--space-3);font-size:.7rem}.distribution-chart{gap:var(--space-2)}.distribution-row{grid-template-columns:auto 1fr auto;gap:var(--space-2);padding:var(--space-1) 0}.distribution-row__bar-container{height:22px}.distribution-row__label{min-width:auto}.grade-badge{min-width:32px;padding:2px 6px;font-size:.75rem}.consensus-badge{width:14px;height:14px}.user-badge{font-size:.6rem;padding:1px 4px}.distribution-row__percentage{font-size:.7rem}.distribution-row__count{font-size:.7rem;min-width:36px}}@media(prefers-reduced-motion:reduce){.stats-display,.stat-card,.distribution-row,.distribution-row__bar{animation:none;transition:opacity .1s ease}.stats-display,.stat-card,.distribution-row{opacity:1;transform:none}.distribution-row__bar:before{animation:none}}.vote-feedback{padding:var(--space-4);margin-bottom:var(--space-5);border-radius:var(--radius-lg);border:1px solid var(--border-default);background:var(--color-surface);animation:fadeInUp .4s cubic-bezier(.34,1.56,.64,1)}.vote-feedback--exact{background:linear-gradient(135deg,rgba(34,197,94,.1) 0%,var(--color-surface) 100%);border-color:#22c55e4d}.vote-feedback--close{background:linear-gradient(135deg,rgba(245,158,11,.1) 0%,var(--color-surface) 100%);border-color:#f59e0b4d}.vote-feedback--off{background:linear-gradient(135deg,rgba(59,130,246,.1) 0%,var(--color-surface) 100%);border-color:#3b82f64d}.vote-feedback__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.vote-feedback__icon{width:24px;height:24px;flex-shrink:0}.vote-feedback--exact .vote-feedback__icon{color:var(--color-success)}.vote-feedback--close .vote-feedback__icon{color:var(--color-warning)}.vote-feedback--off .vote-feedback__icon{color:var(--color-info)}.vote-feedback__title{font-size:1rem;font-weight:600;color:var(--color-text-primary);margin:0}.vote-feedback__subtitle{font-size:.85rem;color:var(--color-text-secondary);margin:0;line-height:1.4}.vote-feedback__grades{display:flex;align-items:center;justify-content:center;gap:var(--space-4);margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.vote-feedback__grade-item{display:flex;flex-direction:column;align-items:center;gap:var(--space-1)}.vote-feedback__grade-label{font-size:.7rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:500}.vote-feedback__grade-value{font-size:1.5rem;font-weight:700;padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);min-width:60px;text-align:center}.vote-feedback__grade-value--user{background:var(--color-surface-elevated);border:1px solid var(--border-default);color:var(--color-text-primary)}.vote-feedback__grade-value--actual{background:#22c55e26;border:1px solid rgba(34,197,94,.3);color:var(--color-success)}.vote-feedback__arrow{color:var(--color-text-tertiary);font-size:1.2rem}@media(max-width:900px){.vote-feedback{padding:var(--space-3);margin-bottom:var(--space-3)}.vote-feedback__header{gap:var(--space-2)}.vote-feedback__icon{width:22px;height:22px}.vote-feedback__title{font-size:.95rem}.vote-feedback__subtitle{font-size:.8rem}.vote-feedback__grades{gap:var(--space-3);margin-top:var(--space-2);padding-top:var(--space-2)}.vote-feedback__grade-value{font-size:1.1rem;min-width:44px;padding:var(--space-1) var(--space-2)}.vote-feedback__arrow{font-size:1rem}}.user-stats{padding:var(--space-4);background:var(--color-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);animation:fadeInUp .5s cubic-bezier(.34,1.56,.64,1);position:relative;overflow:hidden;margin-bottom:var(--space-6)}.user-stats--loading{display:flex;align-items:center;justify-content:center;min-height:120px}.user-stats__spinner{width:32px;height:32px;border:2px solid var(--border-subtle);border-top-color:var(--color-text-secondary);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.user-stats__header{margin-bottom:var(--space-4)}.user-stats__header h3{margin:0;font-size:.9rem;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.user-stats--empty{text-align:center;padding:var(--space-5)}.user-stats__empty-state p{margin:0;color:var(--color-text-tertiary);font-size:.9rem}.user-stats__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-4)}.stat-box{display:flex;flex-direction:column;align-items:center;padding:var(--space-3);background:var(--color-bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);text-align:center}.stat-box__value{font-size:2rem;font-weight:700;color:var(--color-text-primary);line-height:1;margin-bottom:var(--space-1)}.stat-box__label{font-size:.75rem;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.stat-box--streak .stat-box__value{color:var(--color-grade-beginner)}.stat-box--best .stat-box__value{color:var(--color-grade-intermediate)}.user-stats__accuracy{margin-bottom:var(--space-4)}.accuracy-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-2)}.accuracy-label{flex:1;font-size:.85rem;color:var(--color-text-secondary)}.accuracy-value{font-size:1.1rem;font-weight:700;color:var(--color-text-primary)}.accuracy-bar{height:8px;background:var(--color-bg-secondary);border-radius:var(--radius-full);overflow:hidden;margin-bottom:var(--space-2)}.accuracy-bar__fill{height:100%;background:linear-gradient(90deg,var(--color-grade-beginner),var(--color-grade-intermediate));border-radius:var(--radius-full);transition:width 1s cubic-bezier(.34,1.56,.64,1)}.accuracy-breakdown{display:flex;justify-content:space-between;gap:var(--space-2);font-size:.75rem}.breakdown-item{padding:2px 8px;border-radius:var(--radius-sm);background:var(--color-bg-secondary)}.breakdown-item--exact{color:var(--color-success)}.breakdown-item--close{color:var(--color-warning)}.breakdown-item--off{color:var(--color-info)}.user-stats__reset-button{width:100%;padding:var(--space-2);font-size:.75rem;color:var(--color-text-tertiary);background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast)}.user-stats__reset-button:hover{color:var(--color-error);border-color:var(--color-error);background:#ef44440d}.reset-confirm-overlay{position:fixed;inset:0;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:10000;animation:fadeIn .2s ease}.reset-confirm-modal{width:90%;max-width:320px;padding:var(--space-5);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-default);border-radius:var(--radius-xl);text-align:center;animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.reset-confirm-modal h4{margin:0 0 var(--space-2);font-size:1.1rem;color:var(--color-text-primary)}.reset-confirm-modal p{margin:0 0 var(--space-4);font-size:.9rem;color:var(--color-text-secondary);line-height:1.5}.reset-confirm-buttons{display:flex;gap:var(--space-3)}.reset-confirm__cancel,.reset-confirm__confirm{flex:1;padding:var(--space-3) var(--space-4);font-size:.9rem;font-weight:600;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.reset-confirm__cancel{color:var(--color-text-primary);background:var(--color-surface);border:1px solid var(--border-default)}.reset-confirm__cancel:hover{background:var(--color-surface-elevated)}.reset-confirm__confirm{color:#fff;background:var(--color-error)}.reset-confirm__confirm:hover{background:#dc2626;transform:translateY(-1px)}@media(max-width:900px){.user-stats{padding:var(--space-3)}.user-stats__grid{gap:var(--space-2)}.stat-box{padding:var(--space-2)}.stat-box__icon{font-size:1.25rem}.stat-box__value{font-size:1.75rem}.stat-box__label{font-size:.7rem}.accuracy-header{margin-bottom:var(--space-1)}.accuracy-value{font-size:1rem}.accuracy-breakdown{font-size:.7rem}.breakdown-item{padding:2px 6px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.upload-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.upload-modal{background:#121212fa;border-radius:16px;border:1px solid rgba(255,255,255,.1);width:100%;max-width:480px;max-height:90vh;overflow:hidden;box-shadow:0 20px 60px #00000080}.upload-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid rgba(255,255,255,.1)}.upload-modal-header h2{margin:0;font-size:1.25rem;font-weight:600;color:#fff}.close-button{background:none;border:none;color:#fff9;font-size:1.75rem;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:6px;transition:all .15s ease;line-height:1}.close-button:hover{color:#fff;background:#ffffff1a}.upload-modal-content{padding:1.5rem}.file-input-section{margin-bottom:1.5rem}.file-input-label{display:block;cursor:pointer}.file-input{display:none}.file-input-button{display:block;width:100%;padding:.875rem 1rem;background:#ffffff1a;border:2px dashed rgba(255,255,255,.3);border-radius:10px;color:#fff;text-align:center;font-weight:500;transition:all .15s ease}.file-input-button:hover{background:#ffffff26;border-color:#ffffff80}.file-input:disabled+.file-input-button{opacity:.5;cursor:not-allowed}.selected-file-name{margin:.75rem 0 0;color:#ffffffb3;font-size:.875rem;text-align:center;word-break:break-all}.grade-select-section{margin-bottom:1.5rem}.grade-select-section label{display:block;color:#fffc;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.grade-select{width:100%;padding:.75rem 2.5rem .75rem 1rem;background:#ffffff1a;border:1px solid rgba(255,255,255,.2);border-radius:8px;color:#fff;font-size:1rem;cursor:pointer;transition:all .15s ease;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23ffffff' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 1rem center}.grade-select:focus{outline:none;border-color:#fff6;background:#ffffff26}.grade-select:disabled{opacity:.5;cursor:not-allowed}.grade-select option{background:#1a1a1a;color:#fff}.upload-submit-button{width:100%;padding:.875rem;background:#fff;color:#111;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease}.upload-submit-button:hover:not(:disabled){background:#ffffffe6}.upload-submit-button:disabled{opacity:.5;cursor:not-allowed}.upload-error{background:#dc262633;border:1px solid rgba(220,38,38,.4);border-radius:8px;padding:.75rem 1rem;margin-bottom:1rem;color:#fca5a5;font-size:.9rem;text-align:center}.upload-success{text-align:center;padding:2rem 1rem}.success-icon{width:64px;height:64px;background:#22c55e33;border:2px solid rgba(34,197,94,.4);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 1rem;font-size:2rem;color:#4ade80}.upload-success p{color:#fff;font-size:1.1rem;font-weight:500;margin:0}@media(max-width:480px){.upload-modal-overlay{align-items:flex-end;padding:0}.upload-modal{border-radius:20px 20px 0 0;max-height:85vh}.upload-modal-header{padding:1rem 1.25rem}.upload-modal-header h2{font-size:1.1rem}.upload-modal-content{padding:1.25rem}}.toast-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:12px;padding:14px 18px;min-width:300px;max-width:400px;background:var(--color-surface-glass);-webkit-backdrop-filter:blur(24px);backdrop-filter:blur(24px);border:1px solid var(--border-default);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);pointer-events:auto;animation:slideInRight .4s cubic-bezier(.34,1.56,.64,1) forwards;position:relative;overflow:hidden}.toast--exiting{animation:slideOutRight .3s cubic-bezier(.4,0,.2,1) forwards}.toast--success{border-color:#22c55e4d}.toast--success .toast__icon{color:var(--color-success)}.toast--error{border-color:#ef44444d}.toast--error .toast__icon{color:var(--color-error)}.toast--warning{border-color:#f59e0b4d}.toast--warning .toast__icon{color:var(--color-warning)}.toast--info{border-color:#3b82f64d}.toast--info .toast__icon{color:var(--color-info)}.toast__icon{flex-shrink:0;width:22px;height:22px;color:var(--color-text-secondary)}.toast__icon svg{width:100%;height:100%}.toast__content{flex:1;min-width:0}.toast__message{margin:0;font-size:.9rem;font-weight:500;color:var(--color-text-primary);line-height:1.4}.toast__close{flex-shrink:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-sm);cursor:pointer;color:var(--color-text-tertiary);transition:all var(--transition-fast);padding:0}.toast__close:hover{background:#ffffff1a;color:var(--color-text-primary)}.toast__close svg{width:16px;height:16px}.toast__progress{position:absolute;bottom:0;left:0;height:2px;background:currentColor;opacity:.3;animation:progress linear forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(100%) scale(.9)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes slideOutRight{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.9)}}@keyframes progress{0%{width:100%}to{width:0%}}@media(max-width:640px){.toast-container{inset:auto 16px 100px;align-items:stretch}.toast{min-width:auto;max-width:none}}.skeleton{background:var(--color-bg-secondary);border-radius:var(--radius-lg);position:relative;overflow:hidden}.skeleton__shimmer{position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.03) 50%,transparent 100%);background-size:200% 100%;animation:shimmer 2s infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-video{height:100%;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary)}.skeleton-video__content{display:flex;flex-direction:column;align-items:center;gap:var(--space-4);color:var(--color-text-tertiary)}.skeleton-video__spinner{width:48px;height:48px;color:var(--color-text-secondary);animation:pulse 2s ease-in-out infinite}.skeleton-video__spinner svg{width:100%;height:100%}.skeleton-video__text{font-size:.9rem;font-weight:500;letter-spacing:.02em}.skeleton-controls{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.skeleton-controls__header{text-align:center;margin-bottom:var(--space-2)}.skeleton-controls__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.skeleton-stats{padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-4)}.skeleton-stats__header{text-align:center}.skeleton-stats__summary{display:flex;justify-content:center;gap:var(--space-8);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.skeleton__stat{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.skeleton-stats__bars{display:flex;flex-direction:column;gap:var(--space-3)}.skeleton__bar-row{display:grid;grid-template-columns:40px 1fr;gap:var(--space-3);align-items:center}.skeleton__bar{height:24px;background:var(--color-surface);border-radius:var(--radius-sm);overflow:hidden}.skeleton__bar-fill{height:100%;background:var(--color-surface-elevated);border-radius:var(--radius-sm);animation:pulse 2s ease-in-out infinite}.skeleton__line{height:12px;background:var(--color-surface-elevated);border-radius:var(--radius-sm);animation:pulse 2s ease-in-out infinite}.skeleton__line--short{width:60%;margin:0 auto}.skeleton__line--medium{width:40%;margin:0 auto}.skeleton__line--tiny{width:60px;height:8px}.skeleton__line--number{width:50px;height:32px}.skeleton__line--badge{width:60px;height:32px;border-radius:var(--radius-md)}.skeleton__line--label{width:100%;height:16px}.skeleton__button{height:44px;background:var(--color-surface);border-radius:var(--radius-md);animation:pulse 2s ease-in-out infinite}.skeleton__button--large{height:48px;margin-top:var(--space-2)}.skeleton-card{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-3)}@media(max-width:900px){.skeleton-controls,.skeleton-stats{padding:var(--space-4)}.skeleton-stats__summary{gap:var(--space-5)}.skeleton__bar-row{grid-template-columns:35px 1fr}.skeleton__bar{height:20px}}.keyboard-shortcuts-trigger{position:fixed;bottom:24px;left:24px;z-index:100;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:var(--color-surface);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-secondary);transition:all var(--transition-base)}.keyboard-shortcuts-trigger:hover{background:var(--color-surface-elevated);border-color:var(--border-strong);color:var(--color-text-primary);transform:scale(1.1)}.keyboard-shortcuts-trigger svg{width:20px;height:20px}.keyboard-shortcuts-overlay{position:fixed;inset:0;z-index:10000;display:flex;align-items:center;justify-content:center;background:#000c;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);animation:fadeIn .2s ease}.keyboard-shortcuts-modal{position:relative;width:90%;max-width:400px;padding:var(--space-6);background:var(--color-surface-glass);-webkit-backdrop-filter:blur(32px);backdrop-filter:blur(32px);border:1px solid var(--border-default);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);animation:scaleIn .3s cubic-bezier(.34,1.56,.64,1)}.keyboard-shortcuts__close{position:absolute;top:var(--space-3);right:var(--space-3);width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-full);cursor:pointer;color:var(--color-text-tertiary);transition:all var(--transition-fast)}.keyboard-shortcuts__close:hover{background:var(--color-surface);color:var(--color-text-primary)}.keyboard-shortcuts__close svg{width:18px;height:18px}.keyboard-shortcuts-modal h2{font-size:1.1rem;font-weight:600;color:var(--color-text-primary);margin:0 0 var(--space-5);text-align:center}.keyboard-shortcuts__list{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-5)}.keyboard-shortcuts__item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-surface);border:1px solid var(--border-subtle);border-radius:var(--radius-md);animation:fadeInUp .3s ease forwards;opacity:0;transform:translateY(10px)}.keyboard-shortcuts__key{display:inline-flex;align-items:center;justify-content:center;min-width:60px;padding:6px 12px;background:var(--color-bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);font-size:.85rem;font-weight:600;font-family:monospace;color:var(--color-text-secondary);flex-shrink:0}.keyboard-shortcuts__description{font-size:.9rem;color:var(--color-text-primary)}.keyboard-shortcuts__hint{text-align:center;margin:0;font-size:.8rem;color:var(--color-text-tertiary);display:flex;align-items:center;justify-content:center;gap:var(--space-1)}.keyboard-shortcuts__hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:24px;padding:2px 6px;background:var(--color-bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;font-family:monospace}@media(max-width:640px){.keyboard-shortcuts-trigger{display:none}.keyboard-shortcuts-modal{padding:var(--space-5)}.keyboard-shortcuts__item{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.keyboard-shortcuts__key{min-width:auto}}@media(prefers-reduced-motion:reduce){.keyboard-shortcuts-overlay,.keyboard-shortcuts-modal,.keyboard-shortcuts__item{animation:none;opacity:1;transform:none}}
