/*
 * RED CAPE — styles.css
 * All visual styles for the public site and admin panel.
 * No JavaScript. No inline logic. Pure presentation.
 *
 * Sections:
 *   1.  Theme tokens       CSS custom properties (dark / light)
 *   2.  Reset & base       body, page visibility
 *   3.  Navigation         nav, logo, links, hamburger, mobile menu
 *   4.  Layout             .section, shared wrappers
 *   5.  Buttons            .btn-primary, .btn-secondary, .btn-submit etc.
 *   6.  Hero               home hero, about hero
 *   7.  Chapter cards      .chapter-card, cover, badges
 *   8.  Featured card      home page latest-chapter card
 *   9.  Archive            sort toggle
 *  10.  Blog               post cards, editor, toolbar
 *  11.  About              author row, social grid
 *  12.  Reader             scroll, horizontal, paged, sections, nav
 *  13.  Share              dropdown, overlay
 *  14.  Bookmark           button
 *  15.  Admin — layout     wrap, tabs, cards, chapter list item
 *  16.  Admin — forms      form-group, mode/dir toggles, file-drop, thumbs
 *  17.  Admin — sections   sections manager
 *  18.  Login              login box
 *  19.  Toast              floating toast notification
 *  20.  Responsive         mobile breakpoints
 */

/* ─────────────────────────────────────────────────────
   1. THEME TOKENS
   ───────────────────────────────────────────────────── */
[data-theme="dark"] {
  --bg:#111; --bg2:#1a1a1a; --bg3:#2a2a2a;
  --text:#FAFAF5; --text-muted:rgba(255,255,255,.45); --text-dim:rgba(255,255,255,.25);
  --border:#2a2a2a; --card:#1a1a1a; --nav-bg:#0d0d0d;
  --hero-bg:linear-gradient(135deg,#1a0005,#2d0008,#1a0005);
}
[data-theme="light"] {
  --bg:#f5f5f0; --bg2:#fff; --bg3:#e8e8e4;
  --text:#111; --text-muted:rgba(0,0,0,.5); --text-dim:rgba(0,0,0,.3);
  --border:#ddddd8; --card:#fff; --nav-bg:#fff;
  --hero-bg:linear-gradient(135deg,#2d0008,#5a0010,#2d0008);
}
:root { --red:#e8192c; --red-dark:#b0111f; --yellow:#FFD600; }

/* ─────────────────────────────────────────────────────
   2. RESET & BASE
   ───────────────────────────────────────────────────── */
* { margin:0; padding:0; box-sizing:border-box; }
body {
  background:var(--bg); color:var(--text);
  font-family:'Nunito',sans-serif; min-height:100vh;
  transition:background .2s,color .2s;
}
.page { display:none; }
.page.active { display:block; }

/* ─────────────────────────────────────────────────────
   3. NAVIGATION
   ───────────────────────────────────────────────────── */
nav {
  background:var(--nav-bg); border-bottom:3px solid var(--red);
  padding:0 1.25rem; height:56px;
  display:flex; align-items:center; justify-content:space-between;
  box-shadow:0 2px 12px rgba(0,0,0,.3); transition:background .2s;
  position:relative; z-index:1000;
}
.nav-logo {
  font-family:'Bangers',cursive; font-size:1.6rem; color:var(--red);
  letter-spacing:2px; cursor:pointer; text-shadow:2px 2px 0 var(--yellow);
  transition:transform .15s; flex-shrink:0;
}
.nav-logo-img { height:36px; width:auto; max-width:180px; object-fit:contain; display:block; }
.nav-logo:hover .nav-logo-img { opacity:.85; }
.nav-links { display:flex; gap:.25rem; align-items:center; }
.nav-link {
  color:var(--text); font-weight:700; font-size:.75rem; letter-spacing:.5px;
  text-transform:uppercase; cursor:pointer; padding:.4rem .6rem;
  border-radius:5px; border:none; background:none;
  font-family:'Nunito',sans-serif; transition:background .15s,color .15s;
}
.nav-link:hover { background:rgba(232,25,44,.12); color:var(--red); }
.nav-link.active-link { color:var(--red); border-bottom:2px solid var(--red); border-radius:0; }
.theme-toggle {
  display:flex; align-items:center; gap:.35rem;
  margin-left:.5rem; padding-left:.5rem; border-left:1px solid var(--border);
}
.toggle-switch {
  width:42px; height:22px; background:var(--bg3); border-radius:11px;
  position:relative; cursor:pointer; border:none; transition:background .2s; flex-shrink:0;
}
.toggle-switch::after {
  content:''; position:absolute; top:3px; left:3px;
  width:16px; height:16px; background:var(--text); border-radius:50%; transition:transform .2s;
}
[data-theme="light"] .toggle-switch::after { transform:translateX(20px); }
.toggle-icon { font-size:1rem; }
.btn-admin {
  background:transparent; border:2px solid var(--yellow); color:var(--yellow);
  padding:.3rem .6rem; border-radius:4px; font-family:'Nunito',sans-serif;
  font-weight:700; font-size:.72rem; cursor:pointer; letter-spacing:.5px;
  margin-left:.15rem; transition:all .15s;
}
.btn-admin:hover { background:var(--yellow); color:#111; }
.hamburger {
  display:none; background:none; border:none; cursor:pointer;
  flex-direction:column; gap:4px; padding:4px;
}
.hamburger span { display:block; width:22px; height:2px; background:var(--text); border-radius:2px; }
.mobile-menu {
  display:none; position:absolute; top:56px; left:0; right:0;
  background:var(--nav-bg); border-bottom:2px solid var(--red);
  padding:1rem; flex-direction:column; gap:.25rem;
  z-index:9999; box-shadow:0 8px 24px rgba(0,0,0,.5);
}
.mobile-menu.open { display:flex; }

/* ─────────────────────────────────────────────────────
   4. LAYOUT
   ───────────────────────────────────────────────────── */
.section { max-width:900px; margin:0 auto; padding:3rem 1.5rem; }
.section-title { font-family:'Bangers',cursive; font-size:2.2rem; color:var(--red); letter-spacing:2px; margin-bottom:.25rem; }
.section-divider { width:60px; height:4px; background:var(--yellow); margin-bottom:2rem; border-radius:2px; }
.empty-state { text-align:center; padding:4rem 2rem; color:var(--text-dim); }
.empty-state .big { font-size:3rem; margin-bottom:1rem; }

/* ─────────────────────────────────────────────────────
   5. BUTTONS
   ───────────────────────────────────────────────────── */
.back-btn {
  background:none; border:2px solid var(--border); color:var(--text);
  padding:.4rem .8rem; cursor:pointer; border-radius:4px;
  font-family:'Nunito',sans-serif; font-size:.85rem; font-weight:700; transition:all .15s;
}
.back-btn:hover { border-color:var(--red); color:var(--red); }
.btn-primary {
  background:var(--red); color:white; border:none;
  padding:.75rem 1.6rem; font-family:'Bangers',cursive; font-size:1.1rem;
  letter-spacing:2px; cursor:pointer; border-radius:4px;
  box-shadow:3px 3px 0 var(--red-dark); transition:all .12s;
}
.btn-primary:hover { transform:translate(-2px,-2px); box-shadow:5px 5px 0 var(--red-dark); }
.btn-secondary {
  background:transparent; color:white; border:2px solid white;
  padding:.75rem 1.6rem; font-family:'Bangers',cursive; font-size:1.1rem;
  letter-spacing:2px; cursor:pointer; border-radius:4px; transition:all .12s;
}
.btn-secondary:hover { border-color:var(--yellow); color:var(--yellow); }
.btn-submit {
  background:var(--red); color:white; border:none;
  padding:.85rem 2.5rem; font-family:'Bangers',cursive; font-size:1.2rem;
  letter-spacing:2px; cursor:pointer; border-radius:6px;
  box-shadow:4px 4px 0 var(--red-dark); transition:all .12s; width:100%;
}
.btn-submit:hover { transform:translateY(-2px); box-shadow:4px 6px 0 var(--red-dark); }
.btn-delete {
  background:none; border:1px solid var(--red); color:var(--red);
  padding:.3rem .75rem; border-radius:4px; cursor:pointer;
  font-size:.8rem; font-weight:700; font-family:'Nunito',sans-serif; transition:all .15s;
}
.btn-delete:hover { background:var(--red); color:white; }
.btn-sig-clear {
  background:none; border:1px solid var(--border); color:var(--text-muted);
  padding:.3rem .75rem; border-radius:4px; cursor:pointer;
  font-size:.8rem; font-weight:700; font-family:'Nunito',sans-serif; transition:all .15s;
}
.btn-sig-clear:hover { border-color:var(--red); color:var(--red); }

/* ─────────────────────────────────────────────────────
   6. HERO
   ───────────────────────────────────────────────────── */
.hero {
  background:var(--hero-bg); padding:5rem 2rem; text-align:center;
  position:relative; overflow:hidden; border-bottom:4px solid var(--red);
  background-image:url('assets/hero-home-1920.jpg');
  background-size:cover; background-position:center; background-blend-mode:multiply;
}
@media(max-width:1440px) {
  .hero { background-image:url('assets/hero-home-1440.jpg'); }
}
.hero::before {
  content:''; position:absolute; inset:0;
  background:repeating-linear-gradient(45deg,transparent,transparent 40px,rgba(232,25,44,.04) 40px,rgba(232,25,44,.04) 80px);
}
.hero-title {
  font-family:'Bangers',cursive; font-size:clamp(4rem,12vw,9rem); color:var(--red);
  text-shadow:6px 6px 0 var(--yellow),10px 10px 0 rgba(0,0,0,.4);
  letter-spacing:4px; line-height:1; position:relative;
}
.hero-sub { font-size:1rem; color:rgba(255,255,255,.7); letter-spacing:3px; text-transform:uppercase; margin-top:.5rem; font-weight:600; position:relative; }
.hero-cta { margin-top:2.5rem; display:flex; gap:1rem; justify-content:center; flex-wrap:wrap; position:relative; }
.about-hero {
  background:var(--hero-bg); padding:3rem 2rem; border-bottom:3px solid var(--red);
  background-image:url('assets/hero-about-1200.jpg');
  background-size:cover; background-position:center; background-blend-mode:multiply;
}
.about-content { max-width:720px; margin:0 auto; padding:3rem 1.5rem; }
.about-content h2 { font-family:'Bangers',cursive; font-size:2rem; color:var(--red); letter-spacing:2px; margin-bottom:.5rem; }
.about-content p { color:var(--text-muted); line-height:1.7; margin-bottom:1.5rem; font-size:.95rem; }

/* ─────────────────────────────────────────────────────
   7. CHAPTER CARDS
   ───────────────────────────────────────────────────── */
.chapter-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(170px,1fr)); gap:1.2rem; }
.chapter-card {
  background:var(--card); border-radius:8px; overflow:hidden;
  cursor:pointer; border:2px solid transparent; position:relative;
  box-shadow:0 2px 8px rgba(0,0,0,.15); transition:all .15s;
}
.chapter-card:hover { border-color:var(--red); transform:translateY(-4px); box-shadow:0 8px 24px rgba(232,25,44,.2); }
.chapter-cover { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; }
.chapter-cover-placeholder {
  width:100%; aspect-ratio:3/4; background:linear-gradient(135deg,#2a0005,#3d0008);
  display:flex; align-items:center; justify-content:center;
}
.chapter-cover-placeholder .ch-num { font-family:'Bangers',cursive; font-size:3rem; color:var(--red); opacity:.7; }
.chapter-info { padding:.75rem; }
.chapter-num { font-size:.7rem; color:var(--red); font-weight:700; text-transform:uppercase; letter-spacing:1px; }
.chapter-title { font-size:.9rem; font-weight:700; color:var(--text); margin-top:.1rem; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.chapter-date { font-size:.75rem; color:var(--text-muted); margin-top:.2rem; }
.new-badge {
  position:absolute; top:8px; right:8px; background:var(--yellow); color:#111;
  font-size:.65rem; font-weight:900; padding:2px 7px; border-radius:20px;
  letter-spacing:1px; text-transform:uppercase;
}
.mode-badge {
  position:absolute; bottom:60px; left:8px; background:rgba(0,0,0,.75);
  color:rgba(255,255,255,.8); font-size:.6rem; font-weight:700;
  padding:2px 6px; border-radius:3px; letter-spacing:1px; text-transform:uppercase;
}

/* ─────────────────────────────────────────────────────
   8. FEATURED CHAPTER CARD (home — latest chapter)
   ───────────────────────────────────────────────────── */
.featured-chapter {
  display:flex; gap:2rem; align-items:flex-start;
  background:var(--card); border:2px solid var(--border);
  border-radius:14px; overflow:hidden;
  box-shadow:0 4px 24px rgba(0,0,0,.2);
  cursor:pointer; transition:all .18s;
}
.featured-chapter:hover {
  border-color:var(--red);
  box-shadow:0 8px 36px rgba(232,25,44,.18);
  transform:translateY(-3px);
}
.featured-cover-wrap { flex-shrink:0; width:220px; position:relative; }
.featured-cover-wrap img, .featured-cover-placeholder {
  width:220px; aspect-ratio:4/5.6; object-fit:cover; display:block;
}
.featured-cover-placeholder {
  background:linear-gradient(135deg,#2a0005,#3d0008);
  display:flex; align-items:center; justify-content:center;
}
.featured-cover-placeholder .fc-num { font-family:'Bangers',cursive; font-size:4rem; color:var(--red); opacity:.6; }
.featured-new-badge {
  position:absolute; top:10px; left:10px;
  background:var(--yellow); color:#111;
  font-size:.65rem; font-weight:900; padding:3px 9px;
  border-radius:20px; letter-spacing:1px; text-transform:uppercase;
}
.featured-mode-badge {
  position:absolute; bottom:10px; left:10px;
  background:rgba(0,0,0,.75); color:rgba(255,255,255,.8);
  font-size:.6rem; font-weight:700; padding:2px 7px;
  border-radius:3px; letter-spacing:1px; text-transform:uppercase;
}
.featured-info {
  flex:1; padding:1.75rem 1.75rem 1.75rem 0;
  display:flex; flex-direction:column; justify-content:center; gap:.75rem;
}
.featured-chapter-num { font-size:.72rem; font-weight:900; text-transform:uppercase; letter-spacing:2px; color:var(--red); }
.featured-chapter-title { font-family:'Bangers',cursive; font-size:clamp(1.6rem,4vw,2.4rem); letter-spacing:1.5px; color:var(--text); line-height:1.1; }
.featured-chapter-date { font-size:.8rem; color:var(--text-dim); font-weight:600; }
.featured-chapter-desc {
  font-size:.9rem; color:var(--text-muted); line-height:1.65;
  display:-webkit-box; -webkit-line-clamp:3; -webkit-box-orient:vertical; overflow:hidden;
}
.featured-read-btn {
  display:inline-flex; align-items:center; gap:.5rem;
  background:var(--red); color:white; border:none;
  padding:.7rem 1.6rem; border-radius:6px;
  font-family:'Bangers',cursive; font-size:1.1rem; letter-spacing:2px;
  cursor:pointer; box-shadow:3px 3px 0 var(--red-dark);
  transition:all .12s; align-self:flex-start; margin-top:.25rem;
}
.featured-read-btn:hover { transform:translate(-2px,-2px); box-shadow:5px 5px 0 var(--red-dark); }

/* ─────────────────────────────────────────────────────
   9. ARCHIVE — sort toggle
   ───────────────────────────────────────────────────── */
.sort-toggle { display:flex; border:2px solid var(--border); border-radius:6px; overflow:hidden; }
.sort-btn { background:none; border:none; color:var(--text-muted); padding:.4rem .85rem; cursor:pointer; font-family:'Nunito',sans-serif; font-weight:700; font-size:.78rem; transition:all .15s; }
.sort-btn:hover { color:var(--text); }
.sort-btn.active { background:var(--red); color:white; }

/* ─────────────────────────────────────────────────────
   10. BLOG
   ───────────────────────────────────────────────────── */
.blog-post-card { background:var(--card); border:1px solid var(--border); border-radius:10px; overflow:hidden; margin-bottom:1.5rem; transition:box-shadow .15s; }
.blog-post-card:hover { box-shadow:0 4px 20px rgba(232,25,44,.15); }
.blog-post-img { width:100%; max-height:300px; object-fit:cover; display:block; }
.blog-post-body { padding:1.25rem 1.5rem; }
.blog-post-meta { display:flex; align-items:center; gap:.75rem; flex-wrap:wrap; margin-bottom:.6rem; }
.blog-post-tag { background:var(--red); color:white; font-size:.65rem; font-weight:900; padding:2px 8px; border-radius:3px; letter-spacing:1px; text-transform:uppercase; }
.blog-post-tag.scheduled-tag { background:var(--yellow); color:#111; }
.blog-post-tag.chapter-tag { background:#1a4a2e; color:#4ade80; }
.blog-post-date { font-size:.75rem; color:var(--text-dim); font-weight:600; }
.blog-post-title { font-family:'Bangers',cursive; font-size:1.6rem; color:var(--text); letter-spacing:1px; margin-bottom:.5rem; line-height:1.2; }
.blog-post-desc { font-size:.9rem; color:var(--text-muted); line-height:1.65; margin-bottom:.75rem; }
.blog-post-desc a { color:var(--red); text-decoration:none; font-weight:700; }
.blog-post-desc a:hover { text-decoration:underline; }
.blog-post-desc img { max-width:100%; border-radius:6px; margin:.5rem 0; display:block; }
.blog-post-read-more { background:none; border:none; color:var(--red); font-weight:700; font-size:.82rem; cursor:pointer; font-family:'Nunito',sans-serif; padding:0; }
.blog-post-read-more:hover { text-decoration:underline; }
.blog-editor-area { background:var(--bg); border:2px solid var(--border); border-radius:6px; padding:.75rem; min-height:120px; width:100%; color:var(--text); font-family:'Nunito',sans-serif; font-size:.9rem; line-height:1.6; outline:none; resize:vertical; transition:border-color .15s; }
.blog-editor-area:focus { border-color:var(--red); }
.blog-toolbar { display:flex; gap:.4rem; flex-wrap:wrap; margin-bottom:.4rem; }
.blog-tool { background:var(--bg3); border:1px solid var(--border); color:var(--text); padding:.25rem .55rem; border-radius:4px; font-size:.75rem; font-weight:700; cursor:pointer; font-family:'Nunito',sans-serif; transition:all .15s; }
.blog-tool:hover { background:var(--red); color:white; border-color:var(--red); }

/* ─────────────────────────────────────────────────────
   11. ABOUT — author + social
   ───────────────────────────────────────────────────── */
.about-author-row { display:flex; gap:1.5rem; align-items:flex-start; margin:.75rem 0 1.25rem; flex-wrap:wrap; }
.about-author-img-wrap { flex-shrink:0; }
.about-author-img-placeholder {
  width:120px; height:120px; border-radius:12px;
  background:var(--bg2); border:2px dashed var(--border);
  display:flex; flex-direction:column; align-items:center; justify-content:center;
}
.about-author-img { width:120px; height:120px; border-radius:12px; object-fit:cover; border:2px solid var(--border); display:block; }
.about-author-bio { flex:1; min-width:180px; }
.about-join-section { margin-top:2.5rem; padding-top:2rem; border-top:2px solid var(--border); text-align:center; }
.about-join-title { font-family:'Bangers',cursive; font-size:1.8rem; letter-spacing:2px; color:var(--red); margin-bottom:.3rem; }
.about-join-sub { color:var(--text-dim); font-size:.9rem; margin-bottom:1.5rem; }
.about-social-grid { display:flex; flex-wrap:wrap; gap:.75rem; justify-content:center; }
.about-social-card {
  display:flex; flex-direction:column; align-items:center; justify-content:center; gap:.3rem;
  width:130px; padding:1rem .75rem;
  background:var(--card); border:1.5px solid var(--border); border-radius:12px;
  text-decoration:none; color:var(--text); transition:all .18s;
}
.about-social-card:hover { border-color:var(--red); transform:translateY(-3px); box-shadow:0 6px 20px rgba(232,25,44,.15); }
.about-social-icon { font-size:1.6rem; line-height:1; }
.about-social-name { font-weight:900; font-size:.8rem; }
.about-social-handle { font-size:.7rem; color:var(--text-dim); }
.about-social-discord:hover { border-color:#5865f2; box-shadow:0 6px 20px rgba(88,101,242,.2); }
.about-social-patreon:hover { border-color:#ff424d; box-shadow:0 6px 20px rgba(255,66,77,.2); }

/* ─────────────────────────────────────────────────────
   12. READER
   ───────────────────────────────────────────────────── */
#page-reader { display:none; flex-direction:column; }
#page-reader.active { display:flex; min-height:100vh; }
.reader-header { background:var(--nav-bg); border-bottom:3px solid var(--red); padding:.85rem 1.5rem; display:flex; align-items:center; gap:1rem; flex-wrap:wrap; }
.reader-chapter-title { font-family:'Bangers',cursive; font-size:1.4rem; letter-spacing:1px; flex:1; color:var(--text); }
.view-toggle { display:flex; border:2px solid var(--border); border-radius:6px; overflow:hidden; }
.view-toggle button { background:none; border:none; color:var(--text-muted); padding:.4rem .85rem; cursor:pointer; font-family:'Nunito',sans-serif; font-weight:700; font-size:.78rem; transition:all .15s; }
.view-toggle button.active { background:var(--red); color:white; }
.reader-body { flex:1; overflow-y:auto; overflow-x:hidden; background:var(--bg); }
.chapter-nav { display:flex; justify-content:center; align-items:center; gap:.75rem; padding:1.2rem 1rem; flex-wrap:wrap; }
.chapter-nav button { background:var(--card); border:1px solid var(--border); color:var(--text); padding:.28rem .65rem; cursor:pointer; border-radius:4px; font-family:'Nunito',sans-serif; font-weight:600; font-size:.72rem; transition:all .15s; }
.chapter-nav button:hover:not(:disabled) { border-color:var(--red); color:var(--red); }
.chapter-nav button:disabled { opacity:.3; cursor:not-allowed; }
.chapter-select { background:var(--card); border:2px solid var(--border); color:var(--text); padding:.4rem .75rem; border-radius:4px; font-family:'Nunito',sans-serif; font-weight:700; font-size:.82rem; cursor:pointer; outline:none; }
.chapter-select:focus { border-color:var(--red); }
.page-jump-select { background:var(--card); border:2px solid var(--border); color:var(--text); padding:.4rem .75rem; border-radius:4px; font-family:'Nunito',sans-serif; font-weight:700; font-size:.82rem; cursor:pointer; outline:none; }
.page-jump-select:focus { border-color:var(--red); }

/* Reader — vertical scroll */
.reader-scroll { width:100%; max-width:800px; margin:0 auto; display:block; font-size:0; line-height:0; }
.reader-scroll img { width:100%; height:auto; display:block; margin:0; padding:0; border:none; vertical-align:top; cursor:pointer; }
.scroll-click-hint { text-align:center; padding:.5rem; font-size:.7rem; color:var(--text-dim); font-weight:700; letter-spacing:1px; font-family:'Nunito',sans-serif; }

/* Reader — horizontal scroll */
.reader-horiz-wrap { width:100%; background:var(--bg); }
.horiz-hint { text-align:center; padding:.5rem; font-size:.72rem; color:var(--text-dim); font-weight:700; letter-spacing:1px; }
.reader-horizontal { display:flex; align-items:flex-start; overflow-x:auto; overflow-y:hidden; cursor:grab; user-select:none; width:100%; height:calc(100vh - 130px); gap:0; font-size:0; line-height:0; scrollbar-width:thin; scrollbar-color:var(--red) var(--bg3); }
.reader-horizontal:active { cursor:grabbing; }
.reader-horizontal img { height:100%; width:auto; flex-shrink:0; display:block; margin:0; padding:0; border:none; vertical-align:top; }
.reader-horizontal::-webkit-scrollbar { height:6px; }
.reader-horizontal::-webkit-scrollbar-track { background:var(--bg3); }
.reader-horizontal::-webkit-scrollbar-thumb { background:var(--red); border-radius:3px; }

/* Reader — page-by-page */
.reader-paged { width:100%; display:flex; flex-direction:column; align-items:center; }
.paged-img-wrap { width:100%; max-width:800px; margin:0 auto; cursor:pointer; display:block; line-height:0; font-size:0; }
.paged-img-wrap img { width:100%; height:auto; display:block; margin:0; padding:0; border:none; vertical-align:top; }
.paged-controls { display:flex; align-items:center; justify-content:center; gap:1.25rem; padding:1rem; background:var(--bg2); border-top:2px solid var(--border); width:100%; }
.paged-controls button { background:var(--card); border:2px solid var(--red); color:var(--text); padding:.35rem 1rem; cursor:pointer; border-radius:4px; font-family:'Bangers',cursive; font-size:.85rem; letter-spacing:1px; transition:all .15s; }
.paged-controls button:hover:not(:disabled) { background:var(--red); color:white; }
.paged-controls button:disabled { opacity:.3; cursor:not-allowed; border-color:var(--border); }
.page-counter { font-family:'Bangers',cursive; font-size:1rem; color:var(--text-muted); min-width:70px; text-align:center; }

/* Reader — sections / flat */
.flat-reader { width:100%; }
.flat-unit { display:none; }
.flat-unit.active { display:block; }
.flat-nav { display:flex; align-items:center; justify-content:center; gap:1rem; padding:1rem; background:var(--bg2); border-top:2px solid var(--border); flex-wrap:wrap; }
.flat-nav button { background:var(--card); border:2px solid var(--border); color:var(--text); padding:.35rem 1rem; cursor:pointer; border-radius:4px; font-family:'Bangers',cursive; font-size:.85rem; letter-spacing:1px; transition:all .15s; }
.flat-nav button:hover:not(:disabled) { background:var(--red); border-color:var(--red); color:white; }
.flat-nav button:disabled { opacity:.3; cursor:not-allowed; }
.flat-nav .flat-counter { font-family:'Bangers',cursive; font-size:1rem; color:var(--text-muted); min-width:70px; text-align:center; }

/* ─────────────────────────────────────────────────────
   13. SHARE
   ───────────────────────────────────────────────────── */
.share-btn {
  background:none; border:1.5px solid var(--border); color:var(--text-dim);
  padding:.3rem .75rem; border-radius:6px; font-size:.78rem; font-weight:700;
  cursor:pointer; font-family:'Nunito',sans-serif; transition:all .15s;
  display:inline-flex; align-items:center; gap:.35rem;
}
.share-btn:hover { border-color:var(--red); color:var(--red); }
.share-dropdown {
  position:absolute; background:var(--card); border:1px solid var(--border);
  border-radius:10px; box-shadow:0 8px 24px rgba(0,0,0,.3);
  z-index:9999; min-width:200px; overflow:hidden; animation:shareIn .12s ease;
}
@keyframes shareIn { from{opacity:0;transform:translateY(-6px)} to{opacity:1;transform:translateY(0)} }
.share-dropdown-item {
  display:flex; align-items:center; gap:.65rem;
  padding:.65rem 1rem; cursor:pointer; font-size:.85rem; font-weight:700;
  color:var(--text-muted); transition:background .12s;
  border:none; background:none; width:100%; text-align:left; font-family:'Nunito',sans-serif;
}
.share-dropdown-item:hover { background:var(--bg2); color:var(--text); }
.share-dropdown-item .share-icon { font-size:1rem; flex-shrink:0; }
.share-overlay { position:fixed; inset:0; z-index:9998; }

/* ─────────────────────────────────────────────────────
   14. BOOKMARK
   ───────────────────────────────────────────────────── */
.bookmark-btn {
  background:none; border:1.5px solid var(--border); color:var(--text-dim);
  padding:.3rem .75rem; border-radius:6px; font-size:.78rem; font-weight:700;
  cursor:pointer; font-family:'Nunito',sans-serif; transition:all .15s;
  display:inline-flex; align-items:center; gap:.35rem;
}
.bookmark-btn:hover { border-color:var(--yellow); color:var(--yellow); }
.bookmark-btn.bookmarked { border-color:var(--yellow); background:rgba(255,214,0,.1); color:var(--yellow); }

/* ─────────────────────────────────────────────────────
   15. ADMIN — layout
   ───────────────────────────────────────────────────── */
.admin-wrap { max-width:860px; margin:0 auto; padding:2.5rem 1.5rem; }
.admin-title { font-family:'Bangers',cursive; font-size:2rem; color:var(--yellow); letter-spacing:2px; margin-bottom:.25rem; }
.admin-sub { color:var(--text-muted); font-size:.85rem; margin-bottom:1.5rem; }
.admin-tabs { display:flex; border-bottom:2px solid var(--border); margin-bottom:1.5rem; flex-wrap:wrap; }
.admin-tab { background:none; border:none; border-bottom:3px solid transparent; color:var(--text-muted); font-family:'Bangers',cursive; font-size:1rem; letter-spacing:1px; padding:.6rem 1.2rem; cursor:pointer; margin-bottom:-2px; transition:all .15s; white-space:nowrap; }
.admin-tab:hover { color:var(--text); }
.admin-tab.active { color:var(--red); border-bottom-color:var(--red); }
.admin-section { display:none; }
.admin-section.active { display:block; }
.admin-card { background:var(--card); border-radius:10px; padding:1.8rem; margin-bottom:1.5rem; border:1px solid var(--border); }
.admin-card h3 { font-family:'Bangers',cursive; font-size:1.3rem; color:var(--red); letter-spacing:1px; margin-bottom:1.2rem; }
.admin-chapter-item { background:var(--bg); border:1px solid var(--border); border-radius:6px; padding:.75rem 1rem; display:flex; align-items:center; justify-content:space-between; gap:.5rem; flex-wrap:wrap; margin-bottom:.5rem; }
.admin-chapter-item .ch-info { font-size:.9rem; font-weight:700; flex:1; min-width:0; }
.admin-chapter-item .ch-meta { font-size:.75rem; color:var(--text-muted); margin-top:.1rem; }

/* ─────────────────────────────────────────────────────
   16. ADMIN — forms
   ───────────────────────────────────────────────────── */
.form-group { margin-bottom:1rem; }
.form-group label { display:block; font-size:.8rem; font-weight:700; letter-spacing:1px; text-transform:uppercase; color:var(--text-muted); margin-bottom:.4rem; }
.form-group input { width:100%; background:var(--bg2); border:2px solid var(--border); color:var(--text); padding:.65rem .9rem; border-radius:6px; font-family:'Nunito',sans-serif; font-size:.9rem; outline:none; transition:border-color .15s; }
.form-group input:focus,
.form-group textarea:focus { border-color:var(--red); outline:none; }
.form-group textarea { resize:vertical; min-height:70px; }
.mode-toggle-group { display:flex; gap:.5rem; flex-wrap:wrap; }
.mode-option { flex:1; min-width:90px; border:2px solid var(--border); border-radius:6px; padding:.65rem .4rem; cursor:pointer; text-align:center; background:var(--bg); transition:all .15s; }
.mode-option:hover { border-color:var(--red); }
.mode-option.selected { border-color:var(--red); background:rgba(232,25,44,.1); }
.mode-option .mode-icon { font-size:1.2rem; margin-bottom:.25rem; }
.mode-option .mode-label { font-size:.7rem; font-weight:700; letter-spacing:.5px; text-transform:uppercase; color:var(--text-muted); }
.mode-option.selected .mode-label { color:var(--red); }
.dir-option { border:2px solid var(--border); border-radius:6px; padding:.5rem .75rem; cursor:pointer; text-align:center; background:var(--bg); font-size:.8rem; font-weight:700; color:var(--text-muted); transition:all .15s; }
.dir-option:hover { border-color:var(--red); }
.dir-option.selected { border-color:var(--red); background:rgba(232,25,44,.1); color:var(--red); }
.file-drop { border:2px dashed var(--border); border-radius:8px; padding:1.5rem; text-align:center; cursor:pointer; position:relative; transition:all .15s; }
.file-drop:hover { border-color:var(--red); background:rgba(232,25,44,.04); }
.file-drop input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.file-drop .drop-icon { font-size:1.8rem; margin-bottom:.4rem; }
.file-drop .drop-text { font-size:.85rem; color:var(--text-muted); font-weight:600; }
.file-drop .drop-hint { font-size:.75rem; color:var(--text-dim); margin-top:.3rem; }
.blog-thumb-preview { max-width:100%; max-height:120px; border-radius:6px; margin-top:.5rem; display:none; border:1px solid var(--border); }
.pages-thumb-grid { display:grid; grid-template-columns:repeat(auto-fill,minmax(80px,1fr)); gap:.55rem; margin-top:.6rem; }
.thumb-item { position:relative; border-radius:6px; overflow:hidden; border:2px solid transparent; cursor:grab; user-select:none; transition:border-color .15s; }
.thumb-item:hover { border-color:rgba(255,255,255,.3); }
.thumb-item.selected { border-color:var(--yellow); box-shadow:0 0 0 1px var(--yellow); }
.thumb-item.dragging { opacity:.3; }
.thumb-item img { width:100%; aspect-ratio:3/4; object-fit:cover; display:block; pointer-events:none; }
.thumb-num { position:absolute; bottom:0; left:0; right:0; background:rgba(0,0,0,.75); font-size:.65rem; font-weight:700; text-align:center; padding:2px 0; color:rgba(255,255,255,.8); pointer-events:none; }
.thumb-check { position:absolute; top:4px; right:4px; width:18px; height:18px; background:var(--yellow); border-radius:50%; display:none; align-items:center; justify-content:center; font-size:.65rem; color:#111; font-weight:900; }
.thumb-item.selected .thumb-check { display:flex; }
.pages-toolbar { display:flex; gap:.4rem; flex-wrap:wrap; align-items:center; margin-bottom:.45rem; }
.pages-toolbar span { font-size:.78rem; color:var(--text-muted); font-weight:700; }
.tool-btn { background:var(--bg3); border:none; color:var(--text); padding:.3rem .6rem; border-radius:4px; font-size:.72rem; font-weight:700; cursor:pointer; font-family:'Nunito',sans-serif; transition:background .15s; }
.tool-btn:hover { background:var(--border); }
.tool-btn.danger { background:rgba(232,25,44,.15); color:var(--red); border:1px solid var(--red); }
.tool-btn.danger:hover { background:var(--red); color:white; }

/* ─────────────────────────────────────────────────────
   17. ADMIN — sections manager
   ───────────────────────────────────────────────────── */
.sections-list { display:flex; flex-direction:column; gap:1rem; margin-top:.75rem; }
.section-item { background:var(--bg); border:2px solid var(--border); border-radius:10px; overflow:hidden; }
.section-item-header { display:flex; align-items:center; gap:.75rem; padding:.85rem 1rem; background:var(--bg2); flex-wrap:wrap; border-bottom:1px solid var(--border); }
.section-item-num { font-family:'Bangers',cursive; font-size:1.15rem; color:var(--yellow); letter-spacing:1px; flex-shrink:0; }
.sec-mode-group { display:flex; gap:.35rem; flex-wrap:wrap; flex:1; }
.sec-mode-btn { background:var(--bg3); border:1px solid transparent; color:var(--text-muted); padding:.28rem .6rem; border-radius:4px; font-size:.72rem; font-weight:700; cursor:pointer; font-family:'Nunito',sans-serif; transition:all .15s; }
.sec-mode-btn.active { background:rgba(232,25,44,.2); border-color:var(--red); color:var(--red); }
.sec-mode-btn:hover { border-color:var(--red); }
.btn-del-section { background:none; border:1px solid rgba(232,25,44,.4); color:rgba(232,25,44,.6); padding:.28rem .6rem; border-radius:4px; cursor:pointer; font-size:.75rem; font-family:'Nunito',sans-serif; font-weight:700; flex-shrink:0; transition:all .15s; }
.btn-del-section:hover { background:var(--red); color:white; border-color:var(--red); }
.section-item-body { padding:.85rem; }
.sec-file-drop { border:2px dashed var(--border); border-radius:6px; padding:1rem; text-align:center; cursor:pointer; position:relative; margin-bottom:.55rem; transition:all .15s; }
.sec-file-drop:hover { border-color:var(--red); background:rgba(232,25,44,.04); }
.sec-file-drop input[type="file"] { position:absolute; inset:0; opacity:0; cursor:pointer; width:100%; height:100%; }
.sec-file-drop .sfd-text { font-size:.8rem; color:var(--text-muted); font-weight:600; }
.sec-pages-count { font-size:.74rem; color:var(--text-dim); margin-bottom:.45rem; }
.btn-add-section { background:rgba(255,214,0,.07); border:1px solid var(--yellow); color:var(--yellow); padding:.55rem 1.2rem; border-radius:6px; cursor:pointer; font-family:'Bangers',cursive; font-size:1rem; letter-spacing:1px; width:100%; margin-top:.5rem; transition:all .15s; }
.btn-add-section:hover { background:rgba(255,214,0,.15); }

/* ─────────────────────────────────────────────────────
   18. LOGIN
   ───────────────────────────────────────────────────── */
.login-wrap { min-height:calc(100vh - 56px); display:flex; align-items:center; justify-content:center; padding:2rem; }
.login-box { background:var(--card); border:2px solid var(--border); border-radius:12px; padding:2.5rem; width:100%; max-width:380px; text-align:center; }
.login-box h2 { font-family:'Bangers',cursive; font-size:1.8rem; color:var(--yellow); letter-spacing:2px; margin-bottom:.25rem; }
.login-box p { font-size:.85rem; color:var(--text-muted); margin-bottom:1.5rem; }
.login-error { color:var(--red); font-size:.8rem; font-weight:700; margin-top:.75rem; min-height:1.2em; }

/* ─────────────────────────────────────────────────────
   19. TOAST
   ───────────────────────────────────────────────────── */
.toast { position:fixed; bottom:2rem; left:50%; transform:translateX(-50%) translateY(100px); background:var(--yellow); color:#111; padding:.75rem 1.5rem; border-radius:6px; font-weight:900; font-size:.9rem; letter-spacing:1px; transition:transform .3s; z-index:9999; white-space:nowrap; }
.toast.show { transform:translateX(-50%) translateY(0); }

/* ─────────────────────────────────────────────────────
   20. RESPONSIVE
   ───────────────────────────────────────────────────── */
@media(max-width:900px) {
  .hero-title { font-size:3.5rem; }
  .chapter-grid { grid-template-columns:repeat(2,1fr); }
  nav { padding:0 .75rem; }
  .nav-links { display:none; }
  .hamburger { display:flex; }
  .desktop-only { display:none !important; }
}
@media(max-width:600px) {
  .featured-chapter { flex-direction:column; }
  .featured-cover-wrap,
  .featured-cover-wrap img,
  .featured-cover-placeholder { width:100%; aspect-ratio:16/9; }
  .featured-cover-placeholder .fc-num { font-size:3rem; }
  .featured-info { padding:1.25rem; }
}
