:root{--bg-primary: #0a0e17;--bg-secondary: #111625;--bg-card: rgba(22, 27, 40, .7);--bg-card-hover: rgba(30, 36, 50, .8);--text-primary: #e2e8f0;--text-secondary: #94a3b8;--text-accent: #38bdf8;--primary: #3b82f6;--primary-glow: rgba(59, 130, 246, .5);--secondary: #64748b;--success: #10b981;--warning: #f59e0b;--danger: #ef4444;--border-color: rgba(148, 163, 184, .1);--glass-border: rgba(255, 255, 255, .05);--radius-sm: .375rem;--radius-md: .5rem;--radius-lg: .75rem;--radius-full: 9999px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-glow: 0 0 15px var(--primary-glow)}*{margin:0;padding:0;box-sizing:border-box}body{font-family:var(--font-sans);background-color:var(--bg-primary);color:var(--text-primary);line-height:1.5;-webkit-font-smoothing:antialiased;min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--bg-primary)}::-webkit-scrollbar-thumb{background:var(--bg-secondary);border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:var(--secondary)}.container{max-width:1280px;margin:0 auto;padding:0 1rem}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.5rem 1rem;border-radius:var(--radius-md);font-weight:500;transition:all .2s ease;cursor:pointer;border:1px solid transparent;gap:.5rem}.btn-primary{background-color:var(--primary);color:#fff;box-shadow:var(--shadow-glow)}.btn-primary:hover{background-color:#2563eb;transform:translateY(-1px)}.btn-ghost{background:transparent;color:var(--text-secondary)}.btn-ghost:hover{background:var(--bg-secondary);color:var(--text-primary)}.card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;transition:transform .2s ease,border-color .2s ease}.card:hover{border-color:var(--border-color)}.input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);transition:all .2s}.input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px var(--primary-glow)}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fadeIn .4s ease-out forwards}.language-switcher{position:relative}.lang-trigger{display:flex;align-items:center;gap:.5rem;padding:.4rem .75rem;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;color:var(--text-primary, #f1f5f9);font-size:.85rem;font-weight:500;cursor:pointer;transition:all .2s;font-family:inherit}.lang-trigger:hover{border-color:var(--primary, #6366f1)}.lang-label{white-space:nowrap}.lang-chevron{transition:transform .2s;opacity:.6}.lang-chevron.open{transform:rotate(180deg)}.lang-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:160px;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;box-shadow:0 8px 24px #0000004d;z-index:100;overflow:hidden;animation:langFadeIn .15s ease}@keyframes langFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.lang-option{display:flex;align-items:center;gap:.6rem;width:100%;padding:.6rem .85rem;background:none;border:none;color:var(--text-primary, #f1f5f9);font-size:.85rem;cursor:pointer;transition:background .15s;font-family:inherit;text-align:left}.lang-option:hover{background:#6366f11a}.lang-option.active{background:#6366f126;color:var(--primary, #6366f1);font-weight:600}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;padding:1rem}.login-background{position:absolute;inset:0;background:radial-gradient(circle at 20% 50%,rgba(59,130,246,.1) 0%,transparent 50%),radial-gradient(circle at 80% 80%,rgba(139,92,246,.1) 0%,transparent 50%);z-index:0}.login-card{position:relative;z-index:1;max-width:420px;width:100%;background:var(--bg-card);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:2.5rem;box-shadow:0 20px 60px #0000004d}.login-header{text-align:center;margin-bottom:2rem}.logo-container{display:inline-flex;align-items:center;justify-content:center;padding:.75rem;margin-bottom:1rem}.logo-container img{max-height:48px;width:auto;object-fit:contain}.logo-icon{color:#fff}.login-header h1{font-size:1.875rem;font-weight:700;margin-bottom:.5rem;background:linear-gradient(135deg,var(--text-primary),var(--text-accent));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.login-header p{color:var(--text-secondary);font-size:.875rem}.login-form{display:flex;flex-direction:column;gap:1.25rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.login-btn{width:100%;padding:.875rem;margin-top:.5rem;font-size:1rem}.error-message{padding:.75rem 1rem;background:#ef44441a;border:1px solid var(--danger);border-radius:var(--radius-md);color:var(--danger);font-size:.875rem}.login-footer{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-color)}.demo-credentials{text-align:center;font-size:.75rem;color:var(--text-secondary);line-height:1.6}.demo-credentials p:first-child{font-weight:600;margin-bottom:.5rem}.demo-credentials p{margin:.25rem 0;font-size:.875rem}.login-feedback-note{text-align:center;font-size:.78rem;color:var(--text-secondary);line-height:1.6;margin:0}.login-feedback-note a{color:#6366f1;text-decoration:none;font-weight:500}.login-feedback-note a:hover{text-decoration:underline}.sso-divider{display:flex;align-items:center;margin:1.5rem 0;gap:1rem}.sso-divider:before,.sso-divider:after{content:"";flex:1;height:1px;background:var(--border-color)}.sso-divider span{font-size:.8rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-weight:500}.sso-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.875rem;font-size:.95rem;font-weight:600;color:var(--text-primary);background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s ease}.sso-btn:hover:not(:disabled){background:var(--bg-hover);border-color:var(--text-accent);box-shadow:0 0 0 2px #6366f126}.sso-btn:disabled{opacity:.6;cursor:not-allowed}.sso-btn-disabled{opacity:.5;background:var(--bg-secondary);border-style:dashed}.sso-not-configured{text-align:center;font-size:.75rem;color:var(--text-secondary);margin:.5rem 0 0;opacity:.7}.sso-spinner{width:32px;height:32px;border:3px solid var(--border-color);border-top-color:var(--text-accent);border-radius:50%;animation:sso-spin .8s linear infinite;margin:0 auto}@keyframes sso-spin{to{transform:rotate(360deg)}}.mfa-icon-container{display:flex;justify-content:center;margin-bottom:.5rem;color:#6366f1}.mfa-description{text-align:center;font-size:.875rem;color:var(--text-secondary);margin:0 0 .5rem;line-height:1.5}.mfa-code-input{font-family:Courier New,monospace}.mfa-code-input::placeholder{letter-spacing:.3em;opacity:.4}.navbar{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-bottom:1px solid var(--glass-border);padding:1rem 0;position:sticky;top:0;z-index:100}.navbar-content{display:flex;align-items:center;justify-content:space-between;gap:2rem}.navbar-brand{display:flex;align-items:center;gap:.75rem;font-size:1.25rem;font-weight:700;color:var(--text-primary)}.navbar-brand svg{color:var(--primary)}.navbar-links{display:flex;align-items:center;gap:.5rem;flex:1;margin-left:2rem}.nav-link{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;border-radius:var(--radius-md);color:var(--text-secondary);text-decoration:none;font-size:.9375rem;font-weight:500;transition:all .2s;border:1px solid transparent}.nav-link:hover{color:var(--text-primary);background:var(--bg-secondary);border-color:var(--border-color)}.nav-link.active{color:var(--primary);background:#3b82f61a;border-color:var(--primary)}.navbar-actions{display:flex;align-items:center;gap:1rem}.user-info{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem}.user-info span{color:var(--text-primary);font-weight:500}.user-logout-btn{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.875rem;border:1px solid var(--border-color);cursor:pointer;transition:all .2s}.user-logout-btn span{color:var(--text-primary);font-weight:500}.user-logout-btn:hover{background:#ef44441a;border-color:#ef44444d;color:#ef4444}.user-logout-btn:hover span{color:#ef4444}.admin-badge{padding:.25rem .625rem;background:linear-gradient(135deg,var(--primary),#8b5cf6);color:#fff;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.nav-dropdown{position:relative}.nav-dropdown-trigger{cursor:pointer;background:none;font-family:inherit}.nav-dropdown-chevron{transition:transform .2s ease;margin-left:2px}.nav-dropdown-chevron.open{transform:rotate(180deg)}.nav-dropdown-menu{position:absolute;top:calc(100% + 6px);left:0;min-width:200px;background:var(--bg-card, #1e293b);border:1px solid var(--border-color, #334155);border-radius:var(--radius-md, 8px);box-shadow:0 8px 24px #0000004d;padding:.375rem;z-index:200;animation:dropdownFadeIn .15s ease}@keyframes dropdownFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.nav-dropdown-item{display:flex;align-items:center;gap:.625rem;padding:.6rem .875rem;border-radius:6px;color:var(--text-secondary, #94a3b8);text-decoration:none;font-size:.875rem;font-weight:500;transition:all .15s ease}.nav-dropdown-item:hover{color:var(--text-primary, #f1f5f9);background:var(--bg-secondary, #0f172a)}.nav-dropdown-item.active{color:var(--primary, #3b82f6);background:#3b82f61a}@media(max-width:768px){.navbar-links{display:none}.navbar-content{gap:1rem}.navbar-actions{gap:.5rem}}.evidence-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.25rem;transition:all .2s;display:flex;flex-direction:column;gap:.875rem}.evidence-card:hover{border-color:var(--border-color);transform:translateY(-2px)}.evidence-header{display:flex;justify-content:space-between;align-items:center}.evidence-icon{color:var(--primary)}.status-badge{display:flex;align-items:center;gap:.375rem;padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.status-badge.warning{background:#f59e0b1a;color:var(--warning)}.status-badge.success{background:#10b9811a;color:var(--success)}.status-badge.danger{background:#ef44441a;color:var(--danger)}.evidence-name{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin:0}.evidence-meta{display:flex;flex-direction:column;gap:.5rem}.meta-item{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.meta-item svg{flex-shrink:0}.evidence-footer{display:flex;justify-content:space-between;align-items:center;padding-top:.75rem;border-top:1px solid var(--border-color);margin-top:auto}.upload-info{font-size:.75rem;color:var(--text-secondary)}.btn-review{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;background:var(--primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-review:hover{background:#2563eb;transform:translateY(-1px)}.rejection-reason{padding:.75rem;background:#ef44440d;border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);font-size:.875rem;color:var(--text-secondary)}.rejection-reason strong{color:var(--danger)}.modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem;animation:fadeIn .2s ease-out}.modal-content{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);max-width:500px;width:100%;max-height:90vh;overflow-y:auto;animation:slideUp .3s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header h2{font-size:1.5rem;font-weight:600;margin:0}.close-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;border-radius:var(--radius-md);transition:all .2s}.close-btn:hover{background:var(--bg-primary);color:var(--text-primary)}.upload-form{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.form-group label{display:flex;align-items:center;gap:.5rem}.textarea{resize:vertical;font-family:inherit}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;padding-top:1rem;border-top:1px solid var(--border-color)}.tags-checkbox-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:.75rem;margin-top:.5rem}.tag-checkbox-label{display:flex;align-items:center;gap:.5rem;padding:.625rem .875rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;font-size:.875rem}.tag-checkbox-label:hover{border-color:var(--primary);background:#3b82f60d}.tag-checkbox-label input[type=checkbox]{cursor:pointer;width:16px;height:16px;accent-color:var(--primary)}.tag-checkbox-label input[type=checkbox]:checked+span{color:var(--primary);font-weight:600}.dashboard{min-height:100vh;background-color:var(--bg-primary)}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.subtitle{color:var(--text-secondary);font-size:.875rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.25rem;margin-bottom:2rem}.stat-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;display:flex;align-items:center;gap:1rem;transition:all .2s}.stat-card:hover{border-color:var(--border-color);transform:translateY(-2px)}.stat-icon{width:40px;height:40px;padding:.625rem;background:#3b82f61a;color:var(--primary);border-radius:var(--radius-md)}.stat-card.pending .stat-icon{background:#f59e0b1a;color:var(--warning)}.stat-card.approved .stat-icon{background:#10b9811a;color:var(--success)}.stat-card.rejected .stat-icon{background:#ef44441a;color:var(--danger)}.stat-value{font-size:1.875rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.875rem;color:var(--text-secondary)}.search-box{display:flex;align-items:center;gap:.75rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:.875rem 1.25rem;max-width:600px}.search-box svg{color:var(--text-secondary)}.search-input{flex:1;background:transparent;border:none;color:var(--text-primary);font-size:.9375rem;outline:none}.search-input::placeholder{color:var(--text-secondary)}.evidences-section h2{font-size:1.5rem;font-weight:600;margin-bottom:1.5rem}.evidences-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.25rem}.empty-state{text-align:center;padding:4rem 2rem;color:var(--text-secondary)}.empty-state svg{margin-bottom:1rem;opacity:.5}.empty-state p{margin-bottom:1.5rem;font-size:1.125rem}.tag-manager{padding-top:2rem;padding-bottom:3rem}.tag-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.tag-manager-header h1{font-size:2rem;font-weight:700;margin:0 0 .25rem}.tag-category-section{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:1.5rem;transition:all .3s ease}.tag-category-section:hover{transform:translateY(-2px);box-shadow:0 8px 16px #0000001f}.tag-category-section:last-child{margin-bottom:0}.category-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem}.category-header svg{color:var(--primary);margin-top:.125rem}.category-header h3{font-size:1.125rem;font-weight:600;margin:0 0 .25rem}.category-description{font-size:.875rem;color:var(--text-secondary);margin:0}.add-tag-form{display:flex;gap:.75rem;margin-bottom:1.5rem}.add-tag-form .input{flex:1}.tags-list{margin-top:1rem}.tags-count{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem;font-weight:500}.tags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.75rem}.tag-item{display:flex;align-items:center;gap:.5rem;padding:.625rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s}.tag-item:hover{border-color:var(--primary)}.tag-name{flex:1;font-size:.9375rem;color:var(--text-primary);font-weight:500}.tag-edit-input{flex:1;background:var(--bg-primary);border:1px solid var(--primary);border-radius:var(--radius-sm);padding:.25rem .5rem;color:var(--text-primary);font-size:.9375rem;outline:none}.tag-action-btn{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:.25rem;border-radius:var(--radius-sm);transition:all .2s;display:flex;align-items:center;justify-content:center}.tag-action-btn:hover{background:var(--bg-primary)}.tag-action-btn.edit:hover{color:var(--primary)}.tag-action-btn.delete:hover{color:var(--danger)}.tag-action-btn.save{color:var(--success)}.tag-action-btn.save:hover{background:#10b9811a}.tag-action-btn.cancel{color:var(--danger)}.tag-action-btn.cancel:hover{background:#ef44441a}@media(max-width:768px){.tag-manager-header{flex-direction:column;align-items:flex-start}.tags-grid{grid-template-columns:1fr}}.admin-panel{min-height:100vh;background-color:var(--bg-primary)}.admin-content{padding-top:2rem;padding-bottom:3rem}.admin-header{margin-bottom:2rem}.admin-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.filters-section{display:flex;gap:1rem;margin-bottom:2rem;flex-wrap:wrap}.filter-buttons{display:flex;gap:.5rem;background:var(--bg-card);padding:.375rem;border-radius:var(--radius-lg);border:1px solid var(--border-color)}.filter-btn{padding:.5rem 1rem;border:none;background:transparent;color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;font-size:.875rem;font-weight:500;transition:all .2s}.filter-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.filter-btn.active{background:var(--primary);color:#fff}.quick-access-section{margin:2rem 0}.quick-access-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:1.5rem}.quick-access-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 8px #00000014;transition:all .3s ease;text-decoration:none;color:inherit;position:relative;overflow:hidden;border:2px solid transparent}.quick-access-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f;border-color:#667eea}.quick-access-icon{color:#667eea;margin-bottom:1rem}.quick-access-card h3{margin:0 0 .5rem;font-size:1.125rem;font-weight:600;color:#1f2937}.quick-access-card p{margin:0;color:#6b7280;font-size:.875rem;line-height:1.5}.quick-access-arrow{position:absolute;bottom:1.5rem;right:1.5rem;color:#667eea;opacity:0;transition:all .3s ease}.quick-access-card:hover .quick-access-arrow{opacity:1;transform:translate(4px)}.admin-dashboard{min-height:100vh;background-color:var(--bg-primary)}.dashboard-content{padding-top:2rem;padding-bottom:3rem}.dashboard-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.stats-grid-large{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.25rem;margin-bottom:2.5rem}.stat-card-large{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.75rem;display:flex;align-items:center;gap:1.25rem;transition:all .3s ease;position:relative;overflow:hidden}.stat-card-large:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;background:var(--primary);opacity:0;transition:opacity .3s}.stat-card-large:hover{transform:translateY(-4px);border-color:var(--border-color);box-shadow:0 8px 24px #0003}.stat-card-large:hover:before{opacity:1}.stat-icon-large{width:64px;height:64px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);background:#3b82f61a;color:var(--primary)}.stat-card-large.warning .stat-icon-large{background:#f59e0b1a;color:var(--warning)}.stat-card-large.success .stat-icon-large{background:#10b9811a;color:var(--success)}.stat-card-large.danger .stat-icon-large{background:#ef44441a;color:var(--danger)}.stat-card-large.info .stat-icon-large{background:#38bdf81a;color:#38bdf8}.stat-card-large.accent .stat-icon-large{background:#8b5cf61a;color:#8b5cf6}.stat-content{flex:1}.stat-value-large{font-size:2.25rem;font-weight:700;color:var(--text-primary);line-height:1;margin-bottom:.5rem}.stat-label-large{font-size:.875rem;color:var(--text-secondary);font-weight:500}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:1.5rem;margin-bottom:2.5rem}.chart-card{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem;transition:all .2s}.chart-card:hover{border-color:var(--border-color)}.chart-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.chart-header svg{color:var(--primary)}.chart-header h3{font-size:1.125rem;font-weight:600;margin:0}.chart-content{min-height:200px}.bar-chart{display:flex;flex-direction:column;gap:1rem}.bar-item{display:flex;flex-direction:column;gap:.5rem}.bar-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.bar-container{position:relative;height:32px;background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden}.bar-fill{height:100%;background:linear-gradient(90deg,var(--primary),#8b5cf6);border-radius:var(--radius-md);display:flex;align-items:center;justify-content:flex-end;padding-right:.75rem;transition:width .5s ease;min-width:40px}.bar-fill.folder{background:linear-gradient(90deg,#10b981,#06b6d4)}.bar-value{color:#fff;font-size:.875rem;font-weight:600}.empty-chart{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-secondary);font-size:.875rem}.activity-section{background:var(--bg-card);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border:1px solid var(--glass-border);border-radius:var(--radius-lg);padding:1.5rem}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-color)}.section-header svg{color:var(--primary)}.section-header h3{font-size:1.125rem;font-weight:600;margin:0}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);transition:all .2s}.activity-item:hover{border-color:var(--primary);transform:translate(4px)}.activity-status{width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-md);flex-shrink:0}.activity-status.pending{background:#f59e0b1a;color:var(--warning)}.activity-status.approved{background:#10b9811a;color:var(--success)}.activity-status.rejected{background:#ef44441a;color:var(--danger)}.activity-content{flex:1}.activity-title{font-size:.9375rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.activity-meta{font-size:.8125rem;color:var(--text-secondary);display:flex;gap:.5rem}.activity-badge{padding:.375rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:capitalize}.activity-badge.pending{background:#f59e0b1a;color:var(--warning)}.activity-badge.approved{background:#10b9811a;color:var(--success)}.activity-badge.rejected{background:#ef44441a;color:var(--danger)}.empty-activity{display:flex;align-items:center;justify-content:center;padding:3rem;color:var(--text-secondary);font-size:.875rem}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}.stats-grid-large{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}}.user-modal{max-width:600px}.form-group label{display:block;font-weight:500;margin-bottom:.5rem;color:var(--text-primary)}.form-group .required{color:var(--danger);margin-left:.25rem}.form-hint{font-size:.875rem;color:var(--text-secondary);margin-bottom:.75rem;margin-top:-.25rem}.form-input,.form-select{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-card);color:var(--text-primary);font-size:1rem;transition:all .2s}.form-input:focus,.form-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-input:disabled{background:var(--bg-secondary);cursor:not-allowed;opacity:.6}.form-select{cursor:pointer}.password-input{position:relative}.password-input .form-input{padding-right:3rem}.password-toggle{position:absolute;right:.75rem;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-secondary);cursor:pointer;padding:.5rem;display:flex;align-items:center;justify-content:center;transition:color .2s}.password-toggle:hover{color:var(--text-primary)}.loading-roles{text-align:center;padding:1.5rem;color:var(--text-secondary);font-size:.875rem}.roles-grid-compact{display:grid;gap:.5rem;max-height:250px;overflow-y:auto;padding:.25rem;margin-bottom:.75rem}.role-option-compact{display:flex;align-items:center;gap:.5rem;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;background:var(--bg-card)}.role-option-compact:hover{border-color:var(--primary);background:var(--bg-primary)}.role-option-compact.selected{border-color:var(--primary);background:#3b82f60d}.role-option-compact input[type=checkbox]{cursor:pointer}.role-color-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.role-name-compact{flex:1;font-size:.9375rem;font-weight:500;color:var(--text-primary)}.role-translation-icon{color:var(--text-tertiary);flex-shrink:0}.selected-count-compact{padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center;font-size:.8125rem;color:var(--text-secondary);font-weight:500}.modal-footer{display:flex;gap:1rem;justify-content:flex-end;padding-top:1.5rem;border-top:1px solid var(--border-color)}@media(max-width:640px){.modal-footer{flex-direction:column-reverse}.modal-footer button{width:100%}}.user-approval-modal{max-width:700px}.user-approval-modal .modal-body{padding:1.5rem;max-height:calc(90vh - 160px);overflow-y:auto}.user-info-section{margin-bottom:2rem}.user-info-section h3{font-size:1.125rem;font-weight:600;margin-bottom:1rem;color:var(--text-primary)}.info-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}.info-item{display:flex;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md)}.info-item svg{color:var(--text-tertiary);flex-shrink:0}.info-label{font-size:.8125rem;color:var(--text-tertiary);margin-bottom:.25rem}.info-value{font-size:.9375rem;color:var(--text-primary);font-weight:500}.verified{color:#16a34a}.not-verified{color:#dc2626}.role-assignment-section{margin-bottom:2rem}.role-assignment-section h3{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.section-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.loading-roles{text-align:center;padding:2rem;color:var(--text-secondary)}.roles-grid{display:grid;gap:.75rem;margin-bottom:1rem}.role-option{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:2px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;background:var(--bg-card)}.role-option:hover{border-color:var(--primary);background:var(--bg-primary)}.role-option.selected{border-color:var(--primary);background:#3b82f60d}.role-option input[type=checkbox]{margin-top:.25rem;cursor:pointer}.role-info{display:flex;gap:.75rem;flex:1}.role-color-indicator{width:4px;height:100%;min-height:2rem;border-radius:2px;flex-shrink:0}.role-name{font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.role-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.role-meta{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:var(--text-tertiary)}.selected-count{padding:.75rem 1rem;background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center;font-size:.875rem;color:var(--text-secondary);font-weight:500}.reject-form-section{margin-bottom:1rem}.reject-form-section h3{font-size:1.125rem;font-weight:600;margin-bottom:.5rem;color:var(--text-primary)}.rejection-textarea{width:100%;padding:.75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);color:var(--text-primary);font-family:inherit;font-size:.9375rem;resize:vertical;min-height:100px}.rejection-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.user-approval-modal .modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color)}.user-approval-modal .alert{margin:0 1.5rem 1rem}@media(max-width:768px){.user-approval-modal{max-width:95%}.info-grid{grid-template-columns:1fr}.user-approval-modal .modal-footer{flex-direction:column}.user-approval-modal .modal-footer .btn{width:100%}}.user-management{min-height:100vh;background-color:var(--bg-primary)}.user-content{padding-top:2rem;padding-bottom:3rem}.user-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.user-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.users-table-container{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.users-table{width:100%;border-collapse:collapse}.users-table thead{background:var(--bg-secondary)}.users-table th{padding:1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;border-bottom:2px solid var(--border-color)}.users-table td{padding:1rem;border-bottom:1px solid var(--border-color);color:var(--text-primary)}.users-table tbody tr:hover{background:var(--bg-secondary)}.users-table tbody tr:last-child td{border-bottom:none}.user-name{display:flex;align-items:center;gap:.5rem;font-weight:500}.clickable-cell{cursor:pointer;transition:color .15s}.clickable-cell:hover{color:#818cf8}.admin-icon{color:var(--primary)}.role-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.role-badge.system_admin{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.role-badge.admin{background:#8b5cf61a;color:#8b5cf6}.role-badge.user{background:#3b82f61a;color:#3b82f6}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600;text-transform:uppercase}.status-badge.active{background:#22c55e1a;color:#22c55e}.status-badge.disabled{background:#ef44441a;color:#ef4444}.actions{display:flex;gap:.5rem}.action-btn{padding:.5rem;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.action-btn:hover:not(:disabled){background:var(--bg-primary);transform:translateY(-1px)}.action-btn:disabled{opacity:.5;cursor:not-allowed}.action-btn.edit:hover:not(:disabled){color:#3b82f6}.action-btn.reset:hover:not(:disabled){color:#8b5cf6}.action-btn.enable:hover:not(:disabled){color:#22c55e}.action-btn.disable:hover:not(:disabled){color:#f59e0b}.action-btn.delete:hover:not(:disabled){color:#ef4444}td.empty-state{text-align:center!important;padding:3rem 1rem;color:var(--text-secondary)}td.empty-state svg{color:var(--text-tertiary);margin-bottom:1rem}td.empty-state p{font-size:1rem;margin:0}.stat-card.clickable{cursor:pointer;transition:all .2s ease}.stat-card.clickable:hover{transform:translateY(-2px);border-color:var(--primary, #6366f1);box-shadow:0 4px 12px #6366f126}.stat-card.selected{border-color:var(--primary, #6366f1)!important;box-shadow:0 0 0 2px #6366f14d;background:#6366f114}.stat-card.active .stat-icon{color:#22c55e}.stat-card.disabled .stat-icon{color:#ef4444}.stat-card.admin .stat-icon{color:#8b5cf6}.stat-card.pending .stat-icon{color:#f59e0b}.pending-users-section{background:#fffbeb;border:2px solid #fcd34d;border-radius:var(--radius-lg);padding:1.5rem;margin-bottom:2rem}.pending-users-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1rem;margin-top:1rem}.pending-user-card{background:#fff;border:1px solid #fde68a;border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column;gap:1rem}.pending-user-info h3{margin:0;font-size:1rem;font-weight:600}.pending-user-info p{margin:.25rem 0 0;font-size:.875rem;color:#666}.pending-user-actions{display:flex;gap:.5rem}.pending-user-actions .btn{flex:1;justify-content:center;padding:.5rem 1rem;font-size:.875rem}.btn-warning{background:#f59e0b;color:#fff}.btn-warning:hover{background:#d97706}.btn-success{background:#16a34a;color:#fff}.btn-success:hover{background:#15803d}.btn-danger{background:#dc2626;color:#fff}.btn-danger:hover{background:#b91c1c}@media(max-width:1024px){.users-table-container{overflow-x:auto}.users-table{min-width:800px}}@media(max-width:768px){.user-header{flex-direction:column;align-items:flex-start}.user-header button{width:100%}}.domain-management{min-height:100vh;background-color:var(--bg-primary)}.domain-content{padding-top:2rem;padding-bottom:3rem}.domain-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.domain-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.stat-card.clickable{cursor:pointer;transition:all .2s}.stat-card.clickable:hover{border-color:var(--primary, #3b82f6);transform:translateY(-2px)}.stat-card.clickable.selected{border-color:var(--primary, #3b82f6);box-shadow:0 0 0 1px var(--primary, #3b82f6)}.list-header{display:flex;justify-content:space-between;align-items:center}.btn-clear-filter{background:none;border:1px solid var(--border-color);color:var(--text-secondary);padding:.25rem .75rem;border-radius:var(--radius-md);font-size:.8rem;cursor:pointer;transition:all .2s}.btn-clear-filter:hover{color:var(--text-primary);border-color:var(--text-secondary)}.add-domain-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:1.5rem;margin-bottom:2rem}.add-domain-card h2{font-size:1.125rem;font-weight:600;color:var(--text-primary);margin-bottom:1rem}.add-domain-form{display:flex;gap:.75rem;margin-bottom:.5rem}.domain-input{flex:1;padding:.625rem .75rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-md);font-size:.9375rem;transition:all .2s}.domain-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.domain-input::placeholder{color:var(--text-tertiary)}.domains-list-container{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden;margin-bottom:2rem}.list-header{padding:1rem 1.5rem;border-bottom:1px solid var(--border-color)}.list-header h2{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.domains-list{divide-y:1px solid var(--border-color)}.domain-item{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;transition:background-color .2s}.domain-item:hover{background:var(--bg-secondary)}.domain-info{flex:1}.domain-main{display:flex;align-items:center;gap:1rem}.status-dot{width:12px;height:12px;border-radius:50%;flex-shrink:0}.status-dot.active{background-color:#22c55e}.status-dot.inactive{background-color:var(--text-tertiary)}.domain-name{font-size:.9375rem;font-weight:600;color:var(--text-primary)}.domain-meta{font-size:.8125rem;color:var(--text-tertiary);margin-top:.125rem}.domain-actions{display:flex;align-items:center;gap:.5rem}.domain-badge{padding:.25rem .625rem;border-radius:var(--radius-full);font-size:.75rem;font-weight:600}.domain-badge.active{background:#22c55e1a;color:#22c55e}.domain-badge.inactive{background:var(--bg-secondary);color:var(--text-tertiary)}.domain-action-btn{padding:.5rem;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.domain-action-btn:hover{background:var(--bg-primary);transform:translateY(-1px)}.domain-action-btn.toggle:hover{color:#f59e0b}.domain-action-btn.delete:hover{color:#ef4444}.info-box{background:#3b82f60d;border:1px solid rgba(59,130,246,.2);border-radius:var(--radius-lg);padding:1rem;display:flex;gap:.75rem}.info-icon{flex-shrink:0;width:1.25rem;height:1.25rem;color:#3b82f6}.info-icon svg{width:100%;height:100%}.info-box h3{font-size:.875rem;font-weight:600;color:var(--text-primary);margin-bottom:.5rem}.info-list{list-style:disc;padding-left:1.25rem;font-size:.875rem;color:var(--text-secondary)}.info-list li{margin-bottom:.25rem}.empty-state{padding:3rem 1rem;text-align:center}.empty-state svg{color:var(--text-tertiary);margin:0 auto 1rem}.empty-state p{font-size:.9375rem;font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.empty-hint{font-size:.875rem;color:var(--text-secondary)}@media(max-width:768px){.add-domain-form{flex-direction:column}.domain-item{flex-direction:column;align-items:flex-start;gap:1rem}.domain-actions{width:100%;justify-content:flex-start}}.step-indicator{display:flex;align-items:center;gap:16px;margin-top:16px;padding:12px;background:var(--surface-color, #1e293b);border-radius:8px}.step{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:6px;background:var(--bg-color, #0f172a);border:2px solid transparent;transition:all .3s ease}.step.active{border-color:var(--primary-color, #3b82f6);background:#3b82f61a}.step.completed{border-color:var(--success-color, #10b981);background:#10b9811a}.step-number{display:flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:50%;background:var(--border-color, #334155);color:var(--text-secondary, #94a3b8);font-weight:600;font-size:14px}.step.active .step-number{background:var(--primary-color, #3b82f6);color:#fff}.step.completed .step-number{background:var(--success-color, #10b981);color:#fff}.step-label{font-size:14px;font-weight:500;color:var(--text-secondary, #94a3b8)}.step.active .step-label{color:var(--primary-color, #3b82f6)}.step.completed .step-label{color:var(--success-color, #10b981)}.step-arrow{color:var(--border-color, #334155);font-size:18px}.alert-warning{background:#fbbf2426;border:3px solid #fbbf24;color:#fbbf24;padding:14px 18px;border-radius:10px;display:flex;align-items:center;gap:10px;margin-bottom:20px;font-weight:500;font-size:14px;line-height:1.5}.alert-warning strong{display:inline;font-size:14px}.alert-warning p{margin:0;font-size:14px;line-height:1.5;color:#fde68a;display:inline}.unsaved-warning{animation:pulse-warning 2s ease-in-out infinite}@keyframes pulse-warning{0%,to{border-color:#fbbf24;box-shadow:0 0 #fbbf2466}50%{border-color:#f59e0b;box-shadow:0 0 0 8px #fbbf2400}}.save-controls-btn{font-size:18px!important;padding:16px 36px!important;font-weight:700!important;display:flex;align-items:center;gap:12px;animation:pulse-save 1.5s ease-in-out infinite;box-shadow:0 6px 20px #3b82f680;position:relative;overflow:visible}.save-controls-btn:before{content:"";position:absolute;inset:-2px;background:linear-gradient(45deg,#3b82f6,#60a5fa,#3b82f6);border-radius:inherit;z-index:-1;opacity:.5;filter:blur(8px);animation:glow-rotate 3s linear infinite}.save-controls-btn:hover{transform:translateY(-3px) scale(1.02);box-shadow:0 8px 28px #3b82f699}@keyframes pulse-save{0%,to{box-shadow:0 6px 20px #3b82f680;transform:scale(1)}50%{box-shadow:0 8px 32px #3b82f6b3,0 0 0 6px #3b82f626;transform:scale(1.05)}}@keyframes glow-rotate{0%{filter:blur(8px) hue-rotate(0deg)}to{filter:blur(8px) hue-rotate(360deg)}}.warning-dialog{text-align:center;padding:32px}.warning-icon{color:#f59e0b;margin-bottom:20px;animation:shake .5s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-10px)}75%{transform:translate(10px)}}.warning-dialog h2{font-size:24px;color:var(--text-primary, #f1f5f9);margin-bottom:16px}.warning-dialog p{font-size:16px;color:var(--text-secondary, #cbd5e1);line-height:1.6;margin-bottom:24px;max-width:400px;margin-left:auto;margin-right:auto}.warning-actions{display:flex;gap:12px;justify-content:center}.warning-actions .btn{min-width:160px}.policy-upload-modal .modal-header{border-bottom:1px solid var(--border-color, #334155);padding-bottom:20px}.policy-upload-modal .modal-header h2{margin-bottom:0}.extracted-controls .alert{margin-bottom:16px}.extracted-controls .alert:last-of-type{margin-bottom:20px}.control-preview-header{display:flex;align-items:center;gap:12px;padding:10px 14px;background:var(--surface-color, #1e293b);border-radius:8px;margin-bottom:8px;font-weight:600;font-size:13px;color:var(--text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.5px}.control-header-code{min-width:90px;flex-shrink:0}.control-header-name{flex:1;min-width:0}.control-header-responsible{min-width:220px;flex-shrink:0}.control-preview-item{display:flex;align-items:flex-start;gap:12px;padding:12px 14px;background:var(--bg-color, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;margin-bottom:6px;transition:border-color .2s}.control-preview-item:hover{border-color:var(--primary-color, #3b82f6)}.control-preview-item .control-code{min-width:90px;flex-shrink:0;font-weight:700;font-size:13px;color:var(--primary-color, #3b82f6);padding-top:2px}.control-preview-item .control-details{flex:1;min-width:0}.control-preview-item .control-name{font-weight:500;font-size:14px;color:var(--text-primary, #f1f5f9);margin-bottom:4px;line-height:1.4}.control-preview-item .control-description{font-size:12px;color:var(--text-secondary, #94a3b8);line-height:1.4}.control-responsible{min-width:220px;flex-shrink:0}.responsible-input{width:100%;padding:8px 10px;border:2px solid var(--border-color, #334155);border-radius:6px;background:var(--surface-color, #1e293b);color:var(--text-primary, #f1f5f9);font-size:13px;transition:border-color .2s,box-shadow .2s}.responsible-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f626}.responsible-input::placeholder{color:var(--text-secondary, #64748b);font-size:12px}.responsible-input.responsible-empty{border-color:#ef4444;background:#ef44440f}.responsible-input.responsible-empty:focus{border-color:#dc2626;box-shadow:0 0 0 3px #ef444426}.responsible-input.responsible-warning{border-color:#f59e0b;background:#f59e0b14}.responsible-input.responsible-warning:focus{border-color:#d97706;box-shadow:0 0 0 3px #f59e0b26}.control-images{margin-top:8px;padding-top:8px;border-top:1px solid var(--border-color, #334155)}.control-images-label{display:flex;align-items:center;gap:6px;font-size:11px;font-weight:600;color:var(--primary-color, #3b82f6);margin-bottom:8px;text-transform:uppercase;letter-spacing:.3px}.control-images-grid{display:flex;flex-wrap:wrap;gap:8px}.control-image-thumb{display:flex;flex-direction:column;align-items:center;gap:4px;padding:6px;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;cursor:pointer;transition:all .2s;max-width:120px}.control-image-thumb:hover{border-color:var(--primary-color, #3b82f6);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.control-image-thumb img{max-width:100px;max-height:80px;object-fit:contain;border-radius:4px;background:#ffffff0d}.control-image-name{font-size:10px;color:var(--text-secondary, #94a3b8);text-align:center;word-break:break-all;line-height:1.2;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.document-preview-section{margin-top:.5rem}.document-preview-content{background:var(--bg-color, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:1rem}.document-preview-content code{background:#3b82f626;color:#60a5fa;padding:.1rem .35rem;border-radius:3px;font-size:.8125rem}.document-preview-text{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;padding:1rem;font-family:Courier New,monospace;font-size:.75rem;line-height:1.5;color:var(--text-primary, #f1f5f9);max-height:300px;overflow-y:auto;white-space:pre-wrap;word-break:break-word;margin:0}.document-preview-text::-webkit-scrollbar{width:6px}.document-preview-text::-webkit-scrollbar-track{background:transparent}.document-preview-text::-webkit-scrollbar-thumb{background:var(--border-color, #334155);border-radius:3px}.controls-preview .controls-list{max-height:400px;overflow-y:auto;padding-right:4px}.controls-preview .controls-list::-webkit-scrollbar{width:6px}.controls-preview .controls-list::-webkit-scrollbar-track{background:transparent}.controls-preview .controls-list::-webkit-scrollbar-thumb{background:var(--border-color, #334155);border-radius:3px}.controls-preview .controls-list::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #64748b)}.user-assignment-modal{max-width:700px}.user-assignment-modal .modal-header{display:flex;justify-content:space-between;align-items:flex-start;gap:1rem}.user-assignment-modal .modal-header h2{margin:0 0 .25rem}.control-info{font-size:.875rem;color:var(--text-secondary);margin:0}.user-assignment-modal .modal-body{padding:1.5rem;max-height:calc(90vh - 200px);overflow-y:auto}.search-section{margin-bottom:1.5rem}.search-box{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);margin-bottom:.75rem}.search-box svg{color:var(--text-tertiary);flex-shrink:0}.search-input{flex:1;background:transparent;border:none;outline:none;font-size:.9375rem;color:var(--text-primary)}.search-input::placeholder{color:var(--text-tertiary)}.assignment-count{padding:.5rem .75rem;background:var(--bg-secondary);border-radius:var(--radius-md);text-align:center;font-size:.8125rem;color:var(--text-secondary);font-weight:500}.loading-state,.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary)}.empty-state p{margin:0}.users-list{display:grid;gap:.75rem}.user-item{display:flex;align-items:flex-start;gap:.75rem;padding:1rem;border:1px solid var(--border-color);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;background:var(--bg-card)}.user-item:hover{border-color:var(--primary);background:var(--bg-primary)}.user-item.selected{border-color:var(--primary);background:#3b82f60d}.user-item input[type=checkbox]{margin-top:.25rem;cursor:pointer}.user-info{flex:1;display:flex;flex-direction:column;gap:.5rem}.user-details{display:flex;flex-direction:column;gap:.25rem}.user-name{display:flex;align-items:center;gap:.5rem;font-weight:600;color:var(--text-primary)}.user-name svg{color:var(--text-tertiary)}.user-email{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-secondary)}.user-email svg{color:var(--text-tertiary)}.user-roles{display:flex;align-items:center;gap:.5rem}.user-roles svg{color:var(--text-tertiary);flex-shrink:0}.role-badges{display:flex;flex-wrap:wrap;gap:.375rem}.user-role-badge{padding:.125rem .5rem;border:1px solid;border-radius:var(--radius-sm);font-size:.75rem;font-weight:500}.user-assignment-modal .modal-footer{display:flex;justify-content:flex-end;gap:1rem;padding:1.5rem;border-top:1px solid var(--border-color)}.user-assignment-modal .alert{margin:0 1.5rem 1rem}@media(max-width:768px){.user-assignment-modal{max-width:95%}.user-assignment-modal .modal-footer{flex-direction:column}.user-assignment-modal .modal-footer .btn{width:100%}.user-item{flex-direction:column;align-items:flex-start}}.tree-view-container{background:var(--card-bg, #fff);border-radius:12px;box-shadow:0 1px 3px #0000001a,0 1px 2px #0000000f;overflow:hidden}.tree-header{padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e5e7eb);background:var(--surface-color, #f9fafb)}.tree-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.tree-title{display:flex;align-items:center;gap:.5rem;font-size:1.125rem;font-weight:600;color:var(--text-primary, #1f2937);margin:0}.tree-title-icon{color:var(--primary-color, #3b82f6)}.tree-stats{display:flex;align-items:center;gap:.5rem;font-size:.8125rem;color:var(--text-secondary, #6b7280)}.tree-stat-sep{color:var(--border-color, #d1d5db)}.tree-toolbar{display:flex;align-items:center;gap:.75rem}.tree-search-box{flex:1;position:relative;display:flex;align-items:center}.tree-search-icon{position:absolute;left:10px;color:var(--text-secondary, #9ca3af);pointer-events:none}.tree-search-input{width:100%;padding:.5rem 2rem .5rem 2.25rem;border:2px solid var(--border-color, #e5e7eb);border-radius:6px;font-size:.875rem;background:var(--card-bg, #fff);color:var(--text-primary, #1f2937);transition:border-color .2s}.tree-search-input:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.tree-search-input::placeholder{color:var(--text-secondary, #9ca3af)}.tree-search-clear{position:absolute;right:8px;background:none;border:none;font-size:1.25rem;color:var(--text-secondary, #9ca3af);cursor:pointer;padding:0 4px;line-height:1}.tree-search-clear:hover{color:var(--text-primary, #1f2937)}.tree-expand-btns{display:flex;gap:.5rem;flex-shrink:0}.tree-btn{padding:.4rem .75rem;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:var(--card-bg, #fff);color:var(--text-secondary, #6b7280);font-size:.8125rem;cursor:pointer;transition:all .2s;white-space:nowrap}.tree-btn:hover{background:var(--surface-color, #f3f4f6);color:var(--text-primary, #1f2937);border-color:var(--text-secondary, #9ca3af)}.tree-btn-inline{display:inline-flex;align-items:center;gap:.35rem;margin-left:.5rem;color:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6)}.tree-btn-inline:hover{background:#3b82f614;color:var(--primary-color, #3b82f6)}.tree-content{padding:.75rem;max-height:70vh;overflow-y:auto}.tree-content::-webkit-scrollbar{width:6px}.tree-content::-webkit-scrollbar-track{background:transparent}.tree-content::-webkit-scrollbar-thumb{background:var(--border-color, #d1d5db);border-radius:3px}.tree-empty{display:flex;flex-direction:column;align-items:center;gap:.75rem;padding:3rem;color:var(--text-secondary, #9ca3af)}.tree-empty p{margin:0;font-size:.9375rem}.tree-empty-hint{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;margin-left:2.5rem;color:var(--text-secondary, #9ca3af);font-size:.8125rem;font-style:italic}.tree-node-standard{margin-bottom:.375rem}.tree-node-policy{margin-bottom:.25rem}.tree-node-row{display:flex;align-items:center;gap:.375rem;padding:.625rem .75rem;border-radius:6px;cursor:pointer;transition:all .15s ease;-webkit-user-select:none;user-select:none}.standard-row{background:var(--surface-color, #f9fafb);font-weight:600;color:var(--text-primary, #1f2937);border:1px solid transparent}.standard-row:hover{background:#eff6ff;border-color:#bfdbfe}.standard-row.expanded{background:#eff6ff;border-color:#93c5fd}.policy-row{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e5e7eb);font-size:.9375rem;color:var(--text-primary, #374151)}.policy-row:hover{background:#f5f3ff;border-color:#c4b5fd}.policy-row.expanded{background:#f5f3ff;border-color:#a78bfa}.control-row{background:var(--card-bg, #fff);border:1px solid var(--border-color, #e5e7eb);font-size:.875rem;cursor:default;padding:.5rem .75rem}.control-row:hover{background:#f0fdf4;border-color:#86efac}.tree-children{margin-left:1.5rem;padding-left:.75rem;border-left:2px solid var(--border-color, #e5e7eb);margin-top:.25rem}.tree-node-standard>.tree-children{border-left-color:#93c5fd}.tree-node-policy>.tree-children{border-left-color:#c4b5fd}.tree-chevron{display:flex;align-items:center;justify-content:center;width:20px;height:20px;flex-shrink:0;color:var(--text-secondary, #6b7280);transition:transform .15s}.tree-leaf-indent{width:20px;flex-shrink:0}.tree-node-icon{flex-shrink:0}.standard-icon{color:#3b82f6}.policy-icon{color:#8b5cf6}.control-icon{color:#10b981}.tree-node-label{flex:1;min-width:0;display:flex;align-items:baseline;gap:.5rem;overflow:hidden}.tree-node-label strong{flex-shrink:0}.tree-node-name{color:var(--text-secondary, #6b7280);font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.control-label{flex-wrap:wrap}.control-code-text{color:var(--text-primary, #1f2937);font-size:.8125rem}.control-name-text{color:var(--text-secondary, #6b7280);font-size:.8125rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:500;flex-shrink:0;white-space:nowrap}.standard-badge{background:#dbeafe;color:#1d4ed8}.version-badge{background:#e0e7ff;color:#4338ca}.status-badge.active{background:#dcfce7;color:#15803d}.status-badge.inactive{background:#fee2e2;color:#b91c1c}.lang-badge{background:#fef3c7;color:#92400e}.lang-badge.small{font-size:.625rem;padding:.1rem .35rem}.control-count-badge{background:#f3e8ff;color:#7c3aed}.tree-responsible-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .5rem;border-radius:10px;font-size:.6875rem;font-weight:500;background:#fef3c7;color:#92400e;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;flex-shrink:0}.tree-assignment-info{display:flex;align-items:center;gap:.35rem;flex-shrink:0}.tree-assignment-badge{display:inline-flex;align-items:center;gap:.2rem;padding:.1rem .4rem;border-radius:8px;font-size:.625rem;font-weight:600}.tree-assignment-badge.roles{background:#dbeafe;color:#1d4ed8}.tree-assignment-badge.users{background:#dcfce7;color:#15803d}.tree-control-actions{display:flex;align-items:center;gap:.25rem;flex-shrink:0;opacity:0;transition:opacity .15s}.control-row:hover .tree-control-actions,.policy-row:hover .tree-action-btn{opacity:1}.tree-action-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;border:1px solid transparent;border-radius:6px;background:transparent;cursor:pointer;transition:all .15s;opacity:0;flex-shrink:0}.policy-row:hover .tree-action-btn,.control-row:hover .tree-control-actions .tree-action-btn{opacity:1}.tree-action-btn.evidence-btn{color:#94a3b8}.tree-action-btn.evidence-btn:hover{background:#fef3c7;border-color:#fcd34d;color:#f59e0b}.tree-action-btn.evidence-btn.active{background:#f59e0b26;border-color:#f59e0b;color:#f59e0b}.tree-action-btn.roles-btn{color:#3b82f6}.tree-action-btn.roles-btn:hover{background:#dbeafe;border-color:#93c5fd}.tree-action-btn.users-btn{color:#10b981}.tree-action-btn.users-btn:hover{background:#dcfce7;border-color:#86efac}.tree-action-btn.edit-btn{color:#6366f1}.tree-action-btn.edit-btn:hover{background:#e0e7ff;border-color:#a5b4fc}.tree-action-btn.delete-btn{color:#ef4444}.tree-action-btn.delete-btn:hover{background:#fee2e2;border-color:#fca5a5}@media(max-width:768px){.tree-toolbar{flex-direction:column}.tree-expand-btns{align-self:flex-end}.tree-responsible-badge{max-width:120px}.tree-node-row{flex-wrap:wrap;gap:.25rem}.tree-control-actions,.tree-action-btn{opacity:1}}.tree-role-warning{display:inline-flex;align-items:center;color:#f59e0b;margin-left:4px;cursor:help;flex-shrink:0;animation:tree-pulse-warning 2s ease-in-out infinite}@keyframes tree-pulse-warning{0%,to{opacity:1}50%{opacity:.5}}.standards-management{min-height:100vh;background-color:var(--bg-primary)}.standards-content{padding-top:2rem;padding-bottom:3rem}.standards-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.standards-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.standards-list-container{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);overflow:hidden}.standard-item{padding:1.5rem;border-bottom:1px solid var(--border-color);transition:background-color .2s}.standard-item:last-child{border-bottom:none}.standard-item:hover{background:var(--bg-secondary)}.standard-header-row{display:flex;align-items:start;justify-content:space-between;gap:1rem}.standard-info{flex:1}.standard-title-row{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem;flex-wrap:wrap}.standard-name{font-size:1.125rem;font-weight:600;color:var(--text-primary)}.standard-badge{display:inline-block;padding:.25rem .625rem;border-radius:var(--radius-md);font-size:.75rem;font-weight:600}.standard-badge.code{background:var(--bg-secondary);color:var(--text-secondary)}.standard-badge.version{background:#3b82f61a;color:#3b82f6}.standard-badge.active{background:#22c55e1a;color:#22c55e}.standard-badge.inactive{background:var(--bg-secondary);color:var(--text-tertiary)}.standard-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:.5rem}.standard-meta{font-size:.875rem;color:var(--text-tertiary)}.standard-actions{display:flex;align-items:center;gap:.5rem}.standard-action-btn{padding:.5rem;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.standard-action-btn:hover{background:var(--bg-primary);transform:translateY(-1px)}.standard-action-btn.expand:hover{color:var(--text-primary)}.standard-action-btn.import:hover{color:#3b82f6}.standard-action-btn.edit:hover{color:var(--text-primary)}.standard-action-btn.toggle:hover{color:#f59e0b}.standard-action-btn.delete:hover{color:#ef4444}.controls-section{margin-top:1rem;padding-top:1rem;border-top:1px solid var(--border-color)}.controls-section h4{font-size:.9375rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.control-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:.5rem;transition:all .2s}.control-item:hover{background:var(--bg-primary)}.control-info{flex:1}.control-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.control-code{font-weight:600;color:#10b981;font-family:monospace;font-size:.9rem}.control-name{color:var(--text-primary);font-weight:500}.control-category{font-size:.75rem;padding:.125rem .5rem;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary)}.control-actions{display:flex;gap:.5rem}.control-role-btn{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.75rem;cursor:pointer;transition:all .2s}.control-role-btn:hover{border-color:var(--primary);color:var(--primary)}.control-role-btn.users:hover{border-color:#8b5cf6;color:#8b5cf6}.control-role-btn.evidence{color:var(--text-secondary)}.control-role-btn.evidence:hover{border-color:#f59e0b;color:#f59e0b}.control-role-btn.evidence.active{background:#f59e0b26;border-color:#f59e0b;color:#f59e0b}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);max-width:32rem;width:100%;padding:1.5rem;max-height:90vh;overflow-y:auto}.modal-content.wide{max-width:42rem}.modal-header{font-size:1.25rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem}.modal-description{font-size:.875rem;color:var(--text-secondary);margin-bottom:1rem}.modal-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-label{font-size:.875rem;font-weight:500;color:var(--text-primary)}.form-input,.form-textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-md);font-size:.9375rem;transition:all .2s}.form-input:focus,.form-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-textarea{resize:vertical;font-family:Courier New,monospace}.form-hint{font-size:.8125rem;color:var(--text-tertiary)}.modal-actions{display:flex;gap:.75rem;padding-top:1rem}.modal-actions .btn{flex:1;justify-content:center}.role-list{display:flex;flex-direction:column;gap:.5rem;max-height:24rem;overflow-y:auto;margin-bottom:1rem}.role-option{display:flex;align-items:center;padding:.75rem;border-radius:var(--radius-md);border:2px solid var(--border-color);cursor:pointer;transition:all .2s}.role-option:hover{background:var(--bg-secondary)}.role-option input[type=checkbox]{margin-right:.75rem;width:1rem;height:1rem}.role-details{flex:1}.role-name-row{display:flex;align-items:center;gap:.5rem}.role-color-dot{width:.75rem;height:.75rem;border-radius:50%}.role-name{font-weight:500;color:var(--text-primary)}.role-description{font-size:.8125rem;color:var(--text-secondary);margin-top:.25rem}.role-list-empty{text-align:center;padding:2rem;color:var(--text-tertiary);font-size:.875rem}.policies-hierarchy{margin-bottom:1.5rem}.policies-hierarchy h4{display:flex;align-items:center;font-size:.9375rem;font-weight:600;color:var(--text-secondary);margin-bottom:.75rem}.policy-hierarchy-item{margin-bottom:1rem;padding:.75rem;background:#8b5cf60d;border:1px solid rgba(139,92,246,.2);border-radius:var(--radius-md)}.policy-header-row{display:flex;align-items:center;gap:.5rem;-webkit-user-select:none;user-select:none}.policy-expand-btn{display:flex;align-items:center;justify-content:center;padding:.2rem;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s;flex-shrink:0}.policy-expand-btn:hover{color:var(--text-primary);background:var(--bg-secondary)}.policy-icon{color:#8b5cf6;flex-shrink:0}.policy-name{flex:1;font-weight:500;color:var(--text-primary)}.policy-controls-count{font-size:.75rem;padding:.25rem .5rem;background:var(--bg-secondary);border-radius:var(--radius-sm);color:var(--text-secondary)}.policy-delete-btn{padding:.25rem;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;border-radius:var(--radius-sm);transition:all .2s;display:flex;align-items:center;justify-content:center}.policy-delete-btn:hover{color:#ef4444;background:#ef44441a}.control-role-btn.edit:hover{border-color:#6366f1;color:#6366f1}.control-role-btn.delete:hover{border-color:#ef4444;color:#ef4444}.policy-controls-list{margin-top:.75rem;margin-left:1.5rem;border-left:2px solid rgba(16,185,129,.3);padding-left:1rem}.control-item.nested{margin-bottom:.5rem;padding:.5rem .75rem;background:#10b9810d;border:1px solid rgba(16,185,129,.15)}.no-policies-hint{color:var(--text-tertiary);font-style:italic;font-size:.875rem;margin:0}.unassigned-controls{margin-top:1.5rem;padding-top:1rem;border-top:1px dashed var(--border-color)}.unassigned-controls h4{display:flex;align-items:center;font-size:.9375rem;font-weight:600;color:var(--text-tertiary);margin-bottom:.75rem}.control-responsible-row{display:flex;align-items:center;gap:.35rem;margin-top:.25rem;font-size:.75rem;color:var(--text-tertiary)}.control-responsible-row svg{flex-shrink:0;color:#f59e0b}.control-responsible-text{color:#92400e;background:#fbbf241a;padding:.1rem .4rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:300px}.policy-lang-badge{display:inline-flex;align-items:center;padding:.1rem .4rem;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;background:#fbbf2426;color:#92400e;flex-shrink:0}.controls-empty{text-align:center;padding:2rem;color:var(--text-tertiary)}.controls-empty .empty-message{margin-bottom:.5rem}.controls-empty .empty-hint{font-size:.875rem;font-style:italic}.controls-loading{text-align:center;padding:2rem;color:var(--text-tertiary)}@media(max-width:768px){.standards-header{flex-direction:column;align-items:flex-start}.standard-header-row{flex-direction:column}.standard-actions{width:100%;justify-content:flex-start}.modal-content{max-width:100%}}.dropzone{padding:3rem 2rem;border:2px dashed var(--border-color);border-radius:var(--radius-md);background:var(--bg-secondary);text-align:center;cursor:pointer;transition:all .3s}.dropzone:hover,.dropzone.active{border-color:var(--primary);background:#3b82f60d}.dropzone-icon{color:var(--text-tertiary);margin-bottom:1rem}.dropzone-text{font-size:1rem;color:var(--text-primary);margin-bottom:.5rem}.dropzone-hint{font-size:.875rem;color:var(--text-tertiary)}.file-info{display:flex;align-items:center;gap:.5rem;justify-content:center;margin-top:1rem;padding:.75rem;background:var(--bg-primary);border-radius:var(--radius-md);color:var(--text-primary);font-weight:500}.control-role-warning{display:inline-flex;align-items:center;color:#f59e0b;margin-left:4px;cursor:help;animation:pulse-warning-icon 2s ease-in-out infinite}@keyframes pulse-warning-icon{0%,to{opacity:1}50%{opacity:.5}}.role-management{min-height:100vh;background-color:var(--bg-primary)}.role-content{padding-top:2rem;padding-bottom:3rem}.role-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.role-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:1.5rem}.role-card{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:1.5rem;transition:all .3s ease;position:relative;overflow:hidden}.role-card:before{content:"";position:absolute;top:0;left:0;width:4px;height:100%;opacity:1;transition:opacity .3s}.role-card:hover{transform:translateY(-4px);box-shadow:0 8px 16px #0000001f;border-color:var(--border-color)}.role-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.role-title{font-size:1.125rem;font-weight:600;margin:0}.role-actions{display:flex;gap:.5rem}.role-action-btn{padding:.5rem;border:none;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.role-action-btn:hover{background:var(--bg-primary);transform:translateY(-1px)}.role-action-btn.edit:hover{color:var(--text-primary)}.role-action-btn.delete:hover{color:#ef4444}.role-description{color:var(--text-secondary);font-size:.9375rem;line-height:1.6;margin-bottom:1rem}.role-meta{padding-top:1rem;border-top:1px solid var(--border-color);display:flex;gap:1rem;flex-wrap:wrap}.meta-item{color:var(--text-tertiary);font-size:.875rem;display:flex;align-items:center}.role-users-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.375rem .75rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:999px;color:var(--text-secondary);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s}.role-users-badge:hover{background:var(--bg-primary);border-color:var(--primary);color:var(--primary);transform:translateY(-1px)}.users-modal .modal-header h2{display:flex;align-items:center;gap:.75rem;font-size:1.25rem}.users-modal-color{display:inline-block;width:12px;height:12px;border-radius:50%;flex-shrink:0}.users-modal-search{display:flex;align-items:center;gap:.75rem;padding:.75rem 1.5rem;border-bottom:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-secondary)}.users-modal-search input{flex:1;border:none;background:transparent;color:var(--text-primary);font-size:.9375rem;outline:none;font-family:inherit}.users-modal-search input::placeholder{color:var(--text-tertiary)}.users-search-clear{display:flex;align-items:center;justify-content:center;padding:.25rem;border:none;background:var(--bg-primary);color:var(--text-secondary);border-radius:50%;cursor:pointer;transition:all .15s}.users-search-clear:hover{background:var(--border-color);color:var(--text-primary)}.users-modal-body{max-height:60vh;overflow-y:auto}.users-modal-body::-webkit-scrollbar{width:6px}.users-modal-body::-webkit-scrollbar-track{background:transparent}.users-modal-body::-webkit-scrollbar-thumb{background:var(--border-color);border-radius:3px}.users-modal-body::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.users-modal-count{padding:.5rem 1.5rem;font-size:.8125rem;color:var(--text-tertiary);border-bottom:1px solid var(--border-color)}.users-modal-list{display:flex;flex-direction:column}.users-modal-item{display:flex;align-items:center;gap:.75rem;padding:.625rem 1.5rem;border-bottom:1px solid var(--border-color);transition:background .15s}.users-modal-item:last-child{border-bottom:none}.users-modal-item:hover{background:var(--bg-secondary)}.users-modal-avatar{width:36px;height:36px;border-radius:50%;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.users-modal-info{display:flex;flex-direction:column;min-width:0;flex:1}.users-modal-name{font-size:.9375rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.users-modal-email{font-size:.8125rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.users-modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem 1.5rem;color:var(--text-tertiary);text-align:center}.users-modal-empty svg{margin-bottom:.75rem;opacity:.5}.users-modal-empty p{font-size:.9375rem;margin:0}.empty-state{text-align:center;padding:3rem 1rem;color:var(--text-secondary);background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color)}.empty-state svg{color:var(--text-tertiary);margin-bottom:1rem}.empty-state p{font-size:1rem;margin-bottom:1rem}.modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;padding:1rem;z-index:50;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:var(--bg-card);border-radius:var(--radius-lg);width:90%;max-width:500px;max-height:90vh;overflow-y:auto}.modal-content.modal-large{max-width:700px}.modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem;border-bottom:1px solid var(--border-color)}.modal-header h2{margin:0;font-size:1.5rem;font-weight:600;color:var(--text-primary)}.close-btn{background:transparent;border:none;padding:.5rem;cursor:pointer;color:var(--text-secondary);border-radius:var(--radius-md);transition:all .2s}.close-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.language-tabs{display:flex;gap:.5rem;padding:1rem 1.5rem;border-bottom:1px solid var(--border-color);overflow-x:auto;background:var(--bg-secondary)}.language-tab{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all .2s;white-space:nowrap;font-size:.875rem}.language-tab:hover{background:var(--bg-primary);border-color:var(--primary)}.language-tab.active{background:var(--primary);color:#fff;border-color:var(--primary)}.language-tab .flag{font-size:1.25rem}.language-tab .lang-name{font-weight:500}.translation-info{display:flex;align-items:center;gap:.75rem;padding:1rem;background:var(--bg-secondary);border-radius:var(--radius-md);color:var(--text-secondary);margin-bottom:1rem;font-size:.9375rem}.modal-form{padding:1.5rem}.form-group{margin-bottom:1.5rem}.form-group label{display:block;font-weight:500;color:var(--text-primary);margin-bottom:.5rem;font-size:.875rem}.form-group input,.form-group textarea{width:100%;padding:.625rem .75rem;border:1px solid var(--border-color);background:var(--bg-primary);color:var(--text-primary);border-radius:var(--radius-md);font-size:.9375rem;font-family:inherit;transition:all .2s}.form-group input:focus,.form-group textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #3b82f61a}.form-group textarea{resize:vertical;min-height:80px}.form-hint{display:block;margin-top:.375rem;font-size:.8125rem;color:var(--text-tertiary);font-weight:400}.color-picker-wrapper{display:flex;gap:1rem;align-items:center}.color-picker-wrapper input[type=color]{width:60px;height:45px;border:1px solid var(--border-color);background:var(--bg-primary);border-radius:var(--radius-md);cursor:pointer;padding:4px}.color-picker-wrapper input[type=text]{flex:1}.modal-actions{display:flex;gap:1rem;justify-content:flex-end;padding:1.5rem;border-top:1px solid var(--border-color)}.modal-actions .btn{flex:1;max-width:150px;justify-content:center}.loading-container{display:flex;align-items:center;justify-content:center;min-height:50vh}.loading-text{font-size:1rem;color:var(--text-secondary)}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;border-radius:var(--radius-lg);margin-bottom:1.5rem;font-size:.9375rem}.alert button{margin-left:auto;background:none;border:none;font-size:1.5rem;line-height:1;cursor:pointer;opacity:.7}.alert button:hover{opacity:1}.alert-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.alert-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#14532d}.checkbox-label{display:flex!important;align-items:center;gap:.625rem;cursor:pointer;font-weight:500;color:var(--text-primary)}.checkbox-label input[type=checkbox]{width:18px;height:18px;accent-color:var(--primary);cursor:pointer;flex-shrink:0}.checkbox-label span{font-size:.9375rem}.role-users-section{display:flex;align-items:center;gap:.625rem;flex-wrap:wrap;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--border-color)}.role-selectable-badge{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .625rem;border-radius:999px;font-size:.75rem;font-weight:500;white-space:nowrap}.role-selectable-badge.selectable{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.25)}.role-selectable-badge.admin-only{background:#f59e0b1a;color:#f59e0b;border:1px solid rgba(245,158,11,.25)}@media(max-width:768px){.role-header{flex-direction:column;align-items:flex-start}.roles-grid{grid-template-columns:1fr}.modal-content{width:95%}.modal-content.modal-large{max-width:95%}.language-tabs{padding:.75rem}.language-tab{padding:.375rem .75rem;font-size:.8125rem}.language-tab .lang-name{display:none}.modal-actions .btn{max-width:none}}.approval-modal{max-width:600px}.evidence-details{padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem}.detail-row{display:flex;gap:1rem;align-items:flex-start}.detail-row svg{color:var(--primary);flex-shrink:0;margin-top:.25rem}.detail-label{font-size:.875rem;color:var(--text-secondary);margin-bottom:.25rem}.detail-value{font-size:1rem;color:var(--text-primary);font-weight:500}.tag-chip{padding:.25rem .75rem;background:#3b82f61a;color:var(--primary);border-radius:var(--radius-full);font-size:.875rem;font-weight:500}.description-section{padding-top:1rem;border-top:1px solid var(--border-color)}.reject-form{padding:1.5rem;padding-top:0;display:flex;flex-direction:column;gap:1rem}.reject-form label{font-size:.875rem;font-weight:500;color:var(--text-secondary)}.btn-approve{background:var(--success);color:#fff;border:none}.btn-approve:hover{background:#059669;transform:translateY(-1px)}.btn-reject{background:transparent;color:var(--danger);border:1px solid var(--danger)}.btn-reject:hover{background:#ef44441a}.evidences-page{min-height:100vh;background:var(--bg-primary)}.evidences-content{padding:2rem;max-width:1600px;margin:0 auto}.evidences-header{margin-bottom:1.5rem}.evidences-header h1{display:flex;align-items:center;gap:.75rem;color:var(--text-primary);font-size:1.75rem;margin-bottom:.25rem}.evidences-header .subtitle{color:var(--text-secondary);font-size:.95rem}.evidence-stats{display:flex;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.stat-pill{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--bg-secondary);border:2px solid var(--border-color);border-radius:50px;cursor:pointer;transition:all .2s}.stat-pill:hover{background:var(--bg-tertiary)}.stat-pill.active{border-color:var(--primary);background:#6366f11a}.stat-pill.pending{border-color:#f59e0b}.stat-pill.pending.active{background:#f59e0b1a}.stat-pill.approved{border-color:#22c55e}.stat-pill.approved.active{background:#22c55e1a}.stat-pill.rejected{border-color:#ef4444}.stat-pill.rejected.active{background:#ef44441a}.stat-count{font-weight:700;font-size:1.1rem}.stat-label{font-size:.85rem;color:var(--text-secondary)}.evidences-layout{display:grid;grid-template-columns:1fr 400px;gap:1.5rem;min-height:600px}@media(max-width:1024px){.evidences-layout{grid-template-columns:1fr}}.tree-container{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.tree-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color);font-weight:600;color:var(--text-primary)}.tree-content{padding:.5rem;max-height:600px;overflow-y:auto}.tree-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;color:var(--text-secondary)}.tree-empty svg{opacity:.3;margin-bottom:1rem}.tree-node{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;border-radius:6px;cursor:pointer;transition:background .15s;-webkit-user-select:none;user-select:none}.tree-node:hover{background:var(--bg-tertiary)}.tree-node.selected{background:#6366f126;border:1px solid var(--primary)}.tree-node-expand{width:20px;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.tree-node-icon{color:var(--text-secondary)}.tree-node.standard .tree-node-icon{color:#6366f1}.tree-node.policy .tree-node-icon{color:#8b5cf6}.tree-node.control .tree-node-icon{color:#10b981}.tree-node.company .tree-node-icon{color:#f59e0b}.tree-node.evidence .tree-node-icon{color:#6b7280}.tree-node.standard .tree-node-name{font-weight:600}.tree-node.policy .tree-node-name{color:#c4b5fd}.tree-node.control .tree-node-name{color:#6ee7b7;font-family:Courier New,monospace}.tree-node.company .tree-node-name{color:#fcd34d}.tree-node-name{flex:1;font-size:.9rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tree-node-count{background:var(--bg-tertiary);padding:.125rem .5rem;border-radius:10px;font-size:.75rem;color:var(--text-secondary)}.status-icon{flex-shrink:0}.status-icon.approved{color:#22c55e}.status-icon.pending{color:#f59e0b}.status-icon.rejected{color:#ef4444}.preview-container{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.preview-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;text-align:center;height:100%;min-height:400px;color:var(--text-secondary)}.preview-empty svg{opacity:.3;margin-bottom:1rem}.preview-empty h3{color:var(--text-primary);margin-bottom:.5rem}.evidence-preview{height:100%;display:flex;flex-direction:column}.preview-header{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-color)}.preview-header h3{font-size:1rem;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.preview-details{flex:1;padding:1.25rem;overflow-y:auto}.detail-row{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border-color)}.detail-row.full{flex-direction:column;align-items:flex-start;gap:.5rem}.detail-label{color:var(--text-secondary);font-size:.85rem}.status-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:capitalize}.status-badge.approved{background:#22c55e26;color:#22c55e}.status-badge.pending{background:#f59e0b26;color:#f59e0b}.status-badge.rejected{background:#ef444426;color:#ef4444}.tags-list{display:flex;flex-wrap:wrap;gap:.5rem}.tag-chip{background:var(--bg-tertiary);padding:.25rem .75rem;border-radius:20px;font-size:.75rem;color:var(--text-secondary);border:1px solid var(--border-color)}.preview-actions{display:flex;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border-color)}.preview-actions .btn{flex:1;display:flex;align-items:center;justify-content:center;gap:.5rem}.loading{display:flex;justify-content:center;align-items:center;height:50vh;color:var(--text-secondary);font-size:1.1rem}.alert{display:flex;align-items:center;gap:.75rem;padding:1rem;border-radius:8px;margin-bottom:1rem}.alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.alert button{margin-left:auto;background:none;border:none;color:inherit;font-size:1.25rem;cursor:pointer}.activity-section{background:var(--bg-secondary, #1e293b);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);border-radius:16px;border:1px solid var(--border-color, #334155);padding:1.5rem}.section-header{display:flex;align-items:center;gap:.75rem;margin-bottom:1.5rem;color:var(--text-primary, #f1f5f9)}.section-header h3{font-size:1.25rem;font-weight:700}.activity-timeline{display:flex;flex-direction:column;gap:.75rem}.activity-item{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-tertiary, #0f172a);border-radius:10px;border:1px solid var(--border-color, #334155);transition:all .2s}.activity-item:hover{border-color:var(--primary, #6366f1);transform:translate(4px)}.activity-status{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-status.pending{background:#f59e0b26;color:#f59e0b}.activity-status.approved{background:#22c55e26;color:#22c55e}.activity-status.rejected{background:#ef444426;color:#ef4444}.activity-content{flex:1;min-width:0}.activity-title{font-weight:600;color:var(--text-primary, #f1f5f9);margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-meta{display:flex;align-items:center;gap:.5rem;font-size:.8rem;color:var(--text-secondary, #94a3b8);flex-wrap:wrap}.activity-badge{padding:.25rem .75rem;border-radius:20px;font-size:.75rem;font-weight:600;text-transform:capitalize;flex-shrink:0}.activity-badge.pending{background:#f59e0b26;color:#f59e0b}.activity-badge.approved{background:#22c55e26;color:#22c55e}.activity-badge.rejected{background:#ef444426;color:#ef4444}.empty-activity{text-align:center;padding:2rem;color:var(--text-secondary, #94a3b8)}.mfa-setup{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.mfa-setup-header{display:flex;align-items:center;gap:.5rem;margin-bottom:1rem}.mfa-setup-header h2{font-size:1.1rem;color:var(--text-primary, #f1f5f9);margin:0}.mfa-setup-header svg{color:#6366f1}.mfa-loading{text-align:center;padding:2rem;color:var(--text-secondary, #94a3b8)}.mfa-alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.85rem;margin-bottom:1rem}.mfa-alert-success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#34d399}.mfa-alert-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171}.mfa-status-section{text-align:center}.mfa-status-badge{display:inline-flex;align-items:center;gap:.5rem;padding:.5rem 1rem;border-radius:20px;font-size:.9rem;font-weight:600;margin-bottom:.75rem}.mfa-status-badge.enabled{background:#10b98126;color:#34d399}.mfa-status-badge.disabled{background:#94a3b826;color:#94a3b8}.mfa-status-desc{color:var(--text-secondary, #94a3b8);font-size:.85rem;margin-bottom:1.25rem;line-height:1.5}.mfa-setup-section h3{color:var(--text-primary, #f1f5f9);font-size:1rem;margin:0 0 .5rem;display:flex;align-items:center;gap:.4rem}.mfa-step-desc{color:var(--text-secondary, #94a3b8);font-size:.85rem;margin:0 0 1rem;line-height:1.5}.mfa-qr-container{display:flex;justify-content:center;margin:1rem 0}.mfa-qr-image{width:200px;height:200px;border-radius:8px;background:#fff;padding:8px}.mfa-manual-entry{text-align:center;margin:1rem 0}.mfa-manual-entry p{color:var(--text-secondary, #94a3b8);font-size:.8rem;margin-bottom:.5rem}.mfa-secret-code{display:inline-block;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:6px;padding:.5rem 1rem;font-size:.9rem;color:#f59e0b;letter-spacing:.1em;word-break:break-all;-webkit-user-select:all;user-select:all}.mfa-verify-form{display:flex;flex-direction:column;gap:1rem}.mfa-code-field{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.75rem 1rem;color:var(--text-primary, #f1f5f9);font-size:1.5rem;text-align:center;letter-spacing:.3em;font-weight:600;font-family:Courier New,monospace;outline:none;transition:border-color .2s}.mfa-code-field:focus{border-color:#6366f1}.mfa-code-field::placeholder{opacity:.3;letter-spacing:.3em}.mfa-form-actions{display:flex;gap:.75rem;justify-content:flex-end}.mfa-form-actions .btn{min-width:120px}.mfa-btn-danger{color:#f87171!important;border-color:#ef44444d!important}.mfa-btn-danger:hover{background:#ef44441a!important}.mfa-backup-warning{display:flex;gap:.75rem;background:#f59e0b1a;border:1px solid rgba(245,158,11,.3);border-radius:8px;padding:1rem;margin-bottom:1rem}.mfa-backup-warning svg{color:#f59e0b;flex-shrink:0;margin-top:2px}.mfa-backup-warning strong{color:#f59e0b;display:block;margin-bottom:.25rem;font-size:.9rem}.mfa-backup-warning p{color:var(--text-secondary, #94a3b8);font-size:.8rem;margin:0;line-height:1.4}.mfa-backup-codes{display:grid;grid-template-columns:repeat(2,1fr);gap:.5rem;margin-bottom:1rem}.mfa-backup-code{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:6px;padding:.5rem;text-align:center;font-size:.9rem;color:var(--text-primary, #f1f5f9);letter-spacing:.1em;font-family:Courier New,monospace;-webkit-user-select:all;user-select:all}@media(max-width:480px){.mfa-backup-codes{grid-template-columns:1fr}.mfa-form-actions{flex-direction:column}.mfa-form-actions .btn{width:100%;min-width:unset}}.user-dashboard{min-height:100vh;background:var(--bg-color, #0f172a)}.dashboard-content{padding:2rem 1rem;max-width:1200px;margin:0 auto}.ud-container{width:100%}.dashboard-header{margin-bottom:2rem}.dashboard-header h1{color:var(--text-primary, #f1f5f9);font-size:1.75rem;font-weight:700;margin:0 0 .5rem}.dashboard-header .subtitle{color:var(--text-secondary, #94a3b8);font-size:.95rem;margin:0}.ud-loading{display:flex;justify-content:center;align-items:center;padding:3rem;color:var(--text-secondary, #94a3b8);font-size:1rem}.ud-empty{text-align:center;padding:2.5rem 1rem;color:var(--text-secondary, #94a3b8);font-style:italic;font-size:.95rem}.ud-alert{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;font-size:.875rem;margin-bottom:1rem}.ud-alert-success{background:#10b9811a;color:#10b981;border:1px solid rgba(16,185,129,.25)}.ud-alert-error{background:#ef44441a;color:#ef4444;border:1px solid rgba(239,68,68,.25)}.ud-icon-success{color:#10b981}.ud-highlight{color:var(--primary-color, #6366f1);font-weight:600}.ud-tabs{display:flex;gap:.25rem;margin-bottom:1.5rem;border-bottom:2px solid var(--border-color, #334155);padding-bottom:0;overflow-x:auto}.ud-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;background:none;border:none;color:var(--text-secondary, #94a3b8);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s ease;white-space:nowrap;border-radius:6px 6px 0 0}.ud-tab:hover{color:var(--text-primary, #f1f5f9);background:#6366f10d}.ud-tab.active{color:var(--primary-color, #6366f1);border-bottom-color:var(--primary-color, #6366f1);background:#6366f114}.ud-tab-content{animation:udFadeIn .25s ease}@keyframes udFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.ud-section-title{display:flex;align-items:center;gap:.5rem;color:var(--text-primary, #f1f5f9);font-size:1.25rem;font-weight:600;margin:0 0 .5rem}.ud-section-desc{color:var(--text-secondary, #94a3b8);font-size:.9rem;margin:0 0 1.25rem}.ud-btn{display:inline-flex;align-items:center;gap:.4rem;padding:.6rem 1.2rem;border-radius:8px;font-size:.875rem;font-weight:500;border:none;cursor:pointer;transition:all .2s ease;white-space:nowrap}.ud-btn:disabled{opacity:.5;cursor:not-allowed}.ud-btn-primary{background:var(--primary-color, #6366f1);color:#fff}.ud-btn-primary:hover:not(:disabled){background:#4f46e5;box-shadow:0 2px 8px #6366f14d}.ud-btn-outline{background:transparent;color:var(--primary-color, #6366f1);border:1px solid var(--primary-color, #6366f1)}.ud-btn-outline:hover:not(:disabled){background:#6366f11a}.ud-btn-ghost{background:transparent;color:var(--text-secondary, #94a3b8)}.ud-btn-ghost:hover:not(:disabled){color:var(--text-primary, #f1f5f9);background:#94a3b81a}.ud-btn-sm{padding:.35rem .75rem;font-size:.8rem;border-radius:6px}.ud-save-roles{margin-top:1.25rem}.ud-roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(260px,1fr));gap:.75rem}.ud-role-card{display:flex;align-items:center;gap:.75rem;padding:1rem 1.25rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;cursor:pointer;transition:all .2s ease}.ud-role-card:hover{border-color:var(--primary-color, #6366f1);background:#6366f10a}.ud-role-card.selected{border-color:var(--primary-color, #6366f1);background:#6366f114;box-shadow:0 0 0 1px #6366f133}.ud-role-check{flex-shrink:0;color:var(--text-secondary, #94a3b8)}.ud-role-card.selected .ud-role-check{color:var(--primary-color, #6366f1)}.ud-role-info{display:flex;flex-direction:column;gap:.2rem;min-width:0}.ud-role-name{color:var(--text-primary, #f1f5f9);font-weight:500;font-size:.95rem}.ud-role-desc{color:var(--text-secondary, #94a3b8);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ud-progress-section{display:flex;align-items:center;gap:2rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;padding:1.5rem;margin-bottom:1.5rem}.ud-progress-chart{position:relative;flex-shrink:0}.ud-progress-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:1.5rem;font-weight:700;color:var(--text-primary, #f1f5f9)}.ud-progress-stats{display:flex;gap:1.5rem;flex-wrap:wrap}.ud-stat{display:flex;flex-direction:column;gap:.15rem;padding:.75rem 1rem;background:var(--bg-color, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;min-width:100px;text-align:center}.ud-stat.success{border-color:#10b98166}.ud-stat.warning{border-color:#f59e0b66}.ud-stat.active-filter{box-shadow:0 0 0 2px #6366f199;transform:scale(1.05);transition:all .2s ease}.ud-stat.active-filter.success{box-shadow:0 0 0 2px #10b98199}.ud-stat.active-filter.warning{box-shadow:0 0 0 2px #f59e0b99}.ud-stat.active-filter[style*="border-color: rgb(239, 68, 68)"]{box-shadow:0 0 0 2px #ef444499}.ud-stat:hover{transform:scale(1.03);transition:all .15s ease}.ud-stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #f1f5f9);line-height:1.2}.ud-stat.success .ud-stat-value{color:#10b981}.ud-stat.warning .ud-stat-value{color:#f59e0b}.ud-stat-label{font-size:.75rem;color:var(--text-secondary, #94a3b8);text-transform:uppercase;letter-spacing:.03em}.ud-search-bar{display:flex;align-items:center;gap:.5rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;margin-bottom:1rem;flex:1}.ud-search-bar svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.ud-search-bar input{background:none;border:none;outline:none;color:var(--text-primary, #f1f5f9);font-size:.9rem;width:100%}.ud-search-bar input::placeholder{color:var(--text-secondary, #64748b)}.ud-standards-list{display:flex;flex-direction:column;gap:.75rem}.ud-standard-group{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;overflow:hidden}.ud-standard-header{display:flex;align-items:center;gap:.5rem;padding:.85rem 1rem;cursor:pointer;transition:background .15s ease}.ud-standard-header:hover{background:#6366f10a}.ud-standard-header svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.ud-standard-name{color:var(--text-primary, #f1f5f9);font-weight:600;font-size:.95rem;flex:1}.ud-standard-count{color:var(--text-secondary, #94a3b8);font-size:.8rem;background:var(--bg-color, #0f172a);padding:.2rem .6rem;border-radius:12px}.ud-controls-list{border-top:1px solid var(--border-color, #334155)}.ud-control-row{display:flex;align-items:center;justify-content:space-between;padding:.7rem 1rem .7rem 2.25rem;border-bottom:1px solid rgba(51,65,85,.5);transition:background .15s ease}.ud-control-row:last-child{border-bottom:none}.ud-control-row:hover{background:#6366f108}.ud-control-row.has-evidence,.ud-control-row.completed{background:#10b98108}.ud-control-info{display:flex;align-items:center;gap:.75rem;flex:1;min-width:0}.ud-control-code{background:#6366f11f;color:var(--primary-color, #6366f1);padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;white-space:nowrap;font-family:Courier New,monospace}.ud-control-name{color:var(--text-primary, #f1f5f9);font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ud-control-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0;margin-left:.75rem}.ud-training-stats{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.ud-training-actions{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.ud-training-actions .ud-search-bar{margin-bottom:0}.ud-evidence-stats{display:flex;gap:1rem;margin-bottom:1.25rem;flex-wrap:wrap}.ud-evidence-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;flex-wrap:wrap}.ud-evidence-toolbar .ud-search-bar{margin-bottom:0}.ud-filter-buttons{display:flex;gap:.25rem;flex-shrink:0}.ud-evidence-list{display:flex;flex-direction:column;gap:.6rem}.ud-evidence-card{display:flex;align-items:center;justify-content:space-between;gap:1rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;padding:1rem 1.25rem;transition:border-color .2s ease}.ud-evidence-card:hover{border-color:#6366f14d}.ud-evidence-info{display:flex;flex-direction:column;gap:.25rem;flex:1;min-width:0}.ud-evidence-name{color:var(--text-primary, #f1f5f9);font-weight:500;font-size:.95rem}.ud-evidence-desc{color:var(--text-secondary, #94a3b8);font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ud-evidence-tags{display:flex;gap:.35rem;flex-wrap:wrap;margin-top:.25rem}.ud-tag{padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:600}.ud-tag-control{background:#6366f11a;color:var(--primary-color, #6366f1)}.ud-tag-extra{background:#10b9811a;color:#10b981}.ud-evidence-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.35rem;flex-shrink:0}.ud-status-badge{display:inline-flex;align-items:center;gap:.3rem;padding:.25rem .65rem;border-radius:12px;font-size:.75rem;font-weight:600;text-transform:capitalize}.ud-status-badge.pending{background:#f59e0b1a;color:#f59e0b}.ud-status-badge.approved{background:#10b9811a;color:#10b981}.ud-status-badge.rejected{background:#ef44441a;color:#ef4444}.ud-evidence-date{color:var(--text-secondary, #64748b);font-size:.75rem}.ud-evidence-actions{display:flex;gap:.25rem}.ud-clickable{cursor:pointer;transition:color .15s ease}.ud-clickable:hover{color:var(--primary-color, #6366f1);text-decoration:underline}.ud-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ud-modal{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:14px;width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 20px 60px #0006;animation:udModalIn .2s ease}@keyframes udModalIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.ud-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #334155)}.ud-modal-header h3{color:var(--text-primary, #f1f5f9);font-size:1.05rem;font-weight:600;margin:0}.ud-modal-header h3 small{color:var(--text-secondary, #94a3b8);font-weight:400;font-size:.85rem}.ud-modal-close{background:none;border:none;color:var(--text-secondary, #94a3b8);cursor:pointer;padding:.25rem;border-radius:6px;transition:all .15s ease}.ud-modal-close:hover{color:var(--text-primary, #f1f5f9);background:#94a3b81a}.ud-modal .ud-alert{margin:1rem 1.5rem 0}.ud-modal-form{padding:1.25rem 1.5rem;display:flex;flex-direction:column;gap:1rem}.ud-form-group{display:flex;flex-direction:column;gap:.35rem}.ud-form-group label{color:var(--text-primary, #f1f5f9);font-size:.85rem;font-weight:500}.ud-form-group label small{color:var(--text-secondary, #94a3b8);font-weight:400}.ud-form-group input,.ud-form-group textarea{background:var(--bg-color, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.6rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem;outline:none;transition:border-color .2s ease;font-family:inherit}.ud-form-group input:focus,.ud-form-group textarea:focus{border-color:var(--primary-color, #6366f1);box-shadow:0 0 0 2px #6366f126}.ud-form-group input::placeholder,.ud-form-group textarea::placeholder{color:var(--text-secondary, #64748b)}.ud-file-drop{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1.5rem;border:2px dashed var(--border-color, #334155);border-radius:10px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary, #94a3b8);text-align:center}.ud-file-drop:hover{border-color:var(--primary-color, #6366f1);background:#6366f10a;color:var(--text-primary, #f1f5f9)}.ud-file-drop span{font-size:.85rem}.ud-modal-actions{display:flex;justify-content:flex-end;gap:.75rem;padding-top:.5rem;border-top:1px solid var(--border-color, #334155);margin-top:.5rem;padding-top:1rem}.ud-detail-row{display:flex;align-items:center;justify-content:space-between;padding:.6rem 0;border-bottom:1px solid var(--border-color, #1e293b)}.ud-detail-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);font-weight:500}.ud-detail-value{font-size:.875rem;color:var(--text-primary, #f1f5f9)}.ud-text-error{color:#ef4444}.ud-file-actions{display:flex;gap:.5rem}.ud-input-readonly{opacity:.6;cursor:not-allowed}.ud-csv-input{display:flex;align-items:center;gap:.5rem;background:var(--bg-color, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.35rem .75rem;transition:border-color .2s ease}.ud-csv-input:focus-within{border-color:var(--primary-color, #6366f1);box-shadow:0 0 0 2px #6366f126}.ud-csv-readonly-tag{display:inline-flex;align-items:center;background:#6366f126;color:var(--primary-color, #6366f1);padding:.25rem .6rem;border-radius:4px;font-size:.8rem;font-weight:600;white-space:nowrap;font-family:Courier New,monospace;-webkit-user-select:none;user-select:none}.ud-csv-input input{background:none;border:none;outline:none;color:var(--text-primary, #f1f5f9);font-size:.875rem;flex:1;min-width:0;padding:.25rem 0}.ud-csv-input input::placeholder{color:var(--text-secondary, #64748b)}@media(max-width:640px){.ud-modal{max-width:100%;border-radius:12px 12px 0 0;max-height:95vh}}@media(max-width:768px){.dashboard-content{padding:1rem .75rem}.dashboard-header h1{font-size:1.35rem}.ud-tabs{gap:0}.ud-tab{padding:.6rem .75rem;font-size:.8rem}.ud-tab span{display:none}.ud-progress-section{flex-direction:column;align-items:stretch;gap:1rem}.ud-progress-chart{align-self:center}.ud-progress-stats{justify-content:center}.ud-roles-grid{grid-template-columns:1fr}.ud-training-actions,.ud-evidence-toolbar{flex-direction:column;align-items:stretch}.ud-evidence-card{flex-direction:column;align-items:flex-start}.ud-evidence-meta{flex-direction:row;align-items:center;width:100%;justify-content:space-between}.ud-control-row{padding-left:1rem}}.user-control-guide{min-height:100vh;background:var(--bg-color, #0f172a)}.guide-content{padding:2rem 0;max-width:1200px}.guide-header{margin-bottom:2rem}.guide-header h1{color:var(--text-primary, #f1f5f9);font-size:2rem;margin-bottom:.5rem}.guide-header .subtitle{color:var(--text-secondary, #94a3b8);font-size:1rem}.search-section{margin-bottom:2rem}.search-input{width:100%;padding:.875rem 1rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;color:var(--text-primary, #f1f5f9);font-size:1rem;transition:border-color .2s ease}.search-input:focus{outline:none;border-color:var(--primary-color, #3b82f6)}.search-meta{color:var(--text-secondary, #94a3b8);font-size:.875rem;margin-top:.5rem}.controls-list{display:flex;flex-direction:column;gap:1.5rem}.standard-section{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;overflow:hidden}.standard-header{padding:1.25rem 1.5rem;cursor:pointer;transition:background .2s ease}.standard-header:hover{background:#3b82f60d}.standard-title{display:flex;align-items:center;gap:1rem}.standard-title svg{color:var(--text-secondary, #94a3b8);flex-shrink:0}.standard-title h2{color:var(--text-primary, #f1f5f9);font-size:1.25rem;margin:0;flex-shrink:0}.standard-badge{background:var(--primary-color, #3b82f6);color:#fff;padding:.25rem .75rem;border-radius:6px;font-size:.875rem;font-weight:600;flex-shrink:0}.control-count-badge{background:var(--bg-color, #0f172a);color:var(--text-secondary, #94a3b8);padding:.25rem .75rem;border-radius:6px;font-size:.875rem;margin-left:auto}.controls-grid{padding:1.5rem;display:grid;gap:1rem;background:var(--bg-color, #0f172a)}.control-card{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:1.25rem;transition:all .2s ease}.control-card:hover{border-color:var(--primary-color, #3b82f6);transform:translateY(-2px)}.control-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1rem}.control-code-name{flex:1}.control-code{display:inline-block;background:var(--bg-color, #0f172a);color:var(--primary-color, #3b82f6);padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.control-name{color:var(--text-primary, #f1f5f9);font-size:1rem;font-weight:600;margin:0}.control-status{flex-shrink:0}.status-icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:50%}.status-icon.success{background:#10b9811a;color:var(--success-color, #10b981)}.status-icon.pending{background:#ef44441a;color:var(--error-color, #ef4444)}.control-description{color:var(--text-secondary, #94a3b8);font-size:.875rem;line-height:1.6;margin-bottom:1rem}.control-footer{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding-top:1rem;border-top:1px solid var(--border-color, #334155)}.control-meta{display:flex;flex-direction:column;gap:.25rem;flex:1}.evidence-count{display:flex;align-items:center;gap:.5rem;color:var(--success-color, #10b981);font-size:.875rem}.no-evidence{color:var(--text-secondary, #94a3b8);font-size:.875rem}.policy-indicator{color:var(--text-secondary, #94a3b8);font-size:.75rem;display:flex;align-items:center;flex-wrap:wrap;gap:.25rem}.text-link{background:transparent;border:none;padding:0;margin:0;color:var(--primary-color, #3b82f6);font-size:.75rem;font-weight:600;cursor:pointer;text-decoration:underline}.text-link:hover{color:var(--primary-hover, #2563eb)}.text-link:focus{outline:2px solid rgba(59,130,246,.5);outline-offset:2px;border-radius:4px}.btn-upload{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease;flex-shrink:0}.btn-upload:hover{background:var(--primary-hover, #2563eb);transform:translateY(-1px)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;text-align:center}.empty-state svg{color:var(--text-secondary, #94a3b8);margin-bottom:1rem}.empty-state h3{color:var(--text-primary, #f1f5f9);font-size:1.25rem;margin-bottom:.5rem}.empty-state p{color:var(--text-secondary, #94a3b8);max-width:400px}.loading-state,.error-state{display:flex;justify-content:center;align-items:center;min-height:50vh;color:var(--text-secondary, #94a3b8);font-size:1.125rem}.error-state{color:var(--error-color, #ef4444)}@media(max-width:768px){.control-footer{flex-direction:column;align-items:stretch}.btn-upload{justify-content:center}}.training-stats{display:flex;gap:2rem;margin-bottom:2rem;padding:1.5rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px}.stat-item{display:flex;flex-direction:column;align-items:center;gap:.25rem}.stat-value{font-size:2rem;font-weight:700;color:var(--primary-color, #3b82f6)}.stat-label{font-size:.875rem;color:var(--text-secondary, #94a3b8)}.status-icon.evidence{background:#3b82f61a;color:var(--primary-color, #3b82f6)}.control-card.completed{border-color:var(--success-color, #10b981);background:#10b98108}.acknowledgment-section{margin-top:2rem;padding:1.5rem;background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px}.acknowledgment-confirmation{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#10b9811a;border:1px solid var(--success-color, #10b981);border-radius:8px;margin-bottom:1rem;color:var(--success-color, #10b981);font-weight:500;animation:slideIn .3s ease}@keyframes slideIn{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.acknowledgment-checkbox{display:flex;align-items:center;gap:.75rem;cursor:pointer;padding:1rem;border-radius:8px;transition:all .2s ease;background:var(--bg-color, #0f172a);border:2px solid var(--border-color, #334155)}.acknowledgment-checkbox:hover:not(.checked):not(.loading){border-color:var(--primary-color, #3b82f6);background:#3b82f60d}.acknowledgment-checkbox.checked{border-color:var(--success-color, #10b981);background:#10b9811a}.acknowledgment-checkbox.loading{opacity:.7;cursor:wait}.acknowledgment-checkbox input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.checkbox-icon{display:flex;align-items:center;justify-content:center;color:var(--text-secondary, #94a3b8);transition:color .2s ease}.acknowledgment-checkbox.checked .checkbox-icon{color:var(--success-color, #10b981)}.checkbox-label{font-size:1rem;font-weight:500;color:var(--text-primary, #f1f5f9)}.acknowledgment-checkbox.checked .checkbox-label{color:var(--success-color, #10b981)}@media(max-width:768px){.training-stats{flex-direction:column;gap:1rem}.stat-item{flex-direction:row;justify-content:space-between}.stat-value{font-size:1.5rem}}.control-detail-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.control-detail-modal{background:var(--surface-color, #1e293b);border:1px solid var(--border-color, #334155);border-radius:16px;width:100%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;animation:modalSlideIn .25s ease;box-shadow:0 25px 50px -12px #00000080}@keyframes modalSlideIn{0%{opacity:0;transform:translateY(20px) scale(.97)}to{opacity:1;transform:translateY(0) scale(1)}}.control-detail-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid var(--border-color, #334155)}.control-detail-title{flex:1}.control-detail-title .control-code{display:inline-block;background:var(--bg-color, #0f172a);color:var(--primary-color, #3b82f6);padding:.25rem .75rem;border-radius:6px;font-size:.8rem;font-weight:700;margin-bottom:.5rem}.control-detail-title h2{color:var(--text-primary, #f1f5f9);font-size:1.15rem;font-weight:600;margin:0;line-height:1.5}.modal-close-btn{background:transparent;border:1px solid var(--border-color, #334155);color:var(--text-secondary, #94a3b8);width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0;margin-left:1rem}.modal-close-btn:hover{background:#ef44441a;border-color:var(--error-color, #ef4444);color:var(--error-color, #ef4444)}.control-detail-body{padding:1.5rem;overflow-y:auto;flex:1}.control-detail-description{margin-bottom:1.25rem}.control-detail-description p{color:var(--text-primary, #f1f5f9);font-size:.95rem;line-height:1.7;margin:0;white-space:pre-wrap}.control-detail-responsible{display:flex;align-items:baseline;gap:.5rem;margin-bottom:1.25rem;padding:.75rem 1rem;background:var(--bg-color, #0f172a);border-radius:8px;font-size:.875rem}.control-detail-responsible strong{color:var(--text-secondary, #94a3b8);flex-shrink:0}.control-detail-responsible span{color:var(--text-primary, #f1f5f9)}.control-detail-images{margin-top:1.25rem}.images-loading{display:flex;align-items:center;gap:.5rem;padding:1rem;color:var(--text-secondary, #94a3b8);font-size:.875rem}.images-loading .spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.images-header{display:flex;align-items:center;gap:.5rem;color:var(--text-secondary, #94a3b8);font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.images-grid{display:flex;flex-direction:column;gap:1rem}.control-image-item{position:relative;border:1px solid var(--border-color, #334155);border-radius:8px;overflow:hidden;background:var(--bg-color, #0f172a)}.control-image{width:100%;height:auto;display:block;max-height:400px;object-fit:contain}.image-lang-badge{position:absolute;top:8px;right:8px;background:#000000b3;color:#fff;padding:.15rem .5rem;border-radius:4px;font-size:.7rem;font-weight:700;letter-spacing:.05em}.no-images{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;color:var(--text-secondary, #94a3b8);font-size:.85rem;background:var(--bg-color, #0f172a);border-radius:8px}.control-detail-evidence{display:flex;align-items:center;gap:.5rem;margin-top:1.25rem;padding:.75rem 1rem;background:#10b98114;border-radius:8px;color:var(--success-color, #10b981);font-size:.875rem}.control-detail-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #334155)}.control-detail-footer .upload-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.control-detail-footer .upload-btn:hover{background:var(--primary-hover, #2563eb)}.control-detail-footer .acknowledge-btn{display:flex;align-items:center;gap:.5rem;padding:.6rem 1.25rem;background:#10b98126;color:var(--success-color, #10b981);border:1px solid var(--success-color, #10b981);border-radius:8px;font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s ease}.control-detail-footer .acknowledge-btn:hover{background:#10b98140}.control-code-name.clickable{cursor:pointer;transition:opacity .2s ease}.control-code-name.clickable:hover{opacity:.8}.control-code-name.clickable:hover .control-name{color:var(--primary-color, #3b82f6);text-decoration:underline;text-underline-offset:3px}@media(max-width:768px){.control-detail-overlay{padding:1rem}.control-detail-modal{max-height:90vh}.control-detail-footer{flex-direction:column}.control-detail-footer .upload-btn,.control-detail-footer .acknowledge-btn{justify-content:center}}.asset-picker{position:relative;width:100%}.asset-picker-selected{display:flex;flex-wrap:wrap;gap:4px;align-items:center;min-height:38px;padding:4px 30px 4px 8px;background:#0f172a;border:1px solid #334155;border-radius:6px;cursor:pointer;position:relative;transition:border-color .2s}.asset-picker-selected:hover{border-color:#6366f1}.asset-picker-placeholder{color:#64748b;font-size:.875rem;padding:2px 0}.asset-picker-chevron{position:absolute;right:8px;top:50%;transform:translateY(-50%);color:#64748b;pointer-events:none}.asset-picker-tag{display:inline-flex;align-items:center;gap:4px;padding:2px 6px 2px 8px;background:#1e293b;border:1px solid #334155;border-radius:4px;font-size:.8rem;color:#e2e8f0;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-picker-tag-company{color:#64748b;font-size:.75rem}.asset-picker-tag-remove{display:inline-flex;align-items:center;justify-content:center;background:none;border:none;color:#94a3b8;cursor:pointer;padding:1px;border-radius:3px;flex-shrink:0}.asset-picker-tag-remove:hover{background:#334155;color:#ef4444}.asset-picker-dropdown{position:absolute;top:calc(100% + 4px);left:0;right:0;background:#1e293b;border:1px solid #334155;border-radius:8px;box-shadow:0 8px 24px #0006;z-index:1000;overflow:hidden}.asset-picker-search{display:flex;align-items:center;gap:8px;padding:8px 12px;border-bottom:1px solid #334155;color:#94a3b8}.asset-picker-search input{flex:1;background:none;border:none;outline:none;color:#f1f5f9;font-size:.875rem}.asset-picker-search input::placeholder{color:#64748b}.asset-picker-list{max-height:220px;overflow-y:auto}.asset-picker-list::-webkit-scrollbar{width:6px}.asset-picker-list::-webkit-scrollbar-track{background:transparent}.asset-picker-list::-webkit-scrollbar-thumb{background:#334155;border-radius:3px}.asset-picker-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;font-size:.875rem;color:#e2e8f0;transition:background .15s}.asset-picker-option:hover{background:#334155}.asset-picker-option.selected{background:#6366f11a}.asset-picker-option-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asset-picker-option-company{color:#64748b;font-size:.75rem;margin-left:8px;flex-shrink:0}.asset-picker-empty{padding:16px 12px;text-align:center;color:#64748b;font-size:.85rem}.asset-picker-option.itself-option{border-bottom:1px solid #334155;color:#818cf8;font-weight:500}.asset-picker-option.itself-option .asset-picker-option-name{font-style:italic}.asset-picker-tag.itself-tag{background:#6366f126;border-color:#6366f14d;color:#818cf8}.asset-picker-option.na-option{border-bottom:1px solid #334155;color:#94a3b8}.asset-picker-tag.na-tag{background:#94a3b826;border-color:#94a3b84d;color:#94a3b8}.aa-modal form .aa-modal-body{max-height:60vh;overflow-y:auto}.aa-modal form .aa-form-grid+.aa-form-grid{margin-top:1rem}.ai-modal-overlay{position:fixed;inset:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.ai-modal{background:var(--bg-primary, #fff);border-radius:12px;width:100%;max-width:860px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #0000004d}.ai-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #e2e8f0)}.ai-modal-header h2{display:flex;align-items:center;gap:.5rem;font-size:1.15rem;margin:0}.ai-modal-close{background:none;border:none;cursor:pointer;color:var(--text-secondary, #64748b);padding:4px;border-radius:6px}.ai-modal-close:hover{background:var(--bg-secondary, #f1f5f9)}.ai-modal-body{padding:1.5rem;overflow-y:auto;flex:1}.ai-modal-footer{display:flex;align-items:center;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #e2e8f0)}.ai-stepper{display:flex;align-items:center;justify-content:center;gap:0;padding:1rem 1.5rem;background:var(--bg-secondary, #f8fafc);border-bottom:1px solid var(--border-color, #e2e8f0)}.ai-stepper-item{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;position:relative;color:var(--text-secondary, #94a3b8);font-size:.85rem}.ai-stepper-item+.ai-stepper-item:before{content:"";width:40px;height:2px;background:var(--border-color, #e2e8f0);position:absolute;left:-20px;top:50%}.ai-stepper-item.done+.ai-stepper-item:before,.ai-stepper-item.active+.ai-stepper-item:before{background:var(--primary, #3b82f6)}.ai-stepper-num{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.8rem;font-weight:600;background:var(--bg-primary, #fff);border:2px solid var(--border-color, #e2e8f0);color:var(--text-secondary, #94a3b8)}.ai-stepper-item.active .ai-stepper-num{background:var(--primary, #3b82f6);border-color:var(--primary, #3b82f6);color:#fff}.ai-stepper-item.done .ai-stepper-num{background:#10b981;border-color:#10b981;color:#fff}.ai-stepper-item.active .ai-stepper-label{color:var(--text-primary, #1e293b);font-weight:600}.ai-stepper-item.done .ai-stepper-label{color:#10b981}.ai-step{min-height:200px}.ai-step-desc{color:var(--text-secondary, #64748b);margin-bottom:1rem}.ai-dropzone{border:2px dashed var(--border-color, #cbd5e1);border-radius:12px;padding:2.5rem;text-align:center;cursor:pointer;transition:all .2s}.ai-dropzone:hover{border-color:var(--primary, #3b82f6);background:#3b82f60a}.ai-dropzone.has-file{border-color:#10b981;background:#10b9810a}.ai-dropzone-text{color:var(--text-secondary, #94a3b8)}.ai-dropzone-text p{margin:.5rem 0 .25rem;font-weight:500}.ai-dropzone-text span{font-size:.8rem}.ai-file-info{display:flex;align-items:center;gap:1rem;justify-content:center;color:#10b981}.ai-file-info .file-name{font-weight:600;font-size:1rem;color:var(--text-primary, #1e293b)}.ai-file-info .file-size{font-size:.85rem;color:var(--text-secondary, #64748b)}.ai-sheet-select{margin-bottom:1rem;display:flex;align-items:center;gap:.75rem}.ai-sheet-select label{font-weight:500}.ai-sheet-select select{padding:.4rem .75rem;border-radius:6px;border:1px solid var(--border-color, #cbd5e1)}.ai-mapping-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.ai-mapping-header h3{margin:0;font-size:1rem}.ai-mapping-info{display:flex;gap:1.5rem;margin-bottom:.75rem;font-size:.85rem;color:var(--text-secondary, #64748b)}.ai-mapping-table-wrap{overflow-x:auto;max-height:400px;overflow-y:auto}.ai-mapping-table{width:100%;border-collapse:collapse;font-size:.9rem}.ai-mapping-table th{text-align:left;padding:.5rem .75rem;background:var(--bg-secondary, #f8fafc);position:sticky;top:0;border-bottom:2px solid var(--border-color, #e2e8f0);font-weight:600;font-size:.8rem;text-transform:uppercase;color:var(--text-secondary, #64748b)}.ai-mapping-table td{padding:.5rem .75rem;border-bottom:1px solid var(--border-color, #f1f5f9)}.ai-excel-col{font-weight:600;white-space:nowrap}.ai-arrow{color:var(--text-secondary, #94a3b8);width:40px;text-align:center}.ai-mapping-table select{width:100%;padding:.35rem .5rem;border-radius:6px;border:1px solid var(--border-color, #cbd5e1);font-size:.85rem}.ai-mapping-table select.mapped{border-color:#10b981;background:#10b9810f}.ai-sample{font-size:.8rem;color:var(--text-secondary, #94a3b8);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ai-importing{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;gap:1rem;color:var(--text-secondary, #64748b)}.ai-spinner{animation:spin 1s linear infinite;color:var(--primary, #3b82f6)}.ai-result-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.ai-result-card{text-align:center;padding:1.25rem;border-radius:10px;background:var(--bg-secondary, #f8fafc);border:1px solid var(--border-color, #e2e8f0)}.ai-result-card.success{background:#10b98114;border-color:#10b9814d;color:#10b981}.ai-result-card.warning{background:#f59e0b14;border-color:#f59e0b4d;color:#f59e0b}.ai-result-card.info{background:#3b82f614;border-color:#3b82f64d;color:#3b82f6}.ai-result-number{font-size:2rem;font-weight:700;margin:.25rem 0}.ai-result-label{font-size:.85rem;opacity:.8}.ai-rejected-download{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);border-radius:10px;padding:1rem 1.25rem;display:flex;align-items:center;justify-content:space-between;gap:1rem;margin-bottom:1.5rem}.ai-rejected-download p{margin:0;font-size:.9rem;color:var(--text-primary, #1e293b)}.ai-rejected-download .btn-warning{background:#f59e0b;color:#fff;border:none;padding:.5rem 1rem;border-radius:8px;cursor:pointer;display:flex;align-items:center;gap:.5rem;font-weight:500;white-space:nowrap;text-decoration:none}.ai-rejected-list h4{margin:0 0 .75rem}.ai-rejected-table-wrap{overflow-x:auto;max-height:300px;overflow-y:auto}.ai-rejected-table{width:100%;border-collapse:collapse;font-size:.85rem}.ai-rejected-table th{text-align:left;padding:.5rem;background:var(--bg-secondary, #f8fafc);border-bottom:2px solid var(--border-color, #e2e8f0);font-size:.8rem;text-transform:uppercase;color:var(--text-secondary, #64748b);position:sticky;top:0}.ai-rejected-table td{padding:.5rem;border-bottom:1px solid var(--border-color, #f1f5f9);vertical-align:top}.ai-error-item{color:#ef4444;font-size:.8rem;margin-bottom:2px}.ai-preview-cells{display:flex;flex-wrap:wrap;gap:.25rem}.ai-cell-preview{background:var(--bg-secondary, #f1f5f9);padding:2px 6px;border-radius:4px;font-size:.75rem;color:var(--text-secondary, #64748b)}.ai-more{color:var(--text-secondary, #94a3b8);font-size:.85rem;margin-top:.5rem}.ai-error{background:#ef444414;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.ai-warning{background:#f59e0b14;border:1px solid rgba(245,158,11,.3);color:#92400e;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem;display:flex;align-items:center;gap:.5rem}.btn-sm{padding:.3rem .75rem;font-size:.85rem}.admin-assets{min-height:100vh;background:var(--bg-primary, #0f172a)}.admin-assets .aa-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.admin-assets .aa-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.admin-assets .aa-header h1{font-size:1.5rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.admin-assets .aa-toolbar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap}.admin-assets .aa-search{display:flex;align-items:center;gap:.5rem;background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem}.admin-assets .aa-search input{background:none;border:none;color:var(--text-primary, #f1f5f9);outline:none;font-size:.875rem;width:200px}.admin-assets .aa-filters{display:flex;gap:.5rem}.admin-assets .aa-filters select{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.admin-assets .aa-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.admin-assets .aa-stat-card{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;padding:1rem 1.25rem}.admin-assets .aa-stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary, #f1f5f9)}.admin-assets .aa-stat-card .stat-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-top:.25rem}.admin-assets .aa-stat-card.success .stat-value{color:#10b981}.admin-assets .aa-stat-card.warning .stat-value{color:#f59e0b}.admin-assets .aa-stat-card.danger .stat-value{color:#ef4444}.admin-assets .aa-stat-card.info .stat-value{color:#6366f1}.admin-assets .aa-stat-card.clickable{cursor:pointer;transition:all .2s ease}.admin-assets .aa-stat-card.clickable:hover{transform:translateY(-2px);border-color:#6366f1;box-shadow:0 4px 12px #6366f126}.admin-assets .aa-stat-card.selected{border-color:#6366f1!important;box-shadow:0 0 0 2px #6366f14d;background:#6366f114}.admin-assets .aa-table-wrap{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;overflow-x:auto}.admin-assets .aa-table{width:100%;border-collapse:collapse;font-size:.875rem}.admin-assets .aa-table th{text-align:left;padding:.75rem 1rem;color:var(--text-secondary, #94a3b8);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color, #334155);white-space:nowrap}.admin-assets .aa-table td{padding:.75rem 1rem;color:var(--text-primary, #f1f5f9);border-bottom:1px solid var(--border-color, #1e293b);vertical-align:middle}.admin-assets .aa-table tr:hover td{background:#6366f10d}.admin-assets .aa-table .user-cell{display:flex;align-items:center;gap:.5rem}.admin-assets .aa-table .user-cell .avatar{width:24px;height:24px;border-radius:50%;background:#6366f1;color:#fff;display:flex;align-items:center;justify-content:center;font-size:.7rem;font-weight:600;flex-shrink:0}.admin-assets .status-badge{display:inline-block;padding:.2rem .6rem;border-radius:12px;font-size:.75rem;font-weight:600}.admin-assets .status-badge.active{background:#10b98126;color:#10b981}.admin-assets .status-badge.archived{background:#94a3b826;color:#94a3b8}.admin-assets .aa-actions{display:flex;gap:.4rem}.admin-assets .aa-actions button{background:none;border:none;cursor:pointer;padding:.3rem;border-radius:6px;color:var(--text-secondary, #94a3b8);transition:all .15s}.admin-assets .aa-actions button:hover{background:#6366f126;color:#6366f1}.admin-assets .aa-actions button.danger:hover{background:#ef444426;color:#ef4444}.aa-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.aa-modal{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;width:100%;max-width:720px;max-height:85vh;overflow-y:auto}.aa-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #334155)}.aa-modal-header h2{font-size:1.1rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.aa-modal-body{padding:1.5rem}.aa-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #334155)}.aa-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.aa-form-grid .full-width{grid-column:1 / -1}.aa-form-group{display:flex;flex-direction:column;gap:.35rem}.aa-form-group label{font-size:.8rem;color:var(--text-secondary, #94a3b8);font-weight:500}.aa-form-group input,.aa-form-group select,.aa-form-group textarea{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.6rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.aa-form-group textarea{min-height:80px;resize:vertical}.aa-form-group input:focus,.aa-form-group select:focus,.aa-form-group textarea:focus{outline:none;border-color:#6366f1}.aa-pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem}.aa-pagination button{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;padding:.4rem .75rem;color:var(--text-primary, #f1f5f9);cursor:pointer;font-size:.8rem}.aa-pagination button:disabled{opacity:.4;cursor:not-allowed}.aa-pagination button.active{background:#6366f1;border-color:#6366f1}.aa-pagination span{color:var(--text-secondary, #94a3b8);font-size:.8rem}.aa-history-list{display:flex;flex-direction:column;gap:.75rem}.aa-history-item{display:flex;gap:1rem;padding:.75rem;background:var(--bg-primary, #0f172a);border-radius:8px;font-size:.85rem}.aa-history-item .history-time{color:var(--text-secondary, #94a3b8);white-space:nowrap;min-width:140px}.aa-history-item .history-user{color:#6366f1;font-weight:600;min-width:100px}.aa-history-item .history-detail{color:var(--text-primary, #f1f5f9);flex:1}.aa-history-item .history-detail .field-name{color:#f59e0b;font-weight:500}.aa-history-item .history-detail .old-val{color:#ef4444;text-decoration:line-through}.aa-history-item .history-detail .new-val{color:#10b981}.aa-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color, #334155);margin-bottom:1.5rem}.aa-tabs button{background:none;border:none;padding:.75rem 1.25rem;color:var(--text-secondary, #94a3b8);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s}.aa-tabs button.active{color:#6366f1;border-bottom-color:#6366f1}.aa-tabs button:hover{color:var(--text-primary, #f1f5f9)}.aa-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #94a3b8)}.aa-empty svg{margin-bottom:1rem;opacity:.5}.aa-col-list{display:flex;flex-direction:column;gap:.5rem}.aa-col-item{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:var(--bg-primary, #0f172a);border-radius:8px;border:1px solid var(--border-color, #334155)}.aa-col-item .col-info{display:flex;align-items:center;gap:.75rem}.aa-col-item .col-name{color:var(--text-primary, #f1f5f9);font-weight:500}.aa-col-item .col-type{font-size:.75rem;color:var(--text-secondary, #94a3b8);background:#6366f11a;padding:.15rem .5rem;border-radius:4px}.aa-col-item .col-required{font-size:.7rem;color:#f59e0b}.admin-assets .aa-active-filters{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap;margin-bottom:1rem;padding:.75rem 1rem;background:#6366f114;border:1px solid rgba(99,102,241,.2);border-radius:8px}.admin-assets .aa-filter-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);font-weight:500}.admin-assets .aa-filter-tag{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .6rem;background:#6366f126;color:#818cf8;border-radius:6px;font-size:.8rem;font-weight:500}.admin-assets .aa-filter-tag button{background:none;border:none;color:#818cf8;cursor:pointer;padding:0;display:flex;align-items:center;opacity:.7;transition:opacity .15s}.admin-assets .aa-filter-tag button:hover{opacity:1}.admin-assets .aa-clear-all{background:none;border:1px solid rgba(239,68,68,.3);color:#f87171;padding:.2rem .6rem;border-radius:6px;font-size:.75rem;cursor:pointer;margin-left:.25rem;transition:all .15s}.admin-assets .aa-clear-all:hover{background:#ef444426;border-color:#ef4444}@media(max-width:768px){.aa-form-grid{grid-template-columns:1fr}.admin-assets .aa-stats{grid-template-columns:repeat(2,1fr)}.admin-assets .aa-header{flex-direction:column;align-items:flex-start}}.admin-asset-dashboard{min-height:100vh;background:var(--bg-primary, #0f172a)}.aad-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.aad-header{margin-bottom:2rem}.aad-header h1{font-size:1.5rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.aad-loading{text-align:center;padding:4rem;color:var(--text-secondary, #94a3b8);font-size:1rem}.aad-overview{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:2rem}.aad-card{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;padding:1.25rem}.overview-card{display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s}.overview-card:hover{border-color:#6366f1;transform:translateY(-2px);box-shadow:0 4px 12px #6366f126}.overview-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.overview-icon.total{background:#6366f126;color:#6366f1}.overview-icon.active{background:#10b98126;color:#10b981}.overview-icon.archived{background:#f59e0b26;color:#f59e0b}.overview-icon.missing{background:#ef444426;color:#ef4444}.overview-value{font-size:1.75rem;font-weight:700;color:var(--text-primary, #f1f5f9);line-height:1.2}.overview-value.success{color:#10b981}.overview-value.warning{color:#f59e0b}.overview-value.danger{color:#ef4444}.overview-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-top:2px}.aad-missing-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem}.missing-card{cursor:pointer;transition:all .2s}.missing-card:hover{border-color:#ef4444;transform:translateY(-2px)}.missing-label{font-size:.85rem;color:var(--text-secondary, #94a3b8);margin-bottom:.5rem}.missing-value{font-size:1.5rem;font-weight:700;color:#ef4444;margin-bottom:.75rem}.missing-bar{height:6px;background:var(--bg-primary, #0f172a);border-radius:3px;overflow:hidden}.missing-bar-fill{height:100%;background:linear-gradient(90deg,#ef4444,#f87171);border-radius:3px;transition:width .5s ease;min-width:2px}.aad-grid{display:grid;grid-template-columns:1fr 1fr;gap:1.5rem}.aad-section{margin-bottom:.5rem}.aad-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.aad-section-header h2{font-size:1rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem;font-weight:600}.aad-count{font-size:.75rem;color:var(--text-secondary, #94a3b8);background:var(--bg-primary, #0f172a);padding:.2rem .6rem;border-radius:10px}.aad-bar-list{display:flex;flex-direction:column;gap:.75rem}.aad-bar-item{padding:.5rem 0}.aad-bar-item.clickable{cursor:pointer;padding:.6rem .75rem;margin:-.1rem -.75rem;border-radius:8px;transition:background .15s}.aad-bar-item.clickable:hover{background:#6366f114}.bar-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.4rem}.bar-name{font-size:.85rem;color:var(--text-primary, #f1f5f9);font-weight:500}.bar-count{font-size:.85rem;color:var(--text-secondary, #94a3b8);font-weight:600}.bar-track{height:6px;background:var(--bg-primary, #0f172a);border-radius:3px;overflow:hidden}.bar-fill{height:100%;border-radius:3px;transition:width .5s ease;min-width:2px}.bar-fill.company{background:linear-gradient(90deg,#6366f1,#818cf8)}.bar-fill.type{background:linear-gradient(90deg,#10b981,#34d399)}.bar-fill.manufacturer{background:linear-gradient(90deg,#f59e0b,#fbbf24)}.bar-fill.infra{background:linear-gradient(90deg,#3b82f6,#60a5fa)}.aad-empty{text-align:center;padding:2rem;color:var(--text-secondary, #94a3b8);font-size:.875rem}@media(max-width:1024px){.aad-grid{grid-template-columns:1fr}.aad-overview{grid-template-columns:repeat(2,1fr)}.aad-missing-grid{grid-template-columns:1fr}}@media(max-width:640px){.aad-overview{grid-template-columns:1fr}}.admin-sbom{min-height:100vh;background:var(--bg-primary, #0f172a)}.sbom-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.sbom-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.sbom-header h1{font-size:1.5rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.sbom-toolbar{display:flex;gap:.75rem;align-items:center}.sbom-empty{text-align:center;padding:3rem 1rem;color:var(--text-secondary, #94a3b8)}.sbom-empty svg{margin-bottom:1rem;opacity:.5}.text-muted{color:#64748b}.sbom-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.sbom-stat-card{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;padding:1rem 1.25rem}.sbom-stat-card .stat-value{font-size:1.75rem;font-weight:700;color:var(--text-primary, #f1f5f9)}.sbom-stat-card .stat-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-top:.25rem}.sbom-stat-card.clickable{cursor:pointer;transition:all .2s}.sbom-stat-card.clickable:hover{border-color:#6366f1;background:#6366f114;transform:translateY(-2px)}.sbom-stat-card.clickable.selected{border-color:#6366f1;box-shadow:0 0 0 1px #6366f1;background:#6366f114}.sbom-stat-card.info .stat-value{color:#6366f1}.sbom-stat-card.success .stat-value{color:#10b981}.sbom-tabs{display:flex;gap:0;border-bottom:2px solid var(--border-color, #334155);margin-bottom:1.5rem}.sbom-tabs button{background:none;border:none;padding:.75rem 1.25rem;color:var(--text-secondary, #94a3b8);font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .15s;display:flex;align-items:center;gap:.4rem}.sbom-tabs button.active{color:#6366f1;border-bottom-color:#6366f1}.sbom-tabs button:hover{color:var(--text-primary, #f1f5f9)}.sbom-filter-bar{display:flex;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.sbom-filter-bar select{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.sbom-table-wrap{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;overflow-x:auto}.sbom-table{width:100%;border-collapse:collapse;font-size:.875rem}.sbom-table th{text-align:left;padding:.75rem 1rem;color:var(--text-secondary, #94a3b8);font-weight:600;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--border-color, #334155);white-space:nowrap}.sbom-table td{padding:.75rem 1rem;color:var(--text-primary, #f1f5f9);border-bottom:1px solid var(--border-color, #1e293b);vertical-align:middle}.sbom-table tr:hover td{background:#6366f10d}.sbom-pagination{display:flex;justify-content:center;align-items:center;gap:.5rem;margin-top:1rem;padding:1rem}.sbom-pagination button{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:6px;padding:.4rem .75rem;color:var(--text-primary, #f1f5f9);cursor:pointer;font-size:.8rem}.sbom-pagination button:disabled{opacity:.4;cursor:not-allowed}.sbom-pagination span{color:var(--text-secondary, #94a3b8);font-size:.8rem}.sbom-actions{display:flex;gap:.4rem}.sbom-actions button{background:none;border:none;cursor:pointer;padding:.3rem;border-radius:6px;color:var(--text-secondary, #94a3b8);transition:all .15s}.sbom-actions button:hover{background:#6366f126;color:#6366f1}.sbom-actions button.danger:hover{background:#ef444426;color:#ef4444}.sbom-format-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;background:#6366f126;color:#818cf8;text-transform:uppercase}.sbom-type-badge{display:inline-block;padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500;background:#10b98126;color:#34d399}.sbom-pkg-count{font-weight:700;color:#6366f1}.sbom-version{font-size:.8rem;color:#f59e0b;background:#f59e0b1a;padding:.1rem .4rem;border-radius:4px}.sbom-modal-overlay{position:fixed;inset:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.sbom-modal{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:12px;width:100%;max-width:720px;max-height:85vh;overflow-y:auto}.sbom-modal-lg{max-width:1000px;max-height:90vh}.sbom-modal-header{display:flex;justify-content:space-between;align-items:center;padding:1.25rem 1.5rem;border-bottom:1px solid var(--border-color, #334155)}.sbom-modal-header h2{font-size:1.1rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.sbom-modal-close{background:none;border:none;color:var(--text-secondary, #94a3b8);cursor:pointer;padding:.25rem;border-radius:6px}.sbom-modal-close:hover{color:var(--text-primary, #f1f5f9);background:#ffffff0d}.sbom-modal-body{padding:1.5rem}.sbom-modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.5rem;border-top:1px solid var(--border-color, #334155)}.sbom-form-group{display:flex;flex-direction:column;gap:.35rem;margin-bottom:1rem}.sbom-form-group label{font-size:.8rem;color:var(--text-secondary, #94a3b8);font-weight:500}.sbom-form-group select,.sbom-form-group textarea{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.6rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.sbom-form-group textarea{min-height:70px;resize:vertical}.sbom-form-group select:focus,.sbom-form-group textarea:focus{outline:none;border-color:#6366f1}.sbom-assign-toggle{display:flex;gap:0;border:1px solid var(--border-color, #334155);border-radius:8px;overflow:hidden}.sbom-toggle-btn{flex:1;padding:.5rem .75rem;background:var(--bg-primary, #0f172a);border:none;color:var(--text-secondary, #94a3b8);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s}.sbom-toggle-btn:not(:last-child){border-right:1px solid var(--border-color, #334155)}.sbom-toggle-btn.active{background:#6366f126;color:#818cf8;font-weight:600}.sbom-toggle-btn:hover:not(.active){background:#ffffff08}.sbom-form-group input[type=text]{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.6rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.sbom-form-group input[type=text]:focus{outline:none;border-color:#6366f1}.sbom-formats-hint{font-size:.7rem;opacity:.6;line-height:1.4;display:block;max-width:400px;margin:0 auto}.sbom-dropzone{border:2px dashed var(--border-color, #334155);border-radius:10px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s}.sbom-dropzone:hover{border-color:#6366f1;background:#6366f10d}.sbom-dropzone.has-file{border-color:#10b981;background:#10b9810d}.sbom-dropzone-text{color:var(--text-secondary, #94a3b8)}.sbom-dropzone-text p{margin:.5rem 0 .25rem;font-weight:500}.sbom-dropzone-text span{font-size:.75rem;opacity:.7}.sbom-file-info{display:flex;align-items:center;gap:.75rem;justify-content:center;color:#10b981}.sbom-file-info .file-name{font-weight:600;color:var(--text-primary, #f1f5f9)}.sbom-file-info .file-size{font-size:.75rem;color:var(--text-secondary, #94a3b8)}.sbom-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#f87171;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.85rem}.sbom-upload-success{text-align:center;padding:1rem 0}.sbom-upload-success svg{color:#10b981;margin-bottom:.75rem}.sbom-upload-success h3{color:var(--text-primary, #f1f5f9);margin-bottom:1rem}.sbom-result-grid{display:grid;grid-template-columns:1fr 1fr;gap:.5rem;text-align:left;background:var(--bg-primary, #0f172a);padding:1rem;border-radius:8px}.sbom-result-grid .label{color:var(--text-secondary, #94a3b8);font-size:.8rem}.sbom-result-grid .value{color:var(--text-primary, #f1f5f9);font-weight:600;font-size:.85rem}.sbom-detail-info{background:var(--bg-primary, #0f172a);border-radius:8px;padding:1rem;margin-bottom:1rem}.sbom-detail-row{display:flex;gap:1.5rem;flex-wrap:wrap;margin-bottom:.5rem}.sbom-detail-row:last-child{margin-bottom:0}.sbom-detail-item{display:flex;align-items:center;gap:.35rem;font-size:.85rem}.sbom-detail-item .detail-label{color:var(--text-secondary, #94a3b8)}.sbom-detail-item .detail-value{color:var(--text-primary, #f1f5f9);font-weight:500}.sbom-detail-notes{font-size:.85rem;color:var(--text-secondary, #94a3b8);margin-top:.5rem;padding-top:.5rem;border-top:1px solid var(--border-color, #334155)}.sbom-detail-notes .detail-label{font-weight:500}.sbom-pkg-toolbar{display:flex;gap:.75rem;align-items:center;margin-bottom:1rem;flex-wrap:wrap}.sbom-pkg-search{display:flex;align-items:center;gap:.5rem;background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;flex:1;min-width:200px}.sbom-pkg-search input{background:none;border:none;color:var(--text-primary, #f1f5f9);outline:none;font-size:.875rem;width:100%}.sbom-pkg-toolbar select{background:var(--bg-primary, #0f172a);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.sbom-pkg-total{font-size:.8rem;color:var(--text-secondary, #94a3b8);white-space:nowrap}.sbom-pkg-table-wrap{max-height:400px;overflow-y:auto;border-radius:8px;border:1px solid var(--border-color, #334155)}.sbom-search-section{margin-top:.5rem}.sbom-search-bar{display:flex;gap:.75rem;align-items:center;flex-wrap:wrap;margin-bottom:1.5rem}.sbom-search-bar .sbom-pkg-search{min-width:300px}.sbom-search-bar select{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:8px;padding:.5rem .75rem;color:var(--text-primary, #f1f5f9);font-size:.875rem}.sbom-search-count{font-size:.85rem;color:var(--text-secondary, #94a3b8);margin-bottom:1rem}.sbom-search-results{margin-top:.5rem}@media(max-width:768px){.sbom-search-bar{flex-direction:column}.sbom-search-bar .sbom-pkg-search{min-width:100%}.sbom-detail-row{flex-direction:column;gap:.5rem}.sbom-result-grid{grid-template-columns:1fr}}.admin-training{min-height:100vh;background:#0a0a0f;color:#e2e8f0}.training-content{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.training-header{margin-bottom:2rem}.training-header h1{display:flex;align-items:center;gap:.5rem;font-size:1.75rem;font-weight:700;color:#f1f5f9;margin-bottom:.25rem}.training-header .subtitle{color:#94a3b8;font-size:.95rem}.training-summary-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:1rem;margin-bottom:1.5rem}.training-summary-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:1.25rem;display:flex;align-items:center;gap:1rem;cursor:pointer;transition:all .2s ease}.training-summary-card:hover{border-color:#374151;transform:translateY(-2px)}.training-summary-card[style*=default]:hover{transform:none;border-color:#1e293b}.training-summary-card.active{border-color:#6366f1;box-shadow:0 0 0 1px #6366f14d}.summary-icon{width:48px;height:48px;border-radius:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.summary-info{flex:1}.summary-value{font-size:1.75rem;font-weight:700;color:#f1f5f9;line-height:1.2}.summary-label{font-size:.8rem;color:#94a3b8;margin-top:.125rem}.training-toolbar{display:flex;align-items:center;gap:1rem;margin-bottom:1.5rem;flex-wrap:wrap}.training-search{display:flex;align-items:center;gap:.5rem;background:#111827;border:1px solid #1e293b;border-radius:8px;padding:.625rem 1rem;flex:1;min-width:250px}.training-search input{background:none;border:none;outline:none;color:#e2e8f0;font-size:.9rem;width:100%}.training-search input::placeholder{color:#64748b}.training-search svg{color:#64748b;flex-shrink:0}.training-results-info{font-size:.82rem;color:#64748b;white-space:nowrap}.training-filter-pills{display:flex;gap:.5rem;flex-wrap:wrap}.filter-pill{display:flex;align-items:center;gap:.375rem;padding:.5rem .875rem;border-radius:20px;border:1px solid #1e293b;background:#111827;color:#94a3b8;font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-pill:hover{border-color:#374151;color:#e2e8f0}.filter-pill.active{background:#6366f1;border-color:#6366f1;color:#fff}.filter-pill.passed.active{background:#10b981;border-color:#10b981}.filter-pill.not-passed.active{background:#ef4444;border-color:#ef4444}.training-table-wrapper{background:#111827;border:1px solid #1e293b;border-radius:12px;overflow:hidden}.training-table{width:100%;border-collapse:collapse}.training-table thead{background:#0f172a}.training-table th{padding:.875rem 1rem;text-align:left;font-size:.8rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #1e293b;-webkit-user-select:none;user-select:none}.training-table th.sortable{cursor:pointer;transition:color .2s}.training-table th.sortable:hover{color:#e2e8f0}.training-table th.center,.training-table td.center{text-align:center}.training-table th svg{display:inline-block;vertical-align:middle;margin-left:.25rem}.training-table tbody tr{border-bottom:1px solid #1e293b;transition:background .15s ease}.training-table tbody tr:last-child{border-bottom:none}.training-table tbody tr:hover{background:#6366f10d}.training-table td{padding:.875rem 1rem;font-size:.875rem;color:#cbd5e1}.user-name-cell{display:flex;align-items:center;gap:.75rem;white-space:nowrap}.user-avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,#6366f1,#8b5cf6);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.875rem;color:#fff;flex-shrink:0}.user-name{font-weight:600;color:#f1f5f9}.user-email{display:flex;align-items:center;gap:.375rem;color:#94a3b8;font-size:.825rem;white-space:nowrap}.user-email svg{flex-shrink:0;opacity:.6}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.3rem .75rem;border-radius:20px;font-size:.775rem;font-weight:600;white-space:nowrap}.status-badge.passed{background:#10b98126;color:#10b981}.status-badge.not-passed{background:#ef444426;color:#ef4444}.progress-cell{display:flex;align-items:center;gap:.5rem;justify-content:center}.progress-bar-mini{width:80px;height:6px;background:#1e293b;border-radius:3px;overflow:hidden}.progress-fill-mini{height:100%;border-radius:3px;transition:width .3s ease}.progress-text{font-size:.8rem;font-weight:600;color:#cbd5e1;min-width:36px;text-align:right}.count-badge{display:inline-flex;align-items:center;justify-content:center;min-width:28px;padding:.2rem .5rem;border-radius:6px;font-size:.825rem;font-weight:600;background:#6366f126;color:#818cf8}.count-badge.total{background:#94a3b826;color:#94a3b8}.last-activity{white-space:nowrap}.activity-time{display:flex;align-items:center;gap:.375rem;font-size:.8rem;color:#94a3b8}.activity-time svg{flex-shrink:0;opacity:.6}.no-activity{color:#4b5563;font-size:.8rem;font-style:italic}.training-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#94a3b8}.training-loading .spinner{width:40px;height:40px;border:3px solid #1e293b;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.training-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#64748b}.training-empty h3{margin:1rem 0 .5rem;color:#94a3b8;font-size:1.1rem}.training-empty p{font-size:.875rem;text-align:center;max-width:400px}.training-footer{text-align:center;padding:1rem;font-size:.825rem;color:#64748b}@media(max-width:1024px){.training-summary-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.training-summary-grid{grid-template-columns:1fr}.training-toolbar{flex-direction:column;align-items:stretch}.training-search{min-width:unset}.training-table-wrapper{overflow-x:auto}.training-table{min-width:800px}}.admin-compliance{min-height:100vh;background:#0a0a0f;color:#e2e8f0}.compliance-content{padding:2rem 1.5rem;max-width:1400px;margin:0 auto}.compliance-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.compliance-header h1{display:flex;align-items:center;gap:.5rem;font-size:1.75rem;font-weight:700;color:#f1f5f9;margin:0}.compliance-header .subtitle{color:#94a3b8;margin:.25rem 0 0;font-size:.95rem}.compliance-title{display:flex;align-items:center;gap:.75rem;color:#818cf8}.compliance-title h1{font-size:1.75rem;font-weight:700;color:#f1f5f9;margin:0}.compliance-title p{color:#94a3b8;margin:.25rem 0 0;font-size:.95rem}.compliance-company-select,.compliance-company-selector{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#111827;border-radius:12px;border:1px solid #1e293b;color:#818cf8}.compliance-company-select select,.compliance-company-selector select{flex:1;max-width:400px;padding:.5rem .75rem;border:1px solid #374151;border-radius:8px;font-size:.9rem;color:#e2e8f0;background:#1e293b}.compliance-company-select select:focus,.compliance-company-selector select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.compliance-company-selector label{font-weight:600;color:#e2e8f0;white-space:nowrap;display:flex;align-items:center;gap:.5rem}.compliance-error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.9rem}.compliance-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#64748b;text-align:center}.compliance-placeholder svg{opacity:.4;margin-bottom:1rem}.compliance-placeholder h3{margin:0 0 .5rem;color:#94a3b8;font-size:1.1rem}.compliance-placeholder p{font-size:.875rem;max-width:400px}.compliance-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.compliance-stat-card{background:#111827;border-radius:12px;padding:1rem 1.25rem;border:1px solid #1e293b;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease}.compliance-stat-card:hover{border-color:#374151;transform:translateY(-2px)}.compliance-stat-card.active{border-color:#6366f1;box-shadow:0 0 0 1px #6366f14d}.stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-info .stat-value{font-size:1.25rem;font-weight:700;color:#f1f5f9}.stat-info .stat-label{font-size:.78rem;color:#94a3b8}.compliance-search{display:flex;align-items:center;gap:.5rem;background:#111827;border:1px solid #1e293b;border-radius:8px;padding:.625rem 1rem;flex:1;max-width:350px}.compliance-search input{border:none;outline:none;background:none;font-size:.9rem;width:100%;color:#e2e8f0}.compliance-search input::placeholder{color:#64748b}.compliance-search svg{color:#64748b;flex-shrink:0}.compliance-results-info{font-size:.82rem;color:#64748b;white-space:nowrap}.compliance-filter-pills{display:flex;gap:.5rem;flex-wrap:wrap}.compliance-filter-pill{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:20px;border:1px solid #1e293b;background:#111827;font-size:.8rem;cursor:pointer;color:#94a3b8;transition:all .15s}.compliance-filter-pill:hover{border-color:#6366f1;color:#818cf8}.compliance-filter-pill.active{background:#6366f1;color:#fff;border-color:#6366f1}.compliance-filter-pill.active.fc{background:#10b981;border-color:#10b981}.compliance-filter-pill.active.pc{background:#f59e0b;border-color:#f59e0b}.compliance-filter-pill.active.nc{background:#ef4444;border-color:#ef4444}.compliance-filter-pill.active.na{background:#64748b;border-color:#64748b}.compliance-filter-pill.active.pending{background:#8b5cf6;border-color:#8b5cf6}.compliance-table-wrapper{background:#111827;border-radius:12px;border:1px solid #1e293b;overflow-x:auto}.compliance-table{width:100%;border-collapse:collapse;font-size:.85rem}.compliance-table thead th{background:#0f172a;padding:.875rem 1rem;text-align:left;font-weight:600;color:#94a3b8;border-bottom:1px solid #1e293b;white-space:nowrap;position:sticky;top:0;z-index:1;text-transform:uppercase;letter-spacing:.05em;font-size:.8rem}.compliance-table thead th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.compliance-table thead th.sortable:hover{color:#e2e8f0}.compliance-table tbody tr{border-bottom:1px solid #1e293b;transition:background .15s ease}.compliance-table tbody tr:last-child{border-bottom:none}.compliance-table tbody tr:hover{background:#6366f10d}.compliance-table tbody tr.has-pending{background:#8b5cf614}.compliance-table tbody td{padding:.75rem 1rem;color:#cbd5e1;vertical-align:top}.control-code{font-family:SF Mono,Fira Code,monospace;font-weight:600;color:#818cf8;font-size:.82rem;white-space:nowrap;display:block}.control-text{color:#94a3b8;font-size:.82rem;line-height:1.4;max-width:300px}.compliance-status-select{padding:.35rem .5rem;border-radius:6px;border:1px solid #374151;font-size:.82rem;cursor:pointer;min-width:160px;background:#1e293b;color:#e2e8f0}.compliance-status-select:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.compliance-status-select.status-fully_compliant{border-color:#10b981;background:#10b98126;color:#10b981}.compliance-status-select.status-partially_compliant{border-color:#f59e0b;background:#f59e0b26;color:#f59e0b}.compliance-status-select.status-non_compliant{border-color:#ef4444;background:#ef444426;color:#ef4444}.compliance-status-select.status-n\/a{border-color:#64748b;background:#64748b26;color:#94a3b8}.extra-info-cell{max-width:200px}.extra-info-input{width:100%;padding:.35rem .5rem;border:1px solid #374151;border-radius:6px;font-size:.82rem;color:#e2e8f0;background:#1e293b;resize:none;min-height:32px;font-family:inherit}.extra-info-input:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.updater-cell{font-size:.8rem;color:#94a3b8;white-space:nowrap}.updater-name{font-weight:500;color:#e2e8f0}.updater-date{font-size:.75rem;color:#64748b}.evidence-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.15rem .45rem;border-radius:10px;font-size:.72rem;background:#6366f126;color:#818cf8;font-weight:500;margin-left:.35rem}.pending-indicator{display:flex;align-items:center;gap:.35rem;margin-top:.35rem;padding:.3rem .5rem;background:#8b5cf61a;border:1px solid rgba(139,92,246,.3);border-radius:6px;font-size:.75rem;color:#a78bfa}.pending-actions{display:flex;gap:.35rem;margin-top:.35rem}.btn-approve-sm,.btn-reject-sm{padding:.2rem .5rem;border-radius:5px;border:none;font-size:.75rem;cursor:pointer;display:flex;align-items:center;gap:.25rem;font-weight:500}.btn-approve-sm{background:#10b98126;color:#10b981;border:1px solid rgba(16,185,129,.3)}.btn-approve-sm:hover{background:#10b98140}.btn-reject-sm{background:#ef444426;color:#ef4444;border:1px solid rgba(239,68,68,.3)}.btn-reject-sm:hover{background:#ef444440}.save-row-btn{padding:.25rem .6rem;border-radius:5px;border:1px solid #6366f1;background:#6366f1;color:#fff;font-size:.78rem;cursor:pointer;font-weight:500;white-space:nowrap;display:inline-flex;align-items:center;gap:.25rem}.save-row-btn:hover{background:#4f46e5}.save-row-btn:disabled{opacity:.5;cursor:not-allowed}.control-text.clickable{cursor:pointer;transition:color .15s ease}.control-text.clickable:hover{color:#818cf8;text-decoration:underline;text-underline-offset:2px}.control-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.control-modal{background:#111827;border:1px solid #1e293b;border-radius:16px;width:100%;max-width:640px;max-height:80vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:modalFadeIn .2s ease}@keyframes modalFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.control-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #1e293b}.control-modal-title{display:flex;align-items:center;gap:.75rem}.control-modal-title .control-code{font-size:1rem}.control-modal-close{background:none;border:none;color:#64748b;cursor:pointer;padding:.375rem;border-radius:6px;display:flex;align-items:center;justify-content:center;transition:all .15s}.control-modal-close:hover{background:#1e293b;color:#e2e8f0}.control-modal-body{padding:1.5rem;overflow-y:auto}.control-modal-section{margin-bottom:1.25rem}.control-modal-section h4{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.control-modal-section p{font-size:.9rem;color:#e2e8f0;line-height:1.6;margin:0;white-space:pre-wrap}.control-modal-meta{display:flex;flex-direction:column;gap:.75rem;padding-top:1rem;border-top:1px solid #1e293b}.control-modal-meta-item{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:#cbd5e1}.control-modal-meta-item .meta-label{font-size:.78rem;font-weight:600;color:#64748b;min-width:100px}.status-pill{display:inline-flex;padding:.2rem .6rem;border-radius:12px;font-size:.78rem;font-weight:600}.status-pill.status-fully_compliant{background:#10b98126;color:#10b981}.status-pill.status-partially_compliant{background:#f59e0b26;color:#f59e0b}.status-pill.status-non_compliant{background:#ef444426;color:#ef4444}.status-pill.status-n\/a{background:#64748b26;color:#94a3b8}.control-modal-attachments{margin-top:1.25rem;padding-top:1rem;border-top:1px solid #1e293b}.attachments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.attachments-header h4{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0}.attachment-upload-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:6px;border:1px solid #6366f1;background:#6366f126;color:#818cf8;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.attachment-upload-btn:hover{background:#6366f140}.attachments-loading{display:flex;align-items:center;gap:.5rem;padding:1rem;color:#64748b;font-size:.82rem}.attachments-empty{padding:1rem;color:#64748b;font-size:.82rem;text-align:center;background:#1e293b80;border-radius:8px}.attachments-list{display:flex;flex-direction:column;gap:.5rem}.attachment-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#1e293b;border-radius:8px;border:1px solid #374151;transition:border-color .15s}.attachment-item:hover{border-color:#6366f1}.attachment-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;cursor:pointer;color:#818cf8;transition:color .15s}.attachment-info:hover{color:#a5b4fc}.attachment-info svg{flex-shrink:0}.attachment-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.attachment-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;flex-shrink:0}.attachment-uploader{font-size:.72rem;color:#94a3b8;font-weight:500}.attachment-date{font-size:.68rem;color:#64748b}.attachment-delete-btn{background:none;border:none;color:#64748b;cursor:pointer;padding:.3rem;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s;flex-shrink:0}.attachment-delete-btn:hover{background:#ef444426;color:#ef4444}.attachment-delete-btn:disabled{opacity:.5;cursor:not-allowed}.compliance-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#94a3b8}.compliance-loading .spinner{width:40px;height:40px;border:3px solid #1e293b;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.compliance-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:4rem 2rem;color:#64748b;text-align:center}.compliance-empty h3{margin:1rem 0 .5rem;color:#94a3b8;font-size:1.1rem}.compliance-empty p{font-size:.875rem;text-align:center;max-width:400px}.compliance-footer{padding:.75rem 1rem;font-size:.82rem;color:#64748b;border-top:1px solid #1e293b;text-align:center}.spinner{width:32px;height:32px;border:3px solid #1e293b;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite}.standard-cell,.policy-cell{max-width:160px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.standard-name{font-size:.82rem;color:#a78bfa;font-weight:500}.policy-name{font-size:.82rem;color:#67e8f9;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block;max-width:160px}.control-modal-hierarchy{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1.25rem;padding:.875rem 1rem;background:#1e293b80;border-radius:10px;border:1px solid #1e293b}.control-modal-hierarchy-item{display:flex;align-items:center;gap:.625rem;font-size:.85rem;color:#cbd5e1}.control-modal-hierarchy-item svg{color:#64748b;flex-shrink:0}.hierarchy-label{font-size:.75rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.04em;min-width:70px}.hierarchy-value{color:#e2e8f0;font-weight:500}.compliance-toolbar{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.25rem}.compliance-toolbar-filters{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.compliance-filter-select{display:flex;align-items:center;gap:.5rem;background:#111827;border:1px solid #1e293b;border-radius:8px;padding:.5rem .75rem}.compliance-filter-select svg{color:#64748b;flex-shrink:0}.compliance-filter-select select{border:none;outline:none;background:none;font-size:.85rem;color:#e2e8f0;cursor:pointer;max-width:220px}.compliance-filter-select select:disabled{opacity:.5;cursor:not-allowed}.compliance-export-pdf-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem 1rem;border-radius:8px;border:1px solid #6366f1;background:#6366f126;color:#818cf8;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s;white-space:nowrap;margin-left:auto}.compliance-export-pdf-btn:hover{background:#6366f140}.compliance-export-pdf-btn:disabled{opacity:.5;cursor:not-allowed}.compliance-filter-summary{display:flex;align-items:center;gap:1.25rem;padding:.5rem 1rem;background:#111827;border:1px solid #1e293b;border-radius:8px;font-size:.82rem}.filter-summary-total{color:#e2e8f0;font-weight:600}.filter-summary-updated{display:flex;align-items:center;gap:.35rem;color:#10b981}.filter-summary-pending{display:flex;align-items:center;gap:.35rem;color:#f59e0b}.compliance-tree-view{display:flex;flex-direction:column;gap:.75rem}.compliance-empty-filtered{text-align:center;padding:3rem 2rem;color:#64748b;font-size:.9rem}.compliance-policy-group{background:#111827;border:1px solid #1e293b;border-radius:12px;overflow:hidden;transition:border-color .2s}.compliance-policy-group:hover{border-color:#374151}.compliance-policy-header{display:flex;align-items:center;justify-content:space-between;padding:.875rem 1.25rem;cursor:pointer;-webkit-user-select:none;user-select:none;transition:background .15s;gap:1rem}.compliance-policy-header:hover{background:#6366f10d}.compliance-policy-header.expanded{border-bottom:1px solid #1e293b}.policy-header-left{display:flex;align-items:center;gap:.625rem;min-width:0}.policy-chevron{color:#64748b;display:flex;align-items:center;flex-shrink:0}.policy-header-icon{color:#67e8f9;flex-shrink:0}.policy-header-name{font-weight:600;color:#e2e8f0;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.policy-header-count{font-size:.78rem;color:#64748b;white-space:nowrap;padding:.15rem .5rem;background:#1e293b;border-radius:10px;flex-shrink:0}.policy-header-stats{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.policy-stat{display:flex;align-items:center;gap:.25rem;font-size:.75rem;font-weight:600;padding:.15rem .5rem;border-radius:10px;white-space:nowrap}.policy-stat.stat-fully{color:#10b981;background:#10b9811f}.policy-stat.stat-partial{color:#f59e0b;background:#f59e0b1f}.policy-stat.stat-non{color:#ef4444;background:#ef44441f}.policy-stat.stat-na{color:#94a3b8;background:#94a3b81f}.policy-stat.stat-updated{color:#64748b;background:#64748b1a}.compliance-policy-controls{overflow-x:auto}.compliance-policy-controls .compliance-table{margin:0}.compliance-policy-controls .compliance-table thead th{background:#0f172a99;font-size:.72rem;padding:.625rem 1rem}.compliance-policy-controls .compliance-table tbody td{padding:.625rem 1rem}.not-updated-badge{display:inline-flex;align-items:center;gap:.25rem;padding:.2rem .5rem;border-radius:10px;font-size:.72rem;font-weight:500;background:#f59e0b1f;color:#f59e0b}.updater-info{display:flex;flex-direction:column;gap:.15rem}.updater-info .updater-date{font-size:.75rem;color:#64748b}.updater-info .updater-name{font-size:.78rem;font-weight:500;color:#94a3b8}@media(max-width:768px){.compliance-stats-grid{grid-template-columns:repeat(2,1fr)}.compliance-toolbar-filters{flex-direction:column;align-items:stretch}.compliance-search,.compliance-filter-select select{max-width:100%}.compliance-filter-summary{flex-wrap:wrap}.policy-header-stats{display:none}.compliance-policy-controls{overflow-x:auto}.compliance-policy-controls .compliance-table{min-width:700px}}.admin-email-notifications{min-height:100vh;background:var(--bg-primary);color:var(--text-primary)}.email-notif-content{padding:2rem 1.5rem;max-width:1200px;margin:0 auto}.email-notif-header{margin-bottom:1.5rem}.email-notif-title{display:flex;align-items:center;gap:.75rem}.email-notif-title svg{color:#818cf8;flex-shrink:0}.email-notif-title h1{font-size:1.75rem;font-weight:700;margin:0;color:var(--text-primary)}.email-notif-title p{color:var(--text-secondary);margin:.25rem 0 0;font-size:.9rem}.email-notif-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border-color);padding-bottom:0}.email-notif-tab{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.25rem;border:none;background:none;color:var(--text-secondary);font-size:.9rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;transition:all .2s;font-family:inherit}.email-notif-tab:hover{color:var(--text-primary);background:#6366f10d}.email-notif-tab.active{color:#818cf8;border-bottom-color:#818cf8}.email-notif-body{min-height:400px}.email-notif-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:3rem;color:var(--text-secondary)}.notif-message{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-radius:8px;margin-bottom:1rem;font-size:.875rem}.notif-message.success{background:#10b9811a;border:1px solid rgba(16,185,129,.3);color:#10b981}.notif-message.error{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444}.notif-settings-desc{color:var(--text-secondary);font-size:.9rem;margin:0 0 1.5rem}.notif-category{margin-bottom:1.5rem}.notif-category-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;color:var(--text-secondary)}.notif-category-header h3{font-size:.85rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;margin:0}.notif-category-items{display:flex;flex-direction:column;gap:.5rem}.notif-setting-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:1rem 1.25rem;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;transition:all .2s}.notif-setting-item:hover{border-color:#6366f1}.notif-setting-item.disabled{opacity:.7}.notif-setting-info{flex:1;min-width:0}.notif-setting-label{font-weight:600;font-size:.95rem;color:var(--text-primary);margin-bottom:.25rem}.notif-setting-desc{font-size:.82rem;color:var(--text-secondary);line-height:1.5}.notif-setting-meta{font-size:.75rem;color:var(--text-tertiary);margin-top:.35rem}.notif-toggle{display:flex;align-items:center;gap:.4rem;padding:.4rem .85rem;border-radius:20px;border:1px solid;font-size:.8rem;font-weight:600;cursor:pointer;white-space:nowrap;transition:all .2s;font-family:inherit}.notif-toggle.on{background:#10b9811a;border-color:#10b9814d;color:#10b981}.notif-toggle.on:hover{background:#10b98133}.notif-toggle.off{background:#64748b1a;border-color:#64748b4d;color:#94a3b8}.notif-toggle.off:hover{background:#64748b33}.notif-toggle:disabled{opacity:.5;cursor:not-allowed}.email-composer{max-width:800px}.composer-section{margin-bottom:1.25rem}.composer-label{display:flex;align-items:center;gap:.5rem;font-weight:600;font-size:.85rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.04em;margin-bottom:.5rem}.composer-chips{display:flex;flex-wrap:wrap;gap:.375rem;margin-bottom:.5rem;min-height:28px}.composer-chip{display:inline-flex;align-items:center;gap:.35rem;padding:.25rem .625rem;border-radius:20px;font-size:.8rem;font-weight:500;background:var(--bg-secondary);border:1px solid var(--border-color);color:var(--text-primary)}.composer-chip button{background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:0;display:flex;align-items:center;transition:color .15s}.composer-chip button:hover{color:#ef4444}.composer-chip.role-chip{border-width:2px}.composer-recipient-buttons{display:flex;gap:.5rem;flex-wrap:wrap}.composer-dropdown-wrapper{position:relative}.composer-add-btn{display:flex;align-items:center;gap:.4rem;padding:.5rem .875rem;border:1px solid var(--border-color);background:var(--bg-card);color:var(--text-secondary);border-radius:8px;font-size:.85rem;cursor:pointer;transition:all .15s;font-family:inherit}.composer-add-btn:hover{border-color:#6366f1;color:#818cf8}.composer-dropdown{position:absolute;top:calc(100% + 4px);left:0;min-width:280px;max-height:300px;background:var(--bg-card);border:1px solid var(--border-color);border-radius:10px;box-shadow:0 8px 24px #0000004d;z-index:50;overflow:hidden}.composer-dropdown-search{padding:.5rem;border-bottom:1px solid var(--border-color)}.composer-dropdown-search input{width:100%;padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:6px;background:var(--bg-primary);color:var(--text-primary);font-size:.85rem;outline:none;font-family:inherit}.composer-dropdown-search input:focus{border-color:#6366f1}.composer-dropdown-list{max-height:240px;overflow-y:auto}.composer-dropdown-item{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;cursor:pointer;font-size:.85rem;color:var(--text-primary);transition:background .1s}.composer-dropdown-item:hover{background:#6366f114}.composer-dropdown-item input[type=checkbox]{accent-color:#6366f1;width:16px;height:16px;flex-shrink:0}.role-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.dropdown-count{margin-left:auto;font-size:.75rem;color:var(--text-tertiary)}.dropdown-email{margin-left:auto;font-size:.75rem;color:var(--text-tertiary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:150px}.composer-dropdown-empty{padding:1rem;text-align:center;color:var(--text-tertiary);font-size:.85rem}.composer-recipient-count{font-size:.82rem;color:var(--text-secondary);margin-top:.5rem;padding:.4rem .75rem;background:#6366f114;border-radius:6px;display:inline-block}.composer-subject{width:100%;padding:.75rem 1rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:1rem;font-family:inherit;outline:none;transition:border-color .2s}.composer-subject:focus{border-color:#6366f1;box-shadow:0 0 0 3px #6366f126}.composer-toolbar{display:flex;align-items:center;gap:.25rem;padding:.5rem;background:var(--bg-secondary);border:1px solid var(--border-color);border-bottom:none;border-radius:8px 8px 0 0}.composer-toolbar button{padding:.375rem .5rem;border:none;background:none;color:var(--text-secondary);cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:all .15s}.composer-toolbar button:hover{background:var(--bg-primary);color:var(--text-primary)}.composer-toolbar select{padding:.25rem .5rem;border:1px solid var(--border-color);border-radius:4px;background:var(--bg-card);color:var(--text-secondary);font-size:.8rem;cursor:pointer;font-family:inherit}.toolbar-separator{width:1px;height:20px;background:var(--border-color);margin:0 .25rem}.composer-editor{min-height:250px;padding:1rem;border:1px solid var(--border-color);border-radius:0 0 8px 8px;background:var(--bg-card);color:var(--text-primary);font-size:.95rem;line-height:1.7;outline:none;overflow-y:auto;max-height:500px;font-family:inherit}.composer-editor:focus{border-color:#6366f1}.composer-editor:empty:before{content:attr(data-placeholder);color:var(--text-tertiary);pointer-events:none}.composer-editor a{color:#818cf8}.composer-editor blockquote{border-left:3px solid #6366f1;margin:.5rem 0;padding:.5rem 1rem;background:var(--bg-secondary);border-radius:0 6px 6px 0}.composer-actions{display:flex;justify-content:flex-end;margin-top:1rem}.composer-send-btn{display:flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;background:#6366f1;color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;font-family:inherit}.composer-send-btn:hover{background:#4f46e5;transform:translateY(-1px)}.composer-send-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.email-logs-filters{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.email-logs-filter{display:flex;align-items:center;gap:.4rem;color:var(--text-secondary)}.email-logs-filter select{padding:.5rem .75rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-primary);font-size:.85rem;cursor:pointer;font-family:inherit}.email-logs-total{margin-left:auto;font-size:.82rem;color:var(--text-tertiary)}.email-logs-empty{text-align:center;padding:3rem;color:var(--text-tertiary)}.email-logs-table-wrapper{background:var(--bg-card);border:1px solid var(--border-color);border-radius:12px;overflow-x:auto}.email-logs-table{width:100%;border-collapse:collapse;font-size:.85rem}.email-logs-table thead th{background:var(--bg-secondary);padding:.75rem 1rem;text-align:left;font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-color);white-space:nowrap;font-size:.78rem;text-transform:uppercase;letter-spacing:.04em}.email-logs-table tbody tr{border-bottom:1px solid var(--border-color);transition:background .1s}.email-logs-table tbody tr:last-child{border-bottom:none}.email-logs-table tbody tr:hover{background:#6366f10a}.email-logs-table tbody td{padding:.625rem 1rem;color:var(--text-primary);vertical-align:top}.log-date{white-space:nowrap;font-size:.8rem;color:var(--text-tertiary)}.log-recipient{display:flex;flex-direction:column;gap:.1rem}.log-recipient-name{font-weight:500;font-size:.85rem}.log-recipient-email{font-size:.75rem;color:var(--text-tertiary)}.log-subject{max-width:250px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.85rem}.log-event-badge{display:inline-block;padding:.2rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;background:#6366f11a;color:#818cf8;white-space:nowrap}.log-status{display:flex;align-items:center;gap:.3rem;font-weight:600;font-size:.82rem;white-space:nowrap}.log-error{display:block;font-size:.72rem;color:#ef4444;margin-top:.2rem;max-width:200px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.log-sender{font-size:.82rem;color:var(--text-secondary);white-space:nowrap}.email-logs-pagination{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1rem;padding:.75rem;font-size:.85rem;color:var(--text-secondary)}.email-logs-pagination button{display:flex;align-items:center;gap:.35rem;padding:.5rem .875rem;border:1px solid var(--border-color);border-radius:8px;background:var(--bg-card);color:var(--text-secondary);font-size:.85rem;cursor:pointer;transition:all .15s;font-family:inherit}.email-logs-pagination button:hover:not(:disabled){border-color:#6366f1;color:#818cf8}.email-logs-pagination button:disabled{opacity:.4;cursor:not-allowed}@media(max-width:768px){.email-notif-tabs{overflow-x:auto}.email-notif-tab span{display:none}.composer-dropdown{min-width:240px}.email-logs-table{min-width:700px}}.user-assets{min-height:100vh;background:var(--bg-primary, #0f172a)}.user-assets .ua-container{max-width:1400px;margin:0 auto;padding:2rem 1.5rem}.user-assets .ua-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;flex-wrap:wrap;gap:1rem}.user-assets .ua-header h1{font-size:1.5rem;color:var(--text-primary, #f1f5f9);display:flex;align-items:center;gap:.5rem}.user-assets .aa-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:1rem;margin-bottom:1.5rem}.user-assets .aa-stat-card{background:var(--bg-secondary, #1e293b);border:1px solid var(--border-color, #334155);border-radius:10px;padding:1rem 1.25rem}.user-assets .aa-stat-card .stat-value{font-size:1.5rem;font-weight:700;color:var(--text-primary, #f1f5f9)}.user-assets .aa-stat-card .stat-label{font-size:.8rem;color:var(--text-secondary, #94a3b8);margin-top:.25rem}.user-assets .aa-stat-card.success .stat-value{color:#10b981}.user-assets .aa-stat-card.info .stat-value{color:#6366f1}.user-assets .aa-stat-card.warning .stat-value{color:#f59e0b}.user-assets .role-badges{display:flex;gap:.5rem;flex-wrap:wrap;margin-bottom:1.5rem}.user-assets .role-badge{padding:.3rem .75rem;border-radius:16px;font-size:.8rem;font-weight:600}.user-assets .role-badge.it-owner{background:#6366f126;color:#6366f1}.user-assets .role-badge.biz-owner{background:#10b98126;color:#10b981}.user-assets .role-badge.spoc{background:#f59e0b26;color:#f59e0b}.user-incidents{min-height:100vh;background:#0a0a0f;color:#e2e8f0}.incidents-content{padding:2rem 1.5rem;max-width:1200px;margin:0 auto}.incidents-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:2rem;flex-wrap:wrap;gap:1rem}.incidents-header h1{display:flex;align-items:center;gap:.5rem;font-size:1.75rem;font-weight:700;color:#f1f5f9;margin:0}.incidents-header .subtitle{color:#94a3b8;margin:.25rem 0 0;font-size:.95rem}.incident-success-alert{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background:#10b98126;border:1px solid rgba(16,185,129,.3);border-radius:10px;color:#10b981;margin-bottom:1.5rem;font-size:.9rem}.incident-success-alert button{background:none;border:none;color:#10b981;font-size:1.25rem;cursor:pointer;padding:0 .25rem}.incident-loading{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;color:#94a3b8}.incident-loading .spinner{width:40px;height:40px;border:3px solid #1e293b;border-top-color:#6366f1;border-radius:50%;animation:spin .8s linear infinite;margin-bottom:1rem}.incident-empty{display:flex;flex-direction:column;align-items:center;padding:4rem 2rem;color:#64748b;text-align:center}.incident-empty h3{margin:1rem 0 .5rem;color:#94a3b8}.incident-empty p{font-size:.9rem}.incident-list{display:flex;flex-direction:column;gap:.75rem}.incident-card{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:1.25rem;cursor:pointer;transition:all .2s}.incident-card:hover{border-color:#374151;transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.incident-card-top{display:flex;align-items:center;gap:.5rem;margin-bottom:.5rem;flex-wrap:wrap}.incident-card-title{font-size:1rem;font-weight:600;color:#f1f5f9;margin:0 0 .25rem}.incident-card-category{font-size:.82rem;color:#94a3b8;margin:0 0 .5rem}.incident-card-meta{display:flex;gap:1rem;font-size:.78rem;color:#64748b;flex-wrap:wrap}.incident-card-meta span{display:flex;align-items:center;gap:.3rem}.incident-severity-badge{padding:.15rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.03em}.incident-status-badge{padding:.15rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;color:var(--status-color);background:color-mix(in srgb,var(--status-color) 15%,transparent);border:1px solid color-mix(in srgb,var(--status-color) 30%,transparent)}.incident-category-badge{padding:.15rem .5rem;border-radius:10px;font-size:.72rem;font-weight:600;color:#818cf8;background:#6366f126;font-family:SF Mono,Fira Code,monospace}.incident-report-form{background:#111827;border:1px solid #1e293b;border-radius:12px;padding:1.5rem}.incident-form-error{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;font-size:.85rem;margin-bottom:1rem}.incident-form-error button{background:none;border:none;color:#ef4444;font-size:1.25rem;cursor:pointer;margin-left:auto}.incident-form-group{margin-bottom:1.25rem}.incident-form-group label{display:block;font-size:.85rem;font-weight:600;color:#94a3b8;margin-bottom:.375rem}.incident-form-group input,.incident-form-group select,.incident-form-group textarea{width:100%;padding:.625rem .875rem;border:1px solid #374151;border-radius:8px;background:#1e293b;color:#e2e8f0;font-size:.9rem;font-family:inherit}.incident-form-group input:focus,.incident-form-group select:focus,.incident-form-group textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 3px #6366f133}.incident-form-group textarea{resize:vertical;min-height:100px}.severity-options{display:flex;gap:.5rem;flex-wrap:wrap}.severity-btn{padding:.4rem .875rem;border-radius:8px;border:1px solid #374151;background:#1e293b;color:#94a3b8;font-size:.85rem;font-weight:500;cursor:pointer;transition:all .15s}.severity-btn:hover{border-color:var(--sev-color);color:var(--sev-color)}.severity-btn.active{background:color-mix(in srgb,var(--sev-color) 20%,transparent);border-color:var(--sev-color);color:var(--sev-color);font-weight:600}.incident-file-area{display:flex;align-items:center;gap:.75rem;flex-wrap:wrap}.incident-file-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;border-radius:8px;border:1px dashed #374151;background:transparent;color:#818cf8;font-size:.85rem;cursor:pointer;transition:all .15s}.incident-file-btn:hover{border-color:#6366f1;background:#6366f11a}.incident-file-hint{font-size:.75rem;color:#64748b}.incident-file-list{display:flex;flex-direction:column;gap:.375rem;margin-top:.625rem}.incident-file-item{display:flex;align-items:center;gap:.5rem;padding:.375rem .625rem;background:#1e293b;border-radius:6px;font-size:.82rem;color:#cbd5e1}.incident-file-size{font-size:.72rem;color:#64748b;margin-left:auto}.incident-file-remove{background:none;border:none;color:#64748b;cursor:pointer;padding:.2rem;border-radius:4px;display:flex}.incident-file-remove:hover{color:#ef4444;background:#ef444426}.incident-form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem;padding-top:1rem;border-top:1px solid #1e293b}.incident-submit-btn{display:flex;align-items:center;gap:.4rem}.incident-modal-overlay{position:fixed;inset:0;background:#000000b3;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem}.incident-modal{background:#111827;border:1px solid #1e293b;border-radius:16px;width:100%;max-width:700px;max-height:85vh;display:flex;flex-direction:column;box-shadow:0 20px 60px #00000080;animation:incidentModalIn .2s ease}@keyframes incidentModalIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.incident-modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem 1.5rem;border-bottom:1px solid #1e293b}.incident-modal-title-row{display:flex;align-items:center;gap:.5rem;flex-wrap:wrap}.incident-modal-close{background:none;border:none;color:#64748b;cursor:pointer;padding:.375rem;border-radius:6px;display:flex}.incident-modal-close:hover{background:#1e293b;color:#e2e8f0}.incident-modal-body{padding:1.5rem;overflow-y:auto}.incident-modal-title{font-size:1.25rem;font-weight:700;color:#f1f5f9;margin:0 0 1.25rem}.incident-detail-section{margin-bottom:1.25rem}.incident-detail-section h4{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .5rem}.incident-detail-section p{font-size:.9rem;color:#e2e8f0;line-height:1.6;margin:0}.incident-description-text{white-space:pre-wrap}.incident-admin-notes{white-space:pre-wrap;padding:.75rem;background:#6366f11a;border-radius:8px;border-left:3px solid #6366f1}.incident-detail-meta{display:flex;flex-direction:column;gap:.625rem;padding:1rem 0;border-top:1px solid #1e293b;border-bottom:1px solid #1e293b;margin-bottom:1.25rem}.incident-meta-item{display:flex;align-items:center;gap:.75rem;font-size:.85rem;color:#cbd5e1}.incident-meta-item .meta-label{font-size:.78rem;font-weight:600;color:#64748b;min-width:100px}.incident-attachments-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.incident-attachments-header h4{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0}.incident-upload-btn{display:inline-flex;align-items:center;gap:.35rem;padding:.3rem .7rem;border-radius:6px;border:1px solid #6366f1;background:#6366f126;color:#818cf8;font-size:.78rem;font-weight:500;cursor:pointer;transition:all .15s}.incident-upload-btn:hover{background:#6366f140}.incident-no-attachments{padding:1rem;color:#64748b;font-size:.82rem;text-align:center;background:#1e293b80;border-radius:8px}.incident-attachments-list{display:flex;flex-direction:column;gap:.5rem}.incident-attachment-item{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;background:#1e293b;border-radius:8px;border:1px solid #374151;transition:border-color .15s}.incident-attachment-item:hover{border-color:#6366f1}.incident-att-info{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0;cursor:pointer;color:#818cf8}.incident-att-info:hover{color:#a5b4fc}.incident-att-name{font-size:.82rem;font-weight:500;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.incident-att-meta{display:flex;flex-direction:column;align-items:flex-end;gap:.1rem;flex-shrink:0;font-size:.72rem;color:#64748b}.incident-att-delete{background:none;border:none;color:#64748b;cursor:pointer;padding:.3rem;border-radius:4px;display:flex}.incident-att-delete:hover{background:#ef444426;color:#ef4444}.spin{animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}@media(max-width:768px){.incidents-header{flex-direction:column}.incident-modal{max-height:95vh;margin:.5rem}}.admin-incidents{min-height:100vh;background:#0a0a0f;color:#e2e8f0}.incident-stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.5rem}.incident-stat-card{background:#111827;border-radius:12px;padding:1rem 1.25rem;border:1px solid #1e293b;display:flex;align-items:center;gap:.75rem;cursor:pointer;transition:all .2s ease;-webkit-user-select:none;user-select:none}.incident-stat-card:hover{background:#1e293b;border-color:#374151;transform:translateY(-1px)}.incident-stat-card.active{background:#1e293b}.incident-stat-icon{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.incident-stat-info{display:flex;flex-direction:column}.incident-stat-value{font-size:1.25rem;font-weight:700;color:#f1f5f9}.incident-stat-label{font-size:.78rem;color:#94a3b8}.admin-incident-filters{display:flex;align-items:center;gap:.75rem;margin-bottom:1rem;flex-wrap:wrap}.admin-incident-search{display:flex;align-items:center;gap:.5rem;background:#111827;border:1px solid #1e293b;border-radius:8px;padding:.625rem 1rem;flex:1;max-width:350px}.admin-incident-search input{border:none;outline:none;background:none;font-size:.9rem;width:100%;color:#e2e8f0}.admin-incident-search input::placeholder{color:#64748b}.admin-incident-search svg{color:#64748b;flex-shrink:0}.search-clear{background:none;border:none;color:#64748b;cursor:pointer;padding:.2rem;border-radius:4px;display:flex}.search-clear:hover{color:#e2e8f0}.admin-incident-filters select{padding:.625rem .75rem;border:1px solid #1e293b;border-radius:8px;background:#111827;color:#e2e8f0;font-size:.85rem}.admin-incident-filters select:focus{outline:none;border-color:#6366f1}.admin-incident-results{font-size:.82rem;color:#64748b;margin-bottom:.75rem}.admin-incident-table-wrapper{background:#111827;border-radius:12px;border:1px solid #1e293b;overflow-x:auto}.admin-incident-table{width:100%;border-collapse:collapse;font-size:.85rem}.admin-incident-table thead th{background:#0f172a;padding:.875rem 1rem;text-align:left;font-weight:600;color:#94a3b8;border-bottom:1px solid #1e293b;white-space:nowrap;text-transform:uppercase;letter-spacing:.05em;font-size:.78rem}.admin-incident-table tbody tr{border-bottom:1px solid #1e293b;cursor:pointer;transition:background .15s}.admin-incident-table tbody tr:last-child{border-bottom:none}.admin-incident-table tbody tr:hover{background:#6366f10d}.admin-incident-table tbody td{padding:.75rem 1rem;color:#cbd5e1;vertical-align:middle}.admin-incident-title{font-weight:600;color:#f1f5f9;font-size:.85rem;max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-incident-category-text{font-size:.75rem;color:#64748b;max-width:280px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.admin-incident-reporter{font-weight:500;color:#e2e8f0;font-size:.82rem}.admin-incident-assignee{display:flex;align-items:center;gap:.3rem;font-size:.82rem;color:#a78bfa}.admin-incident-date{font-size:.78rem;color:#64748b;white-space:nowrap}.admin-incident-files{display:flex;align-items:center;gap:.25rem;color:#818cf8;font-size:.82rem}.admin-incident-controls{margin-bottom:1.25rem;padding:1rem;background:#1e293b80;border-radius:10px;border:1px solid #1e293b}.admin-incident-controls h4{font-size:.78rem;font-weight:600;color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;margin:0 0 .75rem}.admin-incident-fields{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:.75rem;margin-bottom:.75rem}.admin-field{display:flex;flex-direction:column;gap:.25rem}.admin-field label{font-size:.78rem;font-weight:600;color:#64748b}.admin-field select,.admin-field textarea{padding:.5rem .625rem;border:1px solid #374151;border-radius:6px;background:#1e293b;color:#e2e8f0;font-size:.85rem;font-family:inherit}.admin-field select:focus,.admin-field textarea:focus{outline:none;border-color:#6366f1;box-shadow:0 0 0 2px #6366f133}.admin-field-full{width:100%}.admin-field-full textarea{resize:vertical;min-height:80px;width:100%}.admin-incident-save{display:flex;justify-content:flex-end;margin-top:.75rem}.admin-incident-save .btn{display:flex;align-items:center;gap:.35rem;font-size:.85rem}.admin-incident-modal{max-width:800px}@media(max-width:768px){.admin-incident-filters{flex-direction:column;align-items:stretch}.admin-incident-search{max-width:100%}.admin-incident-table{min-width:700px}.admin-incident-fields{grid-template-columns:1fr}}.table-container{border-radius:8px;overflow:hidden}.empty-state{display:flex;flex-direction:column;align-items:center;gap:8px}.config-transfer{min-height:100vh;background-color:var(--bg-primary)}.config-transfer-content{padding-top:2rem;padding-bottom:3rem}.config-header{margin-bottom:2rem}.config-header h1{font-size:2rem;font-weight:700;margin-bottom:.25rem}.config-section{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-color);padding:1.5rem;margin-bottom:1.5rem}.section-header{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1.25rem;color:var(--text-primary)}.section-header h2{font-size:1.125rem;font-weight:600;margin-bottom:.125rem}.section-header p{font-size:.875rem;color:var(--text-secondary)}.entity-selection{margin-bottom:1.25rem}.entity-selection-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.entity-count{font-size:.8125rem;color:var(--text-tertiary)}.entity-quick-actions{display:flex;align-items:center;gap:.5rem}.btn-link{background:none;border:none;color:var(--primary, #6366f1);font-size:.8125rem;cursor:pointer;padding:0}.btn-link:hover{text-decoration:underline}.entity-quick-actions .divider{color:var(--text-tertiary);font-size:.75rem}.entity-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:.625rem}.entity-card{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:1rem .75rem;border:1px solid var(--border-color);border-radius:var(--radius-md);background:var(--bg-primary);cursor:pointer;transition:all .2s;position:relative}.entity-card:hover{border-color:var(--entity-color);transform:translateY(-1px)}.entity-card.selected{border-color:var(--entity-color);background:color-mix(in srgb,var(--entity-color) 8%,var(--bg-primary));box-shadow:0 0 0 1px var(--entity-color)}.entity-icon{color:var(--entity-color)}.entity-label{font-size:.8125rem;font-weight:500;color:var(--text-primary);text-align:center}.entity-check{position:absolute;top:.375rem;right:.375rem;color:var(--entity-color)}.export-btn{display:inline-flex;align-items:center;gap:.5rem}.import-upload-area{margin-bottom:1rem}.upload-zone{width:100%;padding:2rem;border:2px dashed var(--border-color);border-radius:var(--radius-lg);background:var(--bg-primary);cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:.5rem;transition:all .2s;color:var(--text-secondary)}.upload-zone:hover{border-color:var(--primary, #6366f1);color:var(--primary, #6366f1)}.upload-label{font-size:.9375rem;font-weight:500}.upload-hint{font-size:.8125rem;color:var(--text-tertiary)}.import-preview,.import-results{background:var(--bg-primary);border-radius:var(--radius-md);padding:1.25rem;border:1px solid var(--border-color)}.import-preview h3,.import-results h3{font-size:1rem;font-weight:600;margin-bottom:1rem;display:flex;align-items:center;gap:.5rem}.preview-grid,.results-grid{display:flex;flex-direction:column;gap:.5rem;margin-bottom:1rem}.preview-item,.result-item{display:flex;justify-content:space-between;align-items:center;padding:.625rem .75rem;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-color)}.preview-entity,.result-entity{font-weight:500;font-size:.875rem;color:var(--text-primary)}.preview-stats,.result-stats{display:flex;gap:.75rem;font-size:.8125rem}.stat-new{color:#22c55e;font-weight:600}.stat-existing,.stat-skipped{color:var(--text-tertiary)}.stat-updated{color:#f59e0b;font-weight:600}.update-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:var(--text-primary);cursor:pointer;margin-bottom:.75rem}.update-toggle input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary, #6366f1)}.warning-box{display:flex;align-items:center;gap:.5rem;padding:.625rem .75rem;background:#f59e0b14;border:1px solid rgba(245,158,11,.25);border-radius:var(--radius-md);font-size:.8125rem;color:#f59e0b;margin-bottom:1rem}.preview-actions{display:flex;gap:.75rem}.text-success{color:#22c55e}@media(max-width:768px){.entity-grid{grid-template-columns:repeat(2,1fr)}.preview-item,.result-item{flex-direction:column;align-items:flex-start;gap:.375rem}}
