:root{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}button{font-family:inherit}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:#0000001a}::-webkit-scrollbar-thumb{background:#0000004d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00000080}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);padding:20px}.login-card{background:#fffffff2;border-radius:20px;padding:40px;width:100%;max-width:400px;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:30px}.login-header h1{font-size:2rem;color:#1a1a2e;margin-bottom:8px}.login-header p{color:#666;font-size:1rem}.login-form{display:flex;flex-direction:column;gap:20px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-weight:600;color:#333;font-size:.9rem}.form-group input,.form-group select{padding:12px 16px;border:2px solid #e0e0e0;border-radius:10px;font-size:1rem;transition:border-color .3s,box-shadow .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.login-button{background:linear-gradient(135deg,#0f3460,#16213e);color:#fff;border:none;padding:14px 24px;border-radius:10px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:transform .2s,box-shadow .2s;margin-top:10px}.login-button:hover{transform:translateY(-2px);box-shadow:0 10px 30px #0f34604d}.login-button:active{transform:translateY(0)}.player{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;z-index:10;cursor:pointer}.player-circle{width:50px;height:50px;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 15px #0000004d;border:3px solid rgba(255,255,255,.9);transition:transform .2s,box-shadow .2s}.player:hover .player-circle{transform:scale(1.1);box-shadow:0 6px 20px #0006}.player-abbrev{font-weight:700;font-size:.85rem;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.5)}.player-name{margin-top:4px;font-size:.7rem;font-weight:600;color:#333;background:#ffffffe6;padding:2px 8px;border-radius:10px;white-space:nowrap;max-width:80px;overflow:hidden;text-overflow:ellipsis}.player.highlighted .player-circle{animation:pulse 1.5s infinite;box-shadow:0 0 0 0 var(--player-color)}@keyframes pulse{0%{box-shadow:0 0 0 0 var(--player-color)}70%{box-shadow:0 0 0 15px #fff0}to{box-shadow:0 0 #fff0}}.player.current-user .player-circle{border-color:gold;border-width:4px}.you-indicator{position:absolute;top:-20px;background:gold;color:#333;font-size:.6rem;font-weight:700;padding:2px 6px;border-radius:4px;animation:bounce 1s infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}@media(max-width:600px){.player-circle{width:40px;height:40px}.player-abbrev{font-size:.7rem}.player-name{font-size:.6rem;max-width:60px}}.court-container{display:flex;justify-content:center;align-items:center;padding:20px}.court{position:relative;width:100%;max-width:500px;aspect-ratio:9 / 22;background:linear-gradient(180deg,#4a7c3f,#3d6834 75%,#2d4a26 75% 100%);border:4px solid white;border-radius:4px;box-shadow:0 10px 40px #0000004d;overflow:visible}.net{position:absolute;top:0;left:-10px;right:-10px;height:8px;background:repeating-linear-gradient(90deg,#fff 0px,#fff 8px,transparent 8px,transparent 16px);z-index:5;display:flex;align-items:center;justify-content:center}.net span{background:#333;color:#fff;font-size:.6rem;font-weight:700;padding:2px 8px;border-radius:4px;position:absolute;top:-20px}.court-lines{position:absolute;inset:0;pointer-events:none}.attack-line{position:absolute;top:37.5%;left:0;right:0;height:3px;background:#fff;opacity:.8}.end-line{position:absolute;top:75%;left:0;right:0;height:3px;background:#fff;opacity:.8}.center-line-vertical{position:absolute;top:0;bottom:0;left:50%;width:2px;background:#ffffff4d;transform:translate(-50%)}.position-marker{position:absolute;width:24px;height:24px;border-radius:50%;background:#ffffff26;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;color:#ffffff80}.pos-4{top:12%;left:20%}.pos-3{top:12%;left:50%;transform:translate(-50%)}.pos-2{top:12%;right:20%}.pos-5{top:50%;left:20%}.pos-6{top:50%;left:50%;transform:translate(-50%)}.pos-1{top:50%;right:20%}.service-area{position:absolute;bottom:-35px;left:50%;transform:translate(-50%);background:#0000004d;color:#ffffffb3;font-size:.65rem;padding:4px 12px;border-radius:4px;white-space:nowrap}.court:before{content:"FRONT ROW";position:absolute;top:16%;left:50%;transform:translate(-50%);font-size:.6rem;color:#ffffff4d;font-weight:600;letter-spacing:2px}.court:after{content:"BACK ROW";position:absolute;top:65%;left:50%;transform:translate(-50%);font-size:.6rem;color:#ffffff4d;font-weight:600;letter-spacing:2px}@media(max-width:600px){.court{max-width:320px}.position-marker{width:20px;height:20px;font-size:.6rem}}.settings-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.settings-modal{background:#fff;border-radius:16px;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.settings-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #eee}.settings-header h2{margin:0;font-size:1.3rem;color:#333}.close-btn{width:36px;height:36px;border:none;background:#f0f0f0;border-radius:50%;font-size:1.5rem;cursor:pointer;color:#666;transition:all .2s;display:flex;align-items:center;justify-content:center}.close-btn:hover{background:#e0e0e0;color:#333}.settings-content{padding:20px;overflow-y:auto;flex:1}.settings-description{color:#666;font-size:.9rem;margin:0 0 20px}.player-inputs{display:flex;flex-direction:column;gap:15px}.player-input-group{display:flex;flex-direction:column;gap:6px}.player-input-group label{display:flex;align-items:center;gap:8px;font-size:.9rem;color:#333;font-weight:500}.role-badge{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%;font-size:.7rem;font-weight:700;color:#fff}.player-input-group input{padding:10px 14px;border:2px solid #e0e0e0;border-radius:8px;font-size:1rem;transition:border-color .2s,box-shadow .2s}.player-input-group input:focus{outline:none;border-color:#0f3460;box-shadow:0 0 0 3px #0f34601a}.settings-footer{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;border-top:1px solid #eee;background:#f9f9f9}.footer-right{display:flex;gap:10px}.reset-btn,.cancel-btn,.save-btn{padding:10px 18px;border-radius:8px;font-size:.9rem;cursor:pointer;transition:all .2s}.reset-btn{background:transparent;border:2px solid #ddd;color:#666}.reset-btn:hover{border-color:#ccc;color:#333}.cancel-btn{background:transparent;border:2px solid #ddd;color:#666}.cancel-btn:hover{border-color:#ccc;color:#333}.save-btn{background:linear-gradient(135deg,#0f3460,#16213e);border:none;color:#fff;font-weight:600}.save-btn:hover{transform:translateY(-1px);box-shadow:0 5px 15px #0f34604d}@media(max-width:500px){.settings-footer{flex-direction:column;gap:10px}.footer-right{width:100%}.reset-btn,.cancel-btn,.save-btn{flex:1}}.rotation-viewer{min-height:100vh;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff}.viewer-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:#0000004d;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:sticky;top:0;z-index:100}.header-left h1{font-size:1.3rem;margin:0}.header-right{display:flex;align-items:center;gap:12px}.user-info{display:flex;align-items:center;gap:8px;font-size:.9rem}.user-role{padding:3px 8px;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff}.settings-btn,.logout-btn{padding:8px 14px;border:none;border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .2s}.settings-btn{background:#ffffff1a;color:#fff}.settings-btn:hover{background:#fff3}.logout-btn{background:#ff646433;color:#f99}.logout-btn:hover{background:#ff64644d}.viewer-main{max-width:600px;margin:0 auto;padding:20px}.rotation-info{text-align:center;margin-bottom:20px}.rotation-info h2{font-size:1.8rem;margin:0 0 8px}.rotation-info p{color:#ffffffb3;margin:0}.phase-selector{display:flex;gap:8px;justify-content:center;margin-bottom:10px}.phase-btn{padding:10px 16px;border:2px solid rgba(255,255,255,.2);background:transparent;color:#ffffffb3;border-radius:25px;font-size:.85rem;cursor:pointer;transition:all .3s}.phase-btn:hover{border-color:#fff6;color:#fff}.phase-btn.active{background:#fff;color:#1a1a2e;border-color:#fff;font-weight:600}.phase-description{text-align:center;color:#ffffff80;font-size:.85rem;margin-bottom:20px}.court-wrapper{margin:20px 0}.rotation-controls{display:flex;justify-content:center;align-items:center;gap:15px;margin:30px 0}.nav-btn{padding:12px 20px;background:#ffffff1a;border:2px solid rgba(255,255,255,.2);color:#fff;border-radius:10px;font-size:.9rem;cursor:pointer;transition:all .2s}.nav-btn:hover{background:#fff3;border-color:#fff6}.rotation-dots{display:flex;gap:8px}.rotation-dot{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.3);background:transparent;color:#ffffffb3;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.rotation-dot:hover{border-color:#fff9;color:#fff}.rotation-dot.active{background:#fff;color:#1a1a2e;border-color:#fff}.court-positions-legend{background:#ffffff0d;border-radius:12px;padding:15px;margin-bottom:20px}.court-positions-legend h4{margin:0 0 12px;font-size:.9rem;color:#fffc}.positions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.position-item{display:flex;align-items:center;gap:8px;font-size:.8rem}.pos-number{color:#fff9}.pos-role{padding:3px 8px;border-radius:10px;font-size:.7rem;font-weight:700;color:#fff}.player-legend{background:#ffffff0d;border-radius:12px;padding:15px}.player-legend h4{margin:0 0 12px;font-size:.9rem;color:#fffc}.legend-items{display:flex;flex-wrap:wrap;gap:12px}.legend-item{display:flex;align-items:center;gap:6px}.legend-color{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;color:#fff}.legend-name{font-size:.75rem;color:#ffffffb3}@media(max-width:600px){.viewer-header{flex-direction:column;gap:10px}.header-left h1{font-size:1.1rem}.header-right{flex-wrap:wrap;justify-content:center}.phase-selector{flex-direction:column}.phase-btn{width:100%}.rotation-controls{flex-wrap:wrap}.nav-btn{flex:1;min-width:100px}.rotation-dots{order:-1;width:100%;justify-content:center;margin-bottom:10px}.positions-grid{grid-template-columns:repeat(2,1fr)}}*{box-sizing:border-box}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460);color:#fff;gap:20px}.loading-spinner{width:50px;height:50px;border:4px solid rgba(255,255,255,.2);border-top-color:#fff;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-screen p{font-size:1.1rem;color:#fffc}
