:root{--court-blue: #0066b3;--court-blue-dark: #004d8a;--court-green: #2d8c3c;--ball-yellow: #ccff00;--ball-yellow-dark: #a8d600;--white-lines: #ffffff;--glass-bg: rgba(255, 255, 255, .95);--shadow: 0 8px 32px rgba(0, 102, 179, .15)}body{font-family:Inter,system-ui,-apple-system,Segoe UI,Roboto,Helvetica Neue,Arial;background:#1a5fa8;color:#111827;margin:0;min-height:100vh;position:relative;overflow-x:hidden}body:before{content:"";position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:140vmax;height:140vmax;background:linear-gradient(90deg,transparent calc(50% - 2px),rgba(255,255,255,.9) calc(50% - 2px),rgba(255,255,255,.9) calc(50% + 2px),transparent calc(50% + 2px)),linear-gradient(0deg,transparent calc(50% - 2px),rgba(255,255,255,.9) calc(50% - 2px),rgba(255,255,255,.9) calc(50% + 2px),transparent calc(50% + 2px)),linear-gradient(90deg,transparent calc(25% - 1px),rgba(255,255,255,.6) calc(25% - 1px),rgba(255,255,255,.6) calc(25% + 1px),transparent calc(25% + 1px)),linear-gradient(90deg,transparent calc(75% - 1px),rgba(255,255,255,.6) calc(75% - 1px),rgba(255,255,255,.6) calc(75% + 1px),transparent calc(75% + 1px)),linear-gradient(0deg,transparent calc(20% - 1px),rgba(255,255,255,.5) calc(20% - 1px),rgba(255,255,255,.5) calc(20% + 1px),transparent calc(20% + 1px)),linear-gradient(0deg,transparent calc(80% - 1px),rgba(255,255,255,.5) calc(80% - 1px),rgba(255,255,255,.5) calc(80% + 1px),transparent calc(80% + 1px)),radial-gradient(ellipse at center,#2196f3,#1976d2 40%,#1565c0,#0d47a1);pointer-events:none;z-index:0}body:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,rgba(255,255,255,.15) 0%,rgba(255,255,255,.05) 3%,transparent 6%),linear-gradient(270deg,rgba(255,255,255,.15) 0%,rgba(255,255,255,.05) 3%,transparent 6%),linear-gradient(180deg,rgba(0,0,0,.2) 0%,transparent 8%),linear-gradient(0deg,rgba(0,0,0,.15) 0%,transparent 5%),linear-gradient(90deg,transparent 49%,rgba(0,0,0,.1) 49.5%,rgba(0,0,0,.15) 50%,rgba(0,0,0,.1) 50.5%,transparent 51%);pointer-events:none;z-index:0}.app:before{content:"";position:fixed;top:15%;right:8%;width:60px;height:60px;background:radial-gradient(circle at 30% 30%,#e8ff4a,#c4e600 40%,#9fba00);border-radius:50%;box-shadow:inset -8px -8px 20px #0003,inset 5px 5px 15px #fff6,0 4px 20px #0000004d;z-index:0;opacity:.8;animation:float 6s ease-in-out infinite}.app:after{content:"";position:fixed;bottom:20%;left:5%;width:40px;height:40px;background:radial-gradient(circle at 30% 30%,#e8ff4a,#c4e600 40%,#9fba00);border-radius:50%;box-shadow:inset -5px -5px 12px #0003,inset 3px 3px 10px #fff6,0 3px 15px #0000004d;z-index:0;opacity:.6;animation:float 8s ease-in-out infinite reverse}@keyframes float{0%,to{transform:translateY(0) rotate(0)}50%{transform:translateY(-20px) rotate(10deg)}}.app{max-width:1100px;margin:0 auto;padding:24px 16px;position:relative;z-index:1}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;background:var(--glass-bg);padding:16px 24px;border-radius:16px;box-shadow:var(--shadow);border:3px solid var(--white-lines)}.topbar h1{margin:0;font-size:28px;color:var(--court-blue);display:flex;align-items:center;gap:12px}.topbar h1:before{content:"🎾";font-size:32px}.subtitle{margin:0;color:#475569;font-size:13px;background:linear-gradient(90deg,var(--court-blue),var(--court-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;font-weight:500}.main{display:grid;grid-template-columns:360px 1fr;gap:18px;margin-top:18px}.card{background:var(--glass-bg);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:16px;padding:20px;box-shadow:var(--shadow);border:2px solid rgba(255,255,255,.8);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--court-blue),var(--ball-yellow),var(--court-green))}.card h2{color:var(--court-blue-dark);margin:0 0 12px;font-size:18px;display:flex;align-items:center;gap:8px}.left .card+.card{margin-top:14px}.add-form input{width:100%;padding:12px 14px;border:2px solid #e2e8f0;border-radius:10px;margin-top:8px;box-sizing:border-box;font-size:14px;transition:border-color .2s,box-shadow .2s}.add-form input:focus{outline:none;border-color:var(--court-blue);box-shadow:0 0 0 3px #0066b326}.add-form .row{display:flex;gap:10px}.add-form .row input,.add-form .row select{flex:1}.player-select{padding:12px 36px 12px 14px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff;color:#1e293b;cursor:pointer;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23475569' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 14px center}.player-select:focus{outline:none;border-color:var(--court-blue);box-shadow:0 0 0 3px #0066b326}.player-select option{padding:8px}.reason-input-wrapper{display:flex;flex-direction:column;gap:8px}.reason-input{width:100%;padding:12px 14px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;box-sizing:border-box;transition:border-color .2s,box-shadow .2s}.reason-input:focus{outline:none;border-color:var(--court-blue);box-shadow:0 0 0 3px #0066b326}.reason-suggestions{display:flex;flex-wrap:wrap;align-items:center;gap:6px}.reason-suggestions .label{font-size:12px;color:#64748b;margin-right:4px}.suggestion-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 10px!important;background:#f1f5f9!important;border:1px solid #e2e8f0!important;border-radius:20px!important;font-size:12px!important;cursor:pointer;transition:all .2s}.suggestion-chip:hover{background:#e2e8f0!important;border-color:var(--court-blue)!important;transform:none!important}.suggestion-chip .chip-amount{color:var(--court-blue);font-weight:600}.fine-type-select-wrapper{display:flex;align-items:center;gap:12px}.fine-type-select-wrapper .or-text{font-size:12px;color:#64748b;white-space:nowrap}.card-header-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header-row h2{margin:0}.toggle-btn{padding:8px 16px!important;font-size:13px!important;background:#f1f5f9!important;border:1px solid #e2e8f0!important;border-radius:8px!important}.fine-types-list{list-style:none;padding:0;margin:0 0 20px}.fine-type-item{display:flex;align-items:center;gap:16px;padding:16px;border-bottom:1px solid #e2e8f0;background:#f8fafc;border-radius:10px;margin-bottom:8px}.fine-type-item:last-child{margin-bottom:0}.fine-type-reason{flex:1;font-weight:500;color:#1e293b;font-size:15px}.fine-type-amount{font-weight:700;color:var(--court-blue);min-width:100px;text-align:right;font-size:16px}.fine-type-actions{display:flex;gap:8px}.fine-type-actions button{padding:6px 10px!important;font-size:16px!important;background:transparent!important;border:none!important}.fine-type-actions button:hover{transform:scale(1.15)!important}.fine-type-edit{display:flex;gap:10px;width:100%;align-items:center}.fine-type-edit .edit-input{padding:10px 12px;border:2px solid #e2e8f0;border-radius:8px;font-size:14px}.fine-type-edit .edit-input:first-child{flex:1}.fine-type-edit .edit-input.amount{width:100px}.fine-type-edit .save-btn{padding:8px 12px!important;background:#16a34a!important;color:#fff!important;border:none!important}.fine-type-edit .cancel-btn{padding:8px 12px!important;background:#dc2626!important;color:#fff!important;border:none!important}.add-fine-type-form{display:flex;gap:12px;padding-top:16px;border-top:1px solid #e2e8f0;margin-top:8px}.add-fine-type-form input{padding:12px 14px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px}.add-fine-type-form input:first-child{flex:1;min-width:0}.add-fine-type-form input[type=number]{width:100px}.add-fine-type-form button{white-space:nowrap;padding:12px 20px!important}.form-actions{margin-top:14px;display:flex;gap:10px}button{background:#f1f5f9;border:2px solid #e2e8f0;padding:10px 16px;border-radius:10px;cursor:pointer;color:#334155;font-weight:500;transition:all .2s}button:hover{background:#e2e8f0;transform:translateY(-1px)}button.primary{background:linear-gradient(135deg,var(--court-blue),var(--court-blue-dark));color:#fff;border:none;box-shadow:0 4px 12px #0066b34d}button.primary:hover{background:linear-gradient(135deg,var(--court-blue-dark),var(--court-blue));box-shadow:0 6px 16px #0066b366}button:disabled{opacity:.6;cursor:default;transform:none}.error{color:#dc2626;margin-top:10px;padding:8px 12px;background:#fef2f2;border-radius:8px;font-size:13px}.muted{color:#64748b;font-style:italic}.team-total{display:flex;justify-content:space-between;align-items:center;padding:16px;background:linear-gradient(135deg,var(--court-blue),var(--court-blue-dark));border-radius:12px;margin-bottom:16px;color:#fff}.team-total .label{font-weight:500;font-size:14px;opacity:.9}.team-total .amount{font-size:24px;font-weight:700}.leaderboard{list-style:none;padding:0;margin:0}.leaderboard-item{display:flex;align-items:center;gap:12px;padding:14px 12px;border-bottom:1px solid #e2e8f0;transition:background .2s}.leaderboard-item:last-child{border-bottom:none}.leaderboard-item:hover{background:#f8fafc}.leaderboard-item.paid-up{opacity:.6}.leaderboard-item .rank{font-size:18px;min-width:32px;text-align:center;font-weight:600;color:#64748b}.leaderboard-item .name{flex:1;font-weight:600;color:#1e293b}.leaderboard-item .stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.leaderboard-item .outstanding{font-weight:700;font-size:15px}.leaderboard-item .outstanding.owes{color:#dc2626}.leaderboard-item .outstanding.clear{color:#16a34a;font-size:13px}.leaderboard-item .total-small{font-size:12px;color:#64748b}.totals-list{list-style:none;padding:0;margin:0}.totals-item{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:2px dashed rgba(0,102,179,.2)}.totals-item:last-child{border-bottom:none}.totals-item strong{color:var(--court-blue-dark)}.totals-values{text-align:right;font-size:13px;color:#475569}.outstanding{color:#dc2626;font-weight:600}.total{color:var(--court-green);margin-left:10px;font-weight:500}.list-header{display:flex;align-items:center;justify-content:space-between;gap:12px}.filters label{margin-left:10px;font-size:13px;color:#334155;cursor:pointer}.filters input[type=radio]{accent-color:var(--court-blue)}.fines{width:100%;border-collapse:collapse;margin-top:14px;font-size:14px}.fines th,.fines td{text-align:left;padding:12px 14px;border-bottom:1px solid #e2e8f0}.fines thead th{color:var(--court-blue-dark);font-weight:600;font-size:13px;text-transform:uppercase;letter-spacing:.5px;background:linear-gradient(180deg,rgba(0,102,179,.05),transparent)}.fines tbody tr:hover td{background:#0066b308}.fines tr.paid td{background:linear-gradient(90deg,rgba(45,140,60,.1),transparent)}.reason{color:#334155;max-width:260px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.small{font-size:12px;color:#64748b}.footer{margin-top:24px;color:#ffffffb3;font-size:13px;text-align:center;padding:16px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:20px;position:relative;z-index:1}.login-container{width:100%;max-width:420px}.login-header{text-align:center;margin-bottom:24px;color:#fff}.login-header h1{font-size:32px;margin:0 0 8px;text-shadow:0 2px 10px rgba(0,0,0,.3)}.login-header p{margin:0;opacity:.9}.login-card{background:var(--glass-bg);border-radius:20px;padding:32px;box-shadow:var(--shadow)}.login-tabs{display:flex;gap:8px;margin-bottom:24px}.login-tabs button{flex:1;padding:12px;border:none;background:#f1f5f9;border-radius:10px;cursor:pointer;font-weight:500;color:#64748b;transition:all .2s}.login-tabs button.active{background:var(--court-blue);color:#fff}.form-group{margin-bottom:16px}.form-group label{display:block;font-weight:500;margin-bottom:6px;color:#334155}.form-group input{width:100%;padding:12px 14px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;box-sizing:border-box;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--court-blue)}.login-card button[type=submit]{width:100%;padding:14px;margin-top:8px}.login-footer{text-align:center;margin-top:20px;color:#fffc}.login-footer button.link{background:none;border:none;color:var(--ball-yellow);text-decoration:underline;cursor:pointer;padding:0}.app-layout{display:flex;min-height:100vh;position:relative;z-index:1}.loading-screen{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;color:#fff}.loading-spinner{font-size:48px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.sidebar{width:280px;background:#fffffffa;display:flex;flex-direction:column;box-shadow:4px 0 20px #0000001a;z-index:10}.sidebar-header{padding:20px;border-bottom:1px solid #e2e8f0}.sidebar-header h1{font-size:20px;margin:0;color:var(--court-blue)}.sidebar-user{display:flex;align-items:center;gap:12px;padding:16px 20px;background:linear-gradient(135deg,#0066b30d,#2d8c3c0d);border-bottom:1px solid #e2e8f0}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,var(--court-blue),var(--court-green));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.user-info{display:flex;flex-direction:column}.user-name{font-weight:600;color:#1f2937}.user-email{font-size:12px;color:#64748b}.sidebar-nav{flex:1;padding:16px 0;overflow-y:auto}.nav-section h3{font-size:12px;text-transform:uppercase;letter-spacing:.5px;color:#64748b;margin:0 0 8px 20px}.team-list{list-style:none;padding:0;margin:0 0 16px}.team-item{width:100%;padding:12px 20px;border:none;background:none;text-align:left;cursor:pointer;display:flex;align-items:center;justify-content:space-between;transition:background .2s}.team-item:hover{background:#0066b30d}.team-item.active{background:linear-gradient(90deg,rgba(0,102,179,.1),transparent);border-left:3px solid var(--court-blue)}.team-name{font-weight:500;color:#1f2937}.badge{font-size:10px;padding:3px 8px;border-radius:10px;background:var(--ball-yellow);color:#1f2937;font-weight:600}.badge.formand{background:linear-gradient(135deg,#fbbf24,#f59e0b)}.badge.member{background:#e2e8f0;color:#64748b}.team-actions{padding:0 12px;display:flex;gap:8px}.small-btn{flex:1;padding:8px 12px;font-size:12px;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:8px;cursor:pointer;transition:all .2s}.small-btn:hover{background:#e2e8f0}.sidebar-footer{padding:16px 20px;border-top:1px solid #e2e8f0}.logout-btn{width:100%;padding:10px;background:#fee2e2;color:#dc2626;border:none;border-radius:8px;cursor:pointer;font-weight:500;transition:background .2s}.logout-btn:hover{background:#fecaca}.main-content{flex:1;display:flex;flex-direction:column;overflow-y:auto}.page-nav{display:flex;gap:8px;padding:16px 24px;background:#ffffffe6;border-bottom:1px solid rgba(255,255,255,.5);align-items:center}.page-nav button{padding:10px 20px;background:#fff;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;font-weight:500;color:#334155;transition:all .2s;box-shadow:0 1px 3px #0000001a}.page-nav button:hover{background:#f8fafc;border-color:#cbd5e1}.page-nav button.active{background:#fff;border-color:var(--court-blue);color:var(--court-blue)}.current-team-name{margin-left:auto;font-weight:600;color:var(--court-blue);background:#fff;padding:8px 16px;border-radius:20px}.fines-page{padding:24px;flex:1}.fines-page.empty{display:flex;align-items:center;justify-content:center}.empty-state{text-align:center;padding:48px;background:var(--glass-bg);border-radius:20px}.empty-state h2{margin:0 0 8px;color:var(--court-blue)}.empty-state p{color:#64748b;margin:0}.fines-grid{display:grid;grid-template-columns:360px 1fr;gap:20px}.fines-page .left .card+.card{margin-top:16px}.fines-page .actions{display:flex;gap:8px}.fines-page .actions button.danger{background:#fee2e2;color:#dc2626;border:none}.fines-page .actions button.danger:hover{background:#fecaca}.fine-types-page{padding:24px;flex:1;max-width:900px}.fine-types-page.empty{display:flex;align-items:center;justify-content:center}.fine-types-page .page-header{margin-bottom:24px}.fine-types-page .page-header h1{margin:0 0 12px;font-size:32px;color:#1e293b}.page-header{margin-bottom:24px}.page-header h1{margin:0 0 12px;font-size:32px;color:#1e293b}.page-header p{margin:0;color:#fff;font-size:18px;background:linear-gradient(135deg,var(--court-green),#1e8449);padding:12px 20px;border-radius:10px;display:inline-block;font-weight:500;box-shadow:0 4px 12px #2d8c3c4d}.page-header p .team-name{color:var(--ball-yellow);font-weight:700}.error-banner{background:#fef2f2;border:1px solid #fecaca;color:#dc2626;padding:12px 16px;border-radius:10px;margin-bottom:16px}.add-fine-type-card{margin-bottom:24px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid var(--court-blue)}.add-fine-type-form-large{margin-top:16px}.add-fine-type-form-large .form-row{display:flex;gap:16px;align-items:flex-end}.add-fine-type-form-large .form-group{flex:1}.add-fine-type-form-large .form-group:nth-child(2){flex:0 0 150px}.add-fine-type-form-large .form-group label{display:block;font-weight:500;margin-bottom:8px;color:#334155}.add-fine-type-form-large .form-group input{width:100%;padding:14px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:15px;box-sizing:border-box}.add-fine-type-form-large .form-group input:focus{outline:none;border-color:var(--court-blue)}.add-fine-type-form-large button{padding:14px 28px!important;white-space:nowrap}.empty-fine-types{text-align:center;padding:48px 24px;color:#64748b}.empty-fine-types .icon{font-size:48px;display:block;margin-bottom:16px}.empty-fine-types p{margin:0;font-size:16px}.empty-fine-types .hint{margin-top:8px;font-size:14px;color:#94a3b8}.fine-types-grid{display:grid;gap:12px}.fine-type-card{background:#f8fafc;border:1px solid #e2e8f0;border-radius:12px;padding:20px;display:flex;flex-direction:column;gap:12px}.fine-type-card .fine-type-info{display:flex;justify-content:space-between;align-items:center}.fine-type-card .fine-type-reason{font-size:16px;font-weight:600;color:#1e293b}.fine-type-card .fine-type-amount{font-size:20px;font-weight:700;color:var(--court-blue)}.fine-type-card .fine-type-actions{display:flex;gap:8px;padding-top:12px;border-top:1px solid #e2e8f0}.fine-type-card .edit-btn,.fine-type-card .delete-btn{flex:1;padding:10px 16px!important;font-size:13px!important;border-radius:8px!important}.fine-type-card .edit-btn{background:#f1f5f9!important;border:1px solid #e2e8f0!important}.fine-type-card .delete-btn{background:#fef2f2!important;border:1px solid #fecaca!important;color:#dc2626!important}.fine-type-edit-mode{display:flex;flex-direction:column;gap:12px}.fine-type-edit-mode .edit-input{padding:12px 14px;border:2px solid #e2e8f0;border-radius:8px;font-size:15px}.fine-type-edit-mode .edit-input:focus{outline:none;border-color:var(--court-blue)}.fine-type-edit-mode .edit-actions{display:flex;gap:8px}.fine-type-edit-mode .save-btn,.fine-type-edit-mode .cancel-btn{flex:1;padding:10px 16px!important;font-size:14px!important;border-radius:8px!important}.fine-type-edit-mode .save-btn{background:#16a34a!important;color:#fff!important;border:none!important}.fine-type-edit-mode .cancel-btn{background:#f1f5f9!important;border:1px solid #e2e8f0!important}.team-page{padding:24px;flex:1}.team-page.empty{display:flex;align-items:center;justify-content:center}.team-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;background:var(--glass-bg);padding:20px 24px;border-radius:16px}.team-header h2{margin:0 0 4px;color:var(--court-blue-dark)}.team-role{color:#64748b;font-size:14px}.invite-code-box{display:flex;align-items:center;gap:12px;background:#f8fafc;padding:12px 16px;border-radius:10px}.invite-code-box .label{font-size:13px;color:#64748b}.invite-code{font-family:monospace;font-size:18px;font-weight:600;color:var(--court-blue);letter-spacing:2px}.copy-btn{padding:8px 12px;font-size:12px;background:var(--court-blue);color:#fff;border:none;border-radius:6px;cursor:pointer}.members-list{list-style:none;padding:0;margin:0}.member-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid #e2e8f0}.member-item:last-child{border-bottom:none}.member-avatar{width:36px;height:36px;background:linear-gradient(135deg,var(--court-blue),var(--court-green));color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.member-info{flex:1;display:flex;flex-direction:column}.member-name{font-weight:500;color:#1f2937}.member-email{font-size:12px;color:#64748b}.member-role{margin-right:8px}.team-info{margin-top:24px}.team-info p{margin:8px 0;padding:12px 16px;background:#fffc;border-radius:10px}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:100}.modal{background:#fff;border-radius:16px;padding:24px;width:100%;max-width:400px;margin:20px}.modal h2{margin:0 0 20px;color:var(--court-blue-dark)}.modal-actions{display:flex;gap:10px;margin-top:20px}.modal-actions button{flex:1}.modal-note{margin-top:16px;font-size:13px;color:#64748b;text-align:center}@media (max-width: 900px){.fines-grid{grid-template-columns:1fr}.app-layout{flex-direction:column}.sidebar{width:100%;max-height:60vh}.team-header{flex-direction:column;gap:16px}.invite-code-box{width:100%;justify-content:center}}
