.login-container{align-items:center;background:var(--gradient-dark);display:flex;justify-content:center;min-height:100vh;padding:16px}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;gap:var(--space-4);max-width:400px;padding:var(--space-6);width:100%}@media (min-width:768px){.login-card,.login-container{padding:var(--space-8)}}.login-button,.login-input{min-height:44px}.login-header{margin-bottom:var(--space-6);text-align:center}.login-title{color:var(--color-text);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.login-subtitle{color:var(--color-text-muted);font-size:var(--text-sm)}.login-card form{display:flex;flex-direction:column;gap:var(--space-4)}.login-input{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);height:var(--input-height);padding:0 var(--space-4);width:100%}.login-input::placeholder{color:var(--color-text-muted)}.login-button{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-lg);color:var(--white);cursor:pointer;display:flex;font-weight:var(--font-medium);height:var(--button-height);justify-content:center;transition:background var(--transition-fast);width:100%}.login-button:hover{background:var(--color-primary-hover)}.oauth-divider{color:var(--color-text-muted);font-size:var(--text-sm);margin-bottom:var(--space-4);margin-top:var(--space-6);position:relative;text-align:center}.oauth-divider:after,.oauth-divider:before{border-top:1px solid var(--color-border);content:"";position:absolute;top:50%;width:40%}.oauth-divider:before{left:0}.oauth-divider:after{right:0}.oauth-button{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text);display:flex;gap:var(--space-2);justify-content:center}.oauth-button:hover{background:var(--color-surface-hover)}.oauth-logo{flex-shrink:0;height:var(--space-5);width:var(--space-5)}.link-button{background:none;border:none;color:var(--color-primary);cursor:pointer;font-size:var(--text-sm);padding:0;transition:color var(--transition-fast)}.link-button:hover{color:var(--color-primary-hover)}.login-footer{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:var(--space-6);text-align:center}.login-footer a{color:var(--color-primary)}.password-strength{display:flex;flex-direction:column;gap:8px;margin-top:-8px}.password-strength-bar{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border-radius:2px;height:4px;overflow:hidden}.password-strength-fill{border-radius:2px;height:100%;transition:width .3s ease,background .3s ease}.password-strength-label{font-size:12px;font-weight:600;text-align:right}.password-strength-rules{grid-gap:4px 12px;display:grid;gap:4px 12px;grid-template-columns:1fr 1fr;list-style:none;margin:0;padding:0}.password-strength-rules li{align-items:center;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);display:flex;font-size:12px;gap:6px;transition:color .2s}.password-strength-rules li.met{color:#10b981}.password-strength-rules li svg{flex-shrink:0}.email-verify-icon{align-items:center;background:#3b82f61a;border-radius:50%;color:#3b82f6;color:var(--color-primary,#3b82f6);display:flex;height:72px;justify-content:center;margin:0 auto var(--space-4);width:72px}.email-verify-instructions{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.5;text-align:center}.email-verify-instructions p{margin:0}.email-verify-actions{display:flex;flex-direction:column;gap:var(--space-3)}.email-verify-actions .login-button{gap:8px}.email-verify-alert{border-radius:var(--radius-lg);font-size:var(--text-sm);padding:10px 14px;text-align:center}.email-verify-alert p{margin:0}.email-verify-error{background:#ef44441a;border:1px solid #ef444433;color:#f87171}.email-verify-success{background:#10b9811a;border:1px solid #10b98133;color:#34d399}.spinning{animation:spin 1s linear infinite}.landing-page{background:var(--color-background);color:var(--color-text);min-height:100vh;overflow-x:hidden}.landing-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);left:0;position:fixed;right:0;top:0;z-index:100}.landing-nav-inner{align-items:center;display:flex;height:64px;justify-content:space-between;margin:0 auto;max-width:1200px;padding:0 24px}.landing-brand{align-items:center;display:flex;gap:10px}.landing-logo-mark{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border-radius:8px;color:#fff;display:flex;height:32px;justify-content:center;width:32px}.landing-logo-mark-sm{border-radius:6px;height:24px;width:24px}.landing-logo-text{color:var(--color-text);font-size:20px;font-weight:700;letter-spacing:-.5px}.landing-nav-actions{align-items:center;display:flex;gap:12px}.landing-btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:10px 20px;transition:all .2s ease;white-space:nowrap}.landing-btn-primary:hover{box-shadow:0 4px 12px #3b82f64d;filter:brightness(1.1);transform:translateY(-1px)}.landing-btn-ghost{align-items:center;background:#0000;border:none;border-radius:10px;color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.landing-btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.landing-btn-outline{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:10px;color:var(--color-text);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:10px 20px;transition:all .2s ease}.landing-btn-outline:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover,var(--color-border))}.landing-btn-lg{border-radius:12px;font-size:16px;padding:14px 28px}.landing-hero{padding:140px 24px 80px;text-align:center}.landing-hero-inner{margin:0 auto;max-width:800px}.landing-hero-badge{background:#3b82f61a;border:1px solid #3b82f640;border-radius:20px;color:#3b82f6;color:var(--color-primary,#3b82f6);display:inline-block;font-size:13px;font-weight:600;letter-spacing:.02em;margin-bottom:24px;padding:6px 16px}.landing-hero-title{color:var(--color-text);font-size:48px;font-weight:800;letter-spacing:-.03em;line-height:1.1;margin:0 0 20px}.landing-hero-accent{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;background-clip:text}.landing-hero-subtitle{color:var(--color-text-muted);font-size:18px;line-height:1.6;margin:0 auto 36px;max-width:600px}.landing-hero-actions{gap:16px;margin-bottom:64px}.landing-hero-actions,.landing-hero-stats{align-items:center;display:flex;justify-content:center}.landing-hero-stats{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-sm);gap:32px;padding:32px}.landing-stat{align-items:center;display:flex;flex-direction:column;gap:4px}.landing-stat-value{color:var(--color-text);font-size:28px;font-weight:800;letter-spacing:-.02em}.landing-stat-label{color:var(--color-text-muted);font-size:13px}.landing-stat-divider{background:var(--color-border);height:40px;width:1px}.landing-features{padding:80px 24px}.landing-features-inner{margin:0 auto;max-width:1100px}.landing-section-title{color:var(--color-text);font-size:32px;font-weight:700;letter-spacing:-.02em;margin:0 0 12px;text-align:center}.landing-section-subtitle{color:var(--color-text-muted);font-size:16px;line-height:1.6;margin:0 auto 48px;max-width:560px;text-align:center}.landing-features-grid{grid-gap:24px;display:grid;gap:24px;grid-template-columns:repeat(2,1fr)}.landing-feature-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:16px;box-shadow:var(--shadow-xs);padding:32px;transition:all .2s ease}.landing-feature-card:hover{border-color:var(--color-border-hover,var(--color-border));box-shadow:var(--shadow-md);transform:translateY(-2px)}.landing-feature-icon{align-items:center;border-radius:12px;display:flex;height:48px;justify-content:center;margin-bottom:20px;width:48px}.landing-feature-icon.icon-blue{background:#3b82f61a;color:#3b82f6}.landing-feature-icon.icon-green{background:#10b9811a;color:#10b981}.landing-feature-icon.icon-purple{background:#9333ea1a;color:#9333ea}.landing-feature-icon.icon-amber{background:#f59e0b1a;color:#f59e0b}.landing-feature-card h3{color:var(--color-text);font-size:18px;font-weight:600;margin:0 0 10px}.landing-feature-card p{color:var(--color-text-muted);font-size:14px;line-height:1.6;margin:0}.landing-trust{padding:60px 24px}.landing-trust-inner{margin:0 auto;max-width:900px;text-align:center}.landing-trust-items{display:flex;flex-wrap:wrap;gap:20px;justify-content:center;margin-top:32px}.landing-trust-item{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text-muted);display:flex;font-size:14px;gap:8px;padding:10px 18px}.landing-trust-item svg{color:#10b981;flex-shrink:0}.landing-cta{padding:80px 24px}.landing-cta-inner{background:#3b82f60d;border:1px solid #3b82f633;border-radius:24px;margin:0 auto;max-width:600px;padding:64px 40px;text-align:center}.landing-cta-inner h2{color:var(--color-text);font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0 0 12px}.landing-cta-inner p{color:var(--color-text-muted);font-size:16px;line-height:1.5;margin:0 0 28px}.landing-footer{border-top:1px solid var(--color-border);padding:40px 24px}.landing-footer-inner{align-items:center;display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin:0 auto;max-width:1200px}.landing-footer-brand{align-items:center;display:flex;gap:8px}.landing-footer-brand .landing-logo-text{font-size:16px}.landing-footer-links{align-items:center;display:flex;gap:24px}.landing-footer-links a{color:var(--color-text-muted);font-size:13px;text-decoration:none;transition:color .2s}.landing-footer-links a:hover{color:var(--color-text)}.landing-footer-copy{color:var(--color-text-muted);font-size:13px;margin:0}@media (max-width:768px){.landing-hero{padding:120px 20px 60px}.landing-hero-title{font-size:32px}.landing-hero-subtitle{font-size:16px}.landing-hero-actions{flex-direction:column;gap:12px}.landing-hero-actions .landing-btn-lg{justify-content:center;width:100%}.landing-hero-stats{flex-direction:column;gap:20px;padding:24px}.landing-stat-divider{height:1px;width:40px}.landing-features-grid{grid-template-columns:1fr}.landing-section-title{font-size:24px}.landing-cta-inner{padding:40px 24px}.landing-cta-inner h2{font-size:22px}.landing-footer-inner{flex-direction:column;text-align:center}.landing-footer-links{flex-wrap:wrap;justify-content:center}}@media (max-width:480px){.landing-hero-title{font-size:28px}.landing-stat-value{font-size:24px}.landing-trust-items{align-items:center;flex-direction:column}}.legal-page{background:#09090b;background:var(--color-background,#09090b);color:#fafafa;color:var(--color-text,#fafafa);min-height:100vh;padding:40px 24px 80px}.legal-container{margin:0 auto;max-width:720px}.legal-back{align-items:center;background:#0000;border:1px solid #ffffff1a;border-radius:8px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;gap:6px;margin-bottom:32px;padding:8px 16px;transition:all .15s}.legal-back:hover{border-color:#fff3;color:#fafafa;color:var(--color-text,#fafafa)}.legal-container h1{font-size:32px;font-weight:800;letter-spacing:-.02em;margin:0 0 8px}.legal-updated{color:#71717a;color:var(--color-text-muted,#71717a);font-size:14px;margin:0 0 40px}.legal-container section{margin-bottom:32px}.legal-container h2{color:#fafafa;color:var(--color-text,#fafafa);font-size:20px;font-weight:700;margin:0 0 12px}.legal-container h3{color:#e4e4e7;color:var(--color-text,#e4e4e7);font-size:16px;font-weight:600;margin:16px 0 8px}.legal-container p{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:15px;line-height:1.7;margin:0 0 12px}.legal-container ul{margin:0 0 12px;padding-left:24px}.legal-container li{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:15px;line-height:1.7;margin-bottom:4px}.legal-container a{color:#3b82f6;color:var(--color-primary,#3b82f6);text-decoration:none}.legal-container a:hover{text-decoration:underline}@media (max-width:768px){.legal-page{padding:24px 16px 60px}.legal-container h1{font-size:24px}}.user-menu{flex-shrink:0;position:relative}.user-menu-trigger{align-items:center;background:#0000;border:1px solid #0000;border-radius:12px;border-radius:var(--radius-lg,12px);cursor:pointer;display:flex;gap:6px;padding:4px;transition:all .15s ease}.user-menu-trigger.open,.user-menu-trigger:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d)}.user-menu-trigger.open{border-color:#ffffff1a;border-color:var(--color-border,#ffffff1a)}.user-menu-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border-radius:50%;display:flex;flex-shrink:0;height:32px;justify-content:center;overflow:hidden;width:32px}.user-menu-avatar img{height:100%;object-fit:cover;width:100%}.user-menu-initials{color:#fff;font-size:13px;font-weight:600;line-height:1}.user-menu-chevron{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);transition:transform .2s ease}.user-menu-chevron.rotated{transform:rotate(180deg)}.user-menu-dropdown{animation:userMenuSlideIn .15s ease-out;background:#18181b;background:var(--color-surface,#18181b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:16px;border-radius:var(--radius-xl,16px);box-shadow:0 20px 40px #0000004d;box-shadow:var(--shadow-xl,0 20px 40px #0000004d);min-width:240px;overflow:hidden;padding:4px;position:absolute;right:0;top:calc(100% + 8px);z-index:9999}@keyframes userMenuSlideIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.user-menu-header{align-items:center;display:flex;gap:12px;padding:12px}.user-menu-header-avatar{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border-radius:50%;display:flex;flex-shrink:0;height:40px;justify-content:center;overflow:hidden;width:40px}.user-menu-header-avatar img{height:100%;object-fit:cover;width:100%}.user-menu-header-avatar .user-menu-initials{font-size:15px}.user-menu-header-info{display:flex;flex-direction:column;min-width:0}.user-menu-name{color:#fafafa;color:var(--color-text,#fafafa);font-size:14px;font-weight:600}.user-menu-email,.user-menu-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-email{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:12px}.user-menu-divider{background:#ffffff0f;background:var(--color-border,#ffffff0f);height:1px;margin:4px 0}.user-menu-item{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--radius-lg,10px);color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;font-family:inherit;font-size:13px;gap:10px;padding:10px 12px;text-align:left;text-decoration:none;transition:all .15s ease;width:100%}.user-menu-item:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);color:#fafafa;color:var(--color-text,#fafafa)}.user-menu-item svg{flex-shrink:0}.user-menu-item-danger:hover{background:#ef444414;color:#ef4444;color:var(--color-error,#ef4444)}@media (max-width:480px){.user-menu-dropdown{animation:userMenuSlideUp .25s ease-out;border-radius:16px 16px 0 0;bottom:0;left:0;min-width:100%;padding:4px 4px calc(4px + env(safe-area-inset-bottom));position:fixed;right:0;top:auto}@keyframes userMenuSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}}.notification-bell{flex-shrink:0;position:relative}.notification-bell-trigger{align-items:center;background:#0000;border:none;border-radius:10px;border-radius:var(--radius-lg,10px);color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;height:36px;justify-content:center;position:relative;transition:all .15s ease;width:36px}.notification-bell-trigger.open,.notification-bell-trigger:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);color:#fafafa;color:var(--color-text,#fafafa)}.notification-badge{align-items:center;background:#ef4444;border-radius:8px;color:#fff;display:flex;font-size:10px;font-weight:700;height:16px;justify-content:center;line-height:1;min-width:16px;padding:0 4px;pointer-events:none;position:absolute;right:2px;top:2px}.notification-dropdown{animation:notifSlideIn .15s ease-out;background:#18181b;background:var(--color-surface,#18181b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:16px;border-radius:var(--radius-xl,16px);box-shadow:0 20px 40px #0000004d;box-shadow:var(--shadow-xl,0 20px 40px #0000004d);display:flex;flex-direction:column;max-height:480px;overflow:hidden;position:absolute;right:0;top:calc(100% + 8px);width:340px;z-index:9999}@keyframes notifSlideIn{0%{opacity:0;transform:translateY(-4px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.notification-header{align-items:center;border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border,#ffffff0f);display:flex;justify-content:space-between;padding:14px 16px}.notification-header-title{color:#fafafa;color:var(--color-text,#fafafa);font-size:14px;font-weight:600}.notification-header-actions{display:flex;gap:4px}.notification-header-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .15s;width:28px}.notification-header-btn:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);color:#fafafa;color:var(--color-text,#fafafa)}.notification-list{max-height:400px;overflow-y:auto;padding:4px}.notification-list::-webkit-scrollbar{width:4px}.notification-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.notification-item{align-items:flex-start;background:#0000;border:none;border-radius:10px;color:inherit;cursor:pointer;display:flex;font-family:inherit;gap:10px;padding:10px 12px;text-align:left;transition:background .15s;width:100%}.notification-item:hover{background:#ffffff08;background:var(--color-surface-hover,#ffffff08)}.notification-item.unread{background:#3b82f60a}.notification-item.unread:hover{background:#3b82f614}.notification-item-icon{align-items:center;background:#ffffff0d;border-radius:8px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.notification-item-icon.classification{background:#3b82f61a;color:#3b82f6}.notification-item-icon.import{background:#06b6d41a;color:#06b6d4}.notification-item-icon.scraper{background:#10b9811a;color:#10b981}.notification-item-icon.error{background:#ef44441a;color:#ef4444}.notification-item-content{flex:1 1;min-width:0}.notification-item-text{color:#fafafa;color:var(--color-text,#fafafa);font-size:13px;line-height:1.4;margin:0 0 2px}.notification-item-time{color:#71717a;color:var(--color-text-muted,#71717a);font-size:11px}.notification-unread-dot{background:#3b82f6;border-radius:50%;flex-shrink:0;height:8px;margin-top:6px;width:8px}.notification-empty{align-items:center;color:#71717a;color:var(--color-text-muted,#71717a);display:flex;flex-direction:column;gap:8px;padding:40px 16px}.notification-empty p{font-size:13px;margin:0}@media (max-width:480px){.notification-dropdown{animation:notifSlideUp .25s ease-out;border-radius:16px 16px 0 0;bottom:0;left:0;max-height:70vh;position:fixed;right:0;top:auto;width:100%}@keyframes notifSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}}.topnav{background-color:var(--color-surface);border-bottom:1px solid var(--color-border);box-shadow:var(--shadow-sm);height:var(--topnav-height);padding-top:env(safe-area-inset-top);position:relative;width:100%;z-index:var(--z-sticky)}.topnav-container{align-items:center;display:flex;gap:var(--space-2);height:100%;justify-content:space-between;max-width:100%;padding:0 var(--space-3)}@media (min-width:769px){.topnav-container{padding:0 var(--space-6)}}.topnav-left{gap:var(--space-4)}.topnav-brand,.topnav-left{align-items:center;display:flex}.topnav-brand{gap:var(--space-3)}.topnav-logo{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border-radius:var(--radius-md);color:#fff;display:flex;flex-shrink:0;height:30px;justify-content:center;width:30px}.topnav-logo svg{position:relative;z-index:1}.topnav-title{color:var(--color-text);display:none;font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}@media (min-width:640px){.topnav-title{display:block}}.department-selector{position:relative}.department-context{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;display:flex;font-family:inherit;gap:var(--space-3);padding:var(--space-2) var(--space-4);text-align:left;transition:all var(--transition-fast)}.department-context:hover{background:var(--color-surface-active);border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.department-context.open{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626}.dropdown-chevron{color:var(--color-text-muted);flex-shrink:0;margin-left:var(--space-2);transition:transform .2s ease}.dropdown-chevron.rotated{transform:rotate(180deg)}.department-placeholder{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-sm);gap:var(--space-2)}.department-dropdown{animation:dropdownSlideIn .2s ease-out;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);left:0;max-width:90vw;min-width:320px;overflow:hidden;position:absolute;top:calc(100% + 8px);z-index:9999}@keyframes dropdownSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.dropdown-search{border-bottom:1px solid var(--color-border);padding:var(--space-3);position:relative}.dropdown-search .search-icon{color:var(--color-text-muted);left:var(--space-5);pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.dropdown-search-input{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--text-sm);padding:var(--space-2) var(--space-3) var(--space-2) var(--space-10);transition:all var(--transition-fast);width:100%}.dropdown-search-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px #3b82f626;outline:none}.dropdown-search-input::placeholder{color:var(--color-text-muted)}.dropdown-list{max-height:320px;overflow-y:auto;padding:var(--space-2)}.dropdown-list::-webkit-scrollbar{width:6px}.dropdown-list::-webkit-scrollbar-track{background:#0000}.dropdown-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:3px}.dropdown-item{align-items:center;background:#0000;border:none;border-radius:var(--radius-lg);cursor:pointer;display:flex;font-family:inherit;gap:var(--space-3);padding:var(--space-2-5) var(--space-3);text-align:left;transition:all var(--transition-fast);width:100%}.dropdown-item:hover{background:var(--color-surface-hover)}.dropdown-item.selected{background:#3b82f61a}.dropdown-item-badge{align-items:center;background:var(--color-surface-active);border-radius:var(--radius-md);color:var(--color-text);display:flex;flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-bold);height:32px;justify-content:center;min-width:40px;padding:0 var(--space-2);text-transform:uppercase}.dropdown-item.selected .dropdown-item-badge{background:var(--color-primary);color:#fff}.dropdown-item-info{display:flex;flex:1 1;flex-direction:column;min-width:0}.dropdown-item-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dropdown-item-code{color:var(--color-text-muted);font-size:var(--text-xs)}.dropdown-item-check{color:var(--color-primary);flex-shrink:0}.dropdown-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-8) var(--space-4);text-align:center}@media (max-width:480px){.department-dropdown{animation:dropdownSlideUp .3s ease-out;border-radius:var(--radius-xl) var(--radius-xl) 0 0;bottom:0;left:0;max-height:70vh;max-width:100%;min-width:100%;position:fixed;right:0;top:auto}@keyframes dropdownSlideUp{0%{opacity:0;transform:translateY(100%)}to{opacity:1;transform:translateY(0)}}.dropdown-list{max-height:calc(70vh - 80px);padding-bottom:env(safe-area-inset-bottom)}}.department-badge{align-items:center;background:var(--department-badge-bg);border-radius:var(--radius-lg);display:flex;flex-shrink:0;justify-content:center;overflow:hidden;padding:10px;position:relative}.department-badge:before{background:linear-gradient(135deg,#ffffff1a,#0000 50%);bottom:0;content:"";left:0;pointer-events:none;position:absolute;right:0;top:0}.topnav .department-acronym{color:var(--department-badge-text);font-size:var(--text-sm);font-weight:var(--font-bold);letter-spacing:.025em;position:relative;text-transform:uppercase;white-space:nowrap;z-index:1}.department-info{display:flex;flex-direction:column;flex-shrink:0}.department-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);line-height:1.3;margin:0;white-space:nowrap}.department-code{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.3}.topnav-hamburger{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;padding:0;transition:all .15s;width:36px}.topnav-hamburger:hover{background:var(--color-surface-hover);color:var(--color-text)}.topnav-right{align-items:center;display:flex;flex-shrink:0;gap:var(--space-2);margin-left:auto}.department-context{gap:var(--space-2);max-width:40vw;overflow:hidden;padding:var(--space-1) var(--space-2)}.department-badge{min-height:32px;min-width:32px;padding:6px}.department-name,.topnav .department-acronym{font-size:var(--text-xs)}.department-name{overflow:hidden;text-overflow:ellipsis}.department-code,.department-info{display:none}@media (min-width:480px){.department-info{display:flex}.department-context{max-width:50vw}}@media (min-width:769px){.department-context{gap:var(--space-3);max-width:none;padding:var(--space-2) var(--space-4)}.department-badge{min-height:auto;min-width:auto;padding:10px}.department-name,.topnav .department-acronym{font-size:var(--text-sm)}.department-code{display:block}}.nav-sidebar{background:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;flex-shrink:0;height:100%;overflow:hidden;transition:width .2s ease;z-index:20}.nav-sidebar-icons{width:60px}.nav-sidebar-expanded{width:200px}.nav-sidebar-items{display:flex;flex:1 1;flex-direction:column;gap:2px;overflow-y:auto;padding:8px}.nav-sidebar-item{align-items:center;background:#0000;border:none;border-radius:10px;color:var(--color-text-muted);cursor:pointer;display:flex;font-family:inherit;font-size:14px;font-weight:500;gap:12px;padding:10px;position:relative;text-align:left;transition:all .15s ease;white-space:nowrap;width:100%}.nav-sidebar-item:hover{background:var(--color-surface-hover);color:var(--color-text)}.nav-sidebar-item.active{background:#3b82f61a;color:#3b82f6;color:var(--color-primary,#3b82f6)}.nav-sidebar-item.active:hover{background:#3b82f626}.nav-sidebar-indicator{background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:0 3px 3px 0;height:20px;left:0;position:absolute;top:50%;transform:translateY(-50%);width:3px}.nav-sidebar-item svg{flex-shrink:0;height:20px;width:20px}.nav-sidebar-label{overflow:hidden;text-overflow:ellipsis}.nav-sidebar-icons .nav-sidebar-item{justify-content:center;padding:12px 10px}.nav-sidebar-icons .nav-sidebar-indicator{left:0}.nav-sidebar-toggle{align-items:center;background:#0000;border:none;border-radius:8px;color:var(--color-text-muted);cursor:pointer;display:flex;justify-content:center;margin:8px;padding:12px;transition:all .15s}.nav-sidebar-toggle:hover{background:var(--color-surface-hover);color:var(--color-text)}@media (max-width:768px){.nav-sidebar{bottom:0;box-shadow:4px 0 24px #00000026;left:0;position:fixed;top:56px;top:var(--topnav-height,56px);z-index:1000}.nav-sidebar-expanded{width:220px}}.nav-sidebar-item--sandbox{border-top:1px solid #2d3148;border-top:1px solid var(--color-border,#2d3148);margin-top:auto;opacity:.7;padding-top:12px!important}.nav-sidebar-item--sandbox:hover{color:#fbbf24;opacity:1}.nav-sidebar-item--sandbox svg{color:#fbbf24}.home-page{margin:0 auto;max-width:1400px;padding:24px;width:100%}.home-error,.home-loading{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:12px;justify-content:center;min-height:400px}.home-error p,.home-loading p{font-size:15px;margin:0}.home-spin{animation:homeSpin 1s linear infinite}@keyframes homeSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.home-retry-btn{background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border:none;border-radius:10px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px}.home-stats-bar{align-items:center;display:flex;flex-wrap:wrap;gap:12px;margin-bottom:20px}.home-stat-pill{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:20px;color:var(--color-text-muted);display:flex;font-size:13px;gap:6px;padding:6px 14px;white-space:nowrap}.home-stat-pill strong{color:var(--color-text);font-weight:700}.home-stat-pill.freshness-current{border-color:#10b9814d;color:#10b981}.home-stat-pill.freshness-current strong{color:#10b981}.home-stat-pill.freshness-stale{border-color:#ef44444d;color:#ef4444}.home-stat-pill.freshness-stale strong{color:#ef4444}.home-controls{align-items:center;display:flex;flex-wrap:wrap;gap:16px;margin-bottom:24px}.home-search{flex:1 1;max-width:360px;min-width:200px;position:relative}.home-search-icon{color:var(--color-text-muted);left:12px;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%)}.home-search-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;color:var(--color-text);font-family:inherit;font-size:14px;padding:10px 12px 10px 36px;transition:border-color .15s;width:100%}.home-search-input:focus{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 0 0 3px #3b82f61f;outline:none}.home-search-input::placeholder{color:var(--color-text-muted)}.home-sort{align-items:center;display:flex;gap:4px}.home-sort-label{margin-right:4px;white-space:nowrap}.home-sort-btn,.home-sort-label{color:var(--color-text-muted);font-size:13px}.home-sort-btn{background:#0000;border:1px solid #0000;border-radius:8px;cursor:pointer;font-family:inherit;font-weight:500;padding:6px 12px;transition:all .15s}.home-sort-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.home-sort-btn.active{background:#3b82f61a;border-color:#3b82f633;color:#3b82f6;color:var(--color-primary,#3b82f6);font-weight:600}.home-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fill,minmax(340px,1fr))}.home-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:14px;color:inherit;cursor:pointer;display:flex;flex-direction:column;font-family:inherit;gap:16px;padding:20px;text-align:left;transition:all .2s ease;width:100%}.home-card:hover{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 4px 16px #3b82f61a;transform:translateY(-2px)}.home-card-header{justify-content:space-between}.home-card-header,.home-card-name{align-items:flex-start;display:flex;gap:12px}.home-card-name{min-width:0}.home-card-acronym{align-items:center;background:#3b82f61a;border-radius:10px;color:#3b82f6;color:var(--color-primary,#3b82f6);display:flex;flex-shrink:0;font-size:14px;font-weight:800;height:44px;justify-content:center;letter-spacing:.02em;min-width:44px;padding:0 10px;text-transform:uppercase}.home-card-name h3{color:var(--color-text);font-size:15px;font-weight:600;line-height:1.3;margin:0}.home-card-official{color:var(--color-text-muted);font-size:12px;line-height:1.3;margin:2px 0 0}.home-card-chevron{color:var(--color-text-muted);flex-shrink:0;margin-top:4px;opacity:0;transform:translateX(-4px);transition:all .2s}.home-card:hover .home-card-chevron{opacity:1;transform:translateX(0)}.home-card-stats{display:flex;gap:8px}.home-card-stat{align-items:center;background:var(--color-background);border-radius:10px;display:flex;flex:1 1;flex-direction:column;gap:2px;padding:10px 8px}.home-card-stat svg{color:var(--color-text-muted)}.home-card-stat-value{color:var(--color-text);font-size:16px;font-weight:700;line-height:1.2}.home-card-stat-label{color:var(--color-text-muted);font-size:11px;font-weight:500;letter-spacing:.04em;text-transform:uppercase}.home-card-footer{align-items:center;display:flex;gap:8px;justify-content:space-between}.home-card-date-range{align-items:center;color:var(--color-text-muted);display:flex;font-size:12px;gap:5px}.home-card-freshness{border-radius:12px;font-size:11px;font-weight:600;letter-spacing:.02em;padding:3px 10px}.home-empty{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:12px;padding:60px 20px;text-align:center}.home-empty p{font-size:15px;margin:0}@media (max-width:768px){.home-page{padding:16px}.home-grid{grid-template-columns:1fr}.home-controls{align-items:stretch;flex-direction:column}.home-search{max-width:none}.home-sort{flex-wrap:wrap}.home-stats-bar{gap:8px}.home-stat-pill{font-size:12px;padding:5px 10px}}@media (max-width:480px){.home-card-stats{flex-direction:column}.home-card-stat{flex-direction:row;justify-content:space-between;padding:8px 12px}}.assessment-container{animation:slideIn .3s ease-out;background-color:#f9fafb;bottom:0;left:var(--sidebar-width);overflow-y:auto;position:fixed;right:0;top:0;z-index:1000}.assessment-header{background-color:#fff;border-bottom:1px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;padding:1.5rem;position:sticky;top:0;z-index:100}.assessment-title-section{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.assessment-title{color:#111827;font-size:1.5rem;font-weight:600;margin:0}.assessment-close-button{background:none;border:none;color:#6b7280;cursor:pointer;font-size:1.5rem;padding:.5rem;transition:color .2s}.assessment-close-button:hover{color:#111827}.assessment-metrics{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.metric-card{background-color:#f3f4f6;border-radius:.5rem;padding:1rem;text-align:center}.metric-value{color:#111827;font-size:2rem;font-weight:700;margin-bottom:.25rem}.metric-label{color:#6b7280;font-size:.875rem;margin-bottom:.25rem}.metric-percent{color:#3b82f6;font-size:.75rem;font-weight:600}.assessment-controls{align-items:center;background-color:#fff;border-bottom:1px solid #e5e7eb;display:flex;flex-wrap:wrap;gap:1rem;justify-content:space-between;padding:1rem 1.5rem}.assessment-filters{display:flex;flex:1 1;flex-wrap:wrap;gap:.75rem}.assessment-search{flex:1 1;min-width:250px}.assessment-filter,.assessment-search{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem 1rem}.assessment-filter{background-color:#fff;cursor:pointer}.assessment-actions{align-items:center;display:flex;gap:.75rem}.selected-count{color:#3b82f6;font-size:.875rem;font-weight:500}.assessment-button{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .2s}.assessment-button:hover{background-color:#f3f4f6;border-color:#9ca3af}.assessment-button:disabled{cursor:not-allowed;opacity:.5}.bulk-actions-bar{align-items:center;background-color:#eff6ff;border-bottom:1px solid #3b82f6;display:flex;flex-wrap:wrap;gap:1rem;padding:1rem 1.5rem}.bulk-actions-label{color:#1e40af;font-size:.875rem;font-weight:500}.bulk-action-button{background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;padding:.375rem .75rem;transition:background-color .2s}.bulk-action-button:hover{background-color:#2563eb}.bulk-action-button.secondary{background-color:#6b7280}.bulk-action-button.secondary:hover{background-color:#4b5563}.bulk-action-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.375rem .75rem}.assessment-table-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin:1.5rem;overflow-x:auto}.assessment-table{border-collapse:collapse;width:100%}.assessment-table thead{background-color:#f9fafb;border-bottom:2px solid #e5e7eb}.assessment-table th{color:#374151;font-size:.875rem;font-weight:600;padding:1rem;text-align:left;white-space:nowrap}.assessment-table td.checkbox-column,.assessment-table th.checkbox-column{text-align:center;width:40px}.assessment-table td.center-column,.assessment-table th.center-column{text-align:center}.assessment-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .2s}.assessment-table tbody tr:hover{background-color:#f9fafb}.assessment-table tbody tr.has-capability{background-color:#f0fdf4}.assessment-table tbody tr.has-capability:hover{background-color:#dcfce7}.assessment-table td{color:#111827;font-size:.875rem;padding:.75rem 1rem}.capability-cell{min-width:250px}.capability-info{display:flex;flex-direction:column;gap:.25rem}.capability-info strong{color:#111827;font-weight:600}.capability-category{background-color:#f3f4f6;border-radius:.25rem;color:#6b7280;display:inline-block;font-size:.75rem;padding:.125rem .5rem;width:fit-content}.capability-description{color:#6b7280;font-size:.75rem;margin-top:.25rem}.phase-badge{margin-left:.5rem;padding:.125rem .5rem}.capability-checkbox{accent-color:#3b82f6;cursor:pointer;height:18px;width:18px}.assessment-input{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.375rem .5rem;transition:border-color .2s;width:100%}.assessment-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.assessment-input:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.assessment-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.375rem .5rem;transition:all .2s;width:100%}.assessment-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.assessment-select:disabled{background-color:#f3f4f6;color:#9ca3af;cursor:not-allowed}.notes-cell{min-width:200px}.notes-container{align-items:flex-start;display:flex;gap:.5rem;position:relative}.assessment-notes{border:1px solid #d1d5db;border-radius:.375rem;font-family:inherit;font-size:.875rem;min-height:32px;padding:.375rem .5rem;resize:vertical;transition:all .2s;width:100%}.assessment-notes:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.assessment-notes.expanded{min-height:80px}.expand-notes-button{background:none;border:none;color:#6b7280;cursor:pointer;font-size:.75rem;padding:.25rem}.assessment-empty-state{font-size:.875rem}.assessment-empty-state,.assessment-loading{color:#6b7280;padding:3rem;text-align:center}.assessment-loading{font-size:1rem}.assessment-loading:before{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;content:"";display:inline-block;height:2rem;margin-bottom:1rem;width:2rem}.saving-indicator{align-items:center;animation:fadeIn .2s ease-out;background-color:#111827;border-radius:.5rem;bottom:2rem;box-shadow:0 4px 6px #0000001a;color:#fff;display:flex;gap:.75rem;padding:.75rem 1.5rem;position:fixed;right:2rem}.saving-spinner{animation:spin .6s linear infinite;border:2px solid #ffffff4d;border-radius:50%;border-top-color:#fff;height:1rem;width:1rem}@media (max-width:1024px){.assessment-container{left:0}.assessment-metrics{grid-template-columns:repeat(2,1fr)}.assessment-filters{flex-direction:column;width:100%}.assessment-search{width:100%}}@media (max-width:767px){.assessment-container{left:0}.assessment-metrics{grid-template-columns:1fr}.assessment-filters{flex-direction:column;width:100%}.assessment-search{width:100%}.assessment-controls{flex-direction:column;gap:8px}.assessment-controls button{width:100%}.assessment-table,.assessment-table tbody,.assessment-table td,.assessment-table th,.assessment-table thead,.assessment-table tr{display:block}.assessment-table thead tr{display:none}.assessment-table tr{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px;overflow:hidden}.assessment-table td{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;max-width:none!important;min-width:0!important;padding:8px 12px}.assessment-table td:before{color:#666;content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px}.capability-cell,.notes-cell{min-width:0}.coverage-stats{grid-template-columns:1fr}.deployment-coverage-summary{margin:1rem;padding:1rem}}.component-link-cell{align-items:center;display:flex;gap:.5rem}.link-component-button{background-color:#e0e7ff;border:1px solid #818cf8;border-radius:.375rem;cursor:pointer;font-size:.75rem;padding:.25rem .5rem;transition:all .2s}.link-component-button:hover{background-color:#c7d2fe;border-color:#6366f1}.linked-components-badge{background-color:#ede9fe;border-radius:.25rem;color:#4c1d95;font-size:.75rem;max-width:150px;overflow:hidden;padding:.125rem .5rem;text-overflow:ellipsis;white-space:nowrap}.component-list{max-height:400px;overflow-y:auto;padding:1rem 0}.component-item{border-bottom:1px solid #e5e7eb;padding:.5rem}.component-item:last-child{border-bottom:none}.component-label{align-items:center;border-radius:.375rem;cursor:pointer;display:flex;gap:.75rem;padding:.5rem;transition:background-color .2s}.component-label:hover{background-color:#f9fafb}.component-label input[type=checkbox]{accent-color:#8b5cf6;cursor:pointer;height:18px;width:18px}.component-icon{font-size:1.5rem}.component-name{flex:1 1;font-weight:500}.component-type{color:#6b7280;font-size:.875rem}.no-components-message{color:#6b7280;font-style:italic;padding:2rem;text-align:center}.deployment-coverage-summary{background-color:#f3f4f6;border-radius:.5rem;margin:1.5rem 1.5rem 0;padding:1.5rem}.deployment-coverage-summary h3{color:#374151;font-size:1.125rem;margin:0 0 1rem}.coverage-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.coverage-stat{background-color:#fff;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem}.stat-label{font-size:.875rem;margin-bottom:.25rem}.stat-label,.stat-value{display:block}.assessment-table tr.has-linked-components{background-color:#f0f9ff;border-left:3px solid #3b82f6}.assessment-table tr.has-capability.deployed-and-linked{background-color:#ecfdf5;border-left:3px solid #10b981}.content-area{box-sizing:border-box;display:flex;flex-direction:column;height:100%;min-height:0;overflow:hidden;padding:var(--space-6)}.dashboard-header{align-items:center;background-color:#f9fafb;border-radius:.5rem;display:flex;justify-content:space-between;margin-bottom:1.5rem;padding:1rem}.dashboard-customer-title{color:#374151;font-size:1.125rem;font-weight:600;margin:0}.customer-meta{color:#6b7280;font-size:.875rem;margin-left:1rem}.dashboard-controls{display:flex;gap:.75rem}.connection-instructions{background-color:#fef3c7;border:1px solid #fbbf24;border-radius:.5rem;margin-bottom:1rem;padding:1rem}.connection-instructions-content{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem}.connection-instructions-icon{font-size:1.25rem}.connection-instructions-text{color:#92400e;flex:1 1;font-weight:500}.connection-start-badge{background-color:#f59e0b;border-radius:9999px;color:#fff;font-size:.75rem;padding:.25rem .75rem}.dashboard-container{display:flex;flex:1 1;gap:var(--space-6);min-height:0}.tech-palette{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;overflow-y:auto;padding:1.5rem;width:250px}.tech-palette-title{color:#374151;font-size:1rem;font-weight:600;margin-bottom:1rem}.tech-items{flex-direction:column;margin-bottom:1rem}.tech-item,.tech-items{display:flex;gap:.75rem}.tech-item{align-items:center;background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:.75rem;transition:all .15s}.tech-item:hover{background-color:#f3f4f6;box-shadow:0 2px 4px #0000001a;transform:translateY(-2px)}.tech-item.disabled{opacity:.5}.tech-item.disabled:hover{box-shadow:none;transform:none}.tech-item-firewall{border-left:4px solid #ef4444}.tech-item-switch{border-left:4px solid #3b82f6}.tech-item-wireless{border-left:4px solid #10b981}.tech-item-software{border-left:4px solid #8b5cf6}.tech-item-cloud{border-left:4px solid #f59e0b}.tech-item-server{border-left:4px solid #6b7280}.tech-item-icon{font-size:1.25rem;min-width:24px}.tech-item-name{color:#374151;font-size:.875rem;font-weight:500}.tech-palette-hint{color:#6b7280;font-size:.75rem;font-style:italic;line-height:1.5;margin-top:1rem}.connection-types-reference{background-color:#f8fafc;border-radius:.5rem;border-top:1px solid #e5e7eb;margin-top:1.5rem;padding:1rem}.connection-types-title{color:#374151;font-size:.875rem;font-weight:600;margin-bottom:.75rem}.connection-types-list{display:flex;flex-direction:column;gap:.5rem}.connection-type-item{align-items:center;color:#6b7280;display:flex;font-size:.75rem;gap:.5rem}.connection-type-item-icon{align-items:center;display:inline-flex;font-size:.875rem;height:20px;justify-content:center;width:20px}.connection-type-item-name{font-size:.75rem;font-weight:500}.canvas-container{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);flex:1 1}.canvas,.canvas-container{overflow:hidden;position:relative}.canvas{height:100%;width:100%}.canvas-placeholder{color:var(--color-text-muted);left:50%;max-width:400px;position:absolute;text-align:center;top:50%;transform:translate(-50%,-50%)}.canvas-placeholder-title{color:var(--color-text);font-size:1.125rem;font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.canvas-placeholder-text{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.5}.selected-element-capabilities{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);bottom:20px;box-shadow:var(--shadow-md);max-width:300px;padding:var(--space-4);position:absolute;right:20px;z-index:100}.selected-element-capabilities h4{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0 0 var(--space-2) 0}.selected-element-capabilities ul{font-size:var(--text-sm);list-style-type:disc;margin:0;padding-left:1.5rem}.selected-element-capabilities li{color:var(--color-text-muted);margin-bottom:var(--space-1)}.selected-element-capabilities strong{color:var(--color-text);font-weight:var(--font-semibold)}.modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:50}.modal-content{background-color:#fff;border-radius:.5rem;box-shadow:0 20px 25px -5px #0000001a;max-width:28rem;padding:1.5rem;width:100%}.modal-title{color:#1f2937;font-size:1.125rem;margin-bottom:1rem}.modal-description{color:#4b5563;margin-bottom:1rem}.modal-form{display:flex;flex-direction:column;gap:1rem}.form-label{color:#374151;display:block;font-size:.875rem;font-weight:500;margin-bottom:.25rem}.form-select{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;color:#1f2937;font-size:.875rem;padding:.5rem .75rem;width:100%}.form-select:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.form-textarea{border:1px solid #d1d5db;border-radius:.375rem;font-size:.875rem;padding:.5rem .75rem;resize:none;width:100%}.form-textarea:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.connection-type-preview{background-color:#f9fafb;border-radius:.375rem;margin:.5rem 0;padding:1rem}.connection-type-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;height:40px;justify-content:center;width:40px}.connection-type-description{color:#6b7280;flex:1 1;font-size:.875rem}.modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1rem}.insights-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-top:1.5rem;padding:1.5rem}.insights-title{color:#4b5563;font-size:1rem;font-weight:600;margin-bottom:1rem}.insights-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.insight-card{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;padding:1rem;text-align:center}.insight-value{color:#3b82f6;font-size:2rem;font-weight:600;margin-bottom:.25rem}.insight-label{color:#6b7280;font-size:.875rem;letter-spacing:.05em;margin-top:.25rem;text-transform:uppercase}.insight-card:last-child{background-color:#f0fdf4;border:1px solid #86efac}.insight-card:last-child .insight-value{color:#059669}.empty-state-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:2rem;text-align:center}.empty-state-title{color:#374151;font-size:1.125rem;font-weight:600;margin-bottom:.5rem}.empty-state-text{color:#6b7280}@media (max-width:767px){.content-area{padding:var(--space-3)}.dashboard-header{align-items:flex-start;flex-direction:column;gap:8px;padding:12px}.dashboard-controls{flex-wrap:wrap;gap:8px;width:100%}.dashboard-controls .btn{flex:1 1;min-width:0}.customer-meta{margin-left:0}.dashboard-container{flex-direction:column}.tech-palette{max-height:35vh;padding:12px;width:100%}.tech-items{grid-gap:8px;display:grid;gap:8px;grid-template-columns:1fr 1fr}.canvas-container{height:50vh;min-height:300px}.selected-element-capabilities{bottom:10px;left:10px;max-width:none;position:fixed;right:10px}.insights-grid{grid-template-columns:repeat(2,1fr)}.insight-value{font-size:1.5rem}.modal-content{max-width:calc(100vw - 32px);padding:1rem}.connection-instructions-content{flex-direction:column;text-align:center}}@media (max-width:480px){.insights-grid{grid-template-columns:1fr}}.canvas-element{align-items:center;background-color:var(--color-surface);border-radius:var(--radius-md);border-style:solid;border-width:2px;box-shadow:var(--shadow-sm);cursor:move;display:flex;flex-direction:column;gap:var(--space-1);justify-content:center;padding:var(--space-3);position:absolute;transition:box-shadow var(--transition-fast),transform var(--transition-fast);-webkit-user-select:none;user-select:none}.canvas-element-firewall{border-color:#ef4444}.canvas-element-firewall .element-icon{color:#ef4444}.canvas-element-switch{border-color:#3b82f6}.canvas-element-switch .element-icon{color:#3b82f6}.canvas-element-wireless{border-color:#10b981}.canvas-element-wireless .element-icon{color:#10b981}.canvas-element-software{border-color:#8b5cf6}.canvas-element-software .element-icon{color:#8b5cf6}.canvas-element-cloud{border-color:#f59e0b}.canvas-element-cloud .element-icon{color:#f59e0b}.canvas-element-server{border-color:#6b7280}.canvas-element-server .element-icon{color:#6b7280}.canvas-element:hover{box-shadow:0 4px 6px -1px #0000001a;transform:translateY(-2px)}.canvas-element.selected{border-color:#6366f1!important;box-shadow:0 0 0 3px #6366f14d}.canvas-element.connection-start{animation:pulse 1.5s infinite;border-color:#f59e0b!important;box-shadow:0 0 0 3px #f59e0b4d}.canvas-element.connecting{cursor:pointer}.canvas-element.connecting:not(.selected):hover{transform:translateY(-2px) scale(1.02)}.canvas-element.dragging{box-shadow:0 8px 16px #0003;cursor:grabbing;opacity:.8;transform:scale(1.05);z-index:1000}.element-icon{font-size:1.5rem}.element-name{color:var(--color-text);font-size:var(--text-xs);font-weight:var(--font-medium);line-height:1.2;text-align:center;white-space:nowrap}.element-delete-button{align-items:center;background-color:#ef4444;border:none;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-size:.75rem;height:20px;justify-content:center;position:absolute;right:-8px;top:-8px;width:20px}.element-delete-button:hover{background-color:#dc2626}.canvas-element.has-capabilities{border:2px solid #10b981;box-shadow:0 0 0 2px #10b9811a}.canvas-element.has-capabilities:hover{border-color:#059669;box-shadow:0 0 0 3px #10b98133}.element-capabilities-badge{align-items:center;animation:pulseOnce .6s ease-out;background-color:#10b981;border-radius:50%;box-shadow:0 2px 4px #0003;color:#fff;cursor:help;display:flex;font-size:.75rem;font-weight:600;height:24px;justify-content:center;position:absolute;right:-8px;top:-8px;width:24px;z-index:10}.capabilities-count{font-size:.875rem}.capabilities-icon{bottom:2px;font-size:.625rem;position:absolute;right:2px}.canvas{background-color:var(--color-surface);background-image:radial-gradient(circle,var(--canvas-grid-color) 1px,#0000 1px);background-position:0 0,10px 10px;background-size:20px 20px;cursor:grab}.canvas.connecting{cursor:crosshair}.tech-item{cursor:move;-webkit-user-select:none;user-select:none}.tech-item:active{cursor:grabbing}.tech-item.disabled{cursor:not-allowed}.canvas-svg{height:100%;left:0;pointer-events:none;position:absolute;top:0;width:100%;z-index:1}.canvas-svg circle,.canvas-svg path,.canvas-svg text{pointer-events:all}.connection-line{cursor:pointer;transition:all .3s ease}.connection-line:hover{stroke-width:3;opacity:.6!important}.connection-icon-circle{cursor:pointer;transition:all .2s ease}.connection-icon-circle:hover{r:12;opacity:.5!important}.connection-icon-text{font-size:10px;pointer-events:none}.connection-delete-circle{cursor:pointer}@keyframes dash{to{stroke-dashoffset:-10}}.connection-preview{animation:dash 2s linear infinite;opacity:.7;pointer-events:none}@keyframes pulseOnce{0%{transform:scale(0)}50%{transform:scale(1.2)}to{transform:scale(1)}}.connection-instructions{animation:slideDown .3s ease-out}.selected-element-capabilities{animation:slideIn .2s ease-out}Modal backdrop filter
.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.canvas-placeholder{pointer-events:none}@media (max-width:768px){.selected-element-capabilities{bottom:10px;left:10px;max-width:none;position:fixed;right:10px}}@media print{.connection-instructions,.dashboard-controls,.tech-palette{display:none}.dashboard-container{height:auto}.canvas{height:100vh}}.connection-types-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:2rem}.page-description{color:#6b7280;font-size:.875rem;max-width:600px}.add-button{background-color:#3b82f6;border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.875rem;font-weight:500;padding:.75rem 1.5rem;transition:background-color .15s}.add-button:hover{background-color:#2563eb}.connection-types-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fill,minmax(350px,1fr))}.connection-type-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;padding:1.5rem;transition:all .15s}.connection-type-card:hover{border-color:#d1d5db;box-shadow:0 4px 6px -1px #0000001a}.connection-type-card-header{align-items:flex-start;display:flex;gap:1rem;margin-bottom:1rem}.connection-type-icon-large{align-items:center;border-radius:.5rem;color:#fff;display:flex;flex-shrink:0;font-size:1.5rem;height:48px;justify-content:center;width:48px}.connection-type-card-info{flex:1 1}.connection-type-card-name{color:#111827;font-size:1rem;font-weight:600;margin:0 0 .25rem}.connection-type-card-id{color:#6b7280;font-family:monospace;font-size:.75rem;margin:0}.connection-type-card-actions{display:flex;gap:.5rem}.delete-button,.edit-button{align-items:center;background-color:#f3f4f6;border:1px solid #e5e7eb;border-radius:.375rem;cursor:pointer;display:flex;font-size:.875rem;height:32px;justify-content:center;transition:all .15s;width:32px}.edit-button:hover{background-color:#e5e7eb}.delete-button:hover{background-color:#fee2e2;border-color:#fecaca}.connection-type-card-description{color:#6b7280;font-size:.875rem;line-height:1.5;margin-bottom:1rem}.connection-type-card-footer{align-items:center;border-top:1px solid #f3f4f6;display:flex;justify-content:space-between;padding-top:1rem}.connection-type-color-badge{align-items:center;border-radius:9999px;color:#fff;display:inline-flex;font-family:monospace;font-size:.75rem;font-weight:500;padding:.25rem .75rem}.connection-type-order{color:#9ca3af;font-size:.75rem}.connection-type-preview-box{background-color:#f9fafb;border:1px solid #e5e7eb;border-radius:.375rem;margin-top:1rem;padding:1rem}.connection-type-preview-box h4{color:#6b7280;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.connection-type-preview{align-items:center;display:flex;gap:1rem;padding:.5rem}.connection-type-preview .connection-type-icon{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1.25rem;height:40px;justify-content:center;width:40px}.connection-type-preview strong{color:#111827;font-size:.875rem}.connection-type-preview .connection-type-description{color:#6b7280;font-size:.75rem;line-height:1.4;margin-top:.25rem}@media (max-width:767px){.connection-types-header{align-items:flex-start;flex-direction:column;gap:1rem}.add-button{min-height:44px;width:100%}.connection-types-grid{grid-template-columns:1fr}.connection-type-card{width:100%}.delete-button,.edit-button{min-height:44px;min-width:44px}}.export-menu{display:inline-block;position:relative}.export-menu-btn{align-items:center;background:#fff;background:var(--color-surface,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:6px;border-radius:var(--radius-md,6px);color:#334155;color:var(--color-text,#334155);cursor:pointer;display:inline-flex;font-size:14px;font-size:var(--text-sm,14px);font-weight:500;font-weight:var(--font-medium,500);gap:4px;gap:var(--space-1,4px);padding:8px 12px;padding:var(--space-2,8px) var(--space-3,12px);transition:all .15s ease}.export-menu-btn:hover:not(:disabled){background:#f8fafc;background:var(--color-surface-hover,#f8fafc);border-color:#cbd5e1;border-color:var(--color-border-hover,#cbd5e1)}.export-menu-btn:disabled{cursor:not-allowed;opacity:.5}.export-menu-btn svg.rotated{transform:rotate(180deg)}.export-menu-btn-sm{font-size:12px;font-size:var(--text-xs,12px);padding:4px 8px;padding:var(--space-1,4px) var(--space-2,8px)}.export-menu-btn-md{font-size:14px;font-size:var(--text-sm,14px);padding:8px 12px;padding:var(--space-2,8px) var(--space-3,12px)}.export-menu-dropdown{animation:exportMenuFadeIn .15s ease;background:#fff;background:var(--color-surface,#fff);border:1px solid #e2e8f0;border:1px solid var(--color-border,#e2e8f0);border-radius:6px;border-radius:var(--radius-md,6px);box-shadow:0 10px 15px -3px #0000001a;box-shadow:var(--shadow-lg,0 10px 15px -3px #0000001a);min-width:180px;overflow:hidden;position:absolute;right:0;top:calc(100% + 4px);z-index:50}@keyframes exportMenuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.export-menu-header{background:#f8fafc;background:var(--color-surface-hover,#f8fafc);border-bottom:1px solid #e2e8f0;border-bottom:1px solid var(--color-border,#e2e8f0);color:#64748b;color:var(--color-text-muted,#64748b);font-size:12px;font-size:var(--text-xs,12px);font-weight:500;font-weight:var(--font-medium,500)}.export-menu-header,.export-menu-item{padding:8px 12px;padding:var(--space-2,8px) var(--space-3,12px)}.export-menu-item{align-items:center;background:none;border:none;color:#334155;color:var(--color-text,#334155);cursor:pointer;display:flex;font-size:14px;font-size:var(--text-sm,14px);gap:8px;gap:var(--space-2,8px);text-align:left;transition:background .1s ease;width:100%}.export-menu-item:hover{background:#f8fafc;background:var(--color-surface-hover,#f8fafc)}.export-menu-item svg{color:#64748b;color:var(--color-text-muted,#64748b);flex-shrink:0}.export-menu-item:hover svg{color:#334155;color:var(--color-text,#334155)}.export-success{color:#22c55e!important;color:var(--color-success,#22c55e)!important}.export-menu-hint{background:#f1f5f9;background:var(--color-surface-hover,#f1f5f9);border-radius:4px;border-radius:var(--radius-sm,4px);color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:11px;font-size:var(--text-xs,11px);margin-left:auto;padding:2px 6px}@media (prefers-color-scheme:dark){.export-menu-btn{background:#1e293b;background:var(--color-surface,#1e293b);border-color:#334155;border-color:var(--color-border,#334155);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.export-menu-btn:hover:not(:disabled){background:#334155;background:var(--color-surface-hover,#334155)}.export-menu-dropdown{background:#1e293b;background:var(--color-surface,#1e293b);border-color:#334155;border-color:var(--color-border,#334155)}.export-menu-header{background:#0f172a;background:var(--color-surface-hover,#0f172a)}.export-menu-item:hover{background:#334155;background:var(--color-surface-hover,#334155)}}.editable-data-table{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);display:flex;flex-direction:column;height:100%}.edt-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-4)}.edt-title{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0}.edt-controls{align-items:center;display:flex;gap:var(--space-2)}.edt-search{width:200px}.btn-danger{background-color:color-mix(in srgb,var(--color-error) 20%,#0000);border-color:color-mix(in srgb,var(--color-error) 40%,#0000);color:var(--color-error)}.btn-danger:hover{background-color:color-mix(in srgb,var(--color-error) 30%,#0000)}.icon-only{padding:var(--space-2)}.icon-only svg{margin:0}.edt-column-selector{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4)}.edt-column-selector h4{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium);margin:0 0 var(--space-2) 0}.edt-column-list{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.edt-column-item{align-items:center;color:var(--color-text);display:flex;font-size:var(--text-sm);gap:var(--space-2)}.edt-table-container{flex:1 1;overflow:auto}.edt-table{border-collapse:collapse;width:100%}.edt-th{background:var(--color-surface-hover);border-bottom:2px solid var(--color-border);border-right:1px solid var(--color-border);color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium);padding:0;position:relative;text-align:left}.edt-th:last-child{border-right:none}.edt-th-content{justify-content:space-between;padding:var(--space-3);position:relative}.edt-th-content,.edt-th-label{align-items:center;display:flex}.edt-th-label{flex:1 1;gap:var(--space-1);-webkit-user-select:none;user-select:none}.edt-th-label.sortable{cursor:pointer;transition:color var(--transition-fast)}.edt-th-label.sortable:hover{color:var(--color-primary)}.edt-sort-indicator{opacity:.5;transition:opacity var(--transition-fast)}.edt-th-label:hover .edt-sort-indicator{opacity:1}.edt-filter-button{align-items:center;background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-xs);gap:var(--space-1);padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.edt-filter-button:hover{background:var(--color-surface-hover);color:var(--color-text)}.edt-filter-button.active{background:var(--color-primary);color:var(--color-text-inverse)}.edt-filter-count{font-weight:var(--font-medium)}.edt-resize-handle{align-items:center;bottom:0;color:var(--color-text-subtle);cursor:col-resize;display:flex;justify-content:center;opacity:0;position:absolute;right:-3px;top:0;transition:opacity var(--transition-fast);width:6px}.edt-th:hover .edt-resize-handle{opacity:1}.edt-resize-handle:hover{color:var(--color-primary)}.edt-filter-dropdown{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;margin-top:var(--space-1);max-height:400px;max-width:300px;min-width:200px;position:absolute;right:var(--space-2);top:100%;z-index:var(--z-dropdown)}.edt-filter-header{align-items:center;border-bottom:1px solid var(--color-border);color:var(--color-text);display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);justify-content:space-between;padding:var(--space-2) var(--space-3)}.edt-filter-actions{display:flex;gap:var(--space-2)}.edt-filter-actions button{border-radius:var(--radius-sm);cursor:pointer;font-size:var(--text-xs);padding:var(--space-1) var(--space-2);transition:background var(--transition-fast)}.edt-filter-options{overflow-y:auto;padding:var(--space-2)}.edt-filter-option{align-items:center;border-radius:var(--radius-sm);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-2);padding:var(--space-2);transition:background var(--transition-fast)}.edt-filter-option:hover{background:var(--color-surface-hover)}.edt-table td{border-bottom:1px solid var(--color-border);padding:0}.edt-cell{align-items:center;color:var(--color-text);display:flex;font-size:var(--text-sm);min-height:2.5rem;padding:var(--space-3)}.edt-cell.editable{cursor:pointer;position:relative;transition:background var(--transition-fast)}.edt-cell.editable:hover{background:var(--color-surface-hover)}.edt-cell.editable:hover:after{animation:slideIn .2s forwards;background:var(--color-primary);bottom:0;content:"";left:0;opacity:0;position:absolute;top:0;width:3px}.edt-cell.non-editable{background:var(--color-surface-hover);color:var(--color-text-muted);cursor:not-allowed}.edt-empty{color:var(--color-text-subtle);font-size:var(--text-sm);font-style:italic}.edt-cell-input{background:var(--color-surface);border:2px solid var(--color-primary);border-radius:var(--radius-sm);box-shadow:0 0 0 3px #0000000d;font-family:inherit;font-size:var(--text-sm);outline:none;padding:var(--space-2);width:100%}.edt-cell-saving{align-items:center;color:var(--color-text-muted);display:flex;font-style:italic;gap:var(--space-2);padding:var(--space-3)}.edt-saving-indicator{color:var(--color-primary)}.edt-cell-saved{align-items:center;animation:flash .3s ease;background:#d1fae5;display:flex;gap:var(--space-2);padding:var(--space-3)}@keyframes flash{0%{background:#a7f3d0}to{background:#d1fae5}}.edt-saved-indicator{color:var(--color-success)}.edt-new-row{background:var(--color-surface-hover)}.edt-new-input{width:100%}.edt-actions{padding:var(--space-2);text-align:center;width:80px}.edt-actions .btn{margin:0 var(--space-1)}.edt-empty-state{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-10);text-align:center}.edt-footer{border-top:1px solid var(--color-border);display:flex;font-size:var(--text-sm);gap:var(--space-4);padding:var(--space-3) var(--space-4)}.edt-fullscreen-overlay{align-items:center;animation:fadeIn var(--transition-base);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000c;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:var(--z-modal)}.edt-fullscreen-container{animation:slideUp var(--transition-slow);background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;height:95%;position:relative;width:95%}.edt-fullscreen-close{align-items:center;background:var(--color-surface-hover);border:none;border-radius:var(--radius-full);color:var(--color-text);cursor:pointer;display:flex;height:40px;justify-content:center;position:absolute;right:var(--space-4);top:var(--space-4);transition:all var(--transition-fast);width:40px;z-index:10}.edt-fullscreen-close:hover{background:var(--color-surface-active);transform:rotate(90deg)}.fullscreen-mode{border-radius:var(--radius-xl);height:100%}.fullscreen-mode .edt-table-container{max-height:calc(100% - 120px)}.editable-data-table.compact .edt-cell{font-size:var(--text-xs);min-height:2rem;padding:var(--space-2)}.editable-data-table.compact .edt-th-content{padding:var(--space-2)}.editable-data-table.compact .edt-new-input{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}body.col-resizing,body.col-resizing *{cursor:col-resize!important;-webkit-user-select:none!important;user-select:none!important}@media (max-width:767px){.edt-header{align-items:stretch;flex-direction:column;gap:var(--space-3);padding:var(--space-3)}.edt-controls{flex-wrap:wrap}.edt-search{width:100%}.edt-column-list{grid-template-columns:1fr}.edt-resize-handle{display:none}.edt-table,.edt-table tbody,.edt-table td,.edt-table th,.edt-table thead,.edt-table tr{display:block}.edt-table thead tr{display:none}.edt-table tr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);margin-bottom:var(--space-3);overflow:hidden}.edt-table td{align-items:center;border-bottom:1px solid var(--color-surface-hover);display:flex;justify-content:space-between;min-height:auto;padding:0}.edt-table td:last-child{border-bottom:none}.edt-table td:before{color:var(--color-text-muted);content:attr(data-label);flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;min-width:100px;text-transform:uppercase}.edt-cell,.edt-table td:before{padding:var(--space-2) var(--space-3)}.edt-cell{flex:1 1;justify-content:flex-end;text-align:right}.edt-actions{background:var(--color-surface-hover);border-top:1px solid var(--color-border);justify-content:center;width:auto}.edt-actions,.edt-new-row td{display:flex;padding:var(--space-2) var(--space-3)}.edt-new-row td{align-items:stretch;flex-direction:column}.edt-new-row td:before{margin-bottom:var(--space-1);text-align:left}.edt-footer{flex-direction:column;gap:var(--space-2)}.edt-fullscreen-container{border-radius:0;height:100%;width:100%}}.capabilities-header{margin-bottom:1.5rem}.capabilities-controls{gap:1rem;margin-bottom:1.5rem}.capabilities-search{background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;flex:1 1;font-size:.875rem;min-width:250px;padding:.5rem}.capabilities-search:focus{border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a;outline:none}.capabilities-button{border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s;white-space:nowrap}.capabilities-button-add{background-color:#3b82f6;color:#fff}.capabilities-button-add:hover{background-color:#2563eb}.capabilities-button-import{background-color:#10b981;color:#fff}.capabilities-button-import:hover{background-color:#059669}.capabilities-table-container{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;overflow:auto}.capabilities-table-container::-webkit-scrollbar{height:8px}.capabilities-table-container::-webkit-scrollbar-track{background:#f3f4f6;border-radius:0 0 .5rem .5rem}.capabilities-table-container::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.capabilities-table-container::-webkit-scrollbar-thumb:hover{background:#9ca3af}.capabilities-table{border-collapse:collapse;font-size:.875rem;width:100%}.capabilities-table thead tr{background-color:#f9fafb;border-bottom:1px solid #e5e7eb}.capabilities-table th{color:#374151;padding:.75rem 1rem}.capabilities-table th.sortable-header{color:#374151;cursor:pointer;font-weight:600;padding:.75rem 1rem;text-align:left;transition:background-color .15s;-webkit-user-select:none;user-select:none}.capabilities-table th.actions-column{text-align:center;width:100px}.sortable-header{transition:background-color .15s}.sortable-header:hover{background-color:#f3f4f6}.sort-indicator{color:#6b7280;font-size:.75rem;margin-left:.25rem}.capabilities-table tbody tr{border-bottom:1px solid #e5e7eb;transition:background-color .15s}.capabilities-table tbody tr:hover{background-color:#f9fafb}.capabilities-table tbody tr:last-child{border-bottom:none}.capabilities-table td{color:#111827;max-width:300px;overflow:hidden;padding:.75rem 1rem;text-overflow:ellipsis;white-space:nowrap}.capabilities-table td.actions-cell{max-width:none;overflow:visible;padding:.75rem 1rem;text-align:center;white-space:nowrap}.capabilities-table td:not(.actions-cell):not(.phase-cell):hover{background-color:#fff;box-shadow:0 2px 8px #0000001a;overflow:visible;position:relative;white-space:normal;word-break:break-word;z-index:1}.capabilities-new-row{background-color:#f0f9ff}.capabilities-new-row td{padding:.5rem}.capabilities-new-input{background-color:#fff;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;padding:.5rem;width:100%}.capabilities-new-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f61a;outline:none}.capabilities-edit-input{background-color:#fff;border:1px solid #3b82f6;border-radius:.25rem;font-size:.875rem;padding:.25rem;width:100%}.capabilities-edit-input:focus{box-shadow:0 0 0 2px #3b82f633;outline:none}.capabilities-action-button{background:none;border:none;border-radius:.25rem;cursor:pointer;font-size:1rem;margin:0 .125rem;padding:.25rem;transition:background-color .15s}.capabilities-action-button:hover{background-color:#e5e7eb}.capabilities-empty-state{color:#6b7280;font-size:.875rem;padding:3rem;text-align:center}.phase-cell{text-align:center}.phase-badge{border-radius:9999px;display:inline-block;font-size:.75rem;font-weight:500;padding:.25rem .5rem}.phase-badge.phase-1{background-color:#dbeafe;color:#1e40af}.phase-badge.phase-2{background-color:#e0e7ff;color:#3730a3}.phase-badge.phase-3{background-color:#fef3c7;color:#92400e}.phase-badge.phase-4{background-color:#fed7aa;color:#9a3412}.phase-badge.phase-5{background-color:#d1fae5;color:#064e3b}.capabilities-footer{color:#6b7280;font-size:.875rem;margin-top:1rem;text-align:right}.capabilities-button-columns{background-color:#6b7280;color:#fff}.capabilities-button-columns:hover{background-color:#4b5563}.column-selector{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;margin-bottom:1rem;padding:1rem}.column-selector h4{color:#374151;font-size:.875rem;font-weight:600;margin:0 0 .75rem}.column-selector-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.column-selector-item{align-items:center;color:#374151;cursor:pointer;display:flex;font-size:.75rem;gap:.5rem}.column-selector-item input[type=checkbox]{cursor:pointer}.column-selector-item .required-label{color:#9ca3af;font-size:.625rem;font-style:italic}.import-capabilities-title{color:#111827;font-size:1.125rem;font-weight:600;margin-bottom:1rem}.import-file-section{margin-bottom:1.5rem}.import-file-input{display:none}.import-file-label{background-color:#3b82f6;border-radius:.375rem;color:#fff;cursor:pointer;display:inline-block;font-size:.875rem;padding:.5rem 1rem;transition:background-color .2s}.import-file-label:hover{background-color:#2563eb}.import-file-hint{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.5rem}.import-column-debug{margin-bottom:1rem}.import-column-debug summary{background-color:#e0e7ff;border-radius:.25rem;color:#3730a3;cursor:pointer;font-size:.875rem;font-weight:500;padding:.5rem}.import-column-debug details[open] summary{border-bottom-left-radius:0;border-bottom-right-radius:0}.capabilities-loading{color:#6b7280;font-size:1rem;padding:3rem;text-align:center}.import-status{border-radius:.375rem;font-size:.875rem;margin-bottom:1rem;padding:1rem}.import-status.error{background-color:#fee2e2;color:#991b1b}.import-status.warning{background-color:#fef3c7;color:#92400e}.import-status.success{background-color:#d1fae5;color:#064e3b}.import-status.info{background-color:#dbeafe;color:#1e40af}.import-status ul{margin-top:.5rem;padding-left:1.5rem}.import-preview-section{margin-bottom:1.5rem}.import-preview-title{color:#374151;font-size:.875rem;font-weight:600;margin-bottom:.5rem}.import-preview-container{border:1px solid #e5e7eb;border-radius:.375rem;overflow-x:auto}.import-preview-table{border-collapse:collapse;font-size:.75rem;width:100%}.import-preview-table thead tr{background-color:#f9fafb}.import-preview-table th{border-bottom:1px solid #e5e7eb;color:#374151;font-weight:600;padding:.5rem;text-align:left}.import-preview-table td{border-bottom:1px solid #e5e7eb;color:#111827;padding:.5rem}.import-preview-note{color:#6b7280;font-size:.75rem;font-style:italic;margin-top:.25rem}.import-actions{display:flex;gap:.75rem}.import-button{border:none;border-radius:.375rem;cursor:pointer;font-size:.875rem;padding:.5rem 1rem;transition:all .15s}.import-button-confirm{background-color:#10b981;color:#fff}.import-button-confirm:hover{background-color:#059669}.import-button-confirm:disabled{background-color:#9ca3af;cursor:not-allowed}.import-button-cancel{background-color:#e5e7eb;color:#374151}.import-button-cancel:hover{background-color:#d1d5db}.import-button-cancel:disabled{cursor:not-allowed;opacity:.5}.capabilities-table td,.capabilities-table th{transition:width .3s ease,opacity .3s ease}.capabilities-table td:last-of-type:not(.actions-cell),.capabilities-table th:last-of-type:not(.actions-column){animation:fadeIn .3s ease}.capabilities-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1.5rem}.stat-card{background-color:#fff;border:1px solid #e5e7eb;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:1rem}.stat-value{color:#111827;font-size:1.5rem;font-weight:600;margin-bottom:.25rem}.stat-label{color:#6b7280;font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}@media (max-width:1200px){.capabilities-table td{max-width:200px}}@media (max-width:1024px){.capabilities-table-container{border-left:none;border-radius:0;border-right:none;margin-left:-1.5rem;margin-right:-1.5rem}.capabilities-table{min-width:1000px}.column-selector-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}}@media (max-width:640px){.capabilities-controls{flex-direction:column}.capabilities-search{width:100%}.capabilities-button{justify-content:center;width:100%}.column-selector{padding:1rem}.column-selector-grid{grid-template-columns:1fr}.column-selector-actions{flex-wrap:wrap}.column-selector-action{flex:1 1;min-width:80px}}.capabilities-loading:before{animation:spin .8s linear infinite;border:3px solid #e5e7eb;border-radius:50%;border-top-color:#3b82f6;content:"";display:inline-block;height:2rem;margin-bottom:1rem;width:2rem}.table-header{position:relative}.header-content{align-items:center;display:flex;gap:8px;justify-content:space-between}.filter-button{background:none;border:none;border-radius:4px;color:#666;font-size:12px;padding:4px 8px;transition:all .2s}.filter-button:hover{background-color:#f0f0f0;color:#333}.filter-button.has-filter{background-color:#e3f2fd;color:#1976d2;font-weight:700}.filter-dropdown{background:#fff;border:1px solid #ddd;border-radius:8px;box-shadow:0 4px 12px #00000026;left:0;margin-top:4px;max-width:300px;min-width:200px;position:absolute;top:100%;z-index:1000}.filter-dropdown-header{align-items:center;border-bottom:1px solid #eee;color:#333;display:flex;font-size:14px;font-weight:500;justify-content:space-between;padding:12px}.clear-filter-button{background:none;border:1px solid #ddd;border-radius:4px;color:#666;cursor:pointer;font-size:12px;padding:4px 12px;transition:all .2s}.clear-filter-button:hover{background-color:#f5f5f5;border-color:#999;color:#333}.filter-options{max-height:300px;overflow-y:auto;padding:8px 0}.filter-option{align-items:center;color:#555;cursor:pointer;display:flex;font-size:14px;padding:8px 12px;transition:background-color .2s}.filter-option:hover{background-color:#f8f8f8}.filter-option input[type=checkbox]{accent-color:#1976d2;cursor:pointer;height:16px;margin-right:8px;width:16px}.filter-option span{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.capabilities-button-clear-filters{background-color:#ff9800;color:#fff}.capabilities-button-clear-filters:hover{background-color:#f57c00}.capabilities-controls{align-items:center;display:flex;flex-wrap:wrap;gap:10px;margin-bottom:20px}.capabilities-table th{background-color:#f5f5f5;border-bottom:2px solid #ddd;color:#333;font-size:14px;font-weight:600;padding:12px;position:sticky;text-align:left;top:0;white-space:nowrap;z-index:10}.sortable-header{align-items:center;cursor:pointer;display:inline-flex;gap:4px;-webkit-user-select:none;user-select:none}.sortable-header:hover{color:#1976d2}.capabilities-footer{color:#666;font-size:14px;margin-top:20px;text-align:center}.filter-options::-webkit-scrollbar{width:8px}.filter-options::-webkit-scrollbar-track{background:#f1f1f1;border-radius:4px}.filter-options::-webkit-scrollbar-thumb{background:#888;border-radius:4px}.filter-options::-webkit-scrollbar-thumb:hover{background:#555}.filter-options:empty:after{color:#999;content:"No values to filter";display:block;font-style:italic;padding:16px;text-align:center}@media (max-width:767px){.filter-dropdown{left:50%;max-width:400px;position:fixed;top:50%;transform:translate(-50%,-50%);width:90%}.filter-button{padding:8px}.header-content{align-items:flex-start;flex-direction:column}.capabilities-controls{align-items:stretch;flex-direction:column}.capabilities-search{min-width:100%}.capabilities-table,.capabilities-table tbody,.capabilities-table td,.capabilities-table th,.capabilities-table thead,.capabilities-table tr{display:block}.capabilities-table thead tr{display:none}.capabilities-table tr{background:#fff;border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px;overflow:hidden}.capabilities-table td{border-bottom:1px solid #f0f0f0;display:flex;justify-content:space-between;max-width:none!important;min-width:0!important;padding:8px 12px}.capabilities-table td:before{color:#666;content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px}.column-selector-grid{grid-template-columns:1fr!important}}.dashboard-nav{background:var(--color-surface);border-bottom:1px solid var(--color-border)}.tab-percent{color:var(--color-text-muted);font-size:var(--text-xs);margin-left:var(--space-2)}.dashboard-card{padding:0}@media (max-width:767px){.dashboard-nav{-webkit-overflow-scrolling:touch;overflow-x:auto}.dashboard-card{width:100%}.dashboard-nav .filter-bar,.dashboard-nav .filters{flex-direction:column;width:100%}.metrics-grid,.stats-grid,.summary-metrics{grid-template-columns:1fr}.dashboard-nav input,.dashboard-nav select{min-height:44px;width:100%}.dashboard-nav button{min-height:44px}.fixed.inset-0.bg-black\/50{align-items:flex-end!important;padding:0!important}.bg-white.rounded-lg.max-w-5xl{border-radius:1rem 1rem 0 0!important;max-height:100vh!important;max-width:100%!important;width:100%!important}.grid.grid-cols-2.gap-6{gap:1rem!important;grid-template-columns:1fr!important}.grid.grid-cols-3.gap-4{gap:.5rem!important;grid-template-columns:1fr!important}.flex.gap-4{flex-direction:column;gap:.75rem!important}.flex.justify-end.gap-3{flex-direction:column;gap:.5rem!important}.flex.justify-end.gap-3 button{justify-content:center;min-height:44px;width:100%}.mt-3.flex.gap-2{flex-wrap:wrap}.mt-3.flex.gap-2 button{flex:1 1;min-height:44px;min-width:0}.p-6{padding:1rem!important}select{font-size:16px!important;min-height:44px;width:100%!important}label.flex.items-center.gap-2{min-height:44px;padding:.5rem 0}input[type=radio]{min-height:20px;min-width:20px}}.department-manager{display:flex;flex-direction:column;gap:var(--space-6)}.department-header{background:var(--gradient-primary);border-radius:var(--radius-lg);color:var(--white);padding:var(--space-6)}.department-header-inner{justify-content:space-between}.department-header-info,.department-header-inner{align-items:center;display:flex}.department-header-icon{margin-right:var(--space-3)}.department-title{font-size:var(--text-2xl);font-weight:var(--font-bold)}.department-subtitle{color:var(--gray-100)}.department-actions{display:flex;gap:var(--space-3)}.department-action-btn{align-items:center;background:#fff3;border-radius:var(--radius-lg);color:var(--white);display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-4);transition:background var(--duration-normal) var(--ease-in-out)}.department-action-btn:hover{background:#ffffff4d}.department-action-btn.primary{background:var(--white);color:var(--color-primary)}.department-action-btn.primary:hover{background:var(--gray-100)}.department-action-btn:disabled{cursor:not-allowed;opacity:.5}.notification{align-items:center;border-radius:var(--radius-lg);display:flex;justify-content:space-between;padding:var(--space-4)}.notification-success{background:#f0fdf4;border:1px solid #bbf7d0;color:#166534}.notification-error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}.notification-warning{background:#fefce8;border:1px solid #fde68a;color:#854d0e}.notification-info{background:#eff6ff;border:1px solid #bfdbfe;color:#1e3a8a}.notification-content{align-items:center;display:flex}.icon-margin{margin-right:var(--space-2)}.loading-container{height:16rem}.error-box{background:#fef2f2;border:1px solid #fecaca;border-radius:var(--radius-lg);padding:var(--space-4)}.error-box-content{align-items:center;color:#b91c1c;display:flex}.error-retry{margin-top:var(--space-2)}@media (max-width:767px){.department-header{padding:var(--space-4)}.department-header-inner{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.department-title{font-size:var(--text-xl)}.department-actions{flex-wrap:wrap;width:100%}.department-action-btn{flex:1 1;justify-content:center;min-height:44px}}.ap-container{margin:0 auto;max-width:1100px}.ap-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;flex-direction:column;gap:1rem;padding:4rem 2rem}.ap-spin{animation:ap-spin 1s linear infinite}@keyframes ap-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ap-header{justify-content:space-between;margin-bottom:1.5rem}.ap-header,.ap-header-left{align-items:flex-start;display:flex}.ap-header-left{gap:.75rem}.ap-header-left h1{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.35rem;font-weight:700;line-height:1.2;margin:0}.ap-subtitle{font-size:.8rem;margin:.15rem 0 0}.ap-refresh-btn,.ap-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.ap-refresh-btn{align-items:center;background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.5rem;cursor:pointer;display:flex;padding:.5rem;transition:all .2s}.ap-refresh-btn:hover{background:#ffffff1a;background:var(--color-surface-active,#ffffff1a);color:#f1f5f9;color:var(--color-text,#f1f5f9)}.ap-error{align-items:center;background:#ef444414;border:1px solid #ef444433;border-radius:.5rem;color:#ef4444;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:1rem;padding:.65rem 1rem}.ap-error-dismiss{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;opacity:.7;padding:.25rem}.ap-success{align-items:center;background:#22c55e14;border:1px solid #22c55e33;border-radius:.5rem;color:#22c55e;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:.75rem;padding:.65rem 1rem}.ap-tabs{border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--color-border,#ffffff1a);display:flex;gap:.25rem;margin-bottom:1.5rem}.ap-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.6rem 1rem;transition:all .2s}.ap-tab.active,.ap-tab:hover{color:#f1f5f9;color:var(--color-text,#f1f5f9)}.ap-tab.active{border-bottom-color:#3b82f6}.ap-stat-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:1.5rem}.ap-stat-card{align-items:center;background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;display:flex;gap:.75rem;padding:1rem 1.25rem;transition:border-color .2s}.ap-stat-card:hover{border-color:#ffffff26}.ap-stat-icon{align-items:center;border-radius:.5rem;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.ap-stat-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.4rem;font-weight:700;line-height:1.2}.ap-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;margin-top:.1rem}.ap-section{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;margin-bottom:1rem;padding:1.25rem}.ap-section-title{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;font-size:.85rem;font-weight:600;gap:.5rem;margin:0 0 1rem}.ap-role-bars{display:flex;flex-direction:column;gap:.6rem}.ap-role-bar-row{align-items:center;display:flex;gap:.75rem}.ap-role-bar-label{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;flex-shrink:0;font-size:.8rem;gap:.4rem;width:100px}.ap-role-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.ap-role-bar-track{background:#ffffff0d;border-radius:3px;flex:1 1;height:6px;overflow:hidden}.ap-role-bar-fill{border-radius:3px;height:100%;min-width:2px;transition:width .6s ease}.ap-role-bar-count{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.8rem;font-weight:600;text-align:right;width:30px}.ap-classification-stats{display:flex;flex-wrap:wrap;gap:2rem}.ap-class-stat{display:flex;flex-direction:column;gap:.2rem}.ap-class-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem}.ap-class-stat-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.1rem;font-weight:600}.ap-class-stat-value.ap-highlight{color:#22c55e}.ap-signup-timeline{display:flex;flex-direction:column;gap:.4rem}.ap-signup-day{align-items:center;display:flex;gap:.75rem}.ap-signup-date{color:#94a3b8;color:var(--color-text-muted,#94a3b8);flex-shrink:0;font-size:.75rem;width:60px}.ap-signup-dots{display:flex;flex:1 1;gap:4px}.ap-signup-dot{background:#3b82f6;border-radius:50%;height:8px;width:8px}.ap-signup-count{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.75rem;font-weight:600;text-align:right;width:20px}.ap-users-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.ap-users-count{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem}.ap-invite-btn{align-items:center;background:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;transition:background .2s}.ap-invite-btn:hover{background:#2563eb}.ap-table-wrapper{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow-x:auto}.ap-table{border-collapse:collapse;font-size:.85rem;width:100%}.ap-table th{background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;font-weight:500;letter-spacing:.03em;padding:.65rem 1rem;text-align:left;text-transform:uppercase}.ap-table td{border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a);color:#f1f5f9;color:var(--color-text,#f1f5f9);padding:.65rem 1rem}.ap-table tbody tr:hover{background:#ffffff05}.ap-email-cell{font-weight:500}.ap-date-cell{font-size:.8rem}.ap-date-cell,.ap-empty{color:#94a3b8!important;color:var(--color-text-muted,#94a3b8)!important}.ap-empty{padding:2rem!important;text-align:center}.ap-role-badge{align-items:center;background:none;border:1px solid;border-radius:9999px;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.3rem;padding:.25rem .6rem;transition:all .15s}.ap-role-badge:hover{filter:brightness(1.2)}.ap-role-edit{align-items:center;display:flex;gap:.35rem}.ap-role-select{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff26;border:1px solid var(--color-border,#ffffff26);border-radius:.375rem;color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.8rem;padding:.25rem .5rem}.ap-role-cancel,.ap-role-save{align-items:center;background:none;border:none;border-radius:.25rem;cursor:pointer;display:flex;padding:.25rem}.ap-role-save{color:#22c55e}.ap-role-save:hover{background:#22c55e26}.ap-role-cancel{color:#94a3b8}.ap-role-cancel:hover{background:#ffffff14}.ap-action-delete{align-items:center;background:none;border:none;border-radius:.375rem;color:#64748b;color:var(--color-text-muted,#64748b);cursor:pointer;display:flex;padding:.35rem;transition:all .15s}.ap-action-delete:hover{background:#ef44441a;color:#ef4444}.ap-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1100}.ap-modal{background:#1e293b;background:var(--color-surface,#1e293b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.75rem;box-shadow:0 20px 40px #0000004d;max-width:420px;padding:1.5rem;width:90%}.ap-modal-sm{max-width:380px}.ap-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.ap-modal-header h2{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.1rem;font-weight:600;margin:0}.ap-close-btn{background:none;border:none;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;padding:.25rem}.ap-field{margin-bottom:1rem}.ap-field label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:block;font-size:.8rem;font-weight:500;margin-bottom:.35rem}.ap-field input,.ap-field select{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff26;border:1px solid var(--color-border,#ffffff26);border-radius:.5rem;box-sizing:border-box;color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.875rem;padding:.5rem .75rem;transition:border-color .2s;width:100%}.ap-field input:focus,.ap-field select:focus{border-color:#3b82f6;outline:none}.ap-confirm-text{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.875rem;line-height:1.5;margin:0 0 1.25rem}.ap-confirm-text strong{color:#f1f5f9;color:var(--color-text,#f1f5f9)}.ap-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}.ap-cancel-btn{background:#0000;border:1px solid #ffffff26;border:1px solid var(--color-border,#ffffff26);border-radius:.5rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;font-size:.85rem;padding:.5rem 1rem;transition:all .15s}.ap-cancel-btn:hover{background:#ffffff0d}.ap-submit-btn{align-items:center;background:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;transition:background .2s}.ap-submit-btn:hover{background:#2563eb}.ap-submit-btn:disabled{cursor:not-allowed;opacity:.6}.ap-delete-btn{align-items:center;background:#ef4444;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;transition:background .2s}.ap-delete-btn:hover{background:#dc2626}.ap-status-badge{align-items:center;background:none;border:1px solid;border-radius:9999px;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.3rem;padding:.25rem .6rem;transition:all .15s}.ap-status-badge:hover{filter:brightness(1.2)}.ap-row-inactive{opacity:.6}.ap-row-inactive:hover{opacity:.85}.ap-activity-empty{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;flex-direction:column;gap:.5rem;padding:3rem 2rem;text-align:center}.ap-activity-empty p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.95rem;font-weight:500;margin:0}.ap-activity-empty span{font-size:.8rem}.ap-activity-list{display:flex;flex-direction:column;gap:.25rem}.ap-activity-entry{align-items:flex-start;border-radius:.5rem;display:flex;gap:.75rem;padding:.75rem 1rem;transition:background .15s}.ap-activity-entry:hover{background:#ffffff05}.ap-activity-icon{align-items:center;border-radius:.375rem;display:flex;flex-shrink:0;height:30px;justify-content:center;margin-top:.1rem;width:30px}.ap-activity-content{flex:1 1;min-width:0}.ap-activity-text{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.85rem;line-height:1.4}.ap-activity-meta{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.75rem;margin-top:.15rem}@media (max-width:768px){.ap-stat-grid{grid-template-columns:repeat(2,1fr)}.ap-table td:nth-child(4),.ap-table td:nth-child(5),.ap-table th:nth-child(4),.ap-table th:nth-child(5){display:none}.ap-classification-stats{flex-direction:column;gap:.75rem}}@media (max-width:480px){.ap-stat-grid{grid-template-columns:1fr}.ap-table td:nth-child(3),.ap-table td:nth-child(4),.ap-table td:nth-child(5),.ap-table th:nth-child(3),.ap-table th:nth-child(4),.ap-table th:nth-child(5){display:none}}.ap-features-header{align-items:flex-start;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem}.ap-features-title{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.95rem;font-weight:600;margin:0 0 .25rem}.ap-features-desc{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.8rem;line-height:1.4;margin:0}.ap-save-btn{align-items:center;background:#3b82f6;border:none;border-radius:.5rem;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;transition:all .2s;white-space:nowrap}.ap-save-btn:hover:not(:disabled){background:#2563eb}.ap-save-btn:disabled{cursor:not-allowed;opacity:.5}.ap-feature-grid{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden}.ap-feature-row{align-items:center;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--color-border,#ffffff0d);display:grid;grid-template-columns:1fr repeat(3,100px)}.ap-feature-row:last-child{border-bottom:none}.ap-feature-header{background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a)}.ap-feature-header .ap-feature-name,.ap-feature-header .ap-feature-role-header{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;font-weight:500;letter-spacing:.03em;padding:.65rem 1rem;text-transform:uppercase}.ap-feature-role-header{text-align:center}.ap-feature-name{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;font-size:.85rem;font-weight:500;gap:.5rem;padding:.65rem 1rem}.ap-feature-cell{display:flex;justify-content:center;padding:.5rem}.ap-feature-locked{opacity:.5}.ap-lock-icon{color:#64748b;color:var(--color-text-muted,#64748b)}.ap-toggle-track{border:none;border-radius:10px;cursor:pointer;flex-shrink:0;height:20px;padding:0;position:relative;transition:background .2s;width:36px}.ap-toggle-on{background:#22c55e}.ap-toggle-off{background:#ffffff1f}.ap-toggle-disabled{cursor:default;opacity:.6}.ap-toggle-changed{box-shadow:0 0 0 2px #3b82f6}.ap-toggle-thumb{background:#fff;border-radius:50%;box-shadow:0 1px 3px #0003;height:16px;position:absolute;top:2px;transition:transform .2s;width:16px}.ap-toggle-on .ap-toggle-thumb{transform:translateX(18px)}.ap-toggle-off .ap-toggle-thumb{transform:translateX(2px)}.ap-toggle-track:hover:not(.ap-toggle-disabled){filter:brightness(1.15)}@media (max-width:480px){.ap-feature-row{grid-template-columns:1fr repeat(3,70px)}.ap-features-header{flex-direction:column}}.bi-container{margin:0 auto;max-width:900px}.bi-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;flex-direction:column;gap:1rem;padding:4rem 2rem}.bi-spin{animation:bi-spin 1s linear infinite}@keyframes bi-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.bi-header{justify-content:space-between;margin-bottom:1.5rem}.bi-header,.bi-header-left{align-items:flex-start;display:flex}.bi-header-left{gap:.75rem}.bi-header-left h1{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.35rem;font-weight:700;line-height:1.2;margin:0}.bi-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;margin:.15rem 0 0}.bi-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.bi-stat-card{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;gap:1rem;padding:1.25rem}.bi-stat-card,.bi-stat-icon{align-items:center;display:flex}.bi-stat-icon{border-radius:.5rem;height:40px;justify-content:center;width:40px}.bi-stat-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.5rem;font-weight:700;line-height:1}.bi-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;margin-top:.15rem}.bi-section{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;margin-bottom:1.5rem;overflow:hidden}.bi-section-header{align-items:center;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);display:flex;justify-content:space-between;padding:1rem 1.25rem}.bi-section-title{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;font-size:.95rem;font-weight:600;gap:.6rem}.bi-section-badge{border-radius:9999px;font-size:.65rem;font-weight:600;letter-spacing:.05em;padding:.15rem .5rem;text-transform:uppercase}.bi-badge-active{background:#22c55e1f;border:1px solid #22c55e33;color:#22c55e}.bi-badge-disabled{background:#ef444414;border:1px solid #ef444433;color:#ef4444}.bi-toggle-list{padding:0}.bi-toggle-row{align-items:center;border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--color-border,#ffffff0d);display:flex;justify-content:space-between;padding:.85rem 1.25rem;transition:background .15s}.bi-toggle-row:last-child{border-bottom:none}.bi-toggle-row:hover{background:#ffffff08;background:var(--color-surface-hover,#ffffff08)}.bi-toggle-info{align-items:center;display:flex;flex:1 1;gap:.75rem}.bi-toggle-icon{align-items:center;border-radius:.4rem;display:flex;flex-shrink:0;height:32px;justify-content:center;width:32px}.bi-toggle-label{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.85rem;font-weight:500}.bi-toggle-desc{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.72rem;margin-top:.1rem}.bi-switch{flex-shrink:0;height:24px;position:relative;width:44px}.bi-switch input{height:0;opacity:0;width:0}.bi-switch-slider{background:#ffffff26;background:var(--color-border,#ffffff26);border-radius:24px;bottom:0;cursor:pointer;left:0;position:absolute;right:0;top:0;transition:all .25s}.bi-switch-slider:before{background:#fff;border-radius:50%;bottom:3px;content:"";height:18px;left:3px;position:absolute;transition:all .25s;width:18px}.bi-switch input:checked+.bi-switch-slider{background:#3b82f6}.bi-switch input:checked+.bi-switch-slider:before{transform:translateX(20px)}.bi-switch input:disabled+.bi-switch-slider{cursor:not-allowed;opacity:.4}.bi-error{background:#ef444414;border:1px solid #ef444433;border-radius:.5rem;color:#ef4444}.bi-error,.bi-success{align-items:center;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:1rem;padding:.65rem 1rem}.bi-success{background:#22c55e14;border:1px solid #22c55e33;border-radius:.5rem;color:#22c55e}@media (max-width:768px){.bi-stats{grid-template-columns:1fr}}.ai-cost-container{margin:0 auto;max-width:1000px}.ai-cost-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.ai-cost-header h1{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.35rem;font-weight:700;margin:0}.ai-cost-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;margin-top:.15rem}.ai-alert{align-items:center;border-radius:.5rem;display:flex;font-size:.85rem;gap:.5rem;margin-bottom:1rem;padding:.75rem 1rem}.ai-alert-warning{background:#f59e0b1a;border:1px solid #f59e0b40;color:#f59e0b}.ai-alert-critical{background:#ef44441a;border:1px solid #ef444440;color:#ef4444}.ai-cost-stats{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(4,1fr);margin-bottom:1.5rem}.ai-cost-stat{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;padding:1rem}.ai-cost-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.7rem;letter-spacing:.05em;text-transform:uppercase}.ai-cost-stat-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.4rem;font-weight:700;margin-top:.25rem}.ai-cost-stat-sub{color:var(--color-text-muted);font-size:.7rem;margin-top:.15rem}.ai-cost-section{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.75rem;margin-bottom:1.5rem;overflow:hidden}.ai-cost-section-header{border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border,#ffffff0f);color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.9rem;font-weight:600;padding:.85rem 1.25rem}.ai-cost-table{border-collapse:collapse;font-size:.8rem;width:100%}.ai-cost-table th{color:var(--color-text-muted);font-size:.7rem;font-weight:500;letter-spacing:.05em;padding:.6rem 1rem;text-align:left;text-transform:uppercase}.ai-cost-table td{border-top:1px solid #ffffff0a;border-top:1px solid var(--color-border,#ffffff0a);color:#f1f5f9;color:var(--color-text,#f1f5f9);padding:.6rem 1rem}.ai-cost-table tr:hover td{background:#ffffff05}.ai-access-row{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a);display:flex;justify-content:space-between;padding:.75rem 1.25rem}.ai-access-row:last-child{border-bottom:none}.ai-access-email{color:var(--color-text);font-size:.85rem}.ai-access-role{color:var(--color-text-muted);font-size:.7rem;margin-left:.5rem}.ai-access-key{background:#8b5cf61a;border-radius:4px;color:#8b5cf6;font-size:.65rem;padding:2px 6px}.ai-tabs{border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);display:flex;gap:0;margin-bottom:1.5rem}.ai-tab{background:none;border:none;border-bottom:2px solid #0000;color:var(--color-text-muted);cursor:pointer;font-size:.85rem;padding:.65rem 1.25rem;transition:all .2s}.ai-tab:hover{color:var(--color-text)}.ai-tab-active{border-bottom-color:#3b82f6;color:#3b82f6}.ai-spin{animation:ai-spin 1s linear infinite}@keyframes ai-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@media (max-width:768px){.ai-cost-stats{grid-template-columns:repeat(2,1fr)}}.classification-page{animation:fadeIn var(--duration-normal) var(--ease-out)}.toggle-switch{align-items:center;background-color:var(--gray-300);border:none;border-radius:var(--radius-full);cursor:pointer;display:inline-flex;height:2rem;padding:0;position:relative;transition:var(--transition-base);width:3.5rem}.toggle-switch-active{background:var(--gradient-primary)}.toggle-switch-handle{align-items:center;background-color:var(--color-surface);border-radius:var(--radius-full);box-shadow:var(--shadow-sm);display:inline-block;display:flex;height:1.5rem;justify-content:center;transform:translateX(.25rem);transition:var(--transition-base);width:1.5rem}.toggle-switch-handle-active{transform:translateX(1.75rem)}.metrics-container{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:var(--space-4);padding:var(--space-2) var(--space-4)}.metric-item{text-align:center}.metric-label{color:var(--color-text-muted);font-size:var(--text-xs);margin-bottom:var(--space-1)}.metric-value{color:var(--gray-900);font-size:var(--text-lg);font-weight:var(--font-bold)}.metric-value-gradient{-webkit-text-fill-color:#0000;background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.metric-divider{background-color:var(--color-border);height:2rem;width:1px}.customer-info{align-items:center;border-top:1px solid var(--color-border);display:flex;justify-content:space-between;margin-top:var(--space-4);padding-top:var(--space-4)}.tabs-fill{background:var(--color-surface-hover);border-radius:var(--radius-lg);display:flex;gap:var(--space-1);padding:var(--space-1)}.tab-item{color:var(--color-text-muted);transition:var(--transition-base)}.tab-item:hover:not(.tab-item-active){background-color:var(--color-surface)}.tab-item-active{background:var(--gradient-primary);box-shadow:var(--shadow-md);color:#fff}.stat-card-success{background:linear-gradient(135deg,#10b9810d,#10b9811a);border-color:#10b98133}.stat-card-success .icon-lg,.stat-card-success .stat-footer{color:#10b981}.stat-card-primary{background:linear-gradient(135deg,#3b82f60d,#3b82f61a);border-color:#3b82f633}.stat-card-primary .icon-lg,.stat-card-primary .stat-footer{color:var(--color-primary)}.stat-card-warning{background:linear-gradient(135deg,#f59e0b0d,#f59e0b1a);border-color:#f59e0b33}.stat-card-warning .icon-lg,.stat-card-warning .stat-footer{color:#f59e0b}.stat-card-accent{background:linear-gradient(135deg,#06b6d40d,#06b6d41a);border-color:#06b6d433}.stat-card-accent .icon-lg,.stat-card-accent .stat-footer{color:var(--color-accent)}.stat-card-header{align-items:center;display:flex;justify-content:space-between;width:100%}.stat-footer{font-size:var(--text-xs);font-weight:var(--font-medium);margin-top:var(--space-1)}.upload-zone-active{animation:pulse 2s infinite}.loading-content{padding:var(--space-8) var(--space-4);text-align:center}.space-y-3>*+*{margin-top:var(--space-3)}.space-y-4>*+*{margin-top:var(--space-4)}.space-y-6>*+*{margin-top:var(--space-6)}.text-danger{color:var(--color-error)}@media (max-width:767px){.metrics-container{flex-wrap:wrap;width:100%}.metric-divider{display:none}.tabs-fill{flex-direction:column}.tab-item{min-height:44px;width:100%}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}.customer-info{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.classification-page input,.classification-page select{min-height:44px;width:100%}.classification-page button,.toggle-switch{min-height:44px}.classification-page table{display:block}.classification-page thead{display:none}.classification-page tbody,.classification-page td,.classification-page tr{display:block}.classification-page tr{background:#fff;background:var(--color-surface,#fff);border:1px solid #e4e4e7;border:1px solid var(--color-border,#e4e4e7);border-radius:.75rem;border-radius:var(--radius-xl,.75rem);box-shadow:0 1px 3px #0000000a;margin-bottom:12px;overflow:hidden}.classification-page td{align-items:center;border-bottom:1px solid #e4e4e7;border-bottom:1px solid var(--color-border,#e4e4e7);display:flex;font-size:14px;gap:12px;justify-content:space-between;padding:10px 14px}.classification-page td:last-child{border-bottom:none}.classification-page td:before{color:#71717a;color:var(--color-text-subtle,#71717a);content:attr(data-label);flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.05em;text-transform:uppercase}}.settings-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#0006;bottom:0;display:flex;flex-direction:column;left:0;opacity:0;position:fixed;right:0;top:0;transition:opacity .3s ease;transition:opacity var(--transition-slow,.3s ease);z-index:1050;z-index:var(--z-modal,1050)}.settings-overlay.loaded{opacity:1}.settings-overlay.exiting{opacity:0}.settings-header{align-items:center;animation:slideDown .4s ease;background-color:#fff;background-color:var(--color-surface,#fff);border-bottom:1px solid var(--color-border);box-shadow:0 1px 3px #0000000d;display:flex;justify-content:space-between;padding:1rem 1.5rem;position:relative;z-index:1}.btn-secondary{background:var(--color-surface-hover);border-radius:.375rem;color:var(--color-text);font-size:.875rem;font-weight:500;gap:.5rem;padding:.5rem 1rem;transition:all .2s}.btn-secondary:hover{background:var(--color-surface-active)}.btn-secondary.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-secondary.active:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover)}.btn-secondary svg{transition:transform .2s}.btn-secondary:hover svg{transform:translateX(-2px)}.breadcrumb-link{align-items:center;background:var(--color-surface);border:none;border-radius:.375rem;color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:.875rem;gap:.5rem;padding:.375rem .75rem;text-decoration:none;transition:all .2s}.breadcrumb-link:hover{background:var(--color-surface-hover);color:var(--color-text)}button[title="Close Settings"]{background:#0000;border:none;border-radius:.5rem;cursor:pointer;padding:.5rem;transition:all .2s}button[title="Close Settings"]:hover{background:var(--color-surface-hover)}.settings-container{animation:fadeInScale .4s ease .1s both;background:var(--color-background);display:flex;flex:1 1;overflow:hidden}@keyframes fadeInScale{0%{opacity:0;transform:scale(.98)}to{opacity:1;transform:scale(1)}}.settings-navigation{animation:slideInLeft .4s ease;background-color:var(--color-surface);border-right:1px solid var(--color-border);display:flex;flex-direction:column;position:relative;transition:width .3s ease}@keyframes slideInLeft{0%{transform:translateX(-100%)}to{transform:translateX(0)}}.settings-navigation.resizing{transition:none;-webkit-user-select:none;user-select:none}.settings-navigation>div:first-child{border-bottom:1px solid var(--color-border);padding:1.5rem}.settings-navigation h2{align-items:center;color:var(--color-text);display:flex;font-size:1.25rem;font-weight:700;gap:.5rem;margin:0 0 .25rem}.settings-navigation>div:first-child>div:last-child{color:var(--color-text-muted);font-size:.875rem}.nav-list{flex:1 1;overflow-x:hidden;overflow-y:auto;padding:1rem}.nav-list::-webkit-scrollbar{width:6px}.nav-list::-webkit-scrollbar-track{background:#0000;margin:.5rem 0}.nav-list::-webkit-scrollbar-thumb{background:#d4d4d4;background:var(--gray-300,#d4d4d4);border-radius:9999px;-webkit-transition:background .2s;transition:background .2s}.nav-list::-webkit-scrollbar-thumb:hover{background:#a3a3a3;background:var(--gray-400,#a3a3a3)}.nav-item{align-items:center;animation:slideInItem .4s ease 0s both;animation:slideInItem .4s ease var(--animation-delay,0s) both;background:#0000;border:none;border-radius:.5rem;color:var(--color-text-muted);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.75rem;margin-bottom:.5rem;padding:.75rem 1rem;position:relative;text-align:left;transition:all .2s;width:100%}@keyframes slideInItem{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.nav-item:hover:not(.nav-item[style*=background]){background:var(--color-surface-hover);color:var(--color-text);transform:translateX(4px)}.nav-item[style*=background]{box-shadow:0 4px 12px #00000026;color:#fff!important;transform:scale(1.02)}.nav-item[style*=background] svg{color:#fff}.nav-item>div:last-child{background:#fff9;border-radius:9999px;height:2rem;margin-left:auto;width:3px}.settings-resize-handle{align-items:center;bottom:0;cursor:col-resize;display:flex;justify-content:center;position:absolute;right:-4px;top:0;transition:background .2s;width:8px;z-index:10}.settings-resize-handle:hover{background:#3b82f614}.resize-indicator{opacity:0;transition:opacity .2s}.settings-resize-handle:hover .resize-indicator{opacity:.4}.settings-resize-handle:active .resize-indicator{opacity:.6}.content-panel{flex:1 1;overflow-y:auto;padding:var(--space-8);transition:all var(--duration-normal)}.content-panel>*{animation:contentFadeIn .3s ease}@keyframes contentFadeIn{0%{opacity:0;transform:translateX(10px)}to{opacity:1;transform:translateX(0)}}.settings-section{animation:slideUp .4s ease;margin:0 auto;max-width:1200px}.settings-header>div:last-child>div:first-child{align-items:center;background:#3b82f614;border:1px solid #3b82f633;border-radius:.5rem;color:#2563eb;display:flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.375rem .75rem}.settings-header kbd{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:.25rem;color:var(--color-text);font-family:monospace;font-size:.75rem;font-weight:600;padding:.125rem .5rem}.gap-2{gap:.5rem}.gap-3{gap:.75rem}.gap-5{gap:1.25rem}.px-3{padding-left:.75rem;padding-right:.75rem}.px-4{padding-left:1rem;padding-right:1rem}.py-1{padding-bottom:.25rem;padding-top:.25rem}.py-2{padding-bottom:.5rem;padding-top:.5rem}.py-3{padding-bottom:.75rem;padding-top:.75rem}.p-2{padding:.5rem}.p-4{padding:1rem}.p-6{padding:1.5rem}.p-8{padding:2rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-8{margin-bottom:2rem}.text-sm{font-size:.875rem}.text-xs{font-size:.75rem}.text-xl{font-size:1.25rem}.text-3xl{font-size:1.875rem}.text-base{font-size:1rem}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-gray-400{color:#a3a3a3;color:var(--gray-400,#a3a3a3)}.text-gray-500{color:#737373;color:var(--gray-500,#737373)}.text-gray-600{color:#525252;color:var(--gray-600,#525252)}.text-gray-700{color:#404040;color:var(--gray-700,#404040)}.text-gray-900{color:#171717;color:var(--gray-900,#171717)}.text-blue-700{color:#2563eb}.bg-gray-50{background-color:#fafafa;background-color:var(--gray-50,#fafafa)}.bg-gray-100{background-color:#f5f5f5;background-color:var(--gray-100,#f5f5f5)}.bg-blue-50{background-color:#3b82f614}.border{border-width:1px}.border-b{border-bottom-width:1px}.border-r{border-right-width:1px}.border-gray-100{border-color:#f5f5f5;border-color:var(--gray-100,#f5f5f5)}.border-gray-200{border-color:#e5e5e5;border-color:var(--gray-200,#e5e5e5)}.border-blue-200{border-color:#3b82f633}.rounded{border-radius:.25rem}.rounded-md{border-radius:.375rem}.rounded-lg{border-radius:.5rem}.rounded-xl{border-radius:.75rem}.rounded-full{border-radius:9999px}.shadow-sm{box-shadow:0 1px 2px 0 #0000000d}.shadow-md{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.transition-all{transition-duration:.15s;transition-property:all;transition-timing-function:cubic-bezier(.4,0,.2,1)}.transition-transform{transition-property:transform}.hover\:bg-gray-50:hover{background-color:#fafafa;background-color:var(--gray-50,#fafafa)}.hover\:bg-gray-100:hover{background-color:#f5f5f5;background-color:var(--gray-100,#f5f5f5)}.hover\:text-gray-900:hover{color:#171717;color:var(--gray-900,#171717)}.hover\:-translate-x-1:hover{transform:translateX(-.25rem)}.w-1{width:.25rem}.h-8{height:2rem}.opacity-60{opacity:.6}@media (max-width:768px){.settings-container{flex-direction:column}.settings-navigation{border-bottom:1px solid var(--color-border);border-right:none;max-height:40vh;overflow-y:auto;width:100%!important}.content-panel{padding:var(--space-4)}.settings-resize-handle{display:none}.settings-header{align-items:flex-start;flex-direction:column;gap:1rem;padding:1rem}.settings-header>div:last-child{justify-content:space-between;width:100%}.content-panel input,.content-panel select,.content-panel textarea{font-size:16px;min-height:44px;width:100%}.content-panel button,.nav-item{min-height:44px}.nav-item{padding:.75rem 1rem}.settings-navigation>div:first-child{padding:1rem}.settings-navigation h2{font-size:1rem}}.settings-section .classification-page{animation:fadeInUp .3s ease-out}.nav-item .badge{animation:pulse 2s infinite}.classification-hub-header{animation:gradientShift 10s ease infinite;background:linear-gradient(135deg,#667eea,#764ba2)}@keyframes gradientShift{0%,to{background-position:0 50%}50%{background-position:100% 50%}}.classification-tab{overflow:hidden;position:relative}.classification-tab:before{background:linear-gradient(90deg,#0000,#fff3,#0000);content:"";height:100%;left:-100%;position:absolute;top:0;transition:left .5s;width:100%}.classification-tab:hover:before{left:100%}.auto-classification-indicator{position:relative}.auto-classification-indicator.active:after{animation:ripple 2s infinite;background:radial-gradient(circle,#7c3aed4d 0,#0000 70%);content:"";height:120%;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);width:120%}@keyframes ripple{0%{opacity:1;transform:translate(-50%,-50%) scale(.8)}to{opacity:0;transform:translate(-50%,-50%) scale(1.5)}}.classification-metric-card{cursor:pointer;transition:all .3s cubic-bezier(.4,0,.2,1)}.classification-metric-card:hover{box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;transform:translateY(-4px) scale(1.02)}.classification-progress{overflow:hidden;position:relative}.classification-progress:after{animation:shimmer 2s infinite;background:linear-gradient(90deg,#0000,#ffffff4d,#0000);bottom:0;content:"";left:0;position:absolute;right:0;top:0}.nav-item[data-section=classification-hub]{position:relative}.nav-item[data-section=classification-hub]:after{background:#3b82f61a;border-radius:10px;color:#3b82f6;content:"98.58%";font-size:10px;font-weight:700;opacity:0;padding:2px 6px;position:absolute;right:10px;top:50%;transform:translateY(-50%);transition:opacity .3s}.nav-item[data-section=classification-hub]:hover:after{opacity:1}.classification-content-enter{opacity:0;transform:translateX(20px)}.classification-content-enter-active{opacity:1;transform:translateX(0);transition:all .3s ease-out}.classification-content-exit{opacity:1;transform:translateX(0)}.classification-content-exit-active{opacity:0;transform:translateX(-20px);transition:all .3s ease-in}.classification-active-import{animation:highlightPulse 2s ease-in-out infinite;background:linear-gradient(90deg,#3b82f60d,#0000);border-left:4px solid #3b82f6}@keyframes highlightPulse{0%,to{border-left-color:#3b82f6}50%{border-left-color:#8b5cf6}}@media (max-width:1280px){.classification-page .grid{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.classification-page .grid{grid-template-columns:1fr}.classification-page nav{flex-direction:column}.classification-page nav button{width:100%}}.genai-dashboard *{box-sizing:border-box;margin:0;padding:0}.genai-dashboard{background:linear-gradient(135deg,#0a0a0f,#12121a);color:#fff;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;position:relative}.genai-dashboard,.genai-sidebar{display:flex;height:100vh;overflow:hidden}.genai-sidebar{background:#12121a;border-right:1px solid #ffffff0f;flex-direction:column;min-width:260px;transition:transform .3s ease;width:260px;z-index:10}.genai-sidebar.collapsed{min-width:0;transform:translateX(-260px);width:0}.genai-sidebar-header{border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:24px 20px}.genai-sidebar-logo{align-items:center;display:flex;gap:12px}.genai-logo-icon{align-items:center;border-radius:8px;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;font-size:14px;height:32px;justify-content:center;width:32px}.genai-logo-icon,.genai-logo-text{background:linear-gradient(135deg,#3b82f6,#06b6d4);font-weight:600}.genai-logo-text{-webkit-text-fill-color:#0000;-webkit-background-clip:text;background-clip:text;font-size:18px}.genai-new-chat-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:12px;box-shadow:0 4px 12px #3b82f633;color:#fff;cursor:pointer;display:flex;flex-shrink:0;font-size:14px;font-weight:500;gap:8px;justify-content:center;margin:16px;padding:12px;transition:all .2s ease}.genai-new-chat-btn:hover{box-shadow:0 6px 20px #3b82f666;transform:translateY(-2px)}.genai-chat-history{flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;padding:16px}.genai-history-section{margin-bottom:24px}.genai-history-label{color:#6b6b7c;font-size:11px;font-weight:500;letter-spacing:.5px;margin-bottom:8px;padding-left:8px;text-transform:uppercase}.genai-history-item{align-items:center;border-radius:8px;color:#a0a0b0;cursor:pointer;display:flex;font-size:14px;gap:10px;margin-bottom:4px;padding:10px 12px;position:relative;transition:all .2s ease}.genai-history-item:hover{background:#ffffff0d;color:#fff;transform:translateX(4px)}.genai-history-item.active{background:#3b82f61a;color:#fff;padding-left:10px}.genai-history-item.active:before{background:#3b82f6;border-radius:2px;bottom:0;content:"";left:0;position:absolute;top:0;width:2px}.genai-history-icon{flex-shrink:0;height:16px;opacity:.6;width:16px}.genai-history-title{flex:1 1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genai-main{background:#15151f;display:flex;flex:1 1;flex-direction:column;height:100vh;min-width:0;overflow:hidden;position:relative}.genai-header{-webkit-backdrop-filter:blur(var(--sidebar-blur));backdrop-filter:blur(10px);background:#12121acc;border-bottom:1px solid #ffffff0f;flex-shrink:0;padding:20px 24px}.genai-header-content{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.genai-header-left{display:flex;flex-direction:column;gap:4px}.genai-header-title{color:#fff;font-size:24px;font-weight:600}.genai-header-subtitle{color:#a0a0b0;font-size:14px}.genai-header-right{align-items:center;display:flex;gap:16px}.genai-mode-toggle{background:#ffffff0d;border-radius:12px;display:flex;padding:4px}.genai-mode-btn{align-items:center;background:#0000;border:none;border-radius:8px;color:#a0a0b0;cursor:pointer;display:flex;font-size:14px;font-weight:500;gap:6px;padding:8px 16px;transition:all .2s ease}.genai-mode-btn:hover{color:#fff}.genai-mode-btn.active{background:#3b82f633;color:#3b82f6}.genai-header-actions{display:flex;gap:8px}.genai-header-btn{align-items:center;background:#0000;border:1px solid #ffffff0f;border-radius:8px;color:#a0a0b0;cursor:pointer;display:flex;height:36px;justify-content:center;transition:all .2s ease;width:36px}.genai-header-btn:hover{background:#ffffff0d;border-color:#ffffff1f;color:#fff}.genai-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.genai-stat-card{align-items:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;display:flex;justify-content:space-between;padding:16px;transition:all .2s ease}.genai-stat-card:hover{background:#ffffff0d;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.genai-stat-content{display:flex;flex-direction:column;gap:4px}.genai-stat-value{color:#fff;font-size:24px;font-weight:600}.genai-stat-label{color:#a0a0b0;font-size:12px}.genai-stat-icon{color:#3b82f6;height:20px;width:20px}.genai-content-area{gap:24px;padding:24px}.genai-chat-container,.genai-content-area{display:flex;flex:1 1;min-height:0;overflow:hidden}.genai-chat-container{flex-direction:column;gap:16px;min-width:0}.genai-smart-queries{background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;flex-shrink:0;overflow:hidden}.genai-smart-queries-header{align-items:center;border-bottom:1px solid #ffffff0f;display:flex;justify-content:space-between;padding:16px}.genai-smart-queries-header h3{color:#fff;font-size:14px;font-weight:600}.genai-close-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#a0a0b0;cursor:pointer;display:flex;height:28px;justify-content:center;transition:all .2s ease;width:28px}.genai-close-btn:hover{background:#ffffff0d;color:#fff}.genai-smart-queries-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:16px}.genai-smart-query-btn{background:#ffffff08;border:1px solid #ffffff0f;border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:12px;text-align:left;transition:all .2s ease}.genai-smart-query-btn:hover:not(:disabled){background:#ffffff0d;box-shadow:0 4px 12px #0003;transform:translateY(-2px)}.genai-smart-query-btn:disabled{cursor:not-allowed;opacity:.5}.genai-smart-query-btn.blue{border-color:#3b82f64d}.genai-smart-query-btn.green{border-color:#10b9814d}.genai-smart-query-btn.purple{border-color:#8b5cf64d}.genai-smart-query-btn.orange{border-color:#f59e0b4d}.genai-smart-query-icon{color:#3b82f6;height:16px;width:16px}.genai-smart-query-text{color:#fff;font-size:14px;font-weight:500}.genai-smart-query-desc{color:#a0a0b0;font-size:12px}.genai-messages-container{background:#ffffff05;border:1px solid #ffffff0f;border-radius:12px;flex:1 1;min-height:0;overflow-x:hidden;overflow-y:auto;position:relative}.genai-messages-inner{display:flex;flex-direction:column;gap:16px;padding:24px}.genai-empty-state{align-items:center;display:flex;flex-direction:column;justify-content:center;min-height:300px;padding:60px 24px;text-align:center}.genai-empty-icon{color:#fff3;height:48px;margin-bottom:16px;width:48px}.genai-empty-title{color:#fff;font-size:18px;font-weight:600;margin-bottom:8px}.genai-empty-text{color:#a0a0b0;font-size:14px}.genai-message{animation:messageSlideUp .3s ease;display:flex;gap:12px}@keyframes messageSlideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.genai-message-avatar{align-items:center;border-radius:8px;display:flex;flex-shrink:0;font-size:14px;font-weight:600;height:36px;justify-content:center;width:36px}.genai-message.user .genai-message-avatar{background:linear-gradient(135deg,#3b82f6,#2563eb);box-shadow:0 2px 8px #3b82f64d;color:#fff}.genai-message.assistant .genai-message-avatar{background:#1e1e2a;border:1px solid #ffffff0f;color:#3b82f6}.genai-message-content{background:#1e1e2a;border:1px solid #ffffff0f;border-radius:12px;color:#ffffffe6;flex:1 1;font-size:15px;line-height:1.6;padding:12px 16px}.genai-message.user .genai-message-content{background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;box-shadow:0 2px 8px #3b82f633;color:#fff}.genai-message-text{margin-bottom:12px}.genai-response-time{background:#10b98133;border-radius:4px;color:#10b981;display:inline-block;font-size:11px;margin-bottom:8px;padding:2px 6px}.genai-error-message{background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#ef4444;padding:12px}.genai-sql-container{background:#0000004d;border:1px solid #ffffff0f;border-radius:8px;margin-top:12px;padding:12px}.genai-sql-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.genai-sql-header span{color:#a0a0b0;font-size:12px;font-weight:500}.genai-sql-actions{display:flex;gap:8px}.genai-sql-action{align-items:center;background:#0000;border:1px solid #ffffff1a;border-radius:4px;color:#3b82f6;cursor:pointer;display:flex;font-size:11px;gap:4px;padding:4px 8px;transition:all .2s ease}.genai-sql-action:hover{background:#3b82f61a;border-color:#3b82f64d}.genai-sql-code{background:#0a0a0f;border:1px solid #ffffff0f;border-radius:6px;color:#06b6d4;font-family:Monaco,Courier New,monospace;font-size:12px;overflow-x:auto;padding:12px}.genai-viz-container{background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;margin-top:12px;padding:16px}.genai-viz-title{color:#fff;font-size:14px;font-weight:600;margin-bottom:16px}.genai-table-container{background:#ffffff05;border:1px solid #ffffff0f;border-radius:8px;margin-top:12px;overflow-x:auto}.genai-data-table{border-collapse:collapse;width:100%}.genai-data-table th{background:#ffffff08;border-bottom:1px solid #ffffff0f;color:#a0a0b0;font-size:11px;font-weight:600;letter-spacing:.5px;padding:12px;text-align:left;text-transform:uppercase}.genai-data-table td{border-bottom:1px solid #ffffff08;color:#fffc;font-size:13px;padding:12px}.genai-data-table tr:hover td{background:#ffffff05}.genai-table-footer{background:#ffffff08;color:#a0a0b0;font-size:12px;padding:12px;text-align:center}.genai-suggestions{border-top:1px solid #ffffff0f;margin-top:16px;padding-top:16px}.genai-suggestions-label{color:#a0a0b0;font-size:12px;font-weight:500;margin-bottom:8px}.genai-suggestions-list{display:flex;flex-wrap:wrap;gap:8px}.genai-suggestion-btn{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;color:#fffc;cursor:pointer;font-size:12px;padding:6px 12px;transition:all .2s ease}.genai-suggestion-btn:hover:not(:disabled){background:#ffffff14;color:#fff;transform:translateY(-1px)}.genai-suggestion-btn:disabled{cursor:not-allowed;opacity:.5}.genai-input-section{-webkit-backdrop-filter:blur(var(--sidebar-blur));backdrop-filter:blur(10px);background:#12121acc;border-top:1px solid #ffffff0f;flex-shrink:0;padding:20px}.genai-input-wrapper{align-items:flex-end;display:flex;gap:12px;position:relative}.genai-chat-input{background:#18181f;border:1px solid #ffffff0f;border-radius:16px;color:#fff;flex:1 1;font-family:inherit;font-size:15px;line-height:1.5;max-height:200px;min-height:52px;outline:none;overflow-y:auto;padding:14px 50px 14px 16px;resize:vertical;transition:all .2s ease}.genai-chat-input:focus{background:#1a1a22;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f61a}.genai-chat-input::placeholder{color:#6b6b7c}.genai-chat-input:disabled{background:#141418;cursor:not-allowed;opacity:.5}.genai-send-btn{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border:none;border-radius:8px;bottom:8px;box-shadow:0 2px 8px #3b82f633;color:#fff;cursor:pointer;display:flex;height:36px;justify-content:center;position:absolute;right:8px;transition:all .2s ease;width:36px;z-index:1}.genai-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #3b82f666;transform:scale(1.05)}.genai-send-btn:active:not(:disabled){transform:scale(.95)}.genai-send-btn:disabled{background:linear-gradient(135deg,#6b7280,#4b5563);cursor:not-allowed;opacity:.5;transform:none}.genai-analysis-sidebar{display:flex;flex-direction:column;min-height:0;width:400px}.genai-analysis-panel{background:#ffffff08;border:1px solid #ffffff0f;border-radius:12px;height:100%;overflow-x:hidden;overflow-y:auto;padding:20px}.genai-analysis-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:20px}.genai-analysis-title-group{align-items:center;display:flex;gap:12px}.genai-analysis-icon{color:#8b5cf6;height:24px;width:24px}.genai-analysis-title{color:#fff;font-size:18px;font-weight:600}.genai-analysis-loading{align-items:center;color:#a0a0b0;display:flex;font-size:12px;gap:8px}.genai-analysis-loading-icon{animation:pulse 2s infinite;height:14px;width:14px}.genai-analysis-empty{align-items:center;display:flex;flex-direction:column;justify-content:center;padding:40px 20px;text-align:center}.genai-analysis-empty-icon{color:#fff3;height:36px;margin-bottom:12px;width:36px}.genai-analysis-empty-text{color:#a0a0b0;font-size:14px;margin-bottom:4px}.genai-analysis-empty-subtext{color:#6b6b7c;font-size:12px}.genai-analysis-tabs{display:flex;flex-wrap:wrap;gap:8px;margin-bottom:20px}.genai-analysis-tab{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;color:#a0a0b0;cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:8px 12px;transition:all .2s ease;-webkit-user-select:none;user-select:none}.genai-analysis-tab:hover{background:#ffffff14;color:#fff}.genai-analysis-tab.active{color:#fff}.genai-analysis-tab.active.purple{background:#8b5cf633;border-color:#8b5cf666}.genai-analysis-tab.active.orange{background:#f59e0b33;border-color:#f59e0b66}.genai-analysis-tab.active.blue{background:#3b82f633;border-color:#3b82f666}.genai-analysis-tab.active.green{background:#10b98133;border-color:#10b98166}.genai-tab-icon{height:14px;width:14px}.genai-tab-badge{background:#0000004d;border-radius:10px;font-size:10px;font-weight:600;padding:2px 6px}.genai-analysis-content{display:flex;flex-direction:column;gap:12px}.genai-dashboard ::-webkit-scrollbar{height:8px;width:8px}.genai-dashboard ::-webkit-scrollbar-track{background:#0000}.genai-dashboard ::-webkit-scrollbar-thumb{background:#ffffff14;border-radius:4px}.genai-dashboard ::-webkit-scrollbar-thumb:hover{background:#ffffff1f}.genai-dashboard button{position:relative;z-index:1}@media (max-width:1024px){.genai-analysis-sidebar{display:none}}@media (max-width:767px){.genai-dashboard{height:auto;min-height:100vh}.genai-sidebar{box-shadow:2px 0 20px #00000080;height:100vh;left:0;position:fixed;top:0;transform:translateX(-260px);z-index:100}.genai-sidebar.open{transform:translateX(0)}.genai-content-area{gap:16px;padding:16px}.genai-smart-queries-grid,.genai-stats-grid{grid-template-columns:1fr}.genai-mode-toggle{display:none}.genai-data-table,.genai-data-table tbody,.genai-data-table td,.genai-data-table th,.genai-data-table thead,.genai-data-table tr{display:block}.genai-data-table thead tr{display:none}.genai-data-table tr{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:8px;margin-bottom:12px;overflow:hidden}.genai-data-table td{border-bottom:1px solid #ffffff0d;display:flex;justify-content:space-between;padding:8px 12px}.genai-data-table td:before{color:#ffffff80;content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px}}.w-3{width:.75rem}.h-3{height:.75rem}.w-4{width:1rem}.h-4{height:1rem}.transaction-modal-overlay{animation:fadeIn .15s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000bf;padding:16px;z-index:9999}.transaction-modal-content{animation:slideUp .2s ease;background:#1a1a2e;background:var(--color-surface,#1a1a2e);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:12px;box-shadow:0 20px 50px #00000080;display:flex;flex-direction:column;height:90vh;max-height:95vh;max-width:1800px;overflow:hidden;width:95%}.modal-header{align-items:center;background:#ffffff05;background:var(--color-surface-hover,#ffffff05);border-bottom:1px solid #ffffff1a;border-bottom:1px solid var(--color-border,#ffffff1a);display:flex;flex-shrink:0;justify-content:space-between;padding:12px 20px}.modal-header-left{display:flex;flex:1 1;flex-direction:column;gap:6px}.modal-header-right{align-items:center;display:flex;gap:8px}.modal-title{color:#e5e7eb;color:var(--color-text,#e5e7eb);font-size:16px;font-weight:600;margin:0}.node-info{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.node-info-badge{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:4px;color:#9ca3af;color:var(--color-text-muted,#9ca3af);display:inline-flex;font-size:11px;font-weight:500;gap:5px;padding:3px 8px}.node-info-badge.highlight{background:#3b82f626;border-color:#3b82f64d;color:#93c5fd}.node-info-badge svg{height:12px;opacity:.7;width:12px}.column-info-banner{align-items:center;background:#3b82f614;border-bottom:1px solid #3b82f626;display:flex;font-size:11px;gap:12px;justify-content:space-between;padding:8px 16px}.info-content{align-items:center;color:#9ca3af;color:var(--color-text-muted,#9ca3af);display:flex;gap:8px}.info-content svg{height:14px;opacity:.6;width:14px}.info-close{background:#0000;border:none;border-radius:4px;color:#9ca3af;color:var(--color-text-muted,#9ca3af);cursor:pointer;display:flex;padding:4px}.info-close:hover{background:#ffffff1a}.source-indicator{border-radius:3px;display:inline-block;font-size:10px;font-weight:600;letter-spacing:.3px;padding:2px 6px;text-transform:uppercase}.raw-data-indicator{background:#ef44441f;border:1px solid #ef444440;color:#fca5a5}.classification-indicator{background:#fbbf241f;border:1px solid #fbbf2440;color:#fcd34d}.stats-bar{background:#ffffff05;background:var(--color-surface-hover,#ffffff05);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);flex-shrink:0;flex-wrap:wrap;gap:24px;padding:10px 20px}.stat-item,.stats-bar{align-items:center;display:flex}.stat-item{gap:6px;white-space:nowrap}.stat-item svg{color:#60a5fa;color:var(--color-primary,#60a5fa);height:14px;opacity:.8;width:14px}.transaction-modal-content .stat-label{color:#93c5fd;font-size:11px;font-weight:600;letter-spacing:.5px;text-transform:uppercase}.transaction-modal-content .stat-value{font-feature-settings:"tnum";color:#fff;font-size:18px;font-variant-numeric:tabular-nums;font-weight:700}.stat-item.verified .stat-value,.stat-item.verified svg{color:#34d399}.stat-item.pending .stat-value,.stat-item.pending svg{color:#fbbf24}.modal-body{flex:1 1;min-height:0;padding:12px}.modal-body,.transaction-table{display:flex;flex-direction:column;overflow:hidden}.transaction-table{background:#0000;border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:8px;height:100%}.transaction-table.editable-data-table{font-size:12px}.transaction-table .edt-header{background:#ffffff05;background:var(--color-surface-hover,#ffffff05);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);padding:8px 12px}.transaction-table .edt-title{font-size:13px}.transaction-table .edt-controls{gap:6px}.transaction-table .edt-controls .btn{font-size:11px;padding:4px 8px}.transaction-table .edt-controls .btn svg{height:14px;width:14px}.transaction-table .edt-search{font-size:12px;height:28px;padding:4px 10px;width:180px}.transaction-table .edt-table-container{flex:1 1;min-height:0;overflow:auto}.transaction-table .edt-table{border-collapse:collapse;font-size:11px;table-layout:fixed;width:100%}.transaction-table .edt-th{background:#ffffff08;background:var(--color-surface-hover,#ffffff08);border-bottom:2px solid #ffffff1a;border-bottom:2px solid var(--color-border,#ffffff1a);border-right:1px solid #ffffff0d;border-right:1px solid var(--color-border,#ffffff0d);color:#9ca3af;color:var(--color-text-muted,#9ca3af);font-size:10px;font-weight:600;letter-spacing:.5px;padding:0;position:sticky;text-transform:uppercase;top:0;z-index:10}.transaction-table .edt-th:last-child{border-right:none}.transaction-table .edt-th[data-source=raw_data]{border-top:3px solid #ef444480}.transaction-table .edt-th[data-source=classification]{border-top:3px solid #fbbf2499}.transaction-table td[data-source=classification] .edt-cell{border-left:2px solid #fbbf2433}.transaction-table td[data-source=classification] .edt-cell:hover{border-left:2px solid #fbbf2480}.transaction-table .edt-th-content{align-items:center;display:flex;justify-content:space-between;min-height:28px;padding:6px 8px}.transaction-table .edt-th-label{align-items:center;display:flex;gap:4px}.transaction-table .edt-sort-indicator{height:12px;width:12px}.transaction-table .edt-filter-button{font-size:10px;padding:2px 4px}.transaction-table .edt-table td{border-bottom:1px solid #ffffff0d;border-bottom:1px solid var(--color-border,#ffffff0d);overflow:hidden;padding:0}.transaction-table .item-desc-cell{display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-table .item-desc-cell:hover{color:#93c5fd}.transaction-table .edt-cell{color:#e5e7eb;color:var(--color-text,#e5e7eb);font-size:11px;line-height:1.3;min-height:28px;padding:5px 8px}.transaction-table .edt-cell.editable:hover{background:#3b82f614}.transaction-table .edt-cell.non-editable{background:#ffffff03;color:#9ca3af;color:var(--color-text-muted,#9ca3af)}.transaction-table .edt-empty{color:#6b7280;color:var(--color-text-subtle,#6b7280);font-size:10px}.transaction-table .edt-table tbody tr:nth-child(2n){background:hsla(0,0%,100%,.015)}.transaction-table .edt-table tbody tr:hover{background:#3b82f60f}.transaction-table .edt-cell-input{border-width:1px;font-size:11px;height:24px;padding:3px 6px}.transaction-table .edt-cell-input:focus{box-shadow:0 0 0 2px #3b82f633}.transaction-table select.edt-cell-input{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 20 20'%3E%3Cpath stroke='%236b7280' stroke-linecap='round' stroke-linejoin='round' stroke-width='1.5' d='m6 8 4 4 4-4'/%3E%3C/svg%3E");background-position:right 4px center;background-repeat:no-repeat;background-size:16px;cursor:pointer;height:26px;padding-right:24px}.transaction-table .edt-cell-saved,.transaction-table .edt-cell-saving{font-size:11px;gap:4px;padding:5px 8px}.transaction-table .edt-saved-indicator,.transaction-table .edt-saving-indicator{height:12px;width:12px}.transaction-table .edt-actions{padding:2px;width:60px}.transaction-table .edt-actions .btn{padding:3px}.transaction-table .edt-actions .btn svg{height:14px;width:14px}.transaction-table .edt-column-selector{font-size:11px;padding:8px 12px}.transaction-table .edt-column-selector h4{font-size:11px;margin-bottom:6px}.transaction-table .edt-column-list{gap:4px;grid-template-columns:repeat(auto-fill,minmax(150px,1fr))}.transaction-table .edt-column-item{font-size:11px;gap:4px}.transaction-table .edt-column-item input{height:14px;width:14px}.transaction-table .edt-filter-dropdown{font-size:11px;max-width:250px;min-width:160px}.transaction-table .edt-filter-header{font-size:11px;padding:6px 10px}.transaction-table .edt-filter-option{font-size:11px;gap:6px;padding:4px 8px}.transaction-table .edt-filter-option input{height:14px;width:14px}.transaction-table .edt-footer{border-top:1px solid #ffffff14;border-top:1px solid var(--color-border,#ffffff14);font-size:11px;gap:16px;padding:6px 12px}.transaction-table .edt-empty-state{font-size:12px;padding:32px}.status-badge,.verification-status-badge{align-items:center;border-radius:3px;display:inline-flex;font-size:10px;font-weight:600;gap:3px;letter-spacing:.3px;padding:2px 6px;text-transform:uppercase}.status-badge.verified,.verification-status-badge.verified{background:#10b98126;border:1px solid #10b98140;color:#34d399}.status-badge.pending,.verification-status-badge.pending{background:#f59e0b26;border:1px solid #f59e0b40;color:#fbbf24}.status-badge.rejected,.verification-status-badge.rejected{background:#ef444426;border:1px solid #ef444440;color:#f87171}.modal-close-btn{align-items:center;background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;color:#9ca3af;color:var(--color-text-muted,#9ca3af);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s ease;width:32px}.modal-close-btn:hover{background:#ef444426;border-color:#ef44444d;color:#f87171}.modal-close-btn svg{height:18px;width:18px}.info-button{align-items:center;background:#3b82f61a;border:1px solid #3b82f633;border-radius:6px;color:#9ca3af;color:var(--color-text-muted,#9ca3af);cursor:pointer;display:flex;height:28px;justify-content:center;padding:0;width:28px}.info-button:hover{background:#3b82f633;color:#60a5fa}.info-button svg{height:16px;width:16px}.reset-columns-button{align-items:center;background:#0000;border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:6px;color:#9ca3af;color:var(--color-text-muted,#9ca3af);cursor:pointer;display:flex;font-size:11px;gap:4px;height:28px;padding:0 10px}.reset-columns-button:hover{background:#ffffff0d;color:#e5e7eb;color:var(--color-text,#e5e7eb)}.reset-columns-button svg{height:14px;width:14px}.btn-retry{background:#3b82f626;border:1px solid #3b82f64d;border-radius:6px;color:#60a5fa;cursor:pointer;font-size:12px;font-weight:500;margin-top:12px;padding:8px 16px}.btn-retry:hover{background:#3b82f640}.empty-state,.error-state,.loading-state{align-items:center;color:#9ca3af;color:var(--color-text-muted,#9ca3af);display:flex;flex-direction:column;gap:12px;height:100%;justify-content:center;text-align:center}.empty-state svg,.error-state svg,.loading-state svg{height:40px;opacity:.5;width:40px}.error-state{color:#f87171}.empty-state h3,.error-state h3{color:#e5e7eb;color:var(--color-text,#e5e7eb);font-size:16px;font-weight:600;margin:0}.empty-state p,.error-state p{color:#9ca3af;color:var(--color-text-muted,#9ca3af);font-size:13px;margin:0}.modal-footer{align-items:center;background:#ffffff05;background:var(--color-surface-hover,#ffffff05);border-top:1px solid #ffffff14;border-top:1px solid var(--color-border,#ffffff14);display:flex;flex-shrink:0;justify-content:space-between;padding:10px 20px}.pagination-info{color:#9ca3af;color:var(--color-text-muted,#9ca3af);font-size:12px}.pagination-controls{display:flex;gap:8px}.btn-pagination{background:#3b82f61a;border:1px solid #3b82f640;border-radius:6px;color:#60a5fa;cursor:pointer;font-size:12px;font-weight:500;padding:6px 14px}.btn-pagination:hover:not(:disabled){background:#3b82f633}.btn-pagination:disabled{cursor:not-allowed;opacity:.5}.update-indicator{align-items:center;background:#1a1a2e;background:var(--color-surface,#1a1a2e);border:1px solid #3b82f64d;border-radius:6px;bottom:20px;box-shadow:0 4px 12px #0000004d;color:#60a5fa;display:flex;font-size:12px;gap:8px;padding:8px 14px;position:fixed;right:20px;z-index:10000}.update-indicator svg{height:14px;width:14px}.transaction-modal-content ::-webkit-scrollbar{height:6px;width:6px}.transaction-modal-content ::-webkit-scrollbar-track{background:#ffffff05;border-radius:3px}.transaction-modal-content ::-webkit-scrollbar-thumb{background:#ffffff26;border-radius:3px}.transaction-modal-content ::-webkit-scrollbar-thumb:hover{background:#ffffff40}@media (max-width:1200px){.transaction-modal-content{max-width:98%}}@media (max-width:767px){.transaction-modal-content{border-radius:0;height:100vh;height:100dvh;max-height:100vh;width:100%}.transaction-modal-overlay{padding:0}.modal-header{align-items:flex-start;flex-direction:column;gap:8px;padding:12px 16px}.modal-header-right{justify-content:flex-end;width:100%}.stats-bar{flex-wrap:wrap;gap:8px;padding:8px 12px}.stat-item{flex:1 1;min-width:70px}.modal-body{padding:8px}.modal-footer{flex-direction:column;gap:8px;padding:8px 12px}.transaction-table .edt-search{width:100%}}.transaction-modal-content.dense-mode .edt-cell{font-size:11px!important;line-height:1.3!important;max-height:26px!important;min-height:0!important;min-height:auto!important;overflow:hidden!important;padding:3px 6px!important;text-overflow:ellipsis!important;white-space:nowrap!important}.transaction-modal-content.dense-mode .edt-th-content{padding:4px 6px!important}.transaction-modal-content.dense-mode .edt-th,.transaction-modal-content.dense-mode .edt-th-label{font-size:10px!important}.transaction-modal-content.dense-mode .edt-table td,.transaction-modal-content.dense-mode td{height:26px!important;padding:0!important}.transaction-modal-content.dense-mode .edt-table th,.transaction-modal-content.dense-mode th{padding:0!important}.transaction-modal-content.dense-mode .edt-cell div,.transaction-modal-content.dense-mode .edt-cell span{overflow:hidden!important;text-overflow:ellipsis!important;white-space:nowrap!important}.transaction-modal-content.dense-mode .edt-cell.editable:hover:after{width:2px}.transaction-modal-content.dense-mode .stats-bar{gap:16px;padding:4px 16px}.transaction-modal-content.dense-mode .stat-value{font-size:13px}.transaction-modal-content.dense-mode .stat-label{font-size:9px}.transaction-modal-content.dense-mode .stat-item svg{height:12px;width:12px}.transaction-modal-content.dense-mode .modal-header{padding:6px 16px}.transaction-modal-content.dense-mode .modal-header-left{gap:2px}.transaction-modal-content.dense-mode .modal-title{font-size:14px}.transaction-modal-content.dense-mode .node-info{gap:4px}.transaction-modal-content.dense-mode .node-info-badge{font-size:10px;padding:1px 6px}.transaction-modal-content.dense-mode .node-info-badge svg{height:10px;width:10px}.transaction-modal-content.dense-mode .modal-body{padding:6px}.dense-toggle-btn{align-items:center;background:#667eea1a;border:1px solid #667eea40;border-radius:6px;color:#9ca3af!important;cursor:pointer;display:flex;font-size:12px;font-weight:500;gap:4px;padding:4px 10px;transition:all .2s ease;white-space:nowrap}.dense-toggle-btn:hover{background:#667eea33;color:#a5b4fc!important}.dense-toggle-btn.active{background:#667eea40;border-color:#667eea80;color:#a5b4fc!important}:root{--sankey-bg-primary:var(--gray-950,#09090b);--sankey-bg-secondary:var(--gray-900,#18181b);--sankey-bg-tertiary:var(--gray-800,#27272a);--sankey-bg-glass:#18181b80;--sankey-accent-primary:var(--color-primary,#3b82f6);--sankey-accent-secondary:var(--color-success,#10b981);--sankey-accent-tertiary:var(--color-warning,#f59e0b);--sankey-accent-danger:var(--color-error,#ef4444);--sankey-accent-info:var(--color-accent,#06b6d4);--sankey-glow-primary:0 0 30px #3b82f666;--sankey-glow-secondary:0 0 20px #10b9814d;--sankey-glow-danger:0 0 20px #ef44444d;--sankey-text-primary:var(--color-text,#fffffff2);--sankey-text-secondary:var(--color-text-muted,#ffffffb3);--sankey-text-muted:var(--color-text-subtle,#fff9);--sankey-border-subtle:var(--color-border,#ffffff1a);--sankey-border-light:var(--color-border-hover,#fff3);--sankey-shadow-xl:var(--shadow-xl,0 20px 25px -5px #00000014);--sankey-shadow-glow:0 0 60px #3b82f626;--sankey-transition-fast:var(--duration-fast,150ms) var(--ease-out,cubic-bezier(0,0,0.2,1));--sankey-transition-smooth:var(--duration-normal,300ms) var(--ease-out,cubic-bezier(0,0,0.2,1));--sankey-transition-bounce:var(--duration-slow,500ms) var(--ease-out-back,cubic-bezier(0.34,1.56,0.64,1))}.sankey-container{background:#09090b;background:var(--color-surface,var(--sankey-bg-primary));border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:12px;border-radius:var(--radius-xl,12px);box-sizing:border-box;max-width:100%;min-height:600px;overflow:auto;padding:10px;position:relative}.sankey-container.expanded{max-width:100%;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.sankey-container{--sankey-bg-primary:var(--color-surface,#fff);--sankey-bg-secondary:var(--color-surface-hover,#fafafa);--sankey-bg-tertiary:var(--color-surface-active,#f4f4f5);--sankey-text-primary:var(--color-text,#18181b);--sankey-text-secondary:var(--color-text-muted,#52525b);--sankey-text-muted:var(--color-text-subtle,#71717a);--sankey-border-subtle:var(--color-border,#e4e4e7);--sankey-border-light:var(--color-border-hover,#d4d4d8)}[data-theme=dark] .sankey-container{--sankey-bg-primary:var(--gray-950,#09090b);--sankey-bg-secondary:var(--gray-900,#18181b);--sankey-bg-tertiary:var(--gray-800,#27272a);--sankey-text-primary:#fffffff2;--sankey-text-secondary:#ffffffb3;--sankey-text-muted:#fff9;--sankey-border-subtle:#ffffff1a;--sankey-border-light:#fff3;background:linear-gradient(135deg,#09090b,#27272a 50%,#09090b);background:linear-gradient(135deg,var(--sankey-bg-primary) 0,var(--sankey-bg-tertiary) 50%,var(--sankey-bg-primary) 100%)}.sankey-chart-container>svg,.sankey-chart-wrapper>svg,.sankey-container>svg{display:block;height:auto;margin:0;min-height:600px;padding:0;width:100%}.sankey-container .drill-down-controls svg,.sankey-container .filter-button svg,.sankey-container .filter-panel svg,.sankey-container .icon svg,.sankey-container .stat-card svg,.sankey-container .view-controls svg,.sankey-container .zoom-controls svg,.sankey-container button svg,.sankey-container div>svg:not(.sankey-chart-container>svg):not(.sankey-chart-wrapper>svg),.sankey-container span>svg,.sankey-container svg.lucide,.sankey-container svg[class*=lucide]{display:inline-block!important;height:auto!important;min-height:0!important;min-height:auto!important;min-width:0!important;min-width:auto!important;vertical-align:middle;width:auto!important}.sankey-chart-wrapper{height:100%;margin-top:0;padding-top:0;width:100%}.glass-panel{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px) saturate(180%);background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #ffffff1a;border:1px solid var(--sankey-border-subtle);border-radius:16px;box-shadow:0 20px 25px -5px #00000014,inset 0 1px 0 #ffffff0d;box-shadow:var(--sankey-shadow-xl),inset 0 1px 0 #ffffff0d;padding:24px;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.glass-panel:hover{border-color:#3b82f633;box-shadow:0 20px 25px -5px #00000014,0 0 60px #3b82f626,inset 0 1px 0 #ffffff14;box-shadow:var(--sankey-shadow-xl),var(--sankey-shadow-glow),inset 0 1px 0 #ffffff14;transform:translateY(-2px)}.expand-button{cursor:pointer;opacity:.9;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.expand-button:hover{opacity:1;transform:scale(1.15)}.expand-button circle{filter:drop-shadow(0 2px 4px rgba(0,0,0,.3));transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.expand-button:hover circle{stroke-width:2;filter:drop-shadow(0 3px 6px rgba(59,130,246,.4))}.expand-button line{pointer-events:none;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}@keyframes expandPulse{0%{box-shadow:0 0 0 0 #3b82f666;transform:scale(1)}50%{box-shadow:0 0 20px 10px #3b82f600;transform:scale(1.2)}to{box-shadow:0 0 0 0 #3b82f600;transform:scale(1)}}.expand-button:active{animation:expandPulse .3s ease}.expand-button:after{color:#3b82f6;color:var(--sankey-accent-primary);content:"→";font-size:12px;opacity:0;position:absolute;right:-20px;top:-2px;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.expand-button:hover:after{opacity:.6;right:-25px}.node.supplier-node rect{stroke-dasharray:2 2;stroke-opacity:.6;animation:slideInFromLeft .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-30px)}to{opacity:.85;transform:translateX(0)}}.node.others-group rect{fill-opacity:.7;stroke-dasharray:4 2;stroke-opacity:.5}.others-group-label{align-items:center;display:flex;gap:4px}.others-group-label:before{color:#6b7280;content:"∑";font-size:14px}.link.component-to-supplier path{stroke-dasharray:5,3;animation:flowAnimation 2s linear infinite}@keyframes flowAnimation{to{stroke-dashoffset:-8}}.link path[data-custom=true]{stroke-dasharray:1000;stroke-dashoffset:1000;animation:drawPath 1s ease forwards}@keyframes drawPath{to{stroke-dashoffset:0}}.supplier-count-badge{align-items:center;background:linear-gradient(135deg,#3b82f633,#3b82f61a);border:1px solid #3b82f666;border-radius:10px;box-shadow:0 0 10px #3b82f633;color:#3b82f6;color:var(--sankey-accent-primary);display:inline-flex;font-size:11px;font-weight:600;height:20px;justify-content:center;min-width:20px;padding:0 6px}.drill-down-controls{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #ffffff1a;border:1px solid var(--sankey-border-subtle);border-radius:8px;display:flex;gap:16px;margin-bottom:16px;padding:12px 16px;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.drill-down-controls button{transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.drill-down-controls button:hover{box-shadow:0 4px 12px #3b82f633;transform:translateY(-1px)}.drill-down-controls button:active{transform:translateY(0)}.info-panel{animation:slideDown .3s cubic-bezier(.4,0,.2,1) forwards;overflow:hidden}.view-mode-toggle{background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #fff3;border:1px solid var(--sankey-border-light);border-radius:6px;display:inline-flex;overflow:hidden}.view-mode-toggle button{background:#0000;border:none;color:#fff9;color:var(--sankey-text-muted);cursor:pointer;font-size:.85rem;padding:6px 12px;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.view-mode-toggle button.active{background:linear-gradient(135deg,#3b82f633,#3b82f61a);box-shadow:inset 0 0 10px #3b82f61a;color:#3b82f6;color:var(--sankey-accent-primary)}.view-mode-toggle button:hover:not(.active){background:#ffffff0d}input[type=date]{background:linear-gradient(135deg,#141423e6,#1e1e2de6);border:1px solid #fff3;border:1px solid var(--sankey-border-light);border-radius:8px;color:#ffffffb3;color:var(--sankey-text-secondary);font-size:.875rem;padding:10px 14px;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}input[type=date]:hover{background:linear-gradient(135deg,#1e1e2de6,#282837e6);border-color:#3b82f64d}input[type=date]:focus{border-color:#3b82f6;border-color:var(--sankey-accent-primary);box-shadow:0 0 0 3px #3b82f61a,0 0 30px #3b82f666;box-shadow:0 0 0 3px #3b82f61a,var(--sankey-glow-primary);outline:none}input[type=checkbox]{appearance:none;background:#14142399;border:2px solid #fff3;border-radius:6px;cursor:pointer;height:20px;position:relative;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast);width:20px}input[type=checkbox]:hover{border-color:#3b82f6;border-color:var(--sankey-accent-primary);box-shadow:0 0 10px #3b82f633}input[type=checkbox]:checked{animation:checkPulse .3s ease;background:linear-gradient(135deg,#667eea,#764ba2);border-color:#0000}@keyframes checkPulse{0%{transform:scale(.95)}50%{transform:scale(1.1)}to{transform:scale(1)}}input[type=checkbox]:checked:after{animation:checkFadeIn .2s ease;color:#fff;content:"✓";font-size:14px;font-weight:700;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%)}@keyframes checkFadeIn{0%{opacity:0;transform:translate(-50%,-50%) scale(0)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.filter-button{background:linear-gradient(135deg,#ffffff08,#ffffff03);border:1px solid #fff3;border:1px solid var(--sankey-border-light);border-radius:8px;color:#fff9;color:var(--sankey-text-muted);cursor:pointer;font-size:.875rem;overflow:hidden;padding:8px 16px;position:relative;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.filter-button:before{background:radial-gradient(circle,#3b82f64d,#0000);content:"";height:0;left:50%;position:absolute;top:50%;transform:translate(-50%,-50%);transition:width .3s,height .3s;width:0}.filter-button:hover{background:linear-gradient(135deg,#3b82f61a,#3b82f60d);border-color:#3b82f666;box-shadow:0 4px 12px #3b82f633;color:#3b82f6;color:var(--sankey-accent-primary);transform:translateY(-1px)}.filter-button:hover:before{height:100%;width:100%}.filter-button.active{background:linear-gradient(135deg,#3b82f640,#3b82f626);border-color:#3b82f6;border-color:var(--sankey-accent-primary);box-shadow:0 0 20px #3b82f64d,inset 0 0 10px #3b82f61a;color:#3b82f6;color:var(--sankey-accent-primary)}.quick-date-tab{background:#ffffff05;border:1px solid #ffffff1a;border:1px solid var(--sankey-border-subtle);border-radius:8px;color:#fff9;color:var(--sankey-text-muted);cursor:pointer;font-size:.875rem;padding:8px 14px;position:relative;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast);white-space:nowrap}.quick-date-tab:hover{background:#3b82f614;border-color:#3b82f633;color:#ffffffb3;color:var(--sankey-text-secondary);transform:translateY(-1px)}.quick-date-tab.active{background:linear-gradient(135deg,#3b82f633,#3b82f61a);border-color:#3b82f6;border-color:var(--sankey-accent-primary);box-shadow:0 0 15px #3b82f633;color:#3b82f6;color:var(--sankey-accent-primary);font-weight:500}.quick-date-tab.active:after{animation:slideIn .3s ease;background:linear-gradient(90deg,#0000,#3b82f6,#0000);background:linear-gradient(90deg,#0000,var(--sankey-accent-primary),#0000);bottom:-1px;content:"";height:2px;left:10%;position:absolute;right:10%}@keyframes slideIn{0%{left:50%;right:50%}to{left:10%;right:10%}}.stat-card{align-items:center;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px) saturate(180%);background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #ffffff1a;border:1px solid var(--sankey-border-subtle);border-radius:12px;display:flex;gap:16px;overflow:hidden;padding:20px;position:relative;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.stat-card:before{background:linear-gradient(45deg,#0000,#3b82f60d,#0000);content:"";height:200%;left:-50%;opacity:0;position:absolute;top:-50%;transform:rotate(45deg);transition:all .5s;width:200%}.stat-card:hover{border-color:#3b82f64d;box-shadow:0 12px 30px #0006,0 0 30px #3b82f61a;transform:translateY(-3px)}.stat-card:hover:before{animation:shimmer .5s ease;opacity:1}.sankey-chart-container{height:100%;overflow:auto;position:relative;scroll-behavior:smooth;width:100%}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:#ffffff05;border-radius:10px}::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#3b82f64d,#3b82f633);border-radius:10px}::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#3b82f680,#3b82f64d)}.sankey-container::-webkit-scrollbar{height:8px}.sankey-container::-webkit-scrollbar-track{background:#ffffff0d;border-radius:4px}.sankey-container::-webkit-scrollbar-thumb{background:#3b82f64d;border-radius:4px}.sankey-container::-webkit-scrollbar-thumb:hover{background:#3b82f680}svg text{fill:#ffffffb3;fill:var(--sankey-text-secondary);font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif}svg .layer-label{fill:#fff9;fill:var(--sankey-text-muted);font-size:10px;font-weight:600;letter-spacing:1px;opacity:.8;text-transform:uppercase;transition:opacity .3s cubic-bezier(0,0,.2,1);transition:opacity var(--sankey-transition-smooth)}svg .layer-label:hover{opacity:1}svg .node text{fill:#ffffffb3;fill:var(--sankey-text-secondary);font-size:9px;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}svg .node:hover text{fill:#fffffff2;fill:var(--sankey-text-primary);font-weight:500}svg .node.component_type text{font-size:11px;font-weight:600}svg .node rect{cursor:pointer;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}svg .node:hover rect{filter:brightness(1.2) drop-shadow(0 0 10px currentColor)}.node-entering{animation:nodeEnter .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes nodeEnter{0%{opacity:0;transform:translateX(-20px)}to{opacity:1;transform:translateX(0)}}.node-exiting{animation:nodeExit .3s cubic-bezier(.4,0,.2,1) forwards}@keyframes nodeExit{0%{opacity:1;transform:translateX(0)}to{opacity:0;transform:translateX(20px)}}svg .link{transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}svg .link path{mix-blend-mode:multiply;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}svg .link:hover{filter:drop-shadow(0 0 5px rgba(59,130,246,.5));opacity:.8!important}svg .link path:hover{stroke-opacity:.8!important;filter:brightness(1.2)}.link-highlighted{animation:pathHighlight 2s ease-in-out infinite}@keyframes pathHighlight{0%{stroke-width:1;opacity:.5}50%{stroke-width:2;opacity:.8}to{stroke-width:1;opacity:.5}}.zoom-controls{pointer-events:all;-webkit-user-select:none;user-select:none}.zoom-controls text{cursor:pointer;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.zoom-controls text:hover{filter:brightness(1.3);transform:scale(1.1)}.zoom-control{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(10px);background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #fff3;border:1px solid var(--sankey-border-light);border-radius:8px;color:#ffffffb3;color:var(--sankey-text-secondary);cursor:pointer;padding:8px;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast)}.zoom-control:hover{background:#3b82f626;border-color:#3b82f666;box-shadow:0 0 15px #3b82f64d;transform:scale(1.05)}.zoom-control:active{transform:scale(.98)}.animate-spin,.loading-spinner{animation:spin 1s linear infinite}.loading-pulse{animation:pulse 2s ease infinite}.sankey-tooltip{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#18181b80;background:var(--sankey-bg-glass);border:1px solid #3b82f64d;border-radius:12px;box-shadow:0 20px 40px #00000080,0 0 40px #3b82f61a;max-height:500px;max-width:450px;overflow-y:auto;padding:12px;pointer-events:none;position:absolute;transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-fast);z-index:1000}.sankey-tooltip.visible{opacity:1;transform:translateY(0)}.sankey-tooltip.hidden{opacity:0;transform:translateY(-5px)}.category-filter-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(250px,1fr));max-height:400px;overflow-y:auto;padding-right:8px}.filter-panel{transform-origin:top;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--sankey-transition-smooth)}.filter-panel-expanded{max-height:500px;opacity:1;transform:scaleY(1)}.filter-panel-collapsed{max-height:0;opacity:0;overflow:hidden;transform:scaleY(0)}.sankey-flow-chart{background:#1a1a2e;min-height:600px;position:relative}.sankey-flow-chart>svg{display:block;height:100%;width:100%}.sankey-flow-chart .icon svg,.sankey-flow-chart button svg,.sankey-flow-chart svg.lucide{display:inline-block;height:auto;width:auto}.diagram-group.has-expanded-nodes{transition:all .5s cubic-bezier(.4,0,.2,1)}@media (max-width:1600px){.sankey-container{overflow-x:scroll}}@media (min-width:1600px){.sankey-container.expanded{max-width:100%}.expand-button{transform:scale(1.1)}}@media (max-width:1400px){.sankey-chart-container{max-height:800px}.glass-panel{padding:20px}}@media (max-width:1200px){.sankey-chart-container{max-height:700px}.stat-card{padding:16px}}@media (max-width:767px){.sankey-container{-webkit-overflow-scrolling:touch;overflow-x:auto}.sankey-chart-container{max-height:600px;overflow-x:auto}.category-filter-grid{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));max-height:300px}.glass-panel{border-radius:12px;padding:16px}.drill-down-controls{align-items:stretch;flex-direction:column}.zoom-controls{display:flex;flex-direction:column;gap:4px;transform:translate(-60px,10px) scale(.85)}.zoom-control{min-height:44px;min-width:44px}.layer-label{font-size:9px!important}.expand-button{transform:scale(.85)}.filter-button,.quick-date-tab{min-height:44px;width:100%}.view-mode-toggle{flex-direction:column;width:100%}.view-mode-toggle button{min-height:44px}.sankey-rotate-hint{display:block}input[type=date]{min-height:44px;width:100%}}.sankey-rotate-hint{display:none}@media (prefers-color-scheme:dark){.sankey-container{background:linear-gradient(135deg,#050508,#15152a)}.sankey-tooltip{background:#0a0a14fa}}@media print{.sankey-container{background:#fff}svg text{fill:#333}.glass-panel{background:#fff;border:1px solid #ccc}}.expand-button{filter:drop-shadow(0 2px 4px rgba(0,0,0,.2));transition:all .2s cubic-bezier(.4,0,.2,1)}.expand-button:hover{filter:drop-shadow(0 4px 8px rgba(59,130,246,.4));transform:scale(1.1)}.expand-buttons g:hover .expand-button{animation:pulse 1s cubic-bezier(.4,0,.6,1) infinite}.sankey-tooltip{pointer-events:none!important;z-index:10000!important}.ci-dashboard{color:#f3f4f6;color:var(--gray-100,#f3f4f6);display:block!important;flex:none!important;height:auto!important;margin:0 auto;max-width:1400px;min-height:auto!important;overflow:visible!important;padding:24px}.content-wrapper:has(.ci-dashboard){display:block!important;height:auto!important;min-height:auto!important;overflow:visible!important}.content-wrapper:has(.ci-dashboard)>div{display:block!important;flex:none!important;height:auto!important}.ci-error,.ci-loading{align-items:center;color:#9ca3af;color:var(--gray-400,#9ca3af);display:flex;font-size:16px;gap:12px;justify-content:center;padding:80px 24px}.ci-error{color:#ef4444;flex-direction:column;gap:16px}.ci-spin{animation:ci-spin 1s linear infinite}@keyframes ci-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ci-header{flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:24px}.ci-header,.ci-header-left{align-items:center;display:flex}.ci-header-left{color:#3b82f6;color:var(--primary,#3b82f6);gap:14px}.ci-header-left h1{color:#f9fafb;color:var(--gray-50,#f9fafb);font-size:24px;font-weight:700;margin:0}.ci-header-left p{color:#9ca3af;color:var(--gray-400,#9ca3af);font-size:13px;margin:2px 0 0}.ci-grade-badge,.ci-header-right{align-items:center;display:flex;gap:12px}.ci-grade-badge{background:#0003;border:2px solid;border-radius:12px;padding:10px 18px}.ci-grade-letter{font-size:32px;font-weight:800;line-height:1}.ci-grade-detail{display:flex;flex-direction:column}.ci-grade-label{color:var(--gray-400);font-size:11px;letter-spacing:.5px;text-transform:uppercase}.ci-grade-error{color:var(--gray-300);font-size:13px}.ci-tabs{border-bottom:1px solid #1f2937;border-bottom:1px solid var(--gray-800,#1f2937);display:flex;gap:4px;margin-bottom:24px;overflow-x:auto;padding-bottom:2px}.ci-tab{align-items:center;background:none;border:none;border-bottom:2px solid #0000;color:#9ca3af;color:var(--gray-400,#9ca3af);cursor:pointer;display:flex;font-size:13px;font-weight:500;gap:6px;padding:10px 16px;transition:all .15s;white-space:nowrap}.ci-tab:hover{color:var(--gray-200)}.ci-tab.active{border-bottom-color:#3b82f6;border-bottom-color:var(--primary,#3b82f6);color:#3b82f6;color:var(--primary,#3b82f6)}.ci-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:24px}.ci-stat-card{align-items:center;background:#111827cc;background:var(--glass-dark,#111827cc);border:1px solid #1f2937;border:1px solid var(--gray-800,#1f2937);border-radius:12px;display:flex;gap:14px;padding:18px 20px;transition:border-color .2s}.ci-stat-card:hover{border-color:#374151;border-color:var(--gray-700,#374151)}.ci-stat-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.ci-stat-blue .ci-stat-icon{background:#3b82f626;color:#3b82f6}.ci-stat-green .ci-stat-icon{background:#22c55e26;color:#22c55e}.ci-stat-yellow .ci-stat-icon{background:#eab30826;color:#eab308}.ci-stat-red .ci-stat-icon{background:#ef444426;color:#ef4444}.ci-stat-content{flex:1 1;min-width:0}.ci-stat-label{color:var(--gray-400);font-size:12px;letter-spacing:.5px;text-transform:uppercase}.ci-stat-value{color:var(--gray-50);font-size:22px;font-weight:700;margin:2px 0}.ci-stat-sub{color:var(--gray-500);font-size:12px}.ci-stat-trend{align-items:center;border-radius:6px;display:flex;font-size:12px;font-weight:600;gap:2px;padding:4px 8px}.ci-stat-trend.up{background:#22c55e1a;color:#22c55e}.ci-stat-trend.down{background:#ef44441a;color:#ef4444}.ci-stat-trend.flat{color:#9ca3af}.ci-section{background:#111827cc;background:var(--glass-dark,#111827cc);border:1px solid #1f2937;border:1px solid var(--gray-800,#1f2937);border-radius:12px;margin-bottom:20px}.ci-section-header{align-items:center;cursor:default;display:flex;justify-content:space-between;padding:16px 20px;-webkit-user-select:none;user-select:none}.ci-section.collapsed .ci-section-header{cursor:pointer}.ci-section.collapsed .ci-section-header:hover{background:#37415133;border-radius:12px}.ci-section-title{align-items:center;color:var(--gray-200);display:flex;gap:10px}.ci-section-title h3{font-size:15px;font-weight:600;margin:0}.ci-section-actions{align-items:center;color:var(--gray-500);display:flex;gap:8px}.ci-section-body{padding:0 20px 20px}.ci-section-desc{color:var(--gray-400);font-size:13px;line-height:1.5;margin:0 0 16px}.ci-chart-container{margin:0 -8px}.ci-table-wrap{overflow-x:auto}.ci-table-scroll,.ci-table-wrap{-webkit-overflow-scrolling:touch}.ci-table-scroll{max-height:500px;overflow-y:auto}.ci-table{border-collapse:collapse;font-size:13px;width:100%}.ci-table thead th{background:#111827;background:var(--gray-900,#111827);border-bottom:1px solid var(--gray-800);color:var(--gray-400);font-size:11px;font-weight:600;letter-spacing:.5px;padding:10px 12px;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:2}.ci-table tbody td{border-bottom:1px solid #3741514d;color:var(--gray-300);padding:10px 12px}.ci-table tbody tr:hover{background:#37415133}.ci-row-warn{background:#ef44440d}.ci-cell-primary{color:var(--gray-100);font-weight:500}.ci-cell-mono{font-family:JetBrains Mono,monospace}.ci-cell-mono,.ci-cell-small{font-size:11px}.ci-cell-desc{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ci-badge{align-items:center;border-radius:20px;display:inline-flex;font-size:11px;font-weight:600;letter-spacing:.3px;padding:3px 10px;text-transform:uppercase}.ci-badge-green{background:#22c55e26;color:#22c55e}.ci-badge-yellow{background:#eab30826;color:#eab308}.ci-badge-red{background:#ef444426;color:#ef4444}.ci-conf{border-radius:4px;display:inline-flex;font-size:12px;font-weight:600;padding:2px 8px}.ci-conf.ok{background:#22c55e26;color:#22c55e}.ci-conf.warn{background:#eab30826;color:#eab308}.ci-conf.bad{background:#ef444426;color:#ef4444}.ci-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:13px;font-weight:600;gap:8px;padding:10px 18px;transition:all .15s}.ci-btn:disabled{cursor:not-allowed;opacity:.5}.ci-btn-primary{background:#3b82f6;background:var(--primary,#3b82f6);color:#fff}.ci-btn-primary:hover:not(:disabled){background:#2563eb}.ci-btn-ghost{background:#0000;border:1px solid var(--gray-700);color:var(--gray-400);padding:8px}.ci-btn-ghost:hover{background:var(--gray-800);color:var(--gray-200)}.ci-btn-secondary{background:var(--gray-700);color:var(--gray-200)}.ci-btn-secondary:hover{background:var(--gray-600)}.ci-btn-success{background:#22c55e;color:#fff}.ci-btn-success:hover:not(:disabled){background:#16a34a}.ci-filter-bar{gap:16px;margin-bottom:20px}.ci-filter-bar,.ci-search-box{align-items:center;display:flex}.ci-search-box{background:var(--gray-900);border:1px solid var(--gray-700);border-radius:8px;flex:1 1;gap:8px;max-width:320px;padding:8px 14px}.ci-search-box input{background:none;border:none;color:var(--gray-200);font-size:13px;outline:none;width:100%}.ci-search-box svg{color:var(--gray-500);flex-shrink:0}.ci-filter-count{color:var(--gray-500);font-size:13px}.ci-legend{color:var(--gray-400);display:flex;font-size:12px;gap:20px;padding:12px 0 0}.ci-legend-item{align-items:center;display:flex;gap:6px}.ci-dot{border-radius:50%;height:10px;width:10px}.ci-spot-check-actions{margin-bottom:20px}.ci-spot-results{margin-top:16px}.ci-spot-timestamp{color:var(--gray-500);font-size:12px;margin-bottom:12px}.ci-spot-clean{align-items:center;color:#22c55e;display:flex;font-size:16px;font-weight:600;gap:12px;padding:24px}.ci-spot-warning{background:#eab3081a;border:1px solid #eab3084d;border-radius:8px;color:#eab308;font-size:14px;font-weight:500;gap:8px;margin-bottom:16px;padding:12px 16px}.ci-empty,.ci-spot-warning{align-items:center;display:flex}.ci-empty{color:var(--gray-500);font-size:13px;gap:10px;padding:24px}.ci-empty code{background:var(--gray-800);border-radius:4px;font-size:11px;padding:2px 6px}.ci-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}.ci-modal{background:#111827;background:var(--gray-900,#111827);border:1px solid #374151;border:1px solid var(--gray-700,#374151);border-radius:16px;box-shadow:0 25px 50px #00000080;display:flex;flex-direction:column;max-height:80vh;max-width:540px;width:90%}.ci-modal-header{align-items:center;border-bottom:1px solid var(--gray-800);display:flex;justify-content:space-between;padding:18px 22px}.ci-modal-header h3{color:var(--gray-100);font-size:16px;margin:0}.ci-modal-body{flex:1 1;overflow-y:auto;padding:20px 22px}.ci-modal-footer{border-top:1px solid var(--gray-800);display:flex;gap:10px;justify-content:flex-end;padding:16px 22px}.ci-modal-item-info{background:var(--gray-800);border-radius:8px;font-size:13px;margin-bottom:16px;padding:12px 14px}.ci-modal-item-info p{color:var(--gray-300);margin:4px 0}.ci-modal-item-info strong{color:var(--gray-100)}.ci-comp-search{background:var(--gray-800);border:1px solid var(--gray-700);border-radius:8px;box-sizing:border-box;color:var(--gray-200);font-size:13px;margin-bottom:12px;outline:none;padding:10px 14px;width:100%}.ci-comp-search:focus{border-color:#3b82f6;border-color:var(--primary,#3b82f6)}.ci-comp-list{-webkit-overflow-scrolling:touch;max-height:250px;overflow-y:auto}.ci-comp-option{align-items:center;border:1px solid #0000;border-radius:6px;cursor:pointer;display:flex;justify-content:space-between;margin-bottom:4px;padding:10px 12px;transition:all .1s}.ci-comp-option:hover{background:var(--gray-800)}.ci-comp-option.selected{background:#3b82f626;border-color:#3b82f6;border-color:var(--primary,#3b82f6)}.ci-comp-name{color:var(--gray-200);font-size:13px}.ci-comp-vendor{color:var(--gray-500);font-size:11px}.ci-comp-category{background:var(--gray-800);border-radius:10px;color:var(--gray-500);font-size:10px;padding:2px 8px}.ci-checkbox-row{align-items:center;color:var(--gray-300);cursor:pointer;display:flex;font-size:13px;gap:8px;padding:8px 0}.ci-checkbox-row input[type=checkbox]{accent-color:#3b82f6;accent-color:var(--primary,#3b82f6)}.ci-spot-summary{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin:16px 0}.ci-spot-metric{background:var(--gray-800);border-radius:10px;padding:14px;text-align:center}.ci-spot-metric-value{font-size:28px;font-weight:700}.ci-spot-metric-label{color:var(--gray-400);font-size:11px;margin-top:4px;text-transform:uppercase}.ci-spot-metric.correct .ci-spot-metric-value{color:#22c55e}.ci-spot-metric.wrong .ci-spot-metric-value{color:#ef4444}.ci-spot-metric.debatable .ci-spot-metric-value{color:#eab308}.ci-spot-metric.grade .ci-spot-metric-value{font-size:36px}.ci-vendor-health{align-items:center;background:var(--gray-800);border-radius:4px;display:inline-flex;gap:4px;height:8px;overflow:hidden;width:60px}.ci-vendor-health-fill{border-radius:4px;height:100%}.ci-action-btn{align-items:center;background:#3b82f626;border:1px solid #3b82f64d;border-radius:4px;color:#3b82f6;cursor:pointer;display:inline-flex;font-size:11px;gap:4px;padding:4px 10px;transition:all .15s;white-space:nowrap}.ci-action-btn:hover{background:#3b82f640}.ci-btn,.ci-tab{min-height:44px}.ci-comp-search,.ci-search-box input{font-size:16px;min-height:44px}@media (max-width:767px){.ci-dashboard{padding:16px}.ci-header{align-items:flex-start;flex-direction:column}.ci-stats-grid{grid-template-columns:1fr 1fr}.ci-tabs{gap:0}.ci-tab{font-size:12px}.ci-grade-badge,.ci-tab{padding:8px 12px}.ci-grade-letter{font-size:24px}.ci-filter-bar{align-items:stretch;flex-direction:column}.ci-search-box{max-width:100%}.ci-table{display:block}.ci-table thead{display:none}.ci-table tbody,.ci-table tbody td,.ci-table tbody tr{display:block}.ci-table tbody tr{background:#111827;background:var(--gray-900,#111827);border:1px solid #e0e0e0;border-radius:8px;margin-bottom:12px}.ci-table tbody td{border-bottom:1px solid #3741514d;display:flex;justify-content:space-between;padding:10px 14px}.ci-table tbody td:last-child{border-bottom:none}.ci-table tbody td:before{color:#9ca3af;color:var(--gray-400,#9ca3af);content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px;text-transform:uppercase}.ci-section-header{padding:12px 16px}.ci-section-body{padding:0 16px 16px}.ci-modal-overlay{align-items:flex-end}.ci-modal{border-radius:16px 16px 0 0;max-height:90vh;max-width:100%;width:100%}.ci-spot-summary{grid-template-columns:repeat(2,1fr)}.ci-action-btn{justify-content:center;min-height:44px}.ci-legend{flex-wrap:wrap;gap:10px}.ci-cell-desc{max-width:none;white-space:normal}}.ts-dashboard{background:var(--color-background);min-height:100%;overflow-x:hidden;padding:var(--space-4)}.ts-dashboard,.ts-header{display:flex;flex-direction:column}.ts-header{gap:var(--space-3);margin-bottom:var(--space-4)}.ts-header-top{align-items:flex-start;justify-content:space-between}.ts-header-left,.ts-header-top{display:flex;gap:var(--space-3)}.ts-header-left{align-items:center}.ts-header-left svg{color:var(--color-primary);flex-shrink:0}.ts-header-left h1{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-bold);line-height:1.2;margin:0}.ts-header-left p{color:var(--color-text-muted);font-size:var(--text-sm);margin:0}.ts-header-actions{display:flex;gap:var(--space-2)}@media (min-width:640px){.ts-header{align-items:center;flex-direction:row;justify-content:space-between}.ts-header-left h1{font-size:var(--text-2xl)}}.ts-view-selector{-webkit-overflow-scrolling:touch;background:var(--color-surface-hover);border-radius:var(--radius-lg);display:flex;gap:var(--space-1);margin-bottom:var(--space-4);overflow-x:auto;padding:var(--space-1);scrollbar-width:none}.ts-view-selector::-webkit-scrollbar{display:none}.ts-view-tab{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-1-5);min-height:44px;padding:var(--space-2) var(--space-3);transition:all var(--duration-fast) var(--ease-out);white-space:nowrap}.ts-view-tab:hover{background:var(--color-surface);color:var(--color-text)}.ts-view-tab.active{background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-primary)}.ts-view-tab svg{height:16px;width:16px}.ts-summary-stats{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(2,1fr);margin-bottom:var(--space-4)}@media (min-width:640px){.ts-summary-stats{grid-template-columns:repeat(3,1fr)}}@media (min-width:1024px){.ts-summary-stats{grid-template-columns:repeat(5,1fr)}}.ts-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);display:flex;flex-direction:column;padding:var(--space-4);transition:all var(--duration-fast) var(--ease-out)}.ts-stat-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-md)}.ts-stat-icon{align-items:center;border-radius:var(--radius-lg);display:flex;height:36px;justify-content:center;margin-bottom:var(--space-2);width:36px}.ts-stat-card-blue .ts-stat-icon{background:#3b82f61a;color:#3b82f6}.ts-stat-card-green .ts-stat-icon{background:#10b9811a;color:#10b981}.ts-stat-card-purple .ts-stat-icon{background:#8b5cf61a;color:#8b5cf6}.ts-stat-card-amber .ts-stat-icon{background:#f59e0b1a;color:#f59e0b}.ts-stat-card-red .ts-stat-icon{background:#ef44441a;color:#ef4444}.ts-stat-label{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.05em;margin-bottom:var(--space-1);text-transform:uppercase}.ts-stat-value{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-bold);line-height:1.2}.ts-stat-sub{color:var(--color-text-subtle);font-size:var(--text-xs);margin-top:var(--space-1)}.ts-alert-strip{align-items:center;background:#f59e0b1a;border:1px solid #f59e0b4d;border-radius:var(--radius-lg);display:flex;gap:var(--space-3);margin-bottom:var(--space-4);padding:var(--space-3) var(--space-4)}.ts-alert-strip.ts-alert-warning{background:#f59e0b1a;border-color:#f59e0b4d}.ts-alert-strip.ts-alert-critical{background:#ef44441a;border-color:#ef44444d}.ts-alert-icon{color:#f59e0b;flex-shrink:0}.ts-alert-critical .ts-alert-icon{color:#ef4444}.ts-alert-content{flex:1 1;min-width:0}.ts-alert-message{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium);margin:0}.ts-alert-vendors{color:var(--color-text-muted);font-size:var(--text-xs);margin:var(--space-1) 0 0}.ts-alert-action{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;display:flex;flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);min-height:36px;padding:var(--space-2) var(--space-3);transition:all var(--duration-fast) var(--ease-out)}.ts-alert-action:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover)}.ts-domain-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:1fr;margin-bottom:var(--space-4)}@media (min-width:640px){.ts-domain-grid{grid-template-columns:repeat(2,1fr)}}@media (min-width:1024px){.ts-domain-grid{grid-template-columns:repeat(3,1fr)}}.ts-domain-card{animation:ts-card-enter .3s var(--ease-out) forwards;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);display:flex;flex-direction:column;opacity:0;overflow:hidden;transform:translateY(10px);transition:all var(--duration-normal) var(--ease-out)}.ts-domain-card:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-lg);transform:translateY(-2px)}@keyframes ts-card-enter{to{opacity:1;transform:translateY(0)}}.ts-domain-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4)}.ts-domain-title{align-items:center;display:flex;gap:var(--space-2)}.ts-domain-icon{align-items:center;border-radius:var(--radius-md);display:flex;height:32px;justify-content:center;width:32px}.ts-domain-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold)}.ts-domain-count{color:var(--color-text-muted);font-size:var(--text-xs)}.ts-domain-score{align-items:center;border-radius:var(--radius-full);color:#fff;display:flex;font-size:var(--text-xs);font-weight:var(--font-bold);height:28px;justify-content:center;width:28px}.ts-domain-score.score-a{background:#10b981}.ts-domain-score.score-b{background:#eab308}.ts-domain-score.score-c,.ts-domain-score.score-d,.ts-domain-score.score-f{animation:ts-pulse-warning 2s infinite;background:#ef4444}@keyframes ts-pulse-warning{0%,to{opacity:1}50%{opacity:.7}}.ts-domain-meta{align-items:flex-end;display:flex;flex-direction:column;gap:var(--space-1)}.ts-domain-spend{color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-bold)}.ts-domain-expiring{background:#f59e0b26;border-radius:var(--radius-sm);color:#f59e0b;font-size:10px;font-weight:var(--font-medium);letter-spacing:.02em;padding:2px 6px;text-transform:uppercase}.ts-domain-body{min-height:80px;padding:var(--space-3) var(--space-4)}.ts-vendor-list{display:flex;flex-wrap:wrap;gap:var(--space-2)}.ts-empty-domain{align-items:center;color:var(--color-text-subtle);display:flex;font-size:var(--text-sm);height:60px;justify-content:center}.ts-vendor-pill{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1-5);max-width:100%;min-height:30px;padding:var(--space-1-5) var(--space-2-5);transition:all var(--duration-fast) var(--ease-out)}.ts-vendor-pill:hover{background:var(--color-surface-active);border-color:var(--color-primary);transform:translateX(2px)}.ts-vendor-pill:active{transform:scale(.98)}.ts-vendor-pill.selected{background:#3b82f61a;border-color:var(--color-primary);color:var(--color-primary)}.ts-vendor-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ts-vendor-status{border-radius:var(--radius-full);flex-shrink:0;height:6px;width:6px}.ts-vendor-status.active{background:#10b981}.ts-vendor-status.expiring{animation:ts-pulse-warning 2s infinite;background:#f59e0b}.ts-vendor-status.expired{background:#ef4444}.ts-vendor-pill-detailed{align-items:flex-start;border-radius:var(--radius-lg);flex-direction:column;gap:var(--space-1);min-height:auto;padding:var(--space-2) var(--space-3)}.ts-vendor-pill-detailed.expiring{background:#f59e0b0d;border-color:#f59e0b80}.ts-vendor-pill-detailed.expired{background:#ef44440d;border-color:#ef444480}.ts-vendor-pill-main{align-items:center;display:flex;gap:var(--space-1-5);width:100%}.ts-vendor-pill-detailed .ts-vendor-name{flex:1 1;max-width:none}.ts-vendor-expiry-badge{background:#ef444426;border-radius:var(--radius-sm);color:#ef4444;font-size:9px;font-weight:var(--font-semibold);letter-spacing:.02em;padding:2px 6px;text-transform:uppercase}.ts-vendor-pill-meta{align-items:center;display:flex;gap:var(--space-2);padding-left:calc(6px + var(--space-1-5));width:100%}.ts-vendor-spend{color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-semibold)}.ts-vendor-end-date{color:var(--color-text-muted);font-size:10px}.ts-vendor-pill-detailed.expiring .ts-vendor-end-date{color:#f59e0b;font-weight:var(--font-medium)}.ts-vendor-pill-detailed.expired .ts-vendor-end-date{color:#ef4444;font-weight:var(--font-medium)}.ts-drill-overlay{background:#0006;inset:0;opacity:0;position:fixed;transition:all var(--duration-normal) var(--ease-out);visibility:hidden;z-index:1000}.ts-drill-overlay.open{opacity:1;visibility:visible}.ts-drill-panel{background:var(--color-surface);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;bottom:0;box-shadow:0 -10px 40px #00000026;display:flex;flex-direction:column;left:0;max-height:85vh;overflow:hidden;position:fixed;right:0;transform:translateY(100%);transition:transform .3s var(--ease-spring);z-index:1001}.ts-drill-panel.open{transform:translateY(0)}@media (min-width:768px){.ts-drill-panel{border-radius:var(--radius-2xl) 0 0 var(--radius-2xl);bottom:0;left:auto;max-height:none;right:0;top:0;transform:translateX(100%);width:400px}.ts-drill-panel.open{transform:translateX(0)}}.ts-drill-handle{display:flex;justify-content:center;padding:var(--space-2)}.ts-drill-handle-bar{background:var(--color-border);border-radius:var(--radius-full);height:4px;width:40px}@media (min-width:768px){.ts-drill-handle{display:none}}.ts-drill-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-4)}.ts-drill-title{display:flex;flex-direction:column;gap:var(--space-1)}.ts-drill-title h3{color:var(--color-text);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}.ts-drill-title span{color:var(--color-text-muted);font-size:var(--text-sm)}.ts-drill-close{align-items:center;background:var(--color-surface-hover);border:none;border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;display:flex;height:36px;justify-content:center;transition:all var(--duration-fast) var(--ease-out);width:36px}.ts-drill-close:hover{background:var(--color-surface-active);color:var(--color-text)}.ts-drill-body{flex:1 1;overflow-y:auto;padding:var(--space-4)}.ts-drill-section{margin-bottom:var(--space-6)}.ts-drill-section-title{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;margin-bottom:var(--space-3);text-transform:uppercase}.ts-drill-stat{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;padding:var(--space-2) 0}.ts-drill-stat:last-child{border-bottom:none}.ts-drill-stat-value{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.ts-drill-contract-badge{border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-1) var(--space-2)}.ts-drill-contract-badge.active{background:#10b9811a;color:#10b981}.ts-drill-contract-badge.expiring{background:#f59e0b1a;color:#f59e0b}.ts-drill-contract-badge.expired{background:#ef44441a;color:#ef4444}.ts-renewals-section{margin-top:var(--space-4)}.ts-renewals-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.ts-renewals-title{align-items:center;color:var(--color-text);display:flex;font-size:var(--text-base);font-weight:var(--font-semibold);gap:var(--space-2)}.ts-renewals-title svg{color:var(--color-primary)}.ts-renewals-list{display:flex;flex-direction:column;gap:var(--space-2)}.ts-renewal-item{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:var(--space-3);padding:var(--space-3);transition:all var(--duration-fast) var(--ease-out)}.ts-renewal-item:hover{border-color:var(--color-border-hover);box-shadow:var(--shadow-sm)}.ts-renewal-date{align-items:center;background:var(--color-surface-hover);border-radius:var(--radius-md);display:flex;flex-direction:column;min-width:48px;padding:var(--space-2)}.ts-renewal-date-month{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-medium);text-transform:uppercase}.ts-renewal-date-day{color:var(--color-text);font-size:var(--text-lg);font-weight:var(--font-bold)}.ts-renewal-item.urgency-high .ts-renewal-date{background:#ef44441a;color:#ef4444}.ts-renewal-item.urgency-high .ts-renewal-date-day,.ts-renewal-item.urgency-high .ts-renewal-date-month{color:#ef4444}.ts-renewal-item.urgency-medium .ts-renewal-date{background:#f59e0b1a}.ts-renewal-item.urgency-medium .ts-renewal-date-day,.ts-renewal-item.urgency-medium .ts-renewal-date-month{color:#f59e0b}.ts-renewal-content{flex:1 1;min-width:0}.ts-renewal-vendor{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.ts-renewal-description{color:var(--color-text-muted);font-size:var(--text-xs);margin:var(--space-0-5) 0 0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ts-renewal-amount{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap}.ts-btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);justify-content:center;min-height:44px;padding:var(--space-2) var(--space-3);transition:all var(--duration-fast) var(--ease-out)}.ts-btn-ghost{background:#0000;color:var(--color-text-muted)}.ts-btn-ghost:hover{background:var(--color-surface-hover);color:var(--color-text)}.ts-btn-primary{background:var(--color-primary);color:#fff}.ts-btn-primary:hover{background:var(--color-primary-hover)}.ts-loading{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;padding:var(--space-12)}.ts-spin{animation:ts-spin 1s linear infinite}@keyframes ts-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ts-error{align-items:center;display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;padding:var(--space-8);text-align:center}.ts-error svg{color:var(--color-error)}.ts-error span{color:var(--color-text-muted)}.ts-skeleton{animation:ts-shimmer 1.5s infinite;background:linear-gradient(90deg,var(--color-surface-hover) 25%,var(--color-surface) 50%,var(--color-surface-hover) 75%);background-size:200% 100%;border-radius:var(--radius-md)}@keyframes ts-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.ts-skeleton-stat{border-radius:var(--radius-xl);height:100px}.ts-skeleton-card{border-radius:var(--radius-xl);height:180px}.ts-domain-card:first-child{animation-delay:0s}.ts-domain-card:nth-child(2){animation-delay:.05s}.ts-domain-card:nth-child(3){animation-delay:.1s}.ts-domain-card:nth-child(4){animation-delay:.15s}.ts-domain-card:nth-child(5){animation-delay:.2s}.ts-domain-card:nth-child(6){animation-delay:.25s}.ts-domain-card:nth-child(7){animation-delay:.3s}.ts-domain-card:nth-child(8){animation-delay:.35s}.ts-domain-card:nth-child(9){animation-delay:.4s}.ts-risk-badge{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.ts-risk-letter{font-size:var(--text-xl);font-weight:var(--font-bold)}.ts-risk-letter.grade-a{color:#10b981}.ts-risk-letter.grade-b{color:#eab308}.ts-risk-letter.grade-c,.ts-risk-letter.grade-d,.ts-risk-letter.grade-f{color:#ef4444}.ts-risk-detail{display:flex;flex-direction:column}.ts-risk-label{color:var(--color-text-muted);font-size:var(--text-xs)}.ts-risk-sub{color:var(--color-text-subtle);font-size:var(--text-xs)}[data-theme=dark] .ts-domain-card{background:var(--color-surface)}[data-theme=dark] .ts-vendor-pill{background:var(--color-surface-active)}[data-theme=dark] .ts-drill-panel{background:var(--color-surface)}.ts-drill-title-row{align-items:center;display:flex;gap:var(--space-2)}.ts-info-button{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;display:flex;height:28px;justify-content:center;transition:all var(--duration-fast) var(--ease-out);width:28px}.ts-info-button:hover{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ts-product-info-tooltip{animation:ts-tooltip-enter .2s var(--ease-out);background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin:0 var(--space-4) var(--space-4);padding:var(--space-3);position:relative}@keyframes ts-tooltip-enter{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.ts-product-info-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-2)}.ts-product-info-header h4{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.ts-product-info-close{align-items:center;background:#0000;border:none;border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;display:flex;height:24px;justify-content:center;transition:all var(--duration-fast) var(--ease-out);width:24px}.ts-product-info-close:hover{background:var(--color-surface-active);color:var(--color-text)}.ts-product-info-content{display:flex;flex-direction:column;gap:var(--space-2)}.ts-product-info-row{display:flex;flex-direction:column;gap:var(--space-0-5)}.ts-product-info-label{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.03em;text-transform:uppercase}.ts-product-info-value{color:var(--color-text);font-size:var(--text-sm);line-height:1.4}.ts-product-info-empty{color:var(--color-text-muted);font-size:var(--text-sm);font-style:italic;margin:0}.ts-product-criticality{border-radius:var(--radius-sm);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);padding:var(--space-0-5) var(--space-2);text-transform:capitalize}.ts-product-criticality.low{background:#10b9811a;color:#10b981}.ts-product-criticality.medium{background:#f59e0b1a;color:#f59e0b}.ts-product-criticality.high{background:#ef44441a;color:#ef4444}.ts-product-criticality.critical{background:#8b5cf61a;color:#8b5cf6}.ts-product-keywords{display:flex;flex-wrap:wrap;gap:var(--space-1)}.ts-product-keyword{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);font-size:var(--text-xs);padding:var(--space-0-5) var(--space-1-5)}.ts-drill-stat-label{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-sm);gap:var(--space-1-5)}.ts-drill-stat-label svg{color:var(--color-text-subtle)}.ts-value-highlight{color:var(--color-primary);font-weight:var(--font-semibold)}.ts-value-expiring{color:#f59e0b}.ts-value-expired{color:#ef4444}.ts-days-badge{background:#f59e0b26;border-radius:var(--radius-sm);font-size:var(--text-xs);font-weight:var(--font-semibold);margin-left:var(--space-1);padding:var(--space-0-5) var(--space-1)}.ts-drill-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.ts-drill-section-title{align-items:center;display:flex;gap:var(--space-2)}.ts-transaction-count{background:var(--color-surface-hover);color:var(--color-text-subtle);font-weight:var(--font-normal)}.ts-expiring-badge,.ts-transaction-count{border-radius:var(--radius-full);font-size:var(--text-xs);padding:var(--space-0-5) var(--space-1-5)}.ts-expiring-badge{align-items:center;background:#f59e0b1a;color:#f59e0b;display:inline-flex;font-weight:var(--font-medium);gap:var(--space-1)}.ts-transactions-list{display:flex;flex-direction:column;gap:var(--space-2)}.ts-transaction-item{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;padding:var(--space-3);transition:all var(--duration-fast) var(--ease-out)}.ts-transaction-item:hover{background:var(--color-surface-active);border-color:var(--color-border-hover)}.ts-transaction-item.expiring{border-left:3px solid #f59e0b}.ts-transaction-item.expired{border-left:3px solid #ef4444;opacity:.8}.ts-transaction-main{align-items:flex-start;display:flex;gap:var(--space-2);justify-content:space-between;margin-bottom:var(--space-2)}.ts-transaction-desc{align-items:flex-start;display:flex;flex:1 1;gap:var(--space-1-5);min-width:0}.ts-transaction-desc svg{color:var(--color-text-subtle);flex-shrink:0;margin-top:2px}.ts-transaction-desc span{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-text);display:-webkit-box;font-size:var(--text-sm);line-height:1.4;overflow:hidden}.ts-transaction-amount{color:var(--color-primary);font-size:var(--text-sm);font-weight:var(--font-semibold);white-space:nowrap}.ts-transaction-meta{display:flex;flex-wrap:wrap;gap:var(--space-2)}.ts-transaction-meta-item{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-xs);gap:var(--space-1)}.ts-transaction-meta-item svg{color:var(--color-text-subtle)}.ts-transaction-meta-item.warning,.ts-transaction-meta-item.warning svg{color:#f59e0b}.ts-transaction-meta-item.danger,.ts-transaction-meta-item.danger svg{color:#ef4444}.ts-show-more-btn{align-items:center;background:#0000;border:1px dashed var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-1);justify-content:center;margin-top:var(--space-2);padding:var(--space-2) var(--space-3);transition:all var(--duration-fast) var(--ease-out);width:100%}.ts-show-more-btn:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}.ts-show-more-btn svg{transition:transform var(--duration-fast) var(--ease-out)}.ts-show-more-btn svg.rotated{transform:rotate(90deg)}.ts-drill-loading{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-2);justify-content:center;padding:var(--space-6)}.ts-drill-loading svg{color:var(--color-primary)}.ts-drill-empty{align-items:center;color:var(--color-text-subtle);display:flex;flex-direction:column;font-size:var(--text-sm);gap:var(--space-2);justify-content:center;padding:var(--space-6)}.ts-drill-empty svg{opacity:.5}.ts-drill-contract-badge{align-items:center;display:inline-flex;gap:var(--space-1-5)}.ts-transaction-item.flagged{background:#f59e0b0d;border-left:3px solid #f59e0b}.ts-transaction-item.flagged:hover{background:#f59e0b14}.ts-flagged-badge{align-items:center;background:#f59e0b26;border-radius:var(--radius-full);color:#f59e0b;display:inline-flex;font-size:10px;font-weight:var(--font-semibold);gap:var(--space-1);letter-spacing:.02em;padding:var(--space-0-5) var(--space-1-5);text-transform:uppercase}.ts-flagged-badge svg{color:#f59e0b}.ts-transaction-actions{align-items:center;border-top:1px solid var(--color-border);display:flex;gap:var(--space-2);justify-content:flex-end;margin-top:var(--space-2);padding-top:var(--space-2)}.ts-action-btn{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);min-height:32px;padding:var(--space-1-5) var(--space-2-5);transition:all var(--duration-fast) var(--ease-out)}.ts-action-btn:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}.ts-action-btn:disabled{cursor:not-allowed;opacity:.6}.ts-btn-flag.active,.ts-btn-flag:hover:not(:disabled){border-color:#f59e0b;color:#f59e0b}.ts-btn-flag.active{background:#f59e0b1a}.ts-btn-ai{background:linear-gradient(135deg,#8b5cf60d,#3b82f60d);border-color:#8b5cf64d}.ts-btn-ai:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf626,#3b82f626);border-color:#8b5cf6;color:#8b5cf6}.ts-btn-ai svg{color:#8b5cf6}.ts-ai-suggestion{animation:ts-tooltip-enter .2s var(--ease-out);background:linear-gradient(135deg,#8b5cf60d,#3b82f60d);border:1px solid #8b5cf633;border-radius:var(--radius-lg);margin-top:var(--space-3);padding:var(--space-3)}.ts-ai-suggestion-header{align-items:center;color:#8b5cf6;display:flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:var(--space-1-5);letter-spacing:.03em;margin-bottom:var(--space-2);text-transform:uppercase}.ts-ai-suggestion-header svg{color:#8b5cf6}.ts-ai-suggestion-content{display:flex;flex-direction:column;gap:var(--space-1-5);margin-bottom:var(--space-3)}.ts-ai-suggestion-row{align-items:center;display:flex;gap:var(--space-2)}.ts-ai-label{color:var(--color-text-muted);font-size:var(--text-xs)}.ts-ai-value{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.ts-ai-confidence{border-radius:var(--radius-sm);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-0-5) var(--space-1-5)}.ts-ai-confidence.high{background:#10b98126;color:#10b981}.ts-ai-confidence.medium{background:#f59e0b26;color:#f59e0b}.ts-ai-confidence.low{background:#ef444426;color:#ef4444}.ts-ai-suggestion-reason{background:var(--color-surface);border-radius:var(--radius-md);color:var(--color-text-muted);font-size:var(--text-xs);font-style:italic;line-height:1.5;padding:var(--space-2)}.ts-ai-suggestion-actions{align-items:center;display:flex;gap:var(--space-2)}.ts-ai-accept-btn,.ts-ai-reject-btn{align-items:center;border:none;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);min-height:32px;padding:var(--space-1-5) var(--space-3);transition:all var(--duration-fast) var(--ease-out)}.ts-ai-accept-btn{background:#10b981;color:#fff}.ts-ai-accept-btn:hover{background:#059669}.ts-ai-reject-btn{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text-muted)}.ts-ai-reject-btn:hover{background:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}[data-theme=dark] .ts-transaction-item.flagged{background:#f59e0b14}[data-theme=dark] .ts-ai-suggestion{background:linear-gradient(135deg,#8b5cf61a,#3b82f61a)}[data-theme=dark] .ts-ai-suggestion-reason{background:var(--color-surface-hover)}.zta{--zta-bg:var(--color-background,#fff);--zta-surface:var(--color-surface,#fff);--zta-surface-hover:var(--color-surface-hover,#f4f4f5);--zta-border:var(--color-border,#e4e4e7);--zta-text:var(--color-text,#18181b);--zta-text-muted:var(--color-text-muted,#52525b);--zta-text-dim:var(--color-text-subtle,#71717a);--zta-identity:var(--zt-identity,#9333ea);--zta-device:var(--zt-device,#3b82f6);--zta-network:var(--zt-network,#06b6d4);--zta-application:var(--zt-application,#10b981);--zta-data:var(--zt-data,#f59e0b);--zta-visibility:var(--zt-visibility,#8b5cf6);--zta-governance:var(--zt-governance,#9333ea);--zta-pdp:var(--gray-500,#71717a);--zta-pp-roles:var(--color-warning,#f59e0b);--zta-pp-processes:var(--gray-500,#71717a);background:var(--zta-bg);color:var(--zta-text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);min-height:100vh;padding:1rem;position:relative}.zta-header{align-items:flex-start;border-bottom:1px solid var(--zta-border);display:flex;justify-content:space-between;margin-bottom:1rem;padding-bottom:1rem}.zta-title{font-size:1.75rem;font-weight:700;letter-spacing:.05em;margin:0}.zta-subtitle{color:var(--zta-text-muted);font-size:.875rem;margin:.25rem 0 0}.zta-header-right{align-items:center;display:flex;gap:1rem}.zta-dept-badge{background:var(--zta-device);font-weight:600;padding:.375rem .75rem}.zta-confidential,.zta-dept-badge{border-radius:.375rem;color:#fff;font-size:.75rem}.zta-confidential{background:#ef4444;font-weight:700;letter-spacing:.05em;padding:.5rem 1.25rem}.zta-version{color:var(--zta-text-dim);font-size:.75rem}.zta-refreshing{color:var(--zta-device)}.zta-fullscreen-btn,.zta-refreshing{align-items:center;display:flex;font-size:.75rem}.zta-fullscreen-btn{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text);cursor:pointer;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .15s ease}.zta-fullscreen-btn:hover{background:var(--zta-surface-hover);border-color:var(--zta-device);color:var(--zta-device)}.zta--fullscreen{bottom:0;left:0;overflow:auto;padding:1.5rem;position:fixed;right:0;top:0;z-index:9999}.zta--fullscreen .zta-header{background:var(--zta-bg);border-bottom:1px solid var(--zta-border);margin:-1.5rem -1.5rem 1rem;padding:1rem 1.5rem;position:sticky;top:0;z-index:100}.zta--fullscreen .zta-fullscreen-btn{background:#ef4444;border-color:#ef4444;color:#fff}.zta--fullscreen .zta-fullscreen-btn:hover{background:#dc2626;border-color:#dc2626;color:#fff}.zta-layer{display:flex;gap:.75rem;margin-bottom:.75rem}.zta-layer-label{align-items:center;color:var(--zta-text-muted);display:flex;font-size:.625rem;font-weight:700;justify-content:center;letter-spacing:.05em;line-height:1.3;min-width:80px;padding:.5rem;text-align:center;text-transform:uppercase;width:80px}.zta-governance{background:var(--zta-surface);border-left:4px solid var(--zta-governance);border-radius:.5rem;padding:.5rem}.zta-governance .zta-layer-label{color:var(--zta-governance)}.zta-governance-items{display:flex;flex:1 1;flex-wrap:wrap;gap:.5rem}.zta-gov-item{align-items:center;background:var(--zta-governance);border:none;border-radius:.375rem;color:#fff;cursor:pointer;display:flex;font-size:.7rem;font-weight:500;gap:.375rem;padding:.5rem .75rem;position:relative;transition:all .15s ease}.zta-gov-item:hover{filter:brightness(1.15);transform:translateY(-1px)}.zta-gov-item--regulation{background:#dc2626}.zta-gov-item--governance-body{background:#7c3aed}.zta-gov-item--policy{background:#2563eb}.zta-gov-item--framework{background:#059669}.zta-gov-item--has-data{box-shadow:0 0 0 2px #22c55e}.zta-gov-icon{flex-shrink:0;opacity:.9}.zta-gov-name{white-space:nowrap}.zta-gov-check{color:#22c55e;flex-shrink:0;margin-left:.25rem}.zta-policy-decision{background:var(--zta-surface);border-left:4px solid var(--zta-pdp);border-radius:.5rem;padding:.75rem}.zta-pdp-container{align-items:center;display:flex;flex:1 1;gap:1rem;justify-content:space-between}.zta-signals{display:flex;gap:.75rem}.zta-signal-label{color:var(--zta-text);font-size:.625rem;font-weight:700;letter-spacing:.025em;margin-bottom:.25rem}.zta-signal-question{color:var(--zta-text-muted);font-size:.625rem;margin-bottom:.375rem}.zta-signal-vendors{color:var(--zta-text-dim);font-size:.625rem;font-style:italic}.zta-pdp-center{align-items:center;display:flex;flex-direction:column;gap:.5rem}.zta-pdp-box{background:var(--zta-bg);border:2px solid #22c55e;border-radius:.5rem;box-shadow:0 0 20px #22c55e33;padding:1rem 1.5rem;text-align:center}.zta-pdp-title{color:#22c55e;font-size:.75rem;font-weight:700;margin-bottom:.25rem}.zta-pdp-subtitle{color:var(--zta-text-muted);font-size:.625rem;margin-bottom:.25rem}.zta-pdp-example{color:var(--zta-text-dim);font-size:.5rem;font-style:italic}.zta-pdp-box{cursor:pointer;transition:all .15s ease}.zta-pdp-box:hover{border-color:#4ade80;box-shadow:0 4px 20px #22c55e66;transform:translateY(-2px)}.zta-pdp-box--configured{background:linear-gradient(135deg,#22c55e26 0,var(--zta-bg) 100%)}.zta-pdp-vendor{color:#4ade80;font-size:.875rem;font-weight:700;margin:.25rem 0;text-transform:uppercase}.zta-pdp-vendor-sub{color:var(--zta-text-muted);font-size:.625rem;margin-bottom:.25rem;min-height:.75rem}.zta-pdp-badges{display:flex;gap:.375rem;justify-content:center;margin-top:.375rem}.zta-modal--pdp{max-width:700px}.zta-pdp-scores{display:flex;gap:1rem;margin-bottom:1rem}.zta-pdp-scores .zta-readiness-score{flex:1 1}.zta-checklist--signals{grid-gap:.5rem;display:grid;gap:.5rem}.zta-check-item--signal{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;padding:.75rem}.zta-check-item--signal:has(input:checked){background:#22c55e1a;border-color:#22c55e}.zta-check-content{display:flex;flex-direction:column;gap:.125rem}.zta-check-label{color:var(--zta-text);font-weight:600}.zta-check-desc,.zta-section-hint{color:var(--zta-text-muted);font-size:.75rem}.zta-section-hint{margin-bottom:.75rem}.zta-trust-arrow{align-items:center;display:flex;flex-direction:column;gap:.25rem}.zta-trust-arrow span{color:var(--zta-text-muted);font-size:.5rem;font-weight:600;letter-spacing:.05em}.zta-arrow-down{border-left:6px solid #0000;border-right:6px solid #0000;border-top:8px solid var(--zta-text-muted);height:0;width:0}.zta-enforcement{background:var(--zta-surface);border-left:4px solid var(--zta-device);border-radius:.5rem;padding:.75rem}.zta-pillars{grid-gap:.5rem;display:grid;flex:1 1;gap:.5rem;grid-template-columns:repeat(5,1fr)}.zta-pillar{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.5rem;display:flex;flex-direction:column;overflow:hidden}.zta-pillar-header{background:var(--pillar-color);color:#fff;font-size:.75rem;font-weight:700;letter-spacing:.025em;padding:.625rem;text-align:center}.zta-pillar-caps-label{color:var(--pillar-color);font-size:.5rem;font-weight:700;letter-spacing:.05em;padding:.375rem .5rem .25rem}.zta-pillar-capabilities{display:flex;flex:1 1;flex-direction:column;gap:.25rem;padding:0 .5rem}.zta-capability{align-items:center;background:var(--zta-surface);border:none;border-radius:.25rem;cursor:pointer;display:flex;gap:.25rem;justify-content:space-between;padding:.375rem .5rem;text-align:left;transition:all .15s ease;width:100%}.zta-capability:hover:not(:disabled){background:var(--zta-surface-hover);transform:translateX(2px)}.zta-capability:disabled{cursor:default;opacity:.8}.zta-capability--critical{border-left:2px solid #ef4444}.zta-cap-name{color:var(--zta-text);font-size:.625rem;line-height:1.3}.zta-cap-vendors{color:var(--zta-text-dim);font-style:italic}.zta-capability-wrapper{display:flex;flex-direction:column;gap:0;position:relative}.zta-cap-vendor-toggle{align-items:center;background:#0000;border:none;border-radius:.125rem;color:var(--zta-text-dim);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:.125rem;transition:all .15s ease}.zta-cap-vendor-toggle:hover{background:var(--zta-surface-hover);color:var(--zta-text)}.zta-cap-vendor-toggle .rotated{transform:rotate(180deg)}.zta-cap-vendor-row{background:var(--zta-surface-hover);border-radius:0 0 .25rem .25rem;margin-top:-.125rem;padding:.125rem .5rem}.zta-cap-vendor-text{color:var(--zta-text-muted);font-size:.5rem;font-style:italic}.zta-cap-vendor-dropdown{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;box-shadow:0 4px 12px #00000026;display:flex;flex-direction:column;gap:.375rem;left:0;padding:.5rem;position:absolute;right:0;top:100%;z-index:10}.zta-cap-vendor-current{display:flex;flex-direction:column;gap:.125rem}.zta-cap-vendor-label{color:var(--zta-text-dim);font-size:.5rem;font-weight:600;text-transform:uppercase}.zta-cap-vendor-value{color:var(--zta-text);font-size:.625rem}.zta-cap-vendor-suggestion{align-items:center;background:#8b5cf61a;border-radius:.25rem;color:#8b5cf6;display:flex;font-size:.5rem;gap:.25rem;padding:.25rem .375rem}.zta-cap-vendor-edit{background:var(--zta-device);background:var(--pillar-color,var(--zta-device));border:none;border-radius:.25rem;color:#fff;cursor:pointer;font-size:.5rem;font-weight:600;padding:.375rem .5rem;transition:opacity .15s ease}.zta-cap-vendor-edit:hover{opacity:.9}.zta-cap-maturity-bar{border-radius:4px;display:flex;gap:1px;height:8px;margin-top:4px;overflow:hidden}.zta-cap-maturity-segment{background:var(--zta-surface-hover);border:none;cursor:pointer;flex:1 1;padding:0;position:relative;transition:all .15s ease}.zta-cap-maturity-segment:disabled{cursor:default;opacity:.5}.zta-cap-maturity-segment:not(:disabled):hover{box-shadow:0 0 4px #0000004d;z-index:1}.zta-cap-maturity-segment.active[data-level="0"],.zta-cap-maturity-segment.current[data-level="0"]{background:#6b7280}.zta-cap-maturity-segment.active[data-level="1"],.zta-cap-maturity-segment.current[data-level="1"]{background:#eab308}.zta-cap-maturity-segment.active[data-level="2"],.zta-cap-maturity-segment.current[data-level="2"]{background:#3b82f6}.zta-cap-maturity-segment.active[data-level="3"],.zta-cap-maturity-segment.current[data-level="3"]{background:#10b981}.zta-cap-maturity-segment.current{box-shadow:0 0 0 1px #ffffff80;position:relative}.zta-cap-maturity-segment:not(:disabled):hover{opacity:.8;transform:scaleY(1.5)}.zta-pillar-maturity{margin-top:auto;padding:.5rem}.zta-maturity-label{color:var(--zta-text-dim);font-size:.5rem;font-weight:600;margin-bottom:.375rem;text-align:center}.zta-maturity-bar{display:flex;gap:2px}.zta-maturity-segment{background:var(--zta-surface);border-radius:.125rem;color:var(--zta-text-dim);flex:1 1;font-size:.5rem;font-weight:600;padding:.25rem;text-align:center}.zta-maturity-segment--active[data-level="0"]{background:#6b7280;color:#fff}.zta-maturity-segment--active[data-level="1"]{background:#eab308;color:#1e293b}.zta-maturity-segment--active[data-level="2"]{background:#3b82f6;color:#fff}.zta-maturity-segment--active[data-level="3"]{background:#10b981;color:#fff}.zta-ab869-badge{background:#ef4444;color:#fff;font-size:.625rem;font-weight:700;letter-spacing:.025em;padding:.375rem;text-align:center}.zta-visibility-detail{background:var(--zta-surface);border-left:4px solid var(--zta-visibility);border-radius:.5rem;padding:.75rem}.zta-visibility-detail .zta-layer-label{color:var(--zta-visibility)}.zta-visibility-subtitle{color:var(--zta-text-muted);font-size:.75rem;font-style:italic;margin-bottom:.75rem}.zta-visibility-capabilities{grid-gap:.5rem;display:grid;flex:1 1;gap:.5rem;grid-template-columns:repeat(8,1fr)}.zta-vis-capability{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.5rem;cursor:pointer;display:flex;flex-direction:column;gap:.375rem;padding:.625rem;position:relative;text-align:left;transition:all .2s ease}.zta-vis-capability:hover:not(:disabled){background:var(--zta-surface-hover);border-color:var(--zta-visibility);box-shadow:0 4px 12px #8b5cf626;transform:translateY(-2px)}.zta-vis-capability:disabled{cursor:not-allowed;opacity:.6}.zta-vis-cap-header{align-items:center;display:flex;justify-content:space-between}.zta-vis-cap-name{color:var(--zta-text);font-size:.6875rem;font-weight:700;line-height:1.2}.zta-vis-cap-vendors{color:var(--zta-text-dim);font-size:.5625rem;line-height:1.3;min-height:1.5em}.zta-vis-maturity-bar{display:flex;gap:2px;margin-top:auto}.zta-vis-maturity-segment{border-radius:2px;flex:1 1;height:4px;transition:background-color .2s ease}.zta-vis-maturity-label{color:var(--zta-text-muted);font-size:.5rem;font-weight:600;margin-top:.25rem;text-align:center}.zta-vis-suggestion-indicator{align-items:center;background:linear-gradient(135deg,#8b5cf6,#a855f7);border-radius:50%;color:#fff;display:flex;height:16px;justify-content:center;position:absolute;right:4px;top:4px;width:16px}.zta-vis-capability--has-suggestion{background:linear-gradient(135deg,#8b5cf60d,#6366f114);border-color:#8b5cf64d}.zta-vis-capability--has-suggestion:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf61a,#6366f126);border-color:#8b5cf680}.zta-vis-capability--cisco-active{background:linear-gradient(135deg,#049fd926,#00629b33)!important;border-color:#049fd9!important;border-color:var(--cisco-blue)!important}.zta-vis-capability--cisco-active:after{background:#049fd9;background:var(--cisco-blue);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 3.5c-.7 0-1.3.6-1.3 1.3v4.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V4.8c0-.7-.6-1.3-1.3-1.3zm-4.8 2c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zm9.6 0c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zM2.4 7c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3zm19.2 0c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:11px 11px;border-radius:3px;content:"";height:16px;position:absolute;right:4px;top:4px;width:16px}.zta-vis-tool--has-suggestion:hover:not(:disabled){background:linear-gradient(135deg,#8b5cf61a,#6366f126);border-color:#8b5cf680}.zta-vis-suggestion-text{color:#8b5cf6;font-style:italic}.zta-people-process{background:var(--zta-surface);border-left:4px solid var(--zta-pp-roles);border-radius:.5rem;padding:.75rem}.zta-people-process .zta-layer-label{color:var(--zta-pp-roles)}.zta-pp-container{grid-gap:.75rem;display:grid;flex:1 1;gap:.75rem;grid-template-columns:1fr 1fr}.zta-pp-roles{background:var(--zta-surface);border:2px solid var(--zta-pp-roles);border-radius:.5rem;padding:.75rem}.zta-pp-roles-header{color:var(--zta-pp-roles);font-size:.75rem;font-weight:700;margin-bottom:.5rem;text-align:center}.zta-pp-roles-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr)}.zta-pp-role{background:var(--zta-surface-hover);border:1px solid var(--zta-border);border-radius:.375rem;padding:.5rem}.zta-pp-role-title{color:var(--zta-text);font-size:.625rem;font-weight:700;margin-bottom:.25rem}.zta-pp-role-desc{color:var(--zta-text-muted);font-size:.5rem;line-height:1.3;white-space:pre-line}.zta-pp-processes{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.5rem;padding:.75rem}.zta-pp-processes-header{color:var(--zta-text);font-size:.75rem;font-weight:700;margin-bottom:.5rem;text-align:center}.zta-pp-process-list{list-style:none;margin:0;padding:0 0 0 1rem}.zta-pp-process-list li{color:var(--zta-text-muted);font-size:.625rem;padding:.25rem 0;position:relative}.zta-pp-process-list li:before{color:var(--zta-pp-roles);content:"■";left:-1rem;position:absolute}.zta-roadmap{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.5rem;flex-direction:column;padding:.75rem}.zta-roadmap-label{color:var(--zta-text);font-size:.625rem;font-weight:700;letter-spacing:.025em;margin-bottom:.5rem}.zta-roadmap-phases{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr)}.zta-roadmap-phase{background:var(--zta-surface)!important;border:2px solid var(--phase-color,var(--zta-border));padding:.625rem}.zta-roadmap-phase,.zta-roadmap-phase:first-child,.zta-roadmap-phase:last-child{border-radius:.375rem}.zta-phase-header{color:var(--zta-text);color:var(--phase-color,var(--zta-text));font-size:.625rem;font-weight:700;margin-bottom:.25rem}.zta-phase-items{color:var(--zta-text-muted);font-size:.5rem;line-height:1.4}.zta-modal-backdrop{align-items:center;background:#000000bf;display:flex;inset:0;justify-content:center;padding:1rem;position:fixed;z-index:1000}.zta-modal{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.75rem;display:flex;flex-direction:column;max-height:90vh;max-width:500px;overflow:hidden;width:100%}.zta-modal-header{align-items:flex-start;border-bottom:1px solid var(--zta-border);display:flex;justify-content:space-between;padding:1rem 1.25rem}.zta-modal-title{color:var(--zta-text);font-size:1.125rem;font-weight:600;margin:0}.zta-modal-subtitle{color:var(--zta-text-muted);font-size:.75rem;margin:.25rem 0 0}.zta-modal-close{background:#0000;border:none;border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;padding:.25rem;transition:all .15s ease}.zta-modal-close:hover{background:var(--zta-bg);color:var(--zta-text)}.zta-modal-body{display:flex;flex-direction:column;gap:1rem;overflow-y:auto;padding:1.25rem}.zta-modal-field label{color:var(--zta-text);display:block;font-size:.75rem;font-weight:600;margin-bottom:.5rem}.zta-modal-input,.zta-modal-select,.zta-modal-textarea{background:var(--zta-surface-hover);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text);font-size:.875rem;padding:.625rem .75rem;width:100%}[data-theme=dark] .zta-modal-input,[data-theme=dark] .zta-modal-select,[data-theme=dark] .zta-modal-textarea{background:#ffffff0d;border-color:#ffffff1a}.zta-modal-input:focus,.zta-modal-select:focus,.zta-modal-textarea:focus{border-color:var(--zta-device);box-shadow:0 0 0 3px #3b82f626;outline:none}[data-theme=dark] .zta-modal-input:focus,[data-theme=dark] .zta-modal-select:focus,[data-theme=dark] .zta-modal-textarea:focus{background:#ffffff14;border-color:var(--zta-device)}.zta-modal-input::placeholder,.zta-modal-textarea::placeholder{color:var(--zta-text-dim);opacity:.7}[data-theme=dark] .zta-modal-input::placeholder,[data-theme=dark] .zta-modal-textarea::placeholder{color:#fff6}.zta-modal-hint{color:var(--zta-text-dim);display:block;font-size:.625rem;margin-top:.25rem}.zta-modal-maturity{display:flex;gap:.375rem}.zta-modal-maturity-btn{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;flex:1 1;font-size:.625rem;font-weight:600;padding:.5rem;transition:all .15s ease}.zta-modal-maturity-btn:hover{border-color:var(--zta-text-dim)}.zta-modal-maturity-btn.active[data-level="0"]{background:#6b7280;border-color:#6b7280;color:#fff}.zta-modal-maturity-btn.active[data-level="1"]{background:#eab308;border-color:#eab308;color:#1e293b}.zta-modal-maturity-btn.active[data-level="2"]{background:#3b82f6;border-color:#3b82f6;color:#fff}.zta-modal-maturity-btn.active[data-level="3"]{background:#10b981;border-color:#10b981;color:#fff}.zta-modal-footer{background:var(--zta-bg);border-top:1px solid var(--zta-border);display:flex;gap:.75rem;justify-content:flex-end;padding:1rem 1.25rem}.zta-modal-btn{align-items:center;border-radius:.375rem;cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:.375rem;padding:.625rem 1rem;transition:all .15s ease}.zta-modal-btn--secondary{background:#0000;border:1px solid var(--zta-border);color:var(--zta-text)}.zta-modal-btn--secondary:hover{background:var(--zta-surface-hover)}.zta-modal-btn--primary{background:var(--zta-device);border:none;color:#fff}.zta-modal-btn--primary:hover{filter:brightness(1.1)}.zta-modal-btn--primary:disabled{cursor:not-allowed;opacity:.6}.zta-vendor-chips{display:flex;flex-wrap:wrap;gap:.5rem;margin-bottom:.75rem}.zta-vendor-chip{align-items:center;background:var(--zta-surface-hover);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text);display:inline-flex;font-size:.75rem;gap:.375rem;padding:.375rem .5rem}.zta-vendor-chip-product,.zta-vendor-chip-remove{color:var(--zta-text-muted)}.zta-vendor-chip-remove{align-items:center;background:#0000;border:none;border-radius:.25rem;cursor:pointer;display:flex;justify-content:center;padding:.125rem;transition:all .15s ease}.zta-vendor-chip-remove:hover{background:#ef44441a;color:#ef4444}.zta-vendor-selector{align-items:stretch;display:flex;gap:.5rem}.zta-vendor-selector .zta-modal-select{flex:1 1;min-width:0}.zta-vendor-add-btn{background:var(--zta-device);border:none;border-radius:.375rem;color:#fff;cursor:pointer;font-size:.75rem;font-weight:600;padding:.625rem 1rem;transition:all .15s ease;white-space:nowrap}.zta-vendor-add-btn:hover:not(:disabled){filter:brightness(1.1)}.zta-vendor-add-btn:disabled{cursor:not-allowed;opacity:.5}@media (max-width:767px){.zta-vendor-selector{flex-direction:column}.zta-vendor-add-btn{align-self:flex-end;min-height:44px}}.zta-modal--governance{max-width:600px}.zta-modal-header-content{align-items:flex-start;display:flex;gap:.75rem}.zta-gov-modal-icon{align-items:center;background:var(--zta-governance);border-radius:.5rem;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.zta-modal-body--scrollable{max-height:60vh;overflow-y:auto}.zta-gov-summary{background:var(--zta-bg);border-left:3px solid var(--zta-governance);border-radius:.5rem;padding:1rem}.zta-gov-summary p{color:var(--zta-text);font-size:.875rem;line-height:1.5;margin:0}.zta-gov-section{margin-top:.5rem}.zta-gov-section h3{align-items:center;color:var(--zta-text);display:flex;font-size:.8rem;font-weight:600;gap:.375rem;margin:0 0 .5rem}.zta-gov-section p{color:var(--zta-text-muted);font-size:.8rem;line-height:1.6;margin:0}.zta-gov-requirements{list-style:none;margin:0;padding:0}.zta-gov-requirements li{align-items:flex-start;color:var(--zta-text-muted);display:flex;font-size:.8rem;gap:.5rem;padding:.375rem 0}.zta-req-icon{color:#22c55e;flex-shrink:0;margin-top:2px}.zta-gov-links{display:flex;flex-wrap:wrap;gap:.5rem}.zta-gov-link{align-items:center;background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-device);display:flex;font-size:.75rem;gap:.375rem;padding:.5rem .75rem;text-decoration:none;transition:all .15s ease}.zta-gov-link:hover{background:var(--zta-surface-hover);border-color:var(--zta-device)}.zta-gov-divider{background:var(--zta-border);height:1px;margin:1rem 0}.zta-gov-section--editable{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.5rem;padding:1rem}.zta-gov-section--editable h3{color:var(--zta-device);margin-bottom:1rem}.zta-status-buttons{display:flex;flex-wrap:wrap;gap:.375rem}.zta-status-btn{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;flex:1 1;font-size:.75rem;font-weight:500;min-width:100px;padding:.5rem .75rem;transition:all .15s ease}.zta-status-btn:hover{border-color:var(--status-color);color:var(--zta-text)}.zta-status-btn.active{background:var(--status-color);border-color:var(--status-color);color:#fff}.zta-modal-field-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.zta-gov-no-dept{align-items:center;background:var(--zta-bg);border:1px dashed var(--zta-border);border-radius:.5rem;color:var(--zta-text-muted);display:flex;font-size:.875rem;gap:.5rem;justify-content:center;padding:1rem}.zta-signal-card{background:var(--zta-bg);border:1px solid var(--zta-border);border-radius:.5rem;cursor:pointer;min-width:140px;padding:.75rem;position:relative;text-align:center;transition:all .15s ease}.zta-signal-card:hover{border-color:var(--zta-device);box-shadow:0 4px 12px #0000004d;transform:translateY(-2px)}.zta-signal-card--has-data{border-color:#22c55e;box-shadow:0 0 0 1px #22c55e4d}.zta-signal-status{align-items:center;border-radius:50%;display:flex;height:16px;justify-content:center;position:absolute;right:.375rem;top:.375rem;width:16px}.zta-signal-status--fully_integrated{background:#22c55e;color:#fff}.zta-signal-status--partial{background:#f59e0b;color:#fff}.zta-signal-status--not_configured{background:#ef4444;color:#fff}.zta-signal-card--configured{background:linear-gradient(135deg,#22c55e1a 0,var(--zta-bg) 100%);border-color:#22c55e}.zta-signal-vendor-name{color:#22c55e;font-size:.75rem;font-weight:700;letter-spacing:.025em;margin:.25rem 0;text-transform:uppercase}.zta-signal-vendor-sub{color:var(--zta-text-muted);font-size:.625rem;margin-bottom:.375rem;min-height:.875rem}.zta-signal-badges{display:flex;flex-wrap:wrap;gap:.25rem;justify-content:center;margin-top:.375rem}.zta-signal-badge{align-items:center;border-radius:.25rem;display:inline-flex;font-size:.5625rem;font-weight:600;gap:.25rem;letter-spacing:.025em;padding:.125rem .375rem;text-transform:uppercase}.zta-signal-badge--success{background:#22c55e33;color:#22c55e}.zta-signal-badge--warning{background:#f59e0b33;color:#f59e0b}.zta-signal-badge--danger{background:#ef444433;color:#ef4444}.zta-modal--signal{max-width:600px}.zta-signal-description{background:var(--zta-bg);border-left:3px solid var(--zta-device);border-radius:.5rem;padding:1rem}.zta-signal-description p{color:var(--zta-text);font-size:.875rem;line-height:1.5;margin:0}.zta-readiness-score{align-items:center;border-radius:.5rem;display:flex;justify-content:space-between;margin-top:.5rem;padding:.75rem 1rem}.zta-readiness-score--good{background:#22c55e26;border:1px solid #22c55e}.zta-readiness-score--partial{background:#f59e0b26;border:1px solid #f59e0b}.zta-readiness-score--low{background:#ef444426;border:1px solid #ef4444}.zta-readiness-label{color:var(--zta-text);font-size:.75rem;font-weight:600}.zta-readiness-value{color:var(--zta-text);font-size:1.25rem;font-weight:700}.zta-signal-section{border-top:1px solid var(--zta-border);margin-top:1rem;padding-top:1rem}.zta-signal-section h3{color:var(--zta-text);font-size:.875rem;font-weight:600;margin:0 0 1rem}.zta-checklist{display:flex;flex-direction:column;gap:.5rem}.zta-check-item{align-items:center;color:var(--zta-text-muted);cursor:pointer;display:flex;font-size:.8rem;gap:.5rem}.zta-check-item input[type=checkbox]{accent-color:#22c55e;height:16px;width:16px}.zta-check-item input:checked+span{color:var(--zta-text)}.zta-choice-buttons{display:flex;gap:.375rem}.zta-choice-btn{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;flex:1 1;font-size:.75rem;font-weight:500;padding:.5rem .75rem;transition:all .15s ease}.zta-choice-btn:hover{border-color:var(--zta-device);color:var(--zta-text)}.zta-choice-btn.active{background:var(--zta-device);border-color:var(--zta-device);color:#fff}.zta-percentage-input{align-items:center;display:flex;gap:1rem}.zta-range-input{appearance:none;background:var(--zta-border);border-radius:3px;flex:1 1;height:6px;outline:none}.zta-range-input::-webkit-slider-thumb{appearance:none;background:var(--zta-device);border-radius:50%;cursor:pointer;height:18px;width:18px}.zta-range-input::-moz-range-thumb{background:var(--zta-device);border:none;border-radius:50%;cursor:pointer;height:18px;width:18px}.zta-percentage-value{color:var(--zta-text);font-size:1rem;font-weight:600;min-width:50px;text-align:right}.zta-no-dept-hint{background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.5rem;bottom:1rem;box-shadow:0 4px 20px #0000004d;color:var(--zta-text-muted);font-size:.875rem;left:50%;padding:.75rem 1.5rem;position:fixed;transform:translateX(-50%)}@media (max-width:1400px){.zta-pillars{grid-template-columns:repeat(3,1fr)}.zta-visibility-capabilities{grid-template-columns:repeat(4,1fr)}}@media (max-width:1024px){.zta-pillars{grid-template-columns:repeat(2,1fr)}.zta-visibility-capabilities{grid-template-columns:repeat(4,1fr)}.zta-pp-container{grid-template-columns:1fr}.zta-pp-roles-grid,.zta-roadmap-phases{grid-template-columns:repeat(2,1fr)}.zta-roadmap-phase:nth-child(2){border-radius:0 .375rem 0 0}.zta-roadmap-phase:nth-child(3){border-radius:0 0 0 .375rem}.zta-pdp-container,.zta-signals{flex-wrap:wrap;justify-content:center}}@media (max-width:767px){.zta{padding:.5rem}.zta-header{flex-direction:column;gap:.75rem}.zta-header-right{flex-wrap:wrap;width:100%}.zta-pillars{grid-template-columns:1fr}.zta-visibility-capabilities{grid-template-columns:1fr 1fr}.zta-pp-container,.zta-pp-roles-grid,.zta-roadmap-phases{grid-template-columns:1fr}.zta-roadmap-phase{border-radius:0!important}.zta-roadmap-phase:first-child{border-radius:.375rem .375rem 0 0!important}.zta-roadmap-phase:last-child{border-radius:0 0 .375rem .375rem!important}.zta-layer{flex-direction:column}.zta-layer-label{padding:.5rem;width:100%}.zta-pdp-container,.zta-signals{flex-direction:column}.zta input,.zta select,.zta textarea{min-height:44px;width:100%}.zta button{min-height:44px}.zta-modal-content{border-radius:0;margin:0;max-width:100vw;min-height:100vh;width:100%}}.zta-suggest-btn{align-items:center;background:linear-gradient(135deg,#8b5cf6,#6366f1);border:none;border-radius:.5rem;box-shadow:0 2px 8px #8b5cf64d;color:#fff;cursor:pointer;display:flex;font-size:.8125rem;font-weight:600;gap:.375rem;padding:.5rem 1rem;transition:all .2s ease}.zta-suggest-btn:hover:not(:disabled){box-shadow:0 4px 12px #8b5cf666;transform:translateY(-1px)}.zta-suggest-btn:disabled{cursor:not-allowed;opacity:.7}.zta-suggestions-loading{align-items:center;color:#8b5cf6;display:flex}.pulse{animation:pulse 1.5s ease-in-out infinite}.zta-signal-card--has-suggestion{background:linear-gradient(135deg,#8b5cf60d,#6366f114)!important;border:2px solid #8b5cf680!important;position:relative}.zta-signal-card--has-suggestion:hover{border-color:#8b5cf6cc!important;box-shadow:0 4px 16px #8b5cf633}.zta-suggestion-indicator{animation:sparkle 2s ease-in-out infinite;color:#8b5cf6;position:absolute;right:.5rem;top:.5rem}@keyframes sparkle{0%,to{opacity:1;transform:scale(1) rotate(0deg)}50%{opacity:.7;transform:scale(1.2) rotate(15deg)}}.zta-signal-suggestion{align-items:center;display:flex;flex-direction:column;gap:.125rem;margin-top:.25rem}.zta-suggestion-vendor{color:#8b5cf6;font-size:.875rem;font-weight:700}.zta-suggestion-product{color:var(--zta-text-muted);font-size:.75rem}.zta-suggestion-meta{align-items:center;background:#8b5cf61a;border-radius:.25rem;color:#8b5cf6;display:flex;font-size:.625rem;font-weight:500;gap:.25rem;margin-top:.375rem;padding:.25rem .5rem}.zta-suggestion-meta svg{flex-shrink:0}.zta-suggestion-info{align-items:center;background:#8b5cf61a;border-radius:50%;color:var(--zta-text-muted);cursor:help;display:inline-flex;height:18px;justify-content:center;margin-left:.375rem;transition:all .2s ease;width:18px}.zta-suggestion-info:hover{background:#8b5cf633;color:#8b5cf6;transform:scale(1.1)}.zta-suggestion-indicator[title],.zta-suggestion-info[title]{position:relative}.zta-suggestions-banner{align-items:center;background:linear-gradient(135deg,#8b5cf614,#6366f11f);border:1px solid #8b5cf64d;border-radius:.5rem;display:flex;gap:1rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.zta-suggestions-banner-content{align-items:center;display:flex;gap:.75rem}.zta-suggestions-banner-icon{align-items:center;background:#8b5cf626;border-radius:.375rem;color:#8b5cf6;display:flex;height:2rem;justify-content:center;width:2rem}.zta-suggestions-banner-text h4{color:var(--zta-text);font-size:.875rem;font-weight:600;margin:0}.zta-suggestions-banner-text p{color:var(--zta-text-muted);font-size:.75rem;margin:.125rem 0 0}.zta-suggestions-banner-actions{display:flex;gap:.5rem}.zta-suggestions-banner-close{background:#0000;border:none;color:var(--zta-text-muted);cursor:pointer;padding:.25rem}.zta-suggestions-banner-close:hover{color:var(--zta-text)}[data-theme=dark] .zta-suggest-btn{box-shadow:0 2px 8px #8b5cf633}[data-theme=dark] .zta-signal-card--has-suggestion{background:linear-gradient(135deg,#8b5cf61a,#6366f126)!important}[data-theme=dark] .zta-suggestion-meta{background:#8b5cf626}[data-theme=dark] .zta-suggestions-banner{background:linear-gradient(135deg,#8b5cf61f,#6366f12e)}.zta-suggestion-toggle{align-items:center;background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s ease}.zta-suggestion-toggle:hover{border-color:var(--zta-visibility);color:var(--zta-visibility)}.zta-suggestion-toggle.active{background:linear-gradient(135deg,#8b5cf6,#a855f7);border-color:#0000;color:#fff}.zta-suggestion-toggle.active:hover{background:linear-gradient(135deg,#7c3aed,#9333ea)}.zta-suggestion-toggle svg{height:14px;width:14px}.zta-suggestion-banner{align-items:center;background:linear-gradient(135deg,#8b5cf614,#6366f11f);border:1px solid #8b5cf633;border-radius:.5rem;color:var(--zta-text-muted);display:flex;flex-wrap:wrap;font-size:.8125rem;gap:.5rem;justify-content:space-between;margin-bottom:1rem;padding:.75rem 1rem}.zta-suggestion-banner-content{align-items:center;display:flex;flex:1 1;gap:.5rem;min-width:0}.zta-suggestion-banner svg{color:#8b5cf6;flex-shrink:0}.zta-suggestion-banner strong{color:#8b5cf6;font-weight:600}.zta-suggestion-view-btn{align-items:center;background:#0000;border:1px solid #8b5cf666;border-radius:.25rem;color:#8b5cf6;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:.75rem;font-weight:500;gap:.25rem;padding:.25rem .5rem;transition:all .15s ease;white-space:nowrap}.zta-suggestion-view-btn:hover{background:#8b5cf61a;border-color:#8b5cf6}.zta-suggestion-view-btn svg{color:inherit}[data-theme=dark] .zta-suggestion-toggle{background:var(--zta-surface);border-color:var(--zta-border)}[data-theme=dark] .zta-suggestion-toggle.active{background:linear-gradient(135deg,#8b5cf6,#a855f7)}[data-theme=dark] .zta-suggestion-banner{background:linear-gradient(135deg,#8b5cf626,#6366f133);border-color:#8b5cf64d}.zta-modal--capability{max-width:700px}.zta-capability-description{background:var(--zta-surface-hover);border-radius:.5rem;color:var(--zta-text-muted);font-size:.875rem;line-height:1.5;margin-bottom:1rem;padding:.75rem 1rem}.zta-maturity-section{margin-bottom:1.5rem}.zta-maturity-section h3{font-size:1rem;font-weight:600;margin:0 0 .25rem}.zta-maturity-instruction{color:var(--zta-text-muted);font-size:.8125rem;margin:0 0 .75rem}.zta-maturity-cards{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr)}@media (max-width:767px){.zta-maturity-cards{grid-template-columns:1fr}}.zta-maturity-card{align-items:flex-start;background:var(--zta-surface);border:2px solid var(--zta-border);border-radius:.5rem;cursor:pointer;display:flex;flex-direction:column;padding:.75rem;text-align:left;transition:all .2s ease}.zta-maturity-card:hover{background:var(--zta-surface-hover);border-color:var(--pillar-color,var(--zta-device))}.zta-maturity-card--selected{background:#3b82f614;border-color:var(--pillar-color,var(--zta-device))}.zta-maturity-card--selected:hover{background:#3b82f61f}.zta-maturity-card-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:.5rem;width:100%}.zta-maturity-card-level{color:var(--zta-device);color:var(--pillar-color,var(--zta-device));font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.zta-maturity-card[data-level="0"] .zta-maturity-card-level{color:#6b7280}.zta-maturity-card[data-level="1"] .zta-maturity-card-level{color:#eab308}.zta-maturity-card[data-level="2"] .zta-maturity-card-level{color:#3b82f6}.zta-maturity-card[data-level="3"] .zta-maturity-card-level{color:#10b981}.zta-maturity-card--selected[data-level="0"]{background:#6b72801a;border-color:#6b7280}.zta-maturity-card--selected[data-level="1"]{background:#eab3081a;border-color:#eab308}.zta-maturity-card--selected[data-level="2"]{background:#3b82f61a;border-color:#3b82f6}.zta-maturity-card--selected[data-level="3"]{background:#10b9811a;border-color:#10b981}.zta-maturity-card-check{color:inherit}.zta-maturity-card--selected[data-level="0"] .zta-maturity-card-check{color:#6b7280}.zta-maturity-card--selected[data-level="1"] .zta-maturity-card-check{color:#eab308}.zta-maturity-card--selected[data-level="2"] .zta-maturity-card-check{color:#3b82f6}.zta-maturity-card--selected[data-level="3"] .zta-maturity-card-check{color:#10b981}.zta-maturity-card-desc{color:var(--zta-text-muted);font-size:.8125rem;line-height:1.4;margin:0}.zta-capability--has-suggestion{background:linear-gradient(135deg,#8b5cf60d,#6366f114);border-color:#8b5cf64d;position:relative}.zta-capability--has-suggestion:hover{background:linear-gradient(135deg,#8b5cf61a,#6366f126);border-color:#8b5cf680}.zta-cap-suggestion-indicator{align-items:center;background:linear-gradient(135deg,#8b5cf6,#a855f7);border-radius:50%;color:#fff;display:flex;height:16px;justify-content:center;position:absolute;right:2px;top:2px;width:16px}.zta-cap-suggestion{color:#8b5cf6;font-size:.75rem;font-style:italic}[data-theme=dark] .zta-capability--has-suggestion{background:linear-gradient(135deg,#8b5cf61f,#6366f12e)}[data-theme=dark] .zta-maturity-card--selected{background:#3b82f626}body.zt-present-mode-active .breadcrumbs,body.zt-present-mode-active .chat-bubble,body.zt-present-mode-active .chat-widget,body.zt-present-mode-active .help-button,body.zt-present-mode-active .main-app-topnav,body.zt-present-mode-active .topnav,body.zt-present-mode-active .zta-confidential,body.zt-present-mode-active .zta-dept-badge,body.zt-present-mode-active .zta-no-dept-hint,body.zt-present-mode-active .zta-suggest-btn,body.zt-present-mode-active .zta-suggestion-toggle,body.zt-present-mode-active .zta-suggestions-loading,body.zt-present-mode-active [class*=ChatWidget],body.zt-present-mode-active [class*=breadcrumb],body.zt-present-mode-active [class*=chat-widget],body.zt-present-mode-active [class*=help-button],body.zt-present-mode-active [class*=topnav]{display:none!important}body.zt-present-mode-active .main-app-content,body.zt-present-mode-active .main-content,body.zt-present-mode-active [class*=content-area]{margin-top:0!important;padding-top:0!important}body.zt-present-mode-active .zta{bottom:0;left:0;margin:0!important;overflow:auto;padding:1.5rem;position:fixed;right:0;top:0;z-index:9999}body.zt-present-mode-active .zta .zta-header{background:var(--zta-bg);border-bottom:1px solid var(--zta-border);margin:-1.5rem -1.5rem 1rem;padding:1rem 1.5rem;position:sticky;top:0;z-index:100}body.zt-present-mode-active .zta .zta-fullscreen-btn{background:#ef4444;border-color:#ef4444;color:#fff}body.zt-present-mode-active .zta .zta-fullscreen-btn:hover{background:#dc2626;border-color:#dc2626}:root{--cisco-blue:#049fd9;--cisco-blue-dark:#00629b;--cisco-blue-light:#6abce4}.zta-cisco-toggle{align-items:center;background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s ease}.zta-cisco-toggle:hover{color:#049fd9;color:var(--cisco-blue)}.zta-cisco-toggle.active,.zta-cisco-toggle:hover{border-color:#049fd9;border-color:var(--cisco-blue)}.zta-cisco-toggle.active{background:#049fd9;background:var(--cisco-blue);color:#fff}.zta-cisco-toggle.active:hover{background:#00629b;background:var(--cisco-blue-dark);border-color:#00629b;border-color:var(--cisco-blue-dark)}.zta-cisco-toggle svg{height:14px;width:14px}.zta-export-btn{align-items:center;background:var(--zta-surface);border:1px solid var(--zta-border);border-radius:.375rem;color:var(--zta-text-muted);cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:.375rem;padding:.375rem .75rem;transition:all .2s ease}.zta-export-btn:hover:not(:disabled){background:#10b9810d;border-color:#10b981;color:#10b981}.zta-export-btn:disabled{cursor:not-allowed;opacity:.6}.zta-export-btn svg{height:14px;width:14px}.zta-capability--cisco-active{background:linear-gradient(135deg,#049fd926,#00629b33)!important;border-color:#049fd9!important;border-color:var(--cisco-blue)!important;position:relative}.zta-capability--cisco-active:after{background:#049fd9;background:var(--cisco-blue);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 3.5c-.7 0-1.3.6-1.3 1.3v4.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V4.8c0-.7-.6-1.3-1.3-1.3zm-4.8 2c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zm9.6 0c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zM2.4 7c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3zm19.2 0c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:12px 12px;border-radius:3px;content:"";height:18px;position:absolute;right:4px;top:4px;width:18px}.zta-signal-card--cisco-active{background:linear-gradient(135deg,#049fd926,#00629b33)!important;border-color:#049fd9!important;border-color:var(--cisco-blue)!important}.zta-signal-card--cisco-active:before{background:#049fd9;background:var(--cisco-blue);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 3.5c-.7 0-1.3.6-1.3 1.3v4.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V4.8c0-.7-.6-1.3-1.3-1.3zm-4.8 2c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zm9.6 0c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zM2.4 7c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3zm19.2 0c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:12px 12px;border-radius:3px;content:"";height:18px;position:absolute;right:4px;top:4px;width:18px}.zta-vis-tool--cisco-active{background:linear-gradient(135deg,#049fd926,#00629b33)!important;border-color:#049fd9!important;border-color:var(--cisco-blue)!important;position:relative}.zta-vis-tool--cisco-active:after{background:#049fd9;background:var(--cisco-blue);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='%23fff'%3E%3Cpath d='M12 3.5c-.7 0-1.3.6-1.3 1.3v4.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V4.8c0-.7-.6-1.3-1.3-1.3zm-4.8 2c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zm9.6 0c-.7 0-1.3.6-1.3 1.3v2.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V6.8c0-.7-.6-1.3-1.3-1.3zM2.4 7c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3zm19.2 0c-.7 0-1.3.6-1.3 1.3v1.4c0 .7.6 1.3 1.3 1.3s1.3-.6 1.3-1.3V8.3c0-.7-.6-1.3-1.3-1.3z'/%3E%3C/svg%3E");background-position:50%;background-repeat:no-repeat;background-size:10px 10px;border-radius:2px;content:"";height:14px;position:absolute;right:3px;top:3px;width:14px}[data-theme=dark] .zta-cisco-toggle{background:var(--zta-surface);border-color:var(--zta-border)}[data-theme=dark] .zta-cisco-toggle.active{background:#049fd9;background:var(--cisco-blue)}[data-theme=dark] .zta-capability--cisco-active,[data-theme=dark] .zta-signal-card--cisco-active,[data-theme=dark] .zta-vis-tool--cisco-active{background:linear-gradient(135deg,#049fd933,#00629b40)!important}.zt-container{background:var(--color-background);display:flex;flex-direction:column;height:100%;min-height:0;position:relative}.zt-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0;flex-wrap:wrap;padding:var(--space-4) var(--space-5)}.zt-header,.zt-header-left{align-items:center;display:flex;gap:var(--space-3)}.zt-header-left{flex:1 1;min-width:0}.zt-header-title{align-items:center;display:flex;gap:var(--space-2)}.zt-header-title h1{color:var(--color-text);font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}.zt-header-right{align-items:center;display:flex;flex-shrink:0;gap:var(--space-2)}.zt-view-tabs{background:var(--color-surface-hover);border-radius:var(--radius-lg);display:flex;gap:2px;padding:2px}.zt-view-tab{align-items:center;background:#0000;border:none;border-radius:calc(var(--radius-lg) - 2px);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-1) var(--space-3);transition:all var(--transition-fast);white-space:nowrap}.zt-view-tab:hover{color:var(--color-text)}.zt-view-tab.active{background:var(--color-surface);box-shadow:var(--shadow-sm);color:var(--color-primary)}.zt-view-tab:disabled{cursor:not-allowed;opacity:.4}.zt-vendor-badge{align-items:center;background:#3b82f61a;border:1px solid #3b82f64d;border-radius:var(--radius-full);color:var(--color-primary);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-1) var(--space-2)}.zt-loading{align-items:center;color:var(--color-text-muted);display:flex;flex:1 1;flex-direction:column;gap:var(--space-3);justify-content:center;padding:var(--space-12)}.zt-loading svg.spin{animation:spin 1s linear infinite}.zt-error{align-items:center;color:var(--color-error);display:flex;flex:1 1;flex-direction:column;gap:var(--space-3);justify-content:center;padding:var(--space-12)}.zt-error button{margin-top:var(--space-2)}.zt-scroll-area{display:flex;flex:1 1;flex-direction:column;gap:var(--space-4);min-height:0;overflow-x:auto;overflow-y:auto;padding:var(--space-4) var(--space-5)}.governance-layer,.pdp-layer,.people-process-layer,.roadmap-timeline,.visibility-detail-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.layer-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--space-3)}.layer-header,.layer-header-left,.layer-header-right{align-items:center;display:flex;gap:var(--space-2)}.layer-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold)}.layer-subtitle{color:var(--color-text-muted);font-size:var(--text-xs)}.layer-loading{display:flex;justify-content:center;padding:var(--space-4)}.layer-expand-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-xs);gap:var(--space-1);padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.layer-expand-btn:hover{border-color:var(--color-border-hover);color:var(--color-text)}.layer-expand-btn--center{display:flex;margin:var(--space-3) auto 0}.layer-coverage-pct{font-size:var(--text-xs);font-weight:var(--font-medium)}.layer-tab-group{display:flex;gap:var(--space-1)}.layer-tab-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-xs);gap:var(--space-1);padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.layer-tab-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.loading-dots{display:flex;gap:4px}.loading-dots span{animation:bounce 1.2s ease-in-out infinite;background:var(--color-text-muted);border-radius:50%;height:6px;width:6px}.loading-dots span:nth-child(2){animation-delay:.2s}.loading-dots span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{opacity:.4;transform:scale(.6)}40%{opacity:1;transform:scale(1)}}.critical-count-badge{align-items:center;background:#ef44441a;border:1px solid #ef44444d;border-radius:var(--radius-full);color:var(--zt-gap);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);padding:2px var(--space-2)}.governance-items{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(220px,1fr))}.governance-item{background:var(--color-surface-hover);border-left:3px solid var(--zt-governance);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);transition:background var(--transition-fast)}.governance-item--critical{background:#ef44440d;border-left-color:var(--zt-ab869-critical)}.governance-item-header{align-items:center;display:flex;gap:var(--space-2);justify-content:space-between}.governance-item-name{color:var(--color-text);font-size:var(--text-xs);font-weight:var(--font-medium)}.governance-critical-tag{align-items:center;background:var(--zt-gap);border-radius:var(--radius-sm);color:#fff;display:inline-flex;flex-shrink:0;font-size:9px;font-weight:var(--font-bold);gap:2px;padding:1px var(--space-1);white-space:nowrap}.governance-item-desc{color:var(--color-text-muted);font-size:11px;line-height:1.4;margin:var(--space-1) 0 0}.governance-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-2)}.pdp-content{grid-gap:var(--space-4);align-items:center;display:grid;gap:var(--space-4);grid-template-columns:1fr auto 1fr;min-height:120px}.pdp-signals{display:flex;flex-direction:column;gap:var(--space-2)}.pdp-signal-card{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3);position:relative}.pdp-signal-icon{align-items:center;border-radius:var(--radius-md);display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.pdp-signal-label{color:var(--color-text);flex:1 1;font-size:var(--text-xs);font-weight:var(--font-medium)}.pdp-signal-coverage{font-size:var(--text-xs);font-weight:var(--font-bold)}.pdp-signal-arrow{color:var(--color-text-subtle);flex-shrink:0}.pdp-engine{justify-content:center;padding:var(--space-1)}.pdp-engine,.pdp-engine-inner{align-items:center;display:flex}.pdp-engine-inner{background:linear-gradient(135deg,#3b82f61a,#6366f11a);border:2px solid var(--color-primary);border-radius:var(--radius-xl);flex-direction:column;gap:var(--space-2);min-width:160px;padding:var(--space-4);text-align:center}.pdp-engine-icon{color:var(--color-primary)}.pdp-engine-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-bold)}.pdp-engine-desc{color:var(--color-text-muted);font-size:var(--text-xs)}.pdp-engine-principles{display:flex;flex-direction:column;gap:2px}.pdp-principle{background:var(--color-primary);border-radius:var(--radius-full);color:#fff;font-size:10px;font-weight:var(--font-medium);padding:2px var(--space-2)}.pdp-decisions{display:flex;flex-direction:column;gap:var(--space-2)}.pdp-decision{border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);text-align:center}.pdp-decision--allow{background:#10b98114;border-color:#10b9814d}.pdp-decision--conditional{background:#f59e0b14;border-color:#f59e0b4d}.pdp-decision--deny{background:#ef444414;border-color:#ef44444d}.pdp-decision-label{color:var(--color-text);display:block;font-size:var(--text-xs);font-weight:var(--font-bold)}.pdp-decision-desc{color:var(--color-text-muted);font-size:10px;margin-top:2px}.pillar-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(6,minmax(180px,1fr));min-width:0;overflow-x:auto}.pillar-grid--vendor-mode{border:2px solid var(--color-primary);border-radius:var(--radius-lg);padding:var(--space-3);position:relative}.pillar-column{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;min-width:0;overflow:hidden}.pillar-column-header{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);border-top:3px solid #0000;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-3)}.pillar-icon{align-items:center;border-radius:var(--radius-md);display:flex;font-size:16px;height:32px;justify-content:center;width:32px}.pillar-header-text{flex:1 1;min-width:0}.pillar-name{font-size:var(--text-sm);font-weight:var(--font-bold);line-height:1.2;margin:0}.pillar-meta{align-items:center;display:flex;gap:var(--space-2);margin-top:2px}.pillar-cap-count{color:var(--color-text-muted);font-size:var(--text-xs)}.pillar-critical-count{background:#ef44441f;border-radius:var(--radius-sm);color:var(--zt-gap);font-size:10px;font-weight:var(--font-medium);padding:1px var(--space-1)}.pillar-vendor-coverage{font-size:var(--text-sm);font-weight:var(--font-bold);text-align:right}.pillar-capabilities{display:flex;flex:1 1;flex-direction:column;gap:var(--space-2);max-height:600px;overflow-y:auto;padding:var(--space-2)}.pillar-empty{color:var(--color-text-muted);font-size:var(--text-xs);padding:var(--space-3);text-align:center}.capability-card{background:var(--color-surface-hover);border:1px solid var(--color-border);border-left:3px solid #0000;border-radius:var(--radius-md);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.capability-card:hover{background:var(--color-surface-active);border-color:var(--color-border-hover)}.capability-card--critical{background:#ef44440a;border-left-color:var(--zt-ab869-critical)!important}.capability-card--has-vendor{border-left-width:3px}.capability-card-header{margin-bottom:var(--space-1)}.capability-card-name-row{align-items:flex-start;display:flex;gap:var(--space-1);justify-content:space-between}.capability-card-name{color:var(--color-text);flex:1 1;font-size:11px;font-weight:var(--font-medium);line-height:1.3;min-width:0}.capability-card-badges{align-items:center;display:flex;flex-shrink:0;gap:2px}.capability-ab869-badge{align-items:center;background:var(--zt-gap);border-radius:3px;color:#fff;display:inline-flex;font-size:9px;font-weight:var(--font-bold);gap:2px;padding:1px var(--space-1);white-space:nowrap}.capability-card-desc{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:var(--color-text-muted);display:-webkit-box;font-size:10px;line-height:1.3;margin:0 0 var(--space-1);overflow:hidden}.capability-card-maturity{margin-top:var(--space-1)}.capability-card-assessment{display:flex;flex-wrap:wrap;gap:var(--space-1);margin-top:var(--space-1)}.maturity-bar{display:flex;gap:2px;height:18px}.maturity-bar--compact{height:14px}.maturity-segment{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:2px;cursor:default;display:flex;flex:1 1;justify-content:center;padding:0;transition:all var(--transition-fast)}.maturity-segment.filled{border-color:#0000}.maturity-segment.active{box-shadow:0 0 0 1px currentColor}.maturity-bar--interactive .maturity-segment{cursor:pointer}.maturity-bar--interactive .maturity-segment:hover{opacity:.85;transform:scaleY(1.1)}.maturity-segment-label{color:#fff;font-size:8px;font-weight:var(--font-bold);line-height:1;pointer-events:none}.maturity-chip{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:10px;font-weight:var(--font-medium);padding:1px var(--space-2)}.maturity-chip--traditional{background:#6b728026;color:var(--zt-traditional)}.maturity-chip--initial{background:#eab30826;color:var(--zt-#000);color:var(--zt-initial)}.maturity-chip--advanced{background:#3b82f626;color:var(--zt-advanced)}.maturity-chip--optimal{background:#10b98126;color:var(--zt-optimal)}.status-chip{align-items:center;border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);display:inline-flex;font-size:10px;font-weight:var(--font-medium);padding:1px var(--space-2);text-transform:capitalize}.status-chip--deployed{border-color:#10b9814d;color:var(--zt-strong)}.status-chip--in_progress{border-color:#3b82f64d;color:var(--zt-advanced)}.status-chip--planning{border-color:#eab3084d;color:var(--zt-#000);color:var(--zt-initial)}.status-chip--not_started{opacity:.6}.priority-chip{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:10px;font-weight:var(--font-medium);padding:1px var(--space-2)}.priority-chip--critical{background:#ef44441f;color:var(--zt-gap)}.priority-chip--high{background:#f59e0b1f;color:var(--zt-partial)}.priority-chip--medium{background:#3b82f61f;color:var(--zt-advanced)}.priority-chip--low{background:var(--color-surface-hover);color:var(--color-text-muted)}.coverage-badge{align-items:center;display:inline-flex;flex-shrink:0;gap:2px}.coverage-badge-label{font-size:10px;font-weight:var(--font-medium)}.coverage-percentage{align-items:center;display:flex;gap:var(--space-2)}.coverage-percentage-value{font-weight:var(--font-bold);min-width:36px}.coverage-percentage--sm .coverage-percentage-value{font-size:var(--text-xs)}.coverage-percentage--md .coverage-percentage-value{font-size:var(--text-sm)}.coverage-percentage--lg .coverage-percentage-value{font-size:var(--text-lg)}.coverage-percentage-bar{background:var(--color-border);border-radius:var(--radius-full);flex:1 1;height:4px;overflow:hidden}.coverage-percentage-fill{border-radius:var(--radius-full);height:100%;transition:width .5s ease}.vendor-selector{position:relative}.vendor-selector-trigger{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-2);padding:var(--space-1) var(--space-3);transition:all var(--transition-fast);white-space:nowrap}.vendor-selector-trigger:hover{border-color:var(--color-border-hover);color:var(--color-text)}.vendor-selector-trigger.has-selection{background:#3b82f614;border-color:var(--color-primary);color:var(--color-primary)}.vendor-clear{color:var(--color-text-muted)}.vendor-clear:hover{color:var(--zt-gap)}.vendor-selector-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);min-width:220px;overflow:hidden;position:absolute;right:0;top:calc(100% + var(--space-1));z-index:100}.vendor-selector-header{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-2) var(--space-3)}.vendor-selector-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-3);text-align:center}.vendor-selector-item{align-items:flex-start;background:#0000;border:none;border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;flex-direction:column;gap:1px;padding:var(--space-2) var(--space-3);text-align:left;transition:background var(--transition-fast);width:100%}.vendor-selector-item:last-child{border-bottom:none}.vendor-selector-item:hover{background:var(--color-surface-hover)}.vendor-selector-item.selected{background:#3b82f614}.vendor-item-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.vendor-item-category{color:var(--color-text-muted);font-size:var(--text-xs)}.product-dropdown{display:inline-block;position:relative}.product-dropdown-trigger{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-xs);gap:var(--space-1);padding:2px var(--space-2);transition:all var(--transition-fast)}.product-dropdown-trigger:hover{border-color:var(--color-border-hover);color:var(--color-text)}.product-dropdown-menu{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);left:0;max-width:320px;min-width:240px;overflow:hidden;position:absolute;top:calc(100% + 4px);z-index:200}.product-dropdown-header{background:var(--color-surface-hover);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold)}.product-dropdown-header,.product-dropdown-item{border-bottom:1px solid var(--color-border);padding:var(--space-2) var(--space-3)}.product-dropdown-item:last-child{border-bottom:none}.product-item-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.product-item-desc{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:2px}.product-item-caps{color:var(--color-text-subtle);font-size:10px;margin-top:2px}.visibility-capabilities{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.visibility-cap-card{background:var(--color-surface-hover);border:1px solid var(--color-border);border-left:3px solid var(--zt-visibility);border-radius:var(--radius-md);padding:var(--space-2) var(--space-3)}.visibility-cap-card--critical{border-left-color:var(--zt-ab869-critical)}.visibility-cap-header{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-1)}.visibility-cap-name{color:var(--color-text);flex:1 1;font-size:var(--text-xs);font-weight:var(--font-medium);min-width:0}.visibility-cap-desc{color:var(--color-text-muted);font-size:10px;line-height:1.4;margin:var(--space-1) 0 0}.visibility-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-2)}.people-process-content{display:flex;flex-direction:column;gap:var(--space-3)}.people-process-grid{grid-gap:var(--space-2);display:grid;gap:var(--space-2);grid-template-columns:repeat(auto-fill,minmax(200px,1fr))}.people-process-card{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);padding:var(--space-3)}.pp-card-header{align-items:center;display:flex;gap:var(--space-2);margin-bottom:var(--space-1)}.pp-card-icon{color:var(--color-text-muted);flex-shrink:0}.pp-card-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.pp-card-desc{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.4;margin:0 0 var(--space-2)}.pp-card-responsibilities{margin:0;padding-left:var(--space-4)}.pp-card-responsibilities li{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.5}.people-process-empty{color:var(--color-text-muted);font-size:var(--text-sm);grid-column:1/-1;padding:var(--space-4);text-align:center}.roadmap-content{display:flex;flex-direction:column;gap:var(--space-4)}.roadmap-track{align-items:center;overflow-x:auto;padding-bottom:var(--space-2)}.roadmap-phase,.roadmap-track{display:flex;gap:var(--space-2)}.roadmap-phase{align-items:flex-start;background:var(--color-surface-hover);border:2px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;flex-direction:column;min-width:160px;padding:var(--space-3);text-align:left;transition:all var(--transition-fast)}.roadmap-phase:hover{border-color:var(--color-border-hover)}.roadmap-phase--selected{background:var(--color-surface);box-shadow:var(--shadow-md)}.roadmap-phase-number{align-items:center;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-bold);height:24px;justify-content:center;width:24px}.roadmap-phase-info{display:flex;flex-direction:column;gap:2px}.roadmap-phase-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold)}.roadmap-phase-desc{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.4}.roadmap-phase-duration{align-items:center;color:var(--color-text-subtle);display:flex;font-size:var(--text-xs);gap:4px}.roadmap-phase-count{color:var(--color-text-muted);font-size:var(--text-xs)}.roadmap-connector{color:var(--color-text-subtle);flex-shrink:0}.roadmap-detail{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3)}.roadmap-detail-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0 0 var(--space-3)}.roadmap-detail-items{display:flex;flex-direction:column;gap:var(--space-1)}.roadmap-detail-item{align-items:center;border-radius:var(--radius-md);display:flex;gap:var(--space-2);padding:var(--space-2);transition:background var(--transition-fast)}.roadmap-detail-item:hover{background:var(--color-surface-active)}.roadmap-detail-item-content{align-items:center;display:flex;flex:1 1;gap:var(--space-2);min-width:0}.roadmap-detail-item-name{color:var(--color-text);flex:1 1;font-size:var(--text-sm);min-width:0}.roadmap-detail-item-pillar{color:var(--color-text-muted);flex-shrink:0;font-size:var(--text-xs)}.roadmap-detail-item-status{flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-medium)}.roadmap-detail-empty,.roadmap-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-4);text-align:center}.assessment-panel{background:var(--color-surface);border-left:1px solid var(--color-border);bottom:0;box-shadow:-4px 0 24px #00000026;box-shadow:var(--shadow-xl,-4px 0 24px #00000026);display:flex;flex-direction:column;max-width:95vw;overflow:hidden;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:480px;z-index:200}.assessment-panel--open{transform:translateX(0)}.assessment-panel-header{align-items:flex-start;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-4)}.assessment-panel-title{align-items:center;display:flex;flex:1 1;gap:var(--space-3);min-width:0}.assessment-panel-title-text h2{color:var(--color-text);font-size:var(--text-base);font-weight:var(--font-bold);margin:0}.assessment-dept-name,.assessment-saving{color:var(--color-text-muted);font-size:var(--text-xs)}.assessment-saving{align-items:center;display:flex;gap:var(--space-1)}.assessment-panel-close{background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);transition:all var(--transition-fast)}.assessment-panel-close:hover{background:var(--color-surface-hover);color:var(--color-text)}.assessment-summary-bar{align-items:center;background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-3) var(--space-4)}.assessment-score{align-items:baseline;display:flex;gap:var(--space-1)}.assessment-score-value{color:var(--color-primary);font-size:var(--text-xl);font-weight:var(--font-bold)}.assessment-score-label{color:var(--color-text-muted);font-size:var(--text-xs)}.assessment-readiness{align-items:center;display:flex;font-size:var(--text-sm);gap:var(--space-1)}.readiness-label{color:var(--color-text-muted)}.readiness-level{font-weight:var(--font-semibold)}.readiness-level--optimal{color:var(--zt-optimal)}.readiness-level--advanced{color:var(--zt-advanced)}.readiness-level--initial{color:var(--zt-#000);color:var(--zt-initial)}.readiness-level--traditional{color:var(--zt-traditional)}.assessment-ab869{align-items:center;display:flex;font-size:var(--text-sm);gap:var(--space-1)}.ab869-label{color:var(--color-text-muted)}.ab869-value{font-weight:var(--font-bold)}.assessment-tabs{border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0}.assessment-tab{background:#0000;border:none;border-bottom:2px solid #0000;color:var(--color-text-muted);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3);transition:all var(--transition-fast)}.assessment-tab:hover{background:var(--color-surface-hover);color:var(--color-text)}.assessment-tab.active{border-bottom-color:var(--color-primary);color:var(--color-primary)}.assessment-panel-content{flex:1 1;overflow-y:auto;padding:var(--space-3)}.assessment-loading{gap:var(--space-3)}.assessment-loading,.assessment-no-dept{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;height:200px;justify-content:center}.assessment-no-dept{gap:var(--space-2);text-align:center}.assessment-pillars{display:flex;flex-direction:column;gap:var(--space-2)}.assessment-pillar-section{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.assessment-pillar-header{align-items:center;background:var(--color-surface-hover);border:none;border-left:3px solid #0000;cursor:pointer;display:flex;justify-content:space-between;padding:var(--space-2) var(--space-3);text-align:left;transition:background var(--transition-fast);width:100%}.assessment-pillar-header:hover{background:var(--color-surface-active)}.assessment-pillar-name{font-size:var(--text-sm);font-weight:var(--font-semibold)}.assessment-pillar-meta{align-items:center;display:flex;gap:var(--space-2)}.assessment-pillar-progress{color:var(--color-text-muted);font-size:var(--text-xs)}.assessment-pillar-score{font-size:var(--text-sm);font-weight:var(--font-bold)}.assessment-capabilities{divide:1px;display:flex;flex-direction:column}.assessment-cap-row{border-bottom:1px solid var(--color-border);display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-2) var(--space-3)}.assessment-cap-row:last-child{border-bottom:none}.assessment-cap-row.editing{background:var(--color-surface-hover)}.assessment-cap-info{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.assessment-cap-name{color:var(--color-text);flex:1 1;font-size:var(--text-sm);min-width:0}.assessment-cap-current{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.assessment-not-assessed{font-style:italic}.assessment-edit-btn,.assessment-not-assessed{color:var(--color-text-muted);font-size:var(--text-xs)}.assessment-edit-btn{background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;margin-left:auto;padding:2px var(--space-2);transition:all var(--transition-fast)}.assessment-edit-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.assessment-cap-edit{display:flex;flex-direction:column;gap:var(--space-2)}.assessment-edit-row{align-items:center;display:flex;gap:var(--space-2)}.assessment-edit-row label{color:var(--color-text-muted);font-size:var(--text-xs);min-width:80px}.assessment-input,.assessment-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);flex:1 1;font-size:var(--text-sm);outline:none;padding:var(--space-1) var(--space-2)}.assessment-input:focus,.assessment-select:focus{border-color:var(--color-primary)}.assessment-edit-actions{display:flex;gap:var(--space-2);justify-content:flex-end}.maturity-selector{display:flex;flex-direction:column;gap:var(--space-2)}.maturity-selector-cap{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.maturity-selector-options{display:flex;flex-direction:column;gap:var(--space-1)}.maturity-option{align-items:flex-start;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-md);cursor:pointer;display:flex;gap:var(--space-2);padding:var(--space-2) var(--space-3);text-align:left;transition:all var(--transition-fast);width:100%}.maturity-option:hover{border-color:var(--color-border-hover)}.maturity-option--selected{background:var(--color-surface)}.maturity-option-dot{border-radius:50%;flex-shrink:0;height:10px;margin-top:3px;width:10px}.maturity-option-content{display:flex;flex-direction:column;gap:2px;min-width:0}.maturity-option-label{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium)}.maturity-option-desc{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.4}.gap-analysis{display:flex;flex-direction:column;gap:var(--space-4)}.gap-analysis--empty,.gap-analysis--loading{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-2);height:200px;justify-content:center}.gap-summary-stats{display:flex;gap:var(--space-4)}.gap-stat{align-items:center;display:flex;flex-direction:column;gap:var(--space-1)}.gap-stat--critical{align-items:center;flex-direction:row}.gap-stat-value{color:var(--color-text);font-size:1.5rem;font-size:var(--text-2xl,1.5rem);font-weight:var(--font-bold)}.gap-stat-label{color:var(--color-text-muted);font-size:var(--text-xs)}.gap-by-pillar{display:flex;flex-direction:column;gap:var(--space-2)}.gap-section-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0 0 var(--space-2)}.gap-pillar-info,.gap-pillar-row,.gap-section-title{align-items:center;display:flex;gap:var(--space-2)}.gap-pillar-info{min-width:120px}.gap-pillar-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.gap-pillar-name{color:var(--color-text-muted);font-size:var(--text-xs);white-space:nowrap}.gap-pillar-counts{display:flex;font-size:var(--text-xs);gap:var(--space-2);min-width:100px}.gap-pillar-critical{color:var(--zt-gap)}.gap-pillar-total{color:var(--color-text-muted)}.gap-pillar-bar-track{background:var(--color-border);border-radius:var(--radius-full);flex:1 1;height:6px;overflow:hidden}.gap-pillar-bar-fill{border-radius:var(--radius-full);height:100%;transition:width .5s ease}.gap-items{gap:var(--space-3)}.gap-items,.gap-pillar-section{display:flex;flex-direction:column}.gap-pillar-section{gap:var(--space-1)}.gap-pillar-section-header{border-bottom:1px solid var(--color-border);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-1) 0}.gap-item{align-items:flex-start;padding:var(--space-1) 0}.gap-item,.gap-item-content{display:flex;gap:var(--space-2)}.gap-item-content{align-items:center;flex:1 1;flex-wrap:wrap;min-width:0}.gap-item-name{color:var(--color-text);font-size:var(--text-sm)}.gap-item-current,.gap-item-target{color:var(--color-text-muted);font-size:var(--text-xs)}.gap-item-priority{flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-medium)}.questionnaire{display:flex;flex-direction:column;gap:var(--space-4);padding:var(--space-2)}.questionnaire--empty,.questionnaire--loading,.questionnaire--success{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-3);height:250px;justify-content:center;text-align:center}.questionnaire--success h3{color:var(--color-text)}.questionnaire-progress{align-items:center;display:flex;gap:var(--space-3)}.questionnaire-progress-bar{background:var(--color-border);border-radius:var(--radius-full);flex:1 1;height:6px;overflow:hidden}.questionnaire-progress-fill{background:var(--color-primary);border-radius:var(--radius-full);height:100%;transition:width .3s ease}.questionnaire-progress-label{color:var(--color-text-muted);font-size:var(--text-xs);white-space:nowrap}.questionnaire-question{display:flex;flex-direction:column;gap:var(--space-3)}.question-category{color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;text-transform:uppercase}.question-text{color:var(--color-text);font-size:var(--text-base);font-weight:var(--font-semibold);line-height:1.4;margin:0}.question-desc{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.5;margin:0}.question-options{display:flex;flex-direction:column;gap:var(--space-2)}.question-option{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-3);padding:var(--space-3);text-align:left;transition:all var(--transition-fast);width:100%}.question-option:hover{background:var(--color-surface-active);border-color:var(--color-border-hover)}.question-option--selected{background:#3b82f614;border-color:var(--color-primary);color:var(--color-primary)}.question-option-indicator{border:2px solid var(--color-border);border-radius:50%;flex-shrink:0;height:16px;transition:all var(--transition-fast);width:16px}.question-option--selected .question-option-indicator{background:var(--color-primary);border-color:var(--color-primary);box-shadow:inset 0 0 0 3px var(--color-surface)}.question-text-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-size:var(--text-sm);outline:none;padding:var(--space-3);resize:vertical;transition:border-color var(--transition-fast);width:100%}.question-text-input:focus{border-color:var(--color-primary)}.questionnaire-error{background:#ef444414;border:1px solid #ef44444d;border-radius:var(--radius-md);color:var(--zt-gap);font-size:var(--text-sm);padding:var(--space-3)}.questionnaire-nav{display:flex;gap:var(--space-2);justify-content:space-between}.executive-summary{display:flex;flex-direction:column;gap:var(--space-5);padding:var(--space-2)}.executive-summary--empty{color:var(--color-text-muted);flex-direction:column;justify-content:center;min-height:400px;text-align:center}.exec-header,.executive-summary--empty{align-items:center;display:flex;gap:var(--space-3)}.exec-header{flex-wrap:wrap;justify-content:space-between}.exec-header-left{align-items:center;display:flex;gap:var(--space-3)}.exec-title{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-bold);margin:0}.exec-dept{color:var(--color-text-muted);font-size:var(--text-sm);margin:var(--space-1) 0 0}.exec-header-right{align-items:center;display:flex;gap:var(--space-3)}.exec-readiness-badge{align-items:center;border:2px solid;border-radius:var(--radius-full);display:flex;font-size:var(--text-sm);font-weight:var(--font-bold);gap:var(--space-2);letter-spacing:.05em;padding:var(--space-2) var(--space-3);text-transform:uppercase}.exec-export-btn{align-items:center;display:flex;gap:var(--space-1)}.exec-stats-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(4,1fr)}.exec-stat-card{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-4);text-align:center}.exec-stat-value{font-size:1.5rem;font-size:var(--text-2xl,1.5rem);font-weight:var(--font-bold)}.exec-stat-label{color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-medium)}.exec-stat-sub{color:var(--color-text-subtle);font-size:10px}.exec-charts-row{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:1fr 1fr}.exec-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.exec-card-title{align-items:center;color:var(--color-text);display:flex;font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-2);margin:0 0 var(--space-3)}.exec-card--gaps{grid-column:1/-1}.maturity-radar{display:flex;flex-direction:column;gap:var(--space-3)}.maturity-radar--empty{align-items:center;color:var(--color-text-muted);display:flex;height:300px;justify-content:center}.maturity-radar-header{align-items:baseline;display:flex;flex-wrap:wrap;gap:var(--space-2)}.maturity-radar-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.maturity-radar-dept{color:var(--color-text-muted);font-size:var(--text-xs)}.maturity-radar-scale{display:flex;flex-wrap:wrap;gap:var(--space-4);justify-content:center}.maturity-scale-item{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-xs);gap:var(--space-1)}.maturity-scale-dot{border-radius:50%;height:8px;width:8px}.radar-tooltip{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-md);font-size:var(--text-xs);padding:var(--space-2) var(--space-3)}.radar-tooltip-title{color:var(--color-text);font-weight:var(--font-semibold);margin-bottom:var(--space-1)}.radar-tooltip-row{display:flex;gap:var(--space-2);justify-content:space-between}.maturity-dist-row{align-items:flex-end;display:flex;gap:var(--space-3);height:100px;justify-content:space-around}.maturity-dist-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:var(--space-1)}.maturity-dist-bar{border-radius:var(--radius-md) var(--radius-md) 0 0;min-height:8px;transition:height .5s ease;width:100%}.maturity-dist-label{color:var(--color-text-muted);font-size:var(--text-xs);text-align:center}.maturity-dist-count{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-bold)}.gap-table-container{display:flex;flex-direction:column;gap:var(--space-3)}.gap-table-filters{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.gap-filter-select{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-size:var(--text-sm);outline:none;padding:var(--space-1) var(--space-2)}.gap-filter-select:focus{border-color:var(--color-primary)}.gap-filter-count{color:var(--color-text-muted);font-size:var(--text-xs);margin-left:auto}.gap-table-empty{color:var(--color-text-muted);font-size:var(--text-sm);padding:var(--space-6);text-align:center}.gap-table-wrapper{border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow-x:auto}.gap-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.gap-th{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-2) var(--space-3);text-align:left;white-space:nowrap}.gap-th.sortable{cursor:pointer;display:table-cell;-webkit-user-select:none;user-select:none}.gap-th.sortable:hover{color:var(--color-text)}.gap-td{border-bottom:1px solid var(--color-border);padding:var(--space-2) var(--space-3);vertical-align:middle}.gap-table tbody tr:last-child .gap-td{border-bottom:none}.gap-table tbody tr:hover .gap-td{background:var(--color-surface-hover)}.gap-row--critical .gap-td{background:#ef444408}.gap-priority-cell{align-items:center;display:flex;gap:var(--space-1)}.gap-ab869-tag{background:var(--zt-gap);border-radius:3px;color:#fff;font-size:9px;font-weight:var(--font-bold);padding:1px 4px}.gap-td--name{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.gap-recommendations{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4)}.gap-rec-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0 0 var(--space-2)}.gap-rec-list{display:flex;flex-direction:column;gap:var(--space-1);margin:0;padding-left:var(--space-4)}.gap-rec-item{color:var(--color-text-muted);font-size:var(--text-sm);line-height:1.5}.btn-primary{align-items:center;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.btn-primary:hover{background:var(--color-primary-hover)}.btn-primary:disabled{cursor:not-allowed;opacity:.5}.btn-secondary{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-2) var(--space-4);transition:all var(--transition-fast)}.btn-secondary:hover{border-color:var(--color-border-hover);color:var(--color-text)}.btn-secondary:disabled{cursor:not-allowed;opacity:.5}.btn-sm{font-size:var(--text-xs);padding:var(--space-1) var(--space-2)}.spin{animation:spin 1s linear infinite}.zt-mode-banner{align-items:center;background:linear-gradient(135deg,var(--color-primary) 0,#1d4ed8 100%);background:linear-gradient(135deg,var(--color-primary) 0,var(--color-primary-dark,#1d4ed8) 100%);border-radius:var(--radius-lg);color:#fff;display:flex;font-size:var(--text-sm);justify-content:center;margin-bottom:var(--space-2);padding:var(--space-3) var(--space-4)}.zt-mode-banner-text{align-items:center;display:flex;gap:var(--space-2)}.zt-mode-banner-text strong{font-weight:var(--font-bold)}.capability-card.with-vendors{align-items:stretch;flex-direction:column;gap:var(--space-2)}.capability-header{align-items:center;display:flex;justify-content:space-between;width:100%}.capability-vendors{width:100%}.zt-vendor-input-container{display:flex;flex-direction:column;gap:var(--space-1);width:100%}.zt-vendor-chips{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-1)}.zt-vendor-chip{background:#3b82f626;background:var(--color-primary-light,#3b82f626);border:1px solid #3b82f6;border:1px solid var(--color-primary,#3b82f6);border-radius:var(--radius-full);display:inline-flex;font-size:10px;font-weight:var(--font-medium);gap:var(--space-1);padding:2px var(--space-2)}.zt-chip-remove,.zt-vendor-chip{align-items:center;color:#3b82f6;color:var(--color-primary,#3b82f6)}.zt-chip-remove{background:#0000;border:none;border-radius:var(--radius-full);cursor:pointer;display:flex;height:14px;justify-content:center;opacity:.7;padding:0;transition:all var(--transition-fast);width:14px}.zt-chip-remove:hover{background:#3b82f633;opacity:1}.zt-vendor-input-wrapper{position:relative;width:100%}.zt-vendor-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);font-size:10px;outline:none;padding:var(--space-1) var(--space-2);transition:all var(--transition-fast);width:100%}.zt-vendor-input::placeholder{color:var(--color-text-muted);font-size:10px}.zt-vendor-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #3b82f61a}.zt-vendor-suggestions{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);left:0;margin-top:2px;max-height:150px;overflow-y:auto;position:absolute;right:0;top:100%;z-index:100}.zt-vendor-suggestion{color:var(--color-text);cursor:pointer;font-size:10px;padding:var(--space-2);transition:background var(--transition-fast)}.zt-vendor-suggestion:hover{background:var(--color-surface-hover)}.zt-vendor-suggestion:first-child{border-radius:var(--radius-md) var(--radius-md) 0 0}.zt-vendor-suggestion:last-child{border-radius:0 0 var(--radius-md) var(--radius-md)}.zt-saved-check,.zt-saving-spinner{align-items:center;display:inline-flex;height:18px;justify-content:center;width:18px}.zt-saving-spinner{color:var(--color-text-muted)}.zt-spin{animation:spin 1s linear infinite}.zt-saved-check{animation:fadeIn .2s ease-out;color:#10b981;color:var(--zt-strong,#10b981)}@media (max-width:1024px){.pillar-grid{grid-template-columns:repeat(3,minmax(160px,1fr))}.exec-stats-grid{grid-template-columns:repeat(2,1fr)}.exec-charts-row,.pdp-content{grid-template-columns:1fr}}@media (max-width:767px){.zt-header{align-items:flex-start;flex-direction:column}.zt-header-right{flex-wrap:wrap;width:100%}.zt-view-tabs{overflow-x:auto;width:100%}.pillar-grid{grid-template-columns:1fr}.capability-card{width:100%}.assessment-panel{border-radius:0;bottom:0;left:0;overflow-y:auto;position:fixed;right:0;top:0;width:100%;z-index:1000}.assessment-panel-content{flex-direction:column}.exec-charts-row,.exec-stats-grid,.pdp-content{grid-template-columns:1fr}.zt-container input,.zt-container select,.zt-container textarea{min-height:44px;width:100%}.zt-container .btn-group,.zt-container .header-actions{flex-direction:column;width:100%}.zt-container .btn-group button,.zt-container .header-actions button{min-height:44px;width:100%}.zt-view-tab{min-height:44px}}@media print{.assessment-panel,.exec-export-btn,.zt-header{display:none!important}.executive-summary{padding:0}}.capability-suggestion{background:linear-gradient(135deg,#8b5cf614,#3b82f614);border:1px solid #8b5cf640;border-radius:var(--radius-md);display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-2);padding:var(--space-2) var(--space-3)}.capability-suggestion-header{align-items:center;display:flex;gap:var(--space-2)}.capability-suggestion-icon{color:#8b5cf6e6;flex-shrink:0}.capability-suggestion-label{color:#8b5cf6e6;font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;text-transform:uppercase}.capability-suggestion-confidence{font-size:var(--text-xs);font-weight:var(--font-bold);margin-left:auto}.capability-suggestion-content{display:flex;flex-direction:column;gap:var(--space-1)}.capability-suggestion-vendor{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.suggestion-vendor-name{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold)}.suggestion-product-name{border-left:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-sm);padding-left:var(--space-2)}.capability-suggestion-meta{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.suggestion-spend,.suggestion-transaction-count{color:var(--color-text-muted);font-size:var(--text-xs)}.capability-suggestion-actions{align-items:center;display:flex;gap:var(--space-2);margin-top:var(--space-1)}.suggestion-accept-btn,.suggestion-view-btn{align-items:center;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-1);padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.suggestion-accept-btn{background:var(--zt-strong);border:none;color:#fff}.suggestion-accept-btn:hover{background:#0d9669}.suggestion-view-btn{background:#0000;border:1px solid var(--color-primary);color:var(--color-primary)}.suggestion-view-btn:hover{background:#3b82f614}.transaction-modal-overlay{align-items:center;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:var(--space-4);position:fixed;right:0;top:0;z-index:1000}.transaction-modal{background:var(--color-surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);display:flex;flex-direction:column;max-height:85vh;max-width:900px;overflow:hidden;width:100%}.transaction-modal-header{align-items:flex-start;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-4)}.transaction-modal-title{align-items:flex-start;display:flex;gap:var(--space-3)}.transaction-modal-title svg{color:var(--color-primary);flex-shrink:0;margin-top:2px}.transaction-modal-title-text h3{color:var(--color-text);font-size:var(--text-base);font-weight:var(--font-bold);margin:0}.transaction-modal-vendor{color:var(--color-text-muted);display:block;font-size:var(--text-sm);margin-top:2px}.transaction-modal-close{background:#0000;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;padding:var(--space-1);transition:all var(--transition-fast)}.transaction-modal-close:hover{background:var(--color-surface-hover);color:var(--color-text)}.transaction-modal-summary{align-items:center;background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-2) var(--space-4)}.transaction-count{color:var(--color-text-muted);font-size:var(--text-sm)}.transaction-total{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-bold)}.transaction-modal-content{flex:1 1;min-height:200px;overflow-y:auto}.transaction-empty,.transaction-error,.transaction-loading{align-items:center;color:var(--color-text-muted);display:flex;flex-direction:column;gap:var(--space-3);height:200px;justify-content:center;padding:var(--space-4);text-align:center}.transaction-error{color:var(--zt-gap)}.transaction-table-wrapper{overflow-x:auto}.transaction-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.transaction-th{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--space-2) var(--space-3);position:sticky;text-align:left;top:0;white-space:nowrap;z-index:1}.transaction-th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.transaction-th.sortable:hover{color:var(--color-text)}.transaction-th-content{align-items:center;display:inline-flex;gap:var(--space-1)}.transaction-td{border-bottom:1px solid var(--color-border);color:var(--color-text);padding:var(--space-2) var(--space-3);vertical-align:middle}.transaction-row:hover .transaction-td{background:var(--color-surface-hover)}.transaction-td-po{font-family:monospace;font-family:var(--font-mono,monospace);font-size:11px;white-space:nowrap}.transaction-td-date{color:var(--color-text-muted);white-space:nowrap}.transaction-td-desc{max-width:200px}.transaction-td-desc,.transaction-td-partner{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.transaction-td-partner{max-width:150px}.transaction-td-amount{font-weight:var(--font-medium);text-align:right;white-space:nowrap}.transaction-modal-footer{border-top:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:flex-end;padding:var(--space-3) var(--space-4)}.zt-sync-btn{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-muted);cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 12px;position:relative;transition:all .15s}a.zt-sync-btn{text-decoration:none}.zt-sync-btn:hover{background:var(--color-surface-hover);border-color:var(--color-primary);color:var(--color-text)}.zt-sync-btn--stale{border-color:#f59e0b;color:#fbbf24}.zt-sync-btn--stale:hover{background:#f59e0b1a;border-color:#f59e0b}.zt-sync-dot{animation:zt-sync-pulse 2s infinite;background:#f59e0b;border-radius:50%;height:6px;position:absolute;right:4px;top:4px;width:6px}@keyframes zt-sync-pulse{0%,to{opacity:1}50%{opacity:.4}}.zt-sync-overlay{align-items:center;background:#00000080;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:1100}.zt-sync-panel{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:16px;box-shadow:0 24px 48px #00000080;max-height:85vh;max-width:520px;overflow-y:auto;width:100%}.zt-sync-header{align-items:center;border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);display:flex;justify-content:space-between;padding:20px 24px}.zt-sync-header-title{align-items:center;display:flex;gap:10px}.zt-sync-header-title svg{color:#6366f1;color:var(--color-primary,#6366f1)}.zt-sync-header-title h2{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.1rem;font-weight:700;margin:0}.zt-sync-close{background:none;border:none;border-radius:6px;color:#64748b;color:var(--color-text-muted,#64748b);cursor:pointer;padding:4px}.zt-sync-close:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.zt-sync-status{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);display:flex;flex-direction:column;gap:8px;padding:20px 24px}.zt-sync-status-badge{align-items:center;border-radius:8px;display:inline-flex;font-size:.85rem;font-weight:600;gap:6px;padding:6px 12px;width:fit-content}.zt-sync-status-badge.synced{background:#10b9811f;color:#10b981}.zt-sync-status-badge.stale{background:#f59e0b1f;color:#fbbf24}.zt-sync-status-badge.unpublished{background:#94a3b81f;color:#94a3b8}.zt-sync-status-meta{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.8rem;gap:6px}.zt-sync-section{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);padding:20px 24px}.zt-sync-section-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:600;letter-spacing:.03em;margin:0 0 12px;text-transform:uppercase}.zt-sync-modes{display:flex;flex-direction:column;gap:10px}.zt-sync-mode-card{align-items:flex-start;background:#1e2235;background:var(--color-surface-hover,#1e2235);border:2px solid #0000;border-radius:10px;cursor:pointer;display:flex;gap:14px;padding:14px 16px;position:relative;text-align:left;transition:all .15s;width:100%}.zt-sync-mode-card:hover{border-color:#2d3148;border-color:var(--color-border,#2d3148)}.zt-sync-mode-card.active{background:#6366f114;border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.zt-sync-mode-icon{align-items:center;background:#6366f11f;border-radius:10px;color:#6366f1;color:var(--color-primary,#6366f1);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.zt-sync-mode-card.active .zt-sync-mode-icon{background:#6366f1;background:var(--color-primary,#6366f1);color:#fff}.zt-sync-mode-info{flex:1 1}.zt-sync-mode-info strong{color:#e2e8f0;color:var(--color-text,#e2e8f0);display:block;font-size:.9rem;margin-bottom:4px}.zt-sync-mode-info p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;line-height:1.4;margin:0}.zt-sync-mode-check{color:#6366f1;color:var(--color-primary,#6366f1);flex-shrink:0;margin-top:4px}.zt-sync-diff{display:flex;flex-direction:column;gap:6px}.zt-sync-diff-item{align-items:center;border-radius:6px;display:flex;font-size:.85rem;gap:8px;padding:8px 12px}.zt-sync-diff--add{background:#10b98114;color:#10b981}.zt-sync-diff--remove{background:#ef444414;color:#f87171}.zt-sync-diff-icon{font-size:1rem;font-weight:700;text-align:center;width:20px}.zt-sync-no-changes{align-items:center;background:#10b98114;border-radius:8px;color:#10b981;display:flex;font-size:.85rem;gap:8px;padding:12px 16px}.zt-sync-actions{padding:20px 24px}.zt-sync-publish-btn{align-items:center;background:#6366f1;background:var(--color-primary,#6366f1);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .15s;width:100%}.zt-sync-publish-btn:hover{background:#4f46e5}.zt-sync-publish-btn:disabled{cursor:not-allowed;opacity:.4}.zt-sync-footer{padding:16px 24px}.zt-sync-footer p{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.75rem;line-height:1.5;margin:0}.ll-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow:hidden;transition:all var(--transition-normal)}.ll-expanded{display:flex;flex-direction:column;max-height:500px;min-height:300px}.ll-collapsed{max-height:48px}.ll-header{align-items:center;background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);cursor:pointer;display:flex;justify-content:space-between;padding:var(--space-3) var(--space-4);-webkit-user-select:none;user-select:none}.ll-header:hover{background:color-mix(in srgb,var(--color-primary) 5%,var(--color-surface-hover))}.ll-header-left{align-items:center;display:flex;gap:var(--space-2)}.ll-title{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold)}.ll-connection{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:4px;padding:2px 8px}.ll-connection.connected{background:color-mix(in srgb,var(--color-success) 12%,#0000);color:var(--color-success-dark)}.ll-connection.disconnected{background:color-mix(in srgb,var(--color-error) 12%,#0000);color:var(--color-error)}.ll-error-badge{background:color-mix(in srgb,var(--color-warning) 12%,#0000);border-radius:var(--radius-full);color:var(--color-warning-dark);font-size:var(--text-xs);padding:2px 8px}.ll-header-right{align-items:center;display:flex;gap:var(--space-2)}.ll-count{font-size:var(--text-xs)}.ll-chevron,.ll-count{color:var(--color-text-muted)}.ll-chevron{transition:transform var(--transition-fast)}.ll-chevron.rotated{transform:rotate(180deg)}.ll-toolbar{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:var(--space-2);justify-content:space-between;padding:var(--space-2) var(--space-3)}.ll-filters,.ll-toolbar{align-items:center;display:flex}.ll-filters{gap:var(--space-1)}.ll-filter-btn,.ll-filters{color:var(--color-text-muted)}.ll-filter-btn{align-items:center;background:#0000;border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:4px;padding:3px 8px;transition:all var(--transition-fast)}.ll-filter-btn:hover{background:var(--color-surface-hover);border-color:var(--color-border)}.ll-filter-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.ll-filter-count{background:color-mix(in srgb,currentColor 15%,#0000);border-radius:var(--radius-sm);font-size:10px;padding:0 4px}.ll-filter-debug{color:var(--gray-500)}.ll-filter-info{color:var(--color-primary)}.ll-filter-warn{color:var(--color-warning-dark)}.ll-filter-error{color:var(--color-error)}.ll-filter-debug.active{background:var(--gray-500);color:#fff}.ll-filter-info.active{background:var(--color-primary);color:#fff}.ll-filter-warn.active{background:var(--color-warning);color:#fff}.ll-filter-error.active{background:var(--color-error);color:#fff}.ll-actions{align-items:center;display:flex;gap:var(--space-2)}.ll-action-btn{align-items:center;background:#0000;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:4px;padding:var(--space-1) var(--space-2);transition:all var(--transition-fast)}.ll-action-btn:hover{background:var(--color-surface-hover);color:var(--color-text)}.ll-jump-btn{animation:pulse 2s infinite;background:color-mix(in srgb,var(--color-primary) 10%,#0000);border-color:var(--color-primary);color:var(--color-primary)}.ll-list{background:color-mix(in srgb,#000 5%,var(--color-surface));flex:1 1;font-family:var(--font-mono);font-size:11px;line-height:1.5;overflow-y:auto;padding:var(--space-2);scrollbar-width:thin}.ll-list::-webkit-scrollbar{width:6px}.ll-list::-webkit-scrollbar-track{background:#0000}.ll-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-full)}.ll-empty{align-items:center;color:var(--color-text-subtle);display:flex;flex-direction:column;gap:var(--space-3);justify-content:center;padding:var(--space-10);text-align:center}.ll-entry{border-left:2px solid #0000;border-radius:var(--radius-md);cursor:pointer;margin-bottom:2px;padding:var(--space-1) var(--space-2);transition:background var(--transition-fast)}.ll-entry.selected,.ll-entry:hover{background:var(--color-surface-hover)}.ll-entry-main{align-items:flex-start;display:flex;gap:var(--space-2)}.ll-level-icon{flex-shrink:0;margin-top:2px}.ll-timestamp{color:var(--color-text-subtle);flex-shrink:0;opacity:.7}.ll-context{background:var(--color-surface-hover);border-radius:var(--radius-sm);color:var(--color-text-muted);flex-shrink:0;font-size:10px;padding:0 4px}.ll-message{color:var(--color-text);flex:1 1;word-break:break-word}.ll-entry.log-debug{border-left-color:var(--gray-400);color:var(--gray-500)}.ll-entry.log-debug .ll-level-icon{color:var(--gray-400)}.ll-entry.log-debug .ll-message{color:var(--gray-500)}.ll-entry.log-info{border-left-color:var(--color-primary)}.ll-entry.log-info .ll-level-icon{color:var(--color-primary)}.ll-entry.log-warn{background:color-mix(in srgb,var(--color-warning) 5%,#0000);border-left-color:var(--color-warning)}.ll-entry.log-warn .ll-level-icon,.ll-entry.log-warn .ll-message{color:var(--color-warning-dark)}.ll-entry.log-error{background:color-mix(in srgb,var(--color-error) 5%,#0000);border-left-color:var(--color-error)}.ll-entry.log-error .ll-level-icon,.ll-entry.log-error .ll-message{color:var(--color-error)}.ll-entry-details{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);margin-top:var(--space-2);overflow-x:auto;padding:var(--space-2)}.ll-entry-details pre{color:var(--color-text-muted);font-size:10px;margin:0;white-space:pre-wrap;word-break:break-word}@media (max-width:600px){.ll-toolbar{align-items:flex-start;flex-direction:column}.ll-entry-main,.ll-filters{flex-wrap:wrap}.ll-timestamp{width:100%}}.ls-container{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;gap:var(--space-4);padding:var(--space-2) var(--space-4)}.ls-connection{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:4px;padding:var(--space-1) var(--space-2)}.ls-connection.connected{background:color-mix(in srgb,var(--color-success) 12%,#0000);color:var(--color-success-dark)}.ls-connection.disconnected{background:color-mix(in srgb,var(--color-error) 12%,#0000);color:var(--color-error)}.ls-stat{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:var(--space-1);padding:var(--space-1) var(--space-2)}.ls-stat.has-errors{background:color-mix(in srgb,var(--color-error) 8%,var(--color-surface));border-color:color-mix(in srgb,var(--color-error) 25%,#0000)}.ls-icon{flex-shrink:0}.ls-icon-primary{color:var(--color-primary)}.ls-icon-accent{color:var(--color-accent)}.ls-icon-error{color:var(--color-error)}.ls-value{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-bold)}.ls-label{color:var(--color-text-muted);font-size:var(--text-xs);white-space:nowrap}.ls-operations{align-items:center;display:flex;gap:var(--space-1);margin-left:auto}.ls-operation-badge{background:color-mix(in srgb,var(--color-primary) 10%,#0000);border-radius:var(--radius-full);color:var(--color-primary);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;padding:2px 8px;text-transform:uppercase}.ls-last-error{align-items:center;background:color-mix(in srgb,var(--color-error) 6%,#0000);border:1px solid color-mix(in srgb,var(--color-error) 20%,#0000);border-radius:var(--radius-md);color:var(--color-error);display:flex;font-size:var(--text-xs);gap:var(--space-2);margin-top:var(--space-1);padding:var(--space-2);width:100%}.ls-error-message{flex:1 1;font-family:var(--font-mono);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ls-error-time{align-items:center;color:var(--color-text-muted);display:flex;gap:4px;white-space:nowrap}@media (max-width:767px){.ls-container{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.ls-operations{flex-wrap:wrap;margin-left:0;width:100%}}@media (max-width:480px){.ls-stat{justify-content:space-between;width:100%}}.smp-container{background:#1a1a1a;background:var(--surface-1,#1a1a1a);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:12px;border-radius:var(--radius-lg,12px);overflow:hidden}.smp-container.smp-empty{align-items:center;color:#888;color:var(--text-muted,#888);display:flex;flex-direction:column;gap:.5rem;gap:var(--space-2,.5rem);padding:1.5rem;padding:var(--space-6,1.5rem);text-align:center}.smp-header{align-items:center;background:#252525;background:var(--surface-2,#252525);cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);-webkit-user-select:none;user-select:none}.smp-header:hover{background:#2a2a2a;background:var(--surface-3,#2a2a2a)}.smp-header-left{align-items:center;color:#fff;color:var(--text-primary,#fff);display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.smp-title{font-size:.875rem;font-weight:600}.smp-overall-badge{border-radius:999px;border-radius:var(--radius-full,999px);font-size:.7rem;font-weight:600;padding:2px 8px}.smp-overall-badge.badge-success{background:#22c55e33;color:#22c55e;color:var(--success,#22c55e)}.smp-overall-badge.badge-warning{background:#eab30833;color:#eab308;color:var(--warning,#eab308)}.smp-overall-badge.badge-danger{background:#ef444433;color:#ef4444;color:var(--danger,#ef4444)}.smp-header-right{align-items:center;display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.smp-refresh-btn{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#888;color:var(--text-muted,#888);cursor:pointer;display:flex;padding:.25rem;padding:var(--space-1,.25rem)}.smp-refresh-btn:hover{background:#333;background:var(--surface-3,#333);color:#fff;color:var(--text-primary,#fff)}.smp-chevron{color:#888;color:var(--text-muted,#888);transition:transform .2s ease}.smp-chevron.rotated{transform:rotate(180deg)}.smp-spin{animation:smp-spin 1s linear infinite}@keyframes smp-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.smp-body{gap:1rem;gap:var(--space-4,1rem);padding:1rem;padding:var(--space-4,1rem)}.smp-body,.smp-section{display:flex;flex-direction:column}.smp-section{gap:.75rem;gap:var(--space-3,.75rem)}.smp-section-title{color:#888;color:var(--text-muted,#888);font-size:.75rem;font-weight:600;letter-spacing:.05em;margin:0;text-transform:uppercase}.smp-stats-grid{grid-gap:.5rem;grid-gap:var(--space-2,.5rem);display:grid;gap:.5rem;gap:var(--space-2,.5rem);grid-template-columns:repeat(4,1fr)}@media (max-width:600px){.smp-stats-grid{grid-template-columns:repeat(2,1fr)}}.smp-mini-stat{align-items:center;background:#252525;background:var(--surface-2,#252525);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;gap:.5rem;gap:var(--space-2,.5rem);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem)}.smp-mini-icon{flex-shrink:0}.smp-stat-success .smp-mini-icon{color:#22c55e;color:var(--success,#22c55e)}.smp-stat-danger .smp-mini-icon{color:#ef4444;color:var(--danger,#ef4444)}.smp-stat-primary .smp-mini-icon{color:#3b82f6;color:var(--primary,#3b82f6)}.smp-stat-accent .smp-mini-icon{color:#8b5cf6;color:var(--accent,#8b5cf6)}.smp-mini-body{display:flex;flex-direction:column}.smp-mini-value{color:#fff;color:var(--text-primary,#fff);font-size:1rem;font-weight:700;line-height:1.2}.smp-mini-label{color:#888;color:var(--text-muted,#888);font-size:.65rem}.smp-rates{gap:.5rem;gap:var(--space-2,.5rem)}.smp-rate-bar,.smp-rates{display:flex;flex-direction:column}.smp-rate-bar{gap:4px}.smp-rate-header{align-items:center;display:flex;justify-content:space-between}.smp-rate-label{color:#888;color:var(--text-muted,#888);font-size:.7rem}.smp-rate-value{font-size:.75rem;font-weight:600}.smp-rate-value.rate-success{color:#22c55e;color:var(--success,#22c55e)}.smp-rate-value.rate-warning{color:#eab308;color:var(--warning,#eab308)}.smp-rate-value.rate-danger{color:#ef4444;color:var(--danger,#ef4444)}.smp-rate-track{background:#333;background:var(--surface-3,#333);height:6px;overflow:hidden}.smp-rate-fill,.smp-rate-track{border-radius:999px;border-radius:var(--radius-full,999px)}.smp-rate-fill{height:100%;transition:width .3s ease}.smp-rate-fill.rate-success{background:#22c55e;background:var(--success,#22c55e)}.smp-rate-fill.rate-warning{background:#eab308;background:var(--warning,#eab308)}.smp-rate-fill.rate-danger{background:#ef4444;background:var(--danger,#ef4444)}.smp-avg-stat{align-items:center;color:#888;color:var(--text-muted,#888);display:flex;font-size:.75rem;gap:.5rem;gap:var(--space-2,.5rem)}.smp-avg-stat strong{color:#fff;color:var(--text-primary,#fff)}.smp-latest{background:#252525;background:var(--surface-2,#252525);border:1px solid #333;border:1px solid var(--border-color,#333);border-radius:8px;border-radius:var(--radius-md,8px);padding:.75rem;padding:var(--space-3,.75rem)}.smp-latest-header{justify-content:space-between;margin-bottom:.75rem;margin-bottom:var(--space-3,.75rem)}.smp-latest-header,.smp-status{align-items:center;display:flex}.smp-status{border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.7rem;font-weight:600;gap:4px;padding:2px 8px;text-transform:uppercase}.smp-status-success{background:#22c55e33;color:#22c55e;color:var(--success,#22c55e)}.smp-status-error,.smp-status-failed{background:#ef444433;color:#ef4444;color:var(--danger,#ef4444)}.smp-latest-time{color:#888;color:var(--text-muted,#888);font-size:.7rem}.smp-latest-stats{display:flex;flex-direction:column;gap:.25rem;gap:var(--space-1,.25rem)}.smp-stat-row{align-items:center;border-bottom:1px solid #333;border-bottom:1px solid var(--border-color,#333);display:flex;justify-content:space-between;padding:.25rem 0;padding:var(--space-1,.25rem) 0}.smp-stat-row:last-child{border-bottom:none}.smp-stat-key{color:#888;color:var(--text-muted,#888);font-size:.75rem}.smp-stat-val{color:#fff;color:var(--text-primary,#fff);font-size:.8rem;font-weight:600}.smp-val-money{color:#22c55e;color:var(--success,#22c55e)}.smp-criteria{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--space-1,.25rem);margin-top:.5rem;margin-top:var(--space-2,.5rem)}.smp-criteria-chip{background:#333;background:var(--surface-3,#333);border-radius:4px;border-radius:var(--radius-sm,4px);color:#888;color:var(--text-muted,#888);font-size:.65rem;padding:2px 6px}.smp-health-badge{align-items:center;border-radius:999px;border-radius:var(--radius-full,999px);display:inline-flex;font-size:.65rem;font-weight:600;gap:4px;padding:2px 8px}.health-success{background:#22c55e33;color:#22c55e;color:var(--success,#22c55e)}.health-warning{background:#eab30833;color:#eab308;color:var(--warning,#eab308)}.health-danger{background:#ef444433;color:#ef4444;color:var(--danger,#ef4444)}.smp-history-list{display:flex;flex-direction:column;gap:.25rem;gap:var(--space-1,.25rem)}.smp-history-item{align-items:center;background:#252525;background:var(--surface-2,#252525);border-radius:8px;border-radius:var(--radius-md,8px);cursor:pointer;display:flex;gap:.5rem;gap:var(--space-2,.5rem);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);transition:background .15s ease}.smp-history-item:hover{background:#2a2a2a;background:var(--surface-3,#2a2a2a)}.smp-history-item.selected{background:#333;background:var(--surface-3,#333);border:1px solid #3b82f6;border:1px solid var(--primary,#3b82f6)}.smp-hist-status{align-items:center;display:flex}.smp-hist-status.smp-status-success{color:#22c55e;color:var(--success,#22c55e)}.smp-hist-status.smp-status-error,.smp-hist-status.smp-status-failed{color:#ef4444;color:var(--danger,#ef4444)}.smp-hist-count{color:#fff;color:var(--text-primary,#fff);font-size:.8rem;font-weight:600;min-width:40px}.smp-hist-time{flex:1 1;font-size:.7rem}.smp-hist-dept,.smp-hist-time{color:#888;color:var(--text-muted,#888)}.smp-hist-dept{background:#333;background:var(--surface-3,#333);border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.65rem;padding:2px 6px}.asp-container{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:2px solid #333;border:2px solid var(--color-border,#333);border-radius:12px;border-radius:var(--radius-lg,12px);overflow:hidden;transition:border-color .3s ease}.asp-container.asp-active{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);box-shadow:0 0 20px #3b82f626}.asp-container.asp-success{border-color:#22c55e;border-color:var(--color-success,#22c55e)}.asp-container.asp-error{border-color:#ef4444;border-color:var(--color-error,#ef4444)}.asp-header{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);-webkit-user-select:none;user-select:none}.asp-header:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a)}.asp-header-left{align-items:center;display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.asp-spin{animation:aspSpin 1s linear infinite;color:#3b82f6;color:var(--color-primary,#3b82f6)}@keyframes aspSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.asp-icon-success{color:#22c55e;color:var(--color-success,#22c55e)}.asp-icon-error{color:#ef4444;color:var(--color-error,#ef4444)}.asp-title{color:#fff;color:var(--color-text,#fff);font-size:.875rem;font-weight:600}.asp-params{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border-radius:4px;border-radius:var(--radius-sm,4px);color:#888;color:var(--color-text-muted,#888);font-size:.75rem;padding:2px 8px}.asp-header-right{gap:.75rem;gap:var(--space-3,.75rem)}.asp-header-right,.asp-timer{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex}.asp-timer{font-family:monospace;font-family:var(--font-mono,monospace);font-size:.75rem;gap:4px}.asp-body{flex-direction:column;padding:1rem;padding:var(--space-4,1rem)}.asp-body,.asp-stats{display:flex;gap:1rem;gap:var(--space-4,1rem)}.asp-stats{flex-wrap:wrap}.asp-stat{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.asp-stat svg{color:#3b82f6;color:var(--color-primary,#3b82f6)}.asp-stat-value{color:#fff;color:var(--color-text,#fff);font-size:1.25rem;font-weight:700}.asp-stat-label{font-size:.75rem}.asp-stat-stage{flex:1 1;justify-content:flex-end}.asp-stat-stage .asp-stat-value{font-size:.875rem;font-weight:500}.asp-progress{width:100%}.asp-progress-bar{background:#333;background:var(--color-surface-raised,#333);height:6px;overflow:hidden}.asp-progress-bar,.asp-progress-fill{border-radius:999px;border-radius:var(--radius-full,999px)}.asp-progress-fill{background:#3b82f6;background:var(--color-primary,#3b82f6);height:100%;transition:width .3s ease}.asp-progress-indeterminate{animation:aspIndeterminate 1.5s ease-in-out infinite;width:30%}@keyframes aspIndeterminate{0%{transform:translateX(-100%)}to{transform:translateX(400%)}}.asp-result{align-items:center;border-radius:8px;border-radius:var(--radius-md,8px);display:flex;font-size:.875rem;gap:.5rem;gap:var(--space-2,.5rem);padding:.75rem;padding:var(--space-3,.75rem)}.asp-result-success{background:#22c55e26;color:#22c55e;color:var(--color-success,#22c55e)}.asp-result-error{background:#ef444426;color:#ef4444;color:var(--color-error,#ef4444)}.asp-logs{background:#252525;background:var(--color-surface-raised,#252525);border-radius:8px;border-radius:var(--radius-md,8px);overflow:hidden}.asp-logs-header{align-items:center;background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#888;color:var(--color-text-muted,#888);display:flex;font-size:.7rem;font-weight:600;justify-content:space-between;letter-spacing:.05em;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);text-transform:uppercase}.asp-logs-count{font-weight:400}.asp-logs-list{font-family:monospace;font-family:var(--font-mono,monospace);font-size:.7rem;max-height:200px;overflow-y:auto}.asp-log-entry{border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);display:flex;gap:.5rem;gap:var(--space-2,.5rem);padding:.25rem .75rem;padding:var(--space-1,.25rem) var(--space-3,.75rem)}.asp-log-entry:last-child{border-bottom:none}.asp-log-time{color:#666;color:var(--color-text-subtle,#666);flex-shrink:0}.asp-log-message{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.asp-log-info .asp-log-message,.asp-log-message{color:#888;color:var(--color-text-muted,#888)}.asp-log-warn .asp-log-message{color:#eab308;color:var(--color-warning,#eab308)}.asp-log-error .asp-log-message{color:#ef4444;color:var(--color-error,#ef4444)}.asp-log-debug .asp-log-message{color:#666;color:var(--color-text-subtle,#666)}.asp-actions{display:flex;justify-content:flex-end}.asp-cancel-btn{align-items:center;background:#0000;border:1px solid #ef4444;border:1px solid var(--color-error,#ef4444);border-radius:8px;border-radius:var(--radius-md,8px);color:#ef4444;color:var(--color-error,#ef4444);cursor:pointer;display:flex;font-size:.75rem;gap:.25rem;gap:var(--space-1,.25rem);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);transition:all .15s ease}.asp-cancel-btn:hover{background:#ef444426}@media (max-width:600px){.asp-stats{flex-direction:column;gap:.5rem;gap:var(--space-2,.5rem)}.asp-stat-stage{justify-content:flex-start}.asp-header{flex-wrap:wrap;gap:.5rem;gap:var(--space-2,.5rem)}.asp-params{order:3;width:100%}}.shc-card{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;border-radius:var(--radius-lg,12px);overflow:hidden;transition:all .2s ease}.shc-card:hover{border-color:#444;border-color:var(--color-border-hover,#444)}.shc-card.shc-expanded{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6)}.shc-card.shc-success .shc-status{border-left:3px solid #22c55e;border-left:3px solid var(--color-success,#22c55e)}.shc-card.shc-error .shc-status{border-left:3px solid #ef4444;border-left:3px solid var(--color-error,#ef4444)}.shc-header{align-items:center;cursor:pointer;display:flex;gap:.75rem;gap:var(--space-3,.75rem);padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);-webkit-user-select:none;user-select:none}.shc-header:hover{background:#252525;background:var(--color-surface-hover,#252525)}.shc-status{align-items:center;display:flex;padding-left:.5rem;padding-left:var(--space-2,.5rem)}.shc-icon-success{color:#22c55e;color:var(--color-success,#22c55e)}.shc-icon-error{color:#ef4444;color:var(--color-error,#ef4444)}.shc-main{flex:1 1;min-width:0}.shc-top-row{align-items:center;display:flex;gap:.5rem;gap:var(--space-2,.5rem);margin-bottom:4px}.shc-time{color:#fff;color:var(--color-text,#fff);font-size:.8rem;font-weight:600}.shc-dept{background:#3b82f6;background:var(--color-primary,#3b82f6);color:#fff;font-weight:500}.shc-acq,.shc-dept{border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.7rem;padding:2px 8px}.shc-acq{background:#333;background:var(--color-surface-raised,#333);color:#888;color:var(--color-text-muted,#888)}.shc-bottom-row{align-items:center;display:flex;flex-wrap:wrap;gap:.75rem;gap:var(--space-3,.75rem)}.shc-count,.shc-duration,.shc-value{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;font-size:.75rem;gap:4px}.shc-count strong{color:#fff;color:var(--color-text,#fff);font-size:.875rem}.shc-value{color:#22c55e;color:var(--color-success,#22c55e);font-weight:500}.shc-save-rate{background:#eab30833;border-radius:999px;border-radius:var(--radius-full,999px);color:#eab308;color:var(--color-warning,#eab308);font-size:.65rem;padding:1px 6px}.shc-expand{color:#888;color:var(--color-text-muted,#888);transition:transform .2s ease}.shc-expanded .shc-expand{color:#3b82f6;color:var(--color-primary,#3b82f6)}.shc-body{animation:shcSlideDown .2s ease;border-top:1px solid #333;border-top:1px solid var(--color-border,#333);display:flex;flex-direction:column;gap:1rem;gap:var(--space-4,1rem);padding:1rem;padding:var(--space-4,1rem)}@keyframes shcSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.shc-details{grid-gap:.5rem;grid-gap:var(--space-2,.5rem);display:grid;gap:.5rem;gap:var(--space-2,.5rem);grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.shc-detail-row{background:#252525;background:var(--color-surface-raised,#252525);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;flex-direction:column;gap:2px;padding:.5rem;padding:var(--space-2,.5rem)}.shc-detail-label{align-items:center;color:#666;color:var(--color-text-subtle,#666);display:flex;font-size:.65rem;gap:4px;letter-spacing:.03em;text-transform:uppercase}.shc-detail-value{color:#fff;color:var(--color-text,#fff);font-size:.8rem;font-weight:500}.shc-suppliers{background:#252525;background:var(--color-surface-raised,#252525);border-radius:8px;border-radius:var(--radius-md,8px);overflow:hidden}.shc-empty,.shc-error-msg,.shc-loading{color:#888;color:var(--color-text-muted,#888);font-size:.8rem;padding:1rem;padding:var(--space-4,1rem);text-align:center}.shc-error-msg{color:#ef4444;color:var(--color-error,#ef4444)}.shc-table-wrap{overflow-x:auto}.shc-table{border-collapse:collapse;font-size:.75rem;width:100%}.shc-table th{background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#666;color:var(--color-text-subtle,#666);font-size:.65rem;font-weight:600;letter-spacing:.03em;text-align:left;text-transform:uppercase}.shc-table td,.shc-table th{border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem)}.shc-table td{color:#888;color:var(--color-text-muted,#888)}.shc-table tr:last-child td{border-bottom:none}.shc-table tr:hover td{background:#ffffff05}.shc-supplier-name{color:#fff;color:var(--color-text,#fff);font-weight:500;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shc-doc-num{color:#666;color:var(--color-text-subtle,#666);font-family:monospace;font-family:var(--font-mono,monospace);font-size:.65rem}.shc-amount{color:#22c55e!important;color:var(--color-success,#22c55e)!important;font-weight:600;white-space:nowrap}.shc-type-badge{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.65rem;padding:2px 6px;white-space:nowrap}.shc-more{border-top:1px solid #333;border-top:1px solid var(--color-border,#333);color:#666;color:var(--color-text-subtle,#666);font-size:.7rem;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);text-align:center}.shc-table tr.shc-clickable{cursor:pointer;transition:background .15s ease}.shc-table tr.shc-clickable:hover td{background:#3b82f614}.shc-view-cell{text-align:center;width:32px}.shc-view-icon{color:#666;color:var(--color-text-subtle,#666);transition:color .15s ease}.shc-table tr.shc-clickable:hover .shc-view-icon{color:#3b82f6;color:var(--color-primary,#3b82f6)}.shc-suppliers-header{align-items:center;background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#888;color:var(--color-text-muted,#888);display:flex;font-size:.7rem;font-weight:600;justify-content:space-between;letter-spacing:.03em;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);text-transform:uppercase}.shc-hint{color:#666;color:var(--color-text-subtle,#666);font-size:.65rem;font-weight:400;letter-spacing:0;text-transform:none}.shc-detail-badge{align-items:center;border-radius:999px;display:inline-flex;font-size:.65rem;font-weight:500;gap:4px;padding:2px 8px}.shc-detail-complete{background:#22c55e26;color:#22c55e}.shc-detail-pending,.shc-detail-processing,.shc-detail-queued{background:#eab30826;color:#eab308}.shc-detail-failed{background:#ef444426;color:#ef4444}.shc-detail-not_queued{color:#666}@media (max-width:767px){.shc-table th{display:none}.shc-table td{border-bottom:none;display:block;padding:.25rem .75rem;padding:var(--space-1,.25rem) var(--space-3,.75rem)}.shc-table td:before{color:#666;color:var(--color-text-subtle,#666);content:attr(data-label);display:block;font-size:.6rem;font-weight:600;margin-bottom:2px;text-transform:uppercase}.shc-table tr{border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);display:block;padding:.5rem 0;padding:var(--space-2,.5rem) 0}.shc-table tr:last-child{border-bottom:none}.shc-supplier-name{max-width:100%}.shc-top-row{flex-wrap:wrap}.shc-bottom-row{align-items:flex-start;flex-direction:column}}@media (max-width:480px){.shc-details{grid-template-columns:1fr 1fr}}.ssp-container{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;border-radius:var(--radius-lg,12px);overflow:hidden}.ssp-header{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);-webkit-user-select:none;user-select:none}.ssp-header:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a)}.ssp-header-left{align-items:center;color:#fff;color:var(--color-text,#fff);display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.ssp-title{font-size:.875rem;font-weight:600}.ssp-count{background:#22c55e;background:var(--color-success,#22c55e);border-radius:999px;border-radius:var(--radius-full,999px);color:#fff;font-size:.7rem;font-weight:500;padding:2px 8px}.ssp-header-right{color:#888;color:var(--color-text-muted,#888);gap:.5rem;gap:var(--space-2,.5rem)}.ssp-add-btn,.ssp-header-right{align-items:center;display:flex}.ssp-add-btn{background:#3b82f6;background:var(--color-primary,#3b82f6);border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#fff;cursor:pointer;font-size:.7rem;font-weight:500;gap:4px;padding:.25rem .5rem;padding:var(--space-1,.25rem) var(--space-2,.5rem);transition:background .15s ease}.ssp-add-btn:hover{background:#2563eb;background:var(--color-primary-dark,#2563eb)}.ssp-body,.ssp-form{padding:1rem;padding:var(--space-4,1rem)}.ssp-form{background:#252525;background:var(--color-surface-raised,#252525);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px)}.ssp-form,.ssp-form-header{margin-bottom:1rem;margin-bottom:var(--space-4,1rem)}.ssp-form-header{align-items:center;color:#fff;color:var(--color-text,#fff);display:flex;font-size:.875rem;font-weight:600;justify-content:space-between}.ssp-form-close{background:none;border:none;color:#888;color:var(--color-text-muted,#888);cursor:pointer;font-size:1.25rem;line-height:1}.ssp-form-close:hover{color:#fff;color:var(--color-text,#fff)}.ssp-form-grid{grid-gap:.75rem;grid-gap:var(--space-3,.75rem);display:grid;gap:.75rem;gap:var(--space-3,.75rem);grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:1rem;margin-bottom:var(--space-4,1rem)}.ssp-form-group{display:flex;flex-direction:column;gap:.25rem;gap:var(--space-1,.25rem)}.ssp-form-group label{color:#888;color:var(--color-text-muted,#888);font-size:.7rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.ssp-form-group input,.ssp-form-group select{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);color:#fff;color:var(--color-text,#fff);font-size:.8rem;padding:.5rem;padding:var(--space-2,.5rem)}.ssp-form-group input:focus,.ssp-form-group select:focus{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);outline:none}.ssp-form-actions{display:flex;gap:.5rem;gap:var(--space-2,.5rem);justify-content:flex-end}.ssp-btn-cancel,.ssp-btn-save{border-radius:8px;border-radius:var(--radius-md,8px);cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem 1rem;padding:var(--space-2,.5rem) var(--space-4,1rem);transition:all .15s ease}.ssp-btn-cancel{background:#0000;border:1px solid #333;border:1px solid var(--color-border,#333);color:#888;color:var(--color-text-muted,#888)}.ssp-btn-cancel:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a)}.ssp-btn-save{background:#3b82f6;background:var(--color-primary,#3b82f6);border:none;color:#fff}.ssp-btn-save:hover{background:#2563eb;background:var(--color-primary-dark,#2563eb)}.ssp-btn-save:disabled{cursor:not-allowed;opacity:.5}.ssp-error{background:#ef444426;border-radius:8px;border-radius:var(--radius-md,8px);color:#ef4444;color:var(--color-error,#ef4444);margin-bottom:.75rem;margin-bottom:var(--space-3,.75rem);padding:.75rem;padding:var(--space-3,.75rem)}.ssp-error,.ssp-loading{align-items:center;display:flex;font-size:.8rem;gap:.5rem;gap:var(--space-2,.5rem)}.ssp-loading{color:#888;color:var(--color-text-muted,#888);justify-content:center;padding:1rem;padding:var(--space-4,1rem)}.ssp-spin{animation:sspSpin 1s linear infinite}@keyframes sspSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.ssp-empty{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;flex-direction:column;gap:.75rem;gap:var(--space-3,.75rem);padding:1.5rem;padding:var(--space-6,1.5rem);text-align:center}.ssp-empty p{font-size:.875rem;margin:0}.ssp-btn-add{align-items:center;background:#3b82f6;background:var(--color-primary,#3b82f6);border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#fff;cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:.25rem;gap:var(--space-1,.25rem);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem)}.ssp-btn-add:hover{background:#2563eb;background:var(--color-primary-dark,#2563eb)}.ssp-list{display:flex;flex-direction:column;gap:.5rem;gap:var(--space-2,.5rem)}.ssp-item{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);border-radius:8px;border-radius:var(--radius-md,8px);display:flex;gap:.75rem;gap:var(--space-3,.75rem);padding:.75rem;padding:var(--space-3,.75rem);transition:all .15s ease}.ssp-item:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a)}.ssp-item.ssp-disabled{opacity:.5}.ssp-item-status{flex-shrink:0}.ssp-icon-on{color:#22c55e;color:var(--color-success,#22c55e)}.ssp-icon-off{color:#666;color:var(--color-text-subtle,#666)}.ssp-item-main{flex:1 1;min-width:0}.ssp-item-name{color:#fff;color:var(--color-text,#fff);font-size:.875rem;font-weight:600;margin-bottom:2px}.ssp-item-meta{display:flex;flex-wrap:wrap;gap:.25rem;gap:var(--space-1,.25rem)}.ssp-item-cron{background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#888;color:var(--color-text-muted,#888);font-family:monospace;font-family:var(--font-mono,monospace)}.ssp-item-acq,.ssp-item-cron,.ssp-item-dept{border-radius:4px;border-radius:var(--radius-sm,4px);font-size:.65rem;padding:2px 6px}.ssp-item-acq,.ssp-item-dept{background:#3b82f633;color:#3b82f6;color:var(--color-primary,#3b82f6)}.ssp-item-last{align-items:center;color:#666;color:var(--color-text-subtle,#666);display:flex;font-size:.7rem;gap:4px;margin-top:.25rem;margin-top:var(--space-1,.25rem)}.ssp-item-last svg{height:10px;width:10px}.ssp-item-next{align-items:flex-end;display:flex;flex-direction:column;gap:2px}.ssp-next-label{color:#666;color:var(--color-text-subtle,#666);font-size:.6rem;text-transform:uppercase}.ssp-next-time{color:#888;color:var(--color-text-muted,#888);font-size:.75rem;font-weight:500}.ssp-item-actions{display:flex;gap:.25rem;gap:var(--space-1,.25rem)}.ssp-action-btn{background:#0000;border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);color:#888;color:var(--color-text-muted,#888);cursor:pointer;padding:.25rem;padding:var(--space-1,.25rem);transition:all .15s ease}.ssp-action-btn:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a);color:#fff;color:var(--color-text,#fff)}.ssp-action-btn.ssp-action-delete:hover{background:#ef444426;border-color:#ef4444;border-color:var(--color-error,#ef4444);color:#ef4444;color:var(--color-error,#ef4444)}@media (max-width:600px){.ssp-item{flex-wrap:wrap}.ssp-item-next{border-top:1px solid #333;border-top:1px solid var(--color-border,#333);flex-direction:row;justify-content:space-between;margin-top:.5rem;margin-top:var(--space-2,.5rem);padding-top:.5rem;padding-top:var(--space-2,.5rem);width:100%}.ssp-form-grid{grid-template-columns:1fr}}.ads-container{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;border-radius:var(--radius-lg,12px);transition:all .2s ease}.ads-container.ads-expanded{border-color:#444;border-color:var(--color-border-hover,#444)}.ads-header{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);cursor:pointer;display:flex;justify-content:space-between;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem);transition:background .15s ease;-webkit-user-select:none;user-select:none}.ads-header:hover{background:#2a2a2a;background:var(--color-surface-hover,#2a2a2a)}.ads-header-left{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;gap:.5rem;gap:var(--space-2,.5rem)}.ads-expanded .ads-header-left{color:#fff;color:var(--color-text,#fff)}.ads-icon{color:#666;color:var(--color-text-subtle,#666)}.ads-expanded .ads-icon{color:#3b82f6;color:var(--color-primary,#3b82f6)}.ads-title{font-size:.875rem;font-weight:600}.ads-badge{background:#3b82f6;background:var(--color-primary,#3b82f6);border-radius:999px;border-radius:var(--radius-full,999px);color:#fff;font-size:.65rem;font-weight:500;padding:2px 8px}.ads-description{color:#666;color:var(--color-text-subtle,#666);font-size:.75rem;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ads-content{animation:adsSlideDown .2s ease;border-top:1px solid #333;border-top:1px solid var(--color-border,#333);padding:1rem;padding:var(--space-4,1rem)}@keyframes adsSlideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:600px){.ads-header{align-items:flex-start;flex-direction:column;gap:.5rem;gap:var(--space-2,.5rem)}.ads-description{max-width:100%}}.sdm-overlay{align-items:center;animation:sdmFadeIn .15s ease;background:#000000b3;display:flex;inset:0;justify-content:center;padding:1rem;padding:var(--space-4,1rem);position:fixed;z-index:1000}@keyframes sdmFadeIn{0%{opacity:0}to{opacity:1}}.sdm-modal{animation:sdmSlideUp .2s ease;background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;border-radius:var(--radius-lg,12px);display:flex;flex-direction:column;max-height:90vh;max-width:900px;overflow:hidden;width:100%}@keyframes sdmSlideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.sdm-header{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);display:flex;justify-content:space-between;padding:1rem;padding:var(--space-4,1rem)}.sdm-title h2{color:#fff;color:var(--color-text,#fff);font-size:1rem;font-weight:600;margin:0}.sdm-doc-id{font-family:monospace;font-family:var(--font-mono,monospace);font-size:.75rem}.sdm-close,.sdm-doc-id{color:#888;color:var(--color-text-muted,#888)}.sdm-close{background:none;border:none;border-radius:8px;border-radius:var(--radius-md,8px);cursor:pointer;padding:.5rem;padding:var(--space-2,.5rem);transition:all .15s ease}.sdm-close:hover{background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#fff;color:var(--color-text,#fff)}.sdm-tabs{background:#252525;background:var(--color-surface-raised,#252525);border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);padding:.5rem 1rem;padding:var(--space-2,.5rem) var(--space-4,1rem)}.sdm-tab,.sdm-tabs{display:flex;gap:.25rem;gap:var(--space-1,.25rem)}.sdm-tab{align-items:center;background:none;border:none;border-radius:8px;border-radius:var(--radius-md,8px);color:#888;color:var(--color-text-muted,#888);cursor:pointer;font-size:.8rem;font-weight:500;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);transition:all .15s ease}.sdm-tab:hover{background:#1a1a1a;background:var(--color-surface,#1a1a1a);color:#fff;color:var(--color-text,#fff)}.sdm-tab-active{background:#3b82f6;background:var(--color-primary,#3b82f6);color:#fff}.sdm-tab-active:hover{background:#2563eb;background:var(--color-primary-hover,#2563eb);color:#fff}.sdm-content{flex:1 1;overflow-y:auto;padding:1rem;padding:var(--space-4,1rem)}.sdm-comparison{border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);overflow:hidden}.sdm-comparison-actions{display:flex;justify-content:flex-end;padding:.4rem .75rem 0}.sdm-copy-all{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.25rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:inline-flex;gap:.3rem;padding:.25rem .6rem;transition:all .15s}.sdm-copy-all:hover{background:#ffffff1a;background:var(--color-surface-active,#ffffff1a);color:#f1f5f9;color:var(--color-text,#f1f5f9)}.sdm-comparison-header{grid-gap:.5rem;grid-gap:var(--space-2,.5rem);background:#252525;background:var(--color-surface-raised,#252525);border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);color:#666;color:var(--color-text-subtle,#666);display:grid;font-size:.65rem;font-weight:600;gap:.5rem;gap:var(--space-2,.5rem);grid-template-columns:140px 1fr 30px 1fr 90px;letter-spacing:.03em;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem);text-transform:uppercase}.sdm-comparison-body{max-height:400px;overflow-y:auto}.sdm-row{grid-gap:.5rem;grid-gap:var(--space-2,.5rem);align-items:center;border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);display:grid;font-size:.75rem;gap:.5rem;gap:var(--space-2,.5rem);grid-template-columns:140px 1fr 30px 1fr 90px;padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem)}.sdm-row:last-child{border-bottom:none}.sdm-row:hover{background:#ffffff05}.sdm-row-match{background:#22c55e0d}.sdm-row-transformed{background:#3b82f60d}.sdm-row-unmapped{background:#eab3080d}.sdm-col-label{display:flex;flex-direction:column;gap:2px}.sdm-field-name{color:#fff;color:var(--color-text,#fff);font-weight:500}.sdm-raw-key{color:#666;color:var(--color-text-subtle,#666);font-family:monospace;font-family:var(--font-mono,monospace);font-size:.6rem}.sdm-col-classified,.sdm-col-raw{align-items:center;display:flex;gap:.25rem;gap:var(--space-1,.25rem);min-width:0}.sdm-value{color:#888;color:var(--color-text-muted,#888);flex:1 1;font-family:monospace;font-family:var(--font-mono,monospace);font-size:.7rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sdm-col-classified .sdm-value{color:#fff;color:var(--color-text,#fff)}.sdm-copy{background:none;border:none;border-radius:4px;border-radius:var(--radius-sm,4px);color:#666;color:var(--color-text-subtle,#666);cursor:pointer;flex-shrink:0;opacity:0;padding:4px;transition:all .15s ease}.sdm-row:hover .sdm-copy{opacity:1}.sdm-copy:hover{background:#333;background:var(--color-surface-raised,#333);color:#3b82f6;color:var(--color-primary,#3b82f6)}.sdm-col-arrow{align-items:center;display:flex;justify-content:center}.sdm-arrow{color:#666;color:var(--color-text-subtle,#666)}.sdm-col-status{justify-content:flex-end}.sdm-col-status,.sdm-status{align-items:center;display:flex}.sdm-status{border-radius:999px;border-radius:var(--radius-full,999px);font-size:.6rem;font-weight:500;gap:4px;padding:2px 8px}.sdm-status-match{background:#22c55e33;color:#22c55e;color:var(--color-success,#22c55e)}.sdm-status-transformed{background:#3b82f633;color:#3b82f6;color:var(--color-primary,#3b82f6)}.sdm-status-unmapped{background:#eab30833;color:#eab308;color:var(--color-warning,#eab308)}.sdm-status-lost{background:#ef444433;color:#ef4444;color:var(--color-error,#ef4444)}.sdm-classified-view,.sdm-raw-view{display:flex;flex-direction:column;gap:1rem;gap:var(--space-4,1rem)}.sdm-section-header{font-size:.8rem;font-weight:600;justify-content:space-between}.sdm-copy-all,.sdm-section-header{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex}.sdm-copy-all{background:#252525;background:var(--color-surface-raised,#252525);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);cursor:pointer;font-size:.7rem;gap:.25rem;gap:var(--space-1,.25rem);padding:.25rem .5rem;padding:var(--space-1,.25rem) var(--space-2,.5rem);transition:all .15s ease}.sdm-copy-all:hover{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border-color:#3b82f6;border-color:var(--color-primary,#3b82f6);color:#3b82f6;color:var(--color-primary,#3b82f6)}.sdm-json{background:#252525;background:var(--color-surface-raised,#252525);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);color:#888;color:var(--color-text-muted,#888);font-family:monospace;font-family:var(--font-mono,monospace);font-size:.7rem;margin:0;max-height:400px;overflow-x:auto;overflow-y:auto;padding:.75rem;padding:var(--space-3,.75rem);white-space:pre}.sdm-fields-grid{grid-gap:.5rem;grid-gap:var(--space-2,.5rem);display:grid;gap:.5rem;gap:var(--space-2,.5rem);grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.sdm-field-card{background:#252525;background:var(--color-surface-raised,#252525);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;border-radius:var(--radius-md,8px);padding:.5rem .75rem;padding:var(--space-2,.5rem) var(--space-3,.75rem)}.sdm-field-label{color:#666;color:var(--color-text-subtle,#666);font-size:.65rem;font-weight:600;letter-spacing:.03em;margin-bottom:4px;text-transform:uppercase}.sdm-field-value{color:#fff;color:var(--color-text,#fff);font-size:.8rem;word-break:break-word}.sdm-metadata-section{border-top:1px solid #333;border-top:1px solid var(--color-border,#333);margin-top:1rem;margin-top:var(--space-4,1rem);padding-top:1rem;padding-top:var(--space-4,1rem)}.sdm-metadata-section h4{color:#888;color:var(--color-text-muted,#888);font-size:.8rem;font-weight:600;margin:0 0 .5rem;margin:0 0 var(--space-2,.5rem) 0}.sdm-footer{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);border-top:1px solid #333;border-top:1px solid var(--color-border,#333);color:#666;color:var(--color-text-subtle,#666);display:flex;font-size:.7rem;justify-content:space-between;padding:.75rem 1rem;padding:var(--space-3,.75rem) var(--space-4,1rem)}.sdm-id{font-family:monospace;font-family:var(--font-mono,monospace)}@media (max-width:767px){.sdm-modal{border-radius:0;max-height:100vh;max-width:100%}.sdm-overlay{padding:0}.sdm-comparison-header,.sdm-row{gap:.25rem;gap:var(--space-1,.25rem);grid-template-columns:1fr}.sdm-comparison-header>div:not(:first-child){display:none}.sdm-row{padding:.75rem;padding:var(--space-3,.75rem)}.sdm-col-classified,.sdm-col-raw{align-items:flex-start;flex-direction:column;gap:.25rem;gap:var(--space-1,.25rem)}.sdm-col-classified:before,.sdm-col-raw:before{color:#666;color:var(--color-text-subtle,#666);content:attr(data-label);font-size:.6rem;font-weight:600;text-transform:uppercase}.sdm-col-arrow{margin:.25rem 0;margin:var(--space-1,.25rem) 0;transform:rotate(90deg)}.sdm-col-status{justify-content:flex-start;margin-top:.25rem;margin-top:var(--space-1,.25rem)}.sdm-tabs{flex-wrap:wrap}.sdm-tab{flex:1 1;font-size:.7rem;justify-content:center}.sdm-fields-grid{grid-template-columns:1fr}}.sdm-detail-status{align-items:center;border-radius:999px;display:inline-flex;font-size:.65rem;font-weight:500;margin-left:8px;padding:2px 8px}.sdm-detail-status-complete{background:#22c55e26;color:#22c55e}.sdm-detail-status-processing,.sdm-detail-status-queued{background:#eab30826;color:#eab308}.sdm-detail-status-failed{background:#ef444426;color:#ef4444}.sdm-detail-status-not_queued{background:#64646426;color:#888}.sdm-tab-count{align-items:center;background:#ffffff26;border-radius:999px;display:inline-flex;font-size:.6rem;font-weight:600;height:18px;justify-content:center;min-width:18px;padding:0 5px}.sdm-tab-active .sdm-tab-count{background:#ffffff40}.sdm-line-items{display:flex;flex-direction:column;gap:.75rem}.sdm-loading{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;font-size:.8rem;gap:8px;justify-content:center;padding:2rem}.sdm-spinner{animation:sdmSpin 1s linear infinite}@keyframes sdmSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sdm-empty{align-items:center;color:#888;color:var(--color-text-muted,#888);display:flex;flex-direction:column;gap:8px;padding:2rem;text-align:center}.sdm-empty p{font-size:.85rem;margin:0}.sdm-empty-hint{color:#666;color:var(--color-text-subtle,#666);font-size:.75rem!important}.sdm-detail-header-fields{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(180px,1fr))}.sdm-lines-table-wrap{border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:8px;overflow-x:auto}.sdm-lines-table{border-collapse:collapse;font-size:.75rem;width:100%}.sdm-lines-table thead{background:#252525;background:var(--color-surface-raised,#252525)}.sdm-lines-table th{color:#666;color:var(--color-text-subtle,#666);font-size:.65rem;font-weight:600;letter-spacing:.03em;text-align:left;text-transform:uppercase}.sdm-lines-table td,.sdm-lines-table th{border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);padding:8px 12px}.sdm-lines-table td{color:#fff;color:var(--color-text,#fff)}.sdm-lines-table tbody tr:last-child td{border-bottom:none}.sdm-lines-table tbody tr:hover{background:#ffffff05}.sdm-line-desc{max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sdm-line-code{color:#888;color:var(--color-text-muted,#888);font-family:monospace;font-family:var(--font-mono,monospace);font-size:.7rem}.sdm-empty-lines{color:#666;color:var(--color-text-subtle,#666);font-size:.8rem;font-style:italic;padding:1rem;text-align:center}.cov-container{margin-top:1rem}.cov-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;font-size:.85rem;gap:.5rem;padding:1.5rem}.cov-spin{animation:cov-spin 1s linear infinite}.cov-error{align-items:center;background:#ef444414;border:1px solid #ef444433;border-radius:.375rem;color:#ef4444;display:flex;font-size:.8rem;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem}@keyframes cov-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.cov-header{justify-content:space-between;margin-bottom:1rem}.cov-header,.cov-header-left{align-items:center;display:flex}.cov-header-left{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-weight:600;gap:.5rem}.cov-header-left h3{font-size:1rem;margin:0}.cov-header-right{display:flex;gap:.5rem}.cov-btn{align-items:center;border:none;border-radius:.375rem;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:.35rem;padding:.4rem .75rem;transition:all .15s}.cov-btn-primary{background:#3b82f6;color:#fff}.cov-btn-primary:hover{background:#2563eb}.cov-btn-primary:disabled{cursor:not-allowed;opacity:.5}.cov-btn-ghost{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.cov-btn-ghost:hover{background:#ffffff1a;background:var(--color-surface-active,#ffffff1a)}.cov-btn-icon{background:none;border:none;border-radius:.25rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;padding:.35rem}.cov-btn-icon:hover{background:#ffffff14}.cov-stats-bar{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;display:flex;flex-wrap:wrap;gap:1.25rem;margin-bottom:1rem;padding:.75rem 1rem}.cov-stat{display:flex;flex-direction:column;gap:.1rem}.cov-stat-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1rem;font-weight:700}.cov-stat-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.cov-stat-alert .cov-stat-value{color:#ef4444}.cov-retry-link{background:none;border:none;color:#3b82f6;cursor:pointer;font-size:.7rem;padding:0;text-decoration:underline}.cov-empty{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;flex-direction:column;gap:.5rem;padding:2.5rem;text-align:center}.cov-empty p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-weight:500;margin:0}.cov-empty span{font-size:.8rem;max-width:400px}.cov-campaign-list{display:flex;flex-direction:column;gap:.5rem}.cov-campaign{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden;transition:border-color .15s}.cov-campaign:hover{border-color:#ffffff26}.cov-expanded{border-color:#3b82f6}.cov-campaign-header{align-items:center;cursor:pointer;display:flex;gap:1rem;padding:.75rem 1rem;transition:background .15s}.cov-campaign-header:hover{background:#ffffff05}.cov-campaign-info{flex:1 1;min-width:0}.cov-campaign-name{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;font-size:.9rem;font-weight:600;gap:.5rem}.cov-campaign-status{border-radius:9999px;font-size:.65rem;font-weight:500;padding:.1rem .4rem;text-transform:uppercase}.cov-status-active{background:#22c55e26;color:#22c55e}.cov-status-paused{background:#f59e0b26;color:#f59e0b}.cov-status-complete{background:#3b82f626;color:#3b82f6}.cov-status-planning{background:#94a3b826;color:#94a3b8}.cov-campaign-meta{color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.75rem;gap:1rem;margin-top:.25rem}.cov-campaign-meta span{align-items:center;display:flex;gap:.25rem}.cov-campaign-progress{flex-shrink:0;width:180px}.cov-progress-bar{background:#ffffff0f;border-radius:3px;height:6px;margin-bottom:.25rem;overflow:hidden}.cov-progress-fill{background:#22c55e;border-radius:3px;height:100%;transition:width .3s ease}.cov-progress-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.cov-campaign-actions{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;gap:.25rem}.cov-heatmap{background:#00000026;border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);padding:.75rem 1rem}.cov-heatmap-grid{grid-gap:4px;display:grid;gap:4px;grid-template-columns:repeat(auto-fill,minmax(55px,1fr))}.cov-heatmap-cell{align-items:center;border-radius:.25rem;cursor:default;display:flex;flex-direction:column;justify-content:center;min-height:44px;padding:.4rem .25rem;position:relative;transition:transform .1s}.cov-heatmap-cell:hover{transform:scale(1.05)}.cov-cell-complete{background:#22c55e33;border:1px solid #22c55e4d}.cov-cell-pending{background:#64748b26;border:1px solid #64748b33}.cov-cell-in_progress{background:#3b82f633;border:1px solid #3b82f64d}.cov-cell-failed{background:#ef444433;border:1px solid #ef44444d}.cov-cell-month{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.6rem;font-weight:500}.cov-cell-count{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.8rem;font-weight:700}.cov-cell-retry{align-items:center;background:#ef44444d;border:none;border-radius:50%;color:#ef4444;cursor:pointer;display:flex;height:16px;justify-content:center;padding:0;position:absolute;right:2px;top:2px;width:16px}.cov-cell-retry:hover{background:#ef444480}.cov-legend{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);display:flex;gap:1rem;margin-top:.5rem;padding-top:.5rem}.cov-legend-item{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.65rem;gap:.3rem}.cov-legend-dot{border-radius:2px;height:8px;width:8px}.cov-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;position:fixed;z-index:1100}.cov-modal{background:#1e293b;background:var(--color-surface,#1e293b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.75rem;box-shadow:0 20px 40px #0000004d;max-width:480px;padding:1.5rem;width:90%}.cov-modal-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.25rem}.cov-modal-header h3{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.1rem;margin:0}.cov-close{background:none;border:none;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer}.cov-field{margin-bottom:1rem}.cov-field label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:block;font-size:.8rem;font-weight:500;margin-bottom:.3rem}.cov-field input{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff26;border:1px solid var(--color-border,#ffffff26);border-radius:.5rem;box-sizing:border-box;color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.85rem;padding:.5rem .75rem;width:100%}.cov-field input:focus{border-color:#3b82f6;outline:none}.cov-disabled{opacity:.5}.cov-acq-types{display:flex;flex-wrap:wrap;gap:.5rem 1rem;margin-top:.25rem}.cov-checkbox-label{align-items:center;color:#e2e8f0;color:var(--color-text,#e2e8f0);cursor:pointer;display:flex;font-size:.8rem;gap:.35rem}.cov-checkbox-label input[type=checkbox]{accent-color:#3b82f6;cursor:pointer}.cov-hint{color:#64748b;color:var(--color-text-muted,#64748b);display:block;font-size:.7rem;margin-top:.2rem}.cov-field-row{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:1fr 1fr}.cov-modal-actions{display:flex;gap:.75rem;justify-content:flex-end;margin-top:1.25rem}@media (max-width:640px){.cov-stats-bar{flex-direction:column;gap:.75rem}.cov-campaign-header{align-items:flex-start;flex-direction:column}.cov-campaign-progress{width:100%}.cov-heatmap-grid{grid-template-columns:repeat(auto-fill,minmax(45px,1fr))}}.jq-container{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden}.jq-spin{animation:jq-spin 1s linear infinite}@keyframes jq-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.jq-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:.65rem 1rem;transition:background .15s}.jq-header:hover{background:#ffffff05}.jq-header-left{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;gap:.5rem}.jq-header-left h3{font-size:.9rem;font-weight:600;margin:0}.jq-active-badge{align-items:center;background:#3b82f626;border-radius:9999px;color:#3b82f6;display:inline-flex;font-size:.7rem;font-weight:500;gap:.3rem;padding:.15rem .5rem}.jq-header-right{gap:.25rem}.jq-btn,.jq-header-right{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex}.jq-btn{background:none;border:none;border-radius:.25rem;cursor:pointer;padding:.3rem}.jq-btn:hover{background:#ffffff14}.jq-body{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f)}.jq-filters{border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border,#ffffff0f);display:flex;gap:.25rem;padding:.5rem .75rem}.jq-filter{background:none;border:none;border-radius:.25rem;color:#64748b;color:var(--color-text-muted,#64748b);cursor:pointer;font-size:.75rem;padding:.25rem .6rem;transition:all .15s}.jq-filter:hover{background:#ffffff0d}.jq-filter.active{background:#3b82f626;color:#3b82f6;font-weight:500}.jq-worker-banner{border-bottom:1px solid #ffffff0f;padding:.65rem .75rem}.jq-worker-active{background:#3b82f60f;border-bottom-color:#3b82f626}.jq-worker-idle{background:#f59e0b0f;border-bottom-color:#f59e0b1f}.jq-worker-status{align-items:flex-start;color:#3b82f6;display:flex;gap:.5rem}.jq-worker-idle .jq-worker-status{color:#f59e0b}.jq-worker-info{display:flex;flex-direction:column;gap:.1rem}.jq-worker-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.8rem;font-weight:600}.jq-worker-detail{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.jq-worker-progress{margin-top:.5rem}.jq-progress-stats{display:flex;font-size:.7rem;gap:.75rem;margin-bottom:.35rem}.jq-stat-done{color:#22c55e;font-weight:500}.jq-stat-failed{color:#ef4444;font-weight:500}.jq-stat-pending{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.jq-stat-eta{color:#3b82f6;margin-left:auto}.jq-progress-bar{background:#ffffff14;border-radius:2px;height:4px;overflow:hidden}.jq-progress-fill{background:linear-gradient(90deg,#22c55e,#3b82f6);border-radius:2px;height:100%;transition:width .5s ease}.jq-empty,.jq-loading{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.8rem;gap:.5rem;justify-content:center;padding:1.5rem}.jq-list{max-height:400px;overflow-y:auto}.jq-job{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a);display:flex;gap:.75rem;padding:.6rem .75rem;transition:background .1s}.jq-job:hover{background:#ffffff05}.jq-job:last-child{border-bottom:none}.jq-job-active{background:#3b82f608}.jq-job-running{background:#3b82f614;border-left:3px solid #3b82f6}.jq-job-status{align-items:center;border-radius:.375rem;display:flex;flex-shrink:0;height:28px;justify-content:center;width:28px}.jq-job-info{flex:1 1;min-width:0}.jq-job-title{align-items:center;display:flex;font-size:.8rem;gap:.4rem}.jq-job-type{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.75rem;font-weight:600}.jq-job-dept{align-items:center;background:#ffffff0d;border-radius:.2rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:inline-flex;font-size:.7rem;gap:.2rem;padding:.1rem .35rem}.jq-job-acq,.jq-job-meta{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.jq-job-meta{display:flex;gap:.75rem;margin-top:.15rem}.jq-job-meta span{align-items:center;display:flex;gap:.2rem}.jq-job-time{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.jq-job-source{font-style:italic}.jq-job-result{align-items:flex-end;display:flex;flex-direction:column;flex-shrink:0;gap:.1rem;min-width:80px}.jq-result-suppliers{color:#22c55e;font-size:.8rem;font-weight:600}.jq-partial{color:#f59e0b!important}.jq-batch-info{font-size:.6rem;font-style:italic}.jq-batch-info,.jq-result-duration{color:#64748b;color:var(--color-text-muted,#64748b)}.jq-result-duration{font-size:.65rem}.jq-result-error{color:#ef4444;font-size:.7rem;max-width:150px;overflow:hidden;text-align:right;text-overflow:ellipsis;white-space:nowrap}.jq-result-running{align-items:center;color:#3b82f6;display:inline-flex;font-size:.75rem;font-weight:500;gap:.3rem}.jq-result-worker{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-family:monospace;font-size:.65rem}.jq-result-waiting{color:#f59e0b;font-size:.75rem;font-style:italic}.jq-job-badge{border-radius:.2rem;flex-shrink:0;font-size:.6rem;font-weight:600;letter-spacing:.03em;padding:.15rem .4rem;text-transform:uppercase}.jq-list::-webkit-scrollbar{width:4px}.jq-list::-webkit-scrollbar-track{background:#0000}.jq-list::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:2px}.jq-job-clickable{cursor:pointer}.jq-job-clickable:hover{background:#22c55e0a}.jq-modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:1200}.jq-modal{background:#1a1a2e;background:var(--color-surface,#1a1a2e);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.75rem;box-shadow:0 25px 50px #0006;display:flex;flex-direction:column;max-height:85vh;max-width:1000px;width:95%}.jq-modal-header{align-items:flex-start;border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);display:flex;justify-content:space-between;padding:1rem 1.25rem}.jq-modal-header h3{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1rem;margin:0}.jq-modal-meta{color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;flex-wrap:wrap;font-size:.7rem;gap:.75rem;margin-top:.3rem}.jq-modal-meta span{align-items:center;display:flex;gap:.2rem}.jq-modal-actions{gap:.5rem}.jq-copy-btn,.jq-modal-actions{align-items:center;display:flex}.jq-copy-btn{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:.3rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;font-size:.75rem;gap:.3rem;padding:.35rem .65rem;transition:all .15s}.jq-copy-btn:hover{background:#ffffff1a;color:#f1f5f9;color:var(--color-text,#f1f5f9)}.jq-close-btn{background:none;border:none;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;padding:.25rem}.jq-modal-body{flex:1 1;overflow-y:auto}.jq-modal-empty,.jq-modal-loading{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.85rem;gap:.5rem;justify-content:center;padding:2.5rem}.jq-supplier-table{border-collapse:collapse;font-size:.8rem;width:100%}.jq-supplier-table th{background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.65rem;font-weight:500;letter-spacing:.03em;padding:.5rem .75rem;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:1}.jq-supplier-table td{border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a);color:#f1f5f9;color:var(--color-text,#f1f5f9);padding:.45rem .75rem}.jq-supplier-table tbody tr:hover{background:#ffffff05}.jq-td-supplier{min-width:160px}.jq-supplier-name{display:block;font-weight:500}.jq-supplier-id{color:#64748b;color:var(--color-text-muted,#64748b);display:block;font-family:monospace;font-size:.65rem}.jq-td-amount{color:#22c55e;font-weight:600;white-space:nowrap}.jq-td-doc{font-family:monospace;font-size:.7rem}.jq-td-dept,.jq-td-doc{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.jq-td-dept{max-width:150px;overflow:hidden;text-overflow:ellipsis}.jq-td-date,.jq-td-dept{font-size:.75rem;white-space:nowrap}.jq-td-desc{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem;max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}@media (max-width:640px){.jq-job{flex-wrap:wrap}.jq-job-result{flex-direction:row;gap:.5rem;justify-content:flex-start;width:100%}.jq-job-meta{flex-wrap:wrap}.jq-modal{border-radius:0;max-height:100vh;max-width:100%;width:100%}.jq-supplier-table td:nth-child(n+4),.jq-supplier-table th:nth-child(n+4){display:none}}.di-container{margin-top:.5rem}.di-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;font-size:.85rem;gap:.5rem;padding:1.5rem}.di-spin{animation:di-spin 1s linear infinite}@keyframes di-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.di-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:.75rem}.di-header,.di-header-left{align-items:center;display:flex;gap:.5rem}.di-header-left{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-weight:600}.di-header-left h3{font-size:1rem;margin:0}.di-header-right{display:flex;gap:.35rem}.di-health-badge{border-radius:9999px;font-size:.7rem;font-weight:600;padding:.15rem .5rem}.di-health-good{background:#22c55e26;color:#22c55e}.di-health-warn{background:#f59e0b26;color:#f59e0b}.di-health-bad{background:#ef444426;color:#ef4444}.di-btn{align-items:center;border:none;border-radius:.3rem;cursor:pointer;display:inline-flex;font-size:.75rem;font-weight:500;gap:.3rem;padding:.35rem .65rem;transition:all .15s}.di-btn-primary{background:#3b82f6;color:#fff}.di-btn-primary:hover{background:#2563eb}.di-btn-primary:disabled{cursor:not-allowed;opacity:.5}.di-btn-ghost{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.di-btn-ghost:hover{background:#ffffff1a}.di-btn-sm{background:#3b82f626;border:1px solid #3b82f633;color:#3b82f6;font-size:.7rem;padding:.25rem .5rem}.di-btn-sm:hover{background:#3b82f640}.di-btn-sm:disabled{opacity:.5}.di-alert{align-items:center;border-radius:.375rem;display:flex;font-size:.8rem;gap:.5rem;margin-bottom:.75rem;padding:.5rem .75rem}.di-alert-ok{background:#22c55e14;border:1px solid #22c55e33;color:#22c55e}.di-alert-err{background:#ef444414;border:1px solid #ef444433;color:#ef4444}.di-alert-dismiss{background:none;border:none;color:inherit;cursor:pointer;margin-left:auto;opacity:.7}.di-summary-row{grid-gap:.6rem;display:grid;gap:.6rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));margin-bottom:.75rem}.di-summary-card{align-items:center;background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;display:flex;flex-direction:column;gap:.25rem;padding:.6rem}.di-summary-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.2rem;font-weight:700}.di-summary-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.65rem;text-align:center}.di-card-good .di-summary-value{color:#22c55e}.di-card-warn .di-summary-value{color:#f59e0b}.di-distribution{background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;margin-bottom:.75rem;padding:.6rem .75rem}.di-distribution-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.7rem;font-weight:500;margin-bottom:.4rem}.di-distribution-bar{border-radius:4px;display:flex;height:20px;overflow:hidden}.di-distribution-segment{align-items:center;color:#000000b3;display:flex;font-size:.6rem;font-weight:600;justify-content:center;transition:width .3s}.di-distribution-legend{display:flex;flex-wrap:wrap;gap:.6rem;margin-top:.4rem}.di-legend-item{align-items:center;color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.6rem;gap:.25rem}.di-legend-dot{border-radius:2px;height:8px;width:8px}.di-dept-list{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden}.di-dept-header-row{grid-gap:.5rem;background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a);color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:grid;font-size:.65rem;font-weight:600;gap:.5rem;grid-template-columns:1fr 80px 80px 100px 70px 90px;letter-spacing:.03em;padding:.5rem .75rem;text-transform:uppercase}.di-dept-item{border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a)}.di-dept-item:last-child{border-bottom:none}.di-dept-row{grid-gap:.5rem;align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);cursor:pointer;display:grid;font-size:.8rem;gap:.5rem;grid-template-columns:1fr 80px 80px 100px 70px 90px;padding:.5rem .75rem;transition:background .1s}.di-dept-row:hover{background:#ffffff05}.di-dept-name{align-items:center;display:flex;gap:.35rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.di-dept-name strong{font-size:.7rem}.di-dept-count,.di-dept-name strong,.di-dept-score{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.di-dept-count,.di-dept-score,.di-pct{font-size:.8rem}.di-pct{font-weight:600}.di-pct-good{color:#22c55e}.di-pct-warn{color:#f59e0b}.di-pct-bad{color:#ef4444}.di-rescrape-count{color:#f59e0b;font-weight:600}.di-check{color:#22c55e}.di-queued-badge{align-items:center;color:#22c55e;display:inline-flex;font-size:.7rem;font-weight:500;gap:.25rem}.di-dept-detail{background:#00000026;border-top:1px solid #ffffff0a;border-top:1px solid var(--color-border,#ffffff0a);padding:.6rem .75rem}.di-detail-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.di-detail-item{background:#ffffff05;border-radius:.25rem;display:flex;justify-content:space-between;padding:.3rem .5rem}.di-detail-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.di-detail-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.8rem;font-weight:600}.di-val-bad{color:#ef4444}.di-val-warn{color:#f59e0b}@media (max-width:768px){.di-dept-header-row,.di-dept-row{grid-template-columns:1fr 60px 60px 80px}.di-dept-header-row>:nth-child(5),.di-dept-header-row>:nth-child(6),.di-dept-row>:nth-child(5),.di-dept-row>:nth-child(6){display:none}}.dep-panel{background:#1a1a1a;background:var(--color-surface,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;display:flex;flex-direction:column;gap:.75rem;padding:1rem}.dep-header{justify-content:space-between}.dep-header,.dep-title{align-items:center;display:flex}.dep-title{gap:8px}.dep-title h3{color:#fff;color:var(--color-text,#fff);font-size:.9rem;font-weight:600;margin:0}.dep-refresh{background:none;border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:6px;color:#888;color:var(--color-text-muted,#888);cursor:pointer;padding:4px 8px;transition:all .15s}.dep-refresh:hover{background:#252525;background:var(--color-surface-raised,#252525);color:#fff;color:var(--color-text,#fff)}.dep-progress-section{display:flex;flex-direction:column;gap:4px}.dep-progress-bar{background:#252525;background:var(--color-surface-raised,#252525);border-radius:3px;height:6px;overflow:hidden}.dep-progress-fill{background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:3px;height:100%;transition:width .5s ease}.dep-progress-label{color:#888;color:var(--color-text-muted,#888);font-size:.7rem}.dep-stats{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr)}.dep-stat{align-items:center;background:#252525;background:var(--color-surface-raised,#252525);border-radius:8px;display:flex;flex-direction:column;gap:2px;padding:8px}.dep-stat svg{color:#666;color:var(--color-text-subtle,#666)}.dep-stat-value{color:#fff;color:var(--color-text,#fff);font-size:1.1rem;font-weight:600}.dep-stat-success{color:#22c55e}.dep-stat-error{color:#ef4444}.dep-stat-label{color:#666;color:var(--color-text-subtle,#666);font-size:.6rem;letter-spacing:.05em;text-transform:uppercase}.dep-throttle{border-radius:8px;font-size:.8rem;padding:10px 12px}.dep-throttle-clear{background:#22c55e14;border:1px solid #22c55e33}.dep-throttle-blocked{background:#ef444414;border:1px solid #ef444433}.dep-throttle-header{align-items:center;display:flex;font-weight:500;gap:6px}.dep-throttle-clear .dep-throttle-header{color:#22c55e}.dep-throttle-blocked .dep-throttle-header{color:#ef4444}.dep-throttle-detail{border-top:1px solid #ffffff0f;margin-top:6px;padding-top:6px}.dep-throttle-detail p{color:#888;color:var(--color-text-muted,#888);font-size:.75rem;margin:0 0 4px}.dep-throttle-info{color:#666!important;color:var(--color-text-subtle,#666)!important;font-size:.7rem!important}.dep-controls{display:flex;flex-direction:column;gap:8px}.dep-control-row{align-items:center;display:flex;justify-content:space-between}.dep-control-label{color:#888;color:var(--color-text-muted,#888);font-size:.75rem;font-weight:500}.dep-toggle{align-items:center;border:none;border-radius:999px;cursor:pointer;display:inline-flex;font-size:.7rem;font-weight:500;gap:4px;padding:4px 10px;transition:all .15s}.dep-toggle-on{background:#22c55e33;color:#22c55e}.dep-toggle-off{background:#64646433;color:#888}.dep-batch-sizes{display:flex;gap:4px}.dep-batch-btn{background:#252525;background:var(--color-surface-raised,#252525);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:4px;color:#888;color:var(--color-text-muted,#888);cursor:pointer;font-size:.7rem;padding:3px 10px;transition:all .15s}.dep-batch-btn:hover{color:#fff;color:var(--color-text,#fff)}.dep-batch-btn-active,.dep-batch-btn:hover{border-color:#3b82f6;border-color:var(--color-primary,#3b82f6)}.dep-batch-btn-active{background:#3b82f6;background:var(--color-primary,#3b82f6);color:#fff}.dep-btn{align-items:center;border:none;border-radius:8px;cursor:pointer;display:inline-flex;font-size:.8rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s}.dep-btn-primary{background:#3b82f6;background:var(--color-primary,#3b82f6);color:#fff}.dep-btn-primary:hover:not(:disabled){background:#2563eb;background:var(--color-primary-hover,#2563eb)}.dep-btn:disabled{cursor:not-allowed;opacity:.5}.dep-btn-sm{background:#ffffff14;border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:6px;color:#888;color:var(--color-text-muted,#888);font-size:.7rem;padding:4px 10px}.dep-btn-sm:hover{background:#ffffff1f;color:#fff;color:var(--color-text,#fff)}.dep-spin{animation:depSpin 1s linear infinite}@keyframes depSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dep-recent{border-top:1px solid #333;border-top:1px solid var(--color-border,#333);padding-top:.5rem}.dep-recent-header{color:#666;color:var(--color-text-subtle,#666);font-size:.7rem;font-weight:600;letter-spacing:.05em;margin-bottom:6px;text-transform:uppercase}.dep-recent-list{display:flex;flex-direction:column;gap:2px}.dep-recent-item{grid-gap:8px;align-items:center;border-radius:4px;display:grid;font-size:.7rem;gap:8px;grid-template-columns:1fr 1fr auto;padding:4px 8px}.dep-recent-item:hover{background:#ffffff08}.dep-recent-doc{font-family:monospace}.dep-recent-doc,.dep-recent-supplier{color:#888;color:var(--color-text-muted,#888);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dep-recent-status{border-radius:999px;font-size:.6rem;font-weight:500;padding:1px 6px}.dep-status-pending{background:#64646433;color:#888}.dep-status-queued{background:#eab30826;color:#eab308}.dep-status-processing{background:#3b82f626;color:#3b82f6}.dep-status-complete{background:#22c55e26;color:#22c55e}.dep-status-failed{background:#ef444426;color:#ef4444}.dep-loading{color:#888;color:var(--color-text-muted,#888);font-size:.8rem;padding:2rem;text-align:center}.st-container{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden}.st-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:.65rem 1rem;transition:background .15s}.st-header:hover{background:#ffffff05}.st-header-left{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;gap:.5rem}.st-header-left h3{font-size:.9rem;font-weight:600;margin:0}.st-subtitle{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem;font-weight:400}.st-header-right{gap:.25rem}.st-btn,.st-header-right{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex}.st-btn{background:none;border:none;border-radius:.25rem;cursor:pointer;padding:.3rem}.st-btn:hover{background:#ffffff14}.st-body{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);padding:.5rem}.st-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;font-size:.85rem;gap:.5rem;justify-content:center;padding:1.5rem}.st-spin{animation:st-spin 1s linear infinite}@keyframes st-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.st-error{color:#ef4444;font-size:.8rem;padding:1rem;text-align:center}.dsc-container{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;overflow:hidden}.dsc-header{align-items:center;cursor:pointer;display:flex;justify-content:space-between;padding:.65rem 1rem;transition:background .15s}.dsc-header:hover{background:#ffffff05}.dsc-header-left{align-items:center;color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;gap:.5rem}.dsc-header-left h3{font-size:.9rem;font-weight:600;margin:0}.dsc-header-right{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;gap:.25rem}.dsc-dept-badge{background:#3b82f626;border-radius:.2rem;color:#3b82f6;font-size:.65rem;font-weight:600;padding:.1rem .4rem}.dsc-btn{align-items:center;background:none;border:none;border-radius:.25rem;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;padding:.3rem}.dsc-btn:hover{background:#ffffff14}.dsc-time-pills{display:flex;gap:2px;margin-right:.5rem}.dsc-pill{background:#0000;border:none;border-radius:.2rem;color:#64748b;color:var(--color-text-muted,#64748b);cursor:pointer;font-size:.65rem;font-weight:500;padding:.2rem .4rem;transition:all .15s}.dsc-pill:hover{background:#ffffff0f;color:#f1f5f9;color:var(--color-text,#f1f5f9)}.dsc-pill-active{background:#3b82f6;color:#fff}.dsc-body{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);padding:.75rem}.dsc-loading{align-items:center;color:#94a3b8;color:var(--color-text-muted,#94a3b8);display:flex;font-size:.8rem;gap:.5rem;justify-content:center;padding:1rem}.dsc-spin{animation:dsc-spin 1s linear infinite}@keyframes dsc-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dsc-cards{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(130px,1fr))}.dsc-card{align-items:center;background:#ffffff08;background:var(--color-surface,#ffffff08);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;cursor:pointer;display:flex;flex-direction:column;gap:.3rem;padding:.65rem .5rem;text-align:center;transition:all .15s}.dsc-card:hover{transform:translateY(-1px)}.dsc-card-active,.dsc-card:hover{border-color:#3b82f6;border-color:var(--card-color,#3b82f6)}.dsc-card-active{background:#3b82f60f;box-shadow:0 0 0 1px var(--card-color)}.dsc-card-disabled{cursor:default;opacity:.5}.dsc-card-disabled:hover{border-color:#ffffff14;border-color:var(--color-border,#ffffff14);transform:none}.dsc-card-icon{align-items:center;border-radius:.375rem;display:flex;height:32px;justify-content:center;width:32px}.dsc-card-value{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:1.2rem;font-weight:700;line-height:1.1}.dsc-card-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.65rem}.dsc-card-sub{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.6rem}.dsc-po-list{border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:.5rem;margin-top:.75rem;overflow:hidden}.dsc-po-header{align-items:center;background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a);color:#f1f5f9;color:var(--color-text,#f1f5f9);display:flex;font-size:.8rem;font-weight:600;justify-content:space-between;padding:.5rem .75rem}.dsc-close{background:none;border:none;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;padding:.2rem}.dsc-empty{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.8rem;padding:1.5rem;text-align:center}.dsc-table-wrap{max-height:350px;overflow-y:auto}.dsc-table{border-collapse:collapse;font-size:.75rem;width:100%}.dsc-table th{background:#ffffff0a;background:var(--color-surface-hover,#ffffff0a);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.65rem;font-weight:500;letter-spacing:.03em;padding:.4rem .6rem;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:1}.dsc-table td{border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--color-border,#ffffff0a);color:#f1f5f9;color:var(--color-text,#f1f5f9);padding:.4rem .6rem}.dsc-table tbody tr:hover{background:#ffffff05}.dsc-mono{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-family:monospace;font-size:.7rem}.dsc-amount{color:#22c55e;font-weight:600;white-space:nowrap}.dsc-badge{border-radius:.2rem;font-size:.6rem;font-weight:500;padding:.1rem .35rem}.dsc-badge-yes{background:#22c55e26;color:#22c55e}.dsc-badge-no{background:#f59e0b26;color:#f59e0b}.dsc-score{font-size:.7rem;font-weight:600}.dsc-score-good{color:#22c55e}.dsc-score-ok{color:#f59e0b}.dsc-score-bad{color:#ef4444}.dsc-table-footer{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);color:#64748b;color:var(--color-text-muted,#64748b);font-size:.65rem;padding:.4rem .6rem;text-align:right}@media (max-width:640px){.dsc-cards{grid-template-columns:repeat(2,1fr)}}.sd-container{animation:fadeIn var(--duration-normal) var(--ease-out);color:var(--color-text);font-family:var(--font-sans);margin:0 auto;max-width:var(--content-max-width);overflow-x:hidden;padding:var(--space-6);width:100%}@media (max-width:767px){.sd-container{padding:var(--space-4)}}.sd-header{border-bottom:1px solid var(--color-border);flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--space-6);padding-bottom:var(--space-4)}.sd-header,.sd-header-left{align-items:center;display:flex;gap:var(--space-3)}.sd-header-left h2{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-semibold);margin:0}.sd-header-right{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.sd-last-refresh{color:var(--color-text-subtle);font-size:var(--text-xs)}.sd-auto-refresh{align-items:center;color:var(--color-text-muted);cursor:pointer;display:flex;font-size:var(--text-sm);gap:var(--space-2);-webkit-user-select:none;user-select:none}@media (max-width:600px){.sd-header{align-items:flex-start;flex-direction:column}.sd-header-right{justify-content:flex-start;width:100%}}.sd-loading{align-items:center;color:var(--color-text-subtle);display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;padding:var(--space-16)}.sd-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-sm);margin-bottom:var(--space-5);padding:var(--space-5);transition:box-shadow var(--transition-normal)}.sd-section:hover{box-shadow:var(--shadow-md)}.sd-section h3{align-items:center;border-bottom:1px solid var(--color-border);color:var(--color-text-muted);display:flex;font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-2);letter-spacing:.06em;margin:0 0 var(--space-4) 0;padding-bottom:var(--space-3);text-transform:uppercase}.sd-section-trigger{background:linear-gradient(135deg,color-mix(in srgb,var(--color-primary) 4%,var(--color-surface)),var(--color-surface));border-color:var(--color-primary);border-width:1.5px}.sd-section-header-row{align-items:center;border-bottom:1px solid var(--color-border);display:flex;justify-content:space-between;margin-bottom:var(--space-4);padding-bottom:var(--space-3)}.sd-section-header-row h3{align-items:center;border:none;color:var(--color-text-muted);display:flex;font-size:var(--text-sm);font-weight:var(--font-semibold);gap:var(--space-2);letter-spacing:.06em;margin:0;padding:0;text-transform:uppercase}.sd-btn-sm{font-size:var(--text-xs);height:28px;padding:0 var(--space-3)}@media (max-width:767px){.sd-section{padding:var(--space-4)}}.sd-badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:4px;padding:3px 10px;white-space:nowrap}.badge-success{background:color-mix(in srgb,var(--color-success) 12%,#0000)}.badge-danger{background:color-mix(in srgb,var(--color-error) 12%,#0000)}.badge-warning{background:color-mix(in srgb,var(--color-warning) 14%,#0000)}.badge-muted{background:var(--gray-100);color:var(--color-text-subtle)}.sd-health-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(min(180px,100%),1fr))}.sd-health-item{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-3) var(--space-4)}.sd-health-label{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;text-transform:uppercase}.sd-health-value{color:var(--color-text);font-size:var(--text-sm);word-break:break-all}code.sd-health-value{color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--text-xs)}@media (max-width:600px){.sd-health-grid{grid-template-columns:1fr 1fr}}.sd-metrics-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(140px,1fr))}.sd-metric-card{align-items:flex-start;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);display:flex;gap:var(--space-3);overflow:hidden;padding:var(--space-4);position:relative;transition:all var(--transition-normal)}.sd-metric-card:before{border-radius:var(--radius-full) var(--radius-full) 0 0;content:"";height:3px;left:0;position:absolute;right:0;top:0}.sd-metric-primary:before{background:var(--gradient-primary)}.sd-metric-success:before{background:var(--gradient-success)}.sd-metric-warning:before{background:linear-gradient(135deg,var(--color-warning),var(--color-warning-dark))}.sd-metric-danger:before{background:linear-gradient(135deg,var(--color-error),var(--color-danger-dark))}.sd-metric-accent:before{background:var(--gradient-accent)}.sd-metric-muted:before{background:linear-gradient(135deg,var(--gray-300),var(--gray-400))}.sd-metric-icon{align-items:center;border-radius:var(--radius-lg);display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.sd-metric-primary .sd-metric-icon{background:color-mix(in srgb,var(--color-primary) 12%,#0000);color:var(--color-primary)}.sd-metric-success .sd-metric-icon{background:color-mix(in srgb,var(--color-success) 12%,#0000);color:var(--color-success)}.sd-metric-warning .sd-metric-icon{background:color-mix(in srgb,var(--color-warning) 12%,#0000);color:var(--color-warning-dark)}.sd-metric-danger .sd-metric-icon{background:color-mix(in srgb,var(--color-error) 12%,#0000);color:var(--color-error)}.sd-metric-accent .sd-metric-icon{background:color-mix(in srgb,var(--color-accent) 12%,#0000);color:var(--color-accent)}.sd-metric-muted .sd-metric-icon{background:var(--gray-100);color:var(--gray-500)}.sd-metric-value{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-bold);line-height:1.2}.sd-metric-label{font-weight:var(--font-medium);margin-top:2px}.sd-metric-label,.sd-metric-subtitle{color:var(--color-text-subtle);font-size:var(--text-xs)}@media (max-width:480px){.sd-metrics-grid{grid-template-columns:1fr 1fr}}.sd-queues-grid{grid-gap:var(--space-4);display:grid;gap:var(--space-4);grid-template-columns:repeat(auto-fill,minmax(min(220px,100%),1fr))}.sd-queue-panel{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-xl);padding:var(--space-4)}.sd-queue-panel.sd-queue-error{background:color-mix(in srgb,var(--color-error) 4%,var(--color-surface));border-color:color-mix(in srgb,var(--color-error) 25%,#0000)}.sd-queue-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-3)}.sd-queue-header h4{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.sd-queue-total{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-medium)}.sd-queue-bar{background:var(--gray-200);border-radius:var(--radius-full);display:flex;height:6px;margin-bottom:var(--space-3);overflow:hidden}.sd-bar-segment{height:100%;transition:width var(--transition-slow)}.sd-bar-completed{background:var(--color-success)}.sd-bar-processing{background:var(--color-primary)}.sd-bar-failed{background:var(--color-error)}.sd-queue-stats{display:flex;flex-wrap:wrap;gap:var(--space-2)}.sd-stat{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:4px;padding:2px 8px}.sd-stat-pending{background:var(--gray-100);color:var(--gray-600)}.sd-stat-processing{background:color-mix(in srgb,var(--color-primary) 10%,#0000);color:var(--color-primary)}.sd-stat-completed{background:color-mix(in srgb,var(--color-success) 10%,#0000);color:var(--color-success-dark)}.sd-stat-failed{background:color-mix(in srgb,var(--color-error) 10%,#0000);color:var(--color-error)}.sd-queue-activity{color:var(--color-text-subtle);font-size:var(--text-xs);margin-top:var(--space-2)}.sd-error-text{color:var(--color-error);font-size:var(--text-sm)}@media (max-width:767px){.sd-queues-grid{grid-template-columns:1fr}}.sd-form-group,.sd-trigger-form{display:flex;flex-direction:column}.sd-form-group{gap:var(--space-2);margin-bottom:var(--space-4)}.sd-form-label{align-items:center;color:var(--color-text-subtle);display:flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:var(--space-1-5);letter-spacing:.06em;text-transform:uppercase}.sd-input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text);font-family:var(--font-sans);font-size:var(--text-sm);height:var(--input-height);min-height:var(--input-height);outline:none;padding:0 var(--space-3);transition:border-color var(--transition-fast),box-shadow var(--transition-fast);width:100%}.sd-input:hover{border-color:var(--color-border-hover)}.sd-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 15%,#0000)}input[type=date].sd-input{background:var(--color-surface);color:var(--color-text);color-scheme:dark}input[type=date].sd-input::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(.7) sepia(0) saturate(0) brightness(1.4);opacity:.6}input[type=date].sd-input::-webkit-datetime-edit{color:var(--color-text)}input[type=date].sd-input::-webkit-datetime-edit-fields-wrapper{background:#0000}input[type=date].sd-input::-webkit-datetime-edit-text{color:var(--color-text-muted)}input[type=date].sd-input::-webkit-datetime-edit-day-field,input[type=date].sd-input::-webkit-datetime-edit-month-field,input[type=date].sd-input::-webkit-datetime-edit-year-field{background:#0000;color:var(--color-text)}input[type=date].sd-input::-webkit-datetime-edit-day-field:focus,input[type=date].sd-input::-webkit-datetime-edit-month-field:focus,input[type=date].sd-input::-webkit-datetime-edit-year-field:focus{background:var(--color-primary);border-radius:2px;color:#fff}.sd-select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right var(--space-3) center;background-repeat:no-repeat;cursor:pointer;padding-right:var(--space-8)}.sd-form-dates{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr}@media (max-width:480px){.sd-form-dates{grid-template-columns:1fr}}.sd-timeframe-pills{display:flex;flex-wrap:wrap;gap:var(--space-2)}.sd-pill{align-items:center;background:var(--color-surface);border:1.5px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-semibold);height:36px;justify-content:center;min-width:44px;padding:0 var(--space-4);transition:all var(--transition-fast)}.sd-pill:hover{background:color-mix(in srgb,var(--color-primary) 6%,var(--color-surface));border-color:var(--color-primary);color:var(--color-primary)}.sd-pill-active{border-color:var(--color-primary);box-shadow:0 2px 8px color-mix(in srgb,var(--color-primary) 35%,#0000)}.sd-pill-active,.sd-pill-active:hover{background:var(--gradient-primary);color:#fff}.sd-pill-active:hover{border-color:var(--color-primary-dark);opacity:.9}.sd-trigger-footer{border-top:1px solid var(--color-border);gap:var(--space-3);justify-content:space-between;margin-top:var(--space-2);padding-top:var(--space-4)}.sd-trigger-footer,.sd-trigger-summary{align-items:center;display:flex;flex-wrap:wrap}.sd-trigger-summary{gap:var(--space-2)}.sd-summary-acq,.sd-summary-dept,.sd-summary-range{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--text-xs);font-weight:var(--font-semibold);gap:4px;padding:var(--space-1) var(--space-3)}.sd-summary-range{background:var(--gray-100);color:var(--color-text-muted)}.sd-summary-dept{background:color-mix(in srgb,var(--color-primary) 10%,#0000);color:var(--color-primary-dark)}.sd-summary-acq{background:color-mix(in srgb,var(--color-success) 10%,#0000);color:var(--color-success-dark)}@media (max-width:600px){.sd-trigger-footer{align-items:stretch;flex-direction:column}}.sd-trigger-result{align-items:center;animation:slideUp var(--duration-normal) var(--ease-out);border-radius:var(--radius-lg);display:flex;font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-3) var(--space-4)}.sd-result-ok{background:color-mix(in srgb,var(--color-success) 10%,#0000);border:1px solid color-mix(in srgb,var(--color-success) 25%,#0000);color:var(--color-success-dark)}.sd-result-error{background:color-mix(in srgb,var(--color-error) 10%,#0000);border:1px solid color-mix(in srgb,var(--color-error) 25%,#0000);color:var(--color-error)}.sd-btn{align-items:center;border:none;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);gap:var(--space-2);height:var(--button-height);justify-content:center;min-width:44px;padding:0 var(--space-4);transition:all var(--transition-fast);white-space:nowrap}.sd-btn:disabled{cursor:not-allowed;opacity:.6}.sd-btn-primary{background:var(--gradient-primary);box-shadow:0 2px 8px color-mix(in srgb,var(--color-primary) 30%,#0000);color:#fff}.sd-btn-primary:hover:not(:disabled){box-shadow:0 4px 12px color-mix(in srgb,var(--color-primary) 40%,#0000);transform:translateY(-1px)}.sd-btn-primary:active:not(:disabled){transform:translateY(0)}.sd-btn-ghost{background:#0000;border:1px solid var(--color-border);color:var(--color-text-muted)}.sd-btn-ghost:hover:not(:disabled){background:var(--color-surface-hover);border-color:var(--color-border-hover);color:var(--color-text)}@media (max-width:600px){.sd-btn-primary{width:100%}}.sd-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.sd-table th{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;padding:var(--space-2) var(--space-3);text-align:left;text-transform:uppercase;white-space:nowrap}.sd-table td,.sd-table th{border-bottom:1px solid var(--color-border)}.sd-table td{color:var(--color-text);padding:var(--space-3);vertical-align:middle}.sd-table tr:last-child td{border-bottom:none}.sd-table tr:hover td{background:var(--color-surface-hover)}@media (max-width:767px){.sd-table,.sd-table tbody,.sd-table td,.sd-table th,.sd-table thead,.sd-table tr{display:block}.sd-table thead tr{display:none}.sd-table tr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-xs);margin-bottom:var(--space-3);overflow:hidden}.sd-table td{align-items:center;border-bottom:1px solid var(--color-border);display:flex;gap:var(--space-3);justify-content:space-between;padding:var(--space-2-5) var(--space-4)}.sd-table td:last-child{border-bottom:none}.sd-table td:before{color:var(--color-text-subtle);content:attr(data-label);flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.04em;text-transform:uppercase}}.sd-activity-empty{color:var(--color-text-subtle);flex-direction:column;gap:var(--space-3);padding:var(--space-10)}.sd-activity-empty,.sd-expand-btn{align-items:center;display:flex;font-size:var(--text-sm)}.sd-expand-btn{background:none;border:none;border-top:1px solid var(--color-border);color:var(--color-primary);cursor:pointer;font-weight:var(--font-medium);gap:var(--space-2);justify-content:center;margin-top:var(--space-2);padding:var(--space-2);transition:background var(--transition-fast);width:100%}.sd-expand-btn:hover{background:var(--color-surface-hover)}.sd-drilldown-counts{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.sd-failures{border-top:1px solid var(--color-border);margin-top:var(--space-4);padding-top:var(--space-4)}.sd-failures h5{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;margin:0 0 var(--space-3) 0;text-transform:uppercase}.sd-failure-item{align-items:center;border-radius:var(--radius-lg);display:flex;flex-wrap:wrap;font-size:var(--text-sm);gap:var(--space-3);padding:var(--space-2) var(--space-3);transition:background var(--transition-fast)}.sd-failure-item:hover{background:var(--color-surface-hover)}.sd-failure-dept{color:var(--color-text);font-weight:var(--font-semibold);min-width:40px}.sd-failure-doc{color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--text-xs)}.sd-failure-attempts{background:color-mix(in srgb,var(--color-error) 10%,#0000);border-radius:var(--radius-full);color:var(--color-error);font-size:var(--text-xs);padding:2px 8px}.sd-pulse{animation:sdPulse 2s ease-in-out infinite;color:var(--color-success)}@keyframes sdPulse{0%,to{opacity:1}50%{opacity:.4}}.sd-spin{animation:sdSpin .8s linear infinite}@keyframes sdSpin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sd-clickable{cursor:pointer;transition:transform var(--transition-fast),box-shadow var(--transition-fast)}.sd-clickable:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.sd-clickable:active{transform:translateY(0)}.sd-clickable-chip{cursor:pointer;transition:opacity var(--transition-fast),transform var(--transition-fast)}.sd-clickable-chip:hover{opacity:.8;transform:scale(1.05)}.sd-modal-backdrop{background:#0000;inset:0;position:fixed;transition:background .3s ease;z-index:1000}.sd-modal-backdrop.sd-modal-visible{background:#00000059}.sd-modal-panel{background:var(--color-surface);border-left:1px solid var(--color-border);box-shadow:-4px 0 24px #0000001f;display:flex;flex-direction:column;height:100vh;position:fixed;right:0;top:0;transform:translateX(100%);transition:transform .3s ease;width:min(480px,100vw);z-index:1001}.sd-modal-panel.sd-modal-panel-open{transform:translateX(0)}.sd-modal-header{align-items:center;border-bottom:1px solid var(--color-border);display:flex;flex-shrink:0;justify-content:space-between;padding:var(--space-4) var(--space-5)}.sd-modal-title{color:var(--color-text);font-size:var(--text-base);font-weight:var(--font-semibold);letter-spacing:normal;margin:0;text-transform:none}.sd-modal-close{flex-shrink:0;height:36px;min-width:36px;padding:0}.sd-modal-body{-webkit-overflow-scrolling:touch;flex:1 1;overflow-y:auto;padding:var(--space-5)}.sd-modal-loading{color:var(--color-text-subtle);flex-direction:column;gap:var(--space-3);padding:var(--space-10)}.sd-modal-error,.sd-modal-loading{align-items:center;display:flex;font-size:var(--text-sm)}.sd-modal-error{background:color-mix(in srgb,var(--color-error) 10%,#0000);border-radius:var(--radius-lg);color:var(--color-error);gap:var(--space-2);padding:var(--space-3) var(--space-4)}.sd-modal-empty{color:var(--color-text-subtle);font-size:var(--text-sm);padding:var(--space-8);text-align:center}.sd-modal-summary{color:var(--color-text-muted);font-size:var(--text-sm);margin:0 0 var(--space-4) 0}.sd-modal-summary-lg{color:var(--color-text);font-size:var(--text-base);font-weight:var(--font-semibold)}.sd-modal-chart{display:flex;flex-direction:column;gap:var(--space-2);margin-bottom:var(--space-5)}.sd-chart-row{align-items:center;display:flex;gap:var(--space-3)}.sd-chart-label{color:var(--color-text-muted);flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-medium);text-align:right;width:100px}.sd-chart-bar-track{background:var(--gray-100);border-radius:var(--radius-full);flex:1 1;height:16px;overflow:hidden}.sd-chart-bar-fill{background:var(--gradient-primary);border-radius:var(--radius-full);height:100%;min-width:2px;transition:width .5s ease}.sd-chart-count{color:var(--color-text);flex-shrink:0;font-size:var(--text-xs);font-weight:var(--font-semibold);text-align:right;width:60px}.sd-modal-list{margin-top:var(--space-4)}.sd-modal-list-title{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;margin:0 0 var(--space-3) 0;text-transform:uppercase}.sd-modal-list-row{align-items:center;border-bottom:1px solid var(--color-border);display:flex;flex-wrap:wrap;font-size:var(--text-sm);gap:var(--space-3);padding:var(--space-2) var(--space-3)}.sd-modal-list-row:last-child{border-bottom:none}.sd-modal-list-row:hover{background:var(--color-surface-hover)}.sd-modal-list-row-col{align-items:flex-start;flex-direction:column;gap:var(--space-1);padding:var(--space-3)}.sd-modal-row-main{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.sd-modal-row-meta{align-items:center;color:var(--color-text-subtle);display:flex;font-size:var(--text-xs);gap:var(--space-3)}.sd-modal-id{color:var(--color-text-muted);font-family:var(--font-mono);font-size:var(--text-xs)}.sd-modal-date,.sd-modal-import{color:var(--color-text-subtle);font-size:var(--text-xs)}.sd-modal-date{margin-left:auto}.sd-modal-url{color:var(--color-text-muted);word-break:break-all}.sd-modal-error-preview,.sd-modal-url{font-family:var(--font-mono);font-size:var(--text-xs)}.sd-modal-error-preview{background:color-mix(in srgb,var(--color-error) 6%,#0000);border-radius:var(--radius-md);color:var(--color-error);padding:var(--space-2) var(--space-3);white-space:pre-wrap;width:100%;word-break:break-word}.sd-modal-priority-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fill,minmax(100px,1fr));margin:var(--space-4) 0}.sd-modal-priority-card{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-3);text-align:center}.sd-modal-priority-label{color:var(--color-text-subtle);display:block;font-size:var(--text-xs);font-weight:var(--font-semibold);margin-bottom:var(--space-1);text-transform:uppercase}.sd-modal-priority-count{color:var(--color-text);font-size:var(--text-lg);font-weight:var(--font-bold)}.sd-modal-analysis{background:color-mix(in srgb,var(--color-warning) 8%,#0000);border-radius:var(--radius-lg);color:var(--color-text-muted)}.sd-modal-analysis,.sd-modal-recommendation{font-size:var(--text-sm);margin-bottom:var(--space-3);padding:var(--space-3) var(--space-4)}.sd-modal-recommendation{align-items:flex-start;background:color-mix(in srgb,var(--color-warning) 12%,#0000);border:1px solid color-mix(in srgb,var(--color-warning) 25%,#0000);border-radius:var(--radius-lg);color:var(--color-warning-dark);display:flex;gap:var(--space-2)}.sd-modal-error-summary{border-bottom:1px solid var(--color-border);margin-bottom:var(--space-4);padding-bottom:var(--space-4)}.sd-modal-error-row{align-items:center;color:var(--color-text);display:flex;font-size:var(--text-sm);justify-content:space-between;padding:var(--space-1) 0}.sd-modal-detail-grid{grid-gap:var(--space-3);display:grid;gap:var(--space-3);grid-template-columns:1fr 1fr;margin-bottom:var(--space-5)}.sd-modal-detail-item{display:flex;flex-direction:column;gap:var(--space-1)}.sd-modal-detail-label{color:var(--color-text-subtle);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:.05em;text-transform:uppercase}.sd-modal-detail-section{margin-bottom:var(--space-4)}.sd-modal-pre{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-family:var(--font-mono);font-size:var(--text-xs);margin:0;max-height:300px;overflow-x:auto;overflow-y:auto;padding:var(--space-3);white-space:pre-wrap;word-break:break-word}.sd-modal-error-highlight{background:color-mix(in srgb,var(--color-error) 6%,#0000);border-color:color-mix(in srgb,var(--color-error) 20%,#0000);color:var(--color-error)}@media (max-width:480px){.sd-modal-panel{width:100vw}.sd-modal-detail-grid{grid-template-columns:1fr}.sd-chart-label{width:70px}}.sd-training-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);cursor:pointer;display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);transition:border-color var(--transition-fast),box-shadow var(--transition-fast)}.sd-training-card:hover{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,#0000)}.sd-training-card-header{align-items:center;display:flex;gap:var(--space-2)}.sd-training-icon{font-size:16px}.sd-training-title{color:var(--color-text);flex:1 1;font-size:var(--text-sm);font-weight:var(--font-semibold)}.sd-training-badge{background:color-mix(in srgb,#22c55e 15%,#0000);border:1px solid color-mix(in srgb,#22c55e 30%,#0000);border-radius:var(--radius-full);color:#16a34a;font-size:10px;font-weight:700;letter-spacing:.06em;padding:2px 7px;text-transform:uppercase}.sd-training-stat{color:var(--color-text);font-size:2rem;font-weight:800;line-height:1;margin-top:var(--space-1)}.sd-training-label{color:var(--color-text-muted);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase}.sd-training-breakdown{color:var(--color-text-subtle);display:flex;font-size:var(--text-xs);font-weight:var(--font-medium);gap:var(--space-4);margin-top:var(--space-1)}.sd-live-badge{border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--font-semibold);letter-spacing:0;margin-left:auto;padding:2px 10px;text-transform:none}.sd-live-idle{background:var(--gray-100);color:var(--color-text-subtle)}.sd-live-connecting{animation:sd-pulse-bg 1.5s ease-in-out infinite;background:color-mix(in srgb,var(--color-warning) 14%,#0000);color:var(--color-warning-dark)}.sd-live-live{animation:sd-pulse-bg 1.5s ease-in-out infinite}.sd-live-done,.sd-live-live{background:color-mix(in srgb,var(--color-success) 14%,#0000);color:var(--color-success-dark)}.sd-live-error{background:color-mix(in srgb,var(--color-error) 12%,#0000);color:var(--color-danger-dark)}@keyframes sd-pulse-bg{0%,to{opacity:1}50%{opacity:.6}}.sd-live-empty{align-items:center;color:var(--color-text-subtle);gap:var(--space-3);padding:var(--space-8)}.sd-live-empty,.sd-live-log{display:flex;flex-direction:column}.sd-live-log{gap:2px;max-height:320px;overflow-y:auto}.sd-live-entry{align-items:center;background:var(--color-surface-hover);border-left:3px solid var(--gray-200);border-radius:0 var(--radius-md) var(--radius-md) 0;display:flex;font-size:var(--text-sm);gap:var(--space-3);justify-content:space-between;padding:var(--space-2) var(--space-3)}.sd-live-type-status{border-left-color:var(--color-primary)}.sd-live-type-error{background:color-mix(in srgb,var(--color-error) 4%,var(--color-surface-hover));border-left-color:var(--color-error)}.sd-live-type-complete,.sd-live-type-result{border-left-color:var(--color-success)}.sd-live-type-log{border-left-color:var(--gray-300)}.sd-live-msg{flex:1 1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sd-live-time{font-feature-settings:"tnum";color:var(--color-text-subtle);flex-shrink:0;font-size:var(--text-xs);font-variant-numeric:tabular-nums}.sd-results-header{flex-wrap:wrap;justify-content:space-between;margin-bottom:var(--space-4)}.sd-results-header,.sd-results-meta{align-items:center;display:flex;gap:var(--space-3)}.sd-results-meta{color:var(--color-text-muted);font-size:var(--text-sm)}.sd-results-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.sd-results-table{min-width:600px;width:100%}@media (max-width:767px){.sd-results-table{min-width:0}.sd-results-table thead{display:none}.sd-results-table tbody tr{background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-lg);display:block;margin-bottom:var(--space-3);padding:var(--space-3)}.sd-results-table tbody td{border:none;display:flex;font-size:var(--text-sm);justify-content:space-between;padding:var(--space-1) 0}.sd-results-table tbody td:before{color:var(--color-text-subtle);content:attr(data-label);font-weight:var(--font-semibold);margin-right:var(--space-3)}}.sd-section-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:var(--space-4)}.sd-section-title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin:0}.sd-history-table-wrap{border:1px solid var(--color-border);border-radius:var(--radius-xl);overflow-x:auto}.sd-history-table{border-collapse:collapse;font-size:var(--text-sm);width:100%}.sd-history-table th{background:var(--color-surface-raised);color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.05em;padding:10px 14px;text-align:left;text-transform:uppercase;white-space:nowrap}.sd-history-table td,.sd-history-table th{border-bottom:1px solid var(--color-border)}.sd-history-table td{padding:12px 14px;vertical-align:middle}.sd-history-row:last-child td{border-bottom:none}.sd-history-row:hover{background:color-mix(in srgb,var(--color-primary) 4%,#0000);background:var(--color-surface-hover,color-mix(in srgb,var(--color-primary) 4%,#0000))}.sd-history-row--expanded{background:var(--color-surface-raised)}.sd-history-detail-row td{border-bottom:1px solid var(--color-border);padding:0}.sd-supplier-detail{background:var(--color-surface-raised);padding:var(--space-4)}.sd-supplier-stats{color:var(--color-text-muted);display:flex;flex-wrap:wrap;font-size:var(--text-sm);gap:var(--space-3) var(--space-5);margin-bottom:var(--space-4)}.sd-supplier-table{border-collapse:collapse;font-size:13px;width:100%}.sd-supplier-table th{color:var(--color-text-muted);font-size:11px;font-weight:600;letter-spacing:.04em;text-align:left;text-transform:uppercase}.sd-supplier-table td,.sd-supplier-table th{border-bottom:1px solid var(--color-border);padding:8px 10px}.sd-supplier-table tr:last-child td{border-bottom:none}.sd-status-chip{border-radius:var(--radius-full);display:inline-block;font-size:11px;font-weight:700;letter-spacing:.05em;padding:2px 10px;text-transform:uppercase}.sd-status-success{background:color-mix(in srgb,#22c55e 15%,#0000);color:#16a34a}.sd-status-error,.sd-status-failed{background:color-mix(in srgb,#ef4444 15%,#0000);color:#dc2626}.sd-status-running{background:color-mix(in srgb,#3b82f6 15%,#0000);color:#2563eb}.sd-dept-chip{color:var(--color-text-muted)}.sd-dept-chip,.sd-save-badge{font-size:12px;font-weight:600}.sd-save-badge{border-radius:var(--radius-full);display:inline-block;padding:2px 8px}.sd-save-badge--full{background:color-mix(in srgb,#22c55e 15%,#0000);color:#16a34a}.sd-save-badge--partial{background:color-mix(in srgb,#f59e0b 15%,#0000);color:#d97706}.sd-save-badge--none{background:color-mix(in srgb,#ef4444 15%,#0000);color:#dc2626}.sd-btn-expand{background:none;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;font-size:11px;padding:4px 8px}.sd-btn-expand:hover{border-color:var(--color-primary);color:var(--color-primary)}.sd-loading-suppliers{padding:var(--space-4)}.sd-empty-state,.sd-loading-suppliers{color:var(--color-text-muted);font-size:var(--text-sm)}@media (max-width:767px){.sd-history-table thead{display:none}.sd-history-row,.sd-history-table,.sd-history-table tbody,.sd-history-table td{display:block}.sd-history-row{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);margin-bottom:10px;padding:4px 0}.sd-history-table td{border-bottom:1px solid var(--color-border);display:flex;font-size:13px;justify-content:space-between;padding:8px 14px}.sd-history-table td:last-child{border-bottom:none}.sd-history-table td:before{color:var(--color-text-muted);content:attr(data-label);flex-shrink:0;font-size:11px;font-weight:600;letter-spacing:.05em;margin-right:12px;text-transform:uppercase}.sd-supplier-table thead{display:none}.sd-supplier-table,.sd-supplier-table tbody,.sd-supplier-table td,.sd-supplier-table tr{display:block}.sd-supplier-table tr{border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:8px}.sd-supplier-table td{border-bottom:1px solid var(--color-border);display:flex;font-size:12px;justify-content:space-between;padding:7px 12px}.sd-supplier-table td:last-child{border-bottom:none}.sd-supplier-table td:before{color:var(--color-text-muted);content:attr(data-label);flex-shrink:0;font-size:10px;font-weight:600;margin-right:10px;text-transform:uppercase}}.sd-canary-info{background:#06b6d414;border:1px solid #06b6d433;border-radius:var(--radius-md);color:var(--color-text-muted);font-size:.8125rem;line-height:1.5;padding:.75rem 1rem}.sd-files-list{display:flex;flex-direction:column;gap:.25rem}.sd-file-item{align-items:center;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);display:flex;gap:.625rem;padding:.5rem .75rem;transition:background .1s ease}.sd-file-item:hover{background:var(--color-surface-hover)}.sd-file-icon{color:var(--color-text-subtle);flex-shrink:0}.sd-file-info{display:flex;flex:1 1;flex-direction:column;gap:.125rem;min-width:0}.sd-file-name{color:var(--color-text);font-size:.8125rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sd-file-meta{color:var(--color-text-subtle);font-size:.6875rem}.sd-cfg-container{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);overflow:hidden}.sd-cfg-header{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);flex-wrap:wrap;gap:var(--space-3);justify-content:space-between;padding:var(--space-3) var(--space-4)}.sd-cfg-header,.sd-cfg-title{align-items:center;display:flex}.sd-cfg-title{gap:var(--space-2)}.sd-cfg-title h4{color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);margin:0}.sd-cfg-count{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-full);color:var(--color-text-subtle);font-size:var(--text-xs);padding:.125rem .5rem}.sd-cfg-actions{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-2)}.sd-cfg-search{font-size:var(--text-xs);padding:.375rem .625rem;width:160px}@media (max-width:600px){.sd-cfg-search{order:10;width:100%}}.sd-cfg-colsel{background:var(--color-surface);border-bottom:1px solid var(--color-border);padding:var(--space-3) var(--space-4)}.sd-cfg-colsel-header{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-xs);font-weight:var(--font-medium);justify-content:space-between;margin-bottom:var(--space-2)}.sd-cfg-collist{display:flex;flex-wrap:wrap;gap:var(--space-2)}.sd-cfg-colitem{align-items:center;background:var(--color-surface-hover);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text);cursor:pointer;display:flex;font-size:var(--text-xs);gap:var(--space-1);padding:.25rem .5rem;transition:all .15s ease}.sd-cfg-colitem:hover{border-color:var(--color-primary)}.sd-cfg-colitem input[type=checkbox]{cursor:pointer;height:12px;width:12px}.sd-cfg-default{color:var(--color-text-subtle);font-size:.625rem;margin-left:var(--space-1)}.sd-cfg-stats{align-items:center;background:var(--color-surface);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);display:flex;flex-wrap:wrap;font-size:var(--text-xs);gap:var(--space-4);padding:var(--space-2) var(--space-4)}.sd-cfg-stats strong{color:var(--color-text);font-weight:var(--font-semibold)}.sd-cfg-table-wrapper{max-height:400px;overflow-x:auto;overflow-y:auto}.sd-cfg-table{border-collapse:collapse;font-size:var(--text-xs);width:100%}.sd-cfg-table thead{position:sticky;top:0;z-index:1}.sd-cfg-table th{background:var(--color-surface-hover);border-bottom:1px solid var(--color-border);color:var(--color-text-muted);font-weight:var(--font-medium);padding:var(--space-2) var(--space-3);text-align:left;white-space:nowrap}.sd-cfg-sortable{cursor:pointer;transition:background .15s ease;-webkit-user-select:none;user-select:none}.sd-cfg-sortable:hover{background:var(--color-surface)}.sd-cfg-sortable span{align-items:center;display:inline-flex;gap:var(--space-1)}.sd-cfg-table td{border-bottom:1px solid var(--color-border);color:var(--color-text);max-width:250px;overflow:hidden;padding:var(--space-2) var(--space-3);text-overflow:ellipsis;white-space:nowrap}.sd-cfg-table tbody tr:hover{background:var(--color-surface-hover)}.sd-cfg-table tbody tr:last-child td{border-bottom:none}.sd-cfg-empty{color:var(--color-text-subtle);font-size:var(--text-sm);padding:var(--space-8);text-align:center}.sd-btn-active{background:var(--color-primary)!important;border-color:var(--color-primary)!important;color:#fff!important}.sd-btn-xs{font-size:.625rem;padding:.125rem .375rem}.sd-section,.sd-section *{max-width:100%}@media (max-width:767px){.sd-history-detail-row{display:block}.sd-history-detail-row td{box-sizing:border-box;display:block;width:100%}.sd-supplier-detail{overflow-x:hidden;padding:var(--space-3)}.sd-supplier-stats{gap:var(--space-2)}.sd-timeframe-pills{-webkit-overflow-scrolling:touch;flex-wrap:nowrap;overflow-x:auto;padding-bottom:4px}.sd-queues-grid{grid-template-columns:1fr!important}.sd-modal-panel{max-width:100vw!important;width:100vw!important}.sd-btn-trigger{width:100%}.sd-form-summary{flex-wrap:wrap;max-width:100%}.sd-section-header,.sd-section-header-row{flex-wrap:wrap;gap:var(--space-2)}.sd-header{align-items:flex-start;flex-direction:column;gap:var(--space-2)}.sd-header-right{flex-wrap:wrap;justify-content:flex-start;width:100%}.sd-history-table td:last-child:before{display:none}.sd-history-table td:last-child{border-bottom:none;justify-content:flex-end}}@media (max-width:390px){.sd-container{padding:var(--space-3)}.sd-metrics-grid{grid-template-columns:1fr!important}.sd-metric-value{font-size:var(--text-lg)}.sd-pill{font-size:11px;height:34px;min-width:40px;padding:0 var(--space-3)}.sd-section{padding:var(--space-4)}}.scrape-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);padding:var(--space-4)}.scrape-card__result{align-items:center;border-radius:var(--radius-md);display:flex;font-size:var(--text-sm);gap:var(--space-2);margin-top:var(--space-3);padding:var(--space-2) var(--space-3)}.scrape-card__result.is-success{background:color-mix(in srgb,var(--color-success) 10%,#0000);color:var(--color-success-dark)}.scrape-card__result.is-error{background:color-mix(in srgb,var(--color-error) 10%,#0000);color:var(--color-error)}.scrape-form{align-items:center;display:flex;flex-wrap:wrap;gap:var(--space-3)}.scrape-form__hint{color:var(--color-text-muted);flex:1 1;font-size:var(--text-sm);margin:0}.scrape-form__source{background:var(--color-surface-hover);border-radius:var(--radius-md);display:flex;padding:2px}.scrape-form__source-btn{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);padding:6px 12px;transition:all .15s ease}.scrape-form__source-btn:hover{color:var(--color-text)}.scrape-form__source-btn.is-active{background:var(--color-surface);box-shadow:0 1px 2px #0000001a;color:var(--color-text)}.scrape-form__controls{align-items:center;display:flex;flex:1 1;flex-wrap:wrap;gap:var(--space-3)}.scrape-form__presets{background:var(--color-surface-hover);border-radius:var(--radius-md);display:flex;padding:2px}.scrape-form__preset{background:#0000;border:none;border-radius:var(--radius-sm);color:var(--color-text-muted);cursor:pointer;font-family:var(--font-sans);font-size:11px;font-weight:var(--font-medium);padding:4px 8px;transition:all .15s ease}.scrape-form__preset:hover{color:var(--color-text)}.scrape-form__preset.is-active{background:var(--color-primary);color:#fff}.scrape-form__dates{align-items:center;display:flex;gap:6px}.scrape-form__dates span{color:var(--color-text-subtle);font-size:var(--text-sm)}.scrape-form__dates input{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);color-scheme:dark;font-family:var(--font-sans);font-size:var(--text-sm);height:30px;outline:none;padding:0 8px;width:120px}.scrape-form__dates input:focus{border-color:var(--color-primary)}.scrape-form__dates input::-webkit-calendar-picker-indicator{cursor:pointer;filter:invert(.7);opacity:.6}.scrape-form__filters{display:flex;gap:6px}.scrape-form__filters select,.scrape-form__supplier{appearance:none;background:var(--color-surface);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='10' height='10' viewBox='0 0 24 24' fill='none' stroke='%2371717a' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;font-family:var(--font-sans);font-size:var(--text-sm);height:30px;outline:none;padding:0 24px 0 10px}.scrape-form__filters select:focus,.scrape-form__supplier:focus{border-color:var(--color-primary)}.scrape-form__supplier{background-image:none;min-width:100px;padding-right:10px}.scrape-form__submit{align-items:center;background:var(--color-primary);border:none;border-radius:var(--radius-md);color:#fff;cursor:pointer;display:inline-flex;font-family:var(--font-sans);font-size:var(--text-sm);font-weight:var(--font-medium);gap:6px;height:30px;padding:0 14px;transition:background .15s ease;white-space:nowrap}.scrape-form__submit:hover{background:var(--color-primary-dark)}.scrape-form__submit:disabled{cursor:not-allowed;opacity:.6}@media (max-width:768px){.scrape-form,.scrape-form__controls{align-items:stretch;flex-direction:column}.scrape-form__presets{justify-content:center;width:100%}.scrape-form__dates{width:100%}.scrape-form__dates input{flex:1 1}.scrape-form__filters{width:100%}.scrape-form__filters select{flex:1 1}.scrape-form__submit{height:36px;justify-content:center;width:100%}}.sd-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-lg);margin-bottom:var(--space-4);padding:var(--space-5)}.sd-select:hover{border-color:var(--color-border-hover)}.sd-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px color-mix(in srgb,var(--color-primary) 12%,#0000)}.sd-alert{align-items:center;border-radius:var(--radius-md);display:flex;font-size:var(--text-sm);gap:var(--space-2);margin-top:var(--space-4);padding:var(--space-3) var(--space-4)}.sd-alert-success{background:color-mix(in srgb,var(--color-success) 10%,#0000);border:1px solid color-mix(in srgb,var(--color-success) 25%,#0000);color:var(--color-success-dark)}.sd-alert-error{background:color-mix(in srgb,var(--color-error) 10%,#0000);border:1px solid color-mix(in srgb,var(--color-error) 25%,#0000);color:var(--color-error)}@media (max-width:640px){.sd-form-row{align-items:stretch;flex-direction:column;gap:var(--space-2)}.sd-label{min-width:auto}.sd-inline-group{flex-wrap:wrap}.sd-input,.sd-select{width:100%}}.sd-history-cards{display:flex;flex-direction:column;gap:var(--space-3)}.sd-history-more{background:var(--color-surface-hover);border-radius:var(--radius-md);color:var(--color-text-subtle);font-size:var(--text-sm);padding:var(--space-3);text-align:center}.sd-loading-inline{align-items:center;color:var(--color-text-muted);display:flex;font-size:var(--text-sm);gap:var(--space-2);padding:var(--space-4)}.sd-empty-state{align-items:center;color:var(--color-text-subtle);display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-8);text-align:center}.sd-empty-state p{font-size:var(--text-sm);margin:0}.sd-training-summary{align-items:center;background:var(--color-surface-hover);border-radius:var(--radius-lg);cursor:pointer;display:flex;justify-content:space-between;padding:var(--space-4);transition:background .15s ease}.sd-training-summary:hover{background:var(--color-surface)}.sd-training-stat-grid{display:flex;gap:var(--space-6)}.sd-training-stat-item{display:flex;flex-direction:column;gap:var(--space-1)}.sd-training-stat-value{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-bold)}.sd-training-stat-label{color:var(--color-text-subtle);font-size:var(--text-xs);letter-spacing:.05em;text-transform:uppercase}@media (max-width:600px){.sd-training-summary{align-items:flex-start;flex-direction:column;gap:var(--space-3)}.sd-training-stat-grid{gap:var(--space-4)}.sd-training-stat-value{font-size:var(--text-lg)}}.not-found-page{align-items:center;background:#09090b;background:var(--color-background,#09090b);display:flex;justify-content:center;min-height:100vh;padding:24px}.not-found-content{max-width:420px;text-align:center}.not-found-code{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#06b6d4);-webkit-background-clip:text;background-clip:text;font-size:120px;font-weight:800;letter-spacing:-.04em;line-height:1;margin-bottom:16px}.not-found-title{color:#fafafa;color:var(--color-text,#fafafa);font-size:24px;font-weight:700;margin:0 0 8px}.not-found-text{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:15px;line-height:1.5;margin:0 0 32px}.not-found-actions{align-items:center;display:flex;gap:12px;justify-content:center}.not-found-btn-primary{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border:none;border-radius:10px;color:#fff;cursor:pointer;display:inline-flex;font-size:14px;font-weight:600;gap:8px;padding:12px 24px;transition:all .2s ease}.not-found-btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px)}.not-found-btn-ghost{align-items:center;background:#0000;border:1px solid #ffffff1a;border-radius:10px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:inline-flex;font-size:14px;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s ease}.not-found-btn-ghost:hover{border-color:#fff3;color:#fafafa;color:var(--color-text,#fafafa)}@media (max-width:480px){.not-found-code{font-size:80px}.not-found-actions{flex-direction:column}.not-found-actions button{justify-content:center;width:100%}}.welcome-empty{align-items:center;display:flex;justify-content:center;min-height:100%;padding:40px 24px}.welcome-empty-inner{max-width:600px;width:100%}.welcome-empty-header{margin-bottom:40px;text-align:center}.welcome-empty-title{color:#fafafa;color:var(--color-text,#fafafa);font-size:28px;font-weight:700;letter-spacing:-.02em;margin:0 0 8px}.welcome-empty-subtitle{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:15px;line-height:1.5;margin:0}.welcome-steps{display:flex;flex-direction:column;gap:12px}.welcome-step{align-items:center;background:#ffffff08;border:1px solid #ffffff0f;border-radius:14px;color:inherit;cursor:pointer;display:flex;font-family:inherit;gap:16px;padding:20px;text-align:left;transition:all .2s ease;width:100%}.welcome-step:hover:not(.welcome-step-disabled){background:#ffffff0f;border-color:#ffffff1f;transform:translateX(4px)}.welcome-step-disabled{cursor:default;opacity:.5}.welcome-step-number{align-items:center;background:#ffffff0f;border-radius:50%;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);display:flex;flex-shrink:0;font-size:13px;font-weight:700;height:28px;justify-content:center;width:28px}.welcome-step:hover:not(.welcome-step-disabled) .welcome-step-number{background:#3b82f626;color:#60a5fa}.welcome-step-icon{align-items:center;border-radius:12px;display:flex;flex-shrink:0;height:44px;justify-content:center;width:44px}.welcome-step-content{flex:1 1;min-width:0}.welcome-step-content h3{color:#fafafa;color:var(--color-text,#fafafa);font-size:15px;font-weight:600;margin:0 0 4px}.welcome-step-content p{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:13px;line-height:1.4;margin:0}.welcome-step-arrow{color:#71717a;color:var(--color-text-muted,#71717a);flex-shrink:0;opacity:0;transform:translateX(-4px);transition:all .2s ease}.welcome-step:hover:not(.welcome-step-disabled) .welcome-step-arrow{opacity:1;transform:translateX(0)}@media (max-width:480px){.welcome-empty{align-items:flex-start;padding:24px 16px}.welcome-empty-title{font-size:24px}.welcome-step{gap:12px;padding:16px}.welcome-step-icon{height:36px;width:36px}}.session-expired-toast{align-items:center;background:#18181b;background:var(--color-surface,#18181b);border:1px solid #ef44444d;border-radius:12px;box-shadow:0 8px 24px #0000004d;display:flex;gap:12px;max-width:400px;opacity:0;padding:14px 16px;pointer-events:none;position:fixed;right:20px;top:20px;transform:translateY(-12px) scale(.96);transition:all .2s ease;z-index:99999}.session-expired-toast.visible{opacity:1;pointer-events:auto;transform:translateY(0) scale(1)}.session-expired-icon{color:#ef4444;display:flex;flex-shrink:0}.session-expired-content{flex:1 1;min-width:0}.session-expired-title{color:#fafafa;color:var(--color-text,#fafafa);font-size:14px;font-weight:600;margin:0}.session-expired-text{color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);font-size:13px;margin:2px 0 0}.session-expired-login{background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary,linear-gradient(135deg,#3b82f6,#2563eb));border:none;border-radius:8px;color:#fff;cursor:pointer;flex-shrink:0;font-size:13px;font-weight:600;padding:6px 14px;transition:filter .15s;white-space:nowrap}.session-expired-login:hover{filter:brightness(1.1)}.session-expired-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;flex-shrink:0;justify-content:center;padding:4px;transition:all .15s}.session-expired-close:hover{background:#ffffff0d;color:#fafafa;color:var(--color-text,#fafafa)}@media (max-width:480px){.session-expired-toast{bottom:20px;left:16px;max-width:none;right:16px;top:auto}}.breadcrumbs{background:#18181b;background:var(--color-surface,#18181b);border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border,#ffffff0f);flex-shrink:0;padding:8px 24px}.breadcrumbs-list{flex-wrap:wrap;list-style:none;margin:0;padding:0}.breadcrumbs-item,.breadcrumbs-list{align-items:center;display:flex;gap:4px}.breadcrumbs-separator{color:#71717a;color:var(--color-text-muted,#71717a);flex-shrink:0}.breadcrumbs-link{align-items:center;background:#0000;border:none;border-radius:6px;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;font-family:inherit;font-size:13px;gap:5px;padding:4px 8px;transition:all .15s;white-space:nowrap}.breadcrumbs-link:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d)}.breadcrumbs-current,.breadcrumbs-link:hover{color:#fafafa;color:var(--color-text,#fafafa)}.breadcrumbs-current{align-items:center;display:flex;font-size:13px;font-weight:600;gap:5px;padding:4px 8px;white-space:nowrap}@media (max-width:768px){.breadcrumbs{padding:6px 16px}.breadcrumbs-current,.breadcrumbs-link{font-size:12px;padding:3px 6px}}.help-button-container{bottom:24px;position:fixed;right:24px;z-index:900}.help-fab{align-items:center;background:#18181b;background:var(--color-surface,#18181b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:50%;box-shadow:0 4px 12px #0003;color:#a1a1aa;color:var(--color-text-muted,#a1a1aa);cursor:pointer;display:flex;height:44px;justify-content:center;transition:all .2s ease;width:44px}.help-fab:hover{border-color:#fff3;color:#fafafa;color:var(--color-text,#fafafa);transform:scale(1.05)}.help-fab.open{background:#3b82f6;background:var(--color-primary,#3b82f6);border-color:#0000;color:#fff}.help-menu{animation:helpSlideUp .2s ease-out;background:#18181b;background:var(--color-surface,#18181b);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:16px;bottom:calc(100% + 12px);box-shadow:0 12px 32px #0000004d;overflow:hidden;position:absolute;right:0;width:280px}@keyframes helpSlideUp{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.help-menu-header{border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--color-border,#ffffff0f);color:#fafafa;color:var(--color-text,#fafafa);font-size:14px;font-weight:600;padding:14px 16px}.help-menu-item{align-items:center;color:inherit;cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-decoration:none;transition:background .15s}.help-menu-item:hover{background:#ffffff0d;background:var(--color-surface-hover,#ffffff0d)}.help-menu-item-icon{align-items:center;border-radius:10px;display:flex;flex-shrink:0;height:36px;justify-content:center;width:36px}.help-menu-item-content{display:flex;flex:1 1;flex-direction:column;min-width:0}.help-menu-item-title{color:#fafafa;color:var(--color-text,#fafafa);font-size:14px;font-weight:500}.help-menu-item-desc{font-size:12px}.help-menu-item-desc,.help-menu-item-external{color:#71717a;color:var(--color-text-muted,#71717a)}.help-menu-item-external{flex-shrink:0}.help-menu-footer{border-top:1px solid #ffffff0f;border-top:1px solid var(--color-border,#ffffff0f);color:#71717a;color:var(--color-text-muted,#71717a);font-size:12px;padding:10px 16px;text-align:center}.help-menu-footer kbd{background:#ffffff0f;border:1px solid #ffffff1a;border-radius:4px;font-family:inherit;font-size:11px;padding:2px 6px}@media (max-width:768px){.help-button-container{bottom:16px;right:16px}}.sidebar-overlay.visible~.help-button-container{display:none}.dga-dashboard{margin:0 auto;max-width:1600px;min-height:calc(100vh - 120px);padding:24px}.dga-header{align-items:flex-start;border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);display:flex;justify-content:space-between;margin-bottom:24px;padding-bottom:16px}.dga-header-left{align-items:center;display:flex;gap:16px}.dga-header-left svg{color:#6366f1;color:var(--color-primary,#6366f1);flex-shrink:0}.dga-header-left h1{color:#fff;color:var(--color-text-primary,#fff);font-size:1.75rem;font-weight:600;margin:0}.dga-header-left p{color:#888;color:var(--color-text-secondary,#888);font-size:.875rem;margin:4px 0 0}.dga-header-actions{display:flex;gap:8px}.dga-btn{align-items:center;border:none;border-radius:6px;cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:6px;justify-content:center;padding:8px 16px;transition:all .15s ease}.dga-btn-primary{background:#6366f1;background:var(--color-primary,#6366f1);color:#fff}.dga-btn-primary:hover{background:#5558e3;background:var(--color-primary-hover,#5558e3)}.dga-btn-secondary{background:#2a2a2a;background:var(--color-bg-secondary,#2a2a2a);border:1px solid #333;border:1px solid var(--color-border,#333);color:#fff;color:var(--color-text-primary,#fff)}.dga-btn-secondary:hover{background:#333;background:var(--color-bg-hover,#333)}.dga-btn-ghost{background:#0000;color:#888;color:var(--color-text-secondary,#888);padding:8px}.dga-btn-ghost:hover{background:#333;background:var(--color-bg-hover,#333);color:#fff;color:var(--color-text-primary,#fff)}.dga-btn-sm{font-size:.8125rem;padding:6px 12px}.dga-btn-icon{background:#0000;border:none;border-radius:4px;color:#888;color:var(--color-text-secondary,#888);cursor:pointer;padding:4px;transition:all .15s}.dga-btn-icon:hover{background:#333;background:var(--color-bg-hover,#333);color:#fff;color:var(--color-text-primary,#fff)}.dga-btn:disabled{cursor:not-allowed;opacity:.5}.dga-spin{animation:dga-spin 1s linear infinite}@keyframes dga-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.dga-stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));margin-bottom:24px}.dga-stat-card{align-items:flex-start;background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;display:flex;gap:12px;padding:16px}.dga-stat-card.dga-stat-warning{background:#f59e0b0d;border-color:#f59e0b;border-color:var(--color-warning,#f59e0b)}.dga-stat-icon{align-items:center;background:#252525;background:var(--color-bg-tertiary,#252525);border-radius:8px;color:#6366f1;color:var(--color-primary,#6366f1);display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.dga-stat-content{display:flex;flex-direction:column;min-width:0}.dga-stat-value{color:#fff;color:var(--color-text-primary,#fff);font-size:1.5rem;font-weight:600;line-height:1.2}.dga-stat-label{color:#888;color:var(--color-text-secondary,#888);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.dga-stat-sub{color:#666;color:var(--color-text-tertiary,#666);font-size:.8125rem;margin-top:2px}.dga-stat-trend{align-items:center;border-radius:4px;display:flex;font-size:.75rem;font-weight:500;gap:2px;margin-left:auto;padding:2px 6px}.dga-stat-trend.positive{background:#10b9811a;color:#10b981;color:var(--color-success,#10b981)}.dga-stat-trend.negative{background:#ef44441a;color:#ef4444;color:var(--color-error,#ef4444)}.dga-tabs{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border-radius:8px;display:flex;gap:4px;margin-bottom:24px;padding:4px;width:fit-content}.dga-tab{align-items:center;background:#0000;border:none;border-radius:6px;color:#888;color:var(--color-text-secondary,#888);cursor:pointer;display:flex;font-size:.875rem;font-weight:500;gap:6px;padding:10px 16px;transition:all .15s}.dga-tab:hover{background:#252525;background:var(--color-bg-hover,#252525)}.dga-tab.active,.dga-tab:hover{color:#fff;color:var(--color-text-primary,#fff)}.dga-tab.active{background:#333;background:var(--color-bg-tertiary,#333)}.dga-tab-badge{background:#ef4444;background:var(--color-error,#ef4444);border-radius:10px;color:#fff;font-size:.6875rem;font-weight:600;min-width:18px;padding:2px 6px;text-align:center}.dga-freshness-summary{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;margin-bottom:20px;padding:20px}.dga-freshness-summary h3{color:#fff;color:var(--color-text-primary,#fff);font-size:.875rem;font-weight:600;margin:0 0 16px}.dga-freshness-bars{background:#252525;background:var(--color-bg-tertiary,#252525);border-radius:6px;display:flex;height:24px;overflow:hidden}.dga-freshness-segment{min-width:4px;transition:flex .3s ease}.dga-freshness-legend{display:flex;flex-wrap:wrap;gap:16px;margin-top:12px}.dga-legend-item{align-items:center;color:#888;color:var(--color-text-secondary,#888);display:flex;font-size:.8125rem;gap:6px}.dga-legend-dot{border-radius:2px;height:10px;width:10px}.dga-status-current,.dga-status-current .dga-legend-dot{background-color:#10b981;background-color:var(--color-success,#10b981)}.dga-status-aging,.dga-status-aging .dga-legend-dot{background-color:#f59e0b;background-color:var(--color-warning,#f59e0b)}.dga-status-stale,.dga-status-stale .dga-legend-dot{background-color:#f97316;background-color:var(--color-orange,#f97316)}.dga-status-very-stale,.dga-status-very-stale .dga-legend-dot{background-color:#ef4444;background-color:var(--color-error,#ef4444)}.dga-status-no-data,.dga-status-no-data .dga-legend-dot{background-color:#666;background-color:var(--color-text-tertiary,#666)}.dga-filters{justify-content:space-between;margin-bottom:16px}.dga-filter-group,.dga-filters{align-items:center;display:flex}.dga-filter-group{color:#888;color:var(--color-text-secondary,#888);gap:8px}.dga-filter-select{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:6px;color:#fff;color:var(--color-text-primary,#fff);cursor:pointer;font-size:.875rem;padding:8px 12px}.dga-filter-select:focus{border-color:#6366f1;border-color:var(--color-primary,#6366f1);outline:none}.dga-filter-count{color:#666;color:var(--color-text-tertiary,#666);font-size:.8125rem}.dga-table-wrapper{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-radius:12px;overflow:hidden}.dga-coverage-table{border-collapse:collapse;width:100%}.dga-coverage-table th{background:#252525;background:var(--color-bg-tertiary,#252525);border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);color:#888;color:var(--color-text-secondary,#888);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:14px 16px;text-align:left;text-transform:uppercase}.dga-coverage-table th.dga-sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.dga-coverage-table th.dga-sortable:hover{color:#fff;color:var(--color-text-primary,#fff)}.dga-sort-indicator{margin-left:4px;opacity:.7}.dga-coverage-table td{border-bottom:1px solid #333;border-bottom:1px solid var(--color-border,#333);color:#fff;color:var(--color-text-primary,#fff);font-size:.875rem;padding:14px 16px}.dga-coverage-row{cursor:pointer;transition:background .15s}.dga-coverage-row:hover{background:#252525;background:var(--color-bg-hover,#252525)}.dga-coverage-row.dga-status-no-data{opacity:.7}.dga-dept-cell{min-width:200px}.dga-dept-info{align-items:center;display:flex;gap:10px}.dga-dept-acronym{background:#6366f11a;border-radius:4px;color:#6366f1;color:var(--color-primary,#6366f1);font-size:.75rem;font-weight:600;min-width:48px;padding:4px 8px;text-align:center}.dga-dept-name{color:#fff;color:var(--color-text-primary,#fff);max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dga-coverage-cell{min-width:150px}.dga-coverage-bar-wrapper{align-items:center;display:flex;gap:8px}.dga-coverage-bar{background:#6366f1;background:var(--color-primary,#6366f1);border-radius:4px;height:8px;max-width:100px;transition:width .3s ease}.dga-coverage-pct{color:#888;color:var(--color-text-secondary,#888);font-size:.8125rem;min-width:40px}.dga-status-badge{border-radius:12px;display:inline-block;font-size:.75rem;font-weight:500;padding:4px 10px;text-transform:capitalize}.dga-status-badge.dga-status-current{background:#10b98126;color:#10b981;color:var(--color-success,#10b981)}.dga-status-badge.dga-status-aging{background:#f59e0b26;color:#f59e0b;color:var(--color-warning,#f59e0b)}.dga-status-badge.dga-status-stale{background:#f9731626;color:#f97316;color:var(--color-orange,#f97316)}.dga-status-badge.dga-status-very-stale{background:#ef444426;color:#ef4444;color:var(--color-error,#ef4444)}.dga-status-badge.dga-status-no-data{background:#66666626;color:#666;color:var(--color-text-tertiary,#666)}.dga-expanded-row td{background:#1f1f1f;background:var(--color-bg-tertiary,#1f1f1f);padding:0}.dga-expanded-content{align-items:center;display:flex;gap:24px;justify-content:space-between;padding:16px 24px}.dga-expanded-stats{display:flex;gap:32px}.dga-expanded-stat{display:flex;flex-direction:column;gap:4px}.dga-expanded-label{color:#666;color:var(--color-text-tertiary,#666);font-size:.6875rem;letter-spacing:.05em;text-transform:uppercase}.dga-expanded-value{color:#fff;color:var(--color-text-primary,#fff);font-size:.875rem}.dga-expanded-actions{display:flex;gap:8px}.dga-gap-stats{display:flex;gap:16px;margin-bottom:24px}.dga-gap-stat{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-left-width:4px;border-radius:12px;flex:1 1;padding:20px;text-align:center}.dga-gap-stat.dga-severity-critical{border-left-color:#ef4444;border-left-color:var(--color-error,#ef4444)}.dga-gap-stat.dga-severity-high{border-left-color:#f97316;border-left-color:var(--color-orange,#f97316)}.dga-gap-stat.dga-severity-medium{border-left-color:#f59e0b;border-left-color:var(--color-warning,#f59e0b)}.dga-gap-stat.dga-severity-low{border-left-color:#10b981;border-left-color:var(--color-success,#10b981)}.dga-gap-stat-value{color:#fff;color:var(--color-text-primary,#fff);display:block;font-size:2rem;font-weight:600}.dga-gap-stat-label{color:#888;color:var(--color-text-secondary,#888);font-size:.75rem;letter-spacing:.05em;text-transform:uppercase}.dga-gaps-list{grid-gap:12px;display:grid;gap:12px}.dga-gap-card{background:#1a1a1a;background:var(--color-bg-secondary,#1a1a1a);border:1px solid #333;border:1px solid var(--color-border,#333);border-left-width:4px;border-radius:12px;padding:16px 20px}.dga-gap-card.dga-severity-critical{border-left-color:#ef4444;border-left-color:var(--color-error,#ef4444)}.dga-gap-card.dga-severity-high{border-left-color:#f97316;border-left-color:var(--color-orange,#f97316)}.dga-gap-card.dga-severity-medium{border-left-color:#f59e0b;border-left-color:var(--color-warning,#f59e0b)}.dga-gap-card.dga-severity-low{border-left-color:#10b981;border-left-color:var(--color-success,#10b981)}.dga-gap-header{justify-content:space-between;margin-bottom:12px}.dga-gap-dept,.dga-gap-header{align-items:center;display:flex}.dga-gap-dept{gap:10px}.dga-gap-acronym{background:#6366f11a;border-radius:4px;color:#6366f1;color:var(--color-primary,#6366f1);font-size:.75rem;font-weight:600;padding:4px 8px}.dga-gap-name{color:#fff;color:var(--color-text-primary,#fff);font-weight:500}.dga-severity-badge{border-radius:12px;font-size:.6875rem;font-weight:600;padding:4px 10px;text-transform:uppercase}.dga-severity-badge.dga-severity-critical{background:#ef444426;color:#ef4444;color:var(--color-error,#ef4444)}.dga-severity-badge.dga-severity-high{background:#f9731626;color:#f97316;color:var(--color-orange,#f97316)}.dga-severity-badge.dga-severity-medium{background:#f59e0b26;color:#f59e0b;color:var(--color-warning,#f59e0b)}.dga-severity-badge.dga-severity-low{background:#10b98126;color:#10b981;color:var(--color-success,#10b981)}.dga-gap-body{display:flex;flex-wrap:wrap;gap:16px;margin-bottom:12px}.dga-gap-dates{align-items:center;color:#888;color:var(--color-text-secondary,#888);display:flex;font-size:.8125rem;gap:6px}.dga-gap-days{color:#666;color:var(--color-text-tertiary,#666)}.dga-gap-type{align-items:center;display:flex;gap:8px}.dga-gap-type-label{color:#888;color:var(--color-text-secondary,#888);font-size:.8125rem;text-transform:capitalize}.dga-gap-estimate{color:#666;color:var(--color-text-tertiary,#666);font-size:.8125rem}.dga-gap-actions{display:flex;justify-content:flex-end}.dga-empty-state{color:#888;color:var(--color-text-secondary,#888);padding:60px 20px;text-align:center}.dga-empty-state svg{color:#10b981;color:var(--color-success,#10b981);margin-bottom:16px}.dga-empty-state h3{color:#fff;color:var(--color-text-primary,#fff);font-size:1.25rem;font-weight:600;margin:0 0 8px}.dga-empty-state p{font-size:.875rem;margin:0}.dga-empty,.dga-empty-state p{color:#666;color:var(--color-text-tertiary,#666)}.dga-empty{padding:40px;text-align:center}.dga-error{align-items:center;color:#ef4444;color:var(--color-error,#ef4444);display:flex;flex-direction:column;gap:16px;justify-content:center;padding:60px 20px;text-align:center}.dga-error span{color:#888;color:var(--color-text-secondary,#888)}.dga-skeleton{animation:dga-skeleton-shimmer 1.5s infinite;background:linear-gradient(90deg,#1a1a1a 25%,#252525 50%,#1a1a1a 75%);background:linear-gradient(90deg,var(--color-bg-secondary,#1a1a1a) 25%,var(--color-bg-tertiary,#252525) 50%,var(--color-bg-secondary,#1a1a1a) 75%);background-size:200% 100%;border-radius:8px}.dga-skeleton-stat{height:100px}@keyframes dga-skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width:768px){.dga-dashboard{padding:16px}.dga-header{flex-direction:column;gap:16px}.dga-header-left h1{font-size:1.25rem}.dga-stats-grid{grid-template-columns:repeat(2,1fr)}.dga-tabs{overflow-x:auto;width:100%}.dga-freshness-legend{font-size:.75rem;gap:8px}.dga-coverage-table{font-size:.8125rem}.dga-coverage-table td,.dga-coverage-table th{padding:10px 12px}.dga-dept-name{max-width:120px}.dga-expanded-content{align-items:flex-start;flex-direction:column}.dga-expanded-stats{flex-wrap:wrap;gap:16px}.dga-gap-stats{flex-wrap:wrap}.dga-gap-stat{flex-basis:calc(50% - 8px);flex-grow:1;flex-shrink:1;min-width:120px}}.cw-fab{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border:none;border-radius:50%;bottom:24px;box-shadow:0 4px 20px #3b82f666;color:#fff;cursor:pointer;display:flex;height:56px;justify-content:center;position:fixed;right:24px;transition:all .3s;width:56px;z-index:1000}.cw-fab:hover{box-shadow:0 6px 28px #3b82f680;transform:scale(1.1)}.cw-fab-badge{background:#22c55e;border:2px solid #0f172a;border:2px solid var(--color-bg,#0f172a);border-radius:50%;height:14px;position:absolute;right:-2px;top:-2px;width:14px}.cw-panel{animation:cw-slide-up .3s ease-out;background:#0f172a;background:var(--color-bg,#0f172a);border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);border-radius:16px;bottom:92px;box-shadow:0 20px 60px #00000080;display:flex;flex-direction:column;max-height:600px;overflow:hidden;position:fixed;right:24px;width:420px;z-index:1001}@keyframes cw-slide-up{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.cw-header{background:#ffffff08;background:var(--color-surface,#ffffff08);border-bottom:1px solid #ffffff14;border-bottom:1px solid var(--color-border,#ffffff14);justify-content:space-between;padding:16px 20px}.cw-header,.cw-header-left{align-items:center;display:flex}.cw-header-left{gap:10px}.cw-header-icon{align-items:center;background:linear-gradient(135deg,#3b82f6,#8b5cf6);border-radius:8px;display:flex;height:32px;justify-content:center;width:32px}.cw-header-title{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.9rem;font-weight:600}.cw-header-subtitle{font-size:.7rem}.cw-close-btn,.cw-header-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.cw-close-btn{background:none;border:none;border-radius:6px;cursor:pointer;padding:4px;transition:all .2s}.cw-close-btn:hover{background:#ffffff14;background:var(--color-surface-hover,#ffffff14);color:#f1f5f9;color:var(--color-text,#f1f5f9)}.cw-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;max-height:400px;min-height:200px;overflow-y:auto;padding:16px 20px}.cw-message{word-wrap:break-word;border-radius:12px;font-size:.85rem;line-height:1.5;max-width:90%;padding:10px 14px}.cw-message-user{align-self:flex-end;background:#3b82f6;border-bottom-right-radius:4px;color:#fff}.cw-message-assistant{align-self:flex-start;background:#ffffff0d;background:var(--color-surface,#ffffff0d);border:1px solid #ffffff0f;border:1px solid var(--color-border,#ffffff0f);border-bottom-left-radius:4px;color:#f1f5f9;color:var(--color-text,#f1f5f9)}.cw-message-assistant p{margin:0 0 8px}.cw-message-assistant p:last-child{margin-bottom:0}.cw-message-assistant strong{color:#60a5fa}.cw-message-assistant code{background:#ffffff14;border-radius:4px;font-size:.8rem;padding:1px 5px}.cw-message-assistant table{border-collapse:collapse;font-size:.75rem;margin:8px 0;width:100%}.cw-message-assistant td,.cw-message-assistant th{border:1px solid #ffffff1a;border:1px solid var(--color-border,#ffffff1a);padding:4px 8px;text-align:left}.cw-message-assistant th{background:#ffffff0d;font-weight:600}.cw-tools{display:flex;flex-wrap:wrap;gap:4px;margin-top:6px}.cw-tool-tag{background:#8b5cf61f;border:1px solid #8b5cf633;border-radius:99px;color:#a78bfa;font-size:.65rem;padding:2px 8px}.cw-typing{align-items:center;align-self:flex-start;display:flex;gap:6px;padding:10px 14px}.cw-typing-dot{animation:cw-bounce 1.4s ease-in-out infinite;background:#94a3b8;background:var(--color-text-muted,#94a3b8);border-radius:50%;height:6px;width:6px}.cw-typing-dot:first-child{animation-delay:-.32s}.cw-typing-dot:nth-child(2){animation-delay:-.16s}@keyframes cw-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.cw-input-area{align-items:center;background:#ffffff05;background:var(--color-surface,#ffffff05);border-top:1px solid #ffffff14;border-top:1px solid var(--color-border,#ffffff14);display:flex;gap:8px;padding:12px 16px}.cw-input{background:#0f172a;background:var(--color-bg,#0f172a);border:1px solid #ffffff1f;border:1px solid var(--color-border,#ffffff1f);border-radius:10px;color:#f1f5f9;color:var(--color-text,#f1f5f9);flex:1 1;font-family:inherit;font-size:.85rem;max-height:80px;min-height:20px;outline:none;padding:10px 14px;resize:none}.cw-input:focus{border-color:#3b82f6;box-shadow:0 0 0 2px #3b82f626}.cw-input::placeholder{color:#64748b;color:var(--color-text-muted,#64748b)}.cw-send-btn{align-items:center;background:#3b82f6;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-shrink:0;height:36px;justify-content:center;transition:all .2s;width:36px}.cw-send-btn:hover{background:#2563eb}.cw-send-btn:disabled{background:#ffffff1a;background:var(--color-border,#ffffff1a);cursor:not-allowed}.cw-welcome{color:#94a3b8;color:var(--color-text-muted,#94a3b8);padding:24px 16px;text-align:center}.cw-welcome h3{color:#f1f5f9;color:var(--color-text,#f1f5f9);font-size:.95rem;margin:0 0 8px}.cw-welcome p{font-size:.8rem;margin:0 0 16px}.cw-suggestions{display:flex;flex-direction:column;gap:6px}.cw-suggestion{background:#ffffff0a;background:var(--color-surface,#ffffff0a);border:1px solid #ffffff14;border:1px solid var(--color-border,#ffffff14);border-radius:8px;color:#f1f5f9;color:var(--color-text,#f1f5f9);cursor:pointer;font-size:.78rem;padding:8px 12px;text-align:left;transition:all .2s}.cw-suggestion:hover{background:#3b82f614;border-color:#3b82f64d}.cw-error{align-self:center;background:#ef444414;border:1px solid #ef444433;border-radius:8px;color:#ef4444;font-size:.78rem;padding:8px 12px}@media (max-width:768px){.cw-panel{bottom:80px;max-height:70vh;right:16px;width:calc(100vw - 32px)}}*,:after,:before{box-sizing:border-box}blockquote,body,dd,dl,figure,h1,h2,h3,h4,h5,h6,p{margin:0}html:focus-within{scroll-behavior:smooth}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;min-height:100vh;overflow-x:hidden;text-rendering:optimizeSpeed}@media (min-width:768px){:root{--topnav-height:64px}}.container{padding:0 16px;width:100%}@media (min-width:768px){.container{padding:0 24px}}@media (min-width:1024px){.container{padding:0 32px}}[role=button],a,button,select{min-height:44px}input,select,textarea{font-size:16px!important;min-height:44px}@media (min-width:768px){input,select,textarea{font-size:inherit!important;min-height:auto}[role=button],a,button,select{min-height:auto}}.modal-backdrop,.modal-overlay{align-items:center;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:50}.modal-content{-webkit-overflow-scrolling:touch;max-height:90vh;max-width:calc(100vw - 32px);overflow-y:auto}img{height:auto;max-width:100%}ol[role=list],ul[role=list]{list-style:none}a:not([class]){-webkit-text-decoration-skip:ink;text-decoration-skip-ink:auto}canvas,img,picture,svg,video{display:block;height:auto;max-width:100%}button,input,select,textarea{font:inherit}@media (prefers-reduced-motion:reduce){html:focus-within{scroll-behavior:auto}*,:after,:before{animation-duration:.01ms!important;animation-iteration-count:1!important;scroll-behavior:auto!important;transition-duration:.01ms!important}}h1,h2,h3,h4,h5,h6{color:var(--color-text-dark);font-weight:var(--font-semibold);line-height:var(--leading-tight)}h1{font-size:var(--text-4xl);font-weight:var(--font-bold)}h2{font-size:var(--text-3xl)}h3{font-size:var(--text-2xl)}h4{font-size:var(--text-xl)}h5{font-size:var(--text-lg)}h6{font-size:var(--text-base)}p{line-height:var(--leading-relaxed)}@media (max-width:var(--breakpoint-md )){h1{font-size:var(--text-3xl)}h2{font-size:var(--text-2xl)}h3{font-size:var(--text-xl)}h4{font-size:var(--text-lg)}}@media (max-width:var(--breakpoint-sm )){body{font-size:.875rem}}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-hover)}::selection{background-color:var(--color-primary)}::-webkit-scrollbar{height:.75rem;width:.75rem}::-webkit-scrollbar-track{background:var(--gray-100)}::-webkit-scrollbar-thumb{background:var(--gray-400);border:2px solid var(--gray-100);border-radius:var(--radius-md)}::-webkit-scrollbar-thumb:hover{background:var(--gray-500)}*{scrollbar-color:var(--gray-400) var(--gray-100);scrollbar-width:thin}input[type=checkbox],input[type=radio]{cursor:pointer;height:1rem;margin:0;width:1rem}.btn{appearance:none;background-color:#fff;border:1px solid var(--gray-300);color:var(--gray-700);font-family:inherit;font-size:var(--text-sm);gap:var(--space-2);line-height:1.4;overflow:hidden;padding:.5rem 1rem;position:relative;transition:all var(--transition-fast);-webkit-user-select:none;user-select:none;white-space:nowrap}.btn:hover{background-color:var(--gray-50);border-color:var(--gray-400);box-shadow:var(--shadow-sm);color:var(--gray-900);transform:translateY(-1px)}.btn:active{box-shadow:none;transform:translateY(0)}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn:disabled{box-shadow:none;transform:none}.btn-primary{background:var(--gray-900);border-color:var(--gray-900)}.btn-primary:hover{background:var(--gray-800);border-color:var(--gray-800);box-shadow:0 4px 12px #00000026}.btn-primary:active{background:var(--gray-950);border-color:var(--gray-950)}.btn-secondary{background-color:var(--gray-100);border-color:var(--gray-300);color:var(--gray-700)}.btn-secondary:hover{background-color:var(--gray-200);border-color:var(--gray-400);color:var(--gray-900)}.btn-ghost{background-color:initial;border-color:#0000;color:var(--gray-600)}.btn-ghost:hover{background-color:var(--gray-100);border-color:#0000;color:var(--gray-900)}.btn-accent{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.btn-accent:hover{background:var(--color-primary-hover);border-color:var(--color-primary-hover);box-shadow:0 4px 12px #3b82f640}.tabs{width:100%}.tab-item,.tabs{display:flex;gap:var(--space-2)}.tab-item{align-items:center;background:#0000;border:none;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;flex:1 1;font-size:var(--text-sm);font-weight:var(--font-medium);justify-content:center;padding:var(--space-3) var(--space-4);transition:background var(--transition-fast),color var(--transition-fast)}.tab-item:hover:not(.tab-item-active){background-color:var(--gray-100);color:var(--gray-900)}.tab-item-active{background-color:var(--gray-100);box-shadow:inset 0 -2px 0 var(--color-primary);color:var(--color-primary)}.input,.select,.textarea{appearance:none;background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);display:block;font-family:inherit;font-size:var(--text-sm);line-height:1.5;padding:.5rem .75rem;transition:all var(--transition-fast);width:100%}.input:hover,.select:hover,.textarea:hover{border-color:var(--color-border-hover)}.input:focus,.select:focus,.textarea:focus{border-color:var(--color-text);box-shadow:0 0 0 3px rgba(var(--color-text-rgb),.05);outline:none}.input::placeholder,.textarea::placeholder{color:var(--color-text-subtle)}.input[type=file]::file-selector-button{background-color:var(--color-surface-active);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);cursor:pointer;margin-right:.75rem;padding:.5rem .75rem}.input[type=file]::file-selector-button:hover{background-color:var(--color-surface-hover);border-color:var(--color-border-hover)}.select{background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg width='12' height='8' fill='none' xmlns='http://www.w3.org/2000/svg'%3E%3Cpath d='m1 1.5 5 5 5-5' stroke='%2352525b' stroke-width='1.5' stroke-linecap='round' stroke-linejoin='round'/%3E%3C/svg%3E");background-position:right .75rem center;background-repeat:no-repeat;padding-right:2.5rem}.card{background-color:#fff;border:1px solid var(--gray-200);display:flex;flex-direction:column;padding:var(--space-6);position:relative;transition:all var(--transition-normal)}.card-hover:hover{border-color:var(--gray-300);box-shadow:0 10px 25px -5px #0000000d;transform:translateY(-2px)}.stat-card{flex:1 1;min-width:150px;padding:var(--space-4);text-align:center}.stat-value{color:var(--gray-900);font-size:var(--text-2xl);font-weight:var(--font-bold)}.stat-label{color:var(--color-text-muted);font-size:var(--text-sm)}.progress-section{display:flex;flex-direction:column;gap:var(--space-6)}.progress-stats{display:flex;flex-wrap:wrap;gap:var(--space-4)}.progress-stats .stat-card{flex:0 0 auto}.table{background:#fff}.table-responsive{overflow-x:auto;width:100%}.table td,.table th{border-bottom:1px solid var(--gray-100);padding:var(--space-3) var(--space-4);text-align:left}.table th{background-color:var(--gray-50);color:var(--gray-700);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:.05em;text-transform:uppercase}.table tbody tr{transition:background-color var(--transition-fast)}.table tbody tr:hover{background-color:var(--gray-50)}@media (max-width:767px){.card{padding:var(--space-4)}.table thead{display:none}.table tbody,.table tbody td,.table tbody tr{display:block;width:100%}.table tbody tr{background:#fff;background:var(--color-surface,#fff);border:1px solid var(--color-border,var(--gray-200));border-radius:var(--radius-lg);margin-bottom:.75rem;padding:var(--space-3)}.table tbody tr:hover{background-color:var(--gray-50);background-color:var(--color-surface-hover,var(--gray-50))}.table tbody td{border-bottom:none;padding:.25rem 0;text-align:left}.table tbody td:before{color:var(--gray-500);color:var(--color-text-muted,var(--gray-500));content:attr(data-label);display:block;font-size:.6875rem;font-weight:600;font-weight:var(--font-semibold,600);letter-spacing:.025em;margin-bottom:.125rem;text-transform:uppercase}.btn{min-height:44px}.input,.select,input[type=email],input[type=number],input[type=password],input[type=search],input[type=tel],input[type=text],input[type=url],select,textarea{font-size:16px;min-height:44px}}.badge{background-color:var(--gray-100);border:1px solid var(--gray-200);color:var(--gray-700);font-weight:var(--font-medium);gap:var(--space-1);line-height:1;padding:.25rem .625rem;white-space:nowrap}.badge-primary{background-color:var(--gray-900);border-color:var(--gray-900);color:#fff}.badge-accent{background-color:#3b82f614;border-color:#3b82f633;color:var(--color-primary)}.badge-success{background-color:#10b98114;border-color:#10b98133;color:var(--color-success)}.badge-error{background-color:#ef444414;border-color:#ef444433;color:var(--color-error)}.modal-backdrop{align-items:center;animation:fadeIn var(--transition-fast);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background-color:#0000004d;display:flex;inset:0;justify-content:center;position:fixed;z-index:var(--z-modal-backdrop)}.modal{animation:slideUp var(--transition-normal);background-color:#fff;border-radius:var(--radius-xl);box-shadow:0 25px 50px -12px #00000026;max-height:90vh;max-width:90vw;overflow-y:auto;padding:var(--space-6);z-index:var(--z-modal)}.progress{background-color:var(--gray-200);border-radius:var(--radius-full);height:.375rem;overflow:hidden;width:100%}.progress-bar{background:var(--gray-900);height:100%;transition:width var(--transition-slow) ease}.progress-bar-accent{background:var(--color-primary)}.tooltip-content{background-color:var(--gray-900);border-radius:var(--radius-md);bottom:100%;box-shadow:0 4px 12px #00000026;color:#fff;font-size:var(--text-xs);left:50%;margin-bottom:var(--space-2);opacity:0;padding:.375rem .75rem;position:absolute;transform:translateX(-50%);transition:all var(--transition-fast);visibility:hidden;white-space:nowrap;z-index:var(--z-tooltip)}.tooltip:hover .tooltip-content{opacity:1;visibility:visible}.loading-spinner{animation:spin .8s linear infinite;border:2px solid var(--gray-200);border-radius:50%;border-top-color:var(--gray-900);height:2rem;width:2rem}.btn-icon-action{align-items:center;background-color:initial;border:none;border-radius:var(--radius-md);color:var(--gray-600);cursor:pointer;display:flex;height:2rem;justify-content:center;padding:0;transition:all var(--transition-fast);width:2rem}.btn-icon-action:hover{background-color:var(--gray-100);color:var(--gray-900)}.btn-icon-action:active,.divider{background-color:var(--gray-200)}.divider{height:1px;margin:var(--space-6) 0}.alert{background-color:var(--gray-50);border:1px solid var(--gray-200);font-size:var(--text-sm);gap:var(--space-3);padding:var(--space-4)}.alert-info{background-color:#3b82f60d;border-color:#3b82f633;color:var(--color-primary-dark)}.alert-success{background-color:#10b9810d;border-color:#10b98133;color:#047857}.alert-error{background-color:#ef44440d;border-color:#ef444433;color:#dc2626}.loading-container{align-items:center;display:flex;justify-content:center;min-height:24rem}.loading-spinner{text-align:center}.spinner{border:3px solid var(--color-border);border-radius:var(--radius-full);height:3rem;margin:0 auto;width:3rem}.loading-text{color:var(--color-text-secondary);margin-top:var(--spacing-4)}.card{background:var(--color-surface);border:1px solid var(--color-border)}.card-body,.card-header{padding:var(--spacing-6)}.card-gradient-primary{background:linear-gradient(135deg,var(--color-primary-50),var(--color-primary-100));border-color:var(--color-primary-200)}.card-gradient-accent{background:linear-gradient(135deg,var(--color-accent-50),var(--color-accent-100));border-color:var(--color-accent-200)}.btn{font-weight:var(--font-medium);gap:var(--spacing-2);padding:var(--spacing-2) var(--spacing-4)}.btn-primary{background:var(--color-primary);color:var(--color-text-inverse)}.btn-primary:hover{background:var(--color-primary-600)}.btn-secondary{background:var(--color-surface);border-color:var(--color-border);color:var(--color-text-primary)}.btn-secondary:hover{background:var(--color-background-hover)}.btn-sm{font-size:var(--text-sm);padding:var(--spacing-1) var(--spacing-3)}.btn-icon{background:#0000;border:none;border-radius:var(--radius-md);cursor:pointer;padding:var(--spacing-2);transition:var(--transition-base)}.btn-icon:hover{background:var(--color-background-hover)}.badge{font-size:var(--text-xs);font-weight:var(--font-semibold);padding:var(--spacing-1) var(--spacing-2)}.badge-default{background:var(--color-background-subtle);color:var(--color-text-secondary)}.badge-success{background:var(--color-success-100);color:var(--color-success-600)}.badge-warning{background:var(--color-warning-100);color:var(--color-warning-600)}.badge-sm{font-size:var(--text-2xs);padding:.125rem var(--spacing-2)}.alert{border-radius:var(--radius-lg);padding:var(--spacing-4)}.alert-info{background:linear-gradient(to right,var(--color-primary-50),var(--color-accent-50));border-color:var(--color-primary-200);color:var(--color-primary-600)}.icon-xs{height:1rem;width:1rem}.icon-sm{height:1.25rem;width:1.25rem}.icon-md{height:1.5rem;width:1.5rem}.icon-lg{height:2rem;width:2rem}.icon-container{align-items:center;border-radius:var(--radius-xl);display:inline-flex;justify-content:center;padding:var(--spacing-3)}.icon-container-gradient{background:var(--gradient-primary);color:var(--color-text-inverse)}.heading-primary{font-size:var(--text-2xl)}.heading-primary,.heading-secondary{color:var(--color-text-primary);font-weight:var(--font-bold)}.heading-secondary{font-size:var(--text-xl)}.heading-tertiary{color:var(--color-text-primary);font-size:var(--text-lg);font-weight:var(--font-semibold)}.text-success{color:var(--color-success-600)}.text-warning{color:var(--color-warning-600)}.text-danger{color:var(--color-danger-500)}.text-strong{font-weight:var(--font-semibold)}.flex-col,.flex-row{display:flex}.flex-row-between{display:flex;justify-content:space-between}.align-center,.flex-row-between{align-items:center}.gap-1{gap:var(--spacing-1)}.gap-2{gap:var(--spacing-2)}.gap-3{gap:var(--spacing-3)}.gap-4{gap:var(--spacing-4)}.gap-6{gap:var(--spacing-6)}.mb-1{margin-bottom:var(--spacing-1)}.mb-2{margin-bottom:var(--spacing-2)}.mb-6{margin-bottom:var(--spacing-6)}.grid{grid-gap:var(--spacing-4);gap:var(--spacing-4)}.animate-pulse{animation:pulse 2s infinite}.image-upload-manager{background-color:var(--color-background);min-height:100vh}.image-upload-manager .container{margin:0 auto;max-width:72rem;padding:3rem 1rem}.section-title{color:var(--color-text);font-size:var(--text-lg);font-weight:var(--font-semibold)}.category-selector-wrapper{display:flex;justify-content:center;margin-bottom:3rem}.category-selector{background-color:var(--color-surface);border-radius:var(--radius-full);box-shadow:0 10px 25px -5px #0000001a,0 10px 10px -5px #0000000a;display:inline-flex;padding:.25rem}.btn-category{background-color:initial;border:none;border-radius:var(--radius-full);color:var(--color-text-muted);font-weight:var(--font-medium);padding:.75rem 1.5rem;transition:all var(--transition-base)}.btn-category:hover{background-color:var(--color-surface-hover);color:var(--color-text)}.btn-category.active{background-color:var(--color-text);box-shadow:0 4px 12px #00000026;color:var(--color-text-inverse)}.btn-category.active:hover{background-color:var(--color-text-muted);color:var(--color-text-inverse)}.upload-zone{background-color:var(--color-surface);border:2px dashed var(--color-border);border-radius:1.5rem;cursor:pointer;overflow:hidden;position:relative;transition:all var(--transition-base)}.upload-zone:hover{border-color:var(--color-border-hover);box-shadow:0 10px 25px -5px #0000000d}.upload-zone.dragging{background-color:var(--color-background);border-color:var(--color-primary);box-shadow:0 20px 50px -10px #0000001a;transform:scale(1.02)}.upload-input{cursor:pointer;height:100%;inset:0;opacity:0;position:absolute;width:100%;z-index:20}.upload-content{padding:4rem;pointer-events:none;text-align:center}.upload-icon-wrapper{background-color:var(--color-surface-hover);border-radius:var(--radius-full);display:inline-flex;margin-bottom:1.5rem;padding:1.5rem;transition:all var(--transition-base)}.upload-icon-wrapper.dragging{background-color:var(--color-primary)}.upload-icon{color:var(--color-text-muted);transition:all var(--transition-base)}.upload-icon-wrapper.dragging .upload-icon{color:var(--color-text-inverse)}.upload-title{color:var(--color-text);font-size:var(--text-xl);font-weight:var(--font-semibold);margin-bottom:.5rem}.upload-description{color:var(--color-text-subtle)}.upload-list{display:flex;flex-direction:column;gap:.75rem}.upload-item{background-color:var(--color-surface);border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;padding:1rem}.upload-item-content{align-items:center;display:flex;gap:1rem}.upload-preview-wrapper{flex-shrink:0;position:relative}.upload-preview{border-radius:.75rem;height:4rem;object-fit:cover;width:4rem}.upload-preview-overlay{align-items:center;background-color:#00000080;border-radius:.75rem;display:flex;inset:0;justify-content:center;position:absolute}.upload-spinner{animation:spin .8s linear infinite;color:var(--color-text-inverse);height:1.5rem;width:1.5rem}.upload-info{flex:1 1;min-width:0}.upload-filename{color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.upload-filesize{margin-top:.25rem}.upload-progress-wrapper{flex-shrink:0;width:8rem}.status-badge{align-items:center;border-radius:var(--radius-full);display:flex;flex-shrink:0;justify-content:center;padding:.5rem}.status-success{background-color:#10b9811a;color:var(--color-success)}.status-error{background-color:#ef44441a;color:var(--color-error)}.image-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fill,minmax(12rem,1fr))}@media (min-width:640px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(14rem,1fr))}}@media (min-width:768px){.image-grid{grid-template-columns:repeat(auto-fill,minmax(16rem,1fr))}}.image-card{background-color:var(--color-surface);border-radius:1rem;box-shadow:0 4px 6px -1px #0000000d;cursor:pointer;overflow:hidden;position:relative;transition:all var(--transition-base)}.image-card:hover{box-shadow:0 20px 25px -5px #00000014;transform:translateY(-.125rem)}.image-container{aspect-ratio:1;overflow:hidden}.image-preview{height:100%;object-fit:cover;width:100%}.image-overlay{align-items:flex-end;background-color:#0000;display:flex;inset:0;position:absolute;transition:all var(--transition-base)}.image-card:hover .image-overlay{background-color:#000000b3}.image-overlay-content{padding:1rem;transform:translateY(100%);transition:transform var(--transition-base);width:100%}.image-card:hover .image-overlay-content{transform:translateY(0)}.image-name{color:#fff;font-size:var(--text-sm);font-weight:var(--font-medium);margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.image-action-btn{background-color:var(--color-surface);border:none;color:var(--color-text);font-size:var(--text-xs);padding:.5rem .75rem;width:100%}.image-action-btn:hover{background-color:var(--color-surface-hover)}.active-indicator{background-color:var(--color-primary);border-radius:var(--radius-full);box-shadow:0 10px 15px -3px #0000001a;color:var(--color-text-inverse);padding:.5rem;position:absolute;right:.75rem;top:.75rem}@media (max-width:640px){.image-upload-manager .container{padding:2rem 1rem}.category-selector{flex-wrap:wrap;gap:.5rem;padding:.5rem}.btn-category{font-size:var(--text-sm);padding:.5rem 1rem}.upload-content{padding:2rem}.upload-icon-wrapper{padding:1rem}.upload-icon{height:1.5rem;width:1.5rem}.upload-title{font-size:var(--text-lg)}.upload-description{font-size:var(--text-sm)}}.card{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);overflow:hidden}.card-header{background:var(--bg-secondary);border-bottom:1px solid var(--border-color);padding:var(--spacing-md) var(--spacing-lg)}.card-title{color:var(--text-primary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);margin:0}.card-body{padding:var(--spacing-lg)}.btn{align-items:center;border:1px solid #0000;border-radius:var(--radius-md);cursor:pointer;display:inline-flex;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);gap:var(--spacing-sm);justify-content:center;line-height:1;padding:var(--spacing-sm) var(--spacing-md);text-decoration:none;transition:var(--transition-base)}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:var(--gradient-primary);border:none;color:#fff}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:var(--bg-primary);border-color:var(--border-color);color:var(--text-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-secondary)}.btn-success{background:var(--gradient-success);color:#fff}.btn-danger{background:var(--color-danger);color:#fff}.btn-ghost{background:#0000;border:none;color:var(--text-secondary)}.btn-ghost:hover:not(:disabled){background:var(--bg-hover);color:var(--text-primary)}.input-group{display:flex;flex-direction:column;gap:var(--spacing-xs)}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.input,.input-label{color:var(--text-primary)}.input{background:var(--bg-primary);border:1px solid var(--border-color);border-radius:var(--radius-md);font-size:var(--font-size-base);padding:var(--spacing-sm) var(--spacing-md);transition:var(--transition-base)}.input:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-light);outline:none}.input:disabled{background:var(--bg-tertiary);cursor:not-allowed}.badge{align-items:center;border-radius:var(--radius-full);display:inline-flex;font-size:var(--font-size-xs);font-weight:var(--font-weight-semibold);padding:var(--spacing-xs) var(--spacing-sm)}.badge-primary{background:var(--color-primary-light);color:var(--color-primary-dark)}.badge-success{background:var(--color-success-light);color:var(--color-success-dark)}.badge-warning{background:var(--color-warning-light);color:var(--color-warning-dark)}.badge-danger{background:var(--color-danger-light);color:var(--color-danger-dark)}.alert{align-items:flex-start;border:1px solid;border-radius:var(--radius-md);display:flex;gap:var(--spacing-md);padding:var(--spacing-md)}.alert-info{background:var(--color-info-light);border-color:var(--color-info);color:var(--color-info-dark)}.alert-success{background:var(--color-success-light);border-color:var(--color-success);color:var(--color-success-dark)}.alert-warning{background:var(--color-warning-light);border-color:var(--color-warning);color:var(--color-warning-dark)}.alert-danger{background:var(--color-danger-light);border-color:var(--color-danger);color:var(--color-danger-dark)}.table{border-collapse:collapse;width:100%}.table th{background:var(--bg-tertiary);border-bottom:2px solid var(--border-color);color:var(--text-primary);font-weight:var(--font-weight-semibold);text-align:left}.table td,.table th{padding:var(--spacing-sm) var(--spacing-md)}.table td{border-bottom:1px solid var(--border-color-light)}.table tr:hover{background:var(--bg-hover)}.skeleton{animation:loading 1.5s infinite;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-secondary) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;border-radius:var(--radius-sm)}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}.spinner{animation:spin 1s linear infinite;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--color-primary);height:20px;width:20px}.text-sm{font-size:var(--font-size-sm)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-danger{color:var(--color-danger)}.bg-primary{background:var(--bg-primary)}.bg-secondary{background:var(--bg-secondary)}.bg-tertiary{background:var(--bg-tertiary)}.border{border:1px solid var(--border-color)}.border-top{border-top:1px solid var(--border-color)}.border-bottom{border-bottom:1px solid var(--border-color)}.border-left{border-left:1px solid var(--border-color)}.border-right{border-right:1px solid var(--border-color)}.p-1{padding:var(--spacing-xs)}.p-2{padding:var(--spacing-sm)}.p-3{padding:var(--spacing-md)}.p-4{padding:var(--spacing-lg)}.p-5{padding:var(--spacing-xl)}.m-1{margin:var(--spacing-xs)}.m-2{margin:var(--spacing-sm)}.m-3{margin:var(--spacing-md)}.m-4{margin:var(--spacing-lg)}.m-5{margin:var(--spacing-xl)}.mt-1{margin-top:var(--spacing-xs)}.mt-2{margin-top:var(--spacing-sm)}.mt-3{margin-top:var(--spacing-md)}.mt-4{margin-top:var(--spacing-lg)}.mt-5{margin-top:var(--spacing-xl)}.mb-1{margin-bottom:var(--spacing-xs)}.mb-2{margin-bottom:var(--spacing-sm)}.mb-3{margin-bottom:var(--spacing-md)}.mb-4{margin-bottom:var(--spacing-lg)}.mb-5{margin-bottom:var(--spacing-xl)}.gap-1{gap:var(--spacing-xs)}.gap-2{gap:var(--spacing-sm)}.gap-3{gap:var(--spacing-md)}.gap-4{gap:var(--spacing-lg)}.gap-5{gap:var(--spacing-xl)}.flex-column{flex-direction:column}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.inline{display:inline}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.glass-panel{-webkit-backdrop-filter:blur(var(--sidebar-blur));backdrop-filter:blur(var(--sidebar-blur));background-color:var(--glass-white);border:1px solid var(--glass-white-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md);padding:var(--space-6)}.sankey-container{min-height:100vh;width:100%}.chat-container,.sankey-container{display:flex;flex-direction:column}.chat-container{-webkit-backdrop-filter:blur(var(--sidebar-blur));backdrop-filter:blur(20px);background:#14142380;border:1px solid #ffffff0d;border-radius:12px;padding:20px}.chat-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto}.chat-message{border-radius:8px;font-size:.9rem;line-height:1.4;max-width:80%;padding:12px}.chat-message.user{background:#3b82f6cc;color:#fff;margin-left:auto}.chat-message.assistant{background:#ffffff14;color:#e0e0e0}.chat-input{display:flex;gap:8px;margin-top:16px}.chat-input input{background:#ffffff0d;border:1px solid #ffffff1a;border-radius:6px;color:#fff;flex:1 1;font-size:.9rem;padding:8px 12px}.chat-input button{align-items:center;background:#3b82f6cc;border:1px solid #3b82f64d;border-radius:6px;color:#fff;display:flex;font-size:.85rem;gap:4px;padding:8px 16px}.chat-input button:disabled{opacity:.5}@media (max-width:767px){.btn{min-height:44px;min-width:44px}.btn-sm{min-height:36px}.btn-group,.button-group{flex-wrap:wrap;gap:8px}.form-group{flex-direction:column}.form-group label{margin-bottom:4px}input:not([type=checkbox]):not([type=radio]),select,textarea{width:100%}select{appearance:none;background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%23666' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 12px center;background-repeat:no-repeat;padding-right:32px}.modal-backdrop,.modal-overlay{align-items:flex-end;padding:0}.modal-content,.modal-large{-webkit-overflow-scrolling:touch;border-radius:16px 16px 0 0;margin:0;max-height:90vh;max-width:100vw;overflow-y:auto;width:100vw}.modal-close,button[title="Close Settings"],button[title=Close]{min-height:44px;min-width:44px}.card,.card-modern{border-radius:var(--radius-lg);padding:16px}.page-header{margin-bottom:var(--space-4)}.page-title{font-size:var(--text-xl)}.flex-row-mobile-col{flex-direction:column}.mobile-cards table,.mobile-cards tbody,.mobile-cards td,.mobile-cards th,.mobile-cards thead,.mobile-cards tr{display:block}.mobile-cards thead tr{display:none}.mobile-cards tr{background:var(--color-surface);border:1px solid var(--color-border);border-radius:8px;margin-bottom:12px;overflow:hidden}.mobile-cards td{border-bottom:1px solid var(--color-surface-hover);display:flex;justify-content:space-between;padding:8px 12px}.mobile-cards td:before{color:var(--color-text-muted);content:attr(data-label);flex-shrink:0;font-size:12px;font-weight:600;margin-right:8px}.p-6,.p-8{padding:16px!important}.gap-6,.gap-8{gap:16px!important}}.app-container{min-height:100vh}.main-content{display:flex;flex-direction:column;min-height:0}.content-area{flex:1 1;margin:0 auto;max-width:var(--content-max-width);overflow-y:auto;padding:var(--space-4);width:100%}.page-header{margin-bottom:var(--space-8)}.page-title{color:var(--gray-900)}.page-subtitle{color:var(--color-text-muted);font-size:var(--text-lg)}@media (min-width:var(--breakpoint-md )){.content-area{padding:var(--space-6)}}@media (min-width:var(--breakpoint-lg )){.app-container{flex-direction:row}.content-area{padding:var(--space-8)}}@media (max-width:var(--breakpoint-md )){.page-title{font-size:var(--text-2xl)}}:root{--white:#fff;--color-primary:#3b82f6;--color-primary-hover:#2563eb;--color-primary-light:#60a5fa;--color-primary-dark:#1d4ed8;--color-accent:#06b6d4;--color-accent-light:#22d3ee;--color-accent-dark:#0891b2;--gray-50:#fafafa;--gray-100:#f4f4f5;--gray-200:#e4e4e7;--gray-300:#d4d4d8;--gray-400:#a1a1aa;--gray-500:#71717a;--gray-600:#52525b;--gray-700:#3f3f46;--gray-800:#27272a;--gray-900:#18181b;--gray-950:#09090b;--gradient-primary:linear-gradient(135deg,#3b82f6,#2563eb);--gradient-accent:linear-gradient(135deg,#06b6d4,#0891b2);--gradient-success:linear-gradient(135deg,var(--color-success-light,#34d399) 0%,var(--color-success) 100%);--gradient-dark:linear-gradient(180deg,#18181b,#09090b);--gradient-subtle:linear-gradient(180deg,#ffffff05,#fff0);--glass-white:#ffffff14;--glass-white-border:#ffffff1f;--glass-dark:#0000004d;--glass-dark-border:#00000080;--shadow-xs:0 1px 2px #0000000d;--shadow-sm:0 1px 3px #0000000a,0 1px 2px #0000000f;--shadow-md:0 4px 6px -1px #0000000a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000000a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #00000014,0 10px 10px -5px #0000000a;--shadow-2xl:0 25px 50px -12px #00000026;--glow-primary:0 0 20px #6366f166;--glow-accent:0 0 20px #f59e0b66;--glow-subtle:0 0 15px #ffffff1a;--font-sans:"Inter",-apple-system,BlinkMacSystemFont,"Segoe UI",sans-serif;--font-mono:"JetBrains Mono","SF Mono",Monaco,monospace;--text-xs:0.75rem;--text-sm:0.875rem;--text-base:1rem;--text-lg:1.125rem;--text-xl:1.25rem;--text-2xl:1.5rem;--text-3xl:1.875rem;--text-4xl:2.25rem;--font-normal:400;--font-medium:500;--font-semibold:600;--font-bold:700;--space-0:0;--space-px:1px;--space-0-5:0.125rem;--space-1:0.25rem;--space-1-5:0.375rem;--space-2:0.5rem;--space-2-5:0.625rem;--space-3:0.75rem;--space-4:1rem;--space-5:1.25rem;--space-6:1.5rem;--space-8:2rem;--space-10:2.5rem;--space-12:3rem;--space-16:4rem;--radius-none:0;--radius-sm:0.25rem;--radius-md:0.375rem;--radius-lg:0.5rem;--radius-xl:0.75rem;--radius-2xl:1rem;--radius-3xl:1.5rem;--radius-full:9999px;--duration-instant:0ms;--duration-fast:150ms;--duration-normal:300ms;--duration-slow:500ms;--duration-slower:700ms;--ease-linear:linear;--ease-in:cubic-bezier(0.4,0,1,1);--ease-out:cubic-bezier(0,0,0.2,1);--ease-in-out:cubic-bezier(0.4,0,0.2,1);--ease-out-expo:cubic-bezier(0.19,1,0.22,1);--ease-out-back:cubic-bezier(0.34,1.56,0.64,1);--ease-spring:cubic-bezier(0.43,0.195,0.02,1.37);--nav-hover-scale:1.05;--nav-hover-translate-x:2px;--nav-hover-translate-y:-2px;--nav-icon-hover-scale:1.1;--breakpoint-sm:480px;--breakpoint-md:768px;--breakpoint-lg:1024px;--sidebar-width:175px;--sidebar-collapsed-width:0px;--sidebar-min-width:60px;--sidebar-max-width:400px;--topnav-height:56px;--settings-panel-width:800px;--content-max-width:1400px;--z-base:0;--z-dropdown:10;--z-sticky:20;--z-fixed:30;--z-modal-backdrop:40;--z-modal:50;--z-popover:60;--z-tooltip:70;--button-height:44px;--input-height:44px;--navbar-blur:10px;--sidebar-blur:16px;--modal-blur:20px;--department-badge-bg:var(--color-surface-active);--department-badge-text:var(--color-text);--transition-base:var(--duration-normal) var(--ease-out);--transition-fast:var(--duration-fast) var(--ease-out);--transition-normal:var(--duration-normal) var(--ease-out);--transition-slow:var(--duration-slow) var(--ease-out);--transition-spring:var(--duration-normal) var(--ease-spring);--color-background:#fff;--color-surface:#fff;--color-surface-hover:var(--gray-50);--color-surface-active:var(--gray-100);--color-border:var(--gray-200);--color-border-hover:var(--gray-300);--color-text:var(--gray-900);--color-text-muted:var(--gray-600);--color-text-subtle:var(--gray-500);--color-text-inverse:#fff;--color-text-rgb:24,24,27;--logo-invert:invert(0);--color-success:#10b981;--color-success-light:#34d399;--color-success-dark:#059669;--color-warning:#f59e0b;--color-warning-light:#fcd34d;--color-warning-dark:#d97706;--color-error:#ef4444;--color-info:#3b82f6;--canvas-grid-color:var(--gray-200);--bg-primary:var(--color-surface);--bg-secondary:var(--color-background);--bg-tertiary:var(--color-surface-hover);--bg-hover:var(--color-surface-hover);--text-primary:var(--color-text);--text-secondary:var(--color-text-muted);--text-tertiary:var(--color-text-subtle);--border-color:var(--color-border);--border-color-light:var(--color-border-hover);--bg-code:var(--gray-800);--text-code:var(--gray-100);--color-danger:var(--color-error);--color-danger-light:#fee2e2;--color-danger-dark:#b91c1c;--zt-identity:#9333ea;--zt-device:#3b82f6;--zt-network:#06b6d4;--zt-application:#10b981;--zt-data:#f59e0b;--zt-visibility:#8b5cf6;--zt-strong:#10b981;--zt-partial:#f59e0b;--zt-gap:#ef4444;--zt-traditional:#6b7280;--zt-initial:#eab308;--zt-advanced:#3b82f6;--zt-optimal:#10b981;--zt-governance:#9333ea;--zt-ab869-critical:#ef4444}[data-theme=dark]{--color-background:var(--gray-950);--color-surface:var(--gray-900);--color-surface-hover:var(--gray-800);--color-surface-active:var(--gray-700);--color-border:#ffffff1a;--color-border-hover:#fff3;--color-text:#fffffff2;--color-text-muted:#ffffffb3;--color-text-subtle:#fff9;--color-text-inverse:var(--gray-900);--color-text-rgb:255,255,255;--logo-invert:invert(1);--department-badge-bg:var(--color-surface-hover);--canvas-grid-color:var(--gray-800);--bg-code:var(--gray-700);--text-code:var(--gray-200)}*{box-sizing:border-box}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-size:16px;text-rendering:optimizeLegibility}body{background-color:#fff;background-color:var(--color-background);color:#18181b;color:var(--color-text);font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-family:var(--font-sans);font-size:1rem;font-size:var(--text-base);line-height:1.5;margin:0;padding:0}.glass{background:#ffffff14;background:var(--glass-white);border:1px solid #ffffff1f;border:1px solid var(--glass-white-border)}.glass,.glass-dark{backdrop-filter:blur(10px);backdrop-filter:blur(var(--navbar-blur));-webkit-backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(var(--navbar-blur))}.glass-dark{background:#0000004d;background:var(--glass-dark);border:1px solid #00000080;border:1px solid var(--glass-dark-border)}.glow{box-shadow:0 0 15px #ffffff1a;box-shadow:var(--glow-subtle);transition:box-shadow .3s cubic-bezier(0,0,.2,1);transition:box-shadow var(--transition-normal)}.glow:hover{box-shadow:0 0 20px #6366f166;box-shadow:var(--glow-primary)}.gradient-text{-webkit-text-fill-color:#0000;background:linear-gradient(135deg,#3b82f6,#2563eb);background:var(--gradient-primary);-webkit-background-clip:text;background-clip:text}.btn-modern{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius-lg);cursor:pointer;display:inline-flex;font-size:.875rem;font-size:var(--text-sm);font-weight:500;font-weight:var(--font-medium);gap:.5rem;gap:var(--space-2);height:44px;height:var(--button-height);justify-content:center;overflow:hidden;padding:0 1rem;padding:0 var(--space-4);position:relative;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--transition-normal)}.btn-modern:before{background:linear-gradient(180deg,#ffffff1a,#fff0);bottom:0;content:"";left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .15s cubic-bezier(0,0,.2,1);transition:opacity var(--transition-fast)}.btn-modern:hover:before{opacity:1}.btn-modern:active{transform:scale(.98)}.card-modern{background:#fff;background:var(--color-surface);border:1px solid #e4e4e7;border:1px solid var(--color-border);border-radius:.75rem;border-radius:var(--radius-xl);box-shadow:0 1px 3px #0000000a,0 1px 2px #0000000f;box-shadow:var(--shadow-sm);overflow:hidden;position:relative;transition:all .3s cubic-bezier(0,0,.2,1);transition:all var(--transition-normal)}.card-modern:before{background:linear-gradient(180deg,#ffffff05,#fff0);background:var(--gradient-subtle);content:"";height:1px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s cubic-bezier(0,0,.2,1);transition:opacity var(--transition-normal)}.card-modern:hover{box-shadow:0 10px 15px -3px #0000000a,0 4px 6px -2px #0000000d;box-shadow:var(--shadow-lg);transform:translateY(-2px)}.card-modern:hover:before{opacity:1}.input-modern{background:#fff;background:var(--color-surface);border:1px solid #e4e4e7;border:1px solid var(--color-border);border-radius:.5rem;border-radius:var(--radius-lg);color:#18181b;color:var(--color-text);font-size:.875rem;font-size:var(--text-sm);height:44px;height:var(--input-height);outline:none;padding:0 .75rem;padding:0 var(--space-3);transition:all .15s cubic-bezier(0,0,.2,1);transition:all var(--transition-fast)}.input-modern:hover{border-color:#d4d4d8;border-color:var(--color-border-hover)}.input-modern:focus{border-color:#3b82f6;border-color:var(--color-primary);box-shadow:0 0 0 3px #6366f11a}.input-modern:disabled{background:#f4f4f5;background:var(--gray-100);cursor:not-allowed}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#d4d4d8;background:var(--gray-300);background-clip:padding-box;border:2px solid #0000;border-radius:9999px;border-radius:var(--radius-full)}::-webkit-scrollbar-thumb:hover{background:#a1a1aa;background:var(--gray-400)}::selection{background:#3b82f6;background:var(--color-primary);color:#fff;color:var(--color-text-inverse)}:focus-visible{outline:2px solid #3b82f6;outline:2px solid var(--color-primary);outline-offset:2px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}@keyframes slideInRight{0%{opacity:0;transform:translateX(20px)}to{opacity:1;transform:translateX(0)}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{animation:shimmer 1.5s infinite;background:linear-gradient(90deg,#e4e4e7 25%,#f4f4f5 50%,#e4e4e7 75%);background:linear-gradient(90deg,var(--gray-200) 25%,var(--gray-100) 50%,var(--gray-200) 75%);background-size:200% 100%}.hidden{display:none}.block{display:block}.inline-block{display:inline-block}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.flex-1{flex:1 1}.flex-auto{flex:auto}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.m-0{margin:0}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.mx-6{margin-left:var(--space-6);margin-right:var(--space-6)}.mt-0{margin-top:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.ml-2{margin-left:var(--space-2)}.ml-4{margin-left:var(--space-4)}.mr-2{margin-right:var(--space-2)}.mr-4{margin-right:var(--space-4)}.p-0{padding:0}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.py-2{padding-bottom:var(--space-2);padding-top:var(--space-2)}.py-4{padding-bottom:var(--space-4);padding-top:var(--space-4)}.w-full{width:100%}.w-auto{width:auto}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-4xl{max-width:56rem}.max-w-full{max-width:100%}.w-1\/2{width:50%}.w-1\/3{width:33.333%}.w-1\/4{width:25%}@media (min-width:var(--breakpoint-sm )){.sm\:w-1\/2{width:50%}}@media (min-width:var(--breakpoint-lg )){.lg\:w-1\/3{width:33.333%}.lg\:w-1\/4{width:25%}}.h-full{height:100%}.h-screen{height:100vh}.min-h-screen{min-height:100vh}.h-8{height:var(--space-8)}.h-4{height:var(--space-4)}.w-3\/4{width:75%}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-xl{font-size:var(--text-xl)}.text-2xl{font-size:var(--text-2xl)}.text-3xl{font-size:var(--text-3xl)}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.text-primary{color:var(--color-primary)}.text-muted{color:var(--color-text-muted)}.text-gray-500{color:var(--gray-500)}.text-gray-600{color:var(--gray-600)}.text-gray-700{color:var(--gray-700)}.text-gray-900{color:var(--gray-900)}.text-white{color:var(--color-text-inverse)}.text-success{color:var(--color-success)}.text-warning{color:var(--color-warning)}.text-error{color:var(--color-error)}.text-info{color:var(--color-info)}.text-blue-300{color:#93c5fd}.text-blue-400{color:var(--color-primary-light)}.text-blue-600{color:var(--color-primary)}.text-blue-700{color:var(--color-primary-dark)}.text-gray-200{color:var(--gray-200)}.text-gray-300{color:var(--gray-300)}.text-gray-400{color:var(--gray-400)}.text-green-300{color:#86efac}.text-green-400{color:var(--color-success-light)}.text-green-500{color:var(--color-success)}.text-green-600{color:var(--color-success-dark)}.text-green-700{color:#047857}.text-orange-300{color:#fdba74}.text-orange-400{color:var(--color-warning-light)}.text-orange-500{color:var(--color-warning)}.text-orange-600{color:var(--color-warning-dark)}.text-purple-400{color:#a78bfa}.text-red-500{color:var(--color-error)}.text-red-600{color:#dc2626}.text-red-700{color:#b91c1c}.text-red-800{color:#991b1b}.font-normal{font-weight:var(--font-normal)}.font-medium{font-weight:var(--font-medium)}.font-semibold{font-weight:var(--font-semibold)}.font-bold{font-weight:var(--font-bold)}.bg-white{background-color:var(--color-surface)}.bg-gray-50{background-color:var(--gray-50)}.bg-gray-100{background-color:var(--gray-100)}.bg-gray-900{background-color:var(--gray-900)}.bg-transparent{background-color:initial}.bg-blue-500{background-color:var(--color-info)}.bg-blue-600,.bg-primary{background-color:var(--color-primary)}.bg-red-50{background-color:#fef2f2}.bg-red-600{background-color:var(--color-error)}.bg-green-100{background-color:#d1fae5}.bg-gray-200{background-color:var(--gray-200)}.bg-gray-300{background-color:var(--gray-300)}.bg-gray-600{background-color:var(--gray-600)}.bg-gray-700{background-color:var(--gray-700)}.bg-black\/20{background-color:#0003}.bg-blue-900\/20{background-color:#1e3a8a33}.bg-green-900\/20{background-color:#065f4633}.bg-orange-900\/20{background-color:#7c2d1233}.bg-gray-800\/50{background-color:#27272a80}.bg-yellow-600{background-color:#ca8a04}.hover\:bg-blue-600:hover{background-color:var(--color-primary)}.hover\:bg-blue-700:hover{background-color:var(--color-primary-dark)}.hover\:bg-gray-50:hover{background-color:var(--gray-50)}.hover\:bg-gray-200:hover{background-color:var(--gray-200)}.hover\:bg-gray-600:hover{background-color:var(--gray-600)}.hover\:bg-red-700:hover{background-color:#b91c1c}.bg-gradient-primary{background-image:var(--gradient-primary)}.border{border:1px solid var(--color-border)}.border-0{border:0}.border-t{border-top:1px solid var(--color-border)}.border-b{border-bottom:1px solid var(--color-border)}.border-gray-200{border-color:var(--gray-200)}.border-gray-300{border-color:var(--gray-300)}.border-blue-600\/30{border-color:#2563eb4d}.border-green-500{border-color:var(--color-success)}.border-green-600\/30{border-color:#0596694d}.border-orange-600\/30{border-color:#ea580c4d}.border-red-200{border-color:#fecaca}.border-red-500{border-color:var(--color-error)}.border-yellow-500{border-color:#eab308}.border-l-4{border-left-width:4px}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow)}.shadow-md{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.overflow-hidden{overflow:hidden}.overflow-auto{overflow:auto}.overflow-x-auto{overflow-x:auto}.overflow-y-auto{overflow-y:auto}.static{position:static}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.inset-0{bottom:0;left:0;right:0;top:0}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.z-0{z-index:0}.z-10{z-index:10}.z-20{z-index:20}.z-30{z-index:30}.z-40{z-index:40}.z-50{z-index:50}.cursor-pointer{cursor:pointer}.cursor-not-allowed{cursor:not-allowed}.disabled\:bg-gray-300:disabled{background-color:var(--gray-300)}.disabled\:cursor-not-allowed:disabled{cursor:not-allowed}.opacity-0{opacity:0}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.transition-none{transition:none}.transition-all{transition:all var(--transition-base)}.transition-colors{transition:color var(--transition-base),background-color var(--transition-base),border-color var(--transition-base)}.transition-opacity{transition:opacity var(--transition-base)}.transition-transform{transition:transform var(--transition-base)}.scale-95{transform:scale(.95)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.translate-y-0{transform:translateY(0)}.translate-y-1{transform:translateY(.25rem)}.-translate-y-1{transform:translateY(-.25rem)}.animate-pulse{animation:pulse 2s cubic-bezier(.4,0,.6,1) infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.sr-only{clip:rect(0,0,0,0);border-width:0;height:1px;margin:-1px;overflow:hidden;padding:0;position:absolute;white-space:nowrap;width:1px}.focus-visible:focus{outline:2px solid var(--color-primary);outline-offset:2px}@media (max-width:var(--breakpoint-md )){.sm\:hidden{display:none!important}.sm\:block{display:block!important}.sm\:flex{display:flex!important}}@media (min-width:var(--breakpoint-md )){.md\:hidden{display:none!important}.md\:block{display:block!important}.md\:flex{display:flex!important}}@media (min-width:var(--breakpoint-lg )){.lg\:hidden{display:none!important}.lg\:block{display:block!important}.lg\:flex{display:flex!important}}@media (max-width:var(--breakpoint-md )){.md\:hidden{display:none}.md\:block{display:block}.md\:flex{display:flex}.md\:grid-cols-1{grid-template-columns:1fr}.md\:flex-column{flex-direction:column}}@media (max-width:var(--breakpoint-sm )){.sm\:hidden{display:none}.sm\:block{display:block}.sm\:flex{display:flex}.sm\:grid-cols-1{grid-template-columns:1fr}.sm\:flex-column{flex-direction:column}}.app-container{background-color:var(--color-background);display:flex;flex-direction:column;height:100vh;height:100dvh;overflow:hidden;position:relative;width:100vw}.app-body{flex:1 1;flex-direction:row;min-height:0}.app-body,.main-wrapper{display:flex;overflow:hidden}.main-wrapper{flex:1 1;flex-direction:column;min-width:0}.app-container>nav{flex-shrink:0;position:relative;width:100%;z-index:30}.main-content{background-color:var(--color-background);flex:1 1;overflow-x:hidden;overflow-y:auto;position:relative}.content-wrapper{display:flex;flex:1 1;flex-direction:column;height:100%;min-height:0;transition:opacity var(--transition-normal) ease;width:100%}.content-wrapper.transitioning{opacity:0}.content-wrapper>div{min-height:0}.app-loading{align-items:center;background-color:var(--color-background);display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:100vh}.app-loading p{color:var(--color-text-muted);font-size:var(--text-base);margin:0}.app-error{align-items:center;background-color:var(--color-background);display:flex;flex-direction:column;gap:var(--space-4);justify-content:center;min-height:100vh;padding:var(--space-8);text-align:center}.app-error h2{color:var(--color-error);font-size:var(--text-2xl);font-weight:var(--font-semibold);margin:0}.app-error p{color:var(--color-text-muted);font-size:var(--text-base);margin:0}.app-container.settings-mode{background-color:var(--color-background)}.dashboard-container{flex-direction:column}.tech-palette{flex-shrink:0;height:250px;width:100%}@media screen and (min-width:1024px){.dashboard-container{flex-direction:row}.tech-palette{height:auto;width:auto}}.page-title{color:var(--color-text);font-size:var(--text-3xl);font-weight:var(--font-bold);margin-bottom:var(--space-2)}@media print{.assessment-panel,.btn-secondary,.sb-assess-back,.sb-assess-run-btn,.sb-banner,.sb-header-tags,.sb-modal-overlay,.sb-watermark,.zt-view-tabs{display:none!important}.sb-assess,.zt-container,.zt-scroll-area{background:#fff!important;color:#111!important;height:auto!important;overflow:visible!important}.zt-header{background:#fff!important;border-bottom:2px solid #333!important}.zt-header h1{color:#111!important}.governance-layer,.pdp-layer,.pillar-column,.visibility-detail-row{background:#fff!important;border-color:#ccc!important;break-inside:avoid;page-break-inside:avoid}.capability-card,.sb-exec-stat-card{background:#f8f8f8!important;border-color:#ddd!important}}.sb-root{background:#0f1117;background:var(--color-background,#0f1117);color:#e2e8f0;color:var(--color-text,#e2e8f0);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-family:var(--font-sans,-apple-system,BlinkMacSystemFont,"Segoe UI",Roboto,sans-serif);min-height:100vh}.sb-banner{background:#451a03;border-bottom:2px solid #b45309;font-size:.8rem;gap:12px;justify-content:space-between;padding:8px 16px;position:sticky;top:0;z-index:1000}.sb-banner,.sb-banner-left{align-items:center;display:flex;flex-wrap:wrap}.sb-banner-left{gap:8px}.sb-banner-icon{color:#fbbf24}.sb-banner-label{color:#fbbf24;font-size:.75rem;font-weight:700;letter-spacing:.05em;text-transform:uppercase}.sb-banner-sep{color:#92400e}.sb-banner-info{color:#fde68a}.sb-banner-scenario{color:#fbbf24;font-weight:600}.sb-banner-right{align-items:center;display:flex;gap:8px}.sb-banner-btn{align-items:center;background:#0000;border:1px solid #92400e;border-radius:6px;color:#fde68a;cursor:pointer;display:flex;font-size:.75rem;font-weight:500;gap:4px;padding:4px 10px;transition:all .15s}.sb-banner-btn:hover{background:#78350f}.sb-banner-btn--exit{background:#b45309;border-color:#b45309;color:#fff}.sb-banner-btn--exit:hover{background:#d97706}.sb-selector{margin:0 auto;max-width:1100px;padding:0 24px 64px}.sb-selector-header{align-items:center;display:flex;padding:20px 0}.sb-selector-brand{align-items:center;display:flex;gap:8px}.sb-selector-logo{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border-radius:8px;color:#fff;display:flex;height:32px;justify-content:center;width:32px}.sb-selector-logo-text{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.1rem;font-weight:700}.sb-selector-badge{background:#fef3c7;border-radius:4px;color:#92400e;font-size:.7rem;font-weight:600;letter-spacing:.04em;padding:2px 8px;text-transform:uppercase}.sb-selector-hero{padding:48px 0 32px;text-align:center}.sb-selector-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:2rem;font-weight:700;line-height:1.2;margin:0 0 12px}.sb-selector-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:1.05rem;line-height:1.6;margin:0 auto;max-width:600px}.sb-selector-grid{grid-gap:20px;display:grid;gap:20px;grid-template-columns:repeat(2,1fr);margin-bottom:32px}@media (max-width:768px){.sb-selector-grid{grid-template-columns:1fr}}.sb-scenario-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:12px;padding:24px;transition:all .2s}.sb-scenario-card:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1);box-shadow:0 0 0 1px #6366f1,0 8px 24px #0000004d;box-shadow:0 0 0 1px var(--color-primary,#6366f1),0 8px 24px #0000004d;transform:translateY(-2px)}.sb-scenario-emoji{font-size:2rem}.sb-scenario-name{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.15rem;font-weight:600;margin:0}.sb-scenario-desc{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem;line-height:1.5;margin:0}.sb-scenario-tags{display:flex;flex-wrap:wrap;gap:6px}.sb-scenario-cta{align-items:center;color:#6366f1;color:var(--color-primary,#6366f1);display:flex;font-size:.85rem;font-weight:600;gap:6px;margin-top:auto;padding-top:8px}.sb-tag{border-radius:4px;display:inline-block;font-size:.7rem;font-weight:500;padding:2px 8px}.sb-tag--tech{background:#6366f126;border:1px solid #6366f140;color:#a5b4fc}.sb-tag--compliance{background:#10b98126;border:1px solid #10b98140;color:#6ee7b7}.sb-tag--more{background:#94a3b826;color:#94a3b8}.sb-selector-custom{padding:16px 0;text-align:center}.sb-custom-btn{align-items:center;background:#0000;border:1px dashed #2d3148;border:1px dashed var(--color-border,#2d3148);border-radius:10px;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:inline-flex;font-size:.9rem;font-weight:500;gap:8px;padding:12px 24px;transition:all .2s}.sb-custom-btn:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-selector-footer{border-top:1px solid #2d3148;border-top:1px solid var(--color-border,#2d3148);margin-top:24px;padding:32px 0;text-align:center}.sb-selector-footer p{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.78rem;line-height:1.5;margin:0 auto;max-width:500px}.sb-builder{margin:0 auto;max-width:1200px;padding:0 24px 64px}.sb-builder-header{align-items:center;display:flex;justify-content:space-between;padding:20px 0}.sb-builder-back{align-items:center;background:none;border:none;border-radius:6px;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;font-size:.85rem;gap:6px;padding:6px 10px;transition:all .15s}.sb-builder-back:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-builder-layout{grid-gap:32px;align-items:start;display:grid;gap:32px;grid-template-columns:1fr 320px}@media (max-width:900px){.sb-builder-layout{grid-template-columns:1fr}}.sb-builder-form{display:flex;flex-direction:column;gap:32px}.sb-builder-section{display:flex;flex-direction:column;gap:12px}.sb-builder-section-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1rem;font-weight:600;margin:0}.sb-builder-org-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.sb-org-card{align-items:center;background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:6px;padding:16px 8px;transition:all .15s}.sb-org-card--selected,.sb-org-card:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.sb-org-card--selected{background:#6366f11a;box-shadow:0 0 0 1px #6366f1;box-shadow:0 0 0 1px var(--color-primary,#6366f1)}.sb-org-emoji{font-size:1.5rem}.sb-org-label{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.8rem;font-weight:500}.sb-builder-category{margin-bottom:8px}.sb-builder-category-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;font-weight:600;letter-spacing:.04em;margin:0 0 8px;text-transform:uppercase}.sb-builder-chips{display:flex;flex-wrap:wrap;gap:8px}.sb-chip{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:20px;color:#e2e8f0;color:var(--color-text,#e2e8f0);cursor:pointer;font-size:.8rem;font-weight:500;padding:6px 14px;transition:all .15s}.sb-chip--selected,.sb-chip:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.sb-chip--selected{background:#6366f126;color:#a5b4fc}.sb-chip--fw.sb-chip--selected{background:#10b98126;border-color:#10b981;color:#6ee7b7}.sb-builder-risk-grid{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(auto-fill,minmax(180px,1fr))}.sb-risk-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;cursor:pointer;display:flex;flex-direction:column;gap:4px;padding:14px 16px;text-align:left;transition:all .15s}.sb-risk-card--selected,.sb-risk-card:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.sb-risk-card--selected{background:#6366f11a;box-shadow:0 0 0 1px #6366f1;box-shadow:0 0 0 1px var(--color-primary,#6366f1)}.sb-risk-label{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.9rem;font-weight:600}.sb-risk-desc{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem}.sb-builder-actions{align-items:flex-start;display:flex;flex-direction:column;gap:8px}.sb-builder-start{align-items:center;background:#6366f1;background:var(--color-primary,#6366f1);border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:8px;padding:12px 28px;transition:all .15s}.sb-builder-start:hover:not(:disabled){background:#4f46e5}.sb-builder-start:disabled{cursor:not-allowed;opacity:.4}.sb-builder-hint{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.78rem;margin:0}.sb-builder-preview{position:sticky;top:24px}.sb-preview-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;padding:24px}.sb-preview-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.95rem;font-weight:600;margin:0 0 16px}.sb-preview-empty{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.85rem;line-height:1.5}.sb-preview-section{margin-bottom:16px}.sb-preview-section h4{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;font-weight:600;letter-spacing:.04em;margin:0 0 8px;text-transform:uppercase}.sb-preview-list{list-style:none;margin:0;padding:0}.sb-preview-list li{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.82rem;padding:4px 0}.sb-preview-list li:before{color:#6366f1;color:var(--color-primary,#6366f1);content:"→ "}.sb-preview-tags{display:flex;flex-wrap:wrap;gap:4px}.sb-complexity{border-radius:4px;font-size:.85rem;font-weight:600;padding:2px 10px}.sb-complexity--low{background:#10b98126;color:#6ee7b7}.sb-complexity--medium{background:#f59e0b26;color:#fbbf24}.sb-complexity--high{background:#ef444426;color:#fca5a5}.sb-assess{background:#0f1117;background:var(--color-background,#0f1117);min-height:100vh}.sb-zt-container{height:auto;min-height:calc(100vh - 40px)}.sb-zt-container .zt-scroll-area{overflow-y:visible;padding:16px 20px;padding:var(--space-4,16px) var(--space-5,20px)}.sb-zt-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.78rem;margin:2px 0 0}.sb-header-tags{display:flex;flex-wrap:wrap;gap:4px}.sb-tab-count{background:#ef4444;font-size:.6rem;font-weight:700;height:16px;justify-content:center;margin-left:4px;min-width:16px;padding:0 4px}.sb-assess-run-btn--header,.sb-tab-count{align-items:center;border-radius:8px;color:#fff;display:inline-flex}.sb-assess-run-btn--header{background:#6366f1;background:var(--color-primary,#6366f1);border:none;border-radius:var(--radius-lg,8px);cursor:pointer;font-size:.8rem;font-weight:600;gap:6px;padding:6px 14px;transition:background .15s;white-space:nowrap}.sb-assess-run-btn--header:hover{background:#4f46e5}.sb-assess-container{margin:0 auto;max-width:1000px;padding:0 24px 64px}.sb-assess-header{flex-wrap:wrap;justify-content:space-between;padding:20px 0}.sb-assess-header,.sb-assess-header-left{align-items:center;display:flex;gap:12px}.sb-assess-back{align-items:center;background:#0000;border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;height:32px;justify-content:center;transition:all .15s;width:32px}.sb-assess-back:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235)}.sb-assess-back:hover,.sb-assess-title{color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-assess-title{font-size:1.2rem;font-weight:600;margin:0}.sb-assess-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;margin:0}.sb-assess-tabs{background:#1e2235;background:var(--color-surface-hover,#1e2235);border-radius:8px;display:flex;padding:2px}.sb-assess-tab{align-items:center;background:#0000;border:none;border-radius:6px;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:flex;font-size:.8rem;font-weight:500;gap:6px;padding:6px 14px;transition:all .15s}.sb-assess-tab.active{background:#1a1d2e;background:var(--color-surface,#1a1d2e);box-shadow:0 1px 3px #0003;color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-assess-tab:disabled{cursor:not-allowed;opacity:.4}.sb-assess-stats{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);display:flex;flex-wrap:wrap;gap:24px;margin-bottom:16px;padding:16px 0}.sb-stat{align-items:baseline;display:flex;gap:6px}.sb-stat-value{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.2rem;font-weight:700}.sb-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.78rem}.sb-assess-tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:24px}.sb-assess-pillars{display:flex;flex-direction:column;gap:12px}.sb-pillar-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;overflow:hidden;transition:border-color .15s}.sb-pillar-card:hover{border-color:#3d4260;border-color:var(--color-border-hover,#3d4260)}.sb-pillar-header{align-items:center;border-left:3px solid #0000;cursor:pointer;display:flex;gap:12px;padding:16px 20px;transition:background .15s}.sb-pillar-header:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235)}.sb-pillar-icon{font-size:1.2rem}.sb-pillar-name{color:#e2e8f0;color:var(--color-text,#e2e8f0);flex:1 1;font-size:.95rem;font-weight:600}.sb-pillar-maturity{font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.sb-pillar-status{border-radius:4px;font-size:.7rem;font-weight:500;padding:2px 8px}.sb-pillar-status--not-started{background:#6b728033;color:#9ca3af}.sb-pillar-status--planning{background:#eab30826;color:#fbbf24}.sb-pillar-status--in-progress{background:#3b82f626;color:#60a5fa}.sb-pillar-status--deployed{background:#10b98126;color:#34d399}.sb-pillar-title-block{display:flex;flex:1 1;flex-direction:column;gap:2px}.sb-pillar-cap-count{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.7rem}.sb-pillar-detail{border-top:1px solid #2d3148;border-top:1px solid var(--color-border,#2d3148);display:flex;flex-direction:column;gap:4px;padding:4px 12px 12px}.sb-pillar-controls{display:flex;flex-direction:column;gap:16px;padding-top:16px}.sb-control-group{display:flex;flex-direction:column;gap:6px}.sb-control-group label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.sb-maturity-btns{display:flex;flex-wrap:wrap;gap:6px}.sb-maturity-btn{background:#0000;border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:6px;color:#e2e8f0;color:var(--color-text,#e2e8f0);cursor:pointer;font-size:.75rem;font-weight:500;letter-spacing:.02em;padding:6px 14px;text-transform:uppercase;transition:all .15s}.sb-maturity-btn:hover{border-color:#6366f1;border-color:var(--color-primary,#6366f1)}.sb-maturity-btn.active{border-color:#0000}.sb-select{background:#0f1117;background:var(--color-background,#0f1117);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;max-width:240px;padding:8px 12px}.sb-tab-badge{align-items:center;background:#ef4444;border-radius:9px;color:#fff;display:inline-flex;font-size:.65rem;font-weight:700;height:18px;justify-content:center;line-height:1;min-width:18px;padding:0 5px}.sb-stat-value--warn{color:#ef4444}.sb-input{background:#0f1117;background:var(--color-background,#0f1117);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;box-sizing:border-box;color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;padding:8px 12px;width:100%}.sb-input::placeholder{color:#64748b;color:var(--color-text-muted,#64748b)}.sb-input:focus{border-color:#6366f1;border-color:var(--color-primary,#6366f1);box-shadow:0 0 0 2px #6366f126;outline:none}.sb-cap-card{background:#0f1117;background:var(--color-background,#0f1117);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;overflow:hidden;transition:border-color .15s}.sb-cap-card:hover{border-color:#3d4260;border-color:var(--color-border-hover,#3d4260)}.sb-cap-header{align-items:center;cursor:pointer;display:flex;gap:8px;justify-content:space-between;padding:12px 14px;transition:background .15s}.sb-cap-header:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235)}.sb-cap-header-left{align-items:center;display:flex;flex:1 1;gap:8px;min-width:0}.sb-cap-header-right{align-items:center;display:flex;flex-shrink:0;gap:8px}.sb-cap-check{color:#4b5563;color:var(--color-text-muted,#4b5563);flex-shrink:0}.sb-cap-check--done{color:#10b981}.sb-cap-name{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.sb-cap-critical{align-items:center;background:#ef44441f;color:#f87171;display:inline-flex;flex-shrink:0;gap:3px;padding:1px 6px}.sb-cap-critical,.sb-cap-maturity-badge{border-radius:4px;font-size:.65rem;font-weight:600;white-space:nowrap}.sb-cap-maturity-badge{letter-spacing:.03em;padding:2px 8px;text-transform:uppercase}.sb-cap-detail{border-top:1px solid #2d3148;border-top:1px solid var(--color-border,#2d3148);display:flex;flex-direction:column;gap:16px;padding:14px}.sb-cap-desc{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border-left:3px solid #6366f1;border-left:3px solid var(--color-primary,#6366f1);border-radius:8px;color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.82rem;line-height:1.5;margin:0;padding:10px 14px}.sb-maturity-grid{display:flex;flex-direction:column;gap:6px}.sb-maturity-card{align-items:flex-start;background:#0000;border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;cursor:pointer;display:flex;gap:10px;padding:10px 14px;text-align:left;transition:all .15s;width:100%}.sb-maturity-card:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235);border-color:#3d4260;border-color:var(--color-border-hover,#3d4260)}.sb-maturity-card.active{box-shadow:0 0 0 1px currentColor}.sb-maturity-dot{border-radius:50%;flex-shrink:0;height:10px;margin-top:3px;width:10px}.sb-maturity-info{display:flex;flex-direction:column;gap:2px}.sb-maturity-info strong{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.82rem}.sb-maturity-info span{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.72rem;line-height:1.4}.sb-cap-controls-row{display:flex;flex-wrap:wrap;gap:12px}.sb-control-group--grow{flex:1 1;min-width:200px}.sb-suggestion{background:#6366f10f;border:1px solid #6366f126;border-radius:10px;padding:14px}.sb-suggestion-header{align-items:center;color:#a5b4fc;display:flex;font-size:.78rem;font-weight:600;gap:6px;margin-bottom:8px}.sb-suggestion-products{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.sb-suggestion-product{background:#6366f11a;border:1px solid #6366f140;border-radius:6px;color:#c7d2fe;cursor:pointer;font-size:.75rem;font-weight:500;padding:4px 10px;transition:all .15s}.sb-suggestion-product:hover{background:#6366f133;border-color:#6366f1}.sb-suggestion-approach{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.78rem;line-height:1.5;margin:0 0 8px}.sb-suggestion-meta{color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.7rem;gap:16px}.sb-gaps{display:flex;flex-direction:column;gap:20px}.sb-gaps-summary{display:flex;flex-wrap:wrap;gap:12px}.sb-gap-stat-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;flex:1 1;min-width:100px;padding:16px;text-align:center}.sb-gap-stat-card--critical{border-color:#ef44444d}.sb-gap-stat-card--high{border-color:#f973164d}.sb-gap-stat-num{color:#e2e8f0;color:var(--color-text,#e2e8f0);display:block;font-size:1.5rem;font-weight:700}.sb-gap-stat-card--critical .sb-gap-stat-num{color:#ef4444}.sb-gap-stat-card--high .sb-gap-stat-num{color:#f97316}.sb-gaps-empty{color:#94a3b8;color:var(--color-text-muted,#94a3b8);padding:48px 24px;text-align:center}.sb-gaps-empty svg{color:#10b981;margin-bottom:12px}.sb-gaps-empty h3{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.1rem;margin:0 0 8px}.sb-gaps-empty p{font-size:.85rem;margin:0}.sb-gaps-list{display:flex;flex-direction:column;gap:20px}.sb-gaps-pillar-section{display:flex;flex-direction:column;gap:8px}.sb-gaps-pillar-header{align-items:center;border-left:3px solid #0000;display:flex;gap:8px;padding-left:10px}.sb-gaps-pillar-header h3{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.95rem;font-weight:600;margin:0}.sb-gaps-count{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.75rem;margin-left:8px}.sb-gap-detail-card{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;display:flex;flex-direction:column;gap:10px;padding:16px}.sb-gap-detail-header{justify-content:space-between}.sb-gap-detail-header,.sb-gap-detail-left{align-items:center;display:flex;gap:8px}.sb-gap-detail-left strong{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.9rem}.sb-gap-detail-desc{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.82rem;line-height:1.5;margin:0}.sb-gap-maturity-flow{align-items:center;display:flex;flex-wrap:wrap;gap:8px}.sb-gap-maturity-badge{border-radius:4px;font-size:.72rem;font-weight:600;letter-spacing:.03em;padding:2px 10px;text-transform:uppercase}.sb-gap-arrow{font-size:1rem}.sb-gap-arrow,.sb-gap-current-solution{color:#64748b;color:var(--color-text-muted,#64748b)}.sb-gap-current-solution{font-size:.75rem;font-style:italic;margin-left:auto}.sb-gap-suggestion{background:#6366f10f;border:1px solid #6366f11f;border-radius:8px;padding:12px}.sb-gap-suggestion-header{align-items:center;color:#a5b4fc;display:flex;font-size:.78rem;gap:6px;margin-bottom:6px}.sb-gap-suggestion p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.78rem;line-height:1.5;margin:0 0 8px}.sb-gap-suggestion-products{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px}.sb-gap-product-tag{background:#6366f11a;border:1px solid #6366f133;border-radius:4px;color:#c7d2fe;font-size:.72rem;font-weight:500;padding:3px 8px}.sb-gap-suggestion-meta{color:#64748b;color:var(--color-text-muted,#64748b);display:flex;font-size:.7rem;gap:16px}.sb-exec-stats{grid-gap:12px;display:grid;gap:12px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:24px}.sb-exec-stat-card{align-items:center;background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;display:flex;gap:14px;padding:18px}.sb-exec-stat-info{display:flex;flex:1 1;flex-direction:column;gap:2px}.sb-exec-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.72rem;letter-spacing:.03em;text-transform:uppercase}.sb-exec-stat-value{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.1rem;font-weight:700}.sb-exec-score{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem;font-weight:600;white-space:nowrap}.sb-results-section{margin-bottom:28px}.sb-results-section h3{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.95rem;font-weight:600;margin:0 0 14px;padding-bottom:8px}.sb-results-pillar-label{align-items:center;display:flex;gap:6px;min-width:160px}.sb-maturity-dist{align-items:flex-end;background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:10px;display:flex;gap:16px;height:120px;padding:16px 24px}.sb-dist-item{align-items:center;display:flex;flex:1 1;flex-direction:column;gap:4px;height:100%}.sb-dist-bar-container{align-items:flex-end;display:flex;flex:1 1;justify-content:center;width:100%}.sb-dist-bar{border-radius:4px 4px 0 0;min-height:4px;transition:height .3s ease;width:32px}.sb-dist-count{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:700}.sb-dist-label{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.65rem;letter-spacing:.04em;text-transform:uppercase}.sb-assess-run{padding:24px 0;text-align:center}.sb-assess-run-btn{align-items:center;background:linear-gradient(135deg,#6366f1,#8b5cf6);border:none;border-radius:12px;box-shadow:0 4px 16px #6366f14d;color:#fff;cursor:pointer;display:inline-flex;font-size:1rem;font-weight:600;gap:10px;padding:14px 36px;transition:all .2s}.sb-assess-run-btn:hover{box-shadow:0 6px 24px #6366f166;transform:translateY(-1px)}.sb-results{display:flex;flex-direction:column;gap:24px;position:relative}.sb-watermark{color:#b4530914;font-size:4rem;font-weight:800;left:50%;letter-spacing:.05em;pointer-events:none;position:fixed;top:50%;transform:translate(-50%,-50%) rotate(-35deg);-webkit-user-select:none;user-select:none;white-space:nowrap;z-index:1}.sb-results-disclaimer{background:#451a03;border:1px solid #92400e;border-radius:8px;color:#fde68a;font-size:.8rem;padding:12px 16px;text-align:center}.sb-results-readiness{align-items:center;background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;display:flex;gap:16px;padding:24px}.sb-results-readiness svg{color:#6366f1;color:var(--color-primary,#6366f1)}.sb-results-readiness-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.8rem;font-weight:600;letter-spacing:.04em;text-transform:uppercase}.sb-results-readiness-level{font-size:1.5rem;font-weight:700}.sb-results-readiness-score{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.8rem;font-weight:800;margin-left:auto}.sb-results-pillars{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;display:flex;flex-direction:column;gap:12px;padding:24px}.sb-results-pillar{grid-gap:12px;align-items:center;display:grid;gap:12px;grid-template-columns:140px 1fr 100px}.sb-results-pillar-name{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:500}.sb-results-pillar-bar{background:#0f1117;background:var(--color-background,#0f1117);border-radius:4px;height:8px;overflow:hidden}.sb-results-pillar-fill{border-radius:4px;height:100%;transition:width .6s ease}.sb-results-pillar-maturity{font-size:.75rem;font-weight:600;letter-spacing:.03em;text-align:right;text-transform:uppercase}.sb-results-gaps{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;padding:24px}.sb-results-gaps h3{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1rem;font-weight:600;margin:0 0 16px}.sb-results-gap-stats{display:flex;gap:24px;margin-bottom:20px}.sb-gap-stat{display:flex;flex-direction:column;gap:2px}.sb-gap-stat-value{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.5rem;font-weight:700}.sb-gap-stat--critical .sb-gap-stat-value{color:#ef4444}.sb-gap-stat-label{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.75rem}.sb-gap-pillar{margin-bottom:16px}.sb-gap-pillar h4{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:600;margin:0 0 8px}.sb-gap-item{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);display:flex;gap:12px;padding:10px 0}.sb-gap-item:last-child{border-bottom:none}.sb-gap-priority{border-radius:3px;flex-shrink:0;font-size:.65rem;font-weight:700;height:fit-content;margin-top:2px;padding:2px 6px;text-transform:uppercase}.sb-gap-priority--critical{background:#ef444426;color:#fca5a5}.sb-gap-priority--high{background:#f59e0b26;color:#fbbf24}.sb-gap-priority--medium{background:#3b82f626;color:#60a5fa}.sb-gap-priority--low{background:#6b728026;color:#9ca3af}.sb-gap-item strong{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem}.sb-gap-item p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.78rem;line-height:1.4;margin:4px 0 0}.sb-results-recs{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:12px;padding:24px}.sb-results-recs h3{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1rem;font-weight:600;margin:0 0 16px}.sb-rec-item{border-bottom:1px solid #2d3148;border-bottom:1px solid var(--color-border,#2d3148);padding:12px 0}.sb-rec-item:last-child{border-bottom:none}.sb-rec-header{align-items:center;display:flex;gap:10px;margin-bottom:6px}.sb-rec-priority{border-radius:3px;font-size:.65rem;font-weight:700;padding:2px 6px;text-transform:uppercase}.sb-rec-priority--critical{background:#ef444426;color:#fca5a5}.sb-rec-priority--high{background:#f59e0b26;color:#fbbf24}.sb-rec-pillar{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.8rem;font-weight:600}.sb-rec-effort{font-size:.75rem;margin-left:auto}.sb-rec-effort,.sb-rec-item p{color:#94a3b8;color:var(--color-text-muted,#94a3b8)}.sb-rec-item p{font-size:.82rem;line-height:1.5;margin:0}.sb-modal-overlay{align-items:center;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#0009;display:flex;inset:0;justify-content:center;padding:24px;position:fixed;z-index:2000}.sb-modal{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:16px;max-width:520px;padding:40px;position:relative;text-align:center;width:100%}.sb-modal-close{background:none;border:none;color:#64748b;color:var(--color-text-muted,#64748b);cursor:pointer;padding:4px;position:absolute;right:16px;top:16px}.sb-modal-close:hover{color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-modal-icon{color:#10b981;margin-bottom:16px}.sb-modal-title{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.3rem;font-weight:700;margin:0 0 8px}.sb-modal-stats{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.9rem;margin:0 0 24px}.sb-modal-benefits{margin-bottom:24px;text-align:left}.sb-modal-benefits h3{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.85rem;font-weight:600;margin:0 0 12px}.sb-modal-benefits ul{display:flex;flex-direction:column;gap:8px;list-style:none;margin:0;padding:0}.sb-modal-benefits li{align-items:center;color:#e2e8f0;color:var(--color-text,#e2e8f0);display:flex;font-size:.85rem;gap:8px}.sb-modal-benefits li svg{color:#10b981;flex-shrink:0}.sb-modal-actions{display:flex;gap:12px;margin-bottom:16px}.sb-modal-btn{align-items:center;border-radius:10px;cursor:pointer;display:flex;flex:1 1;font-size:.85rem;font-weight:600;gap:8px;justify-content:center;padding:12px 16px;transition:all .15s}.sb-modal-btn--primary{background:#6366f1;background:var(--color-primary,#6366f1);border:none;color:#fff}.sb-modal-btn--primary:hover{background:#4f46e5}.sb-modal-btn--secondary{background:#0000;border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-modal-btn--secondary:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235)}.sb-modal-continue{align-items:center;background:none;border:none;color:#94a3b8;color:var(--color-text-muted,#94a3b8);cursor:pointer;display:inline-flex;font-size:.8rem;gap:6px;padding:8px}.sb-modal-continue:hover{color:#e2e8f0;color:var(--color-text,#e2e8f0)}@media (max-width:500px){.sb-modal-actions{flex-direction:column}}.sb-save-modal{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:16px;box-shadow:0 24px 48px #00000080;max-width:420px;padding:32px;position:relative;text-align:center;width:90vw}.sb-save-header{margin-bottom:20px}.sb-save-header svg{color:#fbbf24;margin-bottom:12px}.sb-save-header h2{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.25rem;font-weight:700;margin:0 0 8px}.sb-save-subtitle{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem;line-height:1.5;margin:0}.sb-save-error{background:#ef44441a;border:1px solid #ef444433;border-radius:8px;color:#f87171;font-size:.85rem;margin-bottom:16px;padding:10px 14px}.sb-save-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.sb-save-input{background:#1e2235;background:var(--color-surface-hover,#1e2235);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);border-radius:8px;box-sizing:border-box;color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:.9rem;height:44px;padding:0 14px;width:100%}.sb-save-input::placeholder{color:#64748b;color:var(--color-text-muted,#64748b)}.sb-save-input:focus{border-color:#6366f1;border-color:var(--color-primary,#6366f1);box-shadow:0 0 0 2px #6366f133;outline:none}.sb-save-btn{align-items:center;border-radius:8px;cursor:pointer;display:flex;font-size:.9rem;font-weight:600;gap:8px;height:44px;justify-content:center;transition:all .15s;width:100%}.sb-save-btn--primary{background:#fbbf24;border:none;color:#1a1d2e}.sb-save-btn--primary:hover{background:#f59e0b}.sb-save-btn--primary:disabled{cursor:not-allowed;opacity:.5}.sb-save-btn--oauth{background:#1a1d2e;background:var(--color-surface,#1a1d2e);border:1px solid #2d3148;border:1px solid var(--color-border,#2d3148);color:#e2e8f0;color:var(--color-text,#e2e8f0)}.sb-save-btn--oauth:hover{background:#1e2235;background:var(--color-surface-hover,#1e2235)}.sb-save-divider{color:#64748b;color:var(--color-text-muted,#64748b);font-size:.8rem;margin:16px 0;position:relative;text-align:center}.sb-save-divider:after,.sb-save-divider:before{border-top:1px solid #2d3148;border-top:1px solid var(--color-border,#2d3148);content:"";position:absolute;top:50%;width:35%}.sb-save-divider:before{left:0}.sb-save-divider:after{right:0}.sb-save-switch{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem;margin-top:16px}.sb-save-switch p{margin:0}.sb-save-link{background:none;border:none;color:#fbbf24;cursor:pointer;font-size:.85rem;font-weight:600;padding:0}.sb-save-link:hover{color:#f59e0b}.sb-save-notice{background:#fbbf2414;border:1px solid #fbbf2426;border-radius:8px;color:#fde68a;font-size:.75rem;line-height:1.5;margin-top:16px;padding:10px 14px}.sb-save-success{align-items:center;display:flex;flex-direction:column;gap:16px;padding:16px 0}.sb-save-success svg{color:#10b981}.sb-save-success h2{color:#e2e8f0;color:var(--color-text,#e2e8f0);font-size:1.25rem;font-weight:700;margin:0}.sb-save-success p{color:#94a3b8;color:var(--color-text-muted,#94a3b8);font-size:.85rem;line-height:1.5;margin:0}.sb-banner-btn--save{background:#fbbf24;border-color:#fbbf24;color:#1a1d2e;font-weight:600}.sb-banner-btn--save:hover{background:#f59e0b;border-color:#f59e0b}
/*# sourceMappingURL=main.79077587.css.map*/