body{margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--background-dark:#2b2e3b;--background-darker:#252830;--card-background:#343845;--accent-blue:#688db1;--accent-green:#9cb68f;--accent-red:#e16162;--accent-yellow:#ffc107;--text-primary:#d1d5db;--text-secondary:#9ca3af;--shadow-sm:0 1px 2px #0000004d;--shadow:0 1px 3px #0006,0 1px 2px #0000004d;--shadow-lg:0 10px 15px #0006,0 4px 6px #0000004d;--spacing-1:0.25rem;--spacing-2:0.5rem;--spacing-3:0.75rem;--spacing-4:1rem;--spacing-6:1.5rem;--spacing-8:2rem;--spacing-12:3rem;--spacing-16:4rem;--radius-sm:0.375rem;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--transition:0.3s ease;--border-color:#4a5568}.max-w-md{max-width:28rem}.mb-8{margin-bottom:2rem}.mb-2{margin-bottom:.5rem}.mb-6{margin-bottom:1.5rem}.text-4xl{font-size:2.25rem;line-height:2.5rem}.text-lg{font-size:1.125rem;line-height:1.75rem}.font-bold{font-weight:700}@keyframes slideIn{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.modern-menu-btn{position:relative}.modern-menu-btn:before{background:linear-gradient(45deg,#ffffff1a,#0000);border-radius:12px;bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.modern-menu-btn:hover:before{opacity:1}.modern-logout-btn{overflow:hidden;position:relative}.modern-logout-btn:before{background:linear-gradient(45deg,#0000,#e161621a,#0000);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(-45deg);transition:transform .6s ease;width:200%}.modern-logout-btn:hover:before{opacity:1;transform:rotate(-45deg) translateX(100%)}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#2b2e3b;background-color:var(--background-dark);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.5}body,h1{color:#d1d5db;color:var(--text-primary)}h1{font-size:2.5rem;font-weight:700;margin-bottom:1.5rem;margin-bottom:var(--spacing-6)}h2{font-size:2rem;margin-bottom:1rem;margin-bottom:var(--spacing-4)}h2,h3{color:#d1d5db;color:var(--text-primary);font-weight:600}h3{font-size:1.5rem;margin-bottom:.75rem;margin-bottom:var(--spacing-3)}h4{color:#d1d5db;color:var(--text-primary);font-size:1.25rem;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}p{color:#9ca3af;color:var(--text-secondary);margin-bottom:1rem;margin-bottom:var(--spacing-4)}.card{background-color:#343845;background-color:var(--card-background);border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 1px 3px #0006,0 1px 2px #0000004d;box-shadow:var(--shadow);padding:1.5rem;padding:var(--spacing-6);transition:transform .3s ease,box-shadow .3s ease;transition:transform var(--transition),box-shadow var(--transition)}.card:hover{box-shadow:0 10px 15px #0006,0 4px 6px #0000004d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-compact{padding:1rem;padding:var(--spacing-4)}.card-large{padding:2rem;padding:var(--spacing-8)}.btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:1rem;font-weight:500;justify-content:center;min-height:44px;padding:.75rem 1.5rem;padding:var(--spacing-3) var(--spacing-6);text-decoration:none;transition:all .3s ease;transition:all var(--transition)}.btn-primary{background-color:#688db1;background-color:var(--accent-blue);color:#fff}.btn-primary:hover{background-color:#5a7a9a;transform:translateY(-1px)}.btn-secondary{background-color:#9cb68f;background-color:var(--accent-green);color:#fff}.btn-secondary:hover{background-color:#8aa47d;transform:translateY(-1px)}.btn-danger{background-color:#e16162;background-color:var(--accent-red);color:#fff}.btn-danger:hover{background-color:#c54545;transform:translateY(-1px)}.btn-outline{background-color:initial;border:2px solid #688db1;border:2px solid var(--accent-blue);color:#688db1;color:var(--accent-blue)}.btn-outline:hover{background-color:#688db1;background-color:var(--accent-blue);color:#fff}.btn-large{font-size:1.125rem;min-height:52px;padding:1rem 2rem;padding:var(--spacing-4) var(--spacing-8)}.btn-small{font-size:.875rem;min-height:36px;padding:.5rem 1rem;padding:var(--spacing-2) var(--spacing-4)}.form-group{margin-bottom:1rem;margin-bottom:var(--spacing-4)}.form-label{display:block;font-weight:500;margin-bottom:.5rem;margin-bottom:var(--spacing-2)}.form-input,.form-label{color:#d1d5db;color:var(--text-primary)}.form-input{background-color:#252830;background-color:var(--background-darker);border:2px solid #252830;border:2px solid var(--background-darker);border-radius:.5rem;border-radius:var(--radius);font-size:1rem;padding:.75rem;padding:var(--spacing-3);transition:border-color .3s ease;transition:border-color var(--transition);width:100%}.form-input:focus{border-color:#688db1;border-color:var(--accent-blue);outline:none}.form-input::placeholder{color:#9ca3af;color:var(--text-secondary)}.form-select{-webkit-appearance:none;appearance:none;background-color:#252830;background-color:var(--background-darker);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='%23d1d5db' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right .75rem center;background-position:right var(--spacing-3) center;background-repeat:no-repeat;background-size:1rem;border:2px solid #252830;border:2px solid var(--background-darker);border-radius:.5rem;border-radius:var(--radius);color:#d1d5db;color:var(--text-primary);font-size:1rem;padding:.75rem;padding:var(--spacing-3);padding-right:2.25rem;padding-right:calc(var(--spacing-3) + 1.5rem);transition:border-color .3s ease;transition:border-color var(--transition);width:100%}.form-select:focus{border-color:#688db1;border-color:var(--accent-blue);outline:none}.form-checkbox{align-items:center;cursor:pointer;display:inline-flex;position:relative;-webkit-user-select:none;user-select:none}.form-checkbox input[type=checkbox]{cursor:pointer;height:0;opacity:0;position:absolute;width:0}.form-checkbox .checkmark{background-color:#252830;background-color:var(--background-darker);border:2px solid #252830;border:2px solid var(--background-darker);border-radius:.375rem;border-radius:var(--radius-sm);height:20px;margin-right:.5rem;margin-right:var(--spacing-2);position:relative;transition:all .3s ease;transition:all var(--transition);width:20px}.form-checkbox input:checked~.checkmark,.form-checkbox:hover .checkmark{border-color:#688db1;border-color:var(--accent-blue)}.form-checkbox input:checked~.checkmark{background-color:#688db1;background-color:var(--accent-blue)}.form-checkbox .checkmark:after{border:solid #fff;border-width:0 2px 2px 0;content:"";display:none;height:12px;left:6px;position:absolute;top:2px;transform:rotate(45deg);width:6px}.form-checkbox input:checked~.checkmark:after{display:block}.grid{grid-gap:1.5rem;grid-gap:var(--spacing-6);display:grid;gap:1.5rem;gap:var(--spacing-6)}.grid-2{grid-gap:1rem;grid-gap:var(--spacing-4);grid-template-columns:repeat(2,1fr)}.grid-2,.grid-3{display:grid;gap:1rem;gap:var(--spacing-4)}.grid-3{grid-gap:1rem;grid-gap:var(--spacing-4);grid-template-columns:repeat(3,1fr)}.grid-4{grid-gap:1rem;grid-gap:var(--spacing-4);display:grid;gap:1rem;gap:var(--spacing-4);grid-template-columns:repeat(4,1fr)}.main-layout{display:flex;min-height:100vh}.main-content{background-color:#2b2e3b;background-color:var(--background-dark);flex:1 1;margin-left:16rem;min-height:100vh}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.space-y-4>*+*{margin-top:1rem;margin-top:var(--spacing-4)}.space-y-6>*+*{margin-top:1.5rem;margin-top:var(--spacing-6)}.p-6{padding:1.5rem;padding:var(--spacing-6)}.p-4{padding:1rem;padding:var(--spacing-4)}.p-3{padding:.75rem;padding:var(--spacing-3)}.p-2{padding:.5rem;padding:var(--spacing-2)}.mb-4{margin-bottom:1rem;margin-bottom:var(--spacing-4)}.mt-4{margin-top:1rem;margin-top:var(--spacing-4)}.text-center{text-align:center}.chart-container{background-color:#343845;background-color:var(--card-background);border:1px solid #688db11a;border-radius:.5rem;border-radius:var(--radius);padding:.5rem;padding:var(--spacing-2)}.chart-container canvas{max-height:100%!important}.chart-wrapper{background:linear-gradient(135deg,#343845,#252830);background:linear-gradient(135deg,var(--card-background) 0,var(--background-darker) 100%);border:1px solid #688db133;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px #0006,0 1px 2px #0000004d;box-shadow:var(--shadow);padding:1rem;padding:var(--spacing-4)}.chart-header{align-items:center;border-bottom:1px solid #688db11a;display:flex;justify-content:space-between;margin-bottom:1rem;margin-bottom:var(--spacing-4);padding-bottom:.75rem;padding-bottom:var(--spacing-3)}.chart-title{color:#d1d5db;color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.chart-legend{border-top:1px solid #688db11a;display:flex;flex-wrap:wrap;gap:.75rem;gap:var(--spacing-3);margin-top:.75rem;margin-top:var(--spacing-3);padding-top:.75rem;padding-top:var(--spacing-3)}.chart-legend-item{align-items:center;color:#9ca3af;color:var(--text-secondary);display:flex;font-size:.875rem;gap:.5rem;gap:var(--spacing-2)}.chart-legend-color{border-radius:.375rem;border-radius:var(--radius-sm);height:12px;width:12px}.block{display:block}.hidden{display:none}.fixed{position:fixed}.absolute{position:absolute}.relative{position:relative}.inset-0{bottom:0;left:0;right:0;top:0}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.w-full{width:100%}.h-full{height:100%}.transform{transform:translateX(0) translateY(0) translateZ(0);transform:translateX(var(--transform-translate-x,0)) translateY(var(--transform-translate-y,0)) translateZ(0)}.translate-x-0{--transform-translate-x:0}.-translate-x-full{--transform-translate-x:-100%}.transition-transform{transition:transform .3s ease}.duration-300{transition-duration:.3s}.bg-opacity-50{background-color:#00000080}@media (min-width:768px){.md\\:hidden{display:none}.md\\:block{display:block}.md\\:translate-x-0{--transform-translate-x:0}}.progress-bar{background-color:#252830;background-color:var(--background-darker);height:.75rem;height:var(--spacing-3);overflow:hidden;width:100%}.progress-bar,.progress-fill{border-radius:.75rem;border-radius:var(--radius-lg)}.progress-fill{background:linear-gradient(90deg,#688db1,#9cb68f);background:linear-gradient(90deg,var(--accent-blue),var(--accent-green));height:100%;transition:width .3s ease;transition:width var(--transition)}.progress-success{background:linear-gradient(90deg,#9cb68f,#7fb069);background:linear-gradient(90deg,var(--accent-green),#7fb069)}.progress-danger{background:linear-gradient(90deg,#e16162,#c54545);background:linear-gradient(90deg,var(--accent-red),#c54545)}.stat-card{text-align:center}.stat-number{color:#688db1;color:var(--accent-blue);display:block;font-size:2.5rem;font-weight:700}.stat-label{color:#9ca3af;color:var(--text-secondary);font-size:.875rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}@media (max-width:768px){.card{border-radius:.75rem;border-radius:var(--radius-lg);padding:1rem;padding:var(--spacing-4)}h1{font-size:2rem}h2{font-size:1.75rem}.grid{gap:1rem;gap:var(--spacing-4)}.btn{min-height:48px;padding:1rem 1.5rem;padding:var(--spacing-4) var(--spacing-6)}.grid-2,.grid-3,.grid-4{gap:.75rem;gap:var(--spacing-3);grid-template-columns:1fr}.p-6{padding:1rem!important;padding:var(--spacing-4)!important}.stat-number{font-size:2rem}.main-content{margin-left:0;padding-top:60px}.chart-container{height:250px!important}.game-mode-grid{grid-template-columns:1fr!important}.grid-3 .player-card{max-width:none}.form-input{font-size:16px}}@media (max-width:1024px) and (min-width:769px){.grid-3,.grid-4{grid-template-columns:repeat(2,1fr)}.main-content{margin-left:0}}@media (hover:none) and (pointer:coarse){.btn{min-height:48px}.btn-large{min-height:56px}}.loading{opacity:.6;pointer-events:none}.spinner{animation:spin 1s linear infinite;border:3px solid #252830;border-top:3px solid #688db1;border:3px solid var(--background-darker);border-radius:50%;border-top-color:var(--accent-blue);height:24px;margin:0 auto;width:24px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.fade-in{animation:fadeIn .5s ease-in}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}@keyframes pulse{0%{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.1)}to{opacity:1;transform:scale(1)}}.pulse{animation:pulse 2s infinite}.App{min-height:100vh}.content-with-nav{margin-left:256px;min-height:100vh}@media (max-width:768px){.content-with-nav{margin-left:0}}.min-h-screen{min-height:100vh}.install-prompt{bottom:20px;left:50%;position:fixed;transform:translateX(-50%);z-index:1000}.dartboard-container{margin:0 auto;max-width:400px}input[type=number]::-webkit-inner-spin-button,input[type=number]::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}input[type=number]{-moz-appearance:textfield}input[inputmode=numeric]{-webkit-appearance:none;appearance:none}.score-display{font-size:3rem;font-weight:700;margin:1rem 0;text-align:center}.throw-input{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin:2rem 0}.quick-scores{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr);margin:1rem 0}.quick-score-btn{align-items:center;aspect-ratio:1;display:flex;font-weight:700;justify-content:center;min-height:60px}.chart-container{height:300px;position:relative;width:100%}.player-card{transition:all .3s ease}.player-avatar{align-items:center;background:var(--accent-blue);border-radius:50%;color:#fff;display:flex;font-size:1.5rem;height:60px;justify-content:center;margin:0 auto 1rem;width:60px}.game-mode-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.game-mode-card{border:2px solid #0000;cursor:pointer;text-align:center;transition:all .3s ease}.game-mode-card.selected{background-color:#688db11a}.game-mode-card.selected,.game-mode-card:hover{border-color:var(--accent-blue)}@media (hover:none) and (pointer:coarse){.btn{min-height:48px}.btn-large{min-height:56px}.quick-score-btn{min-height:64px}}
/*# sourceMappingURL=main.7c5b2610.css.map*/