@import"https://fonts.googleapis.com/css2?family=Cairo:wght@200;300;400;500;600;700;800;900&display=swap";html{font-size:16px;scroll-behavior:smooth}body{margin:0;padding:0;font-family:Cairo,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif}*{margin:0;padding:0;box-sizing:border-box}*{transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.app-nav,.swimmer-card,.leaderboard-table,.rankings-table{contain:layout style paint;will-change:transform}.leaderboard-table,.rankings-table,.times-table{transform:translateZ(0);table-layout:fixed;contain:layout style paint}.swimmer-card{transform:translateZ(0);contain:layout style paint;touch-action:manipulation}.swimmers-grid,.rankings-mobile-grid{transform:translateZ(0);contain:layout style paint;-webkit-overflow-scrolling:touch}:root{--navy: #1e3a8a;--navy-light: #3b82f6;--navy-dark: #1e40af;--navy-50: #eff6ff;--navy-100: #dbeafe;--navy-200: #bfdbfe;--navy-300: #93c5fd;--navy-400: #60a5fa;--navy-500: #3b82f6;--navy-600: #2563eb;--navy-700: #1d4ed8;--navy-800: #1e40af;--navy-900: #1e3a8a;--white: #ffffff;--gray-50: #f8fafc;--gray-100: #f1f5f9;--gray-200: #e2e8f0;--gray-300: #cbd5e1;--gray-400: #94a3b8;--gray-500: #64748b;--gray-600: #475569;--gray-700: #334155;--gray-800: #1e293b;--gray-900: #0f172a;--accent: #06b6d4;--accent-light: #67e8f9;--accent-dark: #0891b2;--success: #10b981;--success-light: #6ee7b7;--warning: #f59e0b;--warning-light: #fcd34d;--error: #ef4444;--error-light: #fca5a5;--primary: var(--navy);--primary-light: var(--navy-light);--primary-dark: var(--navy-dark);--secondary: var(--accent);--background: var(--white);--surface: var(--white);--surface-elevated: var(--gray-50);--text-primary: var(--gray-900);--text-secondary: var(--gray-600);--text-muted: var(--gray-500);--text-inverse: var(--white);--border: var(--gray-200);--border-light: var(--gray-100);--border-dark: var(--gray-300);--shadow-xs: 0 1px 2px rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px rgba(0, 0, 0, .1), 0 1px 2px rgba(0, 0, 0, .06);--shadow: 0 4px 6px rgba(0, 0, 0, .07), 0 2px 4px rgba(0, 0, 0, .06);--shadow-md: 0 10px 15px rgba(0, 0, 0, .1), 0 4px 6px rgba(0, 0, 0, .05);--shadow-lg: 0 20px 25px rgba(0, 0, 0, .1), 0 10px 10px rgba(0, 0, 0, .04);--shadow-xl: 0 25px 50px rgba(0, 0, 0, .15);--shadow-colored: 0 10px 25px rgba(30, 58, 138, .15);--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-sm: .375rem;--radius: .5rem;--radius-md: .75rem;--radius-lg: 1rem;--radius-xl: 1.5rem;--radius-2xl: 2rem;--radius-full: 9999px;--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: 1.875rem;--font-size-4xl: 2.25rem;--font-size-5xl: 3rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--font-weight-extrabold: 800;--line-height-tight: 1.25;--line-height-snug: 1.375;--line-height-normal: 1.5;--line-height-relaxed: 1.625;--line-height-loose: 2;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .35s ease;--transition-bounce: .3s cubic-bezier(.68, -.55, .265, 1.55)}body{font-family:Cairo,-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;background-color:var(--background);color:var(--text-primary);line-height:1.6;-webkit-overflow-scrolling:touch;-webkit-text-size-adjust:100%;padding:env(safe-area-inset-top) env(safe-area-inset-right) env(safe-area-inset-bottom) env(safe-area-inset-left);scroll-behavior:smooth;scroll-padding-top:80px;contain:layout style;font-display:swap;overflow-x:hidden}.app{min-height:100vh;display:flex;flex-direction:column}.app-header{background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);color:var(--navy);border-bottom:1px solid var(--border-light);padding:var(--space-16) var(--space-6);text-align:center;position:relative;overflow:hidden;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.app-header:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:url('data:image/svg+xml,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100"><defs><pattern id="grain" width="100" height="100" patternUnits="userSpaceOnUse"><circle cx="25" cy="25" r="1" fill="rgba(255,255,255,0.1)"/><circle cx="75" cy="75" r="1" fill="rgba(255,255,255,0.05)"/><circle cx="50" cy="10" r="0.5" fill="rgba(255,255,255,0.08)"/></pattern></defs><rect width="100" height="100" fill="url(%23grain)"/></svg>');opacity:.3;pointer-events:none}.logo-container{margin-bottom:var(--space-6);position:relative;z-index:1}.logo{height:72px;width:auto;filter:drop-shadow(0 8px 16px rgba(30,58,138,.2))}.logo:hover{filter:drop-shadow(0 12px 24px rgba(30,58,138,.3))}.app-header h1{font-size:var(--font-size-4xl);margin-bottom:var(--space-3);font-weight:var(--font-weight-extrabold);color:var(--navy);letter-spacing:-.025em;text-shadow:0 4px 8px rgba(30,58,138,.15);position:relative;z-index:1;line-height:var(--line-height-tight)}.subtitle{font-size:var(--font-size-lg);color:var(--text-secondary);font-weight:var(--font-weight-medium);letter-spacing:.01em;position:relative;z-index:1;line-height:var(--line-height-relaxed)}.header-actions{position:absolute;top:1rem;right:1rem;display:flex;gap:.5rem;align-items:center}.refresh-btn{padding:.5rem 1rem;background-color:var(--gray-100);color:var(--navy);border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.refresh-btn:hover{background-color:var(--gray-200);box-shadow:var(--shadow)}.admin-login-btn{padding:.5rem 1rem;background-color:var(--navy);color:var(--white);border:none;border-radius:6px;font-size:.9rem;font-weight:500;cursor:pointer}.admin-login-btn:hover{background-color:var(--navy-dark);box-shadow:var(--shadow)}.admin-bar{background-color:var(--navy);color:var(--white);padding:.75rem 1rem;display:flex;justify-content:space-between;align-items:center;font-size:.9rem}.admin-info{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.admin-badge{background-color:#fff3;padding:.25rem .5rem;border-radius:4px;font-weight:600}.admin-user{font-weight:500}.admin-role{font-size:.8rem;opacity:.8;background:#ffffff1a;padding:.2rem .5rem;border-radius:8px}.admin-actions{display:flex;align-items:center;gap:.5rem}.app-nav{display:flex;justify-content:center;gap:0;padding:0;background:linear-gradient(180deg,var(--white) 0%,var(--navy-50) 100%);border-bottom:1px solid var(--border-light);box-shadow:var(--shadow-sm);position:-webkit-sticky;position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);-webkit-transform:translateZ(0);will-change:transform;-webkit-overflow-scrolling:touch;isolation:isolate;-webkit-transform:translate3d(0,0,0);transform:translateZ(0);backface-visibility:hidden;perspective:1000px}.app-nav:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,var(--navy) 50%,transparent 100%);opacity:.3}.nav-text-mobile{display:none}.nav-text-full{display:inline}.nav-btn{padding:var(--space-5) var(--space-10);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);border:none;background-color:transparent;color:var(--text-secondary);cursor:pointer;border-bottom:3px solid transparent;position:relative;letter-spacing:.01em;border-radius:var(--radius-md) var(--radius-md) 0 0;overflow:hidden}.nav-btn:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);opacity:0;border-radius:8px 8px 0 0}.nav-btn:hover{color:var(--navy);background-color:#1a365d0d}.nav-btn:hover:before{opacity:.1}.nav-btn.active{color:var(--navy);border-bottom-color:var(--navy);background-color:var(--white);box-shadow:0 -4px 12px #1a365d26}.nav-btn.active:before{opacity:.15}.app-main{flex:1;padding:3rem 2rem;max-width:1400px;margin:0 auto;width:100%;background:linear-gradient(180deg,#f8fafc,#f1f5f9);min-height:calc(100vh - 200px);scroll-margin-top:80px}.btn{padding:var(--space-3) var(--space-6);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border:2px solid var(--navy);border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);position:relative;overflow:hidden;text-decoration:none;white-space:nowrap;letter-spacing:.01em;font-family:inherit}.btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(30,58,138,.1),transparent)}.btn:hover:before{left:100%}.btn:hover{box-shadow:var(--shadow-colored)}.btn:active{box-shadow:var(--shadow-md)}.btn:focus{outline:none;box-shadow:0 0 0 3px #1e3a8a33}.btn-primary{background-color:var(--navy);color:var(--white);border-color:var(--navy)}.btn-primary:hover{background-color:var(--navy-dark);border-color:var(--navy-dark)}.btn-secondary{background-color:var(--white);color:var(--navy);border-color:var(--border)}.btn-secondary:hover{background-color:var(--gray-50);border-color:var(--navy)}.btn-danger{background-color:var(--white);color:#dc2626;border-color:#dc2626}.btn-danger:hover{background-color:#fef2f2}.btn-warning{background-color:var(--white);color:#ea580c;border-color:#ea580c}.btn-warning:hover{background-color:#fff7ed}.btn-small{padding:.5rem 1rem;font-size:.85rem}.add-swimmer-button-container{margin-bottom:2rem}.add-swimmer-form{background-color:var(--white);padding:2rem;border-radius:8px;border:1px solid var(--border);margin-bottom:2rem;box-shadow:var(--shadow)}.add-swimmer-form h3{margin-bottom:1.5rem;color:var(--navy);font-size:1.25rem;font-weight:600}.form-group{margin-bottom:1.5rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.form-group input,.form-group select{width:100%;padding:.75rem;font-size:.9rem;border:1px solid var(--border);border-radius:4px;background-color:var(--white)}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1a365d1a}.form-actions{display:flex;gap:1rem;margin-top:1.5rem}.swimmer-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.swimmer-list h2{margin:0;color:var(--navy);font-size:1.5rem;font-weight:600}.filter-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:2px solid var(--navy);border-radius:12px;color:var(--navy);font-weight:600;font-size:.9rem;cursor:pointer;position:relative;overflow:hidden}.filter-toggle-btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(26,54,93,.1),transparent)}.filter-toggle-btn:hover:before{left:100%}.filter-toggle-btn:hover{background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);color:var(--white);box-shadow:0 8px 25px #1a365d66}.filter-toggle-btn.expanded{background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);color:var(--white)}.filter-icon{font-size:1rem}.filter-text{font-weight:600}.filter-arrow{font-size:.8rem}.swimmer-filters{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);margin-bottom:2rem;border-radius:12px;box-shadow:0 4px 20px #00000014;overflow:hidden;position:relative}.swimmer-filters:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%);opacity:0}.swimmer-filters.expanded{padding:1.5rem}.swimmer-filters.expanded:before{opacity:1}.swimmer-filters.collapsed{max-height:0;padding:0;margin-bottom:0;border:none;box-shadow:none}.filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:end}.swimmer-filters .filter-group{display:flex;flex-direction:column;gap:.5rem}.swimmer-filters .filter-group label{font-weight:500;color:var(--text-primary);font-size:.9rem}.swimmer-filters .filter-group select{padding:.75rem;font-size:.9rem;border:1px solid var(--border);border-radius:4px;background-color:var(--white)}.swimmer-filters .filter-group select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1a365d1a}.filter-actions{display:flex;align-items:center;justify-content:center}.swimmer-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem}.swimmer-card{background:linear-gradient(135deg,#fff,#f8fafc);padding:1.5rem;border-radius:16px;border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;position:relative;overflow:hidden;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-left:4px solid transparent}.swimmer-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#3b82f6);opacity:0}.swimmer-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;border-color:#3b82f6;background:linear-gradient(135deg,#fff,#f1f5f9)}.swimmer-card:hover:before{opacity:1}.swimmer-card:active{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.swimmer-card:focus-within{outline:2px solid #3b82f6;outline-offset:2px}.swimmer-level-inline{position:relative;overflow:hidden}.swimmer-level-inline:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.4),transparent)}.swimmer-level-inline:hover:before{left:100%}.swimmer-name-level{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1rem}.swimmer-level-group{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap;margin-top:.5rem}.swimmer-info h3{color:#1e293b;margin:0;font-size:1.25rem;font-weight:700;line-height:1.3;letter-spacing:-.025em}.swimmer-details{color:#64748b;margin:0;font-size:.875rem;line-height:1.5;font-weight:500}.swimmer-level-inline{font-weight:600;white-space:nowrap;font-size:.875rem;padding:.25rem .5rem;border-radius:6px;background:#3b82f61a;border:1px solid rgba(59,130,246,.2)}.swimmer-group{font-weight:600;white-space:nowrap;font-size:.875rem;padding:.25rem .5rem;border-radius:6px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);color:#059669}.swimmer-actions{display:flex;flex-wrap:wrap;gap:.5rem;justify-content:flex-start;margin-top:1rem;padding-top:1rem;border-top:1px solid #e2e8f0}.add-time-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.modal-content{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);padding:2.5rem;border-radius:20px;box-shadow:0 20px 60px #00000026;max-width:500px;width:100%;max-height:90vh;overflow-y:auto;border:1px solid rgba(26,54,93,.1);position:relative;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:auto;transform:none;top:auto;left:auto;right:auto;bottom:auto}.modal-content:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%);border-radius:20px 20px 0 0}.modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border)}.modal-header h2{margin:0;color:var(--navy);font-size:1.25rem;font-weight:600}.close-btn{background:none;border:none;font-size:1.5rem;cursor:pointer;color:var(--text-muted);width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px}.close-btn:hover{background-color:var(--gray-100);color:var(--text-primary)}.add-time-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.help-text{display:block;margin-top:.25rem;color:var(--text-muted);font-size:.8rem}.leaderboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.leaderboard h2{margin:0;color:var(--navy);font-size:1.5rem;font-weight:600}.leaderboard-filters{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);margin-bottom:2rem;border-radius:12px;box-shadow:0 4px 20px #00000014;overflow:hidden;position:relative}.leaderboard-filters:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%);opacity:0}.leaderboard-filters.expanded{padding:1.5rem}.leaderboard-filters.expanded:before{opacity:1}.leaderboard-filters.collapsed{max-height:0;padding:0;margin-bottom:0;border:none;box-shadow:none}.leaderboard-filters .filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:end}.filter-group label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary);font-size:.9rem}.filter-group select{width:100%;padding:.75rem;font-size:.9rem;border:1px solid var(--border);border-radius:4px;background-color:var(--white)}.filter-group select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1a365d1a}.leaderboard-table-container{background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);padding:var(--space-10);border-radius:var(--radius-2xl);border:1px solid var(--border-light);margin-bottom:var(--space-8);box-shadow:var(--shadow-lg);position:relative;overflow:hidden;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.leaderboard-table-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%)}.leaderboard-table-container h3{margin-bottom:1.5rem;color:var(--navy);font-size:1.25rem;font-weight:600}.leaderboard-table{width:100%;border-collapse:collapse}.leaderboard-table thead{background:linear-gradient(135deg,var(--navy) 0%,var(--navy-dark) 100%);border-bottom:none;border-radius:var(--radius-md) var(--radius-md) 0 0}.leaderboard-table th,.leaderboard-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.leaderboard-table th{font-weight:700;color:var(--white);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.leaderboard-table tbody tr:hover{background:linear-gradient(135deg,var(--navy-50) 0%,var(--navy-100) 100%);box-shadow:var(--shadow-sm);border-radius:var(--radius)}.rank-cell{font-weight:700;font-size:1rem;color:var(--navy)}.name-cell{font-weight:600;color:var(--navy)}.name-cell.clickable{cursor:pointer;text-decoration:underline;text-decoration-color:transparent}.name-cell.clickable:hover{color:var(--accent);text-decoration-color:var(--accent)}.time-cell{font-family:Cairo,SF Mono,Monaco,Inconsolata,Roboto Mono,monospace;font-weight:600;font-size:1rem;color:var(--text-primary)}.date-cell{color:var(--text-secondary);font-size:.9rem;white-space:nowrap}.points-cell{font-weight:600;color:var(--navy)}.rank-1{background-color:#fef3c7;border-left:3px solid #f59e0b}.rank-2{background-color:#f3f4f6;border-left:3px solid #6b7280}.rank-3{background-color:#fde2e7;border-left:3px solid #ec4899}.leaderboard-stats{background-color:var(--white);padding:1.5rem;border-radius:8px;border:1px solid var(--border);display:flex;justify-content:space-around;flex-wrap:wrap;gap:1rem;box-shadow:var(--shadow)}.leaderboard-stats p{margin:0;font-weight:500;color:var(--text-primary)}.leaderboard-stats strong{color:var(--navy)}.empty-state{background-color:var(--white);padding:3rem 2rem;border-radius:8px;border:1px solid var(--border);text-align:center;color:var(--text-muted);box-shadow:var(--shadow)}.empty-state-note{margin-top:.5rem;font-size:.9rem;color:var(--text-secondary)}.best-times-ranking{width:100%;max-width:1200px;margin:0 auto}.best-times-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.best-times-header h2{margin:0;color:var(--navy);font-size:1.5rem;font-weight:600}.subtitle-text{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.best-times-filters{margin-bottom:2rem;background-color:var(--white);border-radius:var(--radius-lg);border:1px solid var(--border-light);box-shadow:var(--shadow);overflow:hidden}.best-times-filters.collapsed{max-height:0;margin-bottom:0;border:none;box-shadow:none}.best-times-filters.expanded{max-height:500px}.best-times-filters .filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4);padding:var(--space-6)}.best-times-filters .filter-group input{width:100%;padding:.5rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem}.best-times-filters .filter-group input:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #0033661a}.best-times-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:2rem}.best-times-stats .stat-card{background-color:var(--white);padding:1.5rem;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow);text-align:center}.best-times-stats .stat-number{font-size:2rem;font-weight:700;color:var(--navy);margin-bottom:.5rem}.best-times-stats .stat-label{font-size:.9rem;color:var(--text-secondary);font-weight:500}.best-times-table-container{overflow-x:auto;background-color:var(--white);border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow);margin-bottom:2rem}.best-times-table{width:100%;border-collapse:collapse}.best-times-table thead{background-color:var(--navy);color:var(--white)}.best-times-table th{padding:1rem;text-align:left;font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.best-times-table td{padding:1rem;border-bottom:1px solid var(--border)}.best-times-table tbody tr:hover{background-color:var(--gray-50)}.best-times-summary{text-align:center;color:var(--text-secondary);font-size:.95rem}.rankings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.rankings-header h2{margin:0;color:var(--navy);font-size:1.5rem;font-weight:600;flex:1}.rankings-header .filter-group{display:flex;align-items:center;gap:.5rem}.rankings-header .filter-group label{font-weight:500;color:var(--text-primary);white-space:nowrap}.rankings-header .filter-group select{padding:.5rem 1rem;border:1px solid var(--border);border-radius:6px;font-size:.95rem;background-color:var(--white);cursor:pointer}.rankings-filters{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);margin-bottom:2rem;border-radius:12px;box-shadow:0 4px 20px #00000014;overflow:hidden;position:relative}.rankings-filters:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%);opacity:0}.rankings-filters.expanded{padding:1.5rem}.rankings-filters.expanded:before{opacity:1}.rankings-filters.collapsed{max-height:0;padding:0;margin-bottom:0;border:none;box-shadow:none}.rankings-filters .filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:1rem;align-items:end}.overall-rankings h2{margin-bottom:1.5rem;color:var(--navy);font-size:1.5rem;font-weight:600}.rankings-summary{margin-bottom:2rem}.summary-card{background-color:var(--white);padding:1.5rem;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow)}.summary-card h3{margin-bottom:1rem;color:var(--navy);font-size:1.1rem;font-weight:600}.summary-card p{margin:.5rem 0;color:var(--text-primary)}.rankings-table-container{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);padding:2.5rem;border-radius:16px;border:1px solid rgba(26,54,93,.1);margin-bottom:2rem;box-shadow:0 8px 32px #00000014;position:relative;overflow:hidden}.rankings-table-container:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%)}.rankings-table-container h3{margin-bottom:1.5rem;color:var(--navy);font-size:1.25rem;font-weight:600}.rankings-table{width:100%;border-collapse:collapse}.rankings-table thead{background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);border-bottom:none}.rankings-table th,.rankings-table td{padding:1rem;text-align:left;border-bottom:1px solid var(--border)}.rankings-table th{font-weight:700;color:var(--white);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;text-shadow:0 1px 2px rgba(0,0,0,.3)}.rankings-table tbody tr:hover{background:linear-gradient(135deg,#1a365d0d,#1e3a8a0d);box-shadow:0 4px 12px #1a365d1a}.best-event-cell{font-size:.9rem;color:var(--text-secondary)}.rankings-stats{background-color:var(--white);padding:1.5rem;border-radius:8px;border:1px solid var(--border);margin-bottom:2rem;box-shadow:var(--shadow)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1rem}.stat-item{padding:1rem;background-color:var(--gray-50);border-radius:6px;text-align:center}.stat-item strong{color:var(--navy);display:block;margin-bottom:.25rem}.detailed-breakdown{background-color:var(--white);padding:2rem;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow)}.detailed-breakdown h3{margin-bottom:1.5rem;color:var(--navy);font-size:1.25rem;font-weight:600}.swimmer-details{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem}.swimmer-detail-card{padding:1.5rem;border:1px solid var(--border);border-radius:8px;background-color:var(--gray-50)}.swimmer-detail-card:hover{border-color:var(--navy);box-shadow:var(--shadow)}.swimmer-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.5rem;border-bottom:1px solid var(--border)}.swimmer-rank{background-color:transparent;color:var(--navy);padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600}.swimmer-header h4{margin:0;color:var(--navy);font-size:1.1rem;font-weight:600}.swimmer-header h4.clickable{cursor:pointer;text-decoration:underline;text-decoration-color:transparent}.swimmer-header h4.clickable:hover{color:var(--accent);text-decoration-color:var(--accent)}.total-points{background-color:var(--navy);color:var(--white);padding:.25rem .5rem;border-radius:4px;font-size:.9rem;font-weight:600}.swimmer-events p{margin:.5rem 0;font-size:.9rem;color:var(--text-primary)}.swimmer-events strong{color:var(--navy)}.swimmer-profile-modal{position:fixed;top:0;left:0;right:0;bottom:0;width:100vw;height:100vh;background:linear-gradient(135deg,#0f172acc,#1e293be6);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);display:flex;justify-content:center;align-items:center;z-index:10000;padding:1rem;box-sizing:border-box;overflow:hidden}.modal-content.large{max-width:min(1200px,95vw);width:95vw;max-height:95vh;overflow-y:auto;background:linear-gradient(180deg,#fff,#f8fafc);border-radius:24px;box-shadow:0 25px 50px -12px #00000040,0 0 0 1px #ffffff1a;border:1px solid rgba(255,255,255,.2);position:relative;z-index:10001;display:block;visibility:visible;opacity:1}.swimmer-profile-content{padding:0;max-width:100%;margin:0;background:transparent;display:flex;flex-direction:column;gap:0;align-items:stretch}.profile-header{background:linear-gradient(135deg,#fff,#f8fafc);border-bottom:1px solid #e2e8f0;padding:2rem;position:relative}.profile-header:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#3b82f6)}.header-main{display:flex;align-items:center;gap:2rem;max-width:1200px;margin:0 auto}.swimmer-avatar{position:relative;flex-shrink:0}.avatar-circle{width:80px;height:80px;border-radius:50%;background:linear-gradient(135deg,#3b82f6,#1d4ed8);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #3b82f64d;position:relative;overflow:hidden}.avatar-circle:before{content:"";position:absolute;top:-2px;left:-2px;right:-2px;bottom:-2px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;z-index:-1}.avatar-initial{font-size:2rem;font-weight:800;color:#fff;text-shadow:0 2px 4px rgba(0,0,0,.1)}.avatar-badge{position:absolute;bottom:-8px;right:-8px;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:700;color:#fff;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 2px 8px #00000026;border:2px solid white}.swimmer-info{flex:1;min-width:0}.swimmer-name{font-size:2.5rem;font-weight:800;color:#1e293b;margin:0 0 1rem;line-height:1.2;letter-spacing:-.025em}.meta-item{display:flex;align-items:center;gap:.5rem;background:#f1f5f9;padding:.5rem 1rem;border-radius:20px;font-size:.875rem;font-weight:600;color:#64748b;border:1px solid #e2e8f0;line-height:1;min-height:2.5rem}.meta-icon{font-size:1rem;line-height:1;display:inline-flex;align-items:center;justify-content:center;width:1.4rem;height:1.4rem;flex-shrink:0;text-align:center;vertical-align:middle;position:relative;top:-.08em}.meta-icon.age-icon{top:-.05em}.meta-icon.gender-male,.meta-icon.gender-female{top:-.05em;font-size:1.1rem}.meta-icon.swimming-icon{top:-.05em}.swimmer-rank{flex-shrink:0}.rank-badge{background:transparent;color:#1e293b;padding:.5rem 1rem;border-radius:20px;text-align:center;border:1px solid #e2e8f0;position:relative;min-width:120px;font-size:.875rem;font-weight:600}.rank-badge:hover{background:#3b82f60d;border-color:#3b82f6}.rank-number{display:block;font-size:1.25rem;font-weight:700;line-height:1.3;margin-bottom:.25rem;color:#1e293b;letter-spacing:-.025em}.rank-label{font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:#64748b;margin-top:.125rem}.level-section{background:#f8fafc;padding:2rem;border-bottom:1px solid #e2e8f0}.level-section .level-progress{max-width:1200px;margin:0 auto;background:#fff;border-radius:16px;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0}.metrics-dashboard{background:#fff;padding:2rem}.metrics-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:1.5rem;max-width:1200px;margin:0 auto}.metric-card{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000001a;border:1px solid #e2e8f0;position:relative;overflow:hidden;cursor:pointer;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}.metric-card:focus{outline:2px solid #3b82f6;outline-offset:2px}.metric-card:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.metric-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:0}.metric-card:hover{box-shadow:0 8px 25px #00000026}.metric-card:hover:before{opacity:1}.metric-card.primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;border:1px solid rgba(59,130,246,.2)}.metric-card.primary:before{background:linear-gradient(90deg,#fff,#e2e8f0);opacity:1}.metric-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem}.metric-icon{font-size:1.5rem;width:40px;height:40px;display:flex;align-items:center;justify-content:center;background:#3b82f61a;border-radius:10px;border:1px solid rgba(59,130,246,.2)}.metric-card.primary .metric-icon{background:#fff3;border:1px solid rgba(255,255,255,.3)}.metric-title{font-size:.875rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.metric-card.primary .metric-title{color:#ffffffe6}.metric-value{font-size:2rem;font-weight:800;color:#1e293b;margin-bottom:.5rem;line-height:1.2}.metric-card.primary .metric-value{color:#fff}.metric-subtitle{font-size:.875rem;color:#64748b;font-weight:500;margin-bottom:.5rem}.metric-card.primary .metric-subtitle{color:#fffc}.metric-detail{font-size:.75rem;color:#94a3b8;font-weight:500}.metric-card.primary .metric-detail{color:#ffffffb3}.metric-breakdown{display:flex;flex-direction:column;gap:.25rem;margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.metric-card.primary .metric-breakdown{border-top:1px solid rgba(255,255,255,.2)}.breakdown-item{font-size:.75rem;color:#64748b;font-weight:500}.metric-card.primary .breakdown-item{color:#fffc}.swimmer-info-section{width:100%;background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(255,255,255,.2);position:relative;overflow:hidden;align-self:stretch}.swimmer-info-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#10b981,#059669,#10b981)}.swimmer-basic-info{text-align:center;margin-bottom:2rem;max-width:100%;padding:0}.swimmer-basic-info h3{color:#1e293b;font-size:2rem;margin-bottom:.75rem;font-weight:700;letter-spacing:-.025em;line-height:1.2}.swimmer-basic-info p{color:#64748b;font-size:1.125rem;font-weight:500;line-height:1.5;margin:0}.performance-dashboard{background:#f8fafc;padding:2rem;margin:0}.dashboard-section{max-width:1200px;margin:0 auto}.dashboard-title{font-size:1.5rem;font-weight:700;color:#1e293b;margin-bottom:2rem;text-align:center;position:relative}.dashboard-title:after{content:"";position:absolute;bottom:-8px;left:50%;width:60px;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);border-radius:2px}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem;max-width:1000px;margin:0 auto}.dashboard-card{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(255,255,255,.2);display:flex;align-items:center;gap:1.5rem;position:relative;overflow:hidden}.dashboard-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:0}.dashboard-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.dashboard-card:hover:before{opacity:1}.dashboard-card-icon{font-size:2.5rem;flex-shrink:0;width:60px;height:60px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:16px;border:1px solid rgba(59,130,246,.2)}.dashboard-card-content{flex:1}.dashboard-card-number{font-size:1.75rem;font-weight:800;color:#1e293b;margin-bottom:.25rem;line-height:1.2}.dashboard-card-label{font-size:.875rem;color:#64748b;font-weight:600;text-transform:uppercase;letter-spacing:.05em}.times-section,.bonus-section{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:20px;padding:2rem;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(255,255,255,.2);position:relative;overflow:hidden;display:flex;flex-direction:column;height:100%;min-height:400px;width:100%;max-width:100%;margin:0 auto}.times-section:hover,.bonus-section:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.times-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#f59e0b,#d97706,#f59e0b)}.bonus-section:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#7c3aed,#8b5cf6)}.swimmer-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;max-width:100%;margin:0 auto}.times-section .swimmer-stats-grid,.bonus-section .swimmer-stats-grid{grid-template-columns:1fr;gap:1rem;flex:1;align-content:start}.stat-card{background:linear-gradient(135deg,#fff,#f8fafc);padding:2rem 1.5rem;border-radius:16px;text-align:center;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:0}.stat-card:hover{box-shadow:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d}.stat-number{font-size:2rem;font-weight:800;color:#1e293b;margin-bottom:.5rem;line-height:1.2;letter-spacing:-.025em}.stat-label{font-size:.875rem;color:#64748b;font-weight:600;line-height:1.4;text-transform:uppercase;letter-spacing:.05em}.performance-highlights{margin-bottom:2rem}.performance-highlights h3{margin-bottom:1rem;color:var(--navy);font-size:1.25rem;font-weight:600}.highlights-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.highlight-card{background-color:var(--white);padding:1.5rem;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow)}.highlight-card strong{display:block;color:var(--navy);margin-bottom:.5rem;font-size:.9rem}.time-highlight{font-family:Cairo,monospace;font-size:1.2rem;font-weight:700;color:var(--navy);display:block}.event-highlight{font-size:.9rem;color:var(--text-secondary);display:block;margin-top:.25rem}.points-highlight{font-size:1.2rem;font-weight:700;color:var(--navy)}.improvement-highlight{font-size:1.2rem;font-weight:700}.improvement-highlight.positive{color:#059669}.improvement-highlight.neutral{color:var(--text-secondary)}.personal-bests-section{margin-bottom:2rem;margin-left:0;margin-right:0;width:100%}.swimmer-profile-content{width:100%;max-width:100%;overflow-x:hidden}.swimmer-profile-content>div{margin-left:0;margin-right:0;width:100%}.personal-bests-section h3{margin-bottom:1rem;color:var(--navy);font-size:1.25rem;font-weight:600}.personal-bests-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.personal-best-card{background-color:var(--white);padding:1rem;border-radius:8px;border:1px solid var(--border);box-shadow:var(--shadow);text-align:center}.best-event{font-size:.9rem;color:var(--text-secondary);margin-bottom:.5rem}.best-time{font-family:Cairo,monospace;font-size:1.1rem;font-weight:700;color:var(--navy);margin-bottom:.25rem}.best-points{font-size:.9rem;color:var(--navy);font-weight:600}.all-times-section h3{margin-bottom:1rem;color:var(--navy);font-size:1.25rem;font-weight:600}.times-header{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.times-filters{max-height:0;overflow:hidden;background:var(--white);border-radius:8px;margin-bottom:16px;box-shadow:0 2px 8px #0000001a}.times-filters.expanded{max-height:300px}.times-filters .filter-content{padding:16px;display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.times-filters .filter-group{display:flex;flex-direction:column;gap:.25rem}.times-filters label{font-size:.8rem;font-weight:600;color:var(--text-primary)}.times-filters select{padding:.5rem;font-size:.85rem;border:1px solid var(--border);border-radius:4px;background-color:var(--white)}.times-table-container{background:linear-gradient(135deg,#fff,#f8fafc);border-radius:16px;border:1px solid rgba(255,255,255,.2);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;overflow:hidden;max-height:500px;overflow-x:auto;overflow-y:auto;width:100%}.times-table{width:100%;min-width:600px;border-collapse:separate;border-spacing:0;table-layout:auto}.times-table thead{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-bottom:2px solid #3b82f6}.times-table th,.times-table td{padding:1.25rem 1rem;text-align:left;border-bottom:1px solid #f1f5f9}.times-table .time-cell,.times-table .points-cell,.times-table .date-cell,.attendance-table .date-cell,.attendance-table .points-cell{text-align:right}.times-table th{font-weight:700;color:#1e293b;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em}.times-table tbody tr:hover{background:linear-gradient(135deg,#f8fafc,#f1f5f9)}.times-table tbody tr:last-child td{border-bottom:none}.times-table td{color:#374151;font-weight:500}.bulk-add-times-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#1a365d80;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.bulk-add-content{padding:1rem 0}.bulk-add-instructions{margin-bottom:1.5rem;padding:1rem;background-color:var(--gray-50);border-radius:6px}.bulk-add-instructions h3{margin-top:0;margin-bottom:.5rem;color:var(--navy)}.bulk-add-instructions p{margin-bottom:.5rem}.bulk-add-instructions ul{margin:.5rem 0 0 1.5rem;padding:0}.bulk-add-instructions li{margin:.25rem 0}.bulk-add-form{width:100%}.bulk-add-form .form-group{margin-bottom:1.5rem}.bulk-add-form label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.bulk-add-form textarea{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:.9rem;font-family:Courier New,monospace;resize:vertical}.bulk-add-form textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #0033661a}.json-example{padding:1rem;background-color:var(--gray-100);border-radius:6px;font-size:.85rem;overflow-x:auto;margin:0}.preview-section{margin-top:1.5rem;padding:1rem;background-color:var(--gray-50);border-radius:6px}.preview-section h3{margin-top:0;margin-bottom:1rem;color:var(--navy)}.preview-table-container{overflow-x:auto}.preview-table{width:100%;border-collapse:collapse;font-size:.9rem}.preview-table th,.preview-table td{padding:.5rem;text-align:left;border-bottom:1px solid var(--border)}.preview-table th{background-color:var(--white);font-weight:600;color:var(--navy)}.preview-table tbody tr:hover{background-color:var(--white)}.recalculate-gender-modal,.edit-swimmer-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#1a365d80;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.edit-swimmer-form{width:100%}.edit-swimmer-form .form-group{margin-bottom:1.5rem}.edit-swimmer-form label{display:block;margin-bottom:.5rem;font-weight:500;color:var(--text-primary)}.edit-swimmer-form input,.edit-swimmer-form select{width:100%;padding:.75rem;border:1px solid var(--border);border-radius:6px;font-size:1rem;font-family:inherit}.edit-swimmer-form input:focus,.edit-swimmer-form select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #0033661a}.edit-swimmer-form .form-actions{display:flex;gap:1rem;margin-top:2rem}.edit-swimmer-form .form-actions button{flex:1}.login-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#1a365d80;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.login-content{padding:1rem 0}.login-info{margin-bottom:1.5rem;padding:1rem;background-color:var(--gray-50);border-radius:6px;border:1px solid var(--border)}.login-info p{margin-bottom:.5rem;color:var(--text-primary);font-weight:500}.login-info ul{margin:.5rem 0;padding-left:1.5rem}.login-info li{margin:.25rem 0;color:var(--text-secondary);font-size:.9rem}.login-form{margin-bottom:1.5rem}.error-message{background-color:#fef2f2;color:var(--danger-color);padding:.75rem;border-radius:6px;border:1px solid #fecaca;margin:1rem 0;font-size:.9rem;font-weight:500}.viewer-info{padding:1rem;background-color:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;text-align:center}.viewer-info p{margin:0;color:var(--text-primary);font-size:.9rem}.viewer-info strong{color:var(--navy)}.recalculate-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#1a365d80;display:flex;justify-content:center;align-items:center;z-index:1000;padding:1rem}.recalculate-content{padding:1rem 0}.recalculate-info{margin-bottom:2rem}.recalculate-info h3{color:var(--navy);margin-bottom:1rem;font-size:1.1rem;font-weight:600}.recalculate-info ul{margin:1rem 0;padding-left:1.5rem}.recalculate-info li{margin:.5rem 0;color:var(--text-primary)}.warning-box{background-color:#fef3c7;border:1px solid #f59e0b;border-radius:6px;padding:1rem;margin-top:1rem;color:var(--text-primary)}.warning-box strong{color:#92400e}.recalculate-actions{display:flex;gap:1rem;justify-content:center}.recalculate-results{text-align:center}.success-results h3{color:#059669;margin-bottom:1.5rem;font-size:1.3rem}.error-results h3{color:var(--danger-color);margin-bottom:1rem;font-size:1.3rem}.results-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin:1.5rem 0}.result-stat{background-color:var(--gray-50);padding:1rem;border-radius:6px;border:1px solid var(--border)}.result-stat strong{color:var(--navy);display:block;margin-bottom:.25rem}.errors-list{text-align:left;margin:1.5rem 0;padding:1rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:6px}.errors-list h4{color:var(--danger-color);margin-bottom:.5rem}.errors-list ul{margin:.5rem 0;padding-left:1.5rem}.errors-list li{margin:.25rem 0;font-size:.9rem;color:var(--text-primary)}.error-details{font-size:.9rem;color:var(--danger-color);margin-top:.5rem;font-style:italic}.results-actions{margin-top:2rem}.time-entry{display:flex;justify-content:space-between;align-items:center;padding:1rem;background-color:var(--white);border:1px solid var(--border);border-radius:8px;margin-bottom:.5rem;box-shadow:var(--shadow)}.time-entry:hover{border-color:var(--navy);box-shadow:var(--shadow-lg)}.time-entry-info{flex:1}.swimmer-name{font-weight:600;color:var(--navy);margin-bottom:.25rem}.time-details{display:flex;gap:1rem;margin-bottom:.25rem;font-size:.9rem;color:var(--text-secondary)}.time-results{display:flex;gap:1rem;align-items:center}.time-results .time{font-family:Cairo,monospace;font-weight:700;font-size:1.1rem;color:var(--navy)}.time-results .points{font-weight:600;color:var(--navy);font-size:.9rem}.time-entry-actions{display:flex;align-items:center}.delete-confirm{display:flex;gap:.5rem}.danger-zone{margin-top:3rem;padding:2rem;background-color:#fef2f2;border:1px solid #fecaca;border-radius:8px;text-align:center;display:flex;flex-direction:column;gap:1rem}.app-footer{background-color:var(--white);color:var(--text-secondary);padding:2rem;text-align:center;border-top:1px solid var(--border);margin-top:auto}.app-footer p{margin:.5rem 0;font-size:.9rem}.footer-note{font-size:.8rem;font-style:italic;color:var(--text-muted)}@supports (-webkit-touch-callout: none){.app-nav{position:fixed!important;top:0!important;left:0!important;right:0!important;z-index:100!important;-webkit-transform:translate3d(0,0,0)!important;transform:translateZ(0)!important;-webkit-overflow-scrolling:touch;backface-visibility:hidden;perspective:1000px;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 12px #00000026,0 1px 4px #0000001a}body{-webkit-text-size-adjust:100%;height:100vh;height:-webkit-fill-available;-webkit-overflow-scrolling:touch;position:relative;overflow-x:hidden}.app{min-height:100vh;min-height:-webkit-fill-available;position:relative;z-index:1}.app-nav{-webkit-transform:translate3d(0,0,0);transform:translateZ(0);-webkit-overflow-scrolling:touch;position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:100!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 12px #00000026,0 1px 4px #0000001a}}@media (max-width: 768px){.app-nav{position:fixed!important;top:0!important;left:0!important;right:0!important;z-index:100!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 8px #0000001a,0 1px 3px #00000014;transform:translateZ(0);will-change:transform;isolation:isolate}body,html{overflow-x:hidden;max-width:100vw;position:relative}.app-main{padding-top:80px!important}.app-content{overflow-x:hidden;max-width:100vw;position:relative}*{max-width:100%;box-sizing:border-box}.app-header,.nav-tabs,.swimmer-list,.leaderboard-container,.overall-rankings,.best-times-ranking{max-width:100vw;overflow-x:hidden}html{-webkit-tap-highlight-color:rgba(26,54,93,.1);touch-action:manipulation;-webkit-overflow-scrolling:touch}.swimmer-card,.metric-card,.dashboard-card,.stat-card{transform:none!important;position:relative;max-width:100%}.modal-overlay,.swimmer-profile-modal,.add-time-modal,.bulk-add-times-modal,.recalculate-gender-modal,.edit-swimmer-modal,.login-modal,.recalculate-modal{left:0;right:0;width:100vw;max-width:100vw}body{font-size:16px;padding-bottom:env(safe-area-inset-bottom)}.app{padding-bottom:0}.app-header{padding:1rem 1rem .5rem;position:relative}.logo{height:35px}.subtitle{font-size:.85rem;margin-bottom:0}.app-footer{padding:1.5rem 1rem;padding-bottom:calc(1.5rem + env(safe-area-inset-bottom))}.footer-actions{display:flex;justify-content:center;gap:.75rem;margin-top:1rem}.footer-actions .refresh-btn,.footer-actions .admin-login-btn{padding:.75rem 1.5rem;font-size:.95rem;min-height:48px;flex:1;max-width:200px}.app-nav{position:sticky;top:0;left:0;right:0;z-index:100;background-color:var(--white);border-bottom:1px solid var(--border);padding:.5rem 0;display:grid;grid-template-columns:repeat(4,1fr);gap:0;box-shadow:0 2px 10px #0000000d}.nav-btn{padding:.5rem .25rem;font-size:.7rem;border-radius:8px;margin:0 .25rem;min-height:52px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.25rem;white-space:normal;word-wrap:break-word;overflow-wrap:break-word;-webkit-hyphens:auto;hyphens:auto;line-height:1.2;text-align:center;max-width:100%}.nav-btn.active{background-color:var(--navy);color:var(--white);font-weight:600}.nav-text-full{display:none}.nav-text-mobile{display:inline}.app-main{padding:1rem;overflow-x:hidden}.admin-bar{margin-bottom:.5rem}.btn{min-height:44px;padding:.75rem 1rem;font-size:1rem;border-radius:8px;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.btn-small{min-height:44px;padding:.5rem .75rem;font-size:.9rem}input,select,textarea{font-size:16px!important;min-height:48px;padding:.75rem;border-radius:8px;-webkit-appearance:none;-moz-appearance:none;appearance:none}select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%231a365d' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px;padding-right:2.5rem}.modal-overlay{padding:.5rem!important}.modal-content{max-width:calc(100vw - 1rem)!important;width:calc(100vw - 1rem)!important;max-height:calc(100vh - 1rem)!important;margin:0!important;padding:1.5rem!important;border-radius:12px!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;transform:none!important;overflow-y:auto;-webkit-overflow-scrolling:touch;background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%)}.modal-content.large{max-width:calc(100vw - 1rem)!important;width:calc(100vw - 1rem)!important;margin:0!important;border-radius:12px!important;max-height:calc(100vh - 1rem)!important;position:relative!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important;transform:none!important}.modal-header{position:sticky;top:0;background:linear-gradient(180deg,#fff,#f8fafc);z-index:10;padding:1rem 1.25rem;border-bottom:1px solid #e2e8f0;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);box-shadow:0 1px 3px #0000001a;display:flex;justify-content:space-between;align-items:center}.modal-header h2{font-size:1.25rem;margin:0}.close-btn{min-width:44px;min-height:44px;font-size:1.75rem;padding:.5rem}.app-header h1{font-size:1.75rem}.subtitle{font-size:.9rem}.header-actions{position:static;margin-top:1rem;justify-content:center}.admin-bar{flex-direction:column;gap:.5rem;text-align:center}.admin-info{flex-direction:column;gap:.5rem}.app-main{padding:1rem}.swimmer-grid,.leaderboard-filters{grid-template-columns:1fr}.best-times-filters{margin:0 -var(--space-3) var(--space-6) -var(--space-3);border-radius:0}.best-times-filters .filter-content{grid-template-columns:1fr;gap:var(--space-3);padding:var(--space-4)}.best-times-header{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.best-times-header h2{font-size:var(--font-size-xl)}.best-times-stats{grid-template-columns:1fr}.best-times-table,.best-times-table th,.best-times-table td{font-size:.85rem;padding:.5rem}.rankings-header{flex-direction:column;align-items:flex-start}.rankings-header h2{font-size:1.25rem}.rankings-header .filter-group{width:100%}.rankings-header .filter-group select{flex:1}.add-time-form .form-row{grid-template-columns:1fr}.leaderboard-table,.rankings-table,.best-times-table{display:block;overflow-x:visible}.leaderboard-table thead,.rankings-table thead,.best-times-table thead{display:none}.leaderboard-table tbody,.rankings-table tbody,.best-times-table tbody{display:block}.leaderboard-table tr,.rankings-table tr,.best-times-table tr{display:block;margin-bottom:1rem;background-color:var(--white);border:1px solid var(--border);border-radius:8px;padding:1rem;box-shadow:0 2px 4px #0000000d}.leaderboard-table tr:hover,.rankings-table tr:hover,.best-times-table tr:hover{background-color:var(--gray-50);box-shadow:0 4px 8px #0000001a}.leaderboard-table td,.rankings-table td,.best-times-table td{display:grid;grid-template-columns:120px 1fr;gap:.5rem;padding:.75rem 0;text-align:left;border-bottom:1px solid var(--gray-50);align-items:center}.leaderboard-table td:last-child,.rankings-table td:last-child,.best-times-table td:last-child{border-bottom:none}.leaderboard-table td:before,.rankings-table td:before,.best-times-table td:before{content:attr(data-label);font-weight:600;color:var(--navy);text-transform:uppercase;font-size:.75rem;letter-spacing:.5px}.leaderboard-table .rank-cell,.rankings-table .rank-cell,.best-times-table .rank-cell{font-size:1.5rem;color:var(--navy);justify-self:end}.leaderboard-table .name-cell,.rankings-table .name-cell{font-size:1.1rem;font-weight:700;color:var(--navy);justify-self:start}.leaderboard-table .time-cell,.best-times-table .time-cell{font-size:1.2rem;font-weight:700;justify-self:end}.leaderboard-table .points-cell,.rankings-table .points-cell,.best-times-table .points-cell{font-size:1.1rem;font-weight:700;color:var(--accent);justify-self:end}.leaderboard-table .rank-1 .rank-cell,.rankings-table .rank-1 .rank-cell,.best-times-table .rank-1 .rank-cell{color:gold}.leaderboard-table .rank-2 .rank-cell,.rankings-table .rank-2 .rank-cell,.best-times-table .rank-2 .rank-cell{color:silver}.leaderboard-table .rank-3 .rank-cell,.rankings-table .rank-3 .rank-cell,.best-times-table .rank-3 .rank-cell{color:#cd7f32}.nav-btn{padding:.75rem 1rem}.leaderboard-stats{flex-direction:column;text-align:center}.stats-grid,.detailed-breakdown .swimmer-details{grid-template-columns:1fr}.swimmer-filters{grid-template-columns:1fr;gap:1rem}.filter-actions{justify-content:stretch}.filter-actions .btn{width:100%}.swimmer-header{flex-direction:column;gap:.5rem;text-align:center}}@media (max-width: 480px){.app-nav{position:fixed!important;top:0!important;left:0!important;right:0!important;z-index:100!important;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);box-shadow:0 3px 16px #0003,0 1px 6px #00000026;transform:translateZ(0);will-change:transform;isolation:isolate}.app-header h1{font-size:1.5rem}.modal-content{padding:1.5rem}.swimmer-actions,.form-actions{flex-direction:column}.swimmer-profile-content{padding:0;gap:0}.profile-header{padding:1.5rem}.header-main{flex-direction:column;gap:1.5rem;align-items:center;text-align:center;width:100%;max-width:100%;overflow-x:hidden}.swimmer-avatar{order:1}.swimmer-info{order:2;text-align:center}.swimmer-rank{order:3}.swimmer-name{font-size:2rem;margin-bottom:1rem}.swimmer-meta{justify-content:center;gap:.75rem;flex-wrap:wrap;width:100%;max-width:100%;overflow-x:hidden}.meta-item{font-size:.8rem;padding:.4rem .8rem;min-height:2rem}.meta-icon{width:1.2rem;height:1.2rem;font-size:.9rem}.meta-icon.gender-male,.meta-icon.gender-female{font-size:1rem}.avatar-circle{width:70px;height:70px}.avatar-initial{font-size:1.75rem}.rank-badge{padding:.4rem .8rem;min-width:100px;border-radius:16px;font-size:.8rem}.rank-number{font-size:1.125rem;margin-bottom:.125rem}.rank-label{font-size:.7rem;letter-spacing:.05em}.level-section,.metrics-dashboard{padding:1.5rem}.metrics-grid{grid-template-columns:1fr;gap:1rem}.metric-card{padding:1.25rem}.metric-card.primary{order:-1}.metric-header{margin-bottom:.75rem}.metric-icon{width:35px;height:35px;font-size:1.25rem}.metric-value{font-size:1.75rem}.metric-breakdown{margin-top:.75rem;padding-top:.75rem}.two-column-layout{grid-template-columns:1fr;gap:1rem;align-items:stretch}.times-section,.bonus-section{padding:1.5rem;border-radius:16px;min-height:auto;height:auto}.swimmer-stats-grid{grid-template-columns:1fr;gap:1rem;margin:0 -1.5rem 1.5rem;padding:0 1.5rem;max-width:100%}.stat-card{padding:20px;border-radius:16px;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;min-height:90px;display:flex;flex-direction:column;justify-content:center;position:relative;overflow:hidden}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:0}.stat-card:hover:before,.stat-card:focus-within:before{opacity:1}.stat-card:active{box-shadow:0 2px 4px #0000001a}.stat-number{font-size:1.8rem;font-weight:700;color:var(--navy);margin-bottom:4px;line-height:1.2}.stat-label{font-size:.85rem;color:#64748b;font-weight:500;line-height:1.3;text-align:center}.profile-tabs{display:flex;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:16px;padding:6px;margin:0 -1.5rem 1.5rem;box-shadow:0 2px 4px #0000001a;border:1px solid rgba(255,255,255,.2);flex-direction:row;align-items:center;justify-content:center}.tab-btn{flex:1;background:transparent;border:none;padding:12px 8px;cursor:pointer;font-size:13px;color:#64748b;border-radius:12px;font-weight:600;text-align:center;min-height:44px;display:flex;align-items:center;justify-content:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;position:relative}.tab-btn:hover{background:#3b82f61a;color:#3b82f6}.tab-btn.active{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;font-weight:700;box-shadow:0 4px 12px #3b82f666}.swimmer-info-section,.level-progress{margin:0 -1.5rem;border-radius:0;background:linear-gradient(135deg,#fff,#f8fafc);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid rgba(255,255,255,.2)}.level-progress,.swimmer-info-section{margin-bottom:1rem}.swimmer-basic-info:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#1d4ed8,#3b82f6)}.swimmer-basic-info h3{font-size:1.5rem;margin-bottom:12px;color:#1e293b;font-weight:700;line-height:1.3}.swimmer-basic-info p{font-size:.9rem;color:#64748b;line-height:1.5;font-weight:500}.swimmer-group{font-weight:600;padding:4px 8px;border-radius:8px;background:#10b9811a;border:1px solid rgba(16,185,129,.2);color:#059669;font-size:.8rem}.highlights-grid,.personal-bests-grid{grid-template-columns:1fr;gap:12px}.personal-bests-section{margin:0 -1.5rem 1.5rem;padding:0 1.5rem;width:calc(100% + 3rem)}.swimmer-profile-content>div{margin-left:0;margin-right:0;width:100%}.times-table-container{margin:0 -1.25rem;border-radius:0;border-left:none;border-right:none;background:#fff;overflow-x:auto;-webkit-overflow-scrolling:touch;max-width:100vw;box-shadow:0 1px 3px #0000001a;width:calc(100% + 2.5rem);max-width:calc(100vw + 2.5rem);position:relative}.times-table{font-size:14px;border-collapse:separate;border-spacing:0;width:100%;min-width:500px}.times-table th{background:linear-gradient(135deg,#f8fafc,#e2e8f0);font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0}.times-table th,.times-table td{padding:12px 8px;border-bottom:1px solid #f1f5f9}.times-table th:first-child,.times-table td:first-child{padding-left:16px}.times-table th:last-child,.times-table td:last-child{padding-right:16px}.times-table tbody tr:hover{background:#f8fafc}.times-table tbody tr:last-child td{border-bottom:none}.times-filters{margin:0 -1.25rem;border-radius:0;background:linear-gradient(135deg,#f8fafc,#fff);border:1px solid #e2e8f0;max-width:100vw;overflow-x:hidden}.filter-content{padding:16px;display:flex;flex-direction:column;gap:12px;max-width:100%;overflow-x:hidden}.filter-group{margin-bottom:0;width:100%;max-width:100%}.filter-group label{font-size:13px;font-weight:600;color:#1e293b;margin-bottom:6px;display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.filter-group select{width:100%;padding:10px 12px;border:1px solid #e2e8f0;border-radius:8px;font-size:14px;background:#fff;box-shadow:0 1px 2px #0000000d;max-width:100%}.filter-group select:focus{border-color:#3b82f6;outline:none;box-shadow:0 0 0 2px #3b82f61a}.btn{min-height:48px;padding:14px 20px;font-size:14px;font-weight:600;border-radius:12px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 4px 6px -1px #3b82f64d}.btn-primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af);box-shadow:0 6px 12px -1px #3b82f666}.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 4px 6px -1px #ef44444d}.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 6px 12px -1px #ef444466}.btn-danger:active{background:linear-gradient(135deg,#b91c1c,#991b1b)}.swimmer-profile-modal .modal-content{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.level-progress{margin:0 -1.25rem 1.5rem;border-radius:0;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.level-progress-content{padding:20px}.level-info h3{font-size:1.25rem;margin-bottom:8px;color:#1e293b;font-weight:700}.level-description{font-size:.875rem;color:#64748b;line-height:1.5}.level-points{text-align:center;margin-top:16px;padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:12px;border:1px solid #0ea5e9}.points-value{font-size:1.75rem;font-weight:700;color:#0ea5e9;margin-bottom:4px}.points-label{font-size:.8rem;color:#64748b;font-weight:500}.swimmer-basic-info{padding:0;margin:0 0 1.5rem}.swimmer-info-section{margin-bottom:1.5rem}.attendance-section{margin:0 -10px}.attendance-stats{display:grid;grid-template-columns:1fr;gap:12px;margin-bottom:20px}.attendance-stat-card{background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0;border-radius:12px;padding:16px;text-align:center;box-shadow:0 2px 8px #0000001a}.attendance-stat-number{font-size:1.8rem;font-weight:700;color:var(--navy);margin-bottom:4px}.attendance-stat-label{font-size:.85rem;color:#64748b;font-weight:500}.heat-map{margin:0 -10px;border-radius:0}.heat-map-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(40px,1fr));gap:4px;padding:16px}.heat-map-cell{aspect-ratio:1;border-radius:6px;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;min-height:40px}.bonus-points-history{margin:0 -1.5rem;border-radius:0;padding:0 1.5rem}.bonus-summary{background:linear-gradient(135deg,#fef3c7,#fde68a);border:1px solid #f59e0b;border-radius:16px;padding:1.5rem;margin-bottom:1.5rem;box-shadow:0 2px 8px #f59e0b1a;width:100%;max-width:800px;margin-left:auto;margin-right:auto}.bonus-summary h3{font-size:1.25rem;font-weight:700;color:#92400e;margin:0 0 1rem;display:flex;align-items:center;gap:.5rem}.bonus-total,.bonus-count{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid rgba(146,64,14,.1)}.bonus-total:last-child,.bonus-count:last-child{border-bottom:none}.total-label,.count-label{font-size:.9rem;font-weight:600;color:#92400e}.total-value,.count-value{font-size:1.1rem;font-weight:700;color:#d97706}.bonus-timeline{background:#fff;border:1px solid #e2e8f0;border-radius:16px;padding:1.5rem;box-shadow:0 2px 8px #0000000d;width:100%;max-width:800px;margin:0 auto}@media (min-width: 768px){.bonus-summary,.bonus-timeline{max-width:800px}}@media (min-width: 1200px){.bonus-summary,.bonus-timeline{max-width:900px}}@media (min-width: 1400px){.bonus-summary,.bonus-timeline{max-width:1000px}}.bonus-timeline h4{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0 0 1.25rem}.timeline{position:relative;padding-left:2.5rem}.timeline:before{content:"";position:absolute;left:1rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#3b82f6,#1d4ed8);z-index:1}.timeline-item{position:relative;padding:1rem;border-radius:12px;margin-bottom:1rem;background:#f8fafc;border:1px solid #e2e8f0;box-shadow:0 1px 3px #0000000d}.timeline-marker{position:absolute;left:-2rem;top:.5rem;width:2rem;height:2rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 6px #3b82f666;border:2px solid white;z-index:2}.points-badge{font-size:.75rem;font-weight:700;color:#fff;text-align:center;line-height:1;white-space:nowrap;padding:.125rem}.timeline-content{padding-left:0}.bonus-header{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.75rem}.bonus-points{font-size:1.1rem;font-weight:700;color:#f59e0b}.bonus-date{font-size:.8rem;color:#6b7280;font-weight:500}.bonus-reason,.bonus-coach{margin-bottom:.5rem;font-size:.9rem;line-height:1.4;color:#374151}.bonus-reason strong,.bonus-coach strong{color:#1e293b;font-weight:600}.no-bonus-history{text-align:center;padding:2rem 1rem;color:#6b7280}.empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.no-bonus-history p{font-size:1rem;font-weight:600;margin-bottom:.5rem;color:#374151}.no-bonus-history small{font-size:.85rem;color:#6b7280}.level-progress{margin:0 -10px 20px;border-radius:0;background:linear-gradient(135deg,#fff,#f8fafc);border:1px solid #e2e8f0}.level-progress-content{padding:16px}.level-info h3{font-size:1.3rem;margin-bottom:4px}.level-description{font-size:.85rem;color:#64748b}.level-points{text-align:center;margin-top:12px}.points-value{font-size:1.5rem;font-weight:700;color:var(--navy)}.points-label{font-size:.8rem;color:#64748b;margin-top:4px}.times-header{flex-direction:column;align-items:stretch}.times-filters{justify-content:center}.time-entry{flex-direction:column;align-items:stretch;gap:1rem}.time-entry-actions{justify-content:center}.time-details{flex-direction:column;gap:.25rem}.time-results{justify-content:center}}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.loading-spinner{width:40px;height:40px;border:4px solid var(--border);border-top:4px solid var(--navy);border-radius:50%;margin-bottom:1rem}.loading-container p{color:var(--text-secondary);font-size:1rem;margin:0}@media (max-width: 768px){.swimmer-card{padding:1.5rem;border-radius:16px;box-shadow:0 4px 12px #00000014;margin-bottom:1.25rem;display:flex;flex-direction:column;gap:1rem}.swimmer-card:active{box-shadow:0 1px 4px #0000001f}.swimmer-name-level{gap:.75rem;margin-bottom:0;align-items:flex-start;order:1}.swimmer-info h3{font-size:1.25rem;line-height:1.3;margin-bottom:.5rem;font-weight:700}.swimmer-level-group{gap:.75rem;margin-top:.5rem;flex-wrap:wrap;align-items:center;order:2}.swimmer-level-inline,.swimmer-group{font-size:.85rem;padding:.3rem .6rem;border-radius:8px;font-weight:600}.swimmer-actions{flex-direction:column;gap:.75rem;margin-top:0;padding-top:1rem;border-top:1px solid #e2e8f0;order:3}.btn-small{width:100%;padding:.75rem 1rem;font-size:.875rem;font-weight:600;justify-content:center;min-height:2.5rem;border-radius:8px}.stat-card{min-height:100px;padding:1.25rem}.loading-spinner{width:50px;height:50px}.empty-state{padding:3rem 1.5rem}button:focus-visible,input:focus-visible,select:focus-visible{outline:3px solid var(--navy);outline-offset:2px}@media (prefers-reduced-motion: reduce){*{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}}@media (max-width: 480px){.logo{height:30px}.subtitle{font-size:.75rem}.nav-btn{font-size:.65rem;padding:.4rem .15rem;min-height:48px;line-height:1.1}.app-main{padding:.75rem}h2{font-size:1.25rem!important}.modal-header h2{font-size:1.1rem!important}.stat-number{font-size:2rem!important}}@media (max-width: 896px) and (orientation: landscape){.app-header{padding:.5rem 1rem!important}.logo{height:28px!important}.app-nav{padding:.25rem 0!important}.nav-btn{min-height:44px!important;font-size:.7rem!important}}.level-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .875rem;border-radius:9999px;font-size:.875rem;font-weight:600;white-space:nowrap;box-shadow:0 2px 4px #0000001a}.level-badge-small{display:inline-flex;align-items:center;gap:.25rem;padding:.25rem .625rem;border-radius:9999px;font-size:.75rem;font-weight:600;white-space:nowrap;box-shadow:0 1px 2px #0000001a}.level-badge-large{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:9999px;font-size:1rem;font-weight:700;white-space:nowrap;box-shadow:0 4px 6px #00000026}.level-progress-container{background:linear-gradient(135deg,var(--gray-50) 0%,var(--white) 100%);border:2px solid var(--border);border-radius:12px;padding:1.5rem;margin:1.5rem 0;box-shadow:var(--shadow-lg)}.level-progress-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;gap:1rem;flex-wrap:wrap}.level-info{display:flex;align-items:center;gap:1rem}.level-icon{font-size:3rem;line-height:1;filter:drop-shadow(0 2px 4px rgba(0,0,0,.1))}.level-name{font-size:1.75rem;font-weight:700;margin:0;line-height:1.2}.level-description{font-size:.875rem;color:var(--text-secondary);margin:.25rem 0 0}.level-points{display:flex;flex-direction:column;align-items:flex-end;text-align:right}.points-value{font-size:2.5rem;font-weight:700;color:var(--navy);line-height:1}.points-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-top:.25rem}.progress-bar-container{margin-bottom:1rem}.progress-bar-background{background-color:var(--gray-200);border-radius:9999px;height:2rem;overflow:hidden;position:relative;box-shadow:inset 0 2px 4px #0000001a}.progress-bar-fill{height:100%;display:flex;align-items:center;justify-content:flex-end;padding-right:.75rem;border-radius:9999px;min-width:2rem;box-shadow:0 2px 8px #0003;position:relative;overflow:hidden}.progress-bar-fill:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,#fff0,#ffffff4d,#fff0)}.progress-percentage{font-size:.875rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.3);position:relative;z-index:1}.next-level-info{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;font-size:.875rem;flex-wrap:wrap;gap:.5rem}.next-level-text{color:var(--text-primary)}.points-needed{color:var(--text-secondary);font-weight:500}.max-level-text{color:var(--navy);font-weight:700;font-size:1rem;width:100%;text-align:center}.level-range{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:var(--text-secondary);padding-top:1rem;border-top:1px solid var(--border);margin-top:1rem}.level-range-label{font-weight:600;text-transform:uppercase;letter-spacing:.5px}.swimmer-level{margin-top:.5rem}@media (max-width: 768px){.level-progress-header{flex-direction:column;align-items:flex-start}.level-points{align-items:flex-start;text-align:left}.level-icon{font-size:2.5rem}.level-name{font-size:1.5rem}.points-value{font-size:2rem}.progress-bar-background{height:1.75rem}.progress-percentage{font-size:.75rem}.next-level-info{flex-direction:column;align-items:flex-start;gap:.25rem}}.user-management-modal{max-width:95vw;max-height:95vh;width:1200px;position:fixed;top:50%;left:50%;z-index:1001;background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border-radius:20px;box-shadow:0 25px 80px #00000040;border:1px solid rgba(26,54,93,.1);overflow:hidden}.user-management-modal:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy) 0%,#1e3a8a 50%,var(--navy) 100%)}.user-management-modal+*{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.users-table{overflow-x:auto;margin-top:1rem}.users-table table{width:100%;border-collapse:collapse;background:var(--white);border-radius:8px;overflow:hidden;box-shadow:var(--shadow)}.users-table th,.users-table td{padding:.75rem;text-align:left;border-bottom:1px solid var(--border)}.users-table th{background-color:var(--navy);color:var(--white);font-weight:600}.users-table tr:hover{background-color:var(--background)}.role-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:uppercase}.role-super_admin{background-color:#dc2626;color:#fff}.role-admin{background-color:#7c3aed;color:#fff}.role-coach{background-color:#059669;color:#fff}.role-viewer{background-color:#6b7280;color:#fff}.status-badge{padding:.25rem .5rem;border-radius:12px;font-size:.75rem;font-weight:600}.status-badge.active{background-color:#d1fae5;color:#065f46}.status-badge.inactive{background-color:#fee2e2;color:#991b1b}.user-actions{display:flex;gap:.25rem;flex-wrap:wrap}.user-management-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.login-info{background-color:var(--background);padding:1rem;border-radius:8px;margin-top:1rem}.login-info h4{margin:0 0 .5rem;color:var(--navy)}.login-info p{margin:.25rem 0;font-size:.9rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;cursor:pointer;font-weight:500}@media (max-width: 768px){.user-management-modal{max-width:100vw;max-height:100vh;width:100vw;height:100vh;top:0;left:0;transform:none;border-radius:0;box-shadow:none}.users-table{font-size:.8rem}.users-table th,.users-table td{padding:.5rem}.user-actions{flex-direction:column;gap:.25rem}.user-actions .btn{font-size:.75rem;padding:.5rem .75rem}}.attendance-page{padding:20px}.attendance-tabs{display:flex;gap:5px;margin-top:20px;border-bottom:2px solid var(--border-color);flex-wrap:wrap}.attendance-tabs .tab-btn{background:#f8fafc;border:2px solid #e2e8f0;border-bottom:none;padding:12px 16px;cursor:pointer;font-size:14px;color:#64748b;border-radius:8px 8px 0 0;transition:all .3s ease;display:flex;align-items:center;gap:6px;min-width:120px;justify-content:center;font-weight:500}.attendance-tabs .tab-btn:hover{background:#3b82f6;color:#fff;box-shadow:0 6px 12px #3b82f64d;border-color:#3b82f6}.attendance-tabs .tab-btn.active{background:#1d4ed8;color:#fff!important;font-weight:700;box-shadow:0 8px 16px #1d4ed866;border-color:#1d4ed8}.attendance-tabs .tab-btn.active .tab-icon{color:#fff!important;filter:drop-shadow(0 1px 2px rgba(0,0,0,.2))}.tab-icon{font-size:16px}.sessions-tab,.create-tab,.attendance-tab{margin-top:20px}.create-tab{max-width:800px}.session-form-container{background:#fff;border-radius:12px;padding:24px;box-shadow:0 4px 6px #0000001a;border:1px solid var(--border-color)}.session-form{display:flex;flex-direction:column;gap:20px}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:16px}.form-group{display:flex;flex-direction:column;gap:6px}.label-text{font-weight:600;color:var(--text-primary);font-size:14px}.form-input,.form-select,.form-textarea{padding:12px;border:2px solid var(--border-color);border-radius:8px;font-size:16px;background:#fff}.form-input:focus,.form-select:focus,.form-textarea:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{min-height:80px;resize:vertical}.form-actions{display:flex;gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color)}.btn-large{padding:14px 24px;font-size:16px;font-weight:600}.title-preview{margin-top:8px;padding:12px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:8px;border-left:4px solid var(--primary-color)}.title-preview small{color:var(--text-secondary);font-style:italic;font-size:13px}.attendance-page{max-width:1400px;margin:0 auto;padding:20px}.sessions-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 4px #0000001a}.sessions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px;margin-top:16px}.session-card{background:#fff;border-radius:12px;padding:16px;box-shadow:0 4px 6px #0000000d;border:1px solid #e2e8f0;transition:all .3s ease;position:relative;overflow:hidden}.session-card:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#3b82f6,#8b5cf6)}.session-card:hover{box-shadow:0 8px 25px #0000001a;border-color:#3b82f6}.session-header h4{margin:0 0 8px;color:var(--text-primary);font-size:18px;font-weight:600;line-height:1.3}.session-meta{display:flex;gap:8px;margin-bottom:8px;flex-wrap:wrap}.session-meta span{padding:4px 10px;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:6px;font-size:11px;font-weight:600;color:#475569;border:1px solid #cbd5e1}.session-details p{margin:2px 0;color:var(--text-secondary);font-size:13px}.session-actions{display:flex;gap:8px;margin-top:12px;flex-wrap:wrap;padding-top:12px;border-top:1px solid #f1f5f9}.attendance-header{margin-bottom:20px}.no-session-selected{text-align:center;padding:40px;background:var(--bg-secondary);border-radius:12px;border:2px dashed var(--border-color)}.attendance-content{background:#fff;border-radius:12px;padding:20px;box-shadow:0 4px 6px #0000000d;border:1px solid #e2e8f0;margin-top:16px}.session-info{margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.session-info h4{margin:0 0 8px;color:var(--text-primary)}.session-info .session-meta{display:flex;gap:16px;flex-wrap:wrap}.session-info .session-meta span{padding:4px 12px;background:var(--bg-secondary);border-radius:6px;font-size:14px;font-weight:500}.marking-toolbar{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap;padding:16px;background:#f8fafc;border-radius:12px;border:1px solid #e2e8f0}.search-input{flex:1;min-width:200px;padding:12px 16px;border:2px solid #e2e8f0;border-radius:10px;font-size:14px;background:#fff}.search-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.search-toggle-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);border-radius:8px;color:var(--navy);font-size:14px;font-weight:600;cursor:pointer;position:relative;overflow:hidden}.search-toggle-btn:hover{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-color:var(--navy);box-shadow:0 4px 12px #1a365d26}.search-toggle-btn.expanded{background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);color:var(--white)}.search-icon{font-size:16px}.search-text{font-weight:600}.search-arrow{font-size:12px}.search-bar{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);border-radius:8px;box-shadow:0 2px 8px #0000000d;overflow:hidden;position:relative}.search-bar.collapsed{max-height:0;padding:0;margin-bottom:0;border:none;box-shadow:none}.search-bar.expanded{max-height:200px;padding:16px;margin-bottom:16px}.search-content{display:flex;flex-direction:column;gap:12px}.session-search-bar{background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%);border:1px solid rgba(26,54,93,.1);border-radius:8px;box-shadow:0 2px 8px #0000000d;overflow:hidden;position:relative}.session-search-bar.collapsed{max-height:0;padding:0;margin-bottom:0;border:none;box-shadow:none}.session-search-bar.expanded{max-height:300px;padding:16px;margin-bottom:16px}.clear-search-btn{background:#ef4444;color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:.75rem;font-weight:700;box-shadow:0 1px 3px #0000001a;flex-shrink:0}.clear-search-btn:hover{background:#dc2626;box-shadow:0 2px 6px #0003}.header-controls{display:flex;gap:12px;align-items:center}.search-header{display:flex;justify-content:flex-end;margin-bottom:8px}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important;scroll-behavior:auto!important}}.btn:focus-visible,button:focus-visible,select:focus-visible,input:focus-visible,.tab-btn:focus-visible,.name-cell.clickable:focus-visible{outline:3px solid rgba(59,130,246,.6);outline-offset:2px;border-radius:8px}.name-cell.clickable{cursor:pointer}.name-cell.clickable:hover{text-decoration:underline}.leaderboard-table thead th,.rankings-table thead th,.attendance-table thead th,.times-table thead th{position:sticky;top:0;background:#fff;z-index:2;box-shadow:0 1px #0000000f}.leaderboard-table-container,.rankings-table-container,.attendance-table-container,.times-table-container{overflow-x:auto;overflow-y:auto;-webkit-overflow-scrolling:touch}.rank-cell,.points-cell,.time-cell,.date-cell,.age-cell,.events-cell,.avg-points-cell{text-align:right}.sessions-title-section{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.bulk-actions{display:flex;gap:8px}.btn-bonus{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border:none;font-weight:600;transition:all .3s ease}.btn-bonus:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b4d}.bonus-points-modal{max-width:500px!important;width:90vw!important;position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:10000!important;max-height:90vh!important;overflow-y:auto!important;background:linear-gradient(135deg,var(--white) 0%,#f8fafc 100%)!important;padding:2.5rem!important;border-radius:20px!important;box-shadow:0 20px 60px #00000026!important;margin:0!important}.bonus-form{display:flex;flex-direction:column;gap:20px}.points-selection{display:flex;flex-direction:column;gap:12px}.points-options{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.points-option{padding:16px;border:2px solid #e5e7eb;border-radius:12px;cursor:pointer;transition:all .3s ease;text-align:center;background:#fff}.points-option:hover{border-color:#f59e0b;box-shadow:0 4px 12px #f59e0b26}.points-option.selected{border-color:#f59e0b;background:linear-gradient(135deg,#fef3c7,#fde68a);box-shadow:0 4px 12px #f59e0b40}.points-value{font-size:18px;font-weight:700;color:#f59e0b;margin-bottom:4px}.points-description{font-size:12px;color:#6b7280;font-weight:500}.reason-input label{display:block;font-weight:600;margin-bottom:8px;color:var(--navy)}.reason-input textarea{width:100%;padding:12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;resize:vertical;min-height:80px;transition:border-color .2s ease}.reason-input textarea:focus{outline:none;border-color:#f59e0b;box-shadow:0 0 0 3px #f59e0b1a}.swimmer-info{background:linear-gradient(135deg,#f8fafc,#e2e8f0);padding:16px;border-radius:12px;margin-bottom:20px}.swimmer-info h3{margin:0 0 8px;color:var(--navy);font-size:18px}.swimmer-info p{margin:0;color:#6b7280;font-size:14px}.swimmer-stats{margin-top:12px}.swimmer-stats p{margin:8px 0;font-size:14px;display:flex;align-items:center;justify-content:center;flex-wrap:wrap;gap:4px}.bonus-points-history-enhanced{padding:0;width:100%;max-width:100%;margin:0 auto;display:flex;flex-direction:column;gap:2rem}.bonus-dashboard{background:linear-gradient(135deg,#1e293b,#334155);border-radius:20px;padding:2rem;color:#fff;position:relative;overflow:hidden}.bonus-dashboard:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#f59e0b,#d97706,#f59e0b)}.dashboard-header h3{font-size:1.5rem;font-weight:800;margin:0 0 .5rem;color:#fff;display:flex;align-items:center;gap:.75rem}.dashboard-subtitle{font-size:.9rem;color:#cbd5e1;margin-bottom:2rem}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.analytics-card{background:#ffffff1a;border-radius:16px;padding:1.5rem;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);position:relative;overflow:hidden}.analytics-card:hover{background:#ffffff26;box-shadow:0 8px 25px #0003}.analytics-card.primary{background:linear-gradient(135deg,var(--navy) 0%,#1d4ed8 100%)!important;color:var(--white)!important;border-color:var(--navy)!important;box-shadow:0 4px 12px #1e3a8a4d!important}.analytics-card.primary:hover{background:linear-gradient(135deg,#1d4ed8,#1e40af)!important;color:var(--white)!important;box-shadow:0 8px 25px #1e3a8a66!important}.card-icon{font-size:2rem;margin-bottom:1rem;opacity:.9}.card-content{display:flex;flex-direction:column;gap:.25rem}.card-value{font-size:2rem;font-weight:800;color:#fff;line-height:1}.card-label{font-size:.9rem;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.05em}.card-subtitle{font-size:.8rem;color:#ffffffb3;margin-top:.25rem}.bonus-timeline-enhanced{background:#fff;border-radius:20px;padding:2rem;box-shadow:0 4px 20px #00000014;border:1px solid #e2e8f0}.timeline-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.timeline-header h4{font-size:1.25rem;font-weight:700;color:#1e293b;margin:0}.timeline-controls{display:flex;gap:1rem;flex-wrap:wrap}.filter-group label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.filter-select{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:8px;font-size:.9rem;background:#fff;color:#374151}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.timeline-enhanced{position:relative;padding-left:3rem}.timeline-enhanced:before{content:"";position:absolute;left:1.5rem;top:0;bottom:0;width:3px;background:linear-gradient(to bottom,#3b82f6,#1d4ed8);border-radius:2px}.timeline-item-enhanced{position:relative;margin-bottom:2rem;padding-left:0}.timeline-marker-enhanced{position:absolute;left:-3rem;top:.5rem;width:3rem;height:3rem;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #00000026;border:3px solid white;z-index:2}.points-badge-enhanced{display:flex;flex-direction:column;align-items:center;gap:.125rem}.points-icon{font-size:.8rem;line-height:1}.points-value{font-size:.7rem;font-weight:700;color:#fff;line-height:1}.timeline-content-enhanced{background:#f8fafc;border-radius:16px;padding:1.5rem;border:1px solid #e2e8f0;box-shadow:0 2px 8px #0000000d}.timeline-content-enhanced:hover{box-shadow:0 4px 16px #0000001a;border-color:#cbd5e1}.bonus-header-enhanced{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.bonus-meta{display:flex;flex-direction:column;gap:.25rem}.bonus-points-enhanced{font-size:1.25rem;font-weight:700;line-height:1}.bonus-tier{font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;opacity:.8}.bonus-date-enhanced{font-size:.8rem;color:#64748b;font-weight:500;white-space:nowrap}.bonus-reason-enhanced{margin-bottom:.75rem}.reason-label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem}.reason-text{font-size:.95rem;color:#374151;line-height:1.4}.bonus-coach-enhanced{display:flex;flex-direction:column;gap:.25rem}.coach-label{font-size:.8rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em}.coach-name{font-size:.9rem;color:#1e293b;font-weight:600}.no-bonus-history-enhanced{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:20px;padding:3rem 2rem;text-align:center;border:2px dashed #cbd5e1}.empty-state{max-width:400px;margin:0 auto}.empty-state .empty-icon{font-size:4rem;margin-bottom:1.5rem;opacity:.6}.empty-state h4{font-size:1.5rem;font-weight:700;color:#1e293b;margin:0 0 .75rem}.empty-state p{font-size:1rem;color:#64748b;margin-bottom:2rem;line-height:1.5}.empty-actions{display:flex;flex-direction:column;gap:1rem;align-items:center}.action-item{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;background:#fff;border-radius:12px;border:1px solid #e2e8f0;font-size:.9rem;color:#374151;font-weight:500}.action-item:hover{box-shadow:0 4px 12px #0000001a;border-color:#3b82f6}.action-icon{font-size:1.25rem}@media (max-width: 768px){.bonus-dashboard{padding:1rem;border-radius:12px;margin:0;width:100%;max-width:100%;background:linear-gradient(135deg,#1e293b,#334155);box-shadow:0 4px 12px #00000026}.dashboard-header{margin-bottom:1.5rem}.dashboard-header h3{font-size:1.1rem;font-weight:700;line-height:1.3;color:#fff;margin:0 0 .5rem;word-wrap:break-word;overflow-wrap:break-word}.dashboard-subtitle{font-size:.8rem;line-height:1.4;color:#cbd5e1;word-wrap:break-word;overflow-wrap:break-word}.analytics-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem;width:100%;max-width:100%}.analytics-card{padding:.75rem;background:#ffffff1a;border-radius:8px;border:1px solid rgba(255,255,255,.2);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);width:100%;max-width:100%;box-sizing:border-box;min-height:80px;display:flex;flex-direction:column;justify-content:center}.analytics-card.primary{background:linear-gradient(135deg,var(--navy) 0%,#1d4ed8 100%)!important;color:var(--white)!important;border-color:var(--navy)!important;grid-column:1 / -1}.card-icon{font-size:1.25rem;margin-bottom:.5rem;opacity:.9}.card-content{width:100%;max-width:100%}.card-value{font-size:1.25rem;font-weight:800;color:#fff;line-height:1.1;word-wrap:break-word;overflow-wrap:break-word;margin-bottom:.25rem}.card-label{font-size:.7rem;font-weight:600;color:#ffffffe6;text-transform:uppercase;letter-spacing:.05em;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word}.card-subtitle{font-size:.65rem;color:#ffffffb3;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;margin-top:.125rem}.timeline-header{flex-direction:column;align-items:stretch;gap:1rem;width:100%;max-width:100%;margin-bottom:1.5rem}.timeline-header h4{font-size:1rem;font-weight:700;color:#1e293b;margin:0;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.timeline-controls{display:flex;flex-direction:column;gap:.75rem;width:100%;max-width:100%}.filter-group{display:flex;flex-direction:row;align-items:center;gap:.75rem;width:100%;max-width:100%;min-height:44px}.filter-group label{min-width:60px;font-size:.75rem;font-weight:600;color:#64748b;line-height:1.3;white-space:nowrap;flex-shrink:0}.filter-select{flex:1;padding:.75rem;font-size:.8rem;border:1px solid #d1d5db;border-radius:8px;background:#fff;color:#374151;min-width:0;width:100%;max-width:100%;box-sizing:border-box;min-height:44px}.filter-select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.timeline-enhanced{position:relative;padding-left:2.5rem;width:100%;max-width:100%}.timeline-enhanced:before{content:"";position:absolute;left:1.25rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#3b82f6,#1d4ed8);border-radius:1px}.timeline-item-enhanced{position:relative;margin-bottom:1.5rem;padding-left:0}.timeline-marker-enhanced{position:absolute;left:-2.5rem;top:.5rem;width:2.5rem;height:2.5rem;border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 8px #00000026;border:3px solid white;z-index:2}.points-badge-enhanced{display:flex;flex-direction:column;align-items:center;justify-content:center;width:100%;height:100%;gap:.125rem}.points-icon{font-size:.6rem;line-height:1;margin-bottom:.05rem}.points-value{font-size:.5rem;line-height:1;font-weight:800;white-space:nowrap;text-align:center;color:#fff}.timeline-content-enhanced{background:#f8fafc;border-radius:12px;padding:1rem;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;width:100%;max-width:100%;box-sizing:border-box}.bonus-header-enhanced{display:flex;flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.75rem;width:100%;max-width:100%}.bonus-meta{width:100%;max-width:100%}.bonus-points-enhanced{font-size:1rem;font-weight:700;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;margin-bottom:.25rem}.bonus-tier{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;line-height:1.2;word-wrap:break-word;overflow-wrap:break-word;opacity:.8}.bonus-date-enhanced{font-size:.75rem;color:#64748b;font-weight:500;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.bonus-reason-enhanced{margin-bottom:.75rem;width:100%;max-width:100%}.reason-label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.reason-text{font-size:.85rem;color:#374151;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.bonus-coach-enhanced{width:100%;max-width:100%}.coach-label{font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.25rem;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.coach-name{font-size:.8rem;color:#1e293b;font-weight:600;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.no-bonus-history-enhanced{background:linear-gradient(135deg,#f8fafc,#e2e8f0);border-radius:12px;padding:2rem 1rem;text-align:center;border:2px dashed #cbd5e1;width:100%;max-width:100%}.empty-state{max-width:100%;width:100%}.empty-state .empty-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.empty-state h4{font-size:1.1rem;font-weight:700;color:#1e293b;margin:0 0 .5rem;line-height:1.3;word-wrap:break-word;overflow-wrap:break-word}.empty-state p{font-size:.85rem;color:#64748b;margin-bottom:1.5rem;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.empty-actions{display:flex;flex-direction:column;gap:.75rem;align-items:center;width:100%;max-width:100%}.action-item{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#fff;border-radius:8px;border:1px solid #e2e8f0;font-size:.8rem;color:#374151;font-weight:500;width:100%;max-width:100%;box-sizing:border-box;text-align:center;justify-content:center;min-height:44px}.action-item:hover{box-shadow:0 2px 8px #0000001a;border-color:#3b82f6}.action-icon{font-size:1rem}.bonus-points-history-enhanced{width:100%;max-width:100%;overflow-x:hidden;padding:0;margin:0}.bonus-timeline-enhanced{width:100%;max-width:100%;overflow-x:hidden;background:#fff;border-radius:12px;padding:1rem;box-shadow:0 2px 8px #0000000d;border:1px solid #e2e8f0}@media (max-width: 480px){.analytics-grid{grid-template-columns:1fr;gap:.5rem}.analytics-card{padding:.5rem;min-height:70px}.card-value{font-size:1.1rem}.card-label{font-size:.65rem}.card-subtitle{font-size:.6rem}.timeline-marker-enhanced{width:2rem;height:2rem;left:-2rem}.points-icon{font-size:.5rem}.points-value{font-size:.45rem}.timeline-enhanced{padding-left:2rem}.timeline-content-enhanced{padding:.75rem}.bonus-points-enhanced{font-size:.9rem}.reason-text{font-size:.8rem}.coach-name{font-size:.75rem}}}.bonus-points-history{padding:20px;width:100%;max-width:100%;margin:0 auto;display:flex;flex-direction:column;align-items:center}.bonus-summary{background:linear-gradient(135deg,#fef3c7,#fde68a);padding:20px;border-radius:12px;margin-bottom:24px;border:1px solid #f59e0b;width:100%;max-width:800px;margin-left:auto;margin-right:auto}@media (min-width: 1200px){.bonus-summary,.bonus-timeline{max-width:900px}}@media (min-width: 1400px){.bonus-summary,.bonus-timeline{max-width:1000px}}.bonus-summary h3{margin:0 0 16px;color:#92400e;font-size:20px;display:flex;align-items:center;gap:8px}.bonus-total,.bonus-count{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.total-label,.count-label{font-weight:600;color:#92400e}.total-value{font-size:24px;font-weight:700;color:#f59e0b}.count-value{font-size:18px;font-weight:600;color:#f59e0b}.no-bonus-history{text-align:center;padding:40px 20px;color:#6b7280}.empty-icon{font-size:48px;margin-bottom:16px}.bonus-timeline h4{margin:0 0 20px;color:var(--navy);font-size:18px}.timeline{position:relative;padding-left:2.5rem}.timeline:before{content:"";position:absolute;left:1rem;top:0;bottom:0;width:2px;background:linear-gradient(to bottom,#3b82f6,#1d4ed8);z-index:1}.timeline-item{position:relative;margin-bottom:24px;padding-left:0}.timeline-marker{position:absolute;left:-2rem;top:.5rem;width:2rem;height:2rem;background:linear-gradient(135deg,#3b82f6,#1d4ed8);border-radius:50%;display:flex;align-items:center;justify-content:center;box-shadow:0 3px 6px #3b82f666;border:2px solid white;z-index:2}.points-badge{font-size:.75rem;font-weight:700;color:#fff;text-align:center;line-height:1;white-space:nowrap;padding:.125rem}.timeline-content{background:#fff;padding:16px;border-radius:12px;box-shadow:0 2px 8px #0000001a;border:1px solid #e5e7eb}.bonus-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.bonus-points{font-size:18px;font-weight:700;color:#f59e0b}.bonus-date{font-size:12px;color:#6b7280}.bonus-reason,.bonus-coach{margin-bottom:8px;font-size:14px;line-height:1.5}.bonus-reason strong,.bonus-coach strong{color:var(--navy)}.bonus-history-loading{text-align:center;padding:40px;color:#6b7280}.loading-spinner{width:32px;height:32px;border:3px solid #e5e7eb;border-top:3px solid #f59e0b;border-radius:50%;margin:0 auto 16px}.modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;width:100vw!important;height:100vh!important;background:#00000080!important;z-index:10000!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:1rem!important;box-sizing:border-box!important}.bonus-points-modal{z-index:10001!important}@media (max-width: 768px){.bonus-points-modal{width:95vw!important;max-width:none!important;max-height:85vh!important;position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;z-index:10001!important}.modal-overlay{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;z-index:10000!important;display:flex!important;align-items:center!important;justify-content:center!important;padding:.5rem!important}}.points-options{grid-template-columns:1fr;gap:8px}.points-option{padding:12px}.bonus-summary{padding:16px}.timeline-content{padding:12px}.bonus-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:.75rem}.bonus-points{font-size:1.1rem;font-weight:700;color:#f59e0b}.bonus-date{font-size:.8rem;color:#6b7280;font-weight:500}.bonus-reason,.bonus-coach{margin-bottom:.5rem;font-size:.9rem;line-height:1.4;color:#374151}.bonus-reason strong,.bonus-coach strong{color:#1e293b;font-weight:600}.attendance-table-container{overflow-x:auto;border-radius:12px;border:1px solid #e2e8f0;box-shadow:0 2px 4px #0000000d;background:#fff}.attendance-table{width:100%;border-collapse:collapse;background:#fff}.attendance-table th{background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:16px 12px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:1;font-size:14px}.attendance-table td{padding:14px 12px;border-bottom:1px solid #f1f5f9;vertical-align:middle;font-size:14px}.attendance-table tr:hover{background:#f8fafc}.swimmer-info strong{color:var(--text-primary)}.user-actions{display:flex;gap:4px}.btn-micro{padding:8px 12px;font-size:12px;min-width:36px;text-align:center;border-radius:6px;font-weight:600}.btn-micro:hover{box-shadow:0 2px 4px #0000001a}.history-tab{max-width:1000px}.swimmer-selector{margin-bottom:24px}.attendance-history{background:#fff;border-radius:12px;padding:24px;box-shadow:0 2px 4px #0000001a;border:1px solid var(--border-color)}.attendance-marking-section{margin-top:30px;padding-top:30px;border-top:2px solid var(--border-color)}.section-divider{margin-bottom:20px}.section-divider h4{margin:0 0 8px;color:var(--text-primary);font-size:18px}.section-divider p{margin:0;color:var(--text-secondary);font-size:14px}.attendance-marking-content{background:#f8fafc;border-radius:12px;padding:20px;border:1px solid var(--border-color)}.attendance-save-actions{display:flex;gap:12px;margin-top:20px;padding-top:20px;border-top:1px solid var(--border-color);justify-content:center}.group-selection{display:flex;flex-direction:column;gap:16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);padding:20px;border-radius:12px;border:1px solid #e2e8f0;position:relative;overflow:hidden}.group-selection:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#8b5cf6,#06b6d4)}.group-instruction{margin:0 0 12px;font-size:14px;color:#374151;font-weight:600;text-align:center}.group-checkboxes{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:20px}.group-checkbox{display:flex;flex-direction:column;align-items:center;gap:6px;padding:16px 12px;border:2px solid #e2e8f0;border-radius:10px;cursor:pointer;transition:all .3s ease;background:#fff;position:relative;overflow:hidden;min-height:85px}.group-checkbox:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:currentColor;opacity:0}.group-checkbox:hover{border-color:#3b82f6;background:#f8fafc;box-shadow:0 4px 12px #3b82f626}.group-checkbox input[type=checkbox]{margin:0;accent-color:#3b82f6}.group-checkbox input[type=checkbox]:checked+.group-label{font-weight:700;color:#1d4ed8}.group-checkbox input[type=checkbox]:checked~.group-icon{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2))}.group-checkbox input[type=checkbox]:checked:before{opacity:1}.group-checkbox:has(input[type=checkbox]:checked){background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-color:#3b82f6;box-shadow:0 4px 12px #3b82f633}.group-checkbox:has(input[type=checkbox]:checked):before{opacity:1;background:linear-gradient(90deg,#3b82f6,#1d4ed8)}.group-checkbox:has(input[type=checkbox]:checked) .group-label{color:#1e40af;font-weight:700}.group-checkbox:has(input[type=checkbox]:checked) .group-icon{filter:drop-shadow(0 2px 4px rgba(59,130,246,.3))}.group-label{font-size:13px;font-weight:600;text-align:center}.group-icon{font-size:20px;margin-bottom:2px}.selected-groups-display{padding:16px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:10px;border:2px solid #3b82f6;font-size:14px;text-align:center;position:relative;overflow:hidden;box-shadow:0 2px 8px #3b82f61a}.selected-groups-display:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#10b981,#3b82f6,#8b5cf6)}.selected-group{font-weight:700;margin:0 6px;padding:6px 12px;border-radius:8px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:inline-block;box-shadow:0 2px 4px #3b82f64d}.selected-group:hover{box-shadow:0 4px 8px #3b82f666}.no-groups{color:#6b7280;font-style:italic;font-weight:500;padding:8px 16px;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-radius:6px;border:1px dashed #cbd5e1;display:inline-block}.group-switcher{display:flex;align-items:center;gap:8px;margin-top:12px;padding:12px;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border-radius:8px;border:1px solid #bae6fd}.group-switcher span{font-weight:600;color:#0369a1;font-size:14px}@media (max-width: 768px){.attendance-page{padding:var(--space-3)}.app-header h1{font-size:var(--font-size-3xl);margin-bottom:var(--space-2)}.subtitle{font-size:var(--font-size-base)}.app-nav{position:-webkit-sticky!important;position:sticky!important;top:0!important;z-index:100!important;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);box-shadow:0 2px 12px #00000026,0 1px 4px #0000001a;transform:translateZ(0);will-change:transform;isolation:isolate}.swimmer-card{padding:var(--space-6);margin-bottom:var(--space-4);border-radius:var(--radius-lg)}.swimmer-card:hover{box-shadow:var(--shadow-md)}.leaderboard-table-container,.rankings-table-container{padding:var(--space-6);border-radius:var(--radius-lg);margin:0 -var(--space-3) var(--space-6) -var(--space-3)}.leaderboard-table th,.leaderboard-table td{padding:var(--space-3);font-size:var(--font-size-sm)}.btn{padding:var(--space-3) var(--space-4);font-size:var(--font-size-sm);border-radius:var(--radius-md);min-height:44px}.nav-btn{padding:var(--space-4) var(--space-6);font-size:var(--font-size-sm);border-radius:var(--radius-md);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.nav-text-full,.nav-text-mobile{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.nav-text-mobile{font-size:var(--font-size-xs);font-weight:var(--font-weight-medium)}@media (max-width: 480px){.nav-btn{padding:var(--space-3) var(--space-4);font-size:var(--font-size-xs);min-width:0;flex:1}.nav-text-mobile{font-size:.7rem}.nav-text-full{font-size:var(--font-size-xs)}.app-nav{gap:0}}@media (max-width: 360px){.nav-btn{padding:var(--space-2) var(--space-3);font-size:.65rem}.nav-text-mobile{font-size:.65rem}}.app-main{padding:var(--space-4)}.section{margin-bottom:var(--space-6)}.btn:focus,.nav-btn:focus,.filter-toggle-btn:focus{outline:none;box-shadow:0 0 0 3px #1e3a8a4d;border-color:var(--navy)}.form-group input:focus,.form-group select:focus,.form-group textarea:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1e3a8a1a}.swimmer-card:focus-within{box-shadow:var(--shadow-lg);border-color:var(--navy)}.loading{color:var(--text-secondary);font-style:italic;display:flex;align-items:center;gap:var(--space-2)}.loading:before{content:"";width:16px;height:16px;border:2px solid var(--border);border-top:2px solid var(--navy);border-radius:var(--radius-full)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:var(--space-8);color:var(--text-muted);font-style:italic}.empty-state:before{content:"📊";display:block;font-size:var(--font-size-3xl);margin-bottom:var(--space-3)}.attendance-tabs{flex-direction:column;gap:8px}.attendance-tabs .tab-btn{min-width:auto;justify-content:center;flex:1;text-align:center}.form-row{grid-template-columns:1fr}.sessions-grid{grid-template-columns:1fr;gap:16px}.session-card{padding:14px}.marking-toolbar{flex-direction:column;align-items:stretch;gap:12px}.times-table-container{max-height:400px;overflow-y:auto;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 2px 4px #0000001a;background:#fff;-webkit-overflow-scrolling:touch}.times-table{width:100%;border-collapse:collapse;font-size:.9rem}.times-table th{background:#f8fafc;padding:12px 8px;text-align:left;font-weight:600;color:#374151;border-bottom:2px solid #e2e8f0;position:sticky;top:0;z-index:10;font-size:.85rem}.times-table td{padding:10px 8px;border-bottom:1px solid #f1f5f9;vertical-align:middle;font-size:.85rem}.times-table tr:hover{background:#f8fafc}.times-table .time-cell{font-family:Cairo,monospace;font-weight:600;color:#1e40af}.times-table .points-cell{font-weight:600;color:#059669}.times-table .date-cell{color:#6b7280}.times-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.times-header h3{margin:0;color:var(--navy);font-size:1.25rem;font-weight:600}.times-table-container{max-height:300px;margin:0 -10px;overflow-x:auto;-webkit-overflow-scrolling:touch}.times-table{min-width:500px}.times-table-container{border-radius:0;border-left:none;border-right:none}.times-table{font-size:.8rem}.times-table th{padding:8px 6px;font-size:.75rem}.times-table td{padding:8px 6px;font-size:.8rem}.times-header{flex-direction:column;align-items:stretch;gap:8px}.times-header h3{font-size:1.1rem}.times-filters .filter-content{display:flex;flex-direction:column;gap:10px;padding:12px;max-width:100%;overflow-x:hidden}.times-filters .filter-group{width:100%;max-width:100%}.times-filters .filter-group label{font-size:.8rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.times-filters .filter-group select{padding:8px 10px;font-size:.9rem;width:100%;max-width:100%}.bulk-actions{justify-content:center;flex-wrap:wrap}.search-toggle-btn{padding:6px 12px;font-size:12px;gap:6px}.search-bar.expanded{max-height:150px;padding:12px}.session-search-bar.expanded{max-height:200px;padding:12px}.sessions-title-section{flex-direction:column;align-items:flex-start;gap:12px}.search-header{justify-content:flex-start}.session-actions{justify-content:center;flex-wrap:wrap}.user-actions{flex-wrap:wrap;justify-content:center;gap:6px}.attendance-save-actions{flex-direction:column;gap:12px}.group-checkboxes{grid-template-columns:repeat(2,1fr);gap:12px}.group-checkbox{min-height:80px;padding:16px 12px}.group-icon{font-size:20px}.group-label{font-size:13px}}@media (min-width: 1024px){.group-checkboxes{grid-template-columns:repeat(5,1fr);gap:16px}.group-checkbox{min-height:90px;padding:18px 14px}.group-icon{font-size:22px}.group-label{font-size:14px}}@media (min-width: 769px) and (max-width: 1023px){.group-checkboxes{grid-template-columns:repeat(3,1fr);gap:14px}.group-checkbox{min-height:88px;padding:17px 13px}.attendance-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.attendance-table th,.attendance-table td{padding:10px 8px;font-size:13px}}.attendance-sessions{background:var(--card-bg);padding:20px;border-radius:12px;box-shadow:var(--card-shadow)}.session-list{list-style:none;padding:0;margin:0 0 20px}.session-list li{display:flex;justify-content:space-between;align-items:center;padding:10px;margin-bottom:8px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.session-list li.active{background:var(--primary-color);color:#fff}.session-list .btn-link{background:none;border:none;color:inherit;text-align:left;flex:1;cursor:pointer;padding:0}.session-actions{display:flex;gap:8px}.session-filters{display:grid;grid-template-columns:1fr 1fr 1fr 2fr;gap:8px;margin:10px 0 15px}.session-form{display:flex;flex-direction:column;gap:15px}.session-form label{display:flex;flex-direction:column;gap:5px}.session-form input,.session-form select,.session-form textarea{padding:8px;border:1px solid var(--border-color);border-radius:6px;font-size:14px}.session-form textarea{resize:vertical;min-height:60px}.form-actions{display:flex;gap:10px}.attendance-marking{background:var(--card-bg);padding:20px;border-radius:12px;box-shadow:var(--card-shadow)}.attendance-summary{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;padding:15px;background:var(--bg-secondary);border-radius:8px}.attendance-table{width:100%;border-collapse:collapse;margin-top:10px}.attendance-table th,.attendance-table td{padding:12px;text-align:left;border-bottom:1px solid var(--border-color)}.attendance-table thead th{position:sticky;top:0;background:var(--bg);z-index:1}.attendance-table th{background:var(--bg-secondary);font-weight:600}.user-actions{display:flex;gap:5px;flex-wrap:wrap}.marking-toolbar{display:flex;justify-content:space-between;gap:10px;margin-bottom:10px}.status-toggle{text-transform:capitalize;padding:8px 12px;border-radius:8px;border:2px solid transparent;background:#f1f5f9;color:#64748b;font-weight:600;font-size:12px;cursor:pointer;min-width:80px;text-align:center}.status-toggle:hover{box-shadow:0 2px 4px #0000001a}.status-toggle.present{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border-color:#10b981;box-shadow:0 2px 4px #10b9814d}.status-toggle.late{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;border-color:#f59e0b;box-shadow:0 2px 4px #f59e0b4d}.status-toggle.excused{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;border-color:#6b7280;box-shadow:0 2px 4px #6b72804d}.status-toggle.absent{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border-color:#ef4444;box-shadow:0 2px 4px #ef44444d}.btn-small{padding:4px 8px;font-size:12px;border-radius:4px}.btn-warning{background:#f59e0b;color:#fff;border:none}.btn-warning:hover{background:#d97706}.btn-secondary{background:#6b7280;color:#fff;border:none}.btn-secondary:hover{background:#4b5563}.session-attendance-modal{max-width:1000px;max-height:90vh;overflow-y:auto}.session-info{background:var(--bg-secondary);padding:15px;border-radius:8px;margin-bottom:20px}.session-info h3{margin:0 0 10px;color:var(--primary-color)}.session-info p{margin:5px 0}.summary-stats{display:flex;gap:15px;flex-wrap:wrap}.stat{padding:5px 10px;border-radius:4px;font-weight:600}.stat.present{background:#10b981;color:#fff}.stat.late{background:#f59e0b;color:#fff}.stat.excused{background:#6b7280;color:#fff}.stat.absent{background:#ef4444;color:#fff}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600;text-transform:capitalize}.status-badge.present{background:#10b981;color:#fff}.status-badge.late{background:#f59e0b;color:#fff}.status-badge.excused{background:#6b7280;color:#fff}.status-badge.absent{background:#ef4444;color:#fff}.attendance-table-container{overflow-x:auto}.profile-tabs{display:flex;background:linear-gradient(135deg,#f1f5f9,#e2e8f0);border-radius:16px;padding:6px;margin-bottom:2rem;box-shadow:0 2px 4px #0000001a;border:1px solid rgba(255,255,255,.2);width:100%;margin-left:0;margin-right:0}.tab-btn{background:transparent;border:none;padding:14px 24px;cursor:pointer;font-size:15px;color:#64748b;border-radius:12px;font-weight:600;position:relative;flex:1;text-align:center;min-height:48px;display:flex;align-items:center;justify-content:center}.tab-btn:hover{color:#3b82f6;background:#3b82f61a}.tab-btn.active{color:#fff;background:linear-gradient(135deg,#3b82f6,#1d4ed8);box-shadow:0 4px 12px #3b82f666;font-weight:700}.attendance-section{margin-top:20px}.no-data{text-align:center;color:var(--text-secondary);font-style:italic;padding:40px}@media (max-width: 768px){.attendance-layout{grid-template-columns:1fr;gap:15px}.session-list li{flex-direction:column;align-items:stretch;gap:10px}.session-actions,.user-actions{justify-content:center}.attendance-summary{flex-direction:column;gap:15px;text-align:center}.summary-stats{justify-content:center}.profile-tabs{flex-direction:row;flex-wrap:wrap;gap:4px}.tab-btn{flex:1;min-width:0;text-align:center;padding:12px 8px;font-size:13px}}.edit-time-form{display:flex;flex-direction:column;gap:1rem}.edit-time-form .form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.edit-time-form .form-group{display:flex;flex-direction:column}.edit-time-form label{font-weight:600;color:var(--navy);margin-bottom:.5rem;font-size:.9rem}.edit-time-form input,.edit-time-form select{padding:.75rem;border:2px solid #e2e8f0;border-radius:8px;font-size:.9rem;transition:border-color .2s ease}.edit-time-form input:focus,.edit-time-form select:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.calculated-points{display:flex;flex-direction:column;align-items:center;padding:1rem;background:linear-gradient(135deg,#f0f9ff,#e0f2fe);border:2px solid #0ea5e9;border-radius:8px;text-align:center}.points-value{font-size:1.5rem;font-weight:700;color:#0ea5e9;margin-bottom:.25rem}.points-note{font-size:.8rem;color:#64748b;font-style:italic}.time-actions{display:flex;gap:.5rem;align-items:center}.btn-small{padding:.5rem .75rem;font-size:.8rem;border-radius:8px;font-weight:600;transition:all .2s cubic-bezier(.4,0,.2,1);border:none;cursor:pointer;display:inline-flex;align-items:center;gap:.25rem;min-height:2rem}.btn-small.btn-primary{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;box-shadow:0 2px 4px #3b82f633}.btn-small.btn-primary:hover{background:linear-gradient(135deg,#2563eb,#1d4ed8);box-shadow:0 4px 12px #3b82f666}.btn-small.btn-secondary{background:linear-gradient(135deg,#6b7280,#4b5563);color:#fff;box-shadow:0 2px 4px #6b728033}.btn-small.btn-secondary:hover{background:linear-gradient(135deg,#4b5563,#374151);box-shadow:0 4px 12px #6b728066}.btn-small.btn-danger{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;box-shadow:0 2px 4px #ef444433}.btn-small.btn-danger:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);box-shadow:0 4px 12px #ef444466}.btn-small.btn-bonus{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff;box-shadow:0 2px 4px #f59e0b33}.btn-small.btn-bonus:hover{background:linear-gradient(135deg,#d97706,#b45309);box-shadow:0 4px 12px #f59e0b66}@media (max-width: 768px){.edit-time-form .form-row{grid-template-columns:1fr;gap:.75rem}.edit-time-form input,.edit-time-form select{padding:.875rem;font-size:1rem}.time-actions{flex-direction:column;gap:.5rem}.btn-small{width:100%;padding:.75rem;font-size:.9rem}.calculated-points{padding:1.25rem}.points-value{font-size:1.75rem}}.user-management-page{min-height:100vh;background:linear-gradient(180deg,#f8fafc,#f1f5f9);padding:2rem}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;padding-bottom:1rem;border-bottom:2px solid rgba(26,54,93,.1)}.page-header h1{margin:0;color:var(--navy);font-size:2rem;font-weight:700}.access-denied{text-align:center;padding:4rem 2rem;background:var(--white);border-radius:16px;box-shadow:0 8px 32px #00000014;max-width:500px;margin:2rem auto}.access-denied h2{color:var(--navy);margin-bottom:1rem}.user-management-content{background:var(--white);border-radius:16px;box-shadow:0 8px 32px #00000014;overflow:hidden}.user-management-header{display:flex;justify-content:space-between;align-items:center;padding:2rem;background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);color:var(--white)}.user-management-header h2{margin:0;font-size:1.5rem;font-weight:600}.users-table-container{overflow-x:auto;padding:0}.users-table{width:100%;border-collapse:collapse;background:var(--white)}.users-table thead{background:linear-gradient(135deg,#f8fafc,#e2e8f0)}.users-table th{padding:1.5rem 1rem;text-align:left;font-weight:600;color:var(--navy);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid rgba(26,54,93,.1)}.users-table td{padding:1.5rem 1rem;border-bottom:1px solid rgba(26,54,93,.05);vertical-align:middle}.users-table tr:hover{background:linear-gradient(135deg,#1a365d05,#1e3a8a05)}.users-table tr.inactive{opacity:.6}.user-info{display:flex;align-items:center;gap:1rem}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--navy) 0%,#1e3a8a 100%);display:flex;align-items:center;justify-content:center;font-size:1.5rem;color:var(--white);box-shadow:0 4px 12px #1a365d33}.user-details{flex:1}.user-name{font-weight:600;color:var(--navy);font-size:1rem;margin-bottom:.25rem}.user-username{color:var(--text-secondary);font-size:.85rem;margin-bottom:.25rem}.user-email{color:var(--text-muted);font-size:.8rem}.role-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;color:var(--white);font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.status-badge{padding:.5rem 1rem;border-radius:20px;font-weight:600;font-size:.8rem;text-transform:uppercase;letter-spacing:.5px}.status-badge.active{background:linear-gradient(135deg,#10b981,#059669);color:var(--white)}.status-badge.inactive{background:linear-gradient(135deg,#ef4444,#dc2626);color:var(--white)}.last-active{color:var(--text-secondary);font-size:.9rem}.user-actions{display:flex;gap:.5rem;flex-wrap:wrap}.user-form-modal{max-width:600px;width:90vw}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1rem}.error-message{background:linear-gradient(135deg,#fee2e2,#fecaca);color:#dc2626;padding:1rem;border-radius:8px;margin-bottom:1rem;border:1px solid #FECACA;font-weight:500}@media (max-width: 768px){.user-management-page{padding:1rem}.page-header{flex-direction:column;gap:1rem;align-items:flex-start}.page-header h1{font-size:1.5rem}.user-management-header{flex-direction:column;gap:1rem;align-items:flex-start;padding:1.5rem}.form-row{grid-template-columns:1fr}.user-info{flex-direction:column;align-items:flex-start;gap:.5rem}.user-avatar{width:40px;height:40px;font-size:1.2rem}.users-table th,.users-table td{padding:1rem .5rem}.user-actions{flex-direction:column;gap:.25rem}.user-actions .btn{font-size:.75rem;padding:.5rem .75rem}}@media (min-width: 1400px){.app-main{max-width:1600px;padding:4rem 3rem}.swimmer-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:2rem}.swimmer-card{padding:2.5rem}.leaderboard-table-container,.rankings-table-container{padding:3rem}.nav-btn{padding:1.5rem 3rem;font-size:1.1rem}.app-header{padding:3rem 2rem}.app-header h1{font-size:3rem}.subtitle{font-size:1.25rem}}@media (min-width: 1920px){.app-main{max-width:1800px;padding:5rem 4rem}.swimmer-grid{grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:2.5rem}.leaderboard-table-container,.rankings-table-container{padding:4rem}.leaderboard-table th,.leaderboard-table td,.rankings-table th,.rankings-table td{padding:1.5rem}}@media (max-width: 768px){.swimmer-profile-modal{padding:.5rem}.swimmer-profile-modal .modal-content.large{max-width:100vw;width:100vw;max-height:100vh;height:100vh;border-radius:0;margin:0;padding:0;overflow-y:auto;-webkit-overflow-scrolling:touch}.swimmer-profile-content{padding:1rem;width:100%;max-width:100%}.profile-header{position:sticky;top:0;z-index:10;background:#fff;border-bottom:1px solid var(--border);padding:1rem;margin:0 -1rem 1rem}.profile-tabs{position:sticky;top:0;z-index:9;background:#fff;border-bottom:1px solid var(--border);margin:0 -1rem 1rem;padding:0 1rem}.times-table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.times-table{min-width:600px}}@media (max-width: 480px){.swimmer-profile-modal{padding:0}.swimmer-profile-modal .modal-content.large{border-radius:0;width:100vw;height:100vh}.swimmer-profile-content{padding:.5rem}.profile-header{padding:.75rem;margin:0 -.5rem .75rem}.profile-tabs{padding:0 .5rem;margin:0 -.5rem .75rem}}@media (min-width: 769px) and (max-width: 1024px){.swimmer-profile-modal .modal-content.large{max-width:90vw;width:90vw;max-height:90vh}}@media (min-width: 1025px){.swimmer-profile-modal .modal-content.large{max-width:min(1200px,90vw);width:90vw;max-height:90vh}}.swimmer-profile-modal{display:flex!important;align-items:center!important;justify-content:center!important;position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;z-index:10000!important}.swimmer-profile-modal .modal-content.large{position:relative!important;margin:auto!important;transform:none!important;top:auto!important;left:auto!important;right:auto!important;bottom:auto!important}@media (max-width: 320px){.swimmer-profile-modal{padding:0}.swimmer-profile-modal .modal-content.large{width:100vw;height:100vh;border-radius:0;max-width:100vw;max-height:100vh}}@media (max-width: 768px) and (orientation: landscape){.swimmer-profile-modal .modal-content.large{max-height:100vh;height:100vh}}.swimmer-profile-page{min-height:100vh;background:linear-gradient(135deg,#f8fafc,#e2e8f0);display:flex;flex-direction:column;font-family:Cairo,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.page-header{background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);border-bottom:1px solid var(--border-light);box-shadow:0 2px 8px #0000001a;position:sticky;top:0;z-index:100;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px)}.header-content{display:flex;align-items:center;gap:1rem;padding:1rem 1.5rem;max-width:1200px;margin:0 auto}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:var(--white);border:1px solid var(--border);border-radius:8px;color:var(--text-primary);text-decoration:none;font-weight:500;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000001a}.back-button:hover{background:var(--navy-50);color:var(--navy);border-color:var(--navy);transform:translateY(-1px);box-shadow:0 4px 8px #00000026}.back-button:active{transform:translateY(0);box-shadow:0 2px 4px #0000001a}.page-header h1{font-size:1.75rem;font-weight:700;color:var(--navy);margin:0;text-shadow:0 1px 2px rgba(30,58,138,.1)}.page-content{flex:1;padding:2rem 1.5rem;max-width:1200px;margin:0 auto;width:100%;box-sizing:border-box}@media (max-width: 768px){.page-header{position:sticky;top:0;z-index:100}.header-content{padding:1rem;gap:.75rem}.back-button{padding:.5rem .75rem;font-size:.9rem}.page-header h1{font-size:1.5rem}.page-content{padding:1rem}.swimmer-profile-content{width:100%;max-width:100%}.profile-header{margin:0 -1rem 1.5rem;padding:1.5rem 1rem;background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);border-radius:0}.swimmer-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}.stat-card{padding:.75rem}.stat-value{font-size:1.25rem}.stat-label{font-size:.8rem}.profile-tabs{margin:0 -1rem 1.5rem;padding:0 1rem;background:var(--white);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:10}.tab-btn{padding:.75rem 1rem;font-size:.9rem}.times-table-container{margin:0 -1rem;border-radius:0;overflow-x:auto;-webkit-overflow-scrolling:touch}.times-table{min-width:600px;font-size:.9rem}.times-table th,.times-table td{padding:.75rem .5rem}}@media (max-width: 480px){.header-content{padding:.75rem}.page-header h1{font-size:1.25rem}.page-content{padding:.75rem}.profile-header{margin:0 -.75rem 1rem;padding:1rem .75rem}.swimmer-stats-grid{grid-template-columns:1fr;gap:.5rem}.profile-tabs{margin:0 -.75rem 1rem;padding:0 .75rem}.times-table-container{margin:0 -.75rem}}.page-header{background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);border-bottom:1px solid var(--border-light);box-shadow:0 4px 12px #00000014;position:sticky;top:0;z-index:100;backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px)}.header-content{display:flex;align-items:center;gap:1.5rem;padding:1.5rem 2rem;max-width:1200px;margin:0 auto}.back-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--white);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);text-decoration:none;font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;min-height:44px;min-width:44px}.back-button:hover{background:var(--navy-50);color:var(--navy);border-color:var(--navy);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.back-icon{font-size:1.2rem;font-weight:700}.back-text{font-size:.95rem}.header-title h1{font-size:2rem;font-weight:700;color:var(--navy);margin:0 0 .25rem;text-shadow:0 1px 2px rgba(30,58,138,.1)}.header-subtitle{font-size:1rem;color:var(--text-secondary);margin:0;font-weight:500}.profile-hero{background:linear-gradient(135deg,var(--white) 0%,var(--navy-50) 100%);border-radius:var(--radius-xl);padding:var(--space-10);margin-bottom:var(--space-8);box-shadow:var(--shadow-lg);border:1px solid var(--border-light);position:relative;overflow:hidden}.profile-hero:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy-500) 0%,var(--navy-700) 50%,var(--navy-500) 100%)}.hero-content{display:flex;flex-direction:column;gap:var(--space-6)}.hero-primary{display:flex;align-items:center;justify-content:space-between;gap:var(--space-6)}.swimmer-identity{display:flex;align-items:center;gap:var(--space-4)}.swimmer-identity-info{display:flex;flex-direction:column;gap:var(--space-2)}.swimmer-name{font-size:var(--font-size-4xl);font-weight:var(--font-weight-bold);color:var(--navy);margin:0;line-height:var(--line-height-tight)}.swimmer-meta-compact{display:flex;gap:var(--space-4);flex-wrap:wrap}.meta-item-compact{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.hero-secondary{display:flex;justify-content:space-between;align-items:center;padding-top:var(--space-4);border-top:1px solid var(--border-light)}.group-info{display:flex;flex-direction:column;gap:var(--space-1)}.group-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.group-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.hero-content{display:flex;align-items:center;justify-content:space-between;gap:2rem}.swimmer-avatar-section{display:flex;align-items:center;gap:1.5rem}.avatar-container{position:relative}.avatar-circle{width:80px;height:80px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--navy-500) 0%,var(--navy-700) 100%);display:flex;align-items:center;justify-content:center;box-shadow:var(--shadow-colored);position:relative}.avatar-initial{font-size:2rem;font-weight:700;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.2)}.avatar-badge{position:absolute;bottom:-8px;right:-8px;padding:.5rem 1rem;border-radius:20px;color:#fff;font-size:.8rem;font-weight:600;box-shadow:0 4px 12px #0003;border:2px solid white}.swimmer-basic-info{flex:1}.swimmer-name{font-size:2.5rem;font-weight:700;color:var(--navy);margin:0 0 1rem;text-shadow:0 1px 2px rgba(30,58,138,.1)}.swimmer-meta{display:flex;gap:2rem;flex-wrap:wrap}.meta-item{display:flex;align-items:center;gap:.5rem;font-size:1rem;color:var(--text-secondary);font-weight:500}.meta-icon{font-size:1.2rem}.rank-display{display:flex;align-items:center}.rank-badge{background:linear-gradient(135deg,#fbbf24,#f59e0b);color:#fff;padding:1rem 1.5rem;border-radius:16px;text-align:center;box-shadow:0 8px 24px #fbbf244d;border:2px solid rgba(255,255,255,.2)}.rank-number{display:block;font-size:2rem;font-weight:700;line-height:1;margin-bottom:.25rem}.rank-label{font-size:.9rem;font-weight:600;opacity:.9}.stats-dashboard{margin-bottom:var(--space-6)}.stats-header{margin-bottom:var(--space-4);text-align:left}.stats-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-semibold);color:var(--navy);margin:0 0 var(--space-1) 0}.stats-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0;font-weight:var(--font-weight-medium)}.stats-grid{display:grid;grid-template-columns:2fr 1fr 1fr 1fr;gap:var(--space-4)}.stat-card{background:var(--white);padding:var(--space-5);border-radius:var(--radius-md);border:1px solid var(--border-light);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-2);transition:var(--transition-normal);text-align:center}.stat-primary{background:var(--navy);color:var(--white);border:1px solid var(--navy-500);box-shadow:var(--shadow)}.stat-primary .stat-value{color:var(--white);font-size:var(--font-size-3xl)}.stat-primary .stat-label{color:var(--white);opacity:.9}.stat-primary .stat-description{color:var(--white);opacity:.8}.stat-secondary{background:var(--white);border:1px solid var(--border-light)}.stat-secondary:hover{border-color:var(--navy-300);box-shadow:var(--shadow)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:0;transition:opacity .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 8px 24px #0000001f}.stat-card:hover:before{opacity:1}.stat-card.primary:before{background:linear-gradient(90deg,#3b82f6,#1d4ed8);opacity:1}.stat-card.highlight{background:linear-gradient(135deg,var(--warning-light) 0%,var(--warning) 100%);border-color:var(--warning)}.stat-card.highlight:before{background:linear-gradient(90deg,#f59e0b,#d97706);opacity:1}.stat-icon{font-size:2rem;opacity:.8}.stat-content{display:flex;flex-direction:column;gap:var(--space-2)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--navy);line-height:var(--line-height-tight);margin:0}.stat-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;margin:0}.stat-description{font-size:var(--font-size-xs);color:var(--text-muted);font-weight:var(--font-weight-medium);line-height:var(--line-height-snug);margin:0}.profile-navigation{margin-bottom:var(--space-8)}.nav-tabs{display:flex;background:var(--white);border-radius:var(--radius-xl);padding:var(--space-2);box-shadow:var(--shadow);border:1px solid var(--border-light);overflow-x:auto;-webkit-overflow-scrolling:touch;scrollbar-width:none;-ms-overflow-style:none}.nav-tabs::-webkit-scrollbar{display:none}.nav-tab{flex:1;display:flex;align-items:center;justify-content:center;gap:var(--space-3);padding:var(--space-4) var(--space-5);border:none;background:transparent;border-radius:var(--radius-lg);cursor:pointer;transition:var(--transition-normal);font-weight:var(--font-weight-semibold);color:var(--text-secondary);min-height:48px;min-width:48px;position:relative;touch-action:manipulation;-webkit-tap-highlight-color:transparent}.nav-tab:hover{background:var(--navy-50);color:var(--navy)}.nav-tab.active{background:linear-gradient(135deg,var(--navy) 0%,#1d4ed8 100%);color:#fff;box-shadow:0 4px 12px #1e3a8a4d}.tab-icon{font-size:1.2rem}.tab-label{font-size:1rem;font-weight:600}.tab-count{font-size:.85rem;opacity:.8;background:#fff3;padding:.25rem .5rem;border-radius:8px;margin-left:auto}.nav-tab.active .tab-count{background:#ffffff4d}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;gap:1rem}.section-title h3{font-size:1.5rem;font-weight:700;color:var(--navy);margin:0 0 .25rem}.section-subtitle{font-size:1rem;color:var(--text-secondary);margin:0;font-weight:500}.filter-toggle-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:var(--white);border:1px solid var(--border);border-radius:12px;color:var(--text-primary);font-weight:600;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 8px #0000001a;min-height:44px}.filter-toggle-btn:hover{background:var(--navy-50);color:var(--navy);border-color:var(--navy);transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.filter-toggle-btn.expanded{background:var(--navy);color:#fff;border-color:var(--navy)}.filter-icon{font-size:1.1rem}.filter-text{font-size:.95rem}.filter-arrow{font-size:.8rem;transition:transform .2s ease}.filter-arrow.expanded{transform:rotate(180deg)}.times-section{background:var(--white);border-radius:16px;padding:2rem;box-shadow:0 4px 16px #00000014;border:1px solid var(--border-light)}.times-filters{background:var(--navy-50);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem;transition:all .3s ease;overflow:hidden}.times-filters.collapsed{max-height:0;padding:0 1.5rem;margin-bottom:0}.times-filters.expanded{max-height:200px}.filter-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem}.filter-group{display:flex;flex-direction:column;gap:.5rem}.filter-group label{font-weight:600;color:var(--navy);font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.filter-group select{padding:.75rem 1rem;border:1px solid var(--border);border-radius:8px;background:var(--white);color:var(--text-primary);font-weight:500;cursor:pointer;transition:all .2s ease}.filter-group select:focus{outline:none;border-color:var(--navy);box-shadow:0 0 0 3px #1e3a8a1a}.times-grid-container{margin-top:var(--space-6)}.times-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-6)}.time-card{background:linear-gradient(135deg,var(--white) 0%,var(--gray-50) 100%);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:var(--shadow);transition:var(--transition-normal);position:relative;overflow:hidden}.time-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--navy-500) 0%,var(--navy-700) 100%);opacity:0;transition:opacity var(--transition-normal)}.time-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-lg)}.time-card:hover:before{opacity:1}.time-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-4);gap:var(--space-3)}.event-info{display:flex;flex-direction:column;gap:var(--space-1)}.event-stroke{font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);color:var(--navy)}.event-distance{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.event-course{font-size:var(--font-size-sm);color:var(--text-secondary);background:var(--gray-100);padding:var(--space-1) var(--space-2);border-radius:var(--radius);display:inline-block}.time-date{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium)}.time-card-body{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-bottom:var(--space-4)}.time-display,.points-display{display:flex;flex-direction:column;align-items:center;text-align:center}.time-value,.points-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--navy);font-family:Cairo,monospace;line-height:1;margin-bottom:var(--space-1)}.time-label,.points-label{font-size:var(--font-size-sm);color:var(--text-secondary);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.time-card-actions{display:flex;gap:var(--space-2);justify-content:center;padding-top:var(--space-4);border-top:1px solid var(--border-light)}.attendance-analytics-dashboard{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-light);position:relative}.attendance-analytics-dashboard:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,var(--navy) 0%,#1d4ed8 50%,var(--navy) 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.analytics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-4)}.analytics-card{background:var(--white);border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:0 2px 4px #0000000d;display:flex;align-items:center;gap:var(--space-4);transition:all .2s ease;position:relative;overflow:hidden}.analytics-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--navy-200);opacity:0;transition:opacity .2s ease}.analytics-card:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:var(--navy-300)}.analytics-card:hover:before{opacity:1}.analytics-card.primary{background:linear-gradient(135deg,var(--navy) 0%,#1d4ed8 100%);color:var(--white);border-color:var(--navy);box-shadow:0 4px 12px #1e3a8a4d}.analytics-card.primary:before{background:var(--white);opacity:.2}.analytics-card.primary:hover{box-shadow:0 8px 25px #1e3a8a66}.analytics-card .card-icon{font-size:2rem;opacity:.9;filter:drop-shadow(0 1px 2px rgba(0,0,0,.1))}.analytics-card .card-content{flex:1}.analytics-card .card-value{font-size:1.8rem;font-weight:var(--font-weight-bold);line-height:1.1;margin-bottom:var(--space-1);color:inherit;text-shadow:0 1px 2px rgba(0,0,0,.1)}.analytics-card.primary .card-value{color:var(--white)!important;text-shadow:0 1px 2px rgba(0,0,0,.3)}.analytics-card .card-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-1);opacity:.9}.analytics-card.primary .card-label{color:var(--white)!important;opacity:.9}.analytics-card .card-subtitle{font-size:var(--font-size-xs);opacity:.8;line-height:1.3}.analytics-card.primary .card-subtitle{color:var(--white)!important;opacity:.8}.attendance-grid-enhanced{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:var(--space-4)}.attendance-card-enhanced{background:var(--white);border:2px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:0 2px 4px #0000000d;transition:all .2s ease;position:relative;overflow:hidden}.attendance-card-enhanced:hover{transform:translateY(-2px);box-shadow:0 8px 25px #0000001a;border-color:var(--navy-300)}.attendance-card-enhanced.recent{border-left:4px solid #059669;background:var(--white);border-color:#bbf7d0;box-shadow:0 4px 12px #10b98126}.attendance-card-enhanced.recent:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#10b981,#059669)}.recent-badge{position:absolute;top:var(--space-3);right:var(--space-3);background:#059669;color:var(--white);padding:var(--space-1) var(--space-2);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.5px;box-shadow:0 2px 4px #0596694d}.status-badge-enhanced{padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.5px;border:2px solid transparent;box-shadow:0 2px 4px #0000001a;transition:all .2s ease}.status-badge-enhanced:hover{transform:scale(1.05);box-shadow:0 4px 8px #00000026}.status-badge-enhanced.present{background:#dcfce7;color:#14532d;border-color:#bbf7d0;box-shadow:0 2px 4px #22c55e33}.status-badge-enhanced.late{background:#fef3c7;color:#92400e;border-color:#fde68a;box-shadow:0 2px 4px #f59e0b33}.status-badge-enhanced.absent{background:#fee2e2;color:#991b1b;border-color:#fecaca;box-shadow:0 2px 4px #ef444433}.bonus-section-enhanced{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-6);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-light);position:relative;overflow:hidden}.bonus-section-enhanced:before{content:"";position:absolute;top:0;left:0;right:0;height:4px;background:linear-gradient(90deg,#8b5cf6,#7c3aed,#8b5cf6);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.bonus-points-history-enhanced{margin-top:var(--space-4)}.bonus-dashboard{background:var(--white);border-radius:var(--radius-lg);padding:var(--space-6);margin-bottom:var(--space-6);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;border:1px solid var(--border-light);position:relative}.bonus-dashboard:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,#8b5cf6,#7c3aed);border-radius:var(--radius-lg) var(--radius-lg) 0 0}.dashboard-header h3{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--navy);margin:0 0 var(--space-2) 0;text-shadow:0 1px 2px rgba(0,0,0,.1)}.dashboard-subtitle{color:var(--text-secondary);font-size:var(--font-size-base);margin:0;line-height:1.5}@media (max-width: 768px){.attendance-analytics-dashboard{padding:var(--space-4);margin-bottom:var(--space-4)}.bonus-section-enhanced{padding:var(--space-4)}.bonus-dashboard{padding:var(--space-4);margin-bottom:var(--space-4)}.analytics-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.analytics-card{padding:var(--space-4);flex-direction:column;text-align:center;border-width:1px}.analytics-card .card-icon{font-size:1.5rem;margin-bottom:var(--space-2)}.analytics-card .card-value{font-size:1.5rem;margin-bottom:var(--space-1)}.analytics-card .card-label{font-size:var(--font-size-xs);margin-bottom:var(--space-1)}.analytics-card .card-subtitle{font-size:.75rem;line-height:1.2}.attendance-grid-enhanced{grid-template-columns:1fr;gap:var(--space-3)}.attendance-card-enhanced{padding:var(--space-4);border-width:1px}.status-badge-enhanced{font-size:var(--font-size-xs);padding:var(--space-1) var(--space-2)}.recent-badge{font-size:.7rem;padding:var(--space-1)}}@media (max-width: 480px){.analytics-grid{grid-template-columns:1fr;gap:var(--space-3)}.analytics-card{padding:var(--space-3);border-width:1px}.analytics-card .card-value{font-size:1.25rem}.attendance-card-enhanced{padding:var(--space-3)}.status-badge-enhanced{font-size:.7rem;padding:var(--space-1)}}@media (prefers-contrast: high){.analytics-card{border-width:3px;border-color:var(--navy)}.analytics-card.primary{border-color:var(--white);box-shadow:0 0 0 3px var(--navy)}.attendance-card-enhanced{border-width:2px;border-color:var(--navy-300)}.status-badge-enhanced{border-width:3px;font-weight:var(--font-weight-extrabold)}.status-badge-enhanced.present{background:#10b981;color:var(--white);border-color:#059669}.status-badge-enhanced.late{background:#f59e0b;color:var(--white);border-color:#d97706}.status-badge-enhanced.absent{background:#ef4444;color:var(--white);border-color:#dc2626}}.analytics-card:focus-visible{outline:3px solid var(--navy);outline-offset:2px}.attendance-card-enhanced:focus-visible{outline:3px solid var(--navy);outline-offset:2px}.status-badge-enhanced:focus-visible{outline:3px solid var(--navy);outline-offset:2px}@media (prefers-reduced-motion: reduce){.analytics-card,.attendance-card-enhanced,.status-badge-enhanced{transition:none}.analytics-card:hover,.attendance-card-enhanced:hover,.status-badge-enhanced:hover{transform:none}}.attendance-card{background:linear-gradient(135deg,var(--white) 0%,var(--gray-50) 100%);border:1px solid var(--border-light);border-radius:var(--radius-lg);padding:var(--space-5);box-shadow:var(--shadow);transition:var(--transition-normal)}.attendance-card:hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.attendance-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3)}.attendance-date{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.status-badge{padding:var(--space-2) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.5px}.status-badge.present{background:linear-gradient(135deg,var(--success-light) 0%,var(--success) 100%);color:#fff}.status-badge.late{background:linear-gradient(135deg,var(--warning-light) 0%,var(--warning) 100%);color:#fff}.status-badge.absent{background:linear-gradient(135deg,var(--error-light) 0%,var(--error) 100%);color:#fff}.attendance-comment{background:var(--gray-50);padding:var(--space-3);border-radius:var(--radius);border-left:3px solid var(--navy-500)}.comment-label{font-weight:var(--font-weight-semibold);color:var(--navy);margin-right:var(--space-2)}.empty-state{text-align:center;padding:var(--space-12) var(--space-6);color:var(--text-secondary)}.empty-icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.5}.empty-state p{font-size:var(--font-size-lg);font-weight:var(--font-weight-medium);margin-bottom:var(--space-2)}.empty-subtitle{font-size:var(--font-size-base);color:var(--text-muted)}@media (max-width: 768px){.header-content{padding:1rem;gap:1rem}.back-button{padding:.5rem 1rem;font-size:.9rem}.back-text{display:none}.header-title h1{font-size:1.5rem}.header-subtitle{font-size:.9rem}.profile-hero{padding:1.5rem;margin-bottom:1.5rem}.hero-content{flex-direction:column;gap:1.5rem;text-align:center}.swimmer-avatar-section{flex-direction:column;gap:1rem}.swimmer-name{font-size:2rem}.swimmer-meta{justify-content:center;gap:1rem}.stats-grid{grid-template-columns:repeat(2,1fr);gap:1rem}.stat-card{padding:1.5rem 1rem;flex-direction:column;text-align:center;gap:.75rem}.stat-icon,.stat-value{font-size:1.5rem}.nav-tabs{flex-direction:column;gap:.5rem}.nav-tab{justify-content:center;padding:1rem}.times-section{padding:1.5rem}.filter-content{grid-template-columns:1fr;gap:1rem}.times-grid{grid-template-columns:1fr;gap:var(--space-4)}.time-card{padding:var(--space-5)}.time-card-body{grid-template-columns:1fr;gap:var(--space-3);text-align:center}.time-card-actions{flex-direction:column;gap:var(--space-2)}.attendance-analytics-dashboard{padding:var(--space-4);margin-bottom:var(--space-4)}.analytics-grid{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.analytics-card{padding:var(--space-4);flex-direction:column;text-align:center;gap:var(--space-2)}.analytics-card .card-icon,.analytics-card .card-value{font-size:1.5rem}.attendance-grid-enhanced{grid-template-columns:1fr;gap:var(--space-3)}.attendance-card-enhanced{padding:var(--space-4)}.attendance-card-header{flex-direction:column;align-items:flex-start;gap:var(--space-2)}.recent-badge{position:static;margin-top:var(--space-2);align-self:flex-start}}@media (max-width: 480px){.profile-hero{padding:1rem}.swimmer-name{font-size:1.75rem}.stats-grid{grid-template-columns:1fr;gap:var(--space-4)}.stat-card{padding:var(--space-5)}.stat-primary{order:-1}.hero-primary{flex-direction:column;align-items:flex-start;gap:var(--space-4)}.swimmer-identity{width:100%;justify-content:space-between}.hero-secondary{flex-direction:column;align-items:flex-start;gap:var(--space-3)}.times-section{padding:1rem}.section-header{flex-direction:column;align-items:stretch;gap:1rem}}
