@import"https://fonts.googleapis.com/css2?family=JetBrains+Mono:wght@300;400;500;600;700&family=Space+Grotesk:wght@300;400;500;600;700&family=IBM+Plex+Sans:wght@300;400;500;600;700&family=IBM+Plex+Serif:wght@300;400;500;600;700&display=swap";:root{--sardine-bg: #0a1628;--sardine-bg-raised: #0f1f38;--sardine-bg-panel: #122240;--sardine-bg-hover: #1a2d50;--sardine-border: #1e3a5f;--sardine-border-subtle: #162d4a;--sardine-cyan: #4ec9d4;--sardine-cyan-dim: #2a8a93;--sardine-cyan-glow: rgba(78, 201, 212, .25);--sardine-cyan-bg: rgba(78, 201, 212, .08);--sardine-orange: #e8833a;--sardine-orange-dim: #b5642a;--sardine-orange-glow: rgba(232, 131, 58, .25);--sardine-orange-bg: rgba(232, 131, 58, .08);--sardine-green: #3ddc84;--sardine-green-dim: #2a9e5e;--sardine-green-glow: rgba(61, 220, 132, .2);--sardine-magenta: #d45cff;--sardine-magenta-dim: #9a3db8;--sardine-magenta-glow: rgba(212, 92, 255, .2);--text-primary: #e8edf5;--text-secondary: #8fa4c4;--text-muted: #5a7099;--text-disabled: #3a5070;--status-flood: #ff5c5c;--status-water: #4ea8ff;--status-dry: #c4a35a;--status-success: #3ddc84;--font-mono: "JetBrains Mono", "Fira Code", monospace;--font-display: "Space Grotesk", sans-serif;--font-body: "IBM Plex Sans", sans-serif;--font-serif: "IBM Plex Serif", Georgia, serif;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--space-3xl: 64px;--radius-sm: 2px;--radius-md: 3px;--radius-lg: 4px;--transition-fast: .15s ease;--transition-med: .25s ease}*{margin:0;padding:0;box-sizing:border-box}body{background:var(--sardine-bg);color:var(--text-primary);font-family:var(--font-body);line-height:1.6;min-height:100vh}body:after{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:repeating-linear-gradient(0deg,transparent,transparent 2px,rgba(0,0,0,.03) 2px,rgba(0,0,0,.03) 4px);pointer-events:none;z-index:9999}#app{width:100vw;height:100vh;display:flex;flex-direction:column}.header{background:var(--sardine-bg-panel);padding:var(--space-sm) var(--space-lg);border-bottom:2px dashed var(--sardine-border);display:flex;align-items:center;gap:var(--space-lg)}.header h1{font-family:var(--font-mono);font-size:1.4rem;font-weight:700;letter-spacing:-1px;color:var(--text-primary)}.header h1 .sar{color:var(--sardine-cyan)}.header .subtitle{font-family:var(--font-mono);font-size:.75rem;color:var(--text-muted);letter-spacing:2px;text-transform:uppercase}.main-layout{display:flex;flex:1;overflow:hidden;padding-bottom:0;transition:padding-bottom .3s ease}.controls-panel{width:280px;background:var(--sardine-bg-panel);padding:var(--space-md);padding-bottom:48px;overflow-y:auto;border-right:1px dashed var(--sardine-border);display:flex;flex-direction:column;gap:var(--space-md)}.control-section{background:var(--sardine-bg-raised);padding:var(--space-md);border-radius:var(--radius-md);border:1px solid var(--sardine-border)}.control-section h3{font-family:var(--font-mono);font-size:.7rem;font-weight:500;text-transform:uppercase;letter-spacing:2px;color:var(--text-muted);margin-bottom:var(--space-sm);padding-bottom:var(--space-xs);border-bottom:1px dashed var(--sardine-border-subtle)}.control-section h3.collapsible{cursor:pointer;display:flex;align-items:center;justify-content:space-between;-webkit-user-select:none;user-select:none;transition:color var(--transition-fast)}.control-section h3.collapsible:hover{color:var(--text-secondary)}.control-section h3.collapsible:after{content:"";width:0;height:0;border-left:4px solid transparent;border-right:4px solid transparent;border-top:5px solid currentColor;transition:transform var(--transition-fast)}.control-section h3.collapsible.collapsed{margin-bottom:0;border-bottom-color:transparent}.control-section h3.collapsible.collapsed:after{transform:rotate(-90deg)}.section-body{overflow:hidden;transition:max-height var(--transition-med),opacity var(--transition-fast);max-height:800px;opacity:1}.section-body.collapsed{max-height:0;opacity:0}.control-group{display:flex;flex-direction:column;gap:var(--space-xs);margin-bottom:var(--space-sm)}.control-group:last-child{margin-bottom:0}.control-group label{font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);letter-spacing:.5px}.control-group input[type=text],.control-group select{font-family:var(--font-mono);font-size:.8rem;padding:var(--space-sm) var(--space-md);border-radius:var(--radius-sm);border:1px solid var(--sardine-border);background:var(--sardine-bg);color:var(--text-primary);outline:none;transition:border-color var(--transition-fast);width:100%}.control-group input[type=text]:focus,.control-group select:focus{border-color:var(--sardine-cyan);box-shadow:0 0 0 3px var(--sardine-cyan-bg)}.control-group input[type=text]::placeholder{color:var(--text-disabled)}.control-group select{-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath d='M6 8L1 3h10z' fill='%235a7099'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:32px}.control-group input[type=range]{width:100%;accent-color:var(--sardine-cyan);height:6px}.control-group input[type=file]{font-family:var(--font-mono);font-size:.7rem;color:var(--text-secondary)}.control-row{display:flex;align-items:center;gap:var(--space-sm)}.control-row input[type=checkbox]{accent-color:var(--sardine-cyan)}.control-row label{font-family:var(--font-body);font-size:.85rem;color:var(--text-primary)}button{font-family:var(--font-mono);font-size:.8rem;font-weight:500;letter-spacing:.5px;padding:10px 20px;border-radius:var(--radius-sm);border:1px solid var(--sardine-cyan);background:var(--sardine-cyan);color:var(--sardine-bg);cursor:pointer;transition:all var(--transition-fast);text-transform:uppercase}button:hover{background:#5ed8e6;box-shadow:0 0 20px var(--sardine-cyan-glow)}button:disabled{background:var(--sardine-border);border-color:var(--sardine-border);color:var(--text-disabled);cursor:not-allowed;box-shadow:none}button.btn-secondary{background:transparent;color:var(--sardine-cyan);border-color:var(--sardine-cyan-dim)}button.btn-secondary:hover{background:var(--sardine-cyan-bg);border-color:var(--sardine-cyan)}button.btn-alert{background:var(--sardine-orange);border-color:var(--sardine-orange);color:var(--sardine-bg)}button.btn-alert:hover{box-shadow:0 0 20px var(--sardine-orange-glow)}button.btn-danger{background:rgba(255,92,92,.1);color:var(--status-flood);border-color:#ff5c5c4d}button.btn-danger:hover{background:rgba(255,92,92,.2);border-color:var(--status-flood)}.viewer-container{flex:1;position:relative;background:var(--sardine-bg)}.state-panel{width:350px;background:var(--sardine-bg-raised);border-left:1px dashed var(--sardine-border);display:flex;flex-direction:column}.state-panel-header{padding:var(--space-sm) var(--space-md);background:var(--sardine-bg-panel);border-bottom:1px dashed var(--sardine-border);display:flex;justify-content:space-between;align-items:center}.state-panel-header h3{font-family:var(--font-mono);font-size:.8rem;font-weight:600;color:var(--text-primary);letter-spacing:.5px}.state-panel-header .badge{font-family:var(--font-mono);font-size:.65rem;color:var(--sardine-cyan);background:var(--sardine-cyan-bg);border:1px solid var(--sardine-border);padding:2px 8px;border-radius:var(--radius-sm);letter-spacing:1px;text-transform:uppercase}.state-content{flex:1;padding:0;overflow:hidden;display:flex;flex-direction:column}.state-textarea{flex:1;width:100%;border:none;background:var(--sardine-bg);color:var(--text-secondary);font-family:var(--font-mono);font-size:.8rem;line-height:1.6;padding:var(--space-md);resize:none;outline:none;transition:background var(--transition-fast)}.state-textarea:focus{background:var(--sardine-bg-raised)}.apply-button{margin:var(--space-sm) var(--space-md);display:block}.loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:.85rem;color:var(--text-muted);letter-spacing:1px}.error{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-family:var(--font-mono);font-size:.85rem;color:var(--status-flood);text-align:center;padding:var(--space-lg);max-width:80%;background:rgba(255,92,92,.05);border:1px solid rgba(255,92,92,.2);border-radius:var(--radius-md)}.value-display{font-family:var(--font-mono);color:var(--sardine-cyan);font-size:.75rem}.status-chip{display:inline-flex;align-items:center;gap:var(--space-sm);font-family:var(--font-mono);font-size:.7rem;letter-spacing:.5px;padding:4px 12px;border-radius:var(--radius-sm);text-transform:uppercase}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.progress-track{height:6px;background:var(--sardine-border);border-radius:3px;overflow:hidden}.progress-fill{height:100%;border-radius:3px;background:linear-gradient(90deg,var(--sardine-cyan-dim),var(--sardine-cyan));transition:width 1s ease}.progress-fill.alert{background:linear-gradient(90deg,var(--sardine-orange-dim),var(--sardine-orange))}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--sardine-bg)}::-webkit-scrollbar-thumb{background:var(--sardine-border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--sardine-cyan-dim)}.metadata-panel{position:absolute;top:var(--space-sm);right:var(--space-sm);width:220px;max-height:calc(100% - 16px);background:rgba(10,22,40,.92);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--sardine-border);border-radius:var(--radius-md);z-index:100;font-family:var(--font-mono);font-size:.65rem;color:var(--text-secondary);overflow:hidden;transition:width var(--transition-med),max-height var(--transition-med);box-shadow:0 4px 24px #0006}.metadata-panel.collapsed{width:32px;max-height:32px;cursor:pointer}.metadata-panel-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--sardine-bg-panel);border-bottom:1px solid var(--sardine-border-subtle);cursor:pointer;-webkit-user-select:none;user-select:none}.metadata-panel.collapsed .metadata-panel-header{border-bottom:none;padding:6px 8px;justify-content:center}.metadata-panel-title{font-size:.65rem;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;color:var(--text-primary)}.metadata-panel.collapsed .metadata-panel-title{display:none}.metadata-panel-toggle{font-size:.6rem;color:var(--text-muted);transition:transform var(--transition-fast)}.metadata-panel-body{padding:6px;overflow-y:auto;max-height:calc(100vh - 160px)}.metadata-section{padding:6px 4px;border-bottom:1px dashed var(--sardine-border-subtle)}.metadata-section:last-child{border-bottom:none}.metadata-section-title{font-size:.6rem;font-weight:600;text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);margin-bottom:4px;padding-bottom:2px;border-bottom:1px dashed var(--sardine-border-subtle)}.metadata-row{display:flex;justify-content:space-between;align-items:baseline;padding:1px 0;line-height:1.5}.metadata-label{color:var(--text-disabled);font-size:.6rem;white-space:nowrap;margin-right:8px;flex-shrink:0}.metadata-value{color:var(--text-secondary);font-size:.65rem;text-align:right;word-break:break-word}.metadata-value.accent{color:var(--sardine-cyan);font-weight:500}.overview-map-toggle{position:absolute;bottom:calc(var(--bottom-dock, 40px) + 50px);left:var(--space-md, 12px);width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:rgba(10,22,40,.85);backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);border:1px solid var(--sardine-border);border-radius:var(--radius-sm, 6px);cursor:pointer;z-index:1010;transition:bottom .3s ease,background var(--transition-fast, .15s),border-color var(--transition-fast, .15s);box-shadow:0 2px 12px #0006}.overview-map-toggle:hover{background:rgba(18,34,64,.95);border-color:var(--sardine-cyan-dim)}.overview-map-toggle-icon{font-size:18px;line-height:1}.overview-map{position:absolute;bottom:calc(var(--bottom-dock, 40px) + 50px);left:var(--space-md, 12px);width:400px;background:rgba(10,22,40,.94);backdrop-filter:blur(10px);-webkit-backdrop-filter:blur(10px);border:1px solid var(--sardine-border);border-radius:var(--radius-md, 8px);z-index:1010;font-family:var(--font-mono, "JetBrains Mono", monospace);font-size:.65rem;color:var(--text-secondary);overflow:hidden;box-shadow:0 6px 32px #00000080;transition:bottom .3s ease;animation:overview-map-appear .2s ease-out}@keyframes overview-map-appear{0%{opacity:0;transform:translateY(8px) scale(.96)}to{opacity:1;transform:translateY(0) scale(1)}}.overview-map-header{display:flex;justify-content:space-between;align-items:center;padding:6px 10px;background:var(--sardine-bg-panel);border-bottom:1px solid var(--sardine-border-subtle);-webkit-user-select:none;user-select:none}.overview-map-title{font-size:.65rem;font-weight:600;letter-spacing:1.2px;text-transform:uppercase;color:var(--text-primary)}.overview-map-loading{color:var(--sardine-cyan-dim);animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.overview-map-controls{display:flex;align-items:center;gap:2px}.overview-map-btn{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;background:transparent;border:1px solid var(--sardine-border-subtle);border-radius:var(--radius-sm, 4px);color:var(--text-secondary);font-size:.75rem;font-family:var(--font-mono);cursor:pointer;transition:background var(--transition-fast, .15s),border-color var(--transition-fast, .15s)}.overview-map-btn:hover:not(:disabled){background:var(--sardine-bg-hover);border-color:var(--sardine-cyan-dim);color:var(--text-primary)}.overview-map-btn:disabled{opacity:.3;cursor:not-allowed}.overview-map-btn.overview-map-close{margin-left:4px;color:var(--text-muted)}.overview-map-btn.overview-map-close:hover{color:var(--sardine-orange);border-color:var(--sardine-orange-dim)}.overview-map-zoom-label{font-size:.6rem;color:var(--sardine-cyan);min-width:28px;text-align:center;font-weight:600;letter-spacing:.5px}.overview-map-svg{display:block;width:100%;height:auto;border-bottom:1px solid var(--sardine-border-subtle)}.overview-map-status{display:flex;justify-content:space-between;align-items:center;padding:4px 10px;font-size:.58rem;color:var(--text-muted);letter-spacing:.3px}[data-theme=light]{--sardine-bg: #f5f3ef;--sardine-bg-raised: #ffffff;--sardine-bg-panel: #faf9f6;--sardine-bg-hover: #edeae4;--sardine-border: #d4cdb8;--sardine-border-subtle: #e2ddd0;--sardine-cyan: #0e8a96;--sardine-cyan-dim: #0a6e78;--sardine-cyan-glow: rgba(14, 138, 150, .15);--sardine-cyan-bg: rgba(14, 138, 150, .06);--sardine-orange: #c96a25;--sardine-orange-dim: #a0541d;--sardine-orange-glow: rgba(201, 106, 37, .15);--sardine-orange-bg: rgba(201, 106, 37, .06);--sardine-green: #1a8a4a;--sardine-green-dim: #146b3a;--sardine-green-glow: rgba(26, 138, 74, .15);--sardine-magenta: #9b3dbb;--sardine-magenta-dim: #7a2f94;--sardine-magenta-glow: rgba(155, 61, 187, .15);--text-primary: #1a2233;--text-secondary: #4a5568;--text-muted: #7a8599;--text-disabled: #b0b8c4;--status-flood: #cc3333;--status-water: #2a7acc;--status-dry: #9a8030;--status-success: #1a8a4a}[data-theme=light] body:after{background:none}.data-discovery{font-size:.75rem}.discovery-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:6px;padding:4px 6px;background:var(--sardine-bg-raised, #162033);border:1px solid var(--sardine-border, #1e3a5f);border-radius:4px}.discovery-url{font-family:var(--font-mono, monospace);font-size:.65rem;color:var(--sardine-cyan, #4ec9d4);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discovery-disconnect-btn{flex-shrink:0;padding:1px 6px!important;font-size:.7rem!important;line-height:1;min-width:auto!important;background:transparent!important;color:var(--text-muted)!important;border:none!important}.discovery-disconnect-btn:hover{color:var(--sardine-red, #e74c3c)!important}.discovery-breadcrumbs{display:flex;flex-wrap:wrap;gap:1px;margin-bottom:6px;font-size:.65rem;font-family:var(--font-mono, monospace)}.discovery-crumb{background:none;border:none;color:var(--sardine-cyan, #4ec9d4);cursor:pointer;padding:1px 3px;font-size:.65rem;font-family:inherit}.discovery-crumb:hover{text-decoration:underline}.discovery-crumb:disabled{color:var(--text-primary, #e0e8f0);cursor:default;text-decoration:none}.discovery-sep{color:var(--text-muted, #5a7099);margin:0 1px}.discovery-listing{max-height:300px;overflow-y:auto;border:1px solid var(--sardine-border, #1e3a5f);border-radius:4px;background:var(--sardine-bg, #0a1628)}.discovery-item{display:flex;align-items:center;gap:6px;padding:4px 8px;cursor:default;border-bottom:1px solid rgba(30,58,95,.3);transition:background .15s ease}.discovery-item:last-child{border-bottom:none}.discovery-dir{cursor:pointer}.discovery-dir:hover{background:rgba(78,201,212,.08)}.discovery-icon{flex-shrink:0;font-size:.7rem;width:16px;text-align:center}.discovery-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:.7rem}.discovery-size{flex-shrink:0;font-size:.6rem;color:var(--text-muted, #5a7099);font-family:var(--font-mono, monospace)}.discovery-loadable{cursor:pointer}.discovery-loadable:hover{background:rgba(78,201,212,.12)}.discovery-loadable:hover .discovery-name{color:var(--sardine-cyan, #4ec9d4)}.discovery-nisar .discovery-name{color:var(--sardine-green, #2ecc71)}.discovery-nisar:hover .discovery-name{color:var(--sardine-cyan, #4ec9d4)}.discovery-empty,.discovery-loading{padding:16px;text-align:center;color:var(--text-muted, #5a7099);font-style:italic;font-size:.7rem}.discovery-error{margin-top:6px;padding:6px 8px;background:rgba(231,76,60,.1);border:1px solid rgba(231,76,60,.3);border-radius:4px;color:var(--sardine-red, #e74c3c);font-size:.7rem;word-break:break-word}.discovery-preset-btn{display:block;width:100%;text-align:left;margin-bottom:3px;font-size:.7rem!important;padding:3px 8px!important}.discovery-auth-badge{float:right;font-size:.6rem}.discovery-filter-bar{display:flex;align-items:center;gap:4px;margin-bottom:4px}.discovery-filter-toggle{display:flex;align-items:center;gap:4px;background:var(--sardine-bg-raised, #162033);border:1px solid var(--sardine-border, #1e3a5f);color:var(--text-secondary, #b0bec5);font-size:.65rem;padding:2px 8px;border-radius:3px;cursor:pointer;font-family:inherit;transition:border-color .15s ease,color .15s ease}.discovery-filter-toggle:hover,.discovery-filter-toggle.active{border-color:var(--sardine-cyan, #4ec9d4);color:var(--sardine-cyan, #4ec9d4)}.discovery-filter-badge{display:inline-flex;align-items:center;justify-content:center;min-width:14px;height:14px;padding:0 3px;border-radius:7px;background:var(--sardine-cyan, #4ec9d4);color:var(--sardine-bg, #0a1628);font-size:.55rem;font-weight:700;line-height:1}.discovery-filter-reset{background:none;border:none;color:var(--text-muted, #5a7099);font-size:.6rem;cursor:pointer;padding:2px 4px;font-family:inherit}.discovery-filter-reset:hover{color:var(--sardine-red, #e74c3c)}.discovery-filters{display:grid;grid-template-columns:1fr 1fr;gap:3px 6px;padding:6px;margin-bottom:4px;background:var(--sardine-bg-raised, #162033);border:1px solid var(--sardine-border, #1e3a5f);border-radius:4px}.discovery-filter-group{display:flex;flex-direction:column;gap:1px}.discovery-filter-group label{font-size:.55rem;color:var(--text-muted, #5a7099);text-transform:uppercase;letter-spacing:.05em}.discovery-filter-group select{font-size:.65rem;padding:1px 2px;background:var(--sardine-bg, #0a1628);color:var(--text-primary, #e0e8f0);border:1px solid var(--sardine-border, #1e3a5f);border-radius:3px;font-family:var(--font-mono, monospace)}.discovery-filter-group select:focus{border-color:var(--sardine-cyan, #4ec9d4);outline:none}@media (max-width: 768px){.controls-panel{width:220px}.state-panel{width:280px}.metadata-panel{width:180px}.overview-map{width:280px}}
