.login-container{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;justify-content:center;min-height:100vh;padding:20px}.login-card{background:#fff;border-radius:12px;box-shadow:0 20px 40px #0000001a;max-width:400px;overflow:hidden;width:100%}.login-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 30px;text-align:center}.login-header h1{font-size:2.5rem;font-weight:700;margin:0 0 10px}.login-header p{font-size:1rem;margin:0;opacity:.9}.login-content{padding:40px 30px}.login-content h2{color:#333;font-size:1.5rem;font-weight:600;margin:0 0 10px}.login-content p{color:#666;font-size:.95rem;margin:0 0 30px}.google-login-btn{align-items:center;background:#fff;border:2px solid #dadce0;border-radius:8px;color:#3c4043;cursor:pointer;display:flex;font-size:1rem;font-weight:500;gap:12px;justify-content:center;padding:12px 20px;transition:all .2s ease;width:100%}.google-login-btn:hover{border-color:#4285f4;box-shadow:0 2px 8px #4285f433}.google-login-btn:disabled{cursor:not-allowed;opacity:.6}.google-icon{height:20px;width:20px}.error-message{background:#fef2f2;border:1px solid #fecaca;border-radius:6px;color:#dc2626;font-size:.9rem;padding:12px}.login-footer{margin-top:30px;text-align:center}.login-footer p{color:#666;font-size:.85rem;line-height:1.4;margin:0}.login-footer a{color:#4285f4;text-decoration:none}.login-footer a:hover{text-decoration:underline}@media (max-width:480px){.login-container{padding:10px}.login-card{max-width:100%}.login-content,.login-header{padding:30px 20px}.login-header h1{font-size:2rem}}.auth-callback{background:linear-gradient(135deg,#667eea,#764ba2)}.auth-loading-container{align-items:center;display:flex;justify-content:center;max-width:500px;width:100%}.auth-loading-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #fff3;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;padding:60px 40px;position:relative;text-align:center}.auth-loading-card:before{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#fff6,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;width:100%}@keyframes shimmer{0%{left:-100%}to{left:100%}}.auth-loading-icon{margin-bottom:30px;position:relative}.auth-spinner{animation:spin 1s linear infinite;border:4px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;height:60px;margin:0 auto;position:relative;width:60px}.auth-spinner:after{animation:pulse 1.5s ease-in-out infinite;background:#3b82f6;border-radius:50%;content:"";height:20px;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:20px}.auth-loading-title{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#8b5cf6);-webkit-background-clip:text;background-clip:text;color:#1f2937;font-size:1.8rem;font-weight:700;margin:0 0 16px}.auth-loading-message{color:#6b7280;font-size:1.1rem;font-weight:500;line-height:1.6;margin:0 0 30px}.auth-loading-dots{display:flex;gap:8px;justify-content:center;margin-top:20px}.auth-loading-dots span{animation:bounce 1.4s ease-in-out infinite both;background:#3b82f6;border-radius:50%;height:8px;width:8px}.auth-loading-dots span:first-child{animation-delay:-.32s}.auth-loading-dots span:nth-child(2){animation-delay:-.16s}.auth-loading-dots span:nth-child(3){animation-delay:0s}.error-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #ef444433;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:60px 40px;text-align:center}.error-container h2{font-size:1.8rem;margin-bottom:16px}.error-container p{color:#6b7280;margin-bottom:30px}.error-container button{background:#dc2626;border-radius:8px;font-weight:600;padding:12px 24px;transition:all .2s}.error-container button:hover{background:#b91c1c;transform:translateY(-2px)}.success-container{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border:1px solid #22c55e33;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:60px 40px;text-align:center}.success-container h2{font-size:1.8rem;margin-bottom:16px}.success-container p{color:#6b7280;margin:0}@media (max-width:640px){.auth-loading-card,.error-container,.success-container{margin:20px;padding:40px 30px}.auth-loading-title{font-size:1.5rem}.auth-loading-message{font-size:1rem}}.site-selector{display:flex;flex-direction:column;gap:.5rem;min-width:200px;position:relative}.site-selector.compact{min-width:150px}.site-selector-label{color:#374151;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.site-selector-dropdown{display:inline-block;position:relative}.site-selector-button{background:#fff;border:1px solid #d1d5db;border-radius:.5rem;cursor:pointer;font-size:.875rem;padding:.75rem 1rem;text-align:left;transition:all .2s ease;width:100%}.site-selector-button:hover{border-color:#9ca3af;box-shadow:0 1px 3px 0 #0000001a}.site-selector-button:focus{border-color:#3b82f6;outline:none}.site-selector-button.disabled{background-color:#f9fafb;border-color:#e5e7eb;color:#9ca3af;cursor:not-allowed;opacity:.6}.site-selector-button.disabled:hover{border-color:#e5e7eb;box-shadow:none}.site-selector-button.disabled:focus{border-color:#e5e7eb}.site-selector-content{align-items:center;display:flex;gap:.5rem}.site-selector-icon{flex-shrink:0;font-size:1rem}.site-selector-text{color:#111827;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-selector-arrow{color:#6b7280;flex-shrink:0;font-size:.75rem;transition:transform .2s ease}.site-selector-menu{background:#fff;border:1px solid #d1d5db;border-radius:.5rem;box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;left:0;margin-top:.25rem;max-height:300px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:50}.site-selector-option{background:#fff;border:none;border-bottom:1px solid #f3f4f6;cursor:pointer;font-size:.875rem;padding:.75rem 1rem;text-align:left;transition:background-color .2s ease;width:100%}.site-selector-option:last-child{border-bottom:none}.site-selector-option:hover{background-color:#f9fafb}.site-selector-option.active{background-color:#eff6ff;color:#1d4ed8}.site-selector-option.create-new{color:#059669;font-weight:500}.site-selector-option.create-new:hover{background-color:#f0fdf4}.site-option-content{align-items:center;display:flex;gap:.75rem}.site-option-icon{flex-shrink:0;font-size:1rem}.site-option-details{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.site-option-name{color:#111827;font-weight:500}.site-option-description,.site-option-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-option-description{color:#6b7280;font-size:.75rem}.site-option-check{color:#059669;flex-shrink:0;font-weight:700}.site-selector-divider{background-color:#e5e7eb;height:1px;margin:.5rem 0}@media (max-width:640px){.site-selector{min-width:150px}.site-selector-button,.site-selector-option{font-size:.8125rem;padding:.625rem .75rem}.site-option-details{gap:.0625rem}.site-option-description{font-size:.6875rem}}@media (prefers-color-scheme:dark){.site-selector-label{color:#d1d5db}.site-selector-button{background:#1f2937;border-color:#374151;color:#f9fafb}.site-selector-button:hover{border-color:#4b5563}.site-selector-button:focus{border-color:#3b82f6}.site-selector-text{color:#f9fafb}.site-selector-menu{background:#1f2937;border-color:#374151}.site-selector-option{background:#1f2937;border-bottom-color:#374151;color:#f9fafb}.site-selector-option:hover{background-color:#374151}.site-selector-option.active{background-color:#1e3a8a;color:#93c5fd}.site-option-name{color:#f9fafb}.site-option-description{color:#9ca3af}.site-selector-button.disabled{background-color:#374151;border-color:#4b5563;color:#6b7280}.site-selector-button.disabled:focus,.site-selector-button.disabled:hover{border-color:#4b5563}}.app-header{background:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;position:-webkit-sticky;position:sticky;top:0;z-index:1000}.header-content{gap:20px;height:64px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 20px}.header-content,.header-left{align-items:center;display:flex}.header-left{gap:32px}.app-title-link{text-decoration:none;transition:opacity .2s ease}.app-title-link:hover{opacity:.8}.app-title{color:#667eea;font-size:1.5rem;font-weight:700;margin:0}.main-nav{display:flex;gap:24px}.nav-link{border-radius:6px;color:#374151;font-weight:500;padding:8px 12px;text-decoration:none;transition:all .2s ease}.nav-link:hover{background:#f3f4f6;color:#667eea}.header-center{flex:1 1;justify-content:center;max-width:300px}.header-center,.header-right{align-items:center;display:flex}.user-menu{position:relative}.user-button{align-items:center;background:none;border:none;border-radius:8px;cursor:pointer;display:flex;gap:8px;padding:8px 12px;transition:background-color .2s ease}.user-button:hover{background:#f3f4f6}.user-avatar{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;color:#fff;display:flex;font-size:.9rem;font-weight:600;height:32px;justify-content:center;width:32px}.user-name{color:#374151;font-weight:500;max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-arrow{color:#6b7280;height:16px;transition:transform .2s ease;width:16px}.user-button:hover .dropdown-arrow{transform:rotate(180deg)}.user-dropdown{background:#fff;border:1px solid #e5e7eb;border-radius:8px;box-shadow:0 10px 25px #0000001a;margin-top:8px;max-width:320px;min-width:280px;overflow:hidden;position:absolute;right:0;top:100%;width:-webkit-max-content;width:max-content;z-index:1001}.user-info{border-bottom:1px solid #f3f4f6;padding:16px}.user-details .user-name{word-wrap:break-word;color:#111827;font-weight:600;margin-bottom:4px;overflow-wrap:break-word}.user-details .user-email{word-wrap:break-word;color:#6b7280;font-size:.9rem;margin-bottom:8px;overflow-wrap:break-word}.user-roles{display:flex;flex-wrap:wrap;gap:4px}.role-badge,.user-roles{max-width:100%;overflow:hidden}.role-badge{background:#667eea;border-radius:12px;color:#fff;flex-shrink:0;font-size:.75rem;font-weight:500;padding:2px 8px;text-overflow:ellipsis;white-space:nowrap}.dropdown-divider{background:#f3f4f6;height:1px}.dropdown-menu{padding:8px 0}.dropdown-item{align-items:center;background:none;border:none;box-sizing:border-box;color:#374151;cursor:pointer;display:flex;font-size:.9rem;gap:12px;overflow:hidden;padding:12px 16px;text-align:left;text-decoration:none;text-overflow:ellipsis;transition:background-color .2s ease;white-space:nowrap;width:100%}.dropdown-item:hover{background:#f9fafb}.logout-item{color:#dc2626}.logout-item:hover{background:#fef2f2}.admin-item{color:#7c3aed;font-weight:600}.admin-item:hover{background:#f3e8ff;color:#6d28d9}.menu-icon{color:#6b7280;height:16px;width:16px}.login-link{border:2px solid #667eea;border-radius:6px;color:#667eea;font-weight:500;padding:8px 16px;text-decoration:none;transition:all .2s ease}.login-link:hover{background:#667eea;color:#fff}@media (max-width:768px){.header-content{padding:0 16px}.main-nav{display:none}.header-center{max-width:200px}.user-name{display:none}.user-dropdown{max-width:280px;min-width:240px}.dropdown-item{font-size:.85rem;padding:10px 14px}.user-details .user-name{font-size:.95rem}.user-details .user-email{font-size:.8rem}}@media (max-width:480px){.app-title{font-size:1.25rem}.header-content{height:56px}}.loading-container{bottom:0;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1002}.loading-container,.loading-spinner{align-items:center;background:#fff;display:flex}.loading-spinner{border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;color:#6b7280;flex-direction:column;gap:16px;padding:40px}.spinner{border:3px solid #e5e7eb;border-top-color:#3b82f6;height:40px;width:40px}.loading-message{color:#6b7280;font-size:1em;font-weight:500;margin:0;text-align:center}.site-form{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:600px;padding:20px}.form-header h2{font-size:24px}.form-description{font-size:14px}.form-content{gap:20px}.form-row{grid-template-columns:1fr 1fr}.sport-selector-container{position:relative;width:100%}.sport-selector{align-items:center;background:#fff;border:2px solid #ddd;border-radius:8px;cursor:pointer;display:flex;justify-content:space-between;min-height:48px;padding:12px 16px;transition:all .3s ease}.sport-selector:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.sport-selector.error{border-color:#dc3545}.sport-selector:focus{border-color:#007bff;box-shadow:0 0 0 3px #007bff1a;outline:none}.selected-sport{align-items:center;display:flex;gap:8px}.sport-icon{font-size:20px}.sport-label{color:#333;font-weight:500}.placeholder{color:#999;font-style:italic}.dropdown-arrow{color:#666;font-size:12px;transition:transform .3s ease}.sport-selector.open .dropdown-arrow{transform:rotate(180deg)}.sport-dropdown{background:#fff;border:2px solid #007bff;border-radius:8px;box-shadow:0 8px 25px #00000026;left:0;margin-top:4px;max-height:400px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:1000}.sport-search{background:#f8f9fa;border-bottom:1px solid #eee;padding:16px}.sport-search-input{border:1px solid #ddd;border-radius:6px;font-size:14px;outline:none;padding:10px 12px;transition:border-color .3s ease;width:100%}.sport-search-input:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff1a}.sport-categories{padding:8px 0}.sport-category{margin-bottom:16px}.category-title{background:#f8f9fa;border-bottom:1px solid #dee2e6;color:#495057;font-size:14px;letter-spacing:.5px;margin:0 0 8px;padding:8px 16px;text-transform:uppercase}.sport-options{grid-gap:4px;gap:4px;padding:0 8px}.sport-option{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;gap:8px;padding:10px 12px;transition:all .2s ease}.sport-option:hover{background:#e3f2fd;border-color:#bbdefb}.sport-option.selected{background:#007bff;border-color:#0056b3;color:#fff}.sport-option.selected .sport-icon{filter:brightness(0) invert(1)}.sport-option .sport-icon{flex-shrink:0;font-size:18px}.sport-option .sport-label{font-size:14px;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:768px){.site-form{margin:10px;padding:15px}.form-row,.sport-options{grid-template-columns:1fr}.sport-dropdown{max-height:300px}.sport-option{padding:12px 16px}.form-actions{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sport-dropdown{animation:slideDown .2s ease-out}.sport-dropdown::-webkit-scrollbar{width:6px}.sport-dropdown::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.sport-dropdown::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.sport-dropdown::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.sport-loading{align-items:center;color:#666;display:flex;font-style:italic;justify-content:center;padding:20px}.sport-loading span{align-items:center;display:flex;gap:8px}.sport-loading span:before{animation:spin 1s linear infinite;border:2px solid #e0e0e0;border-radius:50%;border-top-color:#007bff;content:"";height:16px;width:16px}.sports-selector-container{margin-bottom:1rem}.sports-loading{color:#666;font-style:italic;padding:2rem;text-align:center}.sports-grid{background-color:#f9f9f9;border:1px solid #ddd;border-radius:8px;display:flex;flex-direction:column;gap:1.5rem;max-height:400px;overflow-y:auto;padding:1rem}.sport-category{margin-bottom:1rem}.sport-category:last-child{margin-bottom:0}.category-title{border-bottom:1px solid #e0e0e0;color:#333;font-size:1rem;font-weight:600;margin-bottom:.5rem;padding-bottom:.25rem}.sport-options{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.sport-card{align-items:center;background-color:#fff;border:2px solid #e0e0e0;border-radius:8px;cursor:pointer;gap:.5rem;padding:.75rem;transition:all .2s ease;-webkit-user-select:none;user-select:none}.sport-card:hover{background-color:#f8f9fa;border-color:#007bff;box-shadow:0 2px 4px #0000001a;transform:translateY(-1px)}.sport-card.selected{background-color:#e3f2fd;border-color:#007bff;color:#007bff}.sport-card.selected:hover{background-color:#bbdefb}.sport-icon{font-size:1.2rem;line-height:1}.sport-name{flex:1 1;font-size:.9rem;font-weight:500}@media (max-width:768px){.sport-options{grid-template-columns:1fr}.sports-grid{max-height:300px}}.schedule-sport-selector{margin-bottom:1rem}.schedule-sport-selector select{background-color:#fff;border:1px solid #ddd;border-radius:4px;font-size:.9rem;padding:.5rem;width:100%}.schedule-sport-selector select:focus{border-color:#007bff;box-shadow:0 0 0 2px #007bff40;outline:none}.schedule-sport-selector select.error{border-color:#dc3545}.schedule-sport-selector select:disabled{background-color:#f8f9fa;color:#6c757d;cursor:not-allowed}.selected-sports-indicator{background-color:#e3f2fd;border-radius:4px;color:#1976d2;font-size:.85rem;margin-top:.5rem;padding:.5rem}.selected-sports-count{font-weight:600}@keyframes fadeIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.sport-card{animation:fadeIn .2s ease}.sports-selector-container.error .sport-card,.sports-selector-container.error .sports-grid{border-color:#dc3545}.sport-card:focus{outline:2px solid #007bff;outline-offset:2px}.sport-card[aria-selected=true]{background-color:#e3f2fd;border-color:#007bff}@media (max-width:480px){.sport-card{padding:.5rem}.sport-name{font-size:.8rem}.sport-icon{font-size:1rem}}.location-form{background:#fff;border-radius:8px;box-shadow:0 2px 10px #0000001a;margin:0 auto;max-width:800px;padding:20px}.form-header{border-bottom:2px solid #f0f0f0;margin-bottom:30px;padding-bottom:20px;text-align:center}.form-header h2{color:#333;font-size:28px;margin:0 0 10px}.form-description{color:#666;font-size:16px;margin:0}.form-content{display:flex;flex-direction:column;gap:30px}.error-banner{align-items:center;background:#fee;border:1px solid #fcc;border-radius:6px;color:#c33;display:flex;gap:8px;margin-bottom:20px;padding:12px 16px}.error-icon{flex-shrink:0;font-size:16px}.error-text{font-size:14px;font-weight:500}.form-section{background:#f9f9f9;border-left:4px solid #007bff;border-radius:8px;padding:25px}.form-section h3{align-items:center;color:#333;display:flex;font-size:20px;margin:0 0 20px}.form-section h3:before{content:"📍";font-size:24px;margin-right:10px}.form-group{gap:8px;margin-bottom:20px}.form-group label{color:#333;font-size:14px}.form-group input,.form-group select,.form-group textarea{background:#fff;border-radius:8px;padding:12px 16px;transition:all .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{box-shadow:0 0 0 3px #007bff1a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#dc3545}.form-group small{color:#666;font-size:12px;margin-top:4px}.form-row{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.error-message{color:#dc3545;font-size:12px;margin-top:4px}.form-actions{border-top:1px solid #eee;gap:12px;margin-top:30px;padding-top:20px}.schedule-item{border:1px solid #e0e0e0;margin-bottom:20px;padding:20px}.schedule-header{align-items:center;border-bottom:1px solid #f0f0f0;margin-bottom:20px;padding-bottom:10px}.schedule-header h4{color:#333;font-size:16px;margin:0}.days-selector{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-top:8px}.day-checkbox{align-items:center;background:#f8f9fa;border:1px solid #dee2e6;border-radius:6px;cursor:pointer;display:flex;font-size:14px;gap:8px;padding:8px 12px;transition:all .3s ease}.day-checkbox:hover{background:#e9ecef;border-color:#adb5bd}.day-checkbox input[type=checkbox]{cursor:pointer;margin:0}.day-checkbox input[type=checkbox]:checked+span{color:#007bff;font-weight:600}.form-section:first-child h3:before{content:"🏢"}.form-section:nth-child(2) h3:before{content:"📍"}.form-section:nth-child(3) h3:before{content:"⏰"}.form-section:nth-child(4) h3:before{content:"💰"}.form-section:nth-child(5) h3:before{content:"👨‍🏫"}@media (max-width:768px){.location-form{margin:10px;padding:15px}.form-section{padding:15px}.form-row{grid-template-columns:1fr}.days-selector{grid-template-columns:repeat(2,1fr)}.schedule-header{align-items:flex-start;gap:10px}.form-actions,.schedule-header{flex-direction:column}.cancel-btn,.submit-btn{width:100%}}@media (max-width:480px){.days-selector{grid-template-columns:1fr}.form-header h2{font-size:24px}.form-section h3{font-size:18px}}.location-schedule-view{width:100%}.location-schedule-view.compact{font-size:14px}.schedules-header{align-items:center;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:15px;padding-bottom:10px}.schedules-header h4{align-items:center;color:#333;display:flex;font-size:16px;font-weight:600;gap:8px;margin:0}.schedule-count{background:#007bff;border-radius:12px;color:#fff;font-size:12px;font-weight:600;padding:4px 8px}.schedules-list{display:flex;flex-direction:column;gap:12px}.schedule-item{background:#fff;border:1px solid #e9ecef;border-radius:8px;padding:15px;transition:all .3s ease}.schedule-item:hover{border-color:#007bff;box-shadow:0 2px 8px #007bff1a}.schedule-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.schedule-title{align-items:center;display:flex;flex:1 1;gap:10px}.schedule-title h5{color:#333;font-size:14px;font-weight:600;margin:0}.status-badge{border-radius:12px;font-size:11px;padding:2px 8px}.status-badge.active{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.status-badge.inactive{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.schedule-actions{align-items:center;display:flex;gap:6px}.schedule-actions .btn{align-items:center;border:none;border-radius:4px;cursor:pointer;display:flex;font-size:11px;gap:2px;padding:4px 8px;transition:all .3s ease}.schedule-actions .btn:hover{transform:translateY(-1px)}.schedule-details{margin-top:8px}.schedule-info{grid-gap:8px;display:grid;gap:8px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{align-items:flex-start;display:flex;font-size:13px;gap:6px;line-height:1.4}.info-item strong{color:#333;flex-shrink:0;font-weight:600;min-width:80px}.info-item span{color:#666;flex:1 1}.sport-info{align-items:center;display:flex;gap:4px}.no-schedules{background:#f8f9fa;border:1px dashed #dee2e6;border-radius:6px;color:#666;font-style:italic;padding:20px;text-align:center}.location-schedule-view.compact .schedules-header{margin-bottom:10px}.location-schedule-view.compact .schedules-header h4{font-size:14px}.location-schedule-view.compact .schedule-item{padding:12px}.location-schedule-view.compact .schedule-title h5{font-size:13px}.location-schedule-view.compact .schedule-info{gap:6px;grid-template-columns:1fr}.location-schedule-view.compact .info-item{font-size:12px}.location-schedule-view.compact .info-item strong{min-width:70px}@media (max-width:768px){.schedule-header{gap:8px}.schedule-header,.schedule-title{align-items:flex-start;flex-direction:column}.schedule-title{gap:6px}.schedule-actions{justify-content:flex-end;width:100%}.schedule-info{grid-template-columns:1fr}.info-item{flex-direction:column;gap:2px}.info-item strong{min-width:auto}}@media (max-width:480px){.schedules-header{align-items:flex-start;flex-direction:column;gap:8px}.schedule-count{font-size:11px;padding:3px 6px}.schedule-item{padding:10px}.schedule-actions .btn{font-size:10px;padding:3px 6px}}.location-card{position:relative}.location-card.clickable{cursor:pointer}.location-card.clickable:hover{border-color:#007bff}.location-card.compact{margin-bottom:15px}.location-card.compact .location-details,.location-card.compact .location-header{padding:15px}.location-header h3{flex:1 1}.location-actions{align-items:center;gap:8px}.location-actions .btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:12px;gap:4px;padding:6px 10px;transition:all .3s ease}.location-actions .btn:hover{transform:translateY(-1px)}.detail-item{align-items:flex-start;font-size:14px;gap:8px;line-height:1.5;margin-bottom:12px}.detail-item:last-child{margin-bottom:0}.detail-item strong{flex-shrink:0;font-weight:600;min-width:120px}.detail-item span{flex:1 1}.location-schedules{background:#f8f9fa;border-top:1px solid #e9ecef;padding:15px 20px}@media (max-width:768px){.location-header{align-items:flex-start;flex-direction:column;gap:10px}.location-header h3{font-size:16px}.location-actions{justify-content:flex-end;width:100%}.detail-item{flex-direction:column;gap:4px}.detail-item strong{min-width:auto}}@media (max-width:480px){.location-card{margin-bottom:15px}.location-details,.location-header{padding:15px}.location-schedules{padding:10px 15px}.location-actions .btn{font-size:11px;padding:4px 8px}}.location-list{width:100%}.location-list.compact{max-width:600px}.location-list-header{align-items:center;border-bottom:2px solid #f0f0f0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.location-list-header h2{align-items:center;color:#333;display:flex;font-size:24px;gap:10px;margin:0}.location-list-header .icon{font-size:28px}.location-list-error{align-items:center;display:flex;justify-content:center;min-height:200px;padding:20px}.error-content{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:30px;text-align:center}.error-content h3{color:#dc3545;font-size:20px;margin-bottom:15px}.error-content p{color:#666;font-size:16px;margin-bottom:20px}.no-locations{border:1px solid #e9ecef}.location-list.compact .locations-grid{grid-template-columns:1fr;margin:20px auto 0;max-width:500px}.location-form-container{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}@media (max-width:768px){.location-list-header{align-items:flex-start;flex-direction:column;gap:15px}.location-list-header h2{font-size:20px}.locations-grid{grid-template-columns:1fr}.no-locations{padding:40px 15px}.no-locations h3{font-size:20px}}@media (max-width:480px){.location-list-header h2{font-size:18px}.no-locations-icon{font-size:48px}.no-locations h3{font-size:18px}}.site-list{display:flex;flex-direction:column;gap:30px}.site-list.empty{align-items:center;justify-content:center;min-height:400px}.empty-state{color:#666;text-align:center}.empty-icon{font-size:4em;margin-bottom:20px;opacity:.5}.empty-state h3{color:#333;font-size:1.5em;margin-bottom:10px}.empty-state p{font-size:1.1em;line-height:1.6}.sites-section{display:flex;flex-direction:column;gap:20px}.section-title{align-items:center;border-bottom:2px solid #e9ecef;color:#333;display:flex;font-size:1.3em;gap:10px;margin:0;padding-bottom:10px}.section-title .icon{font-size:1.2em}.sites-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.site-card{background:#fff;border-radius:12px;cursor:pointer;overflow:hidden;position:relative}.site-card:hover{box-shadow:0 8px 25px #007bff26;transform:translateY(-2px)}.site-card.active{background:linear-gradient(135deg,#e3f2fd,#f8f9fa);border-color:#007bff;box-shadow:0 8px 25px #007bff33}.site-card.branch{border-left:4px solid #ffc107}.site-card.branch:hover{border-left-color:#ffc107}.site-header{align-items:flex-start}.site-name{color:#333;font-size:1.2em;font-weight:600;line-height:1.3;margin:0}.site-badges{display:flex;flex-wrap:wrap;gap:8px}.badge{border-radius:12px;font-size:.7em;font-weight:600;letter-spacing:.5px;padding:4px 8px;text-transform:uppercase}.badge.main{background:#28a745;color:#fff}.badge.branch{background:#ffc107;color:#333}.badge.active{background:#007bff;color:#fff}.site-description{-webkit-line-clamp:2;-webkit-box-orient:vertical;display:-webkit-box;font-size:.9em;overflow:hidden}.site-details{display:flex;flex-direction:column;gap:8px}.detail-row{align-items:center;display:flex;font-size:.9em;gap:8px}.detail-label{font-size:1em;text-align:center;width:20px}.detail-value{color:#666;flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-actions{justify-content:flex-end;margin-top:auto}.sites-summary{background:#ffffff0d;border:1px solid #fff3;border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-top:20px;padding:40px 0}.summary-card{background:#0000;border:none;border-radius:0;box-shadow:none;color:inherit;padding:0}.summary-card h4{color:inherit;font-size:2.5rem;font-weight:700;letter-spacing:normal;margin:0 0 1rem;text-align:center;text-shadow:none}.summary-stats{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-left:auto;margin-right:auto;margin-top:3rem;max-width:none}.stat{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:2rem;text-align:center;transition:transform .3s ease,background .3s ease}.stat:hover{background:#ffffff26;transform:translateY(-2px)}.stat-number{line-height:1;text-shadow:none}.stat-label{color:inherit;letter-spacing:normal;line-height:1.2;text-shadow:none;text-transform:none}.site-card{animation:fadeInUp .5s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.site-card:first-child{animation-delay:.1s}.site-card:nth-child(2){animation-delay:.2s}.site-card:nth-child(3){animation-delay:.3s}.site-card:nth-child(4){animation-delay:.4s}@media (max-width:768px){.sites-grid{grid-template-columns:1fr}.site-header{align-items:flex-start;flex-direction:column;gap:10px}.site-badges{align-self:flex-start}.site-actions{flex-direction:column}.action-btn{justify-content:center;width:100%}.summary-stats{gap:2rem;grid-template-columns:repeat(2,1fr)}.stat{padding:2rem}.stat-number{font-size:2.2em}.stat-label{font-size:.8em;letter-spacing:.8px}}@media (max-width:480px){.site-card{padding:15px}.site-name{font-size:1.1em}.detail-row{font-size:.85em}.summary-stats{gap:2rem;grid-template-columns:1fr}.stat{padding:2rem}.stat-number{font-size:2em}.stat-label{font-size:.75em;letter-spacing:.7px}.summary-card{padding:0}.summary-card h4{font-size:1.2em;margin-bottom:20px}}.site-card:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.site-card:hover:before{left:100%}.site-card:focus{outline:2px solid #007bff;outline-offset:2px}.action-btn:focus{outline:2px solid #ffffff80;outline-offset:2px}.site-card[data-status=active]{position:relative}.site-card[data-status=active]:after{animation:pulse 2s infinite;color:#28a745;content:"●";font-size:1.2em;position:absolute;right:15px;top:15px}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.manager-dashboard{background:#f8fafc;min-height:100vh;padding:20px}.manager-dashboard.error,.manager-dashboard.loading{align-items:center;display:flex;justify-content:center;min-height:100vh}.loading-spinner{color:#fff;text-align:center}.spinner{animation:spin 1s linear infinite;border:5px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:50px;margin:0 auto 20px;width:50px}.error-message{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0003;max-width:500px;padding:40px;text-align:center}.error-message h2{color:#dc3545;margin-bottom:15px}.welcome-message{border-radius:15px;box-shadow:0 15px 35px #0000001a;margin:0 auto;max-width:600px;padding:60px 40px}.welcome-message h1{color:#333;font-size:2.5em;margin-bottom:20px}.welcome-message p{font-size:1.2em;margin-bottom:30px}.form-container{margin:0 auto;max-width:900px}.dashboard-header{align-items:center;background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;display:flex;justify-content:space-between;margin-bottom:30px;padding:30px}.dashboard-header h1{color:#333;font-size:2.2em;margin:0}.user-info{color:#666;font-size:1.1em}.dashboard-content{display:flex;flex-direction:column;gap:30px}.site-selector-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:25px}.site-selector-section h2{color:#333;font-size:1.5em;margin:0 0 20px}.active-site-info{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:25px}.active-site-info h2{color:#333;font-size:1.5em;margin:0 0 20px}.site-card{border:2px solid #e9ecef;border-radius:10px;padding:20px;transition:all .3s ease}.site-card:hover{border-color:#007bff;box-shadow:0 5px 15px #007bff1a}.site-header{margin-bottom:15px}.site-header h3{color:#333;font-size:1.3em;margin:0}.site-description{color:#666;line-height:1.5;margin-bottom:15px}.site-details{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:20px}.detail-item{display:flex;flex-direction:column;gap:5px}.detail-item strong{color:#333;font-size:.9em}.detail-item span{color:#666;font-size:.9em}.quick-actions{border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:25px}.quick-actions h2{color:#333;font-size:1.5em;margin:0 0 20px}.action-buttons{grid-gap:15px;display:grid;gap:15px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sites-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:25px}.sites-section h2{color:#333;font-size:1.5em;margin:0 0 20px}.stats-section{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;padding:25px}.stats-section h2{color:#333;font-size:1.5em;margin:0 0 20px}.stats-grid{grid-gap:20px;gap:20px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;color:#374151;padding:25px}.stat-number{color:#3b82f6;display:block;font-size:2.5em;margin-bottom:10px}.stat-label{color:#6b7280;font-size:.9em}@media (max-width:768px){.manager-dashboard{padding:10px}.dashboard-header{flex-direction:column;gap:15px;text-align:center}.action-buttons,.site-details{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.welcome-card{padding:30px 20px}.welcome-card h2{font-size:1.8em}.welcome-description{font-size:1.1em}.welcome-features{gap:15px;grid-template-columns:1fr}.welcome-create-btn{font-size:1.1em;padding:15px 25px}}@media (max-width:480px){.welcome-message{padding:40px 20px}.welcome-message h1{font-size:2em}.stats-grid{grid-template-columns:1fr}.welcome-card{border-radius:15px;padding:25px 15px}.welcome-card h2{font-size:1.6em}.welcome-description{font-size:1em}.welcome-icon{font-size:3em}.feature-item{gap:8px;padding:12px}.feature-icon{font-size:1.3em;width:25px}.welcome-create-btn{font-size:1em;justify-content:center;padding:12px 20px;width:100%}}.welcome-section{margin-bottom:30px}.welcome-card{background:#fff;border:2px solid #e9ecef;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;padding:50px 40px;position:relative;text-align:center}.welcome-card:before{background:linear-gradient(90deg,#007bff,#28a745,#ffc107,#dc3545);content:"";height:5px;left:0;position:absolute;right:0;top:0}.welcome-icon{animation:bounce 2s infinite;display:block;font-size:4em;margin-bottom:20px}.welcome-card h2{color:#333;font-size:2.2em;font-weight:700;margin-bottom:20px}.welcome-description{color:#666;font-size:1.2em;line-height:1.6;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:600px}.welcome-features{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:800px}.feature-item{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:10px;display:flex;gap:12px;padding:15px;transition:all .3s ease}.feature-item:hover{background:#e3f2fd;border-color:#007bff;box-shadow:0 5px 15px #007bff1a;transform:translateY(-2px)}.feature-icon{font-size:1.5em;text-align:center;width:30px}.feature-item span:last-child{color:#333;font-size:.95em;font-weight:600}.btn-icon{animation:rocket 2s infinite;font-size:1.3em}.retry-btn{margin-right:10px}.error-actions{margin:20px 0}.error-help{background:#f8f9fa;border-left:4px solid #007bff;border-radius:5px;margin-top:20px;padding:15px;text-align:left}.error-help p{color:#495057;font-weight:700;margin:0 0 10px}.error-help ul{margin:0;padding-left:20px}.error-help li{color:#6c757d;margin:5px 0}.locations-section{margin-top:30px}.locations-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.locations-header h2{color:#333;font-size:24px;margin:0}.no-locations{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;padding:60px 20px;text-align:center}.no-locations-icon{font-size:64px;margin-bottom:20px;opacity:.6}.no-locations h3{color:#333;font-size:24px;margin-bottom:10px}.no-locations p{color:#666;font-size:16px;margin-bottom:30px}.locations-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));margin-top:20px}.location-card{background:#fff;border:1px solid #e9ecef;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden;transition:all .3s ease}.location-card:hover{box-shadow:0 8px 25px #00000026;transform:translateY(-2px)}.location-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e9ecef;display:flex;justify-content:space-between;padding:20px}.location-header h3{color:#333;font-size:18px;font-weight:600;margin:0}.location-actions{display:flex;gap:10px}.location-actions .edit-btn{background:#6c757d;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:12px;font-weight:600;padding:6px 12px;transition:all .3s ease}.location-actions .edit-btn:hover{background:#5a6268;transform:translateY(-1px)}.location-details{padding:20px}.location-details .detail-item{font-size:14px;line-height:1.5;margin-bottom:12px}.location-details .detail-item:last-child{margin-bottom:0}.location-details .detail-item strong{color:#333;display:inline-block;font-weight:600;min-width:120px}.btn{gap:8px;min-height:40px;padding:10px 20px}.btn-primary{background:#007bff;box-shadow:0 2px 4px #007bff33}.btn-primary:hover:not(:disabled){background:#0056b3;box-shadow:0 4px 12px #007bff4d;transform:translateY(-1px)}.btn-secondary{background:#6c757d;box-shadow:0 2px 4px #6c757d33}.btn-secondary:hover:not(:disabled){background:#5a6268;box-shadow:0 4px 12px #6c757d4d;transform:translateY(-1px)}.btn-success{background:#28a745;box-shadow:0 2px 4px #28a74533}.btn-success:hover:not(:disabled){background:#218838;box-shadow:0 4px 12px #28a7454d}.btn-warning{background:#ffc107;box-shadow:0 2px 4px #ffc10733;color:#333}.btn-warning:hover:not(:disabled){background:#e0a800;box-shadow:0 4px 12px #ffc1074d}.btn-danger{background:#dc3545;box-shadow:0 2px 4px #dc354533}.btn-danger:hover:not(:disabled){background:#c82333;box-shadow:0 4px 12px #dc35454d;transform:translateY(-1px)}.btn-outline{background:#0000;border:2px solid #007bff;color:#007bff}.btn-outline:hover:not(:disabled){background:#007bff;color:#fff;transform:translateY(-1px)}.btn-lg{font-size:16px}.site-header{align-items:center;border-bottom:2px solid #e9ecef;display:flex;justify-content:space-between;margin-bottom:20px;padding-bottom:15px}.site-header h2{color:#333;font-size:24px;margin:0}.site-actions{display:flex;flex-wrap:wrap;gap:10px}@media (max-width:768px){.locations-header{align-items:flex-start;flex-direction:column;gap:15px}.locations-grid{grid-template-columns:1fr}.site-actions{flex-direction:column;width:100%}.site-actions button{justify-content:center;width:100%}.location-header{align-items:flex-start;flex-direction:column;gap:15px}.location-actions{width:100%}.location-actions .edit-btn{justify-content:center;width:100%}}.system-landing{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;min-height:100vh}.hero-section{background:linear-gradient(135deg,#667eeae6,#764ba2e6);padding:80px 20px;text-align:center}.hero-content{margin:0 auto;max-width:800px}.hero-title{font-size:3.5rem;font-weight:700;line-height:1.2;margin-bottom:1.5rem}.hero-subtitle{font-size:1.25rem;line-height:1.6;margin-bottom:2.5rem;opacity:.95}.hero-actions,.user-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.cta-button{align-items:center;border:none;border-radius:12px;cursor:pointer;display:inline-flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;min-width:200px;padding:1rem 2rem;text-decoration:none;transition:all .3s ease}.cta-button.primary{background:linear-gradient(135deg,#ff6b6b,#ee5a52);box-shadow:0 4px 15px #ff6b6b66;color:#fff}.cta-button.primary:hover{box-shadow:0 6px 20px #ff6b6b99;transform:translateY(-2px)}.cta-button.secondary{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fff3;border:2px solid #ffffff4d;color:#fff}.cta-button.secondary:hover{background:#ffffff4d;transform:translateY(-2px)}.btn-icon{font-size:1.2rem}.container{margin:0 auto;max-width:1200px;padding:0 20px}.section-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem;text-align:center}.section-subtitle{font-size:1.1rem;margin-bottom:3rem;margin-left:auto;margin-right:auto;max-width:600px;opacity:.9;text-align:center}.quick-actions-section{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;padding:80px 0}.quick-actions-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:3rem}.quick-action-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:2px solid #fff3;border-radius:16px;color:#fff;cursor:pointer;padding:2rem;text-align:center;text-decoration:none;transition:all .3s ease}.quick-action-card:hover{background:#fff3;box-shadow:0 10px 30px #0003;transform:translateY(-5px)}.action-icon{font-size:3rem;margin-bottom:1rem}.action-title{font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.action-description{font-size:.95rem;line-height:1.4;opacity:.8}.stats-section{background:#ffffff0d;padding:80px 0}.stats-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:3rem}.stat-card{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff1a;border:1px solid #fff3;border-radius:16px;padding:2rem}.stat-icon{font-size:2.5rem;margin-bottom:1rem}.stat-number{color:#ff6b6b;margin-bottom:.5rem}.stat-label{font-size:1rem;font-weight:500;opacity:.9}.features-section{background:#ffffff1a;padding:80px 0}.features-carousel{margin:0 auto;max-width:800px}.feature-display{margin-bottom:2rem}.feature-card-large{-webkit-backdrop-filter:blur(15px);backdrop-filter:blur(15px);background:#ffffff26;border:2px solid #fff3;border-radius:20px;padding:3rem;text-align:center}.feature-icon-large{font-size:4rem;margin-bottom:1.5rem}.feature-title-large{font-size:2rem;font-weight:700;margin-bottom:1rem}.feature-description-large{font-size:1.1rem;line-height:1.6;margin-bottom:2rem;opacity:.95}.feature-highlights{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center;list-style:none;padding:0}.highlight-item{align-items:center;background:#ffffff1a;border-radius:25px;display:flex;font-size:.9rem;font-weight:500;gap:.5rem;padding:.5rem 1rem}.highlight-icon{color:#4ade80;font-weight:700}.feature-navigation{display:flex;justify-content:center;margin-top:2rem}.feature-dots{display:flex;gap:.5rem}.feature-dot{background:#ffffff4d;border:none;border-radius:50%;cursor:pointer;height:12px;transition:all .3s ease;width:12px}.feature-dot.active{background:#ff6b6b;transform:scale(1.2)}.feature-dot:hover{background:#fff9}.cta-section{background:#ffffff0d;padding:80px 0}.cta-content{margin:0 auto;max-width:600px;text-align:center}.cta-title{font-size:2.5rem;font-weight:700;margin-bottom:1rem}.cta-subtitle{font-size:1.1rem;line-height:1.6;margin-bottom:2.5rem;opacity:.9}.cta-actions{flex-wrap:wrap;gap:1rem}.access-denied,.cta-actions{display:flex;justify-content:center}.access-denied{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);min-height:100vh;padding:20px}.access-denied-content{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff2;border-radius:20px;box-shadow:0 20px 40px #0000001a;max-width:500px;padding:3rem;text-align:center;width:100%}.access-denied h2{font-size:2rem;font-weight:700}.access-denied-message{color:#374151;font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.access-denied-reason{color:#6b7280;font-size:.95rem;line-height:1.5;margin-bottom:2rem}.access-denied-actions{display:flex;flex-wrap:wrap;gap:1rem;justify-content:center}.btn-primary,.btn-secondary{border:none;border-radius:8px;cursor:pointer;display:inline-block;font-weight:600;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.btn-primary{background:linear-gradient(135deg,#667eea,#764ba2)}.btn-primary:hover{box-shadow:0 4px 15px #667eea66;transform:translateY(-2px)}.btn-secondary{background:#6b72801a;border:2px solid #6b728033;color:#374151}.btn-secondary:hover{background:#6b728033;transform:translateY(-2px)}@media (max-width:480px){.access-denied-content{padding:2rem}.access-denied h2{font-size:1.5rem}.access-denied-actions{align-items:center;flex-direction:column}.btn-primary,.btn-secondary{max-width:200px;width:100%}}@media (max-width:768px){.hero-title{font-size:2.5rem}.hero-subtitle{font-size:1.1rem}.section-title{font-size:2rem}.quick-actions-grid{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(2,1fr)}.cta-button{max-width:300px;min-width:auto;width:100%}.cta-actions,.feature-highlights,.hero-actions,.user-actions{align-items:center;flex-direction:column}}@media (max-width:480px){.hero-section{padding:60px 20px}.hero-title{font-size:2rem}.cta-section,.features-section,.quick-actions-section,.stats-section{padding:60px 0}.stats-grid{grid-template-columns:1fr}.feature-card-large{padding:2rem}.feature-icon-large{font-size:3rem}.feature-title-large{font-size:1.5rem}}.pricing-section{background:linear-gradient(135deg,#f8f9fa,#e9ecef);color:#2c3e50;padding:80px 20px}.pricing-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-left:auto;margin-right:auto;margin-top:3rem;max-width:1000px}.pricing-card{background:#fff;border-radius:16px;box-shadow:0 8px 32px #0000001a;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.pricing-card:hover{box-shadow:0 16px 48px #00000026;transform:translateY(-8px)}.pricing-card.basic{border:2px solid #3498db}.pricing-card.intermediate{border:2px solid #9b59b6;transform:scale(1.05)}.pricing-card.pro{border:2px solid #e67e22}.pricing-card.intermediate:before{background:linear-gradient(135deg,#9b59b6,#8e44ad);border-radius:0 16px 0 16px;color:#fff;content:"Más Popular";font-size:.8rem;font-weight:600;padding:.5rem 1rem;position:absolute;right:0;text-transform:uppercase;top:0}.pricing-header{margin-bottom:2rem;text-align:center}.plan-name{font-size:1.5rem;font-weight:700;margin:0 0 1rem}.plan-price{margin-bottom:1rem}.price-free{color:#27ae60;font-size:2.5rem;font-weight:700}.price-amount{color:#2c3e50;font-size:3rem;font-weight:700}.price-period{color:#7f8c8d;font-size:1rem;font-weight:400}.plan-features{margin-bottom:2rem}.plan-features li{align-items:center;border-bottom:1px solid #ecf0f1;display:flex;padding:.75rem 0}.plan-features li:last-child{border-bottom:none}.feature-icon{color:#27ae60;font-size:1.1rem;font-weight:700;margin-right:.75rem}.feature-text{color:#34495e;font-weight:500}.plan-cta,.pricing-note{text-align:center}.pricing-note{background:#3498db1a;border:1px solid #3498db33;border-radius:12px;margin-top:3rem;padding:1.5rem}.pricing-note p{color:#2c3e50;font-size:.95rem;margin:0}.pricing-note strong{color:#2980b9}@media (max-width:768px){.pricing-section{padding:60px 20px}.pricing-grid{gap:1.5rem;grid-template-columns:1fr}.pricing-card.intermediate{transform:none}.pricing-card{padding:1.5rem}}@media (max-width:480px){.pricing-section{padding:40px 15px}.pricing-card{padding:1.25rem}.plan-name{font-size:1.25rem}.price-amount{font-size:2.5rem}.price-free{font-size:2rem}}.sport-admin{margin:0 auto;max-width:1200px;overflow:visible;padding:20px;position:relative}.sport-admin-header{align-items:center;border-bottom:2px solid #e0e0e0;display:flex;justify-content:space-between;margin-bottom:30px;padding-bottom:20px}.sport-admin-header h2{color:#333;font-size:2rem;margin:0}.sport-form-modal{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.sport-form-container{background:#fff;border-radius:10px;box-shadow:0 10px 30px #0000004d;max-height:90vh;max-width:500px;overflow-y:auto;padding:30px;width:90%}.sport-form-container h3{color:#333;margin-bottom:20px;margin-top:0;text-align:center}.sport-form{gap:20px}.form-group,.sport-form{display:flex;flex-direction:column}.form-group label{color:#555;font-weight:600;margin-bottom:5px}.form-group input,.form-group select,.form-group textarea{border:2px solid #ddd;border-radius:5px;font-size:14px;padding:10px;transition:border-color .3s ease}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{border-color:#007bff;outline:none}.form-group textarea{min-height:80px;resize:vertical}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}.sports-list{margin-top:30px;position:relative;z-index:1}.no-sports{color:#666;padding:60px 20px;text-align:center}.no-sports-icon{font-size:4rem;margin-bottom:20px}.no-sports h3{color:#333;margin-bottom:10px}.sports-grid{grid-gap:20px;align-items:start;display:grid;gap:20px;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.sport-card{background:#fff;border:1px solid #e0e0e0;border-radius:10px;box-shadow:0 2px 10px #0000001a;display:flex;flex-direction:column;max-height:none;min-height:200px;overflow:visible;padding:20px;transition:transform .2s ease,box-shadow .2s ease}.sport-card:hover{box-shadow:0 4px 20px #00000026;transform:translateY(-2px)}.sport-header{align-items:center;display:flex;flex-shrink:0;margin-bottom:15px}.sport-icon{font-size:2rem;margin-right:15px}.sport-header h3{color:#333;font-size:1.2rem;margin:0}.sport-details{flex-grow:1;margin-bottom:20px}.sport-category,.sport-description{font-size:14px;line-height:1.4;margin-bottom:10px}.sport-category strong,.sport-description strong{color:#555}.sport-actions{display:flex;flex-shrink:0;gap:8px;justify-content:flex-end;margin-top:auto}.btn{border-radius:5px;font-size:14px;gap:5px}.btn-primary{background-color:#007bff}.btn-primary:hover{background-color:#0056b3}.btn-secondary{background-color:#6c757d}.btn-secondary:hover{background-color:#545b62}.btn-danger{background-color:#dc3545;color:#fff}.btn-danger:hover{background-color:#c82333}.btn-sm{font-size:12px;min-width:80px;text-align:center;white-space:nowrap}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:5px;color:#721c24;margin-bottom:20px;padding:15px}@media (max-width:768px){.sport-admin{padding:15px}.sport-admin-header{flex-direction:column;gap:15px;text-align:center}.sports-grid{grid-template-columns:1fr}.sport-form-container{padding:20px;width:95%}.form-actions{flex-direction:column}.sport-actions{flex-direction:row;gap:10px;justify-content:space-between}.sport-card{min-height:180px}}@media (max-width:480px){.sport-actions{flex-direction:column;gap:8px}.btn-sm{min-width:auto;width:100%}}.plan-management{margin:0 auto;max-width:1200px;padding:2rem}.plan-management-header{margin-bottom:2rem}.plan-management-header h2{color:#2c3e50;margin-bottom:.5rem}.plan-management-header p{color:#7f8c8d;font-size:1.1rem}.plan-definitions{margin-bottom:3rem}.plan-definitions h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem}.plans-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.plan-card{background:#fff;border:2px solid #ecf0f1;border-radius:12px;padding:1.5rem;transition:all .3s ease}.plan-card:hover{border-color:#3498db;box-shadow:0 4px 12px #3498db1a}.plan-header{margin-bottom:1rem}.plan-name{color:#2c3e50;font-size:1.2rem;margin:0 0 .5rem}.plan-price{color:#27ae60;font-size:1.5rem;font-weight:700}.plan-features h5{color:#34495e;font-size:1rem;margin:0 0 .5rem}.plan-features ul{list-style:none;margin:0;padding:0}.plan-features li{color:#7f8c8d;font-size:.9rem;padding:.25rem 0}.plan-features li:before{color:#27ae60;content:"✓ ";font-weight:700}.sites-plans h3{color:#2c3e50;font-size:1.3rem;margin-bottom:1.5rem}.no-sites{background:#f8f9fa;border-radius:8px;color:#7f8c8d;padding:3rem;text-align:center}.sites-table{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;overflow:hidden}.table-header{background:#f8f9fa;border-bottom:2px solid #ecf0f1;color:#2c3e50;font-weight:700}.table-header,.table-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:2fr 1.5fr 2fr 1fr;padding:1rem}.table-row{align-items:center;border-bottom:1px solid #ecf0f1}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8f9fa}.site-info h4{color:#2c3e50;font-size:1rem;margin:0 0 .25rem}.site-info p{color:#7f8c8d;font-size:.85rem;margin:0}.plan-selector{background:#fff;border:1px solid #bdc3c7;border-radius:4px;color:#2c3e50;font-size:.9rem;padding:.5rem;width:100%}.plan-selector:focus{border-color:#3498db;box-shadow:0 0 0 2px #3498db33;outline:none}.modules-list{display:flex;flex-wrap:wrap;gap:.25rem}.module-tag{background:#e3f2fd;border-radius:12px;color:#1976d2;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.btn{border-radius:4px;font-weight:500;padding:.5rem 1rem}.btn-primary{background:#3498db}.btn-primary:hover:not(:disabled){background:#2980b9}.btn-sm{padding:.375rem .75rem}@media (max-width:768px){.plan-management{padding:1rem}.plans-grid,.table-header,.table-row{grid-template-columns:1fr}.table-header,.table-row{gap:.5rem}.col-actions,.col-modules,.col-plan,.col-site{margin-bottom:.5rem}.table-header{display:none}.table-row{border:1px solid #ecf0f1;border-radius:8px;margin-bottom:1rem;padding:1rem}.col-site:before{color:#2c3e50;content:"Centro Deportivo: ";font-weight:700}.col-plan:before{color:#2c3e50;content:"Plan: ";font-weight:700}.col-modules:before{color:#2c3e50;content:"Módulos: ";font-weight:700}.col-actions:before{color:#2c3e50;content:"Acciones: ";font-weight:700}}.module-management{margin:0 auto;max-width:1200px;padding:2rem}.module-management-header{margin-bottom:2rem}.module-management-header h2{color:#2c3e50;margin-bottom:.5rem}.module-management-header p{color:#7f8c8d;font-size:1.1rem}.alert{align-items:center;border-radius:8px;display:flex;margin-bottom:1.5rem;padding:1rem;position:relative}.alert-error{background-color:#fee;border:1px solid #fcc;color:#c33}.alert-success{background-color:#efe;border:1px solid #cfc;color:#3c3}.alert-icon{font-size:1.2rem;margin-right:.5rem}.alert-text{flex:1 1}.alert-close{background:none;border:none;cursor:pointer;font-size:1.5rem;margin-left:.5rem;opacity:.7;padding:0}.alert-close:hover{opacity:1}.loading-overlay{align-items:center;background-color:#ffffffe6;border-radius:8px;display:flex;flex-direction:column;justify-content:center;margin-bottom:1rem;padding:2rem}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin-bottom:1rem;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.site-selector{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem;padding:1.5rem}.site-selector label{color:#2c3e50;display:block;font-weight:600;margin-bottom:.5rem}.site-select{background:#fff;border:2px solid #bdc3c7;border-radius:6px;color:#2c3e50;font-size:1rem;max-width:400px;padding:.75rem;width:100%}.site-select:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db33;outline:none}.module-management-content{display:flex;flex-direction:column;gap:2rem}.site-info{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:12px;box-shadow:0 4px 12px #00000026;color:#fff;padding:1.5rem}.site-info h3{font-size:1.5rem;margin:0 0 .5rem}.site-info p{margin:0 0 1rem;opacity:.9}.site-plan-info{align-items:center;display:flex}.plan-badge{border-radius:20px;font-size:.9rem;font-weight:600;padding:.5rem 1rem;text-transform:uppercase}.plan-badge-basic{background:#3498db33;border:1px solid #3498db;color:#3498db}.plan-badge-intermediate{background:#9b59b633;border:1px solid #9b59b6;color:#9b59b6}.plan-badge-pro{background:#e67e2233;border:1px solid #e67e22;color:#e67e22}.module-definitions h4{color:#2c3e50;font-size:1.2rem;margin-bottom:1.5rem}.modules-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr))}.module-card{background:#fff;border:2px solid #ecf0f1;border-radius:12px;padding:1.5rem;position:relative;transition:all .3s ease}.module-card.enabled{background:linear-gradient(135deg,#fff,#f8fff8);border-color:#27ae60}.module-card.disabled{border-color:#bdc3c7;opacity:.8}.module-card.unavailable{background:linear-gradient(135deg,#fff,#fff8f8);border-color:#e74c3c;opacity:.7}.module-card:hover{box-shadow:0 6px 20px #0000001a;transform:translateY(-2px)}.module-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1rem}.module-name{color:#2c3e50;flex:1 1;font-size:1.1rem;margin:0}.module-plan-badge{background:#e3f2fd;border-radius:8px;color:#1976d2;font-size:.75rem;font-weight:600;margin-left:.5rem;padding:.25rem .5rem;text-transform:uppercase}.module-description{color:#7f8c8d;font-size:.9rem;line-height:1.4;margin:0 0 1rem}.module-status{align-items:center;display:flex;justify-content:space-between}.status-badge{border-radius:20px;font-size:.8rem;font-weight:600;padding:.5rem 1rem;text-transform:uppercase}.status-badge.unavailable{background:#fee;border:1px solid #e74c3c;color:#e74c3c}.module-controls{align-items:center;display:flex;gap:.75rem}.status-text{color:#2c3e50;font-size:.9rem;font-weight:500}.toggle-switch{display:inline-block;height:24px;position:relative;width:50px}.toggle-switch input{height:0;opacity:0;width:0}.toggle-slider{background-color:#bdc3c7;border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:.3s}.toggle-slider:before{background-color:#fff;border-radius:50%;bottom:3px;box-shadow:0 2px 4px #0003;content:"";height:18px;left:3px;position:absolute;transition:.3s;width:18px}.toggle-switch input:checked+.toggle-slider{background-color:#27ae60}.toggle-switch input:checked+.toggle-slider:before{transform:translateX(26px)}.toggle-switch input:disabled+.toggle-slider{cursor:not-allowed;opacity:.6}.quick-actions{background:#fff;border-radius:8px;box-shadow:0 2px 8px #0000001a;padding:1.5rem}.quick-actions h4{color:#2c3e50;font-size:1.1rem;margin-bottom:1rem}.action-buttons{display:flex;flex-wrap:wrap;gap:1rem}.btn{border-radius:6px;display:inline-block;padding:.75rem 1.5rem;text-align:center;transition:all .2s ease}.btn-success{background:#27ae60;color:#fff}.btn-success:hover:not(:disabled){background:#229954;transform:translateY(-1px)}.btn-warning{background:#f39c12}.btn-warning:hover:not(:disabled){background:#e67e22;transform:translateY(-1px)}@media (max-width:768px){.module-management{padding:1rem}.modules-grid{grid-template-columns:1fr}.module-header{align-items:flex-start;flex-direction:column;gap:.5rem}.module-plan-badge{margin-left:0}.action-buttons{flex-direction:column}.btn{width:100%}}@media (max-width:480px){.module-management{padding:.5rem}.module-card,.quick-actions,.site-info{padding:1rem}}.administration{background-color:#f8f9fa;min-height:100vh}.administration-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:40px 20px;text-align:center}.administration-header h1{font-size:2.5rem;font-weight:700;margin:0 0 10px}.administration-header p{font-size:1.1rem;margin:0;opacity:.9}.administration-content{margin:0 auto;max-width:1200px;padding:20px}.admin-tabs{border-bottom:2px solid #e0e0e0;display:flex;gap:10px;margin-bottom:30px;overflow-x:auto}.admin-tab{align-items:center;background:none;border:none;border-bottom:3px solid #0000;color:#666;cursor:pointer;display:flex;font-size:16px;font-weight:500;gap:8px;padding:12px 20px;transition:all .3s ease;white-space:nowrap}.admin-tab:hover{background-color:#f8f9fa;color:#007bff}.admin-tab.active{background-color:#fff;border-bottom-color:#007bff;color:#007bff}.tab-icon{font-size:1.2rem}.tab-label{font-weight:600}.admin-content{background:#fff;border-radius:10px;box-shadow:0 2px 10px #0000001a;overflow:hidden}@media (max-width:768px){.administration-header{padding:30px 15px}.administration-header h1{font-size:2rem}.administration-content{padding:15px}.admin-tabs{gap:5px}.admin-tab{font-size:14px;padding:10px 15px}.tab-icon{font-size:1rem}}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#fff;color:#1f2937;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.app{display:flex;flex-direction:column;min-height:100vh}.main-content{box-sizing:border-box;flex:1 1;margin:0 auto;max-width:1200px;padding:20px;width:100%}.access-denied{border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:20px 0;padding:40px 20px}.access-denied h2{margin-bottom:16px}.access-denied p{margin-bottom:8px}.auth-callback{align-items:center;display:flex;justify-content:center;min-height:100vh;padding:20px}.error-container,.success-container{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;max-width:400px;padding:40px;text-align:center;width:100%}.error-container h2,.success-container h2{color:#374151;margin-bottom:16px}.error-container p,.success-container p{color:#6b7280;margin-bottom:20px}.error-container h2{color:#dc2626}.error-container button{background:#3b82f6;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;padding:10px 20px}.error-container button:hover{background:#2563eb}.success-container h2{color:#059669}.btn{align-items:center;border:none;border-radius:8px;box-shadow:0 2px 4px #0000001a;cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:600;gap:6px;justify-content:center;min-height:36px;padding:8px 16px;text-decoration:none;transition:all .3s ease}.btn-primary{background:#3b82f6;box-shadow:0 2px 4px #3b82f633;color:#fff}.btn-primary:hover{background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.btn-secondary{background:#6b7280;box-shadow:0 2px 4px #6b728033;color:#fff}.btn-secondary:hover{background:#4b5563;box-shadow:0 4px 12px #6b72804d;transform:translateY(-1px)}.btn-info{background:#06b6d4;box-shadow:0 2px 4px #06b6d433;color:#fff}.btn-info:hover{background:#0891b2;box-shadow:0 4px 12px #06b6d44d;transform:translateY(-1px)}.btn-warning{background:#f59e0b;box-shadow:0 2px 4px #f59e0b33;color:#fff}.btn-warning:hover{background:#d97706;box-shadow:0 4px 12px #f59e0b4d;transform:translateY(-1px)}.btn-sm{font-size:.8rem;gap:4px;min-height:32px;padding:6px 12px}.btn-lg{font-size:1.1rem;gap:8px;min-height:48px;padding:12px 24px}.btn:disabled{box-shadow:0 1px 2px #0000001a!important;cursor:not-allowed;opacity:.6;transform:none!important}.btn:focus{box-shadow:0 0 0 3px #3b82f64d;outline:none}.card{background:#fff;border-radius:8px;box-shadow:0 1px 3px #0000001a;margin-bottom:20px;padding:20px}.card h3{color:#111827;margin-top:0}.member-list{list-style:none;margin:0;padding:0}.member-list li{border-bottom:1px solid #e5e7eb;padding:12px 16px;transition:background-color .2s ease}.member-list li:hover{background:#f9fafb}.member-list li:last-child{border-bottom:none}.member-list a{color:#374151;font-weight:500;text-decoration:none}.member-list a:hover{color:#667eea}.home-welcome{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:20px}.home-welcome .welcome-section{max-width:800px;width:100%}.home-welcome .welcome-card{background:#fff;border:2px solid #e9ecef;border-radius:20px;box-shadow:0 20px 40px #0000001a;overflow:hidden;padding:50px 40px;position:relative;text-align:center}.home-welcome .welcome-card:before{background:linear-gradient(90deg,#007bff,#28a745,#ffc107,#dc3545);content:"";height:5px;left:0;position:absolute;right:0;top:0}.home-welcome .welcome-icon{animation:bounce 2s infinite;display:block;font-size:4em;margin-bottom:20px}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.home-welcome .welcome-card h2{color:#333;font-size:2.2em;font-weight:700;margin-bottom:20px}.home-welcome .welcome-description{color:#666;font-size:1.2em;line-height:1.6;margin-bottom:30px;margin-left:auto;margin-right:auto;max-width:600px}.home-welcome .welcome-features{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:40px;margin-left:auto;margin-right:auto;max-width:800px}.home-welcome .feature-item{align-items:center;background:#f8f9fa;border:2px solid #0000;border-radius:10px;display:flex;gap:12px;padding:15px;transition:all .3s ease}.home-welcome .feature-item:hover{background:#e3f2fd;border-color:#007bff;box-shadow:0 5px 15px #007bff1a;transform:translateY(-2px)}.home-welcome .feature-icon{font-size:1.5em;text-align:center;width:30px}.home-welcome .feature-item span:last-child{color:#333;font-size:.95em;font-weight:600}.home-welcome .welcome-create-btn{align-items:center;background:linear-gradient(45deg,#007bff,#0056b3);border:none;border-radius:12px;box-shadow:0 8px 25px #007bff4d;color:#fff;cursor:pointer;display:inline-flex;font-size:1.2em;font-weight:700;gap:10px;letter-spacing:.5px;padding:18px 35px;text-transform:uppercase;transition:all .3s ease}.home-welcome .welcome-create-btn:hover{background:linear-gradient(45deg,#0056b3,#004085);box-shadow:0 12px 35px #007bff66;transform:translateY(-3px)}.home-welcome .welcome-create-btn:active{transform:translateY(-1px)}.home-welcome .btn-icon{animation:rocket 2s infinite;font-size:1.3em}@keyframes rocket{0%,to{transform:translateX(0)}50%{transform:translateX(3px)}}.home-manager{background:#f8fafc;min-height:100vh;padding:20px}.manager-summary{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:0 auto;max-width:600px;padding:40px;text-align:center}.manager-summary h2{color:#333;font-size:2em;margin-bottom:15px}.manager-summary p{color:#666;font-size:1.1em;line-height:1.6;margin-bottom:30px}.manager-summary .quick-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.home-member{background:#f8fafc;min-height:100vh;padding:20px}.member-welcome{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;margin:0 auto;max-width:600px;padding:40px;text-align:center}.member-welcome h2{color:#333;font-size:2em;margin-bottom:15px}.member-welcome p{color:#666;font-size:1.1em;line-height:1.6;margin-bottom:30px}.member-welcome .member-actions{display:flex;flex-wrap:wrap;gap:15px;justify-content:center}.home-default{align-items:center;background:#f8fafc;display:flex;justify-content:center;min-height:100vh;padding:20px}.welcome-message{background:#fff;border:1px solid #e5e7eb;border-radius:12px;box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;max-width:500px;padding:40px;text-align:center}.welcome-message h2{color:#333;font-size:2em;margin-bottom:15px}.welcome-message p{color:#666;font-size:1.1em;line-height:1.6}.action-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:1em;font-weight:600;gap:8px;padding:12px 24px;text-align:center;text-decoration:none;transition:all .3s ease}.action-btn.primary{background:#3b82f6;border:1px solid #3b82f6;box-shadow:0 1px 2px 0 #0000000d;color:#fff}.action-btn.primary:hover{background:#2563eb;border-color:#2563eb;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;transform:translateY(-1px)}.action-btn.secondary{background:#fff;border:1px solid #d1d5db;color:#374151}.action-btn.secondary:hover{background:#f9fafb;border-color:#3b82f6;color:#3b82f6}.action-btn .icon{font-size:1.2em}@media (max-width:768px){.main-content{padding:16px}.home-welcome .welcome-card{padding:30px 20px}.home-welcome .welcome-card h2{font-size:1.8em}.home-welcome .welcome-description{font-size:1.1em}.home-welcome .welcome-features{gap:15px;grid-template-columns:1fr}.home-welcome .welcome-create-btn{font-size:1.1em;padding:15px 25px}.manager-summary .quick-actions,.member-welcome .member-actions{align-items:center;flex-direction:column}.action-btn{justify-content:center;max-width:300px;width:100%}}@media (max-width:480px){.home-welcome .welcome-card{border-radius:15px;padding:25px 15px}.home-welcome .welcome-card h2{font-size:1.6em}.home-welcome .welcome-description{font-size:1em}.home-welcome .welcome-icon{font-size:3em}.home-welcome .feature-item{gap:8px;padding:12px}.home-welcome .feature-icon{font-size:1.3em;width:25px}.home-welcome .welcome-create-btn{font-size:1em;justify-content:center;padding:12px 20px;width:100%}.manager-summary,.member-welcome,.welcome-message{padding:30px 20px}}.site-dashboard,.site-locations,.site-schedules,.site-settings{margin:0 auto;max-width:1200px;padding:2rem}.page-header,.site-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:2rem}.page-header h1,.site-header h1{color:#111827;font-size:2rem;font-weight:700;margin:0}.site-description{color:#6b7280;font-size:1.1rem;margin:.5rem 0 0}.site-stats{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.stat-card{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a;padding:1.5rem;text-align:center;transition:all .2s ease}.stat-card:hover{box-shadow:0 4px 6px #0000001a;transform:translateY(-1px)}.stat-card h3{color:#6b7280;font-size:.875rem;font-weight:500;letter-spacing:.05em;margin:0 0 .5rem;text-transform:uppercase}.stat-number{color:#111827;font-size:2.5rem;font-weight:700;margin:0}.page-header{border-bottom:1px solid #e5e7eb;margin-bottom:2rem;padding-bottom:1rem}.page-header h1{font-size:1.875rem;margin:0}.locations-content,.schedules-content,.settings-content{padding:2rem}.access-denied,.locations-content,.schedules-content,.settings-content{background:#fff;border:1px solid #e5e7eb;border-radius:.75rem;box-shadow:0 1px 3px #0000001a}.access-denied{margin:2rem auto;max-width:500px;padding:4rem 2rem;text-align:center}.access-denied h2{color:#dc2626;margin-bottom:1rem}.access-denied p{color:#6b7280;margin-bottom:1.5rem}@media (max-width:768px){.site-dashboard,.site-locations,.site-schedules,.site-settings{padding:1rem}.page-header,.site-header{align-items:stretch;flex-direction:column;gap:1rem}.page-header h1,.site-header h1{font-size:1.5rem}.site-stats{gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-card{padding:1rem}.stat-number{font-size:2rem}.locations-content,.schedules-content,.settings-content{padding:1.5rem}}@media (max-width:480px){.site-dashboard,.site-locations,.site-schedules,.site-settings{padding:.75rem}.page-header h1,.site-header h1{font-size:1.25rem}.site-stats{grid-template-columns:1fr}.stat-card{padding:.75rem}.stat-number{font-size:1.75rem}.locations-content,.schedules-content,.settings-content{padding:1rem}}@media (prefers-color-scheme:dark){.site-dashboard,.site-locations,.site-schedules,.site-settings{background:#111827;color:#f9fafb}.page-header h1,.site-header h1{color:#f9fafb}.site-description{color:#d1d5db}.stat-card{background:#1f2937;border-color:#374151;color:#f9fafb}.stat-card h3{color:#9ca3af}.stat-number{color:#f9fafb}.page-header{border-bottom-color:#374151}.access-denied,.locations-content,.schedules-content,.settings-content{background:#1f2937;border-color:#374151;color:#f9fafb}.access-denied h2{color:#fca5a5}.access-denied p{color:#d1d5db}}.training-tree-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:1000}.training-tree-container{background:#fff;border-radius:.75rem;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:flex;flex-direction:column;max-height:90vh;max-width:90vw;width:100%}.training-tree-header{align-items:center;background:#f9fafb;border-bottom:1px solid #e5e7eb;border-radius:.75rem .75rem 0 0;display:flex;justify-content:space-between;padding:1.5rem}.training-tree-header h3{color:#111827;font-size:1.25rem;font-weight:600;margin:0}.training-tree-content{flex:1 1;overflow:auto;padding:1.5rem}@media (prefers-color-scheme:dark){.training-tree-container{background:#1f2937;color:#f9fafb}.training-tree-header{background:#111827;border-bottom-color:#374151}.training-tree-header h3{color:#f9fafb}}
/*# sourceMappingURL=main.d255ad23.css.map*/