*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-bg: #0a0e27;--color-bg-grid: rgba(255, 255, 255, .03);--color-surface: #1a1e3a;--color-surface-light: #252a4a;--color-border: rgba(255, 255, 255, .08);--color-border-light: rgba(255, 255, 255, .15);--color-text-primary: #ffffff;--color-text-secondary: #b0b0c0;--color-text-muted: #6b6b8a;--color-gold: #FFD700;--color-silver: #C0C0C0;--color-bronze: #CD7F32;--color-bar-start: #00D4AA;--color-bar-end: #00B4D8;--color-bar-gradient: linear-gradient(90deg, var(--color-bar-start), var(--color-bar-end));--anim-fast: 80ms;--anim-medium: .13s;--anim-slow: .2s;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--header-height: 72px;--footer-height: 56px;--lane-height: 72px;--lane-height-mobile: 56px;--font-family: "Pretendard", "Noto Sans KR", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: 11px;--font-size-sm: 13px;--font-size-md: 15px;--font-size-lg: 18px;--font-size-xl: 22px;--font-size-2xl: 28px;--font-size-3xl: 36px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 9999px;--shadow-glow-gold: 0 0 20px rgba(255, 215, 0, .6);--shadow-glow-silver: 0 0 16px rgba(192, 192, 192, .5);--shadow-glow-bronze: 0 0 16px rgba(205, 127, 50, .5);--shadow-card: 0 4px 24px rgba(0, 0, 0, .4)}html{font-size:16px;-webkit-text-size-adjust:100%}body{font-family:var(--font-family);background-color:var(--color-bg);color:var(--color-text-primary);min-height:100vh;overflow-x:hidden;background-image:linear-gradient(rgba(255,255,255,.02) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.02) 1px,transparent 1px);background-size:40px 40px}#root{display:flex;flex-direction:column;min-height:100vh}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--color-bg)}::-webkit-scrollbar-thumb{background:var(--color-surface-light);border-radius:var(--radius-full)}:focus-visible{outline:2px solid var(--color-bar-start);outline-offset:2px;border-radius:var(--radius-sm)}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border-width:0}.app{display:flex;flex-direction:column;min-height:100vh}.app__main{flex:1;display:flex;flex-direction:column;padding:var(--space-md);gap:var(--space-md);max-width:1400px;width:100%;margin:0 auto}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:#1a1e3ae6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-bottom:1px solid var(--color-border-light);position:sticky;top:0;z-index:100;min-height:var(--header-height)}.app-header__title{display:flex;align-items:center;gap:var(--space-sm)}.app-header__title h1{font-size:var(--font-size-xl);font-weight:700;background:linear-gradient(135deg,#00d4aa,#00b4d8,#6b7fff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;white-space:nowrap}.app-header__flag{font-size:var(--font-size-xl)}.app-header__controls{display:flex;align-items:center;gap:var(--space-lg)}.app-header__date{font-size:var(--font-size-sm);color:var(--color-text-secondary);white-space:nowrap}.week-dropdown{position:relative;display:inline-flex}.week-dropdown__trigger{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all .2s;min-width:200px}.week-dropdown__trigger:hover{border-color:var(--color-bar-start);background:var(--color-surface-light)}.week-dropdown__icon{font-size:var(--font-size-md)}.week-dropdown__label{flex:1;text-align:left;font-weight:600}.week-dropdown__chevron{font-size:var(--font-size-xs);color:var(--color-text-secondary);transition:transform .2s}.week-dropdown__chevron--open{transform:rotate(180deg)}.week-dropdown__menu{position:absolute;top:calc(100% + 4px);right:0;min-width:100%;background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-md);box-shadow:var(--shadow-card);z-index:200;overflow:hidden;animation:dropdown-appear .15s ease}@keyframes dropdown-appear{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.week-dropdown__option{display:flex;align-items:center;gap:var(--space-sm);width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;color:var(--color-text-secondary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:all .15s;text-align:left}.week-dropdown__option:hover{background:var(--color-surface-light);color:var(--color-text-primary)}.week-dropdown__option--active{background:#00d4aa1a;color:var(--color-bar-start);font-weight:600}.week-dropdown__option--active:hover{background:#00d4aa26}.week-dropdown__option-icon{font-size:var(--font-size-md);width:20px;text-align:center}.week-dropdown__divider{height:1px;background:var(--color-border);margin:var(--space-xs) 0}.loser-list{margin-top:var(--space-md);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.loser-list__header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);background:#0003;border-bottom:1px solid var(--color-border)}.loser-list__title{font-size:var(--font-size-sm);color:var(--color-text-muted);font-weight:600}.loser-list__count{font-size:var(--font-size-xs);color:var(--color-text-muted);background:#ffffff0d;padding:2px 8px;border-radius:var(--radius-full)}.loser-list__grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:1px;background:var(--color-border)}.loser-list__item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-surface);cursor:pointer;transition:background .15s}.loser-list__item:hover{background:var(--color-surface-light)}.loser-list__rank{font-size:var(--font-size-xs);color:var(--color-text-muted);min-width:28px;font-weight:600}.loser-list__name{font-size:var(--font-size-sm);color:var(--color-text-secondary);flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.loser-list__score{font-size:var(--font-size-xs);color:var(--color-text-muted);font-variant-numeric:tabular-nums}@media (max-width: 768px){.loser-list__grid{grid-template-columns:repeat(auto-fill,minmax(160px,1fr))}.loser-list__item{padding:var(--space-xs) var(--space-sm)}}.stats-footer{display:flex;align-items:center;justify-content:center;gap:var(--space-lg);padding:var(--space-md) var(--space-xl);background:#1a1e3ae6;border-top:1px solid var(--color-border-light);min-height:var(--footer-height);flex-wrap:wrap}.stats-footer--empty{justify-content:center}.stats-footer__item{display:flex;align-items:center;gap:var(--space-sm)}.stats-footer__item--mvp{background:#ffd70014;border:1px solid rgba(255,215,0,.2);padding:var(--space-xs) var(--space-md);border-radius:var(--radius-full)}.stats-footer__label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stats-footer__value{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary)}.stats-footer__value--gold{color:var(--color-gold)}.stats-footer__divider{width:1px;height:20px;background:var(--color-border-light)}.race-container{position:relative;display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md) 0}.race-container--empty{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-muted);font-size:var(--font-size-lg)}.race-container__go-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:var(--font-size-3xl);font-weight:900;color:var(--color-gold);text-shadow:0 0 30px rgba(255,215,0,.8),0 0 60px rgba(255,215,0,.4);z-index:50;pointer-events:none;opacity:0;letter-spacing:.1em}.track-header{margin-bottom:var(--space-sm);padding-left:52px;padding-right:140px}.track-header__markers{display:flex;justify-content:space-between;margin-bottom:var(--space-xs)}.track-header__label{font-size:var(--font-size-xs);color:var(--color-text-muted);white-space:nowrap}.track-header__label--start,.track-header__label--finish{color:var(--color-text-secondary);font-weight:600}.track-header__tick-line{position:relative;height:8px}.track-header__tick{position:absolute;top:0;width:1px;height:100%;background:var(--color-border-light);transform:translate(-50%)}.race-lane{display:flex;align-items:center;height:var(--lane-height);background:var(--color-surface);border-radius:var(--radius-md);border:1px solid var(--color-border);padding:0 var(--space-md);gap:var(--space-md);transition:border-color .3s;position:relative;overflow:visible}.race-lane:hover{border-color:var(--color-border-light)}.race-lane--rank-1{border-color:#ffd7004d;background:linear-gradient(135deg,rgba(255,215,0,.06) 0%,var(--color-surface) 60%);box-shadow:inset 0 0 30px #ffd7000a}.race-lane--rank-2{border-color:#c0c0c033}.race-lane--rank-3{border-color:#cd7f3233}.race-lane__rank{font-size:var(--font-size-lg);min-width:36px;text-align:center;flex-shrink:0}.race-lane__track{flex:1;position:relative;height:36px;background:#0000004d;border-radius:var(--radius-sm);overflow:visible}.race-lane__bar{position:absolute;left:0;top:0;height:100%;background:var(--color-bar-gradient);border-radius:var(--radius-sm);opacity:.6;transition:width .1s;min-width:2px}.race-lane--rank-1 .race-lane__bar{background:linear-gradient(90deg,gold,orange);opacity:.7}.race-lane__marker{position:absolute;top:0;width:1px;height:100%;background:#ffffff1a;z-index:1;pointer-events:none}.race-lane__character-wrapper{position:absolute;top:50%;transform:translateY(-50%) translate(-50%);z-index:10}.race-lane__info{display:flex;flex-direction:column;align-items:flex-end;min-width:120px;flex-shrink:0;gap:2px}.race-lane__name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:120px}.race-lane__score{font-size:var(--font-size-xs);color:var(--color-bar-start);font-weight:700;font-variant-numeric:tabular-nums}.race-lane--rank-1 .race-lane__score{color:var(--color-gold)}.animated-character{position:relative;width:44px;height:52px;cursor:pointer;display:flex;flex-direction:column;align-items:center;-webkit-user-select:none;user-select:none;transition:transform .2s}.animated-character:hover{transform:scale(1.15) translateY(-2px)}.animated-character:active{transform:scale(1.05)}.animated-character--sprint{filter:drop-shadow(0 0 8px rgba(255,215,0,.7))}.char-body{position:relative;width:28px;height:34px;flex-shrink:0}.char-body__torso{position:absolute;left:50%;top:0;transform:translate(-50%);width:6px;height:16px;background:var(--color-text-primary);border-radius:3px}.char-body__arm{position:absolute;top:2px;width:10px;height:4px;background:var(--color-text-primary);border-radius:2px;transform-origin:left center}.char-body__arm--left{left:3px;transform-origin:right center}.char-body__arm--right{right:3px;transform-origin:left center}.char-body__leg{position:absolute;bottom:0;width:5px;height:16px;background:var(--color-text-primary);border-radius:2px;transform-origin:top center}.char-body__leg--left{left:7px}.char-body__leg--right{right:7px}@keyframes sprint-leg-left{0%,to{transform:rotate(-35deg)}50%{transform:rotate(35deg)}}@keyframes sprint-leg-right{0%,to{transform:rotate(35deg)}50%{transform:rotate(-35deg)}}@keyframes sprint-arm-left{0%,to{transform:rotate(40deg)}50%{transform:rotate(-40deg)}}@keyframes sprint-arm-right{0%,to{transform:rotate(-40deg)}50%{transform:rotate(40deg)}}@keyframes sprint-torso{0%,to{transform:translate(-50%) rotate(-5deg)}50%{transform:translate(-50%) rotate(5deg)}}@keyframes sprint-bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-3px)}}.char-body--sprint{animation:sprint-bounce .16s infinite linear}.char-body--sprint .char-body__torso{animation:sprint-torso .16s infinite linear}.char-body--sprint .char-body__leg--left{animation:sprint-leg-left .16s infinite linear}.char-body--sprint .char-body__leg--right{animation:sprint-leg-right .16s infinite linear}.char-body--sprint .char-body__arm--left{animation:sprint-arm-left .16s infinite linear}.char-body--sprint .char-body__arm--right{animation:sprint-arm-right .16s infinite linear}@keyframes run-leg-left{0%,to{transform:rotate(-28deg)}50%{transform:rotate(28deg)}}@keyframes run-leg-right{0%,to{transform:rotate(28deg)}50%{transform:rotate(-28deg)}}@keyframes run-arm-left{0%,to{transform:rotate(30deg)}50%{transform:rotate(-30deg)}}@keyframes run-arm-right{0%,to{transform:rotate(-30deg)}50%{transform:rotate(30deg)}}.char-body--confident .char-body__leg--left{animation:run-leg-left .2s infinite linear}.char-body--confident .char-body__leg--right{animation:run-leg-right .2s infinite linear}.char-body--confident .char-body__arm--left{animation:run-arm-left .2s infinite linear}.char-body--confident .char-body__arm--right{animation:run-arm-right .2s infinite linear}@keyframes jog-leg-left{0%,to{transform:rotate(-20deg)}50%{transform:rotate(20deg)}}@keyframes jog-leg-right{0%,to{transform:rotate(20deg)}50%{transform:rotate(-20deg)}}@keyframes jog-arm-left{0%,to{transform:rotate(20deg)}50%{transform:rotate(-20deg)}}@keyframes jog-arm-right{0%,to{transform:rotate(-20deg)}50%{transform:rotate(20deg)}}.char-body--jog .char-body__leg--left{animation:jog-leg-left .26s infinite linear}.char-body--jog .char-body__leg--right{animation:jog-leg-right .26s infinite linear}.char-body--jog .char-body__arm--left{animation:jog-arm-left .26s infinite linear}.char-body--jog .char-body__arm--right{animation:jog-arm-right .26s infinite linear}@keyframes crawl-leg-left{0%,to{transform:rotate(-10deg)}50%{transform:rotate(10deg)}}@keyframes crawl-leg-right{0%,to{transform:rotate(10deg)}50%{transform:rotate(-10deg)}}@keyframes crawl-arm-left{0%,to{transform:rotate(8deg)}50%{transform:rotate(-8deg)}}@keyframes crawl-arm-right{0%,to{transform:rotate(-8deg)}50%{transform:rotate(8deg)}}@keyframes crawl-droop{0%,to{transform:translate(-50%) rotate(3deg)}50%{transform:translate(-50%) rotate(-3deg)}}.char-body--crawl{opacity:.85}.char-body--crawl .char-body__torso{animation:crawl-droop .4s infinite linear}.char-body--crawl .char-body__leg--left{animation:crawl-leg-left .4s infinite linear}.char-body--crawl .char-body__leg--right{animation:crawl-leg-right .4s infinite linear}.char-body--crawl .char-body__arm--left{animation:crawl-arm-left .4s infinite linear}.char-body--crawl .char-body__arm--right{animation:crawl-arm-right .4s infinite linear}.char-face{position:absolute;top:-16px;left:50%;transform:translate(-50%);width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0;border:2px solid rgba(255,255,255,.3);background:var(--color-surface)}.char-face--emoji{font-size:18px;line-height:1;border:none;background:transparent}.char-face--photo{border-color:#ffffff80}.char-face__img{width:100%;height:100%;object-fit:cover;border-radius:50%;display:block}.char-effects{position:absolute;top:-12px;right:-12px;bottom:-12px;left:-12px;pointer-events:none;z-index:20}.char-effects__glow{position:absolute;top:-4px;right:-4px;bottom:-4px;left:-4px;border-radius:50%;box-shadow:0 0 20px var(--glow-color, transparent);opacity:.5;animation:glow-pulse 1.5s ease-in-out infinite}@keyframes glow-pulse{0%,to{opacity:.4;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}}.char-effects__sparkles{position:absolute;top:-16px;left:50%;transform:translate(-50%);display:flex;gap:2px}.char-effects__sparkle{font-size:10px;animation:sparkle-float 1s ease-in-out infinite;display:inline-block}@keyframes sparkle-float{0%,to{transform:translateY(0) scale(1);opacity:1}50%{transform:translateY(-6px) scale(1.2);opacity:.7}}.char-effects__sweat{position:absolute;top:-8px;right:-12px;display:flex;flex-direction:column;gap:1px}.char-effects__drop{font-size:9px;animation:sweat-drop .8s ease-in infinite;display:inline-block}@keyframes sweat-drop{0%{transform:translateY(0);opacity:1}80%{opacity:.5}to{transform:translateY(10px);opacity:0}}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:var(--space-md);animation:fade-in .2s ease}@keyframes fade-in{0%{opacity:0}to{opacity:1}}.modal{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-lg);width:100%;max-width:440px;box-shadow:var(--shadow-card);animation:modal-slide-in .25s ease;overflow:hidden}@keyframes modal-slide-in{0%{opacity:0;transform:translateY(20px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.modal__header{display:flex;flex-direction:column;gap:4px;padding:var(--space-lg);border-bottom:1px solid var(--color-border);position:relative}.modal__title{font-size:var(--font-size-lg);font-weight:700}.modal__subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.modal__close{position:absolute;top:var(--space-md);right:var(--space-md);background:none;border:none;color:var(--color-text-secondary);font-size:var(--font-size-lg);cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);transition:background .2s,color .2s}.modal__close:hover{background:var(--color-surface-light);color:var(--color-text-primary)}.modal__body{padding:var(--space-lg)}.modal__footer{display:flex;gap:var(--space-md);padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);justify-content:flex-end}.modal__btn{padding:var(--space-sm) var(--space-lg);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all .2s;border:1px solid transparent}.modal__btn--secondary{background:var(--color-surface-light);border-color:var(--color-border-light);color:var(--color-text-primary)}.modal__btn--secondary:hover:not(:disabled){background:#ffffff1a}.modal__btn--primary{background:linear-gradient(135deg,var(--color-bar-start),var(--color-bar-end));color:#000;font-weight:700}.modal__btn--primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #00d4aa66}.modal__btn:disabled{opacity:.4;cursor:not-allowed}.modal__error{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:#ff50501f;border:1px solid rgba(255,80,80,.3);border-radius:var(--radius-sm);color:#ff8080;font-size:var(--font-size-sm)}.modal__success{margin-top:var(--space-md);padding:var(--space-sm) var(--space-md);background:#00d4aa1f;border:1px solid rgba(0,212,170,.3);border-radius:var(--radius-sm);color:var(--color-bar-start);font-size:var(--font-size-sm)}.image-cropper__dropzone{border:2px dashed var(--color-border-light);border-radius:var(--radius-lg);padding:var(--space-xl);text-align:center;cursor:pointer;transition:border-color .2s,background .2s;min-height:160px;display:flex;align-items:center;justify-content:center}.image-cropper__dropzone:hover,.image-cropper__dropzone--active{border-color:var(--color-bar-start);background:#00d4aa0d}.image-cropper__placeholder{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);color:var(--color-text-secondary)}.image-cropper__icon{font-size:40px}.image-cropper__limit{font-size:var(--font-size-xs);color:var(--color-text-muted)}.image-cropper__preview-wrap{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm)}.image-cropper__preview{width:100px;height:100px;border-radius:50%;object-fit:cover;border:3px solid var(--color-bar-start);box-shadow:0 0 20px #00d4aa66}.image-cropper__hint{font-size:var(--font-size-xs);color:var(--color-text-muted)}.image-cropper__input{display:none}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--space-lg);color:var(--color-text-secondary)}.loading-spinner{width:48px;height:48px;border:4px solid var(--color-border-light);border-top-color:var(--color-bar-start);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:var(--space-md);color:var(--color-text-secondary);text-align:center;padding:var(--space-xl)}.error-container__icon{font-size:48px}.error-container__msg{color:#ff8080;font-size:var(--font-size-md)}.error-container__retry{padding:var(--space-sm) var(--space-xl);background:var(--color-surface-light);border:1px solid var(--color-border-light);border-radius:var(--radius-md);color:var(--color-text-primary);font-family:var(--font-family);font-size:var(--font-size-sm);cursor:pointer;transition:background .2s}.error-container__retry:hover{background:#ffffff1a}@media (max-width: 768px){.app-header{padding:var(--space-sm) var(--space-md);flex-wrap:wrap;gap:var(--space-sm);min-height:auto}.app-header__title h1{font-size:var(--font-size-md)}.app-header__controls{gap:var(--space-sm)}.app-header__date{display:none}.week-dropdown__trigger{min-width:160px;font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm)}.app__main{padding:var(--space-sm)}.track-header{padding-left:36px;padding-right:90px}.track-header__label{font-size:9px}.race-lane{height:var(--lane-height-mobile);padding:0 var(--space-sm);gap:var(--space-sm)}.race-lane__rank{font-size:var(--font-size-md);min-width:28px}.race-lane__track{height:28px}.race-lane__info{min-width:80px}.race-lane__name{font-size:var(--font-size-xs);max-width:80px}.race-lane__score{font-size:10px}.animated-character{width:32px;height:40px}.char-body{width:22px;height:26px}.char-body__torso{width:5px;height:12px}.char-body__leg{height:12px;width:4px}.char-face{width:22px;height:22px;top:-12px}.char-face--emoji{font-size:14px}.stats-footer{padding:var(--space-sm) var(--space-md);gap:var(--space-md);font-size:var(--font-size-xs)}.stats-footer__divider{display:none}.stats-footer__item--mvp{width:100%;justify-content:center}}@media (max-width: 480px){.app-header__title h1{font-size:var(--font-size-sm)}.app-header__flag{font-size:var(--font-size-md)}.race-container__go-text{font-size:var(--font-size-2xl)}}
