*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}:root{--font-serif: "STSong", "Songti SC", "Cormorant Garamond", "Source Han Serif SC", serif;--font-sans: "Outfit", "PingFang SC", "Microsoft YaHei", sans-serif;--transition: all .4s cubic-bezier(.2, .8, .2, 1);--radius-sm: 4px}:root[data-theme=dark],:root{--bg-main: #121211;--bg-secondary: #0a0a09;--bg-card: #181816;--bg-card-hover: #1f1f1d;--bg-input: #1f1f1d;--bg-header: rgba(18, 18, 17, .85);--text-primary: #f2efe9;--text-secondary: #dcd8d0;--text-muted: #8d8a83;--accent: #c49a6c;--accent-dim: rgba(196, 154, 108, .4);--accent-bg: rgba(196, 154, 108, .08);--border: #2a2a28;--shadow-card: 0 12px 32px rgba(0,0,0,.4)}:root[data-theme=light]{--bg-main: #f0eee9;--bg-secondary: #e6e3dd;--bg-card: #f6f5f0;--bg-card-hover: #fdfdf9;--bg-input: #f6f5f0;--bg-header: rgba(240, 238, 233, .85);--text-primary: #3b3a38;--text-secondary: #5a5753;--text-muted: #8a8781;--accent: #93683a;--accent-dim: rgba(147, 104, 58, .3);--accent-bg: rgba(147, 104, 58, .05);--border: #dcd9d2;--shadow-card: 0 12px 32px rgba(0,0,0,.04)}html{font-size:16px;scroll-behavior:smooth}body{font-family:var(--font-sans);background:var(--bg-main);color:var(--text-primary);line-height:1.65;min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app{min-height:100vh;display:flex;flex-direction:column}.header{padding:24px 40px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid var(--border);background:var(--bg-header);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);position:sticky;top:0;z-index:100}.logo{display:flex;align-items:center;gap:14px;cursor:pointer;transition:opacity .3s ease}.logo:hover{opacity:.8}.logo-icon{width:28px;height:28px;border:1px solid var(--accent-dim);border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:14px;background:var(--accent-bg)}.logo-text{font-family:var(--font-sans);font-size:1.05rem;font-weight:300;color:var(--text-primary);letter-spacing:.25em}.nav-links{display:flex;gap:32px;align-items:center}.nav-link{font-family:var(--font-sans);font-size:.95rem;font-weight:300;color:var(--text-muted);cursor:pointer;transition:var(--transition);padding-bottom:4px;border-bottom:1px dashed transparent;letter-spacing:.05em}.nav-link.active{color:var(--accent);border-bottom:1px solid var(--accent)}.nav-link:hover{color:var(--text-primary)}.main{flex:1;padding:60px 40px;max-width:1100px;margin:0 auto;width:100%}.library-hero{text-align:center;padding:60px 0 80px}.library-hero h1{font-family:var(--font-serif);font-size:3.2rem;font-weight:400;margin-bottom:16px;letter-spacing:.02em;color:var(--text-primary)}.library-hero p{font-family:var(--font-sans);font-weight:300;color:var(--text-secondary);font-size:1.05rem;max-width:480px;margin:0 auto;line-height:1.8}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:28px;margin-top:20px}.book-card{background:transparent;border:none;cursor:pointer;display:flex;flex-direction:column}.book-card-cover-wrapper{position:relative;width:100%;height:280px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);padding:24px;overflow:hidden;transition:all .4s ease}.book-card-cover{width:100%;height:100%;object-fit:contain;display:block;filter:drop-shadow(0 8px 16px rgba(0,0,0,.6)) sepia(.15) contrast(.95);transition:all .5s ease;position:relative;z-index:1}.book-card-overlay{position:absolute;bottom:0;left:0;right:0;top:0;display:flex;justify-content:center;align-items:center;background:#121211d9;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);opacity:0;transition:opacity .3s ease;z-index:2}.book-card-overlay span{color:var(--text-primary);font-family:var(--font-serif);font-size:1.15rem;letter-spacing:.1em;border:1px solid var(--accent);padding:10px 24px;border-radius:4px;transform:translateY(10px);transition:transform .3s ease}.book-card:hover .book-card-cover-wrapper{transform:scale(1.03);border-color:var(--accent-dim);box-shadow:var(--shadow-card)}.book-card:hover .book-card-cover{filter:drop-shadow(0 16px 32px rgba(0,0,0,.9)) sepia(0) contrast(1.05)}.book-card:hover .book-card-overlay{opacity:1}.book-card:hover .book-card-overlay span{transform:translateY(0)}.book-card-body{padding:16px 0 0;display:flex;justify-content:center}.book-card-domain{display:inline-block;font-size:.75rem;color:var(--text-muted);letter-spacing:.08em;text-transform:uppercase;font-family:var(--font-sans);transition:color .3s ease}.book-card:hover .book-card-domain{color:var(--accent)}.chat-view{display:flex;flex-direction:column;height:calc(100vh - 100px);max-width:760px;margin:0 auto}.chat-header{display:flex;align-items:center;gap:20px;padding:0 0 24px;border-bottom:1px solid var(--border);margin-bottom:24px}.chat-header-cover{width:52px;height:74px;border-radius:2px;object-fit:cover;border:1px solid var(--border)}.chat-header-info h2{font-family:var(--font-serif);font-size:1.4rem;font-weight:500;margin-bottom:4px;letter-spacing:.02em}.chat-header-info p{color:var(--accent);font-size:.85rem;letter-spacing:.05em;text-transform:uppercase;font-weight:300}.chat-back-btn{background:transparent;border:1px solid var(--border);color:var(--text-secondary);padding:8px 16px;border-radius:20px;cursor:pointer;font-size:.85rem;font-weight:300;transition:var(--transition);margin-left:auto}.chat-back-btn:hover{border-color:var(--accent-dim);color:var(--text-primary);background:var(--accent-bg)}.chat-messages{flex:1;overflow-y:auto;padding:20px 10px;display:flex;flex-direction:column;gap:32px;scrollbar-width:thin;scrollbar-color:var(--border-light) transparent}.chat-messages::-webkit-scrollbar{width:4px}.chat-messages::-webkit-scrollbar-track{background:transparent}.chat-messages::-webkit-scrollbar-thumb{background:var(--border-light);border-radius:2px}.msg{max-width:88%;font-size:1rem;line-height:1.8;animation:fadeIn .4s ease}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}.msg-user{align-self:flex-end;background:var(--bg-secondary);border:1px solid var(--border-light);color:var(--text-primary);padding:16px 24px;border-radius:var(--radius-md);border-bottom-right-radius:2px;font-weight:300}.msg-assistant{align-self:flex-start;color:var(--text-primary);padding:0;background:transparent;border:none;font-weight:300}.msg-assistant h1,.msg-assistant h2,.msg-assistant h3{font-family:var(--font-serif);color:var(--accent);font-weight:400;margin:1.5em 0 .5em;letter-spacing:.02em}.msg-assistant h3{font-size:1.15rem}.msg-assistant p{margin:.8em 0;color:var(--text-primary)}.msg-copy-btn{position:absolute;top:0;right:-50px;background:var(--bg-secondary);border:1px solid var(--border);color:var(--text-muted);border-radius:var(--radius-sm);padding:4px 10px;font-size:.75rem;font-family:var(--font-sans);cursor:pointer;opacity:0;transition:var(--transition)}.msg:hover .msg-copy-btn{opacity:1}.msg-copy-btn:hover{background:var(--bg-card);color:var(--accent);border-color:var(--accent-dim)}.msg-assistant ul,.msg-assistant ol{padding-left:24px;margin:1em 0;color:var(--text-secondary)}.msg-assistant li{margin:.5em 0;padding-left:8px}.msg-assistant li::marker{color:var(--accent-dim)}.msg-assistant strong{color:var(--text-primary);font-weight:500}.msg-assistant blockquote{border-left:1px solid var(--accent);padding-left:20px;color:var(--text-secondary);font-family:var(--font-serif);font-size:1.15rem;font-style:italic;margin:1.5em 0;background:var(--accent-bg);padding-top:10px;padding-bottom:10px}.typing-cursor{display:inline-block;width:6px;height:1.1em;background-color:var(--accent);vertical-align:text-bottom;margin-left:4px;animation:blink .8s ease infinite}@keyframes blink{0%,to{opacity:1}50%{opacity:0}}.msg-system{align-self:center;color:var(--text-muted);font-size:.8rem;font-style:italic;text-align:center;border-bottom:1px solid var(--border);padding-bottom:8px;margin-bottom:16px;max-width:80%;font-family:var(--font-serif)}.msg-loading{display:flex;align-items:center;gap:12px;padding:0}.dot-pulse{display:flex;gap:6px}.dot-pulse span{width:6px;height:6px;background:var(--accent-dim);border-radius:50%;opacity:.4;animation:pulse 1.4s ease-in-out infinite}.dot-pulse span:nth-child(2){animation-delay:.2s}.dot-pulse span:nth-child(3){animation-delay:.4s}@keyframes pulse{0%,to{transform:translateY(0);opacity:.4}50%{transform:translateY(-3px);opacity:1}}.chat-input-area{padding:24px 0 0;margin-top:20px;border-top:1px solid var(--border)}.chat-input-row{display:flex;gap:16px;align-items:flex-end}.chat-input{flex:1;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);padding:16px 20px;font-size:1rem;font-family:var(--font-sans);font-weight:300;resize:none;min-height:56px;max-height:140px;transition:var(--transition);outline:none}.chat-input:focus{border-color:var(--accent-dim);background:var(--bg-card)}.chat-input::placeholder{color:var(--text-muted);font-weight:300}.chat-send-btn{background:var(--accent);border:1px solid transparent;color:#fff;padding:0 24px;height:56px;border-radius:var(--radius-sm);cursor:pointer;font-size:.95rem;font-weight:500;transition:var(--transition);font-family:var(--font-sans)}.chat-send-btn:hover:not(:disabled){opacity:.9;filter:brightness(1.1)}.chat-send-btn:disabled{background:var(--bg-secondary);color:var(--text-muted);border-color:var(--border);cursor:not-allowed}.chat-guardrail-note{font-size:.75rem;font-family:var(--font-serif);color:var(--text-muted);text-align:center;margin-top:12px;letter-spacing:.02em}.loading-page{display:flex;align-items:center;justify-content:center;min-height:50vh;color:var(--text-secondary);gap:16px;font-size:1rem;font-family:var(--font-serif);font-style:italic}.spinner{width:20px;height:20px;border:1px solid var(--border-light);border-top-color:var(--accent);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.error-banner{background:transparent;border:1px solid var(--danger);color:var(--danger);padding:16px 20px;border-radius:var(--radius-sm);font-size:.9rem;margin:24px 0;font-family:var(--font-monospace, monospace)}.vision-view{max-width:680px;margin:0 auto;padding:20px 0 80px}.vision-view h1{font-family:var(--font-serif);color:var(--accent);font-size:2.2rem;font-weight:400;margin-bottom:48px;line-height:1.3;text-align:center}.vision-view h2{font-family:var(--font-serif);font-size:1.4rem;color:var(--text-primary);font-weight:400;margin:40px 0 20px;border-bottom:1px solid var(--border);padding-bottom:8px}.vision-view p{font-family:var(--font-sans);font-weight:300;font-size:1.05rem;color:var(--text-secondary);line-height:1.8;margin-bottom:24px}.vision-view strong{color:var(--text-primary);font-weight:500}.vision-view blockquote{border-left:2px solid var(--accent);padding-left:20px;margin:32px 0;font-style:italic}.article-list{display:flex;flex-direction:column;gap:20px;margin-top:32px;max-width:800px;margin-left:auto;margin-right:auto}.article-item{display:flex;gap:24px;align-items:center;padding:24px;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.article-item:hover{background:var(--bg-card-hover);border-color:var(--accent-dim);transform:translate(4px)}.article-item-cover-wrapper{flex-shrink:0;width:100px;height:100px;border-radius:var(--radius-sm);overflow:hidden;border:1px solid var(--border)}.article-item-cover{width:100%;height:100%;object-fit:cover;filter:sepia(.2) contrast(.9);transition:var(--transition)}.article-item:hover .article-item-cover{filter:sepia(0) contrast(1);transform:scale(1.05)}.article-item-content{flex:1;display:flex;flex-direction:column;justify-content:center}.article-title{font-family:var(--font-serif);font-size:1.4rem;color:var(--text-primary);margin-bottom:12px;font-weight:500;line-height:1.3}.article-date{font-size:.85rem;color:var(--text-muted);font-family:var(--font-sans);font-weight:300}.empty-state{color:var(--text-muted);font-family:var(--font-serif);font-style:italic;padding:60px 0;text-align:center}.article-detail-view{max-width:760px;margin:0 auto;padding:0 0 80px}.article-main-title{font-family:var(--font-serif);font-size:2.4rem;color:var(--accent);margin-bottom:48px;line-height:1.4;font-weight:400}.article-content{font-family:var(--font-sans);font-size:1.1rem;line-height:1.85;color:var(--text-secondary);font-weight:300}.article-content h1,.article-content h2,.article-content h3{font-family:var(--font-serif);color:var(--text-primary);margin:2em 0 1em;font-weight:400}.article-content p{margin-bottom:1.5em}.article-content img{max-width:100%;border-radius:var(--radius-sm);margin:32px 0;border:1px solid var(--border);filter:sepia(.1) contrast(.95)}.article-content blockquote{border-left:2px solid var(--accent);padding-left:20px;margin:32px 0;font-style:italic;font-family:var(--font-serif);font-size:1.15rem;color:var(--text-muted)}.article-content ul,.article-content ol{padding-left:24px;margin-bottom:1.5em}@media(max-width:768px){.header{padding:12px 20px;flex-wrap:wrap;gap:12px}.logo-text{font-size:.9rem;letter-spacing:.1em}.nav-links{width:100%;justify-content:space-between;gap:8px;font-size:.85rem}.header-tagline{display:none}.main{padding:24px 16px}.library-hero h1{font-size:1.8rem}.book-grid{grid-template-columns:repeat(2,1fr);gap:12px}.book-card-domain{font-size:.7em;padding:4px}.msg{max-width:95%;font-size:.95rem}.chat-view{height:calc(100vh - 110px)}.chat-header-info h2{font-size:1.1rem}.chat-input{font-size:.85rem;padding:12px;min-height:48px}.chat-send-btn{height:48px;padding:0 16px;font-size:.85rem}.article-main-title{font-size:1.8rem;margin-bottom:32px}.article-content{font-size:1rem}}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border);border-radius:6px;border:2px solid var(--bg-main)}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.footer{text-align:center;padding:40px 20px 24px;font-size:.85rem;color:var(--text-muted);font-family:var(--font-sans);border-top:1px solid var(--border);margin-top:auto}.footer p{margin-bottom:4px}.ai-disclaimer{font-size:.75rem;opacity:.7}.todo-fab{position:fixed;top:50%;left:0;transform:translateY(-50%);background:var(--accent);color:#fff;border:1px solid var(--accent);border-left:none;border-radius:0 12px 12px 0;padding:16px 8px 16px 12px;font-size:.9rem;font-family:var(--font-sans);cursor:pointer;box-shadow:4px 0 12px #00000026;transition:transform .3s cubic-bezier(.4,0,.2,1),background .3s,opacity .3s;z-index:900;font-weight:600;writing-mode:vertical-rl;text-orientation:mixed;letter-spacing:2px;display:flex;align-items:center;gap:8px}.todo-fab:hover{background:var(--text-primary);border-color:var(--text-primary);color:var(--bg-primary);transform:translateY(-50%) translate(2px)}.todo-fab.hidden{transform:translateY(-50%) translate(-100%);opacity:0;pointer-events:none}@media(max-width:768px){.todo-fab{top:auto;bottom:24px;left:auto;right:24px;transform:none;writing-mode:horizontal-tb;border-radius:30px;padding:12px 20px;border:none;box-shadow:0 4px 12px #0003;letter-spacing:normal}.todo-fab:hover{transform:translateY(-2px)}.todo-fab.hidden{transform:translateY(100px)}}.todo-drawer{position:fixed;top:0;left:0;width:380px;max-width:90vw;height:100vh;max-height:100vh;background:var(--bg-main);border-right:1px solid var(--border);box-shadow:4px 0 24px #00000026;display:flex;flex-direction:column;transform:translate(-100%);opacity:0;transition:transform .4s cubic-bezier(.16,1,.3,1),opacity .3s;z-index:950;pointer-events:none}.todo-drawer.open{transform:translate(0);opacity:1;pointer-events:auto}@media(max-width:768px){.todo-drawer{top:auto;bottom:0;left:0;width:100%;max-width:100%;height:80vh;border-right:none;border-top:1px solid var(--border);border-radius:16px 16px 0 0;transform:translateY(100%)}.todo-drawer.open{transform:translateY(0)}}.todo-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border)}.todo-header h3{font-family:var(--font-serif);font-size:1.2rem;color:var(--accent);margin:0;font-weight:500}.todo-close-btn{background:transparent;border:none;font-size:1.5rem;color:var(--text-muted);cursor:pointer;line-height:1;transition:var(--transition)}.todo-close-btn:hover{color:var(--text-primary)}.todo-content{padding:20px 24px;display:flex;flex-direction:column;overflow-y:auto;gap:16px}.todo-subtitle{font-size:.85rem;color:var(--text-muted);margin:0;font-family:var(--font-sans)}.todo-input-row{display:flex;gap:8px}.todo-input-row input{flex:1;padding:10px 12px;background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-family:var(--font-sans);font-size:.9rem;outline:none}.todo-input-row input:focus{border-color:var(--accent-dim)}.todo-input-row button{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:0 16px;border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition)}.todo-input-row button:hover{background:var(--text-primary);color:var(--bg-primary)}.todo-list{display:flex;flex-direction:column;gap:10px;margin-top:8px}.todo-empty{text-align:center;color:var(--text-muted);font-size:.85rem;padding:24px 0;font-style:italic}.todo-item{display:flex;align-items:flex-start;gap:12px;background:var(--bg-card);padding:12px 16px;border:1px solid var(--border-light);border-radius:var(--radius-sm);transition:var(--transition)}.todo-item:hover{border-color:var(--border)}.todo-item.completed{opacity:.5}.todo-item.completed .todo-text{text-decoration:line-through}.todo-text{flex:1;font-size:.9rem;line-height:1.4;color:var(--text-primary);word-break:break-word}.todo-del-btn{background:transparent;border:none;color:var(--text-muted);cursor:pointer;font-size:1.1rem;opacity:0;transition:var(--transition)}.todo-item:hover .todo-del-btn{opacity:1}.todo-del-btn:hover{color:var(--danger)}.checkbox-container{display:block;position:relative;width:20px;height:20px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.checkbox-container input{position:absolute;opacity:0;cursor:pointer;height:0;width:0}.checkmark{position:absolute;top:0;left:0;height:20px;width:20px;background-color:transparent;border:2px solid var(--text-muted);border-radius:4px;transition:var(--transition)}.checkbox-container:hover input~.checkmark{border-color:var(--text-primary)}.checkbox-container input:checked~.checkmark{background-color:var(--accent);border-color:var(--accent)}.checkmark:after{content:"";position:absolute;display:none}.checkbox-container input:checked~.checkmark:after{display:block}.checkbox-container .checkmark:after{left:6px;top:2px;width:5px;height:10px;border:solid white;border-width:0 2px 2px 0;transform:rotate(45deg)}
