:root{--reader-font:"Amiri",serif;--reader-size:20px;--reader-lh:2;--maxw:740px}*{box-sizing:border-box}body,html{margin:0;padding:0}body{font-family:Tajawal,system-ui,sans-serif}.app{height:100dvh;overflow:hidden;display:flex;flex-direction:column;background:var(--bg);color:var(--text);transition:background .3s,color .3s}.app[data-theme=light]{--bg:#eceff3;--panel:#fff;--text:#1c2430;--muted:#6b7785;--accent:#2f6f4f;--page-bg:#fdfcf8;--page-text:#20262e}.app[data-theme=dark]{--bg:#11151b;--panel:#1a2027;--text:#e7edf3;--muted:#93a1ad;--accent:#7fd1a8;--page-bg:#1e242c;--page-text:#e7edf3}.app[data-theme=sepia]{--bg:#e6dcc6;--panel:#f3ead6;--text:#4a3f2e;--muted:#7a6c52;--accent:#9a6a3a;--page-bg:#f7efdc;--page-text:#4a3f2e}.toolbar{position:-webkit-sticky;position:sticky;top:0;z-index:5;display:flex;flex-wrap:wrap;align-items:center;gap:14px;padding:10px 16px;background:var(--panel);border-bottom:1px solid hsla(0,0%,50%,.18);box-shadow:0 1px 6px rgba(0,0,0,.06)}.toolbar .title{font-weight:700;font-size:18px;color:var(--accent);-webkit-margin-end:auto;margin-inline-end:auto}.toolbar .group{display:flex;align-items:center;gap:6px}.toolbar label{color:var(--muted);font-size:13px}.toolbar button,.toolbar select{background:transparent;color:var(--text);border:1px solid hsla(0,0%,50%,.35);border-radius:8px;padding:6px 10px;font:inherit;cursor:pointer;line-height:1}.toolbar button:hover,.toolbar button[aria-pressed=true]{border-color:var(--accent);color:var(--accent)}.toolbar button[aria-pressed=true]{font-weight:700}.stage{flex:1 1;position:relative;display:flex;align-items:center;justify-content:center;min-height:0;padding:14px;overflow:hidden}.flip-book{width:100%;max-width:1180px}.flip-book.dir-rtl,.flip-book.dir-rtl .page-content{transform:scaleX(-1)}.page{background:var(--page-bg);border-radius:10px;box-shadow:0 4px 30px rgba(0,0,0,.18)}.page,.page-content{color:var(--page-text);overflow:hidden}.page-content{width:100%;height:100%;text-align:justify}.page-content p{margin:0 0 .7em}.page-content strong{color:var(--accent)}.page-content img{max-width:100%;height:auto;display:block;margin:.6em auto}.page-content table{width:100%;border-collapse:collapse;font-size:.85em;margin:.6em 0}.page-content td,.page-content th{border:1px solid hsla(0,0%,50%,.4);padding:5px 7px;vertical-align:top}.edge{position:absolute;top:50%;transform:translateY(-50%);z-index:4;width:46px;height:clamp(96px,32vh,220px);border:none;border-radius:12px;background:var(--panel);color:var(--text);font-size:26px;cursor:pointer;opacity:.75;box-shadow:0 2px 12px rgba(0,0,0,.18)}.edge:hover{opacity:1;color:var(--accent)}.edge:disabled{opacity:.25;cursor:default}.edge-prev{right:16px}.edge-next{left:16px}.statusbar{background:var(--panel);border-top:1px solid hsla(0,0%,50%,.18);padding:8px 16px;font-size:13px;color:var(--muted);display:flex;align-items:center;gap:14px}.progress{flex:1 1;height:6px;background:hsla(0,0%,50%,.25);border-radius:3px;overflow:hidden}.progress-bar{height:100%;width:0;background:var(--accent);transition:width .3s}.loading{margin:auto;color:var(--muted);font-size:15px}.marks-panel{background:var(--panel);border-bottom:1px solid hsla(0,0%,50%,.18);max-height:42vh;overflow:auto;padding:8px 12px;display:flex;flex-direction:column;gap:6px}.marks-empty{color:var(--muted);font-size:14px;padding:6px}.mark{gap:8px}.mark,.mark-jump{display:flex;align-items:center}.mark-jump{flex:1 1;gap:10px;text-align:start;background:transparent;border:1px solid hsla(0,0%,50%,.25);border-radius:8px;padding:8px 10px;color:var(--text);cursor:pointer;font:inherit}.mark-jump:hover{border-color:var(--accent)}.mark-pct{color:var(--accent);font-weight:700;font-size:13px;min-width:44px}.mark-snip{color:var(--muted);font-size:13px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mark-del{background:transparent;border:none;color:var(--muted);cursor:pointer;font-size:14px;padding:6px}.mark-del:hover{color:#c0392b}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.mark-jump:focus-visible,button:focus-visible,select:focus-visible{outline:2px solid var(--accent);outline-offset:2px}.admin{max-width:760px;min-height:100vh;padding:28px 20px 60px;background:#eef1f4}.admin h1{color:#2f6f4f;margin:6px 0 18px}.admin h2{margin-top:28px}.admin-form{gap:14px;background:#fff;padding:20px;border-radius:12px;box-shadow:0 2px 16px rgba(0,0,0,.06)}.admin .row,.admin-form{display:flex;flex-direction:column}.admin .row{gap:6px}.admin .row.inline{flex-direction:row;align-items:center;gap:16px}.admin label{font-size:14px;color:#4a5560;font-weight:600}.admin .check{display:flex;align-items:center;gap:8px;font-weight:400}.admin input[type=file],.admin input[type=password],.admin input[type=text],.admin select,.admin textarea{border:1px solid #cdd5dd;border-radius:8px;padding:9px 11px;font:inherit;background:#fff;color:inherit}.admin .grid2{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px}.admin .primary{background:#2f6f4f;color:#fff;border:none;border-radius:9px;padding:11px 16px;font:inherit;font-weight:700;cursor:pointer}.admin .primary:disabled{opacity:.6;cursor:default}.admin .msg{padding:10px 12px;border-radius:8px;font-size:14px}.admin .msg.ok{background:#e3f4ea;color:#1c5a3a}.admin .msg.err{background:#fdeaea;color:#a3271f}.admin-list{display:flex;flex-direction:column;gap:8px;margin-top:10px}.admin-book{display:flex;justify-content:space-between;align-items:center;gap:12px;background:#fff;border:1px solid #e4e9ee;border-radius:10px;padding:12px 14px}.admin-book .info{display:flex;flex-direction:column;gap:3px}.admin-book .info span{font-size:13px;color:#6b7785}.admin-book .actions{display:flex;align-items:center;gap:12px;white-space:nowrap}.admin-book a{color:#2f6f4f;font-size:13px;text-decoration:none}.admin-book a:hover{text-decoration:underline}.admin-book button{background:transparent;border:1px solid #e0b4b0;color:#a3271f;border-radius:8px;padding:6px 12px;cursor:pointer;font:inherit;font-size:13px}.admin-book button:hover{background:#fdeaea}@media (max-width:600px){.admin .grid2{grid-template-columns:1fr}}.book-detail,.lib{min-height:100dvh;background:#eef1f4;color:#1c2430}.lib{padding:0 0 60px}.lib-head{display:flex;align-items:center;justify-content:space-between;padding:22px 28px;background:#fff;border-bottom:1px solid #e4e9ee}.lib-head h1{margin:0;color:#2f6f4f;font-size:24px}.lib-admin{color:#6b7785;text-decoration:none;font-size:14px;border:1px solid #cdd5dd;padding:7px 12px;border-radius:8px}.lib-admin:hover{border-color:#2f6f4f;color:#2f6f4f}.lib-empty{padding:40px 28px;color:#6b7785}.lib-section{padding:22px 28px 0}.lib-section h2{font-size:18px;color:#3a4654;margin:0 0 14px}.grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:18px;gap:18px}.card{gap:8px}.cover{aspect-ratio:3/4.2;border-radius:10px;background:linear-gradient(140deg,#2f6f4f,#1c4a34);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 14px rgba(0,0,0,.12);transition:transform .15s}.card:hover .cover{transform:translateY(-3px)}.cover-ph{font-weight:700;font-size:16px;line-height:1.7}.card-body strong{font-size:15px}.card-body span{font-size:13px}.book-detail{padding:18px 20px 60px}.detail-card{max-width:820px;margin:14px auto 0;background:#fff;border-radius:14px;padding:24px;display:flex;gap:24px;box-shadow:0 2px 20px rgba(0,0,0,.06)}.detail-cover{flex:0 0 200px;aspect-ratio:3/4.2;border-radius:12px;overflow:hidden;background:linear-gradient(140deg,#2f6f4f,#1c4a34);display:flex;align-items:center;justify-content:center}.detail-cover img{width:100%;height:100%;object-fit:cover}.detail-info h1{margin:0 0 4px}.detail-info .by{color:#6b7785;margin:0 0 12px}.tags{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:12px}.tag{background:#e8eef0;color:#3a5a4a;font-size:12px;padding:4px 10px;border-radius:20px}.desc{line-height:1.9;color:#3a4654}.detail-info .meta{color:#6b7785;font-size:13px}.actions{display:flex;flex-wrap:wrap;gap:10px;margin-top:18px}.btn{font:inherit;border-radius:9px;padding:10px 16px;cursor:pointer;text-decoration:none;border:1px solid transparent}.btn.primary{background:#2f6f4f;color:#fff}.btn.primary:hover{background:#275f43}.btn.ghost{background:transparent;color:#2f6f4f;border:1px solid #cdd5dd}.btn.ghost:hover{border-color:#2f6f4f}.btn:disabled{opacity:.5;cursor:default}.home-link{color:var(--accent,#2f6f4f);text-decoration:none;font-size:14px}.home-link:hover{text-decoration:underline}@media (max-width:600px){.detail-card{flex-direction:column}.detail-cover{flex:none;width:150px}}.lib-head-actions{display:flex;gap:10px;flex-wrap:wrap}.lib-controls{display:flex;flex-wrap:wrap;align-items:center;gap:12px;padding:18px 28px 0}.search{flex:0 1 320px;border:1px solid #cdd5dd;border-radius:10px;padding:10px 14px;font:inherit;background:#fff;color:#1c2430}.search:focus{outline:none;border-color:#2f6f4f}.chips{display:flex;flex-wrap:wrap;gap:8px}.chip{background:#fff;border:1px solid #cdd5dd;border-radius:20px;padding:6px 14px;font:inherit;font-size:13px;cursor:pointer;color:#3a4654}.chip.on,.chip:hover{border-color:#2f6f4f}.chip.on{background:#2f6f4f;color:#fff}.player{position:fixed;inset:0;overflow:hidden;display:flex;align-items:center;justify-content:center;color:#fff}.player-bg{position:absolute;inset:0;width:100%;height:100%;object-fit:cover;z-index:0}.player-bg.anim{background:linear-gradient(120deg,#1c4a34,#2f6f4f,#16432f,#2a4a6a);background-size:300% 300%;animation:bgmove 18s ease infinite}@keyframes bgmove{0%{background-position:0 50%}50%{background-position:100% 50%}to{background-position:0 50%}}.player-overlay{position:absolute;inset:0;background:linear-gradient(180deg,rgba(0,0,0,.35),rgba(0,0,0,.7));z-index:1}.player-back{position:fixed;top:18px;inset-inline-start:18px;z-index:3;color:#fff;text-decoration:none;opacity:.85;background:rgba(0,0,0,.25);padding:7px 12px;border-radius:8px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.player-back:hover{opacity:1}.player-content{position:relative;z-index:2;width:min(92vw,420px);flex-direction:column;text-align:center}.player-content,.player-cover{display:flex;align-items:center}.player-cover{width:200px;aspect-ratio:3/4.2;border-radius:14px;overflow:hidden;box-shadow:0 14px 44px rgba(0,0,0,.55);background:linear-gradient(140deg,#2f6f4f,#1c4a34);justify-content:center;margin-bottom:16px}.player-cover img{width:100%;height:100%;object-fit:cover}.player-title{margin:6px 0 0;font-size:22px}.player-author{margin:2px 0 14px;opacity:.8;font-size:14px}.player-seek{width:100%;accent-color:#7fd1a8;cursor:pointer}.player-times{width:100%;display:flex;justify-content:space-between;font-size:12px;opacity:.8;margin-top:4px}.player-controls{display:flex;align-items:center;gap:16px;margin-top:18px}.player-controls button{background:hsla(0,0%,100%,.15);color:#fff;border:none;border-radius:50%;width:52px;height:52px;cursor:pointer;font-size:14px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.player-controls .play{width:72px;height:72px;font-size:24px;background:#fff;color:#1c4a34}.player-controls button:hover{background:hsla(0,0%,100%,.3)}.player-controls .play:hover{background:#eafff3}.player-rate{background:hsla(0,0%,100%,.15);color:#fff;border:none;border-radius:20px;padding:8px 10px;font:inherit;cursor:pointer}.player-rate option{color:#1c2430}.player.no-audio .player-content{font-size:16px}.btn.alt{background:#1c4a34;color:#fff}.btn.alt:hover{background:#143a28}.admin-book-wrap{display:flex;flex-direction:column;gap:8px}.ab-edit{display:flex;gap:8px;flex-wrap:wrap;align-items:center;background:#f3f6f9;border:1px solid #e4e9ee;border-radius:10px;padding:10px}.ab-edit input{flex:1 1 220px;border:1px solid #cdd5dd;border-radius:8px;padding:8px 10px;font:inherit;background:#fff}.ab-edit .primary{background:#2f6f4f;color:#fff;border:none;border-radius:8px;padding:8px 18px;cursor:pointer;font:inherit}.settings-btn{font-weight:700}.settings-panel{background:var(--panel);border-bottom:1px solid hsla(0,0%,50%,.18);padding:12px 16px;display:flex;flex-direction:column;gap:12px}.settings-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.settings-row>label{color:var(--muted);font-size:13px;min-width:48px}.settings-row select{background:transparent;color:var(--text);border:1px solid hsla(0,0%,50%,.35);border-radius:8px;padding:7px 10px;font:inherit;cursor:pointer}.seg{display:inline-flex;align-items:center;gap:4px;border:1px solid hsla(0,0%,50%,.3);border-radius:10px;padding:3px}.seg button{background:transparent;color:var(--text);border:none;border-radius:7px;padding:7px 12px;font:inherit;cursor:pointer}.seg button:hover{color:var(--accent)}.seg button[aria-pressed=true]{background:var(--accent);color:var(--bg);font-weight:700}.seg-val{min-width:26px;text-align:center;color:var(--muted);font-size:13px}.cover{transition:transform .18s ease,box-shadow .18s ease}.card:hover .cover{transform:translateY(-4px);box-shadow:0 10px 28px rgba(0,0,0,.22)}.cover-ph{flex-direction:column;align-items:center;justify-content:center;gap:10px;padding:16px;text-align:center;color:#fdfcf8}.cover-glyph{width:42px;height:42px}.cover-ph-title{font-weight:700;font-size:15px;line-height:1.6}.card-progress{background:rgba(0,0,0,.35)}.card-progress>div{transition:width .3s}body{background:#eef1f4;transition:background .3s}html[data-theme=dark] body{background:#0f1318}.admin,.book-detail,.lib{animation:fadeUp .35s ease both}.lib-section{animation:fadeUp .4s ease both}@keyframes fadeUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}@media (prefers-reduced-motion:reduce){.admin,.book-detail,.lib,.lib-section{animation:none}}.btn,.card,.chip,.lib-admin,.theme-toggle{transition:background .2s,color .2s,border-color .2s,transform .18s}html[data-theme=dark] .admin,html[data-theme=dark] .book-detail,html[data-theme=dark] .lib{background:#0f1318;color:#e7edf3}html[data-theme=dark] .lib-head{background:#161b22;border-bottom-color:#2a323c}html[data-theme=dark] .admin h1,html[data-theme=dark] .lib-head h1{color:#7fd1a8}html[data-theme=dark] .lib-admin{color:#aeb9c4;border-color:#2a323c}html[data-theme=dark] .lib-admin:hover{color:#7fd1a8;border-color:#7fd1a8}html[data-theme=dark] .lib-section h2{color:#c3ccd6}html[data-theme=dark] .card-body span,html[data-theme=dark] .detail-info .by,html[data-theme=dark] .detail-info .meta,html[data-theme=dark] .lib-empty{color:#93a1ad}html[data-theme=dark] .chip,html[data-theme=dark] .search{background:#1a2027;border-color:#3a434f;color:#c3ccd6}html[data-theme=dark] .chip.on{background:#2f6f4f;color:#fff;border-color:#2f6f4f}html[data-theme=dark] .detail-card{background:#1a2027;box-shadow:0 2px 20px rgba(0,0,0,.4)}html[data-theme=dark] .desc{color:#c3ccd6}html[data-theme=dark] .tag{background:#243240;color:#9fd9bd}html[data-theme=dark] .btn.ghost{color:#7fd1a8;border-color:#3a434f}html[data-theme=dark] .btn.ghost:hover{border-color:#7fd1a8}html[data-theme=dark] .admin-book,html[data-theme=dark] .admin-form{background:#1a2027}html[data-theme=dark] .admin-book{border-color:#2a323c}html[data-theme=dark] .admin h2{color:#e7edf3}html[data-theme=dark] .admin label{color:#aab4bf}html[data-theme=dark] .ab-edit input,html[data-theme=dark] .admin input,html[data-theme=dark] .admin select,html[data-theme=dark] .admin textarea{background:#11161c;border-color:#3a434f;color:#e7edf3}html[data-theme=dark] .admin-book .info span{color:#93a1ad}html[data-theme=dark] .ab-edit{background:#11161c;border-color:#2a323c}.theme-toggle{background:transparent;border:1px solid #cdd5dd;border-radius:8px;padding:7px 11px;cursor:pointer;font:inherit;color:#6b7785}.theme-toggle:hover{border-color:#2f6f4f;color:#2f6f4f}html[data-theme=dark] .theme-toggle{border-color:#2a323c;color:#aeb9c4}html[data-theme=dark] .theme-toggle:hover{border-color:#7fd1a8;color:#7fd1a8}.detail-cover{flex:0 0 230px}.sk-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));grid-gap:18px;gap:18px}.sk-card{aspect-ratio:3/4.2;border-radius:10px;background:linear-gradient(90deg,#e1e6ec,#eef1f4,#e1e6ec);background-size:200% 100%;animation:sk 1.3s ease infinite}html[data-theme=dark] .sk-card{background:linear-gradient(90deg,#1a2027,#222a33,#1a2027);background-size:200% 100%}@keyframes sk{0%{background-position:200% 0}to{background-position:-200% 0}}.toast-wrap{position:fixed;inset-block-end:22px;inset-inline:0;display:flex;flex-direction:column;align-items:center;gap:8px;z-index:9999;pointer-events:none}.toast{background:#1c2430;color:#fff;padding:10px 18px;border-radius:10px;font-size:14px;box-shadow:0 6px 24px rgba(0,0,0,.3);animation:toastIn .25s ease,toastOut .3s ease 2.2s forwards}html[data-theme=dark] .toast{background:#2f6f4f}@keyframes toastIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@keyframes toastOut{to{opacity:0;transform:translateY(10px)}}.skip-link{position:fixed;top:-60px;inset-inline-start:12px;background:#2f6f4f;color:#fff;padding:10px 16px;border-radius:8px;z-index:99999;transition:top .2s}.skip-link:focus{top:12px}.btn:focus-visible,.card:focus-visible,.chip:focus-visible,.lib-admin:focus-visible,.theme-toggle:focus-visible,a:focus-visible{outline:2px solid #2f6f4f;outline-offset:2px}html[data-theme=dark] .btn:focus-visible,html[data-theme=dark] .theme-toggle:focus-visible,html[data-theme=dark] a:focus-visible{outline-color:#7fd1a8}@media (max-width:640px){.lib-head{flex-direction:column;align-items:flex-start;gap:10px}.lib-controls{padding:14px 16px 0}.lib-section{padding:16px 16px 0}.grid,.sk-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:12px}.detail-card{padding:16px;gap:16px}.detail-cover{flex-basis:150px}}.related{max-width:880px;margin:26px auto 0;padding:0 6px}.related h2{font-size:17px;color:#3a4654;margin:0 0 14px}html[data-theme=dark] .related h2{color:#c3ccd6}.related .grid{grid-template-columns:repeat(auto-fill,minmax(130px,1fr))}.lib{background:#f4f6f9;min-height:100dvh;padding-bottom:60px}html[data-theme=dark] .lib{background:#0c1016}.navbar{position:-webkit-sticky;position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:16px;padding:12px clamp(16px,4vw,36px);background:hsla(0,0%,100%,.85);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid #e6ebf0}html[data-theme=dark] .navbar{background:rgba(16,20,26,.85);border-bottom-color:#232a33}.brand{display:flex;align-items:center;gap:8px;font-weight:800;font-size:20px;color:#2f7d57;text-decoration:none;flex-shrink:0}html[data-theme=dark] .brand{color:#7fd1a8}.nav-search{flex:1 1;max-width:560px;margin-inline:auto}.nav-search input{width:100%;border:1px solid #dde3ea;border-radius:999px;padding:11px 18px;font:inherit;background:#fff;color:#1c2430}.nav-search input:focus{outline:none;border-color:#2f7d57;box-shadow:0 0 0 3px rgba(47,125,87,.15)}html[data-theme=dark] .nav-search input{background:#161b22;border-color:#2a323c;color:#e7edf3}.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.nav-icon{display:inline-flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:10px;text-decoration:none;color:#5a6675;border:1px solid #dde3ea;font-size:16px}.nav-icon:hover{color:#2f7d57;border-color:#2f7d57}html[data-theme=dark] .nav-icon{color:#aeb9c4;border-color:#2a323c}html[data-theme=dark] .nav-icon:hover{color:#7fd1a8;border-color:#7fd1a8}.hero{margin:clamp(16px,3vw,28px) clamp(16px,4vw,36px) 0;border-radius:22px;overflow:hidden;position:relative;background:linear-gradient(120deg,#143a28,#216b46 55%,#1f5e7a);color:#fff;display:flex;align-items:center;gap:30px;padding:clamp(24px,4vw,46px)}.hero:after{content:"";position:absolute;inset:0;background:radial-gradient(120% 120% at 90% 10%,hsla(0,0%,100%,.12),transparent 60%);pointer-events:none}.hero-text{flex:1 1;min-width:0;position:relative;z-index:1}.hero-badge{display:inline-block;background:hsla(0,0%,100%,.18);padding:5px 12px;border-radius:999px;font-size:12px;margin-bottom:14px}.hero-title{margin:0 0 6px;font-size:clamp(26px,4vw,40px);font-weight:800;line-height:1.2}.hero-author{margin:0 0 14px;opacity:.85;font-size:15px}.hero-desc{margin:0 0 22px;opacity:.9;line-height:1.9;max-width:60ch;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.hero-actions{display:flex;gap:12px;flex-wrap:wrap}.hero-actions .btn.primary{background:#fff;color:#16432f;font-weight:700;border:none}.hero-actions .btn.primary:hover{background:#eafff3}.btn.glass{background:hsla(0,0%,100%,.15);color:#fff;border:1px solid hsla(0,0%,100%,.3)}.btn.glass:hover{background:hsla(0,0%,100%,.25)}.hero-cover{flex:0 0 190px;height:270px;border-radius:14px;position:relative;z-index:1;box-shadow:0 18px 50px rgba(0,0,0,.4);display:flex;align-items:flex-end;padding:18px;text-decoration:none;transition:transform .2s}.hero-cover:hover{transform:translateY(-4px) rotate(-1deg)}.hero-cover:before{content:"";position:absolute;top:0;bottom:0;inset-inline-end:0;width:12px;border-radius:0 14px 14px 0;background:rgba(0,0,0,.22)}.hero-cover-title{color:#fff;font-weight:800;font-size:18px;line-height:1.5;text-shadow:0 1px 6px rgba(0,0,0,.5);position:relative}@media (max-width:720px){.hero{flex-direction:column-reverse;text-align:center}.hero-actions{justify-content:center}.hero-desc{margin-inline:auto}}.chips-bar{display:flex;gap:9px;flex-wrap:wrap;padding:22px clamp(16px,4vw,36px) 0}.shelf-section{padding:28px clamp(16px,4vw,36px) 0}.shelf-section h2{font-size:19px;margin:0 0 16px;color:#243244;position:relative;-webkit-padding-start:13px;padding-inline-start:13px}.shelf-section h2:before{content:"";position:absolute;inset-inline-start:0;top:50%;transform:translateY(-50%);width:4px;height:18px;border-radius:3px;background:#2f7d57}html[data-theme=dark] .shelf-section h2{color:#dbe2ea}html[data-theme=dark] .shelf-section h2:before{background:#7fd1a8}.shelf{display:flex;flex-wrap:wrap;gap:22px;justify-content:flex-start}.card{width:158px;text-decoration:none;color:inherit;display:flex;flex-direction:column;gap:9px}.cover{position:relative;aspect-ratio:3/4.35;border-radius:12px;overflow:hidden;box-shadow:0 8px 22px rgba(20,30,40,.16);transition:transform .2s ease,box-shadow .2s ease}.card:hover .cover{transform:translateY(-6px);box-shadow:0 18px 40px rgba(20,30,40,.28)}.cover img{width:100%;height:100%;object-fit:cover}.cover-ph{position:absolute;inset:0;display:flex;flex-direction:row;align-items:flex-end;justify-content:flex-start;gap:0;padding:14px;text-align:start}.cover-ph:before{top:0;inset-inline-end:0;width:9px;background:linear-gradient(270deg,rgba(0,0,0,.28),transparent)}.cover-ph:after,.cover-ph:before{content:"";position:absolute;bottom:0}.cover-ph:after{inset-inline:0;height:62%;background:linear-gradient(0deg,rgba(0,0,0,.5),transparent)}.cover-wm{position:absolute;top:14px;inset-inline-start:14px;width:30px;height:30px;opacity:.3}.cover-ph-title{position:relative;z-index:1;color:#fff;font-weight:800;font-size:14px;line-height:1.5;text-shadow:0 1px 5px rgba(0,0,0,.5)}.card-progress{position:absolute;inset-inline:0;bottom:0;height:5px;background:rgba(0,0,0,.4);z-index:2}.card-progress>div{height:100%;background:#7fd1a8}.card-body strong{display:block;font-size:14px;font-weight:700;line-height:1.4}.card-body span{display:block;font-size:12.5px;color:#6b7785;margin-top:1px}html[data-theme=dark] .card-body span{color:#93a1ad}@media (max-width:560px){.card{width:43vw;max-width:200px}.shelf{gap:14px;justify-content:center}}.admin-page{background:#f4f6f9;min-height:100dvh;padding-bottom:50px}html[data-theme=dark] .admin-page{background:#0c1016}.admin{background:transparent;min-height:0;max-width:820px;margin:0 auto;padding:26px clamp(16px,4vw,24px) 40px;color:#1c2430}html[data-theme=dark] .admin{background:transparent;color:#e7edf3}.nav-label{background:rgba(47,125,87,.12);color:#2f7d57;padding:5px 13px;border-radius:999px;font-size:13px;font-weight:700;-webkit-margin-end:auto;margin-inline-end:auto}html[data-theme=dark] .nav-label{background:rgba(127,209,168,.14);color:#7fd1a8}.form-title{margin:0 0 4px;font-size:18px;color:#243244}html[data-theme=dark] .form-title{color:#dbe2ea}.admin-form{border:1px solid #e6ebf0;border-radius:16px}html[data-theme=dark] .admin-form{border-color:#232a33}.admin input:focus,.admin select:focus,.admin textarea:focus{outline:none;border-color:#2f7d57;box-shadow:0 0 0 3px rgba(47,125,87,.12)}.admin .primary{background:#2f7d57;border-radius:10px}.admin .primary:hover{background:#276b49}.admin-book{border-radius:12px}.admin h2{color:#243244}html[data-theme=dark] .admin h2{color:#dbe2ea}.ab-file{display:inline-flex;flex-direction:column;gap:4px;font-size:12px;color:#5a6675;flex:1 1 200px}html[data-theme=dark] .ab-file{color:#aab4bf}.ab-file input[type=file]{font-size:12px}.admin-form input[type=file]:focus{outline:2px solid #2f7d57;outline-offset:2px}.file-field{position:relative}.hint{font-size:11.5px;color:var(--muted,#6b7785);opacity:.85;margin-top:1px}.file-note{font-size:12px;font-weight:600;margin-top:1px;word-break:break-all;line-height:1.4}.file-note.ok{color:#1f8a4c}.file-note.err{color:#c43d35}html[data-theme=dark] .file-note.ok{color:#5fd08a}html[data-theme=dark] .file-note.err{color:#ff8a82}.up-bar{height:8px;border-radius:99px;background:rgba(47,125,87,.12);overflow:hidden}.up-bar>span{display:block;height:100%;border-radius:99px;background:linear-gradient(90deg,#2f7d57,#54b483);transition:width .2s ease;min-width:2%}html[data-theme=dark] .up-bar{background:rgba(127,209,168,.15)}html[data-theme=dark] .up-bar>span{background:linear-gradient(90deg,#46a06f,#7fd1a8)}.ab-edit .file-field{flex:1 1 220px;gap:4px}.ab-edit .file-field label{font-size:12px;color:#5a6675;font-weight:600}html[data-theme=dark] .ab-edit .file-field label{color:#aab4bf}.ab-edit .file-field input[type=file]{font-size:12px}.ab-edit .msg,.ab-edit .up-bar{flex:1 1 100%}.ab-edit .msg{margin:0}