.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0000001a;padding:40px;width:100%;max-width:400px;text-align:center}.login-header h1{color:#333;margin-bottom:10px;font-size:2.5rem}.login-header p{color:#666;margin-bottom:30px;font-size:1.1rem}.login-form{text-align:left}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input[type=email],.form-group input[type=password],.form-group input[type=text]{width:100%;padding:12px 16px;border:2px solid #e1e5e9;border-radius:10px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:-webkit-autofill,.form-group input:-webkit-autofill:hover,.form-group input:-webkit-autofill:focus,.form-group input:-webkit-autofill:active{-webkit-box-shadow:0 0 0 30px white inset!important;-webkit-text-fill-color:#333!important;transition:background-color 5000s ease-in-out 0s}.login-button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease;margin-bottom:20px}.login-button:hover:not(:disabled){transform:translateY(-2px)}.login-button:disabled{opacity:.7;cursor:not-allowed}.toggle-buttons{display:flex;gap:10px;justify-content:center;margin-bottom:15px}.toggle-button{background:none;border:2px solid #667eea;color:#667eea;cursor:pointer;font-size:14px;padding:8px 16px;border-radius:6px;transition:all .3s ease}.toggle-button:hover,.toggle-button.active{background:#667eea;color:#fff}.toggle-button:not(.active){background:none;color:#667eea}.social-login{margin-top:20px}.divider{text-align:center;margin:20px 0;position:relative}.divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:#e1e5e9}.divider span{background:#fff;padding:0 15px;color:#666;font-size:14px}.google-login-button{width:100%;padding:12px;background:#fff;border:2px solid #e1e5e9;border-radius:10px;font-size:16px;font-weight:500;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:10px}.google-login-button:hover:not(:disabled){border-color:#667eea;background:#f8f9ff}.google-login-button:disabled{opacity:.7;cursor:not-allowed}.google-login-button img{width:18px;height:18px}.remember-me{margin-bottom:15px;text-align:center}.remember-me label{display:flex;align-items:center;justify-content:center;gap:8px;font-size:14px;color:#666;cursor:pointer;-webkit-user-select:none;user-select:none}.remember-me input[type=checkbox]{width:16px;height:16px;accent-color:#667eea;cursor:pointer}@media (max-width: 480px){.login-card{padding:30px 20px}.login-header h1{font-size:2rem}}.pm-container{max-width:800px;margin:0 auto;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.6;color:#333}.pm-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e5e5}.pm-back-btn{background:none;border:none;padding:4px 8px;font-size:14px;color:#666;cursor:pointer;transition:color .2s}.pm-back-btn:hover{color:#000}.pm-title{font-size:18px;font-weight:600;margin:0;color:#000}.pm-alert{padding:8px 12px;margin-bottom:16px;font-size:13px;border-radius:4px;border:1px solid}.pm-alert-error{color:#d32f2f;background:#ffebee;border-color:#ffcdd2}.pm-alert-success{color:#2e7d32;background:#e8f5e9;border-color:#c8e6c9}.pm-section{margin-bottom:32px}.pm-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.pm-section-title{font-size:16px;font-weight:600;margin:0;color:#000}.pm-section-actions{display:flex;gap:8px}.pm-form-section{background:#f8f8f8;border:1px solid #e5e5e5;border-radius:4px;padding:16px;margin-bottom:24px}.pm-form-title{font-size:14px;font-weight:600;margin:0 0 16px;color:#000}.pm-form{display:flex;flex-direction:column;gap:16px}.pm-form-row{display:grid;grid-template-columns:1fr 1fr;gap:12px}.pm-form-group{display:flex;flex-direction:column;gap:4px}.pm-form-group label{font-size:12px;font-weight:500;color:#666}.pm-input,.pm-select{padding:6px 8px;border:1px solid #d0d0d0;border-radius:3px;font-size:14px;font-family:inherit;background:#fff;transition:border-color .2s}.pm-input:focus,.pm-select:focus{outline:none;border-color:#666}.pm-form-actions{display:flex;justify-content:flex-end;gap:8px;margin-top:8px}.pm-btn{padding:6px 12px;border:1px solid;border-radius:3px;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit;background:#fff}.pm-btn-primary{background:#000;color:#fff;border-color:#000}.pm-btn-primary:hover{background:#333;border-color:#333}.pm-btn-ghost{background:transparent;color:#666;border-color:#d0d0d0}.pm-btn-ghost:hover{background:#f8f8f8;color:#000;border-color:#999}.pm-btn-danger{background:#fff;color:#d32f2f;border-color:#d32f2f}.pm-btn-danger:hover{background:#ffebee}.pm-btn-sm{padding:4px 8px;font-size:12px}.pm-btn:disabled{opacity:.5;cursor:not-allowed}.pm-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -16px;padding:0 16px}.pm-table{width:100%;border-collapse:collapse;font-size:13px}.pm-th{text-align:left;padding:8px 4px;font-weight:600;color:#666;border-bottom:2px solid #e5e5e5;white-space:nowrap}.pm-th-center{text-align:center}.pm-th-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.pm-th-sortable:hover{color:#000}.pm-td{padding:8px 4px;border-bottom:1px solid #f0f0f0;vertical-align:middle}.pm-td-center{text-align:center}.pm-tr{transition:background-color .1s}.pm-tr:hover{background:#fafafa}.pm-tr-inactive{opacity:.5}.pm-tr-expanded{background:#f8f8f8}.pm-td-expanded{padding:0;border-bottom:1px solid #e5e5e5}.pm-player-name{font-weight:500;color:#000}.pm-player-number{font-weight:600;color:#1976d2}.pm-position-badge{font-size:11px;font-weight:600;color:#666;text-transform:uppercase}.pm-side-info{font-size:12px;color:#666}.pm-badge{display:inline-block;padding:2px 6px;font-size:11px;font-weight:600;border-radius:2px;text-align:center;min-width:20px}.pm-badge-primary{background:#e3f2fd;color:#1976d2}.pm-badge-secondary{background:#f5f5f5;color:#666}.pm-status{font-size:10px}.pm-status-active{color:#4caf50}.pm-status-inactive{color:#999}.pm-action-btn{background:none;border:1px solid #d0d0d0;width:24px;height:24px;border-radius:3px;cursor:pointer;font-size:14px;color:#666;transition:all .2s;display:inline-flex;align-items:center;justify-content:center}.pm-action-btn:hover{background:#f8f8f8;border-color:#999;color:#000}.pm-action-dots{font-size:18px;font-weight:700}.pm-expanded-content{padding:8px}.pm-detail-view{padding:4px 0}.pm-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:8px;margin-bottom:12px}.pm-detail-item{font-size:13px;color:#333}.pm-detail-item strong{font-weight:600;color:#666;margin-right:4px}.pm-detail-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid #e0e0e0}.pm-inline-form{padding:8px}.pm-inline-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:8px;margin-bottom:12px}@media (min-width: 600px){.pm-inline-grid{grid-template-columns:repeat(3,1fr);gap:12px}}@media (min-width: 900px){.pm-inline-grid{grid-template-columns:repeat(4,1fr)}}.pm-inline-group{display:flex;flex-direction:column;gap:4px}.pm-inline-group label{font-size:11px;font-weight:500;color:#666}.pm-input-sm,.pm-select-sm{padding:2px 6px;font-size:11px;border:1px solid #d0d0d0;border-radius:3px;height:26px;background:#fff}.pm-inline-actions{display:flex;justify-content:space-between;align-items:center;padding-top:8px;border-top:1px solid #e5e5e5}.pm-inline-actions>div{display:flex;gap:8px}.pm-switch{position:relative;display:inline-block;width:36px;height:20px}.pm-switch input{opacity:0;width:0;height:0}.pm-switch-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:#ccc;transition:.2s;border-radius:20px}.pm-switch-slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;transition:.2s;border-radius:50%}.pm-switch input:checked+.pm-switch-slider{background-color:#4caf50}.pm-switch input:checked+.pm-switch-slider:before{transform:translate(16px)}.pm-empty{text-align:center;padding:48px 16px;color:#999;font-size:14px}@media (max-width: 640px){.pm-container{padding:12px}.pm-header{margin-bottom:16px;padding-bottom:12px}.pm-title{font-size:16px}.pm-section-header{flex-direction:column;align-items:flex-start;gap:8px}.pm-section-actions{width:100%;justify-content:flex-end}.pm-form-row{grid-template-columns:1fr;gap:12px}.pm-table-container{margin:0 -12px;padding:0 12px}.pm-th,.pm-td{padding:6px 2px;font-size:12px}.pm-th-hide-mobile,.pm-td-hide-mobile{display:none}.pm-inline-actions{flex-direction:column;gap:8px;align-items:stretch}.pm-inline-actions>div{justify-content:flex-end}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:48px;color:#666}.loading-spinner{width:32px;height:32px;border:2px solid #f0f0f0;border-top:2px solid #333;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:16px}.number-keypad-container{position:relative;width:100%}.number-input{width:100%;padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;text-align:center;box-sizing:border-box}.number-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.keypad-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:flex-end;z-index:1000;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.keypad{width:100%;background:#fff;border-radius:16px 16px 0 0;box-shadow:0 -4px 20px #0000001a;animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.keypad-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee}.keypad-header span{font-weight:600;font-size:16px;color:#333}.keypad-close{background:none;border:none;font-size:24px;color:#999;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center}.keypad-display{padding:20px;text-align:center;background:#f8f9fa}.keypad-value{font-size:24px;font-weight:600;color:#333;min-height:30px;display:inline-block}.keypad-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:#eee;padding:1px}.keypad-button{background:#fff;border:none;padding:20px;font-size:20px;font-weight:600;color:#333;cursor:pointer;transition:background-color .2s;min-height:60px;display:flex;align-items:center;justify-content:center}.keypad-button:active{background-color:#e6f3ff}.keypad-button:hover{background-color:#f8f9fa}.keypad-clear{background-color:#ff6b6b!important;color:#fff!important}.keypad-clear:hover{background-color:#ff5252!important}.keypad-clear:active{background-color:#f44336!important}.keypad-backspace{background-color:#ffa726!important;color:#fff!important}.keypad-backspace:hover{background-color:#ff9800!important}.keypad-backspace:active{background-color:#f57c00!important}.keypad-actions{padding:16px 20px;background:#f8f9fa}.keypad-done{width:100%;background:#007bff;color:#fff;border:none;padding:16px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s}.keypad-done:hover{background:#0056b3}.keypad-done:active{background:#004085}@media (min-width: 769px){.keypad-overlay{display:none!important}}.lineup-creator{max-width:800px;margin:0 auto;padding:16px;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:14px;line-height:1.6;color:#333}.lineup-header{display:flex;align-items:center;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #e5e5e5}.back-button{background:none;border:none;padding:4px 8px;font-size:14px;color:#666;cursor:pointer;transition:color .2s}.back-button:hover{color:#000}.lineup-header h2{font-size:18px;font-weight:600;margin:0;color:#000}.error-message{padding:8px 12px;margin-bottom:16px;font-size:13px;border-radius:4px;color:#d32f2f;background:#ffebee;border:1px solid #ffcdd2}.success-message{padding:8px 12px;margin-bottom:16px;font-size:13px;border-radius:4px;color:#2e7d32;background:#e8f5e9;border:1px solid #c8e6c9}.lineup-form{display:flex;flex-direction:column;gap:10px}.lineup-name-section{padding:10px 0;border-bottom:1px solid #e1e5e9}.lineup-name-section label{display:block;margin-bottom:5px;font-weight:600;color:#2c3e50;font-size:14px}.lineup-name-section input{width:100%;padding:8px 12px;border:1px solid #e1e5e9;border-radius:6px;font-size:14px;transition:border-color .2s}.lineup-name-section input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.batting-order-section,.pitcher-section,.bench-section{margin-bottom:32px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h3{font-size:16px;font-weight:600;margin:0;color:#000}.lineup-controls{display:flex;gap:10px}.add-order-btn,.remove-order-btn{padding:8px 16px;border-radius:6px;border:none;font-size:14px;cursor:pointer;transition:all .2s}.add-order-btn{background:#28a745;color:#fff}.add-order-btn:hover:not(:disabled){background:#218838}.remove-order-btn{background:#dc3545;color:#fff}.remove-order-btn:hover:not(:disabled){background:#c82333}.add-order-btn:disabled,.remove-order-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.batting-order-list{display:flex;flex-direction:column;gap:5px;position:relative}.batting-order-item{display:grid;grid-template-columns:1fr .6fr .8fr .8fr 1.8fr;gap:12px;padding:12px 8px;align-items:center;border-bottom:1px solid #f1f3f5;transition:all .2s ease;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.batting-order-item:hover{background:#f8f9fa}.order-container{display:flex;align-items:center;gap:8px;justify-content:center}.drag-handle{font-size:16px;color:#adb5bd;cursor:grab;-webkit-user-select:none;user-select:none;padding:4px;border-radius:4px;transition:background-color .2s}.drag-handle:hover{background-color:#f0f0f0;color:#6c757d}.drag-handle:active{cursor:grabbing}.order-number{font-weight:600;color:#333;font-size:14px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.batting-side{display:flex;align-items:center;justify-content:center;text-align:center;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.batting-display{font-weight:600;color:#333;background:#f8f9fa;padding:4px 6px;border-radius:4px;border:1px solid #e5e5e5;font-size:13px;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.batting-placeholder{color:#999;font-style:italic;user-select:none;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none}.batting-order-item.drag-over-replace{background:linear-gradient(135deg,#e3f2fd,#bbdefb);border:2px solid #2196f3;box-shadow:0 4px 12px #2196f34d;transform:scale(1.02);border-radius:8px;position:relative}.batting-order-item.drag-over-replace:after{content:"⇄ 위치 교환";position:absolute;top:-25px;left:50%;transform:translate(-50%);background:#2196f3;color:#fff;padding:2px 8px;border-radius:12px;font-size:10px;font-weight:600;z-index:11;white-space:nowrap;box-shadow:0 2px 6px #2196f34d;animation:swapBounce .8s infinite alternate}@keyframes swapBounce{0%{transform:translate(-50%) scale(1)}to{transform:translate(-50%) scale(1.05)}}.batting-order-item.drag-over-insert-before:before{content:"▼ 여기에 삽입";position:absolute;left:-12px;right:-12px;top:-16px;height:8px;background:linear-gradient(90deg,#ff5722,#ff9800,#ff5722);border-radius:4px;box-shadow:0 4px 16px #ff572299;z-index:100;animation:insertPulse 1s infinite alternate;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.7)}.batting-order-item.drag-over-insert-after:after{content:"▲ 여기에 삽입";position:absolute;left:-12px;right:-12px;bottom:-16px;height:8px;background:linear-gradient(90deg,#ff5722,#ff9800,#ff5722);border-radius:4px;box-shadow:0 4px 16px #ff572299;z-index:100;animation:insertPulse 1s infinite alternate;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:700;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.7)}@keyframes insertPulse{0%{opacity:.8;transform:scaleY(1)}to{opacity:1;transform:scaleY(1.2)}}.batting-order-item.data-changed{animation:dataChangeGlow 2s ease-out}@keyframes dataChangeGlow{0%{background:linear-gradient(135deg,#e8f5e8,#c8e6c8);box-shadow:0 0 20px #4caf5066;transform:scale(1.02)}50%{background:linear-gradient(135deg,#a5d6a7,#81c784);box-shadow:0 0 30px #4caf5099;transform:scale(1.03)}to{background:transparent;box-shadow:none;transform:scale(1)}}.batting-order-list:before{content:"1번 타순으로 이동";position:absolute;top:-12px;left:-8px;right:-8px;height:8px;background:linear-gradient(90deg,#4caf50,#8bc34a,#4caf50);border-radius:4px;box-shadow:0 3px 12px #4caf5066;opacity:0;transition:all .3s ease;z-index:10;display:flex;align-items:center;justify-content:center;font-size:11px;font-weight:600;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5);animation:topInsertPulse 1.2s infinite alternate}.batting-order-list.drag-over-top:before{opacity:1;top:-16px}@keyframes topInsertPulse{0%{box-shadow:0 3px 12px #4caf5066;transform:scale(1)}to{box-shadow:0 6px 20px #4caf5099;transform:scale(1.02)}}.batting-order-item.touch-dragging{background:linear-gradient(135deg,#fff3cd,#ffe082);border:2px solid #ffc107;transition:none!important;pointer-events:none;position:relative;box-shadow:0 8px 25px #ffc10766;border-radius:8px}.batting-order-item.touch-dragging:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:#0000001a;border:2px dashed #ccc;border-radius:4px;z-index:-1}body.touch-dragging{overflow:hidden!important;touch-action:none;user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}.batting-order-list.dragging{user-select:none!important;-webkit-user-select:none!important;-moz-user-select:none!important;-ms-user-select:none!important}.batting-order-item[draggable=true]{opacity:1}.batting-order-item[draggable=true]:active{opacity:.5}.player-search-container{position:relative;display:flex;align-items:center}.player-name-input{flex:1;padding:6px;border:1px solid #ced4da;border-radius:4px;font-size:12px;transition:border-color .2s;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.player-name-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.player-name-input[readonly]{background:#e9ecef;cursor:default}.clear-player-btn{position:absolute;right:8px;background:#dc3545;color:#fff;border:none;border-radius:50%;width:20px;height:20px;font-size:12px;cursor:pointer;display:flex;align-items:center;justify-content:center}.clear-player-btn:hover{background:#c82333}.player-dropdown{position:absolute;top:100%;left:0;right:0;background:#fff;border:2px solid #007bff;border-top:none;border-radius:0 0 6px 6px;max-height:300px;overflow-y:auto;z-index:1000;box-shadow:0 4px 12px #00000026}.player-option{padding:10px 12px;cursor:pointer;border-bottom:1px solid #e9ecef;transition:background-color .2s}.player-option:hover{background:#f8f9fa}.player-option:last-child{border-bottom:none}.jersey-number-input{padding:6px 8px;border:1px solid #ced4da;border-radius:4px;font-size:13px;text-align:center;transition:border-color .2s;width:100%;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.jersey-number-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.position-select{padding:8px 6px;border:1px solid #ced4da;border-radius:4px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s;width:100%;min-width:80px;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.position-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.lineup-controls{display:flex;justify-content:center;gap:15px;margin-top:20px;padding:15px}.order-number{font-weight:600;color:#495057;min-width:45px;font-size:16px}.player-select{flex:1;padding:10px 12px;border:2px solid #ced4da;border-radius:6px;font-size:14px;background:#fff;cursor:pointer;transition:border-color .2s}.player-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 3px #007bff1a}.selected-player-info{color:#28a745;font-weight:500;font-size:14px;min-width:200px}.pitcher-section{padding:15px 0;border-bottom:1px solid #e1e5e9}.pitcher-section h3{margin:0 0 10px;color:#2c3e50;font-size:18px;font-weight:600}.pitcher-select-container{display:flex;align-items:center;gap:20px}.pitcher-order-item{display:grid;grid-template-columns:40px 1fr 120px;gap:15px;align-items:center;padding:8px 5px;border-bottom:1px solid #f1f3f5;margin-bottom:5px}.pitcher-position{background:#ff6b35;color:#fff;border-radius:6px;padding:8px 0;text-align:center;font-weight:600;font-size:14px}.pitcher-note{padding:12px;background:#f8f9fa;border-left:4px solid #007bff;border-radius:4px;font-size:13px;color:#495057;line-height:1.4}.bench-section{padding:15px 0;border-bottom:1px solid #e1e5e9}.bench-actions{display:flex;gap:10px}.add-bench-btn{background:#17a2b8;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.add-bench-btn:hover{background:#138496}.auto-fill-btn{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.auto-fill-btn:hover{background:#5a6268}.clear-all-btn{background:#dc3545;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:14px;transition:background-color .2s}.clear-all-btn:hover{background:#c82333}.bench-players-list{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-top:10px}.no-bench-players{grid-column:1 / -1;text-align:center;color:#6c757d;padding:20px;font-size:14px}.bench-player-item{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid #e0e0e0;border-radius:6px;background:#f8f9fa;transition:all .2s;min-height:40px;font-size:13px}.bench-player-item:hover{background:#f0f0f0;border-color:#ccc}.bench-player-info{display:flex;align-items:center;gap:4px;font-size:13px;flex:1;overflow:hidden}.bench-player-name{font-weight:500;color:#333;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex:1}.bench-player-separator{color:#999;flex-shrink:0}.bench-player-number{color:#666;flex-shrink:0}.remove-bench-btn{background:none;color:#dc3545;border:none;width:20px;height:20px;font-size:16px;font-weight:700;line-height:1;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;flex-shrink:0}.remove-bench-btn:hover{background:#ffebee;border-radius:4px}.save-section{display:flex;justify-content:center;padding:15px 0}.save-lineup-btn{background:#333;color:#fff;border:none;padding:8px 16px;border-radius:4px;cursor:pointer;font-size:14px;font-weight:500;transition:background-color .2s}.save-lineup-btn:hover{background:#000}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:400px;gap:20px}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{color:#6c757d;font-size:16px}@media (max-width: 768px){.lineup-creator{padding:15px}.lineup-header,.section-header{flex-direction:column;align-items:flex-start;gap:15px}.batting-order-item{grid-template-columns:35px .6fr .8fr .8fr 1.8fr;gap:2px;padding:6px 3px;text-align:left;position:relative}.drag-handle{display:none}.order-number{font-size:12px;font-weight:700;margin-bottom:0}.player-search-container{min-width:0}.jersey-number-input{width:100%;padding:4px 2px;font-size:12px}.position-select{width:100%;padding:4px 3px;font-size:12px;min-width:60px}.player-name-input{font-size:12px;padding:4px 6px}.bench-player-item{padding:6px 8px;font-size:11px}.bench-player-info{font-size:11px;gap:4px}.bench-player-number{font-size:10px}.pitcher-order-item{grid-template-columns:40px 1fr 100px;gap:10px;padding:12px}.pitcher-position{font-size:12px;padding:6px 0}.player-select{width:100%}.selected-player-info{min-width:auto;margin-top:5px}.lineup-controls{flex-direction:column;gap:10px}.add-order-btn,.remove-order-btn{width:100%}}.lineup-viewer{max-width:1200px;margin:0 auto;padding:20px}.lineup-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;padding-bottom:15px;border-bottom:2px solid #e9ecef}.lineup-actions{display:flex;gap:10px}.lineup-header h2{margin:0;color:#2c3e50;font-size:1.8rem}.back-button{background:#6c757d;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s}.delete-button{background:#dc3545;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s}.delete-button:hover{background:#c82333}.edit-button{background:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:8px;cursor:pointer;font-size:1rem;transition:background-color .2s}.edit-button:hover{background:#218838}.error-message{background:#f8d7da;color:#721c24;padding:15px;border-radius:8px;margin-bottom:20px;border:1px solid #f5c6cb}.lineups-list{margin-top:20px}.no-lineups{text-align:center;padding:60px 20px;background:#f8f9fa;border-radius:12px;color:#6c757d}.no-lineups p{margin:10px 0;font-size:1.1rem}.lineups-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px;margin-top:20px}.lineup-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;padding:20px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.lineup-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.lineup-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.lineup-card-header h3{margin:0;color:#2c3e50;font-size:1.3rem}.player-count{background:#007bff;color:#fff;padding:4px 8px;border-radius:4px;font-size:.85rem;font-weight:700}.lineup-card-info{margin-bottom:15px;color:#6c757d}.lineup-card-actions{display:flex;gap:10px}.view-button{flex:1;background:#007bff;color:#fff;border:none;padding:10px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s}.view-button:hover{background:#0056b3}.lineup-card-actions .delete-button{flex:0 0 auto;padding:10px 15px;font-size:.9rem}.lineup-detail{background:#fff;border-radius:12px;padding:25px;box-shadow:0 2px 8px #0000001a}.lineup-info{background:#f8f9fa;padding:15px;border-radius:8px;margin-bottom:25px}.lineup-info p{margin:5px 0;color:#495057}.batting-order-section h3,.pitcher-section h3,.bench-section h3{color:#2c3e50;margin-bottom:15px;font-size:1.4rem}.batting-order-list{display:flex;flex-direction:column;gap:10px;margin-bottom:30px}.batting-order-item{display:grid;grid-template-columns:60px 1fr 80px 100px 60px 60px;gap:15px;align-items:center;background:#f8f9fa;padding:12px 15px;border-radius:8px;border-left:4px solid #007bff}.order-number{font-weight:700;color:#007bff;font-size:1.1rem}.player-name{font-weight:600;color:#2c3e50;font-size:1.1rem}.jersey-number{background:#007bff;color:#fff;padding:4px 8px;border-radius:4px;text-align:center;font-weight:700;font-size:.9rem}.position{background:#28a745;color:#fff;padding:4px 8px;border-radius:4px;text-align:center;font-weight:500;font-size:.9rem}.batting-side,.throwing-side{background:#6c757d;color:#fff;padding:4px 6px;border-radius:4px;text-align:center;font-size:.8rem;font-weight:500}.pitcher-section{margin-bottom:30px}.pitcher-info{display:grid;grid-template-columns:1fr 80px 60px 60px;gap:15px;align-items:center;background:#fff3cd;padding:15px;border-radius:8px;border-left:4px solid #ffc107}.bench-section{margin-bottom:20px}.bench-players-list{display:flex;flex-direction:column;gap:8px}.bench-player-item{display:grid;grid-template-columns:1fr 80px 60px 60px;gap:15px;align-items:center;background:#f1f3f4;padding:10px 15px;border-radius:6px;border-left:3px solid #6c757d}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid #f3f3f3;border-top:4px solid #007bff;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:20px}@media (max-width: 768px){.lineup-viewer{padding:15px}.lineup-header{flex-direction:column;gap:15px;text-align:center}.lineup-header h2{font-size:1.5rem}.lineups-grid{grid-template-columns:1fr;gap:15px}.batting-order-item{grid-template-columns:40px 1fr 60px 70px 45px 45px;gap:5px;padding:8px 10px;font-size:.85rem}.pitcher-info{grid-template-columns:1fr 70px 50px 50px;gap:10px}.bench-player-item{grid-template-columns:1fr 70px 50px 50px;gap:8px;font-size:.9rem}}@media (max-width: 480px){.batting-order-item{grid-template-columns:35px 1fr 45px 55px 35px 35px;gap:3px;padding:6px;font-size:.75rem}.order-number{font-size:.8rem}.player-name{font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.jersey-number,.position{font-size:.75rem}.throwing-batting,.birthdate{font-size:.7rem}.pitcher-info,.bench-player-item{grid-template-columns:1fr 45px 35px 35px;gap:4px;font-size:.75rem}.lineup-card-actions{flex-direction:row;gap:5px}.lineup-card-actions button{font-size:.75rem;padding:4px 8px}}.dashboard-container{min-height:100vh;background:#f8f9fa}.dashboard-header{background:#fff;box-shadow:0 2px 10px #0000001a;padding:1rem 0}.header-content{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1200px;margin:0 auto;padding:0 20px}@media (max-width: 768px){.header-content{padding:0 10px;flex-direction:column;gap:15px}.header-content h1{font-size:1.5rem;text-align:center}.header-left{order:2}}.header-left{display:flex;align-items:center;gap:10px}.home-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease}.home-button:hover{background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-2px)}.header-content h1{color:#333;margin:0;font-size:1.8rem}.user-info{display:flex;align-items:center;gap:1rem}.user-info span{color:#666;font-size:.9rem}.back-button{background:#6c757d;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s ease}.back-button:hover{background:#5a6268}.dashboard-main{max-width:1200px;margin:0 auto;padding:2rem;width:100%}.welcome-section{text-align:center;margin-bottom:3rem}.welcome-section h2{color:#333;margin-bottom:.5rem;font-size:2rem}.welcome-section p{color:#666;font-size:1.1rem}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:2rem}@media (max-width: 768px){.dashboard-main{padding:1rem}.welcome-section h2{font-size:1.5rem}.welcome-section p{font-size:1rem}.feature-grid{grid-template-columns:1fr;gap:1rem}}.feature-card{background:#fff;border-radius:15px;padding:2rem;text-align:center;box-shadow:0 5px 15px #00000014;transition:transform .2s ease,box-shadow .2s ease}.feature-card:hover{transform:translateY(-5px)}@media (max-width: 768px){.feature-card{padding:1.5rem;border-radius:12px}.feature-card:hover{transform:none}}box-shadow: 0 10px 25px rgba(0,0,0,.12); } .feature-icon{font-size:3rem;margin-bottom:1rem}.feature-card h3{color:#333;margin-bottom:.5rem;font-size:1.3rem}.feature-card p{color:#666;margin-bottom:1.5rem;line-height:1.5}.feature-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;cursor:pointer;font-weight:500;transition:transform .2s ease}.feature-button:hover{transform:translateY(-2px)}.admin-card{border:3px solid #e74c3c;background:linear-gradient(135deg,#fff5f5,#fef2f2);position:relative}.admin-card:before{content:"🔐 관리자 전용";position:absolute;top:-10px;left:50%;transform:translate(-50%);background:#e74c3c;color:#fff;padding:4px 12px;border-radius:12px;font-size:.8rem;font-weight:700}.admin-button{background:linear-gradient(135deg,#e74c3c,#c0392b)!important;border:2px solid #c0392b}.admin-button:hover{background:linear-gradient(135deg,#c0392b,#a93226)!important;transform:translateY(-3px);box-shadow:0 8px 20px #e74c3c4d}.success-message{color:#27ae60;background:#f0f9f0;border:1px solid #27ae60;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.team-form-container{background:#fff;border-radius:12px;padding:30px;margin-bottom:30px;box-shadow:0 4px 6px #0000001a}.team-form-container h2{color:#333;margin-bottom:20px;font-size:1.5rem}.team-form{display:grid;grid-template-columns:1fr 1fr;gap:20px}.form-group{display:flex;flex-direction:column}.form-group:nth-child(4){grid-column:1 / -1}.form-group label{margin-bottom:8px;color:#333;font-weight:500}.form-group input{padding:12px;border:2px solid #e1e5e9;border-radius:8px;font-size:16px;transition:border-color .3s ease}.form-group input:focus{outline:none;border-color:#667eea}.form-buttons{grid-column:1 / -1;display:flex;gap:15px;margin-top:20px}.submit-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease}.submit-button:hover{transform:translateY(-2px)}.cancel-button{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .3s ease}.cancel-button:hover{background:#5a6268}.teams-section{margin-bottom:40px}.teams-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.teams-header h2{color:#333;margin:0;font-size:1.8rem}.add-team-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease}.add-team-button:hover{transform:translateY(-2px)}.no-teams{text-align:center;padding:60px 20px;color:#666}.no-teams p{margin:10px 0;font-size:16px}.teams-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:20px}.team-card{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000001a;transition:transform .2s ease,box-shadow .2s ease}.team-card:hover{transform:translateY(-4px);box-shadow:0 8px 15px #00000026}.team-info h3{color:#333;margin:0 0 15px;font-size:1.3rem;font-weight:600}.team-info p{margin:8px 0;color:#666;font-size:14px}.team-info strong{color:#333;font-weight:600}.team-actions{display:flex;gap:10px;margin-top:20px;padding-top:15px;border-top:1px solid #e1e5e9;flex-wrap:wrap}.players-button{background:linear-gradient(135deg,#27ae60,#2ecc71);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;flex:1;min-width:120px}.players-button:hover{background:linear-gradient(135deg,#229954,#27ae60);transform:translateY(-2px)}.lineup-button{background:linear-gradient(135deg,#e67e22,#f39c12);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;flex:1;min-width:120px}.lineup-button:hover{background:linear-gradient(135deg,#d35400,#e67e22);transform:translateY(-2px)}.lineup-view-button{background:linear-gradient(135deg,#007bff,#0056b3);color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .3s ease;flex:1;min-width:120px}.lineup-view-button:hover{background:linear-gradient(135deg,#0056b3,#004085);transform:translateY(-2px)}.edit-button{background:#3498db;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s ease}.edit-button:hover{background:#2980b9}.delete-button{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s ease}@media (max-width: 768px){.header-content{padding:0 1rem}.dashboard-main{padding:1rem}.feature-grid{grid-template-columns:1fr;gap:1rem}.feature-card{padding:1.5rem}}.admin-login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#2c3e50,#34495e);padding:20px}.admin-login-card{background:#fff;border-radius:20px;box-shadow:0 20px 40px #0003;padding:40px;width:100%;max-width:400px;text-align:center}.admin-login-header h1{color:#2c3e50;margin-bottom:10px;font-size:2.5rem}.admin-login-header p{color:#7f8c8d;margin-bottom:30px;font-size:1.1rem}.admin-login-form{text-align:left}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#2c3e50;font-weight:500}.form-group input{width:100%;padding:12px 16px;border:2px solid #bdc3c7;border-radius:10px;font-size:16px;transition:border-color .3s ease;box-sizing:border-box}.form-group input:focus{outline:none;border-color:#3498db}.error-message{color:#e74c3c;background:#fdf2f2;padding:12px;border-radius:8px;margin-bottom:20px;font-size:14px}.admin-login-button{width:100%;padding:14px;background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:transform .2s ease;margin-bottom:20px}.admin-login-button:hover:not(:disabled){transform:translateY(-2px)}.admin-login-button:disabled{opacity:.7;cursor:not-allowed}@media (max-width: 480px){.admin-login-card{padding:30px 20px}.admin-login-header h1{font-size:2rem}}.admin-dashboard-container{min-height:100vh;background:#f8f9fa}.admin-dashboard-header{background:#2c3e50;color:#fff;box-shadow:0 2px 10px #0000001a;padding:1rem 0}.header-content{max-width:1200px;margin:0 auto;padding:0 2rem;display:flex;justify-content:space-between;align-items:center}.header-content h1{color:#fff;margin:0;font-size:1.8rem}.admin-info{display:flex;align-items:center;gap:1rem}.admin-info span{color:#bdc3c7;font-size:.9rem}.logout-button{background:#e74c3c;color:#fff;border:none;padding:8px 16px;border-radius:6px;cursor:pointer;font-size:.9rem;transition:background-color .2s ease}.logout-button:hover{background:#c0392b}.admin-dashboard-main{max-width:1200px;margin:0 auto;padding:2rem}.admin-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:2rem;margin-bottom:3rem}.stat-card{background:#fff;border-radius:15px;padding:2rem;text-align:center;box-shadow:0 5px 15px #00000014;transition:transform .2s ease}.stat-card:hover{transform:translateY(-5px)}.stat-icon{font-size:3rem;margin-bottom:1rem}.stat-card h3{color:#2c3e50;margin-bottom:.5rem;font-size:1.1rem}.stat-number{color:#3498db;font-size:2rem;font-weight:700;margin:0}.users-section{background:#fff;border-radius:15px;padding:2rem;box-shadow:0 5px 15px #00000014}.users-section h2{color:#2c3e50;margin-bottom:1.5rem;font-size:1.5rem}.users-table-container{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;margin-top:1rem}.users-table th,.users-table td{padding:12px;text-align:left;border-bottom:1px solid #ecf0f1}.users-table th{background:#f8f9fa;color:#2c3e50;font-weight:600}.users-table tr:hover{background:#f8f9fa}.delete-button{background:#e74c3c;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;font-size:.8rem;transition:background-color .2s ease}.delete-button:hover{background:#c0392b}.error-message{color:#e74c3c;background:#fdf2f2;padding:12px;border-radius:8px;margin-bottom:1rem;font-size:14px}.admin-loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f8f9fa}.loading-spinner{width:40px;height:40px;border:4px solid #e1e5e9;border-top:4px solid #3498db;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@media (max-width: 768px){.header-content{padding:0 1rem}.admin-dashboard-main{padding:1rem}.admin-stats{grid-template-columns:1fr;gap:1rem}.users-table{font-size:.9rem}.users-table th,.users-table td{padding:8px}}*{box-sizing:border-box}body{margin:0;padding:0;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;background-color:#f8f9fa}.App{min-height:100vh;width:100%;max-width:100vw;overflow-x:hidden}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#f8f9fa}.loading-spinner{width:40px;height:40px;border:4px solid #e1e5e9;border-top:4px solid #667eea;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#666;font-size:1rem;margin-bottom:.5rem}.auto-login-info{text-align:center;margin-top:10px}.auto-login-info small{color:#888;font-size:.85rem;display:block}
