.login-page{display:flex;justify-content:center;align-items:center;min-height:100vh;background-color:#0f0518;background-image:radial-gradient(circle,rgba(139,92,246,.08) 1px,transparent 1px);background-size:24px 24px;padding:1rem}.login-card{background:#1a0a2ee6;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(139,92,246,.25);border-radius:16px;padding:2.5rem;max-width:420px;width:100%;box-shadow:0 25px 50px -12px #0009}.login-header{text-align:center;margin-bottom:2rem}.login-logo{margin-bottom:1rem}.login-logo-icon{width:80px;height:80px}.login-title{font-size:1.5rem;font-weight:700;color:var(--color-text, #f1f5f9);margin:0;letter-spacing:-.025em}.login-content{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.login-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.form-group label{font-size:.875rem;font-weight:500;color:var(--color-text-muted, #94a3b8)}.form-group input{width:100%;padding:.75rem 1rem;background:#0f051899;border:1px solid rgba(139,92,246,.3);border-radius:8px;font-size:1rem;color:var(--color-text, #f1f5f9);transition:all .2s ease}.form-group input::placeholder{color:var(--color-text-muted, #64748b)}.form-group input:focus{outline:none;border-color:var(--color-primary, #8b5cf6);box-shadow:0 0 0 3px #8b5cf633}.form-group input:disabled{opacity:.6;cursor:not-allowed}.login-submit-btn{width:100%;padding:.875rem 1.25rem;background:linear-gradient(135deg,#8b5cf6,#7c3aed);border:none;border-radius:8px;font-size:1rem;font-weight:600;color:#fff;cursor:pointer;transition:all .2s ease;margin-top:.5rem}.login-submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#9d74f7,#8b5cf6);box-shadow:0 4px 12px #8b5cf666;transform:translateY(-1px)}.login-submit-btn:active:not(:disabled){transform:translateY(0)}.login-submit-btn:disabled{opacity:.7;cursor:not-allowed}.login-error{padding:.75rem 1rem;background:#ef444426;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#fca5a5;font-size:.875rem}.login-subtitle{font-size:.9375rem;color:var(--color-text-muted, #94a3b8);margin:0 0 .5rem;text-align:center}.password-requirements{font-size:.75rem;color:var(--color-text-muted, #64748b);margin:.5rem 0 0;text-align:center}.google-login-btn{display:flex;align-items:center;justify-content:center;gap:.75rem;width:100%;padding:.875rem 1.25rem;background:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;color:#1f2937;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #0003}.google-login-btn:hover:not(:disabled){background:#f8fafc;box-shadow:0 4px 12px #00000026;transform:translateY(-1px)}.google-login-btn:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 3px #0003}.google-login-btn:disabled{opacity:.7;cursor:not-allowed}.google-icon{width:20px;height:20px;flex-shrink:0}.bypass-login-btn{width:100%;padding:.75rem 1.25rem;background:transparent;border:1px dashed var(--color-border, #475569);border-radius:8px;font-size:.875rem;color:var(--color-text-muted, #94a3b8);cursor:pointer;transition:all .2s ease}.bypass-login-btn:hover:not(:disabled){background:var(--color-primary-muted, rgba(59, 130, 246, .1));border-color:var(--color-primary, #3b82f6);color:var(--color-primary, #3b82f6)}.bypass-login-btn:disabled{opacity:.5;cursor:not-allowed}.login-footer{text-align:center;padding-top:1rem;border-top:1px solid var(--color-border, #334155)}.login-footer p{font-size:.8125rem;color:var(--color-text-muted, #64748b);margin:0}@media(max-width:480px){.login-card{padding:1.5rem}.login-logo-icon{width:64px;height:64px}.login-title{font-size:1.25rem}}.aso-database-view{flex:1;display:flex;flex-direction:column;background:var(--color-bg);color:var(--color-text);min-height:0;overflow:hidden}.aso-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--color-text-muted)}.aso-empty-state h2{color:var(--color-text);margin-bottom:.5rem}.aso-content{flex:1;display:flex;gap:1rem;padding:1rem;min-height:0;overflow:hidden}.aso-list-panel{width:400px;flex-shrink:0;overflow-y:auto;background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);padding:1rem}.aso-list{display:flex;flex-direction:column;gap:.75rem}.aso-card{padding:1rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.aso-card:hover{border-color:var(--color-primary);background:var(--color-sidebar-hover)}.aso-card.selected{border-color:var(--color-primary);background:var(--color-sidebar-hover);box-shadow:0 0 0 1px var(--color-primary)}.aso-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.5rem}.aso-id-badge{padding:.125rem .5rem;background:var(--color-border);color:var(--color-primary);border-radius:.25rem;font-size:.75rem;font-family:monospace;font-weight:600}.aso-validated-badge{padding:.125rem .5rem;border-radius:.25rem;font-size:.625rem;font-weight:600}.aso-validated-badge.validated{background:#22c55e26;color:var(--color-success)}.aso-validated-badge.pending{background:#f59e0b26;color:var(--color-warning)}.aso-name{margin:0 0 .75rem;font-size:1rem;color:var(--color-text)}.aso-card-details{display:flex;flex-direction:column;gap:.5rem;font-size:.75rem}.aso-detail-row{display:flex;gap:.5rem;align-items:baseline}.aso-detail-row .label{color:var(--color-text-muted);flex-shrink:0}.aso-detail-row .sequence{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;color:var(--color-text);font-size:.7rem;word-break:break-all}.mechanism-badge{padding:.125rem .375rem;background:#8b5cf626;color:var(--color-primary);border-radius:.25rem;font-size:.625rem;border:1px solid rgba(139,92,246,.3)}.design-text{color:var(--color-text);font-size:.7rem}.aso-detail-panel{flex:1;background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);overflow-y:auto;min-width:0}.aso-detail-placeholder{display:flex;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted)}.aso-detail-content{padding:1.5rem}.detail-section{margin-bottom:1.5rem}.detail-section h2{margin:0 0 .5rem;font-size:1.5rem;color:var(--color-text)}.detail-section h3{margin:0 0 1rem;font-size:1rem;color:var(--color-text);border-bottom:1px solid var(--color-border);padding-bottom:.5rem;text-transform:uppercase;font-size:.6875rem;letter-spacing:.08em;font-weight:600;color:var(--color-text-muted)}.detail-meta{display:flex;gap:.5rem;font-size:.875rem;color:var(--color-text-muted)}.sequence-display{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:1rem;overflow-x:auto}.nucleotide-row{display:flex;gap:.25rem}.nucleotide-cell{display:flex;flex-direction:column;align-items:center;gap:.25rem}.nucleotide{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:1rem;font-weight:700;color:#c4b5fd;background:var(--color-input-bg);padding:.25rem .5rem;border-radius:.25rem;min-width:2rem;text-align:center;border:1px solid rgba(139,92,246,.3)}.sugar-mod{font-size:.625rem;color:var(--color-text-muted);background:var(--color-border);padding:.125rem .25rem;border-radius:.125rem;min-width:2rem;text-align:center;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace}.backbone-link{font-size:.5rem;color:var(--color-text-muted);font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace}.detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;background:var(--color-bg);padding:1rem;border-radius:8px;border:1px solid var(--color-border)}.detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-item span:not(.detail-label){color:var(--color-text)}.detail-label{font-size:.625rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.notes-text{color:var(--color-text);line-height:1.6;margin:0}.efficacy-table{overflow-x:auto;background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px}.efficacy-table table{width:100%;border-collapse:collapse;font-size:.875rem}.efficacy-table th{text-align:left;padding:.75rem;background:var(--color-input-bg);color:var(--color-text-muted);font-weight:600;border-bottom:1px solid var(--color-border);white-space:nowrap;text-transform:uppercase;font-size:.6875rem;letter-spacing:.05em}.efficacy-table td{padding:.75rem;border-bottom:1px solid var(--color-border);color:var(--color-text)}.efficacy-table tbody tr:hover{background:var(--color-sidebar-hover)}.view-mode-toggle{display:flex;background:var(--color-input-bg);border-radius:6px;padding:2px;gap:2px}.view-toggle-btn{padding:.375rem .5rem!important;background:transparent!important;border:none!important;color:var(--color-text-muted)!important;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.view-toggle-btn:hover{color:var(--color-text)!important}.view-toggle-btn.active{background:var(--color-primary)!important;color:#fff!important;border-radius:4px}.aso-content.table-mode{flex-direction:column;gap:0}.aso-content.table-mode .aso-detail-panel{height:40%;min-height:200px;max-height:50%;flex-shrink:0}.aso-table-panel{flex:1;background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);overflow:hidden;display:flex;flex-direction:column}.aso-database-table-wrapper{flex:1;overflow:auto}.aso-database-table{width:100%;border-collapse:collapse;font-size:.8125rem;table-layout:fixed}.aso-database-table thead{position:sticky;top:0;z-index:10}.aso-database-table th{text-align:left;padding:.75rem 1rem;background:var(--color-input-bg);color:var(--color-text-muted);font-weight:500;font-size:.6875rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);white-space:nowrap;-webkit-user-select:none;user-select:none}.aso-database-table th.sortable{cursor:pointer;transition:all .15s ease}.aso-database-table th.sortable:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.aso-database-table th.sorted{color:var(--color-primary);background:var(--color-sidebar-hover)}.aso-database-table td{padding:.625rem 1rem;border-bottom:1px solid var(--color-border);color:var(--color-text);vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.aso-database-table tbody tr{cursor:pointer;transition:background .1s ease}.aso-database-table tbody tr:hover{background:var(--color-sidebar-hover)}.aso-database-table tbody tr.selected,.aso-database-table tbody tr.selected:hover{background:var(--color-primary-muted)}.aso-database-table th:nth-child(1),.aso-database-table td.cell-id{width:80px}.aso-database-table th:nth-child(2),.aso-database-table td.cell-name{width:150px;font-weight:500}.aso-database-table th:nth-child(3),.aso-database-table td.cell-sequence{width:180px}.aso-database-table th:nth-child(4),.aso-database-table td.cell-target{width:130px}.aso-database-table th:nth-child(5),.aso-database-table td.cell-mechanism{width:110px}.aso-database-table th:nth-child(6),.aso-database-table td.cell-efficacy{width:90px}.aso-database-table th:nth-child(7),.aso-database-table td.cell-status{width:90px}.aso-database-table th:nth-child(8),.aso-database-table td.cell-date{width:100px;color:var(--color-text-secondary)}.sequence-truncated{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.7rem;color:var(--color-text);letter-spacing:.02em}.efficacy-value{display:flex;align-items:center;gap:.25rem;font-weight:500;color:var(--color-success)}.efficacy-value .exp-count{font-size:.625rem;font-weight:400;color:var(--color-text-muted)}.no-data{color:var(--color-text-muted)}.status-badge{display:inline-block;padding:.125rem .5rem;border-radius:9999px;font-size:.625rem;font-weight:500}.status-badge.validated{background:#22c55e26;color:var(--color-success)}.status-badge.pending{background:#f59e0b26;color:var(--color-warning)}.aso-database-table tbody tr.editing,.aso-database-table tbody tr.editing:hover{background:var(--color-primary-muted)}.inline-edit-input{width:100%;padding:.375rem .5rem;background:var(--color-bg);border:1px solid var(--color-primary);border-radius:4px;color:var(--color-text);font-size:.8125rem;outline:none;box-sizing:border-box}.inline-edit-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #8b5cf633}.inline-edit-input.mono{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.75rem;letter-spacing:.02em}.inline-edit-input::placeholder{color:var(--color-text-muted)}.inline-edit-select{width:100%;padding:.375rem .5rem;background:var(--color-bg);border:1px solid var(--color-primary);border-radius:4px;color:var(--color-text);font-size:.75rem;outline:none;cursor:pointer}.inline-edit-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #8b5cf633}.status-toggle-btn{padding:.125rem .5rem;border-radius:9999px;font-size:.625rem;font-weight:500;border:none;cursor:pointer;transition:all .15s ease}.status-toggle-btn.validated{background:#22c55e26;color:var(--color-success)}.status-toggle-btn.validated:hover{background:#22c55e40}.status-toggle-btn.pending{background:#f59e0b26;color:var(--color-warning)}.status-toggle-btn.pending:hover{background:#f59e0b40}.cell-actions{width:40px!important;text-align:center}.inline-actions{display:flex;gap:.25rem;justify-content:flex-end}.inline-save-btn,.inline-cancel-btn{width:24px;height:24px;border-radius:4px;border:none;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease}.inline-save-btn{background:var(--color-success);color:#fff}.inline-save-btn:hover:not(:disabled){background:#16a34a}.inline-save-btn:disabled{opacity:.5;cursor:not-allowed}.inline-cancel-btn{background:var(--color-text-muted);color:#fff}.inline-cancel-btn:hover:not(:disabled){background:var(--color-danger)}.inline-delete-btn{width:24px;height:24px;border-radius:4px;border:none;cursor:pointer;font-size:.75rem;display:flex;align-items:center;justify-content:center;transition:all .15s ease;background:transparent;color:var(--color-text-muted);opacity:0}.aso-database-table tbody tr:hover .inline-delete-btn{opacity:1}.inline-delete-btn:hover:not(:disabled){background:#ef444426;color:var(--color-danger)}.inline-delete-btn:disabled{opacity:.3;cursor:not-allowed}.cell-actions-header{width:40px}.btn-delete{color:var(--color-text-muted)!important}.btn-delete:hover:not(:disabled){background:#ef444426!important;color:var(--color-danger)!important}.add-row-placeholder{cursor:pointer;transition:background .15s ease}.add-row-placeholder:hover{background:var(--color-sidebar-hover)}.add-row-cell{text-align:center;color:var(--color-text-muted);font-size:.75rem;font-style:italic;padding:1rem!important;border-bottom:none!important}.add-row-cell:hover{color:var(--color-primary)}.new-row .aso-id-badge.new{background:var(--color-primary);color:#fff}.paste-message{position:absolute;bottom:1rem;left:50%;transform:translate(-50%);padding:.75rem 1rem;border-radius:8px;font-size:.8125rem;display:flex;align-items:center;gap:.75rem;box-shadow:var(--shadow-card);animation:slideUp .2s ease;z-index:100}.paste-message.success{background:#22c55ee6;color:#fff}.paste-message.error{background:#ef4444e6;color:#fff}.paste-message button{background:transparent;border:none;color:inherit;cursor:pointer;padding:.25rem;font-size:.875rem;opacity:.8;transition:opacity .15s ease}.paste-message button:hover{opacity:1}@keyframes slideUp{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.aso-table-panel{position:relative}.aso-list-panel::-webkit-scrollbar,.aso-detail-panel::-webkit-scrollbar,.sequence-display::-webkit-scrollbar,.efficacy-table::-webkit-scrollbar,.aso-database-table-wrapper::-webkit-scrollbar{width:8px;height:8px}.aso-list-panel::-webkit-scrollbar-track,.aso-detail-panel::-webkit-scrollbar-track,.sequence-display::-webkit-scrollbar-track,.efficacy-table::-webkit-scrollbar-track,.aso-database-table-wrapper::-webkit-scrollbar-track{background:var(--color-scrollbar-track);border-radius:4px}.aso-list-panel::-webkit-scrollbar-thumb,.aso-detail-panel::-webkit-scrollbar-thumb,.sequence-display::-webkit-scrollbar-thumb,.efficacy-table::-webkit-scrollbar-thumb,.aso-database-table-wrapper::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:4px;transition:background .2s ease}.aso-list-panel::-webkit-scrollbar-thumb:hover,.aso-detail-panel::-webkit-scrollbar-thumb:hover,.sequence-display::-webkit-scrollbar-thumb:hover,.efficacy-table::-webkit-scrollbar-thumb:hover,.aso-database-table-wrapper::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.experiments-list{display:flex;flex-direction:column;gap:.75rem}.experiment-item{padding:.875rem;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:8px;transition:all .2s}.experiment-item:hover{background:var(--color-sidebar-hover);border-color:var(--color-primary);transform:translate(2px)}.experiment-info{display:flex;align-items:center;gap:.75rem;margin-bottom:.5rem}.experiment-name{font-weight:500;color:var(--color-text);flex:1}.experiment-meta{display:flex;align-items:center;gap:1rem;font-size:.8125rem;color:var(--color-text-muted)}.experiment-date{display:inline-block}.experiment-notes{display:inline-block;max-width:300px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.status-badge.status-planned{background:#fbbf2426;color:#f59e0b;border:1px solid rgba(251,191,36,.3)}.status-badge.status-in-progress{background:#3b82f626;color:#3b82f6;border:1px solid rgba(59,130,246,.3)}.status-badge.status-completed{background:#22c55e26;color:#22c55e;border:1px solid rgba(34,197,94,.3)}.modal-overlay{position:fixed;inset:0;background:#000000bf;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .2s ease-out}.modal-content{background:var(--color-bg-elevated);border-radius:16px;box-shadow:0 20px 60px #0000004d;max-width:1200px;max-height:90vh;width:100%;display:flex;flex-direction:column;overflow:hidden;animation:slideUp .3s ease-out;border:1px solid var(--color-border)}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.modal-header{display:flex;justify-content:space-between;align-items:flex-start;padding:1.5rem 2rem;border-bottom:1px solid var(--color-border);background:var(--color-bg);gap:1rem}.modal-title-section{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.file-icon-large{font-size:2rem;flex-shrink:0}.modal-title-info{flex:1;min-width:0}.modal-title{margin:0;font-size:1.25rem;color:var(--color-text);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.modal-meta{display:flex;align-items:center;gap:.5rem;margin-top:.5rem;font-size:.875rem;color:var(--color-text-muted);flex-wrap:wrap}.meta-item{display:inline-block}.meta-separator{color:var(--color-border)}.modal-close-btn{background:transparent;border:none;font-size:1.5rem;color:var(--color-text-muted);cursor:pointer;padding:.5rem;line-height:1;border-radius:8px;transition:all .2s;flex-shrink:0}.modal-close-btn:hover{background:var(--color-danger);color:#fff}.modal-body{flex:1;overflow:auto;background:var(--color-bg);min-height:0}.preview-container{width:100%;height:100%;min-height:500px;display:flex;align-items:center;justify-content:center}.pdf-preview{width:100%;height:70vh;min-height:500px;border:none;background:#fff}.image-container{padding:2rem;background:var(--color-bg)}.image-preview{max-width:100%;max-height:70vh;height:auto;border-radius:8px;box-shadow:0 4px 12px #0000001a;object-fit:contain}.text-preview-notice{text-align:center;padding:3rem 2rem;max-width:500px}.notice-icon{font-size:4rem;margin-bottom:1rem}.text-preview-notice p{margin:.5rem 0;color:var(--color-text);font-size:1.125rem}.notice-hint{font-size:.875rem!important;color:var(--color-text-muted)!important;margin-top:1rem!important;line-height:1.5}.unsupported-preview{text-align:center;padding:3rem 2rem;color:var(--color-text-muted);max-width:500px}.unsupported-icon{font-size:5rem;margin-bottom:1.5rem;opacity:.7}.unsupported-preview h3{margin:0 0 1rem;font-size:1.5rem;color:var(--color-text)}.file-type-info{margin:1rem 0;font-size:.875rem}.file-type-info code{background:var(--color-input-bg);padding:.25rem .5rem;border-radius:4px;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.875rem;color:var(--color-primary)}.preview-hint{margin:1rem 0 2rem;line-height:1.6;color:var(--color-text-muted)}.download-btn-inline{display:inline-block;padding:.75rem 1.5rem;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:all .2s;margin-top:1rem}.download-btn-inline:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 12px #0003}.download-btn-large{display:inline-block;padding:1rem 2rem;background:var(--color-primary);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;font-size:1rem;transition:all .2s;margin-top:1.5rem}.download-btn-large:hover{opacity:.9;transform:translateY(-2px);box-shadow:0 6px 16px #0000004d}.modal-footer{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;border-top:1px solid var(--color-border);background:var(--color-bg);gap:1rem;flex-wrap:wrap}.footer-info{display:flex;align-items:center;gap:1rem;flex:1;min-width:0}.file-description{margin:0;font-size:.875rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.file-description strong{color:var(--color-text)}.file-category-badge{display:inline-block;padding:.25rem .75rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:12px;font-size:.75rem;font-weight:500;color:var(--color-text);white-space:nowrap}.footer-actions{display:flex;gap:.75rem;align-items:center}.btn-download{padding:.625rem 1.25rem;background:var(--color-primary);color:#fff;text-decoration:none;border:none;border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:.5rem}.btn-download:hover{opacity:.9}.btn-close-footer{padding:.625rem 1.25rem;background:var(--color-input-bg);color:var(--color-text);border:1px solid var(--color-border);border-radius:8px;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.btn-close-footer:hover{background:var(--color-sidebar-hover)}.modal-body::-webkit-scrollbar{width:8px;height:8px}.modal-body::-webkit-scrollbar-track{background:var(--color-scrollbar-track);border-radius:4px}.modal-body::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:4px;transition:background .2s ease}.modal-body::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}@media(max-width:768px){.modal-overlay{padding:1rem}.modal-content{max-height:95vh}.modal-header{padding:1rem}.modal-title{font-size:1rem}.modal-footer{padding:1rem;flex-direction:column;align-items:stretch}.footer-info{flex-direction:column;align-items:flex-start}.footer-actions{width:100%}.btn-download,.btn-close-footer{flex:1}.pdf-preview{height:60vh;min-height:400px}.image-container{padding:1rem}.image-preview{max-height:60vh}}.experiment-tracker-view{flex:1;display:flex;flex-direction:column;background:var(--color-bg);color:var(--color-text);min-height:0;overflow:hidden}.loading-state,.error-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:var(--color-text-muted)}.experiment-header{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.5rem;background:var(--color-bg-elevated);border-bottom:1px solid var(--color-border)}.header-left{display:flex;align-items:center;gap:1rem}.header-left h2{margin:0;font-size:1.25rem;color:var(--color-text)}.experiment-count{font-size:.875rem;color:var(--color-text-muted)}.header-controls{display:flex;gap:.75rem;align-items:center}.search-input{min-width:250px}.primary-btn{background:var(--color-primary)!important;color:#fff!important;border:none!important}.primary-btn:hover{opacity:.9}.danger-btn{background:var(--color-danger)!important;color:#fff!important;border:none!important}.danger-btn:hover{opacity:.9}.experiment-content{flex:1;display:flex;gap:1rem;padding:1rem;min-height:0;overflow:hidden}.experiment-list-panel{width:400px;flex-shrink:0;overflow-y:auto;background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);padding:1rem}.experiment-list{display:flex;flex-direction:column;gap:.75rem}.empty-list{text-align:center;padding:2rem;color:var(--color-text-muted)}.empty-list .hint{font-size:.875rem;margin-top:.5rem}.experiment-card{padding:1rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .2s}.experiment-card:hover{border-color:var(--color-primary);background:var(--color-sidebar-hover)}.experiment-card.selected{border-color:var(--color-primary);background:var(--color-sidebar-hover);box-shadow:0 0 0 1px var(--color-primary)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:.5rem;gap:.5rem}.experiment-name{margin:0;font-size:1rem;color:var(--color-text);flex:1}.experiment-description{margin:.5rem 0;font-size:.875rem;color:var(--color-text-muted);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.card-footer{display:flex;justify-content:space-between;align-items:center;margin-top:.75rem;padding-top:.75rem;border-top:1px solid var(--color-border)}.card-meta{display:flex;gap:1rem}.meta-item,.experiment-date{font-size:.75rem;color:var(--color-text-muted)}.status-badge{display:inline-block;padding:.25rem .75rem;border-radius:12px;font-size:.75rem;font-weight:500;white-space:nowrap}.status-badge.status-planned{background:#f59e0b26;color:var(--color-warning)}.status-badge.status-in-progress{background:#3b82f626;color:#3b82f6}.status-badge.status-completed{background:#22c55e26;color:var(--color-success)}.experiment-detail-panel{flex:1;background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);overflow-y:auto;min-width:0}.detail-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;color:var(--color-text-muted);gap:.5rem}.detail-placeholder .hint{font-size:.875rem}.detail-content{padding:1.5rem}.detail-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--color-border)}.header-title{display:flex;align-items:center;gap:1rem;flex:1}.header-title h2{margin:0;font-size:1.5rem;color:var(--color-text)}.header-actions{display:flex;gap:.5rem}.detail-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--color-border)}.tab-btn{padding:.75rem 1.25rem;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--color-text-muted);font-size:.875rem;font-weight:500;cursor:pointer;transition:all .2s}.tab-btn:hover{color:var(--color-text);background:var(--color-sidebar-hover)}.tab-btn.active{color:var(--color-primary);border-bottom-color:var(--color-primary)}.tab-content{min-height:400px}.overview-tab{display:flex;flex-direction:column;gap:1.5rem}.info-section{margin-bottom:1.5rem}.info-section h3{margin:0 0 .75rem;font-size:.875rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-weight:600}.info-section p{margin:0;line-height:1.6;color:var(--color-text)}.objectives-text{white-space:pre-wrap}.info-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;background:var(--color-bg);padding:1.5rem;border-radius:8px;border:1px solid var(--color-border)}.info-item{display:flex;flex-direction:column;gap:.5rem}.info-label{font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);font-weight:600}.form-section{margin-bottom:1.25rem}.form-label{display:block;margin-bottom:.5rem;font-size:.875rem;font-weight:500;color:var(--color-text)}.form-label .required{color:var(--color-danger)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:1rem}.asos-tab{display:flex;flex-direction:column;gap:1.5rem}.aso-selection{padding:1rem;background:var(--color-bg);border-radius:8px;border:1px solid var(--color-border)}.aso-chips{display:flex;flex-direction:column;gap:.75rem}.aso-chip{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:1rem;transition:all .2s}.aso-chip:hover{border-color:var(--color-primary);background:var(--color-sidebar-hover)}.chip-content{display:flex;justify-content:space-between;align-items:center;gap:1rem}.chip-label{font-weight:500;color:var(--color-text)}.chip-label:hover{color:var(--color-primary);text-decoration:underline}.chip-remove{background:var(--color-danger);color:#fff;border:none;border-radius:50%;width:24px;height:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:1.25rem;line-height:1;transition:opacity .2s}.chip-remove:hover{opacity:.8}.chip-sequence{margin-top:.5rem;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.75rem;color:var(--color-text-muted);word-break:break-all}.files-tab{display:flex;flex-direction:column;gap:1.5rem}.file-upload-zone{border:2px dashed var(--color-border);border-radius:8px;padding:2rem;text-align:center;cursor:pointer;transition:all .2s;background:var(--color-bg)}.file-upload-zone:hover{border-color:var(--color-primary);background:var(--color-sidebar-hover)}.file-upload-zone.drag-active{border-color:var(--color-primary);background:var(--color-primary-muted)}.upload-icon{font-size:3rem;margin-bottom:1rem}.upload-text{margin:.5rem 0;font-size:1rem;color:var(--color-text)}.upload-hint{margin:0;font-size:.875rem;color:var(--color-text-muted)}.file-list{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.file-list-header{display:grid;grid-template-columns:1fr 100px 120px 100px;gap:1rem;padding:.75rem 1rem;background:var(--color-input-bg);border-bottom:1px solid var(--color-border);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted)}.file-item{display:grid;grid-template-columns:1fr 100px 120px 100px;gap:1rem;padding:1rem;border-bottom:1px solid var(--color-border);align-items:center;transition:background .2s}.file-item:last-child{border-bottom:none}.file-item:hover{background:var(--color-sidebar-hover)}.file-info{display:flex;align-items:center;gap:.75rem;min-width:0}.file-icon{font-size:1.5rem;flex-shrink:0}.file-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--color-text);font-size:.875rem}.file-size,.file-date{font-size:.875rem;color:var(--color-text-muted)}.file-actions{display:flex;gap:.5rem;justify-content:flex-end}.action-btn{background:transparent;border:none;font-size:1.25rem;cursor:pointer;padding:.25rem;opacity:.7;transition:opacity .2s;text-decoration:none;display:flex;align-items:center;justify-content:center}.action-btn:hover{opacity:1}.action-btn.danger:hover{opacity:1;filter:brightness(1.2)}.notes-tab{min-height:400px}.notes-textarea{width:100%;min-height:400px;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.875rem;line-height:1.6;resize:vertical}.notes-content{background:var(--color-bg);border:1px solid var(--color-border);border-radius:8px;padding:1.5rem;min-height:400px}.notes-text{margin:0;font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:.875rem;line-height:1.6;white-space:pre-wrap;color:var(--color-text)}.empty-state{text-align:center;padding:3rem 2rem;color:var(--color-text-muted)}.empty-state p{margin:.5rem 0}.empty-state .hint{font-size:.875rem}.experiment-list-panel::-webkit-scrollbar,.experiment-detail-panel::-webkit-scrollbar{width:8px;height:8px}.experiment-list-panel::-webkit-scrollbar-track,.experiment-detail-panel::-webkit-scrollbar-track{background:var(--color-scrollbar-track);border-radius:4px}.experiment-list-panel::-webkit-scrollbar-thumb,.experiment-detail-panel::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:4px;transition:background .2s ease}.experiment-list-panel::-webkit-scrollbar-thumb:hover,.experiment-detail-panel::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}.user-menu{position:relative}.user-menu-trigger{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:8px;cursor:pointer;transition:all .15s ease;width:100%}.user-menu-trigger:hover{background:var(--color-sidebar-hover);border-color:var(--color-primary-border)}.user-menu.compact .user-menu-trigger{width:36px;height:36px;padding:0;justify-content:center;border-radius:50%}.user-menu.compact .user-avatar,.user-menu.compact .user-avatar-placeholder{width:28px;height:28px;font-size:.65rem}.user-menu.collapsed .user-menu-trigger{justify-content:center;padding:.5rem}.user-avatar{width:32px;height:32px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-avatar-placeholder{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:600;flex-shrink:0}.user-name{flex:1;font-size:.875rem;font-weight:500;color:var(--color-text);text-align:left;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-chevron{color:var(--color-text-muted);transition:transform .15s ease;flex-shrink:0}.user-menu-chevron.open{transform:rotate(180deg)}.user-menu-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;min-width:220px;background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:8px;box-shadow:var(--shadow-card);z-index:1000;animation:slideDown .15s ease}.user-menu.compact .user-menu-dropdown{animation:slideUp .15s ease}.user-menu.collapsed .user-menu-dropdown{left:auto;right:auto;min-width:220px}@keyframes slideDown{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.user-menu-header{padding:.75rem 1rem;display:flex;align-items:flex-start;justify-content:space-between;gap:.5rem}.user-menu-info{display:flex;flex-direction:column;gap:.125rem;min-width:0}.user-menu-name{font-size:.875rem;font-weight:600;color:var(--color-text)}.user-menu-email{font-size:.75rem;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-menu-org{font-size:.6875rem;color:var(--color-text-secondary);margin-top:.125rem}.admin-badge{font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:.125rem .375rem;background:linear-gradient(135deg,var(--color-primary),#a855f7);color:#fff;border-radius:4px;flex-shrink:0}.user-menu-divider{height:1px;background:var(--color-border);margin:.25rem 0}.user-menu-item{display:flex;align-items:center;gap:.625rem;width:100%;padding:.625rem 1rem;background:transparent;border:none;font-size:.8125rem;color:var(--color-text-secondary);cursor:pointer;text-align:left;transition:all .1s ease}.user-menu-item:hover{background:var(--color-primary-muted);color:var(--color-text)}.user-menu-item svg{flex-shrink:0;opacity:.7}.user-menu-item:hover svg{opacity:1}.user-menu-item.logout{color:var(--color-danger)}.user-menu-item.logout:hover{background:#ef44441a;color:var(--color-danger)}.admin-panel-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000;padding:1rem;animation:fadeIn .15s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.admin-panel{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;width:100%;max-width:900px;max-height:80vh;display:flex;flex-direction:column;box-shadow:var(--shadow-card);animation:slideIn .2s ease}@keyframes slideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.admin-panel-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border)}.admin-panel-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.admin-close-btn{padding:.5rem;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:6px;transition:all .15s ease}.admin-close-btn:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.admin-panel-content{flex:1;overflow:auto;padding:1rem}.admin-loading,.admin-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:3rem;color:var(--color-text-muted)}.admin-spinner{width:32px;height:32px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:1rem}@keyframes spin{to{transform:rotate(360deg)}}.admin-error{color:var(--color-danger)}.admin-error button{margin-top:1rem;padding:.5rem 1rem;background:var(--color-primary);color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .15s ease}.admin-error button:hover{background:var(--color-primary-hover)}.users-table{width:100%;border-collapse:collapse;font-size:.875rem}.users-table th{text-align:left;padding:.75rem 1rem;color:var(--color-text-muted);font-weight:500;font-size:.75rem;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border);background:var(--color-input-bg)}.users-table td{padding:.875rem 1rem;color:var(--color-text);border-bottom:1px solid var(--color-border)}.users-table tr:hover{background:var(--color-primary-muted)}.users-table tr.disabled-user{opacity:.5}.user-cell{display:flex;align-items:center;gap:.75rem}.user-mini-avatar{width:36px;height:36px;border-radius:50%;object-fit:cover;flex-shrink:0}.user-mini-avatar-placeholder{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:.875rem;font-weight:600;flex-shrink:0}.user-info{display:flex;flex-direction:column;min-width:0}.user-display-name{font-weight:500;color:var(--color-text);display:flex;align-items:center;gap:.5rem}.user-display-email{font-size:.75rem;color:var(--color-text-secondary)}.you-badge{font-size:.625rem;font-weight:600;padding:.125rem .375rem;background:var(--color-primary);color:#fff;border-radius:4px}.org-cell{color:var(--color-text-muted)}.date-cell{color:var(--color-text-secondary);font-size:.8125rem}.role-select{padding:.375rem .625rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.8125rem;cursor:pointer;transition:all .15s ease}.role-select:hover:not(:disabled){border-color:var(--color-primary-border)}.role-select:focus{outline:none;border-color:var(--color-primary)}.role-select:disabled{opacity:.5;cursor:not-allowed}.status-toggle{padding:.375rem .75rem;border:none;border-radius:9999px;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s ease}.status-toggle.active{background:#22c55e33;color:var(--color-success)}.status-toggle.active:hover:not(:disabled){background:#22c55e4d}.status-toggle.inactive{background:#ef444433;color:var(--color-danger)}.status-toggle.inactive:hover:not(:disabled){background:#ef44444d}.status-toggle:disabled{opacity:.5;cursor:not-allowed}.admin-panel-footer{padding:.75rem 1.5rem;border-top:1px solid var(--color-border);background:var(--color-input-bg)}.user-count{font-size:.8125rem;color:var(--color-text-secondary)}@media(max-width:768px){.admin-panel{max-height:90vh}.users-table th:nth-child(2),.users-table td:nth-child(2),.users-table th:nth-child(5),.users-table td:nth-child(5){display:none}}.profile-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;justify-content:center;align-items:center;z-index:2000;padding:1rem;animation:profileFadeIn .15s ease}@keyframes profileFadeIn{0%{opacity:0}to{opacity:1}}.profile-modal{background:var(--color-bg-elevated);border:1px solid var(--color-border);border-radius:12px;width:100%;max-width:480px;max-height:90vh;overflow:auto;box-shadow:var(--shadow-card);animation:profileSlideIn .2s ease}@keyframes profileSlideIn{0%{opacity:0;transform:scale(.95) translateY(10px)}to{opacity:1;transform:scale(1) translateY(0)}}.profile-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--color-border);position:sticky;top:0;background:var(--color-bg-elevated);z-index:1}.profile-header h2{margin:0;font-size:1.125rem;font-weight:600;color:var(--color-text)}.profile-close-btn{padding:.5rem;background:transparent;border:none;color:var(--color-text-muted);cursor:pointer;border-radius:6px;transition:all .15s ease}.profile-close-btn:hover{background:var(--color-sidebar-hover);color:var(--color-text)}.profile-content{padding:1.5rem}.profile-section{margin-bottom:1.5rem}.profile-section:last-child{margin-bottom:0}.profile-section h3{margin:0 0 1rem;font-size:.875rem;font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.profile-account-info{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--color-input-bg);border-radius:8px;margin-bottom:.75rem}.profile-avatar{width:56px;height:56px;border-radius:50%;object-fit:cover;flex-shrink:0}.profile-avatar-placeholder{width:56px;height:56px;border-radius:50%;background:linear-gradient(135deg,var(--color-primary),#a855f7);color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:600;flex-shrink:0}.profile-account-details{display:flex;flex-direction:column;gap:.25rem}.profile-name{font-size:1rem;font-weight:600;color:var(--color-text)}.profile-email{font-size:.875rem;color:var(--color-text-muted)}.profile-role{font-size:.75rem;color:var(--color-primary);font-weight:500}.profile-google-note{font-size:.75rem;color:var(--color-text-secondary);margin:0}.profile-field{margin-bottom:1rem}.profile-field:last-child{margin-bottom:0}.profile-field label{display:block;font-size:.8125rem;font-weight:500;color:var(--color-text-secondary);margin-bottom:.375rem}.profile-field input,.profile-field select{width:100%;padding:.625rem .875rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:6px;color:var(--color-text);font-size:.875rem;transition:border-color .15s ease}.profile-field input:focus,.profile-field select:focus{outline:none;border-color:var(--color-primary);background:var(--color-input-bg-focus)}.profile-field input::placeholder{color:var(--color-text-secondary)}.profile-error{padding:.625rem .875rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:6px;color:var(--color-danger);font-size:.8125rem;margin-bottom:1rem}.profile-success{padding:.625rem .875rem;background:#22c55e1a;border:1px solid rgba(34,197,94,.3);border-radius:6px;color:var(--color-success);font-size:.8125rem;margin-bottom:1rem}.profile-save-btn{width:100%;padding:.75rem;background:var(--color-primary);border:none;border-radius:6px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease;margin-top:1rem}.profile-save-btn:hover:not(:disabled){background:var(--color-primary-hover);box-shadow:var(--shadow-button)}.profile-save-btn:disabled{opacity:.7;cursor:not-allowed}:root{--sidebar-width: 280px;--bg-000: 220 10% 8%;--color-bg: hsl(220, 10%, 8%);--color-bg-elevated: hsl(220, 8%, 12%);--color-sidebar: hsl(220, 12%, 10%);--color-sidebar-hover: hsl(220, 10%, 15%);--color-border: hsl(220, 8%, 20%);--color-text: hsl(220, 5%, 90%);--color-text-muted: hsl(220, 5%, 55%);--color-text-secondary: hsl(220, 5%, 70%);--color-primary: #8b5cf6;--color-primary-hover: #7c3aed;--color-primary-muted: rgba(139, 92, 246, .15);--color-primary-border: rgba(139, 92, 246, .3);--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-input-bg: hsl(220, 8%, 15%);--color-input-bg-focus: hsl(220, 8%, 18%);--color-scrollbar-track: hsl(220, 8%, 12%);--color-scrollbar-thumb: hsl(220, 8%, 25%);--shadow-card: 0 4px 12px rgba(0, 0, 0, .3);--shadow-button: 0 4px 12px rgba(139, 92, 246, .4);--dot-color: hsla(220, 5%, 40%, .15)}[data-theme=dark]{--bg-000: 220 10% 8%;--color-bg: hsl(220, 10%, 8%);--color-bg-elevated: hsl(220, 8%, 12%);--color-sidebar: hsl(220, 12%, 10%);--color-sidebar-hover: hsl(220, 10%, 15%);--color-border: hsl(220, 8%, 20%);--color-text: hsl(220, 5%, 90%);--color-text-muted: hsl(220, 5%, 55%);--color-text-secondary: hsl(220, 5%, 70%);--color-primary: #8b5cf6;--color-primary-hover: #7c3aed;--color-primary-muted: rgba(139, 92, 246, .15);--color-primary-border: rgba(139, 92, 246, .3);--color-success: #22c55e;--color-warning: #f59e0b;--color-danger: #ef4444;--color-input-bg: hsl(220, 8%, 15%);--color-input-bg-focus: hsl(220, 8%, 18%);--color-scrollbar-track: hsl(220, 8%, 12%);--color-scrollbar-thumb: hsl(220, 8%, 25%);--shadow-card: 0 4px 12px rgba(0, 0, 0, .3);--shadow-button: 0 4px 12px rgba(139, 92, 246, .4);--dot-color: hsla(220, 5%, 40%, .15)}[data-theme=light]{--bg-000: 40 20% 94%;--color-bg: #f5f1eb;--color-bg-elevated: #ffffff;--color-sidebar: #ffffff;--color-sidebar-hover: #f9f7f4;--color-border: #e5e0d8;--color-text: #2d2a26;--color-text-muted: #6b6560;--color-text-secondary: #8a847d;--color-primary: #8b5cf6;--color-primary-hover: #7c3aed;--color-primary-muted: rgba(139, 92, 246, .1);--color-primary-border: rgba(139, 92, 246, .25);--color-success: #16a34a;--color-warning: #d97706;--color-danger: #dc2626;--color-input-bg: #f9f7f4;--color-input-bg-focus: #ffffff;--color-scrollbar-track: #f0ece6;--color-scrollbar-thumb: #d4cfc7;--shadow-card: 0 2px 8px rgba(0, 0, 0, .08);--shadow-button: 0 2px 8px rgba(139, 92, 246, .25);--dot-color: hsla(30, 10%, 60%, .12)}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Inter,Helvetica Neue,Arial,sans-serif;-webkit-font-smoothing:antialiased;background:var(--color-bg);color:var(--color-text);transition:background-color .3s ease,color .3s ease}.app{display:flex;height:100vh;overflow:hidden;background:var(--color-bg);position:relative}.app:before{content:"";position:absolute;inset:0;background-image:radial-gradient(circle,var(--dot-color) 1px,transparent 1px);background-size:16px 16px;pointer-events:none;z-index:0}[data-theme=dark] .app:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at center,hsl(var(--bg-000)/100%),hsl(var(--bg-000)/95%),hsl(var(--bg-000)/70%) 40%,hsl(var(--bg-000)/0%) 70%);pointer-events:none;z-index:0}.sidebar-toggle{background:transparent;border:1px solid var(--color-border);color:var(--color-text-muted);width:28px;height:28px;padding:0;cursor:pointer;border-radius:6px;font-size:1rem;transition:all .15s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-toggle:hover{background:var(--color-bg-elevated);border-color:var(--color-primary);color:var(--color-primary)}.sidebar-collapsed{width:48px;background:var(--color-sidebar);border-right:1px solid var(--color-border);display:flex;flex-direction:column;align-items:center;padding:1rem .5rem;gap:.5rem;flex-shrink:0;position:relative;z-index:1;transition:background-color .3s ease,border-color .3s ease}.sidebar-collapsed .nav-divider{width:24px;height:1px;background:var(--color-border);margin:.25rem 0}.sidebar-letter-btn{width:32px;height:32px;border-radius:6px;border:1px solid transparent;background:transparent;color:var(--color-text-muted);font-size:1rem;font-weight:600;cursor:pointer;transition:all .15s ease;display:flex;align-items:center;justify-content:center}.sidebar-letter-btn:hover{background:var(--color-sidebar-hover);color:var(--color-text);border-color:var(--color-border)}.sidebar-letter-btn.active{background:var(--color-primary-muted);color:var(--color-primary);border-color:var(--color-primary)}.sidebar{width:var(--sidebar-width);background:var(--color-sidebar);color:var(--color-text);display:flex;flex-direction:column;flex-shrink:0;overflow-y:auto;border-right:1px solid var(--color-border);transition:all .3s ease;position:relative;z-index:1}.sidebar.hidden{margin-left:calc(-1 * var(--sidebar-width))}.sidebar-header{padding:1.25rem 1rem 1rem;border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;gap:.5rem}.sidebar-logo{display:flex;align-items:center;gap:.5rem;font-size:1rem;font-weight:600;letter-spacing:-.02em}.logo-icon{width:32px;height:32px;flex-shrink:0;object-fit:contain}.logo-violet{color:var(--color-primary)}.logo-research{color:var(--color-text)}.sidebar-title{font-size:1rem;font-weight:600;margin:0;letter-spacing:-.02em;color:var(--color-text)}.sidebar-subtitle{font-size:.75rem;color:var(--color-text-muted);margin:0}.nav-section{margin:0;padding:.5rem 0 .25rem;transition:background .15s ease}.nav-section:hover{background:var(--color-primary-muted)}.nav-section.active{background:var(--color-primary-muted);border-left:3px solid var(--color-primary)}.nav-section-title{font-size:.6875rem;text-transform:uppercase;letter-spacing:.08em;font-weight:600;color:var(--color-text-muted);padding:0 1rem .25rem;margin:0;transition:color .15s ease}.nav-section.active .nav-section-title{color:var(--color-primary)}.nav-divider{height:1px;background:var(--color-border);margin:.35rem 0}.exon-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:.25rem;padding:0 1rem}.exon-btn{padding:.25rem .125rem;background:var(--color-primary-muted);border:1px solid var(--color-primary-border);border-radius:4px;color:var(--color-primary);font-size:.625rem;font-weight:500;cursor:pointer;transition:all .15s ease}.exon-btn:hover:not(:disabled){background:#8b5cf640;border-color:#8b5cf680;transform:translateY(-1px)}.exon-btn:active:not(:disabled){transform:translateY(0)}.exon-btn:disabled{opacity:.4;cursor:not-allowed}.load-data-btn{width:100%;padding:.625rem 1rem;background:var(--color-primary);border:none;border-radius:6px;color:#fff;font-size:.875rem;font-weight:500;cursor:pointer;transition:all .15s ease}.load-data-btn:hover:not(:disabled){background:var(--color-primary-hover);transform:translateY(-1px);box-shadow:var(--shadow-button)}.load-data-btn:active:not(:disabled){transform:translateY(0)}.load-data-btn:disabled{opacity:.6;cursor:not-allowed}.clear-data-btn{width:100%;padding:.5rem 1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.2);border-radius:6px;color:var(--color-danger);font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease}.clear-data-btn:hover{background:#ef444426;border-color:#ef44444d}.bottom-panel{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;border-top:1px solid var(--color-border);gap:.75rem}.theme-toggle-container{display:flex;align-items:center;gap:.75rem}.theme-label{font-size:1rem;line-height:1}.theme-label-text{font-size:.8125rem;color:var(--color-text-muted);font-weight:500}.theme-toggle{position:relative;width:44px;height:24px;background:var(--color-border);border:none;border-radius:12px;cursor:pointer;transition:background .2s ease;padding:0}.theme-toggle:hover{background:var(--color-text-muted)}.theme-toggle.light{background:var(--color-primary)}.theme-toggle.light:hover{background:var(--color-primary-hover)}.theme-toggle-slider{position:absolute;top:2px;left:2px;width:20px;height:20px;background:#fff;border-radius:50%;transition:transform .2s ease;box-shadow:0 1px 3px #0003}.theme-toggle.light .theme-toggle-slider{transform:translate(20px)}.main{flex:1;display:flex;flex-direction:column;overflow:hidden;background:radial-gradient(circle,var(--dot-color) 1px,transparent 1px),var(--color-bg);background-size:16px 16px,auto;position:relative;z-index:1;padding:1rem;gap:0;transition:background-color .3s ease}.viz-container{background:var(--color-bg-elevated);border-radius:12px;border:1px solid var(--color-border);box-shadow:var(--shadow-card);display:flex;flex-direction:column;overflow:hidden;min-height:200px;transition:background-color .3s ease,border-color .3s ease,box-shadow .3s ease}.viz-container.linear-viewer{flex-shrink:0;margin-bottom:0}.viz-container.circos-viewer{flex-shrink:0;margin-top:0}.viewer-divider{height:12px;background:transparent;cursor:row-resize;display:flex;align-items:center;justify-content:center;position:relative;z-index:10;flex-shrink:0;-webkit-user-select:none;user-select:none;margin:0}.viewer-divider:hover{background:var(--color-primary-muted)}.divider-handle{width:40px;height:4px;background:var(--color-primary-border);border-radius:2px;transition:background .15s ease}.viewer-divider:hover .divider-handle{background:var(--color-primary)}.error-banner{background:#ef44441a;border-bottom:1px solid rgba(239,68,68,.2);color:var(--color-danger);padding:.875rem 1.5rem;font-size:.875rem}.empty-state{flex:1;display:flex;align-items:center;justify-content:center;padding:3rem}.empty-state-content{text-align:center;max-width:400px}.empty-state-content h2{font-size:1.25rem;font-weight:600;color:var(--color-text);margin:0 0 .5rem}.empty-state-content p{font-size:.9375rem;color:var(--color-text-muted);line-height:1.6;margin:0}.viz-toolbar{display:flex;align-items:center;gap:.5rem;padding:.75rem 1rem;border-bottom:1px solid var(--color-border);flex-wrap:wrap;background:var(--color-bg-elevated);transition:background-color .3s ease,border-color .3s ease}.viz-toolbar-group{display:flex;align-items:center;gap:.25rem}.viz-btn{padding:.4rem .625rem;background:var(--color-input-bg);border:1px solid var(--color-border);border-radius:6px;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .15s ease;color:var(--color-text)}.viz-btn:hover{background:var(--color-sidebar-hover);border-color:var(--color-primary)}.viz-btn:active{transform:scale(.97)}.viz-input{padding:.4rem .625rem;border:1px solid var(--color-border);border-radius:6px;font-size:.8125rem;background:var(--color-input-bg);color:var(--color-text);transition:all .15s ease}.viz-input:focus{outline:none;border-color:var(--color-primary);background:var(--color-input-bg-focus)}.viz-input::placeholder{color:var(--color-text-muted);opacity:.6}.viz-divider{width:1px;height:24px;background:var(--color-border);margin:0 .5rem}.viz-info{margin-left:auto;font-size:.75rem;color:var(--color-text-muted);display:flex;align-items:center;gap:.75rem}.viz-badge{padding:.25rem .5rem;background:var(--color-input-bg);border-radius:4px;font-size:.6875rem;font-weight:600;color:var(--color-primary);text-transform:uppercase;letter-spacing:.02em}.viz-content{flex:1;min-height:0}.legend{display:flex;gap:1.25rem;padding:.75rem 1rem;border-top:1px solid var(--color-border);font-size:.75rem;color:var(--color-text-muted);flex-wrap:wrap;background:var(--color-bg-elevated);transition:background-color .3s ease,border-color .3s ease}.legend-item{display:flex;align-items:center;gap:.5rem}.legend-color{width:14px;height:14px;border-radius:3px;border:1px solid var(--color-border)}.sequence-track{font-family:SF Mono,Monaco,Inconsolata,Fira Code,monospace;font-size:14px;line-height:1.6;padding:.75rem 1rem;background:var(--color-input-bg);border-top:1px solid var(--color-border);overflow-x:auto;white-space:nowrap}.sequence-track .base{display:inline-block;width:16px;text-align:center;font-weight:600}.sequence-track .base.A{color:#4ade80}.sequence-track .base.T{color:#f87171}.sequence-track .base.G{color:#fbbf24}.sequence-track .base.C{color:#60a5fa}.sequence-track .base.diff{background:#fbbf2433;border-radius:2px}.sequence-label{font-size:.75rem;color:var(--color-text-muted);margin-bottom:.375rem;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-scrollbar-track);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-scrollbar-thumb);border-radius:4px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:var(--color-primary)}*{scrollbar-width:thin;scrollbar-color:var(--color-scrollbar-thumb) var(--color-scrollbar-track)}@media(max-width:1024px){:root{--sidebar-width: 240px}.exon-grid{grid-template-columns:repeat(4,1fr)}}@media(max-width:768px){.sidebar{position:fixed;left:0;top:0;bottom:0;z-index:1000;transform:translate(-100%)}.sidebar.open{transform:translate(0)}.exon-grid{grid-template-columns:repeat(3,1fr)}}*{box-sizing:border-box}:root{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif;line-height:1.5;font-weight:400;color:#1e293b;background-color:#f8fafc;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{margin:0;min-width:320px;min-height:100vh}#root{min-height:100vh}a{font-weight:500;color:#3b82f6;text-decoration:none}a:hover{color:#2563eb;text-decoration:underline}button,input{font-family:inherit}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600}
