*,*:before,*:after{box-sizing:border-box}html,body{height:100%}body{margin:0;font-family:var(--sans);font-weight:400;-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;background:var(--bg);color:var(--text)}button{font-family:inherit;cursor:pointer}input,select,button,textarea{font-family:inherit;font-size:inherit;color:inherit}::selection{background:color-mix(in oklab,var(--primary) 38%,transparent)}:root{--mono: "IBM Plex Mono", ui-monospace, monospace;--sans: "IBM Plex Sans", system-ui, sans-serif;--s1: 4px;--s2: 8px;--s3: 12px;--s4: 16px;--s5: 20px;--s6: 24px;--s7: 32px;--s8: 40px;--s9: 56px;--primary: #2f7fff;--primary-hover: #4a90ff;--primary-press: #2b73e8;--on-primary: #07101f;--secondary: #6fb4ff;--ring: color-mix(in oklab, var(--primary) 55%, transparent);--danger: #f2666b;--danger-bg: color-mix(in oklab, var(--danger) 14%, transparent);--success: #34d399;--warning: #f5b14c;--transition: .14s cubic-bezier(.4,0,.2,1);--chevron-url: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" width="14" height="14" viewBox="0 0 24 24" fill="none" stroke="%235b6675" stroke-width="2" stroke-linecap="round" stroke-linejoin="round"><path d="M6 9l6 6 6-6"/></svg>');--bg: #0c0e12;--surface-1: #12151b;--surface-2: #171b22;--surface-3: #1e242d;--elevated: #1a1f28;--paper-surround: #0a0c0f;--border: #262d39;--border-strong: #38414f;--border-faint: #1c222b;--text: #e7ebf2;--text-dim: #9aa6b6;--muted: #5b6675;--radius-sm: 4px;--radius: 6px;--radius-lg: 8px;--radius-xl: 10px;--shadow-card: 0 1px 0 rgba(0,0,0,.4);--shadow-pop: 0 16px 44px rgba(0,0,0,.55);--shadow-paper: 0 4px 22px rgba(0,0,0,.5);--grid-opacity: 1;--grid-size: 40px;--card-pad: 18px;--nav-radius: 6px}[data-theme=light]{--bg: #eceef2;--surface-1: #ffffff;--surface-2: #ffffff;--surface-3: #eceef2;--elevated: #ffffff;--paper-surround: #dde0e6;--border: #e2e5ea;--border-strong: #c9ced7;--border-faint: #e9ebef;--text: #1a1d23;--text-dim: #525b68;--muted: #8b94a1;--shadow-card: 0 1px 2px rgba(18,24,38,.06);--shadow-pop: 0 18px 48px rgba(18,24,38,.18);--shadow-paper: 0 6px 26px rgba(18,24,38,.14)}h1,h2,h3,h4{margin:0;font-weight:600;letter-spacing:-.01em}.label-mono{font-family:var(--mono);font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.12em;color:var(--muted)}.app-root{position:fixed;inset:0;display:flex;flex-direction:column;background:var(--bg);overflow:hidden}.app-root:before{content:"";position:absolute;inset:0;pointer-events:none;opacity:var(--grid-opacity);background-image:linear-gradient(to right,var(--border-faint) 1px,transparent 1px),linear-gradient(to bottom,var(--border-faint) 1px,transparent 1px);background-size:var(--grid-size) var(--grid-size);-webkit-mask-image:radial-gradient(120% 120% at 50% 40%,#000 35%,transparent 100%);mask-image:radial-gradient(120% 120% at 50% 40%,#000 35%,transparent 100%);z-index:0}.fullscreen-notice{position:fixed;inset:0;z-index:9999;background:var(--bg);color:var(--text-dim);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);text-align:center;padding:var(--s7)}.fullscreen-notice .label-mono{color:var(--primary)}.fullscreen-notice .notice-icon{color:var(--muted)}.fullscreen-notice p{margin:0;max-width:360px;line-height:1.6}*::-webkit-scrollbar{width:11px;height:11px}*::-webkit-scrollbar-thumb{background:var(--surface-3);border-radius:8px;border:3px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:var(--border-strong);background-clip:padding-box}.ic{flex:none;vertical-align:middle}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--s2);height:36px;padding:0 var(--s4);border:1px solid transparent;border-radius:var(--radius);background:transparent;color:var(--text);font-size:13px;font-weight:500;white-space:nowrap;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition),box-shadow var(--transition)}.btn:active{transform:scale(.975)}.btn .ic{width:16px;height:16px}.btn-primary{background:var(--primary);color:var(--on-primary);font-weight:600;box-shadow:0 1px color-mix(in oklab,var(--primary) 60%,#fff 0%),inset 0 1px color-mix(in oklab,#fff 22%,transparent)}.btn-primary:hover{background:var(--primary-hover)}.btn-primary:active{background:var(--primary-press)}.btn-primary:disabled{opacity:.6;cursor:default;transform:none}.btn-secondary{border-color:var(--border-strong);background:var(--surface-2);color:var(--text)}.btn-secondary:hover{background:var(--surface-3);border-color:var(--border-strong)}.btn-ghost{color:var(--text-dim)}.btn-ghost:hover{background:var(--surface-3);color:var(--text)}.btn-danger{border-color:color-mix(in oklab,var(--danger) 45%,transparent);background:var(--danger-bg);color:var(--danger);font-weight:600}.btn-danger:hover{background:color-mix(in oklab,var(--danger) 22%,transparent)}.btn-sm{height:30px;padding:0 var(--s3);font-size:12px;border-radius:var(--radius-sm)}.btn-icon{width:34px;height:34px;padding:0}.field{display:flex;flex-direction:column;gap:var(--s2)}.field>.label-mono{margin-bottom:2px}.input,.select{height:40px;width:100%;padding:0 var(--s4);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;transition:border-color var(--transition),box-shadow var(--transition),background var(--transition)}.input::placeholder{color:var(--muted);opacity:.7}.input:focus,.select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.select{appearance:none;background-image:var(--chevron-url);background-repeat:no-repeat;background-position:right 12px center;padding-right:38px;cursor:pointer}.badge{display:inline-flex;align-items:center;gap:5px;height:19px;padding:0 7px;border-radius:5px;font-family:var(--mono);font-size:10px;font-weight:500;letter-spacing:.06em;text-transform:uppercase;border:1px solid var(--border-strong);color:var(--text-dim)}.badge-share{border-color:color-mix(in oklab,var(--secondary) 50%,transparent);color:var(--secondary)}.badge-readonly{border-color:color-mix(in oklab,var(--warning) 45%,transparent);color:var(--warning)}.avatar{display:inline-flex;align-items:center;justify-content:center;border-radius:50%;font-family:var(--mono);font-weight:500;color:#fff;font-size:11px;flex:none}.state{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--s4);text-align:center;padding:var(--s9) var(--s6);border:1px dashed var(--border-strong);border-radius:var(--radius-xl);background:color-mix(in oklab,var(--surface-2) 50%,transparent)}.state .state-icon{width:56px;height:56px;border-radius:14px;display:flex;align-items:center;justify-content:center;background:var(--surface-3);color:var(--text-dim);border:1px solid var(--border)}.state .state-icon .ic{width:26px;height:26px}.state h3{font-size:16px;font-weight:600}.state p{color:var(--muted);font-size:13.5px;max-width:320px;margin:-8px 0 4px}.skeleton-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:var(--s5)}.skeleton{height:244px;border-radius:var(--radius-lg);border:1px solid var(--border);background:linear-gradient(100deg,transparent 30%,color-mix(in oklab,var(--surface-3) 70%,transparent) 50%,transparent 70%),var(--surface-2);background-size:200% 100%,auto;animation:shimmer 1.3s linear infinite}@keyframes shimmer{0%{background-position:200% 0,0 0}to{background-position:-200% 0,0 0}}.seg{display:flex;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:3px;gap:3px}.seg button{display:flex;align-items:center;gap:7px;border:0;background:transparent;color:var(--text-dim);font-family:var(--mono);font-size:12.5px;font-weight:500;height:32px;padding:0 16px;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.seg button .ic{width:16px;height:16px}.seg button.on{background:var(--surface-3);color:var(--text);box-shadow:0 1px 2px #00000047}.seg button.on .ic{color:var(--primary)}.seg button:not(.on):hover{color:var(--text)}.auth-root{align-items:center;justify-content:center}.auth-wrap{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;gap:var(--s5)}.auth-wrap:before{content:"";position:absolute;z-index:-1;width:620px;height:620px;left:50%;top:50%;transform:translate(-50%,-52%);background:radial-gradient(circle,color-mix(in oklab,var(--primary) 14%,transparent),transparent 62%);pointer-events:none}.auth-card{width:400px;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-xl);padding:var(--s8);display:flex;flex-direction:column;gap:var(--s4);box-shadow:var(--shadow-pop)}.auth-brand{display:flex;align-items:center;gap:var(--s2);font-family:var(--mono);font-size:22px;font-weight:600;letter-spacing:-.01em;color:var(--text)}.auth-brand .ic,.auth-brand b{color:var(--primary)}.auth-sub{color:var(--muted);font-size:13.5px;margin:-6px 0 var(--s2)}.auth-toggle{display:grid;grid-template-columns:1fr 1fr;gap:3px;background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);padding:3px;margin-bottom:var(--s1)}.auth-toggle button{border:0;background:transparent;color:var(--text-dim);font-family:var(--mono);font-size:12.5px;font-weight:500;height:32px;border-radius:var(--radius-sm);transition:background var(--transition),color var(--transition)}.auth-toggle button.on{background:var(--surface-3);color:var(--text);box-shadow:0 1px 2px #0000004d}.auth-toggle button:not(.on):hover{color:var(--text)}.auth-msg{padding:var(--s3);border-radius:var(--radius);font-size:12.5px;background:var(--danger-bg);color:var(--danger);border:1px solid color-mix(in oklab,var(--danger) 40%,transparent)}.auth-submit{width:100%;height:42px;margin-top:var(--s1)}.auth-foot{text-align:center;color:var(--muted);font-size:12.5px;margin:0}.linkish{background:none;border:0;color:var(--primary);font:inherit;padding:0;cursor:pointer}.linkish:hover{text-decoration:underline}.auth-tag{opacity:.6}.shell{display:flex;flex:1;min-height:0;position:relative;z-index:1}.sidebar{width:240px;flex:none;background:var(--surface-1);border-right:1px solid var(--border);display:flex;flex-direction:column;padding:var(--s5) var(--s4)}.brand{display:flex;align-items:center;gap:var(--s2);font-family:var(--mono);font-size:17px;font-weight:600;letter-spacing:-.01em;color:var(--text);margin-bottom:2px}.brand .ic{color:var(--primary);width:20px;height:20px}.brand b{color:var(--primary);font-weight:600}.user-chip{display:flex;align-items:center;gap:var(--s2);margin:var(--s4) 0 var(--s5);padding:var(--s2) var(--s2);font-size:12px;color:var(--muted);overflow:hidden}.user-chip .avatar{width:22px;height:22px;flex:none}.user-chip span:not(.avatar){overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.nav{display:flex;flex-direction:column;gap:3px;flex:1;min-height:0}.nav-item{display:flex;align-items:center;gap:var(--s3);height:38px;padding:0 var(--s3);border-radius:var(--nav-radius);background:transparent;border:0;color:var(--text-dim);font-size:13.5px;font-weight:500;text-align:left;width:100%;transition:background var(--transition),color var(--transition)}.nav-item .ic{color:var(--muted);transition:color var(--transition)}.nav-item:hover{background:var(--surface-3);color:var(--text)}.nav-item:hover .ic{color:var(--text-dim)}.nav-item.active{background:color-mix(in oklab,var(--primary) 15%,transparent);color:var(--primary)}.nav-item.active .ic{color:var(--primary)}.nav-spacer{flex:1}.sign-out{color:var(--muted)}.sign-out:hover{background:var(--danger-bg);color:var(--danger)}.sign-out:hover .ic{color:var(--danger)}.content{flex:1;min-width:0;overflow:auto;padding:var(--s8) var(--s9)}.content-inner{max-width:1120px;margin:0 auto}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:var(--s4);margin-bottom:var(--s7)}.page-head h1{font-size:26px;font-weight:600}.page-head .sub{color:var(--muted);font-size:14px;margin:4px 0 0}.section-label{margin:var(--s7) 0 var(--s4);display:flex;align-items:center;gap:var(--s3)}.section-label:after{content:"";flex:1;height:1px;background:var(--border)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));gap:var(--s5)}.canvas-card{display:flex;flex-direction:column;background:var(--surface-2);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;text-align:left;padding:0;transition:border-color var(--transition),transform var(--transition),box-shadow var(--transition),background var(--transition);box-shadow:var(--shadow-card)}.canvas-card:hover{border-color:var(--primary);transform:translateY(-3px);box-shadow:var(--shadow-pop)}.thumb{height:132px;background:var(--paper-surround);border-bottom:1px solid var(--border);display:flex;justify-content:center;padding:16px 16px 0;overflow:hidden}.thumb .sheet{width:100%;background:#fbfbfa;border-radius:3px 3px 0 0;padding:13px 14px;box-shadow:0 3px 14px #00000059}.sheet .ln{height:4px;border-radius:2px;background:#d7d8db;margin-bottom:6px}.sheet .ln.h{height:7px;width:58%;background:#2f3640;margin-bottom:9px}.sheet .ln.s{width:90%}.sheet .ln.m{width:76%}.sheet .ln.x{width:64%}.sheet .ln.accent{width:34%;background:color-mix(in oklab,var(--primary) 70%,#777)}.card-body{padding:var(--card-pad);display:flex;flex-direction:column;gap:var(--s2)}.card-title{font-size:14.5px;font-weight:600;color:var(--text);line-height:1.3}.card-meta{display:flex;align-items:center;gap:7px;font-size:12px;color:var(--muted)}.card-meta .ic{width:13px;height:13px}.card-foot{display:flex;align-items:center;justify-content:space-between;margin-top:2px}.card-date{font-family:var(--mono);font-size:11px;color:var(--muted);letter-spacing:.02em}.tree{display:flex;flex-direction:column;gap:2px}.folder-block{border-radius:var(--radius-lg)}.tree-row{display:flex;align-items:center;gap:var(--s2);height:42px;padding:0 var(--s3);border-radius:var(--radius);position:relative;transition:background var(--transition)}.tree-row:hover{background:var(--surface-2)}.twisty{display:flex;align-items:center;justify-content:center;width:22px;height:22px;flex:none;border:0;background:transparent;color:var(--muted);border-radius:4px;transition:transform var(--transition),color var(--transition),background var(--transition)}.twisty .ic{width:15px;height:15px}.tree-row[data-open=true] .twisty{transform:rotate(90deg)}.twisty:hover{background:var(--surface-3);color:var(--text)}.folder-ico{color:var(--secondary);display:flex}.folder-ico .ic{width:18px;height:18px}.tree-name{font-size:14px;font-weight:600;color:var(--text)}.tree-row .badge{margin-left:var(--s2)}.tree-actions{margin-left:auto;display:flex;align-items:center;gap:2px;opacity:0;transform:translate(6px);transition:opacity var(--transition),transform var(--transition)}.tree-row:hover .tree-actions{opacity:1;transform:none}.tree-actions .btn-icon{width:30px;height:30px;color:var(--text-dim)}.tree-actions .btn-icon .ic{width:16px;height:16px}.tree-actions .btn-icon:hover{background:var(--surface-3);color:var(--text)}.tree-actions .btn-icon.danger:hover{background:var(--danger-bg);color:var(--danger)}.children{margin-left:27px;padding-left:var(--s4);border-left:1px solid var(--border);display:none;flex-direction:column}.children.expanded{display:flex}.child-row{display:flex;align-items:center;gap:var(--s2);height:34px;padding:0 var(--s3);border-radius:var(--radius-sm);color:var(--text-dim);font-size:13px;cursor:pointer;transition:background var(--transition),color var(--transition)}.child-row .ic{width:15px;height:15px;color:var(--muted)}.child-row:hover{background:var(--surface-2);color:var(--primary)}.child-row:hover .ic{color:var(--primary)}.child-row .tree-name{flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.child-row:hover .tree-actions{opacity:1;transform:none}.child-empty{font-style:italic;color:var(--muted);font-size:12.5px;padding:6px var(--s3)}#zm-modal-overlay{position:fixed;inset:0;z-index:9999;background:#0000009e;-webkit-backdrop-filter:blur(5px);backdrop-filter:blur(5px);display:flex;align-items:center;justify-content:center}#zm-modal{width:440px;max-width:calc(100vw - 48px);background:var(--elevated);border:1px solid var(--border-strong);border-radius:var(--radius-xl);box-shadow:var(--shadow-pop),0 0 0 1px color-mix(in oklab,var(--primary) 14%,transparent);animation:zm-rise .18s cubic-bezier(.2,.7,.3,1) both;overflow:hidden}@keyframes zm-rise{0%{opacity:.55;transform:translateY(12px) scale(.985)}to{opacity:1;transform:none}}#zm-modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--s5) var(--s5) var(--s4)}#zm-modal-title{font-family:var(--mono);font-size:14px;font-weight:600;color:var(--text);letter-spacing:.02em}#zm-modal-close{display:inline-flex;align-items:center;justify-content:center;width:34px;height:34px;background:transparent;border:none;color:var(--text-dim);border-radius:var(--radius);transition:color var(--transition),background var(--transition)}#zm-modal-close:hover{color:var(--text);background:var(--surface-3)}#zm-modal-body{padding:0 var(--s5) var(--s5);display:flex;flex-direction:column;gap:var(--s4)}#zm-modal-error{display:flex;align-items:flex-start;gap:var(--s2);padding:var(--s3);background:var(--danger-bg);border:1px solid color-mix(in oklab,var(--danger) 40%,transparent);border-radius:var(--radius);color:var(--danger);font-size:12.5px;line-height:1.45}.zm-modal-note{margin:0;color:var(--muted);font-size:12px;line-height:1.5}.zm-modal-note code{font-family:var(--mono);color:var(--danger);background:var(--danger-bg);padding:1px 5px;border-radius:4px}.zm-modal-note .zm-strong{color:var(--text);font-weight:600}.zm-field{display:flex;flex-direction:column;gap:var(--s2)}.zm-label{font-family:var(--mono);font-size:11px;font-weight:500;color:var(--muted);text-transform:uppercase;letter-spacing:.12em}.zm-input,.zm-select{height:40px;width:100%;padding:0 var(--s4);background:var(--bg);border:1px solid var(--border);border-radius:var(--radius);color:var(--text);font-size:14px;outline:none;transition:border-color var(--transition),box-shadow var(--transition)}.zm-input:focus,.zm-select:focus{border-color:var(--primary);box-shadow:0 0 0 3px var(--ring)}.zm-input::placeholder{color:var(--muted);opacity:.7}.zm-textarea{height:auto;min-height:96px;padding:var(--s3) var(--s4);line-height:1.5;font-family:inherit;resize:vertical}.zm-select{cursor:pointer;appearance:none;background-image:var(--chevron-url);background-repeat:no-repeat;background-position:right 12px center;padding-right:38px}.inline-link{align-self:flex-start;background:none;border:0;padding:2px 0;font-family:var(--mono);font-size:12px;color:var(--primary);display:inline-flex;align-items:center;gap:5px;cursor:pointer}.inline-link:hover{text-decoration:underline}#zm-modal-footer{display:flex;justify-content:flex-end;gap:var(--s3);padding:var(--s4) var(--s5);border-top:1px solid var(--border);background:color-mix(in oklab,var(--bg) 40%,transparent)}.zm-btn{display:inline-flex;align-items:center;justify-content:center;height:36px;padding:0 var(--s4);border-radius:var(--radius);font-size:13px;font-weight:500;border:1px solid transparent;transition:background var(--transition),border-color var(--transition),color var(--transition),transform var(--transition)}.zm-btn:active{transform:scale(.975)}.zm-btn:disabled{opacity:.5;cursor:not-allowed}.zm-btn-secondary{background:transparent;color:var(--text-dim)}.zm-btn-secondary:hover:not(:disabled){background:var(--surface-3);color:var(--text)}.zm-btn-primary{background:var(--primary);color:var(--on-primary);font-weight:600}.zm-btn-primary:hover:not(:disabled){background:var(--primary-hover)}.zm-btn-danger{border-color:color-mix(in oklab,var(--danger) 45%,transparent);background:var(--danger-bg);color:var(--danger);font-weight:600}.zm-btn-danger:hover:not(:disabled){background:color-mix(in oklab,var(--danger) 22%,transparent)}
