:root{--ink: #e7e7ea;--ink-dim: #c2c3c8;--muted: #989aa1;--faint: #6e7077;--amber: #d6b27a;--amber-bright: #e6c99b;--amber-soft: rgba(214, 178, 122, .1);--danger: #c2897a;--line: rgba(231, 231, 234, .1);--line-strong: rgba(231, 231, 234, .18);--panel: rgba(16, 18, 16, .52);--panel-2: rgba(20, 22, 20, .82);--radius: 14px;--radius-sm: 10px;--shadow: 0 24px 64px rgba(0, 0, 0, .5);--shadow-soft: 0 14px 36px rgba(0, 0, 0, .38);--font-serif: "Cormorant Garamond", "Noto Serif SC", "Songti SC", serif;--font-sans: "Inter", -apple-system, BlinkMacSystemFont, "PingFang SC", "Noto Sans SC", "Microsoft YaHei", system-ui, sans-serif;color:var(--ink);font-family:var(--font-sans);font-weight:400;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}html,body{margin:0;min-height:100%}body{min-width:320px;color:var(--ink);text-shadow:0 1px 16px rgba(0,0,0,.55);background:linear-gradient(180deg,#080a0852,#080a087a 55%,#060706b8),url(/assets/reading-room-bg-CgALyzkW.jpg) center center / cover fixed no-repeat,#0a0b0a}body:before{content:"";position:fixed;inset:0;pointer-events:none;z-index:0;background:radial-gradient(135% 105% at 50% 28%,transparent 60%,rgba(5,6,5,.42) 100%)}#root{position:relative;z-index:1;min-height:100vh}button,input,textarea,select{font:inherit;color:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.5}::selection{background:#d6b27a42}h1,h2,h3{margin:0;font-family:var(--font-serif);font-weight:400;color:var(--ink);letter-spacing:.01em}h1{font-size:26px;line-height:1.22}h2{font-size:18px;line-height:1.3}.eyebrow{margin:0 0 10px;color:var(--faint);font-family:var(--font-sans);font-size:11px;font-weight:400;letter-spacing:.24em;text-transform:uppercase}.subtitle,.muted{color:var(--muted);font-size:14px;font-weight:400;line-height:1.65}.topbar{display:flex;align-items:center;justify-content:space-between;gap:18px;padding:22px 0 26px}.brand{border:0;background:transparent;padding:0;display:inline-flex;align-items:baseline;gap:8px;color:var(--ink-dim)}.brand-cn{font-family:var(--font-serif);font-size:18px;font-weight:500;letter-spacing:.06em;color:var(--ink-dim)}.brand-en{font-size:9px;letter-spacing:.36em;text-transform:uppercase;color:var(--faint)}.topnav{display:inline-flex;align-items:center;gap:18px}.navlink{border:0;background:transparent;padding:0;color:var(--muted);display:inline-flex;align-items:center;gap:5px;font-size:13px;font-weight:400;letter-spacing:.02em;transition:color .14s ease}.navlink:hover{color:var(--ink)}.navlink.readonly{color:var(--faint)}.icon-button,.send-button{border:1px solid rgba(214,178,122,.42);border-radius:999px;background:var(--amber-soft);color:var(--amber-bright);display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:0 20px;font-weight:400;letter-spacing:.02em;transition:background .16s ease,border-color .16s ease}.icon-button:hover:not(:disabled),.send-button:hover:not(:disabled){background:#d6b27a2e;border-color:var(--amber)}.text-button,.back-button{border:0;background:transparent;color:var(--muted);display:inline-flex;align-items:center;gap:7px;padding:0;font-weight:400;transition:color .14s ease}.text-button:hover,.back-button:hover{color:var(--ink)}.secondary-button,.mini-button{border:1px solid var(--line-strong);border-radius:999px;background:#10121066;color:var(--ink-dim);display:inline-flex;align-items:center;justify-content:center;gap:6px;min-height:34px;padding:0 14px;font-size:13px;font-weight:400;transition:border-color .14s ease,color .14s ease}.secondary-button:hover:not(:disabled),.mini-button:hover:not(:disabled){border-color:var(--line-strong);color:var(--ink)}.mini-button{min-height:30px;padding:0 11px;font-size:12px;color:var(--muted)}.mini-button.danger{color:var(--danger)}.ghost-icon{width:36px;height:36px;border:1px solid var(--line-strong);border-radius:50%;background:transparent;color:var(--muted);display:inline-flex;align-items:center;justify-content:center;transition:color .14s ease,border-color .14s ease}.ghost-icon:hover{color:var(--ink);border-color:var(--line-strong)}.shelf,.reading,.archive,.users{width:100%;margin:0 auto;padding:0 clamp(20px,4vw,56px) 80px}.shelf{max-width:1120px}.reading{max-width:1280px}.archive{max-width:900px}.users{max-width:980px}.page-state{display:flex;align-items:center;justify-content:center;min-height:70vh;color:var(--muted);font-family:var(--font-serif);font-style:italic;font-size:17px}.shelf-hero{display:flex;align-items:flex-end;justify-content:space-between;gap:28px;padding:18px 0 30px;margin-bottom:14px;border-bottom:1px solid var(--line)}.hero-title{font-size:clamp(22px,2.6vw,30px);font-weight:400;line-height:1.2;max-width:16em;color:var(--ink)}.hero-quote{margin:14px 0 0;font-family:var(--font-serif);font-style:italic;font-size:17px;font-weight:400;color:var(--ink-dim)}.hero-right{flex:0 0 auto;display:grid;justify-items:end;gap:10px;text-align:right}.night-chip{display:inline-flex;align-items:center;gap:7px;color:var(--muted);font-size:13px;letter-spacing:.04em}.night-chip svg{color:var(--amber);opacity:.8}.stat-line{color:var(--faint);font-size:12.5px;letter-spacing:.02em}.shelf-block{margin-top:36px}.block-head{display:flex;align-items:center;gap:14px;margin-bottom:20px}.block-label{font-size:11px;font-weight:400;letter-spacing:.26em;text-transform:uppercase;color:var(--muted);white-space:nowrap}.block-head .line{flex:1;height:1px;background:var(--line)}.empty-state{min-height:84px;border:1px dashed var(--line-strong);border-radius:var(--radius);color:var(--muted);display:flex;align-items:center;justify-content:center;padding:22px;font-size:14px}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(146px,1fr));gap:26px 22px}.book-card{min-width:0;display:grid;grid-template-rows:1fr auto;gap:10px}.book-open{border:0;background:transparent;text-align:left;color:inherit;padding:0;display:grid;gap:9px;min-width:0;outline:none}.book-cover{width:100%;aspect-ratio:2 / 3;object-fit:cover;border-radius:var(--radius-sm);background:#1a1c1a;border:1px solid var(--line);box-shadow:var(--shadow-soft);transition:transform .2s ease,box-shadow .2s ease}.book-cover-empty{display:block;background:linear-gradient(155deg,#20231f,#121412)}.book-open:hover .book-cover,.book-open:focus-visible .book-cover{transform:translateY(-4px);box-shadow:0 28px 56px #0000008c}.book-title{font-family:var(--font-serif);font-size:16px;font-weight:500;line-height:1.3;color:var(--ink)}.book-author,.book-meta,.book-one-line{color:var(--muted);font-size:12.5px;line-height:1.5}.book-meta{color:var(--faint)}.book-one-line{font-family:var(--font-serif);font-style:italic;color:var(--ink-dim);display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.card-actions{display:flex;flex-wrap:wrap;gap:8px;min-height:30px}.year-list{display:grid;gap:8px}.year-section{display:grid;gap:20px}.year-toggle{width:100%;border:0;border-bottom:1px solid var(--line);background:transparent;color:var(--ink-dim);display:flex;align-items:center;gap:12px;min-height:48px;padding:4px 2px 12px;text-align:left;transition:color .14s ease}.year-toggle:hover{color:var(--ink)}.year-name{flex:1;min-width:0;display:inline-flex;align-items:center;gap:10px}.year-name svg,.year-chevron{color:var(--muted);flex:0 0 auto}.year-name h3{margin:0;font-size:17px;font-weight:400;color:inherit}.year-count{color:var(--faint);font-size:12px;letter-spacing:.04em;white-space:nowrap}.year-grid{padding-top:4px}.reading-top{margin-bottom:16px}.reading-grid{display:grid;grid-template-columns:minmax(300px,360px) minmax(0,1fr);gap:24px;align-items:start}.book-pane,.chat-pane{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px)}.book-pane{padding:22px;display:grid;gap:20px;align-content:start}.pane-cover{width:100%;max-width:200px;margin:0 auto;aspect-ratio:2 / 3}.book-headline h1{font-size:24px;line-height:1.24}.book-headline .subtitle{margin-top:6px}.progress-field{display:grid;gap:8px;margin:0}.progress-field>span{font-size:11px;letter-spacing:.18em;text-transform:uppercase;color:var(--faint)}.progress-field small{color:var(--amber);font-size:12px}.saved-block{border-top:1px solid var(--line);padding-top:20px;display:grid;gap:14px}.saved-head{display:flex;align-items:center;justify-content:space-between;gap:12px}.saved-head h2{font-size:15px;letter-spacing:.02em}.artifact{border-left:1px solid var(--line-strong);padding:2px 0 2px 14px;display:grid;gap:6px}.artifact-head{display:flex;align-items:center;justify-content:space-between;gap:10px}.artifact-title{font-family:var(--font-serif);font-size:15px;font-weight:500;color:var(--ink)}.artifact-actions{display:inline-flex;flex-wrap:wrap;gap:6px;justify-content:flex-end}.artifact p{margin:0;color:var(--ink-dim);font-size:14px;line-height:1.7;overflow-wrap:anywhere}.quote-item p:first-of-type{font-family:var(--font-serif);font-style:italic;color:var(--ink)}.quote-meta{display:block;color:var(--muted);font-size:12px;letter-spacing:.04em}.quote-note{color:var(--muted)!important;font-size:13px!important}.artifact-link{justify-self:start}.chat-pane{display:grid;grid-template-rows:auto 1fr auto;min-height:calc(100vh - 130px);overflow:hidden}.chat-head{padding:20px 22px;border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between}.chat-head h2{font-size:17px}.chat-head svg{color:var(--muted)}.messages{padding:22px;overflow-y:auto;display:flex;flex-direction:column;gap:18px}.chat-empty{margin:auto;text-align:center;color:var(--muted);font-family:var(--font-serif);font-style:italic;font-size:17px}.message{display:flex;flex-direction:column;gap:8px;max-width:min(680px,88%)}.message-user{align-self:flex-end;align-items:flex-end}.message-assistant{align-self:flex-start}.message-content{border-radius:var(--radius);padding:13px 16px;line-height:1.78;font-size:14.5px;font-weight:400;white-space:pre-wrap;overflow-wrap:anywhere}.message-content p{margin:0}.message-assistant .message-content{background:#e7e7ea0d;border:1px solid var(--line);color:var(--ink-dim)}.message-user .message-content{background:#d6b27a1a;border:1px solid rgba(214,178,122,.22);color:var(--ink)}.message-failed .message-content{border-color:#c2897a66;background:#c2897a1a}.pending-label{display:inline-flex;align-items:center;gap:6px;color:var(--amber);font-size:12px;letter-spacing:.04em}.pending-label:before{content:"";width:6px;height:6px;border-radius:50%;background:var(--amber);animation:pulse 1.4s ease-in-out infinite}.failed-label{color:var(--danger)}.failed-label:before{display:none}@keyframes pulse{0%,to{opacity:.35}50%{opacity:1}}.message-actions{display:flex;gap:8px;flex-wrap:wrap}.action-error{display:block;margin-top:6px;color:var(--danger);font-size:12px}.chat-input{padding:16px 22px 20px;border-top:1px solid var(--line);display:grid;grid-template-columns:minmax(0,1fr) 48px;gap:10px;align-items:end}.send-button{width:48px;height:48px;padding:0;min-height:0}.readonly-note,.readonly-chat{border:1px solid var(--line);border-radius:var(--radius-sm);background:#1012105c;color:var(--muted);padding:12px 14px;font-size:13px;text-align:center}.readonly-chat{margin:0 22px 18px}label{display:grid;gap:8px;margin-bottom:14px;color:var(--muted);font-size:12px;font-weight:400;letter-spacing:.02em}label>span{letter-spacing:.04em}input,select,textarea{width:100%;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:#08090880;color:var(--ink);outline:none;padding:11px 13px;font-weight:400;transition:border-color .14s ease,box-shadow .14s ease}input::placeholder,textarea::placeholder{color:var(--faint)}textarea{resize:vertical;line-height:1.7}input:focus,select:focus,textarea:focus{border-color:#d6b27a80;box-shadow:0 0 0 3px #d6b27a1a}.check-row{grid-template-columns:18px 1fr;align-items:center;color:var(--ink-dim)}.check-row input{width:16px;height:16px;accent-color:var(--amber)}.two-column-fields{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.inline-actions{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.form-error,.inline-error{color:var(--danger);font-size:13px;line-height:1.5}.inline-error{margin:14px 0 0;padding:10px 12px;border:1px solid rgba(194,137,122,.3);border-radius:var(--radius-sm);background:#c2897a1a}.dialog-backdrop{position:fixed;inset:0;z-index:40;background:#050605b3;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;padding:22px}.dialog{width:min(440px,100%);max-height:calc(100vh - 44px);overflow-y:auto;border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--panel-2);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);padding:26px}.wide-dialog{width:min(760px,100%)}.dialog-head{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px}.dialog-head h2{font-size:21px}.dialog-actions{display:flex;align-items:center;justify-content:flex-end;gap:16px;margin-top:10px}.artifact-dialog textarea{min-height:120px}.form-grid{display:grid;grid-template-columns:minmax(0,1fr) 220px;gap:20px}.cover-picker{display:grid;gap:12px;align-content:start}.preview-cover{width:100%;max-width:200px;aspect-ratio:2 / 3;margin:0 auto}.cover-results{display:grid;grid-template-columns:repeat(3,1fr);gap:8px}.cover-choice{border:1px solid var(--line);border-radius:var(--radius-sm);background:transparent;padding:6px;color:var(--muted);display:grid;gap:5px;font-size:11px;text-align:left;transition:border-color .14s ease}.cover-choice:hover{border-color:var(--line-strong)}.cover-choice img{width:100%;aspect-ratio:2 / 3;object-fit:cover;border-radius:6px}.login-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px}.login-panel{width:min(400px,100%);border:1px solid var(--line-strong);border-radius:var(--radius);background:var(--panel-2);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(22px);backdrop-filter:blur(22px);padding:40px 34px;text-align:center}.login-brand{display:grid;gap:4px;margin-bottom:8px}.login-cn{font-family:var(--font-serif);font-size:28px;font-weight:500;color:var(--ink);letter-spacing:.05em}.login-en{font-size:10px;letter-spacing:.4em;text-transform:uppercase;color:var(--faint)}.login-panel>p{margin:0 0 26px;color:var(--muted);font-family:var(--font-serif);font-style:italic;font-size:16px}.login-form{display:grid;gap:14px;text-align:left}.login-form label{margin:0}.login-form .icon-button{margin-top:6px;width:100%}.archive-top{margin-bottom:18px}.archive-head{display:grid;grid-template-columns:116px minmax(0,1fr);gap:24px;align-items:end;padding-bottom:24px;border-bottom:1px solid var(--line)}.archive-cover{width:116px;aspect-ratio:2 / 3}.archive-head h1{font-size:28px}.archive-content{margin-top:26px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);padding:30px}.archive-content pre{margin:0;color:var(--ink-dim);white-space:pre-wrap;overflow-wrap:anywhere;font-family:var(--font-serif);font-size:16px;line-height:1.85}.archive-content .icon-button{margin-top:8px}.reflection-block{margin-top:24px;border-top:1px solid var(--line);padding-top:20px}.reflection-block h2{margin-bottom:10px}.reflection-block p{margin:0;color:var(--ink-dim);font-family:var(--font-serif);line-height:1.8}.archive-outcomes{margin-top:30px;display:grid;gap:30px}.outcome-group{display:grid;gap:14px}.users-head{padding-bottom:26px;margin-bottom:26px;border-bottom:1px solid var(--line)}.user-form{display:grid;grid-template-columns:repeat(4,minmax(0,1fr)) auto;align-items:end;gap:14px;border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-soft);padding:20px}.user-form label{margin:0}.user-list{margin-top:22px;display:grid;gap:12px}.user-row{border:1px solid var(--line);border-radius:var(--radius);background:var(--panel);box-shadow:var(--shadow-soft);padding:16px 18px;display:flex;justify-content:space-between;gap:16px;align-items:center}.user-row strong{font-family:var(--font-serif);font-size:16px;font-weight:500;color:var(--ink)}.user-row p{margin:4px 0 0;color:var(--muted);font-size:13px}@media(max-width:640px){.shelf,.reading,.archive,.users{padding-left:16px;padding-right:16px}.topbar{padding:16px 0 20px}.topnav{gap:14px}.shelf-hero{flex-direction:column;align-items:flex-start;gap:16px}.hero-right{justify-items:start;text-align:left}.reading-grid{grid-template-columns:1fr}.chat-pane{min-height:70vh}.book-grid{grid-template-columns:repeat(auto-fill,minmax(132px,1fr));gap:22px 16px}.form-grid,.archive-head,.user-form,.two-column-fields{grid-template-columns:1fr}.archive-cover{width:96px}.user-row{flex-direction:column;align-items:flex-start}.message{max-width:100%}.dialog{padding:22px}}
