:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;min-width:320px;min-height:100vh;width:100%}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}#root{width:100%;display:flex;flex-direction:column}.app-container{width:100%;min-height:100vh;display:flex;flex-direction:column}.main-navigation{width:100%;background-color:#333;padding:1rem;display:flex;gap:1rem}.top-bar{width:100%;background-color:#008116;padding:1rem;display:flex;gap:1rem;height:35px;align-items:center}.top-bar h1,.top-bar p{color:#fff;margin:0;display:flex;flex-direction:row;align-items:center}.nav-link{color:#fff;text-decoration:none;padding:.5rem 1rem;border-radius:4px}.nav-link:hover{background-color:#555}.main-content{flex:1;width:100%;display:flex;justify-content:center}.container{width:100%;padding:20px;margin:0 auto}.logo-container{display:flex;align-items:center}.logo-letter{font-size:3rem;font-weight:800;color:#008116}.logo-text{font-size:1.25rem}.green-button{width:100%;padding:12px;margin-bottom:10px;background-color:#4caf50;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:background-color .2s}.green-button:hover{background-color:#45a049}.blue-button{width:100%;padding:12px;margin-bottom:10px;background-color:#422faa;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:background-color .2s}.blue-button:hover{background-color:#080591}.red-button{width:100%;padding:12px;margin-bottom:10px;background-color:#f44336;color:#fff;border:none;border-radius:4px;font-size:16px;cursor:pointer;transition:background-color .2s}.red-button:hover{background-color:#f11808}.form-group{width:100%;margin-bottom:1rem}.form-group label{display:block;margin-bottom:8px;font-weight:700;color:#333}.form-group input,.form-group select{width:100%;padding:8px;border:1px solid #ddd;border-radius:4px;font-size:16px}.player-list{list-style:none;padding:0}.player-item{display:flex;padding:10px;margin:5px 0;background-color:#f5f5f5;border-radius:4px}.player-info{display:flex;justify-content:space-between;align-items:center;width:100%}.player-actions button{margin-left:10px;padding:5px 10px;border:none;border-radius:4px;cursor:pointer}.edit-form{display:flex;flex-direction:column;gap:10px;width:100%}.edit-form-row{display:flex;gap:10px;align-items:center;width:100%}.edit-form-row select{flex:1}.edit-form input,.edit-form select{padding:5px;border:1px solid #ddd;border-radius:4px}.edit-form button{padding:5px 10px;border:none;border-radius:4px;cursor:pointer}.icon-button{background:none;border:none;cursor:pointer;padding:8px;color:#666;transition:color .2s ease}.icon-button:hover{color:#333}.icon-button.delete{color:#dc3545}.icon-button.save{color:#28a745}.icon-button.cancel{color:#dc3545}.player-actions{display:flex;gap:8px;margin-left:auto}.player-stats{margin:1rem 0}.stats-grid{display:grid;gap:.5rem}.player-stat-entry{display:flex;justify-content:space-between;padding:.5rem;background-color:#f5f5f5;border-radius:4px}.player-stat-name{font-weight:500}.player-stat-time{font-family:monospace}.player-stats-divider{width:100%;margin:1rem 0;display:flex;align-items:center;gap:1rem}.player-stats-divider hr{flex:1;border:none;border-top:1px solid #ccc}.player-stats-divider span{color:#666;font-size:.9rem}.game-container{width:100%;max-width:500px;margin:0 auto;padding:10px;background-color:#fff}.game-controls{display:flex;gap:10px;margin-bottom:10px;align-items:center;justify-content:space-between;border-radius:8px}.formation-select{padding:5px;border-radius:4px;border:1px solid #ccc}.game-button{padding:12px;font-size:1.5rem;width:48px;height:48px;border-radius:50%;border:none;background-color:#f0f0f0;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.game-button:hover{background-color:#e0e0e0}.game-button.goal-button{width:auto;border-radius:24px;padding:12px 24px}.game-time{padding:5px 10px;background-color:#333;color:#fff;border-radius:4px;font-weight:700}.field-container{width:100%;aspect-ratio:2/3;position:relative;border:2px solid #666;border-radius:8px;overflow:hidden}.sport-field{width:100%;height:100%;position:relative}.soccer-field{background-color:#4caf50}.netball-court{background-color:#666060}.rugby-field,.rugby-union-field{background-color:#2e7d32}.field-lines{position:relative;width:100%;height:100%}.center-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border:2px solid rgba(255,255,255,.8);border-radius:50%}.center-line{position:absolute;top:50%;width:100%;height:2px;background-color:#fffc}.penalty-area-top,.penalty-area-bottom{position:absolute;left:50%;transform:translate(-50%);width:70%;height:20%;border:2px solid rgba(255,255,255,.8)}.penalty-area-top{top:0}.penalty-area-bottom{bottom:0}.netball-thirds{position:relative;width:100%;height:100%}.netball-third{position:absolute;width:100%;height:33.33%;border-bottom:2px solid rgba(255,255,255,.8)}.netball-third-1{top:0}.netball-third-2{top:33.33%}.netball-third-3{top:66.66%;border-bottom:none}.netball-shooting-circles{position:relative;width:100%;height:100%}.netball-shooting-circle{position:absolute;left:50%;transform:translate(-50%);width:60%;height:30%;border:2px solid rgba(255,255,255,.8);border-radius:50%}.netball-shooting-circle-top{top:-15%}.netball-shooting-circle-bottom{bottom:-15%}.netball-center-circle{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:40px;height:40px;border:2px solid rgba(255,255,255,.8);border-radius:50%}.rugby-halfway-line{position:absolute;top:50%;width:100%;height:2px;background-color:#fffc}.rugby-try-lines{position:relative;width:100%;height:100%}.rugby-try-line{position:absolute;width:100%;height:2px;background-color:#fffc}.rugby-try-line-top{top:10%}.rugby-try-line-bottom{bottom:10%}.rugby-in-goal-areas{position:relative;width:100%;height:100%}.rugby-in-goal{position:absolute;width:100%;height:10%;background-color:#ffffff1a}.rugby-in-goal-top{top:0}.rugby-in-goal-bottom{bottom:0}.rugby-22m-lines{position:relative;width:100%;height:100%}.rugby-22m-line{position:absolute;width:100%;height:2px;background-color:#fff9}.rugby-22m-line-top{top:20%}.rugby-22m-line-bottom{bottom:20%}.player-position-container{position:absolute;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center}.player-circle{width:60px;height:60px;background-color:#2196f3;border:2px solid white;border-radius:50%;display:flex;align-items:center;justify-content:center;color:#fff;text-align:center;box-shadow:0 2px 4px #0003;padding:5px;cursor:pointer}.position-role{margin-top:4px;font-size:12px;font-weight:700;color:#fff;text-shadow:1px 1px 2px rgba(0,0,0,.8);text-align:center;background-color:#0009;padding:2px 6px;border-radius:8px;min-width:24px}.player-circle.fatigue-1{background-color:#dc3545}.player-circle.fatigue-2{background-color:#e66e45}.player-circle.fatigue-3{background-color:#148527}.player-name{font-size:13px;line-height:1.2;word-wrap:break-word}.substitutes-container{width:100%;padding:10px;margin-top:10px;display:flex;justify-content:center;gap:20px;background-color:#0000000d;border-radius:8px}.player-circle.substitute{position:relative;transform:none;width:60px;height:60px;background-color:#ff9800}.player-circle.rested-1{background-color:#148527}.player-circle.rested-2{background-color:#e66e45}.player-circle.rested-3{background-color:#dc3545}.player-circle.substitute:hover{transform:scale(1.1);cursor:pointer}.player-circle.drop-target{background-color:#4caf50;transform:scale(1.1)}.player-circle.dragging{cursor:grabbing}.player-circle.suggested-sub{background-color:#4caf50;transition:background-color .3s ease}.player-circle.needs-rest{background-color:#f44336;transition:background-color .3s ease}.substitutions-list{margin-top:20px;padding:10px;background-color:#0000000d;border-radius:8px}.substitution-entry{padding:8px;border-bottom:1px solid rgba(0,0,0,.1)}.substitution-entry:last-child{border-bottom:none}.game-info{margin-top:20px;display:flex;gap:20px;flex-wrap:wrap}.player-stats{flex:1;min-width:200px;padding:10px;background-color:#0000000d;border-radius:8px}.player-stats h3{margin-bottom:10px;padding-bottom:5px;border-bottom:1px solid rgba(0,0,0,.1)}.stats-grid{display:flex;flex-direction:column;gap:8px}.player-stat-entry{display:flex;justify-content:space-between;align-items:center;padding:4px 8px;background-color:#ffffff80;border-radius:4px}.player-stat-name{font-size:14px}.player-stat-time{font-weight:700;font-family:monospace}.substitutions-list{flex:1;min-width:200px}.player-circle.selected{height:66px;width:66px;border:5px solid #ffd700;box-shadow:0 0 10px #ffd70080}.player-circle.available-for-sub{cursor:pointer}.player-circle.available-for-sub:after{content:"";position:absolute;top:-3px;left:-3px;width:66px;height:66px;border:5px solid rgba(255,255,255,1);border-radius:50%;animation:pulse 1.5s infinite;pointer-events:none}@keyframes pulse{0%{transform:scale(1);opacity:.8}50%{transform:scale(1.2);opacity:.4}to{transform:scale(1);opacity:.8}}.attendance-section{background:#fff;padding:1rem;margin-bottom:1rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.attendance-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.attendance-item{padding:.5rem}.attendance-item label{display:flex;align-items:center;gap:.5rem;cursor:pointer}.attendance-item input[type=checkbox]{width:18px;height:18px}.confirm-attendance-button{margin-top:1rem;padding:.5rem 1rem;background-color:#4caf50;color:#fff;border:none;border-radius:4px;cursor:pointer;font-size:1rem}.confirm-attendance-button:hover{background-color:#45a049}.target-minutes-section{background:#fff;padding:1rem;margin-bottom:1rem;border-radius:8px;box-shadow:0 2px 4px #0000001a}.target-minutes-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.5rem}.target-minutes-item{padding:.5rem;background-color:#f5f5f5;border-radius:4px}.target-minutes-display{font-size:1rem;font-weight:500;color:#333;border-radius:4px}.reset-button{background-color:#dc3545;color:#fff;margin-left:10px}.reset-button:hover{background-color:#c82333}.goal-button{background-color:#4caf50;color:#fff}.goals-list{margin-top:1rem;padding:.5rem;background-color:#f5f5f5;border-radius:4px}.goal-entry{margin:.5rem 0;padding:.5rem;background-color:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000}.goal-modal{background-color:#fff;padding:2rem;border-radius:8px;max-width:90%;width:500px;max-height:90vh;overflow-y:auto}.goal-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.player-selection{display:flex;flex-wrap:wrap;gap:.5rem}.player-button{padding:.5rem 1rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.player-button:hover{background:#f0f0f0}.player-button.selected{background:#4caf50;color:#fff;border-color:#45a049}.player-button:disabled{opacity:.5;cursor:not-allowed}.modal-buttons{display:flex;gap:1rem;justify-content:flex-end;margin-top:1rem}.submit-button{background:#4caf50;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.submit-button:disabled{opacity:.5;cursor:not-allowed}.cancel-button{background:#f44336;color:#fff;border:none;padding:.5rem 1rem;border-radius:4px;cursor:pointer}.goal-entry{display:flex;align-items:center;gap:.5rem;font-size:.9rem}.team-selection{display:flex;gap:1rem;margin-bottom:1rem}.team-button{padding:.5rem 1rem;border:1px solid #ccc;border-radius:4px;background:#fff;cursor:pointer}.team-button.selected{background:#007bff;color:#fff}.opponent-goal{color:#dc3545}.selected-players{display:flex;flex-wrap:wrap;gap:.5rem;margin-top:.5rem}.selected-player-tag{background-color:#4caf50;color:#fff;padding:.25rem .5rem;border-radius:12px;font-size:.85rem;font-weight:500}.attendance-section{padding:20px;background-color:#f8f9fa;border-radius:8px;margin-bottom:20px}.attendance-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:10px;margin:15px 0}.attendance-item{padding:8px;background-color:#fff;border-radius:4px;box-shadow:0 1px 3px #0000001a}.attendance-item label{display:flex;align-items:center;gap:10px;cursor:pointer}.confirm-attendance-button{background-color:#28a745;color:#fff;border:none;padding:10px 20px;border-radius:4px;cursor:pointer;font-size:16px}.confirm-attendance-button:hover{background-color:#218838}
