*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--bg: #09090b;--surface: #18181b;--surface2: #27272a;--border: #3f3f46;--text: #fafafa;--text-muted: #a1a1aa;--accent: #10b981;--accent-dim: rgba(16, 185, 129, .15);--accent-border: rgba(16, 185, 129, .4);--red: #ef4444;--green: #22c55e;--yellow: #eab308;--blue: #3b82f6;--gray: #71717a;--font-body: "Inter", system-ui, sans-serif;--font-mono: "JetBrains Mono", monospace;--radius: 8px;--radius-sm: 4px}html,body{height:100%;font-family:var(--font-body);background:var(--bg);color:var(--text);font-size:14px;line-height:1.5}#app{display:flex;flex-direction:column;height:100%;min-height:100vh}#topbar{display:flex;align-items:center;justify-content:space-between;padding:0 20px;height:52px;background:var(--surface);border-bottom:1px solid var(--border);gap:12px;flex-shrink:0}#topbar-left{display:flex;align-items:center;gap:10px}#app-title{font-weight:700;font-size:16px;letter-spacing:-.02em;color:var(--text)}#topbar-controls{display:flex;align-items:center;gap:10px;flex-wrap:wrap}#sample-select{background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:6px 10px;font-size:13px;font-family:var(--font-body);cursor:pointer;outline:none}#sample-select:focus{border-color:var(--accent)}button{cursor:pointer;font-family:var(--font-body);font-size:13px;border:none;border-radius:var(--radius-sm);padding:6px 14px;transition:background .15s,opacity .15s}#paste-btn{background:var(--surface2);border:1px solid var(--border);color:var(--text)}#paste-btn:hover{background:var(--border)}#upload-label{display:inline-flex;align-items:center;gap:6px;background:var(--surface2);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);padding:6px 14px;cursor:pointer;font-size:13px;transition:background .15s}#upload-label:hover{background:var(--border)}#file-input{display:none}.btn-primary{background:var(--accent);color:#000;font-weight:600}.btn-primary:hover{opacity:.85}.btn-ghost{background:transparent;border:1px solid var(--border);color:var(--text-muted)}.btn-ghost:hover{background:var(--surface2)}.perf-badge{background:var(--accent-dim);border:1px solid var(--accent-border);color:var(--accent);font-family:var(--font-mono);font-size:11px;padding:4px 10px;border-radius:999px}#modal-overlay{position:fixed;inset:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:100;backdrop-filter:blur(4px)}#modal-overlay.hidden{display:none}#modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:min(600px,90vw);display:flex;flex-direction:column;gap:16px;padding:20px}#modal-header{display:flex;align-items:center;justify-content:space-between}#modal-title{font-size:16px;font-weight:600}#modal-close{background:transparent;border:none;color:var(--text-muted);font-size:18px;padding:4px 8px}#modal-close:hover{color:var(--text)}#fasta-textarea{width:100%;height:220px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);font-size:12px;padding:12px;resize:vertical;outline:none}#fasta-textarea:focus{border-color:var(--accent)}#modal-footer{display:flex;gap:10px;justify-content:flex-end}#main{flex:1;display:flex;flex-direction:column;overflow:hidden}#sequence-header{padding:14px 20px 0}#seq-meta{display:flex;align-items:center;gap:10px;flex-wrap:wrap}#seq-name{font-weight:600;font-size:15px}.tag{background:var(--surface2);border:1px solid var(--border);border-radius:999px;padding:2px 10px;font-size:12px;font-family:var(--font-mono);color:var(--text-muted)}.tag.accent{background:var(--accent-dim);border-color:var(--accent-border);color:var(--accent)}#tabs{display:flex;padding:0 20px;border-bottom:1px solid var(--border);margin-top:14px;gap:0;flex-shrink:0}.tab{background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-muted);padding:10px 18px;font-size:13px;font-weight:500;border-radius:0;transition:color .15s,border-color .15s;margin-bottom:-1px}.tab:hover{color:var(--text)}.tab.active{color:var(--accent);border-bottom-color:var(--accent)}#panels{flex:1;overflow-y:auto;padding:20px}.panel{display:none}.panel.active{display:block}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:20px;margin-bottom:16px}.card-title{font-size:13px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);margin-bottom:16px}.empty-state{text-align:center;padding:48px 20px;color:var(--text-muted)}#overview-content{display:grid;grid-template-columns:1fr auto;gap:16px;align-items:start}#base-chart{display:flex;flex-direction:column;gap:8px}.base-row{display:flex;align-items:center;gap:10px}.base-label{font-family:var(--font-mono);font-size:13px;font-weight:500;width:16px;text-align:center}.base-bar-track{flex:1;height:20px;background:var(--surface2);border-radius:var(--radius-sm);overflow:hidden}.base-bar-fill{height:100%;border-radius:var(--radius-sm);transition:width .4s ease}.base-pct{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);width:44px;text-align:right}.base-count{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);width:70px;text-align:right}#gc-pct-display{font-family:var(--font-mono);font-size:48px;font-weight:700;color:var(--accent);padding:20px 32px;text-align:center;white-space:nowrap}.mono-grid{display:grid;grid-template-columns:auto 1fr;gap:6px 16px;font-family:var(--font-mono);font-size:12px}.mono-label{color:var(--text-muted)}.mono-value{color:var(--text)}.align-inputs{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:16px}.align-input-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:12px;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.seq-textarea{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);font-size:11px;padding:10px;height:100px;resize:vertical;outline:none;width:100%}.seq-textarea:focus{border-color:var(--accent)}.align-stats{display:flex;gap:24px;margin:16px 0 12px;flex-wrap:wrap}.stat-item{display:flex;flex-direction:column;gap:2px}.stat-label{font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em}.stat-value{font-family:var(--font-mono);font-size:18px;font-weight:600;color:var(--accent)}.align-output{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px;font-family:var(--font-mono);font-size:12px;overflow-x:auto;max-height:400px;overflow-y:auto}.align-block{margin-bottom:20px}.align-line{display:flex;gap:12px;line-height:1.8}.align-pos{color:var(--text-muted);width:50px;flex-shrink:0;text-align:right}.align-seq{display:inline;word-break:break-all;white-space:pre-wrap}.a-match{color:var(--green)}.a-mismatch{color:var(--red)}.a-gap{color:var(--gray)}.align-mid-line{padding-left:62px;color:var(--text-muted);line-height:1;margin:-6px 0;letter-spacing:0}.gc-controls{display:flex;align-items:center;gap:16px;margin-bottom:16px;flex-wrap:wrap}#window-slider{accent-color:var(--accent);width:200px}#gc-canvas{width:100%;height:240px;display:block;border-radius:var(--radius-sm);background:var(--bg)}.orf-controls{display:flex;align-items:center;gap:16px;margin-bottom:20px;flex-wrap:wrap}#min-codons-slider{accent-color:var(--accent);width:200px}#orf-viz{display:flex;flex-direction:column;gap:12px;margin-bottom:20px}.orf-frame-row{display:flex;align-items:center;gap:12px}.orf-frame-label{font-family:var(--font-mono);font-size:12px;color:var(--text-muted);width:60px;flex-shrink:0}.orf-track{flex:1;height:28px;background:var(--surface2);border-radius:var(--radius-sm);position:relative;overflow:hidden}.orf-arrow{position:absolute;top:4px;height:20px;background:var(--accent);border-radius:3px;cursor:pointer;transition:opacity .15s;display:flex;align-items:center;padding-left:4px;overflow:hidden;min-width:4px}.orf-arrow:hover{opacity:.75}.orf-arrow span{font-size:10px;font-family:var(--font-mono);color:#000;white-space:nowrap;overflow:hidden}#orf-details{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:16px}#orf-details h4{margin-bottom:12px}.motif-controls{display:flex;gap:10px;margin-bottom:20px;align-items:center}.motif-field{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text);font-family:var(--font-mono);font-size:14px;padding:8px 14px;outline:none;flex:1;max-width:300px;text-transform:uppercase}.motif-field:focus{border-color:var(--accent)}.motif-hit{background:var(--bg);border:1px solid var(--border);border-radius:var(--radius-sm);padding:10px 14px;margin-bottom:8px;font-family:var(--font-mono);font-size:12px;display:flex;align-items:baseline;gap:12px}.motif-pos{color:var(--text-muted);flex-shrink:0;width:80px}.motif-ctx{color:var(--text);word-break:break-all}.motif-ctx mark{background:var(--accent-dim);color:var(--accent);border-radius:2px;padding:1px 2px}.motif-count{color:var(--text-muted);font-size:12px;margin-bottom:12px}.hidden{display:none!important}@media(max-width:600px){#overview-content,.align-inputs{grid-template-columns:1fr}#topbar{flex-wrap:wrap;height:auto;padding:10px 16px}#topbar-controls{flex-wrap:wrap;gap:6px}#panels{padding:12px}}
