.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background-color:#000;padding:2rem}.login-form{background-color:#1a1a1a;border:1px solid #333333;border-radius:4px;padding:2rem;width:100%;max-width:400px;text-align:center}.login-logo{width:300px;height:auto;margin-bottom:1rem;opacity:.9}.login-form h1{font-size:1.5rem;margin-bottom:.5rem;color:#fff;font-weight:300;letter-spacing:1px}.login-form h2{font-size:1rem;margin-bottom:2rem;color:#999;font-weight:300;letter-spacing:.5px}.login-form input{width:100%;padding:.75rem;margin-bottom:1rem;background-color:#2a2a2a;border:1px solid #444444;border-radius:2px;color:#fff;font-size:.9rem;box-sizing:border-box;transition:border-color .2s}.login-form input:focus{outline:none;border-color:#666}.login-form input:disabled{opacity:.6;cursor:not-allowed}.login-form button{width:100%;padding:.75rem;background-color:#333;border:1px solid #555555;border-radius:2px;color:#fff;cursor:pointer;transition:all .2s;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.login-form button:hover:not(:disabled){background-color:#444;border-color:#666}.login-form button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#1a0000;color:#f66;padding:.75rem;border:1px solid #330000;border-radius:2px;margin-bottom:1rem;font-size:.9rem;text-align:center}.demo-credentials{margin-top:1.5rem;padding-top:1rem;border-top:1px solid #333333;color:#666;font-size:.8rem}.demo-credentials p{margin:0 0 .5rem;font-weight:500}.demo-credentials small{display:block;line-height:1.4}.landing-container{position:relative;display:flex;flex-direction:column;align-items:center;min-height:100vh;padding:2rem;background-color:#000;overflow-y:auto}.user-header{position:absolute;top:20px;right:20px;display:flex;align-items:center;gap:15px;z-index:10}.user-info{color:#ccc;font-size:.9rem;font-weight:300;letter-spacing:.5px}.logout-button{background-color:transparent;color:#666;border:1px solid #333333;border-radius:4px;padding:.4rem .9rem;font-size:.75rem;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.5px;font-weight:500}.logout-button:hover{background-color:#1a1a1a;color:#fff;border-color:#555}.logo-container{margin-top:2rem;margin-bottom:2rem;text-align:center;display:flex;flex-direction:column;align-items:center}.raynetics-logo{display:block;width:500px;max-width:90vw;height:auto;opacity:.9}.hero-section{text-align:center;margin-bottom:3rem;max-width:800px}.hero-title{font-size:2.5rem;margin:0 0 1rem;color:#fff;font-weight:300;letter-spacing:2px;line-height:1.2}.hero-subtitle{font-size:1.1rem;margin:0;color:#888;font-weight:300;letter-spacing:.8px;line-height:1.5}.datasets-header{display:flex;justify-content:space-between;align-items:center;width:100%;max-width:1400px;margin-bottom:2rem;padding:0 .5rem}.datasets-title{font-size:1.5rem;margin:0;color:#fff;font-weight:400;letter-spacing:1px}.datasets-count{font-size:.9rem;color:#666;font-weight:300;letter-spacing:.5px}.datasets-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(360px,1fr));gap:2rem;width:100%;max-width:1400px;margin-bottom:4rem}.loading-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;margin-top:4rem}.loading-spinner-large{width:60px;height:60px;border:4px solid #222222;border-top-color:#666;border-radius:50%;animation:spin 1s linear infinite}.loading-text{font-size:1.1rem;color:#666;font-weight:300;letter-spacing:.5px}.error-section{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;margin-top:4rem;max-width:600px;text-align:center}.error-icon{font-size:4rem;opacity:.6}.error-message{font-size:1.1rem;color:#f66;background-color:#ff66661a;padding:1.5rem;border:1px solid rgba(255,102,102,.3);border-radius:8px;font-weight:300;letter-spacing:.3px;line-height:1.5}.retry-button{background-color:transparent;color:#666;border:1px solid #333333;border-radius:4px;padding:.7rem 2rem;font-weight:400;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.8px;font-size:.9rem}.retry-button:hover{background-color:#1a1a1a;color:#fff;border-color:#555;transform:translateY(-2px)}.retry-button:active{transform:translateY(0)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:1.5rem;margin-top:4rem;max-width:600px;text-align:center;padding:3rem 2rem;background-color:#ffffff05;border:1px solid #222222;border-radius:12px}.empty-icon{font-size:4rem;opacity:.4}.empty-title{margin:0;font-size:1.5rem;color:#fff;font-weight:400;letter-spacing:.5px}.empty-description{margin:0;font-size:1rem;color:#888;font-weight:300;letter-spacing:.3px;line-height:1.6}@media (max-width: 1400px){.datasets-grid{grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:1.5rem}}@media (max-width: 1200px){.datasets-grid{grid-template-columns:repeat(auto-fill,minmax(320px,1fr))}.hero-title{font-size:2.2rem}.hero-subtitle{font-size:1rem}}@media (max-width: 768px){.landing-container{padding:1.5rem}.user-header{top:15px;right:15px;gap:10px}.user-info{font-size:.8rem}.logout-button{padding:.35rem .7rem;font-size:.7rem}.logo-container{margin-top:1rem;margin-bottom:1.5rem}.raynetics-logo{width:400px}.hero-section{margin-bottom:2rem}.hero-title{font-size:1.8rem;letter-spacing:1.5px}.hero-subtitle{font-size:.95rem}.datasets-header{flex-direction:column;align-items:flex-start;gap:.5rem;margin-bottom:1.5rem}.datasets-title{font-size:1.3rem}.datasets-count{font-size:.85rem}.datasets-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.5rem;margin-bottom:5rem}.loading-section,.error-section,.empty-state{margin-top:2rem;padding:2rem 1rem}.error-icon,.empty-icon{font-size:3rem}}@media (max-width: 480px){.landing-container{padding:1rem}.user-header{position:static;width:100%;justify-content:space-between;margin-bottom:1rem;padding:.5rem;background-color:#ffffff05;border-radius:8px}.raynetics-logo{width:300px}.hero-title{font-size:1.5rem;letter-spacing:1px}.hero-subtitle{font-size:.9rem;letter-spacing:.5px}.datasets-grid{grid-template-columns:1fr;gap:1.5rem}.datasets-title{font-size:1.2rem}.error-message,.empty-description{font-size:.95rem}}@media (max-width: 360px){.raynetics-logo{width:250px}.hero-title{font-size:1.3rem}.hero-subtitle{font-size:.85rem}}@media (prefers-contrast: high){.landing-container{background-color:#000}.logout-button,.retry-button{border:2px solid #ffffff}.datasets-grid{gap:2.5rem}}@media (prefers-reduced-motion: reduce){.loading-spinner-large{animation:none;border-top-color:#666}.retry-button:hover{transform:none}*{transition:none!important;animation:none!important}}@media print{.user-header,.logout-button,.retry-button{display:none}.landing-container{padding:1rem}.datasets-grid{grid-template-columns:repeat(2,1fr);gap:1rem}}.dataset-card{position:relative;display:flex;flex-direction:column;background-color:#0a0a0a;border:2px solid #222222;border-radius:12px;overflow:hidden;cursor:pointer;transition:all .3s ease;height:100%;min-height:380px}.dataset-card:hover{border-color:#444;transform:translateY(-4px);box-shadow:0 8px 24px #0009}.dataset-card-thumbnail{position:relative;width:100%;height:240px;background-color:#000;overflow:hidden;flex-shrink:0}.dataset-thumbnail-image{width:100%;height:100%;object-fit:cover;opacity:0;transition:opacity .4s ease}.dataset-thumbnail-image.loaded{opacity:1}.dataset-thumbnail-loading{position:absolute;top:0;left:0;width:100%;height:100%;display:flex;align-items:center;justify-content:center;background-color:#0a0a0a}.loading-spinner{width:40px;height:40px;border:3px solid #222222;border-top-color:#666;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.dataset-thumbnail-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:#fff9}.placeholder-content{display:flex;flex-direction:column;align-items:center;gap:12px;padding:20px;text-align:center}.placeholder-icon{width:64px;height:64px;opacity:.4}.placeholder-name{font-size:1.1rem;font-weight:500;letter-spacing:.5px;opacity:.7;max-width:200px;word-wrap:break-word}.dataset-card-content{padding:20px;display:flex;flex-direction:column;gap:12px;flex-grow:1}.dataset-card-header{display:flex;justify-content:space-between;align-items:flex-start;gap:12px}.dataset-card-title{margin:0;font-size:1.25rem;font-weight:600;color:#fff;letter-spacing:.3px;line-height:1.3;flex-grow:1}.dataset-card-badges{display:flex;gap:8px;flex-shrink:0}.technique-badge{padding:4px 10px;border-radius:4px;font-size:.75rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;white-space:nowrap;border:1px solid}.technique-tem{background-color:#4a90e226;border-color:#4a90e2;color:#5ba3f5}.technique-fibsem{background-color:#76b90026;border-color:#76b900;color:#8cc500}.technique-em{background-color:#9c9c9c26;border-color:#666;color:#999}.dataset-card-description{margin:0;font-size:.95rem;color:#999;line-height:1.5;font-weight:300}.dataset-card-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.95);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:24px;opacity:0;pointer-events:none;transition:opacity .3s ease;z-index:5}.dataset-card:hover .dataset-card-overlay{opacity:1;pointer-events:auto}.overlay-content{width:100%;display:flex;flex-direction:column;gap:16px;color:#fff}.overlay-title{margin:0;font-size:1.4rem;font-weight:600;color:#fff;letter-spacing:.3px;line-height:1.3}.overlay-info{display:flex;flex-direction:column;gap:10px}.overlay-info-item{display:flex;align-items:center;gap:10px;font-size:.9rem;color:#ccc}.overlay-icon{font-size:1.1rem;flex-shrink:0;opacity:.8}.overlay-text{letter-spacing:.3px;font-weight:400}.overlay-description{margin:8px 0 0;font-size:.95rem;color:#aaa;line-height:1.6;font-weight:300}.overlay-button{margin-top:8px;padding:12px 24px;background-color:#4a90e2;color:#fff;border:none;border-radius:6px;font-size:.95rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;cursor:pointer;transition:all .2s ease;align-self:flex-start}.overlay-button:hover{background-color:#5ba3f5;transform:translateY(-2px);box-shadow:0 4px 12px #4a90e266}.overlay-button:active{transform:translateY(0)}.overlay-no-access{margin-top:8px;padding:12px 24px;background-color:#ff000026;color:#f66;border:1px solid #ff6666;border-radius:6px;font-size:.9rem;font-weight:600;letter-spacing:.5px;text-transform:uppercase;text-align:center}.dataset-card-disabled{opacity:.5;cursor:not-allowed;border-color:#1a1a1a}.dataset-card-disabled:hover{transform:none;border-color:#1a1a1a;box-shadow:none}.dataset-card-disabled-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.7);z-index:10;pointer-events:none}@media (max-width: 768px){.dataset-card{min-height:340px}.dataset-card-thumbnail{height:200px}.dataset-card-content{padding:16px}.dataset-card-title{font-size:1.1rem}.overlay-title{font-size:1.2rem}.dataset-card-overlay{padding:20px}.placeholder-icon{width:48px;height:48px}.placeholder-name{font-size:1rem}}@media (max-width: 480px){.dataset-card-thumbnail{height:180px}.dataset-card-content{padding:14px;gap:10px}.dataset-card-title{font-size:1rem}.dataset-card-description{font-size:.9rem}.technique-badge{font-size:.7rem;padding:3px 8px}.overlay-info-item{font-size:.85rem}.overlay-description{font-size:.9rem}}@media (prefers-contrast: high){.dataset-card,.dataset-card:hover{border-color:#fff}.technique-badge{border-width:2px}}.fab-container{position:fixed;bottom:32px;right:32px;z-index:1000}.fab-button{width:64px;height:64px;border-radius:50%;background:linear-gradient(135deg,#4a90e2 0%,#357abd 100%);border:none;box-shadow:0 4px 12px #4a90e266,0 2px 6px #0009;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;position:relative}.fab-button:hover{transform:scale(1.1);box-shadow:0 6px 20px #4a90e299,0 4px 12px #000c;background:linear-gradient(135deg,#5ba3f5 0%,#4a90e2 100%)}.fab-button:active{transform:scale(1.05);box-shadow:0 4px 16px #4a90e280,0 2px 8px #000000b3}.fab-button:focus{outline:none;box-shadow:0 6px 20px #4a90e299,0 4px 12px #000c,0 0 0 3px #4a90e24d}.fab-icon{width:28px;height:28px;color:#fff;transition:transform .2s ease}.fab-button:hover .fab-icon{transform:translateY(-2px)}.fab-tooltip{position:absolute;right:76px;top:50%;transform:translateY(-50%);background-color:#1e1e1ef2;color:#fff;padding:8px 16px;border-radius:6px;font-size:.9rem;font-weight:500;letter-spacing:.3px;white-space:nowrap;box-shadow:0 4px 12px #0009;pointer-events:none;animation:tooltipFadeIn .2s ease;backdrop-filter:blur(4px);border:1px solid #333333}.fab-tooltip:after{content:"";position:absolute;right:-6px;top:50%;transform:translateY(-50%);width:0;height:0;border-style:solid;border-width:6px 0 6px 6px;border-color:transparent transparent transparent rgba(30,30,30,.95)}@keyframes tooltipFadeIn{0%{opacity:0;transform:translateY(-50%) translate(8px)}to{opacity:1;transform:translateY(-50%) translate(0)}}@keyframes fabPulse{0%,to{box-shadow:0 4px 12px #4a90e266,0 2px 6px #0009}50%{box-shadow:0 4px 16px #4a90e299,0 2px 8px #000000b3}}.fab-button{animation:fabPulse 2s ease-in-out infinite}.fab-button:hover{animation:none}@media (max-width: 768px){.fab-container{bottom:24px;right:24px}.fab-button{width:56px;height:56px}.fab-icon{width:24px;height:24px}.fab-tooltip{font-size:.85rem;padding:6px 12px;right:68px}}@media (max-width: 480px){.fab-container{bottom:20px;right:20px}.fab-button{width:52px;height:52px}.fab-icon{width:22px;height:22px}.fab-tooltip{display:none}}@media (prefers-contrast: high){.fab-button{border:2px solid #ffffff}.fab-tooltip{border:2px solid #ffffff;background-color:#000}}@media (prefers-reduced-motion: reduce){.fab-button{animation:none;transition:none}.fab-button:hover{transform:none}.fab-tooltip{animation:none}.fab-icon{transition:none}}@media print{.fab-container{display:none}}.persistent-panel-container{display:flex;width:100%;height:100%;position:relative;background-color:#000;overflow:hidden;contain:layout style;will-change:auto;transform:translateZ(0);backface-visibility:hidden}.persistent-panel-container.light{background-color:#f8f6f3}.persistent-panel{position:relative;height:100%;overflow:hidden;background-color:inherit;border:none;display:flex;flex-direction:column;contain:layout style;transform:translateZ(0);transition:width .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1),transform .2s cubic-bezier(.4,0,.2,1)}.persistent-panel.panel-visible{visibility:visible;opacity:1;transform:translateZ(0) scale(1);pointer-events:auto}.persistent-panel.panel-hidden{visibility:hidden;opacity:0;transform:translateZ(0) scale(.98);pointer-events:none;will-change:auto}.left-panel{border-right:1px solid #222222}.persistent-panel-container.light .left-panel{border-right-color:#ddd}.center-panel{border-right:1px solid #222222}.persistent-panel-container.light .center-panel{border-right-color:#ddd}.resize-handle{width:4px;height:100%;cursor:col-resize;background-color:#222;position:relative;z-index:10;flex-shrink:0;transform:translateZ(0);will-change:background-color,transform;transition:background-color .15s ease,transform .15s ease;border-left:1px solid transparent;border-right:1px solid transparent}.persistent-panel-container.light .resize-handle{background-color:#ddd}.resize-handle:hover{background-color:#444;border-left:1px solid #666666;border-right:1px solid #666666;transform:translateZ(0) scaleX(1.2)}.persistent-panel-container.light .resize-handle:hover{background-color:#bbb;border-left:1px solid #999999;border-right:1px solid #999999}.resize-handle:active,.resize-handle.active{background-color:#666;border-left:1px solid #888888;border-right:1px solid #888888;transform:translateZ(0) scaleX(1.5)}.persistent-panel-container.light .resize-handle:active,.persistent-panel-container.light .resize-handle.active{background-color:#999;border-left:1px solid #777777;border-right:1px solid #777777}.persistent-panel>*{width:100%;height:100%;min-height:0;contain:layout style}.persistent-panel-container.resizing{user-select:none;cursor:col-resize}.persistent-panel-container.resizing .persistent-panel{pointer-events:none;will-change:width,transform}.persistent-panel-container.resizing .resize-handle{will-change:background-color,border-color}.persistent-panel-container[data-visible-count="1"] .persistent-panel.panel-visible{width:100%!important}.persistent-panel-container[data-visible-count="1"] .persistent-panel.panel-hidden,.persistent-panel-container[data-visible-count="2"] .persistent-panel.panel-hidden{width:0!important;min-width:0;border:none;overflow:hidden}@media (max-width: 1200px){.resize-handle{width:3px}}@media (max-width: 768px){.persistent-panel-container{flex-direction:column;height:100vh}.persistent-panel{width:100%!important;height:33.33vh;border-right:none;border-bottom:1px solid #222222;transition:height .2s cubic-bezier(.4,0,.2,1),opacity .2s cubic-bezier(.4,0,.2,1)}.persistent-panel-container.light .persistent-panel{border-bottom-color:#ddd}.resize-handle{width:100%;height:4px;cursor:row-resize;border-left:none;border-right:none;border-top:1px solid transparent;border-bottom:1px solid transparent}.resize-handle:hover{border-top:1px solid #666666;border-bottom:1px solid #666666;transform:translateZ(0) scaleY(1.2)}.persistent-panel-container.light .resize-handle:hover{border-top:1px solid #999999;border-bottom:1px solid #999999}.persistent-panel.panel-hidden{height:0!important;min-height:0;border:none}}@media (min-resolution: 2dppx){.persistent-panel,.resize-handle{transform:translateZ(0) translateZ(0)}}.resize-handle:focus{outline:2px solid #666666;outline-offset:-1px;background-color:#555}.persistent-panel-container.light .resize-handle:focus{outline-color:#999;background-color:#ccc}.persistent-panel.loading{background:linear-gradient(90deg,#000000 25%,#111111 50%,#000000 75%);background-size:200% 100%;animation:loading-shimmer 2s infinite}.persistent-panel-container.light .persistent-panel.loading{background:linear-gradient(90deg,#f8f6f3 25%,#f0f0f0 50%,#f8f6f3 75%);background-size:200% 100%}@keyframes loading-shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@media (prefers-contrast: high){.resize-handle{background-color:#fff;border:1px solid #000000}.persistent-panel-container.light .resize-handle{background-color:#000;border:1px solid #ffffff}.resize-handle:hover{background-color:#ccc}.persistent-panel-container.light .resize-handle:hover{background-color:#333}.persistent-panel{border-color:#fff}.persistent-panel-container.light .persistent-panel{border-color:#000}}@media (prefers-reduced-motion: reduce){.persistent-panel,.resize-handle{transition:none;animation:none}.persistent-panel.panel-hidden{transform:none}}@media print{.resize-handle{display:none}.persistent-panel{width:33.33%!important;height:100vh;page-break-inside:avoid}.persistent-panel.panel-hidden{display:none}}.sidebar{position:relative;width:280px;min-width:50px;padding:0;background-color:#2e2d2d;color:#fff;display:flex;flex-direction:column;border-right:1px solid #222222;transition:width .3s ease,padding .3s ease;overflow:hidden}.sidebar.light{background-color:#f5f5f5;color:#333;border-right-color:#ccc}.sidebar.collapsed{width:50px;padding:.5rem 0}.sidebar.collapsed .sidebar-content{opacity:0;pointer-events:none;padding:.5rem}.sidebar.collapsed .collapse-toggle{opacity:1;pointer-events:auto}.sidebar-content{display:flex;flex-direction:column;height:100vh;padding:.75rem;gap:.75rem;opacity:1;transition:opacity .3s ease;overflow:hidden;scrollbar-width:thin;scrollbar-color:rgba(255,255,255,.3) transparent}.sidebar-content::-webkit-scrollbar{width:4px}.sidebar-content::-webkit-scrollbar-track{background:rgba(255,255,255,.05)}.sidebar-content::-webkit-scrollbar-thumb{background:rgba(255,255,255,.2);border-radius:2px}.sidebar.light .sidebar-content::-webkit-scrollbar-track{background:rgba(0,0,0,.05)}.sidebar.light .sidebar-content::-webkit-scrollbar-thumb{background:rgba(0,0,0,.2)}.logo-container{display:flex;justify-content:center;margin-bottom:.5rem;flex-shrink:0}.raynetics-logo{max-width:100px;height:auto;opacity:.9;transition:opacity .2s ease}.dataset-info{text-align:center;margin-bottom:.5rem;flex-shrink:0}.dataset-info h2{margin:0 0 .3rem;font-size:.9rem;color:#fff;font-weight:700;letter-spacing:.5px}.sidebar.light .dataset-info h2{color:#333}.format-info{display:flex;flex-wrap:wrap;gap:2px;margin:.3rem 0;justify-content:center}.format-badge{display:inline-block;padding:1px 5px;border-radius:2px;font-size:.6rem;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.3px}.dataset-badge{background-color:#2d6b2f;border:1px solid #3a8a3c}.dataset-description{font-size:.65rem;color:#999;line-height:1.2;margin-top:.3rem;font-style:italic}.sidebar.light .dataset-description{color:#666}.loading-text{color:#ccc;font-size:.85rem;font-style:italic}.sidebar.light .loading-text{color:#666}.error-message{background-color:#ff00001a;border:1px solid rgba(255,0,0,.3);border-radius:4px;padding:.4rem}.error-title{font-weight:600;color:#f66;font-size:.75rem;margin-bottom:.2rem}.error-details{font-size:.65rem;color:#ccc;line-height:1.2}.sidebar.light .error-details{color:#666}.sidebar-section{margin-bottom:.5rem;border-bottom:1px solid #333333;padding-bottom:.5rem;display:flex;flex-direction:column;flex-shrink:0}.sidebar-section.expandable-section{flex:1;min-height:0;overflow:hidden;margin-bottom:0;padding-bottom:0;border-bottom:none}.sidebar-section:has(.mesh-list){flex:1;min-height:0;overflow:hidden;flex-shrink:1}.sidebar.light .sidebar-section{border-bottom-color:#ccc}.sidebar-section:last-child{border-bottom:none;margin-bottom:0}.section-header{width:100%;background:transparent;border:none;padding:.5rem 0;cursor:pointer;display:flex;justify-content:space-between;align-items:center;color:#fff;transition:all .2s ease;flex-shrink:0}.sidebar.light .section-header{color:#333}.section-header:hover{color:#4a90e2}.sidebar.light .section-header:hover{color:#357abd}.section-title{font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.section-toggle{font-size:.7rem;color:#ccc;transition:transform .2s ease}.sidebar.light .section-toggle{color:#666}.section-content{padding-top:.5rem;display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.mesh-controls-section{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.mesh-bulk-actions{display:flex;gap:.3rem;margin-bottom:.5rem;flex-wrap:wrap;flex-shrink:0}.bulk-action-btn{flex:1;background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:3px;padding:.35rem .5rem;font-size:.65rem;cursor:pointer;transition:all .2s ease;font-weight:600;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap}.sidebar.light .bulk-action-btn{color:#666;border-color:#ccc}.bulk-action-btn:hover:not(:disabled){background-color:#4a90e233;color:#fff;border-color:#4a90e2;transform:translateY(-1px)}.sidebar.light .bulk-action-btn:hover:not(:disabled){background-color:#4a90e226;color:#333;border-color:#357abd}.bulk-action-btn:active:not(:disabled){transform:translateY(0)}.bulk-action-btn:disabled{opacity:.3;cursor:not-allowed}.mesh-count-display{font-size:.65rem;color:#fff;background-color:#ffffff1a;padding:.25rem .4rem;border-radius:3px;text-align:center;font-weight:600;margin-bottom:.5rem;font-family:monospace;letter-spacing:.5px;flex-shrink:0}.sidebar.light .mesh-count-display{color:#333;background-color:#0000001a}.mesh-list{display:flex;flex-direction:column;gap:.5rem;overflow-y:auto;flex:1;min-height:0;padding-right:.25rem}.mesh-list::-webkit-scrollbar{width:4px}.mesh-list::-webkit-scrollbar-track{background:rgba(255,255,255,.05);border-radius:2px}.mesh-list::-webkit-scrollbar-thumb{background:rgba(255,255,255,.3);border-radius:2px}.mesh-list::-webkit-scrollbar-thumb:hover{background:rgba(255,255,255,.5)}.sidebar.light .mesh-list::-webkit-scrollbar-track{background:rgba(0,0,0,.05)}.sidebar.light .mesh-list::-webkit-scrollbar-thumb{background:rgba(0,0,0,.3)}.sidebar.light .mesh-list::-webkit-scrollbar-thumb:hover{background:rgba(0,0,0,.5)}.mesh-item{background-color:#ffffff0d;border-radius:6px;padding:.5rem;border:1px solid #333333;transition:all .2s ease;flex-shrink:0}.sidebar.light .mesh-item{background-color:#0000000d;border-color:#ccc}.mesh-item:hover{background-color:#ffffff14;border-color:#555;transform:translateY(-1px)}.sidebar.light .mesh-item:hover{background-color:#00000014;border-color:#aaa}.mesh-item-header{display:flex;align-items:center;justify-content:space-between;gap:.5rem;margin-bottom:.5rem}.mesh-name-color{display:flex;align-items:center;gap:.5rem;flex:1;min-width:0}.mesh-color-indicator{width:16px;height:16px;border-radius:3px;border:1px solid #444444;flex-shrink:0}.sidebar.light .mesh-color-indicator{border-color:#999}.mesh-name{font-size:.8rem;color:#fff;font-weight:500;flex:1;line-height:1.3;display:flex;align-items:center;gap:.4rem;flex-wrap:wrap}.sidebar.light .mesh-name{color:#333}.mesh-type-badge{display:inline-block;padding:1px 4px;border-radius:2px;font-size:.55rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;background-color:#4a90e24d;color:#4a90e2;border:1px solid rgba(74,144,226,.5);white-space:nowrap}.mesh-type-badge.overlay-only{background-color:#8b45134d;color:#f96;border-color:#ff996680}.mesh-type-badge.mesh-only{background-color:#4b5d234d;color:#9c3;border-color:#99cc3380}.sidebar.light .mesh-type-badge{background-color:#4a90e233;color:#2c5aa0;border-color:#4a90e299}.sidebar.light .mesh-type-badge.overlay-only{background-color:#8b451333;color:sienna;border-color:#a0522d99}.sidebar.light .mesh-type-badge.mesh-only{background-color:#4b5d2333;color:#6b8e2e;border-color:#6b8e2e99}.mesh-visibility-toggle{position:relative;display:inline-block;width:36px;height:20px;flex-shrink:0}.mesh-visibility-toggle input[type=checkbox]{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;inset:0;background-color:#444;transition:.3s;border-radius:20px}.sidebar.light .toggle-slider{background-color:#ccc}.toggle-slider:before{position:absolute;content:"";height:14px;width:14px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}.mesh-visibility-toggle input:checked+.toggle-slider{background-color:#4a90e2}.sidebar.light .mesh-visibility-toggle input:checked+.toggle-slider{background-color:#357abd}.mesh-visibility-toggle input:checked+.toggle-slider:before{transform:translate(16px)}.toggle-slider:hover{background-color:#555}.sidebar.light .toggle-slider:hover{background-color:#bbb}.mesh-visibility-toggle input:checked+.toggle-slider:hover{background-color:#357abd}.sidebar.light .mesh-visibility-toggle input:checked+.toggle-slider:hover{background-color:#2c5aa0}.mesh-opacity-control{display:flex;flex-direction:column;gap:.4rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid rgba(255,255,255,.1)}.sidebar.light .mesh-opacity-control{border-top-color:#0000001a}.opacity-label{display:flex;justify-content:space-between;align-items:center;font-size:.7rem;color:#ccc;font-weight:500}.sidebar.light .opacity-label{color:#666}.opacity-label-text{text-transform:uppercase;letter-spacing:.3px;font-size:.65rem}.opacity-value{color:#fff;font-weight:600;background-color:#ffffff1a;padding:.15rem .35rem;border-radius:3px;font-family:monospace;font-size:.65rem;min-width:35px;text-align:center}.sidebar.light .opacity-value{color:#333;background-color:#0000001a}.opacity-slider{width:100%;height:4px;-webkit-appearance:none;appearance:none;background:#333333;outline:none;border-radius:2px;cursor:pointer}.sidebar.light .opacity-slider{background:#cccccc}.opacity-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;border-radius:50%;background:#666666;cursor:pointer;transition:all .2s}.sidebar.light .opacity-slider::-webkit-slider-thumb{background:#999999}.opacity-slider::-webkit-slider-thumb:hover{background:#888888;transform:scale(1.15)}.sidebar.light .opacity-slider::-webkit-slider-thumb:hover{background:#777777}.opacity-help-text{font-size:.6rem;color:#999;font-style:italic;line-height:1.2;margin-top:.25rem;padding:.25rem;background-color:#ffffff08;border-radius:2px;border-left:2px solid rgba(74,144,226,.3)}.sidebar.light .opacity-help-text{color:#888;background-color:#00000008;border-left-color:#4a90e280}.mesh-info-text{font-size:.65rem;color:#999;font-style:italic;line-height:1.2;margin-top:.5rem;padding:.35rem;background-color:#8b45131a;border-radius:3px;border-left:2px solid rgba(255,153,102,.4);text-align:center}.sidebar.light .mesh-info-text{color:#888;background-color:#8b45130d;border-left-color:#a0522d80}.control-group{margin-bottom:.5rem}.control-button{width:100%;background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:4px;padding:.5rem;font-size:.75rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;justify-content:center;font-weight:500}.sidebar.light .control-button{color:#666;border-color:#ccc}.control-button:hover{background-color:#ffffff1a;color:#fff;border-color:#666}.sidebar.light .control-button:hover{background-color:#0000001a;color:#333;border-color:#999}.button-icon{font-size:1rem}.button-text{flex:1;text-align:left}.back-button{background-color:#2d4a7b;border-color:#3e63a8;color:#fff}.sidebar.light .back-button{background-color:#4a90e2;border-color:#357abd;color:#fff}.back-button:hover{background-color:#3e63a8;border-color:#4a7bc8}.sidebar.light .back-button:hover{background-color:#357abd;border-color:#2c5aa0}.dataset-path-info{margin-top:.75rem;padding-top:.75rem;border-top:1px solid #333333;font-size:.65rem;color:#999}.sidebar.light .dataset-path-info{border-top-color:#ccc;color:#888}.path-label{font-weight:600;text-transform:uppercase;letter-spacing:.3px;margin-bottom:.25rem}.path-value{font-family:monospace;word-break:break-all;line-height:1.3;background-color:#ffffff0d;padding:.25rem;border-radius:2px}.sidebar.light .path-value{background-color:#0000000d}.collapse-toggle{position:absolute;top:50%;right:-12px;width:24px;height:24px;background-color:#444;color:#fff;border:2px solid #666666;border-radius:50%;cursor:pointer;z-index:100;display:flex;align-items:center;justify-content:center;font-size:.8rem;transform:translateY(-50%);transition:all .2s ease;opacity:1!important;pointer-events:auto!important}.sidebar.light .collapse-toggle{background-color:#fff;color:#333;border-color:#999}.collapse-toggle:hover{background-color:#555;transform:translateY(-50%) scale(1.1)}.sidebar.light .collapse-toggle:hover{background-color:#e0e0e0}@media (max-width: 768px){.sidebar{width:100%;height:auto;max-height:40vh;border-right:none;border-bottom:1px solid #222222}.sidebar.light{border-bottom-color:#ccc}.sidebar-content{height:auto;max-height:38vh}.mesh-controls-section{flex:none;max-height:200px}.collapse-toggle{display:none}}.mesh-visibility-toggle:focus,.opacity-slider:focus,.control-button:focus,.bulk-action-btn:focus,.section-header:focus{outline:2px solid #666666;outline-offset:2px}.sidebar.light .mesh-visibility-toggle:focus,.sidebar.light .opacity-slider:focus,.sidebar.light .control-button:focus,.sidebar.light .bulk-action-btn:focus,.sidebar.light .section-header:focus{outline-color:#999}.view-mode-selector{display:flex;flex-direction:column;gap:.75rem;width:100%}.panel-toggle-group{display:flex;flex-direction:column;gap:.25rem}.panel-toggle-button{display:flex;align-items:center;gap:.75rem;background-color:transparent;color:#888;border:1px solid #333333;border-radius:3px;padding:.5rem .75rem;cursor:pointer;transition:all .2s ease;font-size:.8rem;width:100%;text-align:left;position:relative}.panel-toggle-button:hover:not(.disabled){background-color:#1a1a1a;color:#fff;border-color:#555;transform:translateY(-1px)}.panel-toggle-button.active{background-color:#2a2a2a;color:#fff;border-color:#666;box-shadow:inset 0 1px 3px #0000004d}.panel-toggle-button.active:before{content:"";position:absolute;left:4px;top:50%;transform:translateY(-50%);width:3px;height:60%;background-color:#4caf50;border-radius:2px}.panel-toggle-button.disabled{opacity:.5;cursor:not-allowed}.panel-icon{flex-shrink:0;opacity:.7;transition:opacity .2s ease}.panel-toggle-button.active .panel-icon{opacity:1}.panel-info{display:flex;flex-direction:column;gap:.1rem;flex:1;min-width:0}.panel-name{font-weight:500;letter-spacing:.3px;font-size:.85rem;line-height:1.2;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-description{font-size:.7rem;opacity:.7;font-weight:400;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.panel-shortcut{flex-shrink:0;font-size:.65rem;opacity:.5;background-color:#ffffff1a;padding:2px 4px;border-radius:2px;font-family:monospace;font-weight:600;min-width:16px;text-align:center}.panel-toggle-button.active .panel-shortcut{opacity:.8;background-color:#ffffff26}.panel-management{display:flex;flex-direction:column;gap:.5rem;padding-top:.5rem;border-top:1px solid #333333}.panel-control-button{display:flex;align-items:center;justify-content:center;gap:.5rem;background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:3px;padding:.4rem .75rem;cursor:pointer;transition:all .2s ease;font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.panel-control-button:hover:not(.disabled){background-color:#1a1a1a;color:#fff;border-color:#666}.panel-control-button.disabled{opacity:.5;cursor:not-allowed}.panel-control-button svg{flex-shrink:0}.sidebar.light .panel-toggle-button{color:#666;border-color:#ccc}.sidebar.light .panel-toggle-button:hover:not(.disabled){background-color:#f0f0f0;border-color:#999;color:#333}.sidebar.light .panel-toggle-button.active{background-color:#e0e0e0;border-color:#888;color:#333}.sidebar.light .panel-control-button{color:#666;border-color:#ccc}.sidebar.light .panel-control-button:hover:not(.disabled){background-color:#f0f0f0;color:#333;border-color:#999}.sidebar.light .panel-management{border-top-color:#ccc}@media (max-width: 768px){.panel-toggle-button{padding:.4rem .6rem;gap:.5rem}.panel-name{font-size:.8rem}.panel-description{font-size:.65rem}.panel-shortcut{font-size:.6rem;padding:1px 3px;min-width:14px}.panel-control-button{padding:.35rem .6rem;font-size:.7rem}}@media (max-width: 480px){.panel-toggle-button{gap:.4rem;padding:.35rem .5rem}.panel-name{font-size:.75rem}.panel-description{font-size:.6rem}}.panel-toggle-button:focus,.panel-control-button:focus{outline:2px solid #666666;outline-offset:2px}.sidebar.light .panel-toggle-button:focus,.sidebar.light .panel-control-button:focus{outline-color:#999}.panel-toggle-button{transition:all .2s cubic-bezier(.4,0,.2,1)}.panel-icon{transition:all .2s ease}.panel-toggle-button:hover:not(.disabled) .panel-icon{transform:scale(1.1)}@media (prefers-contrast: high){.panel-toggle-button{background-color:#000!important;color:#fff!important;border-color:#fff!important}.sidebar.light .panel-toggle-button{background-color:#fff!important;color:#000!important;border-color:#000!important}.panel-control-button{background-color:#000!important;color:#fff!important;border-color:#fff!important}.sidebar.light .panel-control-button{background-color:#fff!important;color:#000!important;border-color:#000!important}}@media (prefers-reduced-motion: reduce){.panel-toggle-button,.panel-icon{transition:none}}.neuro-viewer{display:flex;flex-direction:column;width:100%;height:100%;position:relative;overflow:hidden;background-color:#000}.neuro-viewer.light{background-color:#f8f6f3}.neuroglancer-container{flex:1;position:relative;width:100%;height:100%;overflow:hidden;min-height:0}.neuroglancer-container .neuroglancer-viewer{width:100%!important;height:100%!important;background:transparent!important}.neuroglancer-container .neuroglancer-panel{background-color:#1e1e1ee6!important;border:1px solid #333333!important;color:#fff!important}.neuro-viewer.light .neuroglancer-container .neuroglancer-panel{background-color:#f8f6f3e6!important;border-color:#ccc!important;color:#333!important}.neuroglancer-container .neuroglancer-button{background-color:#333!important;color:#fff!important;border:1px solid #555555!important;border-radius:3px!important;padding:4px 8px!important;font-size:.8rem!important}.neuro-viewer.light .neuroglancer-container .neuroglancer-button{background-color:#e0e0e0!important;color:#333!important;border-color:#999!important}.neuroglancer-container .neuroglancer-button:hover{background-color:#444!important;border-color:#666!important}.neuro-viewer.light .neuroglancer-container .neuroglancer-button:hover{background-color:#d0d0d0!important;border-color:#888!important}.neuro-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:#ccc;background-color:#000}.neuro-viewer.light .neuro-loading{color:#666;background-color:#f8f6f3}.neuro-viewer.light .loading-spinner{border-color:#ccc;border-top-color:#999}.loading-text{font-size:1.1rem;font-weight:500}.loading-details{font-size:.9rem;opacity:.7;text-align:center;max-width:300px}.neuro-error{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:#f66;background-color:#000;padding:2rem;text-align:center}.neuro-viewer.light .neuro-error{background-color:#f8f6f3}.error-icon{font-size:3rem;margin-bottom:.5rem}.error-message{font-size:.9rem;opacity:.8;max-width:400px;line-height:1.4}.error-actions{display:flex;gap:.5rem;margin-top:1rem}.retry-button{background-color:#333;color:#fff;border:1px solid #555555;border-radius:3px;padding:.5rem 1rem;font-size:.8rem;cursor:pointer;transition:all .2s ease}.neuro-viewer.light .retry-button{background-color:#e0e0e0;color:#333;border-color:#999}.retry-button:hover{background-color:#444;border-color:#666}.neuro-viewer.light .retry-button:hover{background-color:#d0d0d0;border-color:#888}.neuro-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;color:#ccc;background-color:#000}.neuro-viewer.light .neuro-empty{color:#666;background-color:#f8f6f3}.empty-icon{font-size:4rem;opacity:.5;margin-bottom:1rem}.empty-title{font-size:1.1rem;font-weight:500;margin-bottom:.5rem}.empty-message{font-size:.9rem;opacity:.7;text-align:center;max-width:300px;line-height:1.4}.neuro-status{position:absolute;bottom:15px;left:15px;background-color:#1e1e1ecc;color:#ccc;padding:6px 12px;border-radius:3px;font-size:.8rem;z-index:10;backdrop-filter:blur(4px);border:1px solid #444444}.neuro-viewer.light .neuro-status{background-color:#f8f6f3cc;color:#666;border-color:#ccc}.status-ready{color:#4caf50}.status-loading{color:#ff9800}.status-error{color:#f44336}.neuro-viewer-controls{display:flex;flex-direction:column;gap:1rem;padding:1rem;background-color:#1e1e1ef2;border-top:1px solid #333333;min-height:120px;backdrop-filter:blur(4px)}.neuro-viewer.light .neuro-viewer-controls{background-color:#f8f6f3f2;border-top-color:#ccc}.neuro-colormap-section{display:flex;flex-direction:column;gap:.75rem;justify-content:center;align-items:center;padding:.5rem 0;border-top:1px solid #333333;border-bottom:1px solid #333333}.neuro-viewer.light .neuro-colormap-section{border-color:#ccc}.colormap-selection{display:flex;flex-direction:column;gap:.75rem;min-width:300px;align-items:center}.colormap-label{display:flex;justify-content:center;align-items:center;gap:.5rem;font-size:.9rem;color:#ccc;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.neuro-viewer.light .colormap-label{color:#666}.colormap-current-display{color:#fff;font-weight:600;background-color:#ffffff1a;padding:.3rem .6rem;border-radius:3px;font-size:.8rem;min-width:80px;text-align:center;text-transform:capitalize}.neuro-viewer.light .colormap-current-display{color:#333;background-color:#0000001a}.colormap-grid{display:flex;gap:.75rem;flex-wrap:wrap;justify-content:center;align-items:center}.colormap-swatch{width:40px;height:20px;border:2px solid #444444;border-radius:3px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.neuro-viewer.light .colormap-swatch{border-color:#999}.colormap-swatch:hover{border-color:#666;transform:scale(1.1);box-shadow:0 2px 8px #0000004d}.neuro-viewer.light .colormap-swatch:hover{border-color:#777}.colormap-swatch.active{border-color:#4caf50;border-width:3px;transform:scale(1.1);box-shadow:0 0 12px #4caf5066}.colormap-initial{font-size:.7rem;font-weight:700;color:#fff;text-shadow:0 0 3px rgba(0,0,0,.9);text-transform:uppercase;letter-spacing:.5px}.neuro-info-section{display:flex;flex-direction:column;gap:.5rem;align-items:center}.neuro-status-info{font-size:.9rem;font-weight:600;color:#fff;text-align:center;min-width:120px;padding:.25rem .5rem;background-color:#ffffff1a;border-radius:3px;letter-spacing:.3px}.neuro-viewer.light .neuro-status-info{color:#333;background-color:#0000001a}.neuro-metadata{display:flex;justify-content:center;gap:1rem;font-size:.75rem;color:#ccc;opacity:.8;flex-wrap:wrap}.neuro-viewer.light .neuro-metadata{color:#666}.neuro-viewer.light .metadata-item{background-color:#0000000d}@media (max-width: 768px){.neuro-viewer-controls{padding:.75rem;min-height:120px;gap:.75rem}.neuro-colormap-section{padding:.75rem 0}.colormap-selection{min-width:250px}.colormap-grid{gap:.5rem}.colormap-swatch{width:36px;height:18px}.neuro-status-info{font-size:.8rem;min-width:100px;padding:.2rem .4rem}.neuro-metadata{font-size:.7rem;gap:.5rem}}@media (max-width: 480px){.neuro-viewer-controls{min-height:120px}.colormap-selection{min-width:200px}.neuro-metadata{flex-direction:column;gap:.25rem;text-align:center}.colormap-grid{justify-content:center;gap:.4rem}.colormap-swatch{width:32px;height:16px}}.colormap-swatch:focus,.retry-button:focus{outline:2px solid #666666;outline-offset:2px}.neuro-viewer.light .colormap-swatch:focus,.neuro-viewer.light .retry-button:focus{outline-color:#999}@media (prefers-contrast: high){.colormap-swatch{border-width:3px!important;border-color:#fff!important}.neuro-viewer.light .colormap-swatch{border-color:#000!important}.colormap-swatch.active{border-color:#0f0!important}}@media print{.neuro-viewer-controls{display:none}.neuroglancer-container{height:100vh;page-break-inside:avoid}.neuro-status{display:none}}@media (prefers-reduced-motion: reduce){.colormap-swatch{transition:none}.loading-spinner{animation:none}}.raw-data-viewer{display:flex;flex-direction:column;width:100%;height:100%;position:relative;overflow:hidden}.raw-data-viewer.dark{background-color:#000;color:#fff}.raw-data-viewer.light{background-color:#f8f6f3;color:#333}.raw-data-display-area{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;min-height:0}.layered-image-container{position:relative;width:100%;height:100%;display:flex;align-items:center;justify-content:center}.jpeg-image{max-width:100%;max-height:100%;width:auto;height:auto;object-fit:contain;display:block;z-index:1;transition:opacity .3s ease;image-rendering:crisp-edges;-webkit-backface-visibility:hidden;backface-visibility:hidden;-webkit-transform:translateZ(0);transform:translateZ(0)}.jpeg-image.haadf-layer{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:1}.jpeg-image.element-layer{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:2;mix-blend-mode:screen;pointer-events:none}.jpeg-image.element-layer.blend-lighten{mix-blend-mode:lighten}.jpeg-image.element-layer.blend-add{mix-blend-mode:lighter}.jpeg-image.element-layer.blend-normal{mix-blend-mode:normal}.jpeg-image:hover{cursor:crosshair}.jpeg-image.loading{opacity:.7}.image-loading-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);z-index:5;background:rgba(0,0,0,.7);border-radius:8px;padding:12px}.raw-data-viewer.light .image-loading-overlay{background:rgba(255,255,255,.8)}.loading-spinner-small{width:24px;height:24px;border:2px solid #333333;border-top:2px solid #666666;border-radius:50%;animation:spin 1s linear infinite}.raw-data-viewer.light .loading-spinner-small{border-color:#ccc;border-top-color:#999}.error-overlay{position:absolute;bottom:20px;left:50%;transform:translate(-50%);background:rgba(255,0,0,.9);color:#fff;padding:8px 16px;border-radius:4px;z-index:5}.preload-indicator{position:absolute;top:20px;left:50%;transform:translate(-50%);background:rgba(0,0,0,.8);color:#fff;padding:12px 20px;border-radius:6px;z-index:10;text-align:center;min-width:300px}.raw-data-viewer.light .preload-indicator{background:rgba(255,255,255,.9);color:#333}.preload-text{font-size:.85rem;margin-bottom:8px;font-weight:500}.preload-progress-bar{width:100%;height:6px;background:rgba(255,255,255,.2);border-radius:3px;overflow:hidden;margin-bottom:6px}.raw-data-viewer.light .preload-progress-bar{background:rgba(0,0,0,.1)}.preload-progress-fill{height:100%;background:linear-gradient(90deg,#4CAF50,#45a049);border-radius:3px;transition:width .3s ease}.preload-percentage{font-size:.75rem;font-weight:600;opacity:.9}.raw-data-controls{display:flex;flex-direction:column;gap:.75rem;padding:1rem;background-color:#1e1e1ef2;border-top:1px solid #333333;min-height:180px;max-height:180px;height:180px;backdrop-filter:blur(4px);overflow:hidden}.raw-data-viewer.light .raw-data-controls{background-color:#f8f6f3f2;border-top-color:#ccc}.frame-navigation{display:flex;align-items:center;gap:1rem;justify-content:center;flex-shrink:0;height:36px}.frame-nav-button{background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:3px;width:36px;height:36px;font-size:1.3rem;font-weight:300;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;user-select:none}.raw-data-viewer.light .frame-nav-button{color:#666;border-color:#ccc}.frame-nav-button:hover:not(:disabled){background-color:#1a1a1a;color:#fff;border-color:#666;transform:scale(1.05)}.raw-data-viewer.light .frame-nav-button:hover:not(:disabled){background-color:#e0e0e0;color:#333;border-color:#999}.frame-nav-button:disabled{opacity:.3;cursor:not-allowed}.frame-slider-container{flex:1;max-width:450px;position:relative}.frame-slider{width:100%;height:7px;-webkit-appearance:none;appearance:none;background:linear-gradient(to right,#333333 0%,#555555 100%);outline:none;border-radius:3px;transition:all .2s ease;cursor:pointer}.raw-data-viewer.light .frame-slider{background:linear-gradient(to right,#cccccc 0%,#999999 100%)}.frame-slider:hover{background:linear-gradient(to right,#444444 0%,#666666 100%)}.frame-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:19px;height:19px;border-radius:50%;background:linear-gradient(135deg,#666666 0%,#888888 100%);cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000004d}.frame-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#777777 0%,#999999 100%);transform:scale(1.1)}.image-adjustments{display:flex;gap:1.5rem;justify-content:center;align-items:center;padding:.5rem 0;border-top:1px solid #333333;border-bottom:1px solid #333333;flex-shrink:0;height:42px}.raw-data-viewer.light .image-adjustments{border-color:#ccc}.adjustment-group{display:flex;flex-direction:column;gap:.5rem;min-width:140px}.adjustment-label{display:flex;justify-content:space-between;align-items:center;font-size:.75rem;color:#ccc;font-weight:500;text-transform:uppercase;letter-spacing:.3px}.raw-data-viewer.light .adjustment-label{color:#666}.adjustment-name{font-size:.7rem}.adjustment-value{color:#fff;font-weight:600;background-color:#ffffff1a;padding:.2rem .4rem;border-radius:2px;font-size:.7rem;font-family:monospace;min-width:45px;text-align:center}.raw-data-viewer.light .adjustment-value{color:#333;background-color:#0000001a}.adjustment-slider{width:100%;height:5px;-webkit-appearance:none;appearance:none;background:#333333;outline:none;border-radius:2px;transition:background .2s;cursor:pointer}.raw-data-viewer.light .adjustment-slider{background:#cccccc}.adjustment-slider:hover{background:#444444}.raw-data-viewer.light .adjustment-slider:hover{background:#bbbbbb}.adjustment-slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:17px;height:17px;border-radius:50%;background:linear-gradient(135deg,#666666 0%,#888888 100%);cursor:pointer;transition:all .2s;box-shadow:0 1px 3px #0000004d}.adjustment-slider::-webkit-slider-thumb:hover{background:linear-gradient(135deg,#777777 0%,#999999 100%);transform:scale(1.1)}.frame-info-section{display:flex;flex-direction:column;gap:.5rem;align-items:center;flex-shrink:0;height:50px;overflow:visible}.frame-counter{font-size:.95rem;font-weight:600;color:#fff;text-align:center;min-width:130px;padding:.25rem .5rem;background-color:#ffffff1a;border-radius:3px;letter-spacing:.3px}.raw-data-viewer.light .frame-counter{color:#333;background-color:#0000001a}.image-metadata{display:flex;justify-content:center;gap:1rem;font-size:.75rem;color:#ccc;opacity:.8;flex-wrap:wrap}.raw-data-viewer.light .image-metadata{color:#666}.metadata-item{padding:.2rem .4rem;background-color:#ffffff0d;border-radius:2px;font-family:monospace;white-space:nowrap}.raw-data-viewer.light .metadata-item{background-color:#0000000d}.raw-data-loading,.raw-data-error,.raw-data-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;gap:1rem;font-size:1.1rem;color:#ccc;padding:2rem;text-align:center}.raw-data-viewer.light .raw-data-loading,.raw-data-viewer.light .raw-data-error,.raw-data-viewer.light .raw-data-empty{color:#666}.loading-spinner{width:40px;height:40px;border:3px solid #333333;border-top:3px solid #666666;border-radius:50%;animation:spin 1s linear infinite}.raw-data-viewer.light .loading-spinner{border-color:#ccc;border-top-color:#999}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.error-icon{font-size:3rem;color:#f66;margin-bottom:.5rem}.error-title{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.empty-icon{font-size:3rem;margin-bottom:.5rem}.empty-title{font-size:1.3rem;font-weight:600;margin-bottom:.5rem}.empty-message{font-size:1rem;opacity:.8;margin-bottom:.5rem}.empty-details{font-size:.8rem;opacity:.6;font-family:monospace;background:rgba(255,255,255,.05);padding:.5rem 1rem;border-radius:4px;max-width:100%;word-break:break-all}.raw-data-viewer.light .empty-details{background:rgba(0,0,0,.05)}@media (max-width: 768px){.raw-data-controls{padding:.75rem;min-height:180px;max-height:180px;height:180px;gap:.5rem}.frame-navigation{gap:.75rem;height:32px}.frame-nav-button{width:32px;height:32px;font-size:1.1rem}.frame-slider-container{max-width:280px}.image-adjustments{flex-direction:column;gap:.75rem;padding:.75rem 0;height:auto;min-height:60px}.adjustment-group{min-width:200px}.frame-counter{font-size:.85rem;min-width:110px;padding:.25rem .5rem}.image-metadata{font-size:.7rem;gap:.75rem}.preload-indicator{min-width:250px;padding:10px 16px}.frame-info-section{height:38px}}@media (max-width: 480px){.raw-data-controls{min-height:200px;max-height:200px;height:200px}.frame-navigation{flex-direction:column;gap:.5rem;height:36px}.frame-slider-container{width:100%;max-width:none;order:2}.image-adjustments{gap:.75rem;height:auto;min-height:80px}.adjustment-group{min-width:180px}.image-metadata{flex-direction:column;gap:.25rem;text-align:center}.preload-indicator{min-width:200px;padding:8px 12px}}.frame-nav-button:focus,.frame-slider:focus,.adjustment-slider:focus{outline:2px solid #666666;outline-offset:2px}.raw-data-viewer.light .frame-nav-button:focus,.raw-data-viewer.light .frame-slider:focus,.raw-data-viewer.light .adjustment-slider:focus{outline-color:#999}@media (prefers-contrast: high){.adjustment-slider,.frame-slider{background:#ffffff!important;border:1px solid #000000}.raw-data-viewer.light .adjustment-slider,.raw-data-viewer.light .frame-slider{background:#000000!important;border:1px solid #ffffff}.frame-nav-button{background-color:#000!important;color:#fff!important;border-color:#fff!important}.raw-data-viewer.light .frame-nav-button{background-color:#fff!important;color:#000!important;border-color:#000!important}}@media (prefers-reduced-motion: reduce){.jpeg-image,.frame-nav-button,.adjustment-slider::-webkit-slider-thumb,.frame-slider::-webkit-slider-thumb{transition:none}.loading-spinner,.loading-spinner-small{animation:none}}@media print{.raw-data-controls{display:none}.raw-data-display-area{height:100vh;page-break-inside:avoid}.preload-indicator{display:none}}.dual-view-container{display:flex;height:100vh;background-color:#000}.loading-container{display:flex;justify-content:center;align-items:center;height:100vh;background-color:#000}.loading{font-size:1.2rem;color:#666;font-weight:300}.sidebar{position:relative;width:280px;min-width:50px;padding:.75rem;background-color:#2e2d2d;color:#fff;display:flex;flex-direction:column;border-right:1px solid #222222;transition:width .3s ease,padding .3s ease}.sidebar.collapsed{width:50px;padding:.5rem}.sidebar-content{opacity:1;transition:opacity .3s ease;display:flex;flex-direction:column;height:100%}.sidebar.collapsed .sidebar-content{opacity:0;pointer-events:none}.main-content{flex:1;position:relative;display:flex;flex-direction:column;overflow:hidden}.viewers-container{flex:1;display:flex;overflow:hidden;transition:opacity .3s ease}.mesh-viewer-panel{position:relative;width:100%;height:100%;background-color:#000;overflow:hidden;display:flex;flex-direction:column}.mesh-panel-container{display:flex;flex-direction:column;width:100%;height:100%}.mesh-canvas-area{flex:1;position:relative;width:100%;overflow:hidden;min-height:0}.mesh-viewer-content{flex:1;position:relative;width:100%;overflow:hidden}.raw-data-panel,.neuroglancer-panel{position:relative;width:100%;height:100%;background-color:#000;overflow:hidden;display:flex;flex-direction:column}.raw-data-viewer-content{flex:1;position:relative;width:100%;overflow:hidden}.logo-container{display:flex;justify-content:center;margin-bottom:1rem;padding:.5rem}.raynetics-logo{max-width:100%;height:auto;opacity:.9;transition:opacity .2s ease}.logo-container:hover .raynetics-logo{opacity:1}.dataset-info{margin-bottom:1rem;text-align:center}.dataset-info h2{margin:0;font-size:1.1rem;color:#ccc;font-weight:700;letter-spacing:.5px}.format-info{display:flex;gap:5px;margin-top:8px;margin-bottom:5px;justify-content:center}.format-badge{display:inline-block;padding:2px 6px;border-radius:2px;font-size:.75rem;font-weight:500;color:#fff;text-transform:uppercase;letter-spacing:.3px}.dataset-badge{background-color:#2d6b2f;border:1px solid #3a8a3c;font-size:.95rem}.zarr-badge{background-color:#2d4a7b;border:1px solid #3e63a8}.raw-badge{background-color:#8b4513;border:1px solid #a0522d}.mesh-badge{background-color:#4a5d23;border:1px solid #6b8e2e}.dataset-description{font-size:.75rem;color:#999;line-height:1.3;margin-top:.5rem;font-style:italic}.canvas-container{width:100%;height:100%;position:relative;z-index:1;cursor:grab}.mesh-camera-controls{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1rem;background-color:#1e1e1ee6;border-top:1px solid #333333;min-height:50px;max-height:50px;height:50px;flex-shrink:0;backdrop-filter:blur(4px)}.camera-control-buttons{display:flex;align-items:center;gap:.75rem;flex:1;justify-content:center}.camera-control-btn{background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:4px;padding:.5rem .75rem;font-size:.75rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.4rem;user-select:none;font-weight:500;white-space:nowrap}.camera-control-btn:hover{background-color:#1a1a1a;color:#fff;border-color:#666;transform:translateY(-1px)}.camera-control-btn:active{transform:translateY(0)}.camera-control-btn svg{flex-shrink:0}.mesh-status-display{display:flex;align-items:center;justify-content:flex-end;flex-shrink:0}.mesh-count-status{font-size:.75rem;color:#ccc;background-color:#ffffff0d;padding:.25rem .5rem;border-radius:3px;font-family:monospace;font-weight:500}.neuro-viewer-controls{display:flex;flex-direction:column;gap:.5rem;padding:1rem;background-color:#1e1e1ee6;border-top:1px solid #333333;min-height:120px;flex-shrink:0}.raw-data-controls{min-height:160px;flex-shrink:0}.neuro-control-buttons{display:flex;align-items:center;gap:.75rem;justify-content:center}.neuro-control-button{background-color:transparent;color:#ccc;border:1px solid #444444;border-radius:3px;padding:.5rem .75rem;font-size:.8rem;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:.5rem;user-select:none}.neuro-control-button:hover{background-color:#1a1a1a;color:#fff;border-color:#666;transform:translateY(-1px)}.neuro-control-button:active{transform:translateY(0)}.neuro-control-button svg{flex-shrink:0}.neuro-info{display:flex;justify-content:center;align-items:center;gap:1rem}.neuro-status{font-size:.8rem;color:#ccc;background-color:#ffffff0d;padding:.25rem .5rem;border-radius:3px;font-family:monospace}.neuro-colormap-info{font-size:.8rem;color:#ccc;display:flex;align-items:center;gap:.5rem}.colormap-preview-small{width:30px;height:12px;border-radius:2px;border:1px solid #444444}.error-message{background-color:#1a0000;color:#f66;padding:.5rem;font-size:.8rem;margin-bottom:.5rem;border:1px solid #330000}.access-denied-content{text-align:center;color:#fff}.access-denied-content h2{color:#f66;margin-bottom:1rem;font-size:1.5rem;font-weight:300}.access-denied-content p{color:#ccc;margin-bottom:2rem;font-size:1rem}.no-panels-message{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;color:#ccc;text-align:center;gap:1rem}.single-panel-container,.dual-panel-container{width:100%;height:100%;display:flex}.resize-handle{width:2px;height:100%;cursor:col-resize;background-color:#222;z-index:2;transition:background-color .2s}.resize-handle:hover{background-color:#444}.panel-visible{visibility:visible!important;opacity:1!important;transform:translateZ(0) scale(1)!important;pointer-events:auto!important;contain:layout style}.panel-hidden{visibility:hidden!important;opacity:0!important;transform:translateZ(0) scale(.98)!important;pointer-events:none!important;contain:layout style;overflow:hidden}.raw-data-panel,.mesh-viewer-panel,.neuroglancer-panel{contain:layout style;transform:translateZ(0);backface-visibility:hidden;transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),visibility 0s linear .3s}.raw-data-panel.panel-visible,.mesh-viewer-panel.panel-visible,.neuroglancer-panel.panel-visible{transition:opacity .3s cubic-bezier(.4,0,.2,1),transform .3s cubic-bezier(.4,0,.2,1),visibility 0s linear 0s}.tem-mesh-placeholder,.neuroglancer-placeholder{contain:layout style;transform:translateZ(0);width:100%;height:100%;display:flex;align-items:center;justify-content:center}.placeholder-content{text-align:center;color:#ccc;animation:fadeInPlaceholder .5s ease-out}@keyframes fadeInPlaceholder{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.placeholder-icon{font-size:3rem;margin-bottom:1rem;opacity:.6}.placeholder-title{font-size:1.2rem;font-weight:600;margin-bottom:.5rem}.placeholder-message{font-size:.9rem;opacity:.8;line-height:1.4;max-width:300px}@media (max-width: 768px){.dual-view-container{flex-direction:column}.sidebar{width:100%;height:auto;max-height:40vh;overflow-y:auto}.main-content{height:60vh}.mesh-camera-controls{padding:.5rem;min-height:45px;max-height:45px;height:45px}.camera-control-buttons{gap:.5rem}.camera-control-btn{padding:.4rem .6rem;font-size:.7rem}.mesh-count-status{font-size:.7rem;padding:.2rem .4rem}.neuro-viewer-controls{min-height:100px}.neuro-control-buttons{gap:.5rem;flex-wrap:wrap}.neuro-control-button{padding:.4rem .6rem;font-size:.75rem}.neuro-info{flex-direction:column;gap:.5rem}.mesh-panel-container{flex-direction:column}.mesh-canvas-area{flex:1;min-height:200px}}@media (max-width: 480px){.camera-control-btn span:not(svg){display:none}.camera-control-btn{padding:.4rem;min-width:36px;justify-content:center}.mesh-count-status{font-size:.65rem}.neuro-control-button span{display:none}.neuro-control-button{flex:1;min-width:0;justify-content:center}}.viewers-container{contain:layout style;transform:translateZ(0);overflow:hidden}.canvas-container{transform:translateZ(0);backface-visibility:hidden;touch-action:none;contain:layout style}.canvas-container:active{cursor:grabbing}@media (min-resolution: 2dppx){.raw-data-panel,.mesh-viewer-panel,.neuroglancer-panel{transform:translateZ(0)}}@media (prefers-reduced-motion: reduce){.panel-visible,.panel-hidden,.raw-data-panel,.mesh-viewer-panel,.neuroglancer-panel{transition:none!important;animation:none!important}.placeholder-content{animation:none}.camera-control-btn:hover{transform:none}}@media (prefers-contrast: high){.panel-visible{border:2px solid #ffffff}.panel-hidden{border:2px solid #888888}.resize-handle{background-color:#fff!important;border:1px solid #000000}.camera-control-btn{background-color:#000!important;color:#fff!important;border-color:#fff!important}}.loading-container{contain:layout style;transform:translateZ(0)}.loading,.error{animation:fadeIn .3s ease-out}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.panel-hidden .canvas-container,.panel-hidden .neuroglancer-container,.panel-hidden .raw-data-display-area{visibility:hidden;pointer-events:none}@media print{.panel-hidden{display:none!important}.panel-visible{width:100%!important;height:100vh!important;page-break-inside:avoid}.mesh-camera-controls,.neuro-viewer-controls{display:none}}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;background-color:#000;color:#fff}*{box-sizing:border-box}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:#111111}::-webkit-scrollbar-thumb{background:#333333;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#555555}body,input,button,textarea,select{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}
