:root{--deep-ocean: #1a3a52;--azure-flow: #2d6b8a;--teal-mist: #4a8fa8;--celestial-blue: #6ba3b8;--dark-teal: #1d4f64;--warm-light: #f4d03f;--golden-accent: #d4a84b;--soft-white: #fafaf8;--ethereal-cream: #f5f0e8;--mist-grey: #e8e4dc;--color-bg-primary: var(--soft-white);--color-bg-secondary: var(--ethereal-cream);--color-bg-tertiary: var(--mist-grey);--color-bg-hover: var(--ethereal-cream);--color-bg-active: var(--mist-grey);--color-bg-sidebar: var(--soft-white);--color-border: var(--mist-grey);--color-border-light: var(--ethereal-cream);--color-border-dark: #d4cfc4;--color-text-primary: var(--deep-ocean);--color-text-secondary: var(--teal-mist);--color-text-tertiary: var(--celestial-blue);--color-text-inverse: var(--soft-white);--color-accent-primary: var(--azure-flow);--color-accent-primary-hover: var(--dark-teal);--color-accent-secondary: #3d9970;--color-accent-warning: var(--warm-light);--color-accent-danger: #c0392b;--color-accent-info: var(--teal-mist);--color-accent-gold: var(--golden-accent);--color-status-todo: var(--celestial-blue);--color-status-progress: var(--warm-light);--color-status-review: var(--azure-flow);--color-status-done: #3d9970;--shadow-sm: 0 1px 2px 0 rgb(0 0 0 / .05);--shadow-md: 0 4px 6px -1px rgb(0 0 0 / .1), 0 2px 4px -2px rgb(0 0 0 / .1);--shadow-lg: 0 10px 15px -3px rgb(0 0 0 / .1), 0 4px 6px -4px rgb(0 0 0 / .1);--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 24px;--spacing-2xl: 32px;--spacing-3xl: 48px;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 8px;--radius-xl: 12px;--radius-full: 9999px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Oxygen, Ubuntu, sans-serif;--font-size-xs: 11px;--font-size-sm: 12px;--font-size-md: 13px;--font-size-lg: 14px;--font-size-xl: 16px;--font-size-2xl: 20px;--font-size-3xl: 24px;--transition-fast: .15s ease;--transition-normal: .2s ease;--sidebar-width: 240px;--header-height: 52px}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);font-size:var(--font-size-md);line-height:1.5;color:var(--color-text-primary);background-color:var(--color-bg-primary)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--spacing-xs)}.gap-sm{gap:var(--spacing-sm)}.gap-md{gap:var(--spacing-md)}.gap-lg{gap:var(--spacing-lg)}.gap-xl{gap:var(--spacing-xl)}.app-layout{display:flex;min-height:100vh}.sidebar{width:var(--sidebar-width);background:var(--color-bg-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:fixed;top:0;left:0;bottom:0;z-index:100}.sidebar-header{padding:var(--spacing-md) var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:var(--spacing-sm);height:var(--header-height)}.sidebar-logo{width:24px;height:24px;background:linear-gradient(135deg,var(--azure-flow),var(--deep-ocean));border-radius:var(--radius-md);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:600;font-size:var(--font-size-sm)}.sidebar-title{font-weight:600;font-size:var(--font-size-lg);color:var(--color-text-primary)}.sidebar-content{flex:1;overflow-y:auto;padding:var(--spacing-md) 0}.sidebar-section{margin-bottom:var(--spacing-lg)}.sidebar-section-title{padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.sidebar-nav{list-style:none}.sidebar-nav-item{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);color:var(--color-text-secondary);text-decoration:none;font-size:var(--font-size-md);font-weight:500;transition:all var(--transition-fast);cursor:pointer;border:none;background:none;width:100%;text-align:left}.sidebar-nav-item:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.sidebar-nav-item.active{background:var(--color-bg-active);color:var(--color-text-primary)}.sidebar-nav-item svg{width:16px;height:16px;flex-shrink:0}.main-content{flex:1;margin-left:var(--sidebar-width);display:flex;flex-direction:column;min-height:100vh}.main-header{height:var(--header-height);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--spacing-xl);background:var(--color-bg-primary);position:sticky;top:0;z-index:50}.page-content{flex:1;padding:var(--spacing-xl);background:var(--color-bg-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-lg);font-size:var(--font-size-md);font-weight:500;font-family:var(--font-family);border-radius:var(--radius-md);border:1px solid transparent;cursor:pointer;transition:all var(--transition-fast);text-decoration:none}.btn-primary{background:var(--color-accent-primary);color:var(--color-text-inverse)}.btn-primary:hover{background:var(--color-accent-primary-hover)}.btn-secondary{background:var(--color-bg-primary);border-color:var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark)}.btn-ghost{background:transparent;color:var(--color-text-secondary)}.btn-ghost:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-sm)}.btn-lg{padding:var(--spacing-md) var(--spacing-xl);font-size:var(--font-size-lg)}.card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.card-header{padding:var(--spacing-lg);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between}.card-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary)}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-top:2px}.card-body{padding:var(--spacing-lg)}.form-group{margin-bottom:var(--spacing-lg)}.form-label{display:block;font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.form-input{width:100%;padding:var(--spacing-sm) var(--spacing-md);font-size:var(--font-size-md);font-family:var(--font-family);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-primary);color:var(--color-text-primary);transition:all var(--transition-fast)}.form-input:focus{outline:none;border-color:var(--color-accent-primary);box-shadow:0 0 0 3px #2d6b8a26}.form-input::placeholder{color:var(--color-text-tertiary)}.badge{display:inline-flex;align-items:center;gap:4px;padding:2px 8px;font-size:var(--font-size-xs);font-weight:500;border-radius:var(--radius-full);background:var(--color-bg-tertiary);color:var(--color-text-secondary)}.badge-primary{background:#2d6b8a1f;color:var(--color-accent-primary)}.badge-success{background:#10b9811a;color:var(--color-accent-secondary)}.badge-warning{background:#f59e0b1a;color:var(--color-accent-warning)}.badge-danger{background:#ef44441a;color:var(--color-accent-danger)}.badge-info{background:#3b82f61a;color:var(--color-accent-info)}.tabs{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--color-border);padding:0 var(--spacing-lg)}.tab{padding:var(--spacing-md) var(--spacing-lg);font-size:var(--font-size-md);font-weight:500;color:var(--color-text-secondary);background:none;border:none;border-bottom:2px solid transparent;cursor:pointer;transition:all var(--transition-fast);margin-bottom:-1px}.tab:hover{color:var(--color-text-primary)}.tab.active{color:var(--color-accent-primary);border-bottom-color:var(--color-accent-primary)}.avatar{width:32px;height:32px;border-radius:var(--radius-full);background:linear-gradient(135deg,var(--azure-flow),var(--deep-ocean));display:flex;align-items:center;justify-content:center;color:#fff;font-size:var(--font-size-sm);font-weight:600}.avatar-sm{width:24px;height:24px;font-size:var(--font-size-xs)}.avatar-lg{width:48px;height:48px;font-size:var(--font-size-xl)}.avatar-xl{width:80px;height:80px;font-size:var(--font-size-3xl)}.progress-bar{height:6px;background:var(--color-bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.progress-bar-fill{height:100%;background:var(--color-accent-primary);border-radius:var(--radius-full);transition:width var(--transition-normal)}.progress-bar-success .progress-bar-fill{background:var(--color-accent-secondary)}.stat-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin-bottom:var(--spacing-xs)}.stat-value{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-primary)}.stat-change{font-size:var(--font-size-xs);margin-top:var(--spacing-xs)}.stat-change-positive{color:var(--color-accent-secondary)}.stat-change-negative{color:var(--color-accent-danger)}.table{width:100%;border-collapse:collapse}.table th,.table td{padding:var(--spacing-md) var(--spacing-lg);text-align:left;border-bottom:1px solid var(--color-border)}.table th{font-size:var(--font-size-xs);font-weight:500;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;background:var(--color-bg-secondary)}.table td{font-size:var(--font-size-md);color:var(--color-text-primary)}.table tr:hover td{background:var(--color-bg-hover)}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--color-bg-secondary)}.login-card{width:100%;max-width:400px;background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--spacing-3xl);box-shadow:var(--shadow-lg)}.login-logo{display:flex;align-items:center;justify-content:center;gap:var(--spacing-sm);margin-bottom:var(--spacing-2xl)}.login-logo-icon{width:40px;height:40px;background:linear-gradient(135deg,var(--azure-flow),var(--deep-ocean));border-radius:var(--radius-lg);display:flex;align-items:center;justify-content:center;color:#fff;font-weight:700;font-size:var(--font-size-xl)}.login-logo-text{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary)}.login-title{text-align:center;font-size:var(--font-size-xl);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.login-subtitle{text-align:center;font-size:var(--font-size-md);color:var(--color-text-secondary);margin-bottom:var(--spacing-xl)}.grid{display:grid;gap:var(--spacing-lg)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.skill-chip{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;background:var(--color-bg-tertiary);border:1px solid var(--color-border);border-radius:var(--radius-full);font-size:var(--font-size-sm);color:var(--color-text-primary);transition:all var(--transition-fast)}.skill-chip:hover{background:var(--color-bg-hover);border-color:var(--color-border-dark)}.skill-chip-required{background:#2d6b8a1a;border-color:#2d6b8a40;color:var(--color-accent-primary)}.skill-chip-completed{background:#10b98114;border-color:#10b98133;color:var(--color-accent-secondary)}.achievement-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg);display:flex;flex-direction:column;align-items:center;text-align:center;transition:all var(--transition-fast)}.achievement-card:hover{border-color:var(--color-border-dark);box-shadow:var(--shadow-md)}.achievement-card.locked{opacity:.5}.achievement-icon{width:56px;height:56px;border-radius:var(--radius-full);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-md);font-size:24px}.achievement-icon-gold{background:linear-gradient(135deg,var(--warm-light),var(--golden-accent))}.achievement-icon-silver{background:linear-gradient(135deg,var(--celestial-blue),var(--teal-mist))}.achievement-icon-bronze{background:linear-gradient(135deg,var(--golden-accent),#b8860b)}.achievement-icon-purple{background:linear-gradient(135deg,var(--azure-flow),var(--deep-ocean))}.achievement-title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.achievement-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.timeline{position:relative;padding-left:24px}.timeline:before{content:"";position:absolute;left:7px;top:4px;bottom:4px;width:2px;background:var(--color-border)}.timeline-item{position:relative;padding-bottom:var(--spacing-xl)}.timeline-item:last-child{padding-bottom:0}.timeline-dot{position:absolute;left:-20px;top:4px;width:12px;height:12px;border-radius:var(--radius-full);background:var(--color-bg-primary);border:2px solid var(--color-border)}.timeline-dot.active{background:var(--color-accent-primary);border-color:var(--color-accent-primary)}.timeline-dot.completed{background:var(--color-accent-secondary);border-color:var(--color-accent-secondary)}.timeline-content{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--spacing-lg)}.timeline-title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.timeline-desc{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.course-card{background:var(--color-bg-primary);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-fast)}.course-card:hover{border-color:var(--color-border-dark);box-shadow:var(--shadow-md)}.course-thumbnail{height:120px;background:linear-gradient(135deg,var(--azure-flow),var(--deep-ocean));display:flex;align-items:center;justify-content:center}.course-thumbnail svg{width:40px;height:40px;color:#fff;opacity:.9}.course-content{padding:var(--spacing-lg)}.course-category{font-size:var(--font-size-xs);color:var(--color-accent-primary);font-weight:500;margin-bottom:var(--spacing-xs)}.course-title{font-size:var(--font-size-md);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-sm)}.course-meta{display:flex;align-items:center;gap:var(--spacing-md);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.page-header{margin-bottom:var(--spacing-xl)}.page-title{font-size:var(--font-size-2xl);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--font-size-md);color:var(--color-text-secondary)}.search-input{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-sm) var(--spacing-md);background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-md);width:240px}.search-input input{flex:1;border:none;background:none;font-size:var(--font-size-md);font-family:var(--font-family);color:var(--color-text-primary)}.search-input input:focus{outline:none}.search-input input::placeholder{color:var(--color-text-tertiary)}.search-input svg{color:var(--color-text-tertiary);width:16px;height:16px}.breadcrumbs{display:flex;align-items:center;gap:var(--spacing-sm);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.breadcrumbs a{color:var(--color-text-secondary);text-decoration:none;transition:color var(--transition-fast)}.breadcrumbs a:hover{color:var(--color-text-primary)}.breadcrumbs-separator{color:var(--color-text-tertiary)}.breadcrumbs-current{color:var(--color-text-primary);font-weight:500}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--spacing-3xl);text-align:center}.empty-state-icon{width:64px;height:64px;border-radius:var(--radius-full);background:var(--color-bg-tertiary);display:flex;align-items:center;justify-content:center;margin-bottom:var(--spacing-lg);color:var(--color-text-tertiary)}.empty-state-title{font-size:var(--font-size-lg);font-weight:600;color:var(--color-text-primary);margin-bottom:var(--spacing-xs)}.empty-state-desc{font-size:var(--font-size-md);color:var(--color-text-secondary);max-width:300px}.divider{height:1px;background:var(--color-border);margin:var(--spacing-lg) 0}.user-menu{display:flex;align-items:center;gap:var(--spacing-sm);padding:var(--spacing-xs) var(--spacing-sm);border-radius:var(--radius-md);cursor:pointer;transition:background var(--transition-fast)}.user-menu:hover{background:var(--color-bg-hover)}.user-info{text-align:right}.user-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.user-role{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.notification-badge{position:relative}.notification-badge:after{content:"";position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:var(--color-accent-danger);border-radius:var(--radius-full);border:2px solid var(--color-bg-primary)}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}
