:root{color:#16181d;background:#f4f1eb;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-synthesis:none;text-rendering:optimizeLegibility}*{box-sizing:border-box}html,body,#root{min-height:100%;margin:0}button,input,select{font:inherit}button{color:inherit}.library-shell{min-height:100vh;display:grid;grid-template-columns:280px minmax(0,1fr);background:linear-gradient(180deg,#f4f1ebfa,#e5ebe7f0),#f4f1eb}.genre-sidebar{min-height:100vh;padding:20px 14px;background:#20242b;color:#f8f3ea;border-right:1px solid rgba(0,0,0,.18);position:sticky;top:0}.brand-row{display:flex;align-items:center;gap:12px;padding:8px 8px 18px}.brand-row svg{width:30px;height:30px;color:#ff6b4a}.brand-row h1{margin:0;font-size:20px;line-height:1.1;letter-spacing:0}.brand-row span{color:#b9c3bd;font-size:13px}.genre-list{display:grid;gap:6px}.settings-button{width:calc(100% - 8px);min-height:42px;display:flex;align-items:center;gap:10px;margin:0 4px 14px;border:1px solid rgba(255,255,255,.14);border-radius:8px;background:#ffffff0f;color:#fff;padding:0 12px;cursor:pointer}.settings-button svg{width:18px;height:18px}.genre-button{width:100%;min-height:44px;display:grid;grid-template-columns:22px minmax(0,1fr) auto;align-items:center;gap:10px;border:0;border-radius:8px;padding:10px;background:transparent;color:#dbe4df;cursor:pointer;text-align:left}.genre-button:hover,.genre-button.active{background:#2f3840;color:#fff}.genre-button.active{box-shadow:inset 3px 0 #ff6b4a}.genre-button svg{width:18px;height:18px}.genre-button span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.genre-button small{color:#aeb7b2;font-size:12px}.library-main{min-width:0;padding:24px}.library-toolbar{display:flex;align-items:flex-end;justify-content:space-between;gap:20px;margin-bottom:18px}.library-toolbar h2{margin:0;color:#171a1f;font-size:28px;line-height:1.1;letter-spacing:0}.library-toolbar p{margin:6px 0 0;color:#66716d}.toolbar-actions{display:flex;align-items:center;gap:10px}.search-box,.select-box{height:42px;display:flex;align-items:center;gap:8px;border:1px solid #c8d0ca;border-radius:8px;background:#fff;padding:0 12px}.search-box svg,.select-box svg,.icon-button svg{width:18px;height:18px;color:#53615b}.search-box input,.select-box select{min-width:0;border:0;outline:0;background:transparent}.search-box input{width:min(34vw,280px)}.select-box select{cursor:pointer}.icon-button{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid #c8d0ca;border-radius:8px;background:#fff;cursor:pointer}.notice,.empty-state{border:1px solid #c8d0ca;border-radius:8px;background:#ffffffb8;padding:14px;color:#3d4642}.notice.error{border-color:#d58a7c;color:#8e2f1f}.empty-state{min-height:220px;display:grid;place-items:center;align-content:center;gap:8px;text-align:center}.empty-state svg{width:34px;height:34px;color:#53615b}.empty-state h3,.empty-state p{margin:0}.book-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:16px}.book-card{min-width:0;display:grid;gap:8px;border:0;background:transparent;padding:0;cursor:pointer;text-align:left}.book-card img{width:100%;aspect-ratio:3 / 4.25;object-fit:cover;display:block;border-radius:8px;background:linear-gradient(180deg,#dfe7e2,#f3efe7);box-shadow:0 8px 24px #191b1f24;opacity:0;transition:opacity .12s ease-out}.book-card img.cover-loaded{opacity:1}.book-card:hover img{outline:3px solid #ff6b4a}.book-title{min-height:40px;color:#171a1f;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.book-author{color:#8e3b2c;font-size:13px;font-weight:700;line-height:1.25;overflow-wrap:anywhere}.book-meta{color:#66716d;font-size:13px}.reader-shell{height:100vh;height:100dvh;position:fixed;inset:0;z-index:10;overflow:hidden;background:#08090b;color:#fff}.reader-controls{position:fixed;top:max(10px,env(safe-area-inset-top));left:max(10px,env(safe-area-inset-left));z-index:3;display:grid;gap:8px;justify-items:start}.reader-control-row{display:flex;gap:8px}.reader-button{width:42px;height:42px;display:inline-flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.22);border-radius:50%;background:#0e1014b3;color:#fff;cursor:pointer;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.reader-button svg{width:19px;height:19px}.page-select,.fit-toggle{min-height:38px;max-width:170px;border:1px solid rgba(255,255,255,.22);border-radius:8px;background:#0e1014b3;color:#fff;padding:0 10px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.fit-toggle{cursor:pointer}.reader-title{position:fixed;top:max(10px,env(safe-area-inset-top));right:max(10px,env(safe-area-inset-right));z-index:3;max-width:min(42vw,420px);display:grid;justify-items:end;gap:3px;text-align:right;color:#ffffffdb;text-shadow:0 1px 4px rgba(0,0,0,.55)}.reader-title strong{overflow-wrap:anywhere}.reader-title span{color:#ffffff9e;font-size:13px}.reader-scroller{height:100%;display:flex;flex-direction:row-reverse;overflow-x:auto;overflow-y:hidden;scroll-snap-type:x mandatory;scrollbar-width:none}.reader-scroller::-webkit-scrollbar{display:none}.reader-page{width:100vw;height:100%;flex:0 0 100vw;display:flex;align-items:center;justify-content:center;scroll-snap-align:center;scroll-snap-stop:always;overflow:auto}.reader-page img{max-width:100%;max-height:100%;object-fit:contain;-webkit-user-select:none;user-select:none;-webkit-user-drag:none}.reader-page img.fit-width{width:100%;height:auto;max-height:none}.reader-progress{position:fixed;bottom:0;left:0;z-index:4;height:4px;background:#ff6b4a;transition:width .16s ease-out}.reader-error{min-height:100vh;display:grid;place-items:center;align-content:center;gap:12px;background:#20242b;color:#fff}.reader-error button{border:0;border-radius:8px;background:#ff6b4a;color:#fff;padding:10px 16px;cursor:pointer}.login-shell{min-height:100vh;display:grid;place-items:center;padding:20px;background:#20242b}.login-panel{width:min(380px,100%);display:grid;gap:14px;border-radius:8px;background:#f8f5ef;padding:22px;box-shadow:0 24px 80px #00000057}.login-panel>svg{width:34px;height:34px;color:#ff6b4a}.login-panel h1{margin:0 0 4px;color:#171a1f;letter-spacing:0}.login-panel label{display:grid;gap:5px;color:#3d4642;font-size:13px;font-weight:700}.login-panel input{min-height:42px;border:1px solid #c8d0ca;border-radius:8px;background:#fff;padding:0 10px}.dialog-backdrop{position:fixed;inset:0;z-index:20;display:grid;place-items:center;padding:20px;background:#0e101494}.settings-dialog{width:min(920px,100%);max-height:min(820px,calc(100vh - 40px));overflow:auto;border-radius:8px;background:#f8f5ef;box-shadow:0 24px 80px #00000061;padding:18px}.folder-picker{width:min(720px,100%);max-height:min(760px,calc(100vh - 40px));overflow:auto;border-radius:8px;background:#f8f5ef;box-shadow:0 24px 80px #00000061;padding:18px}.settings-header,.settings-section-title,.settings-footer{display:flex;align-items:center;justify-content:space-between;gap:12px}.settings-header{margin-bottom:18px}.settings-header h2,.settings-section-title h3{margin:0;color:#171a1f;letter-spacing:0}.settings-header p{margin:4px 0 0;color:#66716d}.settings-section{display:grid;gap:12px;margin-bottom:16px}.text-button,.primary-button,.secondary-button{min-height:40px;display:inline-flex;align-items:center;justify-content:center;gap:8px;border-radius:8px;padding:0 14px;cursor:pointer}.secondary-button:disabled{cursor:not-allowed;opacity:.55}.text-button{border:1px solid #c8d0ca;background:#fff}.text-button svg,.primary-button svg{width:18px;height:18px}.genre-editor-list{display:grid;gap:10px}.genre-editor-row{display:grid;grid-template-columns:minmax(120px,200px) minmax(260px,1fr) 42px 94px;gap:10px;align-items:end}.genre-order-buttons{display:flex;gap:6px}.genre-order-buttons .icon-button:disabled{cursor:not-allowed;opacity:.45}.settings-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin-bottom:14px}.genre-editor-row label,.settings-grid label{display:grid;gap:5px;color:#3d4642;font-size:13px;font-weight:700}.genre-editor-row input,.settings-grid input{width:100%;min-height:40px;border:1px solid #c8d0ca;border-radius:8px;background:#fff;color:#171a1f;padding:0 10px;outline:0}.toggle-label{min-height:40px;display:flex!important;align-items:center;justify-content:space-between;border:1px solid #c8d0ca;border-radius:8px;background:#fff;padding:0 10px}.toggle-label input{width:20px;min-height:20px}.folder-path-picker{min-height:40px;display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:8px}.folder-path-picker>span{min-height:40px;display:flex;align-items:center;overflow:hidden;border:1px solid #c8d0ca;border-radius:8px;background:#fff;color:#171a1f;padding:0 10px;text-overflow:ellipsis;white-space:nowrap}.folder-picker-actions{display:flex;gap:10px;margin-bottom:12px}.folder-list{display:grid;gap:6px}.folder-row{min-height:42px;display:grid;grid-template-columns:22px minmax(0,1fr);align-items:center;gap:10px;border:1px solid #d7ded9;border-radius:8px;background:#fff;padding:0 10px;cursor:pointer;text-align:left}.folder-row:hover{border-color:#ff6b4a}.folder-row svg{width:18px;height:18px;color:#53615b}.folder-row span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.icon-button.danger{border-color:#deb1a8}.icon-button.danger svg{color:#9b3323}.settings-footer{justify-content:flex-end;margin-top:16px}.primary-button{border:0;background:#ff6b4a;color:#fff}.primary-button:disabled{cursor:not-allowed;opacity:.6}.secondary-button{border:1px solid #c8d0ca;background:#fff}@media(max-width:820px){.library-shell{grid-template-columns:1fr}.genre-sidebar{min-height:auto;position:static;padding:12px}.brand-row{padding-bottom:12px}.genre-list{display:flex;gap:8px;overflow-x:auto;padding-bottom:4px}.genre-button{width:auto;min-width:150px}.settings-button{width:auto;margin:0 0 10px}.library-main{padding:16px}.library-toolbar{align-items:stretch;flex-direction:column}.toolbar-actions{display:grid;grid-template-columns:1fr auto 42px}.search-box input{width:100%}.book-grid{grid-template-columns:repeat(auto-fill,minmax(128px,1fr));gap:14px}.settings-dialog{max-height:calc(100vh - 24px);padding:14px}.genre-editor-row,.settings-grid{grid-template-columns:1fr}.genre-editor-row{align-items:stretch}.reader-title{top:auto;right:max(10px,env(safe-area-inset-right));bottom:max(14px,env(safe-area-inset-bottom));max-width:58vw}}@media(max-width:520px){.toolbar-actions{grid-template-columns:1fr 42px}.select-box{grid-column:1 / -1}.book-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}
