:root{--bg-page: linear-gradient(135deg, #f4efe4 0%, #d9e6e1 48%, #bfd3e9 100%);--bg-panel: rgba(255, 252, 246, .82);--bg-sidebar: rgba(251, 247, 239, .9);--bg-muted: rgba(84, 108, 94, .08);--bg-hover: rgba(94, 132, 111, .12);--bg-active: rgba(42, 118, 96, .16);--text-primary: #183028;--text-secondary: #51675d;--text-muted: #6d8176;--border-soft: rgba(66, 91, 79, .12);--border-strong: rgba(66, 91, 79, .2);--accent: #1f7a63;--accent-strong: #145645;--shadow-xl: 0 28px 90px rgba(33, 54, 62, .18);--radius-xl: 26px;--radius-lg: 18px;--radius-md: 12px;--font-sans: "Avenir Next", "PingFang SC", "Microsoft YaHei", sans-serif}*{box-sizing:border-box}body{margin:0;min-height:100vh;font-family:var(--font-sans);background:var(--bg-page);color:var(--text-primary);font-size:14px;line-height:1.45}button,input,textarea,select{font:inherit}button{cursor:pointer}.login-shell,.dashboard-shell{min-height:100vh;padding:18px}.login-shell{display:grid;place-items:center}.login-card{width:min(460px,100%);background:#fffaf2db;border:1px solid rgba(255,255,255,.58);box-shadow:var(--shadow-xl);border-radius:30px;padding:36px;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px)}.brand-mark{width:64px;height:64px;border-radius:20px;display:grid;place-items:center;background:linear-gradient(135deg,#174f45,#ca8f52);color:#fff;font-weight:700;letter-spacing:.04em}.login-card h1{margin:18px 0 8px;font-size:clamp(28px,5vw,36px)}.login-card p{margin:0 0 24px;color:var(--text-secondary)}.login-form,.editor-form{display:grid;gap:14px}.login-form label,.editor-form label{display:grid;gap:8px;color:var(--text-secondary)}input,textarea,select{border:1px solid var(--border-soft);background:#ffffffe0;border-radius:var(--radius-md);padding:12px 14px;outline:none}input:focus,textarea:focus,select:focus{border-color:#1f7a6373;box-shadow:0 0 0 3px #1f7a631f}.primary-btn,.save-btn{background:linear-gradient(135deg,#1f7a63,#145645);color:#fff;border:none;border-radius:var(--radius-md);padding:11px 16px}.ghost-btn{background:transparent;border:1px solid var(--border-soft);border-radius:var(--radius-md);padding:10px 14px;color:var(--text-primary)}.ghost-btn.danger-btn{border-color:#b94a4852;color:#9b3a37}.ghost-btn.danger-btn:hover{border-color:#b94a486b;background:#f4e4e4b3}.ghost-btn:disabled,.primary-btn:disabled,.save-btn:disabled{opacity:.6;cursor:not-allowed}.form-error{color:#b04b2b;background:#ea97782e;border-radius:var(--radius-md);padding:10px 12px}.app{display:flex;min-height:calc(100vh - 36px);overflow:hidden;position:relative}.sidebar{width:248px;background:#fbf7efc2;border-right:1px solid var(--border-soft);display:flex;flex-direction:column;flex-shrink:0;transition:width .18s ease,transform .18s ease,opacity .18s ease}.sidebar.collapsed{width:0;transform:translate(-100%);opacity:0;border-right-color:transparent;overflow:hidden;pointer-events:none}.sidebar-header{padding:14px 16px;border-bottom:1px solid var(--border-soft)}.logo{display:flex;align-items:center;gap:8px;font-weight:700;letter-spacing:.04em;font-size:15px;min-width:0}.logo span{min-width:0}.logo-dot{width:12px;height:12px;border-radius:999px;background:linear-gradient(135deg,#c7863f,#1f7a63)}.sidebar-section{padding:8px 0}.sidebar-scroll{flex:1;overflow:auto}.sidebar-footer{padding:12px;display:grid;gap:10px}.sidebar-collapse-btn,.sidebar-reopen-btn{border:1px solid var(--border-soft);background:#ffffffad;color:var(--text-primary);display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:14px;padding:10px 12px;transition:background-color .14s ease,border-color .14s ease,color .14s ease,transform .14s ease}.sidebar-collapse-btn{width:100%}.sidebar-collapse-btn svg,.sidebar-reopen-btn svg{width:16px;height:16px;stroke:currentColor;stroke-width:1.9;fill:none;stroke-linecap:round;stroke-linejoin:round}.sidebar-collapse-btn:hover,.sidebar-reopen-btn:hover{background:#1f7a631a;border-color:#1f7a6347;color:var(--accent-strong)}.sidebar-label{padding:0 16px 6px;color:var(--text-muted);font-size:11px;text-transform:uppercase;letter-spacing:.12em}.sidebar-section-header{display:flex;align-items:center;justify-content:space-between;gap:8px;padding-right:12px}.sidebar-section-header .sidebar-label{padding-bottom:4px}.sidebar-add-btn{width:22px;height:22px;border:1px solid var(--border-soft);border-radius:999px;background:#ffffffb8;color:var(--text-secondary);display:grid;place-items:center;font-size:14px;line-height:1;padding:0}.sidebar-add-btn:hover{background:#1f7a631f;color:var(--accent-strong)}.sidebar-inline-form{padding:6px 12px 0}.sidebar-inline-input{width:100%;padding:8px 10px;border-radius:10px;font-size:13px;background:#ffffffd1}.sidebar-divider{border:none;border-top:1px solid var(--border-soft);margin:0}.collection-node{position:relative}.collection-node.dragging{opacity:.5}.collection-node.drop-before .collection-main{box-shadow:inset 0 2px #1f7a638c}.collection-node.drop-after .collection-main{box-shadow:inset 0 -2px #1f7a638c}.collection-node.drop-inside .collection-main{background:#dcf1eab8}.collection-main{position:relative;z-index:1}.collection-main.drag-enabled{cursor:grab}.collection-main.drag-enabled:active{cursor:grabbing}.collection-inline-form{display:flex;align-items:center;gap:8px;padding:8px 14px}.collection-inline-input{width:100%;padding:6px 8px;border-radius:8px;font-size:13px;min-width:0}.collection-actions{position:absolute;top:50%;right:10px;transform:translateY(-50%);display:flex;gap:4px;padding:3px;border-radius:10px;background:#fffaf4f2;border:1px solid rgba(33,73,59,.12);opacity:0;pointer-events:none;transition:opacity .14s ease;z-index:2}.collection-node:hover .collection-actions,.collection-node:focus-within .collection-actions{opacity:1;pointer-events:auto}.collection-node:hover .count-badge,.collection-node:focus-within .count-badge{opacity:0}.collection-action-btn{border:none;background:#21493b14;color:var(--text-secondary);border-radius:8px;padding:4px 6px;font-size:11px;line-height:1}.collection-action-btn:hover{background:#1f7a6324;color:var(--accent-strong)}.collection-action-btn.danger:hover{background:#b94a4824;color:#a13a37}.nav-item{width:100%;display:flex;align-items:center;gap:8px;border:none;background:transparent;padding:8px 14px;color:var(--text-secondary);text-align:left;font-size:13px}.nav-item:hover{background:var(--bg-hover)}.nav-item.active{background:var(--bg-active);color:var(--accent-strong)}.nav-icon{width:16px;text-align:center}.count-badge{margin-left:auto;min-width:22px;padding:1px 7px;border-radius:999px;background:#21493b14;font-size:11px;transition:opacity .14s ease}.main{flex:1;display:flex;flex-direction:column;min-width:0;position:relative}.sidebar-reopen-btn{position:absolute;bottom:16px;left:16px;top:auto;z-index:3;box-shadow:0 12px 30px #21363e1f}.topbar{display:flex;gap:10px;align-items:center}.quick-save{flex:1;border:1px solid var(--border-soft);background:#ffffffbf;border-radius:12px;padding:0 12px}.quick-save input{width:100%;border:none;background:transparent;padding:10px 0;box-shadow:none}.content{padding:16px;overflow:auto}.content-header{display:flex;justify-content:space-between;gap:12px;align-items:flex-start;margin-bottom:14px}.content-title{font-size:24px;font-weight:700}.content-subtitle{margin-top:4px;color:var(--text-secondary);font-size:13px}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap;justify-content:flex-end}.account-menu{position:relative;display:inline-flex;padding-bottom:8px;margin-bottom:-8px}.account-menu-trigger{display:inline-flex;align-items:center;gap:6px}.account-menu-trigger svg{width:14px;height:14px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round}.account-menu-dropdown{position:absolute;top:calc(100% - 2px);right:0;min-width:132px;display:grid;padding:6px;border:1px solid var(--border-soft);border-radius:14px;background:#fffaf4fa;box-shadow:0 18px 40px #21363e24;opacity:0;pointer-events:none;transform:translateY(6px);transition:opacity .14s ease,transform .14s ease;z-index:8}.account-menu:hover .account-menu-dropdown,.account-menu:focus-within .account-menu-dropdown{opacity:1;pointer-events:auto;transform:translateY(0)}.account-menu-item{border:none;background:transparent;border-radius:10px;padding:10px 12px;color:var(--text-primary);text-align:left}.account-menu-item:hover{background:#1f7a631a;color:var(--accent-strong)}.account-menu-item.danger:hover{background:#b94a481f;color:#a13a37}.search-input{min-width:220px}.bookmark-grid{display:grid;gap:12px;grid-template-columns:repeat(auto-fill,minmax(260px,300px));justify-content:start}.bookmark-card{position:relative;display:grid;gap:8px;width:min(100%,300px);padding:12px;border:1px solid var(--border-soft);border-radius:14px;background:#ffffff9e;transform-origin:center top;box-shadow:0 12px 30px #21363e14;transition:transform .14s ease,border-color .14s ease,background-color .14s ease,box-shadow .14s ease,opacity .14s ease}.bookmark-card.selected{border-color:#1f7a6373;background:#ebf7f2c7;box-shadow:0 18px 38px #21363e1f,inset 0 0 0 1px #1f7a632e}.bookmark-cover{display:block;aspect-ratio:16 / 9;overflow:hidden;border:1px dashed rgba(31,122,99,.22);border-radius:10px;background:linear-gradient(135deg,#e4f2eceb,#f8f2e8e0)}.bookmark-cover-link{cursor:pointer}.bookmark-cover-image{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit}.bookmark-cover-placeholder{display:grid;width:100%;height:100%;place-items:center;color:var(--text-secondary);font-size:12px;letter-spacing:.04em}.bookmark-card-add{cursor:pointer;text-align:left}.bookmark-card-add:hover{border-color:#1f7a6352;background:#f4faf7c7}.bookmark-cover-add{display:grid;place-items:center;border-style:dashed}.bookmark-add-sign{display:grid;place-items:center;width:48px;height:48px;border-radius:999px;background:#ffffffc7;color:var(--accent-strong);font-size:30px;line-height:1;box-shadow:inset 0 0 0 1px #1f7a6329}.bookmark-add-title{color:var(--accent-strong)}.bookmark-add-hint{word-break:break-word}.bookmark-card.sortable{cursor:grab}.bookmark-card.sortable:hover{transform:translateY(-3px);border-color:#1f7a633d;box-shadow:0 18px 38px #21363e24}.bookmark-card.sortable:active{cursor:grabbing}.bookmark-card.dragging{opacity:.18;transform:scale(.95);border-color:#1f7a6338;background:#f3f8f5c2;box-shadow:inset 0 0 0 1px #1f7a631f,inset 0 12px 24px #ffffff73}.bookmark-card.drag-over{transform:translateY(-4px) scale(1.015);border-color:#1f7a636b;background:#dcf1ead1;box-shadow:0 20px 42px #1f7a632e}.bookmark-drag-preview{display:grid;gap:8px;padding:12px;border:1px solid rgba(31,122,99,.28);border-radius:14px;background:#fffffff5;box-shadow:0 28px 64px #172a263d,0 10px 24px #1f7a6324;transform:rotate(3deg) scale(1.02);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);pointer-events:none}.bookmark-drag-preview .bookmark-cover{border-color:#1f7a6347}.bookmark-select-btn{position:absolute;top:10px;left:10px;z-index:3;width:28px;height:28px;display:grid;place-items:center;padding:0;border:1px solid rgba(34,72,62,.26);border-radius:999px;background:#ffffffeb;color:transparent;transition:background-color .14s ease,border-color .14s ease,color .14s ease}.bookmark-select-btn svg{width:16px;height:16px}.bookmark-select-btn:hover{border-color:#1f7a6373}.bookmark-select-btn.selected{border-color:#1f7a6385;background:#1f7a63e6;color:#fff}body.bookmark-dragging-active,body.bookmark-dragging-active *{cursor:grabbing!important;-webkit-user-select:none;user-select:none}.bookmark-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:10px}.bookmark-card-actions{display:inline-flex;align-items:center;gap:6px}.bookmark-title{flex:1;min-width:0;color:var(--accent-strong);font-size:18px;font-weight:800;letter-spacing:-.02em;line-height:1.35;display:-webkit-box;overflow:hidden;-webkit-box-orient:vertical;-webkit-line-clamp:2}.bookmark-edit-btn{width:30px;height:30px;flex-shrink:0;display:grid;place-items:center;padding:0;border:1px solid var(--border-soft);border-radius:999px;background:#ffffffc7;color:var(--text-secondary);transition:background-color .14s ease,border-color .14s ease,color .14s ease}.bookmark-edit-btn:hover{background:#dcf1eab8;border-color:#1f7a6342;color:var(--accent-strong)}.bookmark-edit-btn svg{width:14px;height:14px}.bookmark-delete-btn{width:30px;height:30px;flex-shrink:0;display:grid;place-items:center;padding:0;border:1px solid var(--border-soft);border-radius:999px;background:#ffffffc7;color:var(--text-secondary);transition:background-color .14s ease,border-color .14s ease,color .14s ease}.bookmark-delete-btn:hover{background:#f4e4e4b8;border-color:#b94a484d;color:#a13a37}.bookmark-delete-btn:disabled{opacity:.55;cursor:not-allowed}.bookmark-delete-btn svg{width:14px;height:14px}.bookmark-link{color:var(--text-muted);font-size:11px;line-height:1.5}.bookmark-link{display:block;word-break:break-all}@media(max-width:640px){.bookmark-grid{grid-template-columns:1fr}.bookmark-card{width:100%}}.state-card{padding:16px;border:1px dashed var(--border-strong);border-radius:16px;background:#ffffff80;margin-bottom:10px}.editor-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e1a155c;display:grid;place-items:center;padding:20px}.editor-panel{width:min(560px,100%);background:#fffaf4f2;border-radius:20px;padding:20px;box-shadow:var(--shadow-xl)}.bookmark-editor-panel h3{margin:0;font-size:24px}.image-field{gap:10px}.image-paste-zone{width:100%;aspect-ratio:16 / 9;min-height:180px;display:grid;place-items:center;overflow:hidden;border:1px dashed rgba(31,122,99,.28);border-radius:10px;background:linear-gradient(135deg,#e4f2eceb,#f8f2e8e0);color:var(--text-secondary);outline:none}.image-paste-zone:focus{border-color:#1f7a6385;box-shadow:0 0 0 3px #1f7a631f}.image-paste-zone.has-image{background:#ffffffe0;border-style:solid}.image-paste-empty{display:grid;gap:10px;justify-items:center;padding:24px}.image-paste-plus{display:grid;place-items:center;width:64px;height:64px;border-radius:999px;background:#ffffffd1;color:var(--accent-strong);font-size:40px;line-height:1}.image-preview{display:block;width:100%;height:100%;object-fit:cover;border-radius:inherit}.image-field-footer{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.image-field-hint{color:var(--text-secondary);font-size:13px}.settings-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0e1a155c;display:grid;place-items:center;padding:20px;z-index:20}.settings-panel{width:min(1080px,100%);max-height:calc(100vh - 40px);overflow:auto;background:#fffaf4f7;border-radius:22px;padding:20px;box-shadow:var(--shadow-xl)}.password-panel{width:min(440px,100%);background:#fffaf4f7;border-radius:22px;padding:20px;box-shadow:var(--shadow-xl)}.editor-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.management-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:10px}.panel-card{padding:14px;border:1px solid var(--border-soft);border-radius:16px;background:#ffffffad}.panel-title{font-size:15px;font-weight:700;margin-bottom:10px}.inline-form{display:grid;grid-template-columns:1fr auto;gap:8px;margin-bottom:10px}.form-actions{display:flex;justify-content:flex-end;gap:8px}.mini-list{display:grid;gap:8px}.mini-row{display:flex;align-items:center;justify-content:space-between;gap:10px;padding:8px 10px;border-radius:12px;background:#ffffffb8;border:1px solid var(--border-soft);font-size:13px}.mini-row small{color:var(--text-secondary)}.mini-actions{display:flex;gap:6px}.system-settings-trigger{border-radius:14px;margin:0;width:100%;background:#1f7a6314}.system-settings-trigger:hover{background:#1f7a6324}@media(max-width:980px){.dashboard-shell{padding:14px}.app{flex-direction:column}.sidebar{width:auto;transform:none;opacity:1;pointer-events:auto}.sidebar.collapsed{width:auto;transform:none;opacity:1;border-right:1px solid var(--border-soft);overflow:visible;pointer-events:auto}.sidebar-collapse-btn,.sidebar-reopen-btn{display:none}.content-header{flex-direction:column}.toolbar{justify-content:flex-start}.search-input{min-width:0;width:100%}.inline-form{grid-template-columns:1fr}.settings-panel{padding:18px;border-radius:22px}.collection-actions{position:static;transform:none;opacity:1;pointer-events:auto;background:transparent;border:none;padding:0 10px 6px 28px}}
