:root{color:#0f172a;background:#f1f5f9;font-family:Segoe UI,system-ui,sans-serif;font-size:13px}*{box-sizing:border-box}body{margin:0}.shell{gap:10px;padding:12px;display:grid}h1,h2,p{margin:0}h1{letter-spacing:-.01em;font-size:17px;font-weight:700;line-height:1.2}.intro{color:#64748b;margin-top:3px;font-size:12px;line-height:1.4}header{align-items:center;gap:12px;display:flex}.header-logo{object-fit:contain;flex-shrink:0;width:48px;height:48px}.header-text{flex-direction:column;gap:2px;display:flex}.hint,.status{color:#64748b;font-size:12px;line-height:1.4}.card{background:#fff;border:1px solid #e2e8f0;border-radius:10px;padding:14px;box-shadow:0 1px 3px #0f172a0f}.card-header{letter-spacing:.06em;text-transform:uppercase;color:#94a3b8;border-bottom:1px solid #f1f5f9;margin-bottom:12px;padding-bottom:10px;font-size:11px;font-weight:700}label{gap:5px;margin-top:12px;display:grid}label>span{color:#475569;letter-spacing:.02em;font-size:11px;font-weight:600}input,select{color:#0f172a;width:100%;font:inherit;background:#f8fafc;border:1px solid #cbd5e1;border-radius:6px;padding:7px 10px;transition:border-color .15s,box-shadow .15s}input:focus,select:focus{border-color:#2563eb;outline:none;box-shadow:0 0 0 3px #2563eb1f}button{color:#fff;cursor:pointer;font:inherit;background:#2563eb;border:0;border-radius:6px;padding:8px 14px;font-size:12px;font-weight:600;transition:background .15s}button:hover:not(:disabled){background:#1d4ed8}button.secondary{background:#475569}button.secondary:hover:not(:disabled){background:#334155}button:disabled{color:#94a3b8;cursor:not-allowed;background:#cbd5e1}.grid{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.actions{flex-wrap:wrap;gap:8px;margin-top:14px;display:flex}.lookback-presets{gap:5px;margin-top:8px;display:flex}.smoothing-row{align-items:flex-end;gap:8px;margin-top:10px;display:flex}.smoothing-method-label{flex:2}.smoothing-window-label{flex:1}.preset-chip{color:#475569;cursor:pointer;font:inherit;letter-spacing:.02em;text-align:center;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:5px;flex:1;padding:5px 0;font-size:11px;font-weight:600;transition:background .12s,border-color .12s,color .12s}.preset-chip:hover:not(:disabled){color:#1e293b;background:#e2e8f0;border-color:#cbd5e1}.preset-chip.is-active{color:#2563eb;background:#eff6ff;border-color:#2563eb}.hint-inline{color:#94a3b8;letter-spacing:0;font-size:10px;font-weight:400}.dataset-version{color:#64748b;letter-spacing:.04em;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;align-items:center;margin-top:6px;padding:2px 7px;font-size:10px;font-weight:600;display:inline-flex}.description{color:#475569;white-space:pre-wrap;background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;margin-top:10px;padding:10px;font-size:12px;line-height:1.5}.dataset-links{flex-wrap:wrap;gap:6px;margin-top:10px;display:flex}.link-button-outline{color:#2563eb;cursor:pointer;font:inherit;background:0 0;border:1px solid #2563eb;border-radius:5px;padding:4px 9px;font-size:11px;font-weight:600;text-decoration:none;transition:background .15s}.link-button-outline:hover{background:#eff6ff}.selector-panel{gap:14px;margin-top:4px;display:grid}.sel-section{border:1px solid #e2e8f0;border-radius:7px;overflow:hidden}.sel-heading{color:#64748b;letter-spacing:.06em;text-transform:uppercase;background:#f8fafc;border-bottom:1px solid #e2e8f0;margin:0;padding:6px 10px;font-size:10px;font-weight:700}.sel-list{max-height:200px;padding:4px 0;overflow-y:auto}.sel-item{align-items:center;display:flex}.sel-item.is-disabled{opacity:.45;cursor:not-allowed}.sel-label{color:#334155;cursor:pointer;align-items:center;gap:8px;width:100%;margin:0;padding:5px 10px;font-size:12px;font-weight:400;transition:background .1s;display:flex}.sel-label:hover{background:#f1f5f9}.sel-item.is-disabled .sel-label{cursor:not-allowed}.sel-check{accent-color:#2563eb;cursor:pointer;flex-shrink:0;width:14px;height:14px;margin:0}.sel-item.is-disabled .sel-check{cursor:not-allowed}.sel-group{border-bottom:1px solid #f1f5f9}.sel-group:last-child{border-bottom:0}.sel-group-header{gap:2px}.sel-group-header .sel-check{margin-left:2px}.sel-group-header .sel-label{color:#1e293b;cursor:pointer;flex:1;font-weight:600}.sel-caret{color:#94a3b8;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0;padding:6px 4px 6px 8px;font-size:9px;line-height:1;transition:transform .12s}.sel-caret:before{content:"▶"}.sel-caret.is-expanded{transform:rotate(90deg)}.sel-caret:hover{color:#475569}.sel-sublist .sel-label{color:#475569;padding-left:30px;font-weight:400}.sel-empty,.sel-loading{color:#94a3b8;padding:8px 10px;font-size:11px;font-style:italic;display:block}.selected-header{border-bottom:1px solid #f1f5f9;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;padding-bottom:10px;display:flex}.series-limit-warning{color:#92400e;background:#fffbeb;border:1px solid #fde68a;border-radius:6px;margin-top:8px;padding:8px 10px;font-size:12px;line-height:1.4}.selected-count{color:#1d4ed8;background:#eff6ff;border-radius:10px;margin-left:6px;padding:2px 7px;font-size:10px;font-weight:700}.selected-list{gap:6px;display:grid}.selected-list:empty{display:none}.selected-row{background:#f8fafc;border:1px solid #e2e8f0;border-radius:6px;grid-template-columns:1fr auto;align-items:center;gap:4px 10px;padding:8px 10px;display:grid}.selected-cells{flex-wrap:wrap;gap:4px 10px;display:flex}.selected-cell{flex-direction:column;gap:1px;display:inline-flex}.selected-cell-label{color:#94a3b8;letter-spacing:.06em;text-transform:uppercase;font-size:9px;font-weight:700}.selected-cell-value{color:#0f172a;font-size:12px;font-weight:500}.selected-remove{color:#94a3b8;cursor:pointer;background:0 0;border:0;border-radius:4px;padding:4px 6px;font-size:16px;line-height:1}.selected-remove:hover{color:#b91c1c;background:#fee2e2}.connection-summary{background:#f0fdf4;border:1px solid #bbf7d0;border-radius:8px;align-items:center;gap:10px;padding:8px 12px;display:flex}.connected-label{color:#15803d;font-size:12px;font-weight:600}.connected-label:before{content:"● ";color:#16a34a}.link-button{color:#2563eb;cursor:pointer;font:inherit;background:0 0;border:0;padding:0;font-size:12px;text-decoration:underline}.link-button:hover:not(:disabled){color:#1d4ed8;background:0 0}.link-button:disabled{color:#cbd5e1;background:0 0}#log{color:#94a3b8;white-space:pre-wrap;background:#0f172a;border-radius:6px;min-height:52px;max-height:200px;margin:0;padding:10px 12px;font-family:ui-monospace,SFMono-Regular,Menlo,Consolas,monospace;font-size:11px;line-height:1.6;overflow:auto}.info-icon{color:#94a3b8;cursor:default;vertical-align:middle;font-size:10px;display:inline-block;position:relative}.info-icon:after{content:attr(aria-label);color:#f1f5f9;white-space:normal;pointer-events:none;opacity:0;z-index:10;background:#1e293b;border-radius:5px;width:210px;padding:6px 8px;font-size:11px;font-weight:400;line-height:1.4;transition:opacity .15s;position:absolute;top:50%;left:calc(100% + 6px);transform:translateY(-50%)}.info-icon:hover:after{opacity:1}
