:root{font-family:Inter,system-ui,-apple-system,Segoe UI,sans-serif;line-height:1.5;font-weight:400;color:#0f172a;background-color:#f5f7fb;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:#f5f7fb;color:#0f172a}:root{height:100%;font-family:Sora,Inter,SF Pro Display,-apple-system,system-ui,sans-serif;background:#0b1220;color:#0f172a}*,*:before,*:after{box-sizing:border-box}body{margin:0;height:100%;background:radial-gradient(circle at 30% 20%,rgba(59,130,246,.12),transparent 28%),radial-gradient(circle at 70% 0%,rgba(45,212,191,.16),transparent 32%),linear-gradient(180deg,#0b1220,#0f172a 60%,#0b1220);color:#0f172a;overflow:hidden}#root,.no-select,.no-select *{-webkit-user-select:none;user-select:none}#root{height:100%}.workspace-shell{position:relative;width:100%;height:100vh;overflow:hidden}.workspace-shell:before{content:"";position:absolute;inset:-18% 0 auto;height:52%;background:radial-gradient(circle at 24% 18%,rgba(94,234,212,.14),transparent 32%),radial-gradient(circle at 78% 12%,rgba(94,234,212,.12),transparent 32%),radial-gradient(circle at 54% 38%,rgba(79,70,229,.1),transparent 40%);pointer-events:none}.workspace-canvas{position:relative;width:9000px;height:6000px;overflow:hidden;padding:28px;isolation:isolate;touch-action:none;background:linear-gradient(90deg,rgba(255,255,255,.03) 1px,transparent 1px),linear-gradient(0deg,rgba(255,255,255,.03) 1px,transparent 1px),radial-gradient(circle at 20% 20%,rgba(255,255,255,.04),transparent 32%),radial-gradient(circle at 80% 60%,rgba(59,130,246,.08),transparent 38%),transparent;background-size:32px 32px,32px 32px,100% 100%,100% 100%,cover}.hud-layer{position:fixed;inset:0;pointer-events:none;z-index:1200}.brand-mark{position:absolute;top:18px;right:20px;text-align:right;z-index:200;pointer-events:none;color:#e2e8f0;text-shadow:0 6px 18px rgba(0,0,0,.35)}.brand-title{font-size:15px;font-weight:800;letter-spacing:.08em;text-transform:uppercase}.brand-subtitle{font-size:12px;opacity:.88}.floating-hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);padding:16px 18px;border-radius:14px;background:#0f172ae0;color:#e2e8f0;box-shadow:0 18px 50px #00000059;min-width:240px;text-align:center;z-index:600}.empty-hint{position:absolute;left:50%;top:50%;transform:translate(-50%,-50%);padding:12px 16px;background:#ffffffe6;border:1px dashed #cbd5e1;border-radius:12px;color:#475569;font-size:13px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.status-chip{position:absolute;right:22px;bottom:22px;padding:10px 14px;border-radius:12px;background:#0f172a;color:#fff;box-shadow:0 12px 30px #0f172a4d;font-size:12px;z-index:500}.panel-window{position:absolute;display:flex;flex-direction:column;border-radius:16px;border:1px solid #e2e8f0;background:#ffffffeb;box-shadow:0 14px 40px #0f172a29;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);min-width:240px;min-height:200px;overflow:hidden;transition:box-shadow .18s ease,transform .18s ease;cursor:default}.panel-window:hover{box-shadow:0 18px 50px #0f172a33;transform:translateY(-1px)}.panel-window *{cursor:inherit}.panel-header{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:6px 10px;background:linear-gradient(120deg,#f8fafc,#eef2ff);border-bottom:1px solid #e2e8f0;min-height:34px;cursor:grab}.panel-header:active{cursor:grabbing}.panel-header-actions{display:inline-flex;align-items:center;gap:8px}.panel-title{font-weight:700;font-size:13px;color:#0f172a}.panel-subtitle{font-size:11px;color:#475569}.panel-body{flex:1;padding:12px;overflow-y:auto;overflow-x:hidden;background:linear-gradient(180deg,#f8fafce6,#ffffffe6)}.resize-handle{position:absolute;right:4px;bottom:4px;width:24px;height:24px;border-radius:8px;background:linear-gradient(135deg,#e2e8f0,#cbd5e1);border:1px solid #cbd5e1;pointer-events:auto;z-index:2;box-shadow:inset 0 1px #fff9;touch-action:none}.resize-handle:after{content:"";position:absolute;inset:6px;border-radius:6px;background:linear-gradient(135deg,#f8fafc,#e2e8f0);box-shadow:inset 0 1px #ffffffe6;pointer-events:none}.cluster-panel .panel-body{padding:12px 14px 32px}.cluster-actions{display:flex;align-items:center;gap:8px}.action-menu{position:relative}.action-menu__trigger{padding:6px 10px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;cursor:pointer;font-weight:600;font-size:12px;box-shadow:0 4px 10px #0f172a1f}.action-menu__list{position:absolute;top:calc(100% + 6px);right:0;min-width:180px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 14px 36px #0f172a33;padding:6px;z-index:10}.action-menu__item{width:100%;text-align:left;padding:8px 10px;border:none;background:transparent;border-radius:8px;font-size:12px;color:#0f172a;cursor:pointer}.action-menu__item:hover{background:#f1f5f9}.cluster-action-select{padding:6px 10px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;font-size:12px;color:#0f172a}.muuri-grid{display:grid;grid-template-columns:repeat(auto-fill,64px);gap:8px;position:relative;align-content:flex-start}.muuri-grid.muuri-live{display:block}.muuri-grid.muuri-live .item{position:absolute;margin:4px}.item{width:64px;height:64px}.item-content{width:100%;height:100%;border-radius:10px;overflow:hidden;background:#e2e8f0;box-shadow:0 4px 10px #0f172a1f}.color-bar{display:flex;width:180px;height:6px;border-radius:999px;overflow:hidden;margin-top:6px;box-shadow:inset 0 0 0 1px #94a3b859}.color-segment{height:100%}.thumb{width:100%;height:100%;object-fit:cover;display:block}.chart-card{margin-bottom:12px;padding:10px 12px;border-radius:12px;border:1px solid #e2e8f0;background:#fff;box-shadow:0 8px 22px #0f172a14}.chart-card-header{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:6px}.chart-card-body{display:grid;place-items:center}.muted-text{color:#64748b;font-size:12px}.pie-window-body{padding:0;overflow:hidden;display:flex;max-width:none!important}.pie-window-chart{flex:1;min-width:0;min-height:0;position:relative}.pie-window-canvas{width:100%;height:100%;display:block}.side-drawer{position:fixed;top:0;right:0;pointer-events:none;isolation:isolate;padding-right:4px}.side-drawer__track{position:relative;display:grid;justify-items:end;align-items:start;width:max-content;pointer-events:none;transition:transform .32s cubic-bezier(.22,.61,.36,1);will-change:transform}.side-drawer__panel{position:relative;pointer-events:auto}.side-drawer.closed .side-drawer__panel{pointer-events:none}.side-drawer__body{width:100%;height:100%}.side-drawer__body>.panel-window{position:relative!important;width:100%;height:100%}.side-drawer__handle{position:absolute;top:35%;left:calc(var(--drawer-handle-width) * -1);display:grid;place-items:center;padding:8px 10px;border:1px solid rgba(15,23,42,.9);background:linear-gradient(140deg,#1e293b,#0f172a);color:#e2e8f0;border-radius:14px 0 0 14px;box-shadow:0 18px 38px #02061773;cursor:pointer;pointer-events:auto;transition:transform .28s ease,box-shadow .24s ease,background .24s ease;overflow:hidden;transform:translate3d(0,-50%,0)}.side-drawer__handle:after{content:"";position:absolute;inset:2px;border-radius:12px 0 0 12px;background:linear-gradient(120deg,#ffffff14,#fff0);pointer-events:none}.side-drawer__handle.closed{transform:translate3d(-0px,-50%,0)}.side-drawer__handle:hover{box-shadow:0 22px 48px #02061794;background:linear-gradient(140deg,#0f172a,#0b1220)}.side-drawer__chevron{display:grid;place-items:center;transition:transform .26s ease;z-index:1}.side-drawer__chevron svg{width:18px;height:18px}.side-drawer__chevron.open{transform:rotate(180deg)}.photo-window .panel-body{display:flex;justify-content:center;align-items:center;padding:12px;overflow:hidden}.photo-window-body img{width:100%;height:auto;border-radius:12px;object-fit:contain}.photo-preview-shell{position:fixed;inset:0;background:#0c111c73;display:flex;align-items:center;justify-content:center;z-index:2100;pointer-events:auto}.photo-preview-panel{width:min(70vw,560px);max-width:100%;border-radius:18px;border:1px solid rgba(226,232,240,.5);background:#fffffff2;box-shadow:0 26px 60px #02061773;overflow:hidden;animation:popIn .25s ease-out forwards}.photo-preview-header{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;border-bottom:1px solid #e2e8f0;background:#f8fafc}.photo-preview-body{padding:12px}.photo-preview-body img{width:100%;height:auto;border-radius:12px}.close-button{width:28px;height:28px;border-radius:50%;border:none;background:#0f172a;color:#fff;font-size:18px;line-height:0;cursor:pointer;display:grid;place-items:center}@keyframes popIn{0%{transform:scale(.85)}to{transform:scale(1)}}.zoom-widget{position:fixed;right:18px;bottom:18px;display:inline-flex;align-items:center;gap:8px;padding:8px 10px;background:#0f172acc;color:#e2e8f0;border-radius:14px;box-shadow:0 10px 30px #00000059;z-index:800}.zoom-button{background:#fff;border:1px solid #cbd5e1;border-radius:10px;width:32px;height:32px;display:grid;place-items:center;cursor:pointer;font-weight:700;color:#0f172a;box-shadow:0 6px 16px #0f172a40}.zoom-indicator{font-family:DM Mono,SFMono-Regular,ui-monospace,monospace;font-size:12px}.control-panel{background:#fffffff0;border-color:#dce4f1}.chip{font-size:11px;padding:4px 10px;border-radius:999px;background:#e0f2fe;color:#075985;border:1px solid #bae6fd}.chip.muted{background:#e2e8f0;color:#475569;border-color:#cbd5e1}.pin-button{font-size:11px;font-weight:600;padding:4px 10px;border-radius:10px;border:1px solid #cbd5e1;background:#fff;color:#0f172a;cursor:pointer;transition:background .15s ease,color .15s ease,border-color .15s ease}.pin-button.active,.pin-button:hover{border-color:#0f172a;background:#0f172a;color:#fff}.pill-row{display:flex;flex-wrap:wrap;gap:8px}.toggle-row{display:flex;align-items:center;gap:8px;font-size:12px;color:#334155}.toggle-label{font-weight:600;min-width:54px}.pill-group{display:inline-flex;gap:0;border-radius:999px;border:1px solid #cbd5e1;background:#fff;box-shadow:inset 0 0 0 1px #ffffff80;overflow:hidden}.pill{border:none;background:transparent;padding:7px 12px;font-size:12px;color:#0f172a;cursor:pointer;transition:background .15s ease,color .15s ease}.pill:hover{background:#f1f5f9}.pill.active{background:#0f172a;color:#fff;box-shadow:inset 0 1px #ffffff26}.controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:10px;margin-top:10px}.slider-block{display:flex;flex-direction:column;gap:6px;font-size:12px;color:#334155}.slider-label{display:flex;justify-content:space-between;align-items:center}.slider-title{display:inline-flex;align-items:center;gap:6px}.slider-title .info{width:16px;height:16px;border-radius:50%;background:#0f172a;color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:10px;cursor:help}.slider-label .value{font-family:DM Mono,SFMono-Regular,ui-monospace,monospace;font-size:11px;color:#0f172a}.slider{width:100%;accent-color:#0f172a}.run-button{width:100%;margin-top:12px;padding:10px 14px;border-radius:12px;border:1px solid #0f172a;background:#0f172a;color:#fff;font-weight:700;cursor:pointer;box-shadow:0 10px 30px #0f172a40;transition:box-shadow .18s ease,transform .18s ease}.run-button:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 16px 36px #0f172a47}.run-button:disabled,.run-button.waiting{opacity:.7;cursor:wait;box-shadow:none;background:#1e293b}.run-button.waiting{border-color:#cbd5e1}.button-row{display:flex;gap:8px;margin-top:8px}.ghost-button{flex:1;padding:8px 10px;border-radius:10px;border:1px solid #cbd5e1;background:#fffc;color:#0f172a;font-weight:600;cursor:pointer;box-shadow:0 6px 14px #0f172a1f}.ghost-button.small{flex:0 0 auto;padding:6px 10px;font-size:11px;box-shadow:none}.ghost-button:hover{background:#f8fafc}
