*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--color-navy: #024b83;--color-navy-dark: #013a66;--color-cyan: #60a6b3;--color-cyan-hover: #4e939f;--color-purple: #2c1e50;--success: #107c10;--warning: #e67e00;--danger: #d83b01;--danger-dark: #a80000;--text: #333333;--text-light: #666666;--bg: #f5f5f5;--white: #ffffff;--border: #e0e0e0;--radius-sm: 6px;--radius-md: 10px;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .08);--shadow-md: 0 4px 12px rgba(0, 0, 0, .1);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .15);--primary: var(--color-navy);--primary-dark: var(--color-navy-dark);--radius: var(--radius-sm)}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,sans-serif;color:var(--text);background:var(--bg);line-height:1.6;-webkit-font-smoothing:antialiased}.app-layout{min-height:100vh;display:flex;flex-direction:column}.app-header-wrap{position:sticky;top:0;z-index:100;padding:12px 20px 0;max-width:1200px;margin:0 auto;width:100%}.app-banner{background:var(--color-navy);background-image:url(/banner-bg.jpg);background-size:cover;background-position:center;padding:0 25px;display:flex;align-items:center;gap:20px;height:56px;position:relative;box-shadow:var(--shadow-md);border-radius:var(--radius-md) var(--radius-md) 0 0}.app-banner:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#024b838c;border-radius:var(--radius-md) var(--radius-md) 0 0;pointer-events:none}.header-brand{display:flex;align-items:flex-start;gap:10px;flex-shrink:0;position:relative;z-index:1}.header-logo{height:40px;width:auto}.header-title{display:flex;flex-direction:column;padding-top:6px}.header-brand h1{font-size:20px;color:#fff;font-weight:700;white-space:nowrap;line-height:1}.header-version{font-size:11px;color:#ffffff80;font-weight:400;line-height:1;margin-top:2px}.banner-actions{display:flex;align-items:center;gap:12px;margin-left:auto;position:relative;z-index:1}.banner-user-name{font-size:14px;color:#ffffffb3}.role-badge{background:var(--color-cyan);color:var(--color-navy);padding:2px 8px;border-radius:12px;font-size:11px;font-weight:600;text-transform:uppercase}.btn-view-toggle{background:#ffffff26;border:1px solid rgba(255,255,255,.3);padding:4px 10px;border-radius:var(--radius-sm);cursor:pointer;font-size:12px;font-weight:600;color:#fff;transition:all .2s}.btn-view-toggle:hover{background:#ffffff40}.btn-view-toggle-active{background:var(--color-cyan);color:var(--color-navy);border-color:var(--color-cyan)}.btn-view-toggle-active:hover{background:var(--color-cyan-hover)}.btn-logout{background:var(--color-cyan);border:none;padding:6px 16px;border-radius:var(--radius-sm);cursor:pointer;font-size:13px;font-weight:600;color:var(--color-navy);transition:all .2s}.btn-logout:hover{background:var(--color-cyan-hover)}.app-nav{display:flex;align-items:stretch;background:var(--white);padding:0 10px;box-shadow:var(--shadow-sm);overflow-x:auto;border-radius:0 0 var(--radius-md) var(--radius-md)}.app-nav a{display:flex;align-items:center;padding:12px 18px;font-size:14px;font-weight:500;color:var(--text-light);text-decoration:none;border-bottom:3px solid transparent;white-space:nowrap;transition:all .2s}.app-nav a:hover{color:var(--color-navy);background:#60a6b30d}.app-nav a.active{color:var(--color-navy);border-bottom-color:var(--color-cyan);font-weight:600}.nav-link-ext{margin-left:auto;opacity:.65;font-size:.85em}.nav-link-ext:hover{opacity:1}[data-theme=dark] .nav-link-ext{color:var(--text-light)}.hamburger-btn,.mobile-user-actions{display:none}.mobile-user-actions .btn-view-toggle{background:transparent;border:1px solid var(--border);color:var(--text)}.mobile-user-actions .btn-view-toggle:hover{border-color:var(--color-cyan);color:var(--color-navy)}.mobile-user-actions .btn-view-toggle-active{background:var(--color-cyan);color:var(--color-navy);border-color:var(--color-cyan)}.mobile-user-actions .btn-logout{background:var(--color-cyan);color:var(--color-navy);border:none}.mobile-user-actions .theme-toggle{background:var(--bg);border:1px solid var(--border);color:var(--text)}.mobile-user-actions .theme-toggle:hover{border-color:var(--color-cyan)}.app-main{flex:1;padding:24px;max-width:1200px;margin:0 auto;width:100%}.login-page{min-height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:var(--color-navy);background-image:url(/banner-bg.jpg);background-size:cover;background-position:center;background-repeat:no-repeat;position:relative;padding:20px}.login-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background:#024b83b3;z-index:0}.login-card{position:relative;z-index:1;background:#1a1b22f2;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-radius:16px;padding:50px 40px 40px;width:100%;max-width:420px;box-shadow:0 8px 32px #00000080;text-align:center}.login-header{text-align:center;margin-bottom:32px}.login-logo{height:50px;width:auto;margin-bottom:20px}.login-header h1{font-size:1.75rem;color:#60a6b3;margin-bottom:0;font-weight:700}.btn-microsoft{display:flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 20px;background:var(--color-cyan);color:#fff;border:1px solid var(--color-cyan);border-radius:8px;font-size:.9rem;font-weight:600;text-align:center;text-decoration:none;cursor:pointer;transition:all .2s ease}.btn-microsoft:hover{background:var(--color-cyan-hover);border-color:var(--color-cyan-hover);transform:translateY(-1px);box-shadow:0 4px 12px #60a6b366}.btn-microsoft:active{transform:translateY(0)}.login-divider{display:flex;align-items:center;gap:12px;margin:8px 0}.login-divider:before,.login-divider:after{content:"";flex:1;height:1px;background:#2c2d36}.login-divider span{font-size:.8rem;color:#555;text-transform:uppercase;letter-spacing:.5px}.login-footer{position:relative;z-index:1;margin-top:30px;text-align:center}.login-footer p{font-size:.8rem;color:#ffffff80}.login-card .form-group label{color:#e4e4ea}.login-card .form-group input,.login-card .form-group select{background:#1f2029;color:#e4e4ea;border-color:#2c2d36}.login-card .form-group input:focus,.login-card .form-group select:focus{border-color:#60a6b3}.login-card .form-error{background:#3d1010;color:#ff6b6b}.login-card .btn-primary{background:#60a6b3;color:#121317}.login-card .btn-primary:hover:not(:disabled){background:#4e939f}.login-card .btn-outline{background:#1f2029;color:#e4e4ea;border-color:#2c2d36}.login-card .btn-outline:hover:not(:disabled){background:#2a2b36}.login-form{display:flex;flex-direction:column;gap:16px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:13px;font-weight:600;color:var(--text)}.form-group input,.form-group select{width:100%;min-width:0;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;transition:border-color .15s}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--color-cyan);box-shadow:0 0 0 2px #60a6b326}.form-error{color:var(--danger);font-size:13px;padding:8px 12px;background:#fef0ec;border-radius:var(--radius)}.btn{padding:10px 20px;border:none;border-radius:var(--radius);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,opacity .15s}.btn:disabled{opacity:.6;cursor:not-allowed}.btn-primary{background:var(--color-cyan);color:var(--color-navy)}.btn-primary:hover:not(:disabled){background:var(--color-cyan-hover)}.btn-outline{background:transparent;color:var(--color-navy);border:1px solid var(--border)}.btn-outline:hover:not(:disabled){background:var(--bg)}.quick-login{margin-top:16px;text-align:center}.quick-login p{font-size:12px;color:var(--text-light);margin-bottom:8px}.quick-login .btn{margin:0 4px;padding:6px 16px;font-size:13px}.dashboard{display:flex;flex-direction:column;align-items:center;gap:32px}.dashboard-welcome{text-align:center}.dashboard-welcome h2{font-size:24px;margin-bottom:4px}.dashboard-welcome p{color:var(--text-light)}.scan-action{display:flex;justify-content:center;margin-top:20px}.btn-scan{width:200px;height:200px;border-radius:50%;background:var(--color-cyan);color:var(--color-navy);border:none;font-size:20px;font-weight:700;cursor:pointer;box-shadow:0 4px 24px #60a6b359;transition:transform .15s,box-shadow .15s;display:flex;align-items:center;justify-content:center;text-align:center;line-height:1.3}.btn-scan:hover{transform:scale(1.05);box-shadow:0 6px 32px #60a6b380}.btn-scan:active{transform:scale(.98)}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;width:100%;max-width:800px}.stat-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);padding:24px;cursor:pointer;box-shadow:var(--shadow-sm);transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.stat-card h3{font-size:16px;color:var(--primary);margin-bottom:4px}.stat-card p{color:var(--text-light);font-size:14px}.placeholder-page{text-align:center;padding:60px 20px}.placeholder-page h2{font-size:24px;margin-bottom:8px}.placeholder-page p{color:var(--text-light)}.coming-soon{margin-top:16px;padding:8px 16px;background:#f0f1f5;border-radius:var(--radius);display:inline-block;color:var(--primary);font-weight:600;font-size:13px}.loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--text-light);font-size:16px}.scan-page{max-width:500px;margin:0 auto;text-align:center}.scan-page h2{margin-bottom:4px}.scan-page>p{color:var(--text-light);margin-bottom:24px}.scanner-container{margin-top:16px}#scanner-region{max-width:400px;margin:0 auto 16px;border-radius:var(--radius);overflow:hidden}.scanner-idle{display:none}.scanner-active{display:block}.scanner-actions{display:flex;flex-direction:column;gap:12px;align-items:center}.btn-large{padding:14px 32px;font-size:16px}.manual-entry-form{max-width:400px;margin:0 auto}.manual-entry-actions{display:flex;gap:12px;margin-top:12px}.manual-entry-actions .btn{flex:1}.test-form-page{max-width:600px;margin:0 auto}.test-form-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;gap:12px}.test-form-header h2{min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.btn-abandon-test{background:none;border:none;font-size:28px;line-height:1;color:var(--text-light);cursor:pointer;padding:4px 8px;border-radius:var(--radius-sm);transition:color .15s,background .15s;flex-shrink:0}.btn-abandon-test:hover{color:var(--danger);background:#d83b0114}.test-timer{font-size:24px;font-weight:700;color:var(--primary);font-variant-numeric:tabular-nums;white-space:nowrap;flex-shrink:0}.asset-info-section{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.asset-info-section h3,.strand-section h3{font-size:16px;margin-bottom:12px;color:var(--text)}.form-row{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.input-disabled{background:#f5f5f5;color:var(--text-light)}.new-asset-notice{margin-top:12px;padding:8px 12px;background:#f0f1f5;border-radius:var(--radius);color:var(--primary);font-size:13px}.reclean-banner{background:#fff4e6;border:1px solid var(--warning);border-radius:var(--radius);padding:12px 16px;margin-bottom:20px;font-size:14px;color:#8a5700;line-height:1.5}.reclean-banner strong{color:var(--warning)}.previous-test-popup{background:#f0f1f5;border:1px solid var(--primary);border-radius:var(--radius);padding:14px 18px;margin-bottom:20px}.previous-test-popup h4{font-size:13px;color:var(--primary);margin-bottom:8px}.previous-test-info{display:flex;gap:16px;flex-wrap:wrap;font-size:14px;align-items:center}.strand-section{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:20px}.strand-hint{font-size:13px;color:var(--text-light);margin-bottom:12px}.strand-list{display:flex;flex-direction:column;gap:4px}.strand-row{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:var(--radius)}.strand-row-tappable{cursor:pointer;transition:background .1s;border:1px solid transparent}.strand-row-tappable:hover{background:#f7f9fb}.strand-row-tappable:active{background:#eef3f9}.strand-row-filled{border-color:#e0e8f0;background:#fafbfd}.strand-color{width:24px;height:24px;border-radius:6px;flex-shrink:0}.strand-label{font-size:14px;font-weight:500;flex:1}.strand-color-name{font-weight:400;color:var(--text-light);font-size:12px}.strand-display-value{font-size:15px;font-weight:600;font-variant-numeric:tabular-nums;color:var(--text);min-width:60px;text-align:right}.strand-row:not(.strand-row-filled) .strand-display-value{color:var(--border)}.strand-prefilled{background:#f8faf8;border-color:#d4e6d4}.strand-prev-badge{display:inline-block;margin-left:6px;padding:1px 6px;border-radius:8px;font-size:10px;font-weight:600;background:#e6f4e6;color:var(--success);vertical-align:middle}.strand-delta{display:block;font-size:11px;font-weight:500;margin-top:1px}.strand-delta-improved{color:var(--success)}.strand-delta-worsened{color:var(--danger)}.strand-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;display:flex;align-items:flex-end;justify-content:center;z-index:300;padding:0}.strand-modal{background:var(--white);border-radius:16px 16px 0 0;padding:24px 24px 32px;width:100%;max-width:480px;animation:slideUp .2s ease-out}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}.strand-modal-header{display:flex;align-items:center;gap:14px;margin-bottom:24px}.strand-modal-color{width:40px;height:40px;border-radius:10px;flex-shrink:0}.strand-modal-title{font-size:20px;font-weight:700}.strand-modal-subtitle{font-size:14px;color:var(--text-light)}.strand-modal-input-wrap{display:flex;align-items:center;gap:8px;margin-bottom:20px}.strand-modal-input{flex:1;padding:16px 18px;border:2px solid var(--primary);border-radius:var(--radius);font-size:28px;font-weight:700;text-align:center;font-variant-numeric:tabular-nums}.strand-modal-input:focus{outline:none;box-shadow:0 0 0 4px #1b2d5b26}.strand-modal-unit{font-size:20px;font-weight:600;color:var(--text-light)}.strand-modal-actions{display:flex;gap:10px}.strand-modal-actions .btn{flex:1;padding:14px;font-size:15px}.result-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.result-pass{background:#e6f4e6;color:var(--success)}.result-fail{background:#fef0ec;color:var(--danger)}.result-repair{background:#fce4e4;color:var(--danger-dark)}.btn-back{background:none;border:none;color:var(--text-light);font-size:14px;cursor:pointer;padding:0 0 12px;display:inline-block;transition:color .15s}.btn-back:hover{color:var(--primary)}.test-result-page{max-width:600px;margin:0 auto}.result-banner{padding:24px;border-radius:var(--radius);text-align:center;margin-bottom:24px}.result-banner h2{font-size:28px;margin-bottom:8px}.result-banner p{font-size:14px;line-height:1.6}.result-banner-pass{background:#e6f4e6;color:var(--success);border:2px solid var(--success)}.result-banner-fail{background:#fef0ec;color:var(--danger);border:2px solid var(--danger)}.result-banner-repair{background:#fce4e4;color:var(--danger-dark);border:2px solid var(--danger-dark)}.result-details{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px}.detail-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f0f0f0}.detail-row:last-child{border-bottom:none}.detail-label{font-weight:600;font-size:14px}.detail-value{font-size:14px;color:var(--text-light)}.strand-results{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px;margin-bottom:20px}.strand-results h3{font-size:16px;margin-bottom:12px}.strand-result-row{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid #f5f5f5}.strand-result-row:last-child{border-bottom:none}.strand-result-row.strand-fail{background:#fff8f5}.strand-result-row.strand-repair{background:#fef0f0}.strand-value{margin-left:auto;font-size:14px;font-weight:600;font-variant-numeric:tabular-nums}.strand-status{font-size:11px;font-weight:700;min-width:52px;text-align:center;padding:2px 6px;border-radius:4px}.status-pass{background:#e6f4e6;color:var(--success)}.status-fail{background:#fef0ec;color:var(--danger)}.status-repair{background:#fce4e4;color:var(--danger-dark)}.result-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap;margin-bottom:20px}.btn-danger{background:var(--danger);color:var(--white)}.btn-danger:hover:not(:disabled){background:var(--danger-dark)}.ticket-submitted,.ticket-exists{text-align:center}.ticket-submitted p,.ticket-exists p{margin-bottom:12px;color:var(--text-light)}.repair-form-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.repair-form-card{background:var(--white);border-radius:12px;padding:24px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto}.repair-form-card h3{margin-bottom:4px}.repair-form-card>p{color:var(--text-light);font-size:14px;margin-bottom:16px}.repair-form-card textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;resize:vertical}.repair-form-card textarea:focus{outline:none;border-color:var(--primary)}.repair-form-actions{display:flex;gap:12px;margin-top:16px}.repair-wizard-card{background:var(--white);border-radius:12px;padding:24px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}.repair-wizard-card h3{margin-bottom:4px}.repair-wizard-card textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;resize:vertical}.repair-wizard-card textarea:focus{outline:none;border-color:var(--primary)}.repair-wizard-steps{display:flex;align-items:center;justify-content:center;gap:0;margin-bottom:20px}.wizard-step-dot{width:28px;height:28px;border-radius:50%;border:2px solid var(--border);display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:600;color:var(--text-light);background:var(--bg)}.wizard-step-dot.wizard-step-active{border-color:var(--primary);color:var(--primary);background:#e8f5f7}.wizard-step-dot.wizard-step-completed{border-color:var(--success);color:var(--white);background:var(--success)}.wizard-step-line{width:32px;height:2px;background:var(--border)}.repair-wizard-actions{display:flex;gap:10px;justify-content:flex-end;flex-wrap:wrap;margin-top:16px}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:12px}.search-form{display:flex;gap:8px}.search-input{padding:8px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;min-width:200px}.search-input:focus{outline:none;border-color:var(--color-cyan);box-shadow:0 0 0 2px #60a6b326}.tests-controls{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:12px}.sort-control{display:flex;align-items:center;gap:6px}.sort-label{font-size:13px;color:var(--text-light);font-weight:500}.sort-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;cursor:pointer;background:var(--white)}.sort-select:focus{outline:none;border-color:var(--primary)}.filter-tab-pass.filter-tab-active{background:var(--success);border-color:var(--success)}.filter-tab-fail.filter-tab-active{background:var(--danger);border-color:var(--danger)}.filter-tab-repair.filter-tab-active{background:var(--danger-dark);border-color:var(--danger-dark)}.tests-table-wrap{overflow-x:auto}.tests-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden}.tests-table th{background:var(--primary);color:var(--white);padding:10px 14px;text-align:left;font-size:13px;font-weight:600}.tests-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;font-size:14px}.clickable-row{cursor:pointer;transition:background .1s}.clickable-row:hover{background:#f7f9fb}.test-id-cell{font-family:monospace;font-size:12px}.empty-state{text-align:center;padding:40px;color:var(--text-light)}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:20px}.page-info{font-size:14px;color:var(--text-light)}.stat-card-highlight{border-left:4px solid var(--primary)}.stat-card-success{border-left:4px solid var(--success)}.stat-card-warning{border-left:4px solid var(--warning)}.stat-number{font-size:32px;font-weight:700;color:var(--text);margin-bottom:4px}.admin-section{width:100%;max-width:800px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-top:16px}.admin-section h3{font-size:16px;margin-bottom:12px}.stats-bar{display:flex;height:32px;border-radius:var(--radius);overflow:hidden;background:#f0f0f0}.stats-bar-segment{display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;color:var(--white);min-width:0;transition:width .3s}.stats-bar-pass{background:var(--success)}.stats-bar-fail{background:var(--danger)}.stats-bar-repair{background:var(--danger-dark)}.stats-bar-empty{display:flex;align-items:center;justify-content:center;width:100%;font-size:13px;color:var(--text-light)}.recent-tests-list{display:flex;flex-direction:column}.recent-test-item{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid #f0f0f0;cursor:pointer;transition:background .1s}.recent-test-item:last-child{border-bottom:none}.recent-test-item:hover{background:#f7f9fb;margin:0 -20px;padding:10px 20px}.recent-test-asset{font-weight:600;font-size:14px;min-width:120px}.recent-test-tech{font-size:14px;color:var(--text-light);flex:1}.recent-test-date{font-size:13px;color:var(--text-light)}.filter-tabs{display:flex;gap:4px}.filter-tab{padding:6px 14px;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);font-size:13px;font-weight:500;cursor:pointer;color:var(--text-light);transition:all .15s}.filter-tab:hover{border-color:var(--primary);color:var(--primary)}.filter-tab-active{background:var(--color-cyan);color:var(--color-navy);border-color:var(--color-cyan)}.tickets-list{display:flex;flex-direction:column;gap:12px}.ticket-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius-md);overflow:hidden;box-shadow:var(--shadow-sm)}.ticket-card-header{display:flex;justify-content:space-between;align-items:center;padding:14px 18px;border-bottom:1px solid #f0f0f0}.ticket-asset{font-weight:700;font-size:16px}.ticket-status-badge{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:700;text-transform:uppercase}.ticket-status-open{background:#fef0ec;color:var(--danger)}.ticket-status-progress{background:#fff4e6;color:var(--warning)}.ticket-status-resolved{background:#e6f4e6;color:var(--success)}.ticket-card-body{padding:14px 18px}.ticket-notes{font-size:14px;margin-bottom:10px;line-height:1.5}.ticket-meta{display:flex;gap:16px;flex-wrap:wrap;font-size:13px;color:var(--text-light)}.ticket-card-actions{display:flex;gap:12px;align-items:center;padding:12px 18px;border-top:1px solid #f0f0f0;background:#fafbfc}.ticket-status-select{padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;cursor:pointer}.ticket-status-select:focus{outline:none;border-color:var(--primary)}.btn-sm{padding:6px 14px;font-size:13px}.comment-panel-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;justify-content:flex-end;z-index:200}.comment-panel{background:var(--white);width:100%;max-width:520px;height:100%;display:flex;flex-direction:column;animation:slideIn .2s ease-out}@keyframes slideIn{0%{transform:translate(100%)}to{transform:translate(0)}}.comment-panel-header{display:flex;justify-content:space-between;align-items:flex-start;padding:20px 20px 12px;border-bottom:1px solid var(--border)}.comment-panel-header h3{font-size:18px;margin-bottom:2px}.comment-panel-asset{font-family:monospace;font-size:15px;font-weight:700;color:var(--primary)}.comment-panel-close{background:none;border:none;font-size:28px;cursor:pointer;color:var(--text-light);padding:0 4px;line-height:1}.comment-panel-close:hover{color:var(--text)}.comment-panel-ticket-info{padding:14px 20px;border-bottom:1px solid var(--border);background:#fafbfc}.comment-panel-notes{font-size:14px;line-height:1.5;margin-bottom:8px}.comment-panel-meta{display:flex;gap:12px;align-items:center;font-size:13px;color:var(--text-light)}.comment-thread{flex:1;overflow-y:auto;padding:16px 20px;display:flex;flex-direction:column;gap:12px}.comment-empty{text-align:center;color:var(--text-light);padding:32px 0;font-size:14px}.comment-item{border:1px solid #eef1f5;border-radius:var(--radius);padding:12px 14px}.comment-header{display:flex;align-items:center;gap:8px;margin-bottom:6px;flex-wrap:wrap}.comment-author{font-weight:700;font-size:13px}.comment-source{font-size:11px;padding:1px 8px;border-radius:10px;font-weight:600}.comment-source-platform{background:#e8eaf0;color:var(--primary)}.comment-source-email{background:#f0e6ff;color:#7c3aed}.comment-time{font-size:12px;color:var(--text-light);margin-left:auto}.comment-body{font-size:14px;line-height:1.6;white-space:pre-wrap}.comment-input-area{padding:14px 20px;border-top:1px solid var(--border);background:#fafbfc}.comment-textarea{width:100%;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:14px;font-family:inherit;resize:vertical;min-height:60px}.comment-textarea:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #60a6b326}.comment-input-actions{display:flex;justify-content:space-between;align-items:center;margin-top:8px}.comment-hint{font-size:12px;color:var(--text-light)}.test-detail-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.test-detail-modal{background:var(--white);border-radius:12px;padding:24px;max-width:600px;width:100%;max-height:90vh;overflow-y:auto}.test-detail-modal-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.test-detail-modal-header h3{font-size:18px}.comment-attachments{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px}.comment-attachment-thumb{display:flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--border);border-radius:var(--radius);background:#f7f9fb;cursor:pointer;font-size:12px;transition:border-color .15s}.comment-attachment-thumb:hover{border-color:var(--primary)}.attachment-icon{font-size:16px}.attachment-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-preview-row{display:flex;gap:8px;flex-wrap:wrap;margin-top:8px;padding:8px;background:#f7f9fb;border-radius:var(--radius)}.attachment-preview-item{display:flex;align-items:center;gap:6px;padding:4px 8px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);font-size:12px}.attachment-preview-name{max-width:120px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.attachment-preview-remove{background:none;border:none;font-size:16px;cursor:pointer;color:var(--danger);padding:0 2px;line-height:1}.lightbox-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000e6;display:flex;align-items:center;justify-content:center;z-index:400;padding:20px;cursor:pointer}.lightbox-image{max-width:90vw;max-height:90vh;border-radius:4px;object-fit:contain}.lightbox-close{position:fixed;top:16px;right:16px;background:none;border:none;color:var(--white);font-size:36px;cursor:pointer;z-index:401}.user-count{font-size:14px;color:var(--text-light)}.users-table-wrap{overflow-x:auto}.users-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden}.users-table th{background:var(--primary);color:var(--white);padding:10px 14px;text-align:left;font-size:13px;font-weight:600}.users-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;font-size:14px}.users-table tr:hover{background:#f7f9fb}.current-user-row{background:#f0f1f5}.current-user-row:hover{background:#e8eaf0}.user-name-cell{font-weight:600;display:flex;align-items:center;gap:8px}.user-email-cell{color:var(--text-light);font-size:13px}.you-badge{background:var(--primary);color:var(--white);padding:1px 6px;border-radius:8px;font-size:10px;font-weight:600}.role-select{padding:4px 8px;border:1px solid var(--border);border-radius:var(--radius);font-size:13px;cursor:pointer}.role-select:disabled{opacity:.6;cursor:not-allowed}.role-select:focus{outline:none;border-color:var(--primary)}.center-cell{text-align:center}.page-description{color:var(--text-light);font-size:14px;margin-bottom:20px;line-height:1.6}.recipients-list{display:flex;flex-direction:column;gap:12px}.recipient-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px 18px;display:flex;justify-content:space-between;align-items:center;gap:16px}.recipient-inactive{opacity:.6}.recipient-info{flex:1}.recipient-name{font-weight:600;font-size:15px;margin-bottom:2px}.recipient-email{font-size:13px;color:var(--text-light);margin-bottom:6px}.recipient-type-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:11px;font-weight:600}.type-all{background:#e6f4e6;color:var(--success)}.type-critical{background:#fef0ec;color:var(--danger)}.recipient-actions{display:flex;align-items:center;gap:10px;flex-shrink:0}.toggle-switch{display:flex;align-items:center;gap:8px;cursor:pointer}.toggle-switch input{display:none}.toggle-slider{width:40px;height:22px;background:#ccc;border-radius:11px;position:relative;transition:background .2s;flex-shrink:0}.toggle-slider:after{content:"";position:absolute;width:18px;height:18px;background:var(--white);border-radius:50%;top:2px;left:2px;transition:transform .2s}.toggle-switch input:checked+.toggle-slider{background:var(--success)}.toggle-switch input:checked+.toggle-slider:after{transform:translate(18px)}.toggle-label{font-size:12px;color:var(--text-light);min-width:50px}.tech-recent-section{width:100%;max-width:600px;margin-top:32px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.tech-recent-section h3{font-size:16px;margin-bottom:12px}.recent-test-reel{font-size:13px;color:var(--text-light)}.btn-view-all{margin-top:12px;width:100%}.help-page{max-width:800px;margin:0 auto}.help-page h2{margin-bottom:24px}.help-section{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.help-section h3{font-size:16px;margin-bottom:12px;color:var(--primary)}.help-description{color:var(--text-light);font-size:14px;margin-bottom:12px}.help-steps{padding-left:20px;display:flex;flex-direction:column;gap:12px}.help-steps li{font-size:14px;line-height:1.6}.help-steps strong{color:var(--text)}.help-thresholds{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.threshold-card{padding:16px;border-radius:var(--radius);text-align:center}.threshold-card p{font-size:13px;margin-top:8px}.threshold-label{font-size:18px;font-weight:700;margin-bottom:4px}.threshold-value{font-size:24px;font-weight:700;font-variant-numeric:tabular-nums}.threshold-pass{background:#e6f4e6;color:var(--success)}.threshold-fail{background:#fef0ec;color:var(--danger)}.threshold-repair{background:#fce4e4;color:var(--danger-dark)}.color-reference{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.color-ref-item{display:flex;align-items:center;gap:8px;padding:6px 10px;border:1px solid #f0f0f0;border-radius:var(--radius)}.color-ref-swatch{width:20px;height:20px;border-radius:4px;flex-shrink:0}.color-ref-number{font-weight:600;font-size:13px;min-width:16px}.color-ref-name{font-size:13px;color:var(--text-light)}.help-reel-types{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.reel-type-card{padding:16px;border:1px solid var(--border);border-radius:var(--radius);text-align:center}.reel-type-card h4{font-size:16px;color:var(--primary);margin-bottom:4px}.reel-type-card p{font-size:13px;color:var(--text-light)}.wizard-page{max-width:500px;margin:0 auto}.wizard-header{text-align:center;margin-bottom:16px}.wizard-header h2{margin-bottom:4px}.wizard-asset-number{font-size:18px;font-weight:700;color:var(--primary);font-family:monospace}.wizard-progress{display:flex;justify-content:center;gap:8px;margin-bottom:8px}.wizard-step-dot{width:12px;height:12px;border-radius:50%;background:var(--border);transition:background .2s}.wizard-step-dot.active{background:var(--primary);transform:scale(1.2)}.wizard-step-dot.completed{background:var(--success)}.wizard-step-label{text-align:center;font-size:13px;color:var(--text-light);margin-bottom:16px}.wizard-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px;margin-bottom:16px}.wizard-step h3{font-size:18px;margin-bottom:4px}.wizard-hint{font-size:14px;color:var(--text-light);margin-bottom:16px}.wizard-options{display:flex;flex-direction:column;gap:10px}.wizard-option{display:flex;flex-direction:column;align-items:center;padding:16px;border:2px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;transition:border-color .15s,background .15s}.wizard-option:hover{border-color:var(--primary);background:#f0f1f5}.wizard-option.selected{border-color:var(--primary);background:#e8eaf0}.wizard-option-label{font-size:16px;font-weight:700}.wizard-option-detail{font-size:13px;color:var(--text-light);margin-top:2px}.length-input-section{max-width:340px;margin:0 auto}.length-input-row{display:flex;gap:8px;align-items:center}.length-input{flex:1;padding:12px 14px;border:1px solid var(--border);border-radius:var(--radius);font-size:16px;text-align:right}.length-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #60a6b326}.length-unit-toggle{display:flex;border:1px solid var(--border);border-radius:var(--radius);overflow:hidden;flex-shrink:0}.unit-btn{padding:10px 16px;border:none;background:var(--white);font-size:14px;font-weight:600;cursor:pointer;transition:background .15s,color .15s}.unit-btn.active{background:var(--primary);color:var(--white)}.unit-btn:not(.active):hover{background:#f0f1f5}.length-conversion{text-align:center;margin-top:8px;font-size:15px;color:var(--primary);font-weight:600}.wizard-summary{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:16px 20px;margin-bottom:16px}.wizard-summary h4{font-size:14px;color:var(--primary);margin-bottom:8px}.summary-row{display:flex;justify-content:space-between;padding:6px 0;border-bottom:1px solid #f0f0f0;font-size:14px}.summary-row:last-child{border-bottom:none}.summary-row span:first-child{font-weight:600}.summary-row span:last-child{color:var(--text-light)}.wizard-actions{display:flex;gap:12px;justify-content:center}.wizard-actions .btn{min-width:120px}.assets-page h2{display:inline;margin-right:12px}.asset-count{font-size:14px;color:var(--text-light)}.assets-table-wrap{overflow-x:auto}.assets-table{width:100%;border-collapse:collapse;background:var(--white);border-radius:var(--radius);overflow:hidden}.assets-table th{background:var(--primary);color:var(--white);padding:10px 14px;text-align:left;font-size:13px;font-weight:600}.assets-table td{padding:10px 14px;border-bottom:1px solid #f0f0f0;font-size:14px}.assets-table tr:hover{background:#f7f9fb}.asset-number-cell{font-weight:700;font-family:monospace}.asset-detail-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.asset-detail-modal{background:var(--white);border-radius:12px;padding:24px;max-width:700px;width:100%;max-height:90vh;overflow-y:auto}.edit-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.edit-modal-card{background:var(--white);border-radius:12px;padding:24px;max-width:480px;width:100%;max-height:90vh;overflow-y:auto}.edit-modal-card h3{margin-bottom:4px}.edit-modal-asset{font-family:monospace;font-size:16px;font-weight:700;color:var(--primary);margin-bottom:16px}.edit-modal-card .form-group{margin-bottom:14px}.edit-length-row{display:flex;gap:8px;align-items:center}.edit-modal-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}.reports-page{max-width:900px;margin:0 auto}.reports-page h2{margin-bottom:4px}.reports-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;margin-top:16px}.report-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:20px;display:flex;flex-direction:column;overflow:hidden}.report-card h3{font-size:16px;color:var(--primary);margin-bottom:4px}.report-card>p{font-size:13px;color:var(--text-light);margin-bottom:16px}.report-card .form-group{margin-bottom:12px}.report-card-actions{margin-top:auto}.date-range-row{display:grid;grid-template-columns:1fr 1fr;gap:12px;min-width:0}.date-range-row .form-group{min-width:0}.wizard-fullscreen{display:flex;flex-direction:column;align-items:center}.wizard-strand-progress{width:100%;max-width:400px;margin-bottom:16px;text-align:center}.wizard-strand-label{font-size:14px;color:var(--text-light);font-weight:500;display:block;margin-bottom:6px}.wizard-strand-bar{height:6px;background:#e0e0e0;border-radius:3px;overflow:hidden}.wizard-strand-bar-fill{height:100%;background:var(--primary);border-radius:3px;transition:width .3s}.wizard-strand-identity{display:flex;align-items:center;gap:16px;margin-bottom:24px}.wizard-strand-swatch{width:56px;height:56px;border-radius:14px;flex-shrink:0}.wizard-strand-name{font-size:24px;font-weight:700}.wizard-strand-color-name{font-size:15px;color:var(--text-light)}.pass-flash{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;background:#107c10e6;color:var(--white);font-size:48px;font-weight:700;z-index:500;animation:flashIn .6s ease-out;pointer-events:none}@keyframes flashIn{0%{opacity:0;transform:scale(.8)}30%{opacity:1;transform:scale(1.1)}to{opacity:0;transform:scale(1)}}.reclean-prompt-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px;width:100%;max-width:400px;text-align:center}.reclean-prompt-value{font-size:36px;font-weight:700;color:var(--danger);margin-bottom:8px;font-variant-numeric:tabular-nums}.reclean-prompt-message{font-size:15px;color:var(--text-light);margin-bottom:4px}.reclean-prompt-instruction{font-size:15px;font-weight:600;color:var(--text);margin-bottom:4px}.reclean-prompt-attempts{font-size:14px;color:var(--primary);font-weight:600;margin-bottom:16px}.exhausted-value{color:var(--danger-dark);font-size:24px}.reclean-attempt-list{display:flex;flex-direction:column;gap:4px;margin-bottom:16px;padding:12px;background:#f7f9fb;border-radius:var(--radius)}.reclean-attempt-item{display:flex;justify-content:space-between;font-size:14px;padding:4px 0}.reclean-attempt-value{font-weight:600;font-variant-numeric:tabular-nums}.strand-attempt-count{font-size:12px;font-weight:400;color:var(--text-light)}.cleaning-history-inline{display:flex;gap:8px;flex-wrap:wrap;padding:4px 12px 8px 44px}.cleaning-attempt{font-size:12px;padding:2px 8px;border-radius:10px;font-weight:600;font-variant-numeric:tabular-nums}.cleaning-attempt-pass{background:#e6f4e6;color:var(--success)}.cleaning-attempt-fail{background:#fef0ec;color:var(--danger)}.atm-container{display:flex;flex-direction:column;align-items:center;gap:16px}.atm-display{display:flex;align-items:baseline;justify-content:center;gap:8px;padding:16px 24px;background:#f7f9fb;border:2px solid var(--primary);border-radius:var(--radius);min-width:200px}.atm-value{font-size:48px;font-weight:700;font-variant-numeric:tabular-nums;color:var(--text)}.atm-unit{font-size:24px;font-weight:600;color:var(--text-light)}.atm-numpad{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;max-width:300px}.atm-key{padding:18px;font-size:24px;font-weight:600;border:1px solid var(--border);border-radius:var(--radius);background:var(--white);cursor:pointer;transition:background .1s,border-color .1s;user-select:none;-webkit-user-select:none}.atm-key:hover{background:#f0f1f5;border-color:var(--primary)}.atm-key:active{background:#e8eaf0;transform:scale(.97)}.atm-key-action{color:var(--primary);font-weight:700}.atm-actions{display:flex;gap:12px;width:100%;max-width:300px}.atm-actions .btn{flex:1;padding:14px;font-size:15px}.comment-wizard-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:300;padding:20px}.comment-wizard-card{background:var(--white);border-radius:12px;padding:24px;max-width:520px;width:100%;max-height:90vh;overflow-y:auto}.comment-wizard-card h3{font-size:18px;margin-bottom:16px}.comment-wizard-actions{display:flex;gap:10px;margin-top:16px;justify-content:flex-end;flex-wrap:wrap}.photo-wizard-preview{text-align:center}.photo-wizard-img{max-width:100%;max-height:200px;border-radius:var(--radius);object-fit:contain}.photo-list{margin-top:16px}.photo-list-item{display:flex;align-items:center;gap:10px;padding:8px;border:1px solid var(--border);border-radius:var(--radius);margin-bottom:8px}.photo-list-thumb{width:48px;height:48px;border-radius:4px;object-fit:cover;flex-shrink:0}.photo-list-info{flex:1;min-width:0}.photo-list-name{font-size:13px;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.photo-list-caption{font-size:12px;color:var(--text-light);display:block;font-style:italic}.comment-attachment-wrap{display:flex;flex-direction:column;gap:2px}.attachment-caption{font-size:11px;color:var(--text-light);font-style:italic;padding-left:2px}.settings-page{max-width:600px;margin:0 auto}.settings-page h2{margin-bottom:20px}.settings-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:24px}.setting-row{display:flex;justify-content:space-between;align-items:flex-start;gap:24px;margin-bottom:20px}.setting-info{flex:1}.setting-label{font-size:15px;font-weight:600;display:block;margin-bottom:4px}.setting-description{font-size:13px;color:var(--text-light);line-height:1.5}.setting-input{width:80px;padding:10px 12px;border:1px solid var(--border);border-radius:var(--radius);font-size:18px;font-weight:700;text-align:center}.setting-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #60a6b326}.setting-success{color:var(--success);font-size:13px;padding:8px 12px;background:#e6f4e6;border-radius:var(--radius);margin-bottom:12px}.toast-container{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:600;display:flex;flex-direction:column;gap:8px;pointer-events:none}.toast{pointer-events:auto;padding:12px 20px;border-radius:var(--radius);font-size:14px;font-weight:500;color:var(--white);cursor:pointer;animation:toastIn .25s ease-out;box-shadow:0 4px 16px #0003;white-space:nowrap}.toast-success{background:var(--success)}.toast-error{background:var(--danger)}.toast-info{background:var(--primary)}@keyframes toastIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.skeleton{background:linear-gradient(90deg,#eee 25%,#f5f5f5,#eee 75%);background-size:200% 100%;animation:shimmer 1.5s infinite;border-radius:var(--radius)}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.skeleton-card{height:72px;margin-bottom:8px}.skeleton-row{height:44px;margin-bottom:4px}.skeleton-stat{height:120px}.offline-banner{position:fixed;top:0;left:0;right:0;z-index:700;background:var(--danger);color:var(--white);text-align:center;padding:8px 16px;font-size:14px;font-weight:500}.offline-banner+.app-layout .app-header-wrap{top:36px}.confirm-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:250;padding:20px}.confirm-card{background:var(--white);border-radius:12px;padding:24px;max-width:400px;width:100%}.confirm-card h3{font-size:18px;margin-bottom:8px}.confirm-card p{font-size:14px;color:var(--text-light);margin-bottom:20px;line-height:1.5}.confirm-actions{display:flex;gap:12px;justify-content:flex-end}.empty-state-card{text-align:center;padding:48px 24px;background:var(--white);border:1px solid var(--border);border-radius:var(--radius)}.empty-state-icon{font-size:48px;margin-bottom:12px;display:block}.empty-state-card h3{font-size:18px;margin-bottom:4px}.empty-state-card p{color:var(--text-light);font-size:14px;margin-bottom:16px}.sticky-controls{position:sticky;top:114px;z-index:50;background:var(--bg);padding-top:8px;padding-bottom:8px}.pull-indicator{text-align:center;padding:8px;font-size:13px;color:var(--text-light);overflow:hidden;transition:max-height .2s}.pull-indicator-hidden{max-height:0;padding:0}.pull-indicator-visible{max-height:40px}.theme-toggle{background:#ffffff26;border:1px solid rgba(255,255,255,.3);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:16px;transition:all .2s;flex-shrink:0;color:#ffffffb3}.theme-toggle:hover{background:#ffffff40;color:#fff}[data-theme=dark]{--color-navy: #60a6b3;--color-navy-dark: #4a8f9b;--color-cyan: #7ec4cf;--color-cyan-hover: #6ab3be;--primary: var(--color-navy);--primary-dark: var(--color-navy-dark);--text: #e4e4ea;--text-light: #8f90a0;--bg: #0e0f14;--white: #1a1b22;--border: #2c2d36;--shadow-sm: 0 2px 4px rgba(0, 0, 0, .4);--shadow-md: 0 4px 12px rgba(0, 0, 0, .5);--shadow-lg: 0 8px 24px rgba(0, 0, 0, .6)}[data-theme=dark] body{background:var(--bg);color:var(--text)}[data-theme=dark] .skeleton{background:linear-gradient(90deg,#1a1b22 25%,#24252e,#1a1b22 75%);background-size:200% 100%;animation:shimmer 1.5s infinite}[data-theme=dark] .form-group input,[data-theme=dark] .form-group select,[data-theme=dark] .search-input,[data-theme=dark] .sort-select,[data-theme=dark] .role-select,[data-theme=dark] .ticket-status-select,[data-theme=dark] .comment-textarea,[data-theme=dark] .setting-input{background:var(--bg);color:var(--text);border-color:var(--border)}[data-theme=dark] .form-group input:focus,[data-theme=dark] .form-group select:focus,[data-theme=dark] .search-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #60a6b333}[data-theme=dark] .btn-primary{background:var(--primary);color:#0e0f14}[data-theme=dark] .btn-primary:hover:not(:disabled){background:var(--primary-dark)}[data-theme=dark] .btn-outline{background:var(--white);color:var(--primary);border-color:var(--border)}[data-theme=dark] .btn-outline:hover:not(:disabled){background:#24252e}[data-theme=dark] .app-nav{background:var(--white);box-shadow:0 1px 0 var(--border)}[data-theme=dark] .app-nav a{color:var(--text-light)}[data-theme=dark] .app-nav a:hover{color:var(--text);background:#60a6b314}[data-theme=dark] .app-nav a.active{color:var(--color-cyan);border-bottom-color:var(--color-cyan)}[data-theme=dark] .mobile-user-actions{background:var(--white);border-top-color:var(--border)}[data-theme=dark] .filter-tab{background:var(--white);color:var(--text-light);border-color:var(--border)}[data-theme=dark] .filter-tab:hover{border-color:var(--primary);color:var(--primary)}[data-theme=dark] .role-badge{background:var(--primary);color:#0e0f14}[data-theme=dark] .clickable-row:hover,[data-theme=dark] .stat-card:hover,[data-theme=dark] .test-card:hover,[data-theme=dark] .user-card:hover{background:#24252e}[data-theme=dark] .result-details,[data-theme=dark] .strand-results,[data-theme=dark] .strand-section,[data-theme=dark] .asset-info-section{background:var(--white);border-color:var(--border)}[data-theme=dark] .strand-modal{background:var(--white)}[data-theme=dark] .strand-modal-input{background:var(--bg);color:var(--text);border-color:var(--primary)}[data-theme=dark] .atm-display{background:var(--bg);border-color:var(--primary)}[data-theme=dark] .atm-key{background:var(--white);color:var(--text);border-color:var(--border)}[data-theme=dark] .atm-key:hover{background:#24252e}[data-theme=dark] .confirm-card,[data-theme=dark] .repair-form-card,[data-theme=dark] .repair-wizard-card,[data-theme=dark] .edit-modal-card,[data-theme=dark] .comment-wizard-card,[data-theme=dark] .test-detail-modal,[data-theme=dark] .asset-detail-modal{background:var(--white)}[data-theme=dark] .wizard-step-dot{background:var(--bg);color:var(--text-light);border-color:var(--border)}[data-theme=dark] .wizard-step-dot.wizard-step-active{border-color:var(--primary);color:var(--primary);background:#1c2e32}[data-theme=dark] .wizard-step-dot.wizard-step-completed{border-color:var(--success);color:#fff;background:var(--success)}[data-theme=dark] .comment-panel{background:var(--white)}[data-theme=dark] .comment-panel-ticket-info,[data-theme=dark] .comment-input-area,[data-theme=dark] .ticket-card-actions{background:#14151c}[data-theme=dark] .comment-item{border-color:var(--border)}[data-theme=dark] .empty-state-card{background:var(--white);border-color:var(--border)}[data-theme=dark] .detail-row{border-bottom-color:var(--border)}[data-theme=dark] .tests-table th,[data-theme=dark] .users-table th,[data-theme=dark] .assets-table th{background:#14151c;color:var(--text)}[data-theme=dark] .stats-bar-segment,[data-theme=dark] .btn-danger{color:#fff}[data-theme=dark] .you-badge,[data-theme=dark] .unit-btn.active{color:#0e0f14}[data-theme=dark] .pass-flash,[data-theme=dark] .toast,[data-theme=dark] .offline-banner,[data-theme=dark] .lightbox-close{color:#fff}[data-theme=dark] .filter-tab-active{color:#0e0f14}[data-theme=dark] .tests-table td,[data-theme=dark] .users-table td,[data-theme=dark] .assets-table td{border-bottom-color:var(--border)}[data-theme=dark] .new-asset-notice,[data-theme=dark] .previous-test-popup{background:#24252e;border-color:var(--border)}[data-theme=dark] .help-section,[data-theme=dark] .settings-card,[data-theme=dark] .admin-section,[data-theme=dark] .tech-recent-section,[data-theme=dark] .wizard-card,[data-theme=dark] .wizard-summary,[data-theme=dark] .wizard-option{background:var(--white);border-color:var(--border)}[data-theme=dark] .wizard-option:hover{background:#24252e;border-color:var(--primary)}[data-theme=dark] .wizard-option.selected{background:#1c2e32;border-color:var(--primary)}[data-theme=dark] .ticket-card,[data-theme=dark] .recipient-card,[data-theme=dark] .report-card{background:var(--white);border-color:var(--border)}[data-theme=dark] .btn-scan{background:var(--primary);color:#0e0f14;box-shadow:0 4px 24px #60a6b34d}[data-theme=dark] .btn-scan:hover{box-shadow:0 6px 32px #60a6b366}[data-theme=dark] .reclean-prompt-card{background:var(--white);border-color:var(--border)}[data-theme=dark] .reclean-prompt-message{color:var(--text-light)}[data-theme=dark] .reclean-prompt-instruction{color:var(--text)}[data-theme=dark] .reclean-prompt-attempts{color:var(--primary)}[data-theme=dark] .reclean-attempt-list{background:var(--bg)}[data-theme=dark] .reclean-attempt-item,[data-theme=dark] .reclean-attempt-value{color:var(--text)}[data-theme=dark] .reclean-banner{background:#2a2010;border-color:#b8860b;color:#f0c040}[data-theme=dark] .reclean-banner strong{color:#f0c040}[data-theme=dark] .result-pass{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .result-fail{background:#3d1010;color:#ff6b6b}[data-theme=dark] .result-repair{background:#3d0808;color:#f44}[data-theme=dark] .result-banner-pass{background:#0d3d0d;color:#4cdf4c;border-color:#2a8a2a}[data-theme=dark] .result-banner-fail{background:#3d1010;color:#ff6b6b;border-color:#c44}[data-theme=dark] .result-banner-repair{background:#3d0808;color:#f44;border-color:#a22}[data-theme=dark] .status-pass{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .status-fail{background:#3d1010;color:#ff6b6b}[data-theme=dark] .status-repair{background:#3d0808;color:#f44}[data-theme=dark] .ticket-status-open{background:#3d1010;color:#ff6b6b}[data-theme=dark] .ticket-status-progress{background:#2a2010;color:#f0c040}[data-theme=dark] .ticket-status-resolved,[data-theme=dark] .cleaning-attempt-pass{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .cleaning-attempt-fail{background:#3d1010;color:#ff6b6b}[data-theme=dark] .cleaning-history-inline{padding-left:44px}[data-theme=dark] .stats-bar{background:var(--border)}[data-theme=dark] .stats-bar-pass{background:#2a8a2a}[data-theme=dark] .stats-bar-fail{background:#c44}[data-theme=dark] .stats-bar-repair{background:#a22}[data-theme=dark] .threshold-pass{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .threshold-fail{background:#3d1010;color:#ff6b6b}[data-theme=dark] .threshold-repair{background:#3d0808;color:#f44}[data-theme=dark] .filter-tab-pass.filter-tab-active{background:#2a8a2a;border-color:#2a8a2a;color:#fff}[data-theme=dark] .filter-tab-fail.filter-tab-active{background:#c44;border-color:#c44;color:#fff}[data-theme=dark] .filter-tab-repair.filter-tab-active{background:#a22;border-color:#a22;color:#fff}[data-theme=dark] .strand-result-row.strand-fail{background:#2a1515}[data-theme=dark] .strand-result-row.strand-repair{background:#2a0e0e}[data-theme=dark] .strand-prefilled{background:#152015;border-color:#2a4a2a}[data-theme=dark] .strand-prev-badge{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .strand-row-filled{border-color:var(--border);background:#14151c}[data-theme=dark] .strand-row-tappable:hover{background:#1e1f28}[data-theme=dark] .form-error{background:#3d1010;color:#ff6b6b}[data-theme=dark] .new-asset-notice{color:var(--primary)}[data-theme=dark] .setting-success,[data-theme=dark] .recipient-type-badge.type-all{background:#0d3d0d;color:#4cdf4c}[data-theme=dark] .recipient-type-badge.type-critical{background:#3d1010;color:#ff6b6b}[data-theme=dark] .wizard-strand-bar{background:var(--border)}[data-theme=dark] .atm-value{color:var(--text)}[data-theme=dark] .atm-unit{color:var(--text-light)}[data-theme=dark] .atm-key-action{color:var(--primary)}[data-theme=dark] .atm-key:active{background:#2c2d36}[data-theme=dark] .user-card-current{background:#1c2e32;border-color:var(--primary)}[data-theme=dark] .current-user-row{background:#1c2e32}[data-theme=dark] .current-user-row:hover{background:#24353a}[data-theme=dark] .coming-soon{background:#24252e;color:var(--primary)}[data-theme=dark] .recent-test-item{border-bottom-color:var(--border)}[data-theme=dark] .recent-test-item:hover{background:#24252e}[data-theme=dark] .ticket-card-header,[data-theme=dark] .ticket-card-body,[data-theme=dark] .strand-result-row,[data-theme=dark] .summary-row{border-bottom-color:var(--border)}[data-theme=dark] .color-ref-item{border-color:var(--border)}[data-theme=dark] .comment-source-platform{background:#24252e;color:var(--primary)}[data-theme=dark] .comment-source-email{background:#2a1a3d;color:#b88aff}[data-theme=dark] .attachment-preview-row{background:var(--bg)}[data-theme=dark] .comment-attachment-thumb{background:var(--bg);border-color:var(--border)}[data-theme=dark] .input-disabled{background:var(--bg);color:var(--text-light)}[data-theme=dark] .unit-btn{background:var(--white);color:var(--text)}[data-theme=dark] .unit-btn:not(.active):hover{background:#24252e}[data-theme=dark] .strand-row-tappable:active,[data-theme=dark] .users-table tr:hover,[data-theme=dark] .assets-table tr:hover{background:#24252e}[data-theme=dark] .photo-list-item,[data-theme=dark] .reel-type-card{border-color:var(--border)}[data-theme=dark] .reel-type-card h4{color:var(--primary)}[data-theme=dark] .length-input{background:var(--bg);color:var(--text);border-color:var(--border)}[data-theme=dark] .length-input:focus{border-color:var(--primary);box-shadow:0 0 0 3px #60a6b333}[data-theme=dark] .length-unit-toggle{border-color:var(--border)}[data-theme=dark] .repair-form-card textarea{background:var(--bg);color:var(--text);border-color:var(--border)}[data-theme=dark] .repair-form-card textarea:focus{border-color:var(--primary)}.search-toggle{background:#ffffff26;border:1px solid rgba(255,255,255,.3);width:32px;height:32px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;transition:all .2s;flex-shrink:0;color:#ffffffb3;position:relative;z-index:1}.search-toggle:hover{background:#ffffff40;color:#fff}.search-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:500;display:flex;justify-content:center;padding-top:80px}.search-overlay-content{background:var(--white);border-radius:12px;width:100%;max-width:560px;max-height:70vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 8px 32px #0000004d}.search-overlay-input-wrap{display:flex;align-items:center;gap:10px;padding:16px 20px;border-bottom:1px solid var(--border)}.search-overlay-icon{font-size:18px;flex-shrink:0}.search-overlay-input{flex:1;border:none;outline:none;font-size:16px;background:transparent;color:var(--text)}.search-overlay-input::placeholder{color:var(--text-light)}.search-overlay-close{background:none;border:none;font-size:24px;cursor:pointer;color:var(--text-light);padding:0 4px;line-height:1}.search-overlay-close:hover{color:var(--text)}.search-overlay-results{flex:1;overflow-y:auto;padding:8px 0}.search-overlay-loading,.search-overlay-empty{text-align:center;padding:24px;color:var(--text-light);font-size:14px}.search-result-group{padding:8px 0}.search-result-group-label{font-size:11px;font-weight:700;text-transform:uppercase;color:var(--text-light);padding:4px 20px 6px;letter-spacing:.5px}.search-result-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 20px;background:none;border:none;cursor:pointer;font-size:14px;color:var(--text);text-align:left;transition:background .1s}.search-result-item:hover{background:var(--bg)}.search-result-main{font-weight:600;min-width:80px}.search-result-secondary{color:var(--text-light);font-size:13px}.search-result-notes{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:200px}.dashboard-period-filter{display:flex;gap:4px;justify-content:center;width:100%;max-width:800px}.stat-card-header-row{display:flex;justify-content:space-between;align-items:flex-start}.sparkline-svg{flex-shrink:0;opacity:.8}.pwa-install-banner{position:fixed;bottom:0;left:0;right:0;z-index:600;background:var(--primary);color:#fff;display:flex;align-items:center;justify-content:center;gap:16px;padding:12px 20px;font-size:14px;font-weight:500;box-shadow:0 -2px 12px #00000026}.pwa-install-actions{display:flex;gap:8px}.pwa-install-banner .btn-primary{background:#fff;color:var(--primary)}.pwa-install-banner .btn-outline{background:transparent;color:#fff;border-color:#ffffff80}[data-theme=dark] .search-overlay-content{background:var(--white)}[data-theme=dark] .search-result-item:hover{background:#24252e}[data-theme=dark] .pwa-install-banner{background:var(--primary)}[data-theme=dark] .pwa-install-banner .btn-primary{background:#0e0f14;color:var(--primary)}.users-mobile{display:none}.users-cards{flex-direction:column;gap:8px}.user-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px}.user-card-current{background:#f0f1f5;border-color:var(--primary)}.user-card-name{font-weight:600;font-size:15px;display:flex;align-items:center;gap:8px}.user-card-email{font-size:13px;color:var(--text-light);margin:2px 0 8px}.user-card-bottom{display:flex;align-items:center;gap:12px}.user-card-stats{font-size:13px;color:var(--text-light)}.tests-mobile{display:none}.tests-cards{flex-direction:column;gap:8px}.test-card{background:var(--white);border:1px solid var(--border);border-radius:var(--radius);padding:12px 16px;cursor:pointer;transition:border-color .15s}.test-card:hover{border-color:var(--primary)}.test-card-top{display:flex;justify-content:space-between;align-items:center;margin-bottom:4px}.test-card-asset{font-weight:700;font-size:15px}.test-card-bottom{display:flex;gap:12px;font-size:13px;color:var(--text-light)}@media (max-width: 768px){.app-header-wrap{padding:0;max-width:100%}.app-banner{height:auto;padding:10px 16px;gap:0;border-radius:0}.app-banner:before{border-radius:0}.header-brand{flex:1}.header-logo{height:36px}.header-brand h1{font-size:18px}.banner-actions{display:none}.search-toggle{order:1;margin-left:auto}.hamburger-btn{display:flex;align-items:center;justify-content:center;width:40px;height:40px;background:none;border:none;cursor:pointer;padding:0;flex-shrink:0;position:relative;z-index:1;order:2}.hamburger-btn span,.hamburger-btn span:before,.hamburger-btn span:after{display:block;width:22px;height:2px;background:#fffc;border-radius:1px;transition:transform .2s,opacity .2s;position:relative}.hamburger-btn span:before,.hamburger-btn span:after{content:"";position:absolute;left:0;width:22px}.hamburger-btn span:before{top:-7px}.hamburger-btn span:after{top:7px}.hamburger-open span{background:transparent}.hamburger-open span:before{top:0;transform:rotate(45deg);background:#fffc}.hamburger-open span:after{top:0;transform:rotate(-45deg);background:#fffc}.app-nav{display:none}.app-nav{border-radius:0}.app-nav.nav-open{display:flex;flex-direction:column;padding:8px 0;border-radius:0}.app-nav.nav-open a{padding:10px 16px;border-bottom:none;border-left:3px solid transparent;font-size:15px}.app-nav.nav-open a.active{border-bottom:none;border-left-color:var(--color-cyan);background:#60a6b314}.mobile-user-actions.mobile-user-open{display:flex;align-items:center;gap:10px;padding:10px 16px;border-top:1px solid var(--border);background:var(--white);font-size:14px;color:var(--text);flex-wrap:wrap;border-radius:0}.sticky-controls{top:52px}.app-main{padding:16px}.btn-scan{width:160px;height:160px;font-size:18px}.dashboard-grid{grid-template-columns:1fr}.filter-tabs{flex-wrap:wrap}.ticket-meta{flex-direction:column;gap:4px}.ticket-card-actions{flex-wrap:wrap}.users-desktop{display:none}.users-mobile{display:flex}.recent-test-tech{display:none}.recipient-card{flex-direction:column;align-items:flex-start}.recipient-actions{flex-wrap:wrap}.help-thresholds,.help-reel-types{grid-template-columns:1fr}.color-reference{grid-template-columns:repeat(2,1fr)}.assets-table th:nth-child(n+5),.assets-table td:nth-child(n+5){display:none}.wizard-fullscreen .test-form-header{flex-direction:column;align-items:center;gap:2px;margin-bottom:12px}.wizard-fullscreen .test-form-header h2{font-size:22px}.wizard-fullscreen .test-timer{font-size:18px;opacity:.7}.wizard-actions{flex-direction:column}.wizard-actions .btn{width:100%}.strand-modal{padding:16px 16px 20px}.strand-modal-header{margin-bottom:14px}.strand-modal-color{width:32px;height:32px;border-radius:8px}.strand-modal-title{font-size:17px}.atm-container{gap:10px}.atm-display{padding:10px 16px;min-width:160px}.atm-value{font-size:36px}.atm-unit{font-size:18px}.atm-numpad{max-width:260px;gap:6px}.atm-key{padding:14px;font-size:20px}.atm-actions{max-width:260px;gap:8px}.atm-actions .btn,.strand-modal-actions .btn{padding:12px;font-size:14px}.result-banner{padding:16px;margin-bottom:16px}.result-banner h2{font-size:22px;margin-bottom:4px}.result-banner p{font-size:13px}.test-detail-modal,.asset-detail-modal{max-width:100%;max-height:100vh;border-radius:0}.comment-panel-overlay{align-items:stretch}.comment-panel{max-width:100%;height:100dvh}.comment-thread{min-height:0;-webkit-overflow-scrolling:touch}.comment-input-area{position:sticky;bottom:0;padding:10px 14px;padding-bottom:calc(10px + env(safe-area-inset-bottom,0px))}.comment-input-actions{flex-direction:column;gap:8px;align-items:stretch}.comment-input-actions>div{flex-direction:column;gap:8px;align-items:stretch}.comment-input-actions .btn{width:100%;text-align:center}.comment-hint{display:none}.comment-time{margin-left:0;width:100%}.repair-wizard-card{max-width:100%;border-radius:0;max-height:100vh}.repair-wizard-actions{flex-direction:column}.repair-wizard-actions .btn{width:100%;text-align:center}.tests-desktop{display:none}.tests-mobile{display:flex}.tests-controls{flex-direction:column;align-items:stretch}.search-overlay{padding-top:0}.search-overlay-content{max-width:100%;max-height:100vh;border-radius:0}.ticket-card-header,.ticket-card-body{padding:10px 14px}.ticket-card-actions{padding:10px 14px;flex-direction:column;gap:8px}.ticket-card-actions .btn{width:100%;text-align:center}.dashboard-period-filter{flex-wrap:wrap}}
