:root{--font-ui:"Barlow", system-ui, -apple-system, sans-serif;--font-mono:"JetBrains Mono", ui-monospace, monospace;--r-sm:4px;--r-md:6px;--r-lg:10px;--r-xl:14px;--r-pill:999px;--t-fast:.12s cubic-bezier(.2,.8,.2,1);--t-med:.22s cubic-bezier(.2,.8,.2,1);--ok:oklch(62% .15 150);--ok-bg:oklch(62% .15 150/.12);--warn:oklch(74% .15 75);--warn-bg:oklch(74% .15 75/.15);--bad:oklch(60% .21 25);--bad-bg:oklch(60% .21 25/.12)}[data-theme=studio-light]{--bg:#f7f7f5;--surface:#fff;--surface-2:#fbfbf9;--surface-3:#f0f0ec;--border:#e6e5e0;--border-strong:#d4d2cb;--text:#17171a;--text-2:#17171a;--text-3:#17171a;--accent:oklch(52% .18 260);--accent-hover:oklch(46% .19 260);--accent-soft:oklch(52% .18 260/.1);--accent-contrast:#fff;--shadow-sm:0 1px 2px #1414140a, 0 0 0 1px #1414140a;--shadow-md:0 4px 14px #1414140f, 0 0 0 1px #1414140a;--shadow-lg:0 12px 32px #1414141f;--warn-text:oklch(48% .14 75)}[data-theme=studio-dark]{--bg:#0e0e10;--surface:#17171a;--surface-2:#1c1c20;--surface-3:#24242a;--border:#26262c;--border-strong:#34343c;--text:#f3f3f0;--text-2:#f3f3f0;--text-3:#f3f3f0;--accent:oklch(68% .16 260);--accent-hover:oklch(74% .16 260);--accent-soft:oklch(68% .16 260/.16);--accent-contrast:#0e0e10;--shadow-sm:0 1px 2px #0006;--shadow-md:0 4px 14px #0006;--shadow-lg:0 12px 32px #0009;--warn-text:oklch(85% .13 75)}*,:before,:after{box-sizing:border-box;margin:0;padding:0}html,body{font-family:var(--font-ui);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizelegibility;height:100%;font-size:14px;line-height:1.5}button{font:inherit;color:inherit;cursor:pointer;background:0 0;border:none}:focus-visible{outline:2px solid var(--accent);outline-offset:2px;border-radius:var(--r-sm)}:focus:not(:focus-visible){outline:none}input,select,textarea{font:inherit;color:inherit}ul{list-style:none}svg{display:block}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}.sr-only{clip:rect(0,0,0,0);width:1px;height:1px;position:absolute;overflow:hidden}[data-icon]{stroke-width:2px;flex-shrink:0;width:16px;height:16px}[data-icon=sm]{width:14px;height:14px}[data-icon=lg]{width:20px;height:20px}#app-splash{z-index:500;background:var(--bg);padding-bottom:env(safe-area-inset-bottom);flex-direction:column;justify-content:center;align-items:center;gap:20px;display:flex;position:fixed;inset:0}#app-splash.hidden{display:none}.splash-icon{color:#fff;background:#ef4444;border-radius:24px;place-items:center;width:80px;height:80px;animation:1.8s ease-in-out infinite splash-pulse;display:grid}.splash-name{letter-spacing:-.04em;font-size:22px;font-weight:800}.splash-name span{color:#ef4444}@keyframes splash-pulse{0%,to{box-shadow:0 0 #ef444466}50%{box-shadow:0 0 0 16px #ef444400}}#auth-wall{background:radial-gradient(ellipse at top, var(--accent-soft), transparent 60%), var(--bg);place-items:center;min-height:100vh;padding:24px;display:grid}.auth-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);width:100%;max-width:380px;box-shadow:var(--shadow-lg);padding:28px}.auth-logo{border-radius:var(--r-md);background:var(--accent);width:44px;height:44px;color:var(--accent-contrast);place-items:center;margin-bottom:14px;display:grid}.auth-card h1{letter-spacing:-.02em;margin-bottom:6px;font-size:20px;font-weight:700}.auth-card p{color:var(--text-3);margin-bottom:20px;font-size:13px}.m-auth-hero{display:none}.m-auth-bottom{box-shadow:none;background:0 0;border-radius:0;padding:0}.google-btn{justify-content:center;gap:10px;width:100%;padding:10px;font-weight:500}.auth-feats{border-top:1px solid var(--border);flex-direction:column;gap:8px;margin-top:20px;padding-top:16px;display:flex}.auth-feat{color:var(--text-2);align-items:center;gap:10px;font-size:12px;display:flex}.auth-feat svg{color:var(--accent)}#app-shell{flex-direction:column;height:100vh;display:flex;overflow:hidden}.hidden{display:none!important}.topbar{z-index:50;background:color-mix(in oklab, var(--surface), transparent 8%);-webkit-backdrop-filter:saturate(180%)blur(12px);border-bottom:1px solid var(--border);flex-shrink:0;align-items:center;gap:12px;padding:8px 16px;display:flex;position:sticky;top:0}.brand{letter-spacing:-.01em;white-space:nowrap;align-items:center;gap:10px;font-size:15px;font-weight:600;display:flex}.brand-mark{background:var(--accent);width:26px;height:26px;color:var(--accent-contrast);border-radius:7px;flex-shrink:0;place-items:center;display:grid}.brand-mark svg{width:15px;height:15px}.brand-name{align-items:baseline;gap:6px;display:flex}.brand-name .ver{font-family:var(--font-mono);color:var(--text-3);font-size:10px;font-weight:400}.tabs{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);gap:2px;padding:3px;display:flex}.tab{color:var(--text-2);border-radius:var(--r-sm);transition:background var(--t-fast), color var(--t-fast);white-space:nowrap;align-items:center;gap:6px;padding:5px 11px;font-size:13px;font-weight:500;display:inline-flex;position:relative}.tab:hover{color:var(--text)}.tab.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.tab[data-badge]:after{content:attr(data-badge);border-radius:var(--r-pill);background:var(--bad);min-width:16px;height:16px;color:var(--accent-contrast);font-family:var(--font-mono);justify-content:center;align-items:center;margin-left:2px;padding:0 5px;font-size:10px;font-weight:600;display:inline-flex}.topbar-spacer{flex:1}.icon-btn{border-radius:var(--r-md);width:36px;height:36px;color:var(--text-2);transition:background var(--t-fast), color var(--t-fast);flex-shrink:0;place-items:center;display:grid}.icon-btn:hover{background:var(--surface-2);color:var(--text)}@media (pointer:coarse),(any-pointer:coarse){.icon-btn{min-width:44px;min-height:44px}.tab{min-height:44px;padding:8px 14px}}.page{flex:1;grid-template-columns:228px 1fr;min-height:0;display:grid;overflow:hidden}.sidebar{border-right:1px solid var(--border);background:var(--bg);flex-direction:column;gap:16px;padding:12px 8px;display:flex;overflow-y:auto}.sb-search-box{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);transition:border var(--t-fast);flex-shrink:0;align-items:center;gap:8px;padding:6px 8px;display:flex}.sb-search-box:focus-within{border-color:var(--border-strong)}.sb-search-input{font:inherit;color:var(--text);background:0 0;border:none;outline:none;flex:1;min-width:0;font-size:13px}.sb-search-input::placeholder{color:var(--text-3)}mark{background:color-mix(in oklab, var(--accent), transparent 72%);color:inherit;border-radius:2px;padding:0 1px}.sb-section{flex-direction:column;gap:1px;display:flex}.sb-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);justify-content:space-between;align-items:center;padding:4px 10px 6px;font-size:11px;font-weight:600;display:flex}.sb-label button{color:var(--text-3);border-radius:var(--r-sm);transition:background var(--t-fast), color var(--t-fast);place-items:center;padding:2px;display:grid}.sb-label button:hover{color:var(--text);background:var(--surface-2)}.sb-item{border-radius:var(--r-md);color:var(--text-2);transition:background var(--t-fast), color var(--t-fast);cursor:pointer;text-align:left;align-items:center;gap:8px;width:100%;padding:6px 10px;font-size:13px;display:flex}.sb-item:hover{background:var(--surface-2);color:var(--text)}.sb-item.active{background:var(--accent-soft);color:var(--accent);font-weight:500}.sb-item .sb-count{font-family:var(--font-mono);color:var(--text-3);margin-left:auto;font-size:11px}.sb-item.active .sb-count{color:var(--accent)}.sb-item .sb-dot{border-radius:2px;flex-shrink:0;width:8px;height:8px}.sb-folder-children{flex-direction:column;gap:1px;margin-top:1px;padding-left:12px;display:flex}.sb-folder-children .sb-item{font-size:12px}.sb-quick{border-top:1px solid var(--border);flex-direction:column;gap:1px;padding-top:12px;display:flex}.sb-account{border-top:1px solid var(--border);flex-direction:column;gap:4px;margin-top:auto;padding:10px 8px;display:flex}.sb-account-row{align-items:center;gap:8px;padding:6px;display:flex}.sb-account-avatar{background:var(--accent);width:28px;height:28px;color:var(--accent-contrast);border-radius:50%;flex-shrink:0;place-items:center;font-size:11px;font-weight:600;display:grid;overflow:hidden}.sb-account-avatar img{object-fit:cover;border-radius:50%;width:100%;height:100%}.sb-account-avatar .avatar-fallback{color:#fff;background:#ef4444;border-radius:50%;place-items:center;width:100%;height:100%;display:grid}.sb-account-avatar .avatar-fallback svg{width:14px;height:14px}.sb-account-info{flex:1;min-width:0}.sb-account-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:12px;font-weight:600;overflow:hidden}.sb-account-email{color:var(--text-3);text-overflow:ellipsis;white-space:nowrap;font-size:11px;overflow:hidden}.main{padding:20px 24px 80px;overflow-y:auto}.main-inner{max-width:1200px;margin:0 auto}.view{display:none}.view.active{animation:.2s cubic-bezier(.25,1,.5,1) both view-in;display:block}@keyframes view-in{0%{opacity:0}}.page-head{justify-content:space-between;align-items:flex-end;gap:20px;margin-bottom:24px;display:flex}.page-head h1{letter-spacing:-.02em;margin-bottom:3px;font-size:22px;font-weight:700}.page-head .sub{color:var(--text-3);font-size:13px}.page-head-actions{flex-shrink:0;gap:8px;display:flex}.btn{border-radius:var(--r-md);background:var(--surface);border:1px solid var(--border);color:var(--text);transition:background var(--t-fast), border var(--t-fast), transform var(--t-fast);box-shadow:var(--shadow-sm);white-space:nowrap;align-items:center;gap:6px;padding:7px 12px;font-size:13px;font-weight:500;display:inline-flex}.btn:hover{background:var(--surface-2);border-color:var(--border-strong)}.btn:active{transform:translateY(1px)}.btn-primary{background:var(--accent);color:var(--accent-contrast);border-color:color-mix(in oklab, var(--accent), #000 15%)}.btn-primary:hover{background:var(--accent-hover);border-color:var(--accent-hover)}.btn-ghost{box-shadow:none;color:var(--text-2);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--surface-2);color:var(--text);border-color:#0000}.btn-danger{background:var(--bad-bg);color:var(--bad);box-shadow:none;border-color:#0000}.btn-danger:hover{background:color-mix(in oklab, var(--bad), transparent 75%)}.btn-sm{gap:5px;padding:5px 9px;font-size:12px}.hero{margin-bottom:28px;display:block}.upnext{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);flex-direction:column;gap:14px;min-width:0;padding:18px;display:flex}.upnext-head{justify-content:space-between;align-items:center;display:flex}.upnext-head h2{color:var(--text-2);text-transform:uppercase;letter-spacing:.06em;align-items:center;gap:8px;font-size:13px;font-weight:600;display:flex}.upnext-head .pill{font-family:var(--font-mono);border-radius:var(--r-pill);background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);padding:2px 8px;font-size:11px;font-weight:500}.upnext-list{flex-direction:column;display:flex}.task-row{border-bottom:1px solid var(--border);cursor:pointer;transition:background var(--t-fast);border-radius:var(--r-sm);grid-template-columns:10px 1fr auto auto;align-items:center;gap:12px;padding:10px 6px;display:grid}.task-row:last-child{border-bottom:none}.task-row:hover{background:var(--surface-2)}.task-status{background:var(--ok);width:10px;height:10px;box-shadow:0 0 0 3px var(--ok-bg);border-radius:50%;flex-shrink:0}.task-status.warn{background:var(--warn);box-shadow:0 0 0 3px var(--warn-bg)}.task-status.bad{background:var(--bad);box-shadow:0 0 0 3px var(--bad-bg)}.task-main{min-width:0}.task-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin-bottom:1px;font-size:13px;font-weight:500;overflow:hidden}.task-unit{color:var(--text-3);align-items:center;gap:5px;font-size:11px;display:flex}.task-unit .swatch{border-radius:2px;flex-shrink:0;width:6px;height:6px}.task-progress{flex-direction:column;gap:4px;min-width:120px;display:flex}.progress-track{background:var(--surface-3);border-radius:var(--r-pill);height:4px;position:relative;overflow:hidden}.progress-fill{background:var(--ok);border-radius:inherit;transition:width var(--t-med);max-width:100%;position:absolute;inset:0 auto 0 0}.progress-fill.warn{background:var(--warn)}.progress-fill.bad{background:var(--bad)}.progress-label{font-family:var(--font-mono);color:var(--text-3);font-variant-numeric:tabular-nums;justify-content:space-between;font-size:10px;display:flex}.progress-label b{color:var(--text-2);font-weight:500}.task-due{font-family:var(--font-mono);color:var(--text-2);border-radius:var(--r-sm);background:var(--surface-2);border:1px solid var(--border);white-space:nowrap;text-align:right;font-variant-numeric:tabular-nums;min-width:58px;padding:3px 7px;font-size:11px}.task-due.bad{color:var(--bad);background:var(--bad-bg);border-color:#0000}.task-due.warn{color:var(--warn-text);background:var(--warn-bg);border-color:#0000}.upnext-foot{color:var(--text-3);justify-content:space-between;align-items:center;padding-top:4px;font-size:12px;display:flex}.unit-picker-list{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-md);max-height:220px;position:absolute;top:calc(100% + 2px);left:0;right:0;overflow-y:auto}.unit-picker-item{cursor:pointer;color:var(--text);align-items:center;gap:8px;padding:8px 12px;font-size:13px;display:flex}.unit-picker-item:hover,.unit-picker-item.selected{background:var(--surface-2)}.unit-picker-empty{color:var(--text-3);padding:10px 12px;font-size:13px}.section-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:16px;display:flex}.section-head h2{color:var(--text);align-items:center;gap:8px;font-size:14px;font-weight:600;display:flex}.count-pill{font-family:var(--font-mono);border-radius:var(--r-pill);background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);padding:1px 7px;font-size:11px}.filter-bar{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);gap:4px;padding:3px;display:flex}.chip{color:var(--text-2);border-radius:var(--r-sm);transition:background var(--t-fast), color var(--t-fast);white-space:nowrap;align-items:center;gap:5px;padding:4px 10px;font-size:12px;display:inline-flex}.chip:hover{color:var(--text)}.chip:active{background:var(--surface-3);color:var(--text)}.chip.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.chip .dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}.chip .dot.ok{background:var(--ok)}.chip .dot.warn{background:var(--warn)}.chip .dot.bad{background:var(--bad)}.dash-mode-seg{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);flex-shrink:0;gap:2px;padding:3px;display:flex}.dash-mode-btn{color:var(--text-2);border-radius:var(--r-sm);transition:background var(--t-fast), color var(--t-fast);white-space:nowrap;padding:4px 10px;font-size:12px}.dash-mode-btn:hover{color:var(--text)}.dash-mode-btn.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.folder-head{cursor:pointer;-webkit-user-select:none;user-select:none;align-items:center;gap:10px;margin:24px 0 10px;padding:10px 0;display:flex}.folder-head .chev{color:var(--text-3);transition:transform var(--t-fast)}.folder-head.collapsed .chev{transform:rotate(-90deg)}.folder-head .swatch{border-radius:var(--r-sm);flex-shrink:0;width:14px;height:14px}.folder-head h3{color:var(--text);font-size:13px;font-weight:600}.folder-head .meta{color:var(--text-3);gap:12px;margin-left:auto;font-size:12px;display:flex}.folder-head .edit-btn{opacity:0;transition:opacity var(--t-fast);color:var(--text-3);border-radius:var(--r-sm);padding:2px 4px}.folder-head:hover .edit-btn{opacity:1}.folder-head .edit-btn:hover{color:var(--text);background:var(--surface-2)}.asset-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:16px;margin-bottom:8px;display:grid}.asset-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);transition:transform var(--t-fast), box-shadow var(--t-fast), border var(--t-fast);contain:layout style;flex-direction:column;gap:12px;padding:16px;display:flex}.asset-card:hover{box-shadow:var(--shadow-md);border-color:var(--border-strong);transform:translateY(-1px)}.ac-head{align-items:center;gap:10px;display:flex}.ac-avatar{border-radius:var(--r-md);background:color-mix(in oklab, var(--asset-color,var(--accent)), var(--surface) 72%);width:36px;height:36px;color:var(--asset-color,var(--accent));font-family:var(--font-mono);flex-shrink:0;place-items:center;font-size:13px;font-weight:600;display:grid}.ac-title{flex:1;min-width:0}.ac-title .name{color:var(--text);font-size:14px;font-weight:600;line-height:1.2}.ac-title .sub{color:var(--text-3);margin-top:2px;font-size:11px}.ac-status{border-radius:var(--r-pill);background:var(--ok-bg);color:var(--ok);white-space:nowrap;justify-self:start;align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:600;display:inline-flex}.ac-status.warn{background:var(--warn-bg);color:var(--warn-text)}.ac-status.bad{background:var(--bad-bg);color:var(--bad)}.ac-metrics{grid-template-columns:1fr 1fr;gap:8px;padding-top:4px;display:grid}.metric-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:10px;font-weight:600}.metric-value{font-family:var(--font-mono);color:var(--text);font-variant-numeric:tabular-nums;margin-top:2px;font-size:14px}.metric-value .unit{color:var(--text-3);margin-left:3px;font-size:10px}.ac-next{border-top:1px solid var(--border);align-items:center;gap:10px;padding-top:10px;display:flex}.ac-next .icon-wrap{color:var(--text-3);flex-shrink:0;place-items:center;display:grid}.ac-next.warn .icon-wrap{color:var(--warn-text)}.ac-next.bad .icon-wrap{color:var(--bad)}.ac-next-text{flex:1;min-width:0}.ac-next-text .label{color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;font-size:10px;font-weight:600}.ac-next-text .task{color:var(--text);text-overflow:ellipsis;white-space:nowrap;margin-top:1px;font-size:13px;font-weight:500;overflow:hidden}.ac-next-due{font-family:var(--font-mono);color:var(--text-2);text-align:right;white-space:nowrap;font-variant-numeric:tabular-nums;font-size:12px}.ac-next.bad .ac-next-due{color:var(--bad);font-weight:600}.ac-tasks{flex-direction:column;gap:4px;display:flex}.ac-task-mini{grid-template-columns:8px 1fr auto;align-items:center;gap:8px;padding:4px 2px;font-size:12px;display:grid}.ac-task-mini .dot{background:var(--ok);border-radius:50%;flex-shrink:0;width:6px;height:6px}.ac-task-mini .dot.warn{background:var(--warn)}.ac-task-mini .dot.bad{background:var(--bad)}.ac-task-mini .name{color:var(--text-2);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.ac-task-mini .pct{font-family:var(--font-mono);color:var(--text-3);font-size:11px}.ac-no-tasks{color:var(--text-3);font-size:12px}.ac-no-tasks a{color:var(--accent)}.ac-foot{border-top:1px solid var(--border);align-items:center;gap:6px;margin-top:auto;padding-top:10px;display:flex}.ac-foot .btn-sm{flex:1;justify-content:center}.asset-list{flex-direction:column;gap:2px;display:flex}.asset-list .folder-body .asset-list,.asset-list+.asset-list{margin-top:0}.asset-row{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);transition:border-color var(--t-fast), box-shadow var(--t-fast);contain:layout style;overflow:hidden}.asset-row:hover{border-color:var(--border-strong)}.asset-row.expanded{box-shadow:var(--shadow-sm)}.ar-head{cursor:pointer;-webkit-user-select:none;user-select:none;grid-template-columns:28px 1fr 16px 90px 18px;align-items:center;gap:10px;padding:9px 12px;display:grid}.ar-avatar{border-radius:var(--r-md);background:color-mix(in oklab, var(--asset-color,var(--accent)), var(--surface) 72%);width:28px;height:28px;color:var(--asset-color,var(--accent));flex-shrink:0;place-items:center;display:grid}.ar-name{min-width:0;color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:13px;font-weight:500;overflow:hidden}.ar-dot{background:var(--ok);border-radius:50%;flex-shrink:0;justify-self:center;width:8px;height:8px}.ar-dot.warn{background:var(--warn)}.ar-dot.bad{background:var(--bad)}.ar-update{justify-self:start}.ar-date-label{color:var(--text-2);justify-self:start;align-items:center;gap:5px;padding:5px 9px;font-size:12px;font-weight:500;display:inline-flex}.ar-chev{width:14px;height:14px;color:var(--text-3);transition:transform var(--t-fast);flex-shrink:0;justify-self:center}.asset-row.expanded .ar-chev{transform:rotate(180deg)}.ar-detail{grid-template-rows:0fr;transition:grid-template-rows .2s;display:grid}.asset-row.expanded .ar-detail{grid-template-rows:1fr}.ar-detail-inner{border-top:1px solid var(--border);padding:0 12px;overflow:hidden}.ar-detail-inner .ac-metrics{padding-top:10px}.ar-detail-inner .ac-tasks{padding-top:8px}.ar-detail-inner .ac-foot{margin-bottom:10px;padding-bottom:2px}.empty{text-align:center;flex-direction:column;align-items:center;gap:14px;padding:48px 20px;display:flex}.empty-art{border-radius:var(--r-xl);background:var(--surface-2);width:80px;height:80px;color:var(--text-3);border:1px dashed var(--border-strong);place-items:center;display:grid}.empty-art.ok{color:var(--ok);border-color:var(--ok);background:var(--ok-bg)}.empty h3{font-size:15px;font-weight:600}.empty p{color:var(--text-3);max-width:280px;font-size:13px}.skel-grid{grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:14px;display:grid}.skel-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);flex-direction:column;gap:12px;padding:16px;display:flex}.skel{background:var(--surface-2);border-radius:var(--r-sm);position:relative;overflow:hidden}.skel:after{content:"";background:linear-gradient(90deg, transparent, var(--surface-3), transparent);animation:1.6s cubic-bezier(.4,0,.6,1) infinite shimmer;position:absolute;inset:0;transform:translate(-100%)}@keyframes shimmer{to{transform:translate(200%)}}.skel.line{height:10px}.skel.w-60{width:60%}.skel.w-80{width:80%}.skel.w-40{width:40%}.skel.block{height:48px}.skel.avatar{border-radius:var(--r-md);flex-shrink:0;width:36px;height:36px}.cal-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-sm);padding:18px}.cal-head{justify-content:space-between;align-items:center;gap:12px;margin-bottom:18px;display:flex}.cal-title{font-size:16px;font-weight:600}.cal-nav{align-items:center;gap:4px;display:flex}.cal-nav .now{padding:5px 10px;font-size:12px}.cal-grid{background:var(--border);border:1px solid var(--border);border-radius:var(--r-md);grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-hdr{background:var(--surface-2);color:var(--text-3);text-transform:uppercase;letter-spacing:.05em;padding:8px 10px;font-size:11px;font-weight:600}.cal-cell{background:var(--surface);cursor:pointer;min-height:88px;transition:background var(--t-fast);flex-direction:column;gap:3px;padding:6px;display:flex}.cal-cell:hover,.cal-cell.other-month{background:var(--surface-2)}.cal-cell.other-month .cal-date{color:var(--text-3)}.cal-cell.today{background:var(--accent-soft)}.cal-cell.today .cal-date{color:var(--accent);font-weight:700}.cal-date{font-family:var(--font-mono);color:var(--text-2);font-size:12px;font-weight:500}.cal-event{border-radius:var(--r-sm);background:var(--surface-3);color:var(--text);white-space:nowrap;text-overflow:ellipsis;align-items:center;gap:4px;padding:2px 5px;font-size:11px;display:flex;overflow:hidden}.cal-cell.today .cal-event{background:var(--surface)}.cal-event .swatch{border-radius:2px;flex-shrink:0;width:6px;height:6px}.cal-event.bad{background:var(--bad-bg);color:var(--bad)}.cal-event.warn{background:var(--warn-bg);color:var(--warn-text)}.cal-more{color:var(--text-3);padding:1px 5px;font-size:11px}.history-filters{flex-wrap:wrap;align-items:center;gap:8px;margin-bottom:16px;display:flex}.hist-table{border-collapse:collapse;width:100%;font-size:13px}.hist-table thead th{text-align:left;text-transform:uppercase;letter-spacing:.05em;color:var(--text-3);border-bottom:1px solid var(--border);padding:8px;font-size:11px;font-weight:600}.hist-table tbody tr{border-bottom:1px solid var(--border);transition:background var(--t-fast)}.hist-table tbody tr:hover{background:var(--surface-2)}.hist-table tbody tr:last-child{border-bottom:none}.hist-table td{vertical-align:middle;padding:10px 8px}.hist-table td.mono{font-family:var(--font-mono);color:var(--text-2);font-variant-numeric:tabular-nums;font-size:12px}.hist-table td.muted{color:var(--text-3);font-size:12px}.hist-asset{align-items:center;gap:6px;display:inline-flex}.hist-asset .swatch{border-radius:2px;flex-shrink:0;width:8px;height:8px}.overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;opacity:0;pointer-events:none;transition:opacity var(--t-med);background:oklab(0% none none/.5);place-items:center;padding:20px;display:grid;position:fixed;inset:0}.overlay.open{opacity:1;pointer-events:auto}.modal{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);width:100%;max-width:480px;max-height:92vh;transition:transform var(--t-med);flex-direction:column;display:flex;overflow:hidden;transform:translateY(8px)scale(.98)}.overlay.open .modal{transform:none}.modal-sm{max-width:380px}.modal-lg{max-width:560px}.modal-head{border-bottom:1px solid var(--border);flex-shrink:0;justify-content:space-between;align-items:center;padding:16px 18px;display:flex}.modal-head h3{font-size:15px;font-weight:600}.modal-body{flex-direction:column;flex:1;gap:14px;padding:18px;display:flex;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);flex-wrap:wrap;flex-shrink:0;justify-content:flex-end;gap:8px;padding:14px 18px;display:flex}.modal-foot .btn-ghost.btn-danger{margin-right:auto}.field{flex-direction:column;gap:6px;display:flex}.field label{color:var(--text-2);font-size:12px;font-weight:500}.field .hint{color:var(--text-3);font-size:11px}.field-error{color:var(--bad);font-size:11px}.input.invalid{border-color:var(--bad)}.input,.select,.textarea{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);transition:border var(--t-fast), background var(--t-fast);width:100%;padding:8px 10px;font-size:13px}.input:focus,.select:focus,.textarea:focus{border-color:var(--accent);background:var(--surface);outline:none}.input:focus-visible,.select:focus-visible,.textarea:focus-visible{outline:2px solid var(--accent);outline-offset:1px}.textarea{resize:vertical;min-height:66px;font-family:var(--font-ui)}.select{appearance:none;cursor:pointer}.field-row{grid-template-columns:1fr 1fr;gap:10px;display:grid}.field-row-3{grid-template-columns:1fr 1fr 1fr;gap:8px;display:grid}.color-grid{grid-template-columns:repeat(8,1fr);gap:6px;display:grid}.color-swatch{aspect-ratio:1;border-radius:var(--r-sm);cursor:pointer;width:100%;transition:transform var(--t-fast), border var(--t-fast);border:2px solid #0000}.color-swatch:hover{transform:scale(1.1)}.color-swatch.selected{border-color:var(--text)}.icon-pick-btn{border-radius:var(--r-md);border:1px solid var(--border);background:var(--surface);color:var(--text-2);cursor:pointer;transition:border var(--t-fast), color var(--t-fast);align-items:center;gap:8px;padding:7px 10px;font-size:13px;display:inline-flex}.icon-pick-btn:hover{border-color:var(--border-strong);color:var(--text)}.icon-pick-btn .pick-preview{border-radius:var(--r-sm);background:var(--accent-soft);width:22px;height:22px;color:var(--accent);place-items:center;display:grid}.icon-popout{z-index:200;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-lg);box-shadow:var(--shadow-lg);flex-direction:column;gap:8px;width:260px;padding:10px;display:none;position:fixed}.icon-popout.open{display:flex}.icon-popout-search{border-radius:var(--r-sm);border:1px solid var(--border);background:var(--surface-2);width:100%;font:inherit;color:var(--text);outline:none;padding:6px 10px;font-size:12px}.icon-popout-search:focus{border-color:var(--accent)}.icon-popout-grid{grid-template-columns:repeat(6,1fr);gap:3px;max-height:200px;display:grid;overflow-y:auto}.icon-picker-grid{grid-template-columns:repeat(8,1fr);gap:4px;display:grid}.icon-swatch{aspect-ratio:1;border-radius:var(--r-sm);border:2px solid var(--border);background:var(--surface-2);cursor:pointer;color:var(--text-3);transition:border var(--t-fast), background var(--t-fast), color var(--t-fast);place-items:center;display:grid}.icon-swatch:hover{border-color:var(--border-strong);color:var(--text);background:var(--surface-3)}.icon-swatch.selected{border-color:var(--accent);background:var(--accent-soft);color:var(--accent)}.task-banner{background:var(--surface-2);border-radius:var(--r-md);border:1px solid var(--border);align-items:center;gap:10px;padding:10px 12px;display:flex}.task-banner .swatch{border-radius:2px;flex-shrink:0;width:8px;height:8px}.task-banner .name{font-size:14px;font-weight:600}.task-banner .sub{color:var(--text-3);margin-top:2px;font-size:12px}.value-rows{flex-direction:column;gap:8px;display:flex}.value-row{grid-template-columns:1fr 130px;align-items:end;gap:8px;display:grid}.value-label-col{color:var(--text-2);flex-direction:column;gap:2px;font-size:12px;display:flex}.value-label-col .prev{font-family:var(--font-mono);color:var(--text-3);font-size:11px}.mode-toggle{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);align-self:flex-start;gap:2px;padding:2px;display:flex}.mode-toggle button{border-radius:var(--r-sm);color:var(--text-2);transition:background var(--t-fast), color var(--t-fast);flex:1;padding:5px 12px;font-size:12px;font-weight:500}.mode-toggle button.active{background:var(--surface);color:var(--text);box-shadow:var(--shadow-sm)}.adjust-tl-picker{flex-wrap:wrap;gap:6px;margin-bottom:4px;display:flex}.adjust-tl-picker button{border-radius:var(--r-sm);background:var(--surface-2);color:var(--text-2);border:1px solid var(--border);transition:background var(--t-fast), color var(--t-fast);padding:4px 12px;font-size:12px;font-weight:500}.adjust-tl-picker button.active{background:var(--accent);color:#fff;border-color:var(--accent)}.timeline-list{flex-direction:column;gap:6px;display:flex}.timeline-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);align-items:center;gap:8px;padding:8px 10px;font-size:13px;display:flex}.timeline-item .tl-name{flex:1;font-weight:500}.timeline-item .tl-val{font-family:var(--font-mono);color:var(--text-3);font-size:12px}.timeline-item-actions{gap:4px;display:flex}#task-current-tasks-section{margin-top:4px;margin-bottom:4px}#task-current-list{flex-direction:column;gap:2px;margin-top:6px;display:flex}.task-current-row{border-radius:var(--r-sm);grid-template-columns:8px 1fr auto auto;align-items:center;gap:8px;padding:5px 8px;font-size:13px;display:grid}.task-current-row:hover{background:var(--surface-2)}.task-current-active{background:var(--surface-2);opacity:.7}.task-current-name{color:var(--text-secondary);text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.task-current-pct{font-family:var(--font-mono);color:var(--text-muted);font-size:11px}.task-current-badge{text-transform:uppercase;letter-spacing:.05em;color:var(--accent);border:1px solid var(--accent);opacity:.8;border-radius:99px;padding:1px 5px;font-size:10px;font-weight:600}.btn-xs{height:auto;padding:2px 8px;font-size:11px}.linked-list{flex-direction:column;gap:8px;display:flex}.linked-item{background:var(--surface-2);border:1px solid var(--border);border-radius:var(--r-md);flex-direction:column;gap:8px;padding:10px 12px;display:flex}.linked-item-head{justify-content:space-between;align-items:center;font-size:13px;font-weight:500;display:flex}.li-tl-select{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%23f3f3f0' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat;padding-right:28px;font-weight:600}[data-theme=light] .li-tl-select{background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2317171a' stroke-width='2.5' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'/%3E%3C/svg%3E");background-position:right 8px center;background-repeat:no-repeat}.divider{background:var(--border);height:1px}.modal-section-title{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);justify-content:space-between;align-items:center;font-size:12px;font-weight:600;display:flex}.sb-toggle{display:none}#sb-backdrop{z-index:39;background:#00000073;display:none;position:fixed;inset:0}@keyframes highlight-flash{0%{box-shadow:0 0 0 3px var(--accent)}to{box-shadow:var(--shadow-md)}}.asset-card.highlight-flash{animation:.9s ease-out highlight-flash}@media (width<=820px){#sb-backdrop.open{display:block}.page{grid-template-columns:1fr}.sidebar{z-index:40;transition:transform var(--t-med);box-shadow:var(--shadow-lg);border-right:none;width:280px;padding-top:56px;position:fixed;inset:0;transform:translate(-100%)}.sidebar.open{transform:none}.sb-toggle{display:grid!important}.main{padding:14px 14px 80px}.page-head{flex-direction:column;align-items:flex-start;gap:10px}.task-progress{min-width:80px}.history-filters{flex-direction:column;align-items:stretch}.history-filters .input{width:100%!important}#hist-asset-filter,#hist-from,#hist-to{width:100%!important;min-width:0!important}.modal{max-height:90dvh}.modal-body{max-height:calc(90dvh - 121px)}}.cal-agenda{display:none}.cal-agenda-day{border-bottom:1px solid var(--border);padding:10px 0}.cal-agenda-day:last-child{border-bottom:none}.cal-agenda-date{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:6px;font-size:11px;font-weight:700}.cal-agenda-date.today{color:var(--accent)}.cal-agenda-event{align-items:center;gap:8px;padding:4px 0;font-size:13px;display:flex}.cal-agenda-event .swatch{border-radius:2px;flex-shrink:0;width:8px;height:8px}.cal-agenda-empty{color:var(--text-3);padding:12px 0;font-size:13px}@media (width<=480px){.tab-label{display:none}.tab{gap:0;padding:6px 10px}.asset-grid{grid-template-columns:1fr}.task-row{grid-template-columns:10px 1fr auto}.task-progress{display:none}.page-head h1{font-size:18px}.brand-name>span:first-child{display:none}body{font-size:15px}.cal-grid{display:none}.cal-agenda{display:block}}@media (pointer:coarse),(any-pointer:coarse){.input,.select,.textarea{font-size:16px}.folder-head .edit-btn{opacity:.55}}#update-banner{z-index:400;background:var(--surface);border:1px solid var(--border);white-space:nowrap;border-radius:99px;align-items:center;gap:12px;padding:10px 14px 10px 18px;font-size:13px;font-weight:600;animation:.3s cubic-bezier(.34,1.56,.64,1) update-pop;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%);box-shadow:0 4px 24px #0000002e}#update-banner[hidden]{display:none}#btn-apply-update{color:#fff;cursor:pointer;letter-spacing:.01em;background:#ef4444;border:none;border-radius:99px;padding:5px 14px;font-size:12px;font-weight:700}#btn-apply-update:hover{background:#dc2626}@keyframes update-pop{0%{opacity:0;transform:translate(-50%)translateY(12px)scale(.95)}to{opacity:1;transform:translate(-50%)translateY(0)scale(1)}}#offline-banner{top:max(12px, calc(env(safe-area-inset-top) + 8px));z-index:400;color:#fff;letter-spacing:.02em;white-space:nowrap;background:#ef4444;border-radius:99px;align-items:center;gap:6px;padding:6px 14px 6px 10px;font-size:12px;font-weight:700;animation:.25s cubic-bezier(.34,1.56,.64,1) offline-pop;display:flex;position:fixed;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #ef444466}#offline-banner[hidden]{display:none}@keyframes offline-pop{0%{opacity:0;transform:translate(-50%)scale(.85)}to{opacity:1;transform:translate(-50%)scale(1)}}.toast-stack{z-index:300;pointer-events:none;flex-direction:column;align-items:center;gap:8px;width:max-content;max-width:calc(100vw - 32px);display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--r-pill);color:var(--text);box-shadow:var(--shadow-lg);white-space:nowrap;align-items:center;gap:8px;padding:9px 16px;font-size:13px;font-weight:500;animation:.22s cubic-bezier(.2,.8,.2,1) both toast-in;display:inline-flex}.toast svg{color:var(--ok)}@keyframes toast-in{0%{opacity:0;transform:translateY(10px)scale(.95)}to{opacity:1;transform:none}}@keyframes toast-out{0%{opacity:1;transform:none}to{opacity:0;transform:translateY(-6px)scale(.97)}}.install-modal-content{text-align:center;flex-direction:column;align-items:center;gap:16px;padding:4px 0;display:flex}.install-modal-desc{margin:0;font-size:15px;line-height:1.5}.install-modal-steps{text-align:left;flex-direction:column;gap:10px;width:100%;margin:0;padding-left:20px;font-size:14px;display:flex}.install-modal-steps li{line-height:1.5}.hist-detail-field{border-bottom:1px solid var(--border);flex-direction:column;gap:3px;padding:10px 0;display:flex}.hist-detail-field:first-child{padding-top:0}.hist-detail-field:last-child{border-bottom:none;padding-bottom:0}.hist-detail-label{text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);font-size:11px;font-weight:600}.hist-detail-value{font-size:14px;line-height:1.5}.hist-detail-memo{white-space:pre-wrap}@keyframes pulse-bad{0%,to{box-shadow:0 0 0 3px var(--bad-bg)}55%{box-shadow:0 0 0 6px var(--bad-bg)}}.task-status.bad{animation:2.8s ease-in-out infinite pulse-bad}@keyframes fill-bar{0%{max-width:0}to{max-width:100%}}.progress-fill{animation:.5s cubic-bezier(.2,.8,.2,1) both fill-bar}@keyframes card-in{0%{opacity:0;transform:translateY(6px)}}.asset-card{animation:.22s cubic-bezier(.25,1,.5,1) both card-in}.folder-body{grid-template-rows:1fr;transition:grid-template-rows .28s cubic-bezier(.25,1,.5,1);display:grid;overflow:hidden}.folder-body.collapsed{grid-template-rows:0fr}.folder-body>.asset-grid{min-height:0;overflow:hidden}.empty-folder-msg{color:var(--text-3);min-height:0;padding:10px 4px;font-size:12px;overflow:hidden}#sb-folder-ctx{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md);box-shadow:var(--shadow-lg);min-width:148px;padding:4px}.ctx-item{border-radius:var(--r-sm);width:100%;color:var(--text);text-align:left;align-items:center;gap:8px;padding:7px 10px;font-size:13px;font-weight:500;display:flex}.ctx-item:hover{background:var(--surface-2)}.ctx-item.ctx-danger{color:var(--bad)}.ctx-item svg{flex-shrink:0}.text-bad{color:var(--bad)}.text-warn{color:var(--warn-text)}.text-ok{color:var(--ok)}.text-muted{color:var(--text-3)}.mono{font-family:var(--font-mono)}.sb-ws-row{display:block;position:relative}.sb-ws-row .sb-item.ws-scope-btn{width:100%;padding-right:32px}.ws-scope-btn .ws-name{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.ws-shared-tag{letter-spacing:.02em;text-transform:lowercase;opacity:.65;flex-shrink:0;margin-left:2px;font-size:11px;font-weight:500}.ws-kebab{color:var(--text-3);cursor:pointer;opacity:.55;z-index:2;background:0 0;border:none;border-radius:6px;justify-content:center;align-items:center;padding:4px;transition:opacity .12s,background .12s;display:inline-flex;position:absolute;top:50%;right:4px;transform:translateY(-50%)}.sb-ws-row:hover .ws-kebab{opacity:1}.ws-kebab:hover{opacity:1;background:var(--bg-2,#00000014)}.ws-code-input{font-family:var(--font-mono);letter-spacing:.3em;text-align:center;text-transform:uppercase;font-size:22px;font-weight:600}.ws-code-display{font-family:var(--font-mono);letter-spacing:.32em;text-align:center;background:var(--surface-2,var(--surface));border:1px solid var(--border);border-radius:var(--r-md);color:var(--text);-webkit-user-select:all;user-select:all;margin:6px 0 14px;padding:18px 12px;font-size:30px;font-weight:700}.ws-move-list{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.ws-move-item{border:1px solid var(--border);border-radius:var(--r-md);background:var(--surface,transparent);color:var(--text);cursor:pointer;text-align:left;align-items:center;gap:10px;padding:10px 12px;font-size:14px;font-weight:500;transition:background .12s,border-color .12s;display:flex}.ws-move-item:hover{background:var(--bg-2,#0000000a);border-color:var(--accent,var(--border))}.ws-move-item .ws-move-meta{opacity:.7;margin-left:auto;font-size:12px}.ws-members-list{flex-direction:column;gap:6px;max-height:320px;display:flex;overflow-y:auto}.ws-member-row{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:8px 4px;display:flex}.ws-member-row:last-child{border-bottom:none}.ws-member-avatar{background:var(--surface-2,var(--surface));width:32px;height:32px;color:var(--text);border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;font-size:12px;font-weight:600;display:inline-flex;overflow:hidden}.ws-member-avatar img{object-fit:cover;width:100%;height:100%}.ws-member-info{flex:1;min-width:0}.ws-member-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.ws-member-you{color:var(--text);opacity:.7;font-size:12px;font-weight:400}.ws-member-meta{color:var(--text);opacity:.7;text-overflow:ellipsis;white-space:nowrap;font-size:12px;overflow:hidden}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important;animation-duration:.01ms!important;animation-iteration-count:1!important}}:root{--m-accent:#ef4444;--m-accent-soft:#ef44441a;--m-accent-contrast:#fff;--m-radius-card:14px;--m-radius-lg:16px}[data-theme=studio-light]{--m-glass-bg:#ffffffb8;--m-glass-border:#1414140f;--m-glass-shadow:0 18px 40px #1414141a}[data-theme=studio-dark]{--m-glass-bg:#141416b8;--m-glass-border:#ffffff1a;--m-glass-shadow:0 18px 40px #00000080}#mobile-app{display:none}@media (width<=768px){html,body{height:100%;margin:0}body{overflow:clip}#app-shell{display:none!important}#auth-wall{background:var(--bg);align-items:stretch;height:100dvh;padding:0;overflow:hidden}#auth-wall .auth-card{width:100%;max-width:100%;height:100%;box-shadow:none;background:0 0;border:none;border-radius:0;flex-direction:column;padding:0;display:flex;overflow:hidden}.m-auth-hero{text-align:center;background:radial-gradient(ellipse 90% 55% at 50% -5%, color-mix(in srgb, var(--m-accent) 22%, transparent), transparent 65%), radial-gradient(ellipse 60% 40% at 80% 80%, color-mix(in srgb, var(--m-accent) 6%, transparent), transparent 70%);flex-direction:column;flex:1;justify-content:center;align-items:center;gap:0;padding:0 32px 40px;display:flex;position:relative}.m-auth-hero:before{content:"";background-image:radial-gradient(circle, color-mix(in srgb, var(--text) 8%, transparent) 1px, transparent 1px);pointer-events:none;background-size:28px 28px;position:absolute;inset:0;-webkit-mask-image:radial-gradient(70% 60%,#000 30%,#0000 80%);mask-image:radial-gradient(70% 60%,#000 30%,#0000 80%)}.m-auth-icon{background:var(--m-accent);color:#fff;width:88px;height:88px;box-shadow:0 0 0 12px color-mix(in srgb, var(--m-accent) 12%, transparent), 0 0 0 24px color-mix(in srgb, var(--m-accent) 6%, transparent), 0 20px 48px color-mix(in srgb, var(--m-accent) 40%, transparent);border-radius:26px;place-items:center;margin-bottom:28px;display:grid;position:relative}.m-auth-icon svg{width:42px;height:42px}.m-auth-app-name{letter-spacing:-.04em;margin-bottom:10px;font-size:32px;font-weight:800;line-height:1}.m-auth-tagline{color:var(--text-3);max-width:240px;font-size:14px;line-height:1.6}.m-auth-bottom{padding:28px 24px max(36px, env(safe-area-inset-bottom));background:var(--surface);box-shadow:0 -1px 0 var(--border), 0 -20px 60px #0000001a;border-top-left-radius:28px;border-top-right-radius:28px}.m-auth-bottom .google-btn{letter-spacing:-.01em;border-radius:16px;gap:12px;height:56px;margin-bottom:24px;font-size:16px;font-weight:600}.m-auth-bottom .auth-feats,#auth-wall .auth-card>h1,#auth-wall .auth-card>p{display:none}#mobile-app{background:var(--bg);width:100%;height:100dvh;color:var(--text);box-sizing:border-box;flex-direction:column;display:flex;overflow:hidden}.toast-stack{bottom:90px}.overlay{-webkit-backdrop-filter:blur(2px);flex-direction:column;justify-content:flex-end;align-items:stretch;padding:0;display:flex}.overlay .modal{transform-origin:bottom;background:var(--bg);border:none;border-radius:22px 22px 0 0;width:100%;max-width:100%;max-height:88vh;margin:0;box-shadow:0 -10px 40px #0003;transition:transform .3s cubic-bezier(.32,.72,0,1)!important;transform:translateY(100%)!important}.overlay.open .modal{transform:translateY(0)!important}}#m-view-root{flex:1;min-height:0;position:relative;overflow:hidden}.m-view-scroll{-webkit-overflow-scrolling:touch;overscroll-behavior:contain;scrollbar-width:none;padding-bottom:24px;position:absolute;inset:0;overflow:hidden auto}.m-view-scroll::-webkit-scrollbar{display:none}#m-bottom-nav{z-index:20;background:linear-gradient(to bottom, transparent, var(--bg) 30%);flex-shrink:0;padding:8px 16px}.m-nav-inner{background:var(--m-glass-bg);-webkit-backdrop-filter:blur(24px)saturate(180%);border:.5px solid var(--m-glass-border);box-shadow:var(--m-glass-shadow), inset 0 1px 0 #fff6;border-radius:26px;align-items:center;padding:8px 6px;display:flex}.m-nav-btn{min-width:0;color:var(--text-3);-webkit-tap-highlight-color:transparent;border-radius:12px;flex-direction:column;flex:1;align-items:center;gap:3px;padding:7px 4px;transition:color .12s;display:flex}.m-nav-btn svg{display:block}.m-nav-btn span{letter-spacing:.15px;white-space:nowrap;font-size:10.5px;font-weight:500}.m-nav-btn.active{color:var(--m-accent)}.m-nav-btn.active span{font-weight:700}.m-nav-btn.m-nav-primary{padding:0}.m-nav-primary-pill{background:var(--m-accent);width:46px;height:46px;color:var(--m-accent-contrast);border-radius:16px;place-items:center;display:grid;box-shadow:0 8px 22px #ef444459}.m-greeting{color:var(--text-3);letter-spacing:.2px;margin-top:3px;font-size:11px;font-weight:500}.m-header{z-index:8;background:linear-gradient(to bottom, var(--bg) 70%, color-mix(in oklab, var(--bg), transparent 40%));flex-direction:column;gap:10px;padding:12px 20px 14px;transition:padding .24s cubic-bezier(.4,0,.2,1),background .24s,gap .22s;display:flex;position:sticky;top:0}.m-header.collapsed{background:var(--bg);gap:0;padding:10px 20px}.m-header-top{justify-content:space-between;align-items:center;gap:12px;min-height:36px;display:flex}.m-header-left{flex:1;min-width:0}.m-header-right{flex-shrink:0;align-items:center;gap:8px;display:flex}.m-header-bento{background:var(--surface);border:.5px solid var(--border);opacity:1;border-radius:14px;max-height:80px;padding:10px 14px;transition:max-height .22s,opacity .16s,padding .22s;overflow:hidden}.m-header.collapsed .m-header-bento{opacity:0;max-height:0;margin-bottom:0;padding-top:0;padding-bottom:0}.m-title{letter-spacing:-.03em;font-size:28px;font-weight:800;line-height:1.05;transition:font-size .24s cubic-bezier(.4,0,.2,1),letter-spacing .24s}.m-header.collapsed .m-title{letter-spacing:-.015em;font-size:18px}.m-subtitle{color:var(--text-3);font-size:12px;font-weight:600}.m-icon-btn{background:var(--surface);width:36px;height:36px;color:var(--text-2);border:.5px solid var(--border);-webkit-tap-highlight-color:transparent;border-radius:10px;flex-shrink:0;place-items:center;display:grid}.m-icon-btn svg{display:block}.m-filter-row{align-items:center;gap:8px;padding:6px 16px 14px;display:flex}.m-filter-chip{background:var(--surface);border:.5px solid var(--border);color:var(--text);-webkit-tap-highlight-color:transparent;border-radius:999px;align-items:center;gap:7px;padding:8px 13px;font-size:12.5px;font-weight:600;display:inline-flex}.m-filter-chip svg{display:block}.m-section{padding:4px 16px 14px}.m-section-head{align-items:center;gap:8px;margin-bottom:8px;display:flex}.m-section-bar{border-radius:2px;flex-shrink:0;width:4px;height:14px;display:inline-block}.m-section-bar.bad{background:var(--bad)}.m-section-bar.warn{background:var(--warn)}.m-section-bar.ok{background:var(--ok)}.m-section-title{letter-spacing:.6px;text-transform:uppercase;color:var(--text-2);font-size:11px;font-weight:700}.m-section-count{font-size:10.5px;font-family:var(--font-mono);color:var(--text-3)}.m-task-list{flex-direction:column;gap:8px;display:flex}.m-task-row{border-radius:var(--m-radius-card);-webkit-tap-highlight-color:transparent;cursor:pointer;position:relative;overflow:hidden}.m-task-swipe-bg{background:var(--ok);color:#fff;letter-spacing:.15px;border-radius:var(--m-radius-card);opacity:0;justify-content:flex-start;align-items:center;gap:8px;padding-left:18px;font-size:13px;font-weight:700;display:flex;position:absolute;inset:0}.m-task-swipe-bg svg{display:block}.m-task-inner{background:var(--surface);will-change:transform;align-items:center;gap:12px;padding:12px;display:flex;position:relative}.m-asset-chip{background:color-mix(in srgb, var(--chip-color) 15%, transparent);width:36px;height:36px;color:var(--chip-color);border-radius:11px;flex-shrink:0;place-items:center;display:grid}.m-asset-chip [data-lucide]{width:14px;height:14px}.m-task-body{flex:1;min-width:0}.m-task-name{letter-spacing:-.01em;white-space:nowrap;text-overflow:ellipsis;font-size:14.5px;font-weight:600;line-height:1.2;overflow:hidden}.m-task-asset{color:var(--text-3);white-space:nowrap;text-overflow:ellipsis;margin-top:2px;font-size:11px;overflow:hidden}.m-task-prog{align-items:center;gap:8px;margin-top:7px;display:flex}.m-progress-track{background:var(--surface-3);border-radius:999px;flex:1;height:5px;overflow:hidden}.m-progress-fill{border-radius:999px;height:100%;transition:width .24s}.m-progress-fill.bad{background:var(--bad)}.m-progress-fill.warn{background:var(--warn)}.m-progress-fill.ok{background:var(--ok)}.m-pct{font-size:10.5px;font-family:var(--font-mono);font-variant-numeric:tabular-nums;text-align:right;flex-shrink:0;min-width:32px;font-weight:700}.m-pct.bad{color:var(--bad)}.m-pct.warn{color:var(--warn-text,var(--warn))}.m-pct.ok{color:var(--ok)}.m-asset-grid{flex-direction:column;gap:12px;padding:0 16px;display:flex}.m-asset-tile{cursor:pointer;-webkit-tap-highlight-color:transparent;-webkit-user-select:none;user-select:none}.m-asset-tile:active{opacity:.88}.m-asset-chip-lg{border-radius:var(--r-md);background:color-mix(in oklab, var(--chip-color) 15%, transparent);width:36px;height:36px;color:var(--chip-color);flex-shrink:0;place-items:center;display:grid}.m-asset-chip-lg [data-lucide]{width:14px;height:14px}.m-folder-section{padding:0 16px 12px}.m-folder-section .m-asset-grid{padding:0}.m-view-scroll .asset-list{gap:4px;padding:0 16px}.m-folder-section .asset-list{padding:0}.m-folder-section-head{text-align:left;-webkit-tap-highlight-color:transparent;align-items:center;gap:7px;width:100%;padding:10px 2px 8px;display:flex}.m-folder-section-name{text-transform:uppercase;letter-spacing:.5px;color:var(--text-2);flex:1;font-size:12px;font-weight:700}.m-folder-chevron{color:var(--text-3);flex-shrink:0;transition:transform .2s}.m-folder-chevron.collapsed{transform:rotate(-90deg)}.m-folder-empty{color:var(--text-3);padding:4px 2px 8px;font-size:12px}.m-asset-add-tile{border:1.5px dashed var(--border-strong);border-radius:var(--m-radius-lg);color:var(--text-3);cursor:pointer;-webkit-tap-highlight-color:transparent;background:0 0;justify-content:center;align-items:center;gap:8px;height:48px;font-size:13px;font-weight:600;display:flex}.m-asset-add-tile svg{display:block}.m-cal-header{z-index:8;background:linear-gradient(to bottom, var(--bg) 70%, color-mix(in oklab, var(--bg), transparent 40%));justify-content:space-between;align-items:flex-end;padding:12px 20px 8px;display:flex;position:sticky;top:0}.m-cal-year{color:var(--text-3);text-transform:uppercase;letter-spacing:.6px;font-size:11px;font-weight:600}.m-cal-nav{gap:6px;display:flex}.m-cal-grid-wrap{padding:0 16px 4px}.m-cal-dow{grid-template-columns:repeat(7,1fr);margin-bottom:2px;display:grid}.m-cal-dow-cell{text-align:center;color:var(--text-3);letter-spacing:.4px;padding:2px 0;font-size:10.5px;font-weight:600}.m-cal-grid{grid-template-columns:repeat(7,1fr);gap:3px;display:grid}.m-cal-cell{aspect-ratio:1;cursor:default;border-radius:10px;flex-direction:column;justify-content:center;align-items:center;gap:2px;display:flex}.m-cal-cell.blank{visibility:hidden}.m-cal-cell.today{background:var(--m-accent)}.m-cal-day{font-size:13px;font-weight:500;font-family:var(--font-mono);font-variant-numeric:tabular-nums;color:var(--text-2)}.m-cal-cell.today .m-cal-day{color:var(--m-accent-contrast);font-weight:700}.m-cal-dot{border-radius:50%;width:4px;height:4px;display:inline-block}.m-cal-dot.bad{background:var(--bad)}.m-cal-dot.warn{background:var(--warn)}.m-cal-dot.ok{background:var(--ok)}.m-cal-dot.today-dot{background:#ffffffb3}.m-cal-agenda{padding:12px 16px}.m-agenda-day{margin-bottom:16px}.m-agenda-date{letter-spacing:-.01em;color:var(--text);margin-bottom:8px;font-size:15px;font-weight:700}.m-agenda-date.today{color:var(--m-accent)}.m-agenda-event{background:var(--surface);cursor:pointer;-webkit-tap-highlight-color:transparent;border-radius:12px;align-items:center;gap:10px;margin-bottom:6px;padding:10px 12px;display:flex}.m-agenda-event.bad{border-left:3px solid var(--bad)}.m-agenda-event.warn{border-left:3px solid var(--warn)}.m-agenda-swatch{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.m-agenda-name{color:var(--text);font-size:13.5px;font-weight:500}.m-sheet-overlay{z-index:100;-webkit-backdrop-filter:blur(2px);opacity:0;pointer-events:none;background:#14141480;transition:opacity .28s;position:fixed;inset:0}.m-sheet-overlay.open{opacity:1;pointer-events:all}.m-bottom-sheet{background:var(--bg);border-top-left-radius:22px;border-top-right-radius:22px;flex-direction:column;max-height:88vh;transition:transform .3s cubic-bezier(.32,.72,0,1);display:flex;position:absolute;bottom:0;left:0;right:0;transform:translateY(100%);box-shadow:0 -10px 40px #0003}.m-sheet-overlay.open .m-bottom-sheet{transform:translateY(0)}.m-sheet-titlebar{flex-shrink:0;align-items:center;gap:10px;padding:18px 18px 6px;display:flex}.m-sheet-title{letter-spacing:-.02em;font-size:17px;font-weight:700}.m-sheet-sub{color:var(--text-3);margin-top:1px;font-size:11px}.m-sheet-actions{padding:12px 16px;padding-bottom:max(16px, env(safe-area-inset-bottom));background:var(--bg);border-top:.5px solid var(--border);gap:8px;display:flex;position:absolute;bottom:0;left:0;right:0}.m-filter-scroll{-webkit-overflow-scrolling:touch;flex:1;padding:4px 12px 110px;overflow-y:auto}.m-filter-group{margin-bottom:8px}.m-filter-folder-header{text-transform:uppercase;letter-spacing:.6px;color:var(--text-3);padding:8px 8px 4px;font-size:11px;font-weight:700}.m-filter-folder-row,.m-filter-unit-row{text-align:left;-webkit-tap-highlight-color:transparent;border-radius:10px;align-items:center;gap:10px;width:100%;padding:9px 8px;display:flex}.m-filter-unit-row{padding-left:18px}.m-filter-folder-row:active,.m-filter-unit-row:active{background:var(--surface-3)}.m-folder-check,.m-unit-check{border:1.5px solid var(--border-strong);border-radius:6px;flex-shrink:0;place-items:center;width:20px;height:20px;transition:all .12s;display:grid}.m-folder-check.all,.m-folder-check.some,.m-unit-check.checked{background:var(--accent);border-color:var(--accent)}.m-folder-check.all:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:10px;height:7px;display:block;transform:rotate(-45deg)translate(1px,-1px)}.m-folder-check.some:after{content:"";background:#fff;border-radius:1px;width:8px;height:2px;display:block}.m-unit-check.checked:after{content:"";border-bottom:2px solid #fff;border-left:2px solid #fff;width:10px;height:7px;display:block;transform:rotate(-45deg)translate(1px,-1px)}.m-folder-dot,.m-unit-dot{border-radius:50%;flex-shrink:0;width:9px;height:9px;display:inline-block}.m-folder-name{color:var(--text);flex:1;font-size:13px;font-weight:600}.m-folder-count{color:var(--text-3);font-size:11px;font-family:var(--font-mono)}.m-unit-name{color:var(--text);flex:1;font-size:13px}.m-asset-detail{max-height:90vh}.m-detail-header{flex-shrink:0;align-items:flex-start;gap:8px;padding:18px 16px 16px;display:flex}.m-detail-asset{align-items:center;gap:14px;margin-top:8px;display:flex}.m-detail-name{letter-spacing:-.02em;font-size:22px;font-weight:700}.m-detail-sub{color:var(--text-3);margin-top:2px;font-size:12px}.m-detail-scroll{-webkit-overflow-scrolling:touch;flex:1;padding-bottom:130px;overflow-y:auto}.m-detail-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-3);padding:12px 16px 6px;font-size:11px;font-weight:700}.m-detail-section-head{justify-content:space-between;align-items:center;padding:12px 16px 6px;display:flex}.m-tl-list{flex-direction:column;gap:8px;padding:0 16px;display:flex}.m-tl-row{background:var(--surface);border-radius:var(--m-radius-card);align-items:center;gap:12px;padding:12px;display:flex}.m-tl-body{flex:1}.m-tl-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;font-size:11px;font-weight:600}.m-tl-value{letter-spacing:-.02em;font-size:22px;font-weight:700;font-family:var(--font-mono);margin-top:2px}.m-tl-unit{color:var(--text-3);font-size:12px;font-family:var(--font-ui);font-weight:400}.m-tl-edit-btn{background:var(--surface-3);width:34px;height:34px;color:var(--text-2);border-radius:9px;flex-shrink:0;place-items:center;display:grid}.m-tl-edit-btn [data-lucide]{width:14px;height:14px}.m-detail-actions{left:16px;right:16px;bottom:max(16px, env(safe-area-inset-bottom));background:var(--m-glass-bg);-webkit-backdrop-filter:blur(20px)saturate(160%);border:.5px solid var(--m-glass-border);box-shadow:var(--m-glass-shadow);border-radius:18px;gap:8px;padding:6px;display:flex;position:absolute}.m-btn-primary{border-radius:var(--r-lg);background:var(--accent);height:44px;color:var(--accent-contrast);border:1px solid color-mix(in oklab, var(--accent), #000 15%);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:6px;font-size:14px;font-weight:600;transition:opacity .12s;display:inline-flex}.m-btn-primary:active{opacity:.8}.m-btn-primary svg{display:block}.m-btn-secondary{border-radius:var(--r-lg);background:var(--surface);height:44px;color:var(--text);border:1px solid var(--border);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;gap:6px;font-size:14px;font-weight:600;display:inline-flex}.m-btn-secondary [data-lucide]{width:14px;height:14px}.m-btn-ghost{border-radius:var(--r-lg);background:var(--surface);height:44px;color:var(--text);border:1px solid var(--border);-webkit-tap-highlight-color:transparent;flex:1;justify-content:center;align-items:center;font-size:14px;font-weight:600;display:inline-flex}.m-link-btn{color:var(--accent);-webkit-tap-highlight-color:transparent;border-radius:8px;padding:6px 10px;font-size:13px;font-weight:600}.m-profile-card{background:var(--surface);border-radius:var(--m-radius-lg);align-items:center;gap:14px;margin:16px 16px 0;padding:20px 16px;display:flex}.m-avatar{background:var(--m-accent);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:52px;height:52px;font-size:20px;font-weight:700;display:grid;overflow:hidden}.m-avatar img{object-fit:cover;width:100%;height:100%}.m-avatar .avatar-fallback{background:var(--m-accent);color:#fff;border-radius:50%;place-items:center;width:100%;height:100%;display:grid}.m-avatar .avatar-fallback svg{width:26px;height:26px}.m-profile-name{letter-spacing:-.01em;font-size:17px;font-weight:700}.m-profile-email{color:var(--text-3);margin-top:2px;font-size:12px}.m-more-section{margin:16px 16px 0}.m-more-section-title{text-transform:uppercase;letter-spacing:.6px;color:var(--text-3);padding:0 4px 6px;font-size:11px;font-weight:700}.m-more-list{background:var(--surface);border-radius:var(--m-radius-lg);overflow:hidden}.m-more-row{border-bottom:.5px solid var(--border);text-align:left;-webkit-tap-highlight-color:transparent;align-items:center;gap:12px;width:100%;padding:13px 16px;display:flex}.m-more-row:last-child{border-bottom:none}.m-more-row:active{background:var(--surface-3)}.m-more-row-icon{background:var(--surface-3);width:30px;height:30px;color:var(--text-2);border-radius:8px;flex-shrink:0;place-items:center;display:grid}.m-more-row-icon svg{display:block}.m-more-version{text-align:center;letter-spacing:.08em;opacity:.35;padding:20px 0 28px;font-size:11px;font-weight:600}.m-more-row-label{color:var(--text);flex:1;font-size:14px;font-weight:500}.m-more-row-value{color:var(--text-3);font-size:13px}.m-more-row.danger .m-more-row-label{color:var(--bad)}.m-more-row.danger .m-more-row-icon{background:color-mix(in srgb, var(--bad) 12%, transparent);color:var(--bad)}.m-hist-list{flex-direction:column;gap:6px;display:flex}.m-hist-row{background:var(--surface);border-radius:var(--m-radius-card);cursor:pointer;align-items:flex-start;gap:10px;padding:10px 12px;transition:background .12s;display:flex}.m-hist-row:active{background:var(--surface-2)}.m-hist-body{flex:1;min-width:0}.m-hist-task{white-space:nowrap;text-overflow:ellipsis;font-size:13.5px;font-weight:600;overflow:hidden}.m-hist-asset{color:var(--text-3);margin-top:2px;font-size:11px}.m-hist-memo{color:var(--text-3);text-overflow:ellipsis;-webkit-line-clamp:2;-webkit-box-orient:vertical;margin-top:3px;font-size:11px;font-style:italic;display:-webkit-box;overflow:hidden}.m-hist-right{flex-direction:column;flex-shrink:0;align-items:flex-end;gap:4px;display:flex}.m-hist-date{font-size:11px;font-family:var(--font-mono);color:var(--text-3)}.m-hist-memo-dot{background:var(--accent);opacity:.7;border-radius:50%;width:6px;height:6px}.m-icon-btn.m-filter-active,.m-filter-chip.m-filter-active{background:var(--accent);color:var(--accent-contrast);border-color:color-mix(in oklab, var(--accent), #000 15%)}.m-hist-select{background:var(--surface);border:.5px solid var(--border);width:100%;color:var(--text);appearance:none;border-radius:10px;padding:12px 14px;font-size:14px}.m-hist-date-row{gap:10px;display:flex}.m-hist-date-field{flex-direction:column;flex:1;gap:4px;display:flex}.m-hist-date-label{color:var(--text-3);text-transform:uppercase;letter-spacing:.4px;padding-left:2px;font-size:11px;font-weight:600}.m-hist-date-input{background:var(--surface);border:.5px solid var(--border);width:100%;color:var(--text);border-radius:10px;padding:11px 12px;font-size:14px}.m-theme-seg{background:var(--surface);border-radius:var(--m-radius-lg);gap:4px;padding:4px;display:flex}.m-theme-seg-btn{height:40px;color:var(--text-3);-webkit-tap-highlight-color:transparent;border-radius:10px;flex:1;justify-content:center;align-items:center;gap:6px;font-size:13.5px;font-weight:600;transition:background .12s,color .12s;display:inline-flex;position:relative}.m-theme-seg-btn svg{display:block}.m-theme-seg-btn.active{background:var(--bg);color:var(--text);box-shadow:0 1px 4px #0000001f}.m-theme-check{color:var(--m-accent);align-items:center;display:flex}.m-empty{text-align:center;flex-direction:column;align-items:center;gap:8px;padding:40px 30px 20px;display:flex}.m-empty-icon{color:var(--ok);margin-bottom:4px;font-size:32px}.m-empty-title{color:var(--text);font-size:16px;font-weight:700}.m-empty-sub{color:var(--text-3);font-size:13px}.m-empty-action{color:var(--m-accent);border-radius:10px;margin-top:8px;padding:8px 16px;font-size:14px;font-weight:600}.m-ws-list{background:var(--surface);border-radius:var(--m-radius-lg);overflow:hidden}.m-ws-row{border-bottom:.5px solid var(--border);text-align:left;-webkit-tap-highlight-color:transparent;cursor:pointer;align-items:center;gap:12px;width:100%;padding:12px 14px;display:flex}.m-ws-row:last-child{border-bottom:none}.m-ws-row:active{background:var(--surface-3)}.m-ws-row.active{background:color-mix(in srgb, var(--m-accent) 10%, transparent)}.m-ws-icon{background:var(--surface-3);border-radius:8px;flex-shrink:0;place-items:center;width:30px;height:30px;display:grid}.m-ws-icon svg{display:block}.m-ws-body{flex:1;min-width:0}.m-ws-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;font-size:14px;font-weight:600;overflow:hidden}.m-ws-sub{letter-spacing:.6px;text-transform:uppercase;color:var(--text);opacity:.55;margin-top:1px;font-size:11px;font-weight:700}.m-ws-check{color:var(--m-accent);flex-shrink:0;display:inline-flex}.m-ws-cog{width:32px;height:32px;color:var(--text);opacity:.6;background:0 0;border:none;border-radius:8px;flex-shrink:0;place-items:center;display:grid}.m-ws-cog:active{background:var(--surface-3);opacity:1}.m-ws-actions{gap:8px;margin-top:10px;display:flex}.m-ws-action{background:var(--surface);color:var(--text);border:.5px solid var(--border);-webkit-tap-highlight-color:transparent;border-radius:12px;flex:1;justify-content:center;align-items:center;gap:6px;padding:10px 12px;font-size:13px;font-weight:600;display:inline-flex}.m-ws-action:active{background:var(--surface-3)}.m-ws-action svg{display:block}.m-scope-row{padding:4px 16px 0}.m-header.collapsed .m-scope-row{display:none}.m-scope-chip{background:var(--surface);border:.5px solid var(--border);color:var(--text);-webkit-tap-highlight-color:transparent;border-radius:999px;align-items:center;gap:6px;max-width:100%;padding:4px 10px 4px 8px;font-size:11px;font-weight:600;display:inline-flex}.m-scope-chip:active{background:var(--surface-3)}.m-scope-chip.shared{background:color-mix(in srgb, var(--scope-color,var(--m-accent)) 10%, transparent);border-color:color-mix(in srgb, var(--scope-color,var(--m-accent)) 35%, var(--border))}.m-scope-dot{border-radius:999px;flex-shrink:0;width:8px;height:8px}.m-scope-name{text-overflow:ellipsis;white-space:nowrap;max-width:180px;overflow:hidden}.m-scope-tag{letter-spacing:.5px;text-transform:uppercase;opacity:.65;margin-left:2px;font-size:10px;font-weight:700}.m-ptr-indicator{background:var(--surface);border:.5px solid var(--border);width:36px;height:36px;color:var(--text);opacity:0;z-index:30;pointer-events:none;border-radius:999px;place-items:center;margin-left:0;display:grid;position:absolute;top:0;left:50%;transform:translate(-50%,-100%);box-shadow:0 4px 12px #0000002e}.m-ptr-indicator svg{transition:transform .18s}.m-ptr-indicator.armed svg{color:var(--m-accent);transform:rotate(180deg)}.m-ptr-indicator.refreshing svg{color:var(--m-accent);animation:.9s linear infinite mPtrSpin}@keyframes mPtrSpin{to{transform:rotate(360deg)}}.m-ptr-indicator{left:calc(50% - 18px);transform:translateY(-100%)}#ob-svg{z-index:8990;pointer-events:none;opacity:0;width:100%;height:100%;transition:opacity .4s;position:fixed;inset:0}#ob-svg.ob-visible{opacity:1}#ob-card{z-index:8995;background:var(--surface);border:1px solid var(--border);border-radius:var(--r-xl,14px);pointer-events:all;opacity:0;padding:24px 22px 20px;transition:opacity .22s,transform .28s cubic-bezier(.25,1,.5,1);position:fixed;box-shadow:0 2px 8px #0000001a,0 8px 32px #0000002e,0 0 0 1px #0000000a}#ob-card.ob-mode-center{width:min(460px,100vw - 32px);top:50%;left:50%;transform:translate(-50%,-50%)scale(.94)}#ob-card.ob-mode-center.ob-in{opacity:1;transform:translate(-50%,-50%)scale(1)}#ob-card.ob-mode-center.ob-out{opacity:0;transform:translate(-50%,-50%)scale(.96)translateY(4px)}#ob-card.ob-mode-tooltip{transform:translateY(6px)}#ob-card.ob-mode-tooltip.ob-in{opacity:1;transform:translateY(0)}#ob-card.ob-mode-tooltip.ob-out{opacity:0;transform:translateY(-4px)}#ob-card.ob-mode-sheet{padding-bottom:max(24px, env(safe-area-inset-bottom,0px));border-radius:22px 22px 0 0;transform:translateY(24px);width:100%!important;inset:auto 0 0!important}#ob-card.ob-mode-sheet.ob-in{opacity:1;transform:translateY(0)}#ob-card.ob-mode-sheet.ob-out{opacity:0;transform:translateY(28px)}.ob-card-icon{color:var(--accent);margin-bottom:14px;line-height:0;display:block}.ob-card-icon svg{stroke-width:1.75px;width:38px;height:38px}.ob-card-title{color:var(--text);letter-spacing:-.01em;margin:0 0 10px;font-size:18px;font-weight:700;line-height:1.3}.ob-card-body{color:var(--text);margin:0 0 20px;font-size:14px;line-height:1.65}.ob-card-foot{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;display:flex}.ob-card-actions{flex-wrap:wrap;flex-shrink:0;align-items:center;gap:6px;display:flex}.ob-dots{flex-shrink:0;align-items:center;gap:5px;display:flex}.ob-dot{background:var(--border-strong,#ccc);border-radius:99px;flex-shrink:0;width:6px;height:6px;transition:all .25s cubic-bezier(.25,1,.5,1)}.ob-dot.ob-dot-active{background:var(--accent);width:20px}.ob-dot.ob-dot-done{background:var(--ok,#22c55e)}.ob-btn{border-radius:var(--r-md,6px);border:1px solid var(--border);cursor:pointer;white-space:nowrap;flex-shrink:0;align-items:center;gap:4px;padding:6px 11px;font-family:inherit;font-size:12px;font-weight:600;line-height:1;transition:opacity .12s,background .12s;display:inline-flex}.ob-btn:hover{opacity:.8}.ob-btn:active{opacity:.6}.ob-primary{background:var(--accent);color:#fff;border-color:var(--accent)}[data-theme=studio-dark] .ob-primary{color:#fff}.ob-ghost{color:var(--text);border-color:var(--border);background:0 0}@media (width<=768px){#ob-card.ob-mode-center,#ob-card.ob-mode-sheet{background:var(--bg);box-shadow:none;border:none;flex-direction:column;justify-content:flex-end;display:flex;overflow-y:auto;transform:translateY(20px);width:100%!important;height:100%!important;padding:40px 24px max(32px, env(safe-area-inset-bottom,32px))!important;border-radius:0!important;inset:0!important}#ob-card.ob-mode-center.ob-in,#ob-card.ob-mode-sheet.ob-in{opacity:1;transform:translateY(0)}#ob-card.ob-mode-center.ob-out,#ob-card.ob-mode-sheet.ob-out{opacity:0;transform:translateY(24px)}#ob-card.ob-mode-center .ob-card-icon,#ob-card.ob-mode-sheet .ob-card-icon{margin-bottom:20px}#ob-card.ob-mode-center .ob-card-icon svg,#ob-card.ob-mode-sheet .ob-card-icon svg{width:56px;height:56px}#ob-card.ob-mode-center .ob-card-title,#ob-card.ob-mode-sheet .ob-card-title{margin-bottom:14px;font-size:22px}#ob-card.ob-mode-center .ob-card-body,#ob-card.ob-mode-sheet .ob-card-body{margin-bottom:32px;font-size:16px;line-height:1.7}#ob-card.ob-mode-center .ob-card-foot,#ob-card.ob-mode-sheet .ob-card-foot{flex-direction:column;align-items:stretch;gap:14px}#ob-card.ob-mode-center .ob-card-actions,#ob-card.ob-mode-sheet .ob-card-actions{flex-direction:row-reverse;gap:8px;width:100%}#ob-card.ob-mode-center .ob-card-actions .ob-primary,#ob-card.ob-mode-sheet .ob-card-actions .ob-primary{border-radius:var(--r-lg,10px);flex:1;justify-content:center;padding:14px 20px;font-size:15px}#ob-card.ob-mode-center .ob-dots,#ob-card.ob-mode-sheet .ob-dots{justify-content:center}#ob-card.ob-mode-tooltip .ob-card-title{font-size:15px}#ob-card.ob-mode-tooltip .ob-card-body{font-size:13px}.ob-btn{padding:9px 14px}}.ob-demo-wrap{margin:0 0 20px}.ob-demo-card{background:var(--surface-2,var(--bg));border:1px solid var(--border);border-radius:var(--r-lg,10px);padding:14px 14px 12px;font-size:13px}.ob-demo-asset-row{align-items:center;gap:10px;margin-bottom:12px;display:flex}.ob-demo-icon-badge{border-radius:var(--r-md,6px);flex-shrink:0;justify-content:center;align-items:center;width:34px;height:34px;font-size:18px;display:flex}.ob-demo-asset-name{color:var(--text);font-size:13px;font-weight:600}.ob-demo-asset-sub{color:var(--text);opacity:.6;margin-top:1px;font-size:11px}.ob-demo-tl-row{justify-content:space-between;align-items:center;margin-bottom:5px;display:flex}.ob-demo-tl-name{color:var(--text);font-size:12px;font-weight:500}.ob-demo-tl-meta{color:var(--text);opacity:.6;margin-bottom:2px;font-size:11px}.ob-demo-chip{border-radius:99px;padding:2px 7px;font-size:11px;font-weight:700}.ob-chip-warn{background:var(--warn-bg);color:var(--warn)}.ob-chip-ok{background:var(--ok-bg);color:var(--ok)}.ob-chip-bad{background:var(--bad-bg);color:var(--bad)}.ob-demo-bar-track{background:var(--border);border-radius:99px;height:5px;margin-bottom:4px;overflow:hidden}.ob-demo-bar{border-radius:99px;height:100%;transition:width .6s}.ob-bar-ok{background:var(--ok)}.ob-bar-warn{background:var(--warn)}.ob-bar-bad{background:var(--bad)}.ob-demo-task-row{background:var(--surface);border-radius:var(--r-md,6px);border:1px solid var(--border);align-items:center;gap:10px;padding:10px;display:flex;position:relative;overflow:hidden}.ob-demo-status-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.ob-dot-ok{background:var(--ok)}.ob-dot-warn{background:var(--warn)}.ob-dot-bad{background:var(--bad);animation:2s ease-in-out infinite ob-pulse-dot}.ob-demo-task-info{flex:1;min-width:0}.ob-demo-task-name{color:var(--text);font-size:13px;font-weight:600}.ob-demo-task-sub{color:var(--text);opacity:.6;margin-top:1px;font-size:11px}@keyframes ob-pulse-dot{0%,to{opacity:1}50%{opacity:.4}}.ob-demo-tap-ring{border:2px solid var(--accent);border-radius:50%;width:28px;height:28px;animation:2s ease-in-out infinite ob-tap-ring;position:absolute;top:50%;right:12px;transform:translateY(-50%)}@keyframes ob-tap-ring{0%,to{opacity:0;transform:translateY(-50%)scale(.6)}30%{opacity:1;transform:translateY(-50%)scale(1)}60%{opacity:0;transform:translateY(-50%)scale(1.4)}}.ob-demo-tap-hint{text-align:center;color:var(--text);opacity:.55;margin-top:10px;font-size:11px}.ob-demo-swipe-track{border-radius:var(--r-md,6px);height:56px;position:relative;overflow:hidden}.ob-demo-swipe-bg{background:var(--bad-bg,#fef2f2);border-radius:var(--r-md,6px);border:1px solid var(--border);justify-content:flex-end;align-items:center;gap:4px;padding-right:12px;display:flex;position:absolute;inset:0}.ob-demo-swipe-act{border-radius:var(--r-sm,4px);padding:4px 10px;font-size:12px;font-weight:600}.ob-act-done{background:var(--ok);color:#fff}.ob-act-edit{background:var(--accent);color:#fff}.ob-demo-swipe-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--r-md,6px);align-items:center;gap:10px;padding:0 12px;display:flex;position:absolute;inset:0}@keyframes ob-swipe{0%,15%{transform:translate(0)}40%,60%{transform:translate(-90px)}85%,to{transform:translate(0)}}.ob-swipe-anim{animation:3s cubic-bezier(.4,0,.2,1) infinite ob-swipe}.ob-demo-swipe-hint{text-align:center;color:var(--text);opacity:.55;margin-top:8px;font-size:11px}.ob-pulse-ring{z-index:8992;border:2px solid var(--accent);pointer-events:none;opacity:0;border-radius:10px;animation:2s ease-in-out infinite ob-pulse;position:fixed}@keyframes ob-pulse{0%,to{opacity:.3;box-shadow:0 0 0 0 var(--accent)}50%{opacity:1;box-shadow:0 0 0 6px #0000}}
