@import "https://fonts.googleapis.com/css2?family=Hanken+Grotesk:wght@400;500;600;700&family=Libre+Caslon+Text:ital,wght@0,400;0,700;1,400&display=swap";:root{--color-background:#fbf9f4;--color-surface:#fff;--color-surface-low:#f5f3ee;--color-surface-container:#f0eee9;--color-surface-high:#eae8e3;--color-surface-container-lowest:#fff;--color-surface-container-highest:#eae8e3;--color-text:#1b1c19;--color-text-muted:#414844;--color-primary:#012d1d;--color-primary-hover:#1b4332;--color-primary-light:#a5d0b9;--color-secondary:#a7373b;--color-tertiary:#222439;--color-outline:#717973;--color-outline-variant:#c1c8c2;--color-outline-subtle:#e4e2dd;--color-error:#ba1a1a;--color-error-bg:#ffdad6;--color-success:#012d1d;--font-display:"Libre Caslon Text", Georgia, "Times New Roman", serif;--font-body:"Hanken Grotesk", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--transition-fast:.15s cubic-bezier(.4, 0, .2, 1);--transition-normal:.25s cubic-bezier(.4, 0, .2, 1);--radius-sm:.25rem;--radius-md:.5rem;--radius-lg:1rem;--shadow-sm:3px 3px 0px #012d1d1f;--shadow-card:5px 5px 0px #012d1d26}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{background-color:var(--color-background);height:100%;color:var(--color-text);font-family:var(--font-body);-webkit-font-smoothing:antialiased;font-size:16px;line-height:1.5;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background)}::-webkit-scrollbar-thumb{background:var(--color-outline-variant);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}::selection{background-color:var(--color-primary);color:#fff}.app-header{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:2px solid var(--color-outline-subtle);background-color:#fbf9f4eb;width:100%;position:sticky;top:0}.dev-env-banner{color:#fff;letter-spacing:.12em;text-align:center;background-color:#b45309;justify-content:center;align-items:center;gap:6px;width:100%;padding:5px 16px;font-size:.7rem;font-weight:700;display:flex}.header-container{justify-content:space-between;align-items:center;max-width:1280px;height:64px;margin:0 auto;padding:0 24px;display:flex}.brand-logo{font-family:var(--font-display);color:var(--color-primary);letter-spacing:-.01em;transition:opacity var(--transition-fast);font-size:1.25rem;font-weight:700;text-decoration:none}.brand-logo:hover{opacity:.7}.header-actions{align-items:center;gap:8px;display:flex}.header-icon-btn{color:var(--color-text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast), background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:8px;display:flex}.header-icon-btn:hover{color:var(--color-primary);background-color:var(--color-surface-container)}.header-icon-btn svg{fill:currentColor;width:22px;height:22px}.main-viewport{background-color:var(--color-background);justify-content:center;align-items:center;min-height:calc(100vh - 64px);padding:40px 16px;display:flex;position:relative}.main-viewport:has(.dashboard-container){min-height:calc(100vh - 64px);padding:0;display:block}.kinetic-bg{background-image:radial-gradient(circle at 1px 1px,#012d1d0d 1px,#0000 0);background-size:24px 24px}.court-lines{pointer-events:none;opacity:.07;position:absolute;inset:0;overflow:hidden}.court-line-vertical{background-color:var(--color-primary);width:2px;height:100%;position:absolute;top:0;left:50%;transform:translate(-50%)}.court-line-horizontal{background-color:var(--color-primary);width:100%;height:2px;position:absolute;top:33.333%;left:0}.ambient-glow{background-color:var(--color-primary);opacity:.04;filter:blur(120px);pointer-events:none;border-radius:50%;width:400px;height:400px;position:absolute;top:20%;left:10%}.login-card{background-color:var(--color-surface);border:2px solid var(--color-tertiary);border-radius:var(--radius-md);z-index:10;width:100%;max-width:440px;box-shadow:var(--shadow-card);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);padding:40px;position:relative}.login-card.registration-card{max-width:520px}.login-card:before{content:"";background-color:var(--color-primary);border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;height:4px;position:absolute;top:0;left:0}.card-header{text-align:center;margin-bottom:32px}.card-title{font-family:var(--font-display);color:var(--color-primary);letter-spacing:-.02em;margin-bottom:6px;font-size:2rem;font-weight:700}.card-subtitle{color:var(--color-text-muted);font-size:.9rem}.brand-tagline{font-family:var(--font-body);color:var(--color-secondary);text-transform:uppercase;letter-spacing:.15em;margin-bottom:8px;font-size:.7rem;font-weight:600}.login-form{flex-direction:column;gap:20px;display:flex}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.form-group{flex-direction:column;gap:6px;display:flex}.form-label-row{justify-content:space-between;align-items:center;display:flex}.form-label{font-family:var(--font-body);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;transition:color var(--transition-fast);font-size:.7rem;font-weight:600}.form-link{font-family:var(--font-body);color:var(--color-primary);transition:color var(--transition-fast);font-size:.75rem;font-weight:500;text-decoration:none}.form-link:hover{color:var(--color-secondary);text-decoration:underline}.input-wrapper{align-items:center;display:flex;position:relative}.form-input{background-color:var(--color-surface-low);border:2px solid var(--color-outline-variant);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);color:var(--color-text);transition:border-color var(--transition-fast), background-color var(--transition-fast);padding:10px 14px;font-size:.95rem}.form-input::placeholder{color:var(--color-outline)}.form-input:focus{border-color:var(--color-primary);background-color:var(--color-surface);outline:none}.form-input:disabled{opacity:.6;cursor:not-allowed}.input-icon{fill:var(--color-outline);pointer-events:none;transition:fill var(--transition-fast);position:absolute;left:13px}.form-input.icon-padding{padding-left:42px}.input-wrapper:focus-within .input-icon{fill:var(--color-primary)}.password-toggle-btn{color:var(--color-outline);cursor:pointer;border-radius:var(--radius-sm);transition:color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;padding:4px;display:flex;position:absolute;right:10px}.password-toggle-btn:hover{color:var(--color-primary)}.password-toggle-btn svg{fill:currentColor;width:18px;height:18px}select.form-input.select-input{appearance:none;cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23717973'%3E%3Cpath d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;background-size:20px;padding-right:38px}select.form-input.select-input:invalid{color:var(--color-outline)}select.form-input.select-input option{background-color:var(--color-surface);color:var(--color-text)}.checkbox-container{cursor:pointer;color:var(--color-text-muted);-webkit-user-select:none;user-select:none;align-items:center;gap:10px;font-size:.85rem;display:flex}.checkbox-container input{opacity:0;cursor:pointer;width:0;height:0;position:absolute}.custom-checkbox{background-color:var(--color-surface-low);border:2px solid var(--color-outline-variant);border-radius:var(--radius-sm);width:18px;height:18px;transition:background-color var(--transition-fast), border-color var(--transition-fast);flex-shrink:0;position:relative}.checkbox-container:hover input~.custom-checkbox{border-color:var(--color-primary)}.checkbox-container input:checked~.custom-checkbox{background-color:var(--color-primary);border-color:var(--color-primary)}.custom-checkbox:after{content:"";display:none;position:absolute}.checkbox-container input:checked~.custom-checkbox:after{display:block}.checkbox-container .custom-checkbox:after{border:2px solid #fff;border-width:0 2px 2px 0;width:5px;height:9px;top:1px;left:4px;transform:rotate(45deg)}.submit-btn{background-color:var(--color-primary);color:#fff;border:none;border-bottom:3px solid var(--color-primary-hover);border-radius:var(--radius-sm);width:100%;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.1em;cursor:pointer;box-shadow:var(--shadow-sm);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;gap:8px;margin-top:4px;padding:13px;font-size:.8rem;font-weight:700;display:flex}.submit-btn:hover{background-color:var(--color-primary-hover)}.submit-btn:active{box-shadow:none;border-bottom-color:#0000;transform:translate(2px,2px)}.submit-btn:disabled{background-color:var(--color-outline-subtle);color:var(--color-outline);border-bottom-color:var(--color-outline-variant);box-shadow:none;cursor:not-allowed}.spinner{border:2px solid #ffffff40;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.75s linear infinite spin;display:none}.submit-btn.loading .spinner{display:block}.submit-btn.loading span{display:none}@keyframes spin{to{transform:rotate(360deg)}}.registration-prompt{text-align:center;color:var(--color-text-muted);margin-top:28px;font-size:.85rem}.registration-prompt a{color:var(--color-primary);transition:color var(--transition-fast);font-weight:700;text-decoration:none}.registration-prompt a:hover{color:var(--color-secondary);text-decoration:underline}.toast-container{z-index:1000;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background-color:var(--color-surface);border:2px solid var(--color-outline-subtle);border-left:4px solid var(--color-primary);border-radius:var(--radius-sm);box-shadow:var(--shadow-sm);color:var(--color-text);opacity:0;max-width:360px;animation:toast-slide-in var(--transition-normal) forwards;align-items:center;gap:12px;padding:12px 16px;font-size:.875rem;display:flex;transform:translateY(80px)}.toast.error{border-left-color:var(--color-error)}.toast.success{border-left-color:var(--color-primary)}@keyframes toast-slide-in{to{opacity:1;transform:translateY(0)}}@media (width<=580px){.form-row{grid-template-columns:1fr;gap:20px}}@media (width<=480px){.header-container{padding:0 16px}.login-card{box-shadow:none;border-left:none;border-right:none;border-radius:0;padding:28px 20px}.card-title{font-size:1.75rem}.toast-container{bottom:16px;left:16px;right:16px}.toast{max-width:100%}}.dashboard-container{background-color:var(--color-background);width:100%;min-height:100vh;display:flex}.profile-sidebar{background-color:var(--color-surface-low);border-right:2px solid var(--color-outline-subtle);z-index:50;flex-direction:column;width:260px;height:100vh;display:flex;position:sticky;top:0}.sidebar-header{border-bottom:2px solid var(--color-outline-subtle);padding:24px}.sidebar-logo{color:var(--color-primary);align-items:center;gap:12px;display:flex}.sidebar-logo svg{color:var(--color-primary);flex-shrink:0}.logo-title{font-family:var(--font-display);font-size:1.15rem;font-weight:700;line-height:1.2;display:block}.logo-subtitle{color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.1em;margin-top:2px;font-size:.7rem;display:block}.sidebar-nav{flex-direction:column;flex-grow:1;gap:8px;padding:24px 16px;display:flex}.nav-item{font-family:var(--font-body);color:var(--color-text-muted);border-radius:var(--radius-sm);cursor:pointer;text-align:left;transition:background-color var(--transition-fast), color var(--transition-fast);background:0 0;border:none;align-items:center;gap:12px;width:100%;padding:12px 16px;font-size:.95rem;font-weight:600;display:flex}.nav-item:hover{color:var(--color-primary);background-color:var(--color-surface-container)}.nav-item.active{background-color:var(--color-primary);color:#fff}.nav-divider{background-color:var(--color-outline-subtle);height:1px;margin:4px 0}.sidebar-footer{border-top:2px solid var(--color-outline-subtle);padding:24px 16px}.book-court-btn{background-color:var(--color-primary);color:#fff;border:none;border-bottom:3px solid var(--color-primary-hover);width:100%;font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;border-radius:var(--radius-sm);cursor:pointer;box-shadow:var(--shadow-sm);transition:background-color var(--transition-fast), transform var(--transition-fast);padding:12px;font-size:.8rem;font-weight:700}.book-court-btn:hover{background-color:var(--color-primary-hover)}.book-court-btn:active{box-shadow:none;transform:translate(1px,1px)}.profile-main-content{flex-direction:column;flex-grow:1;min-height:100vh;display:flex;overflow-x:hidden}.profile-header{background-color:var(--color-surface);border-bottom:2px solid var(--color-outline-subtle);z-index:40;justify-content:space-between;align-items:center;height:64px;padding:0 32px;display:flex;position:sticky;top:64px}@media (width>=769px){.profile-header:has(>.mobile-menu-toggle:only-child){display:none}}.mobile-menu-toggle{color:var(--color-primary);cursor:pointer;border-radius:var(--radius-sm);transition:background-color var(--transition-fast);background:0 0;border:none;justify-content:center;align-items:center;margin-right:12px;padding:8px;display:none}.mobile-menu-toggle:hover{background-color:var(--color-surface-container)}.mobile-menu-toggle svg{display:block}.profile-header .brand-logo{font-family:var(--font-display);color:var(--color-primary);font-size:1.4rem;font-weight:700}.header-nav{gap:32px;display:flex}.header-nav-link{font-family:var(--font-body);letter-spacing:.08em;color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast);padding:4px 0;font-size:.75rem;font-weight:700}.header-nav-link:hover{color:var(--color-primary)}.header-nav-link.active{color:var(--color-primary);border-bottom:2px solid var(--color-primary)}.header-search{background-color:var(--color-surface-low);border:2px solid var(--color-outline-variant);border-radius:var(--radius-sm);align-items:center;gap:8px;width:220px;padding:6px 12px;display:flex}.header-search svg{color:var(--color-outline);flex-shrink:0}.header-search input{width:100%;font-family:var(--font-body);color:var(--color-text);background:0 0;border:none;font-size:.85rem}.header-search input:focus{outline:none}.autocomplete-dropdown{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-sm);box-shadow:var(--shadow-card);z-index:10;max-height:200px;margin:4px 0 0;padding:0;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto}.autocomplete-item{cursor:pointer;border-bottom:1px solid var(--color-surface-container-highest);transition:background-color var(--transition-fast);justify-content:space-between;align-items:center;padding:10px 16px;display:flex}.autocomplete-item:last-child{border-bottom:none}.autocomplete-item:hover{background-color:var(--color-surface-low)}.header-right-icons{align-items:center;gap:16px;display:flex}.icon-btn{color:var(--color-text-muted);cursor:pointer;transition:color var(--transition-fast), background-color var(--transition-fast);background:0 0;border:none;border-radius:50%;align-items:center;padding:8px;display:flex}.icon-btn:hover{color:var(--color-primary);background-color:var(--color-surface-container)}.user-avatar-mini{border:2px solid var(--color-primary);cursor:pointer;width:36px;height:36px;box-shadow:var(--shadow-sm);transition:transform var(--transition-fast);border-radius:50%;overflow:hidden}.user-avatar-mini:hover{transform:scale(1.05)}.user-avatar-mini img{object-fit:cover;width:100%;height:100%}.profile-viewport{background-color:var(--color-background);flex-grow:1;justify-content:center;padding:40px;display:flex}.profile-content-container{width:100%}.profile-header-row{justify-content:space-between;align-items:flex-end;margin-bottom:28px;display:flex}.profile-breadcrumb{letter-spacing:.12em;color:var(--color-secondary);margin-bottom:6px;font-size:.7rem;font-weight:700;display:block}.profile-title{font-family:var(--font-display);color:var(--color-primary);letter-spacing:-.02em;font-size:2.6rem;font-weight:700;line-height:1.1}.profile-top-actions{gap:12px;display:flex}.profile-card{background-color:var(--color-surface);border:2px solid var(--color-tertiary);border-radius:var(--radius-md);box-shadow:var(--shadow-card);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);padding:48px;position:relative}.profile-card:before{content:"";background-color:var(--color-primary);border-radius:var(--radius-md) var(--radius-md) 0 0;width:100%;height:4px;position:absolute;top:0;left:0}.racket-watermark{color:var(--color-primary);opacity:.04;pointer-events:none;z-index:1;position:absolute;bottom:20px;right:20px}.profile-card-columns{z-index:2;grid-template-columns:200px 1fr;gap:48px;display:grid;position:relative}.profile-avatar-column{text-align:center;flex-direction:column;align-items:center;display:flex}.avatar-container{border:4px solid var(--color-primary);cursor:pointer;width:170px;height:170px;box-shadow:var(--shadow-sm);transition:transform var(--transition-normal);border-radius:50%;margin-bottom:24px;position:relative}.avatar-container:hover{transform:scale(1.02)}.avatar-container img{object-fit:cover;border-radius:50%;width:100%;height:100%}.avatar-edit-badge{background-color:var(--color-secondary);color:#fff;cursor:pointer;width:36px;height:36px;transition:background-color var(--transition-fast), transform var(--transition-fast);border:none;border-radius:50%;justify-content:center;align-items:center;display:flex;position:absolute;bottom:6px;right:6px;box-shadow:2px 2px #012d1d33}.avatar-edit-badge:hover{background-color:var(--color-primary-container);transform:scale(1.05)}.player-display-name{font-family:var(--font-display);color:var(--color-primary);letter-spacing:-.01em;margin-bottom:4px;font-size:1.6rem;font-weight:700}.player-member-since{color:var(--color-text-muted);letter-spacing:.08em;margin-bottom:16px;font-size:.7rem;font-weight:600;display:block}.player-rank-badge{background-color:var(--color-primary);color:#fff;letter-spacing:.05em;border-radius:50px;padding:6px 14px;font-size:.72rem;font-weight:700;box-shadow:2px 2px #012d1d26}.profile-fields-column{flex-direction:column;display:flex}.profile-form-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:32px;display:grid}.form-group.full-width{grid-column:span 2}.disabled-input{background-color:var(--color-surface-low);border-color:var(--color-outline-variant);color:var(--color-text-muted);cursor:not-allowed;opacity:.8}.slider-label-row,.textarea-label-row{justify-content:space-between;align-items:center;display:flex}.slider-value-display{color:var(--color-primary);background-color:var(--color-surface-container);border-radius:var(--radius-sm);padding:2px 8px;font-size:.8rem;font-weight:700}.char-counter{color:var(--color-text-muted);font-size:.75rem}.char-counter.warning{color:var(--color-secondary);font-weight:700}.form-textarea{resize:vertical;font-family:var(--font-body)}.range-slider-wrapper{margin-top:8px;padding-bottom:24px;position:relative}.form-range-input{-webkit-appearance:none;background:0 0;width:100%;margin:8px 0}.form-range-input:focus{outline:none}.form-range-input::-webkit-slider-runnable-track{cursor:pointer;background:var(--color-surface-container-high);border-radius:var(--radius-sm);border:1px solid var(--color-outline-variant);width:100%;height:6px}.form-range-input::-webkit-slider-thumb{background:var(--color-primary);border:2px solid var(--color-surface);cursor:pointer;-webkit-appearance:none;width:20px;height:20px;transition:background-color var(--transition-fast), transform var(--transition-fast);border-radius:50%;margin-top:-8px;box-shadow:2px 2px #012d1d33}.form-range-input::-webkit-slider-thumb:hover{background:var(--color-primary-hover);transform:scale(1.1)}.form-range-input::-moz-range-track{cursor:pointer;background:var(--color-surface-container-high);border-radius:var(--radius-sm);border:1px solid var(--color-outline-variant);width:100%;height:6px}.form-range-input::-moz-range-thumb{background:var(--color-primary);border:2px solid var(--color-surface);cursor:pointer;width:16px;height:16px;transition:background-color var(--transition-fast), transform var(--transition-fast);border-radius:50%;box-shadow:2px 2px #012d1d33}.form-range-input::-moz-range-thumb:hover{background:var(--color-primary-hover);transform:scale(1.1)}.slider-ticks{justify-content:space-between;margin-top:6px;padding:0 4px;display:flex}.slider-ticks span{color:var(--color-outline);font-size:.65rem;font-weight:600}.profile-form-buttons{border-bottom:2px dashed var(--color-outline-variant);gap:16px;padding-bottom:32px;display:flex}.password-change-section{margin-top:36px}.section-subtitle{letter-spacing:.1em;color:var(--color-secondary);margin-bottom:20px;font-size:.8rem;font-weight:700}.password-form-grid{grid-template-columns:1fr 1fr;gap:24px;margin-bottom:24px;display:grid}.password-form-buttons{display:flex}.profile-loading-container{background-color:var(--color-background);min-height:100vh;color:var(--color-primary);font-family:var(--font-body);flex-direction:column;justify-content:center;align-items:center;gap:16px;display:flex}.spinner.large{border-width:3px;border-top-color:var(--color-primary);width:44px;height:44px}.btn-primary{background-color:var(--color-primary);color:#fff;border:none;border-bottom:3px solid var(--color-primary-hover);border-radius:var(--radius-sm);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;box-shadow:var(--shadow-sm);transition:background-color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:12px 24px;font-size:.8rem;font-weight:700;display:inline-flex}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-primary:active{box-shadow:none;border-bottom-color:#0000;transform:translate(2px,2px)}.btn-primary:disabled{background-color:var(--color-outline-subtle);color:var(--color-outline);border-bottom-color:var(--color-outline-variant);box-shadow:none;cursor:not-allowed}.btn-secondary{background-color:var(--color-surface);color:var(--color-primary);border:2px solid var(--color-primary);border-bottom:4px solid var(--color-primary);border-radius:var(--radius-sm);font-family:var(--font-body);text-transform:uppercase;letter-spacing:.08em;cursor:pointer;box-shadow:var(--shadow-sm);transition:background-color var(--transition-fast), color var(--transition-fast), transform var(--transition-fast), box-shadow var(--transition-fast);justify-content:center;align-items:center;gap:8px;padding:10px 22px;font-size:.8rem;font-weight:700;display:inline-flex}.btn-secondary:hover{background-color:var(--color-surface-container)}.btn-secondary:active{box-shadow:none;border-bottom-width:2px;transform:translate(2px,2px)}.btn-secondary:disabled{background-color:var(--color-surface-low);color:var(--color-outline-variant);border-color:var(--color-outline-subtle);box-shadow:none;cursor:not-allowed}@media (width<=900px){.profile-card-columns{grid-template-columns:1fr;gap:36px}.profile-avatar-column{text-align:left;border-bottom:2px dashed var(--color-outline-variant);flex-direction:row;align-items:center;gap:24px;padding-bottom:28px}.avatar-container{width:120px;height:120px;margin-bottom:0}}@media (width<=768px){.mobile-menu-toggle{display:inline-flex}.profile-sidebar{z-index:150;will-change:transform;height:100vh;box-shadow:none;transition:transform .22s cubic-bezier(.16,1,.3,1);position:fixed;top:0;bottom:0;left:0;transform:translate(-100%)}.profile-sidebar.mobile-open{transform:translate(0);box-shadow:4px 0 24px #012d1d26}.sidebar-backdrop{z-index:140;animation:fadeIn var(--transition-fast);will-change:opacity;background-color:#012d1d66;position:fixed;inset:0}.profile-header{padding:0 16px}.profile-header .header-nav,.header-search{display:none}.profile-viewport{padding:24px 16px}.profile-card{padding:28px 20px}.admin-table-card{padding:16px 12px}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@media (width<=580px){.profile-header-row{flex-direction:column;align-items:flex-start;gap:16px}.profile-top-actions{width:100%}.profile-top-actions button{flex:1}.profile-avatar-column{text-align:center;flex-direction:column;gap:16px}.profile-form-grid{grid-template-columns:1fr}.form-group.full-width{grid-column:span 1}.password-form-grid{grid-template-columns:1fr}.profile-form-buttons{flex-direction:column}.profile-form-buttons button{width:100%}}.admin-stats-grid{grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:24px;margin-bottom:32px;display:grid}.stat-card{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:4px 4px 0px var(--color-primary);flex-direction:column;justify-content:center;align-items:flex-start;padding:24px;display:flex;position:relative;overflow:hidden}.stat-label{font-family:var(--font-body);color:var(--color-outline);letter-spacing:.05em;font-size:.75rem;font-weight:700}.stat-value{font-family:var(--font-display);color:var(--color-primary);margin-top:8px;font-size:2.5rem;font-weight:700}.admin-tables-grid{grid-template-columns:1fr;gap:24px;margin-bottom:40px;display:grid}.admin-table-card{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:4px 4px 0px var(--color-primary);transition:border-color var(--transition-fast), box-shadow var(--transition-fast);min-width:0;padding:24px}.admin-table-title{font-family:var(--font-display);color:var(--color-primary);border-bottom:2px solid var(--color-primary);letter-spacing:-.01em;margin-bottom:20px;padding-bottom:8px;font-size:1.1rem;font-weight:600}.table-responsive{-webkit-overflow-scrolling:touch;width:100%;overflow-x:auto}.admin-table{border-collapse:collapse;text-align:left;width:100%}.admin-table th{font-family:var(--font-body);text-transform:uppercase;color:var(--color-outline);border-bottom:2px solid var(--color-outline-variant);letter-spacing:.05em;white-space:nowrap;padding:12px 8px;font-size:.7rem;font-weight:700}.admin-table td{font-family:var(--font-body);color:var(--color-on-background);border-bottom:1px solid var(--color-surface-container-highest);vertical-align:middle;white-space:nowrap;padding:14px 8px;font-size:.85rem}.admin-table tr:last-child td{border-bottom:none}.admin-table .bold-cell{color:var(--color-primary);font-weight:600}.admin-table tbody tr.clickable-row{cursor:pointer;transition:background-color var(--transition-fast)}.admin-table tbody tr.clickable-row:hover{background-color:var(--color-surface-low)}.admin-table .empty-cell{text-align:center;color:var(--color-outline);padding:32px 8px}.club-logo-mini{border-radius:var(--radius-full);object-fit:cover;border:2px solid var(--color-primary);width:32px;height:32px}.club-logo-fallback{border-radius:var(--radius-full);background-color:var(--color-primary-fixed);width:32px;height:32px;color:var(--color-on-primary-fixed);border:2px solid var(--color-primary);justify-content:center;align-items:center;font-size:.75rem;font-weight:700;display:flex}.club-badge{border-radius:var(--radius-full);background-color:var(--color-surface-container-high);color:var(--color-primary);border:1px solid var(--color-outline-variant);padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-block}.admin-search-container{margin-bottom:24px}.admin-search-form{align-items:center;gap:16px;display:flex}.search-input-field{width:320px}.full-width-card{grid-column:span 2}@media (width<=1024px){.full-width-card{grid-column:span 1}}.admin-form-card{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:4px 4px 0px var(--color-primary);padding:32px}.form-actions-row{border-top:2px dashed var(--color-outline-variant);margin-top:32px;padding-top:24px}.superuser-selector-list{border:2px solid var(--color-primary);border-radius:var(--radius-sm);background-color:var(--color-surface-container-lowest);max-height:240px;margin-top:8px;overflow-y:auto;box-shadow:inset 2px 2px 4px #012d1d0d}.superuser-selector-item{border-bottom:1px solid var(--color-surface-container-highest);cursor:pointer;transition:background-color var(--transition-fast);align-items:center;gap:16px;padding:12px 16px;display:flex}.superuser-selector-item:last-child{border-bottom:none}.superuser-selector-item:hover{background-color:var(--color-surface-container-low)}.superuser-selector-item.selected{background-color:var(--color-surface-container)}.superuser-item-details{flex-direction:column;flex-grow:1;display:flex}.superuser-item-name{font-family:var(--font-body);color:var(--color-primary);font-size:.95rem;font-weight:600}.superuser-item-email{font-family:var(--font-body);color:var(--color-outline);font-size:.8rem}.superuser-item-club{font-family:var(--font-body);color:var(--color-outline);margin-top:2px;font-size:.75rem;font-style:italic}.vintage-checkbox{width:18px;height:18px;accent-color:var(--color-primary);cursor:pointer}.superuser-role-badge{border-radius:var(--radius-full);letter-spacing:.05em;padding:2px 8px;font-size:.65rem;font-weight:700;display:inline-block}.superuser-role-badge.superuser{background-color:var(--color-primary-fixed);color:var(--color-on-primary-fixed);border:1px solid var(--color-primary)}.superuser-role-badge.user{background-color:var(--color-surface-container-high);color:var(--color-outline);border:1px solid var(--color-outline-variant)}.superuser-role-badge.admin{background-color:var(--color-secondary-fixed);color:var(--color-on-secondary-fixed);border:1px solid var(--color-secondary)}.field-hint-text{color:var(--color-outline);margin-bottom:8px;font-size:.8rem;display:block}.table-action-btn{padding:4px 12px;font-size:.75rem}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1100;animation:fadeIn var(--transition-fast);background-color:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-dialog{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-md);width:90%;max-width:480px;box-shadow:6px 6px 0px var(--color-primary);animation:slideUp var(--transition-fast);padding:32px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@media (width>=769px){.mobile-cards-view{display:none!important}}@media (width<=768px){.desktop-table-view{display:none!important}.mobile-cards-view{flex-direction:column;gap:16px;width:100%;display:flex}.mobile-match-card{background-color:var(--color-surface-container-lowest);border:2px solid var(--color-primary);border-radius:var(--radius-md);box-shadow:var(--shadow-sm);cursor:pointer;transition:transform var(--transition-fast), box-shadow var(--transition-fast);flex-direction:column;gap:12px;padding:16px;display:flex}.mobile-match-card:hover,.mobile-match-card:active{box-shadow:4px 4px 0px var(--color-primary);transform:translateY(-2px)}.mobile-match-header{justify-content:space-between;align-items:flex-start;display:flex}.mobile-match-players{color:var(--color-text);padding-right:8px;font-size:1.05rem;font-weight:700;line-height:1.3}.mobile-match-details{color:var(--color-text-muted);border-left:3px solid var(--color-primary-light);flex-direction:column;gap:6px;padding-left:10px;font-size:.85rem;display:flex}.mobile-match-score{color:var(--color-primary);background-color:var(--color-surface-low);border-radius:var(--radius-sm);border:1px dashed var(--color-outline-variant);text-align:center;letter-spacing:.02em;padding:8px 12px;font-size:.9rem;font-weight:700}.mobile-match-actions{border-top:1px dashed var(--color-outline-variant);justify-content:flex-end;gap:10px;margin-top:4px;padding-top:12px;display:flex}.match-details-grid{grid-template-columns:1fr!important;gap:24px!important}.match-details-left-col{border-bottom:1px dashed var(--color-outline-variant);padding-bottom:24px;border-right:none!important;padding-right:0!important}.admin-form-card{padding:20px 16px!important}}@media (prefers-color-scheme:dark){:root:not([data-theme=light]){--color-background:#0d1a11;--color-surface:#132016;--color-surface-low:#0e1b13;--color-surface-container:#172a1c;--color-surface-high:#1d3223;--color-surface-container-lowest:#0d1a11;--color-surface-container-highest:#1d3223;--color-text:#e0ede5;--color-text-muted:#8ca898;--color-primary:#c8d0cc;--color-primary-hover:#b8c2be;--color-primary-light:#2a3d32;--color-secondary:#c47878;--color-tertiary:#7880a8;--color-outline:#4a6e5a;--color-outline-variant:#253d2e;--color-outline-subtle:#162418;--color-error:#ff8080;--color-error-bg:#3d1010;--color-success:#c8d0cc;--shadow-sm:3px 3px 0px #00000073;--shadow-card:5px 5px 0px #0000008c}html:not([data-theme=light]) .app-header{background-color:#0d1a11eb}html:not([data-theme=light]) .kinetic-bg{background-image:radial-gradient(circle at 1px 1px,#6b9e820d 1px,#0000 0)}html:not([data-theme=light]) .sidebar-backdrop{background-color:#000000a6}html:not([data-theme=light]) .profile-sidebar.mobile-open{box-shadow:4px 0 24px #0000008c}html:not([data-theme=light]) .avatar-edit-badge{box-shadow:2px 2px #00000073}html:not([data-theme=light]) .player-rank-badge{box-shadow:2px 2px #00000059}html:not([data-theme=light]) .form-range-input::-webkit-slider-thumb{box-shadow:2px 2px #00000073}html:not([data-theme=light]) .form-range-input::-moz-range-thumb{box-shadow:2px 2px #00000073}html:not([data-theme=light]) .superuser-selector-list{box-shadow:inset 2px 2px 4px #00000040}html:not([data-theme=light]) .btn-primary,html:not([data-theme=light]) .btn-primary:hover,html:not([data-theme=light]) .submit-btn,html:not([data-theme=light]) .submit-btn:hover,html:not([data-theme=light]) .book-court-btn,html:not([data-theme=light]) .book-court-btn:hover,html:not([data-theme=light]) .nav-item.active{color:var(--color-background)}}:root[data-theme=dark]{--color-background:#0d1a11;--color-surface:#132016;--color-surface-low:#0e1b13;--color-surface-container:#172a1c;--color-surface-high:#1d3223;--color-surface-container-lowest:#0d1a11;--color-surface-container-highest:#1d3223;--color-text:#e0ede5;--color-text-muted:#8ca898;--color-primary:#c8d0cc;--color-primary-hover:#b8c2be;--color-primary-light:#2a3d32;--color-secondary:#c47878;--color-tertiary:#7880a8;--color-outline:#4a6e5a;--color-outline-variant:#253d2e;--color-outline-subtle:#162418;--color-error:#ff8080;--color-error-bg:#3d1010;--color-success:#c8d0cc;--shadow-sm:3px 3px 0px #00000073;--shadow-card:5px 5px 0px #0000008c}html[data-theme=dark] .app-header{background-color:#0d1a11eb}html[data-theme=dark] .kinetic-bg{background-image:radial-gradient(circle at 1px 1px,#6b9e820d 1px,#0000 0)}html[data-theme=dark] .sidebar-backdrop{background-color:#000000a6}html[data-theme=dark] .profile-sidebar.mobile-open{box-shadow:4px 0 24px #0000008c}html[data-theme=dark] .avatar-edit-badge{box-shadow:2px 2px #00000073}html[data-theme=dark] .player-rank-badge{box-shadow:2px 2px #00000059}html[data-theme=dark] .form-range-input::-webkit-slider-thumb{box-shadow:2px 2px #00000073}html[data-theme=dark] .form-range-input::-moz-range-thumb{box-shadow:2px 2px #00000073}html[data-theme=dark] .superuser-selector-list{box-shadow:inset 2px 2px 4px #00000040}html[data-theme=dark] .btn-primary,html[data-theme=dark] .btn-primary:hover,html[data-theme=dark] .submit-btn,html[data-theme=dark] .submit-btn:hover,html[data-theme=dark] .book-court-btn,html[data-theme=dark] .book-court-btn:hover,html[data-theme=dark] .nav-item.active{color:var(--color-background)}.dashboard-stats-grid{grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:24px;display:grid}.dashboard-breakdown-grid{grid-template-columns:1fr 1fr;gap:16px;margin-bottom:32px;display:grid}.dashboard-breakdown-stats{gap:24px;display:flex}@media (width<=768px){.dashboard-stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.dashboard-stats-grid .stat-card{box-shadow:2px 2px 0px var(--color-primary);padding:14px 16px}.dashboard-stats-grid .stat-value{margin-top:4px;font-size:2rem}.dashboard-stats-grid .stat-label{font-size:.68rem}.dashboard-breakdown-grid{grid-template-columns:1fr;gap:16px}.dashboard-breakdown-stats{flex-wrap:wrap;gap:16px}}@media (width<=480px){.dashboard-breakdown-stats{justify-content:space-between}}.event-actions-header{border-bottom:2px solid var(--color-outline-variant);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;margin-bottom:20px;padding-bottom:12px;display:flex}.event-actions-header-title{border:none;margin:0;padding:0}.event-actions-header-btns{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.event-action-bar{background-color:var(--color-surface-container);border:2px solid var(--color-outline-variant);border-radius:var(--radius-md);justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;padding:12px 20px;display:flex}.event-action-bar-status{flex-direction:column;gap:4px;display:flex}.event-action-bar-status-label{letter-spacing:.1em;text-transform:uppercase;color:var(--color-outline);font-size:.68rem;font-weight:700}.event-action-bar-btns{flex-wrap:wrap;align-items:center;gap:10px;display:flex}.event-info-grid{grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:20px;display:grid}.event-info-label{text-transform:uppercase;letter-spacing:.08em;color:var(--color-outline);margin-bottom:6px;font-size:.72rem;font-weight:700}.event-details-grid{grid-template-columns:3fr 2fr;gap:24px;display:grid}.planned-match-row{background-color:var(--color-surface-container-lowest);border:1px solid var(--color-outline-variant);border-radius:var(--radius-sm);justify-content:space-between;align-items:center;padding:12px 16px;display:flex}.planned-match-info{flex-direction:column;gap:4px;display:flex}.planned-match-court{color:var(--color-outline);font-size:.75rem;font-weight:600}.planned-match-teams{flex-wrap:wrap;align-items:center;gap:8px;font-size:.95rem;display:flex}.planned-match-status{flex-shrink:0;align-items:center;gap:16px;display:flex}.completed-match-row{background-color:var(--color-surface-low);border:1px solid var(--color-outline-variant);border-radius:var(--radius-sm);opacity:.95;align-items:center;gap:12px;padding:6px 12px;display:flex}.completed-match-left{flex:1;align-items:center;gap:10px;min-width:0;display:flex}.completed-match-court{color:var(--color-outline);white-space:nowrap;flex-shrink:0;font-size:.7rem;font-weight:600}.completed-match-teams{flex-direction:column;flex:1;gap:2px;min-width:0;font-size:.85rem;display:flex}.completed-match-vs{color:var(--color-outline);text-transform:uppercase;letter-spacing:.05em;align-self:flex-start;font-size:.7rem}.completed-match-right{flex-shrink:0;align-items:center;gap:8px;margin-left:auto;display:flex}.completed-match-score{color:var(--color-primary);background-color:var(--color-surface-container-low);border:1px solid var(--color-outline-variant);white-space:nowrap;border-radius:4px;align-items:center;gap:4px;padding:2px 8px;font-size:.95rem;font-weight:700;display:flex}.completed-match-score-sep{color:var(--color-outline);font-size:.75rem}.completed-match-edit-btn{color:var(--color-primary);cursor:pointer;white-space:nowrap;background:0 0;border:none;padding:2px 6px;font-size:.75rem;font-weight:600}@media (width<=768px){.event-details-grid{grid-template-columns:1fr}.event-actions-header-btns,.event-action-bar-btns{justify-content:flex-start;width:100%}.event-actions-header-btns .btn-secondary,.event-actions-header-btns .btn-primary,.event-action-bar-btns .btn-secondary,.event-action-bar-btns .btn-primary{text-align:center;white-space:nowrap;flex:1;min-width:0}.event-action-bar{flex-direction:column;align-items:flex-start}.event-info-grid{grid-template-columns:repeat(2,1fr);gap:14px}.planned-match-row{flex-direction:column;align-items:flex-start;gap:8px;padding:14px}.planned-match-status{align-self:flex-end}.planned-match-teams{white-space:normal;font-size:.9rem}.completed-match-row{padding:8px 12px}.completed-match-right{align-self:flex-start;margin-top:2px}}@media (width<=400px){.event-info-grid{grid-template-columns:1fr}.event-actions-header-btns .btn-secondary,.event-actions-header-btns .btn-primary{padding:8px 10px;font-size:.78rem}}@keyframes banner-pulse{0%,to{opacity:.55;transform:scale(1)}50%{opacity:.9;transform:scale(1.08)}}@keyframes banner-shimmer{0%{background-position:-200%}to{background-position:200%}}.event-signup-banner{border:2px solid var(--color-primary);background:var(--color-surface-container);box-shadow:4px 4px 0px var(--color-primary);border-radius:16px;width:fit-content;min-width:260px;max-width:420px;transition:box-shadow .2s,transform .2s;position:relative;overflow:hidden}.event-signup-banner:hover{box-shadow:6px 6px 0px var(--color-primary);transform:translateY(-2px)}.event-signup-banner-dismiss{z-index:10;border:1px solid var(--color-outline-variant);background:var(--color-surface-container-high);width:28px;height:28px;color:var(--color-outline);cursor:pointer;opacity:.5;border-radius:50%;justify-content:center;align-items:center;padding:0;font-size:1.1rem;line-height:1;transition:opacity .15s,background .15s,color .15s;display:flex;position:absolute;top:10px;right:10px}.event-signup-banner-dismiss:hover{opacity:1;background:var(--color-error,#c62828);color:#fff;border-color:#0000}.event-signup-banner-glow{background:radial-gradient(circle, var(--color-primary) 0%, transparent 70%);opacity:.08;pointer-events:none;border-radius:50%;width:200px;height:200px;animation:3s ease-in-out infinite banner-pulse;position:absolute;top:-60px;right:-60px}.event-signup-banner-inner{flex-direction:column;gap:0;padding:20px;display:flex;position:relative}.event-signup-banner-label{letter-spacing:.14em;color:var(--color-primary);text-transform:uppercase;text-align:center;margin-bottom:14px;font-size:.65rem;font-weight:800}.event-signup-banner-icon{background:var(--color-surface-container-low);border-radius:12px;justify-content:center;align-items:center;width:100%;min-height:80px;margin-bottom:16px;font-size:5rem;display:flex;overflow:hidden}.event-signup-banner-body{flex-direction:column;display:flex}.event-signup-banner-title{color:var(--color-text);margin-bottom:16px;font-size:1.4rem;font-weight:800;line-height:1.2}.event-signup-banner-meta{color:var(--color-text);flex-direction:column;gap:10px;margin-bottom:20px;font-size:.9rem;display:flex}.event-signup-banner-meta span{align-items:center;gap:10px;line-height:1.3;display:flex}.event-signup-banner-ics-btn{color:var(--color-outline);border:1px solid var(--color-outline-subtle);cursor:pointer;letter-spacing:.02em;background:0 0;border-radius:6px;align-items:center;gap:6px;margin-bottom:10px;padding:6px 12px;font-size:.75rem;font-weight:600;text-decoration:none;transition:border-color .15s,color .15s;display:inline-flex}.event-signup-banner-ics-btn:hover{border-color:var(--color-outline);color:var(--color-text)}.event-signup-banner-btn{letter-spacing:.08em;background-color:var(--color-primary);color:#fff;cursor:pointer;white-space:nowrap;border:none;border-radius:10px;flex:1;justify-content:center;align-items:center;padding:14px 20px;font-size:.9rem;font-weight:800;transition:opacity .15s;display:inline-flex}.event-signup-banner-btn:hover:not(:disabled){opacity:.88}.event-signup-banner-btn:disabled{opacity:.6;cursor:not-allowed}.event-signup-banner-actions{align-items:stretch;gap:10px;display:flex}.event-signup-banner-share-btn{letter-spacing:.05em;background:var(--color-surface-container-high);color:var(--color-outline);border:1px solid var(--color-outline-variant);cursor:pointer;white-space:nowrap;border-radius:10px;justify-content:center;align-items:center;gap:5px;padding:12px 14px;font-size:.8rem;font-weight:700;transition:background .15s;display:inline-flex}.event-signup-banner-share-btn:hover{background:var(--color-outline-variant);color:var(--color-text)}.event-signup-banner-joined{color:var(--color-primary);border:2px solid var(--color-primary);background-color:#012d1d1a;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:8px;padding:13px 20px;font-size:.88rem;font-weight:700;display:flex}.event-signup-banner-joined span{font-size:1.1rem;font-weight:900}.event-signup-banner--joined{border-color:var(--color-outline-variant);box-shadow:none;opacity:.82}.event-signup-banner--joined:hover{box-shadow:2px 2px 0px var(--color-outline-variant);opacity:1;transform:none}.event-signup-banner--joined .event-signup-banner-glow{display:none}.event-signup-banner--joined .event-signup-banner-inner{padding:14px 16px}.event-signup-banner--joined .event-signup-banner-icon{border-radius:8px;max-width:80px;max-height:80px;font-size:2.2rem}.event-signup-banner--joined .event-signup-banner-title{margin-bottom:10px;font-size:1rem}.event-signup-banner--joined .event-signup-banner-meta{gap:6px;margin-bottom:14px;font-size:.82rem}.dashboard-analytics-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:24px;margin-bottom:32px;display:grid}.analytics-card{flex-direction:column;justify-content:center;align-items:center;min-height:200px;padding:24px;display:flex}.analytics-card-title{color:var(--color-primary);text-transform:uppercase;letter-spacing:.08em;align-self:flex-start;margin-bottom:16px;font-size:.75rem;font-weight:700}.analytics-chart-wrapper{justify-content:center;align-items:center;width:100%;height:140px;display:flex}.no-chart-data{color:var(--color-outline);font-size:.85rem;font-style:italic}.doughnut-chart .chart-text-value{font-family:var(--font-display);font-size:18px;font-weight:800}.doughnut-chart .chart-text-label{font-family:var(--font-body);letter-spacing:.05em;font-size:6px;font-weight:700}.bar-chart-container{flex-direction:column;justify-content:center;width:100%;display:flex}.bar-row{width:100%}.bar-info{justify-content:space-between;margin-bottom:6px;font-size:.75rem;display:flex}.bar-label{color:var(--color-text);font-weight:700}.bar-val{color:var(--color-primary);font-weight:600}.bar-track{background-color:var(--color-surface-container);border-radius:4px;width:100%;height:8px;overflow:hidden}.bar-fill{background-color:var(--color-primary);border-radius:4px;height:100%;transition:width .8s ease-out}.chart-dot-group{cursor:pointer}.chart-dot-group circle{transition:r .15s ease-in-out}.chart-dot-group:hover circle{r:6}
