:root{--color-bg:#0f1419;--color-surface:#1a2332;--color-surface-hover:#243044;--color-border:#2d3a4f;--color-text:#e8edf4;--color-text-muted:#8b9cb3;--color-primary:#22c55e;--color-primary-hover:#16a34a;--color-primary-muted:rgba(34,197,94,0.15);--color-danger:#ef4444;--color-danger-hover:#dc2626;--color-danger-muted:rgba(239,68,68,0.15);--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow:0 4px 24px rgba(0,0,0,0.35);--font-sans:"Segoe UI",system-ui,-apple-system,sans-serif}*,:after,:before{box-sizing:border-box;margin:0;padding:0}body,html{min-height:100vh;font-family:var(--font-sans);background:var(--color-bg);color:var(--color-text);line-height:1.5;-webkit-font-smoothing:antialiased}a{color:var(--color-primary);text-decoration:none}a:hover{text-decoration:underline}.app-shell{min-height:100vh;display:flex;flex-direction:column}.app-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 2rem;background:var(--color-surface);border-bottom:1px solid var(--color-border)}.app-logo{font-size:1.35rem;font-weight:700;color:var(--color-text);letter-spacing:-.02em}.app-logo span{color:var(--color-primary)}.app-header-actions{position:relative}.nav-menu-toggle{display:inline-flex;align-items:center;justify-content:center;min-width:44px;min-height:44px;padding:.5rem}.nav-drawer-backdrop{position:fixed;inset:0;z-index:100;background:rgba(0,0,0,.5);opacity:0;pointer-events:none;transition:opacity .2s ease}.nav-drawer-backdrop-open{opacity:1;pointer-events:auto}.nav-drawer{position:fixed;top:0;right:0;z-index:101;display:flex;flex-direction:column;width:min(280px,85vw);height:100vh;background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:var(--shadow);transform:translateX(100%);transition:transform .2s ease}.nav-drawer-open{transform:translateX(0)}.nav-drawer-user{display:flex;align-items:center;gap:.75rem;padding:1.25rem;border-bottom:1px solid var(--color-border)}.nav-drawer-user-shield{width:40px;height:40px;object-fit:cover;border-radius:var(--radius-sm);border:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.nav-drawer-user-shield-placeholder{display:flex;align-items:center;justify-content:center;font-size:.85rem;font-weight:700;color:var(--color-text-muted)}.nav-drawer-user-name{font-size:.95rem;font-weight:600;line-height:1.3}.nav-drawer-nav{flex:1 1;overflow-y:auto;padding:1rem .75rem}.nav-drawer-section{display:flex;flex-direction:column;gap:.25rem}.nav-drawer-section+.nav-drawer-section{margin-top:1.25rem}.nav-drawer-section-title{padding:0 .75rem .35rem;font-size:.7rem;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--color-text-muted)}.nav-drawer-link{display:flex;align-items:center;gap:.75rem;width:100%;padding:.75rem;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text-muted);font-size:.95rem;font-weight:500;text-decoration:none;cursor:pointer;text-align:left}.nav-drawer-link:hover{color:var(--color-text);background:var(--color-surface-hover);text-decoration:none}.nav-drawer-link-active{color:var(--color-primary);background:var(--color-primary-muted)}.nav-drawer-footer{padding:.75rem;border-top:1px solid var(--color-border)}.nav-drawer-logout,.nav-drawer-logout:hover{color:var(--color-danger)}.nav-drawer-logout:hover{background:var(--color-danger-muted)}body.nav-menu-open{overflow:hidden}.app-main{flex:1 1;padding:2rem;max-width:960px;width:100%;margin:0 auto}.page-title{font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.page-subtitle{color:var(--color-text-muted);margin-bottom:2rem}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:1.5rem;box-shadow:var(--shadow)}.card-list,.game-card{display:flex;flex-direction:column;gap:1rem}.game-card{align-items:stretch;padding:1.25rem;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);transition:background .15s,border-color .15s}.game-card:hover{background:var(--color-surface-hover);border-color:var(--color-primary)}.game-card-meta{display:flex;flex-wrap:wrap;align-items:center;gap:.5rem 1rem;color:var(--color-text-muted);font-size:.85rem}.game-meta-date{font-weight:500;color:var(--color-text)}.game-meta-attendance,.game-meta-location{display:inline-flex;align-items:center;gap:.35rem}.game-status-badge{font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:var(--radius-sm)}.game-status-scheduled{background:rgba(59,130,246,.15);color:#60a5fa}.game-status-played{background:var(--color-primary-muted);color:var(--color-primary)}.game-status-cancelled{background:var(--color-danger-muted);color:var(--color-danger)}.game-match{display:grid;grid-template-columns:1fr auto 1fr;align-items:start;grid-gap:.75rem;gap:.75rem;padding:.5rem 0}.game-match-team{display:flex;flex-direction:column;align-items:center;gap:.5rem;min-width:0}.game-match-team:first-child,.game-match-team:last-child{text-align:center}.game-match-shield{width:64px;height:64px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg);flex-shrink:0}.game-match-shield-placeholder{display:flex;align-items:center;justify-content:center;font-size:1.1rem;font-weight:700;color:var(--color-text-muted)}.game-match-team-name{font-size:.9rem;font-weight:600;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;word-break:break-word;max-width:100%}.game-match-center{flex-direction:column;justify-content:center;padding-top:.75rem;min-width:4.5rem}.game-match-center,.game-match-score{display:flex;align-items:center;gap:.35rem}.game-match-score{font-size:2rem;font-weight:700;letter-spacing:.02em;line-height:1;color:var(--color-text)}.game-match-score-sep{color:var(--color-text-muted);font-weight:400}.game-match-vs{font-size:1.25rem;font-weight:700;color:var(--color-text-muted);letter-spacing:.08em}.game-team-stats{list-style:none;display:flex;flex-direction:column;align-items:center;gap:.35rem;width:100%;margin:.5rem 0 0;padding:0}.game-team-stats-item{display:flex;align-items:flex-start;justify-content:center;gap:.35rem;font-size:.8rem;max-width:100%}.game-team-stats-icon{flex-shrink:0;margin-top:.05rem}.game-team-stats-icon-goal{color:var(--color-text)}.game-team-stats-icon-mom{color:#eab308}.game-team-stats-text{color:var(--color-text-muted);line-height:1.35;text-align:center;word-break:break-word}.game-team-stats-assist{display:inline-flex;align-items:center;gap:.2rem;margin-left:.25rem;color:var(--color-text-muted);font-size:.75rem}.game-actions-bar{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:.25rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.btn-icon{padding:.5rem;min-width:2.75rem;min-height:2.75rem}.btn-icon-danger:hover:not(:disabled){color:var(--color-danger);background:var(--color-danger-muted)}.game-card-actions{display:flex;gap:.5rem;flex-shrink:0}.form-group{display:flex;flex-direction:column;gap:.4rem;margin-bottom:1.25rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-muted)}.form-group input,.form-group textarea{padding:.7rem .9rem;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);font-size:1rem;font-family:inherit;transition:border-color .15s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--color-primary)}.form-group textarea{min-height:100px;resize:vertical}.btn{display:inline-flex;align-items:center;justify-content:center;gap:.4rem;padding:.65rem 1.25rem;font-size:.95rem;font-weight:600;font-family:inherit;border:none;border-radius:var(--radius-sm);cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:var(--color-primary);color:#052e16}.btn-primary:hover:not(:disabled){background:var(--color-primary-hover)}.btn-secondary{background:var(--color-surface-hover);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-border)}.btn-danger{background:var(--color-danger-muted);color:var(--color-danger);border:1px solid transparent}.btn-danger:hover:not(:disabled){background:var(--color-danger);color:white}.btn-ghost{background:transparent;color:var(--color-text-muted);border:1px solid transparent}.btn-ghost:hover:not(:disabled){color:var(--color-text);background:var(--color-surface-hover)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:2rem}.auth-card{width:100%;max-width:420px}.auth-card h1{font-size:1.75rem;margin-bottom:.25rem}.auth-card .subtitle{color:var(--color-text-muted);margin-bottom:2rem}.auth-footer{margin-top:1.5rem;text-align:center;color:var(--color-text-muted);font-size:.9rem}.alert{padding:.75rem 1rem;border-radius:var(--radius-sm);font-size:.9rem;margin-bottom:1.25rem}.alert-error{background:var(--color-danger-muted);color:var(--color-danger);border:1px solid rgba(239,68,68,.3)}.empty-state{text-align:center;padding:3rem 1.5rem;color:var(--color-text-muted)}.empty-state p{margin-bottom:1.5rem}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:2rem}.loading{text-align:center;padding:3rem}.loading,.user-greeting{color:var(--color-text-muted)}.user-greeting{font-size:.9rem}.game-outcome{font-size:.8rem;font-weight:600;padding:.2rem .55rem;border-radius:var(--radius-sm)}.outcome-win{background:var(--color-primary-muted);color:var(--color-primary)}.outcome-loss{background:var(--color-danger-muted);color:var(--color-danger)}.outcome-draw{background:rgba(139,156,179,.15);color:var(--color-text-muted)}.game-context{margin-bottom:1.5rem;padding-bottom:1.25rem;border-bottom:1px solid var(--color-border)}.game-context p{margin-bottom:.35rem}.text-muted{color:var(--color-text-muted);font-size:.9rem}.score-inputs{display:flex;align-items:flex-end;gap:1rem}.score-inputs .form-group{flex:1 1}.score-separator{font-size:1.5rem;font-weight:700;color:var(--color-text-muted);padding-bottom:.65rem}.result-details-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--color-border)}.result-details-section .section-header{margin-bottom:1rem}.result-details-section .section-header h2{font-size:1.1rem;margin-bottom:.25rem}.card-nested{background:var(--color-bg-subtle,rgba(0,0,0,.03));border:1px solid var(--color-border);border-radius:8px;padding:1rem;margin-bottom:1rem}.goal-line-header{display:flex;align-items:center;justify-content:space-between}.goal-line-header,.participant-field{margin-bottom:.75rem}.participant-field-header{display:flex;align-items:center;justify-content:space-between;gap:.75rem;margin-bottom:.35rem}.participant-field-header label{font-weight:600;font-size:.9rem}.participant-toggle{display:flex;gap:.35rem}.participant-field input,.participant-field select{width:100%;padding:.55rem .75rem;border:1px solid var(--color-border);border-radius:6px;font-size:.95rem;background:var(--color-surface);color:var(--color-text)}.checkbox-label{display:flex;align-items:center;gap:.5rem;margin:.75rem 0;font-size:.95rem;cursor:pointer}.attendance-summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));grid-gap:1rem;gap:1rem;margin-bottom:1rem}.attendance-summary-card h3{font-size:.95rem;margin-bottom:.5rem;color:var(--color-text-muted)}.attendance-summary-highlight{border-color:var(--color-primary);box-shadow:0 0 0 1px var(--color-primary-muted)}.attendance-table-card{padding:0;overflow:hidden}.attendance-table-wrap{overflow-x:auto}.attendance-table{width:100%;border-collapse:collapse}.attendance-table td,.attendance-table th{padding:.85rem 1rem;text-align:left;border-bottom:1px solid var(--color-border)}.attendance-table th{font-size:.85rem;color:var(--color-text-muted);font-weight:600;background:rgba(0,0,0,.15)}.attendance-table select{width:100%;min-width:120px}.attendance-guest-badge{padding:.1rem .45rem;border-radius:var(--radius-sm);background:var(--color-primary-muted);color:var(--color-primary)}.attendance-guest-badge,.attendance-saving-badge{display:inline-block;margin-left:.5rem;font-size:.75rem}.attendance-saving-badge{color:var(--color-text-muted)}.attendance-add-guest{display:flex;gap:.75rem;flex-wrap:wrap}.attendance-add-guest input{flex:1 1;min-width:200px}.btn-sm{padding:.35rem .65rem;font-size:.85rem}.auth-card-wide{max-width:520px}.form-hint{margin-top:.75rem;font-size:.85rem;color:var(--color-text-muted)}.shield-cropper{display:flex;flex-direction:column;gap:1rem}.shield-crop-area{position:relative;width:100%;height:280px;background:var(--color-bg);border:1px solid var(--color-border);border-radius:var(--radius-md);overflow:hidden}.shield-preview{display:flex;justify-content:center}.shield-preview-image{width:120px;height:120px;object-fit:cover;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg)}.shield-actions{display:flex;flex-wrap:wrap;gap:.75rem;align-items:center}.opponent-select{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.opponent-select-new{padding:1rem;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg)}.opponent-card{display:flex;flex-direction:column;gap:1rem}.opponent-card-header{display:flex;align-items:center;gap:1rem}.opponent-card-info h3{margin-bottom:.25rem}@media (max-width:640px){.app-header{padding:1rem}.app-main{padding:1.25rem}.game-match-shield{width:52px;height:52px}.game-match-shield-placeholder{font-size:.95rem}.game-match-score{font-size:1.75rem}.game-match-team-name{font-size:.85rem}.game-match-center{min-width:3.5rem;padding-top:.5rem}.game-actions-bar{justify-content:space-around}.page-header{flex-direction:column}}.dashboard-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:1.25rem;gap:1.25rem}.dashboard-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow);overflow:hidden}.dashboard-card-link{display:block;color:inherit;text-decoration:none;transition:border-color .15s,transform .15s}.dashboard-card-link:hover{text-decoration:none;border-color:var(--color-primary);transform:translateY(-1px)}.dashboard-card-header{display:flex;align-items:center;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid var(--color-border);color:var(--color-text-muted)}.dashboard-card-header h2{flex:1 1;font-size:1rem;font-weight:600;color:var(--color-text)}.dashboard-card-hint{font-size:.8rem;color:var(--color-primary)}.dashboard-card-body{padding:1.25rem}.dashboard-card-empty{flex-direction:column;align-items:flex-start;gap:1rem}.dashboard-card-empty,.next-game-date{display:flex;color:var(--color-text-muted)}.next-game-date{gap:.4rem;font-size:.9rem}.next-game-compact,.next-game-date{align-items:center;margin-bottom:1rem}.next-game-compact{display:grid;grid-template-columns:1fr auto 1fr;grid-gap:.75rem;gap:.75rem}.next-game-team{display:flex;flex-direction:column;align-items:center;gap:.35rem;text-align:center}.next-game-shield{width:56px;height:56px;object-fit:contain}.next-game-shield-placeholder{display:flex;align-items:center;justify-content:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:.9rem;font-weight:700;color:var(--color-text-muted)}.next-game-team-name{font-size:.85rem;font-weight:600;line-height:1.2;max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.next-game-vs{font-size:1.1rem;font-weight:700;color:var(--color-text-muted)}.next-game-meta{display:flex;flex-wrap:wrap;gap:1rem;font-size:.85rem;color:var(--color-text-muted)}.next-game-meta span{display:inline-flex;align-items:center;gap:.35rem}.scorer-list{list-style:none;display:flex;flex-direction:column;gap:.5rem}.scorer-list-full{gap:.75rem}.scorer-row{gap:.75rem}.scorer-rank,.scorer-row{display:flex;align-items:center}.scorer-rank{justify-content:center;width:1.75rem;height:1.75rem;border-radius:50%;font-size:.8rem;font-weight:700;background:var(--color-surface-hover);color:var(--color-text-muted);flex-shrink:0}.scorer-rank-gold{background:rgba(234,179,8,.2);color:#eab308}.scorer-rank-silver{background:rgba(148,163,184,.2);color:#94a3b8}.scorer-rank-bronze{background:rgba(180,83,9,.2);color:#d97706}.scorer-info{flex:1 1;min-width:0}.scorer-name{font-weight:500}.scorer-jersey{margin-right:.35rem;color:var(--color-text-muted);font-weight:400}.scorer-goals{display:inline-flex;align-items:center;gap:.3rem;font-weight:700;color:var(--color-primary)}.game-card-focused{outline:2px solid var(--color-primary);box-shadow:0 0 0 4px var(--color-primary-muted)}@media (max-width:720px){.dashboard-grid{grid-template-columns:1fr}.next-game-shield{width:48px;height:48px}}