:root{--bg: #f7f6f3;--surface: #ffffff;--surface-2: #fbfaf8;--border: #e7e3db;--text: #2b2a28;--text-soft: #6b6862;--text-faint: #9c988f;--accent: #c2603a;--accent-soft: #f4e6df;--accent-strong: #a84d2c;--danger: #c0392b;--radius: 10px;--shadow: 0 1px 2px rgba(40, 35, 25, .04), 0 8px 24px rgba(40, 35, 25, .06);--serif: "Source Han Serif SC", "Source Han Serif CN", "Noto Serif SC", "Songti SC", "STSong", "Georgia", "SimSun", serif;--sans: -apple-system, BlinkMacSystemFont, "Segoe UI", "PingFang SC", "HarmonyOS Sans SC", "Microsoft YaHei", system-ui, sans-serif}*{box-sizing:border-box}html,body,#root{height:100%;margin:0}body{font-family:var(--sans);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased}a{color:var(--accent-strong)}button{font-family:inherit;cursor:pointer}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;border:1px solid var(--border);background:var(--surface);color:var(--text);padding:8px 14px;border-radius:var(--radius);font-size:14px;transition:background .15s,border-color .15s,transform .05s}.btn:hover{border-color:var(--text-faint);background:var(--surface-2)}.btn:active{transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:default}.btn-primary{background:var(--accent);border-color:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-strong);border-color:var(--accent-strong)}.btn-soft{background:var(--accent-soft);border-color:var(--accent-soft);color:var(--accent-strong)}.btn-ghost{border-color:transparent;background:transparent;color:var(--text-soft)}.btn-ghost:hover{background:var(--accent-soft);color:var(--accent-strong)}.btn-danger{color:var(--danger);border-color:transparent;background:transparent}.btn-danger:hover{background:#fbe9e7}.btn-danger-solid{background:var(--danger);border-color:var(--danger);color:#fff}.btn-sm{padding:5px 10px;font-size:13px}.input{width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:10px 12px;font-size:15px;font-family:inherit;background:var(--surface);color:var(--text);transition:border-color .15s,box-shadow .15s}.input:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.app{display:flex;flex-direction:column;height:100%}.topbar{display:flex;align-items:center;gap:24px;padding:0 24px;height:56px;background:var(--surface);border-bottom:1px solid var(--border);flex-shrink:0}.brand{font-weight:700;font-size:17px;display:flex;align-items:center;gap:8px}.brand-dot{width:10px;height:10px;border-radius:3px;background:var(--accent);display:inline-block}.nav{display:flex;gap:4px}.nav a{text-decoration:none;color:var(--text-soft);padding:7px 14px;border-radius:var(--radius);font-size:14px}.nav a.active{background:var(--accent-soft);color:var(--accent-strong);font-weight:600}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:12px;color:var(--text-soft);font-size:14px}.page{flex:1;min-height:0;overflow:hidden}.auth-wrap{min-height:100%;display:flex;align-items:center;justify-content:center;padding:24px}.auth-card{width:100%;max-width:380px;background:var(--surface);border:1px solid var(--border);border-radius:16px;box-shadow:var(--shadow);padding:36px 32px}.auth-card h1{margin:0 0 4px;font-size:24px;display:flex;align-items:center;gap:10px}.auth-sub{color:var(--text-soft);font-size:14px;margin:0 0 24px}.field{margin-bottom:16px}.field label{display:block;font-size:13px;color:var(--text-soft);margin-bottom:6px}.auth-error{background:#fbe9e7;color:var(--danger);border-radius:var(--radius);padding:9px 12px;font-size:13px;margin-bottom:16px}.auth-switch{text-align:center;margin-top:18px;font-size:14px;color:var(--text-soft)}.materials{display:grid;grid-template-columns:220px 320px minmax(0,1fr);height:100%}.day-rail{border-right:1px solid var(--border);background:var(--surface-2);overflow-y:auto;padding:16px 12px}.rail-head{font-size:12px;letter-spacing:.5px;color:var(--text-faint);text-transform:uppercase;padding:0 6px 10px}.ym-row{display:flex;gap:8px;margin-bottom:12px}.ym-select{flex:1;width:100%;border:1px solid var(--border);border-radius:var(--radius);padding:7px 8px;font-size:13px;font-family:inherit;background:var(--surface);color:var(--text)}.ym-select:focus{outline:none;border-color:var(--accent)}.rail-subhead{font-size:11px;color:var(--text-faint);padding:0 6px 7px}.day-item{display:flex;align-items:center;justify-content:space-between;width:100%;border:none;background:transparent;text-align:left;padding:9px 12px;border-radius:var(--radius);font-size:14px;color:var(--text-soft);margin-bottom:2px}.day-item:hover{background:var(--accent-soft)}.day-item.active{background:var(--accent);color:#fff;font-weight:600}.day-item .count{font-size:12px;opacity:.7}.rail-empty{color:var(--text-faint);font-size:13px;padding:10px 8px;line-height:1.6}.mat-list-col{border-right:1px solid var(--border);background:var(--surface);display:flex;flex-direction:column;min-height:0}.mat-list-head{display:flex;align-items:center;gap:8px;padding:14px 14px 10px;border-bottom:1px solid var(--border);flex-shrink:0}.search-box{flex:1;display:flex;align-items:center;gap:7px;border:1px solid var(--border);border-radius:var(--radius);padding:6px 10px;background:var(--surface-2)}.search-box .search-icon{color:var(--text-faint);flex-shrink:0}.search-box input{border:none;background:transparent;outline:none;font-size:14px;font-family:inherit;color:var(--text);width:100%}.mat-list{flex:1;min-height:0;overflow-y:auto;padding:8px}.mat-list-item{width:100%;text-align:left;border:1px solid transparent;background:transparent;padding:10px 12px;border-radius:var(--radius);margin-bottom:3px}.mat-list-item:hover{background:var(--surface-2)}.mat-list-item.active{background:var(--accent-soft);border-color:var(--accent-soft)}.mli-title{font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mli-snippet{font-size:12px;color:var(--text-faint);margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mat-detail{min-width:0;overflow-y:auto;padding:40px 48px 56px}.material-editor{max-width:1040px;margin:0 auto}.mat-editor-titlebar{display:flex;align-items:flex-start;gap:14px;margin-bottom:14px}.material-editor .title-input,.mat-read-title{flex:1;min-width:0;margin:0;border:none;font-size:30px;font-weight:700;line-height:1.3;letter-spacing:.4px;font-family:var(--serif);background:transparent;color:var(--text);padding:2px 0}.material-editor .title-input:focus{outline:none}.mat-editor-tools{display:flex;align-items:center;gap:8px;flex-shrink:0;padding-top:4px}.material-meta{display:flex;align-items:center;gap:10px;color:var(--text-faint);font-size:13px;margin-bottom:24px}.meta-pill{display:inline-flex;align-items:center;gap:5px;font-size:12.5px;color:var(--text-soft);background:var(--surface-2);border:1px solid var(--border);padding:4px 11px;border-radius:999px}.meta-pill.soft{color:var(--text-faint)}.meta-pill svg{opacity:.8}.meta-daypick{display:inline-flex;align-items:center;gap:6px;color:var(--text-soft)}.material-meta .day-pick{border:1px solid var(--border);border-radius:6px;padding:3px 6px;font-family:inherit;color:var(--text-soft);background:var(--surface)}.mat-read{font-family:var(--serif);font-size:16.5px;line-height:1.95;color:var(--text);padding-bottom:24px}.content-area{width:100%;min-height:58vh;border:1px solid var(--border);border-radius:var(--radius);padding:20px 22px;font-size:15px;line-height:1.85;font-family:var(--sans);resize:vertical;background:var(--surface);color:var(--text)}.content-area:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.editor-actions{display:flex;align-items:center;gap:12px;margin-top:16px}.save-hint{font-size:13px;color:var(--text-faint)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;text-align:center;color:var(--text-faint);gap:14px;padding:24px}.empty h3{margin:0;color:var(--text-soft);font-weight:600}.write{display:flex;height:100%}.mat-drawer{flex:0 0 auto;border-right:1px solid var(--border);background:var(--surface-2);display:flex;flex-direction:column;min-height:0}.drawer-head{display:flex;align-items:center;gap:8px;padding:14px 14px 10px;flex-shrink:0}.drawer-add{padding:0 12px 10px;flex-shrink:0}.drawer-title{font-size:13px;font-weight:600;color:var(--text-soft)}.drawer-date{margin-left:auto;border:1px solid var(--border);border-radius:var(--radius);padding:5px 8px;font-size:12px;font-family:inherit;background:var(--surface);color:var(--text-soft)}.drawer-scroll{flex:1;min-height:0;overflow-y:auto;padding:0 12px 16px;overscroll-behavior:contain}.add-trigger{width:100%;display:flex;align-items:center;justify-content:center;gap:6px;border:1px dashed var(--accent);color:var(--accent-strong);background:transparent;padding:9px;border-radius:var(--radius);font-size:13px}.add-trigger:hover{background:var(--accent-soft)}.add-form{border:1px solid var(--accent);border-radius:var(--radius);background:var(--surface);overflow:hidden}.add-form-head{display:flex;align-items:center;gap:6px;padding:8px 10px;background:var(--accent-soft);color:var(--accent-strong);font-size:13px;font-weight:600}.add-title,.add-content{width:100%;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:13px;color:var(--text);background:var(--surface)}.add-title{margin:10px 10px 8px;width:calc(100% - 20px)}.add-content{margin:0 10px;width:calc(100% - 20px);min-height:70px;line-height:1.7;resize:vertical}.add-title:focus,.add-content:focus{outline:none;border-color:var(--accent)}.add-actions{display:flex;align-items:center;gap:8px;padding:10px}.add-day{font-size:12px;color:var(--text-faint);border:1px solid var(--border);border-radius:6px;padding:3px 7px;margin-right:auto}.drawer-card{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);margin-bottom:8px}.drawer-card.open{border-color:var(--accent)}.drawer-card-head{display:flex;align-items:center;gap:6px;width:100%;border:none;background:var(--surface);text-align:left;padding:9px 10px;color:var(--text);cursor:pointer;-webkit-user-select:none;user-select:none;position:sticky;top:0;z-index:2;border-radius:var(--radius) var(--radius) 0 0}.drawer-card:not(.open) .drawer-card-head{border-radius:var(--radius)}.drawer-card.open .drawer-card-head{background:var(--accent-soft);color:var(--accent-strong)}.dch-title{font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.drawer-card-head svg{margin-left:auto;flex-shrink:0;color:var(--text-faint)}.drawer-card.open .drawer-card-head svg{color:var(--accent-strong)}.drawer-card-snippet{padding:0 10px 9px;font-size:12px;color:var(--text-faint);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;cursor:pointer}.drawer-card-full{padding:10px 12px;font-size:12.5px;line-height:1.7;border-top:1px solid var(--border)}.dcb-actions{display:flex;justify-content:flex-end;padding:0 10px 10px}.dcb-actions .btn{color:var(--text-soft)}.drawer-card-edit{display:flex;flex-direction:column;gap:8px;padding:10px;border-top:1px solid var(--border)}.dce-title,.dce-content{width:100%;border:1px solid var(--border);border-radius:8px;padding:8px 10px;font-family:inherit;font-size:13px;color:var(--text);background:var(--surface)}.dce-content{min-height:180px;line-height:1.7;resize:vertical}.dce-title:focus,.dce-content:focus{outline:none;border-color:var(--accent);box-shadow:0 0 0 3px var(--accent-soft)}.dce-actions{display:flex;justify-content:flex-end;gap:8px}.drawer-empty{color:var(--text-faint);font-size:13px;padding:8px 4px;line-height:1.6}.editor-pane{flex:1;min-width:360px;display:flex;flex-direction:column;min-height:0}.editor-toolbar{display:flex;align-items:center;gap:14px;padding:12px 24px;border-bottom:1px solid var(--border);flex-shrink:0}.doc-switch{position:relative}.doc-switch-btn{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);padding:7px 12px;max-width:340px}.doc-switch-title{font-size:15px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.doc-switch-btn svg{color:var(--text-faint);flex-shrink:0}.menu-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20}.doc-menu{position:absolute;top:calc(100% + 6px);left:0;z-index:21;width:320px;max-height:380px;display:flex;flex-direction:column;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}.doc-menu-new{display:flex;align-items:center;gap:8px;border:none;background:transparent;padding:11px 14px;font-size:14px;color:var(--accent-strong);border-bottom:1px solid var(--border)}.doc-menu-new:hover{background:var(--accent-soft)}.doc-menu-list{overflow-y:auto;padding:6px}.doc-menu-item{width:100%;text-align:left;border:none;background:transparent;padding:9px 10px;border-radius:8px}.doc-menu-item:hover{background:var(--surface-2)}.doc-menu-item.active{background:var(--accent-soft)}.dmi-title{display:block;font-size:14px;font-weight:600;color:var(--text);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.dmi-time{font-size:12px;color:var(--text-faint)}.toolbar-meta{margin-left:auto;display:flex;align-items:center;gap:14px;font-size:13px;color:var(--text-faint);white-space:nowrap}.toolbar-meta .save-ok{color:#2e7d52}.seg{display:inline-flex;border:1px solid var(--border);border-radius:8px;overflow:hidden}.seg button{border:none;background:var(--surface);color:var(--text-soft);padding:5px 12px;font-size:13px}.seg button.active{background:var(--accent);color:#fff}.write-body{flex:1;min-height:0;display:flex;flex-direction:column}.write-title{border:none;background:transparent;font-size:24px;font-weight:700;padding:22px 44px 10px;flex-shrink:0}.write-title:focus{outline:none}.write-area{flex:1;min-height:0;border:none;resize:none;padding:6px 44px 44px;line-height:1.9;background:transparent;overflow-y:auto}.write-area:focus{outline:none}.preview{flex:0 1 auto;min-width:260px;border-left:1px solid var(--border);padding:22px 40px 44px;overflow-y:auto}.resize-handle{flex:0 0 6px;cursor:col-resize;position:relative;background:transparent;touch-action:none}.resize-handle:after{content:"";position:absolute;top:0;bottom:0;left:50%;width:1px;transform:translate(-50%);background:var(--border);transition:background .12s,width .12s}.resize-handle:hover:after{background:var(--accent);width:3px}.appear{position:relative}.appear-menu{position:absolute;top:calc(100% + 8px);right:0;z-index:21;width:250px;background:var(--surface);border:1px solid var(--border);border-radius:12px;box-shadow:var(--shadow);padding:12px}.appear-label{font-size:12px;color:var(--text-faint);margin:8px 2px 6px}.appear-label:first-child{margin-top:0}.appear-row{display:flex;flex-wrap:wrap;gap:6px}.chip{border:1px solid var(--border);background:var(--surface);color:var(--text);border-radius:8px;padding:5px 12px;font-size:13px}.chip:hover{border-color:var(--text-faint)}.chip.active{border-color:var(--accent);background:var(--accent-soft);color:var(--accent-strong)}.swatch{width:30px;height:30px;border-radius:8px;border:1px solid var(--border);padding:0}.swatch.active{box-shadow:0 0 0 2px var(--accent);border-color:var(--accent)}.prose{font-family:var(--serif);color:var(--text);line-height:1.8;font-size:16px}.preview .prose{max-width:760px;margin:0 auto}.prose h1{font-size:28px;margin:.6em 0 .4em}.prose h2{font-size:23px;margin:1em 0 .4em}.prose h3{font-size:19px;margin:1em 0 .4em}.prose p{margin:.6em 0}.prose ul,.prose ol{padding-left:1.4em;margin:.6em 0}.prose li{margin:.2em 0}.prose blockquote{border-left:3px solid var(--accent);margin:.8em 0;padding:4px 14px;color:var(--text-soft);background:var(--accent-soft);border-radius:0 8px 8px 0}.prose code{font-family:SFMono-Regular,Consolas,monospace;background:#efece6;padding:1px 6px;border-radius:5px;font-size:.88em}.prose pre{background:#2b2a28;color:#f3efe7;padding:14px;border-radius:var(--radius);overflow-x:auto}.prose pre code{background:transparent;color:inherit;padding:0}.prose hr{border:none;border-top:1px solid var(--border);margin:1.4em 0}.drawer-card-full.prose{font-size:12.5px}.drawer-card-full.prose h1{font-size:16px}.drawer-card-full.prose h2{font-size:15px}.drawer-card-full.prose h3{font-size:14px}.context-menu{position:fixed;z-index:40;min-width:132px;background:var(--surface);border:1px solid var(--border);border-radius:8px;box-shadow:var(--shadow);padding:5px}.context-menu button{display:flex;align-items:center;gap:8px;width:100%;border:none;background:transparent;text-align:left;padding:8px 10px;border-radius:6px;font-size:13px;color:var(--text)}.context-menu button:hover{background:var(--surface-2)}.context-menu button.danger{color:var(--danger)}.context-menu button.danger:hover{background:#fbe9e7}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;z-index:50;background:#231e1666;display:flex;align-items:center;justify-content:center;padding:24px}.modal-card{width:100%;max-width:380px;background:var(--surface);border-radius:14px;box-shadow:var(--shadow);padding:24px 24px 20px}.modal-title{margin:0 0 8px;font-size:17px}.modal-message{margin:0 0 20px;font-size:14px;color:var(--text-soft);line-height:1.6}.modal-actions{display:flex;justify-content:flex-end;gap:10px}.center-loading{display:flex;align-items:center;justify-content:center;height:100%;color:var(--text-faint)}.icon-btn{display:inline-flex;align-items:center;justify-content:center;border:none;background:transparent;color:var(--text-faint);padding:5px;border-radius:6px}.icon-btn:hover{background:#fbe9e7;color:var(--danger)}
