:root{color-scheme:light;--font-ui: "Inter", ui-sans-serif, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-reader: "Literata", Georgia, "Times New Roman", serif;--paper: #f4efe7;--paper-soft: #fbf7f0;--panel: rgba(255, 252, 246, .82);--panel-solid: #fffaf2;--ink: #171411;--ink-soft: #332c26;--muted: #7a6c5e;--faint: #b8aa99;--border: rgba(48, 37, 28, .14);--accent: #f0ad28;--accent-strong: #c87d0d;--accent-soft: rgba(240, 173, 40, .16);--shadow: 0 24px 70px rgba(53, 37, 24, .12);--reader-paper: #fffaf2;--reader-ink: #211b16}:root[data-theme=dark]{color-scheme:dark;--paper: #11100f;--paper-soft: #171514;--panel: rgba(28, 25, 23, .78);--panel-solid: #1d1a18;--ink: #f7efe3;--ink-soft: #dfd0be;--muted: #a99986;--faint: #5f5449;--border: rgba(238, 220, 196, .14);--accent: #f3b43a;--accent-strong: #ffd37a;--accent-soft: rgba(243, 180, 58, .18);--shadow: 0 24px 80px rgba(0, 0, 0, .36);--reader-paper: #171514;--reader-ink: #f0e2cf}*{box-sizing:border-box;margin:0;padding:0}html{min-height:100%;background:var(--paper)}body{min-height:100%;background:radial-gradient(circle at 12% 0%,var(--accent-soft),transparent 32rem),linear-gradient(180deg,var(--paper-soft),var(--paper));color:var(--ink);font-family:var(--font-ui);font-size:16px;line-height:1.5;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased}a{color:inherit;text-decoration:none}button,input,textarea{font:inherit}button{cursor:pointer}button:disabled{cursor:not-allowed;opacity:.48}img{display:block;max-width:100%}h1,h2,h3{color:var(--ink);letter-spacing:-.02em}[x-cloak]{display:none}.app-header{position:sticky;z-index:20;top:0;border-bottom:1px solid var(--border);background:color-mix(in srgb,var(--paper-soft) 86%,transparent);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.app-header-inner{display:grid;grid-template-columns:minmax(170px,1fr) auto minmax(220px,1fr);gap:22px;align-items:center;max-width:1240px;min-height:74px;margin:0 auto;padding:0 26px}.brand-cluster{display:flex;flex-direction:column;gap:2px}.brand-mark{font-family:var(--font-reader);font-size:25px;font-weight:700;letter-spacing:-.04em}.brand-read{color:#fff}.brand-noir{color:var(--accent)}.brand-line{color:var(--muted);font-size:12px}.primary-nav,.nav-actions{display:flex;align-items:center;gap:10px}.primary-nav{justify-content:center}.primary-nav a,.nav-link-button{border-radius:999px;padding:9px 13px;color:var(--muted);font-size:14px;font-weight:650}.primary-nav a:hover,.primary-nav a.current,.nav-link-button:hover{background:var(--accent-soft);color:var(--ink)}.nav-actions{justify-content:flex-end}.mobile-nav-actions,.mobile-menu-panel{display:none}.theme-toggle,.nav-button,.button-primary,.button-ghost,.reader-chip,.mobile-menu-button{width:auto;border:1px solid var(--border);border-radius:999px;padding:8px 15px;font-weight:700}.theme-toggle,.button-ghost,.reader-chip,.mobile-menu-button{background:var(--panel);color:var(--ink)}.nav-button,.button-primary{border-color:var(--accent);background:var(--accent);color:#1d1711}.theme-toggle:hover,.button-ghost:hover,.reader-chip:hover,.mobile-menu-button:hover{border-color:var(--accent);color:var(--accent-strong)}.nav-button:hover,.button-primary:hover{border-color:var(--accent-strong);background:var(--accent-strong)}.logout-form{display:block}.user-badge{display:grid;width:44px;height:44px;place-items:center;border:1px solid var(--border);border-radius:999px;background:var(--panel);color:var(--ink);font-size:13px;font-weight:800}.app-main{width:min(1240px,calc(100% - 40px));min-height:calc(100vh - 102px);margin:20px auto 28px;overflow:hidden;border:1px solid var(--border);border-radius:28px;background:var(--panel);box-shadow:var(--shadow)}.eyebrow{color:var(--accent);font-size:12px;font-weight:800;letter-spacing:.13em;text-transform:uppercase}.home-hero{display:grid;grid-template-columns:minmax(0,.92fr) minmax(320px,.78fr);gap:clamp(28px,6vw,82px);align-items:center;min-height:620px;padding:clamp(34px,7vw,86px)}.home-hero-copy{max-width:730px}.home-hero h1{max-width:760px;margin-top:14px;font-family:var(--font-reader);font-size:clamp(44px,7vw,88px);font-weight:700;line-height:.95}.home-hero-copy>p:not(.eyebrow){max-width:610px;margin-top:24px;color:var(--ink-soft);font-size:clamp(18px,2.2vw,23px);line-height:1.55}.hero-actions{display:flex;flex-wrap:wrap;gap:12px;margin-top:34px}.home-logo-wordmark{font-family:var(--font-reader);font-size:18px;font-weight:800;letter-spacing:0}.hero-image-panel{position:relative;display:grid;min-height:460px;overflow:hidden;border:1px solid var(--border);border-radius:8px;background:radial-gradient(circle at 72% 28%,var(--accent-soft),transparent 18rem),color-mix(in srgb,var(--panel-solid) 82%,transparent);place-items:end center}.hero-image-panel:before{position:absolute;inset:auto 8% 8%;height:18%;border-radius:999px;background:color-mix(in srgb,var(--accent) 24%,transparent);filter:blur(22px);content:"";opacity:.55}.hero-image-panel img{position:relative;width:min(100%,560px);max-height:560px;object-fit:contain}.noir-note{position:absolute;right:34px;bottom:42px;left:34px;border:1px solid var(--border);border-radius:18px;padding:22px;background:color-mix(in srgb,var(--panel-solid) 84%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.noir-note span,.featured-book p,.book-author{color:var(--muted);font-size:13px;font-weight:700}.noir-note strong{display:block;margin-top:8px;font-family:var(--font-reader);font-size:28px;line-height:1.05}.noir-lines{position:absolute;top:110px;right:42px;display:grid;gap:12px;width:38%}.noir-lines span{height:2px;background:var(--faint)}.section-heading{max-width:620px}.section-heading h2{margin-top:8px;font-family:var(--font-reader);font-size:clamp(32px,4vw,50px)}.featured-shelf{padding:0 clamp(28px,7vw,86px) clamp(34px,7vw,72px)}.featured-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:18px;margin-top:28px}.featured-book{display:grid;gap:12px}.featured-book img,.featured-book .cover-fallback{aspect-ratio:3 / 4;width:100%;border:1px solid var(--border);border-radius:14px;object-fit:cover;box-shadow:0 14px 34px #00000029}.featured-book h3{display:-webkit-box;overflow:hidden;font-size:16px;line-height:1.25;-webkit-box-orient:vertical;-webkit-line-clamp:2}.books-management{padding:clamp(22px,5vw,54px)}.books-toolbar{display:grid;grid-template-columns:minmax(0,1fr) minmax(260px,420px);gap:22px;align-items:end;margin-bottom:32px}.books-toolbar h1{margin-top:8px;font-family:var(--font-reader);font-size:clamp(38px,5vw,62px);line-height:1}.books-toolbar p:not(.eyebrow){margin-top:10px;color:var(--muted)}.books-search{display:grid;grid-template-columns:1fr auto;gap:10px}input,textarea{width:100%;border:1px solid var(--border);border-radius:999px;background:var(--panel-solid);color:var(--ink);outline:none}input{min-height:44px;padding:0 16px}input:focus,textarea:focus{border-color:var(--accent);box-shadow:0 0 0 4px var(--accent-soft)}.books-search button,.pagination button{width:auto;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#1d1711;padding:0 18px;font-weight:800}.books-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(238px,1fr));gap:18px}.book-card{display:grid;grid-template-columns:88px minmax(0,1fr);gap:15px;min-height:168px;border:1px solid var(--border);border-radius:18px;padding:12px;background:color-mix(in srgb,var(--panel-solid) 82%,transparent);transition:transform .16s ease,border-color .16s ease,box-shadow .16s ease}.book-card:hover{transform:translateY(-2px);border-color:color-mix(in srgb,var(--accent) 45%,var(--border));box-shadow:0 18px 40px #0000001f}.book-cover-frame img,.book-cover-frame .cover-fallback{width:88px;height:132px;border-radius:12px;object-fit:cover}.cover-fallback{display:grid;place-items:center;background:linear-gradient(135deg,var(--accent-soft),transparent),var(--paper-soft);color:var(--accent);font-family:var(--font-reader);font-size:34px;font-weight:800}.book-card-copy h2{display:-webkit-box;overflow:hidden;margin-top:5px;font-size:18px;line-height:1.18;-webkit-box-orient:vertical;-webkit-line-clamp:2}.book-summary{display:-webkit-box;overflow:hidden;margin-top:12px;color:var(--muted);font-size:14px;-webkit-box-orient:vertical;-webkit-line-clamp:3}.empty-state{display:grid;min-height:360px;place-items:center;border:1px dashed var(--border);border-radius:22px;padding:34px;text-align:center}.empty-state h2{margin-top:8px;font-family:var(--font-reader);font-size:34px}.empty-state p:not(.eyebrow){max-width:420px;color:var(--muted)}.pagination{display:flex;justify-content:center;align-items:center;gap:16px;margin-top:32px}.pagination button{min-height:42px}.pagination span{color:var(--muted);font-size:14px;font-weight:700}.back-link{display:inline-flex;margin-bottom:24px;color:var(--muted);font-weight:800}.back-link:hover{color:var(--accent)}.book-detail{padding:clamp(22px,5vw,58px)}.admin-shell{width:min(1160px,calc(100% - 32px));margin:0 auto;padding:32px 0 64px}.admin-header,.admin-header-actions,.admin-toolbar,.admin-actions,.admin-action-group,.admin-action-stack{display:flex;gap:16px}.admin-header{align-items:flex-end;justify-content:space-between;margin-bottom:24px}.admin-header h1{font-size:clamp(2rem,4vw,3.25rem)}.admin-header p{margin-top:6px;color:var(--muted)}.admin-header-actions{align-items:center;flex-wrap:wrap;justify-content:flex-end}.admin-toolbar{align-items:center;justify-content:flex-end;gap:12px}.admin-stats{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.admin-stat,.admin-panel,.admin-row,.admin-callout{border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--panel-solid) 88%,transparent);box-shadow:var(--shadow)}.admin-stat{display:grid;gap:8px;padding:18px}.admin-stat strong{font-size:2rem}.admin-stat small,.admin-row small,.admin-row span{color:var(--muted)}form.admin-search,.admin-search{display:flex;flex-direction:row;gap:8px;align-items:center;width:min(100%,420px);border:1px solid var(--border);border-radius:14px;padding:6px;background:color-mix(in srgb,var(--panel-solid) 94%,transparent)}.admin-search button,.admin-panel button,.admin-actions button,.admin-header-actions .button,.admin-primary-action,.button-quiet,.button-danger,.button-secondary{display:inline-flex;align-items:center;justify-content:center;width:auto;min-width:max-content;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#1d1711;padding:8px 18px;font-weight:800}.admin-search input{flex:1 1 auto;min-width:0;min-height:40px;border:0;border-radius:10px;background:transparent;padding:0 12px;box-shadow:none}.admin-search input:focus{box-shadow:none}.button-secondary,.button-quiet{border-color:var(--border);background:color-mix(in srgb,var(--panel-solid) 88%,transparent);color:var(--ink)}.admin-search button{min-height:38px;padding:8px 14px}.button-quiet:hover,.button-secondary:hover{border-color:color-mix(in srgb,var(--accent) 40%,var(--border));color:var(--accent)}.button-danger{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:var(--accent-soft);color:var(--accent-strong)}.admin-panel input,.admin-panel textarea,.admin-row input,.admin-data-table input{border-radius:12px}.admin-panel textarea{min-height:120px;padding:12px 14px;resize:vertical;font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace}.admin-table{display:grid;gap:12px}.admin-table-surface{overflow:hidden;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--panel-solid) 90%,transparent);box-shadow:var(--shadow)}.admin-data-table{width:100%;border-collapse:collapse}.admin-data-table th,.admin-data-table td{padding:16px 18px;border-bottom:1px solid var(--border);text-align:left;vertical-align:middle}.admin-data-table th{color:var(--muted);background:color-mix(in srgb,var(--paper-soft) 78%,transparent);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.admin-data-table tbody tr{transition:background .16s ease,transform .16s ease}.admin-data-table tbody tr:hover{background:color-mix(in srgb,var(--accent-soft) 50%,transparent)}.admin-data-table tbody tr:last-child td{border-bottom:0}.actions-column{width:1%;white-space:nowrap}.table-primary{color:var(--ink);font-weight:900}.table-secondary,.table-muted{margin-top:3px;color:var(--muted);font-size:14px}.admin-data-table code,.invite-code{display:inline-flex;max-width:100%;border:1px solid var(--border);border-radius:999px;padding:5px 9px;background:var(--paper-soft);color:var(--ink-soft);font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:13px;overflow-wrap:anywhere}.status-badge{display:inline-flex;align-items:center;min-height:30px;border:1px solid var(--border);border-radius:999px;padding:4px 10px;background:var(--paper-soft);color:var(--ink-soft);font-size:13px;font-weight:900;text-transform:capitalize}.status-badge[data-status=open]{border-color:#2d7f5d47;background:#2d7f5d1f;color:#2d7f5d}.status-badge[data-status=expired],.status-badge[data-status=unavailable],.status-badge[data-status=disabled]{border-color:color-mix(in srgb,var(--accent) 34%,var(--border));background:var(--accent-soft);color:var(--accent-strong)}.status-badge[data-status=used]{background:color-mix(in srgb,var(--faint) 16%,transparent);color:var(--muted)}.admin-action-group,.admin-action-stack{align-items:center;justify-content:flex-end;gap:8px}.admin-action-group{flex-wrap:nowrap}.admin-action-stack{flex-wrap:wrap}.admin-action-stack input{width:min(220px,100%)}.role-editor{display:flex;align-items:center;gap:12px}.role-editor .compact-checks{flex:1 1 auto}.role-editor .button-quiet{flex:0 0 auto}.user-access-actions{min-width:290px}.user-access-actions input{width:150px;min-height:40px}.admin-panel,.admin-row{padding:18px}.admin-panel{display:grid;gap:16px;margin-bottom:18px}.admin-panel h2{font-size:1.25rem}.admin-row{display:grid;grid-template-columns:minmax(220px,1fr) minmax(260px,1.4fr) minmax(220px,auto);gap:18px;align-items:center}.admin-row.compact{grid-template-columns:minmax(260px,1fr) auto}.admin-row>div:first-child{display:grid;gap:4px}.admin-actions{align-items:center;flex-wrap:wrap;justify-content:flex-end}.admin-actions a{color:var(--accent);font-weight:800}.admin-actions input{width:min(220px,100%)}.admin-form-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:14px}.admin-form-grid label,.admin-book-form>label{display:grid;gap:6px}.check-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 14px;min-width:0;border:0}.check-grid label{display:flex;align-items:center;gap:8px}.check-grid input{width:auto;min-height:auto}.compact-checks{grid-template-columns:repeat(2,minmax(120px,1fr));font-size:14px}.role-fields{grid-template-columns:minmax(120px,1fr)}.admin-callout{display:grid;gap:6px;margin-bottom:18px;padding:16px}.admin-callout strong{font-family:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,monospace;font-size:1.15rem}.danger{color:var(--accent-strong)}button.danger{border-color:color-mix(in srgb,var(--accent) 55%,var(--border));background:var(--accent-soft);color:var(--accent-strong)}.breadcrumbs{width:min(1160px,calc(100% - 32px));margin:0 auto;padding:18px 0 0}.breadcrumbs ol{display:flex;flex-wrap:wrap;align-items:center;gap:8px;list-style:none}.breadcrumbs li{display:inline-flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.breadcrumbs li+li:before{content:"/";color:var(--faint)}.breadcrumbs a{color:var(--accent)}.book-detail-header{display:grid;grid-template-columns:minmax(160px,280px) minmax(0,760px);gap:clamp(24px,5vw,54px);align-items:end;padding-bottom:34px;border-bottom:1px solid var(--border)}.book-detail-cover{align-self:start}.book-detail-cover img{width:min(100%,280px);max-height:410px;border:1px solid var(--border);border-radius:18px;object-fit:cover;box-shadow:0 24px 58px #00000038}.book-detail h1{margin-top:10px;font-family:var(--font-reader);font-size:clamp(38px,6vw,74px);line-height:.98}.book-detail-author{margin-top:13px;color:var(--accent);font-size:18px;font-weight:800}.book-detail-summary{max-width:710px;margin-top:22px;color:var(--ink-soft);font-size:clamp(17px,2vw,21px);line-height:1.58}.reader-controls{position:sticky;z-index:5;top:92px;display:flex;flex-wrap:wrap;gap:12px;align-items:center;max-width:var(--reader-width);margin:28px auto 0;border:1px solid var(--border);border-radius:999px;padding:10px;background:color-mix(in srgb,var(--paper-soft) 86%,transparent);-webkit-backdrop-filter:blur(14px);backdrop-filter:blur(14px)}.reader-controls label{display:flex;align-items:center;gap:8px;color:var(--muted);font-size:13px;font-weight:800}.reader-controls input{width:110px;min-height:auto;padding:0;accent-color:var(--accent);box-shadow:none}.reader-content{max-width:var(--reader-width);margin:0 auto;padding:34px clamp(0px,1vw,10px) 20px;color:var(--reader-ink);font-family:var(--font-reader);font-size:var(--reader-font-size);line-height:1.78}.reader-content h2{margin:42px 0 14px;color:var(--ink);font-family:var(--font-ui);font-size:1.48em;line-height:1.16}.reader-content p{margin:0 0 1.08em}.reader-content strong{font-weight:700}.reader-content hr{margin:42px 0;border:0;border-top:1px solid var(--border)}.reader-content ul,.reader-content ol{margin:0 0 1.2em 1.3em}.form-container{display:grid;align-content:center;max-width:440px;min-height:calc(100vh - 150px);margin:0 auto;padding:32px}.form-container h1{font-family:var(--font-reader);font-size:42px}.form-container p{margin:8px 0 34px;color:var(--muted)}form{display:flex;flex-direction:column;gap:20px}label{display:block;margin-bottom:6px;color:var(--muted);font-size:13px;font-weight:800}input[data-invalid=true],textarea[data-invalid=true]{border-color:#fb2c36}input[data-invalid=true]+div,textarea[data-invalid=true]+div{margin-top:4px;color:#fb2c36;font-size:14px;font-weight:700}.form-container button{width:100%;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#1d1711;padding:12px;font-weight:800}.field-help{margin:6px 0 0;color:var(--muted);font-size:13px}.form-footer-links{display:flex;flex-wrap:wrap;gap:12px;justify-content:center;margin-top:20px;color:var(--muted);font-size:14px;font-weight:800}.form-footer-links a:hover{color:var(--accent-strong)}.profile-shell{width:min(960px,calc(100% - 40px));margin:0 auto;padding:clamp(28px,6vw,64px) 0}.profile-header{margin-bottom:28px}.profile-header h1{margin-top:8px;font-family:var(--font-reader);font-size:clamp(38px,5vw,62px)}.profile-header p:not(.eyebrow){color:var(--muted)}.profile-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;align-items:start}.profile-panel{display:grid;gap:18px;border:1px solid var(--border);border-radius:8px;background:color-mix(in srgb,var(--panel-solid) 88%,transparent);padding:22px}.profile-panel h2{font-size:22px}.profile-panel button{width:auto;border:1px solid var(--accent);border-radius:999px;background:var(--accent);color:#1d1711;padding:10px 18px;font-weight:800}.alert{min-width:320px;border:1px solid var(--border);border-radius:14px;background:var(--panel-solid);padding:12px 16px;color:var(--ink);font-size:14px;font-weight:700;animation:scale-up .2s cubic-bezier(.39,.575,.565,1) both}.alert-destructive{border-color:#fb2c36;background:#fb2c361a;color:#fb2c36}.alert-success{border-color:#00a63e;background:#00a63e1a;color:#00a63e}.flash-container{position:fixed;top:80px;right:0;left:0;display:flex;flex-direction:column;align-items:center}@media(max-width:860px){.app-header-inner{position:relative;grid-template-columns:1fr auto;gap:12px;min-height:58px;padding:8px 12px}.brand-cluster{min-width:0}.brand-line{display:none}.brand-mark{font-size:22px}.primary-nav,.nav-actions{display:none}.mobile-nav-actions{display:flex;align-items:center;justify-content:flex-end;gap:8px}.mobile-nav-actions .theme-toggle,.mobile-menu-button{min-height:38px;padding:8px 12px;font-size:13px}.mobile-menu-panel{position:absolute;top:calc(100% + 8px);right:10px;left:10px;display:grid;gap:14px;border:1px solid var(--border);border-radius:18px;padding:12px;background:color-mix(in srgb,var(--panel-solid) 94%,transparent);box-shadow:var(--shadow);-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px)}.mobile-menu-panel nav{display:grid;gap:6px}.mobile-menu-panel a,.mobile-account-row{border-radius:14px;padding:11px 12px;color:var(--ink);font-weight:800}.mobile-menu-panel a.current,.mobile-menu-panel a:hover{background:var(--accent-soft);color:var(--accent-strong)}.mobile-account-row{display:flex;align-items:center;justify-content:space-between;gap:12px;border-top:1px solid var(--border);border-radius:0;padding-top:12px}.mobile-account-row .nav-button{min-height:38px;padding:8px 14px}.app-main{width:calc(100% - 20px);margin-top:8px;border-radius:22px}.home-hero,.books-toolbar,.book-detail-header{grid-template-columns:1fr}.home-hero{min-height:auto}.hero-image-panel{min-height:300px}.profile-grid,.books-search{grid-template-columns:1fr}.books-search button{min-height:44px}.admin-header,.admin-row,.admin-row.compact{grid-template-columns:1fr}.admin-header{display:grid;align-items:start}.admin-header-actions,.admin-toolbar,.admin-actions,.admin-action-group,.admin-action-stack{justify-content:start}.admin-stats,.admin-form-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-data-table thead{display:none}.admin-data-table,.admin-data-table tbody,.admin-data-table tr,.admin-data-table td{display:block;width:100%}.admin-data-table tr{padding:14px 0;border-bottom:1px solid var(--border)}.admin-data-table tr:last-child{border-bottom:0}.admin-data-table td{display:grid;grid-template-columns:124px minmax(0,1fr);gap:12px;border-bottom:0;padding:8px 16px}.admin-data-table td:before{content:attr(data-label);color:var(--muted);font-size:12px;font-weight:900;letter-spacing:.04em;text-transform:uppercase}.admin-action-group,.admin-action-stack{justify-content:flex-start;flex-wrap:wrap}.reader-controls{position:static;border-radius:20px}}@media(max-width:560px){.hero-actions,.pagination{flex-wrap:wrap}.home-hero,.books-management,.book-detail,.admin-shell,.profile-shell{padding:22px}.books-grid{grid-template-columns:1fr}.book-card{grid-template-columns:76px minmax(0,1fr)}.book-cover-frame img,.book-cover-frame .cover-fallback{width:76px;height:114px}.featured-grid{grid-template-columns:repeat(2,minmax(0,1fr))}.admin-shell{width:calc(100% - 20px)}.admin-stats,.admin-form-grid,.check-grid,.compact-checks{grid-template-columns:1fr}.admin-search,.admin-toolbar{width:100%;flex-wrap:wrap}.admin-primary-action{width:100%;flex-wrap:nowrap}.admin-data-table td{grid-template-columns:1fr;gap:5px}.breadcrumbs{width:calc(100% - 20px);padding-top:12px}.pagination{display:grid;grid-template-columns:1fr 1fr;gap:10px}.pagination span{grid-column:1 / -1;grid-row:1;text-align:center}.pagination button{grid-row:2;min-width:0;width:100%}.reader-content{font-size:clamp(17px,var(--reader-font-size),21px)}}@keyframes scale-up{0%{transform:scale(.7)}to{transform:scale(1)}}html[dir=ltr],[data-sonner-toaster][dir=ltr]{--toast-icon-margin-start: -3px;--toast-icon-margin-end: 4px;--toast-svg-margin-start: -1px;--toast-svg-margin-end: 0px;--toast-button-margin-start: auto;--toast-button-margin-end: 0}html[dir=rtl],[data-sonner-toaster][dir=rtl]{--toast-icon-margin-start: 4px;--toast-icon-margin-end: -3px;--toast-svg-margin-start: 0px;--toast-svg-margin-end: -1px;--toast-button-margin-start: 0;--toast-button-margin-end: auto}[data-sonner-toaster]{position:fixed;width:var(--width);font-family:ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,Noto Sans,sans-serif,Apple Color Emoji,Segoe UI Emoji,Segoe UI Symbol,Noto Color Emoji;--gray1: hsl(0, 0%, 99%);--gray2: hsl(0, 0%, 97.3%);--gray3: hsl(0, 0%, 95.1%);--gray4: hsl(0, 0%, 93%);--gray5: hsl(0, 0%, 90.9%);--gray6: hsl(0, 0%, 88.7%);--gray7: hsl(0, 0%, 85.8%);--gray8: hsl(0, 0%, 78%);--gray9: hsl(0, 0%, 56.1%);--gray10: hsl(0, 0%, 52.3%);--gray11: hsl(0, 0%, 43.5%);--gray12: hsl(0, 0%, 9%);--border-radius: 8px;box-sizing:border-box;padding:0;margin:0;list-style:none;outline:none;z-index:999999999;transition:transform .4s ease}@media(hover:none)and (pointer:coarse){[data-sonner-toaster][data-lifted=true]{transform:none}}[data-sonner-toaster][data-x-position=right]{right:var(--offset-right)}[data-sonner-toaster][data-x-position=left]{left:var(--offset-left)}[data-sonner-toaster][data-x-position=center]{left:50%;transform:translate(-50%)}[data-sonner-toaster][data-y-position=top]{top:var(--offset-top)}[data-sonner-toaster][data-y-position=bottom]{bottom:var(--offset-bottom)}[data-sonner-toast]{--y: translateY(100%);--lift-amount: calc(var(--lift) * var(--gap));z-index:var(--z-index);position:absolute;opacity:0;transform:var(--y);touch-action:none;transition:transform .4s,opacity .4s,height .4s,box-shadow .2s;box-sizing:border-box;outline:none;overflow-wrap:anywhere}[data-sonner-toast][data-styled=true]{padding:16px;background:var(--normal-bg);border:1px solid var(--normal-border);color:var(--normal-text);border-radius:var(--border-radius);box-shadow:0 4px 12px #0000001a;width:var(--width);font-size:13px;display:flex;align-items:center;gap:6px}[data-sonner-toast]:focus-visible{box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}[data-sonner-toast][data-y-position=top]{top:0;--y: translateY(-100%);--lift: 1;--lift-amount: calc(1 * var(--gap))}[data-sonner-toast][data-y-position=bottom]{bottom:0;--y: translateY(100%);--lift: -1;--lift-amount: calc(var(--lift) * var(--gap))}[data-sonner-toast][data-styled=true] [data-description]{font-weight:400;line-height:1.4;color:#3f3f3f}[data-rich-colors=true][data-sonner-toast][data-styled=true] [data-description]{color:inherit}[data-sonner-toaster][data-sonner-theme=dark] [data-description]{color:#e8e8e8}[data-sonner-toast][data-styled=true] [data-title]{font-weight:500;line-height:1.5;color:inherit}[data-sonner-toast][data-styled=true] [data-icon]{display:flex;height:16px;width:16px;position:relative;justify-content:flex-start;align-items:center;flex-shrink:0;margin-left:var(--toast-icon-margin-start);margin-right:var(--toast-icon-margin-end)}[data-sonner-toast][data-promise=true] [data-icon]>svg{opacity:0;transform:scale(.8);transform-origin:center;animation:sonner-fade-in .3s ease forwards}[data-sonner-toast][data-styled=true] [data-icon]>*{flex-shrink:0}[data-sonner-toast][data-styled=true] [data-icon] svg{margin-left:var(--toast-svg-margin-start);margin-right:var(--toast-svg-margin-end)}[data-sonner-toast][data-styled=true] [data-content]{display:flex;flex-direction:column;gap:2px}[data-sonner-toast][data-styled=true] [data-button]{border-radius:4px;padding-left:8px;padding-right:8px;height:24px;font-size:12px;color:var(--normal-bg);background:var(--normal-text);margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end);border:none;font-weight:500;cursor:pointer;outline:none;display:flex;align-items:center;flex-shrink:0;transition:opacity .4s,box-shadow .2s}[data-sonner-toast][data-styled=true] [data-button]:focus-visible{box-shadow:0 0 0 2px #0006}[data-sonner-toast][data-styled=true] [data-button]:first-of-type{margin-left:var(--toast-button-margin-start);margin-right:var(--toast-button-margin-end)}[data-sonner-toast][data-styled=true] [data-cancel]{color:var(--normal-text);background:#00000014}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-styled=true] [data-cancel]{background:#ffffff4d}[data-sonner-toaster] [data-close-button-position=top-left]{--toast-close-button-left: 0;--toast-close-button-right: unset;--toast-close-button-top: 0;--toast-close-button-bottom: unset;--toast-close-button-transform: translate(-35%, -35%)}[data-sonner-toaster] [data-close-button-position=top-right]{--toast-close-button-left: unset;--toast-close-button-right: 0;--toast-close-button-top: 0;--toast-close-button-bottom: unset;--toast-close-button-transform: translate(35%, -35%)}[data-sonner-toaster] [data-close-button-position=bottom-left]{--toast-close-button-left: 0;--toast-close-button-right: unset;--toast-close-button-top: unset;--toast-close-button-bottom: 0;--toast-close-button-transform: translate(-35%, 35%)}[data-sonner-toaster] [data-close-button-position=bottom-right]{--toast-close-button-left: unset;--toast-close-button-right: 0;--toast-close-button-top: unset;--toast-close-button-bottom: 0;--toast-close-button-transform: translate(35%, 35%)}[data-sonner-toast][data-styled=true] [data-close-button]{position:absolute;left:var(--toast-close-button-left);right:var(--toast-close-button-right);top:var(--toast-close-button-top);bottom:var(--toast-close-button-bottom);height:20px;width:20px;display:flex;justify-content:center;align-items:center;padding:0;color:var(--gray12);background:var(--normal-bg);border:1px solid var(--gray4);transform:var(--toast-close-button-transform);border-radius:50%;cursor:pointer;z-index:1;transition:opacity .1s,background .2s,border-color .2s}[data-sonner-toast][data-styled=true] [data-close-button]:focus-visible{box-shadow:0 4px 12px #0000001a,0 0 0 2px #0003}[data-sonner-toast][data-styled=true] [data-disabled=true]{cursor:not-allowed}[data-sonner-toast][data-styled=true]:hover [data-close-button]:hover{background:var(--gray2);border-color:var(--gray5)}[data-sonner-toast][data-swiping=true]:before{content:"";position:absolute;left:-100%;right:-100%;height:100%;z-index:-1}[data-sonner-toast][data-y-position=top][data-swiping=true]:before{bottom:50%;transform:scaleY(3) translateY(50%)}[data-sonner-toast][data-y-position=bottom][data-swiping=true]:before{top:50%;transform:scaleY(3) translateY(-50%)}[data-sonner-toast][data-swiping=false][data-removed=true]:before{content:"";position:absolute;inset:0;transform:scaleY(2)}[data-sonner-toast][data-expanded=true]:after{content:"";position:absolute;left:0;height:calc(var(--gap) + 1px);bottom:100%;width:100%}[data-sonner-toast][data-mounted=true]{--y: translateY(0);opacity:1}[data-sonner-toast][data-expanded=false][data-front=false]{--scale: var(--toasts-before) * .05 + 1;--y: translateY(calc(var(--lift-amount) * var(--toasts-before))) scale(calc(-1 * var(--toasts-before) * .05 + 1));height:var(--front-toast-height)}[data-sonner-toast]>*{transition:opacity .4s}[data-sonner-toast][data-x-position=right]{right:0}[data-sonner-toast][data-x-position=left]{left:0}[data-sonner-toast][data-expanded=false][data-front=false][data-styled=true]>*{opacity:0}[data-sonner-toast][data-visible=false]{opacity:0;pointer-events:none}[data-sonner-toast][data-mounted=true][data-expanded=true]{--y: translateY(calc(var(--lift) * var(--offset)));height:var(--initial-height)}[data-sonner-toast][data-removed=true][data-front=true][data-swipe-out=false]{--y: translateY(calc(var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=true]{--y: translateY(calc(var(--lift) * var(--offset) + var(--lift) * -100%));opacity:0}[data-sonner-toast][data-removed=true][data-front=false][data-swipe-out=false][data-expanded=false]{--y: translateY(40%);opacity:0;transition:transform .5s,opacity .2s}[data-sonner-toast][data-removed=true][data-front=false]:before{height:calc(var(--initial-height) + 20%)}[data-sonner-toast][data-swiping=true]{transform:var(--y) translateY(var(--swipe-amount-y, 0px)) translate(var(--swipe-amount-x, 0px));transition:none}[data-sonner-toast][data-swiped=true]{-webkit-user-select:none;user-select:none}[data-sonner-toast][data-swipe-out=true][data-y-position=bottom],[data-sonner-toast][data-swipe-out=true][data-y-position=top]{animation-duration:.2s;animation-timing-function:ease-out;animation-fill-mode:forwards}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=left]{animation-name:swipe-out-left}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=right]{animation-name:swipe-out-right}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=up]{animation-name:swipe-out-up}[data-sonner-toast][data-swipe-out=true][data-swipe-direction=down]{animation-name:swipe-out-down}@keyframes swipe-out-left{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) - 100%));opacity:0}}@keyframes swipe-out-right{0%{transform:var(--y) translate(var(--swipe-amount-x));opacity:1}to{transform:var(--y) translate(calc(var(--swipe-amount-x) + 100%));opacity:0}}@keyframes swipe-out-up{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) - 100%));opacity:0}}@keyframes swipe-out-down{0%{transform:var(--y) translateY(var(--swipe-amount-y));opacity:1}to{transform:var(--y) translateY(calc(var(--swipe-amount-y) + 100%));opacity:0}}@media(max-width:600px){[data-sonner-toaster]{position:fixed;right:var(--mobile-offset-right);left:var(--mobile-offset-left);width:100%}[data-sonner-toaster][dir=rtl]{left:calc(var(--mobile-offset-left) * -1)}[data-sonner-toaster] [data-sonner-toast]{left:0;right:0;width:calc(100% - var(--mobile-offset-left) * 2)}[data-sonner-toaster][data-x-position=left]{left:var(--mobile-offset-left)}[data-sonner-toaster][data-y-position=bottom]{bottom:calc(var(--mobile-offset-bottom) + max(env(safe-area-inset-bottom),0px))}[data-sonner-toaster][data-y-position=top]{top:calc(var(--mobile-offset-top) + max(env(safe-area-inset-top),0px))}[data-sonner-toaster][data-x-position=center]{left:var(--mobile-offset-left);right:var(--mobile-offset-right);transform:none}}[data-sonner-toaster][data-sonner-theme=light]{--normal-bg: #fff;--normal-border: var(--gray4);--normal-text: var(--gray12);--success-bg: hsl(143, 85%, 96%);--success-border: hsl(145, 92%, 87%);--success-text: hsl(140, 100%, 27%);--info-bg: hsl(208, 100%, 97%);--info-border: hsl(221, 91%, 93%);--info-text: hsl(210, 92%, 45%);--warning-bg: hsl(49, 100%, 97%);--warning-border: hsl(49, 91%, 84%);--warning-text: hsl(31, 92%, 45%);--error-bg: hsl(359, 100%, 97%);--error-border: hsl(359, 100%, 94%);--error-text: hsl(360, 100%, 45%)}[data-sonner-toaster][data-sonner-theme=light] [data-sonner-toast][data-invert=true]{--normal-bg: #000;--normal-border: hsl(0, 0%, 20%);--normal-text: var(--gray1)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast][data-invert=true]{--normal-bg: #fff;--normal-border: var(--gray3);--normal-text: var(--gray12)}[data-sonner-toaster][data-sonner-theme=dark]{--normal-bg: #000;--normal-bg-hover: hsl(0, 0%, 12%);--normal-border: hsl(0, 0%, 20%);--normal-border-hover: hsl(0, 0%, 25%);--normal-text: var(--gray1);--success-bg: hsl(150, 100%, 6%);--success-border: hsl(147, 100%, 12%);--success-text: hsl(150, 86%, 65%);--info-bg: hsl(215, 100%, 6%);--info-border: hsl(223, 43%, 17%);--info-text: hsl(216, 87%, 65%);--warning-bg: hsl(64, 100%, 6%);--warning-border: hsl(60, 100%, 9%);--warning-text: hsl(46, 87%, 65%);--error-bg: hsl(358, 76%, 10%);--error-border: hsl(357, 89%, 16%);--error-text: hsl(358, 100%, 81%)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]{background:var(--normal-bg);border-color:var(--normal-border);color:var(--normal-text)}[data-sonner-toaster][data-sonner-theme=dark] [data-sonner-toast] [data-close-button]:hover{background:var(--normal-bg-hover);border-color:var(--normal-border-hover)}[data-rich-colors=true][data-sonner-toast][data-type=success],[data-rich-colors=true][data-sonner-toast][data-type=success] [data-close-button]{background:var(--success-bg);border-color:var(--success-border);color:var(--success-text)}[data-rich-colors=true][data-sonner-toast][data-type=info],[data-rich-colors=true][data-sonner-toast][data-type=info] [data-close-button]{background:var(--info-bg);border-color:var(--info-border);color:var(--info-text)}[data-rich-colors=true][data-sonner-toast][data-type=warning],[data-rich-colors=true][data-sonner-toast][data-type=warning] [data-close-button]{background:var(--warning-bg);border-color:var(--warning-border);color:var(--warning-text)}[data-rich-colors=true][data-sonner-toast][data-type=error],[data-rich-colors=true][data-sonner-toast][data-type=error] [data-close-button]{background:var(--error-bg);border-color:var(--error-border);color:var(--error-text)}.sonner-loading-wrapper{--size: 16px;height:var(--size);width:var(--size);position:absolute;inset:0;z-index:10}.sonner-loading-wrapper[data-visible=false]{transform-origin:center;animation:sonner-fade-out .2s ease forwards}.sonner-spinner{position:relative;top:50%;left:50%;height:var(--size);width:var(--size)}.sonner-loading-bar{animation:sonner-spin 1.2s linear infinite;background:var(--gray11);border-radius:6px;height:8%;left:-10%;position:absolute;top:-3.9%;width:24%}.sonner-loading-bar:nth-child(1){animation-delay:-1.2s;transform:rotate(.0001deg) translate(146%)}.sonner-loading-bar:nth-child(2){animation-delay:-1.1s;transform:rotate(30deg) translate(146%)}.sonner-loading-bar:nth-child(3){animation-delay:-1s;transform:rotate(60deg) translate(146%)}.sonner-loading-bar:nth-child(4){animation-delay:-.9s;transform:rotate(90deg) translate(146%)}.sonner-loading-bar:nth-child(5){animation-delay:-.8s;transform:rotate(120deg) translate(146%)}.sonner-loading-bar:nth-child(6){animation-delay:-.7s;transform:rotate(150deg) translate(146%)}.sonner-loading-bar:nth-child(7){animation-delay:-.6s;transform:rotate(180deg) translate(146%)}.sonner-loading-bar:nth-child(8){animation-delay:-.5s;transform:rotate(210deg) translate(146%)}.sonner-loading-bar:nth-child(9){animation-delay:-.4s;transform:rotate(240deg) translate(146%)}.sonner-loading-bar:nth-child(10){animation-delay:-.3s;transform:rotate(270deg) translate(146%)}.sonner-loading-bar:nth-child(11){animation-delay:-.2s;transform:rotate(300deg) translate(146%)}.sonner-loading-bar:nth-child(12){animation-delay:-.1s;transform:rotate(330deg) translate(146%)}@keyframes sonner-fade-in{0%{opacity:0;transform:scale(.8)}to{opacity:1;transform:scale(1)}}@keyframes sonner-fade-out{0%{opacity:1;transform:scale(1)}to{opacity:0;transform:scale(.8)}}@keyframes sonner-spin{0%{opacity:1}to{opacity:.15}}@media(prefers-reduced-motion){[data-sonner-toast],[data-sonner-toast]>*,.sonner-loading-bar{transition:none!important;animation:none!important}}.sonner-loader{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transform-origin:center;transition:opacity .2s,transform .2s}.sonner-loader[data-visible=false]{opacity:0;transform:scale(.8) translate(-50%,-50%)}
