:root{--bg: #faf7f2;--ink: #2a2622;--muted: #7a726a;--accent: #e26d4f;--accent-ink: #fff;--card: #fff;--border: #e6dfd5;--danger: #e63946;--radius: 12px;font-family:system-ui,-apple-system,Segoe UI,Roboto,sans-serif;color:var(--ink);background:var(--bg)}*{box-sizing:border-box}body{margin:0;transition:background .2s ease}a{color:var(--accent);text-decoration:none}a:hover{text-decoration:underline}button{font:inherit;background:var(--accent);color:var(--accent-ink);border:none;padding:.55rem 1rem;border-radius:var(--radius);cursor:pointer}button.secondary{background:var(--card);color:var(--ink);border:1px solid var(--border)}button.secondary.danger-active{background:var(--danger);color:#fff;border-color:var(--danger)}button:disabled{opacity:.5;cursor:not-allowed}input,textarea{font:inherit;width:100%;padding:.55rem .75rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--ink)}textarea{min-height:6rem;resize:vertical}.app{max-width:1100px;margin:0 auto;padding:1.5rem}.app header{display:flex;align-items:baseline;justify-content:space-between;margin-bottom:1.5rem}.app h1{margin:0;font-size:1.6rem}.app h1 a,.app h1 a:hover{text-decoration:none;color:inherit}.app .brand{color:var(--accent)}.library-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:1rem}.library-card{background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:.75rem;display:flex;flex-direction:column;gap:.5rem}.library-card .cover{aspect-ratio:4 / 3;background:var(--bg);border-radius:8px;overflow:hidden;display:flex;align-items:center;justify-content:center;color:var(--muted)}.library-card .cover img{width:100%;height:100%;object-fit:cover}.library-card .title{font-weight:600}.library-card .actions{display:flex;gap:.4rem}.library-card .actions button{flex:1;padding:.4rem .5rem;font-size:.85rem}.editor-toolbar{display:flex;gap:.5rem;align-items:center;margin-bottom:1.25rem}.link-button{display:inline-block;padding:.55rem 1rem;border:1px solid var(--border);border-radius:var(--radius);background:var(--card);color:var(--ink);text-decoration:none}.link-button:hover{text-decoration:none}.editor{display:grid;grid-template-columns:220px 1fr;gap:1.5rem;align-items:start}.editor .page-list{display:flex;flex-direction:column;gap:.5rem}.editor .page-thumb{background:var(--card);border:1px solid var(--border);border-radius:8px;padding:.5rem;cursor:pointer;text-align:left;color:var(--ink);font-size:.85rem}.editor .page-thumb.active{border-color:var(--accent)}.editor .page-thumb .num{color:var(--muted);font-size:.75rem}.book-stage{display:flex;justify-content:center;padding:1.5rem 0;width:100%}.book-page{position:relative;width:min(560px,100%);aspect-ratio:3 / 4;background:linear-gradient(180deg,#fffdf7,#fbf6e9);border-radius:4px 14px 14px 4px;box-shadow:0 1px #0000000a,0 12px 30px -10px #00000059,inset 12px 0 18px -16px #00000073;border:1px solid #e8dec5;overflow:hidden}.book-page:before{content:"";position:absolute;left:0;top:0;bottom:0;width:14px;background:linear-gradient(90deg,rgba(0,0,0,.18),transparent);pointer-events:none;z-index:1}.book-page.cover{color:var(--cover-ink, #fff7e8);padding:1.75rem;display:flex;flex-direction:column;gap:1rem;border:1px solid rgba(0,0,0,.4);box-shadow:0 2px #00000014,0 18px 40px -10px #00000080,inset 12px 0 18px -16px #0000008c,inset 0 0 0 8px #ffffff0a,inset 0 0 0 9px #00000040}.book-page.cover:before{background:linear-gradient(90deg,rgba(0,0,0,.35),transparent)}.image-slot{background:color-mix(in srgb,var(--cover-ink, #fff) 8%,transparent);border:1px dashed color-mix(in srgb,var(--cover-ink, #fff) 35%,transparent);border-radius:6px;display:flex;align-items:center;justify-content:center;color:color-mix(in srgb,var(--cover-ink, #fff) 70%,transparent);overflow:hidden;cursor:pointer;flex:1;min-height:0}.image-slot img{width:100%;height:100%;object-fit:cover}.cover-title,.cover-author{background:transparent;border:1px dashed transparent;color:inherit;text-align:center;padding:.4rem .6rem;border-radius:4px}.cover-title{font-family:Georgia,Times New Roman,serif;font-size:2rem;font-weight:700;letter-spacing:.02em}.cover-author{font-family:Georgia,Times New Roman,serif;font-style:italic;font-size:1.1rem;opacity:.92}.cover-title:hover,.cover-author:hover,.cover-title:focus,.cover-author:focus{border-color:color-mix(in srgb,var(--cover-ink, #fff) 45%,transparent);outline:none}.cover-title::placeholder,.cover-author::placeholder{color:color-mix(in srgb,var(--cover-ink, #fff) 55%,transparent)}.cover-color{display:flex;align-items:center;justify-content:center;gap:.5rem;font-size:.85rem;opacity:.9}.cover-color input[type=color]{width:32px;height:28px;padding:0;border:1px solid color-mix(in srgb,var(--cover-ink, #fff) 50%,transparent);border-radius:6px;cursor:pointer;background:none}.reset-btn{background:transparent;border:1px solid var(--border);color:inherit;padding:.1rem .4rem;font-size:.95rem;border-radius:6px;cursor:pointer;line-height:1}.reset-btn.on-cover{border-color:color-mix(in srgb,var(--cover-ink, #fff) 50%,transparent)}.pattern-picker{display:inline-flex;gap:4px}.pattern-swatch{width:24px;height:24px;padding:0;border:1px solid var(--border);border-radius:6px;cursor:pointer;background-color:transparent}.pattern-swatch.active{outline:2px solid var(--accent);outline-offset:1px}.cover-image-static{width:100%;flex:1;min-height:0;object-fit:cover;border-radius:6px}.cover-title-static{font-family:Georgia,serif;font-size:2rem;font-weight:700;text-align:center;margin-top:.5rem}.cover-author-static{font-family:Georgia,serif;font-style:italic;text-align:center;opacity:.92}.line-element{position:absolute;display:flex;align-items:center;gap:.25rem;z-index:2;pointer-events:none}.line-element>*{pointer-events:auto}.line-input{flex:1;display:block;box-sizing:border-box;background:transparent;border:none;border-bottom:2px solid #6a5b3e;border-radius:0;padding:.25rem .5rem 0;font-family:Georgia,Times New Roman,serif;font-size:1.1rem;line-height:1.4;color:#2a2622;width:auto;min-height:0;resize:none;overflow:hidden;vertical-align:top;field-sizing:content}.line-input:focus{outline:none;border-bottom-color:var(--accent)}.line-input:disabled,.line-input[readonly]{color:#2a2622;-webkit-text-fill-color:#2a2622;opacity:1;cursor:default;border-bottom:none}.image-element{position:absolute;border:1px dashed rgba(0,0,0,.25);background:#0000000a;border-radius:6px;overflow:hidden;display:flex;align-items:center;justify-content:center;z-index:2}.image-element img{width:100%;height:100%;object-fit:cover;display:block;pointer-events:none}.image-placeholder{color:var(--muted);font-size:.85rem;pointer-events:none}.image-pick-btn{position:absolute;top:4px;right:4px;background:#ffffffeb;color:var(--ink);border:1px solid var(--border);border-radius:4px;padding:.15rem .45rem;font-size:.75rem;cursor:pointer}.image-delete-btn{position:absolute;bottom:4px;left:4px;background:#ffffffeb;color:var(--danger);border:1px solid var(--border);border-radius:4px;padding:.05rem .4rem;font-size:.75rem;cursor:pointer;line-height:1.2}.image-delete-btn:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.handle{width:22px;height:22px;display:inline-flex;align-items:center;justify-content:center;background:#ffffffeb;border:1px solid var(--border);border-radius:4px;font-size:.85rem;-webkit-user-select:none;user-select:none;touch-action:none;color:var(--ink)}.handle-move{cursor:grab}.handle-resize-line{cursor:ew-resize}.handle-move-box{position:absolute;top:4px;left:4px;cursor:grab}.handle-resize-box{position:absolute;bottom:4px;right:4px;cursor:nwse-resize}.handle-delete{cursor:pointer;color:var(--danger);padding:0}.handle-delete:hover{background:var(--danger);color:#fff;border-color:var(--danger)}.page-number{position:absolute;bottom:.75rem;right:1rem;font-family:Georgia,serif;font-style:italic;color:var(--muted);font-size:.9rem;z-index:1}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;display:flex;align-items:center;justify-content:center;z-index:10}.modal{background:var(--card);border-radius:var(--radius);padding:1.25rem;width:min(720px,92vw);max-height:86vh;display:flex;flex-direction:column;gap:.75rem}.modal .results{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:.5rem;overflow-y:auto;padding:.25rem}.modal .results button{padding:0;background:none;border:1px solid var(--border);border-radius:8px;overflow:hidden;aspect-ratio:1;cursor:pointer}.modal .results img{width:100%;height:100%;object-fit:cover;display:block}.viewer{display:flex;flex-direction:column;align-items:center;gap:1rem}.viewer .nav{display:flex;gap:1rem;align-items:center}.viewer .nav .count{color:var(--muted)}.header-user{display:flex;align-items:center;gap:.6rem;font-size:.9rem}.header-user-name{color:inherit}.role-badge{display:inline-block;margin-left:.4rem;padding:.05rem .4rem;border-radius:999px;background:var(--accent);color:var(--accent-ink);font-size:.7rem;text-transform:uppercase;letter-spacing:.05em}.library-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:1rem;flex-wrap:wrap}.library-controls{display:flex;gap:.75rem;align-items:center}.library-bg-label{display:flex;align-items:center;gap:.4rem;font-size:.9rem}.library-bg-label input[type=color]{width:32px;height:28px;padding:0;border:1px solid var(--border);border-radius:6px}.library-card.is-delisted{opacity:.7}.badge{display:inline-block;margin-left:.4rem;padding:.05rem .4rem;border-radius:999px;font-size:.7rem;text-transform:uppercase;letter-spacing:.05em;vertical-align:middle}.badge-private{background:#4a3f6a;color:#fff}.badge-delisted{background:var(--danger);color:#fff}.banner{border-radius:var(--radius);padding:.7rem 1rem;margin-bottom:1rem;font-size:.9rem}.banner-delisted{background:#e639461f;border:1px solid rgba(230,57,70,.4);color:#6a1d24}.banner-admin{background:#e26d4f26;border:1px solid rgba(226,109,79,.5);color:#5a3826}.auth-card{max-width:380px;margin:2rem auto;background:var(--card);border:1px solid var(--border);border-radius:var(--radius);padding:1.5rem}.auth-card h2{margin-top:0}.auth-card form{display:flex;flex-direction:column;gap:.75rem}.auth-card label{display:flex;flex-direction:column;gap:.3rem;font-size:.9rem}.auth-card button{margin-top:.5rem}.auth-aside{color:var(--muted);font-size:.9rem;margin-top:1rem}.form-error{color:var(--danger);background:#e6394614;border:1px solid rgba(230,57,70,.3);border-radius:8px;padding:.5rem .75rem;font-size:.9rem}.page-loading{color:var(--muted);padding:1rem}.admin{display:grid;grid-template-columns:180px 1fr;gap:1.5rem}.admin-nav{display:flex;flex-direction:column;gap:.25rem}.admin-nav a{padding:.5rem .75rem;border-radius:8px;color:var(--ink);border:1px solid transparent}.admin-nav a.active{background:var(--card);border-color:var(--border);color:var(--accent)}.admin-row{display:flex;gap:.75rem;align-items:center;margin-bottom:.75rem}.admin-table{width:100%;border-collapse:collapse;font-size:.9rem;background:var(--card);border-radius:var(--radius);overflow:hidden}.admin-table th,.admin-table td{text-align:left;padding:.55rem .75rem;border-bottom:1px solid var(--border);vertical-align:middle}.admin-table th{background:var(--bg);font-weight:600}.admin-table tr:last-child td{border-bottom:none}.row-actions{display:flex;gap:.4rem;flex-wrap:wrap}.status-banned{color:var(--danger);font-weight:600}.status-pwreset{color:var(--muted);font-size:.85rem}.audit-meta{font-size:.75rem;color:var(--muted);white-space:pre-wrap;word-break:break-word}.modal-tabs{display:flex;gap:.4rem;align-items:center}.modal-tab{background:transparent;color:var(--muted);border:1px solid transparent;padding:.4rem .75rem;border-radius:8px}.modal-tab.active{background:var(--card);border-color:var(--border);color:var(--ink)}.upload-pane{display:flex;flex-direction:column;gap:.75rem;padding:1rem 0}.privacy-toggle{display:flex;gap:.4rem;align-items:center;font-size:.85rem;color:var(--ink);margin-top:.75rem;padding:.5rem;border:1px solid var(--border);border-radius:8px;background:var(--card)}.privacy-toggle input[type=checkbox]{width:auto}.layout-picker{display:grid;grid-template-columns:1fr 1fr;gap:.4rem;padding:.5rem;background:var(--card);border:1px solid var(--border);border-radius:8px;margin-top:.25rem}.layout-picker button{display:flex;flex-direction:column;align-items:center;gap:.3rem;padding:.4rem .25rem;background:transparent;color:var(--ink);border:1px solid var(--border);border-radius:6px;font-size:.7rem;text-align:center}.layout-picker button:hover{background:var(--bg)}.layout-thumb{position:relative;width:36px;aspect-ratio:3 / 4;background:#fffdf7;border:1px solid var(--border);border-radius:2px;overflow:hidden}.layout-thumb:before,.layout-thumb:after{content:"";position:absolute;pointer-events:none}.layout-thumb.layout-image-top:before{top:8%;right:8%;bottom:30%;left:8%;background:#d8d2c3;border-radius:1px}.layout-thumb.layout-image-top:after{left:12%;right:12%;bottom:18%;height:1.5px;background:#6a5b3e}.layout-thumb.layout-three-lines{background:linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 32% / 76% 1.5px,linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 52% / 76% 1.5px,linear-gradient(#6a5b3e,#6a5b3e) no-repeat 12% 72% / 76% 1.5px,#fffdf7}.layout-thumb.layout-full-image:before{top:0;right:0;bottom:0;left:0;background:#d8d2c3}
