:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.5;font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{min-height:100vh}*{box-sizing:border-box;margin:0;padding:0}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:#0f0f1a;min-height:100vh;color:#fff}.app-layout{display:flex;min-height:100vh}.sidebar{width:290px;background:#1a1a2e;padding:24px;display:flex;flex-direction:column;border-right:1px solid #2a2a4a;position:sticky;top:0;height:100vh;overflow-y:auto}.sidebar-logo{display:flex;align-items:center;justify-content:center;margin-bottom:40px;padding-bottom:20px;border-bottom:1px solid #2a2a4a}.sidebar-logo .logo-img{max-width:100%;max-height:60px;object-fit:contain}.sidebar-nav{display:flex;flex-direction:column;gap:8px;flex:1}.nav-link{display:flex;align-items:center;gap:12px;padding:12px 16px;border-radius:10px;color:#88a;text-decoration:none;font-weight:500;transition:all .2s}.nav-link:hover{background:#2a2a4a;color:#fff}.nav-link.active{background:#4a90d9;color:#fff}.nav-link .icon{font-size:20px}.sidebar-footer{padding-top:20px;border-top:1px solid #2a2a4a}.sidebar-legal-links{display:flex;justify-content:center;align-items:center;gap:6px;margin-top:12px;font-size:12px}.sidebar-legal-links a{color:#668;text-decoration:none}.sidebar-legal-links a:hover{color:#88a}.legal-separator{color:#668}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.user-avatar{width:40px;height:40px;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px}.user-details{flex:1}.user-details .name{font-weight:600;font-size:14px;color:#fff}.user-details .email{font-size:12px;color:#88a}.whatsapp-link{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#25d36626;border:1px solid rgba(37,211,102,.3);border-radius:10px;color:#25d366;text-decoration:none;font-size:14px;font-weight:500;margin-bottom:12px;transition:all .2s ease}.whatsapp-link:hover{background:#25d36640;border-color:#25d36680}.whatsapp-icon{font-size:18px}.social-links{display:flex;align-items:center;justify-content:center;padding:12px 0;margin-bottom:12px}.social-icons{display:flex;gap:8px}.social-icon{display:flex;align-items:center;justify-content:center;width:36px;height:36px;border-radius:8px;text-decoration:none;transition:all .2s ease}.social-icon.whatsapp{background:#25d36626;color:#25d366}.social-icon.whatsapp:hover{background:#25d3664d}.social-icon.instagram{background:#e1306c26;color:#e1306c}.social-icon.instagram:hover{background:#e1306c4d}.main-content{flex:1;padding:32px;overflow-y:auto;min-width:0}.page-title{font-size:28px;font-weight:700;margin-bottom:8px;color:#fff}.page-subtitle{color:#88a;margin-bottom:32px}.card{background:#1a1a2e;border-radius:16px;padding:24px;border:1px solid #2a2a4a}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.card-title{font-size:18px;font-weight:600;color:#fff}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:20px;margin-bottom:32px}.stat-card{background:#1a1a2e;border-radius:16px;padding:24px;border:1px solid #2a2a4a}.stat-label{font-size:13px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.stat-value{font-size:24px;font-weight:700;color:#fff}.stat-value.highlight{color:#4a90d9}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.dashboard-card{background:#1a1a2e;padding:28px;border-radius:16px;border:1px solid #2a2a4a;text-decoration:none;color:inherit;transition:all .2s;display:flex;align-items:flex-start;gap:20px}.dashboard-card:hover{border-color:#4a90d9;transform:translateY(-2px)}.dashboard-card .card-icon{width:56px;height:56px;background:#2a2a4a;border-radius:14px;display:flex;align-items:center;justify-content:center;font-size:28px;flex-shrink:0}.dashboard-card .card-content h2{font-size:18px;margin-bottom:6px;color:#fff}.dashboard-card .card-content p{color:#88a;font-size:14px;line-height:1.5}.profile-header{display:flex;align-items:center;gap:24px;margin-bottom:32px;padding:32px;background:linear-gradient(135deg,#1a1a2e,#2a2a4a);border-radius:20px;border:1px solid #2a2a4a}.profile-avatar{width:100px;height:100px;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:20px;display:flex;align-items:center;justify-content:center;font-size:40px;font-weight:700}.profile-info h1{font-size:32px;margin-bottom:4px}.profile-info .member-id{color:#88a;font-size:14px;margin-bottom:12px}.profile-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.profile-section{background:#1a1a2e;border-radius:16px;padding:24px;border:1px solid #2a2a4a}.profile-section h2{font-size:16px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:20px;padding-bottom:12px;border-bottom:1px solid #2a2a4a}.section-hint{color:#88a;font-size:14px;margin-bottom:8px}.field-hint{color:#66a;font-size:12px;margin-top:4px}.checkbox-option{display:flex;align-items:center;gap:12px;cursor:pointer;color:#fff}.checkbox-option input[type=checkbox]{width:18px;height:18px;accent-color:#4a90d9;cursor:pointer}.success-text{color:#4ade80;font-size:14px;font-weight:500}.profile-field{display:flex;flex-direction:column;gap:6px;padding:16px 0;border-bottom:1px solid #2a2a4a}.profile-field:last-child{border-bottom:none}.profile-field .label{color:#88a;font-size:13px;text-transform:uppercase;letter-spacing:.5px}.profile-field .value{color:#fff;font-weight:500;font-size:16px;word-break:break-word}.profile-edit-form{display:flex;flex-direction:column;gap:12px}.profile-edit-row{display:flex;gap:12px}.profile-edit-row .form-group.compact{flex:1;margin-bottom:0}.profile-edit-row .form-group.compact label{font-size:12px;margin-bottom:4px}.profile-edit-row .form-group.compact input{padding:8px 12px;font-size:14px}.profile-edit-actions{display:flex;gap:8px;margin-top:4px}.btn-link{background:#4a90d91a;color:#4a90d9;padding:6px 12px;font-size:13px;border-radius:6px;border:1px solid rgba(74,144,217,.2)}.btn-link:hover{background:#4a90d933;border-color:#4a90d966}.profile-edit-btn{background:transparent;color:#88a;padding:4px 8px;font-size:13px;border:none;border-radius:4px;vertical-align:middle;margin-left:8px}.profile-edit-btn:hover{background:#4a90d926;color:#4a90d9}.profile-edit-btn svg{margin:0}.profile-name-row{display:flex;align-items:center;gap:8px}.profile-name-row h1{margin:0}.email-row{display:flex;align-items:center;gap:8px}.email-row .member-id{margin:0}.email-display{display:flex;flex-direction:column;gap:4px}.email-display .member-id{display:flex;align-items:center;margin-bottom:0}.pending-email-notice{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#eab30826;border:1px solid rgba(234,179,8,.3);border-radius:8px;font-size:13px;color:#eab308;margin-top:8px}.pending-email-notice span{flex:1}.status-badge{display:inline-block;padding:6px 14px;border-radius:20px;font-size:13px;font-weight:600}.status-badge.active{background:#22c55e33;color:#22c55e}.status-badge.inactive{background:#ef444433;color:#ef4444}button,.btn{padding:12px 24px;border:none;border-radius:10px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:8px;text-decoration:none}.btn-primary{background:#4a90d9;color:#fff}.btn-primary:hover{background:#357abd}.btn-secondary{background:#2a2a4a;color:#fff}.btn-secondary:hover{background:#3a3a5a}.btn-danger{background:#ef444433;color:#ef4444}.btn-danger:hover{background:#ef44444d}.btn-small{padding:8px 16px;font-size:13px}.btn-icon{padding:8px;min-width:32px}.btn-icon svg{margin:0}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:#0f0f1a;padding:20px}.login-card{background:#1a1a2e;padding:48px;border-radius:20px;border:1px solid #2a2a4a;width:100%;max-width:420px;text-align:center}.login-logo{max-width:200px;max-height:80px;object-fit:contain;margin-bottom:20px}.email-status-card{max-width:420px}.status-icon{width:64px;height:64px;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 20px}.status-icon svg{width:32px;height:32px}.status-icon-info{background:#4a90d926;color:#4a90d9}.status-icon-success{background:#22c55e26;color:#22c55e}.status-icon-error{background:#ef444426;color:#ef4444}.status-icon-loading{background:#4a90d926;color:#4a90d9}.status-icon-loading .spin{animation:spin 1.5s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.email-highlight{font-size:16px;font-weight:600;color:#4a90d9;margin:8px 0 20px;word-break:break-all}.email-instructions{background:#1a1a2e;border-radius:8px;padding:16px;margin-top:20px}.email-instructions p{margin:0;font-size:14px;color:#88a;line-height:1.5}.email-instructions .small-text{font-size:12px;margin-top:12px;color:#666}.invite-banner{display:flex;align-items:center;gap:10px;padding:14px 16px;background:#4a90d926;border:1px solid rgba(74,144,217,.3);border-radius:8px;margin-bottom:20px;color:#4a90d9;font-size:14px}.invite-success-notice{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#22c55e26;border:1px solid rgba(34,197,94,.3);border-radius:8px;margin:16px 0;color:#22c55e;font-size:14px}.invite-mode-toggle{display:flex;gap:0;margin:16px 0;border-radius:8px;overflow:hidden;border:1px solid #2a2a4a}.invite-mode-toggle .toggle-btn{flex:1;padding:10px 16px;background:#1a1a2e;border:none;color:#88a;font-size:13px;cursor:pointer;transition:all .2s}.invite-mode-toggle .toggle-btn:first-child{border-right:1px solid #2a2a4a}.invite-mode-toggle .toggle-btn.active{background:#4a90d9;color:#fff}.invite-mode-toggle .toggle-btn:hover:not(.active){background:#2a2a4a}.modal-hint{color:#88a;font-size:13px;margin:8px 0 0}.login-card .subtitle{color:#88a;margin-bottom:32px}.form-group{margin-bottom:20px;text-align:left}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:#88a;font-size:14px}.form-group input,.form-group textarea{width:100%;padding:14px 18px;background:#0f0f1a;border:2px solid #2a2a4a;border-radius:10px;font-size:16px;color:#fff;transition:border-color .2s;font-family:inherit}.form-group input::placeholder,.form-group textarea::placeholder{color:#5a5a7a}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#4a90d9}.form-group .form-hint,.form-group small.form-hint{display:block;margin-top:6px;font-size:12px;color:#6a6a8a}button[type=submit]{width:100%;padding:16px;background:#4a90d9;color:#fff;border:none;border-radius:10px;font-size:16px;font-weight:600;cursor:pointer;transition:background .2s;margin-top:8px;display:flex;align-items:center;justify-content:center}button[type=submit]:hover{background:#357abd}button[type=submit]:disabled{background:#2a2a4a;color:#5a5a7a;cursor:not-allowed}.error-message{background:#ef444426;color:#ef4444;padding:14px;border-radius:10px;margin-bottom:20px;text-align:center;border:1px solid rgba(239,68,68,.3)}.bookings-section{margin-bottom:32px}.section-title{font-size:18px;color:#88a;margin-bottom:16px;text-transform:uppercase;letter-spacing:.5px}.bookings-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.booking-card{background:#1a1a2e;border-radius:16px;border:1px solid #2a2a4a;overflow:hidden;transition:border-color .2s}.booking-card:hover{border-color:#4a90d9}.booking-card.past{opacity:.6}.booking-card.past:hover{border-color:#2a2a4a}.booking-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;background:#2a2a4a}.booking-status{padding:4px 12px;border-radius:20px;font-size:12px;font-weight:600;text-transform:uppercase}.booking-status.status-confirmed{background:#22c55e33;color:#22c55e}.booking-status.status-cancelled{background:#ef444433;color:#ef4444}.booking-ref{font-size:12px;color:#88a;font-family:monospace}.booking-main{padding:20px}.booking-court{font-size:22px;font-weight:700;color:#fff;margin-bottom:12px}.booking-datetime{display:flex;flex-direction:column;gap:4px}.booking-date{color:#4a90d9;font-weight:600;font-size:15px}.booking-time{color:#88a;font-size:14px}.booking-footer{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-top:1px solid #2a2a4a}.booking-site{color:#88a;font-size:14px}.booking-players{display:flex;flex-wrap:wrap;gap:8px;margin-top:16px;padding-top:16px;border-top:1px solid #2a2a4a}.player-badge{display:inline-flex;align-items:center;gap:6px;background:#2a2a4a;padding:6px 12px;border-radius:20px;font-size:13px;color:#fff}.player-badge .lead-indicator{background:#4a90d9;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;text-transform:uppercase}.filters{background:#1a1a2e;padding:24px;border-radius:16px;margin-bottom:24px;border:1px solid #2a2a4a;display:flex;gap:20px;align-items:flex-end}.filters .form-group{margin-bottom:0;min-width:200px}.form-group select{width:100%;padding:14px 18px;background:#0f0f1a;border:2px solid #2a2a4a;border-radius:10px;font-size:16px;color:#fff;transition:border-color .2s;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%238888aa' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10l-5 5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}.form-group select:focus{outline:none;border-color:#4a90d9}.form-group select option{background:#1a1a2e;color:#fff}.slots-table{background:#1a1a2e;border-radius:16px;border:1px solid #2a2a4a;overflow:hidden}.slots-header{display:flex;background:#2a2a4a;font-weight:600;font-size:14px}.slots-header .time-col{width:100px;padding:16px;color:#88a;text-transform:uppercase;letter-spacing:.5px}.slots-header .courts-col{display:flex;flex:1}.slots-header .court-header{flex:1;padding:16px 8px;text-align:center;color:#fff}.slots-body{max-height:600px;overflow-y:auto}.slots-row{display:flex;border-bottom:1px solid #2a2a4a}.slots-row:last-child{border-bottom:none}.slots-row .time-col{width:100px;padding:12px 16px;font-weight:600;color:#fff;display:flex;align-items:center;background:#2a2a4a4d}.slots-row .courts-col{display:flex;flex:1}.court-cell{flex:1;padding:8px;display:flex;align-items:center;justify-content:center;min-height:50px}.court-cell .unavailable{color:#5a5a7a;font-size:18px}.court-cell .btn{padding:8px 16px;font-size:13px}.availability-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:16px}.slot-card{background:#1a1a2e;padding:20px;border-radius:14px;text-align:center;border:1px solid #2a2a4a;transition:all .2s}.slot-card:hover{border-color:#4a90d9}.slot-time{font-size:24px;font-weight:700;color:#fff;margin-bottom:8px}.slot-info{color:#88a;font-size:14px;margin-bottom:16px}.tokens-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:20px}.token-card{background:#1a1a2e;padding:24px;border-radius:16px;border:1px solid #2a2a4a}.token-card.full-width{grid-column:span 2}.token-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.token-card h3{margin:0;color:#fff;font-size:16px}.token-info{color:#88a;font-size:13px;margin-bottom:16px}.token-value{background:#0f0f1a;padding:16px;border-radius:10px;font-family:SF Mono,Monaco,monospace;font-size:12px;word-break:break-all;max-height:140px;overflow-y:auto;color:#4a90d9;border:1px solid #2a2a4a}.code-block{background:#0f0f1a;color:#88a;padding:20px;border-radius:10px;font-family:SF Mono,Monaco,monospace;font-size:13px;overflow-x:auto;white-space:pre-wrap;word-break:break-all;border:1px solid #2a2a4a}.loading,.loading-screen{display:flex;align-items:center;justify-content:center;padding:60px;color:#88a;font-size:16px}.empty-state{text-align:center;padding:80px 40px;background:#1a1a2e;border-radius:16px;border:1px solid #2a2a4a}.empty-state p{color:#88a;margin-bottom:20px;font-size:16px}.empty-state-hint{color:#6a6a8a;font-size:14px;margin-top:-10px}.empty-hint{color:#5a5a7a;font-size:14px;padding:16px;text-align:center;background:#0f0f1a;border-radius:8px;border:1px dashed #2a2a4a}.teams-list{display:flex;flex-direction:column;gap:8px}.team-row-inline{display:flex;align-items:center;gap:8px}.team-row-inline select{flex:1}.team-separator{color:#88a;font-weight:600}.page-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:32px}.page-header .page-title{margin-bottom:8px}.page-header .page-subtitle{margin-bottom:0}.header-actions{display:flex;gap:12px}.schedules-container{display:flex;flex-direction:column;gap:32px}.schedule-day-group{background:#1a1a2e;border-radius:16px;padding:24px;border:1px solid #2a2a4a}.day-title{font-size:18px;font-weight:600;color:#4a90d9;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #2a2a4a}.schedules-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px}.schedule-card{background:#0f0f1a;border-radius:14px;border:1px solid #2a2a4a;overflow:hidden;transition:border-color .2s}.schedule-card:hover{border-color:#4a90d9}.schedule-card.disabled{opacity:.6}.schedule-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;background:#2a2a4a}.schedule-status{padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.schedule-status.active{background:#22c55e33;color:#22c55e}.schedule-status.inactive{background:#ef444433;color:#ef4444}.schedule-day{font-size:13px;color:#88a;font-weight:500}.schedule-main{padding:18px}.schedule-date{font-size:15px;font-weight:600;color:#88a;margin-bottom:4px}.schedule-time{font-size:28px;font-weight:700;color:#4a90d9;margin-bottom:8px}.schedule-court{font-size:18px;font-weight:600;color:#fff;margin-bottom:4px}.schedule-type{color:#88a;font-size:14px}.schedule-booked{background:#22c55e33;color:#22c55e;padding:4px 12px;border-radius:20px;font-size:11px;font-weight:600;text-transform:uppercase}.schedule-log{padding:12px 18px;background:#2a2a4a4d;border-top:1px solid #2a2a4a}.schedule-log .log-label{font-size:11px;color:#5a5a7a;text-transform:uppercase;margin-bottom:4px}.schedule-log .log-time{font-size:12px;color:#88a;margin-bottom:4px}.schedule-log .log-error{font-size:12px;color:#ef4444;word-break:break-word}.schedule-log .log-success{font-size:12px;color:#22c55e}.schedule-actions{display:flex;gap:8px;padding:14px 18px;border-top:1px solid #2a2a4a}.schedule-actions .btn{flex:1 1 0;min-width:0;justify-content:center;text-align:center}.schedule-form-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow:hidden;touch-action:none}.schedule-form{background:#1a1a2e;border-radius:20px;padding:32px;width:100%;max-width:400px;max-height:85vh;overflow-x:hidden;overflow-y:auto;border:1px solid #2a2a4a;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.schedule-form input[type=date]{max-width:100%;box-sizing:border-box}.schedule-form h3{font-size:22px;margin-bottom:24px;color:#fff}.schedule-form .form-group{margin-bottom:20px}.schedule-form .form-actions{display:flex;gap:12px;margin-top:28px}.schedule-form .form-actions .btn{flex:1 1 0;min-width:0;justify-content:center;text-align:center}.schedule-info-box{background:#0f0f1a;border:1px solid #2a2a4a;border-radius:12px;padding:16px;margin-bottom:24px}.schedule-info-box .info-row{display:flex;flex-direction:column;gap:4px;padding:10px 0}.schedule-info-box .info-row:not(:last-child){border-bottom:1px solid #2a2a4a}.schedule-info-box .info-label{color:#88a;font-size:13px}.schedule-info-box .info-value{color:#fff;font-weight:500;font-size:14px}.schedule-info-box .info-row.highlight,.schedule-info-box .info-row.success,.schedule-info-box .info-row.pending,.schedule-info-box .info-row.error{margin:8px -16px -16px;padding:12px 16px;border-radius:0 0 12px 12px;border-bottom:none}.schedule-info-box .info-row.success{background:#22c55e1a}.schedule-info-box .info-row.success .info-value{color:#22c55e;font-weight:600}.schedule-info-box .info-row.pending{background:#eab3081a}.schedule-info-box .info-row.pending .info-value{color:#eab308;font-weight:600}.schedule-info-box .info-row.error{background:#ef44441a}.schedule-info-box .info-row.error .info-value{color:#ef4444;font-weight:600}.form-group input[type=date]{width:100%;padding:14px 18px;background:#0f0f1a;border:2px solid #2a2a4a;border-radius:10px;font-size:16px;color:#fff;transition:border-color .2s}.form-group input[type=date]:focus{outline:none;border-color:#4a90d9}.form-group input[type=date]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.league-section{margin-bottom:32px}.league-section:last-child{margin-bottom:0}.section-title{font-size:18px;font-weight:600;color:#fff;margin-bottom:16px;padding-bottom:8px;border-bottom:1px solid #2a2a4a}.leagues-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.league-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:16px;padding:20px;cursor:pointer;transition:all .2s}.league-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:16px;flex-wrap:wrap}.league-header h3{margin:0;color:#fff;font-size:18px;flex:1;min-width:0;word-wrap:break-word}.league-level{background:#2a2a4a;padding:4px 12px;border-radius:12px;font-size:12px;color:#88a}.league-standings{margin-bottom:16px}.standing-row-mini{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:8px;margin-bottom:4px}.standing-row-mini.promotion{background:#22c55e1a}.standing-row-mini.relegation{background:#ef44441a}.standing-row-mini .position{font-size:18px;width:28px}.standing-row-mini .name{flex:1;color:#fff;font-weight:500}.standing-row-mini .points{font-weight:600;color:#4a90d9}.league-club{font-size:12px;color:#88a;margin:4px 0 8px}.league-card-actions{display:flex;gap:8px;margin-top:16px}.league-card-actions .btn-secondary{flex:1}.league-card-actions .btn-danger{padding:8px 10px}.standings-table{width:100%;border-collapse:collapse;margin-top:16px}.standings-table th{text-align:left;padding:12px;background:#2a2a4a;color:#88a;font-size:12px;text-transform:uppercase}.standings-table th:first-child{border-radius:8px 0 0 8px}.standings-table th:last-child{border-radius:0 8px 8px 0}.standings-table td{padding:12px;border-bottom:1px solid #2a2a4a;color:#fff}.standings-table tr.promotion-zone{background:#22c55e1a}.standings-table tr.promotion-zone td:first-child{border-left:3px solid #22c55e}.standings-table tr.relegation-zone{background:#ef44441a}.standings-table tr.relegation-zone td:first-child{border-left:3px solid #ef4444}.zone-legend{display:flex;gap:20px;margin:16px 0;font-size:13px}.zone-item{display:flex;align-items:center;gap:8px}.zone-item.promotion{color:#22c55e}.zone-item.relegation{color:#ef4444}.league-detail-grid{display:grid;grid-template-columns:1fr 1fr;gap:32px}@media(max-width:900px){.league-detail-grid{grid-template-columns:1fr}}.standings-section,.matches-section{background:#1a1a2e;border-radius:16px;padding:24px;border:1px solid #2a2a4a}.standings-section h2,.matches-section h2{margin:0 0 16px;color:#fff;font-size:18px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.section-header h2{margin:0}.members-admin{margin-top:24px;padding-top:24px;border-top:1px solid #2a2a4a}.members-admin h4{color:#88a;font-size:13px;margin-bottom:12px;text-transform:uppercase}.members-list{display:flex;flex-direction:column;gap:8px}.member-row{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#0f0f1a;border-radius:8px;color:#fff}.matches-list{display:flex;flex-direction:column;gap:12px}.match-card{display:flex;flex-direction:column;gap:10px;padding:14px 16px;background:#0f0f1a;border-radius:10px;border:1px solid #2a2a4a}.match-card.match-completed{border-color:#22c55e33}.match-header{display:flex;align-items:center;gap:12px}.match-date{color:#88a;font-size:13px;min-width:80px;flex-shrink:0}.match-players{display:flex;align-items:center;gap:8px;flex:1;color:#fff;font-size:14px;flex-wrap:wrap}.match-players .vs{color:#5a5a7a;font-size:12px}.match-players .winner{color:#22c55e;font-weight:600}.match-contacts-row{display:flex;flex-wrap:wrap;gap:16px;padding:8px 0;border-top:1px solid #2a2a4a}.match-contact-player{display:flex;align-items:center;gap:6px}.contact-player-name{color:#88a;font-size:12px}.contact-icons{display:flex;align-items:center;gap:4px}.contact-icon{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:6px;transition:all .2s ease}.contact-icon.contact-whatsapp{color:#25d366;background:#25d36615}.contact-icon.contact-whatsapp:hover{background:#25d36630}.contact-icon.contact-sms{color:#4a90d9;background:#4a90d915}.contact-icon.contact-sms:hover{background:#4a90d930}.match-footer{display:flex;align-items:center;gap:12px}.match-score{font-weight:600;color:#4a90d9;font-size:14px}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.badge-secondary{background:#2a2a4a;color:#88a}.badge-primary{background:#4a90d933;color:#4a90d9}.badge-owner{background:#eab30833;color:#eab308}.badge-info{background:#4a90d933;color:#4a90d9}.badge-warning{background:#eab30833;color:#eab308}.badge-success{background:#22c55e33;color:#22c55e}.badge-danger{background:#ef444433;color:#ef4444}.badge-doubles{background:#a855f733;color:#a855f7}.badge-padel{background:#fb923c33;color:#fb923c}.badge-member{background:#3b82f633;color:#3b82f6}.club-card.member{border-color:#3b82f64d}.club-badges{display:flex;gap:6px;flex-wrap:wrap}.league-filters{display:flex;gap:8px;margin-bottom:24px;flex-wrap:wrap}@media(max-width:768px){.league-filters{position:sticky;top:0;background:#0a0a14;margin:0 -16px 16px;padding:12px 16px;z-index:100;border-bottom:1px solid #2a2a4a}}.filter-btn{background:#1a1a2e;border:1px solid #2a2a4a;color:#88a;padding:10px 20px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.filter-btn:hover{background:#2a2a4a;color:#fff}.filter-btn.active{background:#4a90d9;border-color:#4a90d9;color:#fff}.badge-singles{background:#4a90d933;color:#4a90d9}.league-badges{display:flex;gap:8px;align-items:center}.team-builder{display:flex;flex-direction:column;gap:16px}.team-row{display:flex;flex-direction:column;gap:12px;padding:16px;background:#0f0f1a;border-radius:10px;border:1px solid #2a2a4a}.team-row-header{display:flex;justify-content:space-between;align-items:center}.team-number{font-weight:600;color:#88a;font-size:13px}.team-players{display:flex;align-items:center;gap:10px}.team-players select{flex:1;min-width:0}.team-separator{color:#88a;font-weight:600;flex-shrink:0}.team-row-footer{display:flex;justify-content:space-between;align-items:center;gap:12px}.team-preview{background:#a855f726;color:#a855f7;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:500}.team-preview-box{background:#a855f71a;border:1px solid rgba(168,85,247,.3);border-radius:8px;padding:12px 16px;margin-bottom:16px;color:#a855f7;font-size:14px}.match-card-full .partner{color:#a855f7;font-size:13px;margin:0 0 4px}.modal-large{max-width:700px}.modal-xlarge{max-width:800px}.tabs{display:flex;gap:8px;border-bottom:2px solid #2a2a4a;margin-bottom:24px;padding-bottom:0}.tabs button{padding:12px 20px;background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;font-weight:500;color:#88a;margin-bottom:-2px;transition:all .2s;font-size:14px}.tabs button:hover{color:#fff}.tabs button.active{color:#4a90d9;border-bottom-color:#4a90d9}.modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px;overflow:hidden;touch-action:none}.modal-content{background:#1a1a2e;padding:32px;border-radius:20px;max-width:500px;width:100%;border:1px solid #2a2a4a;max-height:85vh;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain;touch-action:pan-y}.modal-content h3{margin:0 0 24px;color:#fff;font-size:20px}.modal-content .form-group{margin-bottom:20px}.modal-content .form-group label{margin-bottom:10px}.match-context{color:#88a;margin-bottom:24px}.form-actions{display:flex;gap:12px;margin-top:24px}.form-actions .btn{flex:1 1 0;min-width:0;justify-content:center;text-align:center}.end-season-info{margin-bottom:24px}.end-season-info ul{list-style:none;padding:0;margin:16px 0}.end-season-info li{padding:8px 0;color:#ccc}.end-season-info .warning-text{color:#ef4444;font-weight:500;margin-top:16px}.season-results{margin-bottom:24px}.season-results .next-season{font-size:16px;color:#ccc;margin-bottom:20px}.season-results h4{color:#fff;margin:0 0 12px;font-size:14px;text-transform:uppercase;letter-spacing:.5px}.movements-list{display:flex;flex-direction:column;gap:8px}.movement-item{display:flex;align-items:center;gap:12px;padding:12px;border-radius:8px;background:#0f0f1a}.movement-item.promotion{border-left:3px solid #22c55e}.movement-item.relegation{border-left:3px solid #ef4444}.movement-icon{font-size:18px}.movement-player{flex:1;color:#fff;font-weight:500}.movement-detail{color:#88a;font-size:13px}.no-movements{color:#88a;text-align:center;padding:20px}.score-inputs{display:flex;flex-direction:column;gap:12px}.set-input{display:flex;align-items:center;gap:12px}.set-input span:first-child{width:50px;color:#88a}.set-input input{width:60px;text-align:center;padding:10px}.tiebreak-input{display:flex;align-items:center;gap:12px;background:#8b5cf61a;border-left:3px solid #8b5cf6;margin-left:10px;padding:8px 12px;border-radius:0 8px 8px 0}.tiebreak-input span:first-child{width:70px;color:#8b5cf6;font-size:.9em}.tiebreak-input input{width:50px;text-align:center;padding:8px;font-size:.95em}.super-tiebreak-toggle{padding:12px 0;border-top:1px solid #2a2a4a;margin-top:4px}.super-tiebreak-toggle .checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:#88a;font-size:.9em}.super-tiebreak-toggle .checkbox-label:hover{color:#fff}.super-tiebreak-toggle input[type=checkbox]{width:18px;height:18px;accent-color:#8b5cf6;cursor:pointer}.outcome-options{display:flex;flex-direction:column;gap:10px}.outcome-options .radio-label{display:flex;align-items:center;gap:10px;cursor:pointer;color:#ccc;font-size:.95em;padding:8px 12px;border-radius:8px;background:#1a1a2e;border:1px solid #2a2a4a;transition:all .2s}.outcome-options .radio-label:hover{background:#2a2a4a;border-color:#4a4a6a}.outcome-options .radio-label:has(input:checked){background:#2a2a4a;border-color:#8b5cf6;color:#fff}.outcome-options input[type=radio]{width:18px;height:18px;accent-color:#8b5cf6;cursor:pointer}.outcome-hint{color:#88a;font-size:.85em;font-style:italic;margin-top:8px}.member-selector{max-height:250px;overflow-y:auto;border:1px solid #2a2a4a;border-radius:10px;background:#0f0f1a}.member-option{display:flex!important;align-items:center;gap:12px;padding:14px 18px;cursor:pointer;border-bottom:1px solid #2a2a4a;transition:background .2s}.member-option:last-child{border-bottom:none}.member-option:hover{background:#2a2a4a}.member-option.selected{background:#4a90d933}.member-option input[type=checkbox]{width:18px;height:18px;accent-color:#4a90d9;cursor:pointer;flex-shrink:0}.member-option span{color:#fff;flex:1}.member-option .phone{color:#88a;font-size:12px;margin-left:20px;flex-shrink:0}.member-option-info{display:flex;flex-direction:column;gap:2px}.member-option-name{color:#fff;font-weight:500}.member-option-email{color:#88a;font-size:13px}.section-header{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:16px}.section-header .section-title{margin-bottom:0}.add-members-list{max-height:400px;overflow-y:auto;border:1px solid #2a2a4a;border-radius:8px;margin-bottom:20px}.matches-list-full{display:flex;flex-direction:column;gap:16px}.match-card-full{background:#1a1a2e;border-radius:16px;padding:20px;border:1px solid #2a2a4a;display:flex;justify-content:space-between;align-items:center}.match-card-full .match-info h3{margin:0 0 4px;color:#4a90d9;font-size:13px}.match-card-full .opponent{margin:0 0 8px;color:#fff;font-size:18px;font-weight:600}.match-card-full .match-date{color:#88a;font-size:14px}.match-card-full .match-score-display{color:#22c55e;font-size:16px;font-weight:600;margin-top:8px}.match-card-full .match-winner{color:#88a;font-size:13px}.match-card-full .match-actions{display:flex;gap:10px}.contact-buttons{display:flex;flex-direction:column;gap:6px;margin:8px 0}.contact-row{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.contact-name{color:#88a;font-size:12px;min-width:60px}.contact-btn{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:6px;font-size:12px;text-decoration:none;transition:all .2s ease}.contact-whatsapp{background:#25d36626;color:#25d366;border:1px solid rgba(37,211,102,.3)}.contact-whatsapp:hover{background:#25d36640}.contact-sms{background:#4a90d926;color:#4a90d9;border:1px solid rgba(74,144,217,.3)}.contact-sms:hover{background:#4a90d940}.no-contact-hint{color:#66a;font-size:12px;font-style:italic;margin:8px 0}.league-name{color:#4a90d9;font-size:12px;margin:0 0 4px;text-transform:uppercase}.form-group input[type=datetime-local]{width:100%;padding:14px 18px;background:#0f0f1a;border:2px solid #2a2a4a;border-radius:10px;font-size:16px;color:#fff;transition:border-color .2s}.form-group input[type=datetime-local]:focus{outline:none;border-color:#4a90d9}.form-group input[type=datetime-local]::-webkit-calendar-picker-indicator{filter:invert(1);cursor:pointer}.impersonate-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(90deg,#f59e0b,#d97706);color:#000;padding:10px 20px;display:flex;justify-content:center;align-items:center;gap:20px;font-weight:600;z-index:1001}.impersonate-banner button{background:#0003;border:none;padding:6px 14px;border-radius:6px;cursor:pointer;font-weight:600;color:#000;transition:background .2s}.impersonate-banner button:hover{background:#0000004d}.app-layout:has(.impersonate-banner){padding-top:44px}.app-layout:has(.impersonate-banner) .sidebar{top:44px;height:calc(100vh - 44px)}.auth-tabs{display:flex;gap:0;margin-bottom:20px;background:#1a1a2e;border-radius:8px;padding:4px}.auth-tab{flex:1;padding:10px 16px;background:transparent;border:none;border-radius:6px;color:#888;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.auth-tab:hover{color:#fff}.auth-tab.active{background:#4a90d9;color:#fff}.form-row{display:flex;gap:12px}.form-row .form-group{flex:1}.auth-link{margin-top:20px;text-align:center;color:#888;font-size:14px}.auth-link a{color:#4a90d9;text-decoration:none;font-weight:500}.auth-link a:hover{text-decoration:underline}.forgot-link{display:block;text-align:center;margin-top:16px;color:#888;font-size:14px;text-decoration:none}.forgot-link:hover{color:#4a90d9}.dl-note{margin-top:20px;text-align:center;color:#666;font-size:13px}.nav-section{padding:12px 16px 6px;color:#666;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-top:10px}.dl-linked-status{display:flex;flex-direction:column;gap:10px}.dl-linked-status p{color:#88a;margin:0}.dl-profile-details{margin-top:20px;display:grid;gap:12px}.dl-not-linked{padding:20px;background:#1a1a2e;border-radius:8px;text-align:center}.dl-not-linked p{color:#88a;margin:0}.dl-not-linked .btn{display:inline-flex;width:auto}.login-footer{margin-top:32px;padding-top:20px;border-top:1px solid #2a2a4a;text-align:center}.login-footer a{color:#666;font-size:12px;text-decoration:none}.login-footer a:hover{color:#4a90d9}.privacy-note{margin-top:16px;font-size:12px;color:#666;text-align:center}.privacy-note a{color:#4a90d9;text-decoration:none}.privacy-note a:hover{text-decoration:underline}.privacy-container{min-height:100vh;background:#0f0f1a;padding:40px 20px}.privacy-content{max-width:720px;margin:0 auto;background:#1a1a2e;border-radius:12px;padding:40px;border:1px solid #2a2a4a}.privacy-content .back-link{display:inline-block;color:#4a90d9;text-decoration:none;font-size:14px;margin-bottom:24px}.privacy-content .back-link:hover{text-decoration:underline}.privacy-content h1{color:#fff;font-size:28px;margin-bottom:8px}.privacy-content .last-updated{color:#666;font-size:13px;margin-bottom:32px}.privacy-content section{margin-bottom:32px}.privacy-content h2{color:#fff;font-size:18px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid #2a2a4a}.privacy-content h3{color:#ddd;font-size:15px;margin:16px 0 8px}.privacy-content p{color:#aaa;font-size:14px;line-height:1.7;margin-bottom:12px}.privacy-content ul{color:#aaa;font-size:14px;line-height:1.7;margin-left:20px;margin-bottom:12px}.privacy-content li{margin-bottom:6px}.privacy-content strong{color:#ddd}.privacy-content .contact-email a{color:#4a90d9;font-size:16px;text-decoration:none}.privacy-content .contact-email a:hover{text-decoration:underline}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:60px;background:#1a1a2e;border-bottom:1px solid #2a2a4a;padding:0 16px;align-items:center;justify-content:space-between;z-index:100}.mobile-logo{height:36px;object-fit:contain}.mobile-avatar{width:36px;height:36px;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:8px;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.menu-toggle{background:none;border:none;padding:8px;cursor:pointer;display:flex;align-items:center;justify-content:center}.hamburger-icon{display:flex;flex-direction:column;gap:5px;width:24px}.hamburger-icon span{display:block;height:2px;background:#fff;border-radius:2px;transition:all .3s}.sidebar-overlay{display:none;position:fixed;inset:0;background:#0009;z-index:199}@media(max-width:768px){.mobile-header{display:flex}.app-layout{flex-direction:column}.app-layout:has(.impersonate-banner) .mobile-header{top:44px}.sidebar{position:fixed;top:0;left:-280px;width:280px;height:100vh;z-index:200;transition:left .3s ease;padding-top:20px;overflow-y:auto;-webkit-overflow-scrolling:touch;overscroll-behavior:contain}.sidebar.open{left:0}.sidebar-overlay{display:block}.app-layout:has(.impersonate-banner) .sidebar{top:44px;height:calc(100vh - 44px)}.main-content{padding:80px 16px 24px;margin-left:0}.app-layout:has(.impersonate-banner) .main-content{padding-top:124px}.page-header{flex-direction:column;align-items:flex-start;gap:16px}.header-actions{width:100%;flex-wrap:wrap}.header-actions .btn{flex:1;min-width:120px;justify-content:center}.page-title{font-size:24px}.page-subtitle{margin-bottom:24px}.stats-grid{grid-template-columns:repeat(2,1fr);gap:12px}.stat-card{padding:16px}.stat-value{font-size:20px}.dashboard-grid{grid-template-columns:1fr;gap:16px}.dashboard-card{padding:20px}.bookings-grid{grid-template-columns:1fr;gap:12px}.leagues-grid{grid-template-columns:1fr;gap:16px}.schedules-grid{grid-template-columns:1fr;gap:12px}.schedule-day-group{padding:16px}.profile-header{flex-direction:column;text-align:center;padding:24px 20px}.profile-avatar{width:80px;height:80px;font-size:32px}.profile-info h1{font-size:24px}.profile-name-row,.email-row{justify-content:center}.email-display{align-items:center}.profile-edit-form{text-align:left}.profile-grid{grid-template-columns:1fr}.profile-section{padding:20px}.tokens-grid{grid-template-columns:1fr}.token-card.full-width{grid-column:span 1}.filters{flex-direction:column;align-items:stretch;gap:16px;padding:20px}.filters .form-group{min-width:100%}.filters .btn{width:100%;justify-content:center}.slots-table{overflow-x:auto;-webkit-overflow-scrolling:touch}.slots-header,.slots-row{min-width:600px}.match-header{flex-direction:column;align-items:flex-start;gap:6px}.match-date{min-width:auto}.match-contacts-row{gap:10px}.match-contact-player{gap:4px}.contact-icon{width:28px;height:28px}.match-footer{flex-wrap:wrap;gap:8px}.match-card-full{flex-direction:column;align-items:flex-start;gap:16px}.match-card-full .match-actions{width:100%;flex-wrap:wrap}.match-card-full .match-actions .btn{flex:1;min-width:100px;justify-content:center}.standings-section{overflow-x:auto;-webkit-overflow-scrolling:touch}.standings-table{min-width:500px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch;gap:4px}.tabs button{padding:10px 14px;font-size:13px;white-space:nowrap}.modal-content{padding:24px 20px;margin:16px;max-width:calc(100% - 32px)}.schedule-form-overlay{padding:60px 16px 16px;align-items:flex-start}.schedule-form{padding:24px 16px;max-width:calc(100% - 32px);max-height:calc(100vh - 120px)}.schedule-form .form-group{max-width:100%;overflow:hidden}.schedule-form input,.schedule-form select{max-width:100%;width:100%;box-sizing:border-box}.form-actions{flex-direction:column}.form-actions .btn{width:100%}.schedule-actions{flex-direction:column}.zone-legend{flex-direction:column;gap:8px}.team-players{flex-direction:column}.team-players select{width:100%}.team-separator{align-self:center}.login-card{padding:32px 24px;margin:16px}.form-row{flex-direction:column;gap:0}.privacy-content{padding:24px 20px;margin:16px}.empty-state{padding:40px 20px}.impersonate-banner{flex-direction:column;gap:10px;padding:12px 16px;text-align:center}.booking-players{gap:6px}.player-badge{font-size:12px;padding:4px 10px}}@media(max-width:480px){.stats-grid{grid-template-columns:1fr}.stat-card{display:flex;justify-content:space-between;align-items:center;padding:14px 16px}.stat-label{margin-bottom:0}.stat-value{font-size:18px}.page-title{font-size:20px}.dashboard-card{padding:16px;gap:14px}.dashboard-card .card-icon{width:44px;height:44px;font-size:22px}.dashboard-card .card-content h2{font-size:16px}.dashboard-card .card-content p{font-size:13px}.schedule-time{font-size:24px}.schedule-court{font-size:16px}.booking-court{font-size:18px}.league-header h3{font-size:16px}button,.btn{min-height:44px;padding:12px 20px}.btn-small{min-height:36px;padding:8px 14px}.tabs button{min-height:44px}.nav-link{padding:14px 16px;min-height:48px}.user-details .email{font-size:11px;word-break:break-all}.modal-content h3{font-size:18px}.card{padding:20px 16px}.section-title{font-size:16px}}body.sidebar-open{overflow:hidden;position:fixed;width:100%}.sidebar,.main-content,.mobile-header{transition:all .3s ease}@media(pointer:coarse){button,.btn,.nav-link,.tabs button{min-height:44px}.form-group input,.form-group select{min-height:48px;font-size:16px}}.admin-tabs{display:flex;gap:8px;margin-bottom:24px;border-bottom:1px solid #2a2a4a;padding-bottom:16px}.tab-btn{background:transparent;border:none;color:#88a;padding:12px 20px;border-radius:8px;cursor:pointer;font-weight:500;transition:all .2s}.tab-btn:hover{background:#2a2a4a;color:#fff}.tab-btn.active{background:#4a90d9;color:#fff}.admin-section{background:#1a1a2e;border-radius:12px;padding:24px}.admin-section h2{font-size:18px;margin-bottom:8px}.admin-section .section-hint{color:#88a;font-size:14px;margin-bottom:20px}.feature-list{display:flex;flex-direction:column;gap:12px}.feature-item{display:flex;align-items:center;justify-content:space-between;background:#0f0f1a;padding:20px;border-radius:10px;border:1px solid #2a2a4a}.feature-info h3{font-size:16px;margin-bottom:4px}.feature-info p{color:#88a;font-size:14px;margin-bottom:8px}.feature-key{font-family:monospace;background:#2a2a4a;padding:2px 8px;border-radius:4px;font-size:12px;color:#4a90d9}.toggle-switch{position:relative;display:inline-block;width:52px;height:28px;flex-shrink:0}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#2a2a4a;transition:.3s;border-radius:28px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:4px;bottom:4px;background-color:#fff;transition:.3s;border-radius:50%}.toggle-switch input:checked+.toggle-slider{background-color:#4a90d9}.toggle-switch input:checked+.toggle-slider:before{transform:translate(24px)}.toggle-switch input:disabled+.toggle-slider{opacity:.5;cursor:not-allowed}.users-list{display:flex;flex-direction:column;gap:8px}.user-item{display:flex;align-items:center;justify-content:space-between;background:#0f0f1a;padding:16px 20px;border-radius:10px;border:1px solid #2a2a4a}.user-item .user-info{display:flex;flex-direction:column;align-items:flex-start;gap:4px}.user-name{font-weight:500}.user-meta{font-size:12px;color:#6a6a8a}.user-email{color:#88a;font-size:13px}.user-badges{display:flex;gap:8px}.badge{padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.badge-dl{background:#2a4a2a;color:#4ade80}.badge-admin{background:#4a2a4a;color:#f472b6}.badge-mod{background:#2a3a4a;color:#60a5fa}.impersonation-banner{display:flex;align-items:center;gap:12px;background:linear-gradient(90deg,#f59e0b20,#f59e0b10);border:1px solid #f59e0b;padding:12px 16px;border-radius:8px;margin-bottom:20px;color:#fbbf24}.impersonation-banner strong{color:#fcd34d}.impersonation-banner .btn{margin-left:auto;background:#f59e0b;color:#000;border:none}.impersonation-banner .btn:hover{background:#d97706}.user-actions{margin-left:auto}.user-actions .btn{display:flex;align-items:center;gap:6px}@media(max-width:768px){.admin-tabs{flex-wrap:wrap;gap:6px}.tab-btn{padding:8px 12px;font-size:13px;flex:1;min-width:calc(50% - 6px);justify-content:center}.admin-section{padding:16px}.admin-section h2{font-size:16px}.feature-item{flex-direction:column;align-items:flex-start;gap:12px}.feature-info{width:100%}.feature-info h3{font-size:14px}.feature-info p{font-size:13px}.toggle-switch{align-self:flex-end}.user-item{flex-direction:column;align-items:flex-start;gap:12px;padding:12px}.user-info{width:100%}.user-name{font-size:14px}.user-email{font-size:12px}.user-badges{flex-wrap:wrap;gap:6px}.user-badges .badge{font-size:10px;padding:3px 8px}.user-actions{margin-left:0;width:100%}.user-actions .btn{width:100%;justify-content:center}.feedback-stats{flex-wrap:wrap;gap:10px}.feedback-stat{flex:1;min-width:calc(33% - 10px);padding:12px}.feedback-stat .stat-value{font-size:18px}.feedback-item{padding:12px}.feedback-header{flex-direction:column;align-items:flex-start;gap:6px}.feedback-subject{font-size:14px}.feedback-preview{font-size:13px}.feedback-meta{flex-direction:column;gap:4px}.queue-admin-group{padding:12px}.queue-admin-header{flex-direction:column;align-items:flex-start;gap:8px}.queue-admin-entry{flex-direction:column;align-items:flex-start;gap:8px;padding:12px}.queue-entry-position{position:absolute;top:12px;right:12px}.queue-admin-entry{position:relative}.queue-entry-info{width:100%}.queue-entry-club{min-width:auto}.queue-entry-time{order:1}.queue-admin-entry .btn{width:100%;justify-content:center;margin-top:4px}.season-input-row{flex-direction:column;gap:10px}.season-input-row input,.season-input-row .btn{width:100%}.announcements-list{gap:12px}.announcement-item{padding:12px}.announcement-item-header{flex-direction:column;gap:12px}.announcement-item-info{flex-wrap:wrap}.announcement-item-info h3{font-size:14px;width:100%;order:1;margin-top:4px}.announcement-item-actions{width:100%;justify-content:flex-end}.announcement-item-content{font-size:13px}.announcement-item-meta{flex-wrap:wrap;gap:8px}}.tab-badge{background:#ef4444;color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;margin-left:6px}.feedback-stats{display:flex;gap:20px;margin-bottom:24px}.feedback-stat{display:flex;flex-direction:column;align-items:center;padding:16px 24px;background:#1a1a2e;border-radius:10px;border:1px solid #2a2a4a}.feedback-stat .stat-value{font-size:24px;font-weight:600;color:#fff}.feedback-stat .stat-label{font-size:12px;color:#88a;margin-top:4px}.feedback-item{padding:16px;background:#1a1a2e;border-radius:10px;border:1px solid #2a2a4a;cursor:pointer;transition:all .2s}.feedback-item:hover{border-color:#4a4a6a;background:#22223a}.feedback-item.selected{border-color:#4a90d9}.feedback-item.new{border-left:3px solid #ef4444}.feedback-item.read{border-left:3px solid #f59e0b}.feedback-item.replied{border-left:3px solid #22c55e}.feedback-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.feedback-name{font-weight:500;color:#fff}.feedback-status{font-size:11px;padding:3px 8px;border-radius:10px;text-transform:uppercase}.status-new{background:#ef444420;color:#ef4444}.status-read{background:#f59e0b20;color:#f59e0b}.status-replied{background:#22c55e20;color:#22c55e}.feedback-subject{font-weight:500;color:#ccc;margin-bottom:6px}.feedback-preview{font-size:13px;color:#88a;margin-bottom:10px;line-height:1.4}.feedback-meta{display:flex;justify-content:space-between;font-size:12px;color:#6a6a8a}.feedback-modal{max-width:600px}.feedback-detail-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.feedback-detail-header h3{margin:0}.feedback-detail-meta{display:flex;flex-wrap:wrap;gap:12px;font-size:13px;color:#88a;padding-bottom:16px;border-bottom:1px solid #2a2a4a;margin-bottom:16px}.feedback-detail-message{margin-bottom:20px}.feedback-detail-message h4,.feedback-detail-reply h4,.feedback-reply-form h4{font-size:14px;color:#88a;margin-bottom:8px}.feedback-detail-message p{white-space:pre-wrap;line-height:1.6;color:#fff}.feedback-detail-reply{background:#22c55e10;border:1px solid #22c55e30;padding:16px;border-radius:8px;margin-bottom:20px}.feedback-detail-reply p{white-space:pre-wrap;line-height:1.6;color:#fff}.feedback-detail-reply small{display:block;margin-top:12px;color:#6a6a8a;font-size:12px}.feedback-reply-form textarea{width:100%;min-height:100px;resize:vertical}.feedback-reply-form .form-actions{margin-top:16px}@media(max-width:768px){.feedback-stats{flex-wrap:wrap}.feedback-stat{flex:1;min-width:80px;padding:12px 16px}.feedback-meta{flex-direction:column;gap:4px}}.clubs-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.club-invites-section{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:20px;margin-bottom:24px}.club-invites-section h2{font-size:16px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px}.club-invites-list{display:flex;flex-direction:column;gap:12px}.club-invite-item{display:flex;align-items:center;justify-content:space-between;padding:16px;background:#4a90d91a;border:1px solid rgba(74,144,217,.3);border-radius:8px}.club-invite-info{display:flex;flex-direction:column;gap:4px}.club-invite-name{font-weight:600;font-size:16px;color:#fff}.club-invite-from{font-size:14px;color:#88a}.club-invite-city{font-size:13px;color:#66a}.club-invite-actions,.section-header-actions{display:flex;gap:8px}.clubs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(380px,1fr));gap:20px}.club-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;overflow:hidden;transition:border-color .2s,transform .2s}.club-card.clickable{cursor:pointer}.club-card.clickable:hover{border-color:#4a90d9;transform:translateY(-2px)}.club-card-header{padding:20px;border-bottom:1px solid #2a2a4a;display:flex;align-items:center;justify-content:space-between}.club-badges{display:flex;flex-wrap:nowrap;gap:6px;flex-shrink:0}.club-card-header h3{font-size:18px;font-weight:600}.club-card-body{padding:20px}.club-detail{display:flex;justify-content:space-between;margin-bottom:8px}.club-detail .label{color:#88a}.club-detail .value{font-weight:500}.club-stats{display:flex;gap:24px;margin-top:16px;padding-top:16px;border-top:1px solid #2a2a4a}.club-stats .stat{display:flex;flex-direction:column;align-items:center}.club-stats .stat-value{font-size:24px;font-weight:600;color:#4a90d9}.club-stats .stat-label{font-size:12px;color:#88a;margin-top:4px}.club-card-actions{padding:12px 16px;border-top:1px solid #2a2a4a;display:flex;flex-wrap:wrap;gap:6px}.club-card-actions .btn{font-size:12px;padding:6px 10px;white-space:nowrap}.feature-hint{background:#4a90d91a;border:1px solid rgba(74,144,217,.3);color:#88a;padding:16px 20px;border-radius:10px;margin-bottom:24px;font-size:14px}.members-list{display:flex;flex-direction:column;gap:8px;max-height:400px;overflow-y:auto}.member-item{display:flex;justify-content:space-between;align-items:center;background:#0f0f1a;padding:12px 16px;border-radius:8px;border:1px solid #2a2a4a}.member-info{display:flex;flex-direction:column;gap:4px}.member-name{font-weight:500}.member-email,.member-contact{color:#88a;font-size:13px}.club-selector{display:flex;align-items:center;gap:12px;margin-bottom:16px;padding:12px 16px;background:#1a1a2e;border:1px solid #2a2a4a;border-radius:10px}.club-selector label{color:#88a;font-size:14px;white-space:nowrap}.club-selector select{flex:1;max-width:300px;padding:8px 12px;background:#0f0f1a;border:1px solid #2a2a4a;border-radius:6px;color:#fff;font-size:14px}.club-selector select:focus{outline:none;border-color:#4a90d9}.stats-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:16px;margin-bottom:24px}.stats-row .stat-card{text-align:center;padding:20px 16px}.stats-row .stat-value{font-size:28px;font-weight:700;color:#4a90d9;margin-bottom:4px}.stats-row .stat-label{font-size:13px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:0}.stats-row .stat-card.stat-warning .stat-value{color:#ff9800}.stats-row-interactive{gap:12px}.stat-card-clickable{display:flex;align-items:center;gap:16px;cursor:pointer;transition:all .2s ease;text-align:left;border:1px solid #2a2a4a;background:#1a1a2e;position:relative}.stat-card-clickable:hover:not(:disabled){background:#252542;border-color:#4a90d9;transform:translateY(-2px)}.stat-card-clickable:disabled{opacity:.5;cursor:not-allowed}.stat-card-clickable .stat-icon{width:48px;height:48px;background:#4a90d926;border-radius:12px;display:flex;align-items:center;justify-content:center;color:#4a90d9;flex-shrink:0}.stat-card-clickable.stat-warning .stat-icon{background:#ff980026;color:#ff9800}.stat-card-clickable .stat-info{flex:1;min-width:0}.stat-card-clickable .stat-value{font-size:24px;font-weight:700;color:#fff;line-height:1.2}.stat-card-clickable .stat-label{font-size:13px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin:0}.stat-card-clickable .stat-badge{position:absolute;top:-6px;right:-6px;background:#ff9800;color:#000;font-size:12px;font-weight:700;min-width:22px;height:22px;border-radius:11px;display:flex;align-items:center;justify-content:center;padding:0 6px}.membership-banner{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:24px;margin-bottom:24px}.membership-banner .banner-pending,.membership-banner .banner-join{display:flex;align-items:center;justify-content:space-between;gap:16px}.membership-banner p{color:#c0c0d0;margin:0;font-size:15px}.membership-banner .banner-pending{border-left:4px solid #ff9800;margin:-24px -24px -24px 0;padding:24px 24px 24px 20px;background:#ff98000d;border-radius:0 12px 12px 0}.member-actions,.owner-actions{margin-bottom:24px;display:flex;gap:12px}.section{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:24px;margin-bottom:24px}.section-title{font-size:18px;font-weight:600;margin-bottom:20px;color:#fff}.requests-list{display:flex;flex-direction:column;gap:12px}.request-item{display:flex;justify-content:space-between;align-items:center;background:#0f0f1a;padding:16px;border-radius:8px;border:1px solid #2a2a4a}.request-info{display:flex;flex-direction:column;gap:4px}.request-date{font-size:12px;color:#666}.request-actions{display:flex;gap:8px}.leagues-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.league-card-link{text-decoration:none;color:inherit}.league-card{background:#0f0f1a;border:1px solid #2a2a4a;border-radius:10px;padding:20px;transition:all .2s;min-width:0}.league-card:hover{border-color:#4a90d9;transform:translateY(-2px)}.league-card h3{font-size:16px;font-weight:600;margin-bottom:12px;word-wrap:break-word;overflow-wrap:break-word}.league-badges{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.league-season{font-size:13px;color:#88a;margin:0}.league-card-wrapper{position:relative}.league-delete-btn{position:absolute;top:10px;right:10px;opacity:0;transition:opacity .2s;z-index:10}.league-card-wrapper:hover .league-delete-btn{opacity:1}.empty-state{color:#666;text-align:center;padding:32px;font-size:14px}@media(max-width:768px){.clubs-header{flex-direction:column;gap:16px}.clubs-header .btn{width:100%}.clubs-grid{grid-template-columns:1fr}.club-badges{flex-wrap:wrap}.club-card-actions{gap:6px}.club-card-actions .btn{flex:0 1 auto;min-width:auto}.club-selector{flex-direction:column;align-items:flex-start;gap:8px}.club-selector select{width:100%;max-width:none}.club-invite-item{flex-direction:column;gap:12px;align-items:flex-start}.club-invite-actions{width:100%;justify-content:flex-end}.section-header-actions{flex-wrap:wrap}.stats-row{grid-template-columns:repeat(2,1fr);gap:12px}.stats-row .stat-card{padding:16px 12px}.stats-row .stat-value{font-size:24px}.stat-card-clickable{padding:14px 12px;gap:12px}.stat-card-clickable .stat-icon{width:40px;height:40px}.stat-card-clickable .stat-icon svg{width:20px;height:20px}.stat-card-clickable .stat-value{font-size:20px}.stat-card-clickable .stat-label{font-size:11px}.membership-banner .banner-pending,.membership-banner .banner-join{flex-direction:column;align-items:flex-start}.membership-banner .banner-pending{margin:-24px;padding:20px;border-radius:0 0 12px 12px;border-left:none;border-top:4px solid #ff9800}.request-item{flex-direction:column;align-items:flex-start;gap:12px}.request-actions{width:100%}.request-actions .btn{flex:1}.member-item{flex-direction:column;align-items:flex-start;gap:12px}.leagues-grid{grid-template-columns:1fr}.club-stats{flex-wrap:wrap;gap:16px;justify-content:space-around}.club-stats .stat{flex:1;min-width:80px}}.landing-page{min-height:100vh;background:#0f0f1a}.landing-container{max-width:1200px;margin:0 auto;padding:0 24px}.landing-header{padding:20px 0;border-bottom:1px solid #2a2a4a;position:sticky;top:0;background:#0f0f1a;z-index:100}.landing-header .landing-container{display:flex;justify-content:space-between;align-items:center}.landing-logo{height:50px}.landing-nav{display:flex;gap:12px}.landing-hero{padding:80px 0;text-align:center;background:linear-gradient(180deg,#1a1a2e,#0f0f1a)}.hero-badge{display:inline-block;background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:8px 20px;border-radius:20px;font-size:14px;font-weight:600;margin-bottom:24px;text-transform:uppercase;letter-spacing:1px}.landing-hero h1{font-size:48px;font-weight:700;margin-bottom:20px;background:linear-gradient(135deg,#fff,#4a90d9);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.hero-subtitle{font-size:20px;color:#88a;max-width:600px;margin:0 auto 40px;line-height:1.6}.hero-cta{display:flex;flex-direction:column;align-items:center;gap:12px}.hero-hint{color:#88a;font-size:14px}.btn-large{padding:16px 48px;font-size:18px}.landing-features{padding:80px 0}.landing-features h2{text-align:center;font-size:36px;margin-bottom:48px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(260px,1fr));gap:24px;justify-content:center;max-width:900px;margin:0 auto}.feature-card{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:16px;padding:32px;text-align:center;transition:transform .2s,border-color .2s}.feature-card:hover{transform:translateY(-4px);border-color:#4a90d9}.feature-icon{font-size:48px;margin-bottom:16px}.feature-card h3{font-size:20px;margin-bottom:12px}.feature-card p{color:#88a;font-size:15px;line-height:1.6}.landing-formats{padding:80px 0;background:#1a1a2e}.landing-formats h2{text-align:center;font-size:36px;margin-bottom:48px}.formats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px;max-width:800px;margin:0 auto}.format-card{background:#0f0f1a;border:2px solid #2a2a4a;border-radius:16px;padding:32px 24px;text-align:center;transition:transform .2s,border-color .2s}.format-card:hover{transform:translateY(-4px)}.format-icon{margin-bottom:16px;display:flex;justify-content:center;align-items:center}.format-singles .format-icon{color:#4a90d9}.format-singles:hover{border-color:#4a90d9}.format-doubles .format-icon{color:#4caf50}.format-doubles:hover{border-color:#4caf50}.format-padel .format-icon{color:#ff9800}.format-padel:hover{border-color:#ff9800}.format-card h3{font-size:20px;margin-bottom:8px}.format-card p{color:#88a;font-size:14px;line-height:1.5}.landing-cta{padding:80px 0;text-align:center}.landing-cta h2{font-size:36px;margin-bottom:16px}.landing-cta p{color:#88a;font-size:18px;margin-bottom:32px}.landing-footer{padding:32px 0;border-top:1px solid #2a2a4a}.landing-footer .landing-container{display:flex;justify-content:space-between;align-items:center}.landing-footer p{color:#88a;font-size:14px}.footer-links{display:flex;flex-wrap:wrap;justify-content:flex-end;gap:16px 24px}.footer-links a{color:#88a;text-decoration:none;font-size:14px;transition:color .2s;display:inline-flex;align-items:center;gap:6px}.footer-links a:hover{color:#fff}.nav-link-text{color:#ccc;text-decoration:none;font-size:14px;font-weight:500;transition:all .2s;padding:10px 16px;border-radius:8px;display:flex;align-items:center;gap:6px}.nav-link-text:hover{color:#fff;background:#ffffff1a}.app-footer{margin-top:48px;padding:24px 0;border-top:1px solid #2a2a4a;text-align:center;font-size:13px}.app-footer a{color:#88a;text-decoration:none;transition:color .2s}.app-footer a:hover{color:#4a90d9}.app-footer .footer-divider{color:#3a3a5a;margin:0 12px}.dashboard-card-feedback{background:linear-gradient(135deg,#1a2a3a,#1a1a2e);border-color:#3a4a5a}.dashboard-card-feedback:hover{border-color:#4a90d9}.dashboard-card-feedback .card-icon{color:#4a90d9}@media(max-width:768px){.landing-hero{padding:48px 0}.landing-hero h1{font-size:32px}.hero-subtitle{font-size:16px}.landing-features,.landing-formats,.landing-cta{padding:48px 0}.landing-features h2,.landing-formats h2,.landing-cta h2{font-size:28px}.formats-grid{grid-template-columns:1fr;max-width:300px}.landing-footer .landing-container{flex-direction:column;gap:20px;text-align:center}.footer-links{justify-content:center;gap:12px 20px}.landing-header{padding:12px 0}.landing-header .landing-container{flex-direction:row;gap:12px}.landing-logo{height:36px}.landing-nav{gap:8px}.landing-nav .nav-link-text{display:none}.landing-nav .btn{padding:8px 12px;font-size:13px}}@media(max-width:480px){.landing-container{padding:0 16px}.landing-hero h1{font-size:26px}.hero-subtitle{font-size:15px}.btn-large{padding:14px 32px;font-size:16px}.footer-links{flex-direction:column;gap:12px}.footer-links a{justify-content:center}.landing-footer p{font-size:13px}}.onboarding-page{min-height:100vh;background:#0f0f1a;display:flex;align-items:center;justify-content:center;padding:24px}.onboarding-container{max-width:560px;width:100%}.onboarding-progress{display:flex;justify-content:center;gap:12px;margin-bottom:48px}.progress-step{width:36px;height:36px;border-radius:50%;background:#1a1a2e;border:2px solid #2a2a4a;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#88a;transition:all .3s}.progress-step.active{background:#4a90d9;border-color:#4a90d9;color:#fff}.progress-step.current{box-shadow:0 0 0 4px #4a90d933}.onboarding-step{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:20px;padding:48px 40px;text-align:center}.onboarding-icon{width:80px;height:80px;background:linear-gradient(135deg,#4a90d9,#357abd);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 24px;color:#fff}.onboarding-step h1{font-size:28px;margin-bottom:12px}.onboarding-subtitle{color:#88a;font-size:16px;line-height:1.6;margin-bottom:32px}.onboarding-highlights{display:flex;flex-direction:column;gap:12px;margin-bottom:32px}.highlight-item{display:flex;align-items:center;justify-content:center;gap:10px;color:#88a;font-size:15px}.highlight-item svg{color:#4a90d9}.onboarding-form{text-align:left;margin-bottom:24px}.onboarding-form .form-group{margin-bottom:20px}.onboarding-actions{display:flex;gap:12px;justify-content:center}.onboarding-actions .btn{min-width:140px}.btn-large{display:inline-flex;align-items:center;gap:8px}.how-it-works-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:32px;text-align:left}.how-card{background:#0f0f1a;border:1px solid #2a2a4a;border-radius:12px;padding:20px}.how-icon{width:48px;height:48px;background:#4a90d91a;border-radius:12px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;color:#4a90d9}.how-card h3{font-size:16px;margin-bottom:6px}.how-card p{color:#88a;font-size:13px;line-height:1.5}.queue-options{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;text-align:left}.queue-option{background:#0f0f1a;border:2px solid #2a2a4a;border-radius:12px;padding:20px;cursor:pointer;transition:all .2s}.queue-option:hover{border-color:#4a90d9}.queue-option.selected{border-color:#4a90d9;background:#4a90d91a}.queue-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.queue-option h3{font-size:16px;margin:0}.queue-count{font-size:13px;color:#4a90d9;background:#4a90d91a;padding:4px 10px;border-radius:20px}.queue-option p{color:#88a;font-size:14px;margin:0}.partner-selection{text-align:left;margin-bottom:24px}.partner-selection label{display:block;margin-bottom:8px;font-weight:500}.partner-selection select{width:100%;padding:12px 16px;background:#0f0f1a;border:1px solid #2a2a4a;border-radius:8px;color:#fff;font-size:15px}.partner-selection select:focus{outline:none;border-color:#4a90d9}.clubs-list-onboarding{display:flex;flex-direction:column;gap:12px;margin-bottom:24px;text-align:left;max-height:320px;overflow-y:auto}.onboarding-step .empty-state{padding:32px 24px;margin-bottom:16px}.club-option{display:flex;justify-content:space-between;align-items:center;background:#0f0f1a;border:2px solid #2a2a4a;border-radius:12px;padding:16px 20px;transition:all .2s}.club-option:hover{border-color:#3a3a5a}.club-option.joined{border-color:#4caf50;background:#4caf500d}.club-option-info{flex:1}.club-option-header{display:flex;align-items:center;gap:10px;margin-bottom:6px}.club-option-header h3{font-size:16px;font-weight:600;margin:0}.club-option-meta{display:flex;gap:16px;font-size:13px;color:#88a}.club-option-meta span{display:flex;align-items:center;gap:5px}.club-option-action{display:flex;align-items:center}.club-option-action .joined-icon{color:#4caf50}.club-option-action .pending-text{font-size:13px;color:#ff9800}.create-club-card{display:flex;align-items:center;gap:16px;background:transparent;border:2px dashed #4a90d9;border-radius:12px;padding:20px;margin-bottom:24px;cursor:pointer;transition:all .2s;text-align:left}.create-club-card:hover{background:#4a90d91a;border-color:#6aa8e8;transform:translateY(-2px)}.create-club-icon{display:flex;align-items:center;justify-content:center;width:48px;height:48px;background:#4a90d933;border-radius:12px;color:#4a90d9;flex-shrink:0}.create-club-content{flex:1}.create-club-content h3{margin:0 0 4px;font-size:16px;color:#fff}.create-club-content p{margin:0;font-size:14px;color:#88a}.create-club-arrow{color:#4a90d9;flex-shrink:0}@media(max-width:600px){.onboarding-step{padding:32px 24px}.onboarding-step h1{font-size:24px}.how-it-works-grid{grid-template-columns:1fr}.onboarding-actions{flex-direction:column}.onboarding-actions .btn{width:100%}.club-option{flex-direction:column;align-items:flex-start;gap:12px}.club-option-action,.club-option-action .btn{width:100%}.club-option-meta{flex-wrap:wrap;gap:12px}}.queue-section{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:16px;padding:24px;margin-bottom:32px}.queue-section h2{display:flex;align-items:center;gap:10px;font-size:20px;margin-bottom:8px}.queue-section .section-hint{color:#88a;font-size:14px;margin-bottom:20px}.queue-status-list{background:#0f0f1a;border-radius:12px;padding:16px;margin-bottom:20px}.queue-status-list h4{font-size:14px;color:#88a;margin-bottom:12px}.queue-status-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#1a1a2e;border-radius:8px;margin-bottom:8px}.queue-status-item:last-child{margin-bottom:0}.queue-status-item.partner{opacity:.7}.queue-status-info{display:flex;flex-direction:column;gap:4px}.queue-type{font-weight:600;font-size:15px}.queue-position{color:#4a90d9;font-size:13px}.queue-invites-list,.queue-pending-list{background:#0f0f1a;border-radius:12px;padding:16px;margin-bottom:20px}.queue-invites-list{border:2px solid #4a90d9;background:#4a90d90d}.queue-pending-list{border:2px solid #f59e0b;background:#f59e0b0d}.queue-invites-list h4,.queue-pending-list h4{font-size:14px;color:#88a;margin-bottom:12px}.queue-invite-item,.queue-pending-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#1a1a2e;border-radius:8px;margin-bottom:8px}.queue-invite-item:last-child,.queue-pending-item:last-child{margin-bottom:0}.queue-invite-info,.queue-pending-info{display:flex;flex-direction:column;gap:4px}.queue-invite-from,.queue-pending-type{font-weight:600;font-size:15px}.queue-invite-type,.queue-pending-partner{color:#88a;font-size:13px}.queue-invite-actions{display:flex;gap:8px}.queue-options-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;margin-bottom:20px}.queue-option-card{background:#0f0f1a;border:2px solid #2a2a4a;border-radius:12px;padding:16px;cursor:pointer;transition:all .2s}.queue-option-card:hover{border-color:#4a90d9}.queue-option-card.selected{border-color:#4a90d9;background:#4a90d91a}.queue-option-card .queue-option-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.queue-option-card h4{font-size:15px;margin:0}.queue-badge{font-size:12px;color:#4a90d9;background:#4a90d91a;padding:3px 8px;border-radius:12px}.queue-option-card p{color:#88a;font-size:13px;margin:0}.queue-partner-select{margin-bottom:16px}.queue-partner-select label{display:block;margin-bottom:8px;font-size:14px;font-weight:500}.queue-partner-select select{width:100%;max-width:300px;padding:10px 14px;background:#0f0f1a;border:1px solid #2a2a4a;border-radius:8px;color:#fff;font-size:14px}.queue-partner-select select:focus{outline:none;border-color:#4a90d9}.queue-unavailable-hint{color:#88a;font-size:14px;text-align:center;padding:20px;background:#0f0f1a;border-radius:12px}@media(max-width:600px){.queue-options-grid{grid-template-columns:1fr}.queue-status-item{flex-direction:column;align-items:flex-start;gap:10px}.queue-status-item .btn{width:100%}.queue-invite-item,.queue-pending-item{flex-direction:column;align-items:flex-start;gap:12px}.queue-invite-actions{width:100%;flex-direction:column}.queue-invite-actions .btn{width:100%}.queue-partner-select select{max-width:none}}.queue-admin-list{display:flex;flex-direction:column;gap:24px}.queue-admin-group{background:#0f0f1a;border-radius:12px;padding:20px}.queue-admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid #2a2a4a}.queue-admin-header h3{font-size:16px;margin:0}.queue-admin-count{font-size:14px;color:#88a}.ready-badge{color:#4caf50;font-weight:600}.queue-admin-entries{display:flex;flex-direction:column;gap:8px}.queue-admin-entry{display:flex;align-items:center;gap:16px;padding:12px;background:#1a1a2e;border-radius:8px}.queue-admin-entry.assigned{opacity:.6}.queue-admin-entry.cancelled{opacity:.4;text-decoration:line-through}.queue-entry-position{font-weight:600;color:#4a90d9;min-width:30px}.queue-entry-info{flex:1;display:flex;flex-direction:column;gap:2px}.queue-entry-name{font-weight:500}.queue-entry-partner{font-size:13px;color:#88a}.queue-entry-status .status-badge{font-size:11px;padding:3px 8px;border-radius:10px;text-transform:uppercase}.queue-entry-status .status-badge.waiting{background:#4a90d933;color:#4a90d9}.queue-entry-status .status-badge.assigned{background:#4caf5033;color:#4caf50}.queue-entry-status .status-badge.cancelled{background:#f4433633;color:#f44336}.queue-entry-status .status-badge.pending_partner{background:#ff980033;color:#ff9800}.queue-entry-time{display:flex;align-items:center;gap:4px;font-size:12px;color:#666}.queue-entry-club{display:flex;align-items:center;gap:4px;font-size:12px;color:#88a;min-width:100px}.section-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:16px}.section-header-row h2{margin-bottom:4px}.section-header-row .section-hint{margin-top:0}@media(max-width:600px){.section-header-row{flex-direction:column;gap:12px}}@media(max-width:600px){.queue-admin-entry{flex-wrap:wrap}.queue-entry-info{flex-basis:calc(100% - 50px)}.queue-entry-status,.queue-entry-time{margin-top:8px}}.season-info{background:#0f0f1a;border-radius:10px;padding:20px;margin-bottom:24px;border:1px solid #2a2a4a}.season-current{display:flex;align-items:center;gap:12px}.season-label{color:#88a;font-size:14px}.season-value{font-size:24px;font-weight:600;color:#fff}.season-form{max-width:500px}.season-input-row{display:flex;gap:10px;align-items:center}.season-input-row input{max-width:150px}@media(max-width:600px){.season-input-row{flex-wrap:wrap}.season-input-row input{max-width:100%;width:100%}}.toast{position:fixed;bottom:24px;right:24px;display:flex;align-items:center;gap:12px;padding:14px 18px;border-radius:10px;background:#1e1e3f;box-shadow:0 4px 20px #0006;z-index:10000;animation:slideInRight .3s ease-out;max-width:400px}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.toast-icon{display:flex;flex-shrink:0}.toast-message{flex:1;font-size:14px;line-height:1.4}.toast-close{background:none;border:none;color:#88a;cursor:pointer;padding:4px;display:flex;flex-shrink:0;transition:color .2s}.toast-close:hover{color:#fff}.toast-success{border-left:4px solid #4caf50}.toast-success .toast-icon{color:#4caf50}.toast-error{border-left:4px solid #f44336}.toast-error .toast-icon{color:#f44336}.toast-warning{border-left:4px solid #ff9800}.toast-warning .toast-icon{color:#ff9800}.toast-info{border-left:4px solid #4a90d9}.toast-info .toast-icon{color:#4a90d9}@media(max-width:480px){.toast{left:16px;right:16px;bottom:16px;max-width:none}}.announcement-banner{width:100%;padding:10px 16px;display:flex;align-items:center;justify-content:space-between;cursor:pointer;transition:filter .2s;position:relative;z-index:100}.announcement-banner:hover{filter:brightness(1.1)}.announcement-content{display:flex;align-items:center;gap:8px;flex:1;min-width:0}.announcement-type{font-weight:600;font-size:13px;white-space:nowrap}.announcement-title{font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.announcement-cta{font-size:12px;opacity:.8;white-space:nowrap;margin-left:8px}.announcement-dismiss{background:none;border:none;color:inherit;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center;opacity:.7;transition:opacity .2s;flex-shrink:0}.announcement-dismiss:hover{opacity:1}.announcement-feature{background:linear-gradient(90deg,#4a90d9,#5c6bc0);color:#fff}.announcement-update{background:linear-gradient(90deg,#26a69a,#4db6ac);color:#fff}.announcement-general{background:linear-gradient(90deg,#7c4dff,#9575cd);color:#fff}.announcement-maintenance{background:linear-gradient(90deg,#ff9800,#ffb74d);color:#1a1a2e}.announcement-modal-content{padding:8px 0}.announcement-type-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:20px;font-size:12px;font-weight:600;margin-bottom:16px}.announcement-body{line-height:1.7;color:#ccc}.announcement-body p{margin-bottom:12px}.announcement-body p:last-child{margin-bottom:0}.markdown-content h1,.markdown-content h2,.markdown-content h3{color:#fff;margin-top:20px;margin-bottom:12px}.markdown-content h1{font-size:1.5em}.markdown-content h2{font-size:1.25em}.markdown-content h3{font-size:1.1em}.markdown-content h1:first-child,.markdown-content h2:first-child,.markdown-content h3:first-child{margin-top:0}.markdown-content ul,.markdown-content ol{margin:12px 0;padding-left:24px}.markdown-content li{margin-bottom:6px}.markdown-content strong{color:#fff;font-weight:600}.markdown-content em{font-style:italic}.markdown-content code{background:#252540;padding:2px 6px;border-radius:4px;font-family:monospace;font-size:.9em}.markdown-content a{color:#4a90d9;text-decoration:none}.markdown-content a:hover{text-decoration:underline}.announcement-date{margin-top:20px;padding-top:16px;border-top:1px solid #2a2a4a;font-size:12px;color:#888}@media(max-width:768px){.announcement-banner{position:fixed;top:60px;left:0;right:0;padding:10px 12px;z-index:150}.announcement-cta{display:none}.announcement-title,.announcement-type{font-size:12px}body:has(.announcement-banner) .main-content{padding-top:130px}}.announcements-list{display:flex;flex-direction:column;gap:16px}.announcement-item{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:16px}.announcement-item.active{border-color:#4caf50}.announcement-item-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.announcement-item-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.announcement-item-info h3{font-size:16px;font-weight:600;margin:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.announcement-type-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:6px;flex-shrink:0}.announcement-type-icon.type-feature{background:#4a90d933;color:#4a90d9}.announcement-type-icon.type-update{background:#26a69a33;color:#26a69a}.announcement-type-icon.type-announcement{background:#7c4dff33;color:#7c4dff}.announcement-type-icon.type-maintenance{background:#ff980033;color:#ff9800}.announcement-item-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.announcement-item-content{color:#aaa;font-size:14px;line-height:1.5;margin:0 0 12px}.announcement-item-meta{display:flex;align-items:center;gap:12px;font-size:12px}.type-badge{padding:4px 8px;border-radius:4px;font-size:11px;font-weight:600;text-transform:capitalize}.type-badge.type-feature{background:#4a90d933;color:#4a90d9}.type-badge.type-update{background:#26a69a33;color:#26a69a}.type-badge.type-announcement{background:#7c4dff33;color:#7c4dff}.type-badge.type-maintenance{background:#ff980033;color:#ff9800}.announcement-date{color:#666}.checkbox-label{display:flex;align-items:center;gap:10px;cursor:pointer}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer}.checkbox-label span{font-weight:500}.input-readonly{background:#1a1a2e!important;color:#888!important;cursor:not-allowed;border-color:#2a2a4a!important}.input-readonly:focus{outline:none;border-color:#2a2a4a!important}.not-found-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;background:#0f0f1a}.not-found-content{text-align:center;max-width:400px}.not-found-code{font-size:120px;font-weight:800;line-height:1;background:linear-gradient(135deg,#4a90d9,#7c4dff);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:16px}.not-found-content h1{font-size:28px;font-weight:600;margin-bottom:12px;color:#fff}.not-found-content p{color:#888;font-size:16px;margin-bottom:32px;line-height:1.5}.not-found-actions{display:flex;gap:12px;justify-content:center}.not-found-actions .btn{display:flex;align-items:center;gap:8px}@media(max-width:480px){.not-found-code{font-size:80px}.not-found-content h1{font-size:24px}.not-found-actions{flex-direction:column}.not-found-actions .btn{width:100%;justify-content:center}}.rules-content h2{display:flex;align-items:center;gap:10px}.rules-content h2 svg{color:#4a90d9;flex-shrink:0}.rules-content ol{color:#aaa;font-size:14px;line-height:1.7;margin-left:20px;margin-bottom:12px}.rules-content ol li{margin-bottom:8px}.rule-highlight{padding:16px 20px;border-radius:10px;font-size:16px;margin-bottom:16px}.rule-highlight.promotion{background:#4caf501a;border:1px solid rgba(76,175,80,.3);color:#4caf50}.rule-highlight.relegation{background:#f443361a;border:1px solid rgba(244,67,54,.3);color:#f44336}.rule-note{display:flex;align-items:flex-start;gap:10px;background:#ff98001a;border:1px solid rgba(255,152,0,.3);padding:12px 16px;border-radius:8px;font-size:13px;color:#ffb74d;margin-top:12px}.rule-note svg{flex-shrink:0;margin-top:2px}.match-flow-list{list-style:none;margin-left:0;counter-reset:step}.match-flow-list li{position:relative;padding-left:50px;margin-bottom:20px}.match-flow-list li:before{counter-increment:step;content:counter(step);position:absolute;left:0;top:0;width:32px;height:32px;background:#4a90d9;color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:14px}.match-flow-list li strong{display:block;color:#fff;margin-bottom:4px}.match-flow-list li p{margin:0;font-size:13px}.rules-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px;background:#0f0f1a;padding:20px;border-radius:12px;border:1px solid #2a2a4a}.summary-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:12px}.summary-label{font-size:12px;color:#88a;text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.summary-value{font-size:18px;font-weight:600;color:#4a90d9}.rules-cta{text-align:center;padding-top:24px;margin-top:32px;border-top:1px solid #2a2a4a}.rules-cta p{margin-bottom:16px;font-size:16px;color:#fff}@media(max-width:600px){.rules-summary{grid-template-columns:repeat(2,1fr)}.match-flow-list li{padding-left:44px}.match-flow-list li:before{width:28px;height:28px;font-size:12px}}.feedback-list{display:flex;flex-direction:column;gap:12px}.feedback-list-item{display:block;background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:16px 20px;text-decoration:none;color:inherit;transition:border-color .2s,background-color .2s}.feedback-list-item:hover{border-color:#4a90d9;background:#1f1f35}.feedback-list-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.feedback-subject{font-weight:600;font-size:16px;color:#fff}.feedback-preview{color:#88a;font-size:14px;line-height:1.5;margin-bottom:12px}.feedback-meta{display:flex;gap:16px;font-size:12px;color:#668}.reply-count{color:#4a90d9}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.status-badge.new{background:#eab30826;color:#eab308}.status-badge.read{background:#3b82f626;color:#3b82f6}.status-badge.replied{background:#22c55e26;color:#22c55e}.status-badge.closed{background:#6b728026;color:#6b7280}.status-icon{flex-shrink:0}.feedback-detail{background:#1a1a2e;border:1px solid #2a2a4a;border-radius:12px;padding:24px;margin-top:20px}.feedback-detail-header{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;padding-bottom:16px;border-bottom:1px solid #2a2a4a}.feedback-detail-header h2{font-size:20px;font-weight:600;margin:0}.conversation-thread{display:flex;flex-direction:column;gap:16px;margin-bottom:24px}.message{padding:16px;border-radius:12px;max-width:85%}.message-user{background:#252540;align-self:flex-end;border-bottom-right-radius:4px}.message-admin{background:#4a90d926;border:1px solid rgba(74,144,217,.3);align-self:flex-start;border-bottom-left-radius:4px}.message-header{display:flex;justify-content:space-between;align-items:center;gap:12px;margin-bottom:8px}.message-author{font-weight:600;font-size:13px;color:#fff}.message-admin .message-author{color:#4a90d9}.message-time{font-size:11px;color:#668}.message-content{font-size:14px;line-height:1.6;color:#ccc;white-space:pre-wrap}.reply-form{border-top:1px solid #2a2a4a;padding-top:20px}.reply-form textarea{width:100%;background:#252540;border:1px solid #3a3a5a;border-radius:8px;padding:12px;color:#fff;font-size:14px;resize:vertical;min-height:80px}.reply-form textarea:focus{outline:none;border-color:#4a90d9}.reply-form-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.char-count{font-size:12px;color:#668}.conversation-closed{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:#6b72801a;border:1px solid rgba(107,114,128,.2);border-radius:8px;color:#6b7280;font-size:14px}.back-link{display:inline-flex;align-items:center;gap:8px;color:#88a;text-decoration:none;font-size:14px;margin-bottom:8px;transition:color .2s}.back-link:hover{color:#4a90d9}.danger-zone{margin-top:40px;padding-top:30px;border-top:1px solid #3a2a2a}.danger-zone h2{color:#ef4444;margin-bottom:8px}.danger-zone p{color:#88a;margin-bottom:16px;font-size:14px}.btn-danger{background:#ef4444;color:#fff;border:none}.btn-danger:hover{background:#dc2626}.delete-confirm-warning{background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;padding:16px;margin-bottom:20px}.delete-confirm-warning h4{color:#ef4444;margin-bottom:8px;display:flex;align-items:center;gap:8px}.delete-confirm-warning ul{margin:12px 0 0 20px;color:#ccc;font-size:14px}.delete-confirm-warning li{margin-bottom:6px}.delete-confirm-input{margin-bottom:20px}.delete-confirm-input label{display:block;margin-bottom:8px;color:#ccc;font-size:14px}.delete-confirm-input input{width:100%;padding:12px;background:#252540;border:1px solid #3a3a5a;border-radius:8px;color:#fff;font-size:14px}.delete-confirm-input input:focus{outline:none;border-color:#ef4444}.delete-confirm-input input::placeholder{color:#668}.delete-confirm-input code{background:#252540;padding:2px 6px;border-radius:4px;color:#ef4444}@media(max-width:768px){.feedback-list-header{flex-direction:column;align-items:flex-start;gap:8px}.message{max-width:95%}.feedback-detail{padding:16px}.feedback-detail-header{flex-direction:column;gap:12px}}
