*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f4f0;--panel-bg: #ffffff;--panel-bg-2: #fafaf7;--border: #e8e5df;--border-light: #f0ede7;--text: #1c1a18;--text-2: #4a4745;--text-3: #8a8784;--text-4: #b8b5b0;--accent: #2563eb;--accent-bg: #eff6ff;--accent-hover: #1d4ed8;--success: #16a34a;--danger: #dc2626;--danger-bg: #fef2f2;--topbar-h: 48px;--lib-w: 230px;--editor-w: 310px;--radius: 7px;--radius-sm: 5px;--font: "DM Sans", -apple-system, "Segoe UI", sans-serif;--font-mono: "DM Mono", "Fira Code", monospace;--shadow-sm: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-md: 0 4px 12px rgba(0,0,0,.09), 0 1px 4px rgba(0,0,0,.05);--shadow-lg: 0 12px 32px rgba(0,0,0,.13), 0 4px 12px rgba(0,0,0,.08)}html,body,#root{height:100%;overflow:hidden;font-family:var(--font);font-size:13px;color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:none}input,textarea{font-family:inherit}a{color:var(--accent)}.app{display:flex;flex-direction:column;height:100%;background:var(--bg)}.app-body{display:flex;flex:1;overflow:hidden;gap:1px;background:var(--border)}.topbar{height:var(--topbar-h);background:var(--panel-bg);border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 12px 0 80px;gap:8px;position:relative;flex-shrink:0;-webkit-app-region:drag}.drag-region{-webkit-app-region:drag}.no-drag{-webkit-app-region:no-drag}.topbar-left{display:flex;align-items:center;gap:8px;min-width:120px}.topbar-app-name{font-size:12px;font-weight:500;color:var(--text-3);letter-spacing:.01em}.topbar-center{flex:1;display:flex;justify-content:center;align-items:center}.topbar-name-btn{font-size:13.5px;font-weight:500;color:var(--text);padding:4px 10px;border-radius:var(--radius-sm);transition:background .15s;display:flex;align-items:center;gap:6px}.topbar-name-btn:hover{background:var(--bg)}.topbar-dirty{color:var(--accent);font-size:18px;line-height:1;margin-top:-2px}.topbar-name-input{font-size:13.5px;font-weight:500;color:var(--text);border:1.5px solid var(--accent);border-radius:var(--radius-sm);padding:3px 8px;outline:none;background:#fff;min-width:200px;text-align:center}.topbar-right{display:flex;align-items:center;gap:6px;min-width:120px;justify-content:flex-end}.topbar-btn{display:flex;align-items:center;gap:5px;padding:5px 10px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:450;transition:background .12s,color .12s;height:30px}.topbar-btn--ghost{color:var(--text-2);background:transparent}.topbar-btn--ghost:hover{background:var(--bg);color:var(--text)}.topbar-btn--primary{background:var(--accent);color:#fff;font-weight:500}.topbar-btn--primary:hover{background:var(--accent-hover)}.topbar-btn--primary:disabled{opacity:.6;cursor:not-allowed}.topbar-btn--icon{color:var(--text-3);padding:5px 6px}.topbar-btn--icon:hover{background:var(--bg);color:var(--text)}.topbar-divider{width:1px;height:20px;background:var(--border);margin:0 2px}.topbar-dropdown-wrap{position:relative}.topbar-dropdown{position:absolute;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-md);min-width:180px;padding:4px;z-index:200}.topbar-dropdown button{display:block;width:100%;text-align:left;padding:7px 10px;font-size:12.5px;color:var(--text-2);border-radius:var(--radius-sm);transition:background .1s}.topbar-dropdown button:hover{background:var(--bg);color:var(--text)}.dropdown-divider{height:1px;background:var(--border);margin:3px 0}.lib-panel{width:var(--lib-w);background:var(--panel-bg-2);border-right:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.lib-header{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 10px;flex-shrink:0}.lib-title{font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.lib-new-btn{display:flex;align-items:center;gap:4px;font-size:12px;font-weight:500;color:var(--accent);padding:3px 8px;border-radius:var(--radius-sm);transition:background .12s}.lib-new-btn:hover{background:var(--accent-bg)}.lib-search-wrap{position:relative;padding:0 10px 8px;flex-shrink:0}.lib-search-icon{position:absolute;left:18px;top:50%;transform:translateY(-60%);pointer-events:none}.lib-search{width:100%;padding:6px 8px 6px 28px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text);background:#fff;outline:none;transition:border-color .15s}.lib-search:focus{border-color:var(--accent)}.lib-section{padding:6px 10px;flex-shrink:0}.lib-section--files{flex:1;overflow-y:auto;padding-bottom:20px}.lib-section-head{display:flex;align-items:center;justify-content:space-between;padding:2px 4px 6px;font-size:10.5px;font-weight:600;letter-spacing:.05em;text-transform:uppercase;color:var(--text-4)}.lib-icon-btn{font-size:15px;color:var(--text-4);line-height:1;padding:1px 4px;border-radius:3px;transition:background .1s,color .1s}.lib-icon-btn:hover{background:var(--border);color:var(--text-2)}.lib-folder-row{display:flex;align-items:center}.lib-folder-del{opacity:0;transition:opacity .1s;margin-left:2px}.lib-folder-row:hover .lib-folder-del{opacity:1}.lib-folder{display:flex;align-items:center;gap:7px;padding:5px 8px;border-radius:var(--radius-sm);font-size:12.5px;color:var(--text-2);width:100%;text-align:left;transition:background .1s;cursor:pointer}.lib-folder:hover{background:var(--border-light)}.lib-folder--active{background:var(--accent-bg);color:var(--accent);font-weight:500}.lib-folder--active svg path{stroke:var(--accent)}.lib-count{margin-left:auto;font-size:11px;color:var(--text-4);background:var(--border-light);padding:1px 5px;border-radius:8px}.lib-inline-edit{flex:1;font-size:12.5px;border:1.5px solid var(--accent);border-radius:3px;padding:2px 6px;outline:none;color:var(--text)}.lib-file{padding:8px;border-radius:var(--radius-sm);cursor:pointer;transition:background .1s;margin-bottom:2px;border:1px solid transparent}.lib-file:hover{background:#fff;border-color:var(--border)}.lib-file--active{background:#fff;border-color:var(--accent)}.lib-file--locked{opacity:.7}.lib-file-name{font-size:12.5px;font-weight:450;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}.lib-file-meta{display:flex;align-items:center;justify-content:space-between;margin-top:2px;font-size:11px;color:var(--text-4)}.lib-file-del{color:var(--text-4);padding:2px 3px;border-radius:3px;opacity:0;transition:opacity .1s,background .1s}.lib-file:hover .lib-file-del{opacity:1}.lib-file-del:hover{background:var(--danger-bg);color:var(--danger)}.lib-empty-hint{padding:10px 8px;font-size:12px;color:var(--text-4)}.center-col{flex:1;display:flex;flex-direction:column;overflow:hidden;background:var(--bg)}.preview-pane{flex:1;display:flex;flex-direction:column;overflow:hidden}.preview-empty{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg)}.preview-empty-inner{text-align:center;color:var(--text-3)}.preview-empty-inner p{margin-top:10px;font-size:13px}.preview-empty-sub{font-size:12px;color:var(--text-4);margin-top:4px}.preview-frame-wrap{flex:1;display:flex;flex-direction:column;padding:16px;overflow:hidden}.preview-chrome{flex:1;background:#fff;border-radius:10px;box-shadow:var(--shadow-md);overflow:hidden;display:flex;flex-direction:column;border:1px solid var(--border)}.preview-chrome-bar{height:36px;background:#f3f3f3;border-bottom:1px solid var(--border);display:flex;align-items:center;padding:0 14px;gap:6px;flex-shrink:0}.preview-chrome-dot{width:11px;height:11px;border-radius:50%;display:inline-block;opacity:.8}.preview-chrome-label{flex:1;text-align:center;font-size:11px;color:var(--text-4);margin-right:55px}.preview-iframe{flex:1;border:none;width:100%}.source-panel{flex:1;display:flex;flex-direction:column;overflow:hidden;margin:16px;background:#fff;border:1px solid var(--border);border-radius:var(--radius)}.source-panel-header{padding:8px 14px;border-bottom:1px solid var(--border);font-size:12px;font-weight:500;color:var(--text-3);flex-shrink:0}.source-pre{flex:1;overflow:auto;padding:14px;font-family:var(--font-mono);font-size:11.5px;line-height:1.7;color:var(--text-2);white-space:pre-wrap;word-break:break-all}.ef-panel{width:var(--editor-w);background:var(--panel-bg);border-left:1px solid var(--border);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0}.ef-panel-header{padding:14px 16px 10px;border-bottom:1px solid var(--border-light);flex-shrink:0}.ef-panel-title{display:block;font-size:11px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-3)}.ef-panel-sub{display:block;font-size:11px;color:var(--text-4);margin-top:2px}.ef-scroll{flex:1;overflow-y:auto;padding:10px 0 0}.ef-bottom-space{height:40px}.ef-group{margin-bottom:4px}.ef-group-header{display:flex;align-items:center;gap:7px;padding:8px 16px 6px}.ef-group-icon{font-size:13px}.ef-group-title{font-size:11px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--text-3)}.ef-group-body{padding:0 0 12px;border-bottom:1px solid var(--border-light)}.ef-group-body:last-child{border-bottom:none}.ef-field{padding:6px 16px}.ef-label{display:block;font-size:11.5px;font-weight:500;color:var(--text-3);margin-bottom:4px}.ef-hint{display:block;font-size:11px;color:var(--text-4);margin-bottom:5px;font-style:italic}.ef-input{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:12.5px;color:var(--text);background:#fff;outline:none;transition:border-color .15s,box-shadow .15s}.ef-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb14}.ef-input::placeholder{color:var(--text-4)}.ef-textarea{width:100%;padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:12px;color:var(--text);background:#fff;outline:none;resize:vertical;line-height:1.6;font-family:var(--font);transition:border-color .15s,box-shadow .15s}.ef-textarea:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb14}.ef-textarea::placeholder{color:var(--text-4)}.ef-url-wrap{position:relative}.ef-url-icon{position:absolute;left:9px;top:50%;transform:translateY(-50%);pointer-events:none}.ef-input--url{padding-left:28px}.ef-image-row{display:flex;align-items:flex-start;gap:8px}.ef-thumb-wrap{width:48px;height:36px;flex-shrink:0;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border);background:var(--bg)}.ef-thumb{width:100%;height:100%;object-fit:cover}.ef-thumb-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:var(--bg)}.ef-input--image-url{flex:1;font-size:11.5px}.ef-empty{flex:1;display:flex;align-items:center;justify-content:center;padding:20px}.ef-empty-inner{text-align:center}.ef-empty-icon{font-size:28px;margin-bottom:10px}.ef-empty-title{font-size:13.5px;font-weight:500;color:var(--text);margin-bottom:6px}.ef-empty-sub{font-size:12px;color:var(--text-3);line-height:1.6}.ef-empty-btn{margin-top:14px;background:var(--accent);color:#fff;padding:7px 16px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;transition:background .12s}.ef-empty-btn:hover{background:var(--accent-hover)}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000040;display:flex;align-items:center;justify-content:center;z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);width:480px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.settings-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px 14px;border-bottom:1px solid var(--border)}.settings-header h2{font-size:16px;font-weight:600;color:var(--text)}.settings-close{color:var(--text-3);padding:4px;border-radius:4px;transition:background .1s}.settings-close:hover{background:var(--bg);color:var(--text)}.settings-tabs{display:flex;gap:2px;padding:10px 16px 0;border-bottom:1px solid var(--border)}.settings-tab{padding:7px 14px;font-size:13px;font-weight:450;color:var(--text-3);border-radius:var(--radius-sm) var(--radius-sm) 0 0;transition:background .1s,color .1s;border-bottom:2px solid transparent;margin-bottom:-1px}.settings-tab:hover{color:var(--text)}.settings-tab--active{color:var(--accent);font-weight:500;border-bottom-color:var(--accent)}.settings-body{padding:20px;overflow-y:auto}.settings-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.06em;color:var(--text-3);margin-bottom:8px}.settings-desc{font-size:12.5px;color:var(--text-2);line-height:1.6;margin-bottom:16px}.settings-toggle-row{display:flex;align-items:center;justify-content:space-between;padding:10px 0;border-bottom:1px solid var(--border-light)}.settings-toggle-label{font-size:13px;font-weight:450;color:var(--text)}.settings-toggle-sub{font-size:11.5px;color:var(--text-3);margin-top:2px}.settings-toggle{width:38px;height:22px;background:var(--border);border-radius:11px;position:relative;transition:background .2s;flex-shrink:0}.settings-toggle--on{background:var(--accent)}.settings-toggle-knob{position:absolute;top:3px;left:3px;width:16px;height:16px;background:#fff;border-radius:50%;box-shadow:0 1px 3px #00000026;transition:transform .2s}.settings-toggle--on .settings-toggle-knob{transform:translate(16px)}.settings-btn-row{display:flex;gap:8px;margin-top:14px}.settings-action-btn{padding:7px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:500;background:var(--accent);color:#fff;transition:background .12s}.settings-action-btn:hover{background:var(--accent-hover)}.settings-action-btn--danger{background:var(--danger)}.settings-action-btn--danger:hover{background:#b91c1c}.settings-action-btn--ghost{background:var(--bg);color:var(--text-2);border:1px solid var(--border)}.settings-action-btn--ghost:hover{background:var(--border)}.settings-form{margin-top:14px;display:flex;flex-direction:column;gap:12px}.settings-field{display:flex;flex-direction:column;gap:5px;font-size:12.5px;color:var(--text-2)}.settings-input{padding:7px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;outline:none;transition:border-color .15s}.settings-input:focus{border-color:var(--accent)}.settings-msg{font-size:12.5px;margin-top:4px}.settings-msg--ok{color:var(--success)}.settings-msg--err{color:var(--danger)}.ntm-modal{background:#fff;border-radius:12px;box-shadow:var(--shadow-lg);width:520px;max-height:80vh;display:flex;flex-direction:column;overflow:hidden}.ntm-body{padding:16px 20px;overflow-y:auto;flex:1}.ntm-loading{padding:20px;text-align:center;color:var(--text-3);font-size:13px}.ntm-card{width:100%;display:flex;align-items:center;gap:14px;padding:14px 16px;border:1.5px solid var(--border);border-radius:var(--radius);margin-bottom:10px;text-align:left;transition:border-color .15s,box-shadow .15s;background:#fff}.ntm-card:hover{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb14}.ntm-card-icon{font-size:24px;flex-shrink:0}.ntm-card-info{flex:1}.ntm-card-name{font-size:13.5px;font-weight:500;color:var(--text);margin-bottom:3px}.ntm-card-desc{font-size:12px;color:var(--text-3);line-height:1.5}.ntm-card-cat{display:inline-block;margin-top:6px;font-size:10.5px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:var(--accent);background:var(--accent-bg);padding:2px 7px;border-radius:20px}.ntm-card-arrow{color:var(--text-4);flex-shrink:0}.ntm-footer{padding:12px 20px 16px;border-top:1px solid var(--border)}.ntm-footer-note{font-size:12px;color:var(--text-3);line-height:1.5}.lib-dialog-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0000004d;display:flex;align-items:center;justify-content:center;z-index:2000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.lib-dialog{background:#fff;border-radius:10px;box-shadow:var(--shadow-lg);width:360px;padding:22px}.lib-dialog-title{font-size:15px;font-weight:600;color:var(--text);margin-bottom:12px}.lib-dialog-msg{font-size:13px;color:var(--text-2);line-height:1.6;margin-bottom:14px}.lib-dialog-input{width:100%;padding:8px 10px;border:1.5px solid var(--border);border-radius:var(--radius-sm);font-size:13px;outline:none;font-family:var(--font);transition:border-color .15s;margin-bottom:8px}.lib-dialog-input:focus{border-color:var(--accent)}.lib-dialog-err{font-size:12px;color:var(--danger);margin-bottom:8px}.lib-dialog-btns{display:flex;gap:8px;justify-content:flex-end;margin-top:6px}.lib-dialog-cancel{padding:7px 14px;font-size:13px;color:var(--text-2);background:var(--bg);border-radius:var(--radius-sm);border:1px solid var(--border);font-family:var(--font);transition:background .1s}.lib-dialog-cancel:hover{background:var(--border)}.lib-dialog-ok{padding:7px 14px;font-size:13px;color:#fff;background:var(--accent);border-radius:var(--radius-sm);font-family:var(--font);font-weight:500;transition:background .12s}.lib-dialog-ok:hover{background:var(--accent-hover)}.lib-dialog-danger{padding:7px 14px;font-size:13px;color:#fff;background:var(--danger);border-radius:var(--radius-sm);font-family:var(--font);font-weight:500;transition:background .12s}.lib-dialog-danger:hover{background:#b91c1c}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--text-4)}.ntm-category{margin-bottom:20px}.ntm-category-label{display:flex;align-items:center;gap:6px;font-size:10.5px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text-4);margin-bottom:8px;padding:0 2px}.source-panel{display:flex;flex-direction:column;height:100%;overflow:hidden}.source-panel-header{display:flex;align-items:center;justify-content:space-between;padding:8px 14px;font-size:11.5px;font-weight:600;color:var(--text-3);background:var(--bg-2);border-bottom:1px solid var(--border);flex-shrink:0}.source-panel-hint{font-size:10.5px;font-weight:400;color:var(--text-4)}.source-textarea{flex:1;width:100%;height:100%;padding:14px;font-family:DM Mono,Fira Code,Cascadia Code,monospace;font-size:11.5px;line-height:1.65;color:var(--text-1);background:var(--bg);border:none;outline:none;resize:none;box-sizing:border-box;overflow:auto;-moz-tab-size:2;tab-size:2}.source-textarea:focus{background:var(--bg)}.ef-select{width:100%;padding:7px 10px;font-size:12px;font-family:inherit;color:var(--text-1);background:var(--bg);border:1.5px solid var(--border);border-radius:6px;outline:none;cursor:pointer;margin-bottom:0;-webkit-appearance:auto;-moz-appearance:auto;appearance:auto}.ef-select:focus{border-color:var(--accent)}.ef-textarea--policy{margin-top:6px;rows:4}.ef-visibility-btn{display:flex;align-items:center;gap:4px;margin-left:auto;padding:3px 8px;font-size:11px;font-weight:500;color:var(--accent);background:color-mix(in srgb,var(--accent) 10%,transparent);border:1px solid color-mix(in srgb,var(--accent) 25%,transparent);border-radius:10px;cursor:pointer;transition:background .15s,color .15s;white-space:nowrap}.ef-visibility-btn:hover{background:color-mix(in srgb,var(--accent) 18%,transparent)}.ef-visibility-btn--off{color:var(--text-4);background:var(--bg-2);border-color:var(--border)}.ef-visibility-btn--off:hover{color:var(--text-2);background:var(--bg-3)}.ef-group--hidden .ef-group-header{opacity:.55}.login-screen{min-height:100vh;background:var(--bg);display:flex;align-items:center;justify-content:center}.login-card{width:360px;background:var(--panel);border:1px solid var(--border);border-radius:16px;padding:40px 36px 36px;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;align-items:center;gap:4px}.login-logo{margin-bottom:12px}.login-title{font-size:20px;font-weight:600;color:var(--text-1);margin:0 0 4px;text-align:center}.login-sub{font-size:13px;color:var(--text-3);margin:0 0 24px;text-align:center}.login-form{width:100%;display:flex;flex-direction:column;gap:14px}.login-label{display:flex;flex-direction:column;gap:5px;font-size:12.5px;font-weight:500;color:var(--text-2)}.login-input{padding:9px 12px;font-size:13.5px;font-family:inherit;color:var(--text-1);background:var(--bg);border:1.5px solid var(--border);border-radius:8px;outline:none;transition:border-color .15s}.login-input:focus{border-color:var(--accent);box-shadow:0 0 0 3px #2563eb1a}.login-error{font-size:12.5px;color:var(--danger);margin:0;text-align:center}.login-btn{margin-top:4px;padding:10px;font-size:13.5px;font-weight:600;font-family:inherit;color:#fff;background:var(--accent);border:none;border-radius:8px;cursor:pointer;transition:background .15s,opacity .15s}.login-btn:hover{background:#1d4ed8}.login-btn:disabled{opacity:.6;cursor:not-allowed}.topbar-signout{color:var(--text-4)}.topbar-signout:hover{color:var(--danger)!important;background:#ef444414!important}.ef-computed-badge{display:inline-block;margin-left:6px;padding:1px 6px;font-size:10px;font-weight:600;letter-spacing:.04em;text-transform:uppercase;color:#059669;background:#d1fae5;border-radius:10px;vertical-align:middle}.ef-input--computed{background:#f0fdf4;color:#065f46;border-color:#a7f3d0}.ef-input--computed:focus{border-color:#059669;box-shadow:0 0 0 3px #0596691a}.ef-hint-below{display:block;margin-top:3px;font-size:11px;color:var(--text-4)}
