*,*:before,*:after{box-sizing:border-box}html{overflow-x:hidden;overscroll-behavior-x:none;touch-action:manipulation}body{overflow-x:hidden;max-width:100vw;overscroll-behavior-x:none}html{-moz-text-size-adjust:none;-webkit-text-size-adjust:none;text-size-adjust:none}body,h1,h2,h3,h4,p,figure,blockquote,dl,dd{margin:0}ul[role=list],ol[role=list]{list-style:none;margin:0;padding:0}body{min-height:100vh;min-height:100dvh;min-height:var(--app-height, 100vh);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}h1,h2,h3,h4,button,input,label{line-height:1.1}h1,h2,h3,h4{text-wrap:balance}a:not([class]){text-decoration-skip-ink:auto;color:currentColor}img,picture,svg{max-width:100%;display:block}input,button,textarea,select{font-family:inherit;font-size:inherit}textarea:not([rows]){min-height:10em}:target{scroll-margin-block:5ex}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}:focus-visible{outline:2px solid var(--color-border-focus, #00ffff);outline-offset:2px}button{background:none;border:none;padding:0;cursor:pointer;color:inherit}fieldset{border:none;padding:0;margin:0}::-webkit-scrollbar-track{background:var(--color-background, #0d0d1a)}::-webkit-scrollbar-thumb{background:var(--color-border, #3d3d5c);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-border-focus, #00ffff)}*{scrollbar-width:thin;scrollbar-color:var(--color-border, #3d3d5c) var(--color-background, #0d0d1a)}::selection{background:var(--color-accent, #ffff00);color:var(--color-background, #0d0d1a)}:root{color-scheme:dark;--color-primary: #22d3ee;--color-primary-hover: #67e8f9;--color-secondary: #c084fc;--color-accent: #fbbf24;--color-background: #0a0a0f;--color-background-alt: #12121a;--color-background-elevated: #16161f;--color-background-hover: #1c1c27;--color-background-active: #1e1e2a;--color-background-glass: rgba(10, 10, 15, .85);--color-background-gradient-start: rgba(34, 211, 238, .08);--color-header-action-bg: rgba(255, 255, 255, .02);--color-header-action-bg-hover: rgba(255, 255, 255, .04);--color-text: #f0f0f8;--color-text-dim: #9ca3af;--color-text-muted: #6b7280;--color-border: #2d2d3a;--color-border-subtle: #232330;--color-border-light: #3d3d4a;--color-border-focus: #22d3ee;--color-success: #10b981;--color-warning: #f59e0b;--color-error: #ef4444;--color-info: #22d3ee;--color-diff-highlight: #c084fc;--color-gene-forward: #22d3ee;--color-gene-reverse: #c084fc;--color-gene-highlight: #fbbf24;--color-gradient-low: #0f0f1a;--color-gradient-mid: #7c3aed;--color-gradient-high: #22d3ee;--color-kmer-normal: #6b7280;--color-kmer-anomaly: #ef4444;--color-shadow: #000000;--color-highlight: #ffffff;--color-glow: rgba(34, 211, 238, .3);--color-glow-soft: rgba(34, 211, 238, .15);--color-glow-secondary: rgba(192, 132, 252, .2);--focus-ring-color: rgba(34, 211, 238, .65);--focus-ring-color-soft: rgba(34, 211, 238, .25);--focus-ring-width: 3px;--focus-ring-offset: 2px;--glass-bg: rgba(18, 18, 26, .75);--glass-bg-elevated: rgba(22, 22, 31, .85);--glass-border: rgba(255, 255, 255, .06);--glass-blur: 16px;--color-badge-bg: rgba(34, 211, 238, .1);--color-badge-text: #22d3ee;--color-badge-border: rgba(34, 211, 238, .2);--color-separator: #2d2d3a;--color-icon-primary: #22d3ee;--color-icon-secondary: #c084fc;--color-panel-header: #16161f;--color-panel-border: #2d2d3a;--color-panel-shadow: #050508;--sparkline-0: #0f0f1a;--sparkline-1: #7c3aed;--sparkline-2: #a855f7;--sparkline-3: #22d3ee;--sparkline-4: #10b981;--nucleotide-a-fg: #000000;--nucleotide-a-bg: #22d3ee;--nucleotide-c-fg: #000000;--nucleotide-c-bg: #c084fc;--nucleotide-g-fg: #000000;--nucleotide-g-bg: #fbbf24;--nucleotide-t-fg: #000000;--nucleotide-t-bg: #f472b6;--nucleotide-n-fg: #9ca3af;--nucleotide-n-bg: #2d2d3a;--space-0: 0;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--space-20: 5rem;--space-24: 6rem;--radius-none: 0;--radius-sm: 4px;--radius-md: 6px;--radius-lg: 10px;--radius-xl: 14px;--radius-2xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px rgba(0, 0, 0, .25);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3), 0 1px 3px rgba(0, 0, 0, .15);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .3), 0 2px 4px -2px rgba(0, 0, 0, .15);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .35), 0 4px 6px -4px rgba(0, 0, 0, .2);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .4), 0 8px 10px -6px rgba(0, 0, 0, .2);--shadow-2xl: 0 25px 50px -12px rgba(0, 0, 0, .5);--shadow-glow: 0 0 8px var(--color-glow), 0 0 16px var(--color-glow);--shadow-glow-lg: 0 0 12px var(--color-glow), 0 0 24px var(--color-glow);--shadow-glow-soft: 0 0 12px var(--color-glow-soft);--shadow-inner: inset 0 2px 4px 0 rgba(0, 0, 0, .25);--shadow-ambient-sm: 0 8px 30px -10px rgba(0, 0, 0, .25);--shadow-ambient-md: 0 16px 50px -12px rgba(0, 0, 0, .3);--shadow-ambient-lg: 0 25px 60px -15px rgba(0, 0, 0, .35);--shadow-key-sm: 0 2px 4px rgba(0, 0, 0, .15);--shadow-key-md: 0 4px 8px rgba(0, 0, 0, .18);--shadow-key-lg: 0 8px 16px rgba(0, 0, 0, .2);--shadow-premium-sm: var(--shadow-key-sm), var(--shadow-ambient-sm);--shadow-premium-md: var(--shadow-key-md), var(--shadow-ambient-md);--shadow-premium-lg: var(--shadow-key-lg), var(--shadow-ambient-lg);--elevation-1: 0 1px 1px rgba(0, 0, 0, .07), 0 2px 2px rgba(0, 0, 0, .07), 0 4px 4px rgba(0, 0, 0, .07);--elevation-2: 0 2px 4px rgba(0, 0, 0, .07), 0 4px 8px rgba(0, 0, 0, .07), 0 8px 16px rgba(0, 0, 0, .07);--elevation-3: 0 4px 8px rgba(0, 0, 0, .08), 0 8px 16px rgba(0, 0, 0, .08), 0 16px 32px rgba(0, 0, 0, .08);--elevation-4: 0 8px 16px rgba(0, 0, 0, .09), 0 16px 32px rgba(0, 0, 0, .09), 0 32px 64px rgba(0, 0, 0, .09);--shadow-primary-glow: 0 4px 12px -4px rgba(34, 211, 238, .18);--shadow-secondary-glow: 0 4px 12px -4px rgba(192, 132, 252, .18);--shadow-accent-glow: 0 4px 12px -4px rgba(251, 191, 36, .18);--shadow-elevated: 0 4px 12px rgba(0, 0, 0, .35), 0 0 1px rgba(0, 0, 0, .2);--shadow-floating: 0 12px 28px rgba(0, 0, 0, .4), 0 4px 8px rgba(0, 0, 0, .2), 0 0 0 1px var(--glass-border);--shadow-focus-ring: 0 0 0 var(--focus-ring-offset) var(--color-background), 0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color);--duration-instant: 50ms;--duration-fast: .15s;--duration-normal: .25s;--duration-slow: .4s;--duration-slower: .6s;--ease-linear: linear;--ease-in: cubic-bezier(.4, 0, 1, 1);--ease-out: cubic-bezier(0, 0, .2, 1);--ease-in-out: cubic-bezier(.4, 0, .2, 1);--ease-spring: cubic-bezier(.34, 1.56, .64, 1);--ease-spring-soft: cubic-bezier(.22, 1, .36, 1);--ease-smooth: cubic-bezier(.45, 0, .55, 1);--ease-expo-out: cubic-bezier(.16, 1, .3, 1);--ease-back: cubic-bezier(.68, -.6, .32, 1.6);--duration-micro: 80ms;--duration-press: .12s;--duration-hover: .18s;--duration-focus: .2s;--z-base: 0;--z-dropdown: 100;--z-sticky: 200;--z-fixed: 300;--z-crt: 350;--z-modal-backdrop: 400;--z-modal: 500;--z-popover: 600;--z-tooltip: 700;--z-toast: 800;--z-overlay: 900;--z-max: 9999;--app-height: var(--visual-viewport-height, 100vh);--header-height: 3rem;--footer-height: 2rem;--sidebar-width: 16rem;--panel-max-width: 1200px;--content-max-width: 80ch;--overlay-border-radius: var(--radius-lg);--overlay-border-radius-mobile: var(--radius-2xl) var(--radius-2xl) 0 0;--overlay-header-padding-x: var(--space-4);--overlay-header-padding-y: var(--space-3);--overlay-content-padding: var(--space-4);--overlay-footer-padding-x: var(--space-4);--overlay-footer-padding-y: var(--space-3);--overlay-section-gap: var(--space-4);--overlay-title-gap: var(--space-2);--overlay-border: 1px solid var(--color-border-subtle);--overlay-divider-border: 1px solid var(--color-border-light);--overlay-shadow: var(--shadow-floating);--overlay-title-size: var(--text-lg);--overlay-title-weight: var(--font-bold);--overlay-title-line-height: var(--leading-tight);--overlay-title-tracking: var(--tracking-tight);--overlay-section-title-size: var(--text-base);--overlay-section-title-weight: var(--font-semibold);--overlay-section-title-line-height: var(--leading-snug);--overlay-section-title-tracking: var(--tracking-normal);--overlay-subtitle-size: var(--text-sm);--overlay-subtitle-weight: var(--font-medium);--overlay-subtitle-line-height: var(--leading-snug);--overlay-body-size: var(--text-sm);--overlay-body-weight: var(--font-normal);--overlay-body-line-height: var(--leading-relaxed);--overlay-body-max-width: 60ch;--overlay-description-size: var(--text-sm);--overlay-description-weight: var(--font-normal);--overlay-description-line-height: var(--leading-normal);--overlay-description-color: var(--color-text-dim);--overlay-caption-size: var(--text-xs);--overlay-caption-weight: var(--font-normal);--overlay-caption-line-height: var(--leading-normal);--overlay-caption-color: var(--color-text-muted);--overlay-label-size: var(--text-xs);--overlay-label-weight: var(--font-medium);--overlay-label-tracking: var(--tracking-wide);--overlay-label-color: var(--color-text-muted);--overlay-value-size: var(--text-lg);--overlay-value-weight: var(--font-medium);--chrome-padding-x: var(--space-3);--chrome-padding-y: var(--space-2);--chrome-padding-compact-x: var(--space-2);--chrome-padding-compact-y: var(--space-1);--chrome-gap: var(--space-2);--chrome-gap-compact: var(--space-1);--chrome-gap-lg: var(--space-4);--badge-padding-x: .4rem;--badge-padding-y: .1rem;--badge-radius: var(--radius-sm);--badge-font-size: var(--text-xs, .75rem);--hotkey-padding-x: .4rem;--hotkey-padding-y: .1rem;--hotkey-radius: var(--radius-sm);--hotkey-font-size: var(--text-sm);--btn-padding-x: var(--space-4);--btn-padding-y: var(--space-2);--btn-padding-x-sm: var(--space-3);--btn-padding-y-sm: var(--space-1);--btn-padding-x-lg: var(--space-6);--btn-padding-y-lg: var(--space-3);--btn-min-height: 36px;--btn-min-height-sm: 28px;--btn-min-height-lg: 44px;--btn-font-size: var(--text-sm);--btn-font-size-sm: var(--text-xs);--btn-font-size-lg: var(--text-base);--btn-font-weight: var(--font-medium);--btn-radius: var(--radius-lg);--btn-radius-sm: var(--radius-md);--btn-disabled-opacity: .5}.p-0{padding:var(--space-0)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.m-0{margin:var(--space-0)}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/JetBrainsMono-Regular.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:500;font-display:swap;src:url(/fonts/JetBrainsMono-Medium.woff2) format("woff2")}@font-face{font-family:JetBrains Mono;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/JetBrainsMono-Bold.woff2) format("woff2")}:root{--font-mono: "JetBrains Mono", "SFMono-Regular", ui-monospace, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--font-sans: "Inter", system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--text-2xs: .64rem;--text-xs: .75rem;--text-sm: .875rem;--text-base: 1rem;--text-lg: 1.125rem;--text-xl: 1.25rem;--text-2xl: 1.5rem;--text-3xl: 1.875rem;--text-4xl: 2.25rem;--text-5xl: 3rem;--leading-none: 1;--leading-tight: 1.15;--leading-snug: 1.35;--leading-normal: 1.55;--leading-relaxed: 1.7;--leading-loose: 2;--tracking-tighter: -.03em;--tracking-tight: -.015em;--tracking-normal: 0;--tracking-wide: .015em;--tracking-wider: .03em;--tracking-widest: .06em;--font-normal: 400;--font-medium: 500;--font-semibold: 600;--font-bold: 700;--font-features-code: "calt" 1, "liga" 1, "zero" 1, "ss01" 1}@media(max-width:640px){:root{--text-2xs: .67rem}}@media(max-width:900px){:root{--text-2xs: 10px;--text-xs: 12px;--text-sm: 14px;--text-base: 16px}}html{font-family:var(--font-sans);font-size:15px;line-height:var(--leading-normal);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}@media(min-width:640px){html{font-size:15px}}@media(min-width:1024px){html{font-size:16px}}body{font-size:var(--text-sm);color:var(--color-text, #f0f0f8);letter-spacing:var(--tracking-normal)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);color:var(--color-text, #f0f0f8);margin:0}h1{font-size:var(--text-4xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tighter)}h2{font-size:var(--text-3xl);line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}h3{font-size:var(--text-2xl);line-height:var(--leading-snug)}h4{font-size:var(--text-xl);line-height:var(--leading-snug)}h5{font-size:var(--text-lg);line-height:var(--leading-normal)}h6{font-size:var(--text-sm);font-weight:var(--font-semibold);line-height:var(--leading-normal);text-transform:uppercase;letter-spacing:var(--tracking-wide);color:var(--color-text-dim)}p{margin-bottom:1em;max-width:65ch}small,.text-sm{font-size:var(--text-sm)}.text-xs{font-size:var(--text-xs)}.text-dim{color:var(--color-text-dim, #8888aa)}.text-error{color:var(--color-error, #ef4444)}.text-muted{color:var(--color-text-muted, #555577)}code,pre,kbd,samp{font-family:var(--font-mono);font-feature-settings:var(--font-features-code)}pre{font-size:var(--text-sm);line-height:var(--leading-relaxed);overflow-x:auto;padding:1rem;background:var(--color-background-alt, #1a1a2e);border-radius:4px;border:1px solid var(--color-border, #3d3d5c)}code{font-size:.9em;padding:.125em .25em;background:var(--color-background-alt, #1a1a2e);border-radius:2px}pre code{padding:0;background:none}kbd{font-size:var(--text-xs);padding:.125em .375em;background:var(--color-background-alt, #1a1a2e);border:1px solid var(--color-border, #3d3d5c);border-radius:3px;box-shadow:0 1px 0 var(--color-border, #3d3d5c)}@media(max-width:640px){kbd{font-size:max(var(--text-xs),11px);padding:.2em .5em}}a{color:var(--color-primary, #00ffff);text-decoration:none;text-decoration-color:transparent;text-underline-offset:2px;text-decoration-thickness:1px;transition:color var(--duration-fast, .15s) ease,text-decoration-color var(--duration-fast, .15s) ease}a:hover{color:var(--color-accent, #ffff00);text-decoration:underline;text-decoration-color:currentColor;text-underline-offset:2px;text-decoration-thickness:1px}a:active{opacity:.8}a[role=button],a.btn{text-decoration:none!important;text-decoration-color:transparent!important}ul,ol{padding-left:1.5em;margin-bottom:1em}li{margin-bottom:.25em}dl{margin-bottom:1em}dt{font-weight:var(--font-bold);color:var(--color-text, #e0e0ff)}dd{margin-left:1.5em;margin-bottom:.5em;color:var(--color-text-dim, #8888aa)}blockquote{margin:1em 0;padding-left:1em;border-left:3px solid var(--color-primary, #00ffff);color:var(--color-text-dim, #8888aa);font-style:italic}hr{border:none;border-top:1px solid var(--color-border, #3d3d5c);margin:1.5em 0}.tabular-nums{font-variant-numeric:tabular-nums}.font-data{font-family:var(--font-mono);font-variant-numeric:tabular-nums}.uppercase{text-transform:uppercase;letter-spacing:var(--tracking-wider)}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nowrap{white-space:nowrap}.text-glow{text-shadow:0 0 8px currentColor}.phosphor-glow{text-shadow:0 0 4px currentColor,0 0 8px currentColor,0 0 16px currentColor}.overlay-title{font-size:var(--overlay-title-size);font-weight:var(--overlay-title-weight);line-height:var(--overlay-title-line-height);letter-spacing:var(--overlay-title-tracking);color:var(--color-text);margin:0}.overlay-section-title{font-size:var(--overlay-section-title-size);font-weight:var(--overlay-section-title-weight);line-height:var(--overlay-section-title-line-height);letter-spacing:var(--overlay-section-title-tracking);color:var(--color-primary);margin:0 0 var(--space-2) 0}.overlay-subtitle{font-size:var(--overlay-subtitle-size);font-weight:var(--overlay-subtitle-weight);line-height:var(--overlay-subtitle-line-height);color:var(--color-text);margin:0}.overlay-body{font-size:var(--overlay-body-size);font-weight:var(--overlay-body-weight);line-height:var(--overlay-body-line-height);max-width:var(--overlay-body-max-width);color:var(--color-text)}.overlay-body p{margin-bottom:.75em}.overlay-body p:last-child{margin-bottom:0}.overlay-desc,.overlay-description{font-size:var(--overlay-description-size);font-weight:var(--overlay-description-weight);line-height:var(--overlay-description-line-height);color:var(--overlay-description-color)}.overlay-caption{font-size:var(--overlay-caption-size);font-weight:var(--overlay-caption-weight);line-height:var(--overlay-caption-line-height);color:var(--overlay-caption-color)}.overlay-label{font-size:var(--overlay-label-size);font-weight:var(--overlay-label-weight);letter-spacing:var(--overlay-label-tracking);color:var(--overlay-label-color);text-transform:uppercase}.overlay-value{font-family:var(--font-mono);font-size:var(--overlay-value-size);font-weight:var(--overlay-value-weight);font-variant-numeric:tabular-nums;color:var(--color-text)}.overlay-value--sm{font-size:var(--text-base)}.overlay-value--lg{font-size:var(--text-xl)}.overlay-legend{display:flex;flex-wrap:wrap;gap:var(--space-4);font-size:var(--overlay-caption-size);color:var(--overlay-caption-color)}.overlay-legend-item{display:inline-flex;align-items:center;gap:var(--space-1)}.overlay-text-primary{color:var(--color-primary)}.overlay-text-accent{color:var(--color-accent)}.overlay-text-success{color:var(--color-success)}.overlay-text-warning{color:var(--color-warning)}.overlay-text-error{color:var(--color-error)}.overlay-text-muted{color:var(--color-text-muted)}.overlay-text-dim{color:var(--color-text-dim)}@media(max-width:640px){.overlay-title{font-size:var(--text-base)}.overlay-section-title{font-size:var(--text-sm)}.overlay-value{font-size:var(--text-base)}.overlay-value--lg{font-size:var(--text-lg)}}.prose{font-size:var(--text-sm);line-height:var(--leading-relaxed);color:var(--color-text);max-width:60ch}.prose>*+*{margin-top:1em}.prose p{margin-bottom:0}.prose h1,.prose h2,.prose h3,.prose h4,.prose h5,.prose h6{margin-top:1.5em;margin-bottom:.5em;line-height:var(--leading-snug)}.prose h1{font-size:var(--text-2xl)}.prose h2{font-size:var(--text-xl)}.prose h3{font-size:var(--text-lg)}.prose h4{font-size:var(--text-base)}.prose a{color:var(--color-primary);text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px;text-decoration-color:#22d3ee66;transition:color .15s var(--ease-out),text-decoration-color .15s var(--ease-out)}.prose a:hover{color:var(--color-primary-hover, #67e8f9);text-decoration-color:currentColor}.prose ul,.prose ol{padding-left:1.25em;margin-bottom:0}.prose li{margin-bottom:.375em}.prose li:last-child{margin-bottom:0}.prose li>ul,.prose li>ol{margin-top:.375em}.prose code{font-size:.9em;padding:.125em .3em;background:var(--color-background-alt);border-radius:var(--radius-sm);color:var(--color-primary)}.prose pre{margin:1em 0;max-width:100%}.prose pre code{padding:0;background:none;color:inherit}.prose blockquote{margin:1em 0;padding:.5em 1em;border-left:3px solid var(--color-border-light);color:var(--color-text-dim);font-style:normal}.prose strong{font-weight:var(--font-semibold);color:var(--color-text)}.prose em{font-style:italic;color:inherit}.prose hr{margin:1.5em 0;border:none;border-top:1px solid var(--color-border)}.prose--sm{font-size:var(--text-xs)}.prose--lg{font-size:var(--text-base);line-height:var(--leading-loose);max-width:65ch}.prose--centered{margin-left:auto;margin-right:auto}@media(max-width:640px){.prose{font-size:var(--text-sm);max-width:100%}.prose--lg{font-size:var(--text-sm)}}:root{--ease-bounce: cubic-bezier(.68, -.55, .265, 1.55)}.transition-none{transition:none}.transition-all{transition:all var(--duration-normal) var(--ease-in-out)}.transition-colors{transition:color var(--duration-normal) var(--ease-in-out),background-color var(--duration-normal) var(--ease-in-out),border-color var(--duration-normal) var(--ease-in-out)}.transition-opacity{transition:opacity var(--duration-normal) var(--ease-in-out)}.transition-transform{transition:transform var(--duration-normal) var(--ease-in-out)}@keyframes fade-out{0%{opacity:1}to{opacity:0}}.animate-fade-out{animation:fade-out var(--duration-normal) var(--ease-in) forwards}@keyframes slide-up{0%{transform:translateY(8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slide-down{0%{transform:translateY(-8px);opacity:0}to{transform:translateY(0);opacity:1}}@keyframes slide-left{0%{transform:translate(8px);opacity:0}to{transform:translate(0);opacity:1}}@keyframes slide-right{0%{transform:translate(-8px);opacity:0}to{transform:translate(0);opacity:1}}.animate-slide-up{animation:slide-up var(--duration-normal) var(--ease-out) forwards}.animate-slide-down{animation:slide-down var(--duration-normal) var(--ease-out) forwards}.animate-slide-left{animation:slide-left var(--duration-normal) var(--ease-out) forwards}.animate-slide-right{animation:slide-right var(--duration-normal) var(--ease-out) forwards}@keyframes scale-in{0%{transform:scale(.95);opacity:0}to{transform:scale(1);opacity:1}}@keyframes scale-out{0%{transform:scale(1);opacity:1}to{transform:scale(.95);opacity:0}}.animate-scale-in{animation:scale-in var(--duration-normal) var(--ease-spring) forwards}.animate-scale-out{animation:scale-out var(--duration-fast) var(--ease-in) forwards}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.animate-pulse{animation:pulse 2s var(--ease-in-out) infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.animate-blink{animation:blink 1s step-end infinite}@keyframes glow-pulse{0%,to{box-shadow:0 0 3px var(--color-glow, #00ffff),0 0 6px var(--color-glow, #00ffff)}50%{box-shadow:0 0 5px var(--color-glow, #00ffff),0 0 10px var(--color-glow, #00ffff),0 0 14px var(--color-glow, #00ffff)}}.animate-glow-pulse{animation:glow-pulse 2s var(--ease-in-out) infinite}@keyframes scanline{0%{transform:translateY(-100%)}to{transform:translateY(100vh)}}.scanline-overlay:after{content:"";position:fixed;top:0;left:0;right:0;height:4px;background:linear-gradient(to bottom,transparent,rgba(255,255,255,.03),transparent);animation:scanline 8s linear infinite;pointer-events:none;z-index:9999}@keyframes crt-flicker{0%{opacity:1}3%{opacity:.98}6%{opacity:1}9%{opacity:.97}12%{opacity:1}}.crt-flicker{animation:crt-flicker .15s infinite}@keyframes matrix-char-fade{0%{opacity:1;color:var(--color-primary, #00ff00);text-shadow:0 0 8px currentColor}to{opacity:.1;color:var(--color-text-muted, #005500);text-shadow:none}}@keyframes typing-cursor{0%,50%{border-color:var(--color-primary, #00ffff)}51%,to{border-color:transparent}}.typing-cursor:after{content:"";display:inline-block;width:.5em;height:1.1em;margin-left:2px;border-right:2px solid var(--color-primary, #00ffff);animation:typing-cursor 1s step-end infinite;vertical-align:text-bottom}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-spin{animation:spin 1s linear infinite}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-4px)}}.animate-bounce{animation:bounce .5s var(--ease-bounce)}@keyframes shake{0%,to{transform:translate(0)}10%,30%,50%,70%,90%{transform:translate(-4px)}20%,40%,60%,80%{transform:translate(4px)}}.animate-shake{animation:shake .5s var(--ease-in-out)}.theme-transitioning,.theme-transitioning *{transition:background-color var(--duration-slow) var(--ease-in-out),color var(--duration-slow) var(--ease-in-out),border-color var(--duration-slow) var(--ease-in-out),box-shadow var(--duration-slow) var(--ease-in-out)!important}.stagger-children>*{opacity:0;animation:slide-up var(--duration-normal) var(--ease-out) forwards}.stagger-children>*:nth-child(1){animation-delay:0ms}.stagger-children>*:nth-child(2){animation-delay:50ms}.stagger-children>*:nth-child(3){animation-delay:.1s}.stagger-children>*:nth-child(4){animation-delay:.15s}.stagger-children>*:nth-child(5){animation-delay:.2s}.stagger-children>*:nth-child(6){animation-delay:.25s}.stagger-children>*:nth-child(7){animation-delay:.3s}.stagger-children>*:nth-child(8){animation-delay:.35s}@keyframes overlay-backdrop-enter{0%{opacity:0;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}to{opacity:1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}}@keyframes overlay-backdrop-exit{0%{opacity:1;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}to{opacity:0;backdrop-filter:blur(0px);-webkit-backdrop-filter:blur(0px)}}@keyframes overlay-panel-enter{0%{opacity:0;transform:translateY(24px) scale(.96)}60%{opacity:1;transform:translateY(-4px) scale(1.01)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes overlay-panel-exit{0%{opacity:1;transform:translateY(0) scale(1)}to{opacity:0;transform:translateY(12px) scale(.97)}}@keyframes overlay-panel-enter-mobile{0%{opacity:0;transform:translateY(100%)}70%{opacity:1;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}@keyframes overlay-panel-exit-mobile{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(30%)}}.overlay-backdrop-enter{animation:overlay-backdrop-enter .25s var(--ease-out) forwards}.overlay-backdrop-exit{animation:overlay-backdrop-exit .18s var(--ease-in) forwards}.overlay-panel-enter{animation:overlay-panel-enter .4s var(--ease-spring-soft) forwards;animation-delay:80ms;opacity:0}.overlay-panel-exit{animation:overlay-panel-exit .18s var(--ease-in) forwards}.overlay-panel-enter-mobile{animation:overlay-panel-enter-mobile .45s var(--ease-spring-soft) forwards;animation-delay:60ms;opacity:0}.overlay-panel-exit-mobile{animation:overlay-panel-exit-mobile .2s var(--ease-in) forwards}.overlay-content-stagger>*{opacity:0;animation:slide-up var(--duration-normal) var(--ease-out) forwards}.overlay-content-stagger>*:nth-child(1){animation-delay:.15s}.overlay-content-stagger>*:nth-child(2){animation-delay:.19s}.overlay-content-stagger>*:nth-child(3){animation-delay:.23s}.overlay-content-stagger>*:nth-child(4){animation-delay:.27s}.overlay-content-stagger>*:nth-child(5){animation-delay:.31s}.overlay-content-stagger>*:nth-child(6){animation-delay:.35s}@keyframes handle-bounce{0%,to{transform:scaleX(1)}50%{transform:scaleX(1.1)}}.sheet-handle-active{animation:handle-bounce .3s var(--ease-spring) forwards}@media(prefers-reduced-motion:reduce){.animate-fade-in,.animate-fade-out,.animate-slide-up,.animate-slide-down,.animate-slide-left,.animate-slide-right,.animate-scale-in,.animate-scale-out,.animate-pulse,.animate-blink,.animate-glow-pulse,.animate-spin,.animate-bounce,.animate-shake,.overlay-backdrop-enter,.overlay-backdrop-exit,.overlay-panel-enter,.overlay-panel-exit,.overlay-panel-enter-mobile,.overlay-panel-exit-mobile,.overlay-content-stagger>*,.sheet-handle-active,.theme-transitioning,.theme-transitioning *{animation-duration:.01ms!important;animation-iteration-count:1!important;animation:none!important;transition-duration:.01ms!important}.scanline-overlay:after,.with-scanlines:before{display:none!important;animation:none!important}.crt-flicker,.typing-cursor:after{animation:none!important}}@media(hover:none)and (pointer:coarse){.scanline-overlay:after,.with-scanlines:before{display:none!important;animation:none!important}.crt-flicker{animation:none!important}.animate-glow-pulse{animation-duration:4s}}@keyframes content-reveal{0%{opacity:0;transform:translateY(20px) scale(.98)}60%{opacity:1;transform:translateY(-2px) scale(1.005)}to{opacity:1;transform:translateY(0) scale(1)}}.content-reveal>*{opacity:0;animation:content-reveal .5s var(--ease-spring-soft) forwards}.content-reveal>*:nth-child(1){animation-delay:0ms}.content-reveal>*:nth-child(2){animation-delay:60ms}.content-reveal>*:nth-child(3){animation-delay:.12s}.content-reveal>*:nth-child(4){animation-delay:.18s}.content-reveal>*:nth-child(5){animation-delay:.24s}.content-reveal>*:nth-child(6){animation-delay:.3s}.content-reveal>*:nth-child(7){animation-delay:.36s}.content-reveal>*:nth-child(8){animation-delay:.42s}.content-reveal>*:nth-child(9){animation-delay:.48s}.content-reveal>*:nth-child(10){animation-delay:.54s}.content-reveal--fast>*{animation-duration:.3s}.content-reveal--fast>*:nth-child(1){animation-delay:0ms}.content-reveal--fast>*:nth-child(2){animation-delay:40ms}.content-reveal--fast>*:nth-child(3){animation-delay:80ms}.content-reveal--fast>*:nth-child(4){animation-delay:.12s}.content-reveal--fast>*:nth-child(5){animation-delay:.16s}.content-reveal--fast>*:nth-child(6){animation-delay:.2s}.content-reveal--subtle>*{animation:slide-up .4s var(--ease-out) forwards}@keyframes skeleton-exit{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.98)}}@keyframes content-enter{0%{opacity:0;transform:scale(1.02)}to{opacity:1;transform:scale(1)}}.skeleton-crossfade__skeleton{position:absolute;inset:0;z-index:1;animation:skeleton-exit .3s var(--ease-out) forwards}.skeleton-crossfade__content{animation:content-enter .4s var(--ease-out) forwards;animation-delay:.1s;opacity:0}.skeleton-crossfade--loading .skeleton-crossfade__skeleton{animation:none;opacity:1}.skeleton-crossfade--loading .skeleton-crossfade__content{display:none}.skeleton-shimmer{background:linear-gradient(90deg,var(--color-background-alt) 0%,var(--color-background-elevated) 20%,var(--color-background-alt) 40%,var(--color-background-alt) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.content-reveal>*,.content-reveal--fast>*,.content-reveal--subtle>*,.skeleton-crossfade__skeleton,.skeleton-crossfade__content,.skeleton-shimmer{animation:none!important;opacity:1!important;transform:none!important}}@keyframes focus-ring-pulse{0%,to{box-shadow:var(--shadow-focus-ring)}50%{box-shadow:0 0 0 var(--focus-ring-offset) var(--color-background),0 0 0 calc(var(--focus-ring-offset) + var(--focus-ring-width)) var(--focus-ring-color),0 0 12px var(--focus-ring-color-soft)}}@keyframes focus-ring-expand{0%{box-shadow:0 0 0 var(--focus-ring-offset) var(--color-background),0 0 0 var(--focus-ring-offset) var(--focus-ring-color);opacity:.5}to{box-shadow:var(--shadow-focus-ring);opacity:1}}:focus-visible{outline:none}.focus-ring:focus-visible,button:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible,[role=button]:focus-visible,[tabindex]:focus-visible:not([tabindex="-1"]){outline:none;box-shadow:var(--shadow-focus-ring);animation:focus-ring-expand var(--duration-focus) var(--ease-expo-out)}.focus-ring--pulse:focus-visible{animation:focus-ring-pulse 2s var(--ease-smooth) infinite}.skeleton{position:relative;overflow:hidden;background:var(--color-background-elevated);border-radius:var(--radius-md)}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.04) 20%,rgba(255,255,255,.08) 50%,rgba(255,255,255,.04) 80%,transparent 100%);background-size:200% 100%;animation:skeleton-shimmer 1.8s var(--ease-smooth) infinite}.skeleton--pulse{animation:skeleton-pulse 1.5s var(--ease-smooth) infinite}.skeleton--pulse:after{display:none}.skeleton-text{height:1em;width:100%}.skeleton-text--sm{height:.875em;width:60%}.skeleton-avatar{width:40px;height:40px;border-radius:50%}.skeleton-button{height:36px;width:100px;border-radius:var(--radius-lg)}.skeleton-group>.skeleton{animation-delay:calc(var(--skeleton-index, 0) * .1s)}.skeleton-group>:nth-child(1){--skeleton-index: 0}.skeleton-group>:nth-child(2){--skeleton-index: 1}.skeleton-group>:nth-child(3){--skeleton-index: 2}.skeleton-group>:nth-child(4){--skeleton-index: 3}.skeleton-group>:nth-child(5){--skeleton-index: 4}.glass{background:var(--glass-bg);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border)}.glass-elevated{background:var(--glass-bg-elevated);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--glass-border);box-shadow:var(--shadow-floating)}@supports not (backdrop-filter: blur(1px)){.glass,.glass-elevated{background:var(--color-background-elevated)}}:root{--breakpoint-sm: 640px;--breakpoint-md: 768px;--breakpoint-lg: 1024px;--breakpoint-xl: 1280px;--breakpoint-2xl: 1536px}.two-column{display:grid!important;grid-template-columns:minmax(280px,360px) 1fr;gap:var(--space-5);min-height:0;flex:1}@media(min-width:1440px){.two-column{grid-template-columns:minmax(320px,400px) 1fr;gap:var(--space-6)}}@media(min-width:1920px){.two-column{grid-template-columns:minmax(400px,500px) 1fr;gap:var(--space-8)}}@media(min-width:2560px){.two-column{grid-template-columns:minmax(480px,600px) 1fr;gap:var(--space-10)}}@media(min-width:3440px){.two-column{grid-template-columns:minmax(600px,720px) 1fr;gap:var(--space-12)}}@media(min-width:769px)and (max-width:1024px){.two-column{grid-template-columns:minmax(240px,300px) 1fr;gap:var(--space-4)}}@media(max-width:1100px){.two-column{grid-template-columns:1fr;gap:var(--space-4)}.column--detail{order:1}.column--list{order:2}}@media(max-width:640px){.two-column{gap:var(--space-3)}}.column{display:flex;flex-direction:column;gap:var(--space-4);min-height:0;min-width:0}@media(max-width:768px){.column--list .list{max-height:220px;min-height:140px}}.list{display:flex;flex-direction:column;gap:var(--space-2);overflow-y:auto;overscroll-behavior:contain;max-height:60vh;min-height:200px;padding:var(--space-1);margin:calc(-1 * var(--space-1));flex:1}@media(min-width:1024px){.list{max-height:70vh}}@media(min-width:1440px){.list{max-height:75vh;gap:var(--space-3)}}@media(min-width:1920px){.list{max-height:80vh}}@media(min-width:2560px){.list{max-height:85vh}}@media(max-width:768px){.list{max-height:300px;min-height:150px}}.list::-webkit-scrollbar{width:6px}.list::-webkit-scrollbar-track{background:var(--color-background);border-radius:var(--radius-full)}.list::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full);transition:background var(--duration-fast) var(--ease-out)}.list::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}.list-item{display:flex;flex-direction:row;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-3) var(--space-4);background:transparent;border:1px solid transparent;border-radius:var(--radius-lg);cursor:pointer;transition:background .2s var(--ease-out),border-color .2s var(--ease-out),transform .35s var(--ease-spring),box-shadow .2s var(--ease-out);text-align:left;width:100%;color:inherit;font:inherit;position:relative;will-change:transform}.list-item-main{flex:1;min-width:0;display:flex;flex-direction:column;gap:var(--space-1)}.list-item-meta{display:flex;flex-direction:column;align-items:flex-end;gap:var(--space-1);flex-shrink:0}.meta-gc{font-size:var(--text-xs);font-family:var(--font-mono)}@media(max-width:400px){.list-item-meta{display:none}}.list-item:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%) scaleY(0);width:3px;height:60%;background:var(--color-primary);border-radius:var(--radius-full);transition:transform var(--duration-normal) var(--ease-spring)}.list-item:hover{background:var(--color-background-elevated);border-color:var(--color-border-light);transform:translateY(-1px);box-shadow:var(--shadow-sm),0 0 0 1px #ffffff05}.list-item:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus-ring);animation:focus-ring-expand var(--duration-focus) var(--ease-expo-out)}.list-item:active{transform:scale(.98);transition:transform 80ms var(--ease-out),background 80ms var(--ease-out)}.list-item.active{background:var(--color-background-active);border-color:var(--color-primary);box-shadow:var(--shadow-sm),0 0 12px -6px var(--color-glow-soft),inset 0 1px #ffffff08}.list-item.active:before{transform:translateY(-50%) scaleY(1);transition:transform .4s var(--ease-spring)}.list-item.active .list-title{color:var(--color-primary);transition:color .2s var(--ease-out)}.list-item.active:after{content:"";position:absolute;top:0;left:0;right:0;height:50%;background:linear-gradient(180deg,rgba(34,211,238,.04) 0%,transparent 100%);border-radius:var(--radius-lg) var(--radius-lg) 0 0;pointer-events:none}.list-title{font-size:var(--text-base);font-weight:var(--font-medium);color:var(--color-text);line-height:var(--leading-snug);transition:color var(--duration-fast) var(--ease-out)}.list-subtitle{font-size:var(--text-sm);color:var(--color-text-dim);line-height:var(--leading-normal);display:flex;align-items:center;gap:var(--space-2)}.list-subtitle:before{display:none}.detail-card{background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);position:relative;overflow:hidden;box-shadow:var(--shadow-elevated),inset 0 1px #ffffff0d;transition:box-shadow var(--duration-normal) var(--ease-out),transform var(--duration-normal) var(--ease-out)}.detail-card:hover{box-shadow:var(--shadow-lg),inset 0 1px #ffffff0f;transform:translateY(-2px)}.detail-card:after{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.08) 50%,transparent 90%);pointer-events:none}.detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:120px;background:linear-gradient(180deg,var(--color-background-gradient-start) 0%,transparent 100%);pointer-events:none;opacity:.5}.detail-card--glass{background:var(--glass-bg-elevated);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-color:var(--glass-border)}.detail-card>*{position:relative;z-index:1}.detail-card h4{font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);margin:0;line-height:var(--leading-tight);letter-spacing:var(--tracking-tight)}.detail-card>p{margin:0;font-size:var(--text-sm);color:var(--color-text-dim)}.detail-card--enter{animation:content-reveal .4s var(--ease-out, ease-out) forwards}@media(prefers-reduced-motion:reduce){.detail-card--enter{animation:none}}@media(max-width:640px){.detail-card{padding:var(--space-4);gap:var(--space-4)}}.metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-4);padding:var(--space-4);background:var(--color-background);border-radius:var(--radius-lg);border:1px solid var(--color-border-subtle)}.metrics>div{display:flex;flex-direction:column;gap:var(--space-1);padding:var(--space-2) 0}.metric-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wider);line-height:var(--leading-normal)}.metric-value{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);line-height:var(--leading-tight);font-variant-numeric:tabular-nums}.metric-value.primary{color:var(--color-primary)}.metric-value.success{color:var(--color-success)}.metric-value.warning{color:var(--color-warning)}.sequence-preview{display:flex;flex-direction:column;gap:var(--space-3);margin-top:var(--space-2)}.sequence-block{font-family:var(--font-mono);font-size:var(--text-sm);line-height:var(--leading-relaxed);background:var(--color-background);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);overflow-x:auto;overflow-y:auto;white-space:pre-wrap;word-break:break-all;color:var(--color-text-dim);max-height:400px;min-height:200px;overscroll-behavior:contain}@media(min-width:1024px){.sequence-block{max-height:500px;min-height:300px}}@media(min-width:1536px){.sequence-block{max-height:600px}}@media(max-width:640px){.sequence-block{max-height:60vh;min-height:300px;padding:var(--space-3);font-size:var(--text-xs)}.btn{white-space:normal;height:auto;min-height:36px;line-height:1.2;padding:var(--space-2) var(--space-3)}}.sequence-block::-webkit-scrollbar{height:6px;width:6px}.sequence-block::-webkit-scrollbar-track{background:var(--color-background-alt);border-radius:var(--radius-full)}.sequence-block::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full)}.status-line{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) 0;font-size:var(--text-sm);color:var(--color-text-dim)}.progress-bar{flex:1;height:6px;background:var(--color-background);border-radius:var(--radius-full);overflow:hidden;position:relative}.progress-bar:before{content:"";position:absolute;inset:0;box-shadow:inset 0 1px 2px #0000004d;border-radius:var(--radius-full);pointer-events:none}.progress{height:100%;background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-accent) 100%);border-radius:var(--radius-full);transition:width var(--duration-normal) var(--ease-out);position:relative}.progress:after{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.2) 50%,transparent 100%);animation:progress-shine 2s ease-in-out infinite}@keyframes progress-shine{0%{transform:translate(-100%)}to{transform:translate(100%)}}.db-status-bar{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);font-size:var(--text-sm);color:var(--color-text-dim);margin-bottom:var(--space-2)}.db-status-icon{color:var(--color-success);font-weight:var(--font-bold);font-size:var(--text-base)}.db-status-text{flex:1;min-width:0;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media(max-width:768px){.db-status-bar{padding:var(--space-1) var(--space-3)}.db-status-text{display:none}}.panel-compact{padding:var(--space-3)}.panel-compact .panel-header{margin-bottom:var(--space-2)}.panel-compact .panel-header h2{font-size:var(--text-base)}.detail-viewers{display:grid;grid-template-columns:repeat(auto-fit,minmax(320px,1fr));gap:var(--space-4);margin-top:var(--space-4);align-items:stretch;width:min(1200px,100%);margin-left:auto;margin-right:auto}.viewer-panel{min-width:0;display:flex;flex-direction:column;gap:var(--space-2)}@media(min-width:1024px){.detail-viewers{grid-template-columns:1.05fr 1fr;gap:var(--space-5)}}@media(min-width:1440px){.viewer-panel .sequence-block,.viewer-panel .three-container{height:520px}}@media(min-width:2000px){.viewer-panel .sequence-block,.viewer-panel .three-container{height:620px}}@media(max-width:640px){.detail-viewers{gap:var(--space-3)}}@media(max-width:960px)and (orientation:landscape){.detail-viewers{grid-template-columns:1fr 1fr;gap:var(--space-3)}}@media(max-width:768px){.detail-viewers{gap:var(--space-3)}.detail-viewers .sequence-view,.detail-viewers .three-container{min-height:360px}.sequence-view .btn.compact{min-width:40px}}.panel{background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4);box-shadow:var(--shadow-elevated),inset 0 1px #ffffff0a;position:relative}.panel:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 10%,rgba(255,255,255,.08) 50%,transparent 90%);border-radius:var(--radius-xl) var(--radius-xl) 0 0;pointer-events:none}.panel--glass{background:var(--glass-bg-elevated);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border-color:var(--glass-border);box-shadow:var(--shadow-floating)}.panel--elevated{box-shadow:var(--shadow-xl);border-color:var(--color-border-light)}.panel--interactive{transition:box-shadow var(--duration-hover) var(--ease-out),transform var(--duration-hover) var(--ease-out),border-color var(--duration-hover) var(--ease-out);cursor:pointer}.panel--interactive:hover{box-shadow:var(--shadow-lg),0 0 20px #22d3ee14;transform:translateY(-2px);border-color:var(--color-border-light)}.panel--interactive:active{transform:translateY(0);box-shadow:var(--shadow-md)}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-subtle);margin-bottom:var(--space-1)}.panel-header h2,.panel-header h3{font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text);margin:0;letter-spacing:var(--tracking-normal)}@media(max-width:640px){.panel{padding:var(--space-4);border-radius:var(--radius-lg)}}@media(min-width:1440px){.panel{padding:var(--space-6);gap:var(--space-5)}.panel-header{padding-bottom:var(--space-4);gap:var(--space-4)}.panel-header h2,.panel-header h3{font-size:var(--text-lg)}}@media(min-width:1920px){.panel{padding:var(--space-8);gap:var(--space-6);border-radius:var(--radius-2xl)}.panel-header{padding-bottom:var(--space-5)}.panel-header h2,.panel-header h3{font-size:var(--text-xl)}}@media(min-width:2560px){.panel{padding:var(--space-10);gap:var(--space-8)}.panel-header h2,.panel-header h3{font-size:var(--text-2xl)}}.badge{display:inline-flex;align-items:center;justify-content:center;padding:var(--space-1) var(--space-3);font-size:var(--text-xs);font-weight:var(--font-medium);letter-spacing:var(--tracking-wide);text-transform:uppercase;background:var(--color-badge-bg);color:var(--color-badge-text);border-radius:var(--radius-full);border:1px solid var(--color-badge-border);line-height:1;min-width:0;max-width:100%;flex-shrink:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.badge-info{background:#22d3ee26;color:var(--color-info);border-color:#22d3ee4d}.badge-warning{background:#f59e0b26;color:var(--color-warning);border-color:#f59e0b4d}.badge-success{background:#10b98126;color:var(--color-success);border-color:#10b9814d}.badge-error{background:#ef444426;color:var(--color-error);border-color:#ef44444d}.badge.subtle{background:var(--color-background);color:var(--color-text-dim);border-color:var(--color-border)}.badge-small{padding:2px 6px;font-size:var(--text-xs)}.badge-tiny{padding:1px 5px;font-size:10px;font-size:max(10px,var(--text-2xs));letter-spacing:.5px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--btn-padding-y) var(--btn-padding-x);min-height:var(--btn-min-height);font-size:var(--btn-font-size);font-weight:var(--btn-font-weight);letter-spacing:var(--tracking-normal);border-radius:var(--btn-radius);border:1px solid var(--color-border-subtle);background:var(--color-background-elevated);color:var(--color-text);cursor:pointer;transition:background var(--duration-hover) var(--ease-out),border-color var(--duration-hover) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-press) var(--ease-spring-soft),box-shadow var(--duration-hover) var(--ease-out);white-space:nowrap;text-overflow:ellipsis;user-select:none;position:relative;overflow:hidden;will-change:transform,box-shadow;transform:translateZ(0)}@media(max-width:640px){.btn{white-space:normal;text-align:center;line-height:1.2}.btn.compact{white-space:nowrap}}.btn:before{content:"";position:absolute;inset:0;background:linear-gradient(180deg,rgba(255,255,255,.05) 0%,transparent 100%);pointer-events:none}.btn:after{content:"";position:absolute;inset:0;border-radius:inherit;background:radial-gradient(circle at var(--ripple-x, 50%) var(--ripple-y, 50%),rgba(34,211,238,.35) 0%,rgba(34,211,238,.15) 30%,transparent 70%);opacity:0;transform:scale(0);pointer-events:none}.btn:hover{background:var(--color-background-hover);border-color:var(--color-border-light);color:var(--color-text);box-shadow:var(--shadow-elevated),0 0 0 1px #ffffff08;transform:translateY(-1px)}.btn:hover:before{background:linear-gradient(180deg,rgba(255,255,255,.08) 0%,transparent 50%)}.btn:active{transform:scale(.96) translateY(0);background:var(--color-background-active);box-shadow:var(--shadow-xs),inset 0 1px 2px #00000026;transition:transform var(--duration-micro) var(--ease-out),background var(--duration-micro) var(--ease-out),box-shadow var(--duration-micro) var(--ease-out)}.btn:active:after{opacity:1;transform:scale(2);transition:transform .4s var(--ease-out),opacity .1s var(--ease-out)}.btn:not(:active){transition:transform .35s var(--ease-spring),background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.btn:not(:active):after{opacity:0;transition:opacity .3s var(--ease-out)}.btn:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus-ring);animation:focus-ring-expand var(--duration-focus) var(--ease-expo-out)}.btn-primary{background:linear-gradient(180deg,var(--color-primary-hover) 0%,var(--color-primary) 100%);border-color:var(--color-primary);color:var(--color-background);box-shadow:var(--shadow-sm),0 0 0 1px #22d3ee33}.btn-primary:before{background:linear-gradient(180deg,rgba(255,255,255,.15) 0%,transparent 50%)}.btn-primary:after{background:linear-gradient(105deg,transparent 20%,rgba(255,255,255,.2) 35%,rgba(255,255,255,.35) 50%,rgba(255,255,255,.2) 65%,transparent 80%);transform:translate(-150%);transition:transform .6s var(--ease-out)}.btn-primary:hover:after{transform:translate(150%)}.btn-primary:hover{background:linear-gradient(180deg,#7dd3fc 0%,var(--color-primary-hover) 100%);border-color:var(--color-primary-hover);color:var(--color-background);box-shadow:var(--shadow-md),0 0 10px var(--color-glow-soft)}.btn-primary:active{background:var(--color-primary);box-shadow:var(--shadow-xs),inset 0 2px 4px #0003}.btn-primary:active:after{transform:translate(-150%);transition:none}.btn-secondary{background:var(--color-background-alt);border-color:var(--color-border-light);color:var(--color-text);box-shadow:var(--shadow-xs)}.btn-secondary:before{background:linear-gradient(180deg,rgba(255,255,255,.03) 0%,transparent 100%)}.btn-secondary:hover{background:var(--color-background-hover);border-color:var(--color-primary);color:var(--color-primary);box-shadow:var(--shadow-sm),0 0 0 1px #22d3ee1a}.btn-secondary:active{background:var(--color-background-active);border-color:var(--color-primary);box-shadow:var(--shadow-xs),inset 0 1px 2px #0000001a}.btn-ghost{background:transparent;border-color:transparent;box-shadow:none}.btn-ghost:before{display:none}.btn-ghost:hover{background:var(--color-background-hover);border-color:transparent;box-shadow:none}.btn-ghost:active{background:var(--color-background-active)}.btn:disabled,.btn[disabled],.btn.disabled{opacity:.5;cursor:not-allowed;pointer-events:none;background:var(--color-background-alt);border-color:var(--color-border-subtle);color:var(--color-text-muted);box-shadow:none;transform:none}.btn:disabled:before,.btn[disabled]:before,.btn.disabled:before,.btn:disabled:after,.btn[disabled]:after,.btn.disabled:after{display:none}.btn-primary:disabled,.btn-primary[disabled],.btn-primary.disabled{background:var(--color-primary);opacity:.4;color:var(--color-background)}.btn-icon{padding:var(--space-2);min-width:36px;min-height:36px}.btn-sm{padding:var(--btn-padding-y-sm) var(--btn-padding-x-sm);min-height:var(--btn-min-height-sm);font-size:var(--btn-font-size-sm);border-radius:var(--btn-radius-sm)}.btn-lg{padding:var(--btn-padding-y-lg) var(--btn-padding-x-lg);min-height:var(--btn-min-height-lg);font-size:var(--btn-font-size-lg)}.btn.compact{padding:var(--space-1) var(--space-2);min-height:28px;min-width:28px;font-size:var(--text-sm);border-radius:var(--radius-md)}.sequence-view{display:flex;flex-direction:column;border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-background);overflow-x:auto;overflow-y:hidden}.sequence-view__header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-2) var(--space-3);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap;gap:var(--space-2)}.sequence-view__title{color:var(--color-primary);font-weight:var(--font-bold);font-size:var(--text-sm);letter-spacing:var(--tracking-wide)}.sequence-view__controls{display:flex;gap:var(--space-3);align-items:center;flex-wrap:wrap;justify-content:flex-end}@media(max-width:640px){.sequence-view__header{flex-direction:column;align-items:stretch}.sequence-view__controls{justify-content:flex-start;flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;padding:2px 0;scrollbar-width:none;-webkit-overflow-scrolling:touch;margin:0 calc(-1 * var(--space-2));padding-left:var(--space-2);padding-right:var(--space-2);-webkit-mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 14px),transparent 100%);mask-image:linear-gradient(90deg,transparent 0,#000 14px,#000 calc(100% - 14px),transparent 100%);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-size:100% 100%;mask-size:100% 100%}.sequence-view__controls>*{flex:0 0 auto}.sequence-view__controls::-webkit-scrollbar{display:none}.sequence-view__zoom{flex-wrap:nowrap}.sequence-view__range{display:none}}.sequence-view__zoom{display:flex;gap:var(--space-1);align-items:center;flex-wrap:wrap}.sequence-view__zoom-btn{min-width:32px;min-height:32px;padding:var(--space-1) var(--space-3);font-size:var(--text-base)}.sequence-view__zoom-label{font-size:var(--text-xs);padding:var(--space-1) var(--space-2);background:var(--color-background-alt);color:var(--color-text-muted);border-radius:var(--radius-sm);border:1px solid var(--color-border-light);min-width:3.5rem;text-align:center;display:inline-flex;align-items:center;justify-content:center;height:32px}.sequence-view__snap-btn{min-height:32px;padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.sequence-view__snap-btn.is-active{background:var(--color-background-alt);border-color:var(--color-border-light)}.sequence-view__orientation{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-2);display:none}.sequence-view__frame-btn{min-height:36px;padding:var(--space-2) var(--space-3);font-size:var(--text-xs)}.sequence-view__range{font-size:var(--text-xs);color:var(--color-text-muted);margin-left:var(--space-1)}.sequence-view__jump-row,.sequence-view__jump-form{display:flex;gap:var(--space-2);align-items:center;flex-wrap:wrap}.sequence-view__jump-input{width:130px;padding:var(--space-2) var(--space-2);border-radius:var(--radius-md);border:1px solid var(--color-border-light);background:var(--color-background-alt);color:var(--color-text);font-size:var(--text-sm)}.sequence-view__jump-btn{min-height:32px;padding:var(--space-2) var(--space-3)}.sequence-view__jump-status{color:var(--color-text-muted);font-size:var(--text-xs)}.sequence-grid-canvas{background-color:var(--color-background)}.view-mode-toggle{position:relative;display:inline-flex;align-items:stretch;flex-wrap:nowrap;gap:var(--space-2);padding:6px;max-width:100%;overflow:hidden;border-radius:var(--radius-xl);background:var(--view-toggle-bg, var(--color-background-elevated));border:1px solid var(--view-toggle-border, var(--color-border-subtle));box-shadow:var(--shadow-sm)}.view-mode-indicator{position:absolute;top:6px;left:6px;height:calc(100% - 12px);border-radius:var(--radius-md);background:var(--view-toggle-active, var(--color-primary));box-shadow:var(--shadow-md),var(--shadow-primary-glow);pointer-events:none;z-index:0;transition:transform .35s var(--ease-spring-soft),width .3s var(--ease-spring-soft);transform:translate(var(--indicator-x, 0px));width:var(--indicator-width, 100px)}.view-mode-segment{position:relative;z-index:1;display:inline-flex;align-items:center;gap:var(--space-2);padding:10px 14px;min-height:44px;min-width:0;border-radius:var(--radius-md);border:1px solid transparent;background:transparent;color:var(--view-toggle-muted, var(--color-text-muted));cursor:pointer;font-size:var(--text-sm);font-weight:600;letter-spacing:var(--tracking-normal);transition:color var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),transform var(--duration-micro) var(--ease-out)}@media(max-width:768px){.view-mode-segment{min-height:45px}}.view-mode-segment.active{color:var(--view-toggle-active-text, var(--color-background))}.view-mode-toggle:not(.has-indicator) .view-mode-segment.active{background:var(--view-toggle-active, var(--color-primary));box-shadow:var(--shadow-md)}.view-mode-segment:not(.active):hover{background:var(--color-background-hover);color:var(--view-toggle-text, var(--color-text));border-color:var(--view-toggle-border, var(--color-border-light))}.view-mode-segment:active{transform:scale(.97)}.view-mode-segment:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:var(--shadow-focus-ring);animation:focus-ring-expand var(--duration-focus) var(--ease-expo-out)}.view-mode-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}.view-mode-label{font-weight:600}.view-mode-subtle{font-size:var(--text-xs);color:var(--view-toggle-muted, var(--color-text-muted));line-height:1.2}.analysis-menu-item-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;color:var(--color-primary);margin-top:2px}.command-palette-category-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0;color:var(--color-primary)}.command-palette__experience{display:flex;align-items:center;flex-wrap:wrap;gap:var(--space-2)}.command-palette__experience-label{color:var(--color-text-muted);font-size:var(--text-sm);font-weight:var(--font-medium)}.command-palette__experience-btn{padding:.5rem .875rem;min-height:36px;border-radius:var(--radius-md);background:var(--color-background);border-color:var(--color-border);text-transform:capitalize}.command-palette__experience-btn:before,.command-palette__experience-btn:after{display:none}.command-palette__experience-btn:hover{background:var(--color-background-hover);transform:none}.command-palette__experience-btn.is-active{background:var(--color-accent);border-color:var(--color-accent);color:#000;font-weight:var(--font-semibold)}.command-palette__experience-hint{color:var(--color-text-muted);font-size:var(--text-xs)}.command-palette__hints{display:flex;flex-wrap:wrap;gap:var(--space-3) var(--space-4);padding:var(--space-2);border-top:1px solid var(--color-border-light);color:var(--color-text-muted);font-size:var(--text-xs)}@media(max-width:640px){.view-mode-subtle,.command-palette__experience-hint{display:none}}@media(max-width:640px){.list{max-height:300px}}@media(max-width:768px){.metrics{grid-template-columns:repeat(2,1fr);gap:var(--space-3)}}@media(hover:none)and (pointer:coarse){.list-item{padding:var(--space-4);min-height:60px}.btn{min-height:44px;padding:var(--space-3) var(--space-5)}.list-item:hover{background:transparent;border-color:transparent}.list-item.active:hover{background:var(--color-background-active);border-color:var(--color-primary)}.btn,.list-item,[role=button],button{touch-action:manipulation;transition:transform var(--duration-micro) var(--ease-out),background var(--duration-micro) var(--ease-out),box-shadow var(--duration-micro) var(--ease-out)}.btn:active,.list-item:active{transform:scale(.97);background:var(--color-background-active);transition:transform 0ms,background 0ms}.touch-highlight{-webkit-tap-highlight-color:rgba(34,211,238,.15)}}@supports (-webkit-touch-callout: none){.btn,.list-item,[role=button]{-webkit-touch-callout:none;-webkit-tap-highlight-color:rgba(34,211,238,.12)}}.learn-menu{position:relative}.learn-menu-trigger-icon,.learn-menu-trigger-chevron{display:inline-flex;align-items:center;justify-content:center;line-height:0}.learn-menu-popover{position:absolute;right:0;margin-top:var(--space-2);min-width:280px;max-width:min(360px,90vw);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:12px;box-shadow:var(--shadow-lg, 0 12px 36px rgba(0,0,0,.35));z-index:20;padding:var(--space-2)}@media(max-width:640px){.learn-menu-popover{position:fixed;left:var(--space-3);right:var(--space-3);bottom:calc(var(--control-deck-reserved-height, 140px) + var(--space-3) + env(safe-area-inset-bottom,0px));top:auto;min-width:0;max-width:none;margin-top:0;max-height:60vh;overflow-y:auto}}.learn-menu-section+.learn-menu-section{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-subtle)}.learn-menu-section-title{padding:var(--space-1) var(--space-2);font-size:10px;letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);user-select:none}.learn-menu-item{width:100%;justify-content:flex-start;text-align:left;padding:var(--space-3);border-radius:12px;gap:var(--space-3);white-space:normal;line-height:1.2}.learn-menu-item.btn-ghost{border-color:transparent}.learn-menu-item.btn-ghost:hover{border-color:var(--color-border-subtle);background:var(--color-background-hover)}.learn-menu-item-icon{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;flex:0 0 22px;color:var(--color-primary);line-height:0}.learn-menu-item-content{display:flex;flex-direction:column;gap:2px}.learn-menu-item-title{font-weight:var(--font-semibold);color:var(--color-text)}.learn-menu-item-desc{font-size:var(--text-xs);color:var(--color-text-muted)}.settings-overlay{display:flex;flex-direction:column;gap:var(--space-4)}.settings-section{display:flex;flex-direction:column;gap:var(--space-3)}.settings-section-header{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text)}.settings-section-title{margin:0;font-size:var(--text-sm);font-weight:var(--font-bold);color:var(--color-text)}.settings-row{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.settings-row--top{align-items:flex-start}.settings-row-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.settings-row-label{font-weight:var(--font-bold);color:var(--color-text)}.settings-row-desc{color:var(--color-text-muted);font-size:var(--text-xs);line-height:1.4}.input.settings-select{min-width:160px;width:auto;flex:0 0 auto;background:var(--color-background);border-color:var(--color-border-light)}.settings-paragraph{margin:var(--space-2) 0;color:var(--color-text-dim);line-height:1.5}.settings-meta{margin:0;color:var(--color-text-muted);font-size:var(--text-xs)}.settings-row-actions{display:flex;align-items:center}.settings-footer{display:flex;justify-content:flex-end}@media(max-width:768px){.settings-row{flex-direction:column;align-items:stretch}.input.settings-select{min-width:0;width:100%}.settings-footer{justify-content:stretch}.settings-footer .btn{width:100%}}.glossary-panel{display:grid;grid-template-columns:minmax(220px,280px) 1fr;gap:var(--space-3);height:100%;min-height:360px;position:relative}.glossary-panel__sidebar{display:flex;flex-direction:column;gap:var(--space-2);min-width:0}.glossary-panel__controls{display:flex;flex-direction:column;gap:var(--space-2)}.glossary-panel__search-row{display:flex;align-items:center;position:relative;background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out),background .2s var(--ease-out)}.glossary-panel__search-row:focus-within{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #22d3ee26;background:var(--color-background)}.glossary-panel__search-icon{display:flex;align-items:center;justify-content:center;padding-left:var(--space-3);color:var(--color-text-muted);pointer-events:none}.glossary-panel__search{flex:1;background:transparent;border:none;padding-left:var(--space-2)}.glossary-panel__search:focus{outline:none;box-shadow:none}.glossary-panel__search-clear{display:flex;align-items:center;justify-content:center;padding:var(--space-2);margin-right:var(--space-1);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-muted);cursor:pointer;transition:color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out)}.glossary-panel__search-clear:hover{color:var(--color-text);background:var(--color-background-hover)}.glossary-panel__search-clear:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.glossary-panel__chips{display:flex;gap:6px;overflow-x:auto;padding-bottom:2px}.glossary-panel__chips--alpha{flex-wrap:wrap;overflow:visible;padding-bottom:0}.glossary-panel__list{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);overflow:hidden;flex:1;min-height:220px;background:var(--color-background)}.glossary-panel__listbox{max-height:100%;overflow-y:auto;display:flex;flex-direction:column}.glossary-panel__term{text-align:left;padding:var(--space-3) var(--space-4);background:transparent;color:var(--color-text);border:none;border-bottom:1px solid var(--color-border-subtle);cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.glossary-panel__term:hover{background:var(--color-background-hover)}.glossary-panel__term[aria-selected=true]{background:#22d3ee14;border-left:2px solid var(--color-primary)}.glossary-panel__term[aria-selected=true]:hover{background:#22d3ee1f}.glossary-panel__term:focus-visible{outline:none;background:var(--color-background-hover);box-shadow:inset 0 0 0 2px var(--color-border-focus)}.glossary-panel__term-title{font-weight:var(--font-bold)}.glossary-panel__term-desc{color:var(--color-text-muted);font-size:var(--text-xs)}.glossary-panel__list-header{display:flex;align-items:center;padding:var(--space-1) 0}.glossary-panel__count{font-size:var(--text-2xs);color:var(--color-text-dim);letter-spacing:.02em}.glossary-panel__empty{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);padding:var(--space-6) var(--space-4);color:var(--color-text-muted);text-align:center}.glossary-panel__empty-icon{font-size:var(--text-xl);opacity:.5}.glossary-panel__detail{border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-3) var(--space-4);background:var(--color-background-alt);min-height:240px}.glossary-panel__detail-header{display:flex;justify-content:space-between;align-items:center}.glossary-panel__detail-eyebrow{font-size:var(--text-2xs);letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted)}.glossary-panel__detail-title{font-size:var(--text-lg);font-weight:800}.glossary-panel__detail-body{margin-top:var(--space-2);line-height:1.5;color:var(--color-text)}.glossary-panel__related{margin-top:var(--space-3)}.glossary-panel__related-label{font-size:var(--text-2xs);letter-spacing:.12em;text-transform:uppercase;color:var(--color-text-muted);margin-bottom:var(--space-2)}.glossary-panel__related-list{display:flex;gap:var(--space-2);flex-wrap:wrap}.glossary-panel__related-chip{font-size:var(--text-xs);padding:4px 10px;border-radius:var(--radius-full);background:#22d3ee1a;color:var(--color-primary);border:1px solid rgba(34,211,238,.2);cursor:pointer;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out)}.glossary-panel__related-chip:hover{background:#22d3ee2e;border-color:#22d3ee59}.glossary-panel__related-chip:active{background:#22d3ee40}.glossary-panel__related-chip:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.glossary-panel__empty-detail{color:var(--color-text-muted)}@media(max-width:720px){.glossary-panel{grid-template-columns:1fr}}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8) var(--space-4);text-align:center;min-height:200px}.empty-state__icon{display:flex;align-items:center;justify-content:center;width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,var(--color-background-alt),var(--color-background-hover));border:1px solid var(--color-border-subtle);margin-bottom:var(--space-4);color:var(--color-text-muted);font-size:28px}.empty-state__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.empty-state__description{font-size:var(--text-sm);color:var(--color-text-muted);max-width:320px;line-height:1.5}.empty-state__action{margin-top:var(--space-4)}@keyframes empty-state-pulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:.8;transform:scale(1.02)}}.empty-state__icon--animated{animation:empty-state-pulse 3s ease-in-out infinite}.toast{position:fixed;left:50%;transform:translate(-50%);bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px));z-index:var(--z-toast, 600);padding:var(--space-3) var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);font-size:var(--text-sm);max-width:calc(100vw - var(--space-8));animation:toast-slide-in var(--duration-normal) var(--ease-out)}@keyframes toast-slide-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.toast-info{border-color:var(--color-info);background:linear-gradient(135deg,var(--color-background-elevated),rgba(34,211,238,.05))}.toast-success{border-color:var(--color-success);background:linear-gradient(135deg,var(--color-background-elevated),rgba(16,185,129,.05))}.toast-warning{border-color:var(--color-warning);background:linear-gradient(135deg,var(--color-background-elevated),rgba(245,158,11,.05))}.toast-error{border-color:var(--color-error);background:linear-gradient(135deg,var(--color-background-elevated),rgba(239,68,68,.05))}.blocked-hotkey-toast{display:flex;align-items:flex-start;gap:var(--space-4)}.blocked-hotkey-toast__body{flex:1;min-width:0}.blocked-hotkey-toast__title{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-semibold);color:var(--color-warning);margin-bottom:var(--space-1)}.blocked-hotkey-toast__text{color:var(--color-text);font-size:var(--text-sm)}.blocked-hotkey-toast__subtext{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:var(--space-1)}.blocked-hotkey-toast__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}.fx-safe-mode-toast{display:flex;align-items:flex-start;gap:var(--space-4)}.fx-safe-mode-toast__body{flex:1;min-width:0}.fx-safe-mode-toast__title{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-semibold);color:var(--color-warning);margin-bottom:var(--space-1)}.fx-safe-mode-toast__text{color:var(--color-text);font-size:var(--text-sm)}.fx-safe-mode-toast__subtext{color:var(--color-text-muted);font-size:var(--text-xs);margin-top:var(--space-1)}.fx-safe-mode-toast__actions{display:flex;align-items:center;gap:var(--space-2);flex-shrink:0}@media(max-width:640px){.toast{bottom:calc(var(--control-deck-reserved-height, 140px) + var(--space-4) + env(safe-area-inset-bottom,0px))}.blocked-hotkey-toast{align-items:stretch;gap:var(--space-3)}.blocked-hotkey-toast__actions{justify-content:flex-end}.fx-safe-mode-toast{align-items:stretch;gap:var(--space-3)}.fx-safe-mode-toast__actions{justify-content:flex-end}}.viewer-placeholder{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:300px;padding:var(--space-6);text-align:center;background:radial-gradient(circle at 30% 30%,rgba(34,211,238,.08),transparent 50%),radial-gradient(circle at 70% 70%,rgba(192,132,252,.08),transparent 50%),var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg)}.viewer-placeholder__icon{width:80px;height:80px;margin-bottom:var(--space-4);opacity:.6;color:var(--color-primary)}.viewer-placeholder__title{font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:var(--space-2)}.viewer-placeholder__description{font-size:var(--text-sm);color:var(--color-text-muted);max-width:280px;line-height:1.5;margin-bottom:var(--space-4)}@media print{.app-header,.app-footer,.crt-overlay{display:none!important}.panel,.detail-card{break-inside:avoid;border:1px solid var(--color-border-light);box-shadow:none}}kbd,.kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.5em;padding:2px 6px;font-family:var(--font-mono, monospace);font-size:max(.85em,10px);line-height:1.2;background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);box-shadow:0 1px 0 var(--color-border-light);white-space:nowrap;transition:background-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}kbd:hover,.kbd:hover{background:var(--color-background-hover)}@media(max-width:640px){kbd{font-size:max(.9em,11px)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up-fade{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-down-fade{0%{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}@keyframes scale-up-fade{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}@keyframes content-reveal{0%{opacity:0;transform:translateY(8px);filter:blur(2px)}to{opacity:1;transform:translateY(0);filter:blur(0)}}.animate-fade-in{animation:fade-in var(--duration-normal) var(--ease-out) forwards}.animate-slide-up{animation:slide-up-fade var(--duration-normal) var(--ease-expo-out) forwards}.animate-slide-down{animation:slide-down-fade var(--duration-normal) var(--ease-expo-out) forwards}.animate-scale-up{animation:scale-up-fade var(--duration-normal) var(--ease-spring-soft) forwards}.animate-content-reveal{animation:content-reveal var(--duration-slow) var(--ease-expo-out) forwards}.animate-stagger>*{opacity:0;animation:slide-up-fade var(--duration-normal) var(--ease-expo-out) forwards}.animate-stagger>:nth-child(1){animation-delay:0ms}.animate-stagger>:nth-child(2){animation-delay:50ms}.animate-stagger>:nth-child(3){animation-delay:.1s}.animate-stagger>:nth-child(4){animation-delay:.15s}.animate-stagger>:nth-child(5){animation-delay:.2s}.animate-stagger>:nth-child(6){animation-delay:.25s}.animate-stagger>:nth-child(7){animation-delay:.3s}.animate-stagger>:nth-child(8){animation-delay:.35s}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}.animate-fade-in,.animate-slide-up,.animate-slide-down,.animate-scale-up,.animate-content-reveal,.animate-stagger>*{animation:none;opacity:1;transform:none;filter:none}}@keyframes spinner-rotate{to{transform:rotate(360deg)}}@keyframes spinner-dash{0%{stroke-dasharray:1,150;stroke-dashoffset:0}50%{stroke-dasharray:90,150;stroke-dashoffset:-35}to{stroke-dasharray:90,150;stroke-dashoffset:-124}}.spinner{width:24px;height:24px;animation:spinner-rotate 2s linear infinite}.spinner-track{stroke:var(--color-border-subtle);stroke-width:3;fill:none}.spinner-fill{stroke:var(--color-primary);stroke-width:3;stroke-linecap:round;fill:none;animation:spinner-dash 1.5s var(--ease-in-out) infinite}.spinner--sm{width:16px;height:16px}.spinner--lg{width:40px;height:40px}.tooltip{position:absolute;z-index:var(--z-tooltip);padding:var(--space-2) var(--space-3);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);box-shadow:var(--shadow-floating);font-size:var(--text-xs);color:var(--color-text);white-space:nowrap;pointer-events:none;opacity:0;transform:translateY(4px);transition:opacity var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.tooltip--visible{opacity:1;transform:translateY(0)}.tooltip:before{content:"";position:absolute;width:8px;height:8px;background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-right:none;border-bottom:none;transform:rotate(45deg)}.tooltip--top:before{bottom:-5px;left:50%;margin-left:-4px;transform:rotate(-135deg)}.tooltip--bottom:before{top:-5px;left:50%;margin-left:-4px;transform:rotate(45deg)}.error-boundary{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:var(--space-6);background:repeating-linear-gradient(-45deg,transparent,transparent 40px,rgba(239,68,68,.02) 40px,rgba(239,68,68,.02) 80px),radial-gradient(ellipse at 50% 30%,rgba(239,68,68,.06) 0%,transparent 50%),var(--color-background);text-align:center}.error-boundary__card{max-width:480px;width:100%;padding:var(--space-8);background:var(--color-background-elevated);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-xl),0 0 40px #ef444414;position:relative;overflow:hidden}.error-boundary__card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:linear-gradient(90deg,var(--color-error),var(--color-warning),var(--color-error));background-size:200% 100%;animation:error-gradient-shift 4s ease infinite}@keyframes error-gradient-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}.error-boundary__icon{display:flex;align-items:center;justify-content:center;width:72px;height:72px;margin:0 auto var(--space-5);background:#ef44441a;border-radius:50%;color:var(--color-error);animation:error-pulse 2s ease-in-out infinite}@keyframes error-pulse{0%,to{box-shadow:0 0 #ef444433}50%{box-shadow:0 0 0 12px #ef444400}}@media(prefers-reduced-motion:reduce){.error-boundary__card:before,.error-boundary__icon{animation:none}}.error-boundary__title{margin:0 0 var(--space-3);font-size:var(--text-xl);font-weight:var(--font-bold);color:var(--color-text);letter-spacing:var(--tracking-tight)}.error-boundary__message{margin:0 0 var(--space-6);color:var(--color-text-dim);line-height:1.6;font-size:var(--text-base)}.error-boundary__details{padding:var(--space-4);margin-bottom:var(--space-6);background:var(--color-background);border:1px solid var(--color-border-subtle);border-left:3px solid var(--color-error);border-radius:var(--radius-md);text-align:left;overflow:auto;max-height:360px}.error-boundary__details-summary{cursor:pointer;user-select:none;font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.error-boundary__details-summary::marker{color:var(--color-text-muted)}.error-boundary__details[open] .error-boundary__details-summary{margin-bottom:var(--space-3)}.error-boundary__code{font-family:var(--font-mono);font-size:var(--text-sm);color:var(--color-error);word-break:break-word;white-space:pre-wrap;margin:0}.error-boundary__actions{display:flex;gap:var(--space-3);justify-content:center;flex-wrap:wrap}.error-boundary__btn-primary{min-width:160px}.error-boundary__btn-secondary{min-width:120px}@media(max-width:640px){.error-boundary{padding:var(--space-4)}.error-boundary__card{padding:var(--space-6)}.error-boundary__actions{flex-direction:column}.error-boundary__btn-primary,.error-boundary__btn-secondary{width:100%}}.feature-error{display:flex;flex-direction:column;gap:var(--space-3);padding:var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border-light);border-left:3px solid var(--color-error);border-radius:var(--radius-lg);text-align:left}.feature-error__content{display:flex;align-items:flex-start;gap:var(--space-3)}.feature-error__icon{flex-shrink:0;color:var(--color-error);margin-top:2px}.feature-error__text{display:flex;flex-direction:column;gap:var(--space-1);min-width:0}.feature-error__title{font-size:var(--text-sm);font-weight:var(--font-semibold);color:var(--color-text)}.feature-error__message{font-size:var(--text-sm);color:var(--color-text-dim);word-break:break-word}.feature-error__actions{display:flex;align-items:center;gap:var(--space-2);padding-top:var(--space-2)}.feature-error__toggle{display:inline-flex;align-items:center;gap:var(--space-1)}.feature-error__details{margin:0;padding:var(--space-3);background:var(--color-background);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);font-family:var(--font-mono);font-size:var(--text-xs);color:var(--color-error);white-space:pre-wrap;word-break:break-word;max-height:200px;overflow:auto}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;padding:var(--space-8);min-height:200px}.empty-state__icon{display:flex;align-items:center;justify-content:center;width:80px;height:80px;margin-bottom:var(--space-4);background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:50%;color:var(--color-text-muted);transition:color var(--duration-normal) var(--ease-out),background var(--duration-normal) var(--ease-out),border-color var(--duration-normal) var(--ease-out)}.empty-state:hover .empty-state__icon{color:var(--color-primary);background:#22d3ee14;border-color:var(--color-primary)}.empty-state__title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:var(--font-semibold);color:var(--color-text);letter-spacing:var(--tracking-tight)}.empty-state__description{margin:0 0 var(--space-5);max-width:320px;font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5}.empty-state__content{margin-bottom:var(--space-5);max-width:360px}.empty-state__actions{display:flex;gap:var(--space-3);flex-wrap:wrap;justify-content:center}.empty-state--compact{padding:var(--space-5);min-height:140px}.empty-state--compact .empty-state__icon{width:56px;height:56px;margin-bottom:var(--space-3)}.empty-state--compact .empty-state__title{font-size:var(--text-base);margin-bottom:var(--space-1)}.empty-state--compact .empty-state__description{font-size:var(--text-xs);margin-bottom:var(--space-4)}.empty-state--large{padding:var(--space-10);min-height:300px}.empty-state--large .empty-state__icon{width:100px;height:100px;margin-bottom:var(--space-5)}.empty-state--large .empty-state__title{font-size:var(--text-xl);margin-bottom:var(--space-3)}.empty-state--large .empty-state__description{font-size:var(--text-base);max-width:400px}.empty-state--search .empty-state__icon{color:var(--color-primary);background:#22d3ee14;border-color:#22d3ee33}.empty-state--error .empty-state__icon{color:var(--color-error);background:#ef444414;border-color:#ef444433}.empty-state--loading .empty-state__icon{animation:empty-state-pulse 2s ease-in-out infinite}@keyframes empty-state-pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(.95)}}.empty-state--animate-in>*{opacity:0;animation:slide-up var(--duration-normal, .3s) var(--ease-out, ease-out) forwards}.empty-state--animate-in>.empty-state__icon{animation-delay:.1s}.empty-state--animate-in>.empty-state__title{animation-delay:.18s}.empty-state--animate-in>.empty-state__description{animation-delay:.26s}.empty-state--animate-in>.empty-state__content{animation-delay:.3s}.empty-state--animate-in>.empty-state__actions{animation-delay:.34s}@media(max-width:640px){.empty-state{padding:var(--space-6);min-height:160px}.empty-state__icon{width:64px;height:64px}.empty-state__title{font-size:var(--text-base)}.empty-state__description{font-size:var(--text-sm)}.empty-state__actions{flex-direction:column;width:100%}.empty-state__actions .btn{width:100%}}@media(prefers-reduced-motion:reduce){.empty-state--animate-in>*{animation:none;opacity:1}}.three-container{cursor:grab}.three-container:active{cursor:grabbing}.gene-map-canvas,.gene-map-canvas canvas{cursor:crosshair}.zoomable-image,img[data-zoomable]{cursor:zoom-in}.zoomable-image--zoomed,img[data-zoomable].zoomed{cursor:zoom-out}.gesture-onboarding{position:fixed;inset:0;z-index:var(--z-modal);display:flex;align-items:flex-end;justify-content:center;padding:var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px));animation:fade-in .3s var(--ease-out) forwards}.gesture-onboarding--exit{animation:fade-out .3s var(--ease-in) forwards}.gesture-onboarding__backdrop{position:absolute;inset:0;background:#0009;backdrop-filter:blur(4px);-webkit-backdrop-filter:blur(4px)}.gesture-onboarding__card{position:relative;width:100%;max-width:340px;padding:var(--space-6);background:var(--color-background-elevated);border:1px solid var(--color-border-light);border-radius:var(--radius-2xl);box-shadow:var(--shadow-2xl);text-align:center;animation:slide-up .4s var(--ease-spring-soft) forwards}.gesture-onboarding--exit .gesture-onboarding__card{animation:slide-down .25s var(--ease-in) forwards}@keyframes slide-down{0%{opacity:1;transform:translateY(0)}to{opacity:0;transform:translateY(20px)}}.gesture-onboarding__close{position:absolute;top:var(--space-3);right:var(--space-3);display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:none;border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.gesture-onboarding__close:hover{background:var(--color-background-hover);color:var(--color-text)}.gesture-onboarding__title{margin:0 0 var(--space-2);font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text)}.gesture-onboarding__description{margin:0 0 var(--space-5);font-size:var(--text-sm);color:var(--color-text-muted);line-height:1.5}.gesture-onboarding__demo{display:flex;justify-content:center;margin-bottom:var(--space-5);padding:var(--space-4)}.gesture-onboarding__demo-hand{position:relative;display:flex;align-items:center;justify-content:center;gap:var(--space-3)}.gesture-onboarding__demo-arrows{display:flex;align-items:center;gap:var(--space-4)}.gesture-onboarding__demo-finger{width:40px;height:40px;background:var(--color-primary);border-radius:50%;box-shadow:0 0 20px #22d3ee66,0 0 40px #22d3ee33;animation:gesture-demo 2s ease-in-out infinite}@keyframes gesture-demo{0%,to{transform:translate(0)}25%{transform:translate(-20px)}75%{transform:translate(20px)}}.gesture-onboarding__arrow{color:var(--color-text-muted);opacity:.6;transition:opacity var(--duration-fast) var(--ease-out)}.gesture-onboarding__arrow--left{animation:arrow-pulse-left 2s ease-in-out infinite}.gesture-onboarding__arrow--right{animation:arrow-pulse-right 2s ease-in-out infinite}@keyframes arrow-pulse-left{0%,50%,to{opacity:.4;transform:translate(0)}25%{opacity:1;transform:translate(-4px)}}@keyframes arrow-pulse-right{0%,50%,to{opacity:.4;transform:translate(0)}75%{opacity:1;transform:translate(4px)}}.gesture-onboarding__button{width:100%}@media(prefers-reduced-motion:reduce){.gesture-onboarding,.gesture-onboarding__card,.gesture-onboarding__demo-finger,.gesture-onboarding__arrow--left,.gesture-onboarding__arrow--right{animation:none!important;opacity:1!important;transform:none!important}}.dna-spinner{display:inline-flex;align-items:center;justify-content:center}.dna-spinner__svg{width:100%;height:100%}.dna-spinner__pair{animation:dna-helix-rotate 1.5s ease-in-out infinite;transform-origin:18px center}@keyframes dna-helix-rotate{0%{transform:perspective(100px) rotateY(0);opacity:.4}25%{opacity:1}50%{transform:perspective(100px) rotateY(180deg);opacity:.4}75%{opacity:1}to{transform:perspective(100px) rotateY(360deg);opacity:.4}}.dna-spinner__nucleotide{transition:fill .2s var(--ease-out)}.dna-spinner__nucleotide--left{fill:var(--nucleotide-a-fg, #ef4444);animation:dna-nucleotide-pulse-left 1.5s ease-in-out infinite}.dna-spinner__nucleotide--right{fill:var(--nucleotide-t-fg, #22c55e);animation:dna-nucleotide-pulse-right 1.5s ease-in-out infinite}@keyframes dna-nucleotide-pulse-left{0%,50%,to{fill:var(--nucleotide-a-fg, #ef4444);filter:drop-shadow(0 0 2px rgba(239,68,68,.5))}25%{fill:var(--nucleotide-c-fg, #3b82f6);filter:drop-shadow(0 0 4px rgba(59,130,246,.6))}75%{fill:var(--nucleotide-g-fg, #f59e0b);filter:drop-shadow(0 0 4px rgba(245,158,11,.6))}}@keyframes dna-nucleotide-pulse-right{0%,50%,to{fill:var(--nucleotide-t-fg, #22c55e);filter:drop-shadow(0 0 2px rgba(34,197,94,.5))}25%{fill:var(--nucleotide-g-fg, #f59e0b);filter:drop-shadow(0 0 4px rgba(245,158,11,.6))}75%{fill:var(--nucleotide-c-fg, #3b82f6);filter:drop-shadow(0 0 4px rgba(59,130,246,.6))}}.dna-spinner__bond{stroke:var(--color-border-light);stroke-linecap:round;opacity:.6}.dna-spinner--small{width:24px;height:32px}.dna-spinner--medium{width:36px;height:48px}.dna-spinner--large{width:48px;height:64px}@media(prefers-reduced-motion:reduce){.dna-spinner__pair{animation:none!important;opacity:1!important;transform:none!important}.dna-spinner__nucleotide--left,.dna-spinner__nucleotide--right{animation:none!important}.dna-spinner{animation:pulse 2s ease-in-out infinite}}.animated-icon{display:inline-flex;align-items:center;justify-content:center;line-height:0}.animated-icon--rotate{animation:icon-rotate var(--animation-duration, .3s) var(--ease-spring) forwards}@keyframes icon-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animated-icon--bounce{animation:icon-bounce var(--animation-duration, .3s) var(--ease-spring) forwards}@keyframes icon-bounce{0%,to{transform:translateY(0)}30%{transform:translateY(-6px)}50%{transform:translateY(2px)}70%{transform:translateY(-2px)}}.animated-icon--shake{animation:icon-shake var(--animation-duration, .3s) var(--ease-out) forwards}@keyframes icon-shake{0%,to{transform:translate(0)}20%{transform:translate(-4px)}40%{transform:translate(4px)}60%{transform:translate(-3px)}80%{transform:translate(3px)}}.animated-icon--pulse{animation:icon-pulse var(--animation-duration, 1s) var(--ease-in-out) infinite}@keyframes icon-pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.15);opacity:.8}}.animated-icon--spin{animation:icon-spin var(--animation-duration, 1s) linear infinite}@keyframes icon-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animated-icon--pop{animation:icon-pop var(--animation-duration, .3s) var(--ease-spring) forwards}@keyframes icon-pop{0%{transform:scale(0);opacity:0}60%{transform:scale(1.2);opacity:1}to{transform:scale(1)}}.animated-icon--wobble{animation:icon-wobble var(--animation-duration, .3s) var(--ease-spring) forwards}@keyframes icon-wobble{0%,to{transform:rotate(0)}25%{transform:rotate(-8deg)}50%{transform:rotate(6deg)}75%{transform:rotate(-4deg)}}@media(prefers-reduced-motion:reduce){.animated-icon--rotate,.animated-icon--bounce,.animated-icon--shake,.animated-icon--pulse,.animated-icon--spin,.animated-icon--pop,.animated-icon--wobble{animation:none!important;transform:none!important}}.swipe-indicator{position:fixed;top:50%;transform:translateY(-50%);z-index:var(--z-toast);pointer-events:none;opacity:0;transition:opacity .3s ease;display:flex;align-items:center;justify-content:center;width:48px;height:80px;color:var(--color-primary);filter:drop-shadow(0 0 8px rgba(0,0,0,.5))}button.swipe-indicator{pointer-events:auto;cursor:pointer;background:transparent;border:none;outline:none}button.swipe-indicator:active{transform:translateY(-50%) scale(.9)}.swipe-indicator--left{left:0;background:linear-gradient(90deg,rgba(0,0,0,.3) 0%,transparent 100%);border-top-right-radius:40px;border-bottom-right-radius:40px;justify-content:flex-start;padding-left:8px}.swipe-indicator--right{right:0;background:linear-gradient(-90deg,rgba(0,0,0,.3) 0%,transparent 100%);border-top-left-radius:40px;border-bottom-left-radius:40px;justify-content:flex-end;padding-right:8px}.swipe-indicator:not(.swipe-indicator--hidden){opacity:.85}.swipe-indicator--subtle:not(.swipe-indicator--hidden){opacity:.5}.swipe-indicator--pulse{animation:swipe-pulse 2s infinite}@keyframes swipe-pulse{0%{opacity:.4;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.1)}to{opacity:.4;transform:translateY(-50%) scale(1)}}.swipe-indicator__arrow{width:32px;height:32px}@media(min-width:641px){.swipe-indicator{display:none}}body{background:var(--color-background);color:var(--color-text);min-height:100vh;min-height:100dvh}#root{min-height:100vh;min-height:100dvh;min-height:var(--app-height, 100vh);display:flex;flex-direction:column}.app-shell{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh;min-height:var(--app-height, 100vh);background:var(--color-background)}.flex{display:flex}.flex-col{flex-direction:column}.flex-row{flex-direction:row}.flex-1{flex:1}.flex-none{flex:none}.items-center{align-items:center}.items-start{align-items:flex-start}.items-end{align-items:flex-end}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.justify-start{justify-content:flex-start}.justify-end{justify-content:flex-end}.grid{display:grid}.w-full{width:100%}.h-full{height:100%}.min-h-screen{min-height:100vh;min-height:100dvh}.hidden{display:none!important}.invisible{visibility:hidden}[disabled],.disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.loading{position:relative;pointer-events:none}.loading:after{content:"";position:absolute;inset:0;background:var(--color-background);opacity:.7}.panel-body{padding:var(--space-4)}.panel:focus-within{border-color:var(--color-border-focus);outline:var(--focus-ring-width) solid var(--focus-ring-color-soft);outline-offset:var(--focus-ring-offset)}.btn:not(:focus-visible):hover{box-shadow:var(--shadow-sm)}.btn:not(:focus-visible):active{box-shadow:var(--shadow-inner)}.input{width:100%;padding:var(--space-2) var(--space-3);font-size:var(--text-sm);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text);transition:border-color var(--duration-fast) var(--ease-out),background var(--duration-fast) var(--ease-out),box-shadow var(--duration-focus) var(--ease-out)}.input:focus{outline:none;border-color:var(--color-primary);background:var(--color-background-alt);box-shadow:var(--shadow-focus-ring),inset 0 1px 2px #0000002e}.input::placeholder{color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.input:focus::placeholder{color:var(--color-text-dim)}.divider{height:1px;background:var(--color-separator);margin:var(--space-4) 0}.divider-vertical{width:1px;height:100%;background:var(--color-separator);margin:0 var(--space-4)}.scrollable{overflow:auto;overscroll-behavior:contain}.scrollable-x{overflow-x:auto;overflow-y:hidden;overscroll-behavior-x:contain}.scrollable-y{overflow-x:hidden;overflow-y:auto;overscroll-behavior-y:contain}.key-hint{display:inline-flex;align-items:center;justify-content:center;min-width:1.5em;padding:.125em .375em;font-family:var(--font-mono);font-size:var(--text-xs);font-weight:var(--font-medium);font-variant-numeric:tabular-nums;background:var(--color-background-alt);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-dim);box-shadow:0 1px 0 var(--color-border)}@media(max-width:640px){.key-hint{font-size:max(var(--text-xs),11px);padding:.2em .5em}}.nucleotide{display:inline-block;width:1ch;text-align:center;font-weight:var(--font-bold)}.nucleotide-a{color:var(--nucleotide-a-fg);background:var(--nucleotide-a-bg)}.nucleotide-c{color:var(--nucleotide-c-fg);background:var(--nucleotide-c-bg)}.nucleotide-g{color:var(--nucleotide-g-fg);background:var(--nucleotide-g-bg)}.nucleotide-t{color:var(--nucleotide-t-fg);background:var(--nucleotide-t-bg)}.badge-row{display:inline-flex;align-items:center;gap:var(--space-2)}.panel-footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border);margin-top:var(--space-3);font-size:var(--text-sm)}.three-container{position:relative;width:100%;min-height:340px;height:clamp(340px,60vh,600px);border:1px solid var(--color-border);border-radius:var(--radius-lg);background:radial-gradient(circle at 28% 20%,rgba(56,189,248,.16),transparent 40%),radial-gradient(circle at 72% 62%,rgba(168,85,247,.18),transparent 46%),linear-gradient(180deg,#0c1224f5,#0c1224e6),var(--color-background-alt);overflow:hidden;box-shadow:0 18px 42px #00000052}@media(min-width:1024px){.three-container{height:clamp(500px,65vh,800px)}}@media(min-width:1440px){.three-container{height:clamp(580px,70vh,900px)}}@media(min-width:1920px){.three-container{height:clamp(650px,75vh,1000px)}}@media(min-width:2560px){.three-container{height:clamp(750px,80vh,1200px)}}@media(max-width:640px){.three-container{min-height:380px;height:clamp(380px,68vh,640px)}}.three-container--fullscreen:not(:fullscreen){position:fixed!important;inset:0!important;z-index:9999!important;width:100vw!important;height:100vh!important;height:100dvh!important;max-width:none!important;max-height:none!important;min-height:unset!important;border-radius:0!important;border:none!important;background:var(--color-background)!important}@media(max-width:1024px){.fx-layer{display:none}}.fx-layer{position:fixed;inset:0;pointer-events:none;z-index:0}.matrix-rain{position:absolute;inset:0;width:100%;height:100%;display:block;pointer-events:none}.fx-layer--crt{mix-blend-mode:overlay}.three-container canvas{width:100%;height:100%;display:block;touch-action:none;user-select:none}.three-overlay{position:absolute;inset:0;z-index:3;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);background:linear-gradient(180deg,#0b1021cc,#0b1021b3)}.three-overlay.error{background:#ef444414}.three-hud{position:absolute;z-index:2;pointer-events:auto}.spinner{width:28px;height:28px;border-radius:50%;border:3px solid var(--color-border);border-top-color:var(--color-accent);animation:spin .9s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.nucleotide-n{color:var(--nucleotide-n-fg);background:var(--nucleotide-n-bg)}.glow{box-shadow:var(--shadow-glow)}.glow-lg{box-shadow:var(--shadow-glow-lg)}.with-scanlines{position:relative}.with-scanlines:before{content:"";position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.015) 2px,rgba(0,0,0,.015) 4px);pointer-events:none;z-index:var(--z-overlay)}.chromatic-aberration{text-shadow:-.5px 0 var(--color-secondary),.5px 0 var(--color-primary)}@media(prefers-reduced-motion:reduce){.spinner{animation:none}.input,.input::placeholder{transition:none}}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}button:focus-visible,[role=button]:focus-visible,a:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background),0 0 0 4px var(--color-primary),0 0 12px var(--color-glow)}[tabindex="-1"]:focus-visible{outline:none;box-shadow:none}.skip-nav{position:fixed;top:-100px;left:50%;transform:translate(-50%);background:var(--color-primary);color:var(--color-background);padding:var(--space-3) var(--space-5);z-index:var(--z-max);font-weight:var(--font-bold);font-size:var(--text-sm);border-radius:0 0 var(--radius-lg) var(--radius-lg);transition:top var(--duration-fast) var(--ease-out);text-decoration:none}.skip-nav:focus{top:0;outline:none;box-shadow:0 4px 12px #0000004d,0 0 0 4px var(--color-background),0 0 0 6px var(--color-primary)}.high-contrast,:root.high-contrast{color-scheme:dark!important;--color-primary: #ffffff !important;--color-primary-hover: #e0e0e0 !important;--color-secondary: #ffd700 !important;--color-accent: #00ffff !important;--color-background: #000000 !important;--color-background-alt: #0a0a0a !important;--color-background-elevated: #111111 !important;--color-background-hover: #1a1a1a !important;--color-background-active: #222222 !important;--color-background-glass: rgba(0, 0, 0, .95) !important;--color-background-gradient-start: rgba(255, 255, 255, .05) !important;--color-text: #ffffff !important;--color-text-dim: #e0e0e0 !important;--color-text-muted: #b0b0b0 !important;--color-border: #666666 !important;--color-border-subtle: #444444 !important;--color-border-light: #888888 !important;--color-border-focus: #ffffff !important;--color-success: #00ff00 !important;--color-warning: #ffff00 !important;--color-error: #ff4444 !important;--color-info: #00ffff !important;--color-badge-bg: #222222 !important;--color-badge-text: #ffffff !important;--color-badge-border: #666666 !important;--color-panel-header: #111111 !important;--color-panel-border: #666666 !important;--color-separator: #666666 !important;--color-glow: rgba(255, 255, 255, .6) !important;--nucleotide-a-fg: #000000 !important;--nucleotide-a-bg: #00ffff !important;--nucleotide-c-fg: #000000 !important;--nucleotide-c-bg: #ff00ff !important;--nucleotide-g-fg: #000000 !important;--nucleotide-g-bg: #ffff00 !important;--nucleotide-t-fg: #000000 !important;--nucleotide-t-bg: #ff6666 !important;--nucleotide-n-fg: #ffffff !important;--nucleotide-n-bg: #444444 !important}.high-contrast .crt-overlay{display:none}.high-contrast .panel,.high-contrast .card,.high-contrast .list-item,.high-contrast .btn{border-width:2px}.high-contrast :focus-visible{outline-width:3px}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}.sr-only-focusable:focus,.sr-only-focusable:active{position:static;width:auto;height:auto;padding:inherit;margin:0;overflow:visible;clip:auto;white-space:normal}@media(prefers-reduced-motion:reduce){*,:before,:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.crt-overlay,.matrix-rain,.glow,.phosphor-glow{display:none!important}.btn:after,.deck-btn:after,.tab-btn:after{display:none!important}.btn,.list-item,.card{transition-duration:.1ms!important}}@media(forced-colors:active){.btn,.list-item,.badge{forced-color-adjust:none;border:2px solid currentColor}:focus-visible{outline:3px solid Highlight;outline-offset:2px}a{text-decoration:underline}}@media print{*{color:#000!important;background:#fff!important}a[href]:after{content:" (" attr(href) ")";font-size:.8em;color:#666}.btn,.crt-overlay,nav{display:none!important}}@keyframes holographic-shift{0%,to{background-position:0% 50%}50%{background-position:100% 50%}}@keyframes holographic-pulse{0%,to{opacity:.3}50%{opacity:.5}}@keyframes border-glow{0%,to{box-shadow:0 0 5px #00f5ff4d,0 0 10px #bf00ff33,inset 0 0 20px #00f5ff0d}50%{box-shadow:0 0 10px #00f5ff80,0 0 20px #bf00ff4d,inset 0 0 30px #00f5ff14}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}[data-theme=holographic]{--holo-gradient: linear-gradient( 135deg, rgba(191, 0, 255, .08) 0%, rgba(0, 245, 255, .05) 25%, rgba(255, 0, 110, .05) 50%, rgba(0, 245, 255, .08) 75%, rgba(191, 0, 255, .05) 100% );--holo-border-gradient: linear-gradient( 135deg, rgba(0, 245, 255, .6) 0%, rgba(191, 0, 255, .6) 50%, rgba(255, 0, 110, .6) 100% );--glass-bg: rgba(3, 0, 20, .7);--glass-blur: 20px;--glass-border: rgba(255, 255, 255, .08)}[data-theme=holographic] .app-shell{background:radial-gradient(ellipse at 20% 0%,rgba(191,0,255,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(0,245,255,.12) 0%,transparent 50%),radial-gradient(ellipse at 40% 60%,rgba(255,0,110,.08) 0%,transparent 40%),linear-gradient(180deg,#030014,#050020,#030014);background-size:200% 200%,200% 200%,100% 100%,100% 100%}[data-theme=holographic] .app-shell.fx-enabled{animation:holographic-shift 20s ease infinite}[data-theme=holographic] .panel,[data-theme=holographic] .detail-card{background:#05001e99;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border:1px solid rgba(255,255,255,.08);box-shadow:0 8px 32px #0006,0 0 0 1px #bf00ff1a,inset 0 0 60px #00f5ff08;position:relative;overflow:hidden}[data-theme=holographic] .app-shell.fx-disabled .panel,[data-theme=holographic] .app-shell.fx-disabled .detail-card{backdrop-filter:none;-webkit-backdrop-filter:none;background:#05001ee6;box-shadow:0 8px 24px #00000059,0 0 0 1px #bf00ff14,inset 0 0 40px #00f5ff05}[data-theme=holographic] .panel:before,[data-theme=holographic] .detail-card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent 0%,rgba(0,245,255,.5) 20%,rgba(191,0,255,.5) 50%,rgba(255,0,110,.5) 80%,transparent 100%);opacity:.6}[data-theme=holographic] .app-header{background:#030014d9;backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid rgba(191,0,255,.2);box-shadow:0 4px 30px #0000004d,0 0 40px #bf00ff0d}[data-theme=holographic] .app-shell.fx-disabled .app-header{backdrop-filter:none;-webkit-backdrop-filter:none;background:#030014f2}[data-theme=holographic] .db-status-bar{background:#05001e80;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid rgba(0,245,255,.15);box-shadow:0 4px 20px #0000004d,inset 0 0 30px #00f5ff05}[data-theme=holographic] .app-shell.fx-disabled .db-status-bar{backdrop-filter:none;-webkit-backdrop-filter:none;background:#05001ed9}[data-theme=holographic] .db-status-icon{color:#00ffa3;text-shadow:0 0 10px rgba(0,255,163,.5)}[data-theme=holographic] .list-item{background:#05001e4d;border:1px solid rgba(255,255,255,.05);transition:all .3s ease}[data-theme=holographic] .list-item:hover{background:#00f5ff14;border-color:#00f5ff33;box-shadow:0 4px 20px #00f5ff1a,inset 0 0 20px #00f5ff08}[data-theme=holographic] .list-item.active{background:linear-gradient(135deg,#00f5ff26,#bf00ff1a);border-color:#00f5ff66;box-shadow:0 0 20px #00f5ff33,0 0 40px #bf00ff1a,inset 0 0 30px #00f5ff0d;animation:border-glow 3s ease-in-out infinite}[data-theme=holographic] .app-shell.fx-disabled .list-item.active{animation:none}[data-theme=holographic] .list-item.active:before{background:linear-gradient(180deg,#00f5ff,#bf00ff);box-shadow:0 0 10px #00f5ff80}[data-theme=holographic] .btn{background:#05001e99;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(0,245,255,.3);color:#00f5ff;transition:all .3s ease;position:relative;overflow:hidden}[data-theme=holographic] .app-shell.fx-disabled .btn{backdrop-filter:none;-webkit-backdrop-filter:none;background:#05001ee6}[data-theme=holographic] .btn:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(0,245,255,.2) 50%,transparent 100%);transition:left .5s ease}[data-theme=holographic] .btn:hover{background:#00f5ff26;border-color:#00f5ff80;box-shadow:0 0 20px #00f5ff4d,inset 0 0 20px #00f5ff0d;text-shadow:0 0 10px rgba(0,245,255,.5)}[data-theme=holographic] .btn:hover:before{left:100%}[data-theme=holographic] .badge{background:linear-gradient(135deg,#00f5ff33,#bf00ff33);border:1px solid rgba(0,245,255,.3);color:#00f5ff;text-shadow:0 0 5px rgba(0,245,255,.3);backdrop-filter:blur(5px);-webkit-backdrop-filter:blur(5px)}[data-theme=holographic] .app-shell.fx-disabled .badge{backdrop-filter:none;-webkit-backdrop-filter:none}[data-theme=holographic] .badge-info{background:linear-gradient(135deg,#00f5ff33,#00d4ff33);border-color:#00f5ff66;color:#00f5ff}[data-theme=holographic] .badge-warning{background:linear-gradient(135deg,#fa03,#f803);border-color:#fa06;color:#fa0}[data-theme=holographic] .sequence-block{background:#030014cc;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid rgba(191,0,255,.2);box-shadow:inset 0 0 60px #00000080,0 4px 20px #0000004d}[data-theme=holographic] .three-container{border:1px solid rgba(0,245,255,.2);box-shadow:0 8px 32px #0006,0 0 0 1px #bf00ff1a,inset 0 0 100px #00f5ff05;background:radial-gradient(ellipse at 30% 20%,rgba(0,245,255,.1) 0%,transparent 40%),radial-gradient(ellipse at 70% 80%,rgba(191,0,255,.1) 0%,transparent 40%),#030014e6}[data-theme=holographic] ::-webkit-scrollbar{width:8px;height:8px}[data-theme=holographic] ::-webkit-scrollbar-track{background:#03001480;border-radius:4px}[data-theme=holographic] ::-webkit-scrollbar-thumb{background:linear-gradient(180deg,#00f5ff,#bf00ff);border-radius:4px;border:1px solid rgba(0,245,255,.3)}[data-theme=holographic] ::-webkit-scrollbar-thumb:hover{background:linear-gradient(180deg,#33f7ff,#d633ff);box-shadow:0 0 10px #00f5ff80}[data-theme=holographic] .app-title{background:linear-gradient(90deg,#00f5ff,#bf00ff,#00f5ff);background-size:200% auto;-webkit-background-clip:text;background-clip:text;-webkit-text-fill-color:transparent;animation:shimmer 3s linear infinite}[data-theme=holographic] h1,[data-theme=holographic] h2,[data-theme=holographic] h3,[data-theme=holographic] h4{text-shadow:0 0 20px rgba(0,245,255,.2)}[data-theme=holographic] *:focus-visible{outline:none;box-shadow:0 0 0 2px #00f5ff80,0 0 20px #00f5ff4d}[data-theme=holographic] .app-footer{background:#030014e6;backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border-top:1px solid rgba(191,0,255,.2)}@media(prefers-reduced-motion:reduce){[data-theme=holographic] .app-shell{animation:none;background:radial-gradient(ellipse at 20% 0%,rgba(191,0,255,.15) 0%,transparent 50%),radial-gradient(ellipse at 80% 100%,rgba(0,245,255,.12) 0%,transparent 50%),#030014}[data-theme=holographic] .app-title{animation:none;background-position:0% 0%}[data-theme=holographic] .list-item.active{animation:none}[data-theme=holographic] .btn:before{display:none}}@media(hover:none)and (pointer:coarse){[data-theme=holographic] .app-shell,[data-theme=holographic] .app-title,[data-theme=holographic] .list-item.active{animation:none!important}[data-theme=holographic] .btn:before{display:none}[data-theme=holographic] .panel,[data-theme=holographic] .detail-card,[data-theme=holographic] .sequence-block,[data-theme=holographic] .btn,[data-theme=holographic] .badge,[data-theme=holographic] .glass-panel,[data-theme=holographic] .app-header,[data-theme=holographic] .db-status-bar,[data-theme=holographic] .overlay-content,[data-theme=holographic] .modal-content,[data-theme=holographic] .command-palette,[data-theme=holographic] .toast,[data-theme=holographic] .context-menu,[data-theme=holographic] .control-deck,[data-theme=holographic] .app-footer{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}[data-theme=holographic] .glass-panel,[data-theme=holographic] .app-header,[data-theme=holographic] .db-status-bar,[data-theme=holographic] .overlay-content,[data-theme=holographic] .modal-content,[data-theme=holographic] .command-palette,[data-theme=holographic] .toast,[data-theme=holographic] .context-menu,[data-theme=holographic] .control-deck,[data-theme=holographic] .app-footer{background:#030014f2!important}}:root{--mobile-header-height: 56px;--mobile-tab-bar-height: 56px;--control-deck-reserved-height: var(--mobile-tab-bar-height);--mobile-safe-bottom: env(safe-area-inset-bottom, 0px);--mobile-safe-top: env(safe-area-inset-top, 0px);--mobile-safe-left: env(safe-area-inset-left, 0px);--mobile-safe-right: env(safe-area-inset-right, 0px)}@media(max-width:900px){.app-shell{grid-template-rows:calc(var(--mobile-header-height) + var(--mobile-safe-top)) minmax(0,1fr) auto}.app-header{padding:0 var(--space-3);min-height:var(--mobile-header-height);gap:var(--space-2)}.header-left,.header-right{gap:var(--space-2)}.app-subtitle{display:none}.app-body{padding:var(--space-3);gap:var(--space-3)}.panel.two-column{display:flex;flex-direction:column;gap:var(--space-3)}.detail-viewers{grid-template-columns:1fr;gap:var(--space-3)}.three-container{min-height:280px;height:clamp(280px,50vh,400px)}.analysis-sidebar,.action-toolbar{display:none}.fab{display:flex}}@media(max-width:640px){.app-body{padding:var(--space-3);padding-bottom:calc(var(--mobile-tab-bar-height) + var(--mobile-safe-bottom) + var(--space-6))}.app-header{padding:0 var(--space-2);padding-top:var(--mobile-safe-top);min-height:calc(var(--mobile-header-height) + var(--mobile-safe-top))}.app-title{font-size:var(--text-base);max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-header .badge{display:none}.header-right{gap:var(--space-1)}.header-right .btn{padding:var(--space-1) var(--space-2);min-height:36px;min-width:36px}.app-footer{display:none}.column--list.mobile-drawer{position:fixed;inset:0;top:calc(var(--mobile-header-height) + var(--mobile-safe-top));z-index:var(--z-overlay);background:var(--color-background);padding:var(--space-3);padding-bottom:calc(var(--mobile-tab-bar-height) + var(--mobile-safe-bottom) + var(--space-3));display:flex;flex-direction:column;animation:slideInFromLeft .2s var(--ease-out)}@keyframes slideInFromLeft{0%{transform:translate(-100%);opacity:0}to{transform:translate(0);opacity:1}}.column--list.mobile-drawer .list{flex:1;max-height:none;min-height:0;overflow-y:auto}.column--list:not(.mobile-drawer) .list{max-height:35vh;min-height:150px}.panel{padding:var(--space-2);border-radius:var(--radius-lg)}.panel-header{padding:var(--space-2) var(--space-3)}.panel-body,.detail-card{padding:var(--space-2)}.three-container{min-height:240px;height:clamp(240px,45vh,320px);border-radius:var(--radius-lg)}.sequence-view{min-height:200px}.sequence-view .btn.compact{min-height:44px;min-width:44px}.sequence-view__zoom-label{height:44px}.view-mode-toggle{padding:3px;gap:2px;width:fit-content;max-width:none;flex:0 0 auto}.view-mode-segment{padding:6px 10px;min-height:44px;min-width:44px;font-size:13px;font-weight:600;white-space:nowrap}.view-mode-icon{display:none}.view-mode-indicator{top:3px;left:3px;height:calc(100% - 6px)}.quick-stats--mobile{margin:0;max-width:100vw;overscroll-behavior-x:contain}.btn{min-height:44px;padding:var(--space-2) var(--space-3);font-size:var(--text-sm)}.btn-sm{min-height:36px;padding:var(--space-1) var(--space-2);font-size:var(--text-xs)}.list-item{min-height:56px;padding:var(--space-3)}.badge{font-size:10px;padding:2px 6px}.fab{display:none}.empty-state{padding:var(--space-6) var(--space-4)}.empty-state__icon{font-size:2.5rem}.empty-state__title{font-size:var(--text-lg)}.empty-state__description{font-size:var(--text-sm)}.glossary-shell{top:0;bottom:0;width:100%;max-width:100%;border-left:none;border-radius:0}}@media(max-width:480px){.app-title{font-size:var(--text-sm);max-width:120px}.header-right .btn{padding:var(--space-1);min-width:36px;font-size:10px}.app-body{padding:var(--space-1)}.panel{border-radius:var(--radius-md)}.header-right{gap:var(--space-1)}}@media(hover:none)and (pointer:coarse){button,.btn,[role=button],[role=tab],[role=option],a[href]:not(.badge){min-height:44px;min-width:44px}.list-item,[role=option]{min-height:52px;padding:var(--space-3)}input[type=text],input[type=search],input[type=number],select,textarea{min-height:48px;padding:var(--space-3);font-size:16px}input[type=checkbox],input[type=radio]{width:24px;height:24px}label:has(input[type=checkbox]),label:has(input[type=radio]){min-height:44px;display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) 0}.btn:hover,.list-item:hover{transform:none}.btn:active{transform:scale(.97);background:var(--color-background-active)}.list-item:active{background:var(--color-background-active)}::-webkit-scrollbar{display:none}*{scrollbar-width:none}}@media(orientation:landscape)and (max-height:500px){.app-header{min-height:44px;padding:0 var(--space-2)}.app-title{font-size:var(--text-sm)}.app-subtitle,.header-left .badge,.beginner-indicator{display:none}.app-body{padding:var(--space-2);padding-bottom:calc(48px + var(--mobile-safe-bottom) + var(--space-2))}.panel.two-column{display:grid;grid-template-columns:minmax(200px,1fr) 2fr;gap:var(--space-2);height:calc(var(--app-height, 100vh) - 44px - 48px - var(--mobile-safe-bottom) - var(--space-4))}.column--list{max-height:none;overflow-y:auto}.column--detail{overflow-y:auto}.detail-viewers{gap:var(--space-2)}.three-container{min-height:150px;height:clamp(150px,35vh,200px)}.control-deck .deck-content{display:none}.control-deck.is-expanded .deck-content{display:flex;position:absolute;bottom:100%;left:0;right:0;background:var(--color-background-elevated);border-top:1px solid var(--color-border);border-bottom:none}}.mobile-only{display:none}@media(max-width:640px){.mobile-only{display:flex}}.desktop-only{display:flex}@media(max-width:640px){.desktop-only{display:none}}.data-freshness-indicator{position:fixed;bottom:var(--space-3);right:var(--space-3);z-index:var(--z-fixed)}@media(max-width:900px){.data-freshness-indicator{bottom:calc(var(--space-3) + 60px);right:var(--space-3)}}@media(max-width:640px){.data-freshness-indicator{bottom:calc(var(--mobile-tab-bar-height) + var(--mobile-safe-bottom) + var(--space-3));right:var(--space-2)}}@media(prefers-reduced-motion:reduce){.column--list.mobile-drawer{animation:none}}@media(orientation:landscape)and (max-height:500px)and (pointer:coarse){.control-deck{position:fixed;inset:0 0 0 auto;width:48px;height:100%;flex-direction:column;justify-content:center;padding:env(safe-area-inset-top,0px) env(safe-area-inset-right,0px) env(safe-area-inset-bottom,0px) 0;border-top:none;border-left:1px solid var(--color-border-subtle)}.app-body{padding-right:calc(48px + env(safe-area-inset-right,0px));padding-bottom:0}.bottom-sheet__container{max-height:70dvh}.gene-map-canvas{max-height:40dvh}.app-header{padding-top:0;padding-bottom:0;min-height:36px}.app-footer{padding-top:var(--space-1);padding-bottom:var(--space-1);min-height:24px;font-size:var(--text-2xs, .64rem)}.detail-card{padding:var(--space-3);gap:var(--space-3)}.metrics{gap:var(--space-2)}}@media(orientation:landscape)and (max-height:500px)and (pointer:coarse){.control-deck .control-deck__btn{min-width:44px;min-height:44px}}.scrollable,.list,.sequence-block,[data-scroll],[role=listbox]{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scroll-behavior:smooth}html{overscroll-behavior:none}@media(hover:none)and (pointer:coarse){.app-header,.app-footer,.panel,.detail-card,.glass-panel,.overlay-content,.modal-content,.command-palette,.toast,.context-menu,.translation-viz__ribosome-body,.glossary-drawer,.glossary-backdrop,.db-status-bar,.control-deck{backdrop-filter:none!important;-webkit-backdrop-filter:none!important}.fx-layer{display:none!important}.app-header,.control-deck,.fab,.bottom-sheet__container,.bottom-sheet__backdrop{backface-visibility:hidden;transform:translateZ(0);contain:paint}}@media(max-width:640px){.list,.app-body,.overlay-content,.bottom-sheet__content{overscroll-behavior-y:auto}}.scroll-snap-x{scroll-snap-type:x mandatory;scroll-padding:var(--space-4)}.scroll-snap-x>*{scroll-snap-align:start}.scroll-snap-y{scroll-snap-type:y proximity;scroll-padding:var(--space-4)}.scroll-snap-y>*{scroll-snap-align:start}@media(hover:none)and (pointer:coarse){button,.btn,[role=button],[role=option],[role=tab],[role=menuitem]{min-height:45px!important;min-width:45px!important}input:not([type=checkbox]):not([type=radio]),select,textarea{min-height:45px!important}.view-mode-segment,.sequence-view__zoom-btn,.sequence-view__snap-btn,.sequence-view__frame-btn{min-height:45px!important;min-width:45px!important}input[type=checkbox],input[type=radio]{width:24px;height:24px;min-width:24px;min-height:24px;cursor:pointer;accent-color:var(--color-primary)}label:has(input[type=checkbox]),label:has(input[type=radio]){min-height:48px;padding:var(--space-3) var(--space-2);display:flex;align-items:center;gap:var(--space-3);cursor:pointer;border-radius:var(--radius-md);transition:background var(--duration-fast) var(--ease-out);-webkit-user-select:none;user-select:none}label:has(input[type=checkbox]):active,label:has(input[type=radio]):active{background:var(--color-background-hover)}}@media(max-width:768px){button,.btn,[role=button],[role=option],[role=tab],[role=menuitem]{min-height:45px!important;min-width:45px!important}input:not([type=checkbox]):not([type=radio]),select,textarea{min-height:45px!important}.view-mode-segment,.sequence-view__zoom-btn,.sequence-view__snap-btn,.sequence-view__frame-btn{min-height:45px!important;min-width:45px!important}}@media(hover:none)and (pointer:coarse){.touch-ripple{position:relative;overflow:hidden}.touch-ripple:after{content:"";position:absolute;inset:0;background:radial-gradient(circle at var(--touch-x, 50%) var(--touch-y, 50%),rgba(34,211,238,.25) 0%,rgba(34,211,238,.1) 40%,transparent 70%);opacity:0;pointer-events:none;transition:opacity .15s var(--ease-out)}.touch-ripple:active:after{opacity:1;transition:none}.btn:active,.list-item:active,.tab-btn:active,[role=button]:active,.chip:active{transform:scale(.97);transition:transform 0ms}.btn:not(:active),.list-item:not(:active),.tab-btn:not(:active),[role=button]:not(:active),.chip:not(:active){transition:transform .35s var(--ease-spring)}.btn:active{background-color:var(--color-background-active)}.list-item:active{background-color:var(--color-background-hover)}.btn:hover:not(:active),.list-item:hover:not(:active){transform:none}.instant-feedback:active{transform:scale(.96);transition:transform 50ms var(--ease-out)}.instant-feedback:not(:active){transition:transform .4s var(--ease-spring)}}.bottom-sheet{position:fixed;inset:0;z-index:var(--z-modal);pointer-events:none;display:flex;flex-direction:column;justify-content:flex-end}.bottom-sheet.is-open{pointer-events:auto}.bottom-sheet__backdrop{position:absolute;inset:0;background:#0009;opacity:0;will-change:opacity}.bottom-sheet__container{position:relative;min-height:var(--bottom-sheet-min-height-vh, 30vh);min-height:var(--bottom-sheet-min-height-dvh, 30dvh);max-height:var(--bottom-sheet-max-height-vh, 90vh);max-height:var(--bottom-sheet-max-height-dvh, 90dvh);background:var(--color-background-elevated);border-top-left-radius:var(--radius-2xl);border-top-right-radius:var(--radius-2xl);box-shadow:0 -4px 16px #0000004d;transform:translateY(100%);padding-bottom:env(safe-area-inset-bottom);display:flex;flex-direction:column;overflow:hidden;will-change:transform}.bottom-sheet__handle{display:flex;justify-content:center;padding:var(--space-4) var(--space-4);cursor:grab;touch-action:none;min-height:44px}.bottom-sheet__handle:before{content:"";width:40px;height:5px;background:var(--color-border);border-radius:var(--radius-full);transition:background var(--duration-fast) var(--ease-out),width var(--duration-fast) var(--ease-spring),transform var(--duration-fast) var(--ease-spring)}.bottom-sheet__handle:active:before,.bottom-sheet--dragging .bottom-sheet__handle:before{width:48px;background:var(--color-primary);transform:scaleY(1.25)}.bottom-sheet__container:before{content:"";position:absolute;top:0;left:0;right:0;height:80px;background:linear-gradient(to bottom,#22d3ee00 0% 100%);border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;pointer-events:none;z-index:10;opacity:0;transition:opacity var(--duration-fast) var(--ease-out)}.bottom-sheet--dragging .bottom-sheet__container:before{background:linear-gradient(to bottom,#22d3ee26,#22d3ee0d 40%,#22d3ee00);opacity:1}.bottom-sheet__header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-4) var(--space-3);border-bottom:1px solid var(--color-border-subtle);touch-action:none;cursor:grab}.bottom-sheet__title{font-size:var(--text-lg);font-weight:var(--font-bold);color:var(--color-text);margin:0}.bottom-sheet__close{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border:none;background:var(--color-background-alt);border-radius:var(--radius-full);color:var(--color-text-muted);cursor:pointer;transition:background var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent}.bottom-sheet__close:active{background:var(--color-background-hover)}.bottom-sheet__content{flex:1;min-height:0;overflow-y:auto;overscroll-behavior-y:auto;-webkit-overflow-scrolling:touch;padding:var(--space-4)}@media(max-width:640px){.bottom-sheet__content{padding:var(--space-3);padding-bottom:var(--space-4)}}.bottom-sheet__content>.overlay{min-height:100%}.bottom-sheet__content>.overlay-commandPalette{height:100%;max-height:100%;overflow:hidden}.bottom-sheet__footer{padding:var(--space-3) var(--space-4);border-top:1px solid var(--color-border-subtle);display:flex;gap:var(--space-3)}.bottom-sheet__footer .btn{flex:1}@keyframes skeleton-translate-shimmer{0%{transform:translate(-100%)}to{transform:translate(200%)}}.skeleton{position:relative;overflow:hidden;background:linear-gradient(135deg,var(--color-background-alt) 0%,var(--color-background-hover) 50%,var(--color-background-alt) 100%);background-size:200% 100%;border-radius:var(--radius-md);animation:skeleton-pulse 2s ease-in-out infinite}.skeleton:after{content:"";position:absolute;inset:0;background:linear-gradient(105deg,transparent 0%,transparent 35%,rgba(34,211,238,.03) 45%,rgba(255,255,255,.08) 50%,rgba(192,132,252,.03) 55%,transparent 65%,transparent 100%);animation:skeleton-translate-shimmer 2s ease-in-out infinite;will-change:transform}.skeleton:before{content:"";position:absolute;inset:0;background:linear-gradient(90deg,transparent 0%,rgba(255,255,255,.02) 50%,transparent 100%);animation:skeleton-translate-shimmer 2s ease-in-out infinite;animation-delay:.3s;will-change:transform}.skeleton-text{height:1em;margin-bottom:var(--space-2)}.skeleton-text--sm{height:.75em;width:60%}.skeleton-text--lg{height:1.25em;width:80%}.skeleton-avatar{width:40px;height:40px;border-radius:var(--radius-full)}.skeleton-button{height:44px;width:120px}.skeleton-card{height:120px;border-radius:var(--radius-lg)}.skeleton-image{aspect-ratio:16/9;border-radius:var(--radius-lg)}.skeleton-list-item{display:flex;gap:var(--space-3);padding:var(--space-3);align-items:center}.skeleton-list-item .skeleton-avatar{flex-shrink:0}.skeleton-list-item .skeleton-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}@media(prefers-reduced-motion:reduce){.skeleton:after{animation:none;display:none}.skeleton{background:var(--color-background-hover)}}.pull-to-refresh{position:relative;overflow:hidden}.pull-to-refresh__indicator{display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none;will-change:transform,opacity}.pull-to-refresh__icon{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:var(--color-background-elevated);border-radius:var(--radius-full);box-shadow:var(--shadow-md);will-change:transform}.pull-to-refresh__text{margin-top:var(--space-2);font-size:var(--text-xs);font-weight:500;color:var(--color-text-muted);white-space:nowrap;transition:color .15s var(--ease-out)}.pull-to-refresh[data-state=ready] .pull-to-refresh__icon,.pull-to-refresh[data-state=ready] .pull-to-refresh__text{color:var(--color-primary)}.pull-to-refresh[data-state=ready] .pull-to-refresh__icon{box-shadow:var(--shadow-md),var(--shadow-primary-glow)}.pull-to-refresh[data-state=refreshing] .pull-to-refresh__icon{color:var(--color-primary);box-shadow:var(--shadow-md),var(--shadow-primary-glow)}@keyframes ptr-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.pull-to-refresh[data-state=refreshing] .pull-to-refresh__icon svg{animation:ptr-spin .8s linear infinite}.pull-to-refresh__content{will-change:transform}.pull-to-refresh--legacy{display:flex;align-items:center;justify-content:center;height:0;overflow:hidden;transition:height var(--duration-fast) var(--ease-out)}.pull-to-refresh--legacy.is-pulling,.pull-to-refresh--legacy.is-refreshing{height:60px}.pull-to-refresh__spinner{width:24px;height:24px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:ptr-spin .8s linear infinite}.pull-to-refresh__arrow{width:24px;height:24px;color:var(--color-text-muted);transition:transform var(--duration-fast) var(--ease-out)}.pull-to-refresh--legacy.is-pulling .pull-to-refresh__arrow{transform:rotate(180deg)}.swipe-container{position:relative;overflow:hidden}.swipe-content{position:relative;background:var(--color-background);z-index:1;transition:transform var(--duration-fast) var(--ease-out)}.swipe-actions{position:absolute;top:0;bottom:0;display:flex;align-items:stretch}.swipe-actions--left{left:0;transform:translate(-100%)}.swipe-actions--right{right:0}.swipe-action{display:flex;align-items:center;justify-content:center;min-width:80px;padding:var(--space-3);color:#fff;font-weight:var(--font-medium)}.swipe-action--delete{background:var(--color-error)}.swipe-action--archive{background:var(--color-warning)}.swipe-action--favorite{background:var(--color-success)}@media(hover:none)and (pointer:coarse){*:focus:not(:focus-visible){outline:none;box-shadow:none}*:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}}.fab{box-shadow:0 4px 12px #00000040,0 8px 24px #00000026;transition:transform var(--duration-fast) var(--ease-spring),box-shadow var(--duration-fast) var(--ease-out)}.fab:active{transform:scale(.92);box-shadow:0 2px 8px #0000004d,0 4px 12px #0003}@media(max-width:640px){.overlay{align-items:flex-end}.overlay-content{border-radius:var(--radius-2xl) var(--radius-2xl) 0 0;max-height:85vh;max-height:85dvh;animation:slide-up var(--duration-normal) var(--ease-out);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom))}@keyframes slide-up{0%{transform:translateY(100%);opacity:0}to{transform:translateY(0);opacity:1}}}.gesture-hint{display:none}@media(hover:none)and (pointer:coarse){.gesture-hint{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:#000000b3;border-radius:var(--radius-lg);font-size:var(--text-xs);color:var(--color-text-muted)}.gesture-hint__icon{width:16px;height:16px;opacity:.7}}@media(hover:none)and (pointer:coarse){::-webkit-scrollbar{display:none}*{scrollbar-width:none}.list::-webkit-scrollbar,.sequence-block::-webkit-scrollbar{display:block;width:3px}.list::-webkit-scrollbar-thumb,.sequence-block::-webkit-scrollbar-thumb{background:var(--color-border-light);border-radius:var(--radius-full)}}@media(max-width:640px){input[type=text],input[type=search],input[type=email],input[type=password],input[type=number],input[type=tel],input[type=url],select,textarea{font-size:16px}input,select,textarea{min-height:48px;padding:var(--space-3)}input[type=search]::-webkit-search-cancel-button{-webkit-appearance:none;height:20px;width:20px;background:var(--color-text-muted);mask:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' viewBox='0 0 24 24' fill='none' stroke='currentColor' stroke-width='2'%3E%3Cpath d='M18 6L6 18M6 6l12 12'/%3E%3C/svg%3E") center / contain no-repeat}}.context-menu{position:fixed;z-index:var(--z-popover);min-width:200px;background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);padding:var(--space-2);transform-origin:top left;animation:context-menu-in var(--duration-fast) var(--ease-out)}@keyframes context-menu-in{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.context-menu__item{display:flex;align-items:center;gap:var(--space-3);width:100%;padding:var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);text-align:left;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.context-menu__item:active{background:var(--color-background-hover)}.context-menu__item--destructive{color:var(--color-error)}.context-menu__divider{height:1px;background:var(--color-border-subtle);margin:var(--space-2) 0}@keyframes loading-shimmer{0%{transform:translate(-100%)}to{transform:translate(400%)}}@keyframes loading-gradient{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.loading-progress{position:fixed;top:0;left:0;right:0;height:3px;z-index:var(--z-toast);overflow:hidden;pointer-events:none}.loading-progress__bar{height:100%;border-radius:0 2px 2px 0;box-shadow:0 0 8px var(--color-glow)}.loading-progress__bar--determinate{background:linear-gradient(90deg,var(--color-primary) 0%,var(--color-secondary) 50%,var(--color-primary) 100%);background-size:200% 100%;transition:width .2s var(--ease-out)}.loading-progress__bar--indeterminate{animation:loading-gradient 2s ease-in-out infinite}.loading-progress__shimmer{animation:loading-shimmer 1.5s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.loading-progress__bar--indeterminate{animation:none}.loading-progress__shimmer{display:none}}@media(max-width:1024px){.app-shell,.app-body,.app-header,.panel,.detail-card,.overlay-content,.bottom-sheet__content{max-width:100vw;overflow-x:hidden}#root{overflow-x:hidden;max-width:100vw}}@supports (-webkit-touch-callout: none){html,body{overflow-x:hidden;width:100%;max-width:100vw}body,#root,.app-shell{min-height:-webkit-fill-available;min-height:var(--app-height, -webkit-fill-available)}.app-shell{-webkit-transform:translate3d(0,0,0);transform:translateZ(0)}html.pe-three-fullscreen .app-shell{-webkit-transform:none!important;transform:none!important}input,textarea,select{-webkit-appearance:none;appearance:none;border-radius:0;font-size:16px}.app-body,.overlay-content,.bottom-sheet__content{-webkit-overflow-scrolling:touch}.app-header,.control-deck{-webkit-transform:translateZ(0);transform:translateZ(0)}html{background-color:var(--color-background, #0a0a0f)}button,.btn,[role=button],.list-item,.tab-btn{-webkit-user-select:none;user-select:none}.sequence-grid-canvas{-webkit-touch-callout:none;-webkit-user-select:none;user-select:none;-webkit-tap-highlight-color:transparent}*:focus{-webkit-tap-highlight-color:transparent}.bottom-sheet__container,.overlay-content{-webkit-backface-visibility:hidden;backface-visibility:hidden}}@media all and (display-mode:standalone){.app-header{padding-top:env(safe-area-inset-top,20px)}.control-deck,.bottom-sheet__container{padding-bottom:max(env(safe-area-inset-bottom),8px)}html{overscroll-behavior-y:none}.app-shell{min-height:100vh;min-height:-webkit-fill-available}}@media(max-width:375px){.panel,.detail-card{padding:var(--space-3)}.btn{font-size:13px;padding:var(--space-2) var(--space-3)}.tab-btn .tab-label{font-size:10px;font-size:max(10px,var(--text-2xs));letter-spacing:.2px}.overlay-content{max-width:calc(100vw - var(--space-4))}input[type=search],input[type=text]{min-width:0;flex:1}}.content-stagger>*{opacity:0;animation:content-reveal .4s var(--ease-out, ease-out) forwards}.content-stagger>*:nth-child(1){animation-delay:0ms}.content-stagger>*:nth-child(2){animation-delay:60ms}.content-stagger>*:nth-child(3){animation-delay:.12s}.content-stagger>*:nth-child(4){animation-delay:.18s}.content-stagger>*:nth-child(5){animation-delay:.24s}.content-stagger>*:nth-child(6){animation-delay:.3s}.content-stagger>*:nth-child(7){animation-delay:.36s}.content-stagger>*:nth-child(8){animation-delay:.42s}@media(prefers-reduced-motion:reduce){.content-stagger>*{animation:none;opacity:1}}@media(max-width:640px){.empty-state{padding:var(--space-8) var(--space-4);text-align:center}.empty-state__icon{font-size:3rem;margin-bottom:var(--space-4);opacity:.6}.empty-state__title{font-size:var(--text-lg);font-weight:var(--font-semibold);margin-bottom:var(--space-2)}.empty-state__description{font-size:var(--text-sm);color:var(--color-text-muted);max-width:280px;margin:0 auto var(--space-4);line-height:1.5}.empty-state__action{margin-top:var(--space-4)}}@media(max-width:640px){.toast-container{bottom:calc(var(--mobile-tab-bar-height, 56px) + var(--mobile-safe-bottom, 0px) + 80px);left:var(--space-3);right:var(--space-3);max-width:none}.toast{width:100%;max-width:none;min-height:52px;padding:var(--space-3) var(--space-4);font-size:var(--text-sm);position:relative}.toast:after{content:"";position:absolute;bottom:6px;left:50%;transform:translate(-50%);width:32px;height:3px;background:currentColor;opacity:.25;border-radius:var(--radius-full);pointer-events:none}}.scroll-fade-container{position:relative}.scroll-fade-container:before,.scroll-fade-container:after{content:"";position:absolute;left:0;right:0;height:24px;pointer-events:none;opacity:0;transition:opacity var(--duration-fast) var(--ease-out);z-index:5}.scroll-fade-container:before{top:0;background:linear-gradient(to bottom,var(--color-background) 0%,transparent 100%)}.scroll-fade-container:after{bottom:0;background:linear-gradient(to top,var(--color-background) 0%,transparent 100%)}.scroll-fade-container[data-scroll-top=true]:before{opacity:1}.scroll-fade-container[data-scroll-bottom=true]:after{opacity:1}@media(hover:none)and (pointer:coarse){.btn-primary:active,.btn--primary:active{transform:scale(.95);filter:brightness(.9)}.btn-danger:active,.btn--danger:active{transform:scale(.96);background:var(--color-error);filter:brightness(1.1)}.btn-toggle:active,[role=switch]:active{transform:scale(.94)}.btn-icon:active,.icon-btn:active{transform:scale(.9);background:var(--color-background-active)}}@supports (padding: env(safe-area-inset-top)){.notch-safe{padding-left:max(var(--space-4),env(safe-area-inset-left));padding-right:max(var(--space-4),env(safe-area-inset-right))}.safe-area-aware{padding-top:env(safe-area-inset-top);padding-bottom:env(safe-area-inset-bottom);padding-left:env(safe-area-inset-left);padding-right:env(safe-area-inset-right)}@media(orientation:landscape){.notch-safe{padding-left:max(var(--space-6),env(safe-area-inset-left));padding-right:max(var(--space-6),env(safe-area-inset-right))}}}@media(hover:none)and (pointer:coarse){.list-item{-webkit-user-select:none;user-select:none;transition:background var(--duration-fast) var(--ease-out)}.list-item--selected,.list-item.selected,.list-item[aria-selected=true]{background:color-mix(in srgb,var(--color-primary) 15%,transparent);box-shadow:inset 3px 0 0 var(--color-primary)}.list-item:active:not(.list-item--selected){background:var(--color-background-active);transition:none}.list-item:not(:last-child){border-bottom:1px solid var(--color-border-subtle)}}@media(max-width:640px){.popover--mobile-centered{position:fixed;left:var(--space-4);right:var(--space-4);bottom:auto;top:50%;transform:translateY(-50%);max-width:none;width:calc(100vw - var(--space-8))}.popover{max-width:calc(100vw - var(--space-4))}.popover-backdrop{position:fixed;inset:0;background:#00000080;z-index:calc(var(--z-popover) - 1)}}@media(max-width:640px){input:focus,textarea:focus,select:focus{scroll-margin-bottom:120px}@supports (height: 100dvh){.keyboard-aware-container{min-height:100dvh}}}.control-deck{display:none}@media(max-width:640px){.control-deck{display:flex;position:fixed;bottom:0;left:0;right:0;height:calc(var(--mobile-tab-bar-height, 56px) + env(safe-area-inset-bottom,0px));padding-bottom:env(safe-area-inset-bottom,0px);background:var(--color-background-elevated);border-top:1px solid var(--color-border);z-index:calc(var(--z-modal) + 50);justify-content:space-around;align-items:stretch;will-change:transform;transform:translateZ(0);pointer-events:auto;touch-action:manipulation}.app-shell>.app-footer,footer.app-footer{display:none!important}}.tab-btn{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:2px;position:relative;background:transparent;border:none;color:var(--color-text-muted);font-size:11px;font-weight:600;text-transform:none;letter-spacing:.01em;padding:8px 4px;min-width:0;cursor:pointer;touch-action:manipulation;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none;transition:color var(--duration-fast) var(--ease-out)}.tab-btn:not(:disabled):not([disabled]){pointer-events:auto}.tab-btn:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}.tab-btn:active{background:var(--color-background-active)}.tab-btn.active{color:var(--color-primary)}.tab-btn .tab-icon{display:flex;align-items:center;justify-content:center;height:24px;width:24px}.tab-btn .tab-icon svg{width:20px;height:20px}.tab-btn .tab-label{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.tab-btn .tab-icon{position:relative;transition:transform .2s var(--ease-spring),color .15s var(--ease-out)}.tab-btn:active .tab-icon{transform:scale(.88);transition:transform 80ms var(--ease-out)}.tab-btn:not(:active) .tab-icon{transition:transform .35s var(--ease-spring)}.tab-btn.active{position:relative;color:var(--color-primary)}.tab-btn.active:after{content:"";position:absolute;bottom:6px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--color-primary),transparent);border-radius:var(--radius-full);box-shadow:0 0 4px var(--color-glow-soft)}.tab-btn.active .tab-icon{filter:drop-shadow(0 0 2px var(--color-glow-soft))}.tab-btn:before{content:"";position:absolute;inset:4px;border-radius:var(--radius-lg);background:radial-gradient(circle at center,rgba(34,211,238,.1) 0%,transparent 70%);opacity:0;transform:scale(.5);transition:opacity .15s var(--ease-out),transform .15s var(--ease-out);pointer-events:none}.tab-btn:active:before{opacity:1;transform:scale(1);transition:none}.tab-btn .state-badge{position:absolute;top:-2px;right:-2px;width:8px;height:8px;border-radius:50%;background:var(--color-primary);border:2px solid var(--color-background-elevated)}.tab-btn:disabled,.tab-btn[disabled]{opacity:.4;cursor:not-allowed;pointer-events:none}.tab-btn:disabled .tab-icon,.tab-btn[disabled] .tab-icon{color:var(--color-text-disabled, var(--color-text-muted))}.tab-btn:disabled .tab-label,.tab-btn[disabled] .tab-label{color:var(--color-text-disabled, var(--color-text-muted))}.tab-btn:disabled:hover,.tab-btn:disabled:active,.tab-btn[disabled]:hover,.tab-btn[disabled]:active{background:transparent;color:var(--color-text-muted)}@media(max-width:640px)and (orientation:landscape){.control-deck{height:calc(48px + env(safe-area-inset-bottom,0px))}.tab-btn{padding:6px 4px;gap:1px}.tab-btn .tab-icon{height:20px;width:20px}.tab-btn .tab-icon svg{width:18px;height:18px}.tab-btn .tab-label{font-size:10px}}@media(prefers-reduced-motion:reduce){.tab-btn,.tab-btn .tab-icon,.tab-btn:before{transition:none}.tab-btn:active .tab-icon{transform:none}}:root{--fab-size: 56px;--fab-margin: 16px;--fab-gap-above-nav: 20px;--fab-bottom-tablet: calc(24px + env(safe-area-inset-bottom, 0px)) ;--fab-bottom-phone: calc(var(--mobile-tab-bar-height, 56px) + var(--fab-gap-above-nav) + env(safe-area-inset-bottom, 0px));--fab-bottom-landscape: calc(48px + var(--fab-gap-above-nav) + env(safe-area-inset-bottom, 0px))}.fab{position:fixed;bottom:var(--fab-bottom-tablet);right:calc(var(--fab-margin) + env(safe-area-inset-right,0px));width:var(--fab-size);height:var(--fab-size);border-radius:50%;border:none;background:var(--color-primary);color:var(--color-text-on-primary, #0a0a0f);box-shadow:0 4px 12px #0000004d,0 0 #22d3ee00;display:none;align-items:center;justify-content:center;cursor:pointer;z-index:var(--z-fixed);transition:transform .35s var(--ease-spring),box-shadow .2s var(--ease-out),background .15s var(--ease-out);-webkit-tap-highlight-color:transparent;will-change:transform;transform:translateZ(0)}.fab .fab-icon{display:flex;align-items:center;justify-content:center;transition:transform .35s var(--ease-spring)}.fab--open .fab-icon{transform:rotate(45deg)}.fab:active{transform:scale(.88);transition:transform 80ms var(--ease-out)}.fab:hover{box-shadow:0 8px 24px #00000059,0 0 12px #22d3ee2e}@keyframes fab-glow-pulse{0%,to{box-shadow:0 4px 12px #0000004d,0 0 #22d3ee00}50%{box-shadow:0 4px 12px #0000004d,0 0 10px #22d3ee1f}}.fab:not(.fab--open):not(:active){animation:fab-glow-pulse 3s ease-in-out infinite}.fab:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px;box-shadow:0 0 0 4px #4882ff59}.fab--no-anim,.fab--no-anim .fab-icon{transition:none}.fab--open{background:var(--color-background-elevated);color:var(--color-text);z-index:calc(var(--z-modal) + 10);animation:none;box-shadow:0 8px 20px #00000059,0 0 14px #22d3ee1f,inset 0 0 0 1px #22d3ee33}@media(max-width:900px){.fab{display:inline-flex}}@media(max-width:640px){.fab{bottom:var(--fab-bottom-phone)}}@media(max-width:640px)and (orientation:landscape){.fab{bottom:var(--fab-bottom-landscape)}}@media(prefers-reduced-motion:reduce){.fab,.fab .fab-icon{transition:none;animation:none}.fab:not(.fab--open):not(:active){animation:none}}@media(hover:none)and (pointer:coarse){.fab:not(.fab--open):not(:active){animation-duration:6s}}.fab-hint{position:fixed;bottom:calc(var(--fab-bottom-tablet) + var(--fab-size) / 2 - 12px);right:calc(var(--fab-margin) + env(safe-area-inset-right,0px) + var(--fab-size) + var(--space-3));display:none;align-items:center;padding:var(--space-2) var(--space-3);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);white-space:nowrap;box-shadow:var(--shadow-lg);z-index:var(--z-fixed);pointer-events:none;animation:fab-hint-fade-in .3s var(--ease-out) forwards;animation-delay:1s;opacity:0}@keyframes fab-hint-fade-in{0%{opacity:0;transform:translate(8px)}to{opacity:1;transform:translate(0)}}@media(max-width:900px){.fab-hint{display:flex}}@media(max-width:640px){.fab-hint{bottom:calc(var(--fab-bottom-phone) + var(--fab-size) / 2 - 12px)}}@media(max-width:640px)and (orientation:landscape){.fab-hint{bottom:calc(var(--fab-bottom-landscape) + var(--fab-size) / 2 - 12px)}}.fab-hint--hidden,.fab--open~.fab-hint{display:none!important}@media(prefers-reduced-motion:reduce){.fab-hint{animation:none;opacity:1}}.phage-picker-trigger{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;border-radius:var(--radius-lg);border:1px solid transparent;background:var(--color-background-hover);color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);cursor:pointer;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),transform .35s var(--ease-spring),box-shadow var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;max-width:200px;min-width:0;will-change:transform}@media(max-width:380px){.phage-picker-trigger{max-width:140px;padding:.25rem .5rem;gap:.25rem;font-size:var(--text-xs)}.phage-picker-trigger__badge{display:none}}.phage-picker-trigger:hover{background:var(--color-background-active);box-shadow:0 2px 8px #00000026}.phage-picker-trigger:active{background:var(--color-background-active);transform:scale(.96);transition:transform 80ms var(--ease-out)}.phage-picker-trigger:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.phage-picker-trigger--open{border-color:var(--color-primary);background:var(--color-background-active)}.phage-picker-trigger__name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.phage-picker-trigger__badge{flex-shrink:0;padding:.125rem .375rem;border-radius:var(--radius-full);background:var(--color-background-elevated);color:var(--color-text-muted);font-size:var(--text-2xs);font-weight:var(--font-medium);font-variant-numeric:tabular-nums}.phage-picker-trigger svg{transition:transform .35s var(--ease-spring);flex-shrink:0;color:var(--color-text-dim)}.phage-picker-trigger--open svg{transform:rotate(180deg);color:var(--color-primary)}.phage-picker-sheet{display:flex;flex-direction:column;gap:var(--space-3);height:100%;overflow:hidden}.phage-picker-sheet__search{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-lg);color:var(--color-text-dim);transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out),background .2s var(--ease-out)}.phage-picker-sheet__search:focus-within{border-color:var(--color-border-focus);box-shadow:0 0 0 3px #22d3ee26;background:var(--color-background-alt)}.phage-picker-sheet__search-input{flex:1;border:none;background:transparent;color:var(--color-text);font-size:var(--text-base);outline:none;min-width:0}.phage-picker-sheet__search-input::placeholder{color:var(--color-text-muted)}.phage-picker-sheet__list{flex:1;overflow-y:auto;overflow-x:hidden;margin:0;padding:0;overscroll-behavior:contain;-webkit-overflow-scrolling:touch}.phage-picker-sheet__empty{padding:var(--space-6) var(--space-4);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.phage-picker-sheet__item{position:relative;display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);width:100%;padding:var(--space-3) var(--space-2);margin-bottom:2px;border:none;border-radius:var(--radius-md);background:transparent;color:var(--color-text);text-align:left;cursor:pointer;transition:background .15s var(--ease-out),transform .35s var(--ease-spring),box-shadow .15s var(--ease-out);-webkit-tap-highlight-color:transparent;will-change:transform}.phage-picker-sheet__item:hover{background:var(--color-background-hover)}.phage-picker-sheet__item:active{background:var(--color-background-active);transform:scale(.98);transition:transform 80ms var(--ease-out)}.phage-picker-sheet__item--selected{background:#22d3ee14;box-shadow:inset 0 0 0 1px #22d3ee33}.phage-picker-sheet__item--selected:hover{background:#22d3ee1f}.phage-picker-sheet__item:before{content:"";position:absolute;left:0;top:20%;bottom:20%;width:3px;background:var(--color-primary);border-radius:var(--radius-full);opacity:0;transform:scaleY(0);transition:opacity .15s var(--ease-out),transform .35s var(--ease-spring)}.phage-picker-sheet__item--selected:before{opacity:1;transform:scaleY(1)}.phage-picker-sheet__item-content{display:flex;flex-direction:column;gap:2px;min-width:0}.phage-picker-sheet__item-name{font-weight:var(--font-medium);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phage-picker-sheet__item--selected .phage-picker-sheet__item-name{color:var(--color-primary)}.phage-picker-sheet__item-meta{font-size:var(--text-xs);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.phage-picker-sheet__item-check{flex-shrink:0;color:var(--color-primary)}.phage-picker-sheet__item:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:-2px}@media(min-width:641px){.phage-picker-trigger{background:transparent;padding:0;cursor:default}.phage-picker-trigger svg,.phage-picker-trigger__badge{display:none}.phage-picker-trigger:hover,.phage-picker-trigger:active{background:transparent;transform:none}}@media(prefers-reduced-motion:reduce){.phage-picker-trigger,.phage-picker-trigger svg,.phage-picker-sheet__search,.phage-picker-sheet__item,.phage-picker-sheet__item:before{transition:none}.phage-picker-trigger:active,.phage-picker-sheet__item:active{transform:none}}.action-drawer{padding:var(--space-3) var(--space-4);padding-bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px))}.action-drawer__category{margin-bottom:var(--space-4)}.action-drawer__category:last-child{margin-bottom:0}.action-drawer__category-label{font-size:var(--text-xs);font-weight:var(--font-semibold);text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin:0 0 var(--space-3) var(--space-1);padding-bottom:var(--space-1);border-bottom:1px solid var(--color-border-subtle)}.action-drawer__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}@media(max-width:380px){.action-drawer__grid{grid-template-columns:repeat(3,1fr);gap:var(--space-2)}}@media(min-width:641px)and (max-width:900px){.action-drawer__grid{grid-template-columns:repeat(5,1fr)}}.action-drawer__item{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-3) var(--space-2);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-lg);cursor:pointer;transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out);-webkit-tap-highlight-color:transparent;min-height:72px}.action-drawer__item:active{transform:scale(.95);background:var(--color-background-active)}.action-drawer__item:focus-visible{outline:2px solid var(--color-border-focus);outline-offset:2px}.action-drawer__item--active{background:color-mix(in srgb,var(--color-primary) 15%,transparent);border-color:var(--color-primary);color:var(--color-primary)}.action-drawer__item--active .action-drawer__item-icon{color:var(--color-primary)}.action-drawer__item--disabled{opacity:.45;cursor:not-allowed;position:relative}.action-drawer__item--disabled:active{transform:none;background:var(--color-background-elevated)}.action-drawer__item-hint{position:absolute;inset:0;display:flex;align-items:center;justify-content:center;background:#000000bf;border-radius:var(--radius-lg);font-size:var(--text-xs);color:var(--color-text-muted);text-align:center;padding:var(--space-2);opacity:0;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-out)}.action-drawer__item--disabled:focus .action-drawer__item-hint,.action-drawer__item--disabled:active .action-drawer__item-hint{opacity:1}.action-drawer__item--disabled:after{content:"Select a phage first";position:absolute;bottom:calc(100% + var(--space-2));left:50%;transform:translate(-50%);padding:var(--space-2) var(--space-3);background:var(--color-background-elevated);border:1px solid var(--color-border);border-radius:var(--radius-md);font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity var(--duration-fast) var(--ease-out);z-index:100;box-shadow:var(--shadow-lg);min-height:auto;min-width:auto}.action-drawer__item--disabled:focus:after,.action-drawer__item--disabled:active:after{opacity:1}.action-drawer__item--disabled:has(.action-drawer__item-hint):after{display:none}.action-drawer__item-icon{display:flex;align-items:center;justify-content:center;color:var(--color-text);transition:color var(--duration-fast) var(--ease-out)}.action-drawer__item-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text);text-align:center;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:100%}.action-drawer__item-shortcut{font-size:var(--text-2xs);line-height:1;padding:2px 6px;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-background);color:var(--color-text-muted)}@media(prefers-reduced-motion:reduce){.action-drawer__item{transition:none}.action-drawer__item:active{transform:none}}.action-toolbar{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3) var(--space-4);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);box-shadow:var(--shadow-md);flex-wrap:wrap}.toolbar-section{display:flex;align-items:center;gap:var(--space-2)}.toolbar-section--compact{gap:var(--space-1)}.toolbar-label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.toolbar-button-group{display:flex;align-items:center;gap:0;background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:2px;box-shadow:inset 0 1px #ffffff08,0 1px 2px #0000001a}.toolbar-button-group .toolbar-btn:not(:first-child):before{content:"";position:absolute;left:0;top:20%;height:60%;width:1px;background:var(--color-border-subtle);opacity:.5;transition:opacity var(--duration-fast) var(--ease-out)}.toolbar-button-group .toolbar-btn:hover:before,.toolbar-button-group .toolbar-btn.active:before,.toolbar-button-group .toolbar-btn.active+.toolbar-btn:before{opacity:0}.toolbar-button-group .toolbar-btn:first-child{border-top-left-radius:calc(var(--radius-lg) - 2px);border-bottom-left-radius:calc(var(--radius-lg) - 2px)}.toolbar-button-group .toolbar-btn:last-child{border-top-right-radius:calc(var(--radius-lg) - 2px);border-bottom-right-radius:calc(var(--radius-lg) - 2px)}.toolbar-button-group .toolbar-btn:not(:first-child):not(:last-child){border-radius:0}.toolbar-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);min-height:36px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-dim);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);white-space:nowrap;position:relative}.toolbar-btn:hover:not(:disabled){background:var(--color-background-hover);color:var(--color-text)}.toolbar-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background),0 0 0 4px var(--color-primary)}.toolbar-btn.active{background:var(--color-primary);color:var(--color-background);box-shadow:var(--shadow-sm),inset 0 1px #ffffff26}.toolbar-btn:active:not(:disabled){transform:scale(.97)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn--primary{background:var(--color-primary);color:var(--color-background)}.toolbar-btn--primary:hover:not(:disabled){background:var(--color-primary-hover);color:var(--color-background)}.toolbar-btn--icon{padding:var(--space-2);min-width:36px}.toolbar-btn--small{padding:var(--space-1) var(--space-2);min-height:28px}.toolbar-btn-label{display:none}@media(min-width:1200px){.toolbar-btn-label{display:inline}}.toolbar-select{padding:var(--space-2) var(--space-3);padding-right:var(--space-6);min-height:36px;background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-medium);cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%236b7280' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}.toolbar-select:hover:not(:disabled){border-color:var(--color-border-light)}.toolbar-select:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #22d3ee33}.toolbar-divider{width:1px;height:24px;background:var(--color-border-subtle);margin:0 var(--space-2)}.toolbar-spacer{flex:1;min-width:var(--space-4)}@media(max-width:900px){.action-toolbar{display:none}}@media(min-width:1440px){.action-toolbar{padding:var(--space-3) var(--space-6);gap:var(--space-3)}.toolbar-section{gap:var(--space-3)}.toolbar-btn{padding:var(--space-2) var(--space-4)}}@media(min-width:1920px){.action-toolbar{padding:var(--space-4) var(--space-8);gap:var(--space-4)}}.analysis-sidebar{display:flex;flex-direction:column;width:280px;min-width:280px;max-width:320px;height:100%;background:var(--color-background-alt);border:1px solid var(--color-border-light);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);overflow:hidden;transition:width var(--duration-normal) var(--ease-out),min-width var(--duration-normal) var(--ease-out),max-width var(--duration-normal) var(--ease-out),padding var(--duration-normal) var(--ease-out)}.analysis-sidebar--collapsed{width:56px;min-width:56px;max-width:56px;padding:var(--space-2);align-items:center}@media(prefers-reduced-motion:reduce){.analysis-sidebar{transition:none}}.sidebar-expand-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);color:var(--color-text-dim);cursor:pointer;transition:all var(--duration-fast) var(--ease-out);margin-bottom:var(--space-3)}.sidebar-expand-btn:hover{background:var(--color-background-hover);color:var(--color-text)}.sidebar-expand-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background-elevated),0 0 0 4px var(--color-primary)}.sidebar-icons{display:flex;flex-direction:column;gap:var(--space-2)}.sidebar-icon-btn{display:flex;align-items:center;justify-content:center;width:44px;height:44px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-dim);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.sidebar-icon-btn:hover{background:var(--color-background-alt);color:var(--color-primary)}.sidebar-icon-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background-elevated),0 0 0 4px var(--color-primary)}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-4);border-bottom:1px solid var(--color-border-subtle)}.sidebar-title{display:flex;align-items:center;gap:var(--space-2);margin:0;font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-text)}.sidebar-collapse-btn{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text-dim);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.sidebar-collapse-btn:hover{background:var(--color-background-alt);color:var(--color-text)}.sidebar-collapse-btn:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background-elevated),0 0 0 4px var(--color-primary)}.sidebar-empty{padding:var(--space-6);text-align:center;color:var(--color-text-muted);font-size:var(--text-sm)}.sidebar-categories{flex:1;overflow-y:auto;padding:var(--space-2)}.sidebar-category{margin-bottom:var(--space-1)}.category-header{display:flex;align-items:center;gap:var(--space-2);width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);font-weight:var(--font-semibold);text-align:left;cursor:pointer;transition:background var(--duration-fast) var(--ease-out)}.category-header:hover{background:var(--color-background-alt)}.category-header:focus-visible{outline:none;background:var(--color-background-alt);box-shadow:inset 0 0 0 2px var(--color-primary)}.category-icon{display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.category-name{flex:1}.category-level{padding:2px 6px;font-size:var(--text-2xs);font-weight:var(--font-medium);text-transform:uppercase;letter-spacing:.05em;border-radius:var(--radius-full)}.category-level--intermediate{background:#f59e0b26;color:var(--color-warning)}.category-level--power{background:#a855f726;color:#a855f7}.category-chevron{display:flex;align-items:center;color:var(--color-text-dim)}.category-tools{list-style:none;margin:0;padding:0;padding-left:var(--space-6)}.tool-btn{display:flex;align-items:center;justify-content:space-between;width:100%;padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-md);color:var(--color-text);font-size:var(--text-sm);text-align:left;cursor:pointer;transition:background-color var(--duration-fast) var(--ease-out),color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out);position:relative}.tool-btn:hover:not(:disabled){background:var(--color-background-hover);color:var(--color-text)}.tool-btn:hover:not(:disabled):before{content:"";position:absolute;left:0;top:4px;bottom:4px;width:2px;background:var(--color-primary);border-radius:1px;opacity:.7}.tool-btn:focus-visible{outline:none;background:var(--color-background-hover);box-shadow:0 0 0 2px var(--color-background-elevated),0 0 0 4px var(--color-primary)}.tool-btn:disabled{opacity:.4;cursor:not-allowed}.tool-name{flex:1}.tool-shortcut{padding:2px 6px;font-size:var(--text-2xs);font-family:var(--font-mono);background:var(--color-background-alt);border:1px solid var(--color-border-light);border-radius:var(--radius-sm);color:var(--color-text-dim)}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--color-border-subtle)}.sidebar-help-btn{width:100%;padding:var(--space-2) var(--space-3);background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);color:var(--color-text-dim);font-size:var(--text-sm);cursor:pointer;transition:all var(--duration-fast) var(--ease-out)}.sidebar-help-btn:hover{background:var(--color-background-hover);color:var(--color-text);border-color:var(--color-border-light)}.sidebar-help-btn:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px #22d3ee33}@media(max-width:1200px){.analysis-sidebar{display:none}}@media(min-width:1600px){.analysis-sidebar{width:300px;min-width:300px;max-width:360px}}@media(min-width:1920px){.analysis-sidebar{width:340px;min-width:340px;max-width:400px}}@media(min-width:2560px){.analysis-sidebar{width:380px;min-width:380px;max-width:440px}.sidebar-header{padding:var(--space-5)}.sidebar-title{font-size:var(--text-lg)}.category-header{padding:var(--space-3) var(--space-4);font-size:var(--text-base)}.tool-btn{padding:var(--space-3) var(--space-4)}}.dashboard-layout{display:block}.dashboard-layout--with-sidebar{display:grid;grid-template-columns:1fr auto;gap:var(--space-4);align-items:start}@media(min-width:1200px){.dashboard-layout--with-sidebar{gap:var(--space-5)}}@media(min-width:1920px){.dashboard-layout--with-sidebar{gap:var(--space-6)}}@media(min-width:2560px){.dashboard-layout--with-sidebar{gap:var(--space-8)}}.quick-stats{display:flex;align-items:stretch;gap:var(--space-5);padding:var(--space-3) var(--space-5);background:var(--color-background-alt);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);flex-wrap:wrap}.quick-stats--mobile{border-radius:var(--radius-md);margin-bottom:var(--space-2);overflow-x:auto;overflow-y:hidden;flex-wrap:nowrap;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch}.quick-stats--mobile::-webkit-scrollbar{display:none}.quick-stat{display:flex;flex-direction:column;gap:4px;min-width:max-content;position:relative;padding-right:var(--space-5);flex-shrink:0}.quick-stat--wide{min-width:0;flex-shrink:1;max-width:200px}.quick-stat:not(:last-child):after{content:"";position:absolute;right:0;top:4px;bottom:4px;width:1px;background:var(--color-border-subtle);opacity:.4}.quick-stat__label{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;white-space:nowrap}.quick-stat__value{font-size:var(--text-base);font-weight:var(--font-semibold);color:var(--color-text);font-variant-numeric:tabular-nums;white-space:nowrap}.quick-stat__value--highlight{color:var(--color-primary);text-shadow:0 0 8px rgba(34,211,238,.3)}.quick-stat__value--host{max-width:180px;overflow:hidden;text-overflow:ellipsis}.quick-stat__value--mono{font-family:var(--font-mono);font-size:var(--text-sm);letter-spacing:-.01em}.quick-stat__detail{opacity:.6;font-size:.85em;font-weight:var(--font-normal)}@media(max-width:900px){.quick-stats{gap:var(--space-4);padding:var(--space-3) var(--space-4)}.quick-stat{padding-right:var(--space-4)}.quick-stat__value{font-size:var(--text-sm)}}@media(max-width:640px){.quick-stats{gap:var(--space-4);padding:var(--space-3) var(--space-4);flex-wrap:nowrap;overflow-x:auto;overflow-y:hidden;scrollbar-width:none;-webkit-overflow-scrolling:touch}.quick-stats::-webkit-scrollbar{display:none}.quick-stat{padding-right:var(--space-4)}.quick-stat__label{font-size:11px}.quick-stat__value{font-size:var(--text-sm)}.quick-stat__value--host{max-width:140px}.quick-stat:not(:last-child):after{opacity:.3}}@media(hover:none)and (pointer:coarse){.quick-stats{background:var(--color-background-alt)}}.main-content-area{display:flex;flex-direction:column;gap:var(--space-4);min-width:0;flex:1}.viewers-grid{display:grid;grid-template-columns:1fr;gap:var(--space-4)}@media(min-width:1024px){.viewers-grid{grid-template-columns:1fr 1fr;gap:var(--space-5)}}@media(min-width:1920px){.viewers-grid{gap:var(--space-6)}}@media(min-width:2560px){.viewers-grid{gap:var(--space-8)}}.viewers-grid--single{grid-template-columns:1fr}@media(min-width:1024px){.viewers-grid--single{grid-template-columns:1fr;max-width:none}}.toast-container{position:fixed;bottom:var(--space-4);right:var(--space-4);z-index:var(--z-toast, 9000);display:flex;flex-direction:column-reverse;gap:var(--space-2);pointer-events:none;max-width:420px;width:100%}.toast-item{pointer-events:auto;position:relative;overflow:hidden;background:var(--color-background-elevated, #1a1a2e);border:1px solid var(--color-border-subtle, #333);border-radius:var(--radius-lg, 8px);box-shadow:var(--shadow-lg, 0 8px 24px rgba(0, 0, 0, .4));color:var(--color-text, #e0e0e0);font-size:var(--text-sm, .875rem);animation:toast-slide-in var(--duration-normal, .25s) var(--ease-out, ease-out) forwards}.toast-item--exiting{animation:toast-slide-out var(--duration-fast, .15s) var(--ease-in, ease-in) forwards}.toast-item__body{display:flex;align-items:flex-start;gap:var(--space-3, .75rem);padding:var(--space-3, .75rem) var(--space-4, 1rem)}.toast-item__icon{flex-shrink:0;display:flex;align-items:center;font-size:var(--text-base, 1rem);line-height:1;margin-top:1px}.toast-item__content{flex:1;min-width:0}.toast-item__title{font-weight:var(--font-semibold, 600);margin-bottom:2px}.toast-item__message{color:var(--color-text-muted, #999);line-height:var(--leading-relaxed, 1.6)}.toast-item__close{flex-shrink:0;background:none;border:none;color:var(--color-text-dim, #666);cursor:pointer;padding:var(--space-1, .25rem);border-radius:var(--radius-sm, 4px);display:flex;align-items:center;justify-content:center;min-width:28px;min-height:28px;transition:color var(--duration-fast, .15s) var(--ease-out, ease-out)}.toast-item__close:hover{color:var(--color-text, #e0e0e0)}.toast-item__actions{display:flex;gap:var(--space-2, .5rem);padding:0 var(--space-4, 1rem) var(--space-3, .75rem);padding-left:calc(var(--space-4, 1rem) + var(--space-3, .75rem) + 1rem)}.toast-item__progress{position:absolute;bottom:0;left:0;height:2px;background:var(--color-primary, #00ffff);transition:width .1s linear;border-radius:0 0 0 var(--radius-lg, 8px)}.toast-item--info .toast-item__icon{color:var(--color-primary, #00ffff)}.toast-item--info .toast-item__progress{background:var(--color-primary, #00ffff)}.toast-item--success .toast-item__icon{color:var(--color-success, #22c55e)}.toast-item--success .toast-item__progress{background:var(--color-success, #22c55e)}.toast-item--warning .toast-item__icon{color:var(--color-warning, #f59e0b)}.toast-item--warning .toast-item__progress{background:var(--color-warning, #f59e0b)}.toast-item--warning{border-color:#f59e0b40}.toast-item--error .toast-item__icon{color:var(--color-error, #ef4444)}.toast-item--error .toast-item__progress{background:var(--color-error, #ef4444)}.toast-item--error{border-color:#ef444440}@keyframes toast-slide-in{0%{opacity:0;transform:translate(100%) scale(.95)}to{opacity:1;transform:translate(0) scale(1)}}@keyframes toast-slide-out{0%{opacity:1;transform:translate(0) scale(1)}to{opacity:0;transform:translate(100%) scale(.95)}}@media(prefers-reduced-motion:reduce){.toast-item{animation:none;opacity:1}.toast-item--exiting{animation:none;opacity:0}}@media(max-width:640px){.toast-container{bottom:calc(var(--space-4) + env(safe-area-inset-bottom,0px) + 64px);left:var(--space-3);right:var(--space-3);max-width:none}}.tooltip-container{position:relative;display:inline-block}.tooltip-content{position:absolute;z-index:var(--z-tooltip, 1000);padding:var(--space-2, .5rem) var(--space-3, .75rem);background:var(--color-background-alt, #1a1a2e);color:var(--color-text, #e0e0e0);border:1px solid var(--color-border, #333);border-radius:var(--radius-md, 6px);font-size:var(--text-xs, .75rem);white-space:nowrap;pointer-events:none;box-shadow:var(--shadow-md, 0 4px 12px rgba(0, 0, 0, .3));animation:tooltip-enter var(--duration-fast, .15s) var(--ease-out, ease-out) forwards}.tooltip-top{bottom:100%;left:50%;transform:translate(-50%);margin-bottom:var(--space-2, .5rem);--tooltip-enter-from: translateX(-50%) translateY(4px);--tooltip-enter-to: translateX(-50%) translateY(0)}.tooltip-bottom{top:100%;left:50%;transform:translate(-50%);margin-top:var(--space-2, .5rem);--tooltip-enter-from: translateX(-50%) translateY(-4px);--tooltip-enter-to: translateX(-50%) translateY(0)}.tooltip-left{right:100%;top:50%;transform:translateY(-50%);margin-right:var(--space-2, .5rem);--tooltip-enter-from: translateY(-50%) translateX(4px);--tooltip-enter-to: translateY(-50%) translateX(0)}.tooltip-right{left:100%;top:50%;transform:translateY(-50%);margin-left:var(--space-2, .5rem);--tooltip-enter-from: translateY(-50%) translateX(-4px);--tooltip-enter-to: translateY(-50%) translateX(0)}.tooltip-top.tooltip-flipped{bottom:auto;top:100%;margin-bottom:0;margin-top:var(--space-2, .5rem);--tooltip-enter-from: translateX(-50%) translateY(-4px);--tooltip-enter-to: translateX(-50%) translateY(0)}.tooltip-bottom.tooltip-flipped{top:auto;bottom:100%;margin-top:0;margin-bottom:var(--space-2, .5rem);--tooltip-enter-from: translateX(-50%) translateY(4px);--tooltip-enter-to: translateX(-50%) translateY(0)}.tooltip-left.tooltip-flipped{right:auto;left:100%;margin-right:0;margin-left:var(--space-2, .5rem);--tooltip-enter-from: translateY(-50%) translateX(-4px);--tooltip-enter-to: translateY(-50%) translateX(0)}.tooltip-right.tooltip-flipped{left:auto;right:100%;margin-left:0;margin-right:var(--space-2, .5rem);--tooltip-enter-from: translateY(-50%) translateX(4px);--tooltip-enter-to: translateY(-50%) translateX(0)}@keyframes tooltip-enter{0%{opacity:0;transform:var(--tooltip-enter-from, translateX(-50%) translateY(4px))}to{opacity:1;transform:var(--tooltip-enter-to, translateX(-50%) translateY(0))}}@media(prefers-reduced-motion:reduce){.tooltip-content{animation:none;opacity:1}}.app-shell{display:grid;grid-template-rows:auto minmax(0,1fr) auto;height:100vh;height:100dvh;height:var(--app-height, 100vh);min-height:100vh;min-height:100dvh;min-height:var(--app-height, 100vh);background:var(--color-background);position:relative;overflow:hidden}.app-header{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-5);background:var(--color-background-glass);backdrop-filter:blur(12px) saturate(180%);-webkit-backdrop-filter:blur(12px) saturate(180%);border-bottom:1px solid var(--color-border-subtle);position:sticky;top:0;z-index:var(--z-sticky);transition:background var(--duration-normal) var(--ease-out)}.app-header.scrolled{background:#0a0a0ff2;box-shadow:var(--shadow-md)}.header-left,.header-right{display:flex;align-items:center;gap:var(--space-4)}.app-title{font-size:var(--text-lg);font-weight:var(--font-bold);letter-spacing:var(--tracking-tight);color:var(--color-primary);text-shadow:0 0 12px var(--color-glow-soft);transition:text-shadow var(--duration-normal) var(--ease-out)}.app-title:hover{text-shadow:0 0 16px var(--color-glow-soft)}.app-subtitle{font-size:var(--text-xs);color:var(--color-text-muted);letter-spacing:var(--tracking-normal);padding:var(--space-1) var(--space-2);background:var(--color-background-elevated);border-radius:var(--radius-full);border:1px solid var(--color-border-subtle)}.header-action{background:var(--color-header-action-bg);border-color:var(--color-border-subtle);padding:var(--space-2) var(--space-3);min-height:36px;gap:var(--space-2)}.header-action:before,.header-action:after{display:none}.header-action:hover{background:var(--color-header-action-bg-hover);border-color:var(--color-border-light);box-shadow:var(--shadow-sm)}.header-action:active{box-shadow:var(--shadow-xs),inset 0 1px 2px #00000026}.header-action__label{font-size:var(--text-sm);font-weight:var(--font-medium)}.header-action__shortcut{font-size:var(--text-2xs);padding:1px 6px;border-radius:5px;opacity:.85;background:#0000002e;border-color:var(--color-border-subtle);color:var(--color-text-dim)}@media(max-width:1024px){.header-action{padding:var(--space-1) var(--space-2);font-size:var(--text-xs);min-height:32px}.header-action__shortcut{display:none}}@media(max-width:640px){.app-header{padding-left:calc(var(--space-3) + env(safe-area-inset-left,0px));padding-right:calc(var(--space-3) + env(safe-area-inset-right,0px));flex-wrap:nowrap;gap:var(--space-2);min-height:calc(var(--mobile-header-height, 56px) + env(safe-area-inset-top,0px));padding-top:calc(var(--space-2) + env(safe-area-inset-top,0px));padding-bottom:var(--space-2)}.header-left{flex:1 1 auto;min-width:0;gap:var(--space-2)}.header-right{flex:0 0 auto;gap:var(--space-1)}.app-header .badge{display:none}.app-title{font-size:var(--text-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.app-subtitle{display:none}.header-left .badge{padding:2px 6px;font-size:10px}.header-action{padding:var(--space-2);min-width:44px;min-height:44px}.header-action__label,.header-action__shortcut{display:none}}@media(max-width:380px){.app-title{max-width:120px;font-size:var(--text-xs)}.header-right .btn{padding:var(--space-2) var(--space-2);font-size:11px;min-height:44px}.header-right .btn{overflow:hidden;max-width:80px;text-overflow:ellipsis}}.app-body{flex:1;min-height:0;overflow:auto;overflow-x:hidden;padding:var(--space-6);display:flex;flex-direction:column;gap:var(--space-5);width:100%;max-width:1400px;margin:0 auto}@media(min-width:1600px){.app-body{max-width:1600px;padding:var(--space-6) var(--space-8)}}@media(min-width:1920px){.app-body{max-width:calc(100% - 6rem);padding:var(--space-6) var(--space-10)}}@media(min-width:2560px){.app-body{max-width:calc(100% - 8rem);padding:var(--space-8) var(--space-12)}}@media(max-width:640px){:root{--footer-height: 0rem}.app-shell{padding-bottom:calc(var(--mobile-tab-bar-height, 56px) + env(safe-area-inset-bottom,0px))}.app-body{padding:var(--space-4);padding-bottom:calc(var(--mobile-tab-bar-height, 56px) + env(safe-area-inset-bottom,0px) + 72px);gap:var(--space-4);max-width:100%}}@media(max-width:380px){.app-body{padding:var(--space-3);padding-bottom:calc(var(--mobile-tab-bar-height, 56px) + env(safe-area-inset-bottom,0px) + 72px);gap:var(--space-3)}}.app-footer{display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-5);background:var(--color-background-glass);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border-top:1px solid var(--color-border-subtle);font-size:var(--text-xs);color:var(--color-text-muted)}.footer-version{color:var(--color-text-muted);font-variant-numeric:tabular-nums}.footer-hints{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap}.hint-separator{color:var(--color-border-light);user-select:none}.hint-item{display:inline-flex;align-items:center;gap:var(--space-1)}.hint-item .key-hint{font-size:var(--text-2xs);padding:2px 5px;min-width:auto}.hint-label{color:var(--color-text-muted)}@media(max-width:768px){.footer-hints{display:none}.app-footer{justify-content:center}}@media(max-width:640px){.app-footer{padding:0 var(--space-3)}.footer-hints{gap:var(--space-2)}}.card{background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-6);box-shadow:var(--shadow-md);transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.card:hover{border-color:var(--color-border-light);box-shadow:var(--shadow-lg)}.card:focus-within{border-color:var(--color-primary);box-shadow:var(--shadow-glow)}.card h1,.card h2,.card h3{margin:0 0 var(--space-3);color:var(--color-text);letter-spacing:var(--tracking-tight)}.card h1{font-size:var(--text-2xl)}.card h2{font-size:var(--text-xl)}.card h3{font-size:var(--text-lg)}.card p{margin:0;color:var(--color-text-dim);line-height:var(--leading-relaxed)}.cards-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-5)}@media(max-width:640px){.cards-grid{grid-template-columns:1fr;gap:var(--space-4)}.card{padding:var(--space-4)}}.sparkline,.histogram{display:block;border-radius:var(--radius-md);overflow:hidden}.recent-commands{display:flex;flex-direction:column;gap:var(--space-2);min-width:160px}.recent-commands__title{font-size:var(--text-xs);font-weight:var(--font-medium);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:var(--tracking-wide)}.recent-commands__empty{color:var(--color-text-muted);font-size:var(--text-xs);font-style:italic}.recent-commands__list{list-style:none;padding:0;margin:0;display:flex;gap:var(--space-2);flex-wrap:wrap}.recent-commands__item{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:var(--color-background-elevated);color:var(--color-text-dim);font-size:var(--text-xs);transition:background var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.recent-commands__item:hover{background:var(--color-background-hover);border-color:var(--color-border-light)}.recent-commands__item .dot{width:6px;height:6px;border-radius:50%;background:var(--color-primary);display:inline-block;flex-shrink:0}.beginner-indicator{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;margin-left:var(--space-3, 12px);border-radius:var(--radius-lg, 12px);background:var(--color-background-elevated);border:1px solid var(--color-border-subtle);box-shadow:var(--shadow-sm)}.beginner-indicator__button{display:inline-flex;align-items:center;gap:6px;border:none;background:transparent;color:var(--color-text);font-weight:var(--font-medium);cursor:pointer;padding:4px 6px}.beginner-indicator__dot{width:10px;height:10px;border-radius:50%;background:var(--color-success, #22c55e);box-shadow:0 0 10px #22c55e99}.beginner-indicator__text{white-space:nowrap;font-size:var(--text-sm, .9rem)}.beginner-indicator__dismiss{border:none;background:transparent;color:var(--color-text-muted);cursor:pointer;padding:4px 6px;font-size:.9rem;line-height:1}.beginner-indicator__dismiss:hover{color:var(--color-text)}.rfv-card{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg, 12px);padding:var(--space-4, 16px);background:var(--color-background-elevated);box-shadow:var(--shadow-sm);display:flex;flex-direction:column;gap:var(--space-3, 12px)}.rfv-header{display:flex;flex-direction:column;gap:4px}.rfv-title{font-weight:var(--font-semibold, 700);color:var(--color-text)}.rfv-subtitle{color:var(--color-text-muted);font-size:var(--text-sm, .9rem)}.rfv-grid{display:flex;flex-direction:column;gap:8px}.rfv-row{display:grid;grid-template-columns:48px 1fr;gap:8px;align-items:center;font-family:var(--font-mono, ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace)}.rfv-label{display:inline-flex;align-items:center;justify-content:center;padding:6px 8px;border-radius:var(--radius-md, 8px);background:var(--color-background-alt);color:var(--color-text);font-weight:var(--font-semibold, 700);min-width:44px}.rfv-aa{color:var(--color-text);font-size:var(--text-sm, .9rem);letter-spacing:.4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.rfv-footnote{color:var(--color-text-muted);font-size:var(--text-xs, .8rem)}.crt-overlay{position:fixed;inset:0;pointer-events:none;z-index:var(--z-crt);overflow:hidden}.scanlines{position:absolute;inset:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.015) 2px,rgba(0,0,0,.015) 4px);pointer-events:none}.vignette{position:absolute;inset:0;background:radial-gradient(ellipse at center,transparent 60%,rgba(0,0,0,.15) 90%,rgba(0,0,0,.35) 100%);pointer-events:none}.noise{position:absolute;inset:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.8' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.015;pointer-events:none;mix-blend-mode:overlay}@media(max-width:640px){.scanlines,.noise{display:none}.vignette{background:radial-gradient(ellipse at center,transparent 70%,rgba(0,0,0,.2) 100%)}}@media(prefers-reduced-motion:reduce){.crt-overlay{display:none}}.glossary-drawer{position:fixed;right:1rem;bottom:1rem;top:1rem;width:min(480px,42vw);background:var(--color-background);border:1px solid var(--color-border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg);padding:.75rem;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);z-index:var(--z-overlay);display:flex;flex-direction:column;gap:.75rem}.glossary-drawer__header{display:flex;align-items:center;justify-content:space-between;gap:.5rem}.glossary-drawer__eyebrow{font-size:.75rem;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.04em}.glossary-drawer__title{font-size:1.15rem;font-weight:800}.glossary-backdrop{position:fixed;inset:0;background:#0508148c;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);border:none;padding:0;margin:0;cursor:pointer;z-index:calc(var(--z-overlay) - 1)}.glossary-shell{position:fixed;top:var(--header-height, 64px);right:0;bottom:var(--footer-height, 60px);width:min(440px,45vw);background:var(--color-background);border-left:1px solid var(--color-border-subtle);box-shadow:var(--shadow-lg, 0 12px 36px rgba(0, 0, 0, .35));z-index:var(--z-overlay);display:flex;flex-direction:column;transform:translate(100%);transition:transform var(--duration-normal, .18s) var(--ease-out)}.glossary-shell.is-open{transform:translate(0)}.glossary-shell--beginner{border-left-color:var(--color-accent, #22d3ee);box-shadow:0 18px 48px #22d3ee2e}.glossary-shell__header{display:flex;align-items:center;justify-content:space-between;padding:.65rem .85rem;border-bottom:1px solid var(--color-border-subtle);background:var(--color-background-elevated)}.glossary-shell__title{font-weight:800;font-size:1.1rem}.glossary-shell__body{padding:.75rem;overflow:auto;flex:1}@media(max-width:900px){.glossary-shell{width:min(520px,92vw);right:0;left:auto;border-radius:var(--radius-lg) 0 0 var(--radius-lg)}}@media(max-width:640px){.glossary-shell{top:0;bottom:0;width:100%;border-left:none;border-radius:0}}.chip{display:inline-flex;align-items:center;justify-content:center;padding:.35rem .65rem;border-radius:999px;border:1px solid var(--color-border-subtle);background:var(--color-surface-0, rgba(255, 255, 255, .02));color:var(--color-text);font-size:.9rem;cursor:pointer;transition:transform var(--duration-fast, .12s) var(--ease-out),border-color var(--duration-fast, .12s) var(--ease-out)}.chip:focus-visible{outline:2px solid var(--color-accent, #22d3ee);outline-offset:2px}.chip:hover{transform:translateY(-1px)}.chip-ghost{background:transparent}.chip[aria-selected=true],.chip[aria-pressed=true]{background:var(--color-background-hover);border-color:var(--color-primary);color:var(--color-primary)}.info-button{display:inline-flex;align-items:center;justify-content:center;width:28px;height:28px;border-radius:999px;border:1px solid var(--color-border-subtle, #2a2f3b);background:var(--color-surface-1, rgba(255, 255, 255, .04));color:var(--color-accent, #22d3ee);font-weight:var(--font-semibold, 600);font-size:var(--text-sm, .9rem);line-height:1;cursor:pointer;transition:background var(--duration-fast, .12s) var(--ease-out, ease),transform var(--duration-fast, .12s) var(--ease-out, ease),box-shadow var(--duration-fast, .12s) var(--ease-out, ease)}.info-button--sm{width:24px;height:24px;font-size:var(--text-xs, .8rem)}.info-button:hover:not(:disabled){background:var(--color-surface-2, rgba(255, 255, 255, .08));color:var(--color-accent-strong, #38bdf8);box-shadow:0 4px 18px #0000002e;transform:translateY(-1px)}.info-button:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-border-strong, rgba(56, 189, 248, .6))}.info-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.context-info-button--absolute{position:absolute;top:var(--space-2, .5rem);right:var(--space-2, .5rem);z-index:10}.context-info-button--active{background:rgba(var(--color-accent-rgb, 0, 200, 255),.2);border-color:var(--color-accent, #0af);color:var(--color-accent, #0af);box-shadow:0 0 12px rgba(var(--color-accent-rgb, 0, 200, 255),.4)}.context-info-button__preview{display:block;max-width:200px;font-size:var(--text-xs, .8rem);line-height:1.4}.context-info-button__preview strong{display:block;margin-bottom:.25rem;font-weight:var(--font-semibold, 600)}.codon-wheel{background:var(--color-surface-1);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);box-shadow:var(--shadow-md);display:flex;flex-direction:column;gap:var(--space-4)}.codon-wheel__header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3)}.codon-wheel__badges{display:inline-flex;gap:var(--space-2)}.codon-wheel__layout{display:grid;grid-template-columns:1fr minmax(220px,260px);gap:var(--space-5);align-items:center}.codon-wheel__svg{width:100%;max-width:420px;height:auto;margin:0 auto}.codon-wheel__segment path{cursor:pointer;transition:transform var(--duration-fast) var(--ease-out),opacity var(--duration-fast) var(--ease-out)}.codon-wheel__segment path:hover{transform:scale(1.01);opacity:.9}.codon-wheel__label{fill:var(--color-text);font-weight:var(--font-semibold);font-size:.95rem;pointer-events:none;opacity:.75}.codon-wheel__label.active{opacity:1}.codon-wheel__center{fill:var(--color-background);stroke:var(--color-border-subtle);stroke-width:1.5;filter:drop-shadow(0 2px 6px rgba(0,0,0,.25))}.codon-wheel__codon{fill:var(--color-text-strong);font-size:1.25rem;font-weight:var(--font-bold)}.codon-wheel__codon-sub{fill:var(--color-text-muted);font-size:.9rem}@media(max-width:640px){.glossary-drawer{left:.75rem;right:.75rem;width:auto;top:auto;height:55vh}}.codon-wheel__panel{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-4);display:grid;gap:var(--space-3)}.codon-wheel__codon-chip{display:inline-flex;align-items:center;gap:var(--space-2);background:var(--color-surface-3);border-radius:var(--radius-lg);padding:var(--space-2) var(--space-3);border:1px solid var(--color-border-subtle);width:fit-content}.codon-wheel__details{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-3)}.codon-wheel__details .label{color:var(--color-text-muted);font-size:.85rem;margin:0}.codon-wheel__details .value{color:var(--color-text);font-weight:var(--font-semibold);margin:.25rem 0 0}.codon-wheel__hint{margin:0}@media(max-width:900px){.codon-wheel__layout{grid-template-columns:1fr}.codon-wheel__panel{order:2}}.translation-viz{border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-5);background:var(--color-surface-1);display:flex;flex-direction:column;gap:var(--space-4)}.translation-viz__header{display:flex;justify-content:space-between;align-items:center;gap:var(--space-3)}.translation-viz__controls{display:inline-flex;gap:var(--space-2)}.translation-viz__layout{display:grid;grid-template-columns:1fr;gap:var(--space-4)}.translation-viz__timeline{display:grid;grid-template-columns:repeat(auto-fit,minmax(110px,1fr));gap:var(--space-2)}.translation-viz__codon{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);background:var(--color-background-alt);padding:var(--space-2);display:flex;flex-direction:column;gap:var(--space-2);transition:transform var(--duration-fast) var(--ease-out),border-color var(--duration-fast) var(--ease-out)}.translation-viz__codon--active{border-color:var(--color-accent);transform:translateY(-4px);box-shadow:var(--shadow-md)}.translation-viz__codon--done{opacity:.72}.translation-viz__codon-text{font-family:var(--font-mono);font-weight:var(--font-semibold);letter-spacing:.06em}.translation-viz__codon-aa{border-radius:var(--radius-md);padding:6px 10px;font-weight:var(--font-semibold);display:inline-flex;align-items:center;justify-content:center;min-width:60px}.translation-viz__panel{display:grid;grid-template-columns:minmax(320px,420px) 1fr;gap:var(--space-4);align-items:stretch}.translation-viz__ribosome{border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);background:var(--color-surface-2);display:flex;flex-direction:column;gap:var(--space-3)}.translation-viz__track{position:relative;height:76px;border-radius:var(--radius-md);background:var(--color-background-alt);overflow:hidden;border:1px dashed var(--color-border-subtle)}.translation-viz__track-line{position:absolute;top:50%;left:8%;right:8%;height:2px;background:var(--color-border-light);transform:translateY(-50%)}.translation-viz__ribosome-body{position:absolute;top:14px;transform:translate(-50%);padding:10px 14px;border-radius:999px;font-weight:var(--font-bold);box-shadow:var(--shadow-md);border:1px solid var(--color-border);transition:left var(--duration-normal) var(--ease-out);backdrop-filter:blur(6px)}.translation-viz__cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:var(--space-2)}.translation-viz__card{padding:var(--space-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-md);background:var(--color-background)}.translation-viz__card .label{color:var(--color-text-muted);font-size:var(--text-xs);text-transform:uppercase;letter-spacing:.04em}.translation-viz__card .value{font-weight:var(--font-semibold);color:var(--color-text);margin-top:4px}.translation-viz__card .hint{color:var(--color-text-dim);font-size:var(--text-xs);margin-top:4px}.translation-viz__chain{border:1px dashed var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);background:var(--color-background-alt);display:flex;flex-direction:column;gap:var(--space-2)}.translation-viz__chain-label{font-size:var(--text-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em}.translation-viz__chain-track{display:flex;flex-wrap:wrap;gap:var(--space-2);align-items:center;min-height:38px}.translation-viz__chain-aa{padding:6px 10px;border-radius:var(--radius-md);font-weight:var(--font-semibold);box-shadow:var(--shadow-sm)}@media(max-width:960px){.translation-viz__panel{grid-template-columns:1fr}.translation-viz__header{flex-direction:column;align-items:flex-start}}.context-help{background:var(--color-surface-1);border:1px solid var(--color-border-subtle);border-radius:var(--radius-xl);padding:var(--space-4);box-shadow:var(--shadow-md);display:grid;gap:var(--space-3)}.context-help--collapsed{padding:var(--space-3)}.context-help__header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-3)}.context-help__eyebrow{margin:0;text-transform:uppercase;letter-spacing:.04em;font-size:.8rem;color:var(--color-text-muted)}.context-help__title{margin:.15rem 0 .2rem;font-size:1.1rem;font-weight:var(--font-bold);color:var(--color-text-strong)}.context-help__desc{margin:0;color:var(--color-text-muted)}.context-help__section{display:grid;gap:var(--space-2)}.context-help__section-title{margin:0;font-weight:var(--font-semibold);color:var(--color-text)}.context-help__list{list-style:none;padding:0;margin:0;display:grid;gap:var(--space-2)}.context-help__item{background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-3);box-shadow:var(--shadow-sm)}.context-help__term{font-weight:var(--font-semibold);color:var(--color-text);margin-bottom:.25rem}.context-help__summary{margin:0;color:var(--color-text-muted)}.context-help__chips{list-style:none;padding:0;margin:0;display:flex;flex-wrap:wrap;gap:var(--space-2)}.context-help--collapsed .context-help__section,.context-help--collapsed .context-help__desc{display:none}.infection-viz{display:grid;gap:var(--space-3)}.infection-viz__metrics{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:var(--space-2);background:var(--color-surface-2);border:1px solid var(--color-border-subtle);border-radius:var(--radius-lg);padding:var(--space-3)}.infection-viz__metrics .metric{display:flex;flex-direction:column;gap:2px}.infection-viz__metrics .label{margin:0;color:var(--color-text-muted);font-size:.85rem}.infection-viz__metrics .value{margin:0;color:var(--color-text);font-weight:var(--font-semibold)}:focus-visible{outline:none;box-shadow:0 0 0 2px var(--color-background),0 0 0 4px #22d3ee66}a{transition:color var(--duration-fast) var(--ease-out)}a:hover{color:var(--color-primary)}input,select,textarea{transition:border-color .2s var(--ease-out),box-shadow .2s var(--ease-out),background-color .2s var(--ease-out),transform .35s var(--ease-spring)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--color-border-focus);box-shadow:0 0 0 3px #22d3ee26,0 0 12px #22d3ee1a}input[type=text]:focus,input[type=search]:focus,input[type=email]:focus,input[type=password]:focus,input[type=number]:focus,input[type=url]:focus,textarea:focus{background:var(--color-background-alt)}.panel{transition:border-color var(--duration-fast) var(--ease-out),box-shadow var(--duration-normal) var(--ease-out)}.panel:hover{border-color:var(--color-border-light)}button[aria-label]:not(.btn):not([class*=sidebar]){transition:color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}button[aria-label]:not(.btn):not([class*=sidebar]):hover{transform:scale(1.1)}button[aria-label]:not(.btn):not([class*=sidebar]):active{transform:scale(.95)}.badge{transition:background-color var(--duration-fast) var(--ease-out),transform var(--duration-fast) var(--ease-out)}.badge:hover{transform:scale(1.02)}::-webkit-scrollbar-track{background:var(--color-background-alt);border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px;transition:background-color var(--duration-fast) var(--ease-out)}::-webkit-scrollbar-thumb:hover{background:var(--color-border-light)}::selection{background:#22d3ee4d;color:var(--color-text)}.panel,.card,.overlay{contain:content}.matrix-rain{position:fixed;inset:0;pointer-events:none;z-index:-1;will-change:contents;contain:strict}.three-container{contain:strict;will-change:contents}.overlay-backdrop{will-change:opacity}@media(prefers-reduced-motion:reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}.matrix-rain{display:none}}@media(prefers-contrast:high){:root{--color-border: #4a5568;--color-border-light: #718096;--color-text-dim: #cbd5e0;--color-text-muted: #a0aec0}}:root{--skeleton-base: var(--color-background-alt, #12121a);--skeleton-highlight: var(--color-background-hover, #1c1c27);--skeleton-shimmer-start: var(--color-background-alt, #12121a);--skeleton-shimmer-mid: var(--color-background-active, #1e1e2a);--skeleton-shimmer-end: var(--color-background-alt, #12121a);--skeleton-pulse-duration: 1.5s;--skeleton-shimmer-duration: 2s}.skeleton{display:block;background-color:var(--skeleton-base)}.skeleton--text{border-radius:var(--radius-sm, 4px);transform-origin:0 50%}.skeleton--rect{border-radius:var(--radius-md, 6px)}.skeleton--circular{border-radius:var(--radius-full, 9999px)}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.7}}.skeleton--pulse{animation:skeleton-pulse var(--skeleton-pulse-duration) ease-in-out infinite}@keyframes skeleton-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton--shimmer{background:linear-gradient(90deg,var(--skeleton-shimmer-start) 0%,var(--skeleton-shimmer-start) 40%,var(--skeleton-shimmer-mid) 50%,var(--skeleton-shimmer-start) 60%,var(--skeleton-shimmer-start) 100%);background-size:200% 100%;animation:skeleton-shimmer var(--skeleton-shimmer-duration) ease-in-out infinite}.skeleton--none{animation:none;background:var(--skeleton-base)}@media(prefers-reduced-motion:reduce){.skeleton--pulse,.skeleton--shimmer{animation:none;opacity:.5;background:var(--skeleton-base)}}.skeleton-sequence-view{display:flex;flex-direction:column;gap:var(--space-3, 12px);padding:var(--space-4, 16px);background:var(--color-background, #0a0a0f);border-radius:var(--radius-lg, 10px)}.skeleton-sequence-view__header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-2, 8px);border-bottom:1px solid var(--color-border-subtle, #232330)}.skeleton-sequence-view__rows{display:flex;flex-direction:column;gap:var(--space-2, 8px)}.skeleton-sequence-view__row{display:flex;align-items:center;gap:var(--space-3, 12px)}.skeleton-sequence-view__gene-map{margin-top:var(--space-2, 8px);padding-top:var(--space-3, 12px);border-top:1px solid var(--color-border-subtle, #232330)}.skeleton-model3d{display:flex;flex-direction:column;gap:var(--space-2, 8px);background:var(--color-background, #0a0a0f);border-radius:var(--radius-lg, 10px);overflow:hidden}.skeleton-model3d__viewport{position:relative;width:100%;aspect-ratio:16 / 9;min-height:200px}.skeleton-model3d__viewport>.skeleton{position:absolute;inset:0}.skeleton-model3d__center{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1}.skeleton-model3d__controls{display:flex;justify-content:center;gap:var(--space-3, 12px);padding:var(--space-3, 12px);background:var(--color-background-elevated, #16161f);border-top:1px solid var(--color-border-subtle, #232330)}.skeleton-phage-list{display:flex;flex-direction:column;gap:var(--space-1, 4px)}.skeleton-phage-list__item{display:flex;align-items:center;gap:var(--space-3, 12px);padding:var(--space-3, 12px) var(--space-4, 16px);background:var(--color-background-elevated, #16161f);border-radius:var(--radius-md, 6px)}.skeleton-phage-list__content{flex:1;display:flex;flex-direction:column;gap:var(--space-1, 4px)}.skeleton-gene-map{display:flex;flex-direction:column;gap:var(--space-2, 8px);padding:var(--space-2, 8px) 0}.skeleton-gene-map__track{display:flex;gap:var(--space-1, 4px);height:12px}.skeleton-gene-map__track>.skeleton{flex-shrink:0}.skeleton-analysis-panel{display:flex;flex-direction:column;gap:var(--space-4, 16px);padding:var(--space-4, 16px);background:var(--color-background-elevated, #16161f);border-radius:var(--radius-lg, 10px);border:1px solid var(--color-border-subtle, #232330)}.skeleton-analysis-panel__header{display:flex;justify-content:space-between;align-items:center}.skeleton-analysis-panel__stats{display:flex;gap:var(--space-6, 24px)}.skeleton-analysis-panel__stat{display:flex;flex-direction:column;gap:var(--space-1, 4px)}.skeleton-analysis-panel__chart{margin:var(--space-2, 8px) 0}.skeleton-analysis-panel__details{display:flex;flex-direction:column;gap:var(--space-2, 8px)}.skeleton-search-results{display:flex;flex-direction:column;gap:var(--space-1, 4px)}.skeleton-search-results__item{display:flex;align-items:center;gap:var(--space-3, 12px);padding:var(--space-3, 12px);background:var(--color-background-elevated, #16161f);border-radius:var(--radius-md, 6px)}.skeleton-search-results__icon{flex-shrink:0}.skeleton-search-results__content{flex:1;display:flex;flex-direction:column;gap:var(--space-1, 4px)}.skeleton-search-results__badge{flex-shrink:0}.skeleton-phage-list__item:nth-child(1){animation-delay:0ms}.skeleton-phage-list__item:nth-child(2){animation-delay:50ms}.skeleton-phage-list__item:nth-child(3){animation-delay:.1s}.skeleton-phage-list__item:nth-child(4){animation-delay:.15s}.skeleton-phage-list__item:nth-child(5){animation-delay:.2s}.skeleton-search-results__item:nth-child(1){animation-delay:0ms}.skeleton-search-results__item:nth-child(2){animation-delay:50ms}.skeleton-search-results__item:nth-child(3){animation-delay:.1s}.skeleton-search-results__item:nth-child(4){animation-delay:.15s}.skeleton-phage-list__item .skeleton--shimmer,.skeleton-search-results__item .skeleton--shimmer{animation-delay:inherit}@keyframes content-reveal-up{0%{opacity:0;transform:translateY(12px)}60%{opacity:1;transform:translateY(-2px)}to{opacity:1;transform:translateY(0)}}@keyframes content-reveal-scale{0%{opacity:0;transform:scale(.96)}60%{opacity:1;transform:scale(1.01)}to{opacity:1;transform:scale(1)}}@keyframes content-reveal-fade{0%{opacity:0}to{opacity:1}}.content-reveal{animation:content-reveal-up .4s var(--ease-spring-soft, cubic-bezier(.22, 1, .36, 1)) forwards}.content-reveal--scale{animation:content-reveal-scale .4s var(--ease-spring-soft, cubic-bezier(.22, 1, .36, 1)) forwards}.content-reveal--fade{animation:content-reveal-fade .3s var(--ease-out, cubic-bezier(0, 0, .2, 1)) forwards}.content-reveal-list>*{opacity:0;animation:content-reveal-up .4s var(--ease-spring-soft, cubic-bezier(.22, 1, .36, 1)) forwards}.content-reveal-list>*:nth-child(1){animation-delay:0ms}.content-reveal-list>*:nth-child(2){animation-delay:40ms}.content-reveal-list>*:nth-child(3){animation-delay:80ms}.content-reveal-list>*:nth-child(4){animation-delay:.12s}.content-reveal-list>*:nth-child(5){animation-delay:.16s}.content-reveal-list>*:nth-child(6){animation-delay:.2s}.content-reveal-list>*:nth-child(7){animation-delay:.24s}.content-reveal-list>*:nth-child(8){animation-delay:.28s}.content-reveal-list>*:nth-child(9){animation-delay:.32s}.content-reveal-list>*:nth-child(10){animation-delay:.36s}.content-reveal-list>*:nth-child(n+11){animation-delay:.4s}.skeleton-crossfade{position:relative}.skeleton-crossfade>.skeleton-wrapper{transition:opacity .2s var(--ease-out, cubic-bezier(0, 0, .2, 1))}.skeleton-crossfade>.content-wrapper{opacity:0;transition:opacity .3s var(--ease-out, cubic-bezier(0, 0, .2, 1));transition-delay:.1s}.skeleton-crossfade[data-loaded=true]>.skeleton-wrapper{opacity:0;pointer-events:none}.skeleton-crossfade[data-loaded=true]>.content-wrapper{opacity:1}@media(prefers-reduced-motion:reduce){.content-reveal,.content-reveal--scale,.content-reveal--fade,.content-reveal-list>*{animation:none;opacity:1;transform:none}.skeleton-crossfade>.skeleton-wrapper,.skeleton-crossfade>.content-wrapper{transition-duration:.01ms}}.welcome-modal{display:flex;flex-direction:column;gap:var(--space-5);min-height:300px}.welcome-step-indicator{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-2)}.welcome-step-dot{width:8px;height:8px;border-radius:50%;background:var(--color-border);transition:width .35s var(--ease-spring),height .35s var(--ease-spring),background .2s var(--ease-out),box-shadow .2s var(--ease-out),transform .35s var(--ease-spring);will-change:transform,width,height}.welcome-step-dot--current{width:10px;height:10px;background:var(--color-primary);box-shadow:0 0 8px #22d3ee80;animation:step-dot-pulse 2s ease-in-out infinite}.welcome-step-dot--completed{background:var(--color-accent);transform:scale(1.05)}@keyframes step-dot-pulse{0%,to{box-shadow:0 0 8px #22d3ee80;transform:scale(1)}50%{box-shadow:0 0 12px #22d3eeb3;transform:scale(1.08)}}.welcome-step-label{margin-left:var(--space-3);font-size:var(--text-sm);color:var(--color-text-muted);font-variant-numeric:tabular-nums}.welcome-intro{text-align:center;padding:var(--space-4) 0}.welcome-intro__title{color:var(--color-text);margin-bottom:var(--space-4);font-size:var(--overlay-title-size);font-weight:var(--overlay-title-weight);line-height:var(--overlay-title-line-height);letter-spacing:var(--overlay-title-tracking)}.welcome-intro__description{color:var(--overlay-description-color);font-size:var(--overlay-body-size);line-height:var(--overlay-body-line-height);max-width:var(--overlay-body-max-width);margin:0 auto}.welcome-features{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4);margin-top:var(--space-4)}@media(max-width:640px){.welcome-features{grid-template-columns:1fr}}.welcome-feature{position:relative;background:var(--color-background-alt);padding:var(--space-4);border-radius:var(--radius-lg);border:1px solid transparent;transition:transform .35s var(--ease-spring),box-shadow .2s var(--ease-out),border-color .2s var(--ease-out);will-change:transform}.welcome-feature:hover{transform:translateY(-2px);border-color:var(--color-border);box-shadow:0 8px 24px #0003}.welcome-feature:before{content:"";position:absolute;inset:0;border-radius:inherit;background:linear-gradient(180deg,rgba(34,211,238,.03) 0%,transparent 50%);opacity:0;transition:opacity .2s var(--ease-out);pointer-events:none}.welcome-feature:hover:before{opacity:1}.welcome-feature__header{display:flex;align-items:center;gap:var(--space-2);font-weight:var(--font-bold);margin-bottom:var(--space-2)}.welcome-feature__icon{display:inline-flex;align-items:center;line-height:0}.welcome-feature__header--primary{color:var(--color-primary)}.welcome-feature__header--secondary{color:var(--color-secondary)}.welcome-feature__text{font-size:var(--overlay-body-size);color:var(--overlay-description-color);line-height:var(--overlay-body-line-height);margin:0}.welcome-level{text-align:center}.welcome-level__title{color:var(--color-text);margin-bottom:var(--space-5);font-size:var(--overlay-section-title-size);font-weight:var(--overlay-section-title-weight)}.welcome-level__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--space-4)}@media(max-width:768px){.welcome-level__grid{grid-template-columns:1fr}}.welcome-level__hint{text-align:center;font-size:var(--overlay-caption-size);color:var(--overlay-caption-color);margin-top:var(--space-4)}.welcome-level-card{position:relative;text-align:left;border:2px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-4);cursor:pointer;background:transparent;transition:border-color .2s var(--ease-out),background .2s var(--ease-out),transform .35s var(--ease-spring),box-shadow .2s var(--ease-out);width:100%;will-change:transform;-webkit-tap-highlight-color:transparent}.welcome-level-card:hover{border-color:var(--color-border-light);background:var(--color-background-hover);transform:translateY(-2px);box-shadow:0 6px 20px #00000026}.welcome-level-card:active{transform:scale(.98);box-shadow:var(--shadow-sm);transition:transform 80ms var(--ease-out)}.welcome-level-card:focus-visible{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-background),0 0 0 4px var(--color-primary)}.welcome-level-card[aria-pressed=true]{border-color:var(--color-accent);background:#22d3ee14;box-shadow:0 0 16px #22d3ee26}.welcome-level-card[aria-pressed=true]:hover{background:#22d3ee1f}.welcome-level-card:after{content:"";position:absolute;bottom:-2px;left:20%;right:20%;height:2px;background:linear-gradient(90deg,transparent,var(--color-accent),transparent);border-radius:var(--radius-full);opacity:0;transform:scaleX(0);transition:opacity .2s var(--ease-out),transform .35s var(--ease-spring)}.welcome-level-card[aria-pressed=true]:after{opacity:1;transform:scaleX(1);box-shadow:0 0 8px var(--color-glow)}.welcome-level-card__header{display:flex;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.welcome-level-card__icon{display:inline-flex;align-items:center;line-height:0;color:var(--color-text-muted);transition:color var(--duration-fast) var(--ease-out)}.welcome-level-card[aria-pressed=true] .welcome-level-card__icon{color:var(--color-accent)}.welcome-level-card__title{margin:0;font-size:var(--text-base);font-weight:var(--font-bold);color:var(--color-primary);transition:color var(--duration-fast) var(--ease-out)}.welcome-level-card[aria-pressed=true] .welcome-level-card__title{color:var(--color-accent)}.welcome-level-card__desc{margin:0;font-size:var(--overlay-body-size);color:var(--overlay-description-color);line-height:var(--overlay-body-line-height)}.welcome-primer{text-align:center}.welcome-primer__title{color:var(--color-text);margin-bottom:var(--space-2);font-size:var(--overlay-section-title-size);font-weight:var(--overlay-section-title-weight)}.welcome-footer{display:flex;justify-content:space-between;align-items:center;gap:var(--space-4)}.welcome-footer__skip{color:var(--overlay-description-color);font-size:var(--overlay-body-size)}.welcome-footer__skip:hover{text-decoration:underline;text-underline-offset:3px}.welcome-footer__actions{display:flex;gap:var(--space-2)}@media(max-width:640px){.welcome-footer{flex-direction:column;align-items:stretch;gap:var(--space-3)}.welcome-footer__skip{align-self:flex-start}.welcome-footer__actions{width:100%;flex-wrap:wrap;justify-content:flex-end}.welcome-footer__actions .btn{flex:1 1 auto;min-width:120px}}.btn-tour{border-color:var(--color-accent);background:transparent;color:var(--color-accent);font-weight:var(--font-bold)}.btn-tour:hover{background:#fbbf241a;border-color:var(--color-accent);box-shadow:0 0 12px #fbbf2433}.btn-tour:focus-visible{box-shadow:0 0 0 2px var(--color-background),0 0 0 4px var(--color-accent)}.btn-tour:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent 0%,rgba(251,191,36,.15) 50%,transparent 100%);animation:tour-shimmer 3s ease-in-out infinite}@keyframes tour-shimmer{0%{left:-100%}to{left:200%}}.animate-fade-in{animation:welcomeFadeIn var(--duration-normal) var(--ease-out)}@keyframes welcomeFadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@media(prefers-reduced-motion:reduce){.welcome-step-dot,.welcome-feature,.welcome-level-card{transition:none;animation:none}.welcome-step-dot--current{animation:none}.btn-tour:before{animation:none}.animate-fade-in{animation:none;opacity:1}}.full-feature-modal{display:flex;flex-direction:column;gap:.75rem;max-height:80vh;overflow:hidden}.ffm-level-selector{display:flex;align-items:center;gap:.5rem;padding:.5rem;background:linear-gradient(135deg,rgba(var(--color-background-rgb, 20, 20, 30),.8),rgba(var(--color-background-alt-rgb, 30, 30, 45),.8));border-radius:8px;border:1px solid var(--color-border, #333)}.ffm-level-label{color:var(--color-text-muted, #888);font-size:.85rem;margin-right:.5rem}.ffm-level-btn{display:flex;align-items:center;gap:.35rem;padding:.4rem .75rem;background:transparent;border:1px solid var(--color-border, #444);border-radius:6px;color:var(--color-text-dim, #aaa);font-size:.85rem;cursor:pointer;transition:all .2s ease}.ffm-level-btn:hover{background:rgba(var(--color-accent-rgb, 0, 200, 255),.1);border-color:var(--color-accent, #0af)}.ffm-level-btn--active{background:linear-gradient(135deg,rgba(var(--color-accent-rgb, 0, 200, 255),.2),rgba(var(--color-primary-rgb, 100, 100, 255),.2));border-color:var(--color-accent, #0af);color:var(--color-text, #fff);box-shadow:0 0 10px rgba(var(--color-accent-rgb, 0, 200, 255),.3)}.ffm-level-btn-label{text-transform:capitalize}.ffm-category-pills{display:flex;flex-wrap:wrap;gap:.5rem;padding:.5rem 0}.ffm-category-pill{display:flex;align-items:center;gap:.35rem;padding:.35rem .75rem;background:rgba(var(--color-background-alt-rgb, 30, 30, 45),.6);border:1px solid var(--color-border, #333);border-radius:16px;color:var(--color-text-muted, #888);font-size:.8rem;cursor:pointer;transition:all .2s ease}.ffm-category-pill:hover{background:rgba(var(--color-accent-rgb, 0, 200, 255),.1);border-color:var(--color-accent, #0af);color:var(--color-text, #fff)}.ffm-category-pill--active{background:linear-gradient(135deg,rgba(var(--color-accent-rgb, 0, 200, 255),.25),rgba(var(--color-secondary-rgb, 200, 50, 200),.15));border-color:var(--color-accent, #0af);color:var(--color-text, #fff);box-shadow:0 0 8px rgba(var(--color-accent-rgb, 0, 200, 255),.25)}.ffm-category-pill-icon{display:flex;align-items:center;opacity:.8}.ffm-category-pill-count{margin-left:.25rem;padding:.1rem .35rem;background:rgba(var(--color-text-rgb, 255, 255, 255),.1);border-radius:8px;font-size:.7rem;opacity:.7}.ffm-search-container{position:relative;display:flex;align-items:center}.ffm-search-icon{position:absolute;left:.75rem;color:var(--color-text-muted, #888);pointer-events:none}.ffm-search-input{width:100%;padding:.75rem 2.5rem;background:rgba(var(--color-background-rgb, 20, 20, 30),.9);border:1px solid var(--color-border, #444);border-radius:8px;color:var(--color-text, #fff);font-size:1rem;font-family:inherit;outline:none;transition:all .2s ease}.ffm-search-input:focus{border-color:var(--color-accent, #0af);box-shadow:0 0 12px rgba(var(--color-accent-rgb, 0, 200, 255),.3),inset 0 0 20px rgba(var(--color-accent-rgb, 0, 200, 255),.05)}.ffm-search-input::placeholder{color:var(--color-text-muted, #666)}.ffm-search-clear{position:absolute;right:.75rem;background:none;border:none;color:var(--color-text-muted, #888);font-size:1.25rem;cursor:pointer;padding:.25rem;line-height:1;transition:color .2s}.ffm-search-clear:hover{color:var(--color-text, #fff)}.ffm-results-count{color:var(--color-text-muted, #888);font-size:.8rem;padding:0 .25rem}.ffm-feature-list{flex:1;overflow-y:auto;overflow-x:hidden;max-height:50vh;scrollbar-width:thin;scrollbar-color:var(--color-accent, #0af) transparent}.ffm-feature-list::-webkit-scrollbar{width:6px}.ffm-feature-list::-webkit-scrollbar-track{background:transparent}.ffm-feature-list::-webkit-scrollbar-thumb{background:var(--color-accent, #0af);border-radius:3px}.ffm-section{margin-bottom:.5rem}.ffm-section-header{display:flex;align-items:center;gap:.5rem;padding:.5rem .75rem;color:var(--color-text-muted, #888);font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid var(--color-border, #333);background:linear-gradient(90deg,rgba(var(--color-background-alt-rgb, 30, 30, 45),.5),transparent)}.ffm-section-icon{display:flex;align-items:center;opacity:.7}.ffm-section-count{margin-left:auto;opacity:.6;font-size:.7rem}.ffm-feature-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;cursor:pointer;transition:all .15s ease;border-left:3px solid transparent}.ffm-feature-item:hover{background:rgba(var(--color-accent-rgb, 0, 200, 255),.08)}.ffm-feature-item--selected{background:linear-gradient(90deg,rgba(var(--color-accent-rgb, 0, 200, 255),.15),rgba(var(--color-accent-rgb, 0, 200, 255),.05));border-left-color:var(--color-accent, #0af)}.ffm-feature-item--disabled{opacity:.5;cursor:not-allowed}.ffm-feature-item--active{background:linear-gradient(90deg,rgba(var(--color-success-rgb, 0, 200, 100),.12),transparent)}.ffm-feature-item--selected.ffm-feature-item--active{background:linear-gradient(90deg,rgba(var(--color-success-rgb, 0, 200, 100),.2),rgba(var(--color-accent-rgb, 0, 200, 255),.1))}.ffm-feature-icon{display:flex;align-items:center;justify-content:center;width:28px;height:28px;background:rgba(var(--color-text-rgb, 255, 255, 255),.05);border-radius:6px;color:var(--color-text-muted, #888);flex-shrink:0}.ffm-feature-item--selected .ffm-feature-icon{background:rgba(var(--color-accent-rgb, 0, 200, 255),.2);color:var(--color-accent, #0af)}.ffm-feature-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:.15rem}.ffm-feature-label{color:var(--color-text, #fff);font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ffm-feature-item--selected .ffm-feature-label{font-weight:500}.ffm-feature-desc{color:var(--color-text-muted, #888);font-size:.75rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ffm-feature-shortcut{padding:.2rem .5rem;background:rgba(var(--color-text-rgb, 255, 255, 255),.08);border:1px solid var(--color-border, #444);border-radius:4px;color:var(--color-text-muted, #888);font-size:.7rem;font-family:monospace;flex-shrink:0}.ffm-feature-item--selected .ffm-feature-shortcut{background:rgba(var(--color-accent-rgb, 0, 200, 255),.15);border-color:var(--color-accent, #0af);color:var(--color-accent, #0af)}.ffm-feature-active-badge{padding:.15rem .4rem;background:var(--color-success, #0c8);border-radius:3px;color:#000;font-size:.65rem;font-weight:700;text-transform:uppercase;flex-shrink:0}.ffm-highlight{color:var(--color-accent, #0af);font-weight:700;text-shadow:0 0 8px rgba(var(--color-accent-rgb, 0, 200, 255),.5)}.ffm-empty{padding:2rem;text-align:center;color:var(--color-text-muted, #888);font-style:italic}.ffm-footer{display:flex;justify-content:center;gap:1.5rem;padding:.75rem;border-top:1px solid var(--color-border, #333);background:linear-gradient(to top,rgba(var(--color-background-rgb, 20, 20, 30),.8),transparent)}.ffm-hint{display:flex;align-items:center;gap:.35rem;color:var(--color-text-muted, #888);font-size:.75rem}.ffm-hint kbd{display:inline-flex;align-items:center;justify-content:center;min-width:1.5rem;padding:.15rem .4rem;background:rgba(var(--color-text-rgb, 255, 255, 255),.08);border:1px solid var(--color-border, #444);border-radius:4px;font-family:inherit;font-size:.7rem}@media(max-width:640px){.ffm-category-pills{overflow-x:auto;flex-wrap:nowrap;padding-bottom:.75rem;-webkit-overflow-scrolling:touch}.ffm-category-pill{flex-shrink:0}.ffm-feature-desc{display:none}.ffm-footer{gap:1rem;flex-wrap:wrap}.ffm-level-btn-label{display:none}}@keyframes ffm-glow-pulse{0%,to{box-shadow:0 0 8px rgba(var(--color-accent-rgb, 0, 200, 255),.3)}50%{box-shadow:0 0 16px rgba(var(--color-accent-rgb, 0, 200, 255),.5)}}.ffm-feature-item--selected{animation:ffm-glow-pulse 2s ease-in-out infinite}@media(prefers-reduced-motion:reduce){.ffm-feature-item--selected{animation:none}}html.lenis,html.lenis body{height:auto}.lenis.lenis-smooth{scroll-behavior:auto!important}.lenis.lenis-smooth [data-lenis-prevent]{overscroll-behavior:contain}.lenis.lenis-stopped{overflow:hidden}.lenis.lenis-scrolling iframe{pointer-events:none}.lenis-prevent{overscroll-behavior:contain}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background-alt, rgba(0, 0, 0, .1));border-radius:4px}::-webkit-scrollbar-thumb{background:var(--color-border, rgba(255, 255, 255, .2));border-radius:4px;transition:background .2s ease}::-webkit-scrollbar-thumb:hover{background:var(--color-border-focus, rgba(255, 255, 255, .4))}*{scrollbar-width:thin;scrollbar-color:var(--color-border, rgba(255, 255, 255, .2)) var(--color-background-alt, rgba(0, 0, 0, .1))}.scroll-snap-y{scroll-snap-type:y proximity}.scroll-snap-x{scroll-snap-type:x mandatory}.scroll-snap-item{scroll-snap-align:start}.scroll-snap-item-center{scroll-snap-align:center}.scroll-indicator{position:absolute;pointer-events:none;opacity:0;transition:opacity .3s ease}.scroll-indicator--top,.scroll-indicator--bottom{left:0;right:0;height:40px}.scroll-indicator--top{top:0;background:linear-gradient(to bottom,var(--color-background) 0%,transparent 100%)}.scroll-indicator--bottom{bottom:0;background:linear-gradient(to top,var(--color-background) 0%,transparent 100%)}.scroll-indicator--visible{opacity:1}@media(prefers-reduced-motion:reduce){html,html body,*{scroll-behavior:auto!important}}
