:root{--color-primary: #7c3aed;--color-primary-dark: #6d28d9;--color-tab-active-bg: #1e1040;--color-tab-active-text: #ffffff;--color-tab-inactive-bg: #ede9f6;--color-tab-inactive-text: #3b1d8e;--color-bg: #eeedf2;--color-surface: #ffffff;--color-border: #ddd8ee;--color-folder-row: #f2f0f8;--color-text: #111827;--color-text-muted: #6b7280;--color-icon-muted: #71717a;--color-danger: #dc2626;--color-star: #f59e0b;--font-size-sm: 12px;--font-size-base: 13px;--radius-sm: 4px;--radius: 6px;--transition-theme: background-color .2s ease, color .2s ease, border-color .2s ease}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%}body{height:100%;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);-webkit-font-smoothing:antialiased}:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.search-input:focus-visible,.form-input:focus-visible,.dialog-input:focus-visible,.dialog-select:focus-visible,.dialog-textarea:focus-visible{outline:none}.app{display:flex;flex-direction:column;width:100%;max-width:440px;min-height:100dvh;margin:0 auto;background:var(--color-bg);box-shadow:0 0 0 1px var(--color-border)}.library-header{background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.tabs{display:flex;width:100%}.tab{flex:1;padding:13px 4px;border:none;cursor:pointer;font-size:var(--font-size-base);font-weight:500;letter-spacing:.01em;transition:background .15s;background:var(--color-tab-inactive-bg);color:var(--color-tab-inactive-text)}.tab.active{background:var(--color-tab-active-bg);color:var(--color-tab-active-text)}.tab:not(:last-child){border-right:1px solid var(--color-border)}.edit-toolbar{display:flex;gap:8px;padding:8px 10px;border-top:1px solid var(--color-border)}.btn-add{display:flex;align-items:center;gap:5px;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm);font-weight:500;cursor:pointer}.btn-add:hover{background:var(--color-folder-row)}.search-bar{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--color-surface);border-bottom:1px solid var(--color-border);flex-shrink:0}.search-input{flex:1;height:32px;padding:0 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-bg);outline:none}.search-input:focus{border-color:var(--color-primary)}.search-input::placeholder{color:var(--color-text-muted)}.btn-icon-primary{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;cursor:pointer;flex-shrink:0}.btn-icon-primary:hover{background:var(--color-primary-dark)}.tree-scroll{flex:1;overflow-y:auto;background:var(--color-surface)}.tree-row{display:flex;align-items:center;gap:6px;padding:0 10px;height:40px;border-bottom:1px solid var(--color-border);-webkit-user-select:none;user-select:none}.tree-row.folder-row{background:var(--color-folder-row)}.tree-row.bookmark-row{background:var(--color-surface);padding-left:24px}.tree-row.section-root{font-weight:600;letter-spacing:.01em}.tree-row.folder-virtual{font-style:italic}.tree-row.folder-virtual .tree-icon{color:var(--color-primary)}.modal--note-view{max-width:720px;height:82dvh;display:flex;flex-direction:column;overflow:hidden}.modal--note-view .modal-body{flex:1;overflow-y:auto}.note-view-content{font-size:var(--font-size-base);color:var(--color-text);line-height:1.6}.modal--note{max-width:720px;height:82dvh;display:flex;flex-direction:column;overflow:hidden}.modal--note .modal-body{flex:1;overflow-y:auto;display:flex;flex-direction:column}.dialog-field--grow{flex:1;min-height:0}.note-editor-wrap{flex:1;display:flex;flex-direction:column;min-height:300px;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.note-toolbar{display:flex;align-items:center;gap:2px;padding:4px 6px;border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0;flex-wrap:wrap}.note-toolbar-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border:none;border-radius:4px;background:none;color:var(--color-text-muted);cursor:pointer;flex-shrink:0}.note-toolbar-btn:hover{background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-text)}.note-toolbar-btn.active{background:color-mix(in srgb,var(--color-primary) 18%,transparent);color:var(--color-primary)}.note-toolbar-btn:disabled{opacity:.35;cursor:default}.note-toolbar-sep{width:1px;height:18px;background:var(--color-border);margin:0 3px;flex-shrink:0}.note-editor-body{flex:1;overflow-y:auto;background:var(--color-bg)}.note-editor-body .ProseMirror{height:100%;min-height:200px;padding:10px 12px;outline:none;font-size:var(--font-size-base);color:var(--color-text);line-height:1.6}.note-editor-content h1,.note-editor-content h2,.note-editor-content h3{font-weight:600;line-height:1.3;margin:.8em 0 .3em}.note-editor-content h1{font-size:1.4em}.note-editor-content h2{font-size:1.2em}.note-editor-content h3{font-size:1.05em}.note-editor-content p{margin:0 0 .5em}.note-editor-content p:last-child{margin-bottom:0}.note-editor-content ul,.note-editor-content ol{padding-left:1.4em;margin:.3em 0 .5em}.note-editor-content li{margin:.1em 0}.note-editor-content strong{font-weight:700}.note-editor-content em{font-style:italic}.note-editor-content u{text-decoration:underline}.note-editor-content s{text-decoration:line-through}.note-editor-content code{font-family:monospace;font-size:.88em;background:color-mix(in srgb,var(--color-primary) 10%,var(--color-surface));border-radius:3px;padding:.1em .3em}.note-editor-content hr{border:none;border-top:1px solid var(--color-border);margin:.8em 0}.note-editor-content blockquote{border-left:3px solid var(--color-primary);margin:.5em 0;padding:.2em .8em;color:var(--color-text-muted)}.note-editor-body .ProseMirror p.is-editor-empty:first-child:before{content:"Write your note here…";color:var(--color-text-muted);pointer-events:none;float:left;height:0}.tree-row.dragging{opacity:.4}.tree-row.drag-over{outline:2px solid var(--color-primary);outline-offset:-2px;background:color-mix(in srgb,var(--color-primary) 12%,var(--color-folder-row))}.status-popup{position:absolute;bottom:calc(100% + 6px);left:50%;transform:translate(-50%);min-width:220px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 8px 32px #0000002e;padding:10px 14px;z-index:300}.status-popup-row{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text);margin-bottom:4px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:#16a34a}.status-dot.disconnected{background:var(--color-danger)}.status-label{flex:1}.status-popup-detail{font-size:var(--font-size-sm);color:var(--color-text);word-break:break-all;line-height:1.4}.status-popup-detail.muted{color:var(--color-text-muted)}.tree-indent{width:14px;flex-shrink:0}.tree-icon{display:flex;align-items:center;color:var(--color-text-muted);flex-shrink:0}.tree-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--font-size-base);color:var(--color-text)}.tree-link{background:none;border:none;padding:0;font:inherit;color:inherit;text-align:left;text-decoration:none;cursor:pointer}.tree-link:hover{text-decoration:underline;text-decoration-thickness:1px;text-underline-offset:2px}.tree-count{font-size:var(--font-size-sm);color:var(--color-text-muted);flex-shrink:0;min-width:16px;text-align:right}.tree-actions{display:flex;align-items:center;gap:4px;flex-shrink:0}.btn-tree-action{display:flex;align-items:center;justify-content:center;width:22px;height:22px;border:none;border-radius:3px;background:transparent;cursor:pointer;color:var(--color-icon-muted);padding:0}.btn-tree-action:hover{background:var(--color-border);color:var(--color-text)}.btn-tree-action.danger:hover{background:#fee2e2;color:var(--color-danger)}.btn-tree-action.active{color:var(--color-primary)}.bookmark-actions-row{background:var(--color-folder-row);border-bottom:1px solid var(--color-border);display:flex;align-items:center;gap:6px;padding:4px 10px 4px 24px;min-height:32px}.bookmark-action-btns{display:flex;gap:6px}.btn-bookmark-action{display:flex;align-items:center;gap:5px;padding:4px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer;transition:background .12s}.btn-bookmark-action:hover{background:var(--color-border)}.btn-bookmark-action--danger{color:var(--color-danger);border-color:var(--color-danger)}.btn-bookmark-action--danger:hover{background:#fee2e2}.btn-star{color:var(--color-icon-muted)}.btn-star.favorited{color:var(--color-star)}.favicon{width:14px;height:14px;border-radius:2px;object-fit:contain;flex-shrink:0}.favicon-placeholder{width:14px;height:14px;border-radius:2px;background:var(--color-border);flex-shrink:0}.footer{display:flex;align-items:center;justify-content:space-between;padding:0 10px;height:48px;background:var(--color-folder-row);border-top:1px solid var(--color-border);flex-shrink:0}.footer-username{display:flex;align-items:center;gap:5px;font-size:var(--font-size-sm);color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:160px;background:none;border:none;padding:0;cursor:pointer}.footer-username:hover{color:var(--color-text)}.footer-admin-badge{display:inline-block;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;background:var(--color-primary);color:#fff;border-radius:3px;padding:1px 4px;flex-shrink:0}.footer-actions{display:flex;align-items:center;gap:2px}.btn-footer{display:flex;align-items:center;justify-content:center;width:34px;height:34px;border:none;border-radius:50%;background:transparent;cursor:pointer;color:var(--color-text-muted)}.btn-footer:hover{background:var(--color-border);color:var(--color-text)}.btn-footer.active{color:var(--color-primary)}.btn-footer.connected{color:#16a34a}.btn-footer.disconnected{color:var(--color-danger)}.login-page{display:flex;align-items:center;justify-content:center;min-height:100dvh;background:var(--color-bg);padding:24px}.login-card{width:100%;max-width:360px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);padding:32px 24px}.login-title{font-size:20px;font-weight:700;color:var(--color-primary);margin-bottom:6px;text-align:center}.login-subtitle{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;margin-bottom:24px}.login-form{display:flex;flex-direction:column;gap:12px}.form-field{display:flex;flex-direction:column;gap:4px}.form-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.form-input{height:36px;padding:0 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);outline:none}.form-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed26}.btn-primary{height:38px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:var(--font-size-base);font-weight:600;cursor:pointer;margin-top:4px}.btn-primary:hover{background:var(--color-primary-dark)}.login-toggle{margin-top:16px;text-align:center;font-size:var(--font-size-sm);color:var(--color-text-muted)}.login-toggle button{border:none;background:transparent;color:var(--color-primary);cursor:pointer;font-size:var(--font-size-sm);font-weight:500}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#1e10408c;display:flex;align-items:center;justify-content:center;z-index:200;padding:16px;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.modal{background:var(--color-surface);border-radius:var(--radius);width:100%;max-width:360px;max-height:90dvh;overflow-y:auto;box-shadow:0 24px 64px #00000059}.modal-header{padding:20px 20px 0}.modal-title{font-size:16px;font-weight:600;color:var(--color-text)}.modal-body{padding:16px 20px;display:flex;flex-direction:column;gap:13px}.modal-footer{padding:4px 20px 20px;display:flex;justify-content:flex-end;gap:8px}.dialog-field{display:flex;flex-direction:column;gap:4px}.dialog-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text)}.dialog-input,.dialog-select{height:34px;padding:0 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);color:var(--color-text);background:var(--color-surface);outline:none;width:100%}.dialog-input:focus,.dialog-select:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed26}.dialog-textarea{padding:8px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);font-size:var(--font-size-base);font-family:inherit;color:var(--color-text);background:var(--color-surface);outline:none;resize:vertical;width:100%;min-height:80px}.dialog-textarea:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px #7c3aed26}.dialog-checkbox-label{display:flex;align-items:center;gap:8px;font-size:var(--font-size-sm);color:var(--color-text);cursor:pointer;-webkit-user-select:none;user-select:none}.dialog-checkbox-label input[type=checkbox]{width:14px;height:14px;accent-color:var(--color-primary);cursor:pointer;flex-shrink:0}.btn-cancel{padding:7px 16px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-text);font-size:var(--font-size-base);cursor:pointer}.btn-cancel:hover{background:var(--color-folder-row)}.btn-save{padding:7px 18px;border:none;border-radius:var(--radius-sm);background:var(--color-primary);color:#fff;font-size:var(--font-size-base);font-weight:600;cursor:pointer}.btn-save:hover{background:var(--color-primary-dark)}.settings-anchor{position:relative}.settings-menu{position:absolute;bottom:calc(100% + 6px);right:0;width:210px;background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:0 8px 32px #0000002e;padding:4px 0;z-index:300}.settings-item{display:flex;align-items:center;gap:10px;width:100%;padding:9px 14px;border:none;background:transparent;color:var(--color-text);font-size:var(--font-size-base);text-align:left;cursor:pointer;white-space:nowrap}.settings-item:hover{background:var(--color-folder-row)}.settings-item.danger{color:var(--color-danger)}.settings-item.danger:hover{background:#fee2e2}.settings-item-icon{display:flex;align-items:center;color:var(--color-text-muted);flex-shrink:0}.settings-item.danger .settings-item-icon{color:var(--color-danger)}.settings-item--admin,.settings-item--admin .settings-item-icon{color:var(--color-primary)}.settings-divider{height:1px;background:var(--color-border);margin:4px 0}.lib-type-row{display:flex;gap:6px}.lib-type-btn{flex:1;padding:6px 10px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:var(--color-surface);color:var(--color-text-muted);font-size:var(--font-size-sm);cursor:pointer;transition:background .15s,color .15s,border-color .15s}.lib-type-btn.active{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.color-swatches{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:10px}.color-swatch{width:26px;height:26px;border-radius:var(--radius-sm);border:2px solid transparent;cursor:pointer;padding:0;transition:transform .1s,border-color .15s}.color-swatch:hover{transform:scale(1.12)}.color-swatch.selected{border-color:var(--color-text);box-shadow:0 0 0 2px var(--color-surface);outline:2px solid var(--color-text);outline-offset:2px}.color-custom-swatch{display:flex;align-items:center;justify-content:center;border:2px dashed var(--color-border);position:relative;overflow:hidden;cursor:pointer}.color-custom-swatch.selected{border-style:solid;border-color:var(--color-text)}.color-custom-plus{font-size:16px;line-height:1;color:var(--color-text-muted);pointer-events:none}.color-custom-input{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;cursor:pointer;border:none;padding:0}.color-preview-tab{display:inline-block;padding:4px 14px;border-radius:var(--radius-sm) var(--radius-sm) 0 0;font-size:var(--font-size-sm);font-weight:500;min-width:80px;text-align:center;margin-top:4px}.lib-list{list-style:none;display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.lib-list-row{display:flex;align-items:center;gap:8px;padding:6px 8px;border-radius:var(--radius-sm);background:var(--color-folder-row);cursor:grab}.lib-list-row.dragging{opacity:.4}.lib-list-row.drag-over{outline:2px solid var(--color-primary);outline-offset:-2px}.lib-drag-handle{display:flex;align-items:center;color:var(--color-text-muted);flex-shrink:0;cursor:grab}.lib-list-swatch{width:16px;height:16px;border-radius:3px;flex-shrink:0}.lib-list-name{flex:1;font-size:var(--font-size-base);font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.lib-list-type{font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.04em;padding:2px 6px;border-radius:99px;flex-shrink:0}.lib-list-type--bookmarks{background:#dbeafe;color:#1e3a8a}.lib-list-type--notes{background:#dcfce7;color:#15803d}.lib-list-type--both{background:#ede9fe;color:#5b21b6}.lib-manager-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:12px 0}.lib-manager-note{font-size:var(--font-size-sm);color:var(--color-text-muted);background:var(--color-folder-row);border-left:3px solid var(--color-primary);padding:6px 10px;border-radius:0 var(--radius-sm) var(--radius-sm) 0;line-height:1.4}.btn-add-library{display:flex;align-items:center;gap:5px;padding:6px 12px;background:transparent;border:1px solid var(--color-primary);border-radius:var(--radius-sm);color:var(--color-primary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:background .15s}.btn-add-library:hover{background:var(--color-primary);color:#fff}.btn-danger{padding:7px 18px;border:none;border-radius:var(--radius-sm);background:var(--color-danger);color:#fff;font-size:var(--font-size-base);font-weight:600;cursor:pointer}.btn-danger:hover{background:#b91c1c}.modal--confirm{max-width:320px}.confirm-message{font-size:var(--font-size-base);color:var(--color-text);line-height:1.5}.toast-container{position:fixed;bottom:60px;left:50%;transform:translate(-50%);width:min(400px,calc(100vw - 32px));display:flex;flex-direction:column;gap:6px;z-index:500;pointer-events:none}.toast{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:var(--radius);box-shadow:0 4px 16px #0003;font-size:var(--font-size-sm);animation:toast-in .18s ease;pointer-events:all}.toast--success{background:#f0fdf4;border:1px solid #86efac;color:#15803d}.toast--error{background:#fef2f2;border:1px solid #fca5a5;color:#b91c1c}.toast--info{background:var(--color-surface);border:1px solid var(--color-border);color:var(--color-text)}.toast-icon{display:flex;align-items:center;flex-shrink:0}.toast-message{flex:1}.toast-close{display:flex;align-items:center;justify-content:center;width:20px;height:20px;border:none;background:transparent;cursor:pointer;color:inherit;opacity:.6;border-radius:3px;flex-shrink:0}.toast-close:hover{opacity:1}@keyframes toast-in{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.btn-tag-filter{position:relative}.btn-tag-filter--active{background:var(--color-primary-dark);box-shadow:inset 0 0 0 2px #ffffff40}.btn-tag-filter:disabled{opacity:.4;cursor:not-allowed}.tag-filter-badge{position:absolute;top:-5px;right:-5px;min-width:16px;height:16px;padding:0 4px;border-radius:99px;background:#f59e0b;color:#fff;font-size:10px;font-weight:700;line-height:16px;text-align:center;pointer-events:none}.tag-filter-panel{background:var(--color-surface);border-bottom:2px solid var(--color-primary);padding:10px 12px;flex-shrink:0}.tag-filter-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px;gap:8px}.tag-filter-title{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.05em;flex-shrink:0}.tag-filter-controls{display:flex;align-items:center;gap:6px}.tag-mode-toggle{display:flex;border:1px solid var(--color-border);border-radius:var(--radius-sm);overflow:hidden}.tag-mode-btn{padding:3px 9px;border:none;background:transparent;color:var(--color-text-muted);font-size:11px;font-weight:700;letter-spacing:.04em;cursor:pointer;transition:background .12s,color .12s}.tag-mode-btn:not(:last-child){border-right:1px solid var(--color-border)}.tag-mode-btn.active{background:var(--color-primary);color:#fff}.tag-filter-clear{display:flex;align-items:center;gap:4px;padding:3px 8px;border:1px solid var(--color-border);border-radius:var(--radius-sm);background:transparent;color:var(--color-text-muted);font-size:11px;cursor:pointer;transition:background .12s,color .12s}.tag-filter-clear:hover{background:#fee2e2;border-color:var(--color-danger);color:var(--color-danger)}.tag-chip-list{display:flex;flex-wrap:wrap;gap:5px}.tag-chip{display:inline-flex;align-items:center;padding:3px 10px;border:1px solid var(--color-border);border-radius:99px;background:var(--color-bg);color:var(--color-text);font-size:var(--font-size-sm);cursor:pointer;transition:background .12s,border-color .12s,color .12s;-webkit-user-select:none;user-select:none}.tag-chip:hover{border-color:var(--color-primary);color:var(--color-primary)}.tag-chip--selected{background:var(--color-primary);border-color:var(--color-primary);color:#fff;font-weight:500}.tag-chip--selected:hover{background:var(--color-primary-dark);border-color:var(--color-primary-dark);color:#fff}.tag-filter-summary{margin-top:8px;font-size:var(--font-size-sm);color:var(--color-text-muted);line-height:1.5}.tag-filter-summary em{font-style:normal;color:var(--color-primary);font-weight:500}.tag-filter-summary strong{font-size:10px;letter-spacing:.04em;color:var(--color-text-muted)}.tag-filter-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);text-align:center;padding:4px 0}.tree-row.highlighted{background:color-mix(in srgb,var(--color-primary) 10%,var(--color-surface));outline:1px solid color-mix(in srgb,var(--color-primary) 40%,transparent);outline-offset:-1px}.dialog-input--error{border-color:var(--color-danger)!important}.dialog-field-error{display:block;margin-top:3px;font-size:11px;color:var(--color-danger)}.search-results-panel{border-bottom:1px solid var(--color-border);background:var(--color-surface);flex-shrink:0}.search-results-header{display:flex;align-items:center;gap:4px;width:100%;padding:5px 10px;background:none;border:none;cursor:pointer;color:var(--color-text);font-size:12px;font-weight:600;text-align:left}.search-results-header:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.search-results-icon{display:flex;align-items:center;color:var(--color-text-muted);flex-shrink:0}.search-results-label{flex:1}.search-results-count{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:16px;padding:0 5px;border-radius:8px;background:var(--color-primary);color:#fff;font-size:10px;font-weight:700}.search-results-list{max-height:200px;overflow-y:auto}.search-result-row{display:flex;align-items:center;gap:6px;width:100%;padding:4px 10px 4px 24px;background:none;border:none;cursor:pointer;color:var(--color-text);font-size:12px;text-align:left}.search-result-row:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.search-result-icon{display:flex;align-items:center;flex-shrink:0;color:var(--color-text-muted)}.search-result-icon .favicon,.search-result-icon .favicon-placeholder{width:13px;height:13px}.search-result-body{display:flex;align-items:baseline;gap:5px;overflow:hidden}.search-result-title{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.search-result-path{flex-shrink:0;font-size:11px;color:var(--color-text-muted);white-space:nowrap}@media(max-width:480px){.app{max-width:100%;box-shadow:none}}.modal--profile{width:420px}.profile-admin-link{display:inline-flex;align-items:center;gap:5px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);border:1px solid color-mix(in srgb,var(--color-primary) 30%,transparent);border-radius:5px;padding:4px 10px;cursor:pointer}.profile-admin-link:hover{background:color-mix(in srgb,var(--color-primary) 18%,transparent)}.profile-tabs{display:flex;border-bottom:1px solid var(--color-border);padding:0 20px;gap:0}.profile-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 16px;font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;margin-bottom:-1px}.profile-tab:hover{color:var(--color-text)}.profile-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.profile-meta{font-size:var(--font-size-sm);color:var(--color-text-muted);margin:4px 0 0}.profile-msg{font-size:var(--font-size-sm);border-radius:6px;padding:8px 12px;margin:4px 0 0}.profile-msg--error{background:#fef2f2;color:#b91c1c}.profile-msg--success{background:#f0fdf4;color:#15803d}[data-theme=dark] .profile-msg--error{background:#3b1010;color:#fca5a5}[data-theme=dark] .profile-msg--success{background:#0d2e19;color:#86efac}.admin-page{flex:1;padding:24px;overflow-y:auto;background:var(--color-bg);color:var(--color-text)}.admin-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.admin-title{display:flex;align-items:center;gap:8px;font-size:18px;font-weight:700;margin:0;color:var(--color-text)}.admin-count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.admin-error{color:var(--color-danger);font-size:var(--font-size-sm);margin-bottom:12px}.admin-loading{color:var(--color-text-muted);font-size:var(--font-size-sm)}.admin-forbidden{display:flex;flex-direction:column;align-items:center;gap:12px;padding:60px 20px;color:var(--color-text-muted)}.admin-table-wrap{overflow-x:auto;border:1px solid var(--color-border);border-radius:8px}.admin-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.admin-table thead th{background:var(--color-folder-row);padding:8px 12px;text-align:left;font-weight:600;color:var(--color-text-muted);border-bottom:1px solid var(--color-border);white-space:nowrap}.admin-table tbody td{padding:8px 12px;border-bottom:1px solid var(--color-border);vertical-align:middle;color:var(--color-text)}.admin-row:last-child td{border-bottom:none}.admin-row:hover td{background:var(--color-folder-row)}.admin-row--self td{background:color-mix(in srgb,var(--color-primary) 5%,transparent)}.admin-row--editing td{background:var(--color-folder-row)}.admin-cell--username{font-weight:500}.admin-cell--date{white-space:nowrap;color:var(--color-text-muted)}.admin-you-badge{display:inline-block;font-size:10px;background:var(--color-border);color:var(--color-text-muted);border-radius:3px;padding:1px 4px;margin-left:5px;vertical-align:middle}.admin-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;font-weight:500;border-radius:4px;padding:2px 7px}.admin-badge--admin{background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary)}.admin-badge--user{background:var(--color-border);color:var(--color-text-muted)}.admin-badge-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;border-radius:4px;padding:3px 8px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer}.admin-badge-btn--on{background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary);border-color:var(--color-primary)}.admin-badge-btn:disabled{opacity:.5;cursor:default}.admin-input{font-size:var(--font-size-sm);padding:4px 8px;border:1px solid var(--color-border);border-radius:5px;background:var(--color-bg);color:var(--color-text);width:100%;min-width:0}.admin-input--pw{width:160px}.admin-input:focus{outline:none;border-color:var(--color-primary)}.admin-pw-cell{display:flex;align-items:center;gap:6px}.admin-row-actions{display:flex;align-items:center;gap:4px;justify-content:flex-end}.admin-action-btn{display:flex;align-items:center;justify-content:center;width:26px;height:26px;border-radius:5px;border:1px solid var(--color-border);background:transparent;color:var(--color-text-muted);cursor:pointer}.admin-action-btn:hover{background:var(--color-folder-row);color:var(--color-text)}.admin-action-btn--save:hover{color:#15803d;border-color:#15803d}.admin-action-btn--danger:hover{color:var(--color-danger);border-color:var(--color-danger)}.admin-action-btn:disabled{opacity:.4;cursor:default}.admin-inline-error{font-size:11px;color:var(--color-danger);margin-right:4px}.admin-empty{font-size:var(--font-size-sm);color:var(--color-text-muted);padding:16px 0}.admin-tabs{display:flex;border-bottom:1px solid var(--color-border);margin-bottom:20px;gap:0}.admin-tab{background:none;border:none;border-bottom:2px solid transparent;padding:10px 18px;font-size:var(--font-size-sm);color:var(--color-text-muted);cursor:pointer;margin-bottom:-1px}.admin-tab:hover{color:var(--color-text)}.admin-tab.active{color:var(--color-primary);border-bottom-color:var(--color-primary);font-weight:600}.admin-stat-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(160px,1fr));gap:16px}.admin-stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:20px 16px;display:flex;flex-direction:column;align-items:center;gap:6px;text-align:center}.admin-stat-icon{color:var(--color-text-muted);margin-bottom:4px}.admin-stat-icon--active{color:#22c55e}.admin-stat-icon--bookmark{color:var(--color-primary)}.admin-stat-icon--note{color:#f59e0b}.admin-stat-value{font-size:28px;font-weight:700;color:var(--color-text);line-height:1}.admin-stat-label{font-size:var(--font-size-sm);color:var(--color-text-muted)}.admin-dashboard{display:flex;flex-direction:column;gap:16px}.admin-stat-card--btn{cursor:pointer;text-align:center;position:relative;transition:border-color .15s,box-shadow .15s}.admin-stat-card--btn:hover{border-color:var(--color-primary);box-shadow:0 0 0 2px color-mix(in srgb,var(--color-primary) 15%,transparent)}.admin-stat-card--btn.active{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 6%,var(--color-surface))}.admin-stat-chevron{color:var(--color-text-muted);margin-top:4px;transition:transform .2s}.admin-stat-chevron.open{transform:rotate(180deg)}.admin-detail-panel{border:1px solid var(--color-border);border-radius:8px;overflow:hidden}.admin-detail-header{padding:8px 12px;font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-muted);background:var(--color-folder-row);border-bottom:1px solid var(--color-border)}.admin-groups{display:flex;flex-direction:column;gap:12px}.admin-groups-toolbar{display:flex;justify-content:flex-end}.admin-btn-new{display:inline-flex;align-items:center;gap:5px;font-size:var(--font-size-sm);font-weight:500;padding:6px 14px;border-radius:6px;border:1px solid var(--color-primary);background:color-mix(in srgb,var(--color-primary) 10%,transparent);color:var(--color-primary);cursor:pointer}.admin-btn-new:hover{background:color-mix(in srgb,var(--color-primary) 18%,transparent)}.admin-group-form-panel{border:1px solid var(--color-primary);border-radius:10px;background:var(--color-surface);overflow:hidden}.admin-group-form-header{display:flex;align-items:center;padding:10px 16px;background:color-mix(in srgb,var(--color-primary) 8%,var(--color-surface));border-bottom:1px solid var(--color-border)}.admin-group-form-title{font-size:var(--font-size-sm);font-weight:700;color:var(--color-primary)}.admin-group-form-fields{display:flex;flex-direction:column;gap:10px;padding:14px 16px 10px}.admin-group-form-row{display:flex;align-items:center;gap:10px}.admin-form-label{font-size:var(--font-size-sm);color:var(--color-text-muted);width:90px;flex-shrink:0}.admin-group-form-row .admin-input{flex:1}.admin-group-form-section-label{font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.05em;color:var(--color-text-muted);padding:8px 16px 4px;border-top:1px solid var(--color-border);margin-top:4px}.admin-group-form-members{padding:4px 16px 12px;display:flex;flex-direction:column;gap:4px}.admin-group-form-footer{display:flex;align-items:center;justify-content:flex-end;gap:8px;padding:10px 16px;border-top:1px solid var(--color-border);background:var(--color-folder-row)}.admin-group-list{display:flex;flex-direction:column;gap:8px}.admin-group-card{border:1px solid var(--color-border);border-radius:8px;overflow:hidden;background:var(--color-surface)}.admin-group-row{display:flex;align-items:center;gap:8px;padding:10px 12px}.admin-group-expand{background:none;border:none;color:var(--color-text-muted);cursor:pointer;padding:2px;display:flex;align-items:center;flex-shrink:0}.admin-group-expand:hover{color:var(--color-text)}.admin-group-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.admin-group-name{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text)}.admin-group-desc{font-size:11px;color:var(--color-text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-group-count{font-size:11px;color:var(--color-text-muted);white-space:nowrap;flex-shrink:0}.admin-group-members{border-top:1px solid var(--color-border);padding:8px 12px 8px 36px;display:flex;flex-direction:column;gap:4px;background:var(--color-bg)}.admin-group-empty-members{font-size:11px;color:var(--color-text-muted);padding:4px 0}.admin-group-member-row{display:flex;align-items:center;gap:8px;padding:4px 0}.admin-group-member-name{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text);min-width:100px}.admin-group-member-email{font-size:11px;color:var(--color-text-muted);flex:1;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.admin-group-card--editing{opacity:.5;pointer-events:none}.admin-group-role-btn{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:500;padding:2px 8px;border-radius:4px;border:1px solid var(--color-border);background:var(--color-bg);color:var(--color-text-muted);cursor:pointer;white-space:nowrap;flex-shrink:0}.admin-group-role-btn:hover{border-color:var(--color-primary);color:var(--color-primary)}.admin-group-role-btn--admin{border-color:var(--color-primary);background:color-mix(in srgb,var(--color-primary) 12%,transparent);color:var(--color-primary)}.admin-group-role-badge{display:inline-flex;align-items:center;gap:3px;font-size:11px;padding:1px 6px;border-radius:4px;background:var(--color-border);color:var(--color-text-muted);flex-shrink:0}.admin-group-role-badge--admin{background:color-mix(in srgb,var(--color-primary) 15%,transparent);color:var(--color-primary)}.admin-add-member-row{display:flex;align-items:center;gap:6px;padding-top:4px}.admin-input--select{flex:1;min-width:0}.admin-add-member-btn{display:inline-flex;align-items:center;gap:5px;font-size:11px;color:var(--color-primary);background:none;border:1px dashed color-mix(in srgb,var(--color-primary) 40%,transparent);border-radius:5px;padding:4px 10px;cursor:pointer;margin-top:4px}.admin-add-member-btn:hover{background:color-mix(in srgb,var(--color-primary) 8%,transparent)}.admin-settings{display:flex;flex-direction:column;gap:24px}.admin-settings-section{background:var(--color-surface);border:1px solid var(--color-border);border-radius:10px;padding:20px 24px}.admin-settings-heading{font-size:13px;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:var(--color-muted);margin:0 0 14px;display:flex;align-items:center;gap:8px}.admin-settings-badge{display:inline-flex;align-items:center;justify-content:center;min-width:18px;height:18px;padding:0 5px;border-radius:9px;background:var(--color-primary);color:#fff;font-size:10px;font-weight:700;letter-spacing:0}.admin-enrollment-options{display:flex;flex-direction:column;gap:4px}.admin-enrollment-option{display:flex;align-items:flex-start;gap:10px;padding:10px 12px;border-radius:7px;border:1px solid transparent;cursor:pointer;transition:background .15s,border-color .15s}.admin-enrollment-option:hover{background:var(--color-hover)}.admin-enrollment-option.selected{background:color-mix(in srgb,var(--color-primary) 8%,transparent);border-color:color-mix(in srgb,var(--color-primary) 30%,transparent)}.admin-enrollment-option input[type=radio]{margin-top:2px;accent-color:var(--color-primary);cursor:pointer}.admin-enrollment-option-label{font-size:13px;font-weight:600;color:var(--color-text)}.admin-enrollment-option-desc{font-size:11px;color:var(--color-muted);margin-top:2px}.admin-settings-footer{margin-top:16px;display:flex;justify-content:flex-end}.admin-req-approve{color:#16a34a!important}.admin-req-approve:hover{background:color-mix(in srgb,#16a34a 12%,transparent)!important}.login-pending-msg{text-align:center;padding:8px 0 16px}.login-pending-msg p{font-size:13px;color:var(--color-text);margin-bottom:20px;line-height:1.5}.admin-pw-cell{display:flex;flex-direction:column;gap:4px}body,.app,.library-header,.tab,.edit-toolbar,.search-bar,.search-input,.tree-scroll,.tree-row,.footer,.settings-menu,.modal,.modal-overlay,.dialog-input,.dialog-select,.dialog-textarea,.form-input,.btn-add,.btn-cancel,.btn-save,.btn-footer,.settings-item,.lib-list-row,.lib-manager-note,.login-card,.toast--info,.tag-filter-panel,.tag-chip,.search-results-panel,.search-result-row{transition:var(--transition-theme)}[data-theme=dark]{--color-primary: #a78bfa;--color-primary-dark: #8b5cf6;--color-tab-active-bg: #1a1a1a;--color-tab-active-text: #f5f5f5;--color-tab-inactive-bg: #2a2a2a;--color-tab-inactive-text: #d4d4d4;--color-bg: #111111;--color-surface: #1c1c1c;--color-border: #333333;--color-folder-row: #242424;--color-text: #f0f0f0;--color-text-muted: #9a9a9a;--color-icon-muted: #7a7a7a;--color-star: #fbbf24;--color-danger: #f87171}
