:root{--bg-primary: #0A0E17;--bg-secondary: #111827;--bg-card: #141B2D;--bg-input: #0D1321;--border-subtle: rgba(255, 255, 255, .06);--border-input: rgba(255, 255, 255, .1);--border-focus: #3B82F6;--text-primary: #F1F5F9;--text-secondary: #94A3B8;--text-muted: #64748B;--accent-blue: #3B82F6;--accent-blue-hover: #2563EB;--accent-cyan: #06B6D4;--accent-emerald: #10B981;--glow-blue: rgba(59, 130, 246, .15);--glow-cyan: rgba(6, 182, 212, .08);--danger: #EF4444;--warning-amber: #F59E0B;--radius-sm: 8px;--radius-md: 12px;--radius-lg: 16px;--radius-xl: 20px}*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}body{font-family:DM Sans,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.login-layout{display:flex;min-height:100vh;overflow:hidden}.left-panel{flex:1;display:flex;flex-direction:column;justify-content:space-between;padding:48px;position:relative;overflow:hidden}.left-panel:before{content:"";position:absolute;inset:0;background:radial-gradient(ellipse 80% 60% at 20% 80%,rgba(6,182,212,.07),transparent),radial-gradient(ellipse 60% 50% at 70% 20%,rgba(59,130,246,.05),transparent);pointer-events:none}.mol-grid{position:absolute;inset:0;opacity:.03;background-image:radial-gradient(circle at 1px 1px,rgba(255,255,255,.5) 1px,transparent 0);background-size:40px 40px;pointer-events:none}.hex-deco{position:absolute;border:1px solid rgba(59,130,246,.08);border-radius:4px;transform:rotate(30deg);pointer-events:none}.hex-deco.h1{width:180px;height:180px;top:15%;left:60%;animation:float-hex 20s ease-in-out infinite}.hex-deco.h2{width:120px;height:120px;top:55%;left:20%;border-color:#06b6d40f;animation:float-hex 25s ease-in-out infinite reverse}.hex-deco.h3{width:80px;height:80px;top:75%;left:70%;border-color:#10b9810d;animation:float-hex 18s ease-in-out infinite}.hex-deco.h4{width:220px;height:220px;top:-5%;left:30%;border-color:#3b82f60a;animation:float-hex 30s ease-in-out infinite reverse}@keyframes float-hex{0%,to{transform:rotate(30deg) translate(0)}25%{transform:rotate(35deg) translate(10px,-15px)}50%{transform:rotate(28deg) translate(-5px,10px)}75%{transform:rotate(33deg) translate(8px,5px)}}.brand-top{position:relative;z-index:2}.logo-mark{display:flex;align-items:center;gap:14px}.logo-icon{width:44px;height:44px;position:relative}.logo-icon svg{width:100%;height:100%}.logo-text{font-family:DM Sans,sans-serif;font-size:22px;font-weight:700;letter-spacing:-.5px;color:var(--text-primary)}.logo-text span{color:var(--accent-blue)}.brand-center{position:relative;z-index:2;max-width:480px}.brand-headline{font-family:"Instrument Serif",serif;font-size:52px;line-height:1.1;letter-spacing:-1px;margin-bottom:20px;color:var(--text-primary)}.brand-headline .highlight{background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.brand-sub{font-size:16px;line-height:1.7;color:var(--text-secondary);max-width:400px}.stats-row{display:flex;gap:40px;margin-top:48px}.stat-item{display:flex;flex-direction:column;gap:4px}.stat-number{font-size:28px;font-weight:700;letter-spacing:-.5px;background:linear-gradient(135deg,var(--text-primary),var(--text-secondary));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.stat-label{font-size:12px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted)}.brand-bottom{position:relative;z-index:2;display:flex;align-items:center;gap:24px}.compliance-badge{display:flex;align-items:center;gap:8px;padding:8px 14px;border:1px solid var(--border-subtle);border-radius:100px;font-size:12px;color:var(--text-muted);letter-spacing:.5px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#ffffff05}.compliance-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--accent-emerald);box-shadow:0 0 8px #10b98166}.right-panel{width:520px;min-height:100vh;display:flex;flex-direction:column;justify-content:center;padding:48px 56px;background:var(--bg-card);border-left:1px solid var(--border-subtle);position:relative}.right-panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(59,130,246,.2),transparent)}.form-header{margin-bottom:40px}.form-header h2{font-size:26px;font-weight:600;letter-spacing:-.5px;margin-bottom:8px}.form-header p{font-size:14px;color:var(--text-secondary)}.form-header p a{color:var(--accent-blue);text-decoration:none;font-weight:500;transition:color .2s}.form-header p a:hover{color:var(--accent-cyan)}.oauth-row{display:flex;gap:12px;margin-bottom:28px}.oauth-btn{flex:1;display:flex;align-items:center;justify-content:center;gap:10px;padding:12px 16px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-md);color:var(--text-secondary);font-family:DM Sans,sans-serif;font-size:13px;font-weight:500;cursor:pointer;transition:all .2s ease}.oauth-btn:hover{border-color:#ffffff2e;background:#ffffff0a;color:var(--text-primary)}.oauth-btn svg{width:18px;height:18px;flex-shrink:0}.divider{display:flex;align-items:center;gap:16px;margin-bottom:28px}.divider:before,.divider:after{content:"";flex:1;height:1px;background:var(--border-subtle)}.divider span{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted)}.field{margin-bottom:20px}.field label{display:block;font-size:13px;font-weight:500;color:var(--text-secondary);margin-bottom:8px;letter-spacing:.2px}.input-wrap{position:relative}.input-wrap .icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none;display:flex}.input-wrap .icon svg{width:18px;height:18px}.input-wrap input{width:100%;padding:13px 14px 13px 44px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:var(--radius-md);color:var(--text-primary);font-family:DM Sans,sans-serif;font-size:14px;outline:none;transition:all .2s ease}.input-wrap input::placeholder{color:var(--text-muted)}.input-wrap input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px var(--glow-blue),0 0 20px var(--glow-blue)}.input-wrap .toggle-pw{position:absolute;right:14px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);cursor:pointer;display:flex;padding:2px;transition:color .2s}.input-wrap .toggle-pw:hover{color:var(--text-secondary)}.input-wrap .toggle-pw svg{width:18px;height:18px}.field-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px}.remember{display:flex;align-items:center;gap:8px;cursor:pointer}.remember input[type=checkbox]{appearance:none;width:16px;height:16px;border:1px solid var(--border-input);border-radius:4px;background:var(--bg-input);cursor:pointer;position:relative;transition:all .2s}.remember input[type=checkbox]:checked{background:var(--accent-blue);border-color:var(--accent-blue)}.remember input[type=checkbox]:checked:after{content:"";position:absolute;left:4.5px;top:1.5px;width:5px;height:9px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}.remember span{font-size:13px;color:var(--text-secondary)}.forgot-link{font-size:13px;color:var(--accent-blue);text-decoration:none;font-weight:500;transition:color .2s}.forgot-link:hover{color:var(--accent-cyan)}.submit-btn{width:100%;padding:14px 24px;background:var(--accent-blue);border:none;border-radius:var(--radius-md);color:#fff;font-family:DM Sans,sans-serif;font-size:15px;font-weight:600;cursor:pointer;transition:all .25s ease;position:relative;overflow:hidden;letter-spacing:.2px}.submit-btn:before{content:"";position:absolute;inset:0;background:linear-gradient(135deg,transparent,rgba(255,255,255,.1),transparent);transform:translate(-100%);transition:transform .5s ease}.submit-btn:hover{background:var(--accent-blue-hover);box-shadow:0 4px 24px #3b82f64d,0 0 60px #3b82f61a;transform:translateY(-1px)}.submit-btn:hover:before{transform:translate(100%)}.submit-btn:active{transform:translateY(0)}.form-footer{margin-top:32px;padding-top:24px;border-top:1px solid var(--border-subtle);text-align:center}.form-footer p{font-size:12px;color:var(--text-muted);line-height:1.6}.form-footer a{color:var(--text-secondary);text-decoration:none;transition:color .2s}.form-footer a:hover{color:var(--accent-blue)}@keyframes fadeInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.brand-top{animation:fadeInUp .6s ease-out both;animation-delay:.1s}.brand-center{animation:fadeInUp .6s ease-out both;animation-delay:.25s}.brand-bottom{animation:fadeInUp .6s ease-out both;animation-delay:.4s}.form-header{animation:fadeInUp .5s ease-out both;animation-delay:.3s}.oauth-row{animation:fadeInUp .5s ease-out both;animation-delay:.4s}.divider{animation:fadeInUp .5s ease-out both;animation-delay:.45s}.field:nth-child(1){animation:fadeInUp .5s ease-out both;animation-delay:.5s}.field:nth-child(2){animation:fadeInUp .5s ease-out both;animation-delay:.55s}.field-row{animation:fadeInUp .5s ease-out both;animation-delay:.6s}.submit-btn{animation:fadeInUp .5s ease-out both;animation-delay:.65s}.mobile-logo{display:none}@media(max-width:1024px){.login-layout{overflow:auto}.left-panel{display:none}.mobile-logo{display:flex;justify-content:center;margin-bottom:32px}.right-panel{width:100%;max-width:480px;margin:0 auto;min-height:100vh;min-height:100dvh;border-left:none;background:var(--bg-primary);padding:48px 32px;justify-content:center}}@media(max-width:480px){.right-panel{padding:48px 20px 40px;justify-content:flex-start}.mobile-logo,.form-header{margin-bottom:28px}.form-header h2{font-size:22px}.oauth-row{gap:8px;margin-bottom:24px}.oauth-btn{padding:11px 10px;font-size:12px;gap:6px}.oauth-btn svg{width:16px;height:16px}.divider{margin-bottom:24px}.field{margin-bottom:16px}.input-wrap input{padding:12px 14px 12px 40px;font-size:16px}.field-row{margin-bottom:24px}.submit-btn{padding:13px 20px;font-size:15px}.form-footer{margin-top:24px;padding-top:20px}}@media(max-width:360px){.right-panel{padding:40px 16px 32px}.form-header h2{font-size:20px}.oauth-btn{padding:10px 6px;font-size:11px;gap:5px}.oauth-btn svg{width:14px;height:14px}.remember span,.forgot-link{font-size:12px}}.al-content{padding:28px 32px 40px;flex:1;animation:alFadeIn .4s ease-out both .05s}@keyframes alFadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.al-header{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:24px}.al-header-left{display:flex;flex-direction:column;gap:4px}.al-header-right{display:flex;gap:8px;align-items:center}.al-page-title{font-size:22px;font-weight:700;letter-spacing:-.5px;display:flex;align-items:center;gap:10px}.al-count-badge{display:inline-flex;align-items:center;justify-content:center;background:var(--danger);color:#fff;font-size:12px;font-weight:700;min-width:24px;height:24px;border-radius:100px;padding:0 8px}.al-scan-time{font-size:12px;color:var(--text-muted)}.al-summary-strip{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.al-summary-card{background:var(--bg-card);border:1px solid;border-radius:12px;padding:16px 20px;display:flex;align-items:center;gap:12px;cursor:pointer;transition:all .2s}.al-summary-card:hover{transform:translateY(-1px);box-shadow:0 4px 16px #00000040}.al-summary-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.al-summary-count{font-size:28px;font-weight:700;letter-spacing:-1px;line-height:1}.al-summary-label{font-size:12px;color:var(--text-secondary);font-weight:500}.al-filter-bar{margin-bottom:20px;display:flex;flex-direction:column;gap:12px}.al-filter-tabs{display:flex;gap:4px;overflow-x:auto;padding-bottom:4px}.al-filter-tab{padding:8px 16px;border-radius:8px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}.al-filter-tab:hover{border-color:#ffffff1f;color:var(--text-primary)}.al-filter-tab--active{background:#3b82f61f;border-color:#3b82f633;color:var(--accent-blue)}.al-filter-controls{display:flex;gap:10px;align-items:center}.al-search-wrap{position:relative;flex:1;max-width:320px}.al-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex;pointer-events:none}.al-search-input{width:100%;padding:8px 12px 8px 36px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:12px;outline:none;transition:all .2s}.al-search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61f}.al-search-input::placeholder{color:var(--text-muted)}.al-sort-select{padding:8px 32px 8px 12px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:8px;color:var(--text-primary);font-family:inherit;font-size:12px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748B' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer}.al-view-toggle{display:flex;border:1px solid var(--border-input);border-radius:8px;overflow:hidden}.al-view-btn{padding:8px 14px;background:transparent;border:none;color:var(--text-muted);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.al-view-btn--active{background:#3b82f61f;color:var(--accent-blue)}.al-view-btn:not(:last-child){border-right:1px solid var(--border-input)}.al-groups{display:flex;flex-direction:column;gap:16px}.al-group{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden}.al-group-header{display:flex;align-items:center;gap:10px;padding:14px 20px;cursor:pointer;transition:background .15s;border-bottom:1px solid var(--border-subtle)}.al-group-header:hover{background:#ffffff05}.al-group-header--critical{background:#ef44440a}.al-group-icon{font-size:18px}.al-group-name{font-size:13px;font-weight:600;flex:1}.al-group-count{background:#ffffff0f;color:var(--text-secondary);font-size:11px;font-weight:600;padding:2px 8px;border-radius:100px}.al-group-chevron{color:var(--text-muted);display:flex}.al-alert-row{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .12s;position:relative}.al-alert-row:last-child{border-bottom:none}.al-alert-row:hover{background:#ffffff05}.al-alert-border{position:absolute;left:0;top:0;bottom:0;width:4px}.al-alert-icon{width:38px;height:38px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:16px}.al-alert-content{flex:1;min-width:0}.al-alert-title-row{display:flex;align-items:center;gap:8px;margin-bottom:3px;flex-wrap:wrap}.al-alert-name{font-size:13.5px;font-weight:500}.al-alert-cas{font-size:11px;color:var(--text-muted);font-family:JetBrains Mono,monospace}.al-badge{display:inline-flex;align-items:center;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:600;letter-spacing:.2px}.al-badge--red{color:#ef4444;background:#ef44441f}.al-badge--amber{color:#f59e0b;background:#f59e0b1f}.al-badge--blue{color:#3b82f6;background:#3b82f61f}.al-badge--green{color:#10b981;background:#10b9811f}.al-badge--gray{color:#64748b;background:#64748b1f}.al-badge--purple{color:#a855f7;background:#a855f71f}.al-alert-desc{font-size:12px;color:var(--text-muted);line-height:1.4;margin-bottom:2px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.al-alert-meta{font-size:11px;color:var(--text-muted);opacity:.7}.al-alert-actions{display:flex;align-items:center;gap:6px;flex-shrink:0}.al-action-btn{font-family:inherit;cursor:pointer;transition:all .15s}.al-action-btn--primary{padding:6px 14px;border-radius:8px;border:1px solid;background:transparent;font-size:12px;font-weight:600;white-space:nowrap}.al-action-btn--primary:hover{filter:brightness(1.2);background:#ffffff08}.al-action-btn--icon{width:30px;height:30px;border-radius:8px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-muted);display:flex;align-items:center;justify-content:center;opacity:.5}.al-alert-row:hover .al-action-btn--icon{opacity:1}.al-action-btn--icon:hover{border-color:#ffffff26;color:var(--text-primary);background:#ffffff08}.al-flat-list{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden}.al-empty{text-align:center;padding:60px 20px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px}.al-empty-icon{font-size:48px;margin-bottom:16px}.al-empty-title{font-size:16px;font-weight:600;margin-bottom:6px}.al-empty-desc{font-size:13px;color:var(--text-muted)}.al-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:500;animation:alFadeIn .15s ease-out}.al-modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;width:440px;max-width:95vw;max-height:80vh;overflow:auto}.al-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;border-bottom:1px solid var(--border-subtle)}.al-modal-header h3{font-size:15px;font-weight:600}.al-modal-close{background:none;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-muted);cursor:pointer;padding:6px;display:flex;transition:all .15s}.al-modal-close:hover{color:var(--text-primary);border-color:#ffffff26}.al-modal-body{padding:20px 24px}.al-modal-desc{font-size:13px;color:var(--text-secondary);margin-bottom:16px;line-height:1.5}.al-modal-footer{display:flex;gap:10px;justify-content:flex-end;padding:16px 24px 20px;border-top:1px solid var(--border-subtle)}.al-modal-footer .s-btn:disabled{opacity:.4;cursor:not-allowed}.al-dismiss-options{display:flex;flex-direction:column;gap:6px;margin-bottom:12px}.al-dismiss-option{display:flex;align-items:center;gap:10px;padding:10px 14px;border:1px solid var(--border-subtle);border-radius:10px;cursor:pointer;font-size:13px;color:var(--text-secondary);transition:all .15s}.al-dismiss-option:hover{border-color:#ffffff1f}.al-dismiss-option--selected{border-color:#3b82f64d;background:#3b82f60f;color:var(--text-primary)}.al-dismiss-option input[type=radio]{display:none}.al-dismiss-textarea{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;resize:vertical;transition:all .2s}.al-dismiss-textarea:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f61f}.al-dismiss-textarea::placeholder{color:var(--text-muted)}.al-snooze-options{display:flex;gap:6px}.al-snooze-btn{padding:8px 16px;border:1px solid var(--border-subtle);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.al-snooze-btn:hover{border-color:#ffffff1f}.al-snooze-btn--selected{background:#3b82f61f;border-color:#3b82f633;color:var(--accent-blue)}.al-sub-content{padding:28px 32px 40px;flex:1;animation:alFadeIn .4s ease-out both .05s}.al-sub-header{display:flex;align-items:center;gap:12px;margin-bottom:24px}.al-back-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;border:1px solid var(--border-subtle);border-radius:8px;background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.al-back-btn:hover{border-color:#ffffff1f;color:var(--text-primary)}.al-sub-title{font-size:20px;font-weight:700;letter-spacing:-.3px}.al-timeline-wrap{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:24px;margin-bottom:24px;overflow-x:auto}.al-timeline{position:relative;height:80px;min-width:600px}.al-timeline-line{position:absolute;top:40px;left:0;right:0;height:2px;background:var(--border-subtle)}.al-timeline-today{position:absolute;top:0;bottom:0;width:2px;background:var(--accent-blue);z-index:2}.al-timeline-today-label{position:absolute;top:-2px;left:50%;transform:translate(-50%);font-size:10px;font-weight:600;color:var(--accent-blue);background:var(--bg-card);padding:2px 8px;border-radius:4px;white-space:nowrap}.al-timeline-zone{position:absolute;top:30px;bottom:10px;border-right:1px dashed rgba(255,255,255,.06)}.al-timeline-zone-label{position:absolute;bottom:-2px;right:4px;font-size:9px;color:var(--text-muted);opacity:.5}.al-timeline-dot{position:absolute;top:34px;width:12px;height:12px;border-radius:50%;cursor:pointer;transition:transform .15s;z-index:3;border:2px solid var(--bg-card)}.al-timeline-dot:hover{transform:scale(1.5);z-index:4}.al-timeline-dot-tooltip{display:none;position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:var(--bg-primary);border:1px solid var(--border-subtle);border-radius:8px;padding:8px 12px;font-size:11px;white-space:nowrap;z-index:10;pointer-events:none}.al-timeline-dot:hover .al-timeline-dot-tooltip{display:block}.al-table-wrap{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden}.al-table{width:100%;border-collapse:collapse}.al-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:.8px;color:var(--text-muted);font-weight:600;padding:12px 16px;background:#ffffff05;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.al-table td{padding:12px 16px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.al-table tr:last-child td{border-bottom:none}.al-table tr:hover td{background:#ffffff05}.al-table .mono{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.al-days-cell{display:flex;align-items:center;gap:4px}.al-days-number{font-size:18px;font-weight:700;line-height:1}.al-days-label{font-size:11px;color:var(--text-muted)}.al-progress-cell{display:flex;align-items:center;gap:8px}.al-progress-bar{flex:1;height:6px;border-radius:6px;background:#ffffff0f;overflow:hidden;min-width:60px}.al-progress-fill{height:100%;border-radius:6px;transition:width .3s ease}.al-progress-text{font-size:11px;font-weight:600;min-width:32px;text-align:right}.al-expiry-type{display:inline-flex;padding:2px 8px;border-radius:100px;font-size:10px;font-weight:600}.al-tabs{display:flex;gap:4px;margin-bottom:20px;overflow-x:auto}.al-tab{padding:10px 18px;border-radius:10px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;white-space:nowrap;transition:all .15s}.al-tab:hover{border-color:#ffffff1f;color:var(--text-primary)}.al-tab--active{background:#3b82f61f;border-color:#3b82f633;color:var(--accent-blue)}.al-class-badge{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:8px;font-size:13px;font-weight:700}.al-class-badge--A{background:#ef444426;color:#ef4444}.al-class-badge--B{background:#f59e0b26;color:#f59e0b}.al-class-badge--C{background:#3b82f626;color:#3b82f6}.al-h-badge{display:inline-flex;padding:2px 6px;border-radius:4px;font-size:10px;font-weight:600;font-family:JetBrains Mono,monospace;background:#ef44441a;color:#ef4444;margin-right:4px}.al-detail-overlay{position:fixed;inset:0;background:#0006;z-index:400;animation:alFadeIn .15s ease-out}.al-detail-panel{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:95vw;background:var(--bg-secondary);border-left:1px solid var(--border-subtle);z-index:401;display:flex;flex-direction:column;animation:alSlideIn .2s ease-out;overflow-y:auto}@keyframes alSlideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.al-detail-header{padding:20px 24px;border-bottom:1px solid var(--border-subtle);display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.al-detail-title{font-size:15px;font-weight:600;line-height:1.4;flex:1}.al-detail-badges{display:flex;gap:6px;margin-top:8px;flex-wrap:wrap}.al-detail-section{padding:16px 24px;border-bottom:1px solid rgba(255,255,255,.03)}.al-detail-section-title{font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;margin-bottom:12px}.al-reagent-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:16px}.al-reagent-name{font-size:14px;font-weight:600;margin-bottom:4px}.al-reagent-meta{font-size:12px;color:var(--text-muted);display:flex;flex-direction:column;gap:4px}.al-reagent-meta-row{display:flex;gap:16px}.al-detail-timeline{display:flex;flex-direction:column;gap:0;position:relative;padding-left:20px}.al-detail-timeline:before{content:"";position:absolute;left:5px;top:8px;bottom:8px;width:2px;background:var(--border-subtle)}.al-timeline-event{position:relative;padding:8px 0 8px 16px}.al-timeline-event:before{content:"";position:absolute;left:-17px;top:14px;width:8px;height:8px;border-radius:50%;background:var(--text-muted);border:2px solid var(--bg-secondary)}.al-timeline-event--active:before{background:var(--accent-blue)}.al-timeline-event--critical:before{background:#ef4444}.al-timeline-event-title{font-size:12px;font-weight:500;margin-bottom:2px}.al-timeline-event-time{font-size:11px;color:var(--text-muted)}.al-detail-actions{padding:20px 24px;display:flex;gap:8px;flex-wrap:wrap}.al-notif-panel{position:fixed;top:60px;right:80px;width:360px;max-height:520px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;z-index:300;display:flex;flex-direction:column;box-shadow:0 16px 48px #0006;animation:alFadeIn .15s ease-out}.al-notif-header{display:flex;align-items:center;justify-content:space-between;padding:16px 18px 12px;border-bottom:1px solid var(--border-subtle)}.al-notif-title{font-size:14px;font-weight:600}.al-notif-mark-read{font-size:11px;color:var(--accent-blue);background:none;border:none;cursor:pointer;font-family:inherit;font-weight:500}.al-notif-mark-read:hover{color:var(--accent-cyan)}.al-notif-tabs{display:flex;gap:2px;padding:8px 18px;border-bottom:1px solid var(--border-subtle)}.al-notif-tab{padding:6px 12px;border-radius:6px;border:none;background:transparent;color:var(--text-muted);font-size:11px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.al-notif-tab:hover{color:var(--text-secondary)}.al-notif-tab--active{background:#3b82f61f;color:var(--accent-blue)}.al-notif-list{flex:1;overflow-y:auto;max-height:360px}.al-notif-item{display:flex;gap:12px;padding:12px 18px;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:background .12s}.al-notif-item:hover{background:#ffffff05}.al-notif-item--unread{background:#ffffff08}.al-notif-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0;margin-top:5px}.al-notif-body{flex:1;min-width:0}.al-notif-item-title{font-size:12px;font-weight:500;margin-bottom:2px;line-height:1.3}.al-notif-item-desc{font-size:11px;color:var(--text-muted);line-height:1.3}.al-notif-item-time{font-size:10px;color:var(--text-muted);opacity:.6;white-space:nowrap;flex-shrink:0;margin-top:2px}.al-notif-footer{padding:12px 18px;border-top:1px solid var(--border-subtle);text-align:center}.al-notif-footer a{font-size:12px;color:var(--accent-blue);text-decoration:none;font-weight:500}.al-notif-footer a:hover{color:var(--accent-cyan)}.al-notif-overlay{position:fixed;inset:0;z-index:299}@media(max-width:1280px){.al-summary-strip{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.al-filter-controls{flex-wrap:wrap}.al-search-wrap{max-width:none;flex-basis:100%}}@media(max-width:768px){.al-content,.al-sub-content{padding:20px 16px 32px}.al-summary-strip{grid-template-columns:repeat(2,1fr);gap:8px}.al-summary-card{padding:12px 16px}.al-summary-count{font-size:22px}.al-alert-row{padding:12px 14px;gap:10px}.al-alert-cas{display:none}.al-alert-desc{-webkit-line-clamp:1}.al-action-btn--icon{display:none}.al-detail-panel{width:100%;max-width:100vw}.al-notif-panel{right:8px;left:8px;width:auto}.al-table{font-size:12px}.al-table th,.al-table td{padding:10px 12px}}@media(max-width:480px){.al-page-title{font-size:18px}.al-summary-strip{grid-template-columns:1fr 1fr}.al-summary-card{padding:10px 12px}.al-summary-count{font-size:20px}.al-filter-tabs{gap:3px}.al-filter-tab{padding:6px 10px;font-size:11px}.al-alert-row{flex-wrap:wrap}.al-alert-actions{width:100%;justify-content:flex-end;margin-top:4px}}.app-shell{display:flex;min-height:100vh;background:var(--bg-primary);font-family:DM Sans,-apple-system,BlinkMacSystemFont,sans-serif;color:var(--text-primary)}.app-sidebar{width:252px;min-height:100vh;background:var(--bg-card);border-right:1px solid var(--border-subtle);display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100;transition:transform .25s ease}.sidebar-overlay,.sidebar-close-btn{display:none}.sidebar-logo{display:flex;align-items:center;gap:12px;padding:24px 24px 28px;border-bottom:1px solid var(--border-subtle)}.sidebar-logo-icon{width:36px;height:36px}.sidebar-logo-text{font-size:18px;font-weight:700;letter-spacing:-.5px}.sidebar-logo-highlight{color:var(--accent-blue)}.sidebar-nav{padding:16px 12px;flex:1;overflow-y:auto}.nav-label{font-size:10px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:8px 12px;font-weight:600}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;cursor:pointer;font-size:13.5px;font-weight:400;color:var(--text-secondary);background:transparent;transition:all .15s ease;margin-bottom:2px;border:1px solid transparent}.nav-item:hover{background:#ffffff08}.nav-item--active{font-weight:500;color:var(--text-primary);background:#3b82f61f;border-color:#3b82f61f}.nav-item--active:hover{background:#3b82f61f}.nav-badge{margin-left:auto;background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:100px;min-width:20px;text-align:center}.sidebar-bottom{padding:16px 20px 24px;border-top:1px solid var(--border-subtle)}.plan-info{font-size:12px;color:var(--text-muted);margin-bottom:8px}.plan-bar{height:4px;border-radius:4px;background:#ffffff0f;overflow:hidden}.plan-bar-fill{height:100%;width:25.4%;border-radius:4px;background:linear-gradient(90deg,var(--accent-blue),var(--accent-cyan))}.app-main{margin-left:252px;flex:1;min-height:100vh;display:flex;flex-direction:column}.app-topbar{display:flex;align-items:center;justify-content:space-between;padding:16px 32px;border-bottom:1px solid var(--border-subtle);background:var(--bg-primary);position:sticky;top:0;z-index:50;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);gap:16px}.topbar-left{display:flex;align-items:center;gap:12px}.topbar-hamburger{display:none;background:none;border:1px solid var(--border-subtle);border-radius:10px;padding:8px;color:var(--text-secondary);cursor:pointer;align-items:center;justify-content:center}.page-title{font-size:18px;font-weight:600;letter-spacing:-.3px}.page-date{font-size:12px;color:var(--text-muted)}.search-wrap{position:relative;width:400px;flex-shrink:1;min-width:0}.search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);display:flex;pointer-events:none}.search-input{width:100%;padding:10px 14px 10px 42px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;transition:all .2s}.search-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.search-input::placeholder{color:var(--text-muted)}.search-kbd{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--text-muted);background:#ffffff0a;border:1px solid var(--border-subtle);border-radius:5px;padding:2px 8px;font-family:inherit}.topbar-right{display:flex;align-items:center;gap:16px}.notif-btn{position:relative;background:none;border:1px solid var(--border-subtle);border-radius:10px;padding:8px;color:var(--text-secondary);cursor:pointer;display:flex;transition:all .15s}.notif-btn:hover{border-color:#ffffff1f;background:#ffffff08}.notif-dot{position:absolute;top:6px;right:6px;width:8px;height:8px;border-radius:50%;background:var(--danger);border:2px solid var(--bg-primary)}.notif-count{position:absolute;top:-4px;right:-6px;background:var(--danger);color:#fff;font-size:9px;font-weight:700;min-width:16px;height:16px;border-radius:100px;display:flex;align-items:center;justify-content:center;padding:0 4px;border:2px solid var(--bg-primary)}.user-pill{display:flex;align-items:center;gap:10px;padding:6px 14px 6px 6px;border-radius:100px;border:1px solid var(--border-subtle);cursor:pointer;transition:all .15s}.user-pill:hover{border-color:#ffffff1f}.user-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--accent-blue),var(--accent-cyan));display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.user-name{font-size:13px;font-weight:500}.user-role{font-size:11px;color:var(--text-muted)}@media(max-width:1024px){.app-sidebar{transform:translate(-100%);z-index:200}.app-sidebar--open{transform:translate(0)}.sidebar-overlay{display:block;position:fixed;inset:0;background:#0000;z-index:199;pointer-events:none;transition:background .25s ease}.sidebar-overlay--visible{background:#0009;pointer-events:auto}.sidebar-close-btn{display:flex;align-items:center;justify-content:center;margin-left:auto;background:none;border:1px solid var(--border-subtle);border-radius:8px;padding:6px;color:var(--text-muted);cursor:pointer;transition:all .15s}.sidebar-close-btn:hover{color:var(--text-primary);border-color:#ffffff26}.app-main{margin-left:0}.topbar-hamburger{display:flex}.search-wrap{width:auto;flex:1;max-width:360px}}@media(max-width:768px){.app-topbar{padding:12px 16px;flex-wrap:wrap;gap:12px}.search-wrap{order:10;flex-basis:100%;max-width:none}.search-kbd,.user-info{display:none}.user-pill{padding:4px;border-radius:50%}}@media(max-width:480px){.search-input,.page-title{font-size:16px}.page-date{font-size:11px}}@media(max-width:360px){.app-topbar{padding:10px 12px}}.dash-content{padding:28px 32px 40px;flex:1}.cards-row{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:28px}.summary-card{background:var(--bg-card);border:1px solid;border-radius:14px;padding:22px 24px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.summary-card:hover{transform:translateY(-2px);box-shadow:0 8px 32px #0000004d}.card-glow{position:absolute;top:-20px;right:-20px;width:100px;height:100px;border-radius:50%;filter:blur(40px);pointer-events:none}.card-icon{font-size:22px;margin-bottom:12px;display:block}.card-value{font-size:36px;font-weight:700;letter-spacing:-1px;line-height:1;margin-bottom:6px}.card-label{font-size:13px;color:var(--text-secondary);font-weight:500;margin-bottom:4px}.card-sub{font-size:12px;display:flex;align-items:center;gap:4px}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:14px}.section-title{font-size:15px;font-weight:600;letter-spacing:-.2px}.section-link{font-size:12px;color:var(--accent-blue);cursor:pointer;font-weight:500;display:flex;align-items:center;gap:4px;border:none;background:none;font-family:inherit}.section-link:hover{color:var(--accent-cyan)}.alerts-panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden;margin-bottom:28px}.alert-row{display:flex;align-items:center;gap:14px;padding:14px 20px;border-bottom:1px solid var(--border-subtle);transition:background .15s;cursor:pointer}.alert-row:hover{background:#ffffff05}.alert-row--last{border-bottom:none}.alert-dot{width:36px;height:36px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0;font-size:15px}.alert-info{flex:1;min-width:0}.alert-name{font-size:13.5px;font-weight:500;margin-bottom:2px}.alert-cas{font-size:11px;color:var(--text-muted);font-family:monospace;margin-left:8px}.alert-detail{font-size:12px;color:var(--text-muted)}.alert-action{padding:6px 14px;border-radius:8px;border:1px solid;background:transparent;font-size:12px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.alert-action:hover{filter:brightness(1.2);background:#ffffff08}.two-col{display:grid;grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px}.panel{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden}.panel-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border-subtle)}.panel-title{font-size:14px;font-weight:600}.panel-body{padding:0}.act-item{display:flex;align-items:flex-start;gap:12px;padding:13px 20px;border-bottom:1px solid rgba(255,255,255,.03);font-size:13px}.act-item--last{border-bottom:none}.act-avatar{width:30px;height:30px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:10px;font-weight:700;flex-shrink:0;margin-top:1px}.act-text{flex:1;line-height:1.5;min-width:0}.act-user{font-weight:600}.act-action{color:var(--text-secondary)}.act-item-name{color:var(--accent-cyan);font-weight:500}.act-qty{color:var(--text-muted)}.act-time{font-size:11px;color:var(--text-muted);white-space:nowrap;margin-top:2px}.exp-item{display:flex;align-items:center;gap:14px;padding:13px 20px;border-bottom:1px solid rgba(255,255,255,.03)}.exp-item--last{border-bottom:none}.exp-bar{width:4px;height:36px;border-radius:4px;flex-shrink:0}.exp-bar--critical{background:var(--danger)}.exp-bar--high{background:#f59e0b}.exp-bar--medium{background:#eab308}.exp-bar--low{background:var(--accent-emerald)}.exp-info{flex:1;min-width:0}.exp-name{font-size:13px;font-weight:500;margin-bottom:2px}.exp-meta{font-size:11px;color:var(--text-muted);display:flex;gap:8px}.exp-days{font-size:12px;font-weight:600;white-space:nowrap}.exp-days--critical{color:var(--danger)}.exp-days--high{color:#f59e0b}.exp-days--medium{color:#eab308}.exp-days--low{color:var(--text-muted)}.quick-bar{display:flex;gap:12px;flex-wrap:wrap}.q-btn{display:flex;align-items:center;gap:8px;padding:11px 18px;border-radius:10px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .2s}.q-btn:hover{border-color:#ffffff26;color:var(--text-primary)}.q-btn--primary{padding:11px 22px;border:none;background:var(--accent-blue);color:#fff}.q-btn--primary:hover{background:var(--accent-blue-hover);box-shadow:0 4px 20px #3b82f64d;color:#fff}@keyframes fadeIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.cards-row{animation:fadeIn .4s ease-out both .1s}.alerts-panel{animation:fadeIn .4s ease-out both .2s}.two-col{animation:fadeIn .4s ease-out both .3s}.quick-bar{animation:fadeIn .4s ease-out both .4s}@media(max-width:1280px){.cards-row{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.two-col{grid-template-columns:1fr}}@media(max-width:768px){.dash-content{padding:20px 16px 32px}.cards-row{grid-template-columns:repeat(2,1fr);gap:12px}.summary-card{padding:16px 18px}.card-value{font-size:28px}.card-icon{font-size:18px;margin-bottom:8px}.alert-row{padding:12px 14px;gap:10px}.alert-cas{display:none}.alert-action{padding:5px 10px;font-size:11px}.quick-bar{gap:8px}.q-btn{padding:10px 14px;font-size:12px}.q-btn--primary{padding:10px 18px}}@media(max-width:480px){.cards-row{gap:10px}.summary-card{padding:14px}.card-value{font-size:24px}.card-label{font-size:11px}.card-sub{font-size:10px}.section-title{font-size:14px}.alert-row{padding:10px 12px;gap:8px}.alert-dot{width:30px;height:30px;border-radius:8px}.act-item,.exp-item{padding:10px 14px}.panel-header{padding:14px 14px 12px}.q-btn{flex:1;min-width:calc(50% - 6px);justify-content:center;padding:10px 12px;font-size:12px}.q-btn--primary{padding:10px 12px;flex-basis:100%}}@media(max-width:360px){.dash-content{padding:16px 12px 28px}.card-value{font-size:22px}.summary-card{padding:12px}.exp-meta{flex-direction:column;gap:2px}}.inv-page{padding:28px 32px 40px;flex:1;position:relative}.inv-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:20px}.inv-title{font-size:22px;font-weight:700;letter-spacing:-.5px}.inv-subtitle{font-size:13px;color:var(--text-muted);margin-top:4px}.inv-toolbar{display:flex;align-items:center;gap:10px;margin-bottom:16px;flex-wrap:wrap}.inv-search-wrap{position:relative;flex:1;min-width:200px;max-width:400px}.inv-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.inv-search{width:100%;padding:10px 36px 10px 40px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;transition:all .2s}.inv-search:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.inv-search::placeholder{color:var(--text-muted)}.inv-search-clear{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:var(--text-muted);font-size:18px;cursor:pointer;padding:2px 6px;line-height:1}.inv-tool-btn{display:flex;align-items:center;gap:6px;padding:10px 14px;border-radius:10px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;transition:all .15s}.inv-tool-btn:hover{border-color:#ffffff1f;color:var(--text-primary)}.inv-tool-btn--active{background:#3b82f61f;border-color:#3b82f633;color:var(--text-primary)}.inv-filter-count{background:var(--accent-blue);color:#fff;font-size:10px;font-weight:700;width:18px;height:18px;border-radius:50%;display:inline-flex;align-items:center;justify-content:center}.inv-sort-select{padding:10px 14px;border-radius:10px;border:1px solid var(--border-subtle);background:var(--bg-input);color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;outline:none}.inv-sort-select:focus{border-color:var(--accent-blue)}.inv-view-toggle{display:flex;border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden}.inv-view-btn{padding:9px 12px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;display:flex;transition:all .15s}.inv-view-btn:first-child{border-right:1px solid var(--border-subtle)}.inv-view-btn:hover{color:var(--text-primary)}.inv-view-btn--active{background:#3b82f61f;color:var(--text-primary)}.inv-filters{display:flex;align-items:center;gap:8px;margin-bottom:16px;flex-wrap:wrap;animation:fadeSlideDown .15s ease}.inv-filters-label{font-size:12px;color:var(--text-muted);font-weight:500}.inv-status-pill{display:flex;align-items:center;gap:6px;padding:6px 12px;border-radius:100px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.inv-status-pill:hover{border-color:var(--pill-color)}.inv-status-pill--active{background:var(--pill-bg);border-color:var(--pill-color);color:var(--pill-color)}.inv-pill-dot{width:8px;height:8px;border-radius:50%;background:var(--pill-color);opacity:.6}.inv-status-pill--active .inv-pill-dot{opacity:1}.inv-clear-filters{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;text-decoration:underline;font-family:inherit}.inv-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.inv-empty h3{font-size:18px;font-weight:600;margin-top:16px}.inv-empty p{font-size:13px;color:var(--text-muted);margin:8px 0 20px}.inv-table-wrap{overflow-x:auto;border:1px solid var(--border-subtle);border-radius:12px;background:var(--bg-card)}.inv-table{width:100%;border-collapse:collapse;min-width:800px}.inv-table th{text-align:left;padding:12px 14px;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border-subtle);white-space:nowrap}.inv-th-check{width:40px;text-align:center}.inv-th-actions{width:50px}.inv-table td{padding:12px 14px;border-bottom:1px solid rgba(255,255,255,.02);vertical-align:middle}.inv-row{cursor:pointer;transition:background .1s}.inv-row:hover{background:#ffffff05}.inv-row--selected{background:#3b82f60f}.inv-row--expired{background:#ef444408}.inv-row--low{background:#f59e0b08}.inv-td-check,.inv-td-actions{text-align:center}.inv-cell-name{font-size:13px;font-weight:500;margin-bottom:2px}.inv-cell-supplier{font-size:11px;color:var(--text-muted)}.inv-cell-cas{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-muted)}.inv-status-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;white-space:nowrap}.inv-cell-qty{font-size:13px;font-weight:500;margin-bottom:4px}.inv-qty-bar{height:3px;border-radius:3px;background:#ffffff0f;overflow:hidden;width:100%;max-width:100px}.inv-qty-bar--card{max-width:none}.inv-qty-fill{height:100%;border-radius:3px;transition:width .3s ease}.inv-cell-loc{font-size:12px;color:var(--text-secondary)}.inv-cell-shelf{color:var(--text-muted)}.inv-cell-expiry{font-size:12px}.inv-cell-expiry--past{color:var(--danger)}.inv-cell-expiry--soon{color:#f59e0b}.inv-cell-days{font-size:10px;margin-top:2px;color:var(--text-muted)}.inv-cell-days--past{color:var(--danger)}.inv-cell-days--soon{color:#f59e0b}.inv-cell-ghs{display:flex;gap:4px;align-items:center}.inv-ghs-pip{font-size:14px;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px}.inv-ghs-more{font-size:10px;color:var(--text-muted);background:#ffffff0a;padding:2px 6px;border-radius:4px}.inv-action-dot{background:none;border:1px solid var(--border-subtle);border-radius:6px;padding:5px 7px;color:var(--text-muted);cursor:pointer;display:inline-flex;transition:all .15s}.inv-action-dot:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.inv-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.inv-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:18px;cursor:pointer;transition:all .15s}.inv-card:hover{border-color:#ffffff1a;transform:translateY(-1px)}.inv-card--expired{border-color:#ef444426}.inv-card--low{border-color:#f59e0b26}.inv-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.inv-card-ghs{display:flex;gap:4px}.inv-card-name{font-size:15px;font-weight:600;margin-bottom:4px}.inv-card-cas{font-size:11px;font-family:JetBrains Mono,monospace;color:var(--text-muted);margin-bottom:2px}.inv-card-supplier{font-size:12px;color:var(--text-secondary);margin-bottom:14px}.inv-card-qty-section{margin-bottom:12px}.inv-card-qty-text{font-size:12px;color:var(--text-secondary);margin-top:5px}.inv-card-meta{font-size:11px;color:var(--text-muted);margin-bottom:4px}.inv-card-meta--warn{color:#f59e0b}.inv-card-loc{font-size:11px;color:var(--text-muted);margin-bottom:14px}.inv-card-actions{display:flex;gap:8px}.inv-card-actions .s-btn{flex:1;justify-content:center}.inv-bulk-bar{position:fixed;bottom:24px;left:50%;transform:translate(-50%);display:flex;align-items:center;gap:16px;padding:14px 24px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;box-shadow:0 12px 40px #00000080;z-index:50;animation:slideUp .2s ease}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.inv-bulk-count{font-size:13px;font-weight:600;white-space:nowrap}.inv-bulk-actions{display:flex;gap:8px;flex-wrap:wrap}.inv-bulk-clear{background:none;border:none;color:var(--text-muted);font-size:12px;cursor:pointer;font-family:inherit;text-decoration:underline;white-space:nowrap}.inv-modal-overlay{position:fixed;inset:0;background:#0009;z-index:200;display:flex;align-items:center;justify-content:center;padding:20px;animation:fadeIn .15s ease}.inv-modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;padding:24px;width:100%;max-width:440px;animation:scaleIn .15s ease}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.inv-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.inv-modal-header h3{font-size:16px;font-weight:600}.inv-modal-close{background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:4px 8px;line-height:1}.inv-modal-reagent{padding:12px 14px;background:#ffffff05;border-radius:10px;border:1px solid var(--border-subtle);margin-bottom:16px}.inv-modal-name{font-size:14px;font-weight:600;margin-bottom:4px}.inv-modal-current{font-size:12px;color:var(--text-muted)}.inv-quick-pills{display:flex;gap:8px;flex-wrap:wrap;margin-top:12px}.inv-quick-pill{padding:8px 14px;border-radius:8px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:12px;font-family:inherit;cursor:pointer;transition:all .15s}.inv-quick-pill:hover{border-color:var(--accent-blue);color:var(--text-primary)}.inv-quick-pill--active{background:#3b82f61f;border-color:#3b82f64d;color:var(--accent-blue)}.inv-modal-remaining{margin-top:16px;padding:12px 14px;background:#ffffff05;border-radius:10px;display:flex;flex-wrap:wrap;gap:8px;align-items:center;font-size:13px;color:var(--text-secondary)}.inv-modal-remaining-val{font-weight:600;color:var(--text-primary)}.inv-modal-warning{width:100%;font-size:12px;font-weight:500;margin-top:4px}.inv-modal-warning--red{color:var(--danger)}.inv-modal-warning--amber{color:#f59e0b}.inv-modal-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:20px}@media(max-width:1280px){.inv-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.inv-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.inv-page{padding:20px 16px 32px}.inv-header{flex-direction:column;gap:12px}.inv-search-wrap{max-width:none}.inv-grid{grid-template-columns:1fr}.inv-sort-select{font-size:12px;padding:8px 10px}.inv-bulk-bar{left:16px;right:16px;transform:none;flex-wrap:wrap;bottom:16px}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.inv-bulk-actions{flex-wrap:wrap}}@media(max-width:480px){.inv-page{padding:16px 12px 28px}.inv-title{font-size:18px}.inv-toolbar{gap:6px}.inv-search{font-size:16px}.inv-view-toggle{display:none}.inv-modal{padding:20px 16px}}.wm-modal{max-width:520px}.wm-reagent-card{padding:14px 16px;background:#ffffff05;border-radius:10px;border:1px solid var(--border-subtle);margin-bottom:16px}.wm-reagent-row{display:flex;align-items:baseline;gap:10px;flex-wrap:wrap}.wm-reagent-name{font-size:14px;font-weight:600;color:var(--text-primary)}.wm-reagent-cas{font-size:11px;color:var(--text-muted);font-family:var(--font-mono, monospace)}.wm-reagent-meta{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-secondary);margin-top:6px;flex-wrap:wrap}.wm-qty-row{display:flex;align-items:center;gap:10px;margin-top:10px}.wm-qty-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.wm-qty-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden;min-width:60px}.wm-qty-fill{height:100%;border-radius:3px;transition:width .3s ease}.wm-qty-text{font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap}.wm-after-section{margin-top:16px;padding:12px 14px;background:#ffffff05;border-radius:10px;display:flex;flex-wrap:wrap;gap:10px;align-items:center}.wm-after-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.wm-after-value{font-size:13px;font-weight:600;color:var(--text-primary)}.wm-after-pct{font-weight:400;color:var(--text-muted);font-size:11px}.wm-purpose-row{display:flex;gap:12px;margin-top:14px}.inv-quick-pill--all{border-style:dashed}.wm-open-info{margin-bottom:16px}.wm-open-list{margin:0;padding:0 0 0 18px;font-size:13px;color:var(--text-secondary);line-height:1.7}.dm-modal{max-width:540px}.dm-cer-section{margin-top:12px}.dm-cer-toggle{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;padding:4px 0}.dm-cer-toggle:hover{color:var(--text-primary)}.dm-next-box{margin-top:16px;padding:14px 16px;background:#3b82f60f;border:1px solid rgba(59,130,246,.15);border-radius:10px}.dm-next-title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.dm-next-list{margin:0;padding:0 0 0 18px;font-size:12px;color:var(--text-muted);line-height:1.8}.dm-marking-info{padding:12px 14px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:10px;margin-bottom:16px;font-size:12px}.dm-marking-row{display:flex;gap:8px;color:var(--text-secondary);margin-bottom:4px}.dm-marking-row:last-child{margin-bottom:0}.dm-marking-label{color:var(--text-muted);min-width:80px}.dm-confirm-box{margin-top:16px;padding:14px 16px;background:#ef44440f;border:1px solid rgba(239,68,68,.15);border-radius:10px}.dm-confirm-label{display:flex;gap:10px;align-items:flex-start;font-size:13px;color:var(--text-primary);cursor:pointer}.dm-confirm-label input[type=checkbox]{margin-top:3px;flex-shrink:0}.dm-confirm-warn{margin:10px 0 0;font-size:11px;color:var(--danger);font-weight:500}.bm-modal{max-width:560px}.bm-items{padding:12px 14px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:10px;margin-bottom:16px}.bm-items-label{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.bm-item{font-size:12px;color:var(--text-primary);padding:3px 0;display:flex;gap:6px;align-items:baseline}.bm-item--excluded{opacity:.4;text-decoration:line-through}.bm-item-name{font-weight:500}.bm-item-loc{color:var(--text-muted);font-size:11px}.bm-target{display:flex;gap:12px;margin-bottom:16px}.bm-target .s-field{flex:1}.bm-compat{padding:12px 14px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:10px;margin-bottom:16px}.bm-compat-title{font-size:12px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.bm-compat-row{display:flex;align-items:center;gap:8px;padding:4px 0;font-size:12px}.bm-compat--ok{color:#10b981}.bm-compat--fail{color:#ef4444}.bm-compat-msg{flex:1}@media(max-width:768px){.wm-modal,.dm-modal,.bm-modal{max-width:none;max-height:95vh;overflow-y:auto;border-radius:16px 16px 0 0;align-self:flex-end;margin:0}.inv-modal-overlay{align-items:flex-end;padding:0}.wm-purpose-row,.bm-target{flex-direction:column;gap:8px}.inv-quick-pills{gap:6px}.inv-quick-pill{min-height:48px;display:flex;align-items:center;justify-content:center}}.inv-view-switcher{display:flex;border:1px solid var(--border-subtle);border-radius:10px;overflow:hidden;background:var(--bg-input)}.inv-vs-btn{display:flex;align-items:center;gap:6px;padding:8px 14px;background:transparent;border:none;color:var(--text-muted);font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:all .15s;white-space:nowrap}.inv-vs-btn+.inv-vs-btn{border-left:1px solid var(--border-subtle)}.inv-vs-btn:hover{color:var(--text-primary);background:#ffffff08}.inv-vs-btn--active{background:#3b82f61f;color:var(--text-primary);font-weight:600}@media(max-width:768px){.inv-view-switcher{border:none;overflow:visible;background:none}.inv-vs-btn{display:none}.inv-vs-btn--active{display:flex;border:1px solid var(--border-subtle);border-radius:10px;background:var(--bg-input)}.inv-view-switcher--expanded .inv-vs-btn{display:flex;border:1px solid var(--border-subtle);border-radius:0;border-bottom:none}.inv-view-switcher--expanded .inv-vs-btn:first-child{border-radius:10px 10px 0 0}.inv-view-switcher--expanded .inv-vs-btn:last-child{border-radius:0 0 10px 10px;border-bottom:1px solid var(--border-subtle)}.inv-view-switcher--expanded{flex-direction:column;position:relative;z-index:10}}.inv-header-row{display:flex;justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:20px}.inv-header-left{flex:1}.inv-header-right{display:flex;align-items:center;gap:12px}.inv-bulk-close{background:none;border:none;color:var(--text-muted);font-size:20px;cursor:pointer;padding:2px 6px;line-height:1}.inv-bulk-select-all{background:none;border:none;color:var(--accent-blue);font-size:12px;cursor:pointer;font-family:inherit;text-decoration:underline;white-space:nowrap}.loc-summary-bar{display:flex;align-items:center;gap:8px;padding:12px 16px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:10px;margin-bottom:16px;font-size:13px;color:var(--text-secondary);flex-wrap:wrap}.loc-summary-sep{color:var(--text-muted)}.loc-summary-warn{color:#ef4444;font-weight:600}.loc-sort-select{margin-left:auto}.loc-breadcrumb{display:flex;align-items:center;gap:8px;margin-bottom:16px;font-size:13px}.loc-breadcrumb-btn{display:flex;align-items:center;gap:6px;background:none;border:none;color:var(--accent-blue);font-size:13px;font-family:inherit;cursor:pointer;padding:4px 8px 4px 0}.loc-breadcrumb-btn:hover{text-decoration:underline}.loc-breadcrumb-sep{color:var(--text-muted)}.loc-breadcrumb-current{color:var(--text-primary);font-weight:500}.loc-room-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.loc-room-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-left:4px solid #10B981;border-radius:12px;padding:18px 20px;cursor:pointer;transition:all .15s}.loc-room-card:hover{border-color:#ffffff1a;border-left-width:4px;transform:translateY(-1px);box-shadow:0 4px 16px #0003}.loc-room-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:14px}.loc-room-icon{color:var(--text-muted);flex-shrink:0;margin-top:2px}.loc-room-name{font-size:15px;font-weight:600;color:var(--text-primary)}.loc-room-meta{font-size:12px;color:var(--text-muted);margin-top:3px}.loc-room-arrow{margin-left:auto;color:var(--text-muted);flex-shrink:0;margin-top:4px}.loc-room-occupancy{display:flex;align-items:center;gap:10px;margin-bottom:12px}.loc-room-occ-label{font-size:12px;color:var(--text-muted);white-space:nowrap}.loc-room-occ-pct{font-size:12px;font-weight:600;color:var(--text-primary);white-space:nowrap}.loc-occ-bar{flex:1;height:6px;background:#ffffff0f;border-radius:3px;overflow:hidden}.loc-occ-bar--lg{height:8px}.loc-occ-fill{height:100%;border-radius:3px;transition:width .3s ease}.loc-room-issues{display:flex;gap:10px;flex-wrap:wrap;margin-bottom:10px}.loc-issue{font-size:12px;font-weight:500}.loc-issue--red{color:#ef4444}.loc-issue--amber{color:#f59e0b}.loc-issue--green{color:#10b981}.loc-room-ghs,.loc-cab-ghs{display:flex;gap:4px;align-items:center;flex-wrap:wrap}.loc-ghs-pip{font-size:16px;display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px}.loc-ghs-more{font-size:10px;color:var(--text-muted);background:#ffffff0a;padding:2px 6px;border-radius:4px}.loc-cabinet-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:16px}.loc-cabinet-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-left:4px solid #10B981;border-radius:12px;padding:18px 20px;cursor:pointer;transition:all .15s}.loc-cabinet-card:hover{border-color:#ffffff1a;border-left-width:4px;transform:translateY(-1px);box-shadow:0 4px 16px #0003}.loc-cab-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:12px}.loc-cab-title{display:flex;align-items:center;gap:8px}.loc-cab-icon{color:var(--text-muted)}.loc-cab-code{font-size:16px;font-weight:700;color:var(--text-primary)}.loc-cab-name{font-size:14px;color:var(--text-secondary)}.loc-cab-badges{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.loc-type-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600;white-space:nowrap}.loc-conflict-badge{display:inline-block;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:700;background:#ef44441f;color:#ef4444;white-space:nowrap}.loc-cab-occupancy{margin-bottom:10px}.loc-cab-occ-text{font-size:12px;color:var(--text-muted);margin-top:4px}.loc-occ-warn{color:#ef4444;font-weight:700}.loc-occ-near{color:#f59e0b;font-weight:600}.loc-cab-issues{display:flex;gap:10px;margin-bottom:10px}.loc-cab-groups{display:flex;gap:6px;margin-bottom:10px;flex-wrap:wrap}.loc-group-tag{display:inline-block;padding:2px 8px;border-radius:4px;background:#ffffff0a;border:1px solid var(--border-subtle);font-size:10px;font-weight:600;color:var(--text-muted);letter-spacing:.5px;font-family:var(--font-mono, monospace)}.loc-shelf-preview{display:flex;flex-wrap:wrap;gap:6px 16px;margin-top:10px}.loc-shelf-bar-row{display:flex;align-items:center;gap:6px;font-size:11px;color:var(--text-muted)}.loc-shelf-label{font-weight:500;width:20px}.loc-shelf-minibar{width:60px;height:4px;background:#ffffff0f;border-radius:2px;overflow:hidden}.loc-shelf-minifill{height:100%;border-radius:2px;transition:width .2s}.loc-shelf-count{font-size:10px}.loc-shelf-full-tag{font-size:9px;font-weight:700;color:#f59e0b;padding:1px 4px;border-radius:3px;background:#f59e0b1f}.loc-cab-detail-header{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:20px 24px;margin-bottom:16px}.loc-cab-detail-top{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:12px}.loc-cab-detail-title{font-size:18px;font-weight:700;display:flex;align-items:center;gap:8px}.loc-cab-detail-sub{font-size:13px;color:var(--text-muted);margin-top:4px}.loc-cab-detail-occ{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary);margin-bottom:10px}.loc-cab-detail-groups{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);margin-bottom:12px}.loc-conflict-banner{padding:12px 16px;background:#f9731614;border:1px solid rgba(249,115,22,.2);border-radius:8px;margin-bottom:12px;font-size:13px;color:#f97316}.loc-conflict-banner strong{display:block;margin-bottom:4px;font-size:12px;letter-spacing:.5px}.loc-conflict-text{font-size:12px;color:var(--text-secondary);margin-top:4px}.loc-cab-controls{display:flex;gap:10px;align-items:center}.loc-shelves{display:flex;flex-direction:column;gap:16px}.loc-shelf{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.loc-shelf--full{border-color:#f59e0b33}.loc-shelf--over{border-color:#ef444433}.loc-shelf-header{display:flex;align-items:center;gap:12px;padding:12px 18px;cursor:pointer;transition:background .1s}.loc-shelf-header:hover{background:#ffffff05}.loc-shelf-title{font-size:14px;font-weight:600;color:var(--text-primary)}.loc-shelf-occ{font-size:12px;color:var(--text-muted)}.loc-shelf-toggle{margin-left:auto;color:var(--text-muted)}.loc-shelf-over-tag{font-size:10px;font-weight:700;color:#ef4444;padding:2px 8px;border-radius:4px;background:#ef44441f}.loc-shelf-over-warn{padding:8px 18px;font-size:12px;color:#ef4444;background:#ef44440d}.loc-positions{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;padding:14px 18px 18px}.loc-pos{border-radius:10px;padding:12px;min-height:120px;display:flex;flex-direction:column;transition:all .15s;cursor:pointer}.loc-pos--empty{border:2px dashed rgba(255,255,255,.08);align-items:center;justify-content:center;gap:6px;color:var(--text-muted)}.loc-pos--empty:hover{border-color:#3b82f64d;background:#3b82f60a}.loc-pos-num{font-size:12px;font-weight:500}.loc-pos-plus{color:var(--text-muted);opacity:.6}.loc-pos-empty-label{font-size:10px}.loc-pos--filled{border:2px solid var(--border-subtle);background:#ffffff05;gap:4px}.loc-pos--filled:hover{border-color:#3b82f64d;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.loc-pos-name{font-size:12px;font-weight:600;color:var(--text-primary);line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.loc-pos-qty{font-size:11px;color:var(--text-secondary)}.loc-pos-status{display:flex;align-items:center;gap:5px;font-size:11px;color:var(--text-muted)}.loc-pos-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.loc-pos-ghs{font-size:14px;margin-top:2px}.loc-pos-badge{font-size:10px;font-weight:700;margin-top:auto}.loc-popover-overlay{z-index:250}.loc-popover{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:20px 24px;width:100%;max-width:400px;animation:scaleIn .15s ease}.loc-popover-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.loc-popover-header h4{font-size:16px;font-weight:600}.loc-popover-meta{display:flex;gap:10px;font-size:12px;color:var(--text-muted);flex-wrap:wrap;margin-bottom:14px;font-family:var(--font-mono, monospace)}.loc-popover-qty{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary);margin-bottom:14px}.loc-popover-qty-val{font-weight:600;color:var(--text-primary);white-space:nowrap}.loc-popover-info{display:flex;flex-direction:column;gap:6px;margin-bottom:16px}.loc-popover-row{display:flex;gap:8px;font-size:12px;color:var(--text-secondary)}.loc-popover-row>span:first-child{color:var(--text-muted);min-width:70px;flex-shrink:0}.loc-popover-expired{color:#ef4444;font-weight:500}.loc-popover-warning{color:#f59e0b;font-weight:500}.loc-popover-ghs{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.loc-popover-ghs span{font-size:12px}.loc-popover-actions{display:flex;gap:8px}.emg-view{color:var(--text-primary)}.emg-header{margin-bottom:24px}.emg-header-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.emg-title{font-size:20px;font-weight:800;letter-spacing:.5px;color:#ef4444}.emg-header-sub{font-size:14px;color:var(--text-secondary)}.emg-header-time{font-size:12px;color:var(--text-muted);margin-top:4px}.emg-room{margin-bottom:32px;border:1px solid var(--border-subtle);border-radius:12px;overflow:hidden}.emg-room-banner{padding:14px 20px;background:#ffffff0f;font-size:16px;font-weight:800;letter-spacing:1px;border-bottom:1px solid var(--border-subtle)}.emg-room-total{padding:12px 20px;font-size:15px;font-weight:600;color:var(--text-secondary)}.emg-hazard-table{width:100%;border-collapse:collapse;margin:0 0 4px}.emg-hazard-table th{text-align:left;padding:8px 20px;font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.5px;color:var(--text-muted);border-bottom:1px solid var(--border-subtle)}.emg-hazard-table td{padding:8px 20px;font-size:14px;border-bottom:1px solid rgba(255,255,255,.02)}.emg-hazard-name{font-weight:500;min-width:200px}.emg-hazard-count{font-weight:700;font-size:16px;width:60px}.emg-hazard-icon{display:flex;align-items:center;gap:8px}.emg-ghs{font-size:22px}.emg-specials{padding:12px 20px 16px;display:flex;flex-direction:column;gap:6px}.emg-special-row{display:flex;align-items:center;gap:8px;font-size:14px;color:var(--text-secondary)}.emg-special-icon{font-size:16px;flex-shrink:0}.emg-special--cmr{color:#dc2626}.emg-special--expired{color:#ef4444}.emg-special--conflict{color:#f97316}.emg-cabinets{padding:12px 20px 20px;border-top:1px solid var(--border-subtle)}.emg-cabinets-title{font-size:12px;font-weight:700;color:var(--text-muted);letter-spacing:.5px;margin-bottom:8px}.emg-cabinet-row{display:flex;align-items:center;gap:8px;font-size:14px;padding:4px 0;color:var(--text-secondary)}.emg-cab-code{font-weight:700;color:var(--text-primary);min-width:28px}.emg-cab-type{font-size:12px;padding:2px 8px;border-radius:4px;background:#ffffff0a}.emg-cab-sep{color:var(--text-muted)}.emg-cab-count{white-space:nowrap}.emg-cab-ghs{display:flex;gap:4px;align-items:center}.emg-cab-ghs .emg-ghs{font-size:16px}.emg-cab-conflict{color:#f97316;font-weight:700;font-size:12px}.emg-legend{padding:20px 24px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;margin-bottom:16px}.emg-legend-title{font-size:12px;font-weight:700;letter-spacing:.5px;color:var(--text-muted);margin-bottom:12px}.emg-legend-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:6px}.emg-legend-item{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.emg-legend-item .emg-ghs{font-size:18px}.emg-footer{text-align:center;font-size:12px;color:var(--text-muted);padding:16px}@media print{.emg-view{background:#fff;color:#000}.emg-header-actions{display:none}.emg-room{page-break-inside:avoid;break-inside:avoid;border-color:#333}.emg-room-banner{background:#eee;color:#000}.emg-ghs{font-size:28px}.emg-hazard-table td{font-size:16px}.emg-title{color:#c00}}@media(max-width:768px){.loc-room-grid,.loc-cabinet-grid{grid-template-columns:1fr}.loc-positions{grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:8px;padding:10px 12px 14px}.loc-pos{min-height:100px;padding:10px}.loc-pos-name{font-size:11px}.loc-cab-detail-header{padding:16px}.loc-cab-detail-title{font-size:16px}.loc-breadcrumb{flex-wrap:wrap}.loc-popover{max-width:none;border-radius:16px 16px 0 0;align-self:flex-end}.loc-popover-overlay{align-items:flex-end;padding:0}.emg-hazard-table td{font-size:13px;padding:6px 12px}.emg-hazard-table th{padding:6px 12px}.emg-room-banner{font-size:14px;padding:10px 14px}.emg-room-total{font-size:13px;padding:8px 14px}.emg-legend-grid{grid-template-columns:1fr}}.rd-page{padding:28px 32px 40px;flex:1}.rd-not-found{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:80px 20px;text-align:center}.rd-not-found h2{font-size:20px;margin-bottom:8px}.rd-not-found p{color:var(--text-muted);margin-bottom:20px}.rd-breadcrumb{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 0;margin-bottom:16px;transition:color .15s}.rd-breadcrumb:hover{color:var(--text-secondary)}.rd-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:28px}.rd-header-left{flex:1;min-width:0}.rd-name-row{display:flex;align-items:center;gap:14px;margin-bottom:8px;flex-wrap:wrap}.rd-name{font-size:24px;font-weight:700;letter-spacing:-.5px}.rd-meta-row{display:flex;gap:16px;align-items:center;margin-bottom:12px;flex-wrap:wrap}.rd-cas{font-size:13px;font-family:JetBrains Mono,monospace;color:var(--text-muted);background:#ffffff0a;padding:3px 10px;border-radius:6px}.rd-formula{font-size:14px;font-weight:600;color:var(--accent-cyan)}.rd-mw{font-size:12px;color:var(--text-muted)}.rd-ghs-row{display:flex;gap:8px;align-items:center;flex-wrap:wrap;margin-bottom:16px}.rd-ghs-chip{display:inline-flex;align-items:center;gap:5px;padding:4px 10px;border-radius:6px;background:#ffffff0a;border:1px solid var(--border-subtle);font-size:11px;font-weight:500;color:var(--text-secondary)}.rd-ghs-emoji{font-size:14px}.rd-signal{font-size:11px;font-weight:800;letter-spacing:1px;color:var(--danger);background:#ef44441a;padding:4px 12px;border-radius:6px}.rd-qty-section{margin-bottom:0}.rd-qty-bar-wrap{display:flex;align-items:center;gap:14px}.rd-qty-bar{height:8px;border-radius:8px;background:#ffffff0f;overflow:hidden;flex:1;max-width:300px}.rd-qty-fill{height:100%;border-radius:8px;transition:width .3s}.rd-qty-text{font-size:14px;font-weight:600;white-space:nowrap}.rd-qty-pct{color:var(--text-muted);font-weight:400;margin-left:6px}.rd-header-actions{flex-shrink:0}.rd-action-group{display:flex;gap:8px;align-items:center}.rd-overflow-wrap{position:relative}.rd-overflow-btn{padding:10px 14px;font-size:16px;letter-spacing:2px}.rd-overflow-menu{position:absolute;right:0;top:calc(100% + 6px);background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:6px;min-width:200px;box-shadow:0 12px 40px #0006;z-index:100;animation:fadeSlideDown .12s ease}@keyframes fadeSlideDown{0%{opacity:0;transform:translateY(-6px)}to{opacity:1;transform:translateY(0)}}.rd-menu-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 12px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-family:inherit;cursor:pointer;border-radius:8px;transition:all .1s;text-align:left}.rd-menu-item:hover{background:#ffffff0a;color:var(--text-primary)}.rd-menu-item--danger{color:var(--danger)}.rd-menu-item--danger:hover{background:#ef444414}.rd-menu-divider{height:1px;background:var(--border-subtle);margin:4px 0}.rd-content{display:grid;grid-template-columns:1fr 340px;gap:24px;align-items:start}.rd-left,.rd-right{min-width:0}.rd-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;margin-bottom:16px;overflow:hidden}.rd-section-toggle{display:flex;align-items:center;gap:10px;width:100%;padding:16px 20px;border:none;background:transparent;color:var(--text-primary);font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;text-align:left}.rd-section-toggle:hover{background:#ffffff05}.rd-chevron{transition:transform .2s}.rd-chevron--open{transform:rotate(90deg)}.rd-section-body{padding:0 20px 20px;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.rd-detail-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.rd-detail-grid--sidebar{grid-template-columns:1fr}.rd-detail-item{display:flex;flex-direction:column;gap:3px}.rd-detail-label{font-size:11px;color:var(--text-muted);font-weight:500}.rd-detail-value{font-size:13px;font-weight:500}.rd-detail-value--warn{color:#f59e0b}.rd-detail-value--danger{color:var(--danger)}.rd-mono{font-family:JetBrains Mono,monospace;font-size:12px}.rd-days-badge{display:inline-block;margin-left:8px;font-size:11px;font-weight:600;padding:1px 8px;border-radius:100px;background:#ffffff0a;color:var(--text-muted)}.rd-no-data{font-size:12px;color:var(--text-muted);font-style:italic}.rd-signal-banner{display:inline-block;font-size:12px;font-weight:800;letter-spacing:1.5px;color:var(--danger);background:#ef444414;padding:6px 16px;border-radius:6px;margin-bottom:16px}.rd-h-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px;margin-top:16px}.rd-h-label:first-child{margin-top:0}.rd-ghs-icons{display:flex;gap:10px;flex-wrap:wrap}.rd-ghs-icon-item{display:flex;align-items:center;gap:8px;padding:8px 14px;background:#ffffff05;border:1px solid var(--border-subtle);border-radius:8px;font-size:12px;color:var(--text-secondary)}.rd-ghs-icon-emoji{font-size:18px}.rd-ghs-icon-label{font-weight:500}.rd-h-list{list-style:none;display:flex;flex-wrap:wrap;gap:6px}.rd-h-item{padding:4px 10px;border-radius:6px;background:#ffffff08;border:1px solid var(--border-subtle);font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-secondary)}.rd-flags{display:flex;gap:8px;flex-wrap:wrap;margin-top:16px}.rd-flag{padding:4px 12px;border-radius:6px;font-size:11px;font-weight:600}.rd-flag--acid{background:#ec48991f;color:#ec4899}.rd-flag--base{background:#a855f71f;color:#a855f7}.rd-flag--peroxide{background:#ef44441f;color:#ef4444}.rd-flag--cmr{background:#dc26261f;color:#dc2626}.rd-flag--water{background:#06b6d41f;color:#06b6d4}.rd-flag--light{background:#eab3081f;color:#eab308}.rd-compat-status{font-size:13px;display:flex;align-items:center;gap:8px}.rd-compat-ok{color:var(--accent-emerald);display:flex;align-items:center;gap:8px}.rd-compat-warn{color:#f59e0b;display:flex;align-items:center;gap:8px}.rd-sds-info{display:flex;flex-direction:column;gap:10px}.rd-sds-badge{font-size:12px;color:var(--text-muted)}.rd-sds-source{color:var(--accent-emerald);font-weight:600}.rd-sds-actions{display:flex;gap:8px;flex-wrap:wrap}.rd-sds-actions a{text-decoration:none}.rd-sds-missing{display:flex;flex-direction:column;align-items:flex-start;gap:6px;font-size:13px;color:#f59e0b}.rd-movements{display:flex;flex-direction:column}.rd-movement{display:flex;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.03)}.rd-movement:last-child{border-bottom:none}.rd-mv-indicator{width:3px;border-radius:3px;background:var(--mv-color);flex-shrink:0}.rd-mv-content{flex:1;min-width:0}.rd-mv-top{display:flex;gap:10px;align-items:center;margin-bottom:4px;flex-wrap:wrap}.rd-mv-date{font-size:12px;color:var(--text-muted)}.rd-mv-user{font-size:12px;font-weight:500}.rd-mv-action{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;padding:2px 8px;border-radius:4px;background:color-mix(in srgb,var(--mv-color) 15%,transparent);color:var(--mv-color)}.rd-mv-bottom{display:flex;gap:10px;align-items:center;flex-wrap:wrap}.rd-mv-change{font-size:13px;font-weight:600}.rd-mv-change--plus{color:#10b981}.rd-mv-change--minus{color:#ef4444}.rd-mv-balance{font-size:12px;color:var(--text-muted)}.rd-mv-notes{font-size:12px;color:var(--text-muted);font-style:italic}.rd-sidebar-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:18px;margin-bottom:16px}.rd-sidebar-title{font-size:13px;font-weight:600;margin-bottom:12px}.rd-special-props{display:flex;flex-direction:column;gap:8px}.rd-prop{display:flex;align-items:center;gap:10px;font-size:13px;color:var(--text-secondary)}.rd-prop-check{width:18px;height:18px;border-radius:4px;border:1.5px solid var(--border-input);display:flex;align-items:center;justify-content:center;flex-shrink:0}.rd-prop-check--on{background:#3b82f626;border-color:var(--accent-blue)}.rd-prop-check--on:after{content:"✓";font-size:11px;color:var(--accent-blue);font-weight:700}.rd-tags{display:flex;gap:6px;flex-wrap:wrap}.rd-tag{padding:4px 12px;border-radius:6px;font-size:12px;font-weight:500;background:#3b82f614;color:var(--accent-blue);border:1px solid rgba(59,130,246,.15)}.rd-tag--add{background:transparent;border:1px dashed var(--border-input);color:var(--text-muted);cursor:pointer}.rd-tag--add:hover{border-color:var(--accent-blue);color:var(--accent-blue)}.rd-qr-preview{display:flex;justify-content:center;padding:16px;background:#ffffff08;border-radius:10px;margin-bottom:8px}.rd-qr-id{text-align:center;font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-muted);margin-bottom:10px}.rd-qr-actions{display:flex;gap:8px}.rd-qr-actions .s-btn{justify-content:center}.rd-notes-text{font-size:13px;color:var(--text-secondary);line-height:1.6}@media(max-width:1024px){.rd-content{grid-template-columns:1fr}.rd-right{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}}@media(max-width:768px){.rd-page{padding:20px 16px 32px}.rd-header{flex-direction:column}.rd-name{font-size:20px}.rd-detail-grid,.rd-right{grid-template-columns:1fr}.rd-action-group{flex-wrap:wrap}.rd-qty-bar-wrap{flex-direction:column;align-items:flex-start}.rd-qty-bar{max-width:none;width:100%}}@media(max-width:480px){.rd-page{padding:16px 12px 28px}.rd-name{font-size:18px}.rd-meta-row{gap:8px}.rd-ghs-row{gap:6px}}.add-page{padding:28px 32px 60px;flex:1;max-width:900px}.add-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:28px;gap:16px}.add-title{font-size:22px;font-weight:700;letter-spacing:-.5px}.add-header-actions{display:flex;gap:10px}.add-section{display:flex;gap:20px;margin-bottom:24px;padding-bottom:24px;border-bottom:1px solid rgba(255,255,255,.03)}.add-section:last-of-type{border-bottom:none;margin-bottom:0}.add-section-num{width:32px;height:32px;border-radius:10px;background:#3b82f61a;color:var(--accent-blue);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0;margin-top:2px}.add-section-content{flex:1;min-width:0}.add-section-title{font-size:16px;font-weight:600;margin-bottom:16px;display:flex;align-items:center;gap:10px}.add-autofill-badge{font-size:10px;font-weight:600;padding:3px 10px;border-radius:100px;background:#10b9811f;color:#10b981}.add-cas-row{display:flex;gap:10px;align-items:flex-end;margin-bottom:16px}.add-lookup-btn{align-self:flex-end;gap:8px;white-space:nowrap}.add-spinner{width:16px;height:16px;border:2px solid rgba(255,255,255,.15);border-top-color:var(--accent-blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.add-lookup-card{display:flex;align-items:center;gap:12px;padding:14px 16px;border-radius:10px;margin-bottom:16px;font-size:13px;flex-wrap:wrap}.add-lookup-card--found{background:#10b9810f;border:1px solid rgba(16,185,129,.2)}.add-lookup-card--accepted{background:#10b9810f;border:1px solid rgba(16,185,129,.15);color:#10b981}.add-lookup-card--notfound{background:#f59e0b0f;border:1px solid rgba(245,158,11,.2);color:#f59e0b}.add-lookup-card--error{background:#ef44440f;border:1px solid rgba(239,68,68,.2);color:#ef4444}.add-lookup-icon{flex-shrink:0}.add-lookup-info{flex:1;min-width:200px}.add-lookup-name{font-weight:500;color:var(--text-primary);margin-bottom:4px}.add-lookup-meta{font-size:12px;color:var(--text-secondary)}.add-lookup-actions{display:flex;gap:8px;flex-shrink:0}.add-ghs-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.add-ghs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:8px}.add-ghs-btn{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:8px;border:1px solid var(--border-subtle);background:transparent;cursor:pointer;font-family:inherit;transition:all .15s;color:var(--text-secondary)}.add-ghs-btn:hover{border-color:#ffffff1f;background:#ffffff05}.add-ghs-btn--active{border-color:#3b82f666;background:#3b82f614;color:var(--text-primary)}.add-ghs-emoji{font-size:18px}.add-ghs-code{font-size:10px;font-weight:700;color:var(--text-muted)}.add-ghs-name{font-size:11px;font-weight:500}.add-radio-group{display:flex;gap:16px;margin-top:6px}.add-radio{display:flex;align-items:center;gap:6px;font-size:13px;color:var(--text-secondary);cursor:pointer}.add-radio input[type=radio]{accent-color:var(--accent-blue);cursor:pointer}.add-auto-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-top:16px;margin-bottom:10px}.add-flags-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:8px}.add-flag-check{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.add-flag-check input[type=checkbox]{accent-color:var(--accent-blue);cursor:pointer}.add-opened-check{display:flex;align-items:center;gap:16px;margin-top:12px;flex-wrap:wrap}.add-checkbox-label{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary);cursor:pointer}.add-checkbox-label input[type=checkbox]{accent-color:var(--accent-blue);cursor:pointer}.add-compat-check{display:flex;align-items:center;gap:8px;margin-top:12px;font-size:13px;color:#10b981}.add-sds-found{display:flex;align-items:center;gap:10px;font-size:13px;color:#10b981}.add-sds-link{color:var(--accent-blue);font-weight:500;text-decoration:none;margin-left:auto}.add-sds-link:hover{text-decoration:underline}.add-sds-upload{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.add-sds-hint{font-size:12px;color:var(--text-muted)}.add-advanced-toggle{display:flex;align-items:center;gap:10px;font-size:16px;font-weight:600;color:var(--text-primary);background:none;border:none;cursor:pointer;font-family:inherit;padding:0;margin-bottom:8px}.add-advanced-body{animation:fadeIn .15s ease;margin-top:12px}.add-textarea{resize:vertical;min-height:60px}.add-bottom-actions{display:flex;justify-content:space-between;align-items:center;padding-top:24px;border-top:1px solid var(--border-subtle);margin-top:8px}.add-bottom-right{display:flex;gap:10px}@media(max-width:768px){.add-page{padding:20px 16px 60px}.add-header{flex-direction:column;align-items:flex-start}.add-section{flex-direction:column;gap:10px}.add-section-num{width:28px;height:28px;font-size:12px}.add-cas-row{flex-direction:column;align-items:stretch}.add-lookup-actions{width:100%}.add-lookup-actions .s-btn{flex:1;justify-content:center}.add-ghs-grid{grid-template-columns:repeat(3,1fr)}.add-flags-grid{grid-template-columns:1fr}.add-radio-group{flex-wrap:wrap}.add-bottom-actions{flex-direction:column-reverse;gap:10px}.add-bottom-right{width:100%}.add-bottom-right .s-btn{flex:1;justify-content:center}}@media(max-width:480px){.add-page{padding:16px 12px 60px}.add-title{font-size:18px}.add-ghs-grid{grid-template-columns:repeat(2,1fr)}}.scanner-page{padding:28px 32px 40px;flex:1}.scanner-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px}.scanner-layout{display:grid;grid-template-columns:1fr 340px;gap:20px;align-items:start}.scanner-camera-section{min-width:0}.scanner-viewfinder-card{min-height:400px;display:flex;flex-direction:column}.scanner-idle{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px}.scanner-idle-icon{margin-bottom:20px;opacity:.8}.scanner-idle-title{font-size:18px;font-weight:600;margin-bottom:8px}.scanner-idle-desc{font-size:13px;color:var(--text-muted);margin-bottom:24px;text-align:center}.scanner-start-btn{gap:10px;padding:12px 28px;font-size:14px}.scanner-active{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;background:radial-gradient(ellipse at center,rgba(59,130,246,.05) 0%,transparent 70%)}.scanner-viewfinder{position:relative;width:220px;height:220px;margin-bottom:24px}.scanner-corner{position:absolute;width:36px;height:36px;border-color:var(--accent-blue);border-style:solid;border-width:0}.scanner-corner--tl{top:0;left:0;border-top-width:3px;border-left-width:3px;border-radius:4px 0 0}.scanner-corner--tr{top:0;right:0;border-top-width:3px;border-right-width:3px;border-radius:0 4px 0 0}.scanner-corner--bl{bottom:0;left:0;border-bottom-width:3px;border-left-width:3px;border-radius:0 0 0 4px}.scanner-corner--br{bottom:0;right:0;border-bottom-width:3px;border-right-width:3px;border-radius:0 0 4px}.scanner-scanline{position:absolute;top:10%;left:10%;right:10%;height:2px;background:linear-gradient(90deg,transparent,var(--accent-cyan),transparent);animation:scanMove 2s ease-in-out infinite;box-shadow:0 0 12px #06b6d466}@keyframes scanMove{0%,to{top:10%}50%{top:85%}}.scanner-active-text{display:flex;align-items:center;gap:10px;font-size:14px;font-weight:500;color:var(--accent-cyan)}.scanner-pulse{width:10px;height:10px;border-radius:50%;background:var(--accent-cyan);animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.scanner-result{padding:4px 0}.scanner-result-header{display:flex;align-items:center;gap:10px;margin-bottom:16px;padding-bottom:16px;border-bottom:1px solid var(--border-subtle)}.scanner-result-title{font-size:14px;font-weight:600;color:#10b981}.scanner-result-id{margin-left:auto;font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-muted);background:#ffffff0a;padding:3px 10px;border-radius:6px}.scanner-result-details{margin-bottom:20px}.scanner-result-name{font-size:20px;font-weight:700;letter-spacing:-.3px;margin-bottom:8px}.scanner-result-meta{display:flex;align-items:center;gap:10px;margin-bottom:14px}.scanner-result-cas{font-size:12px;font-family:JetBrains Mono,monospace;color:var(--text-muted)}.scanner-result-info{display:flex;flex-direction:column;gap:8px}.scanner-result-info-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}.scan-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600}.scan-badge--sm{padding:2px 8px;font-size:10px}.scan-badge--green{color:var(--accent-emerald);background:#10b9811f}.scan-badge--amber{color:#f59e0b;background:#f59e0b1f}.scan-badge--red{color:var(--danger);background:#ef44441f}.scan-badge--gray{color:var(--text-muted);background:#ffffff0f}.scanner-quick-actions{display:grid;grid-template-columns:repeat(4,1fr);gap:10px;margin-bottom:16px}.scanner-action-btn{display:flex;flex-direction:column;align-items:center;gap:6px;padding:14px 8px;border-radius:12px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);cursor:pointer;font-family:inherit;transition:all .15s}.scanner-action-btn:hover{border-color:var(--action-color);background:color-mix(in srgb,var(--action-color) 8%,transparent);color:var(--text-primary)}.scanner-action-btn--active{border-color:var(--action-color);background:color-mix(in srgb,var(--action-color) 12%,transparent);color:var(--text-primary);box-shadow:0 0 0 1px var(--action-color)}.scanner-action-label{font-size:12px;font-weight:600}.scanner-action-desc{font-size:10px;color:var(--text-muted);text-align:center;line-height:1.3}.scanner-flow{padding:16px;background:#ffffff05;border-radius:12px;border:1px solid var(--border-subtle);margin-bottom:8px;animation:fadeSlideIn .2s ease-out}.scanner-flow-title{font-size:14px;font-weight:600;margin-bottom:14px}@keyframes fadeSlideIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.scanner-sidebar{min-width:0}.scanner-recent-list{display:flex;flex-direction:column}.scanner-recent-item{display:flex;align-items:center;gap:12px;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.03);cursor:pointer;transition:all .15s;border-radius:8px}.scanner-recent-item:last-child{border-bottom:none}.scanner-recent-item:hover{background:#ffffff05}.scanner-recent-item--active{background:#3b82f614}.scanner-recent-qr{flex-shrink:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:8px;background:#ffffff08}.scanner-recent-info{flex:1;min-width:0}.scanner-recent-name{font-size:13px;font-weight:500;margin-bottom:3px;display:flex;align-items:center;gap:8px}.scanner-recent-meta{font-size:11px;color:var(--text-muted);display:flex;gap:6px}.scanner-recent-time{font-size:11px;color:var(--text-muted);white-space:nowrap}.scanner-tips{display:flex;flex-direction:column;gap:10px}.scanner-tip{display:flex;align-items:center;gap:10px;font-size:12px;color:var(--text-secondary);line-height:1.5}.scanner-tip-icon{flex-shrink:0;font-size:16px}@media(max-width:1024px){.scanner-layout{grid-template-columns:1fr}.scanner-sidebar{display:grid;grid-template-columns:1fr 1fr;gap:16px}}@media(max-width:768px){.scanner-page{padding:20px 16px 32px}.scanner-header{flex-direction:column;gap:12px}.scanner-sidebar{grid-template-columns:1fr}.scanner-quick-actions{grid-template-columns:repeat(2,1fr)}.scanner-viewfinder{width:180px;height:180px}.s-row{flex-direction:column}}@media(max-width:480px){.scanner-page{padding:16px 12px 28px}.scanner-action-desc{display:none}.scanner-viewfinder-card{min-height:320px}}.gen-page{padding:28px 32px 40px;flex:1}.gen-header{margin-bottom:24px}.gen-back-btn{display:inline-flex;align-items:center;gap:6px;font-size:12px;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;padding:4px 0;margin-bottom:12px;transition:color .15s}.gen-back-btn:hover{color:var(--text-secondary)}.gen-layout{display:grid;grid-template-columns:1fr 380px;gap:20px;align-items:start}.gen-templates{display:grid;grid-template-columns:repeat(auto-fill,minmax(130px,1fr));gap:10px;margin-bottom:16px}.gen-template{display:flex;flex-direction:column;align-items:center;padding:14px 10px;border-radius:10px;border:1px solid var(--border-subtle);background:transparent;cursor:pointer;font-family:inherit;transition:all .15s;text-align:center}.gen-template:hover{border-color:#ffffff1f;background:#ffffff05}.gen-template--active{border-color:#3b82f666;background:#3b82f614;box-shadow:0 0 0 1px #3b82f633}.gen-template-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.gen-template-size{font-size:11px;color:var(--accent-cyan);font-family:JetBrains Mono,monospace;margin-bottom:4px}.gen-template-desc{font-size:10px;color:var(--text-muted)}.gen-template-fields{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.gen-template-fields-label{font-size:11px;color:var(--text-muted)}.gen-field-tag{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;background:#ffffff0a;color:var(--text-secondary);border:1px solid var(--border-subtle)}.gen-reagent-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.gen-search-wrap{position:relative;margin-bottom:12px}.gen-search-icon{position:absolute;left:14px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.gen-search-input{padding-left:40px!important}.gen-reagent-list{display:flex;flex-direction:column;gap:4px;max-height:400px;overflow-y:auto}.gen-reagent-item{display:flex;align-items:flex-start;gap:12px;padding:12px;border-radius:10px;cursor:pointer;transition:all .15s;border:1px solid transparent}.gen-reagent-item:hover{background:#ffffff05}.gen-reagent-item--selected{background:#3b82f60f;border-color:#3b82f626}.gen-checkbox{width:18px;height:18px;margin-top:2px;flex-shrink:0;accent-color:var(--accent-blue);cursor:pointer}.gen-reagent-info{flex:1;min-width:0}.gen-reagent-name{font-size:13px;font-weight:500;margin-bottom:4px;display:flex;align-items:center;gap:8px}.gen-reagent-id{font-size:10px;font-family:JetBrains Mono,monospace;color:var(--text-muted);background:#ffffff0a;padding:1px 6px;border-radius:4px}.gen-reagent-meta{font-size:11px;color:var(--text-muted);display:flex;gap:6px;margin-bottom:6px}.gen-reagent-hazards{display:flex;gap:6px;flex-wrap:wrap}.gen-hazard-icon{padding:2px 8px;border-radius:4px;font-size:10px;font-weight:600;border:1px solid}.gen-toggles{margin-top:16px}.gen-preview-section{position:sticky;top:80px}.gen-preview-card{min-height:300px}.gen-preview-area{min-height:200px;display:flex;flex-direction:column;align-items:center;justify-content:center}.gen-preview-empty{display:flex;flex-direction:column;align-items:center;gap:12px;color:var(--text-muted);font-size:13px;padding:20px}.gen-preview-labels{display:flex;flex-direction:column;gap:12px;width:100%}.gen-label{display:flex;gap:12px;padding:14px;border-radius:10px;border:1px dashed var(--border-input);background:#ffffff05;transition:all .15s}.gen-label:hover{border-color:#ffffff1f}.gen-label-qr{flex-shrink:0}.gen-label--small .gen-label-qr{width:36px;height:36px}.gen-label--medium .gen-label-qr{width:48px;height:48px}.gen-label--large .gen-label-qr{width:56px;height:56px}.gen-label--shelf .gen-label-qr{width:36px;height:36px}.gen-label--cabinet .gen-label-qr{width:64px;height:64px}.gen-label-content{flex:1;min-width:0}.gen-label-name{font-size:13px;font-weight:600;margin-bottom:3px}.gen-label-cas{font-size:10px;font-family:JetBrains Mono,monospace;color:var(--text-muted);margin-bottom:4px}.gen-label-hazards{display:flex;gap:4px;margin-bottom:4px}.gen-label-hazard-dot{width:18px;height:18px;display:flex;align-items:center;justify-content:center;font-size:9px;font-weight:700;border-radius:3px;background:#ef444426;color:var(--danger);transform:rotate(45deg)}.gen-label-hazard-dot span{transform:rotate(-45deg)}.gen-label-loc,.gen-label-exp{font-size:10px;color:var(--text-muted);margin-bottom:2px}.gen-label-id{font-size:9px;font-family:JetBrains Mono,monospace;color:var(--text-muted);opacity:.7}.gen-preview-more{text-align:center;font-size:12px;color:var(--text-muted);padding:10px}.gen-summary{display:flex;flex-direction:column;gap:0;margin-bottom:16px}.gen-summary-row{display:flex;justify-content:space-between;align-items:center;padding:8px 0;font-size:13px;color:var(--text-secondary);border-bottom:1px solid rgba(255,255,255,.03)}.gen-summary-row:last-child{border-bottom:none}.gen-summary-value{font-weight:600;color:var(--text-primary)}.gen-summary-value--accent{color:var(--accent-blue);font-size:16px}.gen-print-actions{display:flex;gap:10px}.gen-print-actions .s-btn{justify-content:center}.gen-print-actions .s-btn:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.gen-layout{grid-template-columns:1fr}.gen-preview-section{position:static}}@media(max-width:768px){.gen-page{padding:20px 16px 32px}.gen-templates{grid-template-columns:repeat(3,1fr)}.gen-print-actions{flex-direction:column}}@media(max-width:480px){.gen-page{padding:16px 12px 28px}.gen-templates{grid-template-columns:repeat(2,1fr)}.gen-reagent-list{max-height:300px}}.compat-page{padding:28px 32px 40px;flex:1}.compat-header{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;margin-bottom:24px}.compat-stats{display:flex;gap:12px;flex-shrink:0}.compat-stat{display:flex;flex-direction:column;align-items:center;padding:12px 20px;border-radius:12px;border:1px solid var(--border-subtle);background:var(--bg-card);min-width:80px}.compat-stat--critical{border-color:#ef444433}.compat-stat--warning{border-color:#f59e0b33}.compat-stat--ok{border-color:#10b98133}.compat-stat-value{font-size:22px;font-weight:700;letter-spacing:-.5px;line-height:1;margin-bottom:4px}.compat-stat--critical .compat-stat-value{color:var(--danger)}.compat-stat--warning .compat-stat-value{color:#f59e0b}.compat-stat--ok .compat-stat-value{color:var(--accent-emerald)}.compat-stat-label{font-size:11px;color:var(--text-muted);font-weight:500}.compat-tabs{display:flex;gap:4px;margin-bottom:20px;background:var(--bg-card);border-radius:12px;padding:4px;border:1px solid var(--border-subtle);width:fit-content}.compat-tab{display:flex;align-items:center;gap:8px;padding:10px 18px;border-radius:10px;border:none;background:transparent;color:var(--text-secondary);font-size:13px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.compat-tab:hover{color:var(--text-primary);background:#ffffff08}.compat-tab--active{background:#3b82f61f;color:var(--text-primary)}.compat-tab-badge{background:var(--danger);color:#fff;font-size:10px;font-weight:700;padding:2px 7px;border-radius:100px;min-width:20px;text-align:center}.compat-matrix-card{position:relative}.compat-legend{display:flex;gap:20px;margin-bottom:16px}.compat-legend-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary)}.compat-legend-dot{width:12px;height:12px;border-radius:3px}.compat-legend-dot--compatible{background:#10b9814d;border:1px solid rgba(16,185,129,.5)}.compat-legend-dot--conditional{background:#f59e0b4d;border:1px solid rgba(245,158,11,.5)}.compat-legend-dot--incompatible{background:#ef44444d;border:1px solid rgba(239,68,68,.5)}.compat-matrix-scroll{overflow-x:auto;padding-bottom:8px}.compat-matrix{border-collapse:separate;border-spacing:2px;min-width:700px}.compat-corner{width:160px;min-width:160px}.compat-col-header{text-align:center;padding:6px 2px;vertical-align:bottom}.compat-col-code{display:inline-flex;align-items:center;justify-content:center;width:32px;height:26px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.3px}.compat-row-header{display:flex;align-items:center;gap:8px;padding:4px 8px 4px 0;white-space:nowrap}.compat-row-code{display:inline-flex;align-items:center;justify-content:center;width:32px;height:26px;border-radius:6px;font-size:10px;font-weight:700;letter-spacing:.3px;flex-shrink:0}.compat-row-name{font-size:11px;color:var(--text-secondary);font-weight:500}.compat-cell{width:36px;height:32px;text-align:center;vertical-align:middle;font-size:11px;font-weight:700;border-radius:4px;cursor:default;transition:all .1s}.compat-cell--compatible{background:#10b98126;color:#10b981}.compat-cell--incompatible{background:#ef444426;color:#ef4444}.compat-cell--conditional{background:#f59e0b26;color:#f59e0b}.compat-cell--self{background:#ffffff05;color:var(--text-muted)}.compat-cell--highlight{filter:brightness(1.4);box-shadow:0 0 0 1px #ffffff26}.compat-tooltip-bar{display:flex;align-items:center;gap:10px;margin-top:16px;padding:12px 16px;background:#ffffff08;border-radius:10px;border:1px solid var(--border-subtle);font-size:13px}.compat-tooltip-code{font-weight:600}.compat-tooltip-plus,.compat-tooltip-sep{color:var(--text-muted)}.compat-tooltip-result{font-weight:600}.compat-tooltip-result--compatible{color:#10b981}.compat-tooltip-result--incompatible{color:#ef4444}.compat-tooltip-result--conditional{color:#f59e0b}.compat-conflict-filters{display:flex;gap:8px;margin-bottom:16px}.compat-filter{padding:8px 16px;border-radius:8px;border:1px solid var(--border-subtle);background:transparent;color:var(--text-secondary);font-size:12px;font-weight:500;cursor:pointer;font-family:inherit;transition:all .15s}.compat-filter:hover{border-color:#ffffff1f;color:var(--text-primary)}.compat-filter--active{background:#3b82f61f;border-color:#3b82f633;color:var(--text-primary)}.compat-conflicts-list{display:flex;flex-direction:column;gap:12px}.compat-conflict-card{margin-bottom:0}.compat-conflict--critical{border-color:#ef444426}.compat-conflict--warning{border-color:#f59e0b26}.compat-conflict-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.compat-conflict-severity{display:flex;align-items:center;gap:8px}.compat-severity-label{font-size:13px;font-weight:600}.compat-severity--critical{color:var(--danger)}.compat-severity--warning{color:#f59e0b}.compat-conflict-time{font-size:11px;color:var(--text-muted)}.compat-conflict-location{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);margin-bottom:12px}.compat-conflict-chemicals{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:12px}.compat-chemical-tag{padding:5px 12px;border-radius:8px;background:#ffffff0a;border:1px solid var(--border-subtle);font-size:12px;font-weight:500;color:var(--text-primary)}.compat-conflict-rule{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);margin-bottom:16px;line-height:1.5}.compat-conflict-actions{display:flex;gap:8px;justify-content:flex-end}.compat-rule-row{display:flex;align-items:center;justify-content:space-between;padding:16px 0;border-bottom:1px solid rgba(255,255,255,.03)}.compat-rule-row:last-child{border-bottom:none}.compat-rule-info{flex:1}.compat-rule-name{font-size:13px;font-weight:600;margin-bottom:6px}.compat-rule-groups{display:flex;align-items:center;gap:8px;margin-bottom:6px}.compat-rule-group-tag{padding:3px 10px;border-radius:6px;font-size:11px;font-weight:700;border:1px solid}.compat-rule-type{padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600}.compat-rule-type--incompatible{background:#ef44441f;color:#ef4444}.compat-rule-type--conditional{background:#f59e0b1f;color:#f59e0b}.compat-rule-note{font-size:12px;color:var(--text-muted)}.compat-rule-actions{display:flex;gap:8px}.compat-ghs-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(100px,1fr));gap:16px}.compat-ghs-item{display:flex;flex-direction:column;align-items:center;gap:8px;padding:16px 8px;border-radius:12px;background:#ffffff05;border:1px solid var(--border-subtle);transition:all .15s}.compat-ghs-item:hover{border-color:#ffffff1a;background:#ffffff0a}.compat-ghs-diamond{width:48px;height:48px;transform:rotate(45deg);border:2px solid;border-radius:4px;display:flex;align-items:center;justify-content:center;background:#ffffff05}.compat-ghs-diamond span{transform:rotate(-45deg)}.compat-ghs-label{font-size:11px;font-weight:500;color:var(--text-secondary);text-align:center}@media(max-width:1024px){.compat-header{flex-direction:column}.compat-stats{width:100%}.compat-stat{flex:1}}@media(max-width:768px){.compat-page{padding:20px 16px 32px}.compat-tabs{width:100%}.compat-tab{flex:1;justify-content:center;padding:10px 12px;font-size:12px}.compat-legend{flex-wrap:wrap;gap:12px}.compat-conflict-actions{flex-direction:column}.compat-rule-row{flex-direction:column;gap:12px;align-items:flex-start}.compat-ghs-grid{grid-template-columns:repeat(3,1fr)}}@media(max-width:480px){.compat-page{padding:16px 12px 28px}.compat-stats{flex-wrap:wrap}.compat-stat{min-width:calc(33% - 8px)}.compat-conflict-chemicals{flex-direction:column}.compat-ghs-grid{grid-template-columns:repeat(3,1fr);gap:10px}.compat-ghs-diamond{width:40px;height:40px}.compat-ghs-diamond span{font-size:16px}}.rpt-page{padding:24px 32px 60px;flex:1;min-width:0}.rpt-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;gap:16px;flex-wrap:wrap}.rpt-header-left{display:flex;align-items:center}.rpt-header-right{display:flex;align-items:center;gap:10px}.rpt-tab-bar{display:flex;gap:4px;background:#ffffff08;padding:4px;border-radius:12px;border:1px solid var(--border-subtle)}.rpt-tab{padding:8px 20px;border-radius:9px;font-size:13px;font-weight:500;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;transition:all .15s;white-space:nowrap}.rpt-tab:hover{color:var(--text-secondary);background:#ffffff08}.rpt-tab--active{color:var(--text-primary);background:#3b82f61f;font-weight:600}.rpt-tab--active:hover{background:#3b82f61f}.rpt-period-select{display:flex;align-items:center;gap:8px;color:var(--text-muted)}.rpt-period-dropdown{padding:8px 32px 8px 12px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748B' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;cursor:pointer;transition:all .2s}.rpt-period-dropdown:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.rpt-kpi-bar{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:24px}.rpt-kpi{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:18px 20px;min-width:0}.rpt-kpi-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.rpt-kpi-value{font-size:24px;font-weight:700;letter-spacing:-.5px;margin-bottom:6px}.rpt-kpi-unit{font-size:14px;font-weight:500;opacity:.7;margin-left:2px}.rpt-kpi-delta{font-size:11px;font-weight:500;display:flex;align-items:center;gap:4px}.rpt-charts-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:16px}.rpt-chart-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:20px;min-width:0;overflow:hidden}.rpt-chart-card--wide{grid-column:span 2}.rpt-chart-header{display:flex;align-items:baseline;gap:10px;margin-bottom:16px}.rpt-chart-title{font-size:14px;font-weight:600;letter-spacing:-.2px}.rpt-chart-subtitle{font-size:11px;color:var(--text-muted)}.rpt-chart-body{min-height:200px}.rpt-chart-body--centered{display:flex;flex-direction:column;align-items:center}.rpt-tooltip{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:10px;padding:12px 14px;box-shadow:0 8px 24px #0006;font-size:12px}.rpt-tooltip-label{font-weight:600;margin-bottom:6px;color:var(--text-primary)}.rpt-tooltip-row{display:flex;align-items:center;gap:8px;padding:2px 0}.rpt-tooltip-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rpt-tooltip-name{color:var(--text-secondary);flex:1}.rpt-tooltip-value{font-weight:600;color:var(--text-primary)}.rpt-pie-legend{display:grid;grid-template-columns:repeat(3,1fr);gap:6px 16px;width:100%;margin-top:8px}.rpt-pie-legend-item{display:flex;align-items:center;gap:6px;font-size:11px}.rpt-pie-legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.rpt-pie-legend-label{color:var(--text-secondary);flex:1}.rpt-pie-legend-value{font-weight:600;color:var(--text-primary)}.rpt-ghs-list{display:flex;flex-direction:column;gap:10px}.rpt-ghs-row{display:flex;align-items:center;gap:10px}.rpt-ghs-emoji{font-size:16px;flex-shrink:0;width:22px;text-align:center}.rpt-ghs-name{font-size:12px;color:var(--text-secondary);width:100px;flex-shrink:0}.rpt-ghs-bar-track{flex:1;height:8px;background:#ffffff0a;border-radius:8px;overflow:hidden;min-width:40px}.rpt-ghs-bar-fill{height:100%;border-radius:8px;background:linear-gradient(90deg,var(--accent-blue),#06B6D4);transition:width .5s ease}.rpt-ghs-count{font-size:12px;font-weight:700;color:var(--text-primary);width:28px;text-align:right}.rpt-reports-section{animation:rptFadeIn .15s ease}@keyframes rptFadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.rpt-section-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:24px;gap:16px;flex-wrap:wrap}.rpt-section-title{font-size:18px;font-weight:700;letter-spacing:-.3px;margin-bottom:4px}.rpt-section-desc{font-size:13px;color:var(--text-muted);line-height:1.5}.rpt-reports-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:14px}.rpt-report-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:20px;display:flex;gap:16px;transition:all .15s}.rpt-report-card:hover{border-color:#3b82f633;background:#3b82f605}.rpt-report-icon{font-size:28px;flex-shrink:0;margin-top:2px}.rpt-report-body{flex:1;min-width:0}.rpt-report-top{display:flex;align-items:center;gap:8px;margin-bottom:6px}.rpt-report-id{font-size:11px;font-weight:700;color:var(--accent-blue);background:#3b82f61a;padding:2px 8px;border-radius:6px}.rpt-report-format{font-size:10px;font-weight:600;color:var(--text-muted);background:#ffffff0d;padding:2px 8px;border-radius:6px}.rpt-report-title{font-size:14px;font-weight:600;letter-spacing:-.2px;margin-bottom:6px}.rpt-report-desc{font-size:12px;color:var(--text-muted);line-height:1.5;margin-bottom:10px}.rpt-report-meta{display:flex;gap:16px;flex-wrap:wrap}.rpt-report-meta-item{font-size:11px;color:var(--text-muted);display:flex;align-items:center;gap:4px}.rpt-report-btn{align-self:flex-start;flex-shrink:0;white-space:nowrap;margin-top:2px}.rpt-archive-section{animation:rptFadeIn .15s ease}.rpt-archive-toolbar{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px;gap:12px}.rpt-archive-search-wrap{position:relative;flex:1;max-width:320px}.rpt-archive-search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-muted);pointer-events:none}.rpt-archive-search{width:100%;padding:9px 14px 9px 36px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;transition:all .2s}.rpt-archive-search:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.rpt-archive-search::placeholder{color:var(--text-muted)}.rpt-archive-count{font-size:12px;color:var(--text-muted);font-weight:500;white-space:nowrap}.rpt-archive-table-wrap{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;overflow:hidden}.rpt-archive-table td{font-size:12px}.rpt-archive-name{display:flex;align-items:center;gap:8px;font-weight:500}.rpt-archive-id{font-size:10px;font-weight:700;color:var(--accent-blue);background:#3b82f61a;padding:2px 6px;border-radius:4px;flex-shrink:0}.rpt-fmt-badge{display:inline-flex;padding:2px 8px;border-radius:6px;font-size:10px;font-weight:700;text-transform:uppercase}.rpt-fmt--pdf{color:#ef4444;background:#ef44441f}.rpt-fmt--xlsx{color:#10b981;background:#10b9811f}.rpt-fmt--csv{color:#f59e0b;background:#f59e0b1f}.rpt-archive-dl{background:none;border:1px solid var(--border-subtle);border-radius:8px;color:var(--text-muted);cursor:pointer;padding:6px 8px;display:flex;align-items:center;justify-content:center;transition:all .15s}.rpt-archive-dl:hover{border-color:var(--accent-blue);color:var(--accent-blue);background:#3b82f60f}.rpt-modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:1000;display:flex;align-items:center;justify-content:center;padding:20px;animation:rptFadeIn .15s ease}.rpt-modal{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:16px;width:100%;max-width:520px;max-height:80vh;overflow-y:auto;box-shadow:0 20px 60px #00000080}.rpt-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px 0}.rpt-modal-title{font-size:16px;font-weight:700;letter-spacing:-.3px}.rpt-modal-close{background:none;border:none;color:var(--text-muted);font-size:22px;cursor:pointer;padding:4px;line-height:1}.rpt-modal-close:hover{color:var(--text-primary)}.rpt-modal-body{padding:20px 24px 24px}.rpt-modal-desc{font-size:13px;color:var(--text-secondary);line-height:1.6;margin-bottom:20px}.rpt-modal-options{display:flex;gap:16px;margin-bottom:20px}.rpt-modal-actions{display:flex;justify-content:flex-end;gap:10px;padding-top:16px;border-top:1px solid var(--border-subtle)}.rpt-modal-pack-list{margin-bottom:20px;border:1px solid var(--border-subtle);border-radius:10px;padding:14px}.rpt-modal-pack-label{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;margin-bottom:10px}.rpt-modal-pack-item{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary);padding:5px 0}.rpt-modal-pack-icon{font-size:16px}.rpt-modal-pack-id{font-size:10px;font-weight:700;color:var(--accent-blue);background:#3b82f61a;padding:1px 6px;border-radius:4px}.rpt-modal-done{text-align:center;padding:20px 0 8px}.rpt-modal-done-icon{width:48px;height:48px;border-radius:50%;background:#10b9811f;color:#10b981;display:flex;align-items:center;justify-content:center;margin:0 auto 16px}.rpt-modal-done h4{font-size:16px;font-weight:700;margin-bottom:8px}.rpt-modal-done p{font-size:13px;color:var(--text-muted);line-height:1.5;margin-bottom:20px}.rpt-modal-done-actions{display:flex;justify-content:center;gap:10px}.rpt-spinner{display:inline-block;width:14px;height:14px;border:2px solid rgba(255,255,255,.15);border-top-color:#fff;border-radius:50%;animation:rptSpin .8s linear infinite}@keyframes rptSpin{to{transform:rotate(360deg)}}.rpt-dashboard{animation:rptFadeIn .15s ease}@media(max-width:1280px){.rpt-kpi-bar{grid-template-columns:repeat(4,1fr)}.rpt-reports-grid{grid-template-columns:1fr}}@media(max-width:1024px){.rpt-page{padding:20px 20px 60px}.rpt-kpi-bar{grid-template-columns:repeat(2,1fr)}.rpt-charts-grid{grid-template-columns:1fr}.rpt-chart-card--wide{grid-column:span 1}.rpt-reports-grid{grid-template-columns:1fr}}@media(max-width:768px){.rpt-page{padding:16px 14px 60px}.rpt-header{flex-direction:column;align-items:flex-start}.rpt-tab-bar{overflow-x:auto;width:100%}.rpt-tab{padding:7px 14px;font-size:12px}.rpt-kpi-bar{grid-template-columns:repeat(2,1fr);gap:8px}.rpt-kpi{padding:14px 16px}.rpt-kpi-value{font-size:20px}.rpt-section-header{flex-direction:column}.rpt-report-card{flex-direction:column;gap:12px}.rpt-report-btn{align-self:stretch;justify-content:center}.rpt-modal-options{flex-direction:column}.rpt-pie-legend{grid-template-columns:repeat(2,1fr)}.rpt-archive-table-wrap{overflow-x:auto}.rpt-archive-table{min-width:700px}}@media(max-width:480px){.rpt-page{padding:12px 10px 60px}.rpt-kpi-bar{grid-template-columns:1fr 1fr}.rpt-kpi-value{font-size:18px}.rpt-chart-card{padding:14px}.rpt-report-icon{font-size:22px}.rpt-tab{padding:6px 10px;font-size:11px}}.settings-layout{display:flex;flex:1;min-height:0}.settings-nav{width:260px;flex-shrink:0;padding:24px 16px;border-right:1px solid var(--border-subtle);background:#ffffff03}.settings-back{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-muted);background:none;border:none;cursor:pointer;font-family:inherit;padding:6px 8px;border-radius:6px;transition:all .15s;margin-bottom:20px}.settings-back:hover{color:var(--text-secondary);background:#ffffff08}.settings-nav-title{font-size:11px;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);font-weight:600;padding:0 8px 12px}.settings-nav-list{display:flex;flex-direction:column;gap:2px}.settings-nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;text-decoration:none;color:var(--text-secondary);transition:all .15s ease;border:1px solid transparent}.settings-nav-item:hover{background:#ffffff08}.settings-nav-item--active{color:var(--text-primary);background:#3b82f61f;border-color:#3b82f61f}.settings-nav-item--active:hover{background:#3b82f61f}.settings-nav-icon{display:flex;align-items:center;flex-shrink:0;color:var(--text-muted)}.settings-nav-item--active .settings-nav-icon{color:var(--accent-blue)}.settings-nav-label{font-size:13px;font-weight:500;line-height:1.3}.settings-nav-desc{font-size:11px;color:var(--text-muted);line-height:1.3;margin-top:1px}.settings-content{flex:1;padding:28px 32px 40px;overflow-y:auto;min-width:0}.s-page-title{font-size:20px;font-weight:600;letter-spacing:-.3px;margin-bottom:6px}.s-page-desc{font-size:13px;color:var(--text-secondary);margin-bottom:28px;line-height:1.5}.s-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:24px;margin-bottom:20px}.s-card--danger{border-color:#ef444433}.s-card-title{font-size:14px;font-weight:600;margin-bottom:4px}.s-card-desc{font-size:12px;color:var(--text-muted);margin-bottom:20px;line-height:1.5}.s-row{display:flex;gap:16px;margin-bottom:16px}.s-row:last-child{margin-bottom:0}.s-field{flex:1;min-width:0}.s-label{display:block;font-size:12px;font-weight:500;color:var(--text-secondary);margin-bottom:6px;letter-spacing:.2px}.s-input{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;transition:all .2s}.s-input:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.s-input::placeholder{color:var(--text-muted)}.s-select{width:100%;padding:10px 14px;background:var(--bg-input);border:1px solid var(--border-input);border-radius:10px;color:var(--text-primary);font-family:inherit;font-size:13px;outline:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%2364748B' viewBox='0 0 16 16'%3E%3Cpath d='M4 6l4 4 4-4'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;cursor:pointer;transition:all .2s}.s-select:focus{border-color:var(--accent-blue);box-shadow:0 0 0 3px #3b82f626}.s-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:12px 0;border-bottom:1px solid rgba(255,255,255,.03)}.s-toggle-row:last-child{border-bottom:none}.s-toggle-info{flex:1}.s-toggle-label{font-size:13px;font-weight:500;margin-bottom:2px}.s-toggle-desc{font-size:11px;color:var(--text-muted)}.s-toggle{position:relative;width:40px;height:22px;border-radius:100px;background:#ffffff14;cursor:pointer;transition:background .2s;flex-shrink:0;border:none;padding:0}.s-toggle--on{background:var(--accent-blue)}.s-toggle:after{content:"";position:absolute;top:2px;left:2px;width:18px;height:18px;border-radius:50%;background:#fff;transition:left .2s}.s-toggle--on:after{left:20px}.s-btn{display:inline-flex;align-items:center;gap:8px;padding:10px 20px;border-radius:10px;font-size:13px;font-weight:600;cursor:pointer;font-family:inherit;transition:all .2s;border:none}.s-btn--primary{background:var(--accent-blue);color:#fff}.s-btn--primary:hover{background:var(--accent-blue-hover);box-shadow:0 4px 20px #3b82f64d}.s-btn--secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-subtle)}.s-btn--secondary:hover{border-color:#ffffff26;color:var(--text-primary)}.s-btn--danger{background:var(--danger);color:#fff}.s-btn--danger:hover{background:#dc2626}.s-btn--sm{padding:7px 14px;font-size:12px}.s-badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:11px;font-weight:600}.s-badge--blue{color:var(--accent-blue);background:#3b82f61f}.s-badge--green{color:var(--accent-emerald);background:#10b9811f}.s-badge--amber{color:#f59e0b;background:#f59e0b1f}.s-badge--red{color:var(--danger);background:#ef44441f}.s-badge--purple{color:#a855f7;background:#a855f71f}.s-badge--gray{color:var(--text-muted);background:#ffffff0f}.s-table{width:100%;border-collapse:collapse}.s-table th{text-align:left;font-size:11px;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);font-weight:600;padding:10px 14px;background:#ffffff05;border-bottom:1px solid var(--border-subtle)}.s-table td{padding:12px 14px;font-size:13px;border-bottom:1px solid rgba(255,255,255,.03);vertical-align:middle}.s-table tr:hover td{background:#ffffff05}.s-table .mono{font-family:JetBrains Mono,monospace;font-size:11px;color:var(--text-muted)}.s-divider{height:1px;background:var(--border-subtle);margin:20px 0}.s-actions{display:flex;gap:10px;margin-top:20px}.s-upload{border:2px dashed var(--border-input);border-radius:12px;padding:28px;text-align:center;cursor:pointer;transition:all .2s;color:var(--text-muted);font-size:13px}.s-upload:hover{border-color:var(--accent-blue);background:#3b82f60a;color:var(--text-secondary)}.s-progress{height:8px;border-radius:8px;background:#ffffff0f;overflow:hidden}.s-progress-fill{height:100%;border-radius:8px;transition:width .3s ease}@media(max-width:1024px){.settings-layout{flex-direction:column}.settings-nav{width:100%;border-right:none;border-bottom:1px solid var(--border-subtle);padding:16px}.settings-nav-list{flex-direction:row;overflow-x:auto;gap:4px;padding-bottom:4px}.settings-nav-item{white-space:nowrap;padding:8px 14px}.settings-nav-desc,.settings-nav-title{display:none}.settings-content{padding:20px 16px 32px}}@media(max-width:768px){.settings-nav{padding:12px}.settings-nav-item{padding:8px 10px;font-size:12px}.settings-nav-icon{display:none}.s-row{flex-direction:column}.s-card{padding:18px}.settings-content{padding:16px 12px 28px}}@media(max-width:480px){.settings-back{display:none}}
