*,*:before,*:after{box-sizing:border-box}:root{font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;--primary-color: #646cff;--primary-hover: #535bf2;--secondary-color: #6c757d;--secondary-hover: #5a6268;--success-color: #51cf66;--danger-color: #ff6b6b;--warning-color: #ffa500;--error-color: #ff4444;--color-primary: var(--primary-color);--color-primary-light: #7b85ff;--color-success: var(--success-color);--color-error: var(--error-color);--color-warning: var(--warning-color);--text-primary: #213547;--text-secondary: #888;--text-muted: #666;--text-primary-dark: #646cff;--text-color: var(--text-primary);--text-secondary-color: var(--text-secondary);--bg-primary: rgba(255, 255, 255, .1);--bg-primary-light: rgba(255, 255, 255, .9);--bg-secondary: rgba(255, 255, 255, .08);--bg-tertiary: rgba(255, 255, 255, .03);--bg-card: rgba(100, 108, 255, .1);--bg-card-light: rgba(33, 53, 71, .1);--bg-feature: rgba(255, 255, 255, .05);--bg-feature-light: rgba(0, 0, 0, .05);--bg-warning: rgba(255, 165, 0, .1);--primary-bg: rgba(100, 108, 255, .1);--color-error-bg: rgba(255, 68, 68, .1);--color-primary-bg: rgba(100, 108, 255, .1);--surface-color: #ffffff;--background-color: #f5f5f5;--hover-color: #f0f0f0;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-xxl: 3rem;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-full: 50%;--font-size-xs: .75rem;--font-size-sm: .8rem;--font-size-base: .9rem;--font-size-md: 1rem;--font-size-lg: 1.1rem;--font-size-xl: 1.2rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--border-color: rgba(255, 255, 255, .1);--volume-width: 70%}body{margin:0;padding:0;min-width:320px;min-height:100vh;width:100vw;height:100vh;box-sizing:border-box;overflow-x:hidden}#app{width:100vw;height:100vh;margin:0;padding:0;text-align:center;box-sizing:border-box;display:flex;justify-content:center;align-items:stretch}.centered-app{max-width:1280px;margin:0 auto;padding:2rem;width:auto;height:auto}a{font-weight:500;color:var(--primary-color);text-decoration:inherit}a:hover{color:var(--primary-hover)}@media (prefers-color-scheme: dark){:root{--text-heading: var(--text-primary-dark);--bg-card-primary: var(--bg-card);--bg-button: #1a1a1a;--text-button: white}}.page-container{display:flex;justify-content:center;align-items:center;min-height:100vh;width:100%;height:100vh;box-sizing:border-box}.content-container{max-width:800px;margin:0 auto}.card{background:var(--bg-primary);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);padding:var(--space-xl);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);text-align:center;margin:1rem 0}.card--sm{min-width:400px}.card--md{min-width:500px}.card--responsive{min-width:400px}@media (max-width: 600px){.card--responsive{min-width:350px}}.heading{color:var(--text-heading);margin-bottom:var(--space-sm)}.heading--lg{font-size:var(--font-size-3xl);margin-bottom:var(--space-sm)}.heading--md{font-size:var(--font-size-md);margin:0}.text-muted{color:var(--text-secondary)}.text-small{font-size:var(--font-size-base);color:var(--text-secondary)}.btn{border:1px solid transparent;border-radius:var(--radius-md);font-weight:500;font-family:inherit;background-color:var(--bg-button);color:var(--text-button);cursor:pointer;transition:all .25s;text-decoration:none;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.75rem 1.5rem;font-size:var(--font-size-lg)}.btn:hover{border-color:var(--primary-color)}.btn:focus,.btn:focus-visible{outline:4px auto -webkit-focus-ring-color}.btn--primary{background-color:var(--primary-color);color:#fff}.btn--primary:hover{background-color:var(--primary-hover)}.btn--secondary{background:var(--secondary-color);color:#fff}.btn--secondary:hover{background:var(--secondary-hover)}.btn:disabled{opacity:.6;cursor:not-allowed}.btn--wide{min-width:200px}.avatar{width:60px;height:60px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--primary-color),var(--primary-hover));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-2xl);font-weight:700;flex-shrink:0}.user-display{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);background:var(--bg-card-primary);border-radius:var(--radius-md);margin-bottom:var(--space-xl);text-align:left}.user-info h3{margin:0 0 var(--space-xs) 0;color:var(--text-heading)}.user-email{margin:0 0 var(--space-sm) 0;color:var(--text-secondary);font-size:var(--font-size-base)}.user-role{margin:0}.role-badge{display:inline-block;padding:var(--space-xs) .75rem;border-radius:var(--radius-lg);font-size:var(--font-size-sm);font-weight:500;text-transform:uppercase}.role-badge--admin{background:var(--danger-color);color:#fff}.role-badge--user{background:var(--success-color);color:#fff}.features-section{margin-bottom:var(--space-xl)}.features-title{text-align:center;margin-bottom:var(--space-lg);color:var(--text-heading)}.feature-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:var(--space-md)}.feature-list{display:flex;flex-direction:column;gap:.75rem;text-align:left}.feature-card{padding:var(--space-lg) var(--space-md);background:var(--bg-feature);border-radius:var(--radius-md);text-align:center;transition:transform .2s}.feature-card:hover{transform:translateY(-2px)}.feature-card h4{margin:0 0 var(--space-sm) 0;color:var(--text-heading)}.feature-card p{margin:0;font-size:var(--font-size-base);color:var(--text-secondary)}.feature-item{display:flex;align-items:center;gap:.75rem;padding:var(--space-sm) 0}.feature-icon{font-size:var(--font-size-xl);width:24px;text-align:center}.feature-icon--lg{font-size:var(--font-size-3xl);margin-bottom:var(--space-sm)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-xl);flex-wrap:wrap;gap:var(--space-md)}.section{margin:var(--space-xl) 0}.section--sm{margin:var(--space-lg) 0}.actions{display:flex;gap:var(--space-md);justify-content:center;flex-wrap:wrap}.actions--vertical{flex-direction:column}.loading{display:inline-block;width:20px;height:20px;border:3px solid #f3f3f3;border-top:3px solid var(--primary-color);border-radius:var(--radius-full);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.message{padding:var(--space-md);border-radius:var(--radius-sm);margin:var(--space-md) 0}.message--error{background:var(--error-color);color:#fff}.message--warning{background:var(--bg-warning);text-align:center;margin-bottom:var(--space-xl)}.message--info,.message--info small{color:var(--text-secondary)}.message p{margin:var(--space-sm) 0;color:var(--text-muted)}.modal-backdrop{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-lg)}.modal{background:#fff;border-radius:var(--radius-lg);width:100%;max-width:600px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border-color);box-shadow:0 20px 40px #0000004d}.modal--large{max-width:800px}@media (prefers-color-scheme: dark){.modal{background:#1a1a2e;color:#fff}}.modal__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-lg);border-bottom:1px solid var(--border-color);background:var(--bg-feature)}.modal__header h2,.modal__header h3{margin:0;color:var(--text-heading);font-size:var(--font-size-xl)}.modal__close-btn{background:none;border:none;font-size:var(--font-size-2xl);cursor:pointer;color:var(--text-secondary);padding:var(--space-sm);border-radius:var(--radius-sm);transition:all .2s}.modal__close-btn:hover{background:var(--bg-primary);color:var(--text-heading)}.modal__content{flex:1;overflow-y:auto;padding:var(--space-lg)}.modal__actions{display:flex;gap:var(--space-md);justify-content:flex-end;padding:var(--space-lg);border-top:1px solid var(--border-color);background:var(--bg-feature)}.form-group{margin-bottom:0}.form-group label{display:block;margin-bottom:var(--space-xs);color:var(--text-heading);font-weight:500;font-size:var(--font-size-sm)}.form-input,.search-input,.form-group input[type=text],.form-group input[type=email],.form-group input[type=password],.form-group input[type=file],.form-group select,.form-group textarea{width:100%;padding:var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary);color:var(--text-heading);font-size:var(--font-size-sm);font-family:inherit}.form-input:focus,.search-input:focus,.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--primary-color)}.typeahead-container{position:relative;width:100%}.typeahead-container input{width:100%}.typeahead-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-primary-light);border:1px solid var(--border-color);border-top:none;border-radius:0 0 var(--radius-sm) var(--radius-sm);max-height:200px;overflow-y:auto;z-index:1000;box-shadow:0 4px 6px #0000001a}.typeahead-item{padding:var(--space-sm);cursor:pointer;transition:background-color .2s;color:var(--text-heading)}.typeahead-item:hover,.typeahead-item.selected{background:var(--bg-card);color:var(--primary-color)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:0;width:100%;max-width:100%;box-sizing:border-box}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-md);margin-top:var(--space-lg);width:100%}.content-container{padding:var(--space-md);max-width:100%;width:100%;display:flex;flex-direction:column;align-items:center;box-sizing:border-box}.content-container .header{display:flex;align-items:center;gap:var(--space-md);margin:0 0 var(--space-lg) 0;width:100%;max-width:800px}.content-container .header--actions{display:flex;gap:var(--space-sm);justify-content:center;align-items:center}.content-container .header--actions .btn{white-space:nowrap}.content-container .header h2{margin:0;padding:0;font-size:var(--font-size-xl);color:var(--text-heading)}.create-routine-form{width:100%!important;max-width:800px!important;box-sizing:border-box!important;display:flex!important;flex-direction:column!important;min-height:auto!important;margin:0 auto!important;align-items:center!important}.create-routine-form .switchable-content{width:100%!important;max-width:100%!important;min-width:0!important;display:flex!important;flex-direction:column!important;box-sizing:border-box!important;align-items:center!important}.create-routine-form>.form-row:first-of-type{width:100%!important;max-width:100%!important;min-width:0!important;flex-shrink:0!important;box-sizing:border-box!important}.create-routine-form>.form-row:first-of-type .form-group{min-height:auto;width:100%;max-width:100%}.create-routine-form>.form-row:first-of-type .form-group input{width:100%;max-width:100%;box-sizing:border-box;flex-shrink:0}.create-routine-form .form-group{display:flex;flex-direction:column}.create-routine-form .form-group:has(.athlete-routine-selector),.create-routine-form .athlete-routine-selector-container{width:100%!important;max-width:100%!important;min-width:0!important;display:flex!important;flex-direction:column!important;box-sizing:border-box!important;margin-bottom:var(--space-lg);min-height:0!important;align-items:center!important}.create-routine-form .form-row:has(input[type=file]),.create-routine-form .file-upload-container{height:400px!important;width:100%!important;max-width:100%!important;min-width:0!important;display:flex!important;flex-direction:column!important;justify-content:flex-start!important;align-items:center!important;padding:var(--space-md)!important;box-sizing:border-box!important}.file-upload-wrapper{display:flex;gap:var(--space-sm);align-items:center;margin-top:var(--space-md)}.file-display{flex:1;padding:var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-feature);color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tune-selection-mode{width:100%;max-width:100%;margin-top:var(--space-md);margin-bottom:var(--space-md)}.mode-label{display:block;margin-bottom:var(--space-sm);color:var(--text-heading);font-weight:500;font-size:var(--font-size-md)}.segmented-control{display:flex;flex-direction:row;gap:0;background:var(--bg-feature);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:4px;width:100%;max-width:600px;margin:0 auto}.segment-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-xs);padding:var(--space-sm) var(--space-lg);border:none;background:transparent;color:var(--text-secondary);font-size:var(--font-size-md);font-weight:500;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s ease;white-space:nowrap}.segment-btn:hover{background:var(--bg-primary);color:var(--text-heading)}.segment-btn.active{background:var(--bg-card);color:var(--primary-color);box-shadow:0 1px 3px #0000001a}.segment-icon{font-size:1.2em;line-height:1}.segment-text{font-size:var(--font-size-md)}.create-routine-form .athlete-routine-selector{overflow:hidden}.create-routine-form .form-row:has(input[type=file]){min-height:350px;display:flex;align-items:flex-start;padding-top:var(--space-md)}.create-routine-form .form-row .form-group:has(input[type=file]),.create-routine-form .form-row:contains("Upload audio file"){min-height:300px;display:flex;flex-direction:column;justify-content:flex-start}.form-section{margin-bottom:var(--space-md)}.form-section h3{margin:0 0 var(--space-sm) 0;color:var(--text-heading);font-size:var(--font-size-md)}.radio-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-top:var(--space-xs)}.radio-option{display:flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);border:1px solid var(--border-color);border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;background:var(--bg-primary)}.radio-option:hover{background:var(--bg-feature)}.radio-option input[type=radio]{margin:0}.radio-option input[type=radio]:checked+label,.radio-option:has(input[type=radio]:checked){background:var(--bg-card);border-color:var(--primary-color);color:var(--primary-color)}.selection-container{margin-bottom:var(--space-md)}.selection-lists{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:var(--space-xs);width:100%;max-width:100%}.athlete-routine-selector.mode-browser .selection-lists{height:100%}.list-section{display:flex;flex-direction:column}.list-section label{display:block;margin-bottom:var(--space-xs);color:var(--text-secondary);font-weight:700;font-size:.7rem;letter-spacing:.1em;text-transform:uppercase;font-family:system-ui,-apple-system,sans-serif}.selection-list{border:2px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-feature);overflow-y:auto;width:100%;max-width:100%;box-shadow:inset 0 1px 3px #0000000d}.athlete-routine-selector.mode-browser .selection-list{flex:1}.athlete-routine-selector.mode-add-routine{margin-bottom:var(--space-lg)}.athlete-routine-selector.mode-add-routine .selection-list{height:calc(100vh - 350px);max-height:none;min-height:300px}.list-item{padding:var(--space-sm);border-bottom:1px solid rgba(0,0,0,.05);cursor:pointer;transition:all .15s ease;color:var(--text-heading);background:transparent;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;font-size:var(--font-size-base);font-weight:400;letter-spacing:normal;word-wrap:break-word;overflow-wrap:break-word}.list-item:last-child{border-bottom:none}.list-item:hover{background:var(--bg-card);transform:translate(2px)}.list-item.selected{background:var(--primary-color);color:#fff;font-weight:500;box-shadow:0 2px 4px #0000001a}.list-item.selected:hover{background:var(--primary-color);transform:none}.routine-info{display:flex;justify-content:space-between;align-items:center}.routine-apparatus{font-weight:500}.routine-date{font-size:var(--font-size-sm);color:var(--text-secondary)}.list-item.selected .routine-date{color:#ffffffe6}.list-item.selected .routine-apparatus,.list-item.selected .routine-info{color:#fff}.empty-state{padding:var(--space-lg);text-align:center;color:var(--text-secondary);font-style:italic}.routine-player{background:var(--bg-feature);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);margin-top:var(--space-md)}.player-info{margin-bottom:var(--space-sm)}.track-name{font-weight:500;color:var(--text-heading);font-size:var(--font-size-sm)}.player-controls{display:flex;align-items:center;gap:var(--space-sm);flex-wrap:wrap}.play-btn{background:var(--primary-color);color:#fff;border:none;border-radius:var(--radius-full);width:40px;height:40px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:var(--font-size-md);transition:all .2s;flex-shrink:0}.play-btn:hover:not(:disabled){background:var(--primary-hover);transform:scale(1.05)}.play-btn:disabled{opacity:.6;cursor:not-allowed;transform:none}.progress-section{display:flex;align-items:center;gap:var(--space-xs);flex:1;min-width:200px}.routine-player .progress-bar{flex:1;height:4px;border-radius:2px;background:var(--border-color);outline:none;cursor:pointer}.routine-player .progress-bar::-webkit-slider-thumb{appearance:none;width:12px;height:12px;border-radius:50%;background:var(--primary-color);cursor:pointer}.routine-player .progress-bar::-moz-range-thumb{width:12px;height:12px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.time{font-size:var(--font-size-sm);color:var(--text-secondary);min-width:35px;text-align:center}.volume-section{display:flex;align-items:center;gap:var(--space-xs)}.volume-icon{font-size:var(--font-size-sm)}.volume-bar{width:60px;height:4px;border-radius:2px;background:var(--border-color);outline:none;cursor:pointer}.volume-bar::-webkit-slider-thumb{appearance:none;width:10px;height:10px;border-radius:50%;background:var(--primary-color);cursor:pointer}.volume-bar::-moz-range-thumb{width:10px;height:10px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.no-track{display:flex;align-items:center;color:var(--text-secondary);font-style:italic;font-size:var(--font-size-sm)}@media (max-width: 600px){.form-row{grid-template-columns:1fr}.selection-lists{grid-template-columns:minmax(0,1fr) minmax(0,1fr)}.athlete-routine-selector.mode-browser .selection-lists{height:100%}.athlete-routine-selector.mode-browser .selection-list{flex:1}.athlete-routine-selector.mode-add-routine .selection-list{max-height:200px;min-height:150px}}.modal .error-message{background:var(--error-color);color:#fff;padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.modal .success-message{background:var(--success-color);color:#fff;padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-lg)}.modal .warning{background:var(--bg-warning);border:1px solid var(--warning-color);border-radius:var(--radius-md);padding:var(--space-lg);margin-bottom:var(--space-lg);text-align:center}@media (max-width: 768px){.modal-backdrop{padding:var(--space-md)}.modal{max-width:calc(100vw - 2rem)}.modal__content{padding:var(--space-md)}.modal__actions{flex-direction:column}}.login-divider{margin:var(--space-md) 0;text-align:center;position:relative}.login-divider:before{content:"";position:absolute;top:50%;left:0;right:0;height:1px;background:var(--border-color);z-index:0}.login-divider span{background:var(--bg-primary);padding:0 var(--space-md);color:var(--text-secondary);font-size:var(--font-size-sm);position:relative;z-index:1}.btn--keycloak{width:100%;margin-top:var(--space-sm);display:flex;align-items:center;justify-content:center;gap:var(--space-sm)}.btn--keycloak:first-of-type{margin-top:0}.dashboard{display:flex;flex-direction:column;height:100vh;width:100%;max-width:1400px;background:var(--bg-primary);padding:0;box-sizing:border-box;overflow-x:hidden}.dashboard__header{position:fixed;top:0;left:0;right:0;z-index:100;background:var(--bg-primary);border-bottom:1px solid var(--border-color);display:flex;justify-content:center}.dashboard__header>*{width:100%}.dashboard__footer{position:fixed;bottom:0;left:0;right:0;z-index:100;background:var(--bg-primary);border-top:1px solid var(--border-color);display:flex;justify-content:center}.dashboard__footer>*{width:100%}.dashboard__content{flex:1;display:flex;flex-direction:column;padding-top:80px;padding-bottom:200px;overflow-y:auto;overflow-x:hidden;width:100%;max-width:100%;position:relative}.dashboard__main{flex:1;display:flex;flex-direction:column;width:100%;max-width:100%;min-height:0;overflow-y:auto;overflow-x:hidden;box-sizing:border-box}.dashboard__browser{flex:1;overflow:hidden;padding:0 var(--space-lg) var(--space-lg);width:100%;max-width:100%}main{width:100%;max-width:800px}.icon{width:20px;height:20px}.fab{position:fixed;bottom:140px;right:24px;width:56px;height:56px;border-radius:50%;background:var(--primary-color);color:#fff;border:none;font-size:32px;line-height:1;cursor:pointer;box-shadow:0 4px 8px #0000004d;z-index:90;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.fab:hover{background:var(--primary-hover);box-shadow:0 6px 12px #0006;transform:scale(1.05)}.fab:active{transform:scale(.95)}.browser{display:flex;flex-direction:column;height:100%;width:100%;max-width:100%;background:var(--bg-primary);border-radius:var(--radius-md);overflow:hidden;box-sizing:border-box;position:relative}.browser__notice{padding:var(--space-lg);background:var(--bg-card-primary);border-bottom:1px solid var(--border-color)}.browser__notice p{margin:0;color:var(--text-secondary);font-style:italic;text-align:center}.browser__controls{padding:var(--space-sm);background:var(--bg-feature);border-bottom:1px solid var(--border-color);flex-shrink:0;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box}.search-section{margin-bottom:0}.search-bar{display:flex;gap:var(--space-md);align-items:center;width:100%}.search-input{flex:1;min-width:0}.browser__content{flex:1;overflow-y:auto;padding:var(--space-sm);overflow-x:hidden;width:100%;box-sizing:border-box}.routine-list{background:var(--bg-card-primary);border-radius:var(--radius-md);overflow:hidden}.routine-header,.routine-item{display:grid;grid-template-columns:1fr 1fr 120px;gap:var(--space-md);align-items:center;padding:var(--space-md) var(--space-lg);border-bottom:1px solid var(--border-color)}.routine-header{background:var(--bg-feature);font-weight:600;color:var(--text-heading);font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.5px}.routine-item:last-child{border-bottom:none}.routine-item{cursor:pointer;transition:all .2s ease}.routine-item:hover{background:var(--bg-feature);transform:translateY(-1px);box-shadow:0 2px 8px #646cff1a}.routine-item:active{transform:translateY(0);box-shadow:0 1px 4px #646cff1a}.routine-item.selected{background:var(--bg-card);border-left:3px solid var(--primary-color);color:var(--primary-color);font-weight:500;box-shadow:0 2px 12px #646cff26}.routine-item.selected:hover{background:var(--bg-card);transform:translateY(-1px);box-shadow:0 4px 16px #646cff33}.routine-item.selected .routine-created{color:var(--primary-color);opacity:.8}.routine-item.selected .routine-apparatus,.routine-item.selected .routine-gymnast{color:var(--primary-color)}.routine-apparatus,.routine-gymnast{font-weight:500;color:var(--text-heading)}.routine-created{color:var(--text-secondary);font-size:var(--font-size-sm)}.loading-state,.error-state{padding:var(--space-xl);text-align:center}.loading-state{display:flex;flex-direction:column;align-items:center;gap:var(--space-md)}.loading-state p{margin:0;color:var(--text-secondary);font-style:italic}.error-state .error-message{margin:0;color:var(--error-color);font-weight:500}.browser__empty-state{flex:1;display:flex;align-items:center;justify-content:center;padding:var(--space-xl)}.empty-state-card{text-align:center;background:var(--bg-card-primary);padding:var(--space-xl);border-radius:var(--radius-md);max-width:400px}.empty-state-card h4{margin:0 0 var(--space-md) 0;color:var(--text-heading)}.empty-state-card p{margin:0;color:var(--text-secondary)}.player{display:flex;flex-direction:column;background:var(--bg-card-primary);border-top:1px solid var(--border-color)}.player__top{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);gap:var(--space-lg)}.player__bottom{padding:0 var(--space-lg) var(--space-md)}.player__info{flex:1;min-width:200px}.track-info{display:flex;align-items:center;gap:var(--space-md)}.album-art{width:50px;height:50px;border-radius:var(--radius-sm);overflow:hidden;flex-shrink:0}.album-art img{width:100%;height:100%;object-fit:cover}.album-art-placeholder{width:100%;height:100%;background:var(--bg-feature);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-xl)}.track-details{flex:1;display:flex;flex-direction:column;gap:2px}.track-title{font-weight:600;color:var(--text-heading);font-size:var(--font-size-lg);line-height:1.3}.track-artist{color:var(--text-secondary);font-size:var(--font-size-base);line-height:1.3}.track-club{color:var(--text-muted);font-size:var(--font-size-sm)}.no-track-icon{font-size:var(--font-size-2xl);opacity:.6}.no-track-text div{margin-bottom:var(--space-xs)}.no-track-text div:last-child{margin-bottom:0}.no-club-message{font-style:italic;font-size:var(--font-size-sm)}.instruction{font-size:var(--font-size-sm);color:var(--text-muted)}.player__controls{display:flex;align-items:center;justify-content:flex-end}.transport-controls{display:flex;align-items:center;gap:var(--space-md);position:relative}.control-btn{width:80px;height:80px;border:none;background:var(--bg-feature);cursor:pointer;border-radius:var(--radius-lg);transition:all .2s;display:flex;align-items:center;justify-content:center;color:var(--text-heading);font-size:2.5rem}.control-btn:hover:not(:disabled){background:var(--primary-color);color:#fff;transform:scale(1.05)}.control-btn:disabled{opacity:.5;cursor:not-allowed}.loading--sm{width:32px;height:32px;border-width:4px}.progress-section{display:flex;align-items:center;gap:var(--space-md);width:100%}.time-display{font-size:var(--font-size-sm);color:var(--text-secondary);min-width:40px;text-align:center}.progress-bar-container{position:relative;flex:1;height:6px;background:var(--bg-feature);border-radius:3px;overflow:hidden}.progress-bar-container input{position:absolute;top:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;z-index:2}.progress-fill{height:100%;background:var(--primary-color);transition:width .1s ease;border-radius:3px}.volume-btn{border:none;background:transparent;cursor:pointer;width:40px;height:40px;font-size:var(--font-size-xl);border-radius:var(--radius-sm);transition:background .2s ease;display:flex;align-items:center;justify-content:center}.volume-btn:hover{background:var(--bg-feature)}.volume-control-wrapper{position:relative;display:flex;align-items:center}.volume-popup{position:absolute;bottom:100%;left:50%;transform:translate(-50%);margin-bottom:8px;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);box-shadow:0 4px 12px #0000004d;display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);z-index:1000}.volume-slider-vertical{-webkit-appearance:slider-vertical;writing-mode:bt-lr;width:8px;height:120px;padding:0;background:var(--bg-feature);border-radius:4px;outline:none;cursor:pointer}.volume-slider-vertical::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer}.volume-slider-vertical::-moz-range-thumb{width:16px;height:16px;border-radius:50%;background:var(--primary-color);cursor:pointer;border:none}.volume-mute-btn{border:none;background:transparent;cursor:pointer;font-size:var(--font-size-lg);padding:var(--space-xs);border-radius:var(--radius-sm);transition:background .2s ease}.volume-mute-btn:hover{background:var(--bg-feature)}.status-bar{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-xl);background:var(--bg-card-primary);border-bottom:1px solid var(--border-color);gap:var(--space-lg)}.status-bar__left,.status-bar__user{display:flex;align-items:center;gap:var(--space-md)}.avatar--sm{width:40px;height:40px;font-size:var(--font-size-lg)}.user-info{display:flex;flex-direction:column;gap:var(--space-xs)}.user-name{font-weight:600;color:var(--text-heading);font-size:var(--font-size-base)}.user-role{font-size:var(--font-size-sm)}.status-bar__club{flex:1;display:flex;justify-content:center}.club-info{display:flex;align-items:center;gap:var(--space-sm);position:relative}.club-label{font-weight:500;color:var(--text-secondary)}.club-selector{position:relative}.club-button,.no-club-button{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;color:var(--text-heading);font-size:var(--font-size-base)}.club-button:hover,.no-club-button:hover{background:var(--bg-feature);border-color:var(--primary-color)}.club-name{font-weight:500}.club-role,.dropdown-arrow{color:var(--text-secondary);font-size:var(--font-size-sm)}.club-dropdown{position:absolute;top:100%;left:0;right:0;background:var(--bg-card-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 8px 24px #00000040;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);z-index:1000;min-width:200px;margin-top:var(--space-xs);overflow:hidden}.dropdown-item{width:100%;display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:transparent;border:none;cursor:pointer;text-align:left;transition:background-color .2s;color:var(--text-heading)}.dropdown-item:hover{background:var(--bg-feature)}.dropdown-item.active{background:var(--primary-color);color:#fff}.dropdown-item--action{color:var(--primary-color);font-weight:500}.dropdown-separator{height:1px;background:var(--border-color);margin:var(--space-xs) 0}.dropdown-message{padding:var(--space-md);color:var(--text-secondary);font-style:italic}.status-bar__actions{display:flex;gap:var(--space-sm)}.status-bar__placeholder{display:flex;align-items:center;gap:var(--space-md);color:var(--text-secondary)}.club-tabs{display:flex;width:100%;background:var(--bg-feature);border-bottom:1px solid var(--border-color)}.tab-btn{flex:1;padding:var(--space-md) var(--space-lg);background:transparent;border:none;cursor:pointer;color:var(--text-secondary);font-size:var(--font-size-base);transition:all .2s;border-bottom:2px solid transparent}.tab-btn:hover{background:var(--bg-primary);color:var(--text-heading)}.tab-btn.active{color:var(--primary-color);border-bottom-color:var(--primary-color);background:var(--bg-card-primary)}.clubs-list{max-height:300px;overflow-y:auto;margin-bottom:var(--space-lg)}.club-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:var(--space-md);cursor:pointer;transition:all .2s;background:var(--bg-primary)}.club-card:hover{background:var(--bg-feature);border-color:var(--primary-color)}.club-card.selected{border-color:var(--primary-color);background:var(--primary-color);color:#fff}.club-info{flex:1}.club-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.club-header h4{margin:0;color:inherit;font-size:var(--font-size-lg)}.selection-indicator{font-size:var(--font-size-xl);color:#fff;background:var(--success-color);border-radius:var(--radius-full);width:30px;height:30px;display:flex;align-items:center;justify-content:center}.join-confirmation{background:var(--bg-feature);padding:var(--space-lg);border-radius:var(--radius-md);border:1px solid var(--border-color)}.join-message{margin-bottom:var(--space-lg);color:var(--text-heading);font-weight:500}.create-info{margin-bottom:var(--space-lg)}.info-card{background:var(--bg-warning);border:1px solid var(--warning-color);border-radius:var(--radius-md);padding:var(--space-lg)}.info-card h4{margin:0 0 var(--space-md) 0;color:var(--text-heading)}.info-card ul{margin:0;padding-left:var(--space-lg);color:var(--text-heading)}.info-card li{margin-bottom:var(--space-xs)}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff;--text-heading: var(--text-primary);--text-color: var(--text-primary);--bg-primary: var(--bg-primary-light);--bg-secondary: #f5f5f5;--bg-tertiary: #e0e0e0;--bg-card-primary: var(--bg-card-light);--bg-feature: var(--bg-feature-light);--bg-button: #f9f9f9;--text-button: var(--text-primary);--border-color: rgba(0, 0, 0, .1);--surface-color: #ffffff;--background-color: #f5f5f5;--hover-color: #f0f0f0}a:hover{color:#747bff}.card{border:1px solid rgba(0,0,0,.1);background:#f9f9f9;border-color:#e6e6e6}.btn--primary,.button.primary{background-color:var(--primary-color);color:#fff}.button{background-color:#f9f9f9;color:#213547}.result-json{background:#f8f8f8;color:#333}}@media (max-width: 768px){.dashboard{max-width:100%}}@media (min-width: 768px) and (max-width: 1200px){.dashboard{max-width:1200px}}@media (min-width: 1200px) and (max-width: 1600px){.dashboard{max-width:1400px}}@media (min-width: 1600px){.dashboard{max-width:1600px}}@media (max-width: 600px){.page-header{text-align:center}.user-display{flex-direction:column;text-align:center}.actions{flex-direction:column}.feature-grid{grid-template-columns:1fr}.dashboard__content{padding-top:70px;padding-bottom:180px}.dashboard__browser{padding:0 var(--space-md) var(--space-md)}.routine-header,.routine-item{grid-template-columns:1fr 120px;gap:var(--space-sm)}.routine-col-gymnast,.routine-col-created{display:none}.search-bar{flex-direction:column;align-items:stretch}.dashboard__content{padding-top:60px;padding-bottom:90px}.fab{bottom:100px;right:16px;width:48px;height:48px;font-size:28px}.player__top{padding:var(--space-sm);flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-sm)}.player__bottom{padding:0 var(--space-sm) var(--space-sm)}.player__info{flex:1;min-width:0}.player__controls{flex-shrink:0}.progress-section{gap:var(--space-sm)}.track-info,.track-details{gap:0}.track-title,.track-artist,.no-track-text{font-size:var(--font-size-sm)}.control-btn{width:56px;height:56px;font-size:1.6rem}.transport-controls{gap:var(--space-xs)}.time-display{font-size:var(--font-size-sm);min-width:35px}.loading--sm{width:24px;height:24px;border-width:3px}.status-bar{flex-direction:row;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);justify-content:space-between;align-items:center}.status-bar__user{display:none}.status-bar__club{flex:1;justify-content:flex-start}.club-info{font-size:var(--font-size-sm)}.club-label{display:none}.club-button,.no-club-button{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm)}.club-dropdown{min-width:250px}.status-bar__actions{gap:var(--space-xs)}.status-bar__actions .btn{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-sm)}.club-card{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.selection-indicator{align-self:flex-end}.content-container{padding:var(--space-sm)}.content-container .header{margin:0 0 var(--space-md) 0}.content-container .header--actions{gap:var(--space-xs);flex-wrap:wrap;justify-content:center}.content-container .header h2{font-size:var(--font-size-lg);margin:0}.create-routine-form{width:100%!important;max-width:100%!important;min-width:0!important;min-height:0!important;padding:0!important}.create-routine-form .switchable-content{width:100%!important;max-width:100%!important;min-width:0!important;height:auto!important;min-height:250px!important;max-height:none!important}.create-routine-form>.form-row:first-of-type{width:100%!important;max-width:100%!important;min-width:0!important;flex-direction:column!important;gap:var(--space-sm)!important}.create-routine-form .form-group{min-height:auto!important;width:100%}.create-routine-form .form-group:has(.athlete-routine-selector),.create-routine-form .athlete-routine-selector-container{width:100%!important;max-width:100%!important;min-width:0!important;height:auto!important}.create-routine-form .form-row:has(input[type=file]),.create-routine-form .file-upload-container{width:100%!important;max-width:100%!important;min-width:0!important;height:auto!important;min-height:200px!important;padding:var(--space-sm)!important}.create-routine-form .form-row:has(input[type=file]){min-height:200px}.segmented-control{width:100%;max-width:100%;padding:3px}.segment-btn{padding:var(--space-xs) var(--space-sm);font-size:var(--font-size-sm);gap:4px}.segment-icon{font-size:1em}.segment-text{font-size:var(--font-size-sm)}.form-actions{flex-direction:column-reverse!important;gap:var(--space-sm)!important}.form-actions .btn{width:100%!important}.athlete-routine-selector .selection-lists{grid-template-columns:minmax(0,1fr) minmax(0,1fr)!important;gap:var(--space-xs)!important;height:100%}.athlete-routine-selector .list-section{display:flex;flex-direction:column;height:100%}.athlete-routine-selector.mode-browser .selection-list{flex:1!important;max-height:calc(100vh - 280px)!important;min-height:300px!important}.athlete-routine-selector.mode-add-routine .selection-list{height:calc(100vh - 400px)!important;max-height:none!important;min-height:250px!important}.file-upload-wrapper{flex-direction:column;gap:var(--space-sm);align-items:stretch}.file-display{padding:var(--space-sm);font-size:var(--font-size-sm)}.file-upload-wrapper .btn{width:100%}}@media (min-width: 768px){.card--responsive{min-width:500px}}.athlete-routine-selector{display:flex;flex-direction:column;width:100%;max-width:100%}.athlete-routine-selector.mode-browser{height:100%}.athlete-routine-selector .overall-title{margin:0 0 var(--space-sm) 0;padding:0;color:var(--text-heading);font-size:1rem;font-weight:600}.athlete-routine-selector .column{display:flex;flex-direction:column;min-height:0;min-width:0;max-width:100%}.athlete-routine-selector.mode-browser .column{height:100%}.athlete-routine-selector .list-section{display:flex;flex-direction:column;min-width:0;max-width:100%}.athlete-routine-selector.mode-browser .list-section{height:100%}.athlete-routine-selector .list-section h3{margin:0;padding-bottom:4px;color:var(--text-heading);font-size:1rem;font-weight:600}.athlete-routine-selector .routine-info{display:flex;flex-direction:column;gap:2px}.athlete-routine-selector .routine-header-row{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.athlete-routine-selector .routine-apparatus{font-weight:500;color:var(--text-heading);flex:1}.athlete-routine-selector .routine-status-icon{font-size:1.1rem;line-height:1;color:var(--success-color);flex-shrink:0}.athlete-routine-selector .list-item .routine-status-icon{color:var(--text-secondary)}.athlete-routine-selector .list-item.selected .routine-status-icon{color:#fff}.athlete-routine-selector .routine-date{font-size:.875rem;color:var(--text-secondary)}.athlete-routine-selector .routine-tags{display:flex;flex-wrap:wrap;gap:4px;margin-top:4px}.athlete-routine-selector .routine-tag{display:inline-block;padding:2px 8px;font-size:.75rem;background-color:var(--primary-light);color:var(--primary-color);border-radius:12px;font-weight:500}.athlete-routine-selector .list-item.selected .routine-tag{background-color:#fff3;color:#fff}.athlete-routine-selector .loading{color:var(--text-secondary);font-style:italic}.athlete-routine-selector .show-inactive-button{background-color:var(--bg-secondary);border-top:2px solid var(--border-color);font-style:italic;color:var(--text-secondary)}.athlete-routine-selector .show-inactive-button:hover{background-color:var(--primary-light);color:var(--primary-color);font-weight:500}.athlete-routine-selector .show-inactive-text{text-align:center;padding:var(--space-xs)}.notification-banner{position:fixed;top:0;left:0;right:0;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;z-index:1000;box-shadow:0 2px 8px #0000001a}.notification-banner__content{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;max-width:1200px;margin:0 auto}.notification-banner__text p{margin:4px 0 0;font-size:14px;opacity:.9}.notification-banner__actions{display:flex;gap:8px}.message-notifications{display:flex;align-items:center;gap:8px;position:relative}.message-notification-button{position:relative;background:none;border:none;color:var(--text-color, #333333);cursor:pointer;padding:8px;border-radius:4px;transition:background-color .2s}.message-notification-button:hover{background-color:#ffffff1a}.message-notification-button.has-unread{color:var(--primary-color, #667eea)}.unread-badge{position:absolute;top:0;right:0;background:#f44;color:#fff;border-radius:10px;padding:2px 6px;font-size:11px;font-weight:700;min-width:18px;text-align:center;transform:translate(25%,-25%)}.connection-status{display:flex;align-items:center}.status-dot{width:8px;height:8px;border-radius:50%;transition:background-color .3s}.status--connected .status-dot{background-color:#4caf50}.status--connecting .status-dot,.status--reconnecting .status-dot{background-color:#ff9800;animation:pulse 1.5s infinite}.status--disconnected .status-dot{background-color:#f44336}@keyframes pulse{0%{opacity:1}50%{opacity:.5}to{opacity:1}}.messages-panel{position:fixed;top:60px;right:20px;width:400px;max-height:500px;background:var(--surface-color, #ffffff);border:1px solid var(--border-color, #e0e0e0);border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:999;overflow:hidden}.messages-panel__header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color, #e0e0e0);background:var(--background-color, #f5f5f5)}.messages-panel__header h3{margin:0;font-size:18px;color:var(--text-color, #333333)}.close-button{background:none;border:none;color:var(--text-secondary-color, #666666);cursor:pointer;padding:4px;border-radius:4px;transition:background-color .2s}.close-button:hover{background-color:#ffffff1a}.messages-panel__content{max-height:400px;overflow-y:auto}.no-messages{padding:40px 20px;text-align:center;color:var(--text-secondary-color, #666666)}.message-list{padding:8px 0}.message-item{padding:16px 20px;border-left:3px solid transparent;border-bottom:1px solid var(--border-color, #e0e0e0);background:var(--surface-color, #ffffff);transition:background-color .2s}.message-item:hover{background:var(--hover-color, #f0f0f0)}.message-item.unread{background:#667eea0d;border-left:3px solid var(--primary-color, #667eea)}.message-item.join-request{border-left:3px solid #ff9800}.message-item.outgoing{background-color:#e8f5e8;border-left:5px solid #4caf50;margin-left:30px;border-radius:0 8px 8px 0}.message-item.incoming{background-color:#e3f2fd;border-left:5px solid #2196f3;margin-right:30px;border-radius:8px 0 0 8px}.message-item__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.sender-name{font-weight:600;color:var(--text-color, #333333)}.message-item.outgoing .sender-name{color:#2e7d32;font-weight:600}.message-item.incoming .sender-name{color:#1565c0;font-weight:600}.message-time{font-size:12px;color:var(--text-secondary-color, #666666)}.message-metadata{text-align:left;margin-bottom:8px}.message-from-to{display:flex;flex-direction:column;align-items:flex-start;gap:2px;margin-bottom:4px}.message-from,.message-to{font-size:12px;color:var(--text-secondary-color, #666666);font-style:italic}.message-subject{font-size:12px;color:var(--text-secondary-color, #666666);font-weight:500;text-align:left}.message-content{color:var(--text-secondary-color, #666666);line-height:1.4;margin-bottom:8px}.message-item.outgoing .message-content{color:#2e7d32}.message-item.incoming .message-content{color:#1565c0}.message-actions{display:flex;gap:8px;margin-top:12px}.message-status{font-size:12px;font-weight:500;padding:4px 8px;border-radius:4px;display:inline-block;margin-top:8px}.message-status.approved{background:#4caf501a;color:#4caf50}.message-status.rejected{background:#f443361a;color:#f44336}.mark-read-button{background:none;border:none;color:var(--primary-color, #667eea);cursor:pointer;font-size:12px;padding:4px 0;margin-top:8px;transition:opacity .2s}.mark-read-button:hover{opacity:.8}.growl-container{position:fixed;top:20px;right:20px;z-index:10000;display:flex;flex-direction:column;gap:10px}.growl-notification{background:#fff;border-radius:8px;box-shadow:0 4px 12px #00000026;border-left:4px solid;min-width:300px;max-width:400px;cursor:pointer;animation:slideInRight .3s ease-out}.growl-notification--success{border-left-color:#4caf50}.growl-notification--error{border-left-color:#f44336}.growl-notification--warning{border-left-color:#ff9800}.growl-notification--info{border-left-color:#2196f3}.growl-content{display:flex;align-items:center;padding:12px 16px;gap:12px}.growl-icon{font-size:18px;font-weight:700;flex-shrink:0}.growl-notification--success .growl-icon{color:#4caf50}.growl-notification--error .growl-icon{color:#f44336}.growl-notification--warning .growl-icon{color:#ff9800}.growl-notification--info .growl-icon{color:#2196f3}.growl-message{flex:1;font-size:14px;color:var(--text-color, #333333);line-height:1.4}.growl-close{background:none;border:none;font-size:18px;color:var(--text-secondary-color, #666666);cursor:pointer;padding:0;width:20px;height:20px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s}.growl-close:hover{background-color:#0000001a}@keyframes slideInRight{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}@media (max-width: 768px){.messages-panel{right:10px;left:10px;width:auto}.notification-banner__content{flex-direction:column;gap:12px;text-align:center}}.landing-page{width:100%;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);display:flex;flex-direction:column}.landing-container{max-width:1200px;margin:0 auto;width:100%;padding:var(--space-xl);padding-bottom:180px}.hero-section{text-align:center;padding:var(--space-xxl) 0;color:#fff}.hero-title{font-size:3rem;font-weight:700;margin:0 0 var(--space-lg) 0;line-height:1.2;color:#fff}.hero-subtitle{font-size:1.5rem;font-weight:400;margin:0;opacity:.95;color:#fff}.cta-button{background:#fff;color:#667eea;font-size:1.25rem;padding:1rem 2.5rem;border-radius:var(--radius-lg);border:none;font-weight:600;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 15px #0003;display:inline-flex;align-items:center;gap:var(--space-sm)}.cta-button:hover{transform:translateY(-2px);box-shadow:0 6px 20px #0000004d}.cta-button:disabled{opacity:.7;cursor:not-allowed;transform:none}.problem-section{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:var(--space-xl);margin:var(--space-xxl) 0;text-align:center;color:#fff}.problem-text{font-size:1.25rem;margin:0;font-weight:500}.features-section{background:#fff;border-radius:var(--radius-lg);padding:var(--space-xxl);margin:var(--space-xxl) 0}.features-title{text-align:center;font-size:2rem;font-weight:600;margin:0 0 var(--space-xxl) 0;color:var(--text-primary)}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:var(--space-xl)}.landing-feature-card{background:var(--bg-feature-light);border-radius:var(--radius-md);padding:var(--space-lg);transition:all .3s ease;border:2px solid transparent}.landing-feature-card:hover{transform:translateY(-4px);border-color:#667eea;box-shadow:0 8px 20px #667eea26}.landing-feature-icon{font-size:2.5rem;margin-bottom:var(--space-md);display:block}.landing-feature-title{font-size:1.25rem;font-weight:600;margin:0 0 var(--space-sm) 0;color:var(--text-primary)}.landing-feature-description{font-size:1rem;margin:0;color:var(--text-secondary);line-height:1.6}.coming-soon-section{background:#fff;border-radius:var(--radius-lg);padding:var(--space-xxl);margin:var(--space-xxl) 0;text-align:center}.coming-soon-title{font-size:2rem;font-weight:600;margin:0 0 var(--space-md) 0;color:var(--text-primary)}.coming-soon-description{font-size:1.25rem;margin:0 0 var(--space-xl) 0;color:var(--text-secondary)}.mobile-apps{display:flex;justify-content:center;gap:var(--space-xl);flex-wrap:wrap}.mobile-app-badge{display:flex;flex-direction:column;align-items:center;gap:var(--space-sm);padding:var(--space-lg) var(--space-xl);background:var(--bg-feature-light);border-radius:var(--radius-lg);border:2px solid #e0e0e0;min-width:140px;transition:all .3s ease}.mobile-app-badge:hover{transform:translateY(-4px);border-color:#667eea;box-shadow:0 8px 20px #667eea26}.mobile-app-icon{font-size:3rem}.mobile-app-name{font-size:1.25rem;font-weight:600;color:var(--text-primary)}.pain-points-section{background:#ffffff26;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:var(--radius-lg);padding:var(--space-xxl);margin:var(--space-xxl) 0;color:#fff}.pain-points-title{text-align:center;font-size:1.75rem;font-weight:600;margin:0 0 var(--space-xl) 0}.pain-points-list{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-lg);list-style:none;padding:0;margin:0}.pain-point-item{display:flex;align-items:flex-start;gap:var(--space-md);font-size:1.1rem;line-height:1.5}.pain-point-icon{font-size:1.5rem;flex-shrink:0;margin-top:2px}.fixed-cta-section{position:fixed;bottom:0;left:0;right:0;background:linear-gradient(to top,#667eea,#764ba2);box-shadow:0 -4px 20px #0000004d;z-index:100;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.fixed-cta-container{max-width:1200px;margin:0 auto;padding:var(--space-xl);text-align:center}.fixed-cta-title{font-size:1.5rem;font-weight:600;margin:0 0 var(--space-md) 0;color:#fff}@media (max-width: 768px){.landing-page .hero-title{font-size:2rem}.landing-page .hero-subtitle{font-size:1.25rem}.landing-page .features-grid{grid-template-columns:1fr}.landing-page .coming-soon-title{font-size:1.5rem}.landing-page .coming-soon-description{font-size:1.1rem}.landing-page .mobile-apps{gap:var(--space-md)}.landing-page .pain-points-list{grid-template-columns:1fr}.landing-page .landing-container{padding:var(--space-lg);padding-bottom:160px}.landing-page .fixed-cta-container{padding:var(--space-lg)}.landing-page .fixed-cta-title{font-size:1.25rem}.landing-page .cta-button{font-size:1.1rem;padding:.875rem 2rem}}@media (max-width: 480px){.landing-page .hero-title{font-size:1.75rem}.landing-page .hero-subtitle{font-size:1.1rem}.landing-page .features-title{font-size:1.5rem}.landing-page .coming-soon-title{font-size:1.25rem}.landing-page .coming-soon-description{font-size:1rem}.landing-page .mobile-app-badge{min-width:120px;padding:var(--space-md) var(--space-lg)}.landing-page .mobile-app-icon{font-size:2.5rem}.landing-page .mobile-app-name{font-size:1.1rem}.landing-page .pain-points-title{font-size:1.5rem}.landing-page .fixed-cta-container{padding:var(--space-md)}.landing-page .fixed-cta-title{font-size:1.1rem;margin:0 0 var(--space-sm) 0}.landing-page .cta-button{font-size:1rem;padding:.75rem 1.5rem}}.member-management-wrapper{display:flex;flex-direction:column;min-height:100%}.member-management__notice{text-align:center;padding:var(--space-xl);color:var(--text-secondary)}.member-management__header{margin-bottom:var(--space-lg)}.member-management__header h2{color:var(--text-heading);font-size:var(--font-size-xl);font-weight:600;margin:0}.member-management__toolbar{position:sticky;top:0;z-index:10;flex-shrink:0;display:flex;align-items:center;padding:var(--space-md);background:var(--bg-feature);gap:var(--space-xs);flex-wrap:wrap;margin:var(--space-lg);margin-bottom:0;border-radius:var(--radius-md)}.member-management__content{padding:var(--space-lg);padding-top:var(--space-md)}.toolbar__actions{display:flex;gap:var(--space-xs);flex:1;justify-content:flex-end;flex-wrap:wrap}.selection-count{color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap;margin-left:var(--space-sm)}.member-table{border:1px solid var(--border-color);border-radius:var(--radius-md);overflow:visible;display:flex;flex-direction:column}.member-table__header{display:grid;grid-template-columns:60px 1fr;flex-shrink:0;background:var(--bg-feature);border-bottom:2px solid var(--border-color)}.member-table__header-cell{padding:var(--space-md);font-weight:600;color:var(--text-heading)}.member-table__header-cell--checkbox{display:flex;align-items:center;justify-content:center}.member-table__header-cell--checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.member-table__body{background:var(--bg-card-primary)}.member-table__row{display:grid;grid-template-columns:60px 1fr;border-bottom:1px solid var(--border-color);transition:background-color .2s}.member-table__row:last-child{border-bottom:none}.member-table__row:hover,.member-table__row--current{background:var(--bg-feature)}.member-table__row--admin{background:linear-gradient(to right,rgba(255,215,0,.05),transparent);border-left:3px solid #ffd700}.member-table__row--admin:hover{background:linear-gradient(to right,rgba(255,215,0,.1),var(--bg-feature))}.member-table__cell{padding:var(--space-md)}.member-table__cell--checkbox{display:flex;align-items:center;justify-content:center}.member-table__cell--checkbox input[type=checkbox]{cursor:pointer;width:18px;height:18px}.checkbox-placeholder{width:18px;height:18px}.member-info{display:flex;justify-content:space-between;align-items:center;gap:var(--space-md);width:100%}.member-info__name{font-weight:500;color:var(--text-heading);display:flex;align-items:center;gap:var(--space-xs);flex:1}.admin-icon{font-size:16px;line-height:1}.current-user-badge{font-size:var(--font-size-sm);font-weight:500;color:var(--primary-color);background:var(--primary-bg);padding:2px 8px;border-radius:var(--radius-sm)}.member-menu-container{position:relative}.member-menu-button{background:transparent;border:none;color:var(--text-secondary);font-size:24px;padding:var(--space-xs);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s;line-height:1;width:32px;height:32px;display:flex;align-items:center;justify-content:center}.member-menu-button:hover{background:var(--bg-feature);color:var(--text-primary)}.member-menu-dropdown{position:absolute;top:100%;right:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;min-width:250px;z-index:1000;padding:var(--space-sm);margin-top:4px}.member-menu-item{padding:var(--space-sm);color:var(--text-primary);font-size:var(--font-size-sm);display:flex;gap:var(--space-xs);align-items:center;border-bottom:1px solid var(--border-color)}.member-menu-item:last-child{border-bottom:none}.member-menu-item strong{min-width:60px}.role-badge{padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:500;white-space:nowrap}.role-badge--admin{background:var(--primary-color);color:#fff}.role-badge--member{background:var(--bg-feature);color:var(--text-secondary);border:1px solid var(--border-color)}.btn--danger{background:#dc3545;color:#fff}.btn--danger:hover:not(:disabled){background:#c82333}.btn--danger:disabled{background:var(--bg-disabled);color:var(--text-disabled);cursor:not-allowed}@media (max-width: 768px){.member-table__header,.member-table__row{grid-template-columns:50px 1fr}}.view-container{display:flex;flex-direction:column;height:100%;width:100%}.view-header{padding:var(--space-md);border-bottom:1px solid var(--border-color);background:var(--bg-card-primary)}.menu-dropdown-container{position:relative}.menu-button{background:transparent;border:none;color:var(--text-primary);font-size:24px;padding:0;width:40px;height:40px;border-radius:var(--radius-sm);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.menu-button:hover{background:var(--bg-feature)}.menu-dropdown{position:absolute;top:calc(100% + 4px);left:0;background:#fff;border:1px solid var(--border-color);border-radius:var(--radius-md);box-shadow:0 4px 12px #00000026;min-width:200px;z-index:1000;padding:var(--space-xs) 0}.menu-dropdown .dropdown-item{width:100%;padding:var(--space-sm) var(--space-md);background:none;border:none;text-align:left;cursor:pointer;color:var(--text-primary);font-size:var(--font-size-base);transition:background-color .2s;display:flex;align-items:center;gap:var(--space-xs)}.menu-dropdown .dropdown-item:hover:not(:disabled){background:var(--bg-feature)}.menu-dropdown .dropdown-item:disabled{opacity:.6;cursor:not-allowed}.menu-dropdown .dropdown-item--logout{border-top:1px solid var(--border-color);margin-top:var(--space-xs);padding-top:var(--space-sm)}.competium-import{display:flex;flex-direction:column;gap:var(--space-lg);padding:var(--space-lg);height:100%;overflow-y:auto}.competium-import__header{display:flex;justify-content:space-between;align-items:center}.competium-import__title{font-size:var(--font-size-xl);font-weight:600;margin:0;color:var(--text-primary)}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-md);padding:var(--space-xxl);color:var(--text-secondary)}.empty-state{text-align:center;padding:var(--space-xxl);color:var(--text-secondary)}.club-list__title{font-size:var(--font-size-lg);font-weight:600;margin:0 0 var(--space-md) 0;color:var(--text-primary)}.club-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-md)}.club-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-md)}.club-card__header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-sm)}.club-card__name{font-size:var(--font-size-base);font-weight:600;margin:0;color:var(--text-primary);flex:1}.club-card__linked-icon{color:var(--color-success);font-size:var(--font-size-lg);line-height:1}.club-card__actions{display:flex;gap:var(--space-sm)}.import-progress{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);padding:var(--space-lg);margin-top:var(--space-md)}.import-progress__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.import-progress__title{font-size:var(--font-size-lg);font-weight:600;margin:0}.import-progress__title.status--in-progress{color:var(--color-primary)}.import-progress__title.status--completed{color:var(--color-success)}.import-progress__title.status--failed{color:var(--color-error)}.import-progress__title.status--cancelled{color:var(--color-warning)}.import-progress__stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--space-md);margin-bottom:var(--space-md)}.stat{display:flex;flex-direction:column;gap:var(--space-xs)}.stat__label{font-size:var(--font-size-sm);color:var(--text-secondary)}.stat__value{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary)}.stat--success .stat__value{color:var(--color-success)}.stat--warning .stat__value{color:var(--color-warning)}.stat--error .stat__value{color:var(--color-error)}.import-progress__bar{display:flex;align-items:center;gap:var(--space-md);margin-bottom:var(--space-md)}.import-progress-bar{flex:1;height:24px;background:var(--bg-tertiary);border-radius:var(--radius-sm);overflow:hidden}.import-progress-bar__fill{height:100%;background:linear-gradient(90deg,var(--color-primary),var(--color-primary-light));transition:width .3s ease}.progress-percentage{font-size:var(--font-size-base);font-weight:600;color:var(--text-primary);min-width:45px;text-align:right}.import-progress__error{padding:var(--space-md);background:var(--color-error-bg);border:1px solid var(--color-error);border-radius:var(--radius-sm);color:var(--color-error);margin-bottom:var(--space-md)}.import-progress__log{margin-top:var(--space-lg)}.import-progress__log-title{font-size:var(--font-size-base);font-weight:600;margin:0 0 var(--space-md) 0;color:var(--text-primary)}.import-log{max-height:400px;overflow-y:auto;border:1px solid var(--border-color);border-radius:var(--radius-sm);background:var(--bg-primary)}.log-entry{display:flex;align-items:flex-start;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-color)}.log-entry:last-child{border-bottom:none}.log-entry__icon{font-size:var(--font-size-lg);line-height:1;min-width:24px;text-align:center}.log-entry.routine-status--success .log-entry__icon{color:var(--color-success)}.log-entry.routine-status--failed .log-entry__icon{color:var(--color-error)}.log-entry.routine-status--skipped .log-entry__icon{color:var(--color-warning)}.log-entry__content{flex:1;display:flex;flex-direction:column;gap:var(--space-xs)}.log-entry__main{display:flex;gap:var(--space-xs);align-items:baseline}.log-entry__routine{font-weight:500;color:var(--text-primary)}.log-entry__athlete{font-size:var(--font-size-sm);color:var(--text-secondary)}.log-entry__error{font-size:var(--font-size-sm);color:var(--color-error)}.competium-club-badge{display:inline-flex;align-items:center;gap:var(--space-xs);padding:var(--space-xs) var(--space-sm);background:var(--color-primary-bg);border:1px solid var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-size-xs);color:var(--color-primary);font-weight:500}.competium-club-badge__icon{font-size:var(--font-size-sm)}.competium-athlete-id{font-size:var(--font-size-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-xs)}.competium-athlete-id__label{font-weight:500}.alert{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.alert--error{background:var(--color-error-bg);border:1px solid var(--color-error);color:var(--color-error)}.alert__icon{font-size:var(--font-size-lg)}.alert__message{flex:1}.alert__close{background:none;border:none;color:inherit;font-size:var(--font-size-xl);cursor:pointer;padding:0;width:24px;height:24px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm)}.alert__close:hover{background:#0000001a}.cookie-consent-overlay{position:fixed;bottom:0;left:0;right:0;z-index:10000;background:#000c;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);animation:slideUp .3s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.cookie-consent-banner{background:#242424fa;border-top:2px solid var(--primary-color);padding:var(--space-lg);max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:space-between;gap:var(--space-lg);flex-wrap:wrap}@media (max-width: 768px){.cookie-consent-banner{flex-direction:column;align-items:stretch;gap:var(--space-md)}}.cookie-consent-content{flex:1;min-width:300px}.cookie-consent-title{margin:0 0 var(--space-sm) 0;font-size:var(--font-size-lg);font-weight:600;color:#fffffff2}.cookie-consent-text{margin:0;font-size:var(--font-size-sm);color:#fffc;line-height:1.5}.cookie-consent-actions{display:flex;align-items:center;gap:var(--space-md);flex-wrap:wrap}@media (max-width: 768px){.cookie-consent-actions{justify-content:stretch;flex-direction:column;width:100%}.cookie-consent-actions button{width:100%}}.cookie-consent-link{background:none;border:none;color:var(--primary-color);text-decoration:underline;cursor:pointer;font-size:var(--font-size-sm);padding:var(--space-sm) var(--space-md);border-radius:var(--radius-md);transition:background .2s}.cookie-consent-link:hover{background:#646cff1a;text-decoration:none}.cookie-policy-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:10001;display:flex;align-items:center;justify-content:center;padding:var(--space-lg);overflow-y:auto;animation:fadeIn .2s ease-out}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.cookie-policy-container{background:#2a2a2a;border-radius:var(--radius-lg);max-width:800px;width:100%;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 10px 40px #0000004d;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-30px);opacity:0}to{transform:translateY(0);opacity:1}}.cookie-policy-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid rgba(255,255,255,.1)}.cookie-policy-title{margin:0;font-size:var(--font-size-2xl);font-weight:600;color:#fffffff2}.close-button{background:none;border:none;color:#ffffffb3;font-size:var(--font-size-2xl);cursor:pointer;padding:var(--space-sm);width:36px;height:36px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);transition:all .2s}.close-button:hover{background:#ffffff1a;color:#fffffff2}.cookie-policy-content{flex:1;overflow-y:auto;padding:var(--space-lg)}.policy-section{margin-bottom:var(--space-xl)}.policy-section:last-child{margin-bottom:0}.policy-section h2{margin:0 0 var(--space-md) 0;font-size:var(--font-size-xl);font-weight:600;color:#fffffff2}.policy-section h3{margin:var(--space-lg) 0 var(--space-sm) 0;font-size:var(--font-size-lg);font-weight:500;color:#ffffffe6}.policy-section p{margin:0 0 var(--space-md) 0;line-height:1.6;color:#fffc;font-size:var(--font-size-base)}.policy-section ul{margin:var(--space-md) 0;padding-left:var(--space-xl);color:#fffc}.policy-section li{margin-bottom:var(--space-sm);line-height:1.6}.policy-footer{margin-top:var(--space-xl);padding-top:var(--space-lg);border-top:1px solid rgba(255,255,255,.1)}.policy-last-updated{margin:0;font-size:var(--font-size-sm);color:#fff9;font-style:italic}.cookie-policy-actions{padding:var(--space-lg);border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:flex-end;gap:var(--space-md)}.policy-link{background:none;border:none;color:#fff9;text-decoration:underline;cursor:pointer;font-size:var(--font-size-xs);padding:var(--space-xs) var(--space-sm);transition:color .2s}.policy-link:hover{color:var(--primary-color)}.cta-footer{margin-top:var(--space-md);display:flex;justify-content:center;gap:var(--space-md)}@media (prefers-color-scheme: light){.cookie-consent-banner{background:#fffffffa;border-top-color:var(--primary-color)}.cookie-consent-title{color:var(--text-primary)}.cookie-consent-text{color:var(--text-secondary)}.cookie-policy-container{background:#fff}.cookie-policy-title,.policy-section h2,.policy-section h3{color:var(--text-primary)}.policy-section p,.policy-section ul,.policy-section li{color:var(--text-secondary)}.cookie-policy-header,.cookie-policy-actions,.policy-footer{border-color:#0000001a}.close-button{color:var(--text-secondary)}.close-button:hover{background:#0000000d;color:var(--text-primary)}.policy-last-updated,.policy-link{color:var(--text-muted)}.policy-link:hover{color:var(--primary-color)}}
