:root{--bg:#1a1a2e;--surface:#16213e;--border:#0f3460;--text:#e0e0e0;--text-dim:#888;--accent:#0ea5e9}*{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;overflow-x:hidden}.app{flex-direction:column;flex:1;min-height:0;display:flex}.app-header{background:var(--surface);border-bottom:1px solid var(--border);align-items:center;gap:1rem;padding:.5rem 1rem;display:flex}.app-header h1{white-space:nowrap;font-size:1rem;font-weight:600}.error-banner{color:#fca5a5;background:#7f1d1d;padding:.5rem 1rem;font-size:.85rem}.loading{text-align:center;color:var(--text-dim);padding:2rem}.app-body{flex:1;display:flex;overflow:hidden}.main-panel{flex:1;padding:.5rem;overflow-y:auto}.side-panel{border-left:1px solid var(--border);background:var(--surface);width:260px;min-width:200px;padding:.5rem;overflow-y:auto}.cameras-row{gap:.5rem;height:100%;display:flex}.cameras-row .camera-viewer{flex:1;min-width:0}.camera-viewer img{object-fit:contain;background:#000;border-radius:4px;width:100%;height:100%;display:block}.camera-viewer .camera-label{color:var(--text-dim);margin-bottom:2px;font-size:.75rem}.resize-sash{cursor:ns-resize;background:var(--border);border-radius:3px;height:6px;margin:2px 0 4px;transition:background .15s}.resize-sash:hover{background:var(--accent)}.signal-section{margin-bottom:.5rem}.signal-section-header{color:var(--text-dim);text-transform:uppercase;letter-spacing:.05em;cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:4px;margin:0 0 2px;font-size:.75rem;display:flex}.signal-section-header:hover{color:var(--text)}.collapse-arrow{font-size:.55rem;transition:transform .15s;display:inline-block;transform:rotate(0)}.collapse-arrow.open{transform:rotate(90deg)}.signal-plot-container{background:var(--surface);border:1px solid var(--border);border-radius:4px;overflow:hidden}.transport-bar{background:var(--surface);border-top:1px solid var(--border);align-items:center;gap:.5rem;padding:.4rem 1rem;display:flex}.transport-bar button{border:1px solid var(--border);color:var(--text);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .5rem;font-size:.85rem}.transport-bar button:hover{background:var(--border)}.transport-bar .time-display{text-align:center;min-width:180px;font-family:Menlo,Consolas,monospace;font-size:.85rem}.transport-bar .scrubber{accent-color:var(--accent);flex:1}.transport-bar .speed-control{color:var(--text-dim);align-items:center;gap:.25rem;font-size:.8rem;display:flex}.transport-bar .speed-control select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;padding:.15rem;font-size:.8rem}.offset-panel h3{margin-bottom:.5rem;font-size:.8rem}.offset-panel table{border-collapse:collapse;width:100%;font-size:.8rem}.offset-panel td,.offset-panel th{text-align:left;border-bottom:1px solid var(--border);padding:.2rem .4rem}.offset-panel .offset-value{text-align:right;font-family:Menlo,Consolas,monospace}.session-selector select{background:var(--bg);color:var(--text);border:1px solid var(--border);border-radius:4px;min-width:200px;padding:.3rem .5rem;font-size:.85rem}.uplot .u-wrap{background:0 0!important}.uplot .u-legend{font-size:.7rem!important}.uplot .u-legend .u-label{color:var(--text-dim)!important}.page-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.page-header{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:1rem;padding:.4rem 1rem;display:flex}.page-header h2{margin:0 auto 0 0;font-size:.95rem;font-weight:600}.page-header-auth{align-items:center;gap:.5rem;margin-left:auto;display:flex}.page-header-user{color:var(--text-dim);font-size:.8rem}.page-header-btn{border:1px solid var(--border);color:var(--accent);cursor:pointer;background:0 0;border-radius:4px;padding:.25rem .6rem;font-size:.8rem;text-decoration:none}.page-header-btn:hover{background:var(--border)}.page-back{color:var(--accent);white-space:nowrap;font-size:.8rem;text-decoration:none}.page-back:hover{text-decoration:underline}.page-intro{background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0;padding:.4rem 1rem}.page-intro summary{color:var(--text-dim);cursor:pointer;-webkit-user-select:none;user-select:none;font-size:.75rem}.page-intro-body{color:var(--text-dim);padding:.3rem 0;font-size:.8rem;line-height:1.5}.page-intro-body p{margin-bottom:.3rem}.page-content{flex-direction:column;flex:1;min-height:0;display:flex;overflow:auto}.landing{color:#1a1a1a;background:#fff;max-width:780px;min-height:100vh;margin:0 auto;padding:2.5rem 2.5rem 1.5rem}.landing-toprow{justify-content:space-between;align-items:flex-start;gap:1rem;margin-bottom:2.5rem;display:flex}.landing-toprow .cover-logo{margin-bottom:0}.landing-userbar{justify-content:flex-end;align-items:center;gap:.5rem;margin-top:.1rem;display:flex}.landing-userbar-email{color:#666;font-size:.8rem}.landing-userbar-btn{color:#1a73e8;cursor:pointer;background:0 0;border:1px solid #dde1e6;border-radius:4px;padding:.2rem .55rem;font-size:.78rem;text-decoration:none}.landing-userbar-btn:hover{background:#f7f8fa}.cover-logo{width:min(320px,60%);height:auto;margin-bottom:2.5rem;display:block}.landing-intro{color:#333;margin-bottom:1.5rem;line-height:1.6}.landing-intro h1{color:#1a1a1a;margin-bottom:.6rem;font-family:Georgia,Times New Roman,serif;font-size:1.7rem;font-weight:700;line-height:1.3}.landing-intro h1+p{color:#333;margin-bottom:1.5rem;font-size:1rem}.landing-intro p{color:#555;font-size:.88rem}.cover-meta{text-align:right;color:#333;margin-top:2rem;font-size:.82rem;line-height:1.5}.cover-degree{color:#1a73e8;margin-bottom:.6rem;font-weight:500}.cover-role{color:#555;margin-top:.2rem;margin-bottom:.05rem}.cover-name{margin-bottom:.3rem}.landing-cards{grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:.9rem;margin-bottom:2rem;display:grid}.landing-card{color:#1a1a1a;background:#f7f8fa;border:1px solid #dde1e6;border-radius:8px;padding:1.1rem;text-decoration:none;transition:border-color .15s,box-shadow .15s,transform .1s;display:block}.landing-card:hover{border-color:#1a73e8;transform:translateY(-2px);box-shadow:0 2px 8px #1a73e81f}.landing-card.disabled{opacity:.4;pointer-events:none}.landing-card .card-icon{margin-bottom:.4rem;font-size:1.5rem}.landing-card h3{color:#1a1a1a;margin-bottom:.25rem;font-size:.9rem;font-weight:600}.landing-card p{color:#666;margin:0;font-size:.76rem;line-height:1.4}.card-badge{color:#777;background:#e0e0e0;border-radius:3px;margin-top:.4rem;padding:.12rem .35rem;font-size:.62rem;display:inline-block}.cover-footer{text-align:center;color:#888;padding:1rem 0 .5rem;font-size:.82rem}.inspector-loading,.inspector-error,.inspector-empty{color:var(--text-dim);padding:2rem;font-size:.9rem}.inspector-error{color:#ef4444}.so-page{flex-direction:column;flex:1;min-height:0;padding:0 .5rem;display:flex}.so-toolbar{flex-wrap:wrap;align-items:center;gap:1rem;padding:.4rem 0;display:flex}.so-tabs{flex-wrap:wrap;gap:.25rem;display:flex}.so-tab{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:4px;padding:.25rem .6rem;font-size:.75rem}.so-tab.active{background:var(--accent);border-color:var(--accent);color:#fff}.so-tab:hover:not(.active){background:var(--border)}.so-toggle{color:var(--text-dim);white-space:nowrap;align-items:center;gap:.3rem;font-size:.78rem;display:flex}.so-info{color:var(--text-dim);flex-wrap:wrap;gap:1rem;padding:.2rem 0;font-size:.72rem;display:flex}.so-offset{background:var(--surface);border-radius:3px;padding:.1rem .4rem}.so-content{flex:1;min-height:0;overflow-y:auto}.so-burst{padding:.3rem 0}.so-burst-header{color:var(--text);padding:.2rem 0;font-size:.78rem}.so-burst-legend{color:var(--text-dim);gap:1rem;padding:.15rem 0 .3rem;font-size:.7rem;display:flex}.so-plot{margin-bottom:2px}.es-page{flex-direction:column;flex:1;min-height:0;padding:0 .5rem;display:flex}.es-toolbar{flex-wrap:wrap;gap:.25rem;padding:.4rem 0;display:flex}.es-content{flex:1;min-height:0;overflow-y:auto}.es-burst{padding:.3rem 0}.es-burst-header{color:var(--text);padding:.2rem 0;font-size:.78rem}.es-burst-legend{color:var(--text-dim);gap:1rem;padding:.15rem 0 .3rem;font-size:.7rem;display:flex}.es-panels{grid-template-columns:1fr 1fr 1fr;gap:.5rem;display:grid}.es-panel-title{color:var(--text-dim);padding:.15rem 0;font-size:.72rem;font-weight:600}.es-plot{margin-bottom:2px}.cs-page{flex-direction:column;flex:1;min-height:0;padding:0 .5rem;display:flex}.cs-cam-tabs{gap:.25rem;padding:.4rem 0;display:flex}.cs-cam-info{color:var(--text-dim);padding:.2rem 0;font-size:.72rem}.cs-burst-tabs{gap:.25rem;padding:.2rem 0;display:flex}.cs-content{flex:1;min-height:0;overflow-y:auto}.cs-burst{padding:.3rem 0}.cs-burst-header{color:var(--text);padding:.2rem 0;font-size:.78rem}.cs-burst-legend{color:var(--text-dim);gap:1rem;padding:.15rem 0 .3rem;font-size:.7rem;display:flex}.cs-images{gap:.5rem;padding:.3rem 0;display:flex}.cs-img-panel{flex:1;min-width:0}.cs-img-label{color:var(--text-dim);padding:.15rem 0;font-size:.72rem;font-weight:600}.cs-img{border:1px solid var(--border);border-radius:4px;width:100%;height:auto}.cs-plot{margin-bottom:2px}.auth-container{max-width:420px;margin:0 auto 2rem;padding:1.5rem 0}.landing .auth-tabs{border-bottom-color:#dde1e6}.landing .auth-tab{color:#666}.landing .auth-tab.active{color:#1a73e8;border-bottom-color:#1a73e8}.landing .auth-tab:hover{color:#1a1a1a}.landing .auth-form label{color:#555}.landing .auth-form input{color:#1a1a1a;background:#f7f8fa;border-color:#dde1e6}.landing .auth-form input:focus{border-color:#1a73e8}.landing .auth-submit{background:#1a73e8}.landing .auth-error{color:#b91c1c;background:#fef2f2;border-color:#f87171}.landing .auth-success{color:#166534;background:#f0fdf4;border-color:#4ade80}.auth-tabs{border-bottom:1px solid var(--border);gap:0;margin-bottom:1.5rem;display:flex}.auth-tab{color:var(--text-dim);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;flex:1;padding:.6rem .5rem;font-size:.85rem;transition:color .15s,border-color .15s}.auth-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.auth-tab:hover{color:var(--text)}.auth-form{flex-direction:column;gap:1rem;display:flex}.auth-form label{color:var(--text-dim);flex-direction:column;gap:.3rem;font-size:.85rem;display:flex}.auth-form input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:4px;padding:.5rem .6rem;font-size:.9rem}.auth-form input:focus{border-color:var(--accent);outline:none}.auth-submit{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:4px;margin-top:.5rem;padding:.6rem;font-size:.9rem;font-weight:500}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-submit:hover:not(:disabled){opacity:.9}.auth-error{color:#fca5a5;background:#4a1c1c;border:1px solid #ef4444;border-radius:4px;margin-bottom:1rem;padding:.5rem .75rem;font-size:.85rem}.auth-success{color:#86efac;background:#1c4a2e;border:1px solid #22c55e;border-radius:4px;margin-bottom:1rem;padding:.5rem .75rem;font-size:.85rem}.auth-link{color:var(--accent);font-size:.85rem}.admin-container{max-width:800px;margin:0 auto}.admin-add-form{background:var(--surface);border:1px solid var(--border);border-radius:6px;margin-bottom:2rem;padding:1rem}.admin-add-form h3{margin-bottom:.75rem;font-size:.95rem}.admin-add-row{align-items:center;gap:.5rem;display:flex}.admin-add-row input{background:var(--bg);border:1px solid var(--border);color:var(--text);border-radius:4px;flex:1;padding:.45rem .6rem;font-size:.85rem}.admin-add-row button{background:var(--accent);color:#fff;cursor:pointer;border:none;border-radius:4px;padding:.45rem 1rem;font-size:.85rem}.admin-hint{color:var(--text-dim);margin-top:.5rem;font-size:.75rem}.admin-table{border-collapse:collapse;width:100%;font-size:.85rem}.admin-table th,.admin-table td{text-align:left;border-bottom:1px solid var(--border);padding:.5rem .75rem}.admin-table th{color:var(--text-dim);font-weight:500}.admin-actions{flex-wrap:wrap;align-items:center;gap:.4rem;display:flex}.btn-small{background:var(--surface);border:1px solid var(--border);color:var(--text);cursor:pointer;border-radius:3px;padding:.25rem .5rem;font-size:.75rem}.btn-small:hover{background:var(--border)}.btn-activate{color:#22c55e;border-color:#22c55e}.btn-danger{color:#ef4444;border-color:#ef4444}.btn-cancel{color:var(--text-dim)}.pw-edit-inline{align-items:center;gap:.3rem;display:flex}.pw-edit-inline input{background:var(--bg);border:1px solid var(--border);width:120px;color:var(--text);border-radius:3px;padding:.2rem .4rem;font-size:.75rem}.status-badge{border-radius:3px;padding:.15rem .4rem;font-size:.75rem;font-weight:500}.status-active{color:#86efac;background:#1c4a2e}.status-pending{color:#fde68a;background:#4a3c1c}.status-pre-approved{color:#7dd3fc;background:#1c3a4a}
