.app-shell{height:100vh;display:flex;overflow:hidden}.sidebar{width:var(--sidebar-width);background:var(--color-surface);border-right:1px solid var(--color-border);flex-direction:column;flex-shrink:0;transition:width .25s;display:flex;overflow:hidden;box-shadow:2px 0 8px #0000000a}.app-shell.sidebar-collapsed .sidebar{width:60px}.sidebar-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;min-height:72px;padding:18px 14px 14px;display:flex}.sidebar-logo{object-fit:contain;object-position:left center;height:36px}.sidebar-toggle{color:var(--color-muted);flex-shrink:0}.app-shell.sidebar-collapsed .sidebar-header{justify-content:center;padding:18px 0 14px}.sidebar-nav{flex-direction:column;flex:1;gap:2px;padding:12px 8px;display:flex;overflow-y:auto}.sidebar-link{border-radius:var(--radius-sm);color:var(--color-muted);transition:all var(--transition);white-space:nowrap;align-items:center;gap:10px;padding:10px;font-size:13px;font-weight:500;display:flex;overflow:hidden}.sidebar-link:hover{background:var(--color-surface-2);color:var(--color-text)}.sidebar-link.active{background:var(--gradient-brand-soft);color:var(--color-secondary-dark)}.sidebar-link.active .sidebar-link-icon{color:var(--color-secondary)}.sidebar-link-icon{flex-shrink:0}.sidebar-link-label{text-overflow:ellipsis;overflow:hidden}.app-shell.sidebar-collapsed .sidebar-link{justify-content:center;padding:10px}.sidebar-footer{border-top:1px solid var(--color-border);align-items:center;gap:8px;padding:12px 8px;display:flex}.sidebar-user{flex:1;align-items:center;gap:8px;min-width:0;display:flex;overflow:hidden}.sidebar-avatar{background:var(--gradient-brand);color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:30px;height:30px;display:flex}.sidebar-user-info{flex-direction:column;gap:3px;min-width:0;display:flex;overflow:hidden}.sidebar-user-name{color:var(--color-text);white-space:nowrap;text-overflow:ellipsis;font-size:12px;font-weight:500;overflow:hidden}.sidebar-profile-link{border-radius:var(--radius-sm);min-width:0;transition:background var(--transition);flex:1;align-items:center;gap:8px;padding:4px 6px;text-decoration:none;display:flex;overflow:hidden}.sidebar-profile-link:hover{background:var(--color-surface-2)}.sidebar-profile-link.active{background:var(--gradient-brand-soft)}.sidebar-profile-link.active .sidebar-user-name{color:var(--color-secondary-dark)}.sidebar-logout{color:var(--color-muted);flex-shrink:0}.sidebar-logout:hover{color:var(--color-danger);background:var(--color-danger-light)}.main-content{background:var(--color-bg);flex:1;overflow-y:auto}.page-container{max-width:1400px;padding:32px 36px}.login-page{background:var(--color-bg);justify-content:center;align-items:center;min-height:100vh;display:flex;position:relative;overflow:hidden}.login-bg-decor{pointer-events:none;background:radial-gradient(60% 50% at 80% 10%,#8dc63f1f 0%,#0000 70%),radial-gradient(50% 60% at 10% 90%,#00a8a81a 0%,#0000 70%);position:absolute;inset:0}.login-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-xl);width:100%;max-width:420px;box-shadow:var(--shadow-lg);z-index:1;padding:40px 40px 32px;position:relative}.login-logo-wrap{justify-content:center;margin-bottom:28px;display:flex}.login-logo{object-fit:contain;height:48px}.login-header{text-align:center;margin-bottom:32px}.login-header h1{color:var(--color-text);margin-bottom:6px;font-size:20px}.login-header p{color:var(--color-muted);font-size:13px}.login-form{flex-direction:column;gap:18px;display:flex}.password-wrap{position:relative}.password-input{padding-right:40px}.password-toggle{color:var(--color-muted);transition:color var(--transition);background:0 0;border:none;border-radius:4px;align-items:center;padding:4px;display:flex;position:absolute;top:50%;right:10px;transform:translateY(-50%)}.password-toggle:hover{color:var(--color-text)}.login-error{color:var(--color-danger);background:var(--color-danger-light);border-radius:var(--radius-sm);border:1px solid #e53e3e33;padding:8px 12px;font-size:13px}.login-btn{justify-content:center;width:100%;margin-top:4px;padding:12px;font-size:14px}.login-footer{justify-content:center;margin-top:20px;display:flex}.login-forgot{color:var(--color-secondary);transition:opacity var(--transition);font-size:13px}.login-forgot:hover{opacity:.75}.login-demo-hint{text-align:center;border-top:1px solid var(--color-border);margin-top:16px;padding-top:16px}.modal-overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:1000;background:#00000073;justify-content:center;align-items:center;padding:16px;animation:.2s fadeInOverlay;display:flex;position:fixed;inset:0}.modal-dialog{background:var(--color-surface);border-radius:var(--radius-lg);box-shadow:var(--shadow-modal);flex-direction:column;width:100%;max-height:92vh;display:flex;overflow:hidden}.modal-sm{max-width:420px}.modal-md{max-width:640px}.modal-lg{max-width:900px}.modal-xl{max-width:1100px}.modal-full{max-width:1300px}.modal-header{border-bottom:1px solid var(--color-border);flex-shrink:0;justify-content:space-between;align-items:center;padding:20px 24px 16px;display:flex}.modal-title{color:var(--color-text);font-size:16px;font-weight:600}.modal-close{color:var(--color-muted)}.modal-body{flex:1;padding:24px;overflow-y:auto}.modal-footer{border-top:1px solid var(--color-border);flex-shrink:0;justify-content:flex-end;align-items:center;gap:10px;padding:16px 24px;display:flex}.nyquist-wrap{border-radius:var(--radius-md);border:1px solid var(--color-border);background:#fff;width:100%;overflow:hidden}.nyquist-hint{color:var(--color-muted);text-align:center;border-top:1px dashed var(--color-border);padding:6px 12px 10px;font-size:12px}.metrics-row{grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:20px;display:grid}.metric-card{background:var(--gradient-brand-soft);border-radius:var(--radius-md);border:1px solid #00a8a826;flex-direction:column;gap:4px;padding:14px 16px;display:flex}.metric-label{text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);font-size:11px;font-weight:600}.metric-value{color:var(--color-text);font-size:22px;font-weight:700;line-height:1}.metric-unit{color:var(--color-secondary-dark);font-size:12px;font-weight:500}.chart-toolbar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:14px;display:flex}.toggle-group{border:1px solid var(--color-border);border-radius:var(--radius-sm);display:flex;overflow:hidden}.toggle-btn{color:var(--color-muted);background:var(--color-surface);border:none;border-right:1px solid var(--color-border);cursor:pointer;transition:all var(--transition);white-space:nowrap;align-items:center;gap:6px;padding:6px 12px;font-size:12px;font-weight:500;display:flex}.toggle-btn:last-child{border-right:none}.toggle-btn:hover{background:var(--color-surface-2);color:var(--color-text)}.toggle-btn.active{background:var(--gradient-brand-soft);color:var(--color-secondary-dark);font-weight:600}.raw-table-wrap{max-height:380px;overflow-y:auto}.obs-section{margin-top:8px}.obs-history{flex-direction:column;gap:10px;margin-top:14px;display:flex}.obs-item{background:var(--color-surface-2);border-left:3px solid var(--color-secondary);border-radius:0 var(--radius-sm) var(--radius-sm) 0;padding:10px 14px}.obs-text{color:var(--color-text);font-size:13px;line-height:1.5}.obs-meta{color:var(--color-muted);margin-top:5px;font-size:11px}@media (width<=680px){.metrics-row{grid-template-columns:repeat(2,1fr)}}.compare-table-wrap{overflow-x:auto}.compare-legend-dot{vertical-align:middle;border-radius:50%;width:12px;height:12px;margin-right:6px;display:inline-block}.compare-color-picker{appearance:none;cursor:pointer;vertical-align:middle;background-color:#0000;border:none;border-radius:50%;width:14px;height:14px;margin-right:6px;padding:0}.compare-color-picker::-webkit-color-swatch{border:1px solid #0000001a;border-radius:50%}.compare-color-picker::-moz-color-swatch{border:1px solid #0000001a;border-radius:50%}.compare-metric-name{color:var(--color-text-light);white-space:nowrap;background:var(--color-surface-2);font-weight:600}.upload-dropzone{border:2px dashed var(--color-border-strong);border-radius:var(--radius-md);text-align:center;cursor:pointer;transition:all var(--transition);background:var(--color-surface-2);flex-direction:column;align-items:center;gap:10px;padding:36px 24px;display:flex}.upload-dropzone:hover,.upload-dropzone.dragging{border-color:var(--color-secondary);background:#00a8a80d}.upload-dropzone.success{border-color:var(--color-success);background:#38a1690d}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:20px;display:flex}.filters-bar{flex-wrap:wrap;align-items:center;gap:10px;padding:14px 20px;display:flex}.filter-field{flex:1;align-items:center;gap:6px;min-width:160px;display:flex}.filter-input{padding:7px 10px;font-size:13px}:root{--color-primary:#8dc63f;--color-primary-dark:#72a32e;--color-secondary:#00a8a8;--color-secondary-dark:#007f7f;--color-accent:#1b7a6e;--color-bg:#f8f9fa;--color-surface:#fff;--color-surface-2:#f1f5f9;--color-text:#2d3748;--color-text-light:#4a5568;--color-muted:#718096;--color-placeholder:#a0aec0;--color-border:#e2e8f0;--color-border-strong:#cbd5e0;--color-success:#38a169;--color-warning:#d69e2e;--color-danger:#e53e3e;--color-danger-light:#fff5f5;--color-info:#3182ce;--gradient-brand:linear-gradient(135deg, #8dc63f 0%, #00a8a8 100%);--gradient-brand-soft:linear-gradient(135deg, #8dc63f1f 0%, #00a8a81f 100%);--shadow-sm:0 1px 3px #00000014, 0 1px 2px #0000000a;--shadow-md:0 4px 12px #0000001a, 0 2px 4px #0000000f;--shadow-lg:0 10px 32px #0000001f, 0 4px 8px #0000000f;--shadow-modal:0 20px 60px #0000002e;--space-1:4px;--space-2:8px;--space-3:12px;--space-4:16px;--space-5:20px;--space-6:24px;--space-8:32px;--space-10:40px;--space-12:48px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--radius-xl:24px;--radius-full:9999px;--sidebar-width:240px;--transition:.2s ease}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%;color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,sans-serif;font-size:14px}img{max-width:100%;display:block}button{cursor:pointer;font-family:inherit}input,textarea,select{font-family:inherit}a{color:inherit;text-decoration:none}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:var(--color-border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--color-muted)}h1{font-size:24px;font-weight:700;line-height:1.3}h2{font-size:20px;font-weight:600;line-height:1.35}h3{font-size:16px;font-weight:600;line-height:1.4}h4{font-size:14px;font-weight:600;line-height:1.4}p{line-height:1.6}.text-sm{font-size:12px}.text-base{font-size:14px}.text-lg{font-size:16px}.text-muted{color:var(--color-muted)}.text-danger{color:var(--color-danger)}.text-success{color:var(--color-success)}.font-medium{font-weight:500}.font-semibold{font-weight:600}.btn{align-items:center;gap:var(--space-2);border-radius:var(--radius-sm);transition:all var(--transition);white-space:nowrap;border:none;padding:8px 16px;font-size:13px;font-weight:500;line-height:1;display:inline-flex}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--gradient-brand);color:#fff;box-shadow:0 2px 8px #8dc63f4d}.btn-primary:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 14px #8dc63f66}.btn-secondary{background:var(--color-surface);color:var(--color-text);border:1px solid var(--color-border)}.btn-secondary:hover:not(:disabled){background:var(--color-surface-2);border-color:var(--color-border-strong)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover:not(:disabled){background:#c53030;transform:translateY(-1px)}.btn-ghost{color:var(--color-muted);background:0 0;border:1px solid #0000;padding:6px 10px}.btn-ghost:hover:not(:disabled){background:var(--color-surface-2);color:var(--color-text)}.btn-icon{border-radius:var(--radius-sm);padding:7px}.btn-sm{padding:5px 12px;font-size:12px}.btn-lg{padding:12px 24px;font-size:15px}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-md);box-shadow:var(--shadow-sm)}.card-padding{padding:var(--space-6)}.form-group{gap:var(--space-1);flex-direction:column;display:flex}.form-label{color:var(--color-text-light);text-transform:uppercase;letter-spacing:.04em;font-size:12px;font-weight:500}.form-input,.form-select,.form-textarea{border:1px solid var(--color-border);border-radius:var(--radius-sm);width:100%;color:var(--color-text);background:var(--color-surface);transition:border-color var(--transition), box-shadow var(--transition);outline:none;padding:9px 12px;font-size:14px}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--color-secondary);box-shadow:0 0 0 3px #00a8a81f}.form-input::placeholder,.form-textarea::placeholder{color:var(--color-placeholder)}.form-textarea{resize:vertical;min-height:80px}.data-table-wrapper{border-radius:var(--radius-md);border:1px solid var(--color-border);overflow-x:auto}.data-table{border-collapse:collapse;width:100%;font-size:13px}.data-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.06em;color:var(--color-muted);background:var(--color-surface-2);border-bottom:1px solid var(--color-border);white-space:nowrap;padding:10px 14px;font-size:11px;font-weight:600}.data-table tbody tr{border-bottom:1px solid var(--color-border);transition:background var(--transition)}.data-table tbody tr:last-child{border-bottom:none}.data-table tbody tr:hover{background:var(--color-surface-2)}.data-table tbody tr.selected{background:#00a8a80f}.data-table tbody td{color:var(--color-text);padding:11px 14px}.badge{border-radius:var(--radius-full);letter-spacing:.03em;align-items:center;padding:2px 9px;font-size:11px;font-weight:600;display:inline-flex}.badge-primary{color:var(--color-primary-dark);background:#8dc63f26}.badge-secondary{color:var(--color-secondary-dark);background:#00a8a81f}.badge-admin{color:var(--color-accent);background:#1b7a6e1f}.badge-danger{color:var(--color-danger);background:#e53e3e1a}.badge-success{color:#276749;background:#38a1691f}.divider{background:var(--color-border);height:1px;margin:var(--space-6) 0}.empty-state{justify-content:center;align-items:center;gap:var(--space-4);padding:var(--space-12);color:var(--color-muted);text-align:center;flex-direction:column;display:flex}.empty-state svg{opacity:.35}.empty-state h3{color:var(--color-text-light)}.checkbox{width:16px;height:16px;accent-color:var(--color-secondary);cursor:pointer}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.fade-in{animation:.25s fadeIn}.slide-up{animation:.3s slideUp}.flex{display:flex}.flex-col{flex-direction:column;display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.justify-end{justify-content:flex-end}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.w-full{width:100%}.mt-2{margin-top:var(--space-2)}.mt-4{margin-top:var(--space-4)}.mt-6{margin-top:var(--space-6)}.mb-4{margin-bottom:var(--space-4)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.truncate{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}
