:root{--color-primary: #8b5cf6;--color-primary-dark: #7c3aed;--color-primary-light: #a78bfa;--color-secondary: #667eea;--color-secondary-dark: #764ba2;--color-success: #10b981;--color-success-dark: #059669;--color-warning: #f59e0b;--color-warning-dark: #d97706;--color-error: #ef4444;--color-error-dark: #dc2626;--color-info: #3b82f6;--color-info-dark: #2563eb;--gradient-primary: linear-gradient(135deg, var(--color-primary) 0%, var(--color-primary-dark) 100%);--gradient-secondary: linear-gradient(135deg, var(--color-secondary) 0%, var(--color-secondary-dark) 100%);--gradient-success: linear-gradient(135deg, var(--color-success) 0%, var(--color-success-dark) 100%);--gradient-warning: linear-gradient(135deg, var(--color-warning) 0%, var(--color-warning-dark) 100%);--color-gray-50: #f9fafb;--color-gray-100: #f3f4f6;--color-gray-200: #e5e7eb;--color-gray-300: #d1d5db;--color-gray-400: #9ca3af;--color-gray-500: #6b7280;--color-gray-600: #4b5563;--color-gray-700: #374151;--color-gray-800: #1f2937;--color-gray-900: #111827;--color-white: #ffffff;--color-black: #000000;--text-primary: var(--color-gray-800);--text-secondary: var(--color-gray-500);--text-light: var(--color-gray-400);--bg-primary: var(--color-white);--bg-secondary: var(--color-gray-50);--bg-tertiary: var(--color-gray-100);--border-color: var(--color-gray-200);--border-color-light: var(--color-gray-100);--border-color-dark: var(--color-gray-300);--border-width: 2px;--border-radius-sm: 6px;--border-radius-md: 8px;--border-radius-lg: 12px;--border-radius-xl: 16px;--border-radius-full: 9999px;--space-xs: .25rem;--space-sm: .5rem;--space-md: 1rem;--space-lg: 1.5rem;--space-xl: 2rem;--space-2xl: 3rem;--space-3xl: 4rem;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--font-size-4xl: 2.5rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 2px 8px rgba(0, 0, 0, .1);--shadow-lg: 0 4px 16px rgba(0, 0, 0, .15);--shadow-xl: 0 8px 24px rgba(0, 0, 0, .2);--shadow-2xl: 0 20px 60px rgba(0, 0, 0, .3);--shadow-primary: 0 4px 12px rgba(139, 92, 246, .3);--shadow-primary-lg: 0 6px 20px rgba(139, 92, 246, .4);--shadow-success: 0 4px 12px rgba(16, 185, 129, .3);--shadow-success-lg: 0 6px 20px rgba(16, 185, 129, .4);--transition-fast: .15s ease;--transition-base: .2s ease;--transition-slow: .3s ease;--sidebar-width: 280px;--header-height: 64px;--max-width-content: 1400px;--max-width-narrow: 800px;--max-width-medium: 1000px;--max-width-wide: 1200px;--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);font-family:var(--font-family);text-decoration:none;cursor:pointer;transition:all var(--transition-base);white-space:nowrap}.btn:disabled{opacity:.6;cursor:not-allowed;transform:none!important}.btn-primary{background:var(--gradient-primary);color:var(--color-white);box-shadow:var(--shadow-primary)}.btn-primary:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-primary-lg)}.btn-secondary{background:var(--color-gray-200);color:var(--color-gray-700)}.btn-secondary:hover:not(:disabled){background:var(--color-gray-300);transform:translateY(-1px)}.btn-success{background:var(--gradient-success);color:var(--color-white);box-shadow:var(--shadow-success)}.btn-success:hover:not(:disabled){transform:translateY(-2px);box-shadow:var(--shadow-success-lg)}.btn-danger{background:var(--color-error);color:var(--color-white)}.btn-danger:hover:not(:disabled){background:var(--color-error-dark);transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--color-primary);border:var(--border-width) solid var(--border-color)}.btn-ghost:hover:not(:disabled){border-color:var(--color-primary);background:var(--color-gray-50)}.btn-link{background:transparent;color:var(--color-primary);padding:var(--space-sm) 0;text-decoration:underline}.btn-link:hover:not(:disabled){color:var(--color-primary-dark);text-decoration:none}.btn-sm{padding:.5rem 1rem;font-size:var(--font-size-sm)}.btn-lg{padding:1rem 2rem;font-size:var(--font-size-lg)}.btn-xl{padding:1.25rem 2.5rem;font-size:var(--font-size-xl)}.btn-icon{padding:.75rem;width:40px;height:40px}.btn-icon-sm{padding:.5rem;width:32px;height:32px}.btn-icon-lg{padding:1rem;width:48px;height:48px}.btn-rounded{border-radius:var(--border-radius-full)}.btn-block{width:100%}.card{background:var(--bg-primary);border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-lg);padding:var(--space-xl);transition:all var(--transition-base)}.card:hover{border-color:var(--color-primary);box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-flat{box-shadow:none}.card-flat:hover{transform:none}.card-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-md);border-bottom:var(--border-width) solid var(--border-color)}.card-body{padding:var(--space-lg) 0}.card-footer{margin-top:var(--space-lg);padding-top:var(--space-md);border-top:var(--border-width) solid var(--border-color)}.badge{display:inline-flex;align-items:center;padding:.25rem .75rem;border-radius:var(--border-radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);line-height:1;text-transform:uppercase;letter-spacing:.05em}.badge-primary{background:var(--gradient-primary);color:var(--color-white)}.badge-secondary{background:var(--color-gray-200);color:var(--color-gray-700)}.badge-success{background:var(--color-success);color:var(--color-white)}.badge-warning{background:var(--color-warning);color:var(--color-white)}.badge-error{background:var(--color-error);color:var(--color-white)}.badge-info{background:var(--color-info);color:var(--color-white)}.form-control{width:100%;padding:.75rem;border:var(--border-width) solid var(--border-color);border-radius:var(--border-radius-md);font-size:var(--font-size-base);font-family:var(--font-family);transition:all var(--transition-base);background:var(--bg-primary)}.form-control:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf61a}.form-control:disabled{background:var(--color-gray-100);cursor:not-allowed;opacity:.6}.form-control.error{border-color:var(--color-error)}.form-label{display:block;margin-bottom:var(--space-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);font-size:var(--font-size-sm)}.form-group{margin-bottom:var(--space-lg)}.form-error{display:block;margin-top:var(--space-xs);color:var(--color-error);font-size:var(--font-size-sm)}.form-help{display:block;margin-top:var(--space-xs);color:var(--text-secondary);font-size:var(--font-size-sm)}.alert{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);border-radius:var(--border-radius-md);margin-bottom:var(--space-lg);border:var(--border-width) solid transparent}.alert-success{background:#f0fdf4;border-color:var(--color-success);color:#166534}.alert-warning{background:#fef3c7;border-color:var(--color-warning);color:#92400e}.alert-error{background:#fee2e2;border-color:var(--color-error);color:#991b1b}.alert-info{background:#dbeafe;border-color:var(--color-info);color:#1e40af}.alert-close{background:transparent;border:none;color:inherit;font-size:var(--font-size-xl);cursor:pointer;padding:var(--space-xs);opacity:.7;transition:opacity var(--transition-base)}.alert-close:hover{opacity:1}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:var(--color-white);border-radius:var(--border-radius-full);animation:spin .6s linear infinite}.spinner-primary{border-color:var(--color-gray-200);border-top-color:var(--color-primary)}.spinner-lg{width:50px;height:50px;border-width:4px}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-3xl) var(--space-xl);gap:var(--space-md)}.loading-state p{color:var(--text-secondary);font-size:var(--font-size-base)}.empty-state{text-align:center;padding:var(--space-3xl) var(--space-xl)}.empty-state-icon{font-size:var(--font-size-4xl);margin-bottom:var(--space-lg);opacity:.5}.empty-state h3{color:var(--text-primary);font-size:var(--font-size-2xl);margin-bottom:var(--space-sm)}.empty-state p{color:var(--text-secondary);font-size:var(--font-size-base);margin-bottom:var(--space-lg)}.toast{position:fixed;top:var(--space-xl);left:50%;transform:translate(-50%);background:var(--gradient-success);color:var(--color-white);padding:var(--space-md) var(--space-xl);border-radius:var(--border-radius-lg);box-shadow:var(--shadow-xl);font-weight:var(--font-weight-semibold);animation:slideInDown .3s ease-out;z-index:var(--z-tooltip)}.text-primary{color:var(--color-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.m-0{margin:0}.mt-0{margin-top:0}.mb-0{margin-bottom:0}.mt-1{margin-top:var(--space-sm)}.mb-1{margin-bottom:var(--space-sm)}.mt-2{margin-top:var(--space-md)}.mb-2{margin-bottom:var(--space-md)}.mt-3{margin-top:var(--space-lg)}.mb-3{margin-bottom:var(--space-lg)}.mt-4{margin-top:var(--space-xl)}.mb-4{margin-bottom:var(--space-xl)}.p-0{padding:0}.pt-0{padding-top:0}.pb-0{padding-bottom:0}.pt-1{padding-top:var(--space-sm)}.pb-1{padding-bottom:var(--space-sm)}.pt-2{padding-top:var(--space-md)}.pb-2{padding-bottom:var(--space-md)}.pt-3{padding-top:var(--space-lg)}.pb-3{padding-bottom:var(--space-lg)}.pt-4{padding-top:var(--space-xl)}.pb-4{padding-bottom:var(--space-xl)}:root{font-family:var(--font-family);line-height:var(--line-height-normal);font-weight:var(--font-weight-normal);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;min-height:100vh;margin:0;padding:0;background:var(--bg-secondary);color:var(--text-primary)}#root{width:100%;min-height:100vh}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-container{width:100%;max-width:450px;background:transparent;position:relative;z-index:1;background:none!important;background-color:transparent!important}.login-card{background:#fff;border-radius:20px;box-shadow:0 20px 60px #667eea26;animation:slideUp .5s ease-out;position:relative;z-index:2}.logo-section{background:#fff;padding:2rem 2rem 1rem;display:flex;flex-direction:column;align-items:center;justify-content:center}.logo-wrapper{width:400px;height:130px;margin-bottom:0;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-mask-image:var(--logo-url);-webkit-mask-size:contain;-webkit-mask-repeat:no-repeat;-webkit-mask-position:center;mask-image:var(--logo-url);mask-size:contain;mask-repeat:no-repeat;mask-position:center}.logo-gradient{display:none}.tagline{font-size:1rem;margin:0;color:#6b7280;font-weight:500}.login-content h1{font-size:2.5rem;color:#1f2937;margin:0 0 .25rem;font-weight:800;text-align:center}.login-content{padding:.5rem 1.5rem .1rem;background:#fff}.login-content h2{font-size:1.875rem;color:#1f2937;margin:0 0 .5rem;font-weight:700;text-align:center}.subtitle{color:#6b7280;font-size:1rem;margin:0 0 2rem;text-align:center;font-weight:400}.btn-google-signin{width:100%;padding:1rem;background:#fff;border:2px solid #e5e7eb;border-radius:12px;font-size:1.125rem;font-weight:600;color:#374151;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:12px;box-shadow:0 2px 4px #0000000d}.btn-google-signin:hover:not(:disabled){background:#f9fafb;border-color:#667eea;transform:translateY(-2px);box-shadow:0 4px 12px #667eea33}.btn-google-signin:disabled{opacity:.6;cursor:not-allowed;transform:none}.google-icon{width:24px;height:24px}.spinner-small{display:inline-block;width:18px;height:18px;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#667eea;animation:spin .6s linear infinite}.error-message{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1.5rem;font-size:.875rem}.privacy-note{text-align:center;color:#9ca3af;font-size:.875rem;margin-top:2rem;margin-bottom:0}@media(max-width:640px){.login-page{padding:1rem}.logo-section{padding:2rem 1.5rem 1.5rem}.login-content{padding:1.5rem 1.5rem 2rem}.logo-wrapper{width:240px;height:80px}}.welcome-text{font-size:1rem;color:#1f2937;font-weight:700;margin:0 0 .25rem;text-align:center}.coach-selector{margin:24px 0;padding:20px;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.coach-selector-label{display:block;font-size:14px;font-weight:600;color:#374151;margin-bottom:8px}.coach-selector-description{font-size:13px;color:#6b7280;margin:0 0 16px}.coach-selector-loading,.coach-selector-error{display:flex;align-items:center;gap:12px;padding:16px;background:#fff;border-radius:6px;color:#6b7280;font-size:14px}.coach-selector-error{color:#dc2626;border:1px solid #fecaca;background:#fef2f2}.spinner-small{width:16px;height:16px;border:2px solid #e5e7eb;border-top-color:#8b5cf6;border-radius:50%;animation:spin .8s linear infinite}.btn-retry-small{padding:4px 12px;font-size:13px;background:#fff;border:1px solid #d1d5db;border-radius:4px;cursor:pointer;transition:all .2s}.btn-retry-small:hover{background:#f9fafb;border-color:#9ca3af}.coach-selector-actions{display:flex;align-items:center;gap:12px;margin-bottom:16px}.btn-select-action{padding:6px 14px;font-size:13px;font-weight:500;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;transition:all .2s;color:#374151}.btn-select-action:hover:not(:disabled){background:#f9fafb;border-color:#8b5cf6;color:#8b5cf6}.btn-select-action:disabled{opacity:.5;cursor:not-allowed}.coach-count{margin-left:auto;font-size:13px;color:#6b7280;font-weight:500}.coach-buttons-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px}.coach-button{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#374151;text-align:left}.coach-button:hover{border-color:#8b5cf6;background:#faf5ff;transform:translateY(-1px);box-shadow:0 2px 4px #8b5cf61a}.coach-button.selected{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#7c3aed;color:#fff;box-shadow:0 2px 8px #8b5cf64d}.coach-button.selected:hover{background:linear-gradient(135deg,#7c3aed,#6d28d9);border-color:#6d28d9;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf666}.coach-button-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:14px;font-weight:700}.coach-button.selected .coach-button-icon{animation:checkmark-pop .3s ease}@keyframes checkmark-pop{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.coach-button-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.coach-selector-empty{text-align:center;padding:32px;color:#9ca3af;font-size:14px;background:#fff;border-radius:6px;margin:0}@media(max-width:640px){.coach-buttons-grid{grid-template-columns:1fr}.coach-selector-actions{flex-wrap:wrap}.coach-count{width:100%;margin-left:0;margin-top:8px}}.loading-modal-overlay{position:fixed;inset:0;background:#000000bf;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .3s ease-out}.loading-modal-content{background:#fff;border-radius:16px;padding:3rem;max-width:500px;width:90%;text-align:center;box-shadow:0 20px 60px #0000004d;animation:slideUp .4s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.loading-spinner-large{width:80px;height:80px;border:6px solid #f3f4f6;border-top:6px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 2rem}.loading-modal-title{color:#2d3748;font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.loading-modal-subtitle{color:#718096;font-size:1rem;margin-bottom:2rem}.loading-steps{display:flex;flex-direction:column;gap:1rem;text-align:left}.loading-step{display:flex;align-items:center;gap:1rem;padding:.75rem 1rem;background:#f7fafc;border-radius:8px;opacity:0;animation:fadeInStep .5s ease-out forwards}.loading-step:nth-child(1){animation-delay:.2s}.loading-step:nth-child(2){animation-delay:.4s}.loading-step:nth-child(3){animation-delay:.6s}.loading-step:nth-child(4){animation-delay:.8s}@keyframes fadeInStep{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.loading-step-icon{font-size:1.5rem;width:40px;height:40px;background:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.loading-step span{color:#4a5568;font-size:.95rem;font-weight:500}.loading-step.active .loading-step-icon{animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);box-shadow:0 0 #8b5cf666}50%{transform:scale(1.05);box-shadow:0 0 0 10px #8b5cf600}}@media(max-width:600px){.loading-modal-content{padding:2rem}.loading-spinner-large{width:60px;height:60px;border-width:5px}.loading-modal-title{font-size:1.5rem}.loading-steps{gap:.75rem}.loading-step{padding:.5rem .75rem}.loading-step-icon{font-size:1.25rem;width:35px;height:35px}}.export-container{margin-top:2rem}.exportable-summary{background:#fff;padding:3rem;border-radius:12px;border:2px solid #e5e7eb;max-width:800px;margin:0 auto 2rem;box-shadow:0 4px 12px #0000001a}.summary-header{text-align:center;padding-bottom:2rem;border-bottom:3px solid #8b5cf6;margin-bottom:2rem}.summary-logo h1{font-size:2rem;color:#8b5cf6;margin-bottom:.5rem;font-weight:800}.summary-logo p{color:#6b7280;font-size:1.125rem;font-weight:500}.summary-section{margin-bottom:2rem}.summary-section h2{font-size:1.5rem;color:#2d3748;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.summary-details-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.summary-detail{display:flex;flex-direction:column;gap:.25rem;padding:.75rem;background:#f9fafb;border-radius:8px}.detail-label{font-size:.875rem;color:#6b7280;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.detail-value{font-size:1.125rem;color:#1f2937;font-weight:600}.summary-athletes-list{display:grid;grid-template-columns:1fr 1fr;gap:.75rem}.summary-athlete-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#f9fafb;border-radius:8px;border:1px solid #e5e7eb}.athlete-number{font-weight:700;color:#8b5cf6;font-size:1.125rem;min-width:30px}.athlete-name{flex:1;color:#1f2937;font-weight:600}.athlete-ratio{background:#8b5cf6;color:#fff;padding:.25rem .625rem;border-radius:12px;font-size:.875rem;font-weight:600}.summary-footer{margin-top:2rem;padding-top:2rem;border-top:2px solid #e5e7eb;text-align:center}.summary-footer-text{color:#6b7280;font-size:.95rem;margin-bottom:.5rem}.summary-date{color:#9ca3af;font-size:.875rem;font-style:italic;margin-top:1rem}.export-actions{text-align:center;padding:2rem 0}.btn-export{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:1rem 2rem;border-radius:10px;font-size:1.125rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #8b5cf64d;display:inline-flex;align-items:center;gap:.75rem}.btn-export:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.btn-export:disabled{opacity:.7;cursor:not-allowed}.export-spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}.export-hint{margin-top:1rem;color:#6b7280;font-size:.95rem}@media(max-width:768px){.exportable-summary{padding:2rem 1.5rem}.summary-details-grid,.summary-athletes-list{grid-template-columns:1fr}.summary-logo h1{font-size:1.5rem}.btn-export{width:100%;padding:.875rem 1.5rem;font-size:1rem}}@media print{.export-actions{display:none}.exportable-summary{box-shadow:none;border:none}}.enrollment-count{display:flex;flex-direction:row;align-items:baseline;justify-content:center;gap:.5rem;margin-bottom:1rem}.count-number{font-size:3rem;font-weight:800;color:#8b5cf6;line-height:1}.term-tracker-list-page{max-width:1400px;margin:0 auto;padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;gap:2rem}.header-content h1{font-size:2rem;color:#1f2937;margin-bottom:.5rem}.subtitle{color:#6b7280;font-size:1rem}.btn-create-new{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;padding:.875rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #8b5cf64d;white-space:nowrap}.btn-create-new:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.controls-bar{display:flex;gap:1rem;margin-bottom:2rem;align-items:center;flex-wrap:wrap}.search-box{flex:1;min-width:250px;position:relative}.search-icon{position:absolute;left:1rem;top:50%;transform:translateY(-50%);font-size:1.25rem}.search-input{width:100%;padding:.625rem 1rem .625rem 3rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;transition:all .3s}.search-input:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{color:#6b7280;font-weight:600;font-size:.8125rem}.filter-select{padding:.625rem .75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.875rem;background:#fff;cursor:pointer;transition:all .3s;min-width:120px}.filter-select:focus{outline:none;border-color:#8b5cf6}.btn-refresh{padding:.625rem .875rem;border:2px solid #e5e7eb;border-radius:8px;background:#fff;font-size:1.125rem;cursor:pointer;transition:all .3s}.btn-refresh:hover{border-color:#8b5cf6;background:#f9fafb}.results-header{margin-bottom:1.5rem}.results-count{color:#6b7280;font-size:.875rem;font-weight:600}.loading-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;gap:1rem}.spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite}.loading-state p{color:#6b7280;font-size:1rem}.error-state{text-align:center;padding:3rem 2rem}.error-message{color:#dc2626;font-size:1.125rem;margin-bottom:1rem}.btn-retry{padding:.75rem 1.5rem;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-retry:hover{background:#7c3aed}.empty-state{text-align:center;padding:4rem 2rem}.empty-icon{font-size:4rem;margin-bottom:1rem}.empty-state h3{color:#1f2937;font-size:1.5rem;margin-bottom:.5rem}.empty-state p{color:#6b7280;font-size:1rem;margin-bottom:1.5rem}.btn-create-first{padding:.875rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s}.btn-create-first:hover{transform:translateY(-2px);box-shadow:0 6px 20px #8b5cf666}.trackers-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.5rem}.tracker-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;transition:all .3s}.tracker-card:hover{border-color:#8b5cf6;box-shadow:0 8px 24px #8b5cf626;transform:translateY(-2px)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.creation-date{color:#9ca3af;font-size:.875rem}.tracker-title{font-size:1.5rem;color:#1f2937;margin-bottom:1rem;font-weight:700}.tracker-meta{margin-bottom:1.5rem}.meta-item{display:flex;align-items:center;gap:.5rem;color:#6b7280;font-size:.875rem}.meta-icon{font-size:1rem}.card-actions{display:flex;gap:.75rem}.btn-open{flex:1;padding:.75rem 1rem;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;text-decoration:none;text-align:center;border-radius:8px;font-weight:600;font-size:.875rem;transition:all .3s;display:block}.btn-open:hover{transform:translateY(-2px);box-shadow:0 4px 12px #667eea66}@media(max-width:768px){.term-tracker-list-page{padding:1rem}.page-header{flex-direction:column;align-items:flex-start}.btn-create-new{width:100%}.controls-bar{flex-direction:column;align-items:stretch}.search-box{width:100%}.filter-group{width:100%;justify-content:space-between}.trackers-grid{grid-template-columns:1fr}}.program-badge{background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;padding:.375rem .75rem;border-radius:6px;font-size:.75rem;font-weight:700;text-transform:uppercase;letter-spacing:.05em}.program-badge-purple{background:linear-gradient(135deg,#8b5cf6,#7c3aed)}.program-badge-green{background:linear-gradient(135deg,#10b981,#059669)}.program-badge-yellow{background:linear-gradient(135deg,#f59e0b,#d97706)}.btn-clear-filters{padding:.625rem .875rem;border:2px solid #ef4444;border-radius:8px;background:#fff;color:#ef4444;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .3s;white-space:nowrap}.btn-clear-filters:hover{background:#ef4444;color:#fff}.btn-attendance{flex:1;padding:.75rem 1rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;text-align:center;border-radius:8px;font-weight:600;font-size:.875rem;transition:all .3s;cursor:pointer}.btn-attendance:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.tracker-card{position:relative}.btn-favorite{position:absolute;top:60px;right:16px;background:#fff;border:2px solid #e5e7eb;border-radius:50%;width:40px;height:40px;font-size:20px;cursor:pointer;transition:all .2s;z-index:10;display:flex;align-items:center;justify-content:center}.btn-favorite:hover{transform:scale(1.1);border-color:#fbbf24;background:#fffbeb}.btn-favorite.active{background:#fef3c7;border-color:#fbbf24}.mark-attendance-page{max-width:800px;margin:0 auto;padding:2rem}.attendance-header{margin-bottom:2rem}.btn-back{background:none;border:none;color:#6b7280;font-size:.95rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem;transition:color .3s}.btn-back:hover{color:#8b5cf6}.header-info h1{font-size:2rem;color:#1f2937;margin-bottom:.5rem}.tracker-info{color:#6b7280;font-size:1rem;display:flex;align-items:center;gap:.75rem}.program-badge-small{background:#8b5cf6;color:#fff;padding:.25rem .625rem;border-radius:4px;font-size:.75rem;font-weight:700;text-transform:uppercase}.session-selector{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;padding:1.5rem;background:#f9fafb;border-radius:12px}.session-selector label{font-weight:600;color:#374151;font-size:1.125rem}.session-select{padding:.75rem 1rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;background:#fff;cursor:pointer;min-width:150px}.session-select:focus{outline:none;border-color:#8b5cf6}.athletes-list{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1.5rem;margin-bottom:2rem}.athlete-item{padding:1rem;border-bottom:1px solid #f3f4f6}.athlete-item:last-child{border-bottom:none}.athlete-checkbox{display:flex;align-items:center;cursor:pointer;position:relative}.athlete-checkbox input[type=checkbox]{position:absolute;opacity:0;cursor:pointer}.checkbox-custom{width:28px;height:28px;border:2px solid #d1d5db;border-radius:6px;margin-right:1rem;display:flex;align-items:center;justify-content:center;transition:all .3s;flex-shrink:0}.athlete-checkbox input:checked~.checkbox-custom{background:#10b981;border-color:#10b981}.athlete-checkbox input:checked~.checkbox-custom:after{content:"✓";color:#fff;font-weight:700;font-size:18px}.athlete-name{font-size:1.125rem;color:#1f2937;font-weight:500}.attendance-summary{text-align:center;padding:1.5rem;background:#f9fafb;border-radius:12px;margin-bottom:2rem}.attendance-summary p{color:#374151;font-size:1.125rem}.attendance-summary strong{color:#8b5cf6;font-size:1.5rem}.btn-save-attendance{width:100%;padding:1.25rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:12px;font-size:1.25rem;font-weight:700;cursor:pointer;transition:all .3s;box-shadow:0 4px 12px #10b9814d}.btn-save-attendance:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-save-attendance:disabled{opacity:.6;cursor:not-allowed}.loading-state{text-align:center;padding:3rem}.spinner{width:50px;height:50px;border:4px solid #f3f4f6;border-top:4px solid #8b5cf6;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.error-message{background:#fee2e2;color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem}@media(max-width:768px){.mark-attendance-page{padding:1rem}.session-selector{flex-direction:column;align-items:stretch}.session-select{width:100%}}.btn-save-attendance.success{background:linear-gradient(135deg,#10b981,#059669)}.success-toast{position:fixed;top:30px;left:50%;transform:translate(-50%);background:linear-gradient(135deg,#10b981,#059669);color:#fff;padding:16px 24px;border-radius:12px;box-shadow:0 10px 25px #10b9814d;font-weight:600;animation:slideInDown .3s ease-out;z-index:1000}@keyframes slideInDown{0%{transform:translate(-50%,-100px);opacity:0}to{transform:translate(-50%);opacity:1}}.spinner-small{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-radius:50%;border-top-color:#fff;animation:spin .6s linear infinite;margin-right:8px}.btn-open-sheet:hover{transform:translateY(-2px);box-shadow:0 4px 12px #10b98166}.btn-refresh{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.btn-open-sheet{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.session-selector{display:grid;grid-template-columns:auto 1fr auto auto;gap:16px;align-items:center;margin-bottom:24px}.session-selector label{font-weight:600;color:#374151;white-space:nowrap}.session-select{padding:12px 16px;border:2px solid #e5e7eb;border-radius:8px;font-size:16px;background:#fff;cursor:pointer;transition:all .2s;min-width:200px}.btn-refresh{background:linear-gradient(135deg,#6366f1,#4f46e5);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-refresh:hover{transform:translateY(-2px);background:linear-gradient(135deg,#6366f1,#4f46e5);box-shadow:0 6px 20px #6366f166}.btn-refresh:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-open-sheet{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:12px 24px;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-open-sheet:hover{transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}@media(max-width:768px){.session-selector{grid-template-columns:1fr;grid-template-rows:auto auto auto auto}}.notes-section{margin-top:3rem;padding:2rem;background:#f9fafb;border-radius:12px;border:2px solid #e5e7eb}.notes-header{margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid #e5e7eb}.notes-header h2{font-size:1.75rem;color:#1f2937;margin-bottom:.5rem}.notes-header p{color:#6b7280;font-size:1rem}.notes-athlete-list{display:flex;flex-direction:column;gap:1rem;margin-bottom:2rem}.note-athlete-item{display:flex;justify-content:space-between;align-items:center;padding:1.25rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s}.note-athlete-item:hover{border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf61a}.note-athlete-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.note-athlete-name{font-size:1.125rem;font-weight:600;color:#1f2937}.note-preview{font-size:.875rem;color:#6b7280;padding:.5rem;background:#f3f4f6;border-radius:4px;font-style:italic}.btn-add-note{padding:.75rem 1.5rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap}.btn-add-note:hover{transform:translateY(-2px);box-shadow:0 4px 12px #8b5cf666}.notes-actions{display:flex;justify-content:space-between;gap:1rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.btn-finish-without-notes{padding:1rem 2rem;background:#fff;color:#6b7280;border:2px solid #d1d5db;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s}.btn-finish-without-notes:hover{border-color:#9ca3af;color:#374151}.btn-save-all-notes{padding:1rem 2rem;background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;box-shadow:0 4px 12px #10b9814d}.btn-save-all-notes:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 6px 20px #10b98166}.btn-save-all-notes:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-content{max-width:900px;width:100%;max-height:90vh;overflow-y:auto;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.notes-section{padding:1rem}.notes-actions{flex-direction:column}.note-athlete-item{flex-direction:column;align-items:stretch;gap:1rem}.btn-add-note{width:100%}}.btn-refresh-data{padding:10px 20px;background:#6366f1;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:6px}.btn-refresh-data:hover:not(:disabled){background:#4f46e5;transform:translateY(-1px)}.btn-refresh-data:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.modal-content{background:#fff;border-radius:16px;max-width:900px;width:100%;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0000004d}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.75rem;border-bottom:2px solid #e5e7eb}.modal-header h2{margin:0;font-size:1.5rem;font-weight:700;color:#1f2937}.close-button{background:none;border:none;font-size:2rem;color:#6b7280;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-button:hover{background:#f3f4f6;color:#1f2937}.existing-notes-summary{padding:1rem 1.75rem;background:#f9fafb;border-bottom:1px solid #e5e7eb}.existing-notes-summary h3{margin:0 0 .75rem;font-size:.875rem;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.05em}.existing-note{padding:.75rem;background:#fff;border-radius:8px;margin-bottom:.5rem;font-size:.9rem;line-height:1.5;border-left:3px solid #8b5cf6}.existing-note:last-child{margin-bottom:0}.existing-note strong{color:#374151}.tabs{display:flex;gap:.5rem;padding:1rem 1.75rem 0;background:#f9fafb}.tab{flex:1;padding:.75rem 1rem;background:#fff;border:2px solid #e5e7eb;border-bottom:none;border-radius:8px 8px 0 0;font-weight:600;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:.5rem;color:#6b7280}.tab:hover{background:#f9fafb}.tab.active{background:#fff;border-color:#8b5cf6;color:#8b5cf6;transform:translateY(2px)}.challenge-required{font-size:.75rem;padding:.125rem .5rem;background:#fef3c7;color:#92400e;border-radius:12px;font-weight:600}.tab-content{padding:1.5rem 1.75rem}.tab-content h3{margin:0 0 1.25rem;font-size:1.125rem;font-weight:600;color:#1f2937}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:600;font-size:.875rem;color:#374151}.form-group input,.form-group textarea{width:100%;padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:.9375rem;font-family:inherit;transition:all .2s;resize:vertical}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.form-group small{display:block;margin-top:.25rem;font-size:.75rem;color:#6b7280}.summary-meta{display:flex;justify-content:space-between;align-items:flex-start;margin-top:.5rem;gap:.5rem}.tags{display:flex;flex-wrap:wrap;gap:.25rem;flex:1}.tag-pill{padding:.2rem .6rem;border-radius:4px;background:#ede9fe;border:1px solid #d8b4fe;font-size:.75rem;color:#7c3aed;white-space:nowrap;font-weight:500}.button-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:.75rem}.option-button{padding:.75rem 1rem;background:#fff;border:2px solid #e5e7eb;border-radius:8px;font-weight:500;font-size:.875rem;cursor:pointer;transition:all .2s;text-align:center;display:flex;align-items:center;justify-content:center;gap:.4rem}.option-button .icon{font-size:1rem}.option-button:hover{background:#f9fafb;border-color:#d1d5db}.option-button.selected{background:#ede9fe;border-color:#8b5cf6;color:#6d28d9}.option-button.small{font-size:.8125rem;padding:.5rem .75rem}.option-button:disabled{opacity:.5;cursor:not-allowed}.add-moment-button{width:100%;padding:.875rem;background:#8b5cf6;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s;margin-bottom:1.5rem}.add-moment-button:hover{background:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.add-moment-button:disabled{background:#d1d5db;cursor:not-allowed;transform:none}.moments-list{background:#f9fafb;border-radius:8px;padding:1rem;margin-bottom:1.5rem}.moments-list h4{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:#374151;display:flex;align-items:center;gap:.5rem}.moments-list .warning{color:#dc2626;font-size:.8125rem}.empty-state{text-align:center;color:#9ca3af;font-size:.875rem;padding:1.5rem}.moment-card{background:#fff;border:1px solid #e5e7eb;border-radius:8px;padding:.875rem;margin-bottom:.75rem}.moment-card:last-child{margin-bottom:0}.moment-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.moment-number{font-weight:600;font-size:.875rem;color:#374151}.moment-outcome{font-weight:600;font-size:.8125rem}.moment-badge{background:#f3f4f6;padding:.25rem .625rem;border-radius:12px;font-size:.75rem;font-weight:600;color:#6b7280}.moment-comment,.moment-summary{font-size:.875rem;color:#6b7280;margin:.5rem 0;line-height:1.4}.moment-card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.5rem;font-size:.75rem;color:#6b7280}.remove-button{background:none;border:1px solid #e5e7eb;color:#ef4444;padding:.375rem .75rem;border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.remove-button:hover{background:#fef2f2;border-color:#ef4444}.modal-actions{display:flex;gap:.75rem;margin-top:1.5rem;padding-top:1.5rem;border-top:2px solid #e5e7eb}.clear-button{flex:1;padding:.875rem;background:#fff;color:#6b7280;border:2px solid #e5e7eb;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s}.clear-button:hover{background:#f9fafb;border-color:#d1d5db}.save-button{flex:2;padding:.875rem;background:#10b981;color:#fff;border:none;border-radius:8px;font-weight:600;font-size:.9375rem;cursor:pointer;transition:all .2s}.save-button:hover{background:#059669;transform:translateY(-1px);box-shadow:0 4px 12px #10b9814d}.save-button:disabled{background:#d1d5db;cursor:not-allowed;transform:none}@media(max-width:768px){.modal-content{max-height:95vh}.button-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:.5rem}.modal-actions{flex-direction:column}.save-button,.clear-button{flex:1}}.slider-container{position:relative;width:100%}.slider-container input[type=range]{-webkit-appearance:none;appearance:none;width:100%;height:10px;border-radius:999px;background:linear-gradient(to right,#4a148c,#5c6bc0,#90a4ae,#b0bec5,#26a69a);outline:none;margin:0;padding:0;cursor:pointer}.slider-container input[type=range]::-webkit-slider-track{height:10px;border-radius:999px;background:transparent;border:none}.slider-container input[type=range]::-moz-range-track{height:10px;border-radius:999px;background:transparent;border:none}.slider-container input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:26px;height:26px;border-radius:50%;background:#fff;border:3px solid #4A148C;cursor:grab;box-shadow:0 2px 6px #0003;transition:transform .2s ease,box-shadow .2s ease;margin-top:-8px}.slider-container input[type=range]::-moz-range-thumb{width:26px;height:26px;border-radius:50%;background:#fff;border:3px solid #4A148C;cursor:grab;box-shadow:0 2px 6px #0003;transition:transform .2s ease,box-shadow .2s ease;border:none}.slider-container input[type=range]::-webkit-slider-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.slider-container input[type=range]::-moz-range-thumb:hover{transform:scale(1.1);box-shadow:0 4px 8px #0000004d}.slider-container input[type=range]::-webkit-slider-thumb:active{cursor:grabbing;transform:scale(1.15)}.slider-container input[type=range]::-moz-range-thumb:active{cursor:grabbing;transform:scale(1.15)}.slider-container input[type=range][data-level="0"]::-webkit-slider-thumb{border-color:#4a148c}.slider-container input[type=range][data-level="0"]::-moz-range-thumb{border-color:#4a148c}.slider-container input[type=range][data-level="1"]::-webkit-slider-thumb{border-color:#5c6bc0}.slider-container input[type=range][data-level="1"]::-moz-range-thumb{border-color:#5c6bc0}.slider-container input[type=range][data-level="2"]::-webkit-slider-thumb{border-color:#90a4ae}.slider-container input[type=range][data-level="2"]::-moz-range-thumb{border-color:#90a4ae}.slider-container input[type=range][data-level="3"]::-webkit-slider-thumb{border-color:#b0bec5}.slider-container input[type=range][data-level="3"]::-moz-range-thumb{border-color:#b0bec5}.slider-container input[type=range][data-level="4"]::-webkit-slider-thumb{border-color:#26a69a}.slider-container input[type=range][data-level="4"]::-moz-range-thumb{border-color:#26a69a}.slider-labels{display:flex;justify-content:space-between;margin-top:1rem}.slider-labels>div{flex:1;text-align:center;transition:all .2s ease}.slider-labels .emoji{font-size:2rem;margin-bottom:.5rem;font-weight:700}.slider-labels .label{font-size:.75rem;color:#9ca3af}.slider-labels>div.active .label{font-weight:600}.session-coaches{background:#fff;border-radius:8px;padding:20px;margin:20px 0;box-shadow:0 2px 4px #0000001a}.session-coaches.editing{border:2px solid #8b5cf6}.session-coaches-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.session-coaches-header h3{margin:0;font-size:18px;color:#2c3e50}.btn-edit-coaches{padding:8px 16px;background:#8b5cf6;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;font-size:14px;transition:all .2s}.btn-edit-coaches:hover{background:#7c3aed;transform:translateY(-1px)}.coaches-list-readonly{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:12px}.coach-badge{display:inline-flex;align-items:center;padding:8px 14px;background:linear-gradient(135deg,#8b5cf6,#7c3aed);color:#fff;border-radius:20px;font-size:14px;font-weight:500;box-shadow:0 2px 4px #8b5cf633}.no-coaches{color:#9ca3af;font-style:italic;margin:0}.metadata-text{font-size:12px;color:#6b7280;margin:8px 0 0}.edit-help-text{color:#6b7280;font-size:14px;margin-bottom:16px}.coaches-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:10px;margin-bottom:20px}.coach-select-btn{display:flex;align-items:center;gap:10px;padding:12px 16px;background:#fff;border:2px solid #e5e7eb;border-radius:8px;cursor:pointer;transition:all .2s;font-size:14px;font-weight:500;color:#374151;text-align:left}.coach-select-btn:hover{border-color:#8b5cf6;background:#faf5ff;transform:translateY(-1px)}.coach-select-btn.selected{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-color:#7c3aed;color:#fff;box-shadow:0 2px 8px #8b5cf64d}.coach-icon{display:flex;align-items:center;justify-content:center;width:20px;height:20px;font-size:14px;font-weight:700}.coach-select-btn:not(.selected) .coach-icon{color:#9ca3af}.edit-actions{display:flex;justify-content:flex-end;gap:12px;padding-top:16px;border-top:1px solid #e5e7eb}.btn-cancel{padding:10px 20px;background:#fff;border:1px solid #d1d5db;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-cancel:hover{background:#f9fafb;border-color:#9ca3af}.btn-save-coaches{padding:10px 20px;background:#10b981;color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500;transition:all .2s}.btn-save-coaches:hover:not(:disabled){background:#059669;transform:translateY(-1px)}.btn-save-coaches:disabled{opacity:.5;cursor:not-allowed}@media(max-width:640px){.coaches-grid{grid-template-columns:1fr}}.confirm-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:9999;animation:fadeIn .2s}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.confirm-modal{background:#fff;border-radius:12px;padding:30px;max-width:450px;width:90%;box-shadow:0 10px 40px #0000004d;animation:slideUp .3s}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.confirm-modal h3{margin:0 0 15px;color:#2c3e50;font-size:22px}.confirm-modal p{margin:0 0 25px;color:#666;font-size:16px;line-height:1.5}.confirm-actions{display:flex;gap:10px;justify-content:flex-end}.btn-cancel,.btn-confirm{padding:10px 24px;border:none;border-radius:6px;font-size:15px;font-weight:500;cursor:pointer;transition:all .2s}.btn-cancel{background:#e9ecef;color:#495057}.btn-cancel:hover{background:#dee2e6}.btn-confirm{background:#ff6b35;color:#fff}.btn-confirm:hover{background:#f52}.admin-panel{padding:30px;max-width:1200px;margin:0 auto}.admin-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.admin-header h1{margin:0;color:var(--text-primary);font-size:var(--font-size-3xl)}.admin-actions{display:flex;gap:10px}.btn-primary,.btn-secondary,.btn-sm{padding:.75rem 1.5rem;border:none;border-radius:var(--border-radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);transition:all var(--transition-base)}.btn-primary{background:var(--gradient-primary);color:#fff;box-shadow:var(--shadow-primary)}.btn-primary:hover{transform:translateY(-1px);box-shadow:var(--shadow-primary-lg)}.btn-secondary{background:var(--color-gray-500);color:#fff}.btn-secondary:hover{background:var(--color-gray-600)}.btn-sm{padding:.5rem 1rem;font-size:var(--font-size-xs);background:var(--color-info);color:#fff}.btn-sm:hover{background:var(--color-info-dark)}.btn-danger{background:var(--color-error)!important}.btn-danger:hover{background:var(--color-error-dark)!important}.btn-role-admin{background:var(--color-primary)!important}.btn-role-admin:hover{background:var(--color-primary-dark)!important}.btn-role-coach{background:var(--color-info)!important}.btn-role-coach:hover{background:var(--color-info-dark)!important}.message{padding:15px;border-radius:5px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.message button{background:none;border:none;font-size:20px;cursor:pointer;padding:0 10px}.add-user-form{background:var(--bg-tertiary);padding:var(--space-xl);border-radius:var(--border-radius-lg);margin-bottom:var(--space-xl);box-shadow:var(--shadow-md)}.add-user-form h3{margin-top:0;margin-bottom:var(--space-lg);color:var(--text-primary)}.form-group{margin-bottom:15px}.form-group label{display:block;margin-bottom:5px;font-weight:500;color:#495057}.form-group input,.form-group select{width:100%;padding:10px;border:1px solid #ced4da;border-radius:4px;font-size:14px}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px #8b5cf61a}.users-table{background:#fff;border-radius:8px;overflow:hidden;box-shadow:0 2px 4px #0000001a}.users-table table{width:100%;border-collapse:collapse}.users-table th{background:var(--gradient-secondary);color:#fff;padding:var(--space-md);text-align:left;font-weight:var(--font-weight-medium)}.users-table td{padding:15px;border-bottom:1px solid #dee2e6}.users-table tr:hover{background:#f8f9fa}.badge{display:inline-block;padding:4px 10px;border-radius:12px;font-size:12px;font-weight:500}.badge.admin{background:var(--gradient-primary);color:#fff}.badge.coach{background:var(--color-info);color:#fff}.status{font-size:14px;font-weight:500}.status.active{color:#28a745}.status.inactive{color:#dc3545}.actions{display:flex;gap:5px}.loading{text-align:center;padding:40px;color:#6c757d}.system-management{margin-top:40px;padding-top:30px;border-top:2px solid #e5e7eb}.system-management h2{margin-bottom:20px;color:#2c3e50}*{box-sizing:border-box;margin:0;padding:0}html,body{margin:0;padding:0;width:100%;min-height:100vh;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{background:#f5f5f7;color:#333}.portal-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--gradient-secondary);color:#fff;padding:2rem 0;position:fixed;height:100vh;overflow-y:auto;box-shadow:var(--shadow-lg)}.sidebar-header{padding:0 1.5rem 2rem;text-align:center;border-bottom:1px solid rgba(255,255,255,.2);margin-bottom:2rem}.sidebar-header h1{font-size:1.5rem;margin-bottom:.5rem;font-weight:600}.sidebar-nav{list-style:none;padding:0;margin:0}.sidebar-nav li{margin-bottom:.5rem}.sidebar-nav a{display:block;padding:.75rem 1.5rem;color:#fffc;text-decoration:none;transition:all .2s;border-left:3px solid transparent}.sidebar-nav a:hover{background:#ffffff1a;color:#fff;border-left-color:#fff}.sidebar-nav a.active{background:#fff3;color:#fff;border-left-color:#fff;font-weight:600}.main-content{margin-left:var(--sidebar-width);flex:1;padding:2rem;min-height:100vh}.user-profile{padding:1.5rem;border-top:1px solid rgba(255,255,255,.2);margin-top:auto}.user-profile img{width:40px;height:40px;border-radius:50%;margin-bottom:.5rem}.user-profile-info{font-size:.875rem}.user-profile-name{font-weight:600;margin-bottom:.25rem}.user-profile-email{opacity:.8;font-size:.8rem}.logout-btn{margin-top:1rem;width:100%;padding:.5rem;background:#fff3;border:none;color:#fff;border-radius:6px;cursor:pointer;font-size:.875rem;transition:all .2s}.logout-btn:hover{background:#ffffff4d}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:2rem}.login-card{background:#fff;border-radius:16px;padding:3rem;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;text-align:center}.login-logo{width:120px;height:auto;margin-bottom:1.5rem}.login-card h1{font-size:2rem;margin-bottom:.5rem;color:#333}.login-card p{color:#666;margin-bottom:2rem;font-size:1rem}.google-signin-btn{width:100%;padding:1rem;background:#4285f4;color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:.75rem;transition:all .2s}.google-signin-btn:hover{background:#357ae8;transform:translateY(-2px);box-shadow:0 4px 12px #4285f466}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid #e5e7eb;font-size:.875rem;color:#666}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{font-size:2rem;color:#333;margin-bottom:.5rem}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.dashboard-card{background:#fff;border-radius:12px;padding:2rem;box-shadow:0 2px 8px #0000001a;transition:all .2s;text-decoration:none;color:inherit;display:block}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 4px 16px #00000026}.dashboard-card-icon{font-size:2.5rem;margin-bottom:1rem}.dashboard-card h2{font-size:1.25rem;margin-bottom:.5rem;color:#333}.dashboard-card p{color:#666;font-size:.95rem;line-height:1.5}.dashboard-card-arrow{margin-top:1rem;color:#8b5cf6;font-weight:600}.page-header{margin-bottom:2rem}.page-header h1{font-size:2rem;color:#333;margin-bottom:.5rem}.page-header p{color:#666;font-size:1rem}.page-header-compact{margin-bottom:2rem;text-align:center}.page-header-compact h1{font-size:2rem;color:#333;margin-bottom:1rem}.step-indicator-compact{display:flex;justify-content:center;gap:1rem;flex-wrap:wrap}.step-indicator-compact span{padding:.5rem 1rem;background:#e5e7eb;border-radius:20px;font-size:.875rem;color:#6b7280;transition:all .2s}.step-indicator-compact span.active{background:#8b5cf6;color:#fff;font-weight:600}.term-tracker-page{max-width:900px;margin:0 auto}.form-container{background:#fff;border-radius:12px;padding:2.5rem;box-shadow:0 2px 8px #0000001a;margin-bottom:2rem}.form-container h2{color:#333;font-size:1.5rem;margin-bottom:1.5rem;text-align:center}.form-description{color:#666;margin-bottom:2rem;text-align:center;font-size:.95rem}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;margin-bottom:2rem}.form-group{display:flex;flex-direction:column;margin-bottom:1.5rem}.form-group.full-width{grid-column:1 / -1}.form-group label{font-weight:600;margin-bottom:.5rem;color:#333;font-size:.95rem;text-align:left}.required{color:#ef4444}.form-group input,.form-group select,.form-group textarea{padding:.75rem;border:2px solid #e5e7eb;border-radius:8px;font-size:1rem;transition:all .2s;font-family:inherit}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:#8b5cf6;box-shadow:0 0 0 3px #8b5cf61a}.form-group input.error,.form-group select.error,.form-group textarea.error{border-color:#ef4444}.error-message{color:#ef4444;font-size:.875rem;margin-top:.25rem;text-align:left}.help-text{color:#6b7280;font-size:.875rem;margin-top:.25rem;text-align:left}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}@media(max-width:768px){.form-row{grid-template-columns:1fr}.form-container{padding:1.5rem}.sidebar{width:200px}.main-content{margin-left:200px}}@media(max-width:640px){.sidebar{position:relative;width:100%;height:auto}.main-content{margin-left:0}.portal-layout{flex-direction:column}}.term-date-info,.auto-calculated-notice,.review-note,.info-note,.info-banner,.error-banner{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.95rem;animation:slideIn .3s ease-out}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.term-date-info{background:#e0f2fe;border:2px solid #0ea5e9;color:#075985}.auto-calculated-notice{background:#f0fdf4;border:2px solid #4ade80;color:#166534}.review-note{background:#fef3c7;border:2px solid #fbbf24;color:#92400e;font-weight:600}.info-note{background:#fef3c7;border:2px solid #fbbf24;color:#92400e}.info-banner{background:#dbeafe;border:2px solid #3b82f6;color:#1e40af;text-align:center}.error-banner{background:#fee2e2;border:2px solid #ef4444;color:#991b1b}.close-notice-btn{background:transparent;border:none;color:inherit;font-size:1.25rem;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;opacity:.7}.close-notice-btn:hover{opacity:1;background:#0000001a}.btn-primary,.btn-secondary{padding:.75rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .2s;border:none;display:inline-flex;align-items:center;gap:.5rem;text-decoration:none}.btn-primary{background:#8b5cf6;color:#fff}.btn-primary:hover:not(:disabled){background:#7c3aed;transform:translateY(-1px);box-shadow:0 4px 12px #8b5cf64d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:#e5e7eb;color:#4b5563}.btn-secondary:hover{background:#d1d5db}.btn-large{padding:1rem 2rem;font-size:1.1rem}.btn-link{background:transparent;border:none;color:#8b5cf6;font-size:.95rem;cursor:pointer;padding:.5rem 0;margin-bottom:1rem;text-decoration:underline;transition:all .2s}.btn-link:hover{color:#7c3aed;text-decoration:none}.btn-remove{background:#ef4444;color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;transition:all .2s}.btn-remove:hover{background:#dc2626;transform:scale(1.1)}.form-actions{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:2px solid #e5e7eb;margin-top:2rem}@media(max-width:640px){.form-actions{flex-direction:column}.form-actions button,.form-actions a{width:100%}}.session-preview{background:#f8f9fa;border:2px solid #e5e7eb;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.session-preview h3{color:#8b5cf6;font-size:1.25rem;margin-bottom:.75rem}.session-preview p{color:#4b5563;margin-bottom:1rem}.session-dates{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.5rem}.session-date{background:#fff;padding:.5rem;border-radius:6px;font-size:.875rem;text-align:center;border:1px solid #e5e7eb}.athletes-list{margin-bottom:2rem}.athletes-list h3{color:#333;font-size:1.25rem;margin-bottom:1rem}.athlete-cards{display:flex;flex-direction:column;gap:.75rem;margin-bottom:2rem}.athlete-card{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:#f8f9fa;border:2px solid #e5e7eb;border-radius:8px;transition:all .2s}.athlete-info h4{color:#333;font-size:1.1rem;margin-bottom:.5rem}.athlete-details{display:flex;flex-wrap:wrap;gap:.5rem}.badge{display:inline-block;padding:.25rem .75rem;background:#8b5cf6;color:#fff;border-radius:12px;font-size:.875rem;font-weight:500}.badge-secondary{display:inline-block;padding:.25rem .75rem;background:#e5e7eb;color:#4b5563;border-radius:12px;font-size:.875rem;font-weight:500}.add-athlete-section{background:#f0fdf4;border:2px dashed #86efac;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.add-athlete-section h3{color:#16a34a;font-size:1.25rem;margin-bottom:1.5rem}.section-title{color:#6b7280;font-size:1rem;font-weight:600;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:2px solid #e5e7eb}.btn-add-athlete{width:100%;margin-top:1rem}.confirmation-container{max-width:800px;margin:0 auto;padding:2rem 1rem}.confirmation-card{background:#fff;border-radius:12px;padding:3rem 2rem;box-shadow:0 4px 16px #0000001a;text-align:center}.success-icon{margin-bottom:2rem}.checkmark-circle{width:100px;height:100px;background:#10b981;border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto;animation:scaleIn .4s ease-out}.checkmark{color:#fff;font-size:3rem;font-weight:700}@keyframes scaleIn{0%{transform:scale(0)}to{transform:scale(1)}}.success-title{color:#10b981;font-size:2.25rem;margin-bottom:1rem}.success-message{color:#4b5563;font-size:1.1rem;margin-bottom:2rem}.term-summary{background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:2rem;text-align:left}.term-summary h2{color:#8b5cf6;font-size:1.5rem;margin-bottom:1rem;text-align:center}.summary-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.summary-item{display:flex;flex-direction:column;padding:.75rem;background:#fff;border-radius:6px}.summary-label{font-size:.875rem;color:#6b7280;font-weight:600;margin-bottom:.25rem}.summary-value{color:#111827;font-size:1rem}.spreadsheet-link-section{margin-bottom:2rem;padding:2rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:12px;color:#fff}.spreadsheet-link-section h3{color:#fff;font-size:1.5rem;margin-bottom:.5rem}.link-description{margin-bottom:1.5rem;opacity:.9}.btn-spreadsheet{display:inline-flex;align-items:center;gap:.75rem;background:#fff;color:#8b5cf6;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;text-decoration:none;transition:all .2s;margin-bottom:1rem}.btn-spreadsheet:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0003}.spreadsheet-icon{font-size:1.5rem}.external-icon{font-size:1.25rem}.link-help{font-size:.875rem;opacity:.9;margin-top:.5rem}.next-steps{text-align:left;background:#f8f9fa;border-radius:8px;padding:1.5rem;margin-bottom:2rem}.next-steps h3{color:#8b5cf6;font-size:1.25rem;margin-bottom:1rem}.steps-list{margin-left:1.5rem;color:#4b5563}.steps-list li{margin-bottom:.75rem;line-height:1.6}.confirmation-actions{display:flex;gap:1rem;justify-content:center;margin-bottom:2rem;flex-wrap:wrap}.additional-info{padding:1rem;background:#fef3c7;border-radius:8px;border:2px solid #fbbf24}.info-text{color:#92400e;margin:0;font-size:.95rem}.spinner{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.loading-content{text-align:center;color:#fff}.loading-content h2{font-size:1.5rem;margin-bottom:1rem}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.athlete-card .btn-edit{background:#f3f4f6;border:2px solid #e5e7eb;color:#4b5563;padding:.5rem 1rem;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;gap:.5rem}.athlete-card .btn-edit:hover{background:#e5e7eb;border-color:#d1d5db;color:#1f2937;transform:translateY(-1px)}.athlete-card .btn-delete{background:#fee2e2;border:2px solid #fecaca;color:#dc2626;padding:.5rem;border-radius:6px;font-size:1.25rem;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;width:40px;height:40px}.athlete-card .btn-delete:hover{background:#fecaca;border-color:#fca5a5;color:#b91c1c;transform:scale(1.05)}.athlete-actions{display:flex;gap:.75rem;align-items:center}.athlete-card{background:#fff;border:2px solid #e5e7eb;border-radius:12px;padding:1.25rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;transition:all .2s}.athlete-card:hover{border-color:#8b5cf6;box-shadow:0 2px 8px #8b5cf61a}.athlete-card .support-ratio-badge{background:#8b5cf6;color:#fff;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;display:inline-block;margin-right:.5rem}.athlete-card .status-badge{background:#f3f4f6;color:#6b7280;padding:.25rem .75rem;border-radius:12px;font-size:.875rem;font-weight:600;display:inline-block}@media(max-width:768px){.athlete-card{flex-direction:column;align-items:flex-start}.athlete-actions{margin-top:1rem;width:100%;justify-content:flex-end}}.access-denied{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:2rem;text-align:center}.access-denied h2{font-size:2rem;color:#dc2626;margin-bottom:1rem}.access-denied p{color:#6b7280;font-size:1.125rem}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;font-family:system-ui,-apple-system,sans-serif}.spinner{border:4px solid #f3f3f3;border-top:4px solid #ff6b35;border-radius:50%;width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:20px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.access-denied button{margin-top:20px;padding:10px 20px;background:#ff6b35;color:#fff;border:none;border-radius:5px;cursor:pointer;font-size:16px}.access-denied button:hover{background:#f52}.portal-layout{display:flex;min-height:100vh;background:#f5f5f5}.portal-nav{width:280px;background:linear-gradient(180deg,#667eea,#764ba2);color:#fff;display:flex;flex-direction:column;position:fixed;height:100vh;overflow-y:auto}.nav-header{padding:30px 20px;text-align:center;border-bottom:1px solid rgba(255,255,255,.1)}.nav-logo{width:80px;height:auto;margin-bottom:15px;filter:brightness(0) invert(1)}.nav-header h2{font-size:1.2rem;font-weight:600;margin:0}.nav-links{flex:1;padding:20px 0}.nav-link{display:flex;align-items:center;padding:15px 25px;color:#fffc;text-decoration:none;transition:all .2s;font-size:.95rem}.nav-link:hover{background:#ffffff1a;color:#fff}.nav-link.active{background:#fff3;color:#fff;font-weight:600;border-left:4px solid white}.nav-icon{margin-right:12px;font-size:1.2rem}.nav-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.user-info{display:flex;align-items:center;gap:12px;margin-bottom:15px}.user-avatar{width:40px;height:40px;border-radius:50%;border:2px solid rgba(255,255,255,.3)}.user-details{flex:1;min-width:0}.user-name{font-weight:600;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-email{font-size:.75rem;opacity:.8;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.btn-logout{width:100%;padding:10px;background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:6px;cursor:pointer;font-size:.9rem;font-weight:500;transition:all .2s}.btn-logout:hover{background:#ffffff4d}.portal-content{margin-left:280px;flex:1;padding:40px;max-width:1400px}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-card{background:#fff;border-radius:16px;padding:50px;box-shadow:0 20px 60px #0000004d;max-width:450px;width:100%;text-align:center}.login-logo{width:120px;height:auto;margin-bottom:20px}.login-card h1{font-size:2rem;color:#333;margin-bottom:10px}.login-subtitle{color:#666;margin-bottom:40px;font-size:.95rem}.login-button-container{display:flex;justify-content:center;margin-bottom:30px}.login-footer{margin-top:30px;padding-top:30px;border-top:1px solid #e0e0e0}.login-footer p{color:#666;font-size:.85rem;margin:5px 0}.login-contact a{color:#667eea;text-decoration:none;font-weight:600}.login-contact a:hover{text-decoration:underline}.loading-screen{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2)}.loading-screen .loading-content{background:#fff;padding:40px 60px;border-radius:12px;box-shadow:0 10px 40px #0003}.dashboard{max-width:1200px}.dashboard-header{margin-bottom:40px}.dashboard-header h1{font-size:2.5rem;color:#333;margin-bottom:8px}.dashboard-header p{color:#666;font-size:1.1rem}.dashboard-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:25px;margin-bottom:40px}.dashboard-card{background:#fff;border-radius:12px;padding:30px;text-decoration:none;color:inherit;transition:all .3s;border:2px solid #e0e0e0;position:relative;display:block}.dashboard-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#667eea}.dashboard-card.coming-soon{opacity:.6;cursor:not-allowed}.dashboard-card.coming-soon:hover{transform:none;box-shadow:none;border-color:#e0e0e0}.card-icon{font-size:3rem;margin-bottom:15px}.dashboard-card h3{font-size:1.3rem;color:#333;margin-bottom:10px}.dashboard-card p{color:#666;font-size:.95rem;line-height:1.5;margin-bottom:15px}.card-arrow{color:#667eea;font-size:1.5rem;font-weight:700}.coming-soon-badge{position:absolute;top:15px;right:15px;background:#ffc107;color:#333;padding:4px 12px;border-radius:12px;font-size:.75rem;font-weight:600}.dashboard-info{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:25px}.info-card{background:#fff;border-radius:12px;padding:25px;border:2px solid #e0e0e0}.info-card h3{color:#333;margin-bottom:15px;font-size:1.1rem}.info-card ul{list-style:none;padding:0;margin:0}.info-card li{padding:8px 0;border-bottom:1px solid #f0f0f0}.info-card li:last-child{border-bottom:none}.info-card a{color:#667eea;text-decoration:none}.info-card a:hover{text-decoration:underline}.info-card p{color:#666;line-height:1.6;margin:8px 0}.info-card strong{color:#667eea}.resources-page{max-width:1200px}.page-header{margin-bottom:40px}.page-header h1{font-size:2.5rem;color:#333;margin-bottom:8px}.page-header p{color:#666;font-size:1.1rem}.resource-section{margin-bottom:50px}.resource-section h2{color:#333;font-size:1.5rem;margin-bottom:20px;padding-bottom:10px;border-bottom:2px solid #e0e0e0}.resource-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:20px}.resource-card{background:#fff;border-radius:12px;padding:25px;text-decoration:none;color:inherit;border:2px solid #e0e0e0;transition:all .3s;position:relative;display:block}.resource-card:hover{transform:translateY(-4px);box-shadow:0 8px 24px #0000001a;border-color:#667eea}.resource-type-badge{position:absolute;top:15px;right:15px;background:#667eea;color:#fff;padding:4px 10px;border-radius:8px;font-size:.75rem;font-weight:600}.resource-card h3{color:#333;font-size:1.1rem;margin-bottom:10px;padding-right:60px}.resource-card p{color:#666;font-size:.9rem;line-height:1.5;margin-bottom:15px}.resource-link{color:#667eea;font-weight:600;font-size:.9rem}.resources-footer{margin-top:50px}.info-box{background:#f8f9fa;border-left:4px solid #667eea;padding:25px;border-radius:8px}.info-box h3{color:#333;margin-bottom:10px}.info-box p{color:#666;line-height:1.6}.info-box a{color:#667eea;text-decoration:none;font-weight:600}.info-box a:hover{text-decoration:underline}.term-tracker-page{max-width:1000px}.page-header-compact{margin-bottom:30px}.page-header-compact h1{font-size:2rem;color:#333;margin-bottom:15px}.step-indicator-compact{display:flex;gap:15px;flex-wrap:wrap}.step-indicator-compact span{padding:8px 16px;background:#e0e0e0;border-radius:20px;font-size:.9rem;color:#666;transition:all .3s}.step-indicator-compact span.active{background:#667eea;color:#fff;font-weight:600}@media(max-width:900px){.portal-nav{width:100%;height:auto;position:static}.portal-content{margin-left:0;padding:20px}.portal-layout{flex-direction:column}.dashboard-header h1,.page-header h1{font-size:2rem}.login-card{padding:30px}}.nav-divider{height:1px;background:#ffffff1a;margin:10px 0}.user-role-badge{display:inline-block;background:#ff6b35;color:#fff;padding:2px 8px;border-radius:10px;font-size:11px;font-weight:600;margin-top:4px}.coach-view-badge{color:#6c757d;font-size:.9em;font-weight:400}
