@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&display=swap";*,body,html,#root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif}h1,h2,h3,h4,h5,h6{color:var(--text-primary,#1a1a1a);margin:0;padding:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-weight:600;line-height:1.4}h1{font-size:30px;font-weight:700;line-height:1.4}h2{font-size:24px;font-weight:600;line-height:1.4}h3{font-size:20px;font-weight:600;line-height:1.4}h4{font-size:18px;font-weight:600;line-height:1.5}h5{font-size:16px;font-weight:600;line-height:1.5}h6{font-size:14px;font-weight:600;line-height:1.5}body{color:var(--text-primary,#1a1a1a);font-size:16px;font-weight:400;line-height:1.5}p{margin:0;padding:0;font-size:16px;line-height:1.6}.text-sm,small{font-size:14px;line-height:1.5}label,.label,.form-label{text-transform:uppercase;letter-spacing:.025em;color:var(--text-primary,#1a1a1a);font-size:14px;font-weight:500;line-height:1.5;display:block}.label-normal{text-transform:none;letter-spacing:normal}button,.btn{letter-spacing:.01em;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;font-weight:500;line-height:1.5}.btn-lg{font-size:16px}.btn-sm{font-size:12px}input,textarea,select,.form-input,.form-select,.form-textarea{color:var(--text-primary,#1a1a1a);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;font-size:14px;font-weight:400;line-height:1.5}input::-webkit-input-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}input::-moz-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}input::-ms-input-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}input::placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}textarea::-webkit-input-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}textarea::-moz-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}textarea::-ms-input-placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}textarea::placeholder{color:var(--text-secondary,#6c757d);font-size:14px;line-height:1.5}table{font-size:14px;line-height:1.5}th{text-transform:uppercase;letter-spacing:.025em;color:var(--text-secondary,#6c757d);font-size:12px;font-weight:600;line-height:1.4}td{color:var(--text-primary,#1a1a1a);font-size:14px;font-weight:400;line-height:1.5}nav,.nav,.navigation{font-size:14px;font-weight:500;line-height:1.5}nav a,.nav a,.navigation a{font-size:14px;font-weight:500;line-height:1.5;text-decoration:none}.badge,.tag{text-transform:uppercase;letter-spacing:.025em;font-size:12px;font-weight:600;line-height:1}.card-title{color:var(--text-primary,#1a1a1a);font-size:18px;font-weight:600;line-height:1.4}.card-subtitle{color:var(--text-secondary,#6c757d);font-size:14px;font-weight:400;line-height:1.5}.card-text{color:var(--text-primary,#1a1a1a);font-size:14px;font-weight:400;line-height:1.6}ul,ol{font-size:16px;line-height:1.6}li{margin-bottom:.5rem;font-size:16px;line-height:1.6}a{font-size:inherit;line-height:inherit;font-weight:inherit;color:var(--primary-color,#1e40af);text-decoration:none}a:hover{text-decoration:underline}code,pre{font-family:Courier New,Courier,monospace;font-size:14px;line-height:1.5}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-xs{font-size:12px;line-height:1.4}.text-sm{font-size:14px;line-height:1.5}.text-base{font-size:16px;line-height:1.5}.text-lg{font-size:18px;line-height:1.6}.text-xl{font-size:20px;line-height:1.5}.text-2xl{font-size:24px;line-height:1.4}.text-3xl{font-size:30px;line-height:1.4}.leading-tight{line-height:1.4}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.6}.tracking-tight{letter-spacing:-.01em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.025em}.tracking-wider{letter-spacing:.05em}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.sidebar-nav,.sidebar-item,.sidebar-label{font-size:14px;font-weight:500;line-height:1.5}.header-brand,.app-header h1{font-size:18px;font-weight:600;line-height:1.4}.stat-card h3,.stat-value{font-size:24px;font-weight:700;line-height:1.4}.stat-label{text-transform:uppercase;letter-spacing:.025em;font-size:12px;font-weight:600;line-height:1.4}.field-error,.error-message{font-size:14px;font-weight:400;line-height:1.5}.success-message{font-size:16px;font-weight:400;line-height:1.6}@media (max-width:639px){h1{font-size:24px}h2{font-size:20px}h3{font-size:18px}body,p,input,textarea,select{font-size:16px}}@media (min-width:640px) and (max-width:1023px){h1{font-size:28px}h2{font-size:22px}}@media (min-width:1024px){body{font-size:16px}h1{font-size:32px}h2{font-size:26px}}body{color:#1a1a1a}a:focus,button:focus,input:focus,textarea:focus,select:focus{outline:2px solid var(--primary-color,#1e40af);outline-offset:2px}@media (prefers-reduced-motion:reduce){*{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--color-primary:#1d4ed8;--color-primary-dark:#1e3a8a;--color-primary-light:#3b82f6;--color-primary-xlight:#dbeafe;--color-primary-hover:#1e40af;--sidebar-bg:#0f172a;--sidebar-bg-hover:#1e293b;--sidebar-text:#94a3b8;--sidebar-text-active:#fff;--sidebar-accent:#3b82f6;--sidebar-border:#1e293b;--color-bg-primary:#fff;--color-bg-secondary:#f8fafc;--color-bg-tertiary:#f1f5f9;--color-text-primary:#0f172a;--color-text-secondary:#475569;--color-text-tertiary:#94a3b8;--color-border-light:#f1f5f9;--color-border-medium:#e2e8f0;--color-border-dark:#cbd5e1;--color-success:#10b981;--color-warning:#f59e0b;--color-error:#ef4444;--color-info:#3b82f6;--spacing-1:4px;--spacing-2:8px;--spacing-3:12px;--spacing-4:16px;--spacing-5:20px;--spacing-6:24px;--spacing-8:32px;--spacing-10:40px;--spacing-12:48px;--spacing-16:64px;--font-family:"Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs:11px;--font-size-sm:13px;--font-size-base:14px;--font-size-md:15px;--font-size-lg:18px;--font-size-xl:20px;--font-size-2xl:24px;--font-size-3xl:30px;--font-weight-normal:400;--font-weight-medium:500;--font-weight-semibold:600;--font-weight-bold:700;--line-height-tight:1.3;--line-height-normal:1.5;--line-height-relaxed:1.6;--radius-sm:6px;--radius-md:8px;--radius-lg:12px;--radius-xl:16px;--radius-full:9999px;--shadow-xs:0 1px 2px rgba(0,0,0,.05);--shadow-sm:0 1px 3px rgba(0,0,0,.08), 0 1px 2px rgba(0,0,0,.04);--shadow-md:0 4px 6px -1px rgba(0,0,0,.07), 0 2px 4px -1px rgba(0,0,0,.04);--shadow-lg:0 10px 15px -3px rgba(0,0,0,.08), 0 4px 6px -2px rgba(0,0,0,.04);--shadow-xl:0 20px 25px -5px rgba(0,0,0,.08), 0 10px 10px -5px rgba(0,0,0,.03);--transition-fast:.1s ease;--transition-normal:.15s ease;--transition-slow:.25s ease;--header-height:60px;--sidebar-width:260px;--sidebar-collapsed:64px;--z-dropdown:1000;--z-sticky:1020;--z-fixed:1030;--z-modal:1050;--z-tooltip:1070;--bg-color:var(--color-bg-primary);--card-bg:var(--color-bg-secondary);--border-color:var(--color-border-medium);--text-primary:var(--color-text-primary);--text-secondary:var(--color-text-secondary);--primary-color:var(--color-primary);--primary-hover:var(--color-primary-hover);--success-color:var(--color-success);--error-color:var(--color-error);--warning-color:var(--color-warning)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);line-height:var(--line-height-normal);color:var(--text-primary);background-color:var(--color-bg-secondary);min-width:320px;min-height:100vh}#root{width:100%;min-height:100vh}h1,h2,h3,h4,h5,h6{font-family:var(--font-family);font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--text-primary);letter-spacing:-.01em}h1{font-size:var(--font-size-3xl);font-weight:var(--font-weight-bold)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-md)}h6{font-size:var(--font-size-sm);text-transform:uppercase;letter-spacing:.05em}p{font-size:var(--font-size-base);line-height:var(--line-height-relaxed);color:var(--text-secondary)}.btn{justify-content:center;align-items:center;gap:var(--spacing-2);border-radius:var(--radius-md);font-family:var(--font-family);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-normal);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;white-space:nowrap;border:1px solid transparent;padding:9px 18px;line-height:1;text-decoration:none;display:inline-flex}.btn:focus-visible{outline:2px solid var(--primary-color);outline-offset:2px}.btn-primary{background:var(--primary-color);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--primary-hover);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--color-bg-primary);color:var(--text-primary);border-color:var(--border-color);box-shadow:var(--shadow-xs)}.btn-secondary:hover:not(:disabled){background:var(--color-bg-tertiary);border-color:var(--color-border-dark)}.btn-outline{color:var(--primary-color);border-color:var(--primary-color);background:0 0}.btn-outline:hover:not(:disabled){background:var(--color-primary-xlight)}.btn-ghost{color:var(--text-secondary);background:0 0;border-color:transparent}.btn-ghost:hover:not(:disabled){background:var(--color-bg-tertiary);color:var(--text-primary)}.btn-danger{background:var(--color-error);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{font-size:var(--font-size-xs);padding:6px 12px}.btn-lg{font-size:var(--font-size-md);padding:12px 24px}.btn-block{width:100%}.form-group{margin-bottom:var(--spacing-4);flex-direction:column;gap:6px;display:flex}.form-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-primary)}.form-input,.form-select,.form-textarea{border:1px solid var(--border-color);border-radius:var(--radius-md);width:100%;font-family:var(--font-family);font-size:var(--font-size-base);color:var(--text-primary);background:var(--color-bg-primary);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);padding:9px 12px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(29,78,216,.1)}.form-input::-webkit-input-placeholder{color:var(--color-text-tertiary)}.form-input::-moz-placeholder{color:var(--color-text-tertiary)}.form-input::-ms-input-placeholder{color:var(--color-text-tertiary)}.form-input::placeholder{color:var(--color-text-tertiary)}.card{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-header{padding:var(--spacing-5) var(--spacing-6);border-bottom:1px solid var(--border-color)}.card-body{padding:var(--spacing-6)}.card-footer{padding:var(--spacing-4) var(--spacing-6);border-top:1px solid var(--border-color);background:var(--color-bg-secondary);border-radius:0 0 var(--radius-lg) var(--radius-lg)}.table{border-collapse:collapse;width:100%;font-size:var(--font-size-sm)}.table th{text-align:left;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);text-transform:uppercase;letter-spacing:.05em;color:var(--text-secondary);background:var(--color-bg-secondary);border-bottom:1px solid var(--border-color);padding:10px 16px}.table td{border-bottom:1px solid var(--color-border-light);color:var(--text-primary);padding:12px 16px}.table tbody tr:hover{background:var(--color-bg-secondary)}.badge{border-radius:var(--radius-full);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);align-items:center;padding:3px 8px;line-height:1.4;display:inline-flex}.badge-primary{background:var(--color-primary-xlight);color:var(--color-primary)}.badge-success{color:#065f46;background:#d1fae5}.badge-warning{color:#92400e;background:#fef3c7}.badge-error{color:#991b1b;background:#fee2e2}.badge-secondary{background:var(--color-bg-tertiary);color:var(--text-secondary)}.text-muted{color:var(--text-secondary)}.text-primary-color{color:var(--primary-color)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.d-flex{display:flex}.d-grid{display:grid}.d-none{display:none}.align-center{align-items:center}.w-full{width:100%}.mt-4{margin-top:var(--spacing-4)}.mb-4{margin-bottom:var(--spacing-4)}.p-4{padding:var(--spacing-4)}.p-6{padding:var(--spacing-6)}.user-management-page,.mailing-integration-page,.course-management-page,.analytics-dashboard-page,.pending-approvals-page,.certificate-detail-page,.course-creation-page,.course-list-page,.my-courses-page,.my-certificates-page,.certificates-page,.user-profile-page,.calendar-page{background:var(--color-bg-secondary)!important;min-height:unset!important}.user-management-container,.mailing-integration-container,.course-management-container,.analytics-container,.approvals-container,.certificate-container,.course-creation-container,.course-list-container,.my-courses-container,.my-certificates-container,.profile-container,.calendar-container{box-shadow:none!important;background:0 0!important;border-radius:0!important;max-width:100%!important}.user-management-header,.mailing-integration-header,.course-management-header,.analytics-header,.approvals-header,.page-header{background:var(--color-bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-sm)!important;color:var(--text-primary)!important;margin-bottom:1.5rem!important;padding:1.5rem!important;animation:none!important}.user-management-title,.mailing-integration-title,.course-management-title,.analytics-title,.page-title{background:0 0!important;-webkit-background-clip:unset!important;-webkit-text-fill-color:var(--text-primary)!important;background-clip:unset!important;color:var(--text-primary)!important;font-size:1.5rem!important;font-weight:var(--font-weight-bold)!important}.user-management-subtitle,.mailing-integration-subtitle,.page-subtitle{color:var(--text-secondary)!important;opacity:1!important}.btn-create-user,.btn-add-client,.btn-create-campaign,.btn-sync-bulk,.btn-primary-action{background:var(--primary-color)!important;color:#fff!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-sm)!important;transition:background var(--transition-normal)!important;background-image:none!important;border:none!important;animation:none!important;transform:none!important}.btn-create-user:hover,.btn-add-client:hover,.btn-create-campaign:hover,.btn-sync-bulk:hover{background:var(--primary-hover)!important;box-shadow:var(--shadow-md)!important;transform:none!important}.btn-export{background:var(--color-bg-secondary)!important;color:var(--text-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-md)!important}.btn-export:hover{background:var(--color-bg-tertiary)!important;transform:none!important}.stat-card-icon.total,.stat-card-icon.students,.stat-card-icon.admins,.stat-card-icon.active,.stat-card-icon.completed{background:var(--color-primary-xlight)!important;color:var(--primary-color)!important;box-shadow:none!important}.stat-card{transition:border-color var(--transition-normal), box-shadow var(--transition-normal)!important;animation:none!important}.stat-card:hover{border-color:var(--color-primary-light)!important;box-shadow:var(--shadow-md)!important;transform:none!important}.stat-card:hover .stat-card-icon{transform:none!important}.stat-card:before{display:none!important}.stat-completed{color:var(--color-success)!important}.stat-approved{color:var(--primary-color)!important}.stat-rate{color:var(--text-secondary)!important}@keyframes slideDown{0%{opacity:1;transform:none}to{opacity:1;transform:none}}@keyframes fadeInUp{0%{opacity:1;transform:none}to{opacity:1;transform:none}}.rate-limit-message{border-radius:var(--radius-lg)!important;box-shadow:none!important;background:#fef3c7!important;border:1px solid #f59e0b!important;animation:none!important}.users-table-container,.mailing-content,.analytics-content,.approvals-content,.courses-content{background:var(--color-bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-lg)!important;box-shadow:var(--shadow-sm)!important}.badge-active,.status-active{color:#065f46!important;background:#d1fae5!important}.badge-pending,.status-pending{color:#92400e!important;background:#fef3c7!important}.badge-inactive,.status-inactive{background:var(--color-bg-tertiary)!important;color:var(--text-secondary)!important}.badge-admin{background:var(--color-primary-xlight)!important;color:var(--primary-color)!important}.modal-overlay{background:rgba(0,0,0,.5)!important}.modal-content,.modal-container{background:var(--color-bg-primary)!important;border:1px solid var(--border-color)!important;border-radius:var(--radius-xl)!important;box-shadow:var(--shadow-xl)!important}.modal-header{background:var(--color-bg-secondary)!important;border-bottom:1px solid var(--border-color)!important;border-radius:var(--radius-xl) var(--radius-xl) 0 0!important}.modal-content input,.modal-content select,.modal-content textarea,.modal-container input,.modal-container select,.modal-container textarea{border:1px solid var(--border-color)!important;border-radius:var(--radius-md)!important;background:var(--color-bg-primary)!important;color:var(--text-primary)!important}.modal-content input:focus,.modal-content select:focus,.modal-content textarea:focus,.modal-container input:focus,.modal-container select:focus,.modal-container textarea:focus{border-color:var(--primary-color)!important;outline:none!important;box-shadow:0 0 0 3px rgba(29,78,216,.1)!important}.analytics-dashboard{background:0 0!important;max-width:100%!important;margin:0!important;padding:0!important}.summary-icon.users,.summary-icon.courses,.summary-icon.enrollments,.summary-icon.certificates{background:var(--color-primary-xlight)!important;color:var(--primary-color)!important}.summary-card:hover{box-shadow:var(--shadow-md)!important;transform:none!important}.card-header{background:var(--primary-color)!important;background-image:none!important}.certificate-card:before{display:none!important}.certificate-card:hover{transform:none!important}.user-profile-container{box-shadow:none!important;background:0 0!important;border-radius:0!important;overflow:visible!important}.section-header{border-bottom-color:var(--border-color)!important}.section-header svg{color:var(--primary-color)!important}.btn-save-profile{background:var(--primary-color)!important;background-image:none!important}.btn-save-profile:hover:not(:disabled){background:var(--primary-hover)!important;box-shadow:var(--shadow-md)!important;transform:none!important}.pending-approvals-page,.course-management-page{max-width:100%!important;margin:0!important;padding:0!important}.filter-tab.active{color:var(--primary-color)!important;border-bottom-color:var(--primary-color)!important}.certificate-number{color:var(--primary-color)!important;background:var(--color-primary-xlight)!important}:root{--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light;font-synthesis:none;text-rendering:optimizelegibility}*{box-sizing:border-box;margin:0;padding:0}html{-webkit-text-size-adjust:100%;-ms-text-size-adjust:100%;scroll-behavior:smooth;height:100%}body{overscroll-behavior-y:none;-webkit-tap-highlight-color:transparent;min-width:320px;height:100%;min-height:100vh;margin:0;display:flex;overflow-x:hidden}#root{width:100%;min-height:100vh;overflow-x:hidden}.app-layout{flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--bg-color);color:var(--text-primary);border-bottom:1px solid var(--border-color);padding:1rem 2rem}.app-main{flex:1;width:100%;padding:0}.app-footer{background-color:var(--card-bg);text-align:center;color:var(--text-secondary);border-top:1px solid var(--border-color);padding:1rem 2rem}.home-page{max-width:1200px;margin:0 auto;padding:2rem}.hero-section{text-align:center;background:var(--primary-color);color:#fff;border-radius:4px;margin-bottom:3rem;padding:3rem 2rem}.hero-section h1{margin:0 0 1rem;font-size:2.5rem}.subtitle{opacity:.9;margin:0;font-size:1.2rem}.user-section,.auth-section{margin-bottom:3rem}.welcome-card,.auth-card{background:var(--card-bg);border:1px solid var(--border-color);text-align:center;border-radius:4px;margin-bottom:2rem;padding:2rem}.welcome-card h2,.auth-card h2{color:var(--text-primary);margin-top:0}.user-role{margin:1rem 0;font-size:1.1rem}.badge{background:var(--primary-color);color:#fff;border-radius:2px;padding:.25rem .75rem;font-size:.9rem;font-weight:600}.user-email{color:var(--text-secondary);margin-bottom:1.5rem}.auth-buttons{flex-wrap:wrap;justify-content:center;gap:1rem;margin-top:2rem;display:flex}.btn{cursor:pointer;border:none;border-radius:4px;padding:.75rem 1.5rem;font-size:1rem;font-weight:600;text-decoration:none;transition:all .15s;display:inline-block}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}.btn-secondary{background:var(--secondary-color);color:#fff}.btn-secondary:hover{background:#5a6268}.btn:disabled{opacity:.5;cursor:not-allowed}.btn:disabled:hover{box-shadow:none;transform:none}.features-grid{grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:1.5rem;margin-top:2rem;display:grid}.feature-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;padding:1.5rem;transition:all .15s}.feature-card:hover{border-color:var(--primary-color)}.feature-icon{margin-bottom:1rem;font-size:3rem}.feature-card h3{color:var(--text-primary);margin:.5rem 0}.feature-card p{color:var(--text-secondary);margin:.5rem 0 1rem;font-size:.9rem}.info-section{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;margin-top:3rem;padding:2rem}.info-section h2{text-align:center;color:var(--text-primary);margin-top:0}.status-grid{flex-direction:column;gap:1rem;margin-top:1.5rem;display:flex}.status-item{border:2px solid var(--border-color);border-radius:4px;align-items:center;gap:1rem;padding:1rem;display:flex}.status-item.completed{border-color:var(--success-color);background:rgba(72,187,120,.1)}.status-item.in-progress{border-color:var(--warning-color);background:rgba(237,137,54,.1)}.status-item.pending{border-color:var(--text-secondary);background:rgba(100,116,139,.1)}.status-icon{flex-shrink:0;font-size:2rem}.status-item strong{color:var(--text-primary);margin-bottom:.25rem;display:block}.status-item p{color:var(--text-secondary);margin:0;font-size:.9rem}.auth-page{background:var(--bg-color);justify-content:center;align-items:center;min-height:calc(100vh - 120px);padding:2rem 1rem;display:flex}.auth-container{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;width:100%;max-width:480px;padding:2.5rem;box-shadow:0 1px 3px rgba(0,0,0,.1)}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{color:var(--text-primary);margin:0 0 .5rem;font-size:2rem}.auth-subtitle{color:var(--text-secondary);margin:0;font-size:.95rem}.auth-form{flex-direction:column;gap:1.5rem;display:flex}.form-group{flex-direction:column;gap:.5rem;display:flex}.form-group label{color:var(--text-primary);font-size:.95rem;font-weight:500}.form-group input{border:2px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-primary);border-radius:4px;padding:.875rem 1rem;font-size:1rem;transition:all .15s}.form-group input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.form-group input.input-error{border-color:var(--error-color)}.form-group input.input-error:focus{box-shadow:0 0 0 3px rgba(245,101,101,.1)}.password-input-wrapper{align-items:center;display:flex;position:relative}.password-input-wrapper input{padding-right:3rem}.password-toggle{cursor:pointer;opacity:.6;background:0 0;border:none;justify-content:center;align-items:center;padding:.25rem;font-size:1.25rem;transition:opacity .2s;display:flex;position:absolute;right:.75rem}.password-toggle:hover{opacity:1}.field-error{color:var(--error-color);margin-top:-.25rem;font-size:.85rem}.error-message{border:1px solid var(--error-color);color:var(--error-color);text-align:center;background:rgba(220,53,69,.1);border-radius:4px;padding:.875rem 1rem;font-size:.95rem}.success-message{text-align:center;padding:2rem 1rem}.success-icon{background:var(--success-color);color:#fff;border-radius:4px;justify-content:center;align-items:center;width:80px;height:80px;margin:0 auto 1.5rem;font-size:3rem;font-weight:700;display:flex}.success-message h2{color:var(--text-primary);margin:0 0 1rem}.success-message p{color:var(--text-secondary);margin:.5rem 0;line-height:1.6}.success-message .text-secondary{font-size:.9rem}.btn-block{justify-content:center;align-items:center;gap:.5rem;width:100%;display:flex}.spinner{border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:4px;width:16px;height:16px;animation:.6s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.auth-links{text-align:center;margin-top:.5rem}.auth-footer{text-align:center;border-top:1px solid var(--border-color);margin-top:1.5rem;padding-top:1.5rem}.auth-footer p{color:var(--text-secondary);margin:0;font-size:.95rem}.link-primary{color:var(--primary-color);font-weight:500;text-decoration:none;transition:color .2s}.link-primary:hover{color:var(--primary-hover);text-decoration:underline}.link-secondary{color:var(--text-secondary);font-size:.9rem;text-decoration:none;transition:color .15s}.link-secondary:hover{color:var(--text-primary);text-decoration:underline}.password-strength{align-items:center;gap:.75rem;margin-top:.5rem;display:flex}.strength-bar{background:var(--border-color);border-radius:2px;flex:1;height:4px;position:relative;overflow:hidden}.strength-fill{border-radius:2px;height:100%;transition:all .15s}.strength-bar.strength-weak .strength-fill{background:var(--error-color);width:33%}.strength-bar.strength-medium .strength-fill{background:var(--warning-color);width:66%}.strength-bar.strength-strong .strength-fill{background:var(--success-color);width:100%}.strength-text{min-width:60px;font-size:.85rem;font-weight:500}.strength-text.strength-weak{color:var(--error-color)}.strength-text.strength-medium{color:var(--warning-color)}.strength-text.strength-strong{color:var(--success-color)}.login-page,.registration-page{max-width:500px;margin:2rem auto;padding:2rem}.login-page h2,.registration-page h2{text-align:center;color:var(--text-primary);margin-bottom:2rem}.login-page form,.registration-page form{background:var(--card-bg);border:1px solid var(--border-color);border-radius:4px;padding:2rem}.login-page form>div,.registration-page form>div{margin-bottom:1.5rem}.login-page label,.registration-page label{color:var(--text-primary);margin-bottom:.5rem;font-weight:500;display:block}.login-page input,.registration-page input{border:1px solid var(--border-color);background:var(--bg-color);width:100%;color:var(--text-primary);border-radius:4px;padding:.75rem;font-size:1rem}.login-page input:focus,.registration-page input:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.error{border:1px solid var(--error-color);color:var(--error-color);text-align:center;background:rgba(220,53,69,.1);border-radius:4px;margin-bottom:1rem;padding:.75rem}.login-page button[type=submit]{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;font-weight:600;transition:all .15s}.registration-page button[type=submit]{background:var(--primary-color);color:#fff;cursor:pointer;border:none;border-radius:4px;width:100%;padding:.75rem;font-size:1rem;font-weight:600;transition:all .15s}.login-page button[type=submit]:hover{background:var(--primary-hover)}.registration-page button[type=submit]:hover{background:var(--primary-hover)}.login-page button[type=submit]:disabled{opacity:.5;cursor:not-allowed;transform:none}.registration-page button[type=submit]:disabled{opacity:.5;cursor:not-allowed;transform:none}@media (min-width:640px){.hero-section h1{font-size:2.5rem}.subtitle{font-size:1.2rem}.features-grid{grid-template-columns:repeat(2,1fr)}.auth-buttons{flex-direction:row}.btn{width:auto;min-width:120px}.home-page{padding:2rem}.hero-section{padding:3rem 2rem}.auth-container{padding:3rem}}@media (min-width:1024px){.hero-section h1{font-size:3rem}.subtitle{font-size:1.4rem}.features-grid{grid-template-columns:repeat(3,1fr)}.home-page{padding:3rem}.hero-section{padding:4rem 3rem}}@media (max-width:639px){.hero-section h1{font-size:1.75rem}.subtitle{font-size:.95rem}.features-grid{grid-template-columns:1fr}.auth-buttons{flex-direction:column}.btn{width:100%;min-height:44px}.home-page{padding:1rem}.hero-section{padding:2rem 1rem}.auth-container{padding:1.5rem}.app-header{padding:.75rem 1rem}.app-footer{padding:1rem}.form-group input,.form-group select,.form-group textarea{font-size:16px}}@media (prefers-color-scheme:light){:root{color:#1a1a1a;--bg-color:#fff;--card-bg:#f8f9fa;--border-color:#dee2e6;--text-primary:#1a1a1a;--text-secondary:#495057;background-color:#fff}.app-footer{background-color:#f8f9fa}}@media (max-width:1023px){html{-webkit-text-size-adjust:100%;touch-action:manipulation}body{width:100%;position:relative;overflow-x:hidden}.app-layout,.app-header,.app-main,.app-footer{max-width:100vw;overflow-x:hidden}img{max-width:100%;height:auto}*{word-wrap:break-word;overflow-wrap:break-word}input,select,textarea,button{font-size:16px!important}button,a,.btn{justify-content:center;align-items:center;min-width:44px;min-height:44px;display:inline-flex}body{overscroll-behavior-y:contain}.app-main{box-sizing:border-box;width:100%;padding:1rem}.home-page,.auth-page,.auth-container{box-sizing:border-box;width:100%;max-width:100%;padding-left:1rem;padding-right:1rem}}@media (max-width:375px){.app-header{padding:.5rem .75rem}.home-page{padding:.75rem}.hero-section{padding:1.5rem .75rem}.auth-container{padding:1rem}.btn{padding:.625rem 1rem;font-size:.9rem}}@supports (padding:max(0px)){body{padding-left:max(0px, env(safe-area-inset-left));padding-right:max(0px, env(safe-area-inset-right))}.app-header{padding-top:max(1rem, env(safe-area-inset-top))}.app-footer{padding-bottom:max(1rem, env(safe-area-inset-bottom))}}:root{--mobile-max:639px;--tablet-min:640px;--tablet-max:1023px;--desktop-min:1024px;--spacing-xs:.25rem;--spacing-sm:.5rem;--spacing-md:1rem;--spacing-lg:1.5rem;--spacing-xl:2rem;--spacing-2xl:3rem;--spacing-3xl:4rem;--touch-target-min:44px;--touch-target-comfortable:48px;--font-xs:.75rem;--font-sm:.875rem;--font-base:1rem;--font-lg:1.125rem;--font-xl:1.25rem;--font-2xl:1.5rem;--font-3xl:1.875rem;--font-4xl:2.25rem;--container-mobile:100%;--container-tablet:640px;--container-desktop:1024px;--container-wide:1200px}.container{width:100%;padding-left:var(--spacing-md);padding-right:var(--spacing-md);margin-left:auto;margin-right:auto}@media (min-width:640px){.container{max-width:var(--container-tablet);padding-left:var(--spacing-lg);padding-right:var(--spacing-lg)}}@media (min-width:1024px){.container{max-width:var(--container-desktop);padding-left:var(--spacing-xl);padding-right:var(--spacing-xl)}}@media (min-width:1280px){.container{max-width:var(--container-wide)}}.grid{gap:var(--spacing-md);display:grid}.grid-cols-1{grid-template-columns:repeat(1,minmax(0,1fr))}@media (min-width:640px){.grid-cols-sm-2{grid-template-columns:repeat(2,minmax(0,1fr))}.grid-cols-sm-3{grid-template-columns:repeat(3,minmax(0,1fr))}}@media (min-width:1024px){.grid-cols-lg-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-lg-4{grid-template-columns:repeat(4,minmax(0,1fr))}}.grid-auto-fit{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.flex-wrap{flex-wrap:wrap}.justify-between{justify-content:space-between}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}@media (max-width:639px){.flex-col-mobile{flex-direction:column}}@media (min-width:640px){.flex-row-tablet{flex-direction:row}}.btn-touch{min-height:var(--touch-target-min);min-width:var(--touch-target-min);cursor:pointer;font-weight:600;font-size:var(--font-base);-webkit-tap-highlight-color:transparent;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;border:none;border-radius:4px;justify-content:center;align-items:center;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .15s;display:inline-flex}.btn-touch-comfortable{min-height:var(--touch-target-comfortable);min-width:var(--touch-target-comfortable);padding:1rem 2rem}.btn-mobile-full{width:100%}@media (min-width:640px){.btn-mobile-full{width:auto}}.text-xs{font-size:var(--font-xs)}.text-sm{font-size:var(--font-sm)}.text-base{font-size:var(--font-base)}.text-lg{font-size:var(--font-lg)}.text-xl{font-size:var(--font-xl)}.text-2xl{font-size:var(--font-2xl)}.text-3xl{font-size:var(--font-3xl)}.text-4xl{font-size:var(--font-4xl)}.heading-responsive-1{font-size:var(--font-2xl);line-height:1.2}@media (min-width:640px){.heading-responsive-1{font-size:var(--font-3xl)}}@media (min-width:1024px){.heading-responsive-1{font-size:var(--font-4xl)}}.heading-responsive-2{font-size:var(--font-xl);line-height:1.3}@media (min-width:640px){.heading-responsive-2{font-size:var(--font-2xl)}}@media (min-width:1024px){.heading-responsive-2{font-size:var(--font-3xl)}}.p-mobile{padding:var(--spacing-md)}.p-tablet{padding:var(--spacing-lg)}.p-desktop{padding:var(--spacing-xl)}@media (min-width:640px){.p-responsive{padding:var(--spacing-lg)}}@media (min-width:1024px){.p-responsive{padding:var(--spacing-xl)}}.m-mobile{margin:var(--spacing-md)}.m-tablet{margin:var(--spacing-lg)}.m-desktop{margin:var(--spacing-xl)}.card-responsive{background:var(--card-bg);border:1px solid var(--border-color);padding:var(--spacing-md);border-radius:12px;transition:all .3s}@media (min-width:640px){.card-responsive{padding:var(--spacing-lg);border-radius:16px}}@media (min-width:1024px){.card-responsive{padding:var(--spacing-xl)}}.card-responsive:hover{transform:translateY(-2px);box-shadow:0 8px 24px rgba(0,0,0,.1)}.form-responsive{gap:var(--spacing-md);flex-direction:column;display:flex}@media (min-width:640px){.form-responsive{gap:var(--spacing-lg)}}.form-group-responsive{gap:var(--spacing-sm);flex-direction:column;display:flex}.input-responsive{width:100%;min-height:var(--touch-target-min);border:2px solid var(--border-color);background:var(--bg-color);color:var(--text-primary);font-size:var(--font-base);-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;appearance:none;border-radius:8px;padding:.875rem 1rem;transition:all .2s}.input-responsive:focus{border-color:var(--primary-color);outline:none;box-shadow:0 0 0 3px rgba(100,108,255,.1)}.nav-responsive{gap:var(--spacing-sm);flex-direction:column;display:flex}@media (min-width:640px){.nav-responsive{gap:var(--spacing-md);flex-direction:row}}.nav-link-responsive{min-height:var(--touch-target-min);border-radius:8px;align-items:center;padding:.75rem 1rem;text-decoration:none;transition:all .2s;display:flex}.modal-responsive{z-index:1000;justify-content:center;align-items:flex-end;padding:0;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}@media (min-width:640px){.modal-responsive{padding:var(--spacing-lg);align-items:center}}.modal-content-responsive{background:var(--card-bg);width:100%;max-height:90vh;padding:var(--spacing-lg);border-radius:16px 16px 0 0;overflow-y:auto}@media (min-width:640px){.modal-content-responsive{max-width:600px;padding:var(--spacing-xl);border-radius:16px}}.table-responsive-wrapper{-webkit-overflow-scrolling:touch;margin:var(--spacing-md) 0;overflow-x:auto}.table-responsive{border-collapse:collapse;width:100%;min-width:600px}.table-responsive th,.table-responsive td{padding:var(--spacing-sm) var(--spacing-md);text-align:left;border-bottom:1px solid var(--border-color)}@media (min-width:640px){.table-responsive th,.table-responsive td{padding:var(--spacing-md) var(--spacing-lg)}}.table-card-mobile{display:none}@media (max-width:639px){.table-responsive-wrapper{display:none}.table-card-mobile{display:block}.table-card-item{background:var(--card-bg);border:1px solid var(--border-color);padding:var(--spacing-md);margin-bottom:var(--spacing-md);border-radius:12px}}.img-responsive{max-width:100%;height:auto;display:block}.img-cover{object-fit:cover;width:100%;height:100%}.img-contain{object-fit:contain;width:100%;height:100%}.hidden-mobile{display:none}@media (min-width:640px){.hidden-mobile{display:block}}.visible-mobile{display:block}@media (min-width:640px){.visible-mobile{display:none}}.hidden-desktop{display:block}@media (min-width:1024px){.hidden-desktop{display:none}}.aspect-ratio-box{width:100%;position:relative}.aspect-ratio-box:before{content:"";padding-top:100%;display:block}.aspect-ratio-16-9:before{padding-top:56.25%}.aspect-ratio-4-3:before{padding-top:75%}.aspect-ratio-content{width:100%;height:100%;position:absolute;top:0;left:0}.safe-area-inset-top{padding-top:env(safe-area-inset-top)}.safe-area-inset-bottom{padding-bottom:env(safe-area-inset-bottom)}.safe-area-inset-left{padding-left:env(safe-area-inset-left)}.safe-area-inset-right{padding-right:env(safe-area-inset-right)}@media print{.no-print{display:none!important}.page-break-before{page-break-before:always}.page-break-after{page-break-after:always}.page-break-inside-avoid{page-break-inside:avoid}}@media (max-width:767px){.app-layout,.app-main{width:100%;max-width:100%}.app-header{padding:var(--spacing-3) var(--spacing-4)}.app-main{padding:var(--spacing-4)}h1{font-size:var(--font-size-2xl)}h2{font-size:var(--font-size-xl)}.form-group{margin-bottom:var(--spacing-3)}.btn{justify-content:center;width:100%}.card{padding:var(--spacing-3)}.table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.desktop-only{display:none!important}.mobile-only{display:block!important}}@media (min-width:768px) and (max-width:1023px){.app-layout{flex-direction:column;display:flex}.app-header{padding:var(--spacing-4) var(--spacing-6)}.app-main{padding:var(--spacing-6)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}.form-row{gap:var(--spacing-4);grid-template-columns:repeat(2,1fr);display:grid}.btn{width:auto}.card{padding:var(--spacing-4)}.grid-responsive{grid-template-columns:repeat(2,1fr)}.desktop-sidebar{transition:left var(--transition-normal) var(--transition-timing);z-index:var(--z-index-fixed);position:fixed;left:-260px}.desktop-sidebar.open{left:0}.sidebar-toggle{top:calc(var(--header-height) + var(--spacing-4));left:var(--spacing-4);z-index:calc(var(--z-index-fixed) + 1);padding:var(--spacing-2);background:var(--color-primary);color:#fff;border-radius:var(--border-radius-md);cursor:pointer;transition:all var(--transition-normal) var(--transition-timing);border:none;display:block;position:fixed}.sidebar-toggle:hover{background:var(--color-primary-hover)}.desktop-body.sidebar-open .desktop-content{margin-left:var(--sidebar-width)}.tablet-only{display:block!important}}@media (min-width:1024px){.desktop-layout{flex-direction:column;display:flex}.desktop-body{grid-template-columns:var(--sidebar-width) 1fr;margin-top:var(--header-height);flex:1;display:grid}.desktop-content{width:100%;min-height:calc(100vh - var(--header-height));padding:var(--spacing-8);background:var(--color-bg-secondary);overflow-x:hidden;overflow-y:auto}.desktop-sidebar{top:var(--header-height);width:var(--sidebar-width);height:calc(100vh - var(--header-height));background:var(--color-bg-primary);border-right:1px solid var(--color-border-medium);z-index:var(--z-index-sticky);position:fixed;left:0;overflow-y:auto}.sidebar-toggle{display:none}.app-header,.professional-header{height:var(--header-height);z-index:var(--z-index-fixed);position:fixed;top:0;left:0;right:0}.form-row{gap:var(--spacing-4);grid-template-columns:repeat(2,1fr);display:grid}.form-row-3{gap:var(--spacing-4);grid-template-columns:repeat(3,1fr);display:grid}.grid-responsive{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.card{padding:var(--spacing-6)}.table-container{width:100%;overflow-x:auto}h1{font-size:var(--font-size-4xl)}h2{font-size:var(--font-size-3xl)}h3{font-size:var(--font-size-2xl)}.mobile-only{display:none!important}.desktop-only{display:block!important}.modal-content{max-width:600px}.modal-content-large{max-width:900px}.dropdown-menu{min-width:200px}}@media (min-width:1440px){.desktop-content{padding:var(--spacing-12)}.grid-responsive{grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.form-row-wide{gap:var(--spacing-6);grid-template-columns:repeat(3,1fr);display:grid}.card{padding:var(--spacing-8)}.modal-content{max-width:700px}.modal-content-large{max-width:1100px}.dashboard-stats-grid{grid-template-columns:repeat(4,1fr)}.content-constrained{max-width:1400px;margin:0 auto}}@media (min-width:1920px){.desktop-content{padding:var(--spacing-16)}.grid-responsive{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}.dashboard-stats-grid{grid-template-columns:repeat(5,1fr)}.content-constrained{max-width:1600px}.modal-content-large{max-width:1300px}}@media (min-width:768px) and (max-width:1023px){.desktop-sidebar{top:var(--header-height);width:var(--sidebar-width);height:calc(100vh - var(--header-height));background:var(--color-bg-primary);border-right:1px solid var(--color-border-medium);z-index:var(--z-index-modal);transition:left var(--transition-normal) var(--transition-timing);position:fixed;left:-260px;overflow-y:auto}.desktop-sidebar.sidebar-open{box-shadow:var(--shadow-md);left:0}.sidebar-backdrop{top:var(--header-height);z-index:calc(var(--z-index-modal) - 1);transition:opacity var(--transition-normal) var(--transition-timing);background:rgba(0,0,0,.5);display:none;position:fixed;bottom:0;left:0;right:0}.sidebar-backdrop.active{display:block}.desktop-content{width:100%;margin-left:0}}@media (orientation:landscape) and (max-height:600px){.app-header,.professional-header{height:48px}.desktop-body{margin-top:48px}.desktop-sidebar{height:calc(100vh - 48px);top:48px}}@media print{.app-header,.professional-header,.desktop-sidebar,.sidebar-toggle,.notification-badge,.offline-indicator,.sync-status-indicator,.btn,.dropdown-menu{display:none!important}.desktop-layout,.desktop-body,.desktop-content{background:#fff;width:100%;max-width:100%;margin:0;padding:0;display:block}.card,.table{box-shadow:none;border:1px solid #000}body,h1,h2,h3,h4,h5,h6,p,span,div{color:#000!important}}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}.desktop-sidebar{transition:none!important}}@media (prefers-contrast:high){.card,.table,.form-input,.btn{border-width:2px}body{color:#000}.btn{border:2px solid}}@media (max-width:767px){.hide-mobile{display:none!important}}@media (min-width:768px) and (max-width:1023px){.hide-tablet{display:none!important}}@media (min-width:1024px){.hide-desktop{display:none!important}}.show-mobile{display:none!important}@media (max-width:767px){.show-mobile{display:block!important}}.show-tablet{display:none!important}@media (min-width:768px) and (max-width:1023px){.show-tablet{display:block!important}}.show-desktop{display:none!important}@media (min-width:1024px){.show-desktop{display:block!important}}.page-enter{opacity:0}.page-enter-active{opacity:1;transition:opacity .15s ease-out}.page-exit{opacity:1}.page-exit-active{opacity:0;transition:opacity .15s ease-in}.fade-in{animation:.15s ease-out fade-in}.fade-out{animation:.15s ease-out fade-out}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes fade-out{0%{opacity:1}to{opacity:0}}.modal-backdrop-enter{opacity:0}.modal-backdrop-enter-active{opacity:1;transition:opacity .15s ease-out}.modal-backdrop-exit{opacity:1}.modal-backdrop-exit-active{opacity:0;transition:opacity .15s ease-in}.modal-content-enter{opacity:0}.modal-content-enter-active{opacity:1;transition:opacity .15s ease-out}.modal-content-exit{opacity:1}.modal-content-exit-active{opacity:0;transition:opacity .15s ease-in}.btn-interactive{transition:background-color .15s,box-shadow .15s}.btn-interactive:hover{box-shadow:0 2px 6px rgba(0,0,0,.1)}.btn-interactive:active{box-shadow:0 1px 3px rgba(0,0,0,.08)}.card-hover{transition:box-shadow .15s,border-color .15s}.card-hover:hover{border-color:var(--color-border-dark,#ced4da);box-shadow:0 2px 8px rgba(0,0,0,.08)}.spinner{animation:1s linear infinite spin}.focus-ring{transition:box-shadow .15s}.focus-ring:focus{outline:none;box-shadow:0 0 0 3px rgba(100,108,255,.3)}@media (prefers-reduced-motion:reduce){*,:before,:after{transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}.transition-all{transition:all .15s}.transition-fast{transition:all .1s}.transition-color{transition:color .15s,background-color .15s,border-color .15s}.course-list-page,.course-detail-page,.my-courses-page,.certificates-page,.course-management-page,.pending-approvals-page{max-width:100%!important;margin:0 auto!important;padding:16px!important}.page-header h1{color:#1a1a1a!important;letter-spacing:-.3px!important;font-size:20px!important;font-weight:600!important}.subtitle,.page-subtitle{color:#6c757d!important;font-size:14px!important}.btn,.btn-primary,.btn-secondary,.btn-success,.btn-danger{border-radius:4px!important;font-weight:500!important;transition:all .1s!important}.btn-primary{background:#1e40af!important}.btn-primary:hover:not(:disabled){background:#1e3a8a!important}.course-header,.card-header{background-image:none!important}.course-card,.certificate-card{border-radius:4px!important;box-shadow:0 1px 3px rgba(0,0,0,.1)!important}@media (min-width:768px){.course-list-page,.course-detail-page,.my-courses-page,.certificates-page,.course-management-page,.pending-approvals-page{padding:20px 24px!important}.page-header h1{font-size:22px!important}.course-list-page .courses-grid,.my-courses-page .courses-grid{grid-template-columns:repeat(2,1fr)!important;gap:16px!important;display:grid!important}.certificates-page .certificates-container.grid{grid-template-columns:repeat(2,1fr)!important;gap:16px!important}}@media (min-width:1024px){.course-list-page,.course-detail-page,.my-courses-page,.certificates-page,.course-management-page,.pending-approvals-page{max-width:none!important;padding:24px 32px!important}.page-header{text-align:left!important;border-bottom:1px solid #dee2e6!important;margin-bottom:24px!important;padding-bottom:16px!important}.page-header h1{color:#1a1a1a!important;letter-spacing:-.5px!important;margin:0 0 4px!important;font-size:24px!important;font-weight:600!important}.subtitle,.page-subtitle{color:#6c757d!important;margin:0!important;font-size:14px!important}.course-list-page .courses-grid{display:block}.course-list-page .course-card{box-shadow:none;background:#fff;border:1px solid #dee2e6;border-radius:4px;grid-template-columns:1fr 200px 150px 180px;align-items:center;gap:16px;margin-bottom:8px;padding:16px;transition:all .1s;display:grid}.course-list-page .course-card:hover{box-shadow:none;background:#f8f9fa;border-color:#1e40af;transform:none}.course-list-page .course-card-header{flex-direction:column;align-items:flex-start;gap:8px;margin-bottom:0}.course-list-page .course-card-header h3{color:#1a1a1a;font-size:16px;font-weight:600}.course-list-page .course-description{display:none}.course-list-page .course-meta{border-top:none;flex-direction:column;gap:4px;margin-bottom:0;padding-top:0}.course-list-page .meta-item{font-size:13px}.course-list-page .enrollment-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;padding:4px 12px;font-size:12px;font-weight:600}.course-list-page .course-card-footer{margin-top:0}.course-list-page .btn{border-radius:4px;padding:8px 16px;font-size:14px;transition:all .1s}.course-list-page .btn:hover:not(:disabled){box-shadow:none;transform:none}.course-list-page .search-input{border:1px solid #dee2e6;border-radius:4px;padding:10px 16px;font-size:14px}.course-list-page .search-input:focus{border-color:#1e40af;box-shadow:0 0 0 3px rgba(30,64,175,.1)}.course-list-page .empty-state{padding:48px 24px}.course-list-page .empty-icon{font-size:48px}.course-list-page .empty-state h2{font-size:20px;font-weight:600}.course-list-page .empty-state p{font-size:14px}.course-detail-page{max-width:none}.course-detail-page .course-header{background:#1e40af;padding:24px 32px}.course-detail-page .course-header h1{margin:0 0 12px;font-size:28px;font-weight:600}.course-detail-page .meta-badge{background:rgba(255,255,255,.15);border-radius:4px;padding:6px 12px;font-size:14px}.course-detail-page .course-detail-container{border-radius:4px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.course-detail-page .course-content{padding:32px}.course-detail-page .course-section{margin-bottom:32px}.course-detail-page .course-section h2{color:#1a1a1a;border-bottom:1px solid #dee2e6;margin-bottom:16px;padding-bottom:8px;font-size:18px;font-weight:600}.course-detail-page .course-description{color:#495057;font-size:15px;line-height:1.6}.course-detail-page .enrollment-status-banner{border-style:solid;border-width:1px;border-radius:4px;padding:12px 16px}.course-detail-page .status-icon{font-size:20px}.course-detail-page .status-text{font-size:14px;font-weight:600}.course-detail-page .course-actions{background:#f8f9fa;padding:24px 32px}.course-detail-page .btn-large{border-radius:4px;padding:12px 24px;font-size:15px;transition:all .1s}.course-detail-page .btn-large:hover:not(:disabled){transform:none;box-shadow:0 2px 4px rgba(0,0,0,.1)}.course-detail-page .back-button{margin-bottom:16px;padding:8px 0;font-size:14px}.course-detail-page .enrollment-info{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:16px}.course-detail-page .detail-item{padding:8px 0}.course-detail-page .detail-label{font-size:14px;font-weight:500}.course-detail-page .detail-value{font-size:14px}.my-courses-page .filter-tabs{border-bottom:1px solid #dee2e6;margin-bottom:24px}.my-courses-page .filter-tab{border-bottom-width:2px;padding:12px 20px;font-size:14px;font-weight:500;transition:all .1s}.my-courses-page .filter-tab:hover{background:#f8f9fa}.my-courses-page .filter-tab.active{color:#1e40af;border-bottom-color:#1e40af}.my-courses-page .courses-grid{display:block}.my-courses-page .course-card{box-shadow:none;background:#fff;border:1px solid #dee2e6;border-radius:4px;grid-template-columns:1fr 200px 250px;align-items:center;gap:24px;margin-bottom:8px;padding:16px 24px;transition:all .1s;display:grid}.my-courses-page .course-card:hover{box-shadow:none;background:#f8f9fa;border-color:#1e40af;transform:none}.my-courses-page .card-header{color:inherit;background:0 0;padding:0}.my-courses-page .course-title{color:#1a1a1a;margin:0 0 8px;font-size:16px;font-weight:600}.my-courses-page .status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;padding:4px 12px;font-size:12px;font-weight:600}.my-courses-page .badge-active{color:#1976d2;background:#e3f2fd}.my-courses-page .badge-pending{color:#856404;background:#fff3cd}.my-courses-page .card-body{padding:0}.my-courses-page .course-description{color:#6c757d;-webkit-line-clamp:2;margin:0;font-size:14px;display:block}.my-courses-page .course-meta{flex-direction:row;gap:16px;margin-top:8px}.my-courses-page .meta-item{color:#6c757d;font-size:13px}.my-courses-page .card-actions{background:0 0;border-top:none;justify-content:flex-end;gap:8px;padding:0;display:flex}.my-courses-page .btn-small{border-radius:4px;padding:8px 16px;font-size:13px;transition:all .1s}.my-courses-page .btn-small:hover:not(:disabled){box-shadow:none;transform:none}.my-courses-page .pending-message{color:#856404;font-size:13px}.my-courses-page .empty-state{border-radius:4px;padding:48px 24px;box-shadow:0 1px 3px rgba(0,0,0,.1)}.my-courses-page .empty-icon{font-size:48px}.my-courses-page .empty-state h2{font-size:20px;font-weight:600}.my-courses-page .empty-state p{font-size:14px}.certificates-page .header-actions{gap:12px}.certificates-page .cache-indicator,.certificates-page .offline-badge{border-width:1px;border-radius:4px;padding:6px 12px;font-size:13px}.certificates-page .refresh-button{border-radius:4px;padding:8px 16px;font-size:13px;transition:all .1s}.certificates-page .refresh-button:hover:not(:disabled){transform:none}.certificates-page .controls-bar{margin-bottom:24px}.certificates-page .search-input{border:1px solid #dee2e6;border-radius:4px;padding:10px 40px 10px 16px;font-size:14px}.certificates-page .search-input:focus{border-color:#1e40af}.certificates-page .view-toggle{border:1px solid #dee2e6;border-radius:4px;padding:10px 16px;transition:all .1s}.certificates-page .view-toggle:hover{border-color:#1e40af}.certificates-page .certificates-container.list{display:block}.certificates-page .certificates-container.list .certificate-card{border:1px solid #dee2e6;border-radius:4px;grid-template-columns:60px 1fr 200px 200px 120px;align-items:center;gap:24px;margin-bottom:8px;padding:16px 24px;transition:all .1s;display:grid}.certificates-page .certificates-container.list .certificate-card:before{display:none}.certificates-page .certificates-container.list .certificate-card:hover{box-shadow:none;background:#f8f9fa;border-color:#1e40af;transform:none}.certificates-page .certificates-container.list .certificate-header{flex-direction:column;gap:4px}.certificates-page .certificates-container.list .certificate-icon{font-size:28px}.certificates-page .certificates-container.list .certificate-number{border-radius:3px;padding:4px 8px;font-size:11px}.certificates-page .certificates-container.list .certificate-body{margin-bottom:0}.certificates-page .certificates-container.list .course-name{margin:0 0 4px;font-size:16px;font-weight:600}.certificates-page .certificates-container.list .student-name{color:#6c757d;margin:0;font-size:14px}.certificates-page .certificates-container.list .certificate-dates{flex-direction:column;gap:8px}.certificates-page .certificates-container.list .date-item{font-size:13px}.certificates-page .certificates-container.list .date-label{color:#6c757d}.certificates-page .certificates-container.list .date-value{color:#495057;font-weight:500}.certificates-page .certificates-container.list .certificate-footer{border-top:none;padding-top:0}.certificates-page .certificates-container.list .view-details{font-size:13px;font-weight:600}.certificates-page .certificates-container.grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:16px}.certificates-page .certificates-container.grid .certificate-card{border:1px solid #dee2e6;border-radius:4px;padding:20px;transition:all .1s}.certificates-page .certificates-container.grid .certificate-card:before{display:none}.certificates-page .certificates-container.grid .certificate-card:hover{border-color:#1e40af;transform:none;box-shadow:0 2px 4px rgba(0,0,0,.1)}.certificates-page .certificate-number{border-radius:3px;padding:4px 10px;font-size:12px}.certificates-page .course-name{font-size:18px;font-weight:600}.certificates-page .student-name{font-size:14px}.certificates-page .date-item{font-size:13px}.certificates-page .empty-state{padding:48px 24px}.certificates-page .empty-icon{font-size:48px}.certificates-page .empty-state h2{font-size:20px;font-weight:600}.certificates-page .empty-state p{font-size:14px}.certificates-page .action-button,.certificates-page .clear-button{border-radius:4px;padding:10px 20px;font-size:14px;transition:all .1s}.certificates-page .action-button:hover,.certificates-page .clear-button:hover{transform:none}.course-management-page .page-header{justify-content:space-between;align-items:center;margin-bottom:24px;padding-bottom:16px;display:flex}.course-management-page .page-header h1{margin:0}.course-management-page .filters-section{margin-bottom:24px}.course-management-page .search-input{border:1px solid #dee2e6;border-radius:4px;padding:10px 16px;font-size:14px}.course-management-page .search-input:focus{border-color:#1e40af}.course-management-page .filter-buttons{gap:8px;margin-top:16px;display:flex}.course-management-page .filter-btn{color:#495057;cursor:pointer;background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px 16px;font-size:14px;font-weight:500;transition:all .1s}.course-management-page .filter-btn:hover{background:#f8f9fa;border-color:#1e40af}.course-management-page .filter-btn.active{color:#fff;background:#1e40af;border-color:#1e40af}.course-management-page .courses-table-container,.pending-approvals-page .enrollments-table-container{background:#fff;border:1px solid #dee2e6;border-radius:4px;width:100%;overflow-x:auto}.course-management-page .courses-table,.pending-approvals-page .enrollments-table{border-collapse:collapse;width:100%}.course-management-page .courses-table thead,.pending-approvals-page .enrollments-table thead{background:#f8f9fa;border-bottom:2px solid #dee2e6}.course-management-page .courses-table th,.pending-approvals-page .enrollments-table th{text-align:left;color:#495057;text-transform:uppercase;letter-spacing:.5px;padding:12px 16px;font-size:13px;font-weight:600}.course-management-page .courses-table td,.pending-approvals-page .enrollments-table td{color:#495057;border-bottom:1px solid #f1f3f5;padding:16px;font-size:14px}.course-management-page .courses-table tbody tr:hover,.pending-approvals-page .enrollments-table tbody tr:hover{background:#f8f9fa}.course-management-page .courses-table tbody tr:last-child td,.pending-approvals-page .enrollments-table tbody tr:last-child td{border-bottom:none}.course-management-page .status-badge,.pending-approvals-page .status-badge{text-transform:uppercase;letter-spacing:.5px;border-radius:3px;padding:4px 12px;font-size:12px;font-weight:600}.course-management-page .status-draft{color:#6c757d;background:#f8f9fa}.course-management-page .status-published{color:#155724;background:#d4edda}.course-management-page .status-archived{color:#856404;background:#fff3cd}.course-management-page .action-buttons,.pending-approvals-page .action-buttons{align-items:center;gap:8px;display:flex}.course-management-page .btn-sm{border-radius:4px;padding:6px 12px;font-size:13px;transition:all .1s}.course-management-page .btn-sm:hover:not(:disabled){transform:none}.course-management-page .dropdown-container{position:relative}.course-management-page .dropdown-menu{border-radius:4px;box-shadow:0 2px 8px rgba(0,0,0,.15)}.pending-approvals-page .search-section{margin-bottom:24px}.pending-approvals-page .search-box{max-width:600px;position:relative}.pending-approvals-page .search-input{border:1px solid #dee2e6;border-radius:4px;width:100%;padding:10px 40px;font-size:14px}.pending-approvals-page .search-input:focus{border-color:#1e40af}.pending-approvals-page .search-meta{color:#6c757d;justify-content:space-between;align-items:center;margin-top:12px;font-size:13px;display:flex}.pending-approvals-page .student-info,.pending-approvals-page .course-info{flex-direction:column;gap:4px;display:flex}.pending-approvals-page .student-name,.pending-approvals-page .course-title{color:#1a1a1a;font-size:14px;font-weight:600}.pending-approvals-page .student-email{color:#6c757d;font-size:13px}.pending-approvals-page .btn-approve,.pending-approvals-page .btn-reject{cursor:pointer;border:none;border-radius:4px;align-items:center;gap:6px;padding:8px 16px;font-size:13px;font-weight:500;transition:all .1s;display:flex}.pending-approvals-page .btn-approve{color:#fff;background:#28a745}.pending-approvals-page .btn-approve:hover{background:#218838}.pending-approvals-page .btn-reject{color:#fff;background:#dc3545}.pending-approvals-page .btn-reject:hover{background:#c82333}.pending-approvals-page .pagination{justify-content:center;align-items:center;gap:8px;margin-top:24px;display:flex}.pending-approvals-page .pagination-btn,.pending-approvals-page .pagination-page{color:#495057;cursor:pointer;background:#fff;border:1px solid #dee2e6;border-radius:4px;padding:8px 12px;font-size:13px;transition:all .1s}.pending-approvals-page .pagination-btn:hover:not(:disabled),.pending-approvals-page .pagination-page:hover{background:#f8f9fa;border-color:#1e40af}.pending-approvals-page .pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pending-approvals-page .pagination-page.active{color:#fff;background:#1e40af;border-color:#1e40af}.pending-approvals-page .pagination-ellipsis{color:#6c757d;padding:8px 4px}.pending-approvals-page .sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.pending-approvals-page .sortable:hover{background:#e9ecef}.pending-approvals-page .th-content{align-items:center;gap:8px;display:flex}.pending-approvals-page .sort-icon{opacity:.3}.pending-approvals-page .sort-icon.active{opacity:1;color:#1e40af}.pending-approvals-page .success-banner,.pending-approvals-page .error-banner{border-radius:4px;align-items:center;gap:12px;margin-bottom:24px;padding:12px 16px;font-size:14px;display:flex}.pending-approvals-page .success-banner{color:#155724;background:#d4edda;border:1px solid #c3e6cb}.pending-approvals-page .error-banner{color:#721c24;background:#f8d7da;border:1px solid #f5c6cb}.modal-overlay{background:rgba(0,0,0,.4)}.modal-content,.modal{border-radius:4px;max-width:600px;box-shadow:0 4px 12px rgba(0,0,0,.15)}.modal-content h2,.modal-header h2{color:#1a1a1a;font-size:20px;font-weight:600}.modal-content p,.modal-body p{font-size:14px;line-height:1.6}.modal-info{background:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;padding:12px 16px}.modal-info p{font-size:14px;font-weight:600}.modal-info ul{font-size:13px}.modal-actions,.modal-footer{gap:12px}.modal-actions .btn,.modal-footer .btn{border-radius:4px;padding:10px 20px;font-size:14px;transition:all .1s}.modal-actions .btn:hover:not(:disabled),.modal-footer .btn:hover:not(:disabled){transform:none}.btn,.btn-primary,.btn-secondary,.btn-success,.btn-danger{border-radius:4px;font-weight:500;transition:all .1s}.btn:hover:not(:disabled),.btn-primary:hover:not(:disabled),.btn-secondary:hover:not(:disabled),.btn-success:hover:not(:disabled),.btn-danger:hover:not(:disabled){transform:none;box-shadow:0 2px 4px rgba(0,0,0,.1)}.btn-primary{background:#1e40af}.btn-primary:hover:not(:disabled){background:#1e3a8a}.btn-secondary{background:#6c757d}.btn-secondary:hover:not(:disabled){background:#5a6268}.btn-success{background:#28a745}.btn-success:hover:not(:disabled){background:#218838}.btn-danger{background:#dc3545}.btn-danger:hover:not(:disabled){background:#c82333}.loading-state,.error-state,.loading-container,.error-container{padding:48px 24px}.loading-state,.loading-container p{color:#6c757d;font-size:14px}.error-state p,.error-container p{color:#dc3545;font-size:14px}.spinner{border-width:3px;border-top-color:#1e40af;width:40px;height:40px}h1,h2,h3,h4,h5,h6{letter-spacing:-.3px;font-weight:600}p{line-height:1.5}.text-danger{color:#dc3545}.warning-box{background:#fff3cd;border:1px solid #ffc107;border-radius:4px;margin:16px 0;padding:16px}.warning-icon{font-size:24px}.warning-text{font-size:14px}.warning-text strong{color:#856404}.info-box{background:#e3f2fd;border:1px solid #2196f3;border-radius:4px;margin:16px 0;padding:16px}.info-icon{font-size:24px}.info-text{font-size:14px}.info-text strong{color:#1976d2}}@media (max-width:767px){.course-list-page .courses-grid,.my-courses-page .courses-grid{flex-direction:column;gap:12px;display:flex}.course-list-page .course-card,.my-courses-page .course-card{width:100%}.certificates-page .certificates-container.grid{flex-direction:column;gap:12px;display:flex}.page-header{margin-bottom:16px;padding-bottom:12px}.btn{padding:10px 16px;font-size:14px}.modal-content,.modal{width:95%;max-width:none;padding:20px}.modal-actions,.modal-footer{flex-direction:column;gap:8px}.modal-actions .btn,.modal-footer .btn{width:100%}.course-management-page .courses-table-container,.pending-approvals-page .enrollments-table-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.course-management-page .courses-table,.pending-approvals-page .enrollments-table{min-width:600px}}@media (min-width:768px) and (max-width:1023px){.course-list-page .courses-grid,.my-courses-page .courses-grid{grid-template-columns:repeat(2,1fr)}.course-list-page .course-card,.my-courses-page .course-card{padding:16px}.course-management-page .courses-table-container,.pending-approvals-page .enrollments-table-container{overflow-x:auto}}@media (min-width:1440px){.certificates-page .certificates-container.grid{grid-template-columns:repeat(3,1fr)}.course-list-page,.course-detail-page,.my-courses-page,.certificates-page,.course-management-page,.pending-approvals-page{padding:32px 48px}}@media (min-width:1920px){.certificates-page .certificates-container.grid{grid-template-columns:repeat(4,1fr)}}@media print{.page-header button,.btn,.action-buttons,.modal-overlay{display:none!important}.course-list-page,.course-detail-page,.my-courses-page,.certificates-page{padding:0}.course-card,.certificate-card{box-shadow:none;border:1px solid #dee2e6}}.notification-badge-button{cursor:pointer;background:0 0;border:none;border-radius:8px;justify-content:center;align-items:center;padding:8px;transition:background-color .2s;display:flex;position:relative}.notification-badge-button:hover{background-color:rgba(0,0,0,.05)}.notification-badge-button:active{background-color:rgba(0,0,0,.1)}.notification-icon{color:#333;width:24px;height:24px}.notification-badge-count{color:#fff;background-color:#ef4444;border-radius:10px;justify-content:center;align-items:center;min-width:18px;height:18px;padding:2px 5px;font-size:11px;font-weight:600;line-height:1;display:flex;position:absolute;top:4px;right:4px;box-shadow:0 1px 3px rgba(0,0,0,.2)}@media (prefers-color-scheme:dark){.notification-icon{color:#e5e7eb}.notification-badge-button:hover{background-color:rgba(255,255,255,.1)}.notification-badge-button:active{background-color:rgba(255,255,255,.15)}}.professional-header{height:var(--header-height);background:var(--sidebar-bg);border-bottom:1px solid var(--sidebar-border);z-index:var(--z-fixed);justify-content:space-between;align-items:center;gap:1rem;padding:0 1.5rem;display:flex;position:fixed;top:0;left:0;right:0;box-shadow:0 1px 3px rgba(0,0,0,.2)}.header-brand{flex-shrink:0;align-items:center;gap:10px;display:flex}.brand-text{font-size:1rem;font-weight:var(--font-weight-bold);color:#fff;white-space:nowrap;letter-spacing:-.01em}.header-actions{flex-shrink:0;align-items:center;gap:10px;display:flex}.user-info-professional{border-radius:var(--radius-md);background:rgba(255,255,255,.07);border:1px solid rgba(255,255,255,.1);align-items:center;gap:8px;padding:5px 12px;display:flex}.user-name-professional{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:rgba(255,255,255,.9);white-space:nowrap}.admin-badge-professional{color:#78350f;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.04em;background:#f59e0b;padding:2px 7px;line-height:1}.cal-header-btn{border-radius:var(--radius-md);color:rgba(255,255,255,.7);cursor:pointer;width:34px;height:34px;transition:all var(--transition-normal);background:rgba(255,255,255,.07);border:none;justify-content:center;align-items:center;display:flex}.cal-header-btn:hover{color:#fff;background:rgba(255,255,255,.14)}.logout-btn-professional{color:#fca5a5;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.25);align-items:center;gap:6px;padding:6px 12px;display:inline-flex}.logout-btn-professional:hover{color:#fff;background:rgba(239,68,68,.28)}.btn-header-secondary,.btn-header-primary{border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);cursor:pointer;transition:all var(--transition-normal);white-space:nowrap;border:1px solid transparent;padding:7px 14px}.btn-header-secondary{color:rgba(255,255,255,.85);background:rgba(255,255,255,.08);border-color:rgba(255,255,255,.15)}.btn-header-secondary:hover{color:#fff;background:rgba(255,255,255,.14)}.btn-header-primary{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-header-primary:hover{background:var(--primary-hover)}@media (max-width:767px){.professional-header{padding:0 1rem}.brand-text{font-size:.85rem}.user-name-professional,.logout-btn-professional span{display:none}.logout-btn-professional{padding:6px 8px}}@media (min-width:1440px){.professional-header{padding:0 2rem}}.spinner-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;padding:2rem;display:flex}.spinner-fullscreen{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:9999;background:rgba(0,0,0,.5);flex-direction:column;justify-content:center;align-items:center;gap:1rem;display:flex;position:fixed;top:0;bottom:0;left:0;right:0}.spinner{border-style:solid;border-color:var(--primary-color) transparent var(--primary-color) transparent;border-radius:50%;animation:1s linear infinite spin}.spinner-small{border-width:2px;width:20px;height:20px}.spinner-medium{border-width:4px;width:40px;height:40px}.spinner-large{border-width:6px;width:60px;height:60px}.spinner-text{color:var(--text-primary);font-size:var(--font-base);text-align:center;margin:0}.spinner-fullscreen .spinner-text{color:#fff}.desktop-layout{background:var(--color-bg-secondary);flex-direction:column;min-height:100vh;display:flex}.sidebar-toggle{top:calc(var(--header-height) + 12px);z-index:calc(var(--z-fixed) + 1);background:var(--primary-color);color:#fff;border-radius:var(--radius-md);cursor:pointer;box-shadow:var(--shadow-md);transition:background var(--transition-normal);border:none;padding:8px 10px;font-size:1.1rem;line-height:1;display:none;position:fixed;left:12px}.sidebar-toggle:hover{background:var(--primary-hover)}.sidebar-backdrop{top:0;bottom:0;left:0;right:0;top:var(--header-height);z-index:calc(var(--z-modal) - 1);opacity:0;pointer-events:none;transition:opacity var(--transition-normal);background:rgba(0,0,0,.4);display:none;position:fixed}.sidebar-backdrop.active{opacity:1;pointer-events:auto}.desktop-body{grid-template-columns:var(--sidebar-width) 1fr;margin-top:var(--header-height);flex:1;display:grid}.desktop-body:not(:has(.desktop-sidebar)){grid-template-columns:1fr}.desktop-body:not(:has(.desktop-sidebar)) .desktop-content{max-width:1200px;margin:0 auto}.desktop-content{width:100%;min-height:calc(100vh - var(--header-height));background:var(--color-bg-secondary);padding:2rem;overflow-x:hidden;overflow-y:auto}@media (min-width:768px) and (max-width:1023px){.sidebar-toggle{display:flex}.sidebar-backdrop{display:block}.desktop-body{grid-template-columns:1fr}.desktop-sidebar{top:var(--header-height);height:calc(100vh - var(--header-height));z-index:var(--z-fixed);transition:left var(--transition-slow);box-shadow:var(--shadow-xl);left:-280px;position:fixed!important}.desktop-body.sidebar-open .desktop-sidebar{left:0}}@media (min-width:1440px){.desktop-content{padding:2.5rem 3rem}}@media print{.desktop-body{display:block}.desktop-content{min-height:auto;padding:0}.sidebar-toggle,.sidebar-backdrop{display:none!important}}.notification-item{cursor:pointer;border-bottom:1px solid #e5e7eb;align-items:flex-start;gap:12px;padding:16px;transition:background-color .2s;display:flex;position:relative}.notification-item:hover{background-color:#f9fafb}.notification-item:active{background-color:#f3f4f6}.notification-item.unread{background-color:#eff6ff}.notification-item.unread:hover{background-color:#dbeafe}.notification-icon-container{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.notification-icon-container svg{width:20px;height:20px}.notification-blue .notification-icon-container{color:#2563eb;background-color:#dbeafe}.notification-green .notification-icon-container{color:#059669;background-color:#d1fae5}.notification-orange .notification-icon-container{color:#d97706;background-color:#fed7aa}.notification-red .notification-icon-container{color:#dc2626;background-color:#fee2e2}.notification-purple .notification-icon-container{color:#9333ea;background-color:#e9d5ff}.notification-gray .notification-icon-container{color:#6b7280;background-color:#f3f4f6}.notification-content{flex:1;min-width:0}.notification-header{justify-content:space-between;align-items:flex-start;gap:8px;margin-bottom:4px;display:flex}.notification-title{color:#111827;margin:0;font-size:14px;font-weight:600;line-height:1.4}.notification-time{color:#6b7280;white-space:nowrap;flex-shrink:0;font-size:12px}.notification-message{color:#4b5563;margin:0;font-size:14px;line-height:1.5}.notification-actions{opacity:0;flex-shrink:0;gap:4px;transition:opacity .2s;display:flex}.notification-item:hover .notification-actions{opacity:1}.notification-actions:focus-within{opacity:1}.notification-mark-read-btn,.notification-delete-btn{cursor:pointer;color:#6b7280;background:0 0;border:1px solid transparent;border-radius:6px;justify-content:center;align-items:center;min-width:32px;min-height:32px;padding:6px;transition:all .2s;display:flex}.notification-mark-read-btn:hover{color:#059669;background-color:#d1fae5;border-color:#059669}.notification-mark-read-btn:active{background-color:#a7f3d0}.notification-delete-btn:hover{color:#dc2626;background-color:#fee2e2;border-color:#dc2626}.notification-delete-btn:active{background-color:#fecaca}@media (max-width:640px){.notification-item{padding:12px}.notification-icon-container{width:36px;height:36px}.notification-icon-container svg{width:18px;height:18px}.notification-title,.notification-message{font-size:13px}.notification-time{font-size:11px}.notification-actions{opacity:1}.notification-mark-read-btn,.notification-delete-btn{padding:8px}}@media (prefers-color-scheme:dark){.notification-item{border-bottom-color:#374151}.notification-item:hover{background-color:#1f2937}.notification-item:active{background-color:#111827}.notification-item.unread{background-color:#1e3a5f}.notification-item.unread:hover{background-color:#1e40af}.notification-title{color:#f9fafb}.notification-message{color:#d1d5db}.notification-time,.notification-mark-read-btn,.notification-delete-btn{color:#9ca3af}.notification-mark-read-btn:hover{color:#10b981;background-color:#374151}.notification-mark-read-btn:active{background-color:#4b5563}.notification-delete-btn:hover{color:#ef4444;background-color:#7f1d1d}.notification-delete-btn:active{background-color:#991b1b}}.notification-center-overlay{z-index:1000;background-color:rgba(0,0,0,.3);animation:.15s ease-out fadeIn;position:fixed;top:0;bottom:0;left:0;right:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.notification-center-panel{background-color:#fff;flex-direction:column;width:100%;max-width:420px;height:100vh;animation:.15s ease-out fadeIn;display:flex;position:fixed;top:0;right:0;box-shadow:-2px 0 8px rgba(0,0,0,.1)}.notification-center-header{border-bottom:1px solid #e5e7eb;justify-content:space-between;align-items:center;padding:20px;display:flex}.notification-center-title{color:#111827;margin:0;font-size:20px;font-weight:600}.notification-center-close{cursor:pointer;color:#6b7280;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:8px;transition:all .2s;display:flex}.notification-center-close:hover{color:#111827;background-color:#f3f4f6}.notification-center-filters{border-bottom:1px solid #e5e7eb;gap:8px;padding:16px 20px 0;display:flex}.notification-filter-tab{cursor:pointer;color:#6b7280;background:0 0;border:none;border-bottom:2px solid transparent;padding:8px 16px;font-size:14px;font-weight:500;transition:all .2s}.notification-filter-tab:hover{color:#111827}.notification-filter-tab.active{color:#2563eb;border-bottom-color:#2563eb}.notification-center-actions{background-color:#f9fafb;border-bottom:1px solid #e5e7eb;padding:12px 20px}.notification-action-btn{cursor:pointer;color:#2563eb;background:0 0;border:none;padding:0;font-size:14px;font-weight:500;transition:color .2s}.notification-action-btn:hover{color:#1d4ed8;text-decoration:underline}.notification-center-content{background-color:#fff;flex:1;overflow-y:auto}.notification-center-loading,.notification-center-error,.notification-center-empty{text-align:center;color:#6b7280;flex-direction:column;justify-content:center;align-items:center;padding:40px 20px;display:flex}.notification-center-loading .spinner{border:3px solid #e5e7eb;border-top-color:#2563eb;border-radius:50%;width:40px;height:40px;margin-bottom:16px;animation:.8s linear infinite spin}.notification-center-loading p,.notification-center-empty p{margin:0;font-size:14px}.notification-center-error p{color:#dc2626;margin:0 0 16px;font-size:14px}.notification-center-error button{color:#fff;cursor:pointer;background-color:#2563eb;border:none;border-radius:6px;padding:8px 16px;font-size:14px;font-weight:500;transition:background-color .2s}.notification-center-error button:hover{background-color:#1d4ed8}.notification-center-empty svg{color:#d1d5db;margin-bottom:16px}@media (max-width:640px){.notification-center-panel{max-width:100%}.notification-center-header{padding:16px}.notification-center-title{font-size:18px}.notification-center-filters{padding:12px 16px 0}.notification-center-actions{padding:10px 16px}}@media (prefers-color-scheme:dark){.notification-center-overlay{background-color:rgba(0,0,0,.6)}.notification-center-panel{background-color:#1f2937}.notification-center-header{border-bottom-color:#374151}.notification-center-title{color:#f9fafb}.notification-center-close{color:#9ca3af}.notification-center-close:hover{color:#f9fafb;background-color:#374151}.notification-center-filters{border-bottom-color:#374151}.notification-filter-tab{color:#9ca3af}.notification-filter-tab:hover{color:#f9fafb}.notification-filter-tab.active{color:#3b82f6;border-bottom-color:#3b82f6}.notification-center-actions{background-color:#111827;border-bottom-color:#374151}.notification-action-btn{color:#3b82f6}.notification-action-btn:hover{color:#60a5fa}.notification-center-content{background-color:#1f2937}.notification-center-loading,.notification-center-error,.notification-center-empty{color:#9ca3af}.notification-center-loading .spinner{border-color:#3b82f6 #374151 #374151}.notification-center-error p{color:#ef4444}.notification-center-error button{background-color:#3b82f6}.notification-center-error button:hover{background-color:#2563eb}.notification-center-empty svg{color:#4b5563}}.offline-indicator{z-index:9999;background:#fff;border-radius:12px;max-width:300px;padding:12px 16px;animation:.15s ease-out fadeIn;position:fixed;top:60px;right:20px;box-shadow:0 4px 12px rgba(0,0,0,.15)}.offline-indicator.offline{background:#fff3e0;border-left:4px solid #ff9800}.offline-indicator.online{background:#e8f5e9;border-left:4px solid #4caf50}.offline-indicator-content{align-items:center;gap:8px;font-size:14px;font-weight:500;display:flex}.offline-icon,.online-icon{font-size:18px}.offline-text{color:#e65100}.online-text{color:#2e7d32}.pending-badge{color:#fff;background:#ff5722;border-radius:12px;margin-left:auto;padding:2px 8px;font-size:12px;font-weight:600}.sync-button{color:#fff;cursor:pointer;background:#4caf50;border:none;border-radius:6px;margin-left:8px;padding:4px 12px;font-size:12px;font-weight:600;transition:background .2s}.sync-button:hover{background:#45a049}.sync-button:active{transform:scale(.95)}.pending-details{color:#666;border-top:1px solid rgba(0,0,0,.1);flex-direction:column;gap:4px;margin-top:8px;padding-top:8px;font-size:12px;display:flex}@keyframes slideInRight{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}@media (max-width:768px){.offline-indicator{max-width:none;top:10px;left:10px;right:10px}}.sync-status-indicator{z-index:1000;background:#fff;border-radius:8px;min-width:250px;padding:12px 16px;animation:.3s ease-out slideIn;position:fixed;bottom:20px;right:20px;box-shadow:0 4px 12px rgba(0,0,0,.15)}@keyframes slideIn{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.sync-status-content{align-items:center;gap:12px;display:flex}.sync-status-icon{flex-shrink:0;font-size:20px}.sync-status-message{color:#333;flex:1;font-size:14px;font-weight:500}.sync-retry-button{color:#fff;cursor:pointer;background:#2196f3;border:none;border-radius:4px;padding:6px 12px;font-size:12px;font-weight:600;transition:background .2s}.sync-retry-button:hover:not(:disabled){background:#1976d2}.sync-retry-button:disabled{cursor:not-allowed;background:#ccc}.sync-status-indicator.syncing{border-left:4px solid #2196f3}.sync-status-indicator.success{border-left:4px solid #4caf50}.sync-status-indicator.error{border-left:4px solid #f44336}.sync-status-indicator.offline{border-left:4px solid #ff9800}.sync-status-indicator.idle{border-left:4px solid #9e9e9e}.sync-progress-bar{background:#e0e0e0;border-radius:2px;height:3px;margin-top:8px;overflow:hidden}.sync-progress-bar-fill{background:#2196f3;height:100%;animation:1.5s ease-in-out infinite progress}@keyframes progress{0%{transform:translate(-100%)}to{transform:translate(400%)}}@media (max-width:640px){.sync-status-indicator{min-width:auto;bottom:10px;left:10px;right:10px}.sync-status-message{font-size:13px}.sync-retry-button{padding:5px 10px;font-size:11px}}@media (prefers-color-scheme:dark){.sync-status-indicator{background:#2c2c2c;box-shadow:0 4px 12px rgba(0,0,0,.3)}.sync-status-message{color:#e0e0e0}.sync-progress-bar{background:#424242}}.app-layout{background:var(--color-bg-secondary);flex-direction:column;min-height:100vh;display:flex}.app-header{background:var(--sidebar-bg);color:#fff;z-index:var(--z-fixed);height:var(--header-height);border-bottom:1px solid var(--sidebar-border);box-shadow:var(--shadow-md);align-items:center;display:flex;position:-webkit-sticky;position:sticky;top:0}.header-content{justify-content:space-between;align-items:center;gap:1rem;width:100%;padding:0 1rem;display:flex}.dropdown-container{z-index:var(--z-dropdown);position:relative}.dropdown-trigger{color:#fff;font-size:.9rem;font-weight:var(--font-weight-semibold);font-family:var(--font-family);cursor:pointer;border-radius:var(--radius-md);transition:background var(--transition-normal);background:rgba(255,255,255,.08);border:1px solid rgba(255,255,255,.12);align-items:center;gap:8px;padding:8px 14px;display:flex}.dropdown-trigger:hover{background:rgba(255,255,255,.14)}.dropdown-title{white-space:nowrap}.dropdown-arrow{opacity:.7;font-size:.7rem}.dropdown-menu{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-xl);min-width:240px;z-index:var(--z-dropdown);animation:.15s menuSlide;position:absolute;top:calc(100% + 6px);left:0;overflow:hidden}@keyframes menuSlide{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.dropdown-item{color:var(--text-primary);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:background var(--transition-fast);border-left:3px solid transparent;align-items:center;gap:10px;padding:10px 16px;text-decoration:none;display:flex}.dropdown-item:hover{background:var(--color-primary-xlight);color:var(--primary-color);border-left-color:var(--primary-color)}.dropdown-divider{background:var(--border-color);height:1px;margin:4px 0}.dropdown-section-title{font-size:10px;font-weight:var(--font-weight-bold);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.08em;background:var(--color-bg-secondary);padding:8px 16px 4px}.header-right{align-items:center;gap:10px;display:flex}.user-info-compact{color:rgba(255,255,255,.9);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);align-items:center;gap:6px;display:flex}.user-name{white-space:nowrap}.admin-badge{color:#78350f;border-radius:var(--radius-full);font-size:10px;font-weight:var(--font-weight-bold);text-transform:uppercase;letter-spacing:.04em;background:#f59e0b;padding:2px 8px}.logout-btn-compact{color:#fca5a5;border-radius:var(--radius-md);cursor:pointer;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);font-family:var(--font-family);transition:all var(--transition-normal);white-space:nowrap;background:rgba(239,68,68,.15);border:1px solid rgba(239,68,68,.25);padding:6px 12px}.logout-btn-compact:hover{color:#fff;background:rgba(239,68,68,.25)}.nav-link-compact{color:rgba(255,255,255,.8);border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);transition:all var(--transition-normal);border:1px solid rgba(255,255,255,.12);padding:6px 12px;text-decoration:none}.nav-link-compact:hover{color:#fff;background:rgba(255,255,255,.1)}.btn-primary-compact{background:var(--primary-color);color:#fff;border-color:var(--primary-color)}.btn-primary-compact:hover{background:var(--primary-hover)}.app-main{flex:1;padding:1.5rem 1rem}.app-footer{background:var(--sidebar-bg);border-top:1px solid var(--sidebar-border);text-align:center;color:var(--sidebar-text);font-size:var(--font-size-sm);padding:1rem 1.5rem}@media (max-width:640px){.header-content{gap:.5rem;padding:0 .75rem}.dropdown-trigger{padding:6px 10px;font-size:.8rem}.dropdown-title{text-overflow:ellipsis;max-width:110px;overflow:hidden}.dropdown-menu{top:calc(var(--header-height) + 4px);min-width:auto;max-height:calc(100vh - 80px);position:fixed;left:.5rem;right:.5rem;overflow-y:auto}.user-name{display:none}.logout-btn-compact,.nav-link-compact{padding:5px 8px;font-size:.75rem}.app-main{padding:1rem .75rem}}@media (min-width:641px){.header-content{padding:0 1.5rem}.app-main{padding:2rem 1.5rem}}@media (min-width:1024px){.app-main{padding:2.5rem 2rem}}.install-nav-btn{cursor:pointer;font-family:var(--font-family);background:0 0}.skeleton{background:linear-gradient(90deg, var(--border-color) 0%, rgba(255,255,255,.1) 50%, var(--border-color) 100%);background-size:200% 100%;border-radius:4px;animation:1.5s ease-in-out infinite skeleton-loading}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.skeleton-image{width:100%;height:200px}.skeleton-content{flex-direction:column;gap:.75rem;padding:1.5rem;display:flex}.skeleton-title{width:70%;height:24px}.skeleton-text{width:100%;height:16px}.skeleton-text-short{width:60%}.skeleton-list{flex-direction:column;gap:1rem;display:flex}.skeleton-list-item{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;align-items:center;gap:1rem;padding:1rem;display:flex}.skeleton-avatar{border-radius:50%;flex-shrink:0;width:48px;height:48px}.skeleton-list-content{flex-direction:column;flex:1;gap:.5rem;display:flex}.skeleton-table{background:var(--card-bg);border:1px solid var(--border-color);border-radius:12px;overflow:hidden}.skeleton-table-header{border-bottom:1px solid var(--border-color);background:rgba(255,255,255,.05);grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;padding:1rem;display:grid}.skeleton-table-header-cell{height:20px}.skeleton-table-row{border-bottom:1px solid var(--border-color);grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:1rem;padding:1rem;display:grid}.skeleton-table-row:last-child{border-bottom:none}.skeleton-table-cell{height:16px}.skeleton-text-block{flex-direction:column;gap:.75rem;display:flex}@media (max-width:639px){.skeleton-image{height:150px}.skeleton-content{padding:1rem}.skeleton-table-header,.skeleton-table-row{grid-template-columns:1fr}}.toast{min-width:280px;max-width:500px;font-size:var(--font-base);border-radius:8px;align-items:center;gap:.75rem;padding:1rem 1.25rem;font-weight:500;animation:.3s ease-out toast-slide-in;display:flex;box-shadow:0 4px 12px rgba(0,0,0,.15)}.toast-icon{flex-shrink:0;justify-content:center;align-items:center;width:24px;height:24px;font-size:1.5rem;display:flex}.toast-message{flex:1;line-height:1.4}.toast-close{color:inherit;cursor:pointer;opacity:.7;background:0 0;border:none;justify-content:center;align-items:center;min-width:24px;min-height:24px;padding:.25rem;font-size:1.25rem;transition:opacity .2s;display:flex}.toast-close:hover{opacity:1}.toast-success{background:var(--success-color);color:#fff}.toast-error{background:var(--error-color);color:#fff}.toast-warning{background:var(--warning-color);color:#fff}.toast-info{background:var(--primary-color);color:#fff}@keyframes toast-slide-in{0%{opacity:0;transform:translate(400px)}to{opacity:1;transform:translate(0)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0)}to{opacity:0;transform:translate(400px)}}.toast-exit{animation:.3s ease-out forwards toast-slide-out}@media (max-width:639px){.toast{min-width:auto;max-width:calc(100vw - 2rem);margin:0 1rem}}.toast-container{z-index:10000;pointer-events:none;flex-direction:column;gap:.75rem;display:flex;position:fixed;bottom:2rem;right:2rem}.toast-container>*{pointer-events:auto}@media (max-width:639px){.toast-container{align-items:center;bottom:1rem;left:0;right:0}}@supports (padding-bottom:env(safe-area-inset-bottom)){.toast-container{bottom:calc(2rem + env(safe-area-inset-bottom))}@media (max-width:639px){.toast-container{bottom:calc(1rem + env(safe-area-inset-bottom))}}}.progress-bar-container{width:100%}.progress-bar-header{justify-content:space-between;align-items:center;margin-bottom:.5rem;display:flex}.progress-bar-label{font-size:var(--font-sm);color:var(--text-primary);font-weight:500}.progress-bar-percentage{font-size:var(--font-sm);color:var(--text-secondary);font-weight:600}.progress-bar{background:var(--border-color);border-radius:9999px;width:100%;position:relative;overflow:hidden}.progress-bar-small{height:4px}.progress-bar-medium{height:8px}.progress-bar-large{height:12px}.progress-bar-fill{background:var(--primary-color);border-radius:9999px;height:100%;transition:width .3s}.progress-bar-success .progress-bar-fill{background:var(--success-color)}.progress-bar-warning .progress-bar-fill{background:var(--warning-color)}.progress-bar-error .progress-bar-fill{background:var(--error-color)}.progress-bar-indeterminate{width:30%;animation:1.5s ease-in-out infinite progress-indeterminate}@keyframes progress-indeterminate{0%{transform:translate(-100%)}50%{transform:translate(350%)}to{transform:translate(-100%)}}.progress-bar-striped .progress-bar-fill{background-image:linear-gradient(45deg,rgba(255,255,255,.15) 25%,transparent 25%,transparent 50%,rgba(255,255,255,.15) 50%,rgba(255,255,255,.15) 75%,transparent 75%,transparent);background-size:1rem 1rem;animation:1s linear infinite progress-stripes}@keyframes progress-stripes{0%{background-position:0 0}to{background-position:1rem 0}}.error-boundary{background:linear-gradient(135deg,rgba(245,101,101,.05) 0%,rgba(239,68,68,.05) 100%);justify-content:center;align-items:center;min-height:100vh;padding:2rem;display:flex}.error-boundary-content{background:var(--card-bg);border:1px solid var(--border-color);text-align:center;border-radius:16px;width:100%;max-width:600px;padding:3rem 2rem;box-shadow:0 4px 24px rgba(0,0,0,.1)}.error-icon{margin-bottom:1.5rem;font-size:4rem}.error-title{color:var(--text-primary);margin:0 0 1rem;font-size:2rem}.error-message{color:var(--text-secondary);margin:0 0 2rem;font-size:1.1rem;line-height:1.6}.error-details{text-align:left;border:1px solid var(--error-color);background:rgba(245,101,101,.1);border-radius:8px;margin:2rem 0;padding:1rem}.error-details summary{cursor:pointer;color:var(--error-color);-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;padding:.5rem;font-weight:600}.error-details summary:hover{opacity:.8}.error-stack{background:var(--bg-color);color:var(--text-primary);white-space:pre-wrap;word-break:break-word;border-radius:4px;margin:1rem 0 0;padding:1rem;font-size:.85rem;overflow-x:auto}.error-actions{flex-wrap:wrap;justify-content:center;gap:1rem;display:flex}@media (max-width:639px){.error-boundary{padding:1rem}.error-boundary-content{padding:2rem 1.5rem}.error-icon{font-size:3rem}.error-title{font-size:1.5rem}.error-message{font-size:1rem}.error-actions{flex-direction:column}.error-actions .btn{width:100%}}.error-message{border:2px solid;border-radius:12px;align-items:flex-start;gap:1rem;margin:1rem 0;padding:1.5rem;display:flex}.error-message-error{border-color:var(--error-color);background:rgba(245,101,101,.1)}.error-message-warning{border-color:var(--warning-color);background:rgba(237,137,54,.1)}.error-message-info{border-color:var(--primary-color);background:rgba(100,108,255,.1)}.error-message-icon{border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:2rem;display:flex}.error-message-error .error-message-icon{background:var(--error-color);color:#fff}.error-message-warning .error-message-icon{background:var(--warning-color);color:#fff}.error-message-info .error-message-icon{background:var(--primary-color);color:#fff}.error-message-content{flex:1}.error-message-title{color:var(--text-primary);margin:0 0 .5rem;font-size:1.125rem;font-weight:600}.error-message-text{color:var(--text-secondary);margin:0 0 1rem;line-height:1.5}.error-message-retry{margin-top:.5rem}@media (max-width:639px){.error-message{text-align:center;flex-direction:column;align-items:center;padding:1.25rem}.error-message-icon{margin-bottom:.5rem}.error-message-retry{width:100%}}.empty-state{text-align:center;flex-direction:column;justify-content:center;align-items:center;min-height:400px;padding:4rem 2rem;display:flex}.empty-state-icon{opacity:.8;margin-bottom:1.5rem;font-size:5rem}.empty-state-illustration{justify-content:center;align-items:center;width:200px;height:200px;margin-bottom:2rem;display:flex}.empty-state-illustration img,.empty-state-illustration svg{max-width:100%;max-height:100%}.empty-state-title{color:var(--text-primary);margin:0 0 .75rem;font-size:1.5rem;font-weight:600}.empty-state-message{color:var(--text-secondary);max-width:500px;margin:0 0 2rem;font-size:1rem;line-height:1.6}.empty-state-action{min-width:200px}@media (max-width:639px){.empty-state{min-height:300px;padding:3rem 1.5rem}.empty-state-icon{font-size:3.5rem}.empty-state-illustration{width:150px;height:150px}.empty-state-title{font-size:1.25rem}.empty-state-message{font-size:.95rem}.empty-state-action{width:100%;min-width:auto}}.empty-state{animation:.15s ease-out empty-state-fade-in}@keyframes empty-state-fade-in{0%{opacity:0}to{opacity:1}}.rate-limit-message{text-align:center;background:linear-gradient(135deg,#fff5e6 0%,#ffe6cc 100%);border:2px solid #ff9800;border-radius:12px;margin:20px 0;padding:24px;animation:.3s ease-out slideIn;box-shadow:0 4px 12px rgba(255,152,0,.15)}.rate-limit-icon{margin-bottom:16px;font-size:48px;animation:2s ease-in-out infinite pulse}.rate-limit-message h3{color:#e65100;margin:0 0 12px;font-size:20px;font-weight:600}.rate-limit-message p{color:#5d4037;margin:12px 0;font-size:15px;line-height:1.6}.rate-limit-tip{background:rgba(255,255,255,.7);border-radius:8px;margin-top:16px;padding:12px;font-size:14px}.rate-limit-tip strong{color:#e65100}.rate-limit-close-btn{color:#fff;cursor:pointer;background:#ff9800;border:none;border-radius:8px;margin-top:16px;padding:12px 32px;font-size:15px;font-weight:600;transition:all .2s}.rate-limit-close-btn:hover{background:#f57c00;transform:translateY(-2px);box-shadow:0 4px 8px rgba(255,152,0,.3)}.rate-limit-close-btn:active{transform:translateY(0)}@keyframes pulse{0%,to{transform:scale(1)}50%{transform:scale(1.1)}}@media (max-width:640px){.rate-limit-message{margin:16px 0;padding:20px}.rate-limit-icon{font-size:40px}.rate-limit-message h3{font-size:18px}.rate-limit-message p{font-size:14px}.rate-limit-close-btn{width:100%;padding:14px}}.stat-card{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);align-items:center;gap:1rem;min-height:90px;padding:1.25rem 1.5rem;display:flex}.stat-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.stat-card-icon{border-radius:var(--radius-md);background:var(--color-primary-xlight);width:48px;height:48px;color:var(--primary-color);flex-shrink:0;justify-content:center;align-items:center;display:flex}.stat-card-icon svg{stroke-width:2px;width:24px;height:24px}.stat-card-content{flex-direction:column;flex:1;gap:2px;display:flex}.stat-card-value{font-size:1.75rem;font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.02em;margin:0;line-height:1.2}.stat-card-title,.stat-card-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--text-secondary);margin:0}.stat-card-footer{border-top:1px solid var(--color-border-light);font-size:var(--font-size-xs);color:var(--color-text-tertiary);align-items:center;gap:6px;padding-top:8px;display:flex}.stat-card-trend{font-weight:var(--font-weight-medium);align-items:center;gap:4px;display:flex}.stat-card-trend.positive{color:var(--color-success)}.stat-card-trend.negative{color:var(--color-error)}.stat-card-trend svg{width:14px;height:14px}@media (max-width:640px){.stat-card{min-height:76px;padding:1rem}.stat-card-icon{width:40px;height:40px}.stat-card-icon svg{width:20px;height:20px}.stat-card-value{font-size:1.4rem}}.quick-actions-grid{gap:var(--spacing-4);grid-template-columns:repeat(auto-fill,minmax(280px,1fr));display:grid}.quick-action-item{align-items:center;gap:var(--spacing-4);padding:var(--spacing-4);background:var(--color-bg-primary);border:1px solid var(--color-border-medium);border-radius:var(--border-radius-md);color:inherit;transition:all var(--transition-normal) var(--transition-timing);text-decoration:none;display:flex}.quick-action-item:hover{border-color:var(--color-primary);background:var(--color-bg-secondary)}.quick-action-icon{background:var(--color-bg-secondary);border-radius:var(--border-radius-md);width:40px;height:40px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.quick-action-icon svg{stroke-width:2px;width:20px;height:20px}.quick-action-content{flex:1;min-width:0}.quick-action-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.quick-action-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}@media (max-width:768px){.quick-actions-grid{grid-template-columns:1fr}.quick-action-item{padding:var(--spacing-3)}.quick-action-icon{width:36px;height:36px}.quick-action-icon svg{width:18px;height:18px}}.recent-activity-list{flex-direction:column;display:flex}.activity-item{align-items:flex-start;gap:var(--spacing-4);padding:var(--spacing-4);border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-normal) var(--transition-timing);display:flex}.activity-item:last-child{border-bottom:none}.activity-item:hover{background:var(--color-bg-secondary)}.activity-icon{background:var(--color-bg-secondary);border-radius:var(--border-radius-md);width:32px;height:32px;color:var(--color-primary);flex-shrink:0;justify-content:center;align-items:center;display:flex}.activity-icon svg{stroke-width:2px;width:16px;height:16px}.activity-content{flex:1;min-width:0}.activity-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:var(--spacing-1)}.activity-description{font-size:var(--font-size-sm);color:var(--color-text-secondary);line-height:var(--line-height-normal)}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap;flex-shrink:0}.recent-activity-empty{padding:var(--spacing-8);text-align:center}.recent-activity-empty p{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:0}@media (max-width:768px){.activity-item{padding:var(--spacing-3);gap:var(--spacing-3)}.activity-icon{width:28px;height:28px}.activity-icon svg{width:14px;height:14px}.activity-time{display:none}}.pwa-install-prompt{z-index:9999;width:calc(100% - 40px);max-width:500px;animation:.3s ease-out slideUp;position:fixed;bottom:20px;left:50%;transform:translate(-50%)}@keyframes slideUp{0%{opacity:0;transform:translate(-50%)translateY(100px)}to{opacity:1;transform:translate(-50%)translateY(0)}}.pwa-install-content{background:#fff;border:1px solid #e0e0e0;border-radius:12px;flex-direction:column;gap:16px;padding:20px;display:flex;box-shadow:0 4px 20px rgba(0,0,0,.15)}.pwa-install-icon{color:#fff;background:#2196f3;border-radius:50%;justify-content:center;align-items:center;width:48px;height:48px;margin:0 auto;display:flex}.pwa-install-text{text-align:center}.pwa-install-text h3{color:#333;margin:0 0 8px;font-size:1.25rem;font-weight:600}.pwa-install-text p{color:#666;margin:0;font-size:.875rem;line-height:1.5}.pwa-install-actions{justify-content:center;gap:12px;display:flex}.pwa-install-button{cursor:pointer;border:none;border-radius:8px;outline:none;padding:10px 24px;font-size:.875rem;font-weight:500;transition:all .2s}.pwa-install-button.primary{color:#fff;background:#2196f3}.pwa-install-button.primary:hover{background:#1976d2;transform:translateY(-1px);box-shadow:0 2px 8px rgba(33,150,243,.3)}.pwa-install-button.secondary{color:#666;background:0 0;border:1px solid #ddd}.pwa-install-button.secondary:hover{background:#f5f5f5;border-color:#ccc}.pwa-install-button:active{transform:translateY(0)}@media (max-width:640px){.pwa-install-prompt{width:calc(100% - 20px);bottom:10px}.pwa-install-content{padding:16px}.pwa-install-actions{flex-direction:column}.pwa-install-button{width:100%}}@media (prefers-color-scheme:dark){.pwa-install-content{background:#1e1e1e;border-color:#333}.pwa-install-text h3{color:#fff}.pwa-install-text p{color:#aaa}.pwa-install-button.secondary{color:#aaa;border-color:#444}.pwa-install-button.secondary:hover{background:#2a2a2a;border-color:#555}}#root{width:100%;min-height:100vh;font-family:var(--font-family-base);color:var(--color-text-primary);background-color:var(--color-bg-secondary);margin:0;padding:0}.card{background:var(--color-bg-primary);border:1px solid var(--color-border-medium);border-radius:var(--border-radius-md);padding:var(--spacing-6);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-normal) var(--transition-timing)}.card:hover{box-shadow:var(--shadow-md)}.btn{height:var(--button-height);padding:var(--button-padding-y) var(--button-padding-x);border-radius:var(--button-border-radius);font-family:var(--font-family-base);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);cursor:pointer;transition:all var(--transition-normal) var(--transition-timing);border:none;justify-content:center;align-items:center;text-decoration:none;display:inline-flex}.btn-primary{background-color:var(--color-primary);color:#fff}.btn-primary:hover{background-color:var(--color-primary-hover)}.btn-secondary{background-color:var(--color-text-secondary);color:#fff}.btn-secondary:hover{background-color:var(--color-text-primary)}.input{width:100%;height:var(--input-height);padding:var(--input-padding-y) var(--input-padding-x);border:var(--input-border-width) solid var(--input-border-color);border-radius:var(--input-border-radius);font-family:var(--font-family-base);font-size:var(--font-size-base);color:var(--color-text-primary);background-color:var(--color-bg-primary);transition:border-color var(--transition-normal) var(--transition-timing)}.input:focus{border-color:var(--color-primary);outline:none}.input:disabled{background-color:var(--color-bg-secondary);color:var(--color-text-disabled);cursor:not-allowed}a{color:var(--color-primary);transition:color var(--transition-normal) var(--transition-timing);text-decoration:none}a:hover{color:var(--color-primary-hover)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.gap-2{gap:var(--spacing-2)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}@media (min-width:768px){.card{padding:var(--spacing-8)}}@media (min-width:1024px){.form-desktop select{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=text]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=email]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=password]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=date]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=number]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=tel]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop input[type=url]{height:38px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop textarea{min-height:76px;padding:8px 12px;font-size:14px;line-height:1.4}.form-desktop .btn{height:38px;padding:8px 16px;font-size:14px;line-height:1.4}.form-desktop button[type=submit]{height:38px;padding:8px 16px;font-size:14px;line-height:1.4}.form-desktop button[type=button]{height:38px;padding:8px 16px;font-size:14px;line-height:1.4}.form-desktop .btn-lg{height:40px;padding:10px 24px;font-size:15px}.form-desktop .btn-sm{height:32px;padding:6px 12px;font-size:13px}.form-desktop .form-row-2{grid-template-columns:repeat(2,1fr);gap:16px;margin-bottom:16px;display:grid}.form-desktop .form-row-3{grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:16px;display:grid}.form-desktop .form-group-inline{grid-template-columns:140px 1fr;align-items:center;gap:12px;margin-bottom:12px;display:grid}.form-desktop .form-group-inline label{text-align:right;margin-bottom:0;font-size:14px}.form-desktop .form-group{margin-bottom:12px}.form-desktop .form-group label{margin-bottom:4px;font-size:13px;font-weight:500}.form-desktop .field-error{color:var(--color-error);margin:0;padding:0;font-size:12px;line-height:1.2;position:absolute;bottom:-18px;left:0}.form-desktop .form-group-with-error{padding-bottom:20px;position:relative}.form-desktop .input-error,.form-desktop input.input-error{border-color:var(--color-error)}.form-desktop .input-error:focus{border-color:var(--color-error);box-shadow:0 0 0 3px rgba(220,53,69,.1)}.form-desktop .input-success{border-color:var(--color-success)}.form-desktop .password-input-wrapper{align-items:center;display:flex;position:relative}.form-desktop .password-input-wrapper input{padding-right:40px}.form-desktop .password-toggle{cursor:pointer;width:24px;height:24px;color:var(--color-text-secondary);transition:color var(--transition-normal);background:0 0;border:none;justify-content:center;align-items:center;padding:0;display:flex;position:absolute;right:8px}.form-desktop .password-toggle:hover{color:var(--color-text-primary)}.form-desktop .form-actions{border-top:1px solid var(--color-border-light);justify-content:flex-end;gap:12px;margin-top:16px;padding-top:16px;display:flex}.form-desktop.registration-form .form-row-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}.form-desktop.login-form{max-width:400px}.form-desktop.course-form .form-group{margin-bottom:16px}.form-desktop.course-form textarea{min-height:100px}.form-desktop .requirements-list{margin-top:8px}.form-desktop .requirements-list li{margin-bottom:6px;padding:8px 12px}.form-desktop .requirements-input-group{gap:8px;display:flex}.form-desktop select{-webkit-appearance:none;-moz-appearance:none;-ms-appearance:none;appearance:none;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='%23495057' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:36px}.form-desktop input[type=checkbox]{cursor:pointer;width:16px;height:16px;margin-right:8px}.form-desktop input[type=radio]{cursor:pointer;width:16px;height:16px;margin-right:8px}.form-desktop .checkbox-group,.form-desktop .radio-group{align-items:center;gap:8px;margin-bottom:8px;display:flex}.form-desktop .form-help{color:var(--color-text-secondary);margin-top:4px;font-size:12px;line-height:1.3}.form-desktop .required{color:var(--color-error);margin-left:2px}.form-desktop .form-section{border-bottom:1px solid var(--color-border-light);margin-bottom:24px;padding-bottom:24px}.form-desktop .form-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.form-desktop .form-section-title{color:var(--color-text-primary);margin-bottom:16px;font-size:16px;font-weight:600}.form-desktop .password-strength{margin-top:6px}.form-desktop .strength-bar{background-color:var(--color-border-light);border-radius:2px;height:3px;margin-bottom:4px;overflow:hidden}.form-desktop .strength-fill{height:100%;transition:width var(--transition-normal), background-color var(--transition-normal)}.form-desktop .strength-weak .strength-fill{background-color:var(--color-error);width:33%}.form-desktop .strength-medium .strength-fill{background-color:var(--color-warning);width:66%}.form-desktop .strength-strong .strength-fill{background-color:var(--color-success);width:100%}.form-desktop .strength-text{font-size:11px;font-weight:500}.form-desktop .error-box{background-color:#fee;border:1px solid #fcc;border-radius:4px;margin-bottom:16px;padding:12px}.form-desktop .error-box h3{color:var(--color-error);margin-bottom:6px;font-size:14px}.form-desktop .error-box ul{margin:0;padding-left:20px;font-size:13px}.form-desktop .error-box li{margin-bottom:4px}.form-desktop .spinner{border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;width:14px;height:14px;animation:.6s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.form-desktop-container{max-width:800px;margin:0 auto;padding:24px}.form-desktop-container.narrow{max-width:500px}.form-desktop-container.wide{max-width:1000px}}@media (min-width:768px) and (max-width:1023px){.form-desktop select{height:42px;padding:10px 14px;font-size:15px}.form-desktop input[type=text]{height:42px;padding:10px 14px;font-size:15px}.form-desktop input[type=email]{height:42px;padding:10px 14px;font-size:15px}.form-desktop input[type=password]{height:42px;padding:10px 14px;font-size:15px}.form-desktop input[type=date]{height:42px;padding:10px 14px;font-size:15px}.form-desktop .btn{height:42px;padding:10px 18px;font-size:15px}.form-desktop .form-row-2,.form-desktop .form-row-3{grid-template-columns:repeat(2,1fr);gap:14px;display:grid}}@media (min-width:1024px){.courses-table-container,.enrollments-table-container,.certificates-container.list,.table-responsive-wrapper{width:100%;max-width:none;overflow-x:auto;overflow-y:visible}.courses-table,.enrollments-table,table.min-w-full,.table,.table-responsive{table-layout:auto;border-collapse:collapse;width:100%}.courses-table th,.courses-table td,.enrollments-table th,.enrollments-table td,table.min-w-full th,table.min-w-full td{padding:var(--spacing-3,12px) var(--spacing-4,16px);text-align:left;vertical-align:middle}.courses-table th:first-child,.enrollments-table th:first-child{width:35%}.courses-table th:nth-child(2),.enrollments-table th:nth-child(2){width:20%}.courses-table th:nth-child(3),.enrollments-table th:nth-child(3),.courses-table th:nth-child(4),.enrollments-table th:nth-child(4),.courses-table th:last-child,.enrollments-table th:last-child{width:15%}.courses-table-container::-webkit-scrollbar{height:8px}.enrollments-table-container::-webkit-scrollbar{height:8px}.table-responsive-wrapper::-webkit-scrollbar{height:8px}.courses-table-container::-webkit-scrollbar-track{background:var(--color-bg-secondary,#f8f9fa);border-radius:4px}.enrollments-table-container::-webkit-scrollbar-track{background:var(--color-bg-secondary,#f8f9fa);border-radius:4px}.table-responsive-wrapper::-webkit-scrollbar-track{background:var(--color-bg-secondary,#f8f9fa);border-radius:4px}.courses-table-container::-webkit-scrollbar-thumb{background:var(--color-border,#dee2e6);border-radius:4px}.enrollments-table-container::-webkit-scrollbar-thumb{background:var(--color-border,#dee2e6);border-radius:4px}.table-responsive-wrapper::-webkit-scrollbar-thumb{background:var(--color-border,#dee2e6);border-radius:4px}.courses-table-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary,#6c757d)}.enrollments-table-container::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary,#6c757d)}.table-responsive-wrapper::-webkit-scrollbar-thumb:hover{background:var(--color-text-secondary,#6c757d)}.certificates-container,.course-list-container,.user-list-container{width:100%;max-width:none}.certificates-container.list{gap:var(--spacing-3,12px);flex-direction:column;display:flex}.certificates-container.list .certificate-card{width:100%;max-width:none}.certificates-container.grid{gap:var(--spacing-4,16px);grid-template-columns:repeat(auto-fill,minmax(320px,1fr));width:100%;display:grid}.dashboard-stats{gap:var(--spacing-4,16px);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));width:100%;display:grid}.quick-actions-grid{gap:var(--spacing-3,12px);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));width:100%;display:grid}}@media (min-width:1440px){.certificates-container.grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.dashboard-stats{grid-template-columns:repeat(4,1fr)}.quick-actions-grid{grid-template-columns:repeat(auto-fit,minmax(140px,1fr))}}@media (min-width:1920px){.certificates-container.grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.dashboard-stats{grid-template-columns:repeat(5,1fr)}}@media (min-width:1024px){.container.mx-auto.px-4.py-8.max-w-6xl{max-width:none;padding-left:var(--spacing-6,24px);padding-right:var(--spacing-6,24px)}table.min-w-full{min-width:100%}table.min-w-full th:first-child{width:20%}table.min-w-full th:nth-child(2){width:25%}table.min-w-full th:nth-child(3){width:15%}table.min-w-full th:nth-child(4){width:20%}table.min-w-full th:nth-child(5),table.min-w-full th:nth-child(6){width:10%}.pending-approvals-page{width:100%;max-width:none}.enrollments-table-container{width:100%;overflow-x:auto}.enrollments-table{width:100%;min-width:900px}.enrollments-table th:first-child,.enrollments-table th:nth-child(2){width:25%}.enrollments-table th:nth-child(3),.enrollments-table th:nth-child(4){width:18%}.enrollments-table th:nth-child(5){width:14%}.course-management-page{width:100%;max-width:none}.courses-table-container{width:100%;overflow-x:auto}.courses-table{width:100%;min-width:800px}.courses-table th:first-child{width:40%}.courses-table th:nth-child(2),.courses-table th:nth-child(3),.courses-table th:nth-child(4),.courses-table th:nth-child(5){width:15%}.page-container,.content-wrapper,.main-content{width:100%;max-width:none}.app-content{width:100%;padding-left:var(--spacing-6,24px);padding-right:var(--spacing-6,24px)}.page-header,.filters-section,.search-section,.controls-bar{width:100%;max-width:none}.table-scroll-container{overflow-x:auto;overflow-y:visible}.table-scroll-container,.courses-table-container,.enrollments-table-container{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.table-scroll-container:not(:hover)::-webkit-scrollbar-thumb{background:0 0}.courses-table-container:not(:hover)::-webkit-scrollbar-thumb{background:0 0}.enrollments-table-container:not(:hover)::-webkit-scrollbar-thumb{background:0 0}.grid-auto-fit-desktop{gap:var(--spacing-4,16px);grid-template-columns:repeat(auto-fit,minmax(250px,1fr));width:100%;display:grid}@media (min-width:1440px){.grid-auto-fit-desktop{grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}}@media (min-width:1920px){.grid-auto-fit-desktop{grid-template-columns:repeat(auto-fit,minmax(320px,1fr))}}.courses-table td,.enrollments-table td,table.min-w-full td{text-overflow:ellipsis;overflow:hidden}.course-title-cell,.student-info,.course-info{white-space:normal;overflow:visible}.action-buttons{gap:var(--spacing-2,8px);flex-wrap:nowrap;justify-content:flex-start;display:flex;overflow:visible}.action-buttons .btn{padding:var(--spacing-2,8px) var(--spacing-3,12px);font-size:var(--font-size-sm,14px)}.action-buttons .dropdown-container{position:relative;overflow:visible}.list-item,.certificate-card,.course-card{width:100%;max-width:none}.list-view{gap:var(--spacing-3,12px);flex-direction:column;width:100%;display:flex}.list-item-content{justify-content:space-between;align-items:center;gap:var(--spacing-4,16px);width:100%;display:flex}.list-item-main{flex:1;min-width:0}.list-item-actions{flex-shrink:0}.empty-state{width:100%;max-width:600px;margin:var(--spacing-8,48px) auto;text-align:center}.pagination{justify-content:center;align-items:center;gap:var(--spacing-2,8px);width:100%;margin-top:var(--spacing-6,24px);display:flex}.pagination-pages{gap:var(--spacing-1,4px);display:flex}.pagination-page{justify-content:center;align-items:center;min-width:40px;height:40px;display:flex}}.card-responsive,.course-card,.course-stats-card,.enrollments-table tbody tr,.notification-item,.notification-center-tab,.sidebar-item,.form-input,.form-select,.form-textarea,.btn,.dropdown-trigger,.dropdown-item,.logout-btn-compact,.btn-primary-compact{transition-duration:.15s!important}.card-responsive:hover,.course-card:hover,.course-stats-card:hover,.certificate-card:hover,.btn:hover:not(:disabled),.btn:active,.btn-primary:hover:not(:disabled),.btn-primary:active,.dgt-btn-primary:hover:not(:disabled),.dgt-btn-primary:active:not(:disabled),.logout-btn-compact:hover,.logout-btn-compact:active,.btn-primary-compact:hover,.dropdown-trigger:hover,.dropdown-trigger:active,.sync-button:active{transform:none!important}.card-responsive:hover,.course-card:hover,.course-stats-card:hover{border-color:var(--color-border-dark,#ced4da)!important;box-shadow:0 2px 8px rgba(0,0,0,.08)!important}.certificate-card:hover{border-color:#4caf50!important;box-shadow:0 2px 8px rgba(76,175,80,.15)!important}.btn:hover:not(:disabled){box-shadow:0 2px 6px rgba(0,0,0,.1)!important}.btn:active{box-shadow:0 1px 3px rgba(0,0,0,.08)!important}.notification-center-overlay,.notification-center,.offline-indicator,.empty-state,.dropdown-menu{animation:.15s ease-out fadeIn!important}.spinner,.loading-spinner,[class*=spinner]{animation:1s linear infinite spin!important}.form-desktop .form-input:focus,.form-desktop .form-select:focus,.form-desktop .form-textarea:focus{transition:border-color .15s,box-shadow .15s!important}.form-desktop .strength-fill{transition:width .15s,background-color .15s!important}.card-responsive{transition:box-shadow .15s,border-color .15s!important}.dropdown-arrow{transition:transform .15s!important}.dropdown-item{transition:background-color .15s,color .15s!important}.notification-badge{transition:background-color .15s!important}.notification-center-tab{transition:color .15s,border-color .15s!important}.notification-item{transition:background-color .15s!important}.notification-item .action-button{transition:background-color .15s,color .15s!important}.enrollments-table tbody tr{transition:background-color .15s!important}.action-button,.filter-button,.pagination-button{transition:background-color .15s,color .15s,border-color .15s!important}.tab-button{transition:color .15s,border-color .15s!important}.course-stats-card{transition:box-shadow .15s,border-color .15s!important}.course-stats-card:hover{border-color:#2196f3!important;box-shadow:0 2px 8px rgba(0,0,0,.08)!important}.progress-fill{transition:width .15s!important}.sidebar-item,.btn-header-primary,.btn-header-secondary{transition:background-color .15s,color .15s!important}.btn-header-secondary:active,.btn-header-primary:active{transform:none!important}.sync-button{transition:background-color .15s!important}.refresh-button:hover:not(:disabled){background:#45a049!important;transform:none!important}a{transition:color .15s!important}.btn{transition:background-color .15s,color .15s,border-color .15s,box-shadow .15s!important}.form-input,.form-select,.form-textarea{transition:border-color .15s,box-shadow .15s!important}:before,:after{transition-duration:.15s!important}.shimmer{animation:none!important}.stagger-item{animation:.15s ease-out fadeIn!important}.home-page-professional{width:100%}.dashboard-container{flex-direction:column;gap:1.5rem;display:flex}.dashboard-header{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem 2rem}.dashboard-title{font-size:1.5rem;font-weight:var(--font-weight-bold);color:var(--text-primary);letter-spacing:-.02em;margin:0 0 4px}.dashboard-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0}.dashboard-stats-grid{grid-template-columns:repeat(4,1fr);gap:1rem;display:grid}@media (max-width:1024px){.dashboard-stats-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.dashboard-stats-grid{grid-template-columns:repeat(2,1fr);gap:.75rem}}.dashboard-content{grid-template-columns:1fr 1fr;gap:1rem;display:grid}@media (max-width:768px){.dashboard-content{grid-template-columns:1fr}}.dashboard-section{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:1.5rem}.dashboard-section.full-width{grid-column:1/-1}.section-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--text-primary);border-bottom:1px solid var(--border-color);margin:0 0 1rem;padding-bottom:.75rem}.activity-card{min-height:80px}.activity-loading{color:var(--text-secondary);font-size:var(--font-size-sm);padding:1rem 0}.guest-section{flex-direction:column;gap:1.5rem;display:flex}.hero-section{background:var(--primary-color);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-md);padding:3rem 2rem}.hero-title{font-size:2rem;font-weight:var(--font-weight-bold);color:#fff;letter-spacing:-.02em;margin:0 0 .75rem}.hero-subtitle{font-size:var(--font-size-md);color:rgba(255,255,255,.8);margin:0;max-width:500px;margin-left:auto;margin-right:auto}.access-card{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);text-align:center;box-shadow:var(--shadow-sm);padding:2rem}.access-title{font-size:1.25rem;font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0 0 8px}.access-description{font-size:var(--font-size-sm);color:var(--text-secondary);margin:0 0 1.5rem}.access-buttons{flex-wrap:wrap;justify-content:center;gap:.75rem;display:flex}.features-grid{grid-template-columns:repeat(3,1fr);gap:1rem;display:grid}@media (max-width:768px){.features-grid{grid-template-columns:1fr}}.feature-card{background:var(--color-bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);transition:border-color var(--transition-normal), box-shadow var(--transition-normal);padding:1.5rem}.feature-card:hover{border-color:var(--color-primary-light);box-shadow:var(--shadow-md)}.feature-icon{background:var(--color-primary-xlight);border-radius:var(--radius-md);width:44px;height:44px;color:var(--primary-color);justify-content:center;align-items:center;margin-bottom:1rem;display:flex}.feature-icon svg{stroke:currentColor;width:22px;height:22px}.feature-title{font-size:var(--font-size-md);font-weight:var(--font-weight-semibold);color:var(--text-primary);margin:0 0 6px}.feature-description{font-size:var(--font-size-sm);color:var(--text-secondary);line-height:var(--line-height-relaxed);margin:0}@media (max-width:640px){.hero-section{padding:2rem 1.25rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:var(--font-size-sm)}.dashboard-header{padding:1.25rem}.dashboard-title{font-size:1.25rem}}
