@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";:root{--color-primary: hsl(220, 90%, 56%);--color-primary-dark: hsl(220, 90%, 46%);--color-primary-light: hsl(220, 90%, 96%);--color-secondary: hsl(280, 70%, 60%);--color-secondary-dark: hsl(280, 70%, 50%);--color-secondary-light: hsl(280, 70%, 96%);--color-success: hsl(142, 71%, 45%);--color-success-light: hsl(142, 71%, 96%);--color-warning: hsl(38, 92%, 50%);--color-warning-light: hsl(38, 92%, 96%);--color-danger: hsl(0, 84%, 60%);--color-danger-light: hsl(0, 84%, 96%);--color-info: hsl(199, 89%, 48%);--color-info-light: hsl(199, 89%, 96%);--color-white: hsl(0, 0%, 100%);--color-gray-50: hsl(220, 20%, 98%);--color-gray-100: hsl(220, 16%, 96%);--color-gray-200: hsl(220, 13%, 91%);--color-gray-300: hsl(220, 10%, 80%);--color-gray-400: hsl(220, 9%, 60%);--color-gray-500: hsl(220, 9%, 46%);--color-gray-600: hsl(220, 12%, 36%);--color-gray-700: hsl(220, 16%, 26%);--color-gray-800: hsl(220, 20%, 16%);--color-gray-900: hsl(220, 24%, 10%);--bg-primary: var(--color-white);--bg-secondary: var(--color-gray-50);--bg-tertiary: var(--color-gray-100);--bg-dark: var(--color-gray-900);--text-primary: var(--color-gray-900);--text-secondary: var(--color-gray-600);--text-tertiary: var(--color-gray-500);--text-inverse: var(--color-white);--border-light: var(--color-gray-200);--border-medium: var(--color-gray-300);--border-dark: var(--color-gray-400);--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;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", "Roboto", sans-serif;--font-mono: "Fira Code", "Courier New", monospace;--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-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-xl: 1rem;--radius-2xl: 1.5rem;--radius-full: 9999px;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1), 0 10px 10px -5px rgba(0, 0, 0, .04);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .25);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .2s cubic-bezier(.4, 0, .2, 1);--transition-slow: .3s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--bg-secondary);min-height:100vh}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-bold);line-height:var(--line-height-tight);color:var(--text-primary)}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}h4{font-size:var(--font-size-xl)}h5{font-size:var(--font-size-lg)}h6{font-size:var(--font-size-base)}p{margin-bottom:var(--space-4)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}.container{width:100%;max-width:1280px;margin:0 auto;padding:0 var(--space-6)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-2xl{font-size:var(--font-size-2xl)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-danger{color:var(--color-danger)}.mb-2{margin-bottom:var(--space-2)}.mb-4{margin-bottom:var(--space-4)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{transform:translate(-100%)}to{transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-fade-in{animation:fadeIn var(--transition-base) ease-out}.animate-slide-in{animation:slideIn var(--transition-slow) ease-out}.animate-spin{animation:spin 1s linear infinite}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--color-gray-400);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--color-gray-500)}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}::selection{background-color:var(--color-primary-light);color:var(--color-primary-dark)}.spinner-wrapper{display:flex;align-items:center;justify-content:center;padding:var(--space-4)}.spinner{border-radius:50%;border-style:solid;border-top-color:transparent;animation:spin .8s linear infinite}.spinner-sm{width:20px;height:20px;border-width:2px}.spinner-md{width:40px;height:40px;border-width:3px}.spinner-lg{width:60px;height:60px;border-width:4px}.spinner-primary{border-color:var(--color-primary);border-top-color:transparent}.spinner-secondary{border-color:var(--color-secondary);border-top-color:transparent}.spinner-white{border-color:var(--color-white);border-top-color:transparent}.input-wrapper{display:flex;flex-direction:column;gap:var(--space-2);width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.input-required{color:var(--color-danger);margin-left:var(--space-1)}.input-container{position:relative;display:flex;align-items:center}.input{width:100%;padding:var(--space-3) var(--space-4);font-size:var(--font-size-base);font-family:var(--font-sans);color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--border-medium);border-radius:var(--radius-md);transition:all var(--transition-fast)}.input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light)}.input::placeholder{color:var(--text-tertiary)}.input-with-icon{padding-left:var(--space-10)}.input-icon{position:absolute;left:var(--space-3);display:flex;align-items:center;justify-content:center;color:var(--text-tertiary);pointer-events:none}.input-error{border-color:var(--color-danger)}.input-error:focus{border-color:var(--color-danger);box-shadow:0 0 0 3px var(--color-danger-light)}.input-error-message{font-size:var(--font-size-sm);color:var(--color-danger)}.input:disabled{background:var(--bg-tertiary);cursor:not-allowed;opacity:.6}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);font-family:var(--font-sans);font-weight:var(--font-weight-medium);border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;position:relative;overflow:hidden}.btn:disabled{opacity:.6;cursor:not-allowed}.btn:not(:disabled):hover{transform:translateY(-1px);box-shadow:var(--shadow-md)}.btn:not(:disabled):active{transform:translateY(0)}.btn-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%);color:var(--color-white)}.btn-primary:not(:disabled):hover{background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-primary) 100%)}.btn-secondary{background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-dark) 100%);color:var(--color-white)}.btn-secondary:not(:disabled):hover{background:linear-gradient(135deg,var(--color-secondary-dark) 0%,var(--color-secondary) 100%)}.btn-success{background:var(--color-success);color:var(--color-white)}.btn-success:not(:disabled):hover{background:#1eae53}.btn-danger{background:var(--color-danger);color:var(--color-white)}.btn-danger:not(:disabled):hover{background:#ed2c2c}.btn-ghost{background:transparent;color:var(--color-primary);border:1px solid var(--border-light)}.btn-ghost:not(:disabled):hover{background:var(--color-primary-light);border-color:var(--color-primary)}.btn-outline{background:transparent;color:var(--color-primary);border:2px solid var(--color-primary)}.btn-outline:not(:disabled):hover{background:var(--color-primary);color:var(--color-white)}.btn-sm{padding:var(--space-2) var(--space-3);font-size:var(--font-size-sm)}.btn-md{padding:var(--space-3) var(--space-5);font-size:var(--font-size-base)}.btn-lg{padding:var(--space-4) var(--space-6);font-size:var(--font-size-lg)}.btn-full-width{width:100%}.btn-loading{pointer-events:none}.btn-spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.btn-icon{display:flex;align-items:center;justify-content:center}.btn-text{display:flex;align-items:center}.alert{display:flex;align-items:flex-start;gap:var(--space-3);padding:var(--space-4);border-radius:var(--radius-md);border-left:4px solid;animation:fadeIn var(--transition-base) ease-out}.alert-icon{flex-shrink:0;display:flex;align-items:center;justify-content:center}.alert-content{flex:1}.alert-title{font-weight:var(--font-weight-semibold);margin-bottom:var(--space-1)}.alert-message{font-size:var(--font-size-sm)}.alert-close{flex-shrink:0;background:none;border:none;cursor:pointer;padding:var(--space-1);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;transition:background var(--transition-fast)}.alert-close:hover{background:#0000001a}.alert-success{background:var(--color-success-light);border-left-color:var(--color-success);color:#16833e}.alert-success .alert-icon{color:var(--color-success)}.alert-error{background:var(--color-danger-light);border-left-color:var(--color-danger);color:#bc1010}.alert-error .alert-icon{color:var(--color-danger)}.alert-warning{background:var(--color-warning-light);border-left-color:var(--color-warning);color:#935f06}.alert-warning .alert-icon{color:var(--color-warning)}.alert-info{background:var(--color-info-light);border-left-color:var(--color-info);color:#086591}.alert-info .alert-icon{color:var(--color-info)}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-6);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);position:relative;overflow:hidden}.auth-container:before{content:"";position:absolute;top:-50%;right:-50%;width:100%;height:100%;background:radial-gradient(circle,rgba(255,255,255,.1) 0%,transparent 70%);animation:pulse 8s ease-in-out infinite}.auth-card{width:100%;max-width:450px;background:var(--bg-primary);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);padding:var(--space-10);position:relative;z-index:1;animation:fadeIn var(--transition-slow) ease-out}.auth-header{text-align:center;margin-bottom:var(--space-8)}.auth-logo{width:80px;height:80px;margin:0 auto var(--space-4);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-4xl);box-shadow:var(--shadow-lg)}.auth-title{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.auth-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.auth-form{display:flex;flex-direction:column;gap:var(--space-5)}.auth-forgot{text-align:right;margin-top:calc(var(--space-2) * -1)}.auth-link{color:var(--color-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);text-decoration:none;transition:color var(--transition-fast)}.auth-link:hover{color:var(--color-primary-dark);text-decoration:underline}.auth-footer{margin-top:var(--space-6);padding-top:var(--space-6);border-top:1px solid var(--border-light);text-align:center;color:var(--text-secondary);font-size:var(--font-size-sm)}.auth-divider{display:flex;align-items:center;gap:var(--space-4);margin:var(--space-6) 0;color:var(--text-tertiary);font-size:var(--font-size-sm)}.auth-divider:before,.auth-divider:after{content:"";flex:1;height:1px;background:var(--border-light)}.role-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-6);margin-bottom:var(--space-6)}.role-card{cursor:pointer;transition:all var(--transition-base);text-align:center;padding:var(--space-6)!important}.role-card:hover{transform:translateY(-8px);box-shadow:var(--shadow-xl)}.role-icon{width:80px;height:80px;margin:0 auto var(--space-4);border-radius:var(--radius-xl);display:flex;align-items:center;justify-content:center;color:var(--color-white)}.role-icon-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.role-icon-secondary{background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-dark) 100%)}.role-icon-success{background:linear-gradient(135deg,var(--color-success) 0%,hsl(142,71%,40%) 100%)}.role-icon-info{background:linear-gradient(135deg,var(--color-info) 0%,hsl(199,89%,40%) 100%)}.role-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.role-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--space-4) 0}@media(max-width:768px){.role-grid{grid-template-columns:1fr}}.role-selection-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-3)}.role-selection-card{padding:var(--space-4);border:2px solid var(--border-light);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);text-align:center;background:var(--bg-primary)}.role-selection-card:hover{border-color:var(--color-primary);background:var(--color-primary-light);transform:translateY(-2px)}.role-selection-card-active{border-color:var(--color-primary);background:var(--color-primary-light);box-shadow:0 0 0 3px var(--color-primary-light)}.role-selection-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;margin:0 auto var(--space-2);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-md);color:var(--color-white)}.role-selection-card-active .role-selection-icon{background:linear-gradient(135deg,var(--color-primary-dark) 0%,var(--color-secondary-dark) 100%)}.role-selection-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin-bottom:var(--space-1)}.role-selection-description{font-size:var(--font-size-xs);color:var(--text-secondary);line-height:1.3}@media(max-width:768px){.role-selection-grid{grid-template-columns:1fr}}.sidebar{width:260px;height:100vh;background:linear-gradient(180deg,var(--color-gray-900) 0%,var(--color-gray-800) 100%);color:var(--color-white);display:flex;flex-direction:column;position:fixed;left:0;top:0;z-index:var(--z-fixed);box-shadow:var(--shadow-xl)}.sidebar-header{padding:var(--space-6);border-bottom:1px solid rgba(255,255,255,.1)}.sidebar-logo{display:flex;align-items:center;gap:var(--space-3)}.logo-icon{font-size:var(--font-size-3xl);width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.logo-text{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);margin:0;background:linear-gradient(135deg,var(--color-primary-light) 0%,var(--color-white) 100%);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.sidebar-nav{flex:1;padding:var(--space-4);overflow-y:auto}.sidebar-link{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);margin-bottom:var(--space-2);border-radius:var(--radius-md);color:#ffffffb3;text-decoration:none;transition:all var(--transition-fast);font-weight:var(--font-weight-medium)}.sidebar-link:hover{background:#ffffff1a;color:var(--color-white);transform:translate(4px)}.sidebar-link-active{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);color:var(--color-white);box-shadow:var(--shadow-md)}.sidebar-link-icon{display:flex;align-items:center;justify-content:center}.sidebar-link-label{font-size:var(--font-size-base)}.sidebar-footer{padding:var(--space-4);border-top:1px solid rgba(255,255,255,.1)}.sidebar-logout{width:100%;display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:#ffffff0d;border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-md);color:#ffffffb3;cursor:pointer;transition:all var(--transition-fast);font-weight:var(--font-weight-medium);font-size:var(--font-size-base)}.sidebar-logout:hover{background:#ffffff1a;color:var(--color-white);border-color:#fff3}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-thumb{background:#fff3;border-radius:var(--radius-full)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:#ffffff4d}.navbar{height:80px;background:var(--bg-primary);border-bottom:1px solid var(--border-light);position:sticky;top:0;z-index:var(--z-sticky);box-shadow:var(--shadow-sm)}.navbar-content{height:100%;padding:0 var(--space-8);display:flex;align-items:center;justify-content:space-between}.navbar-title h2{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.navbar-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:var(--space-1) 0 0 0}.navbar-actions{display:flex;align-items:center;gap:var(--space-4)}.navbar-icon-btn{position:relative;width:44px;height:44px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all var(--transition-fast)}.navbar-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.navbar-badge{position:absolute;top:-4px;right:-4px;width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--color-danger);color:var(--color-white);font-size:var(--font-size-xs);font-weight:var(--font-weight-bold);border-radius:var(--radius-full);border:2px solid var(--bg-primary)}.navbar-user{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast)}.navbar-user:hover{background:var(--bg-tertiary);border-color:var(--border-medium)}.navbar-avatar{width:40px;height:40px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-secondary) 100%);display:flex;align-items:center;justify-content:center;color:var(--color-white);font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);overflow:hidden}.navbar-avatar img{width:100%;height:100%;object-fit:cover}.navbar-user-info{display:flex;flex-direction:column}.navbar-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--text-primary)}.navbar-user-role{font-size:var(--font-size-xs);color:var(--text-secondary)}.notification-container{position:relative}.notification-popover{position:absolute;top:100%;right:-10px;width:320px;background-color:var(--white);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);border:1px solid var(--border-light);z-index:1000;margin-top:var(--space-2);animation:fadeIn .2s ease-out}.notification-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-light)}.notification-header h3{font-size:var(--text-base);font-weight:600;color:var(--text-primary);margin:0}.mark-all-btn{background:none;border:none;font-size:var(--text-xs);color:var(--primary);cursor:pointer;font-weight:500}.mark-all-btn:hover{text-decoration:underline}.notification-list{max-height:350px;overflow-y:auto}.notification-item{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border-light);transition:background-color .2s;display:flex;align-items:flex-start;gap:var(--space-3)}.notification-item:last-child{border-bottom:none}.notification-item:hover,.notification-item.unread{background-color:var(--bg-secondary)}.notification-content{flex:1}.notification-title{font-size:var(--text-sm);font-weight:600;color:var(--text-primary);margin-bottom:2px;display:flex;align-items:center;gap:var(--space-2)}.unread-dot{width:6px;height:6px;background-color:var(--danger);border-radius:50%}.notification-text{font-size:var(--text-xs);color:var(--text-primary);line-height:1.4;margin-bottom:4px}.notification-time{font-size:10px;color:var(--text-tertiary)}.notification-action{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:2px;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.notification-action:hover{color:var(--primary);background-color:#4361ee1a}.notification-footer{padding:var(--space-2);text-align:center;border-top:1px solid var(--border-light)}.notification-footer button{background:none;border:none;color:var(--primary);font-size:var(--text-sm);font-weight:500;cursor:pointer;width:100%;padding:var(--space-2);border-radius:var(--radius-md)}.notification-footer button:hover{background-color:var(--bg-secondary)}.notification-empty,.notification-loading{padding:var(--space-6);text-align:center;color:var(--text-secondary);font-size:var(--text-sm)}@keyframes fadeIn{0%{opacity:0;transform:translateY(-5px)}to{opacity:1;transform:translateY(0)}}.dashboard-layout{display:flex;min-height:100vh;background:var(--bg-secondary)}.dashboard-main{flex:1;margin-left:260px;display:flex;flex-direction:column}.dashboard-content{flex:1;padding:var(--space-8);animation:fadeIn var(--transition-base) ease-out}@media(max-width:768px){.dashboard-main{margin-left:0}.dashboard-content{padding:var(--space-4)}}.card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-light);overflow:hidden;transition:all var(--transition-base)}.card:hover{box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:flex-start;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-light);background:var(--bg-secondary)}.card-header-content{flex:1}.card-title{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.card-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:var(--space-1) 0 0 0}.card-header-action{margin-left:var(--space-4)}.card-body{padding:var(--space-6)}.card-footer{padding:var(--space-4) var(--space-6);border-top:1px solid var(--border-light);background:var(--bg-secondary)}.dashboard-header{margin-bottom:var(--space-8)}.dashboard-header h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.dashboard-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);margin:0}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:var(--space-6);margin-bottom:var(--space-8)}.stat-card{transition:transform var(--transition-fast)}.stat-card:hover{transform:translateY(-4px)}.stat-content{display:flex;gap:var(--space-4)}.stat-icon{width:60px;height:60px;border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:var(--color-white);flex-shrink:0}.stat-icon-primary{background:linear-gradient(135deg,var(--color-primary) 0%,var(--color-primary-dark) 100%)}.stat-icon-secondary{background:linear-gradient(135deg,var(--color-secondary) 0%,var(--color-secondary-dark) 100%)}.stat-icon-success{background:linear-gradient(135deg,var(--color-success) 0%,hsl(142,71%,40%) 100%)}.stat-icon-info{background:linear-gradient(135deg,var(--color-info) 0%,hsl(199,89%,40%) 100%)}.stat-details{flex:1}.stat-title{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 var(--space-2) 0}.stat-value{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0 0 var(--space-2) 0}.stat-change{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.stat-change.positive{color:var(--color-success)}.stat-change.negative{color:var(--color-danger)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:var(--space-6)}.activity-list{display:flex;flex-direction:column;gap:var(--space-4)}.activity-item{display:flex;gap:var(--space-3);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-md);transition:background var(--transition-fast)}.activity-item:hover{background:var(--bg-tertiary)}.activity-dot{width:12px;height:12px;border-radius:50%;background:var(--color-primary);margin-top:4px;flex-shrink:0}.activity-content{flex:1}.activity-text{font-size:var(--font-size-sm);color:var(--text-primary);margin:0 0 var(--space-1) 0}.activity-time{font-size:var(--font-size-xs);color:var(--text-tertiary);margin:0}.quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-3)}.action-btn{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-4);background:var(--bg-secondary);border:1px solid var(--border-light);border-radius:var(--radius-md);color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--color-primary);color:var(--color-white);border-color:var(--color-primary);transform:translateY(-2px);box-shadow:var(--shadow-md)}@media(max-width:768px){.stats-grid,.dashboard-grid,.quick-actions{grid-template-columns:1fr}}.modal-backdrop{position:fixed;inset:0;background:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:var(--z-modal-backdrop);padding:var(--space-4);animation:fadeIn var(--transition-base) ease-out}.modal{background:var(--bg-primary);border-radius:var(--radius-xl);box-shadow:var(--shadow-2xl);width:100%;max-height:90vh;display:flex;flex-direction:column;animation:slideIn var(--transition-slow) ease-out;z-index:var(--z-modal)}.modal-sm{max-width:400px}.modal-md{max-width:600px}.modal-lg{max-width:800px}.modal-xl{max-width:1200px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-6);border-bottom:1px solid var(--border-light)}.modal-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--text-primary);margin:0}.modal-close{background:none;border:none;cursor:pointer;padding:var(--space-2);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:var(--text-secondary);transition:all var(--transition-fast)}.modal-close:hover{background:var(--bg-tertiary);color:var(--text-primary)}.modal-body{padding:var(--space-6);overflow-y:auto;flex:1}.modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-3);padding:var(--space-6);border-top:1px solid var(--border-light);background:var(--bg-secondary)}.user-table{overflow-x:auto}.user-table table{width:100%;border-collapse:collapse}.user-table th{text-align:left;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border-bottom:2px solid var(--border-light)}.user-table td{padding:var(--space-4);border-bottom:1px solid var(--border-light);font-size:var(--font-size-sm)}.user-table tbody tr{transition:background var(--transition-fast)}.user-table tbody tr:hover{background:var(--bg-secondary)}.user-name{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);color:var(--text-primary)}.role-badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.role-badge-coach{background:var(--color-secondary-light);color:var(--color-secondary-dark)}.role-badge-parent{background:var(--color-success-light);color:#1a9948}.role-badge-player{background:var(--color-info-light);color:#0a76a9}.action-buttons{display:flex;gap:var(--space-2)}.management-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-6)}.management-actions{display:flex;gap:var(--space-3);align-items:center}.search-filter-bar{display:flex;gap:var(--space-3);margin-bottom:var(--space-6);flex-wrap:wrap}.search-input{flex:1;min-width:250px}.filter-select{min-width:150px}.management-table{overflow-x:auto}.management-table table{width:100%;border-collapse:collapse}.management-table th{text-align:left;padding:var(--space-3) var(--space-4);background:var(--bg-secondary);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);border-bottom:2px solid var(--border-light);white-space:nowrap}.management-table td{padding:var(--space-4);border-bottom:1px solid var(--border-light);font-size:var(--font-size-sm)}.management-table tbody tr{transition:background var(--transition-fast)}.management-table tbody tr:hover{background:var(--bg-secondary)}.user-info{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-weight-medium);color:var(--text-primary)}.status-badge{display:inline-block;padding:var(--space-1) var(--space-3);border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold)}.status-badge-active{background:var(--color-success-light);color:#1a9948}.status-badge-inactive{background:var(--color-error-light);color:var(--color-error-dark)}.status-badge-pending{background:var(--color-warning-light);color:#ab6f07}.table-actions{display:flex;gap:var(--space-2)}.empty-state{text-align:center;padding:var(--space-8) var(--space-4);color:var(--text-secondary)}.empty-state-icon{font-size:48px;margin-bottom:var(--space-4);opacity:.5}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.form-grid-full{grid-column:1 / -1}.modal-actions{display:flex;gap:var(--space-3);justify-content:flex-end;margin-top:var(--space-4)}@media(max-width:768px){.management-header{flex-direction:column;gap:var(--space-4)}.search-filter-bar{flex-direction:column}.search-input,.filter-select{width:100%}.form-grid{grid-template-columns:1fr}}
