:root{color:#17201c;background:#eef4ef;font-family:Inter,PingFang SC,Hiragino Sans GB,Microsoft YaHei,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}*{box-sizing:border-box}body{margin:0;min-width:320px;min-height:100vh;background:linear-gradient(180deg,#ffffffbf,#eef4eff2),#eef4ef}button,input{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}.app{width:min(1120px,100%);min-height:100vh;margin:0 auto;padding:20px 18px 92px}.topbar{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.topbar h1{margin:4px 0 0;font-size:28px;line-height:1.2}.topnav{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.topnav button{min-height:34px;padding:7px 11px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#315244}.topnav button.active{border-color:#245f4a;background:#245f4a;color:#fff}.eyebrow{margin:0;color:#61736b;font-size:13px}.streak,.tag{display:inline-flex;align-items:center;gap:6px;min-height:36px;padding:8px 12px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#315244;white-space:nowrap}.screen{display:grid;gap:16px}.daily-panel,.detail,.daily-card,.reading-hero,.upload-zone{border:1px solid #d5e0d8;border-radius:8px;background:#fff;box-shadow:0 16px 40px #30483e14}.reading-hero{padding:24px;background:linear-gradient(135deg,#245f4a14,#d348360f),#fff}.reading-hero h2{margin:6px 0;font-size:32px;line-height:1.2}.reading-hero p{max-width:760px;color:#53645c;line-height:1.7}.daily-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.daily-card{padding:18px}.daily-card h2{margin:4px 0;font-size:24px}.daily-card p{color:#53645c;line-height:1.75}.daily-card blockquote{margin-top:14px;font-size:18px}.icon-only{width:42px;padding:0}.category-strip{display:flex;gap:8px;overflow-x:auto;padding:2px 0 6px}.category-strip button,.chip{flex:0 0 auto;min-height:34px;padding:7px 11px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#315244}.chip.active{border-color:#245f4a;background:#245f4a;color:#fff}.content-shelf{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:10px}.shelf-item{display:grid;gap:6px;min-height:82px;padding:14px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#17201c;text-align:left}.shelf-item small{color:#61736b}.daily-panel{display:grid;grid-template-columns:minmax(0,1.4fr) minmax(240px,.6fr);gap:18px;padding:22px}.panel-copy h2,.detail h2{margin:4px 0;font-size:30px;line-height:1.2}blockquote{margin:18px 0 0;padding-left:14px;border-left:3px solid #d34836;color:#22352d;font-size:20px;line-height:1.8}.today-note{display:flex;align-items:flex-start;gap:10px;padding:16px;border-radius:8px;background:#f5f0e6;color:#4d4032;line-height:1.7}.actions,.mine-actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:16px}.primary,.ghost{display:inline-flex;align-items:center;justify-content:center;gap:8px;min-height:42px;padding:10px 14px;border-radius:8px}.primary{background:#245f4a;color:#fff}.ghost{border:1px solid #d5e0d8;background:#fff;color:#315244}.danger{display:inline-flex;align-items:center;justify-content:center;min-height:42px;padding:10px 14px;border:1px solid #e7c3bd;border-radius:8px;background:#fff7f5;color:#a33a2b}.quick-grid,.stats-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.quick-grid button,.stat{display:flex;align-items:center;gap:10px;min-height:72px;padding:16px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#213c31;font-weight:700;text-align:left}.stats-grid{grid-template-columns:repeat(3,minmax(0,1fr))}.stat{display:grid;gap:4px;text-align:center}.stat strong{font-size:28px}.stat span{color:#61736b}.section-title{margin:6px 0 -4px;font-size:18px}.search-box{display:flex;align-items:center;gap:10px;min-height:48px;padding:0 14px;border:1px solid #d5e0d8;border-radius:8px;background:#fff}.search-box input{width:100%;border:0;outline:0;background:transparent}.segmented{display:flex;gap:8px;overflow-x:auto;padding-bottom:2px}.segmented button{flex:0 0 auto;min-height:36px;padding:8px 12px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#315244}.segmented button.active{border-color:#245f4a;background:#245f4a;color:#fff}.list-summary,.pagination{display:flex;align-items:center;flex-wrap:wrap;gap:10px;color:#61736b}.list-summary span{padding:6px 10px;border:1px solid #d5e0d8;border-radius:8px;background:#fff}.pagination{justify-content:center;padding:6px 0}.library-layout,.books-layout,.workspace-grid{display:grid;grid-template-columns:minmax(260px,.8fr) minmax(0,1.2fr);gap:16px;align-items:start}.library-layout{grid-template-columns:1fr}.workspace-grid{grid-template-columns:minmax(320px,1fr) minmax(320px,.9fr)}.auth-grid{grid-template-columns:repeat(2,minmax(320px,1fr));align-items:start}.content-list,.inline-list,.book-list{display:grid;gap:10px}.expandable-row{overflow:hidden;border:1px solid #d5e0d8;border-radius:8px;background:#fff}.expandable-row.active{border-color:#245f4a;box-shadow:0 0 0 2px #245f4a1f}.expandable-row .content-row{border:0;border-radius:0}.inline-detail{padding:0 14px 14px;border-top:1px solid #e2e8e3}.inline-detail .body-text{margin-top:14px}.content-row,.book-row{display:flex;align-items:center;gap:12px;width:100%;min-height:64px;padding:12px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#17201c;text-align:left}.book-row.active{border-color:#245f4a;box-shadow:0 0 0 2px #245f4a1f}.content-row span:last-child,.book-row span{display:grid;gap:4px;min-width:0}.content-row strong,.book-row strong{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.content-row small,.book-row small{overflow:hidden;color:#61736b;text-overflow:ellipsis;white-space:nowrap}.type-badge{display:inline-grid;place-items:center;flex:0 0 36px;width:36px;height:36px;border-radius:8px;background:#e5efe9;color:#245f4a;font-weight:800}.detail{padding:18px}.detail-head{display:flex;justify-content:space-between;gap:14px;align-items:flex-start}.body-text{margin:16px 0;padding:16px;border-radius:8px;background:#f8faf7;font-size:20px;line-height:1.9}.explain{color:#33443c;line-height:1.75}.explain h3{margin:14px 0 4px;color:#17201c;font-size:16px}.explain p,.explain ul{margin:0}.tags{display:flex;flex-wrap:wrap;gap:8px;margin-top:14px}.tags span{padding:6px 10px;border-radius:8px;background:#f0f4f1;color:#53645c;font-size:13px}.upload-zone{position:relative;display:grid;place-items:center;gap:8px;min-height:150px;padding:20px;color:#315244;text-align:center}.upload-zone span{color:#61736b;line-height:1.6}.upload-zone input{position:absolute;inset:0;opacity:0;cursor:pointer}.upload-zone.compact{min-height:126px;box-shadow:none}.progress-bar{height:10px;margin:12px 0;overflow:hidden;border-radius:8px;background:#e4ece7}.progress-bar span{display:block;height:100%;border-radius:inherit;background:#d34836}.chapter{margin-top:10px;padding:12px;border:1px solid #e2e8e3;border-radius:8px;background:#fbfcfb}.book-meta{display:flex;flex-wrap:wrap;gap:8px;margin-top:12px}.book-meta span{padding:6px 10px;border-radius:8px;background:#f0f4f1;color:#53645c;font-size:13px}.reader-layout{display:grid;grid-template-columns:minmax(180px,.34fr) minmax(0,.66fr);gap:12px;margin-top:8px}.chapter-list{display:grid;align-content:start;gap:8px}.chapter-list button{min-height:40px;padding:9px 10px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#315244;text-align:left}.chapter-list button.active{border-color:#245f4a;background:#245f4a;color:#fff}.chapter-reader{min-height:240px;padding:16px;border:1px solid #e2e8e3;border-radius:8px;background:#fbfcfb}.chapter-reader p{margin-top:10px;white-space:pre-wrap}.empty{padding:18px;border:1px dashed #cbd8cf;border-radius:8px;background:#ffffffa6;color:#61736b;text-align:center}.form-panel{display:grid;gap:14px}.form-panel.narrow{width:min(680px,100%)}.form-panel label,.field-group{display:grid;gap:8px;color:#315244;font-weight:700}.form-panel input,.form-panel select{min-height:42px;padding:9px 12px;border:1px solid #d5e0d8;border-radius:8px;background:#fff;color:#17201c}.form-row{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px}.chip-list{display:flex;flex-wrap:wrap;gap:8px}.api-preview,.success-box,.form-message{display:grid;gap:6px;padding:12px;border-radius:8px;background:#f8faf7;color:#53645c;line-height:1.6}.api-preview code{overflow-wrap:anywhere;color:#245f4a}.success-box{border:1px solid #c8dccf;background:#eef7f0;color:#245f4a}.captcha-row{display:flex;align-items:center;gap:10px}.captcha-row strong{display:inline-grid;place-items:center;min-width:112px;min-height:44px;border-radius:8px;background:#17201c;color:#fff;font-size:20px;letter-spacing:2px}.job-list{display:grid;gap:10px}.job-card{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid #d5e0d8;border-radius:8px;background:#fbfcfb}.job-card p,.job-card small{margin:4px 0 0;color:#61736b}.admin-list{display:grid;gap:10px;margin-top:14px}.admin-row{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border:1px solid #d5e0d8;border-radius:8px;background:#fbfcfb}.admin-row div:first-child{display:grid;gap:4px;min-width:0}.admin-row small{color:#61736b}.row-actions{display:flex;flex-wrap:wrap;gap:8px}.bottom-nav{position:fixed;right:0;bottom:0;left:0;display:grid;grid-template-columns:repeat(4,1fr);width:min(1120px,100%);margin:0 auto;padding:8px 12px calc(8px + env(safe-area-inset-bottom));border-top:1px solid #d5e0d8;background:#fffffff0;-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.bottom-nav button{display:grid;place-items:center;gap:3px;min-height:54px;border-radius:8px;background:transparent;color:#61736b;font-size:12px}.bottom-nav button.active{background:#e5efe9;color:#245f4a}@media(max-width:760px){.app{padding:16px 12px 88px}.topbar{display:grid;align-items:flex-start}.topbar h1{font-size:22px}.streak{padding:8px;font-size:13px}.daily-panel,.library-layout,.books-layout,.workspace-grid,.auth-grid,.daily-grid{grid-template-columns:1fr}.reading-hero h2{font-size:25px}.panel-copy h2,.detail h2{font-size:24px}blockquote,.body-text{font-size:18px}.quick-grid,.content-shelf,.form-row{grid-template-columns:1fr}.stats-grid{grid-template-columns:repeat(3,1fr)}.detail-head,.job-card,.admin-row{display:grid}.reader-layout{grid-template-columns:1fr}}
