@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Space+Grotesk:wght@500;600;700&display=swap";.sidebar{background:var(--bg-surface);border-right:1px solid var(--border);z-index:100;flex-direction:column;width:240px;height:100vh;transition:width .3s;display:flex;position:fixed;top:0;left:0;overflow:hidden}.sidebar.collapsed{width:60px}.sidebar-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;min-height:64px;padding:1.1rem 1rem;display:flex}.sidebar-logo{flex:1;overflow:hidden}.sidebar-logo-img{object-fit:contain;object-position:left;width:auto;height:28px}.sidebar-collapse-btn{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:26px;height:26px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-collapse-btn:hover{color:var(--text-primary);border-color:var(--border-focus)}.sidebar-collapse-btn .rotate-180{transform:rotate(180deg)}.sidebar-app-label{text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);align-items:center;gap:7px;padding:.6rem 1rem .5rem;font-size:.7rem;font-weight:600;display:flex}.sidebar-app-dot{background:var(--accent);width:6px;height:6px;box-shadow:0 0 6px var(--accent-glow);border-radius:50%;flex-shrink:0;animation:2s infinite pulse}.sidebar-nav{flex-direction:column;flex:1;gap:1.25rem;padding:.5rem .75rem;display:flex;overflow-y:auto}.sidebar-nav-section{flex-direction:column;gap:1px;display:flex}.sidebar-section-label{text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);margin-bottom:4px;padding:0 .5rem;font-size:.67rem;font-weight:700}.sidebar-nav-item{border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition);white-space:nowrap;align-items:center;gap:.7rem;padding:.55rem .75rem;font-size:.855rem;font-weight:400;text-decoration:none;display:flex;overflow:hidden}.sidebar-nav-item:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-nav-item.active{background:var(--accent-dim);color:var(--accent);font-weight:500}.sidebar-nav-item.hr-item.active{background:var(--warning-dim);color:var(--warning)}.sidebar-footer{border-top:1px solid var(--border);flex-direction:column;gap:.5rem;padding:.75rem;display:flex}.theme-toggle{cursor:pointer;width:100%;color:var(--text-muted);font-family:var(--font-body);border-radius:var(--radius-md);transition:all var(--transition);text-align:left;background:0 0;border:none;align-items:center;gap:.65rem;padding:.5rem .75rem;font-size:.82rem;display:flex}.theme-toggle:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-user{align-items:center;gap:.65rem;display:flex}.sidebar-avatar{background:var(--accent-dim);border:1px solid var(--border-focus);width:32px;height:32px;font-family:var(--font-display);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.72rem;font-weight:700;display:flex}.sidebar-user-info{flex:1;overflow:hidden}.sidebar-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.82rem;font-weight:500;overflow:hidden}.sidebar-user-role{color:var(--text-muted);align-items:center;gap:4px;font-size:.7rem;display:flex}.sidebar-logout{border:1px solid var(--border);border-radius:var(--radius-sm);width:28px;height:28px;color:var(--text-muted);cursor:pointer;transition:all var(--transition);background:0 0;flex-shrink:0;justify-content:center;align-items:center;display:flex}.sidebar-logout:hover{background:var(--danger-dim);border-color:var(--danger);color:var(--danger)}.ms-badge{color:#fff;letter-spacing:.02em;background:#0078d4;border-radius:3px;padding:1px 5px;font-size:.58rem;font-weight:700}.sidebar-mobile-toggle{z-index:200;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);width:38px;height:38px;color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;display:none;position:fixed;top:1rem;left:1rem}.sidebar-overlay{z-index:99;background:#0009;display:none;position:fixed;inset:0}@media (width<=768px){.sidebar{z-index:200;transform:translate(-100%);width:240px!important}.sidebar.mobile-open{transform:translate(0)}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block}}.login-page{background:var(--bg-base);justify-content:center;align-items:center;min-height:100vh;padding:2rem 1rem;display:flex;position:relative}.login-bg{z-index:0;pointer-events:none;position:fixed;inset:0;overflow:hidden}.login-bg-orb{filter:blur(100px);border-radius:50%;position:absolute}.orb-1{background:radial-gradient(circle,#00e5a014,#0000 70%);width:500px;height:500px;top:-100px;left:-100px}.orb-2{background:radial-gradient(circle,#4a9fff0f,#0000 70%);width:400px;height:400px;bottom:-80px;right:-80px}.login-bg-grid{background-image:linear-gradient(#ffffff06 1px,#0000 1px),linear-gradient(90deg,#ffffff06 1px,#0000 1px);background-size:48px 48px;position:absolute;inset:0}[data-theme=light] .login-bg-grid{background-image:linear-gradient(#0000000a 1px,#0000 1px),linear-gradient(90deg,#0000000a 1px,#0000 1px)}.login-container{z-index:1;flex-direction:column;align-items:center;gap:1.5rem;width:100%;max-width:400px;animation:.4s fadeIn;display:flex;position:relative}.login-brand{align-items:center;gap:1rem;display:flex}.login-brand-logo{width:auto;height:40px}.login-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;box-shadow:var(--shadow-lg), var(--shadow-glow);flex-direction:column;gap:1.2rem;padding:2rem;display:flex}.login-card-header h2{margin-bottom:3px;font-size:1.25rem;font-weight:700}.login-card-header p{color:var(--text-secondary);font-size:.85rem}.btn-ms-sso{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);justify-content:center;align-items:center;gap:.75rem;padding:.7rem 1rem;font-size:.9rem;font-weight:500;display:flex}.btn-ms-sso:hover:not(:disabled){border-color:var(--border-focus);background:var(--bg-card-hover);box-shadow:var(--shadow-glow);transform:translateY(-1px)}.btn-ms-sso:disabled{opacity:.6;cursor:not-allowed}.login-divider{color:var(--text-muted);align-items:center;gap:.75rem;font-size:.78rem;display:flex}.login-divider:before,.login-divider:after{content:"";background:var(--border);flex:1;height:1px}.login-fields{flex-direction:column;gap:1rem;display:flex}.input-wrapper{align-items:center;display:flex;position:relative}.input-icon{color:var(--text-muted);pointer-events:none;flex-shrink:0;position:absolute;left:11px}.input-with-icon{padding-left:2.2rem!important}.input-with-right-icon{padding-right:2.5rem!important}.input-right-btn{cursor:pointer;color:var(--text-muted);transition:color var(--transition);background:0 0;border:none;align-items:center;display:flex;position:absolute;right:10px}.input-right-btn:hover{color:var(--text-primary)}.login-submit{justify-content:center;width:100%;height:42px;margin-top:.25rem}.login-footer{color:var(--text-muted);text-align:center;font-size:.72rem}.portal-home{padding:0}.portal-hero{background:linear-gradient(135deg, var(--bg-surface) 0%, var(--bg-card) 100%);border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:2rem;padding:2.5rem 2.5rem 2rem;display:flex}.portal-hero-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--accent);background:var(--accent-dim);border:1px solid var(--border-focus);border-radius:99px;align-items:center;gap:6px;margin-bottom:.75rem;padding:3px 10px;font-size:.72rem;font-weight:700;display:inline-flex}.portal-hero-title{letter-spacing:-.02em;margin-bottom:.5rem;font-size:2rem;font-weight:700}.portal-hero-sub{color:var(--text-secondary);max-width:480px;font-size:.9rem}.portal-hero-stats{flex-shrink:0;align-items:center;gap:1.5rem;display:flex}.hero-stat{text-align:center}.hero-stat-val{font-family:var(--font-display);color:var(--text-primary);font-size:1.75rem;font-weight:700;line-height:1}.hero-stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;margin-top:3px;font-size:.72rem}.hero-stat-divider{background:var(--border);width:1px;height:40px}.portal-quick-actions{border-bottom:1px solid var(--border);flex-wrap:wrap;gap:.75rem;padding:1.25rem 2.5rem;display:flex}.quick-action-btn{border-radius:var(--radius-md);border:1px solid var(--border);background:var(--bg-card);color:var(--text-secondary);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);align-items:center;gap:7px;padding:.5rem 1rem;font-size:.85rem;display:inline-flex}.quick-action-btn:hover{border-color:var(--border-focus);color:var(--text-primary)}.quick-action-btn.accent{background:var(--accent);color:#0d1117;border-color:var(--accent);font-weight:600}.quick-action-btn.accent:hover{filter:brightness(1.1);box-shadow:0 0 16px var(--accent-glow)}.portal-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:1rem;padding:1.25rem 2.5rem;display:flex}.portal-search-wrap{align-items:center;display:flex;position:relative}.portal-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.portal-search{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-family:var(--font-body);width:220px;transition:border var(--transition);outline:none;padding:.5rem .75rem .5rem 2rem;font-size:.85rem}.portal-search:focus{border-color:var(--border-focus)}.portal-search::placeholder{color:var(--text-muted)}.portal-cats{flex-wrap:wrap;flex:1;gap:.4rem;display:flex}.cat-pill{border:1px solid var(--border);color:var(--text-muted);cursor:pointer;transition:all var(--transition);font-size:.78rem;font-family:var(--font-body);white-space:nowrap;background:0 0;border-radius:99px;padding:.3rem .875rem}.cat-pill:hover{border-color:var(--border-focus);color:var(--text-primary)}.cat-pill.active{background:var(--accent-dim);border-color:var(--border-focus);color:var(--accent);font-weight:500}.view-toggle{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-md);gap:2px;padding:2px;display:flex}.view-toggle button{cursor:pointer;border-radius:calc(var(--radius-md) - 2px);width:30px;height:28px;color:var(--text-muted);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;display:flex}.view-toggle button.active{background:var(--accent-dim);color:var(--accent)}.apps-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;padding:2rem 2.5rem;display:grid}.app-card{transition:all var(--transition);cursor:default;flex-direction:column;gap:0;display:flex;overflow:hidden}.app-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-focus);transform:translateY(-2px)}.app-card-header{justify-content:space-between;align-items:flex-start;padding:1.25rem 1.25rem .75rem;display:flex}.app-card-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:48px;height:48px;font-size:1.5rem;display:flex}.app-settings-btn{opacity:0;transition:opacity var(--transition)}.app-card:hover .app-settings-btn{opacity:1}.app-card-body{flex:1;padding:0 1.25rem .75rem}.app-card-name{margin-bottom:.35rem;font-size:.95rem;font-weight:600}.app-card-desc{color:var(--text-secondary);font-size:.8rem;line-height:1.5}.app-card-features{flex-wrap:wrap;gap:.35rem;margin-top:.75rem;display:flex}.feature-tag{background:var(--bg-input);border:1px solid var(--border);color:var(--text-muted);border-radius:99px;padding:2px 7px;font-size:.68rem}.app-card-footer{border-top:1px solid var(--border);justify-content:space-between;align-items:center;padding:.875rem 1.25rem;display:flex}.app-card-cat{font-size:.75rem;font-weight:600}.app-open-btn{padding:.4rem .9rem;font-size:.82rem}.apps-list{flex-direction:column;gap:.6rem;padding:1.5rem 2.5rem;display:flex}.app-list-item{transition:all var(--transition);align-items:center;gap:1rem;padding:1rem 1.25rem;display:flex}.app-list-item:hover{border-color:var(--border-focus)}.app-list-icon{border-radius:var(--radius-md);flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;font-size:1.25rem;display:flex}.app-list-info{flex:1;overflow:hidden}.app-list-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.app-list-desc{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.8rem;overflow:hidden}.app-list-actions{flex-shrink:0;align-items:center;gap:.5rem;display:flex}.portal-empty{text-align:center;color:var(--text-muted);padding:5rem 2rem}.portal-empty h3{color:var(--text-secondary);margin-bottom:.5rem;font-size:1rem}@media (width<=768px){.portal-hero{padding:1.5rem 1rem}.portal-hero-stats{display:none}.portal-quick-actions,.portal-toolbar{padding:1rem}.apps-grid{grid-template-columns:1fr;padding:1rem}.apps-list{padding:1rem}}.app-icon-sm{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:32px;height:32px;font-size:1rem;display:flex}.reg-steps{align-items:flex-start;gap:0;padding:0 0 2rem;display:flex;overflow-x:auto}.reg-step{text-align:center;flex-direction:column;align-items:center;gap:.4rem;min-width:120px;display:flex}.reg-step-circle{border:2px solid var(--border);background:var(--bg-card);width:36px;height:36px;color:var(--text-muted);transition:all var(--transition);border-radius:50%;justify-content:center;align-items:center;font-size:.85rem;display:flex}.reg-step.active .reg-step-circle{border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.reg-step.done .reg-step-circle{border-color:var(--accent);background:var(--accent);color:#0d1117}.reg-step-label{color:var(--text-muted);font-size:.8rem;font-weight:600}.reg-step.active .reg-step-label,.reg-step.done .reg-step-label{color:var(--text-primary)}.reg-step-desc{color:var(--text-muted);max-width:100px;font-size:.7rem}.reg-step-line{background:var(--border);min-width:40px;height:2px;transition:background var(--transition);flex:1;margin-top:17px}.reg-step-line.done{background:var(--accent)}.reg-card{padding:0}.reg-step-content{padding:2rem;animation:.2s fadeIn}.reg-step-title{margin-bottom:.35rem;font-size:1.1rem;font-weight:700}.reg-step-sub{color:var(--text-secondary);margin-bottom:1.5rem;font-size:.875rem}.reg-footer{border-top:1px solid var(--border);align-items:center;gap:.75rem;padding:1.25rem 2rem;display:flex}.reg-grid-2{grid-template-columns:1fr 1fr;gap:1.25rem;display:grid}@media (width<=640px){.reg-grid-2{grid-template-columns:1fr}}.icon-picker{flex-wrap:wrap;gap:.4rem;margin-top:.4rem;display:flex}.icon-btn{border-radius:var(--radius-md);background:var(--bg-input);cursor:pointer;width:36px;height:36px;transition:all var(--transition);border:2px solid #0000;justify-content:center;align-items:center;font-size:1.1rem;display:flex}.icon-btn:hover{border-color:var(--border-focus)}.icon-btn.selected{border-color:var(--accent);background:var(--accent-dim)}.color-picker{flex-wrap:wrap;gap:.5rem;margin-top:.4rem;display:flex}.color-btn{cursor:pointer;width:28px;height:28px;transition:all var(--transition);border:3px solid #0000;border-radius:50%}.color-btn:hover{transform:scale(1.15)}.color-btn.selected{border-color:var(--text-primary);transform:scale(1.1)}.role-cards{grid-template-columns:repeat(3,1fr);gap:1rem;margin-top:.5rem;display:grid}@media (width<=640px){.role-cards{grid-template-columns:1fr}}.role-card{border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-input);cursor:pointer;text-align:center;transition:all var(--transition);flex-direction:column;align-items:center;gap:.4rem;padding:1.25rem 1rem;display:flex;position:relative}.role-card:hover{border-color:var(--border-focus)}.role-card.selected{border-color:var(--accent);background:var(--accent-dim)}.role-card-check{background:var(--accent);color:#0d1117;border-radius:50%;justify-content:center;align-items:center;width:18px;height:18px;display:flex;position:absolute;top:.6rem;right:.6rem}.role-card-icon{color:var(--text-muted)}.role-card-name{color:var(--text-primary);font-size:.875rem;font-weight:600}.role-card-desc{color:var(--text-muted);font-size:.75rem}.reg-info-box{background:var(--accent-dim);border:1px solid var(--border-focus);border-radius:var(--radius-md);color:var(--text-secondary);margin-top:1.5rem;padding:.875rem 1rem;font-size:.82rem}.reg-info-box strong{color:var(--accent)}.int-toggle{grid-template-columns:1fr 1fr;gap:.75rem;margin-bottom:1.5rem;display:grid}.int-toggle-btn{border:2px solid var(--border);border-radius:var(--radius-lg);background:var(--bg-input);cursor:pointer;text-align:center;font-family:var(--font-body);color:var(--text-secondary);transition:all var(--transition);flex-direction:column;align-items:center;gap:.35rem;padding:1rem;font-size:.875rem;font-weight:500;display:flex}.int-toggle-btn small{color:var(--text-muted);font-size:.72rem;font-weight:400}.int-toggle-btn:hover{border-color:var(--border-focus)}.int-toggle-btn.active{border-color:var(--accent);background:var(--accent-dim);color:var(--accent)}.int-toggle-btn.active small{color:var(--accent);opacity:.7}.review-card{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem}.review-app-preview{align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.review-app-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:52px;height:52px;font-size:1.6rem;display:flex}.review-app-name{font-size:1.1rem;font-weight:700}.review-app-cat{color:var(--text-muted);font-size:.8rem}.review-app-desc{color:var(--text-secondary);margin-bottom:1.25rem;font-size:.875rem;line-height:1.6}.review-grid{flex-direction:column;gap:.5rem;display:flex}.review-row{border-bottom:1px solid var(--border-subtle);align-items:center;gap:1rem;padding:.5rem 0;display:flex}.review-label{text-transform:uppercase;letter-spacing:.05em;color:var(--text-muted);min-width:100px;font-size:.75rem;font-weight:600}.review-value{color:var(--text-primary);font-size:.875rem}.azure-select{width:100%;position:relative}.azure-select-trigger{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);cursor:pointer;width:100%;transition:all var(--transition);text-align:left;font-family:var(--font-body);justify-content:space-between;align-items:center;gap:.5rem;min-height:42px;padding:.55rem .75rem;display:flex}.azure-select-trigger:hover:not(.disabled){border-color:var(--border-focus)}.azure-select-trigger.open{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.azure-select-trigger.disabled{opacity:.5;cursor:not-allowed}.azure-select.has-error .azure-select-trigger{border-color:var(--danger);box-shadow:0 0 0 3px var(--danger-dim)}.azure-select-placeholder{color:var(--text-muted);align-items:center;gap:.5rem;font-size:.875rem;display:flex}.azure-select-value{flex:1;align-items:center;gap:.625rem;display:flex;overflow:hidden}.azure-select-actions{flex-shrink:0;align-items:center;gap:4px;display:flex}.azure-clear-btn{color:var(--text-muted);transition:color var(--transition);border-radius:3px;align-items:center;padding:2px;display:flex}.azure-clear-btn:hover{color:var(--danger)}.azure-chevron{color:var(--text-muted);transition:transform var(--transition)}.azure-chevron.up{transform:rotate(180deg)}.azure-dropdown{background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:500;animation:.15s fadeIn;position:absolute;top:calc(100% + 6px);left:0;right:0;overflow:hidden}.azure-search-row{border-bottom:1px solid var(--border-subtle);align-items:center;gap:.5rem;padding:.625rem .875rem;display:flex}.azure-search-icon{color:var(--text-muted);flex-shrink:0}.azure-search-input{color:var(--text-primary);font-family:var(--font-body);background:0 0;border:none;outline:none;flex:1;font-size:.875rem}.azure-search-input::placeholder{color:var(--text-muted)}.azure-loading-icon{color:var(--accent);flex-shrink:0;animation:1s linear infinite spin}.azure-options{max-height:240px;padding:.375rem;overflow-y:auto}.azure-status{text-align:center;color:var(--text-muted);padding:1.5rem;font-size:.825rem}.azure-option{border-radius:var(--radius-md);cursor:pointer;width:100%;transition:background var(--transition);text-align:left;font-family:var(--font-body);background:0 0;border:none;align-items:center;gap:.625rem;padding:.6rem .75rem;display:flex}.azure-option:hover{background:var(--bg-card-hover)}.azure-option.selected{background:var(--accent-dim)}.azure-user-avatar{background:linear-gradient(135deg, var(--accent-dim), #0ea5e940);border:1px solid var(--border-focus);width:32px;height:32px;font-family:var(--font-display);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.7rem;font-weight:700;display:flex}.azure-user-avatar.sm{width:26px;height:26px;font-size:.65rem}.azure-user-meta{flex-direction:column;flex:1;display:flex;overflow:hidden}.azure-user-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.85rem;font-weight:500;overflow:hidden}.azure-user-email{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.75rem;overflow:hidden}.azure-user-dept{background:var(--bg-card);color:var(--text-muted);border:1px solid var(--border-subtle);white-space:nowrap;border-radius:99px;flex-shrink:0;padding:2px 7px;font-size:.7rem}.upload-modal{max-width:600px}.modal-title{font-family:var(--font-display);color:var(--text-primary);font-size:1.1rem;font-weight:700}.dropzone{border:2px dashed var(--border);border-radius:var(--radius-lg);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--bg-input);flex-direction:column;align-items:center;gap:.5rem;padding:2.5rem 1.5rem;display:flex}.dropzone:hover,.dropzone.active{border-color:var(--accent);background:var(--accent-dim)}.dropzone.error{border-color:var(--danger)}.dropzone-icon{color:var(--accent);opacity:.6;margin-bottom:.25rem}.dropzone.active .dropzone-icon{opacity:1;animation:.8s infinite pulse}.dropzone-title{color:var(--text-primary);font-size:.925rem;font-weight:500}.dropzone-sub{color:var(--text-muted);font-size:.78rem}.upload-file-list{flex-direction:column;gap:6px;margin-top:.5rem;display:flex}.upload-file-item{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-items:center;gap:.625rem;padding:.5rem .75rem;display:flex}.upload-file-icon{background:var(--bg-card);border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;display:flex}.upload-file-meta{flex-direction:column;flex:1;display:flex;overflow:hidden}.upload-file-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;font-size:.825rem;overflow:hidden}.upload-file-size{color:var(--text-muted);font-size:.72rem}.upload-file-remove{color:var(--text-muted);width:auto!important;height:auto!important;padding:4px!important}.upload-file-remove:hover{color:var(--danger)!important}.upload-fields{flex-direction:column;gap:1rem;margin-top:.75rem;display:flex}.upload-progress{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);flex-direction:column;gap:.5rem;margin-top:.5rem;padding:.875rem 1rem;display:flex}.upload-progress-header{justify-content:space-between;align-items:center;display:flex}.upload-progress-text{color:var(--text-secondary);font-size:.825rem}.upload-progress-pct{font-family:var(--font-display);color:var(--accent);font-size:.825rem;font-weight:600}.upload-self-user{background:var(--bg-secondary,#f5f7fa);border:1px solid var(--border,#e2e8f0);cursor:default;border-radius:8px;align-items:center;gap:10px;padding:10px 12px;display:flex}.upload-self-user .azure-user-meta{flex-direction:column;gap:2px;display:flex}.upload-self-user .azure-user-name{color:var(--text-primary,#1a202c);font-size:.875rem;font-weight:500}.upload-self-user .azure-user-email{color:var(--text-muted,#718096);font-size:.75rem}.cert-detail-modal{width:600px;max-width:95vw}.cert-detail-title-row{align-items:flex-start;gap:.75rem;display:flex}.cert-type-icon{border-radius:8px;flex-shrink:0;justify-content:center;align-items:center;width:40px;height:40px;display:flex}.cert-type-icon.pdf{color:#dc2626;background:#fee2e2}.cert-type-icon.img{color:#2563eb;background:#dbeafe}.cert-preview-section{border:1px solid var(--border);background:var(--surface-2);border-radius:8px;overflow:hidden}.cert-preview-wrap{padding:.5rem}.cert-preview-img{object-fit:contain;border-radius:6px;width:100%;max-height:340px;display:block}.cert-pdf-placeholder{color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:.5rem;padding:2.5rem 1rem;display:flex}.sp-badge{color:var(--text-secondary);background:#eff6ff;border:1px solid #bfdbfe;border-radius:6px;align-items:center;gap:6px;padding:6px 10px;font-size:.8rem;display:flex}.sp-dot{background:#2563eb;border-radius:50%;flex-shrink:0;width:8px;height:8px}.sp-badge a{color:#2563eb;text-decoration:none}.sp-badge a:hover{text-decoration:underline}.cert-cert-block{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;flex-direction:column;gap:.5rem;padding:.75rem 1rem;display:flex}.cert-cert-row{align-items:flex-start;gap:8px;display:flex}.cert-cert-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;font-size:.72rem}.cert-cert-value{color:var(--text-primary);font-size:.9rem;font-weight:500}.cert-detail-body{flex-direction:column;gap:.75rem;display:flex}.cert-meta-grid{grid-template-columns:1fr 1fr;gap:.5rem;display:grid}.cert-meta-item{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:.6rem .75rem}.cert-meta-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:4px;margin-bottom:4px;font-size:.72rem;display:flex}.cert-meta-value{color:var(--text-primary);font-size:.875rem;font-weight:500}.cert-comments-block{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;padding:.75rem}.cert-comments-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;align-items:center;gap:4px;margin-bottom:4px;font-size:.75rem;font-weight:600;display:flex}.cert-comments-text{color:var(--text-primary);margin:0;font-size:.875rem;line-height:1.5}.badge-purple{color:#7c3aed;background:#f3e8ff}.badge-orange{color:#c2410c;background:#fff7ed}.badge-red{color:#dc2626;background:#fef2f2}.preview-overlay{z-index:9999;background:#000000eb;flex-direction:column;display:flex;position:fixed;inset:0}.preview-topbar{background:#ffffff0d;border-bottom:1px solid #ffffff1a;flex-shrink:0;justify-content:space-between;align-items:center;padding:.75rem 1.25rem;display:flex}.preview-filename{color:#fff;text-overflow:ellipsis;white-space:nowrap;max-width:60%;font-size:.9rem;font-weight:500;overflow:hidden}.preview-iframe{background:#fff;border:none;flex:1;width:100%}.preview-img-wrap{flex:1;justify-content:center;align-items:center;padding:1rem;display:flex;overflow:auto}.preview-img{object-fit:contain;border-radius:4px;max-width:100%;max-height:100%}.dashboard-table-card{overflow:hidden}.table-footer{border-top:1px solid var(--border-subtle);color:var(--text-muted);padding:.875rem 1.25rem;font-size:.8rem}.bulk-modal{width:720px;max-width:95vw;max-height:90vh;overflow-y:auto}.bulk-steps{border-bottom:1px solid var(--border);background:var(--surface-2);align-items:center;gap:0;padding:.75rem 1.5rem;display:flex}.bulk-step{color:var(--text-muted);flex:1;align-items:center;gap:6px;font-size:.8rem;display:flex;position:relative}.bulk-step:not(:last-child):after{content:"→";color:var(--border);position:absolute;right:0}.bulk-step.active{color:var(--accent);font-weight:600}.bulk-step.done{color:var(--success,#16a34a)}.bulk-step-num{background:var(--border);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:22px;height:22px;font-size:.75rem;font-weight:700;display:flex}.bulk-step.active .bulk-step-num{background:var(--accent);color:#fff}.bulk-step.done .bulk-step-num{background:var(--success,#16a34a);color:#fff}.bulk-guide-toggle{color:var(--accent);cursor:pointer;align-items:center;gap:6px;font-size:.85rem;font-weight:500;display:flex}.bulk-guide{background:var(--surface-2);border:1px solid var(--border);border-radius:8px;padding:1rem;font-size:.83rem}.bulk-col-list{flex-wrap:wrap;gap:6px;display:flex}.bulk-col-item{background:var(--bg);border:1px solid var(--border);border-radius:4px;align-items:center;gap:4px;padding:2px 8px;display:flex}.bulk-col-item code{font-size:.78rem}.bulk-required{color:#92400e;background:#fef3c7;border-radius:3px;padding:1px 4px;font-size:.68rem}.bulk-csv-drop{border:2px dashed var(--border);cursor:pointer;text-align:center;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;padding:2rem;transition:border-color .2s,background .2s;display:flex}.bulk-csv-drop:hover{border-color:var(--accent);background:var(--accent-dim,#6366f10a)}.bulk-csv-loaded{background:var(--surface-2);border:1px solid var(--border);border-radius:6px;align-items:center;gap:8px;padding:8px 12px;font-size:.85rem;display:flex}.bulk-errors{background:#fef2f2;border:1px solid #fca5a5;border-radius:8px;padding:.75rem 1rem;font-size:.83rem}.bulk-errors-title{color:#dc2626;align-items:center;gap:6px;margin-bottom:8px;font-weight:600;display:flex}.bulk-error-row{color:#7f1d1d;border-bottom:1px solid #fecaca;padding:3px 0}.bulk-error-row:last-child{border-bottom:none}.bulk-info-box{color:#1e40af;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;gap:8px;padding:.75rem 1rem;font-size:.83rem;display:flex}.bulk-review-table-wrap{border:1px solid var(--border);border-radius:8px;max-height:320px;overflow-y:auto}.bulk-result-row{border-radius:6px;justify-content:space-between;align-items:center;padding:8px 12px;font-size:.85rem;display:flex}.bulk-result-row.success{background:#f0fdf4}.bulk-result-row.error{background:#fef2f2}.bulk-result-row.skipped{background:var(--surface-2)}.bulk-stat{border-radius:8px;align-items:center;gap:8px;padding:.5rem 1rem;font-size:.9rem;font-weight:600;display:flex}.bulk-stat.success{color:#16a34a;background:#f0fdf4}.bulk-stat.error{color:#dc2626;background:#fef2f2}.bulk-stat.skipped{background:var(--surface-2);color:var(--text-secondary)}.badge-green{color:#166534;background:#dcfce7}.hr-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--warning);background:var(--warning-dim);border:1px solid #fbbf2433;border-radius:99px;align-items:center;gap:5px;margin-bottom:6px;padding:3px 9px;font-size:.72rem;font-weight:600;display:inline-flex}.hr-view-toggle{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);align-items:center;gap:2px;padding:3px;display:flex}.toggle-btn{border-radius:calc(var(--radius-md) - 2px);color:var(--text-muted);font-family:var(--font-body);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:none;align-items:center;gap:6px;padding:.45rem .875rem;font-size:.825rem;font-weight:500;display:flex}.toggle-btn.active{background:var(--accent-dim);color:var(--accent)}.toggle-btn:hover:not(.active){color:var(--text-primary)}.hr-toolbar{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:1rem;padding:.875rem 1.25rem;display:flex}.folder-view{flex-direction:column;gap:.75rem;display:flex}.employee-folder{transition:all var(--transition);overflow:hidden}.employee-folder.open{border-color:var(--border-focus);box-shadow:0 0 0 1px var(--accent-dim)}.employee-folder-header{cursor:pointer;text-align:left;width:100%;font-family:var(--font-body);transition:background var(--transition);background:0 0;border:none;align-items:center;gap:.875rem;padding:1rem 1.25rem;display:flex}.employee-folder-header:hover{background:var(--bg-card-hover)}.emp-avatar{background:linear-gradient(135deg, var(--accent-dim), #0ea5e940);border:1px solid var(--border-focus);width:40px;height:40px;font-family:var(--font-display);color:var(--accent);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:.8rem;font-weight:700;display:flex}.emp-info{flex-direction:column;flex:1;display:flex;overflow:hidden}.emp-name{color:var(--text-primary);font-size:.9rem;font-weight:600}.emp-meta{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.775rem;overflow:hidden}.emp-cert-count{flex-shrink:0}.folder-chevron{color:var(--text-muted);transition:transform var(--transition);flex-shrink:0}.folder-chevron.open{transform:rotate(90deg)}.employee-certs-list{border-top:1px solid var(--border-subtle);flex-direction:column;gap:.5rem;padding:.75rem 1.25rem 1rem;animation:.2s fadeIn;display:flex}.no-certs-msg{text-align:center;color:var(--text-muted);padding:1rem;font-size:.825rem}.category-view{flex-direction:column;gap:1rem;display:flex}.category-block{overflow:hidden}.category-block-header{border-bottom:1px solid var(--border-subtle);justify-content:space-between;align-items:center;padding:1rem 1.25rem;display:flex}.category-block-title{font-family:var(--font-display);color:var(--text-primary);font-size:.9rem;font-weight:600}.category-certs-grid{flex-direction:column;gap:.5rem;padding:.75rem 1.25rem 1rem;display:flex}.cert-list-item{background:var(--bg-input);border:1px solid var(--border-subtle);border-radius:var(--radius-md);transition:border-color var(--transition);align-items:center;gap:.625rem;padding:.625rem .875rem;display:flex}.cert-list-item:hover{border-color:var(--border)}.cert-list-meta{flex:1;align-items:center;gap:.75rem;display:flex;overflow:hidden}.cert-list-name{color:var(--text-primary);white-space:nowrap;text-overflow:ellipsis;flex:1;font-size:.85rem;font-weight:500;overflow:hidden}.cert-list-emp{color:var(--accent);white-space:nowrap;font-size:.775rem}.cert-list-date{color:var(--text-muted);white-space:nowrap;font-size:.775rem}:root{--font-body:"Inter", sans-serif;--font-display:"Space Grotesk", sans-serif;--vita-green:#00e5a0;--vita-cyan:#00c2e0;--vita-blue:#4a9fff;--vita-purple:#7b5cf0;--vita-grad:linear-gradient(135deg, #00e5a0, #00c2e0, #4a9fff);--radius-sm:6px;--radius-md:10px;--radius-lg:14px;--radius-xl:20px;--transition:.18s cubic-bezier(.4,0,.2,1)}[data-theme=dark],:root{--bg-base:#0d1117;--bg-surface:#161b22;--bg-card:#1c2333;--bg-card-hover:#212840;--bg-input:#0d1117;--border:#ffffff14;--border-focus:#00e5a066;--border-subtle:#ffffff0d;--accent:#00e5a0;--accent-dim:#00e5a01a;--accent-glow:#00e5a040;--success:#3dd68c;--success-dim:#3dd68c1a;--warning:#f5a623;--warning-dim:#f5a6231a;--danger:#ff6b6b;--danger-dim:#ff6b6b1a;--text-primary:#e6edf3;--text-secondary:#8b949e;--text-muted:#484f58;--shadow-sm:0 1px 3px #0006;--shadow-md:0 4px 16px #00000080;--shadow-lg:0 8px 32px #0009;--shadow-glow:0 0 24px #00e5a01f}[data-theme=light]{--bg-base:#f5f7fa;--bg-surface:#fff;--bg-card:#fff;--bg-card-hover:#f0f4ff;--bg-input:#f5f7fa;--border:#00000014;--border-focus:#00b47880;--border-subtle:#0000000d;--accent:#00a878;--accent-dim:#00a87814;--accent-glow:#00a87833;--success:#1a9e5c;--success-dim:#1a9e5c14;--warning:#d97706;--warning-dim:#d9770614;--danger:#dc2626;--danger-dim:#dc262614;--text-primary:#111827;--text-secondary:#4b5563;--text-muted:#9ca3af;--shadow-sm:0 1px 3px #0000000f;--shadow-md:0 4px 16px #00000014;--shadow-lg:0 8px 32px #0000001a;--shadow-glow:0 0 24px #00a8781a}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;font-size:16px}body{font-family:var(--font-body);background:var(--bg-base);color:var(--text-primary);transition:background var(--transition), color var(--transition);line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}a{color:var(--accent);text-decoration:none}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--text-primary);line-height:1.25}.app-layout{min-height:100vh;display:flex}.main-content{background:var(--bg-base);flex:1;min-height:100vh;margin-left:240px}.page-container{max-width:1400px;padding:2rem 2.5rem}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2rem;display:flex}.page-title{letter-spacing:-.02em;font-size:1.6rem;font-weight:700}.page-subtitle{color:var(--text-secondary);margin-top:3px;font-size:.85rem}@media (width<=768px){.main-content{margin-left:0}.page-container{padding:1rem}}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);transition:border-color var(--transition), box-shadow var(--transition)}.card:hover{border-color:#ffffff1f}[data-theme=light] .card:hover{border-color:#0000001f}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.25rem 1.5rem;position:relative;overflow:hidden}.stat-card:after{content:"";height:2px;position:absolute;top:0;left:0;right:0}.stat-card.accent:after{background:linear-gradient(90deg,var(--vita-green),transparent)}.stat-card.success:after{background:linear-gradient(90deg,var(--success),transparent)}.stat-card.warning:after{background:linear-gradient(90deg,var(--warning),transparent)}.stat-card.danger:after{background:linear-gradient(90deg,var(--danger),transparent)}.stat-icon{border-radius:var(--radius-md);justify-content:center;align-items:center;width:36px;height:36px;margin-bottom:1rem;display:flex}.stat-icon.accent{background:var(--accent-dim);color:var(--accent)}.stat-icon.success{background:var(--success-dim);color:var(--success)}.stat-icon.warning{background:var(--warning-dim);color:var(--warning)}.stat-icon.danger{background:var(--danger-dim);color:var(--danger)}.stat-value{font-family:var(--font-display);margin-bottom:4px;font-size:1.75rem;font-weight:700;line-height:1}.stat-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em;font-size:.78rem}.grid-2{grid-template-columns:repeat(2,1fr);gap:1.25rem;display:grid}.grid-3{grid-template-columns:repeat(3,1fr);gap:1.25rem;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:1.25rem;display:grid}@media (width<=1200px){.grid-4{grid-template-columns:repeat(2,1fr)}}@media (width<=768px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.dashboard-stats{margin-bottom:1.75rem}.btn{font-family:var(--font-body);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition);white-space:nowrap;-webkit-user-select:none;user-select:none;border:none;outline:none;align-items:center;gap:7px;padding:.5rem 1rem;font-size:.85rem;font-weight:500;text-decoration:none;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed;pointer-events:none}.btn-primary{background:var(--accent);color:#0d1117;font-weight:600}.btn-primary:hover{filter:brightness(1.1);box-shadow:0 0 16px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-focus)}.btn-secondary:hover{background:#00e5a02e;transform:translateY(-1px)}.btn-ghost{color:var(--text-secondary);border:1px solid var(--border);background:0 0}.btn-ghost:hover{background:var(--bg-card-hover);color:var(--text-primary);border-color:var(--border-focus)}.btn-danger{background:var(--danger-dim);color:var(--danger);border:1px solid #ff6b6b40}.btn-danger:hover{background:#ff6b6b2e}.btn-icon{border-radius:var(--radius-sm);padding:.45rem}.btn-lg{padding:.65rem 1.4rem;font-size:.95rem}.form-group{flex-direction:column;gap:5px;display:flex}.form-label{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.76rem;font-weight:600}.form-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:all var(--transition);-webkit-appearance:none;outline:none;padding:.6rem .875rem;font-size:.875rem}.form-input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-dim)}.form-input::placeholder{color:var(--text-muted)}select.form-input{cursor:pointer;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='%238b949e' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}textarea.form-input{resize:vertical;min-height:80px}.field-error{color:var(--danger);margin-top:2px;font-size:.76rem}.input-error{border-color:var(--danger)!important;box-shadow:0 0 0 3px var(--danger-dim)!important}.data-table{border-collapse:collapse;width:100%;font-size:.85rem}.data-table th{text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);text-align:left;border-bottom:1px solid var(--border);padding:.75rem 1rem;font-size:.72rem;font-weight:600}.data-table td{border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle;padding:.85rem 1rem}.data-table tr:last-child td{border-bottom:none}.data-table tr:hover td{background:var(--bg-card-hover)}.table-wrap{overflow-x:auto}.table-toolbar{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:.75rem;padding:1rem 1.25rem;display:flex}.table-footer{color:var(--text-muted);border-top:1px solid var(--border);padding:.75rem 1.25rem;font-size:.8rem}.table-footer strong{color:var(--text-secondary)}.table-search-wrap{flex:1;align-items:center;min-width:150px;max-width:280px;display:flex;position:relative}.table-search-icon{color:var(--text-muted);pointer-events:none;position:absolute;left:10px}.table-search-input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-md);width:100%;color:var(--text-primary);font-family:var(--font-body);transition:border var(--transition);outline:none;padding:.5rem .75rem .5rem 2rem;font-size:.85rem}.table-search-input:focus{border-color:var(--border-focus)}.table-search-input::placeholder{color:var(--text-muted)}.table-filters{align-items:center;gap:.5rem;display:flex}.table-filter-select{width:auto;padding:.45rem 2rem .45rem .75rem;font-size:.82rem}.badge{letter-spacing:.03em;white-space:nowrap;border-radius:99px;align-items:center;gap:4px;padding:2px 8px;font-size:.7rem;font-weight:600;display:inline-flex}.badge-blue{color:#4a9fff;background:#4a9fff1a;border:1px solid #4a9fff33}.badge-green{background:var(--success-dim);color:var(--success);border:1px solid #3dd68c33}.badge-yellow{background:var(--warning-dim);color:var(--warning);border:1px solid #f5a62333}.badge-red{background:var(--danger-dim);color:var(--danger);border:1px solid #ff6b6b33}.cert-name-cell{align-items:center;gap:.6rem;display:flex}.cert-file-badge{border-radius:var(--radius-sm);flex-shrink:0;justify-content:center;align-items:center;width:28px;height:28px;font-size:.75rem;display:flex}.cert-file-badge.pdf{background:var(--danger-dim);color:var(--danger)}.cert-file-badge.img{background:var(--accent-dim);color:var(--accent)}.cert-filename{color:var(--text-primary);text-overflow:ellipsis;white-space:nowrap;max-width:200px;font-size:.85rem;font-weight:500;overflow:hidden}.modal-backdrop{-webkit-backdrop-filter:blur(6px);backdrop-filter:blur(6px);z-index:1000;background:#000000b3;justify-content:center;align-items:center;padding:1rem;animation:.15s fadeIn;display:flex;position:fixed;inset:0}.modal{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-xl);width:100%;max-width:560px;max-height:90vh;box-shadow:var(--shadow-lg);animation:.2s fadeIn;overflow-y:auto}.modal-header{justify-content:space-between;align-items:center;padding:1.5rem 1.75rem 0;display:flex}.modal-body{padding:1.25rem 1.75rem}.modal-footer{justify-content:flex-end;gap:.75rem;padding:0 1.75rem 1.5rem;display:flex}.modal-title{font-family:var(--font-display);font-size:1.05rem;font-weight:600}.modal-subtitle{color:var(--text-muted);margin-top:2px;font-size:.78rem}.toast-container{z-index:9999;flex-direction:column;gap:.6rem;display:flex;position:fixed;bottom:1.5rem;right:1.5rem}.toast{border-radius:var(--radius-md);background:var(--bg-card);border:1px solid var(--border);box-shadow:var(--shadow-lg);align-items:center;gap:.75rem;min-width:260px;max-width:360px;padding:.8rem 1.1rem;font-size:.85rem;animation:.2s slideIn;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.info{border-left:3px solid var(--accent)}.toast.warning{border-left:3px solid var(--warning)}.empty-state{text-align:center;color:var(--text-muted);padding:3.5rem 2rem}.empty-state-icon{opacity:.25;width:56px;height:56px;color:var(--accent);margin:0 auto 1rem}.empty-state h3{color:var(--text-secondary);margin-bottom:.4rem;font-size:.95rem}.empty-state p{font-size:.85rem}.skeleton{background:linear-gradient(90deg, var(--bg-card) 25%, var(--bg-card-hover) 50%, var(--bg-card) 75%);border-radius:var(--radius-md);background-size:200% 100%;animation:1.5s infinite shimmer}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.fade-in{animation:.3s fadeIn}.slide-in{animation:.3s slideIn}.spin-icon{animation:.8s linear infinite spin}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideIn{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}@keyframes spin{to{transform:rotate(360deg)}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.progress-bar-wrapper{background:var(--bg-input);border-radius:3px;height:5px;overflow:hidden}.progress-bar-fill{background:linear-gradient(90deg, var(--vita-green), var(--vita-cyan));border-radius:3px;height:100%;transition:width .3s}
