:root {
  --bg:#0c0b10;
  --bg2:#13111a;
  --card:#1a1726;
  --border:rgba(255,255,255,.08);
  --gold:#c9a84c;
  --gold2:#e8c97a;
  --wine:#8b2252;
  --wine2:#b03068;
  --text:#f0eae0;
  --muted:#a89880;
  --dim:#6a5e52;
  --r:16px
}

* {
  box-sizing:border-box
}

body {
  margin:0;
  background:radial-gradient(circle at top right,rgba(139,34,82,.22),transparent 34%),var(--bg);
  color:var(--text);
  font-family:Sarabun,system-ui,sans-serif
}

a {
  color:inherit;
  text-decoration:none
}

main {
  max-width:1280px;
  margin:auto;
  padding:0 28px
}

.topnav {
  position:sticky;
  top:0;
  z-index:10;
  height:68px;
  background:rgba(12,11,16,.92);
  backdrop-filter:blur(18px);
  border-bottom:1px solid var(--border);
  display:flex;
  align-items:center;
  gap:22px;
  padding:0 36px
}

.logo {
  font-family:Cinzel,serif;
  font-weight:700;
  color:var(--gold);
  font-size:22px;
  white-space:nowrap
}

.logo span {
  color:var(--wine2)
}

.nav-links {
  display:flex;
  gap:14px;
  flex:1
}

.nav-links a {
  color:var(--muted);
  font-size:14px
}

.nav-links a:hover {
  color:var(--gold2)
}

.search {
  height:38px;
  width:380px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.05);
  border-radius:99px;
  display:flex;
  align-items:center;
  gap:8px;
  padding:0 14px
}

.search input {
  background:0;
  border:0;
  outline:0;
  color:var(--text);
  width:100%
}

.actions {
  display:flex;
  align-items:center;
  gap:8px
}

.btn {
  border-radius:99px;
  padding:10px 18px;
  display:inline-flex;
  align-items:center;
  gap:8px;
  border:0;
  cursor:pointer;
  font-family:inherit;
  font-weight:600
}

.solid,.primary {
  background:linear-gradient(135deg,var(--wine),var(--wine2));
  color:white
}

.ghost,.outline {
  border:1px solid rgba(201,168,76,.3);
  color:var(--gold);
  background:transparent
}

.light {
  background:var(--gold);
  color:#1a1200
}

.icon {
  font-size:22px;
  color:var(--gold)
}

.menu-btn {
  display:none;
  background:0;
  border:0;
  color:var(--gold);
  font-size:26px
}

.catbar {
  display:flex;
  flex-wrap:wrap;
  align-items:center;
  gap:8px 20px;
  overflow:visible;
  background:var(--bg2);
  border-bottom:1px solid var(--border);
  padding:10px 36px 12px
}

.catbar a {
  white-space:nowrap;
  display:inline-flex;
  align-items:center;
  padding:6px 0;
  color:var(--muted);
  font-size:14px;
  line-height:1.25
}

.catbar a:hover {
  color:var(--gold2)
}

.catbar span {
  display:inline-block;
  flex:0 0 auto;
  width:7px;
  height:7px;
  background:var(--gold);
  border-radius:50%;
  margin-right:8px
}

.hero {
  min-height:470px;
  display:grid;
  grid-template-columns:1fr 360px;
  gap:34px;
  align-items:center;
  padding:60px 0
}

.tag {
  display:inline-block;
  color:#f0b4d0;
  border:1px solid rgba(176,48,104,.4);
  background:rgba(139,34,82,.22);
  padding:7px 14px;
  border-radius:99px;
  font-size:13px
}

h1,h2,h3 {
  margin:0 0 12px
}

.hero h1 {
  font-family:'Crimson Pro',serif;
  font-size:58px;
  line-height:1.05
}

.hero h1 em {
  color:var(--gold2)
}

.hero p,.desc {
  color:var(--muted);
  line-height:1.8
}

.hero-btns {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
  margin-top:22px
}

.hero-card,.side-card,.auth,.reader,.detail,.promo {
  background:rgba(26,23,38,.88);
  border:1px solid var(--border);
  border-radius:var(--r);
  padding:24px;
  box-shadow:0 18px 50px rgba(0,0,0,.3)
}

.cover-emoji {
  height:180px;
  border-radius:12px;
  background:linear-gradient(135deg,#2d1040,#b03068);
  display:grid;
  place-items:center;
  font-size:70px;
  margin-bottom:16px
}

.section-head {
  display:flex;
  justify-content:space-between;
  align-items:center;
  border-bottom:1px solid var(--border);
  padding-bottom:14px;
  margin:34px 0 20px
}

.section-head h2 {
  font-family:'Crimson Pro',serif;
  font-size:30px
}

.section-head a {
  color:var(--gold)
}

.chips {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(135px,1fr));
  gap:12px;
  overflow:visible;
  padding-bottom:8px
}

.chips.big {
  grid-template-columns:repeat(auto-fill,minmax(160px,1fr))
}

.chip {
  min-width:0;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:16px;
  text-align:center
}

.chip span {
  display:block;
  color:var(--gold);
  font-size:24px
}

.chip small,.novel-card span,.novel-card small,.list-item small {
  color:var(--dim)
}

.promo {
  margin:30px 0;
  background:linear-gradient(135deg,var(--wine),#6b1565,#2d8b7a);
  display:flex;
  justify-content:space-between;
  align-items:center
}

.novel-grid {
  display:grid;
  grid-template-columns:repeat(auto-fill,minmax(155px,1fr));
  gap:22px
}

/* หน้า category แสดง 6 คอลัมน์เต็มความกว้าง */
.category-page .novel-grid {
  grid-template-columns:repeat(6,1fr);
}
@media(max-width:900px) {
  .category-page .novel-grid {
    grid-template-columns:repeat(3,1fr);
  }
}
@media(max-width:600px) {
  .category-page .novel-grid {
    grid-template-columns:repeat(2,1fr);
    gap:12px;
  }
}

.novel-card {
  transition:.2s
}

.novel-card:hover {
  transform:translateY(-5px)
}

.novel-card img {
  width:100%;
  aspect-ratio:2/3;
  object-fit:cover;
  border-radius:13px;
  box-shadow:0 10px 25px rgba(0,0,0,.35);
  background:#20172c
}

.novel-card b {
  display:block;
  margin-top:10px;
  line-height:1.4
}

.novel-card span,.novel-card small {
  display:block;
  font-size:13px;
  margin-top:4px
}

.two-col {
  display:grid;
  grid-template-columns:1fr 330px;
  gap:28px;
  align-items:stretch
}

.two-col > aside {
  padding-top:68px;
}

.list {
  display:grid;
  gap:12px;
  align-content:start
}

.list-item {
  display:flex;
  gap:14px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:14px
}

.list-item img {
  width:64px;
  height:86px;
  object-fit:cover;
  border-radius:8px
}

.side-card {
  margin-bottom:18px;
  text-align:center
}

.avatar {
  width:76px;
  height:76px;
  margin:10px auto;
  border-radius:50%;
  background:linear-gradient(135deg,var(--wine),#2d1040);
  display:grid;
  place-items:center;
  color:var(--gold);
  font:700 30px Cinzel
}

.tags {
  display:flex;
  gap:8px;
  flex-wrap:wrap;
  justify-content:center
}

.tags a {
  border:1px solid var(--border);
  padding:6px 12px;
  border-radius:99px;
  color:var(--muted)
}

/* ===== Footer ===== */
.site-footer {
  margin-top:60px;
  border-top:1px solid var(--border);
  background:var(--bg2);
  color:var(--muted)
}

.footer-inner {
  display:grid;
  grid-template-columns:2fr 1fr 1fr 1fr;
  gap:40px;
  padding:50px 36px 36px
}

.footer-logo {
  font-family:Cinzel,serif;
  font-weight:700;
  font-size:22px;
  color:var(--gold);
  display:inline-block;
  margin-bottom:10px
}

.footer-logo span {
  color:var(--wine2)
}

.footer-tagline {
  font-size:14px;
  line-height:1.6;
  color:var(--muted);
  margin:0 0 18px
}

.footer-social {
  display:flex;
  gap:10px
}

.social-btn {
  width:36px;
  height:36px;
  border-radius:50%;
  border:1px solid rgba(255,255,255,.12);
  display:inline-flex;
  align-items:center;
  justify-content:center;
  color:var(--muted);
  font-size:18px;
  transition:all .2s
}

.social-btn:hover {
  border-color:var(--gold);
  color:var(--gold);
  background:rgba(201,168,76,.08)
}

.footer-col-title {
  font-size:13px;
  font-weight:700;
  text-transform:uppercase;
  letter-spacing:.08em;
  color:var(--gold2);
  margin:0 0 14px;
  padding-bottom:8px;
  border-bottom:1px solid rgba(255,255,255,.07)
}

.footer-col a {
  display:flex;
  align-items:center;
  gap:7px;
  color:var(--muted);
  font-size:14px;
  padding:5px 0;
  transition:color .15s
}

.footer-col a:hover {
  color:var(--gold2)
}

.footer-col a i {
  font-size:15px;
  flex-shrink:0;
  opacity:.6
}

.footer-bottom {
  display:flex;
  align-items:center;
  justify-content:space-between;
  flex-wrap:wrap;
  gap:10px;
  padding:16px 36px;
  border-top:1px solid rgba(255,255,255,.06);
  font-size:13px;
  color:var(--muted)
}

.footer-bottom-links {
  display:flex;
  gap:20px
}

.footer-bottom-links a {
  color:var(--muted);
  font-size:13px
}

.footer-bottom-links a:hover {
  color:var(--gold2)
}

/* footer mobile */
@media(max-width:900px) {
  .footer-inner {
    grid-template-columns:1fr 1fr;
    gap:28px;
    padding:32px 20px 24px
  }

  .footer-brand {
    grid-column:1 / -1
  }

  .footer-bottom {
    padding:14px 20px;
    flex-direction:column;
    align-items:flex-start;
    gap:8px
  }
}

@media(max-width:480px) {
  .footer-inner {
    grid-template-columns:1fr
  }
}

.detail {
  margin-top:36px;
  display:grid;
  grid-template-columns:250px 1fr;
  gap:28px
}

.detail-cover {
  width:100%;
  border-radius:15px;
  aspect-ratio:2/3;
  object-fit:cover
}

.chapter-list {
  display:grid;
  gap:10px
}

.chapter-list a {
  display:flex;
  justify-content:space-between;
  gap:10px;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:15px
}

.chapter-list small {
  color:var(--dim)
}

.reader {
  max-width:1280px;
  margin:36px auto
}

.reader ~ section {
  max-width:1280px;
  margin-left:auto;
  margin-right:auto;
}

.reader-content {
  font-size:19px;
  line-height:2.15;
  color:#f7efe4;
  white-space:pre-wrap
}

.reader-content.largefont {
  font-size:23px
}

.reader-tools {
  display:flex;
  gap:10px;
  margin:16px 0
}

.reader-tools button {
  background:var(--bg2);
  border:1px solid var(--border);
  color:var(--gold);
  border-radius:99px;
  padding:8px 13px
}

.pager {
  display:flex;
  justify-content:space-between;
  gap:10px;
  margin-top:28px
}

.lightmode {
  background:#f7efe4;
  color:#24180f
}

.lightmode .reader {
  background:#fff;
  color:#211
}

.lightmode .reader-content {
  color:#211
}

.auth {
  max-width:430px;
  margin:50px auto
}

.auth form,.comment-form {
  display:grid;
  gap:12px
}

input,textarea,select {
  width:100%;
  background:rgba(255,255,255,.06);
  border:1px solid var(--border);
  border-radius:12px;
  color:var(--text);
  padding:13px;
  font-family:inherit
}

textarea {
  min-height:140px
}

.alert {
  background:rgba(176,48,104,.22);
  border:1px solid rgba(176,48,104,.4);
  padding:12px;
  border-radius:12px;
  margin:10px 0
}

.comments {
  display:grid;
  gap:12px;
  margin-top:16px
}

.comments>div {
  background:var(--card);
  border:1px solid var(--border);
  border-radius:12px;
  padding:14px
}

.empty {
  text-align:center;
  color:var(--muted);
  padding:40px
}

.toast {
  position:fixed;
  bottom:24px;
  left:50%;
  transform:translateX(-50%) translateY(90px);
  background:var(--card);
  border:1px solid var(--border);
  padding:12px 20px;
  border-radius:99px;
  transition:.25s
}

.toast.show {
  transform:translateX(-50%) translateY(0)
}

.admin-table {
  width:100%;
  border-collapse:collapse;
  background:var(--card);
  border-radius:14px;
  overflow:hidden
}

.admin-table th,.admin-table td {
  padding:12px;
  border-bottom:1px solid var(--border);
  text-align:left
}

.admin-actions {
  display:flex;
  gap:8px;
  flex-wrap:wrap
}

.form-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:14px
}

.form-grid .full {
  grid-column:1/-1
}

@media(max-width:900px) {
  main {
    padding:0 16px
  }

  .topnav {
    padding:0 12px;
    gap:8px;
    display:flex;
    align-items:center
  }

  /* ── Mobile topnav layout ─────────────────────────────────────
     hamburger | logo | ช่องค้นหา (flex:1) | actions
  ──────────────────────────────────────────────────────────── */

  /* logo ไม่ shrink */
  .topnav .logo {
    flex-shrink:0
  }

  /* hamburger: แสดงบนมือถือ */
  .menu-btn {
    display:block
  }

  .nav-links {
    display:none;
    position:absolute;
    top:68px;
    left:0;
    right:0;
    background:var(--bg2);
    padding:14px;
    flex-direction:column
  }

  .nav-links.open {
    display:flex
  }

  /* ช่องค้นหา: แสดงบนมือถือ เต็มพื้นที่กลาง */
  .search.live-search {
    display:flex !important;
    flex:1 1 0 !important;
    min-width:0 !important;
    width:auto !important;
  }

  /* ซ่อนปุ่ม ghost (เข้าสู่ระบบ/แอดมิน) บนมือถือ */
  .actions .ghost {
    display:none
  }

  /* actions อยู่ขวาสุด ไม่ shrink */
  .actions {
    flex-shrink:0;
    gap:6px
  }

  /* catbar: เลื่อนซ้ายขวาได้ ไม่ขึ้นบรรทัดใหม่ ไม่มี scrollbar */
  .catbar {
    padding:8px 12px;
    gap:0;
    flex-wrap:nowrap;
    overflow-x:auto;
    overflow-y:hidden;
    scrollbar-width:none;
    -ms-overflow-style:none
  }

  .catbar::-webkit-scrollbar {
    display:none;
    width:0;
    height:0
  }

  .catbar a {
    font-size:13px;
    padding:5px 10px;
    white-space:nowrap;
    flex-shrink:0
  }

  .hero {
    grid-template-columns:1fr;
    padding:35px 0
  }

  .hero h1 {
    font-size:42px
  }

  .two-col,.detail {
    grid-template-columns:1fr
  }

  .promo,footer {
    display:block
  }

  .novel-grid,
  .home-novel-grid,
  .category-page .novel-grid {
    grid-template-columns:repeat(2,1fr);
    gap:16px
  }

  .form-grid {
    grid-template-columns:1fr
  }

  .chapter-list a {
    display:block
  }

  .reader {
    padding:18px
  }

  .reader-content {
    font-size:18px
  }

  .topnav .logo {
    font-size:18px
  }

  .actions .solid {
    padding:8px 10px
  }

  
}

/* Admin editor pages */
.admin-edit-page {
  padding:28px 0
}

.edit-layout {
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:22px;
  align-items:start
}

.chapter-edit-layout {
  grid-template-columns:minmax(0,1fr) 300px
}

.card-panel {
  background:rgba(26,23,38,.88);
  border:1px solid var(--border);
  border-radius:16px;
  padding:20px;
  box-shadow:0 16px 42px rgba(0,0,0,.24)
}

.field-label {
  display:block;
  margin:14px 0 8px;
  color:var(--gold2);
  font-weight:700
}

.field-label:first-child {
  margin-top:0
}

.field-label span {
  color:#ff8aad
}

.save-btn {
  width:100%;
  justify-content:center;
  margin-top:18px
}

.cover-preview-box {
  border:1px solid var(--border);
  border-radius:14px;
  overflow:hidden;
  background:#120f18;
  margin-bottom:12px
}

.cover-preview-box img {
  width:100%;
  aspect-ratio:2/3;
  object-fit:cover;
  display:block
}

.help-text {
  color:var(--muted);
  font-size:13px;
  line-height:1.6
}

.ck.ck-editor {
  color:#1f2937
}

.ck.ck-editor__main>.ck-editor__editable {
  min-height:340px
}

.chapter-edit-layout .ck.ck-editor__main>.ck-editor__editable {
  min-height:560px
}

.ck-content p {
  margin:0 0 1em
}

.ck-content h2,.ck-content h3 {
  color:#111827
}

.reader-content p,.desc p {
  margin:0 0 1em
}

.reader-content h2,.reader-content h3 {
  margin-top:1.5em;
  color:var(--gold2)
}

@media(max-width:900px) {
  .edit-layout,.chapter-edit-layout {
    grid-template-columns:1fr
  }

  .edit-side {
    order:-1
  }

  .admin-edit-page {
    padding:18px 0
  }

  .ck.ck-editor__main>.ck-editor__editable,.chapter-edit-layout .ck.ck-editor__main>.ck-editor__editable {
    min-height:360px
  }

  
}

/* Admin category sorting + dark form fix */
.cat-form-grid {
  display:grid;
  grid-template-columns:1fr 1fr 1fr auto;
  gap:14px;
  align-items:start
}

.cat-form-actions {
  align-self:end;
  padding-top:0
}
.cat-form-actions .btn {
  min-height:46px;
  width:100%;
  justify-content:center;
}

.cat-table code {
  color:#e8c97a;
  font-size:13px
}

/* ปุ่มแก้ไข+ลบในตาราง categories ให้ตรงแถวกัน */
.cat-table td:last-child {
  white-space:nowrap;
  vertical-align:middle;
}
.cat-table td:last-child,
.cat-table td:last-child form {
  display:inline-flex;
  align-items:center;
  gap:6px;
}
.cat-table td:last-child form {
  margin:0;
}

.cat-drag-handle {
  cursor:grab;
  color:var(--gold);
  text-align:center;
  font-weight:900;
  letter-spacing:-2px;
  user-select:none
}

.cat-drag-handle:active {
  cursor:grabbing
}

.cat-order-input {
  width:54px!important;
  padding:7px 6px!important;
  text-align:center;
  border-radius:8px!important;
  color:var(--gold)!important;
  background:rgba(201,168,76,.08)!important;
  font-weight:800
}

.cat-parent-row {
  background:rgba(255,255,255,.015)
}

.cat-sub-row {
  background:rgba(176,48,104,.055)
}

.cat-sub-icon {
  color:var(--gold);
  margin-right:8px
}

.cat-ghost {
  opacity:.32!important;
  outline:2px dashed var(--gold);
  background:rgba(201,168,76,.08)!important
}

.cat-chosen {
  box-shadow:0 10px 28px rgba(0,0,0,.32)
}

.cat-toast {
  position:fixed;
  right:24px;
  bottom:24px;
  z-index:9999;
  background:#10b981;
  color:white;
  padding:11px 18px;
  border-radius:14px;
  box-shadow:0 10px 28px rgba(0,0,0,.28);
  font-weight:700;
  opacity:0;
  transform:translateY(14px);
  transition:.25s;
  pointer-events:none
}

.cat-toast.error {
  background:#ef4444
}

.cat-toast.show {
  opacity:1;
  transform:translateY(0)
}

select,input,textarea {
  color-scheme:dark
}

select option {
  background:#241d33!important;
  color:#f5f1ff!important
}

select option[value=""],select option:disabled {
  color:#b8aeca!important;
  background:#241d33!important
}

input::placeholder,textarea::placeholder {
  color:#a89880!important;
  opacity:1
}

input[type="file"]::file-selector-button {
  background:linear-gradient(135deg,var(--wine),var(--wine2));
  color:#fff;
  border:0;
  border-radius:10px;
  padding:8px 12px;
  margin-right:10px;
  font-weight:700;
  cursor:pointer
}

@media(max-width:900px) {
  .cat-form-grid {
    grid-template-columns:1fr
  }

  .cat-form-actions {
    padding-top:0
  }

  .cat-table th:nth-child(5),.cat-table td:nth-child(5) {
    display:none
  }

  
}

@media(max-width:600px) {
  .chips {
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:10px
  }

  .chip {
    padding:14px 10px
  }

  .chip b {
    font-size:14px
  }

  .chip small {
    display:block;
    margin-top:4px
  }

  
}

.reader-desc {
  margin: 18px 0 28px;
  padding: 18px 20px;
  border-radius: 20px;
  background: rgba(255,255,255,.06);
}
.tall-editor + .ck.ck-editor .ck-editor__editable,
#contentEditor + .ck.ck-editor .ck-editor__editable {
  min-height: 480px;
}

/* ===== Admin Dashboard Sidebar + Auto Post AI Writer ===== */
.admin-body {
  min-height:100vh;
  background:#10131c;
  color:#f7f7ff;
  overflow-x:hidden;
}
.admin-body main,
.admin-main {
  max-width:none;
  margin:0;
  padding:0;
}
.admin-sidebar {
  position:fixed;
  inset:0 auto 0 0;
  width:240px;
  background:#171b25;
  border-right:1px solid rgba(255,255,255,.08);
  padding:22px 16px;
  overflow-y:auto;
  z-index:50;
}
.admin-brand {
  display:block;
  font-size:24px;
  font-weight:900;
  margin:4px 14px 34px;
  letter-spacing:-.5px;
}
.admin-brand span { color:#e1b33d; }
.admin-brand { color:#e83d9a; }
.admin-side-label {
  color:#6f86b8;
  font-size:13px;
  margin:18px 28px 10px;
}
.admin-menu { display:grid; gap:8px; }
.admin-menu a {
  display:flex;
  align-items:center;
  gap:12px;
  padding:14px 18px;
  border-radius:8px;
  color:#87a1d6;
  font-weight:700;
}
.admin-menu a:hover,
.admin-menu a.active {
  background:#23304d;
  color:#4f8bff;
}
.admin-menu span { width:18px; text-align:center; color:#8196c8; }
.admin-shell {
  margin-left:240px;
  min-height:100vh;
}
.admin-topbar {
  height:72px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  padding:0 24px;
  background:#0d0f17;
  border-bottom:1px solid rgba(255,255,255,.08);
  position:sticky;
  top:0;
  z-index:30;
}
.admin-topbar b { display:block; font-size:16px; }
.admin-topbar small { display:block; color:#8a97b6; margin-top:3px; }
.admin-main { padding:24px; }
.admin-alert {
  background:linear-gradient(135deg,#79206c,#238b86);
  border:1px solid rgba(255,255,255,.12);
  border-radius:14px;
  padding:14px 18px;
  margin-bottom:18px;
  font-weight:700;
}
.ap-page { max-width:1180px; margin:0 auto; }
.ap-hero {
  display:flex;
  align-items:center;
  gap:20px;
  background:linear-gradient(120deg,#251b58,#027fc5);
  border-radius:14px;
  padding:28px 26px;
  box-shadow:0 18px 40px rgba(0,0,0,.25);
  margin-bottom:24px;
}
.ap-hero h1 { font-size:21px; margin:0 0 6px; }
.ap-hero p { margin:0; color:#b8c3ea; font-weight:700; font-size:13px; }
.ap-check {
  width:18px;
  height:18px;
  border:2px solid #f4f6ff;
  display:grid;
  place-items:center;
  flex:0 0 auto;
}
.ap-check input { width:12px; height:12px; accent-color:#5b8cff; }
.ap-layout {
  display:grid;
  grid-template-columns:minmax(0,1fr) 340px;
  gap:24px;
  align-items:start;
}
.ap-panel,
.ap-side-panel,
.ap-cron-url {
  background:#24283a;
  border:1px solid rgba(255,255,255,.09);
  border-radius:8px;
  box-shadow:0 10px 30px rgba(0,0,0,.25);
}
.ap-panel-head {
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:12px;
  padding:12px 18px;
  border-bottom:1px solid rgba(255,255,255,.08);
  background:rgba(255,255,255,.02);
}
.ap-panel-head h2 { margin:0; font-size:18px; }
.ap-panel-head.compact h2 { font-size:17px; }
.ap-head-actions { display:flex; align-items:center; gap:10px; flex-wrap:wrap; }
.ap-badge {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  min-width:64px;
  height:22px;
  border-radius:8px;
  background:#87909c;
  color:#fff;
  font-size:12px;
  font-weight:800;
}
.ap-card-list { padding:16px; display:grid; gap:14px; }
.ap-preset-card {
  background:#282d44;
  border:1px solid rgba(255,255,255,.08);
  border-radius:14px;
  padding:20px;
}
.ap-preset-top {
  display:flex;
  justify-content:space-between;
  gap:16px;
  align-items:flex-start;
}
.ap-preset-top h3 { margin:0 0 8px; font-size:20px; color:#fff; }
.ap-preset-top p,
.ap-preset-top span { color:#8795c5; font-size:13px; }
.ap-preset-top p { margin:0; display:flex; gap:18px; flex-wrap:wrap; }
.ap-status {
  color:#fff !important;
  border-radius:8px;
  padding:5px 10px;
  font-weight:900;
  white-space:nowrap;
}
.ap-status.on { background:#2db66d; }
.ap-status.off { background:#676f7c; }
.ap-tags { display:flex; gap:8px; flex-wrap:wrap; margin:18px 0; }
.ap-tags span {
  border:1px solid #3a6eea;
  color:#6ea2ff;
  background:rgba(46,103,255,.08);
  border-radius:99px;
  padding:6px 10px;
  font-size:12px;
  font-weight:700;
}
.ap-stats {
  display:grid;
  grid-template-columns:1fr 1fr 1.85fr;
  gap:9px;
  margin-bottom:16px;
}
.ap-stats div {
  background:#1e2331;
  border:1px solid rgba(255,255,255,.06);
  border-radius:9px;
  text-align:center;
  padding:14px 10px;
}
.ap-stats b { display:block; color:#5a8cff; font-size:25px; line-height:1; }
.ap-stats small { display:block; color:#7e8ab2; margin-top:5px; font-weight:700; }
.ap-actions { display:flex; gap:8px; flex-wrap:wrap; align-items:center; }
.ap-actions form { display:inline-flex; }
.btn.muted { background:#2d3348; border:1px solid rgba(255,255,255,.15); color:#97a3c2; }
.btn.warn { background:transparent; border:1px solid #ffd500; color:#ffd500; }
.ap-color { width:30px; height:30px; display:inline-flex; border-radius:3px; border:1px solid currentColor; }
.ap-color.cyan { color:#0fd6ff; }
.ap-color.pink { color:#ff315d; }
.ap-side-panel { overflow:hidden; margin-bottom:18px; }

/* Fix latest novels right panel frame + overflow */
.ap-right { min-width:0; }
.ap-right .ap-side-panel {
  width:100%;
  min-width:0;
  box-sizing:border-box;
  border:1px solid rgba(255,255,255,.10);
}
.ap-right .ap-panel-head {
  border-bottom:1px solid rgba(255,255,255,.08);
}
.ap-latest-list,
.ap-latest-item,
.ap-latest-item > div {
  min-width:0;
}
.ap-mini-actions {
  grid-template-columns:repeat(3,minmax(0,1fr));
}
.ap-mini-actions a,
.ap-mini-actions button {
  min-width:0;
  white-space:normal;
  word-break:break-word;
  line-height:1.15;
  padding:6px 8px;
  font-size:12px;
}
.ap-latest-list { padding:14px 16px; display:grid; gap:12px; }
.ap-latest-item { display:grid; grid-template-columns:56px 1fr; gap:10px; align-items:center; }
.ap-latest-item img { width:56px; height:42px; object-fit:cover; border-radius:4px; background:#1a2030; }
.ap-latest-item b { display:block; font-size:13px; color:#fff; white-space:nowrap; overflow:hidden; text-overflow:ellipsis; }
.ap-latest-item small { display:block; color:#7f8aac; font-size:11px; margin:4px 0; }
.ap-latest-item em { color:#fff; background:#21ad5f; border-radius:5px; padding:2px 6px; font-style:normal; font-size:10px; }
.ap-latest-item em.draft { background:#777; }
.ap-mini-actions { display:grid; grid-template-columns:1fr 1fr 1fr; gap:5px; }
.ap-mini-actions a,
.ap-mini-actions button {
  width:100%;
  text-align:center;
  border:1px solid #0fd6ff;
  color:#0fd6ff;
  background:transparent;
  border-radius:3px;
  padding:5px 2px;
  font-size:11px;
  font-family:inherit;
  cursor:pointer;
}
.ap-mini-actions form { margin:0; }
.cron-box { text-align:center; padding:24px; }
.cron-box h2 { font-size:18px; }
.cron-box .btn { width:100%; justify-content:center; }
.cron-box p { color:#cfc3a3; line-height:1.7; font-size:14px; }
.ap-cron-url { margin-top:24px; padding:18px; display:grid; gap:10px; }
.ap-cron-url input { background:#1b2030; color:#dce5ff; }
.ap-cron-url small { color:#8b96b5; }
.ap-log-panel { margin-top:24px; }
.ap-log-table { overflow:auto; }
.ap-log-table .admin-table { border-radius:0; min-width:720px; background:transparent; }
.preset-modal{display:none;position:fixed;inset:0;z-index:9999;align-items:center;justify-content:center;padding:22px}
.preset-modal.show{display:flex}
.preset-modal-backdrop{position:absolute;inset:0;background:rgba(0,0,0,.72);backdrop-filter:blur(5px)}
.preset-modal-panel{position:relative;width:min(920px,100%);max-height:88vh;overflow:auto;background:#202538;border:1px solid rgba(255,255,255,.12);border-radius:18px;padding:24px;box-shadow:0 24px 80px rgba(0,0,0,.45)}
.preset-modal-head{display:flex;align-items:center;justify-content:space-between;gap:16px;margin-bottom:18px}.preset-modal-head h3{margin:0}.ap-form-grid label{font-weight:800;color:#dfe6ff}.ap-form-grid label input,.ap-form-grid label select,.ap-form-grid label textarea{margin-top:8px}.ap-checkbox{display:flex!important;align-items:center;gap:10px}.ap-checkbox input{width:auto;margin:0!important}
@media(max-width:1050px){
  .admin-sidebar{width:76px;padding:18px 8px}.admin-brand{font-size:0;margin:4px 8px 28px}.admin-brand:before{content:'AP';font-size:20px;color:#e1b33d}.admin-side-label{display:none}.admin-menu a{justify-content:center;padding:14px 8px;font-size:0}.admin-menu span{font-size:17px}.admin-shell{margin-left:76px}.ap-layout{grid-template-columns:1fr}.ap-right{display:grid;grid-template-columns:1fr;gap:16px}.ap-stats{grid-template-columns:1fr}.ap-preset-top{display:block}.ap-status{display:inline-flex;margin-top:12px}
}
@media(max-width:640px){
  .admin-shell{margin-left:0}.admin-sidebar{position:static;width:auto;height:auto;display:block;border-right:0;border-bottom:1px solid rgba(255,255,255,.08)}.admin-menu{grid-template-columns:repeat(3,1fr)}.admin-menu a{font-size:12px;justify-content:center}.admin-menu span{display:none}.admin-main{padding:14px}.ap-hero{padding:20px}.ap-panel-head{align-items:flex-start;flex-direction:column}.ap-actions .btn{width:100%;justify-content:center}.ap-actions form{width:100%}.ap-mini-actions{grid-template-columns:1fr}.preset-modal{padding:10px}.preset-modal-panel{padding:16px;border-radius:14px}
}

/* ===== Auto Post AI page — matched to reference layout ===== */
.admin-body {
  background:#11141d;
}
.admin-sidebar {
  width:240px;
  background:#171b25;
  padding:20px 14px;
}
.admin-brand {
  margin:0 4px 28px;
  padding:0 2px;
  font-size:18px;
  color:#f1f5ff;
}
.admin-brand span {
  color:#8eb3ff;
}
.admin-menu {
  gap:8px;
}
.admin-menu a {
  min-height:48px;
  padding:13px 14px;
  border-radius:8px;
  color:#8799c6;
  font-weight:800;
}
.admin-menu a:hover,
.admin-menu a.active {
  background:#22304d;
  color:#65a0ff;
}
.admin-menu span {
  font-size:18px;
  color:#88a2d9;
}
.admin-shell {
  margin-left:240px;
}
.admin-topbar {
  height:66px;
  background:#151821;
  border-bottom:1px solid rgba(255,255,255,.09);
  padding:0 30px;
}
.admin-page-title b {
  font-size:20px;
  letter-spacing:-.2px;
}
.admin-top-actions {
  display:flex;
  align-items:center;
  gap:10px;
}
.top-create-btn {
  height:38px;
  padding:0 18px;
  border-radius:8px;
  background:#202640!important;
  border:1px solid #303957!important;
  color:#fff!important;
  box-shadow:none!important;
}
.admin-gear-btn {
  width:38px;
  height:38px;
  display:grid;
  place-items:center;
  border-radius:8px;
  background:#d5a600;
  border:1px solid #f2c200;
  color:#111827;
  font-size:20px;
  font-weight:900;
}
.admin-main {
  padding:26px 24px 40px;
}
.ap-page {
  max-width:100%;
}
.ap-hero {
  margin:0 0 24px;
  min-height:86px;
  border-radius:14px;
  background:linear-gradient(110deg,#25184d 0%,#263a7a 58%,#068ccc 100%);
  box-shadow:none;
}
.ap-hero h1 {
  font-size:17px;
  font-weight:900;
}
.ap-hero p {
  color:#aab7dd;
}
.ap-check {
  border-color:#e8edff;
  background:transparent;
}
.ap-layout {
  grid-template-columns:minmax(0,1fr) 340px;
  gap:24px;
}
.ap-panel,
.ap-side-panel,
.ap-cron-url {
  background:#24283a;
  border:1px solid rgba(255,255,255,.1);
  border-radius:5px;
  box-shadow:none;
}
.ap-panel-head {
  min-height:42px;
  background:#24283a;
  padding:10px 18px;
}
.ap-panel-head h2 {
  font-size:18px;
  display:flex;
  align-items:center;
  gap:8px;
}
.ap-badge {
  min-width:auto;
  height:22px;
  padding:0 10px;
  background:#89929d;
  border-radius:7px;
}
.ap-card-list {
  padding:16px;
  gap:14px;
}
.ap-preset-card {
  background:#262b41;
  border-color:rgba(255,255,255,.08);
  border-radius:14px;
  padding:18px 20px;
}
.ap-preset-top h3 {
  font-size:18px;
}
.ap-status.on {
  background:#2faf64;
}
.ap-status.off {
  background:#69717f;
}
.ap-tags {
  margin:14px 0 16px;
}
.ap-tags span {
  padding:5px 10px;
  border-color:#3e72e8;
  color:#75a3ff;
  background:#273050;
}
.ap-stats {
  grid-template-columns:1fr 1fr 1.85fr;
  gap:8px;
}
.ap-stats div {
  background:#1c2130;
  border-radius:9px;
}
.ap-actions .btn {
  min-height:31px;
  padding:7px 12px;
  border-radius:4px;
  font-size:13px;
}
.ap-actions .btn.solid {
  background:#5d86ff;
}
.btn.warn {
  border-color:#ffda00!important;
  color:#ffda00!important;
  background:transparent!important;
}
.ap-icon-btn {
  width:32px;
  height:32px;
  display:inline-grid;
  place-items:center;
  border-radius:4px;
  font-weight:900;
  background:#202638;
}
.ap-icon-btn.cyan {
  color:#05d7ff;
  border:1px solid #05d7ff;
}
.ap-icon-btn.pink {
  color:#ff3b66;
  border:1px solid #ff3b66;
}
.ap-latest-item {
  grid-template-columns:56px minmax(0,1fr);
}
.ap-latest-item img {
  border-radius:4px;
}
.ap-mini-actions a,
.ap-mini-actions button {
  min-height:24px;
}
.preset-modal-panel {
  background:#202538;
  border-radius:16px;
}
@media(max-width:1050px){
  .admin-sidebar{width:78px;padding:18px 8px}.admin-brand{font-size:0;margin:4px 8px 28px}.admin-brand:before{content:'NA';font-size:20px;color:#e1b33d}.admin-menu a{justify-content:center;padding:14px 8px;font-size:0}.admin-menu span{font-size:18px}.admin-shell{margin-left:78px}.ap-layout{grid-template-columns:1fr}.ap-stats{grid-template-columns:1fr 1fr 1fr}
}
@media(max-width:640px){
  .admin-shell{margin-left:0}.admin-sidebar{position:static;width:auto;height:auto}.admin-topbar{padding:0 14px}.admin-top-actions{gap:6px}.top-create-btn{padding:0 10px;font-size:12px}.ap-stats{grid-template-columns:1fr}.ap-actions form,.ap-actions .btn{width:100%;justify-content:center}.ap-icon-btn{flex:1}.admin-main{padding:16px}
}

/* Font Awesome icon alignment */
.btn i,
.admin-gear-btn i,
.ap-icon-btn i,
.ap-panel-head h2 i,
.ap-hero h1 i,
.admin-page-title i,
.ap-mini-actions i {
  display:inline-flex;
  align-items:center;
  justify-content:center;
  line-height:1;
}
.btn i { margin-right:6px; }
.admin-menu span i { width:18px; text-align:center; }
.admin-brand i { margin-right:8px; color:#e1b33d; }
.ap-icon-btn i, .admin-gear-btn i { margin:0; }
.ap-mini-actions a, .ap-mini-actions button { display:inline-flex; align-items:center; justify-content:center; gap:5px; }

/* ===== Admin global spacing fix: add breathing room on every admin page ===== */
.admin-body .admin-shell {
  background:#11141d;
}
.admin-body .admin-topbar {
  padding-left:36px !important;
  padding-right:36px !important;
}
.admin-body .admin-main {
  padding:34px 36px 52px !important;
}
.admin-body .admin-main > section,
.admin-body .admin-main > .ap-page {
  width:100%;
  max-width:1280px;
  margin-left:auto;
  margin-right:auto;
}
.admin-body .admin-main > section {
  background:#202538;
  border:1px solid rgba(255,255,255,.09);
  border-radius:14px;
  padding:24px;
  box-shadow:0 14px 36px rgba(0,0,0,.22);
}
.admin-body .section-head {
  margin:-4px 0 22px;
  padding-bottom:16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.admin-body .admin-table {
  margin-top:12px;
}
.admin-body .form-grid {
  gap:18px;
}
.admin-body input,
.admin-body select,
.admin-body textarea {
  min-height:42px;
}
.admin-body textarea {
  min-height:120px;
}
.admin-body .alert {
  margin-bottom:18px;
}

/* Auto Post page: keep layout full but away from browser edges */
.admin-body .ap-page {
  max-width:1280px;
}
.admin-body .ap-hero {
  margin-bottom:26px;
}
.admin-body .ap-layout {
  gap:28px;
}
.admin-body .ap-panel,
.admin-body .ap-side-panel,
.admin-body .ap-cron-url {
  border-radius:10px;
}
.admin-body .ap-card-list,
.admin-body .ap-latest-list {
  padding:18px;
}
.admin-body .ap-preset-card {
  padding:22px;
}

@media(max-width:1050px){
  .admin-body .admin-topbar{padding-left:24px!important;padding-right:24px!important}
  .admin-body .admin-main{padding:26px 24px 44px!important}
}
@media(max-width:640px){
  .admin-body .admin-topbar{padding-left:16px!important;padding-right:16px!important}
  .admin-body .admin-main{padding:18px 14px 34px!important}
  .admin-body .admin-main > section{padding:18px;border-radius:12px}
}

/* ===== Settings page: tabbed admin UI like reference ===== */
.settings-page .settings-head h2{display:flex;align-items:center;gap:10px;margin:0 0 6px;font-size:22px}.settings-page .settings-head p{margin:0;color:#9aa7c7;font-size:14px}.settings-form{display:block}.settings-tabs{display:flex;align-items:center;gap:6px;overflow:auto;border-bottom:1px solid rgba(255,255,255,.1);margin:0 0 22px;padding:0 0 0}.settings-tab{appearance:none;border:0;background:transparent;color:#9ca8c3;padding:13px 17px;border-bottom:2px solid transparent;cursor:pointer;font-weight:800;font-family:inherit;white-space:nowrap;display:inline-flex;align-items:center;gap:8px}.settings-tab:hover{color:#dfe7ff}.settings-tab.active{color:#6f97ff;border-bottom-color:#6f97ff}.settings-panel{display:none}.settings-panel.active{display:block}.settings-card{background:#24283a;border:1px solid rgba(255,255,255,.1);border-radius:12px;margin:0 0 18px;overflow:hidden}.settings-card-head{padding:14px 18px;border-bottom:1px solid rgba(255,255,255,.08);background:#262b40}.settings-card-head h3{margin:0;display:flex;align-items:center;gap:10px;font-size:18px}.settings-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:20px}.settings-grid label{display:flex;flex-direction:column;gap:8px;color:#dfe6ff;font-weight:800;font-size:14px}.settings-grid label.full{grid-column:1/-1}.settings-grid label.top-line{border-top:1px solid rgba(255,255,255,.09);padding-top:16px}.settings-grid small{color:#9aa7c7;font-weight:500;line-height:1.45}.settings-grid input,.settings-grid select,.settings-grid textarea{width:100%;background:#171c2b;border:1px solid rgba(255,255,255,.11);color:#e8edff;border-radius:10px;padding:12px 13px;outline:none;font-family:inherit}.settings-grid input:focus,.settings-grid select:focus,.settings-grid textarea:focus{border-color:#5d86ff;box-shadow:0 0 0 3px rgba(93,134,255,.12)}.settings-inline{display:flex;align-items:center;gap:10px}.settings-inline input{flex:1}.settings-info{background:rgba(29,160,242,.12);border-color:rgba(29,160,242,.35);color:#cfeaff}.settings-success{display:flex;align-items:center;gap:8px;background:rgba(47,175,100,.15);border-color:rgba(47,175,100,.4);color:#d5ffe5}.sitemap-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px;padding:20px}.sitemap-box{background:#1c2130;border:1px solid rgba(255,255,255,.09);border-radius:12px;padding:18px}.sitemap-box strong{display:block;margin-bottom:10px;font-size:16px}.sitemap-box p{color:#9aa7c7;margin:0 0 14px}.status{display:inline-flex;align-items:center;gap:6px;padding:3px 9px;border-radius:999px;font-weight:900;font-size:12px}.status.ok{background:#29b866;color:#fff}.status.draft{background:#69717f;color:#fff}.settings-savebar{display:flex;gap:10px;justify-content:flex-start;padding-top:4px}.settings-page .btn i{margin-right:7px}@media(max-width:760px){.settings-grid,.sitemap-grid{grid-template-columns:1fr}.settings-inline{flex-direction:column;align-items:stretch}.settings-tab{padding:12px 13px}.settings-card-head,.settings-grid,.sitemap-grid{padding:16px}}

/* ===== Auto Post modal reference-like UI ===== */
.modal-overlay{position:fixed;inset:0;display:none;align-items:center;justify-content:center;padding:24px;z-index:9999;background:rgba(7,10,18,.72);backdrop-filter:blur(8px)}
.modal-overlay.show{display:flex}
.ap-ref-modal{position:relative;width:min(920px,100%);max-height:min(88vh,900px);overflow:hidden;background:#1d2234;border:1px solid rgba(255,255,255,.11);border-radius:18px;box-shadow:0 28px 90px rgba(0,0,0,.45)}
.ap-ref-modal-scroll{position:relative;max-height:min(88vh,900px);overflow:auto;padding:28px;border-radius:18px;scrollbar-gutter:stable both-edges}
.modal-close{position:absolute;top:14px;right:14px;width:38px;height:38px;border-radius:999px;border:1px solid rgba(255,255,255,.12);background:#23283d;color:#e7eeff;display:grid;place-items:center;cursor:pointer;z-index:3}
.modal-title{font-size:28px;font-weight:900;color:#f2f5ff;margin:0 0 18px}.mb-3{margin-bottom:22px}.form-label{display:block;font-size:15px;color:#f2f5ff;margin:0 0 8px}.fw-semibold{font-weight:800}.fw-normal{font-weight:500}.text-muted{color:#94a3c3}.form-text{margin-top:8px;color:#94a3c3;font-size:13px;line-height:1.55}.form-control{width:100%;min-height:46px;background:#191e2d;border:1px solid rgba(255,255,255,.1);color:#eef3ff;border-radius:12px;padding:12px 14px;font:inherit;outline:none}.form-control:focus{border-color:#477dff;box-shadow:0 0 0 3px rgba(71,125,255,.16)}textarea.form-control{min-height:88px;resize:vertical}.chip-group{display:flex;flex-wrap:wrap;gap:10px}.chip{display:inline-flex;align-items:center;gap:8px;padding:9px 14px;border-radius:999px;background:#232840;border:1px solid rgba(255,255,255,.1);color:#aeb8d6;font-size:14px;font-weight:700;cursor:pointer;transition:.18s ease}.chip input{display:none}.chip .dot{width:7px;height:7px;border-radius:999px;background:#7682a2;flex:0 0 auto}.chip.on{border-color:#3d74f1;color:#bdddff;background:#24325e;box-shadow:inset 0 0 0 1px rgba(85,139,255,.3)}.chip.on .dot{background:#65a3ff}.row-2{display:grid;grid-template-columns:1fr 1fr;gap:18px}.sw-row{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;padding:14px 0;border-top:1px solid rgba(255,255,255,.07)}.sw-row:first-child{border-top:0;padding-top:0}.sw-lbl{font-weight:800;color:#f2f5ff;display:flex;align-items:center;gap:8px;margin-bottom:4px}.sw-sub{font-size:13px;line-height:1.55;color:#94a3c3;max-width:620px}.sw{position:relative;display:inline-block;width:56px;height:32px;flex:0 0 auto}.sw input{display:none}.sw-track{position:absolute;inset:0;border-radius:999px;background:#3a415c;transition:.18s}.sw-thumb{position:absolute;top:4px;left:4px;width:24px;height:24px;border-radius:999px;background:#fff;transition:.18s;box-shadow:0 2px 8px rgba(0,0,0,.28)}.sw input:checked + .sw-track{background:#2faf64}.sw input:checked + .sw-track + .sw-thumb{transform:translateX(24px)}.modal-save-btn{width:100%;justify-content:center;min-height:46px;font-size:15px;border-radius:12px}
@media(max-width:860px){.ap-ref-modal-scroll{padding:22px}.modal-title{font-size:24px}.row-2{grid-template-columns:1fr}.modal-overlay{padding:14px}}

/* Auto Post generate modal - 3 modes + progress */
.ap-generate-modal{position:relative;width:min(560px,calc(100vw - 28px));background:#1d2234;border:1px solid rgba(255,255,255,.13);border-radius:18px;box-shadow:0 28px 90px rgba(0,0,0,.48);padding:26px;overflow:hidden}
.ap-generate-modal .modal-title{font-size:22px;margin:0 0 18px;color:#f8fafc;font-weight:800}
.gen-title-input{width:100%;height:40px;background:#242941!important;border:1px solid rgba(255,255,255,.09)!important;color:#e5e7eb!important;border-radius:8px!important;padding:0 14px!important;margin-bottom:14px!important}
.gen-mode-label{color:#aab2c8;font-size:13px;font-weight:700;margin:6px 0 8px}
.gen-mode-grid.three{display:grid;grid-template-columns:1fr;gap:10px;margin-bottom:14px}
.gen-mode-card{display:grid;grid-template-columns:34px 1fr;grid-template-areas:'ico title' 'ico sub';gap:2px 10px;text-align:left;background:#282d48;border:1px solid rgba(255,255,255,.08);border-radius:9px;padding:12px 14px;color:#f1f5f9;cursor:pointer;transition:.18s ease}
.gen-mode-card:hover{transform:translateY(-1px);border-color:rgba(96,165,250,.55)}
.gen-mode-card.active{background:#202b44;border-color:#5b93ff;box-shadow:inset 0 0 0 1px rgba(91,147,255,.35)}
.gen-mode-card i{grid-area:ico;display:flex;align-items:center;justify-content:center;font-size:20px;color:#5b93ff;margin-top:2px}
.gen-mode-card b{grid-area:title;font-size:14px;line-height:1.2}
.gen-mode-card small{grid-area:sub;color:#8e98b3;font-size:12px;line-height:1.35}
.gen-source-wrap{margin:12px 0}.gen-source-wrap textarea{background:#242941!important;border:1px solid rgba(255,255,255,.09)!important;color:#e5e7eb!important;border-radius:10px!important}
.gen-progress{margin:14px 0;padding:12px;border:1px solid rgba(91,147,255,.25);border-radius:12px;background:rgba(31,41,68,.72)}
.gen-progress-top{display:flex;align-items:center;justify-content:space-between;color:#dbeafe;font-size:13px;font-weight:700;margin-bottom:8px}.gen-progress-top b{color:#60a5fa}
.gen-progress-bar{height:9px;background:#111827;border-radius:999px;overflow:hidden;border:1px solid rgba(255,255,255,.08)}
.gen-progress-bar span{display:block;height:100%;width:0;background:linear-gradient(90deg,#3b82f6,#22c55e);border-radius:999px;transition:width .35s ease}
.gen-progress small{display:block;color:#93a4c2;font-size:12px;margin-top:8px}
.ap-mini-actions button{background:transparent;border:0;color:#60a5fa;cursor:pointer;font-size:12px;padding:0;margin:0 8px 0 0}
.ap-mini-actions button:hover{text-decoration:underline}
/* ปุ่ม "สร้างใหม่" — สไตล์เดียวกับปุ่มพรีวิวและแก้ไข */
.ap-mini-actions .ap-btn-rewrite{
  background:transparent;
  border:1px solid #0fd6ff;
  color:#0fd6ff;
  border-radius:3px;
  padding:5px 2px;
  font-size:11px;
  font-family:inherit;
  cursor:pointer;
  width:100%;
  text-align:center;
  text-decoration:none;
  transition:opacity .15s ease;
}
.ap-mini-actions .ap-btn-rewrite:hover{
  opacity:0.75;
  text-decoration:none;
}
@media(min-width:720px){.gen-mode-grid.three{grid-template-columns:1fr}.ap-generate-modal{padding:26px}}

.gen-context-note{
  margin:6px 0 14px;
  padding:10px 12px;
  border:1px solid rgba(93,134,255,.25);
  border-radius:10px;
  background:rgba(93,134,255,.08);
  color:#b9c7ef;
  font-size:13px;
  line-height:1.45;
}

/* Member profile / account management */
.profile-page {
  padding:28px 0 10px
}

.profile-hero {
  display:flex;
  align-items:center;
  gap:18px;
  text-align:left;
  margin-top:28px
}

.profile-hero .avatar {
  margin:0;
  flex:0 0 82px
}

.profile-hero h1 {
  font-family:'Crimson Pro',serif;
  font-size:40px;
  margin:8px 0 4px
}

.profile-hero p {
  color:var(--muted);
  margin:0
}

.success-alert {
  background:rgba(45,160,90,.18);
  border-color:rgba(45,160,90,.42);
  color:#d8ffe6
}

.profile-stats {
  display:grid;
  grid-template-columns:repeat(3,1fr);
  gap:14px;
  margin:18px 0 24px
}

.profile-stats div {
  background:rgba(26,23,38,.88);
  border:1px solid var(--border);
  border-radius:16px;
  padding:18px;
  text-align:center
}

.profile-stats b {
  display:block;
  color:var(--gold2);
  font-size:30px;
  line-height:1
}

.profile-stats span {
  display:block;
  color:var(--muted);
  margin-top:8px
}

.profile-layout {
  display:grid;
  grid-template-columns:minmax(0,1fr) 360px;
  gap:24px;
  align-items:start
}

.profile-layout > aside {
  padding-top:68px;
}

.profile-follow-list {
  display:grid;
  gap:12px
}

.profile-follow-item {
  display:grid;
  grid-template-columns:64px minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  background:var(--card);
  border:1px solid var(--border);
  border-radius:14px;
  padding:12px
}

.follow-thumb img {
  width:64px;
  height:86px;
  object-fit:cover;
  border-radius:10px;
  display:block
}

.follow-title {
  display:inline-block;
  font-weight:800;
  margin-bottom:4px
}

.profile-follow-item p,
.profile-follow-item small {
  color:var(--muted);
  margin:0;
  font-size:13px
}

.profile-follow-item form {
  margin:0
}

.profile-card-form {
  text-align:left
}

.profile-card-form h2,
.profile-links h2 {
  font-family:'Crimson Pro',serif;
  font-size:26px
}

.profile-card-form form {
  display:grid;
  gap:12px
}

.profile-card-form label {
  display:grid;
  gap:8px;
  color:var(--gold2);
  font-weight:700
}

.profile-links {
  text-align:left;
  display:grid;
  gap:10px
}

.profile-links a {
  display:flex;
  align-items:center;
  gap:10px;
  border:1px solid var(--border);
  background:rgba(255,255,255,.04);
  padding:12px 14px;
  border-radius:12px;
  color:var(--muted)
}

.profile-links a:hover {
  color:var(--gold2);
  border-color:rgba(201,168,76,.35)
}

@media(max-width:950px) {
  .profile-layout {
    grid-template-columns:1fr
  }

  .profile-stats {
    grid-template-columns:1fr
  }

  .profile-follow-item {
    grid-template-columns:56px 1fr;
    align-items:start
  }

  .profile-follow-item form {
    grid-column:1/-1
  }

  .profile-follow-item .btn {
    width:100%;
    justify-content:center
  }

  .profile-hero {
    display:block;
    text-align:center
  }

  .profile-hero .avatar {
    margin:0 auto 12px
  }
}

/* ===== Admin management pages: users / comments / follows ===== */
.admin-list-page,
.admin-dashboard-page,
.admin-edit-page.narrow {
  max-width:1180px;
  margin:0 auto;
}
.admin-filter {
  display:flex;
  gap:10px;
  align-items:center;
  background:#171b25;
  border:1px solid rgba(255,255,255,.08);
  padding:14px;
  border-radius:14px;
  margin:0 0 16px;
}
.admin-filter input {
  flex:1;
  min-width:220px;
}
.admin-table-wrap {
  overflow:auto;
  border-radius:14px;
  border:1px solid rgba(255,255,255,.08);
  background:#171b25;
}
.admin-table small {
  color:#8a97b6;
}
.admin-table a {
  color:#7db5ff;
}
.inline-form select {
  min-width:105px;
  padding:9px 10px;
}
.admin-actions form {
  margin:0;
}
.btn.danger,
.admin-alert.danger {
  color:#ff8b9a;
  border-color:rgba(255,99,132,.35);
}
.admin-form-card {
  background:#171b25;
  border:1px solid rgba(255,255,255,.08);
  border-radius:16px;
  padding:20px;
}
.admin-form-card label {
  display:grid;
  gap:8px;
  color:#d9e4ff;
  font-weight:800;
}
.admin-form-card label small {
  color:#8a97b6;
  font-weight:600;
}
.form-actions {
  display:flex;
  gap:10px;
  flex-wrap:wrap;
  margin-top:18px;
}
.comment-edit-box {
  margin-bottom:18px;
}
.comment-edit-box textarea {
  width:100%;
  margin-top:10px;
}
.admin-stat-grid {
  display:grid;
  grid-template-columns:repeat(5,minmax(140px,1fr));
  gap:14px;
  margin-bottom:18px;
}
.admin-stat-grid .chip {
  text-decoration:none;
  color:inherit;
}
.admin-quick-grid {
  display:grid;
  grid-template-columns:repeat(4,minmax(180px,1fr));
  gap:14px;
  margin:18px 0;
}
.admin-quick-card {
  display:grid;
  gap:8px;
  text-decoration:none;
  color:#f7f7ff;
  min-height:130px;
}
.admin-quick-card i {
  font-size:24px;
  color:#7db5ff;
}
.admin-quick-card small {
  color:#8a97b6;
  line-height:1.5;
}
.admin-two-col {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:16px;
}
.admin-table.compact {
  background:transparent;
}
.admin-table.compact td {
  padding:10px 0;
}
@media(max-width:1050px) {
  .admin-stat-grid,
  .admin-quick-grid,
  .admin-two-col {
    grid-template-columns:1fr 1fr;
  }
}
@media(max-width:680px) {
  .admin-filter,
  .form-actions {
    flex-direction:column;
    align-items:stretch;
  }
  .admin-stat-grid,
  .admin-quick-grid,
  .admin-two-col,
  .form-grid {
    grid-template-columns:1fr;
  }
}


/* Admin profile */
.admin-profile-page{display:grid;gap:18px}
.admin-profile-hero{display:flex;align-items:center;gap:18px;padding:24px;border-radius:24px}
.admin-profile-hero h2{margin:0 0 6px;font-size:26px;color:#111827}
.admin-profile-hero p{margin:0 0 12px;color:#6b7280}
.admin-avatar-big{width:82px;height:82px;border-radius:26px;display:grid;place-items:center;background:linear-gradient(135deg,#7c3aed,#ec4899);color:#fff;font-size:34px;box-shadow:0 18px 38px rgba(124,58,237,.25)}
.admin-pill{background:#fff7ed;color:#9a3412;border-color:#fed7aa}
.admin-stat-grid.small{grid-template-columns:repeat(4,minmax(0,1fr));margin:0}
.admin-profile-grid{display:grid;grid-template-columns:minmax(0,1fr) minmax(320px,.75fr);gap:18px;align-items:start}
.section-head.compact{margin-bottom:14px}
.section-head.compact h2{font-size:18px}
.form-grid.one{grid-template-columns:1fr}
.admin-alert.success{background:#ecfdf5;color:#047857;border:1px solid #a7f3d0}
@media(max-width:900px){.admin-profile-grid,.admin-stat-grid.small{grid-template-columns:1fr}.admin-profile-hero{align-items:flex-start}.admin-avatar-big{width:64px;height:64px;border-radius:20px;font-size:26px}}


/* ===== Admin UI refresh: dashboard + profile ===== */
.admin-topbar {
  background:linear-gradient(180deg,rgba(17,20,29,.96),rgba(17,20,29,.88));
  backdrop-filter:blur(16px);
}
.admin-page-title b {
  font-size:22px;
  font-weight:900;
  letter-spacing:-.3px;
}
.admin-page-title small {
  color:#91a1ca;
  font-size:13px;
}
.admin-top-actions .btn {
  min-height:42px;
  border-radius:14px;
  padding:10px 15px;
  background:rgba(255,255,255,.03);
  border:1px solid rgba(255,255,255,.1);
  color:#e9efff;
}
.admin-top-actions .btn:hover {
  background:rgba(109,146,255,.12);
  border-color:rgba(109,146,255,.35);
}
.admin-dashboard-modern,
.admin-profile-modern {
  background:transparent !important;
  border:0 !important;
  padding:0 !important;
  box-shadow:none !important;
}
.admin-dashboard-modern .card-panel,
.admin-profile-modern .card-panel {
  background:linear-gradient(180deg,rgba(31,36,53,.96),rgba(24,28,43,.96));
  border:1px solid rgba(255,255,255,.08);
  border-radius:24px;
  box-shadow:0 22px 50px rgba(0,0,0,.24);
}
.dashboard-hero {
  display:grid;
  grid-template-columns:minmax(0,1.35fr) minmax(280px,.75fr);
  gap:22px;
  align-items:stretch;
  padding:28px;
  margin-bottom:22px;
  background:
    radial-gradient(circle at top right,rgba(115,92,255,.18),transparent 30%),
    linear-gradient(135deg,#1a2034 0%,#202944 48%,#182137 100%) !important;
}
.dashboard-hero-copy h2 {
  font-size:32px;
  line-height:1.15;
  margin:10px 0 10px;
  color:#f8fbff;
}
.dashboard-hero-copy p {
  margin:0;
  color:#9dadcf;
  line-height:1.8;
  max-width:720px;
}
.dashboard-hero-kicker {
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:28px;
  padding:0 12px;
  border-radius:999px;
  background:rgba(122,145,255,.12);
  border:1px solid rgba(122,145,255,.25);
  color:#b6c6ff;
  font-size:12px;
  font-weight:800;
  letter-spacing:.08em;
}
.dashboard-hero-actions {
  display:flex;
  flex-wrap:wrap;
  gap:12px;
  margin-top:22px;
}
.dashboard-hero-actions .btn {
  min-height:46px;
  border-radius:14px;
}
.dashboard-hero-actions .btn.solid {
  background:linear-gradient(135deg,#5c71ff,#8d48ff);
  color:#fff;
}
.dashboard-hero-badges {
  display:grid;
  gap:14px;
}
.dashboard-badge-card {
  padding:20px;
  border-radius:20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
  display:grid;
  gap:8px;
  align-content:center;
}
.dashboard-badge-card span,
.dashboard-badge-card small {
  color:#94a5cb;
}
.dashboard-badge-card b {
  font-size:38px;
  line-height:1;
  color:#fff;
}
.dashboard-stats-grid {
  display:grid;
  grid-template-columns:repeat(5,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.dashboard-stat-card {
  display:flex;
  align-items:flex-start;
  gap:14px;
  min-height:136px;
  padding:20px;
  border-radius:22px;
  background:linear-gradient(180deg,rgba(29,33,48,.98),rgba(21,25,39,.98));
  border:1px solid rgba(255,255,255,.08);
  box-shadow:0 18px 42px rgba(0,0,0,.18);
  color:#f6f8ff;
  transition:transform .18s ease, border-color .18s ease, background .18s ease;
}
.dashboard-stat-card:hover {
  transform:translateY(-3px);
  border-color:rgba(123,154,255,.38);
  background:linear-gradient(180deg,rgba(33,38,57,1),rgba(24,28,43,1));
}
.dashboard-stat-card.static:hover { transform:none; }
.stat-icon {
  width:50px;
  height:50px;
  border-radius:18px;
  display:grid;
  place-items:center;
  font-size:20px;
  color:#fff;
  flex:0 0 auto;
  box-shadow:0 10px 22px rgba(0,0,0,.18);
}
.stat-icon.blue { background:linear-gradient(135deg,#4b8cff,#3d66ff); }
.stat-icon.violet { background:linear-gradient(135deg,#7c5cff,#9e52ff); }
.stat-icon.amber { background:linear-gradient(135deg,#ffb648,#ff8b36); }
.stat-icon.pink { background:linear-gradient(135deg,#ff5e8a,#f13d71); }
.stat-icon.cyan { background:linear-gradient(135deg,#1fc8ff,#02a1f3); }
.stat-meta {
  display:grid;
  gap:6px;
}
.stat-meta small {
  color:#91a3c9;
  font-size:13px;
  font-weight:800;
}
.stat-meta b {
  font-size:32px;
  line-height:1.05;
}
.stat-meta span {
  color:#7f8eaf;
  font-size:13px;
  line-height:1.6;
}
.dashboard-shortcuts-grid {
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
  margin-bottom:18px;
}
.dashboard-shortcut-card {
  display:flex;
  gap:14px;
  align-items:flex-start;
  padding:20px;
  border-radius:20px;
  background:linear-gradient(180deg,rgba(29,33,48,.94),rgba(23,27,40,.94));
  border:1px solid rgba(255,255,255,.08);
  color:#f5f7ff;
  transition:transform .18s ease, border-color .18s ease;
}
.dashboard-shortcut-card:hover {
  transform:translateY(-3px);
  border-color:rgba(123,154,255,.34);
}
.shortcut-icon {
  width:46px;
  height:46px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(110,140,255,.12);
  color:#8fb0ff;
  font-size:18px;
  flex:0 0 auto;
}
.dashboard-shortcut-card b {
  display:block;
  margin:2px 0 6px;
  font-size:16px;
}
.dashboard-shortcut-card small {
  display:block;
  color:#8ea1c7;
  line-height:1.65;
}
.dashboard-content-grid {
  display:grid;
  grid-template-columns:1fr 1fr;
  gap:18px;
}
.dashboard-panel {
  padding:0 !important;
  overflow:hidden;
}
.dashboard-panel-head {
  display:flex;
  justify-content:space-between;
  align-items:flex-start;
  gap:14px;
  padding:22px 22px 16px;
  border-bottom:1px solid rgba(255,255,255,.08);
}
.dashboard-panel-head h3 {
  margin:0 0 6px;
  font-size:20px;
  color:#f8fbff;
}
.dashboard-panel-head p {
  margin:0;
  color:#8ea1c8;
  font-size:13px;
  line-height:1.6;
}
.dashboard-panel-head .btn,
.dashboard-list-meta .btn,
.admin-profile-sidecard .btn {
  min-height:38px;
  border-radius:12px;
  padding:8px 12px;
}
.small-btn { font-size:13px; }
.dashboard-list {
  display:grid;
  gap:0;
}
.dashboard-list-item {
  display:grid;
  grid-template-columns:48px minmax(0,1fr) auto;
  gap:14px;
  align-items:center;
  padding:18px 22px;
  border-top:1px solid rgba(255,255,255,.06);
}
.dashboard-list-item:first-child { border-top:0; }
.dashboard-list-item.align-start { align-items:flex-start; }
.dashboard-list-avatar {
  width:48px;
  height:48px;
  border-radius:16px;
  display:grid;
  place-items:center;
  background:rgba(109,140,255,.14);
  color:#8fb0ff;
  font-size:18px;
}
.dashboard-list-avatar.pink {
  background:rgba(241,61,113,.12);
  color:#ff7da7;
}
.dashboard-list-content b {
  display:block;
  font-size:15px;
  margin-bottom:4px;
}
.dashboard-list-content small {
  display:block;
  color:#8fa1c7;
  line-height:1.5;
}
.dashboard-list-content p {
  margin:8px 0 0;
  color:#d8e0f7;
  line-height:1.7;
  font-size:14px;
}
.dashboard-list-meta {
  display:flex;
  flex-direction:column;
  align-items:flex-end;
  gap:10px;
}
.dashboard-empty {
  padding:26px 22px;
  color:#90a3cb;
}
.pill {
  display:inline-flex;
  align-items:center;
  gap:6px;
  min-height:30px;
  padding:0 12px;
  border-radius:999px;
  border:1px solid rgba(255,255,255,.11);
  background:rgba(255,255,255,.05);
  color:#e8efff;
  font-size:13px;
  font-weight:700;
}

/* Admin profile page refresh */
.admin-profile-page {
  display:grid;
  gap:18px;
}
.admin-alert {
  display:flex;
  align-items:center;
  gap:10px;
  border-radius:16px;
  margin-bottom:0;
}
.admin-alert.success {
  background:rgba(35,197,94,.14);
  color:#d6ffe6;
  border:1px solid rgba(35,197,94,.25);
}
.admin-alert.danger {
  background:rgba(239,68,68,.13);
  color:#ffd7d7;
  border:1px solid rgba(239,68,68,.24);
}
.admin-profile-hero {
  display:grid;
  grid-template-columns:auto minmax(0,1fr) minmax(280px,.78fr);
  gap:20px;
  align-items:center;
  padding:26px 28px;
}
.admin-avatar-big {
  width:88px;
  height:88px;
  border-radius:28px;
  background:linear-gradient(135deg,#6c63ff,#9d4dff 55%,#f04d8a);
  color:#fff;
  font-size:36px;
  box-shadow:0 18px 38px rgba(124,58,237,.26);
}
.admin-profile-summary h2 {
  margin:10px 0 6px;
  font-size:32px;
  color:#fff;
}
.admin-profile-summary p {
  margin:0;
  color:#97a8ce;
}
.admin-profile-badges {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin-top:16px;
}
.admin-pill {
  background:rgba(251,191,36,.12);
  color:#ffd987;
  border-color:rgba(251,191,36,.2);
}
.admin-profile-sidecard {
  display:grid;
  gap:10px;
  padding:18px 18px 18px 20px;
  border-radius:20px;
  background:rgba(255,255,255,.04);
  border:1px solid rgba(255,255,255,.08);
}
.admin-profile-sidecard strong {
  font-size:16px;
}
.admin-profile-sidecard small {
  color:#95a6cb;
  line-height:1.65;
}
.profile-stats-grid {
  margin-bottom:0;
}
.admin-profile-grid {
  display:grid;
  grid-template-columns:1.1fr .9fr;
  gap:18px;
  align-items:start;
}
.admin-profile-card {
  padding:0 !important;
  overflow:hidden;
}
.admin-profile-card .form-grid,
.admin-profile-card .form-actions {
  padding-left:22px;
  padding-right:22px;
}
.admin-profile-card .form-grid {
  padding-top:18px;
  padding-bottom:0;
}
.admin-profile-card .form-actions {
  padding-bottom:22px;
  margin-top:18px;
}
.admin-profile-card label {
  color:#eaf0ff;
  font-size:14px;
  font-weight:800;
}
.admin-profile-card label small {
  display:block;
  color:#8fa1c8;
  font-weight:500;
  margin-top:6px;
  line-height:1.55;
}
.admin-profile-card input,
.admin-profile-card select,
.admin-profile-card textarea,
.admin-filter input,
.admin-filter select {
  background:#14192a;
  border:1px solid rgba(255,255,255,.1);
  color:#eef3ff;
  border-radius:14px;
  padding:12px 14px;
}
.admin-profile-card input:focus,
.admin-profile-card select:focus,
.admin-profile-card textarea:focus,
.admin-filter input:focus,
.admin-filter select:focus,
.admin-body input:focus,
.admin-body select:focus,
.admin-body textarea:focus {
  outline:none;
  border-color:rgba(109,146,255,.55);
  box-shadow:0 0 0 4px rgba(109,146,255,.12);
}
.form-actions {
  display:flex;
  gap:12px;
  flex-wrap:wrap;
}
.form-actions .btn {
  min-height:44px;
  border-radius:14px;
}
.form-actions .btn.solid {
  background:linear-gradient(135deg,#5c71ff,#8d48ff);
  color:#fff;
}

@media(max-width:1200px){
  .dashboard-stats-grid { grid-template-columns:repeat(3,minmax(0,1fr)); }
  .dashboard-shortcuts-grid { grid-template-columns:repeat(2,minmax(0,1fr)); }
  .dashboard-content-grid,
  .admin-profile-grid,
  .admin-profile-hero,
  .dashboard-hero { grid-template-columns:1fr; }
}
@media(max-width:760px){
  .dashboard-stats-grid,
  .profile-stats-grid,
  .dashboard-shortcuts-grid,
  .dashboard-content-grid,
  .admin-profile-grid { grid-template-columns:1fr; }
  .dashboard-list-item { grid-template-columns:44px minmax(0,1fr); }
  .dashboard-list-meta { grid-column:1/-1; align-items:flex-start; flex-direction:row; flex-wrap:wrap; }
  .dashboard-hero,
  .admin-profile-hero { padding:22px; }
  .dashboard-hero-copy h2,
  .admin-profile-summary h2 { font-size:28px; }
  .dashboard-panel-head { flex-direction:column; align-items:flex-start; }
}


/* ===== Reader rating system ===== */
.reader-stats {
  color:var(--muted);
  line-height:1.7;
}
.rating-box {
  margin:18px 0 20px;
  padding:18px;
  border-radius:18px;
  display:flex;
  align-items:center;
  justify-content:space-between;
  gap:16px;
  background:rgba(255,255,255,.055);
  border:1px solid rgba(201,168,76,.2);
}
.rating-box b {
  display:block;
  margin-bottom:4px;
  color:var(--gold2);
}
.rating-box p {
  margin:0;
  color:var(--muted);
  line-height:1.6;
  font-size:14px;
}
.rating-form {
  display:flex;
  align-items:center;
  gap:12px;
  flex-wrap:wrap;
  justify-content:flex-end;
}
.star-select {
  display:flex;
  flex-direction:row-reverse;
  gap:3px;
}
.star-select input {
  position:absolute;
  opacity:0;
  pointer-events:none;
}
.star-select label {
  font-size:30px;
  line-height:1;
  color:#5c5262;
  cursor:pointer;
  transition:.15s ease;
}
.star-select label:hover,
.star-select label:hover ~ label,
.star-select input:checked ~ label {
  color:#f6c64a;
  transform:translateY(-1px);
}
.rating-alert {
  margin:16px 0 0;
  border-radius:14px;
}
@media(max-width:720px){
  .rating-box { align-items:flex-start; flex-direction:column; }
  .rating-form { justify-content:flex-start; }
}

/* ===== Author follow + notifications ===== */
.notify-badge {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  min-width: 18px;
  height: 18px;
  padding: 0 5px;
  margin-left: 6px;
  border-radius: 999px;
  background: #e11d48;
  color: #fff;
  font-size: 11px;
  font-weight: 700;
  line-height: 1;
}
.inline-follow-form {
  display: inline-flex;
  margin: 0;
}
.notifications-page .profile-follow-item.unread {
  border-color: rgba(225, 29, 72, .35);
  background: rgba(225, 29, 72, .08);
}
.notifications-page .profile-follow-item {
  align-items: center;
}

/* Featured novel card from real database */
.hero-card {
  display:block;
  color:inherit;
  text-decoration:none;
}
.featured-cover {
  width:100%;
  height:180px;
  border-radius:12px;
  object-fit:cover;
  display:block;
  margin-bottom:16px;
  background:linear-gradient(135deg,#2d1040,#b03068);
}

/* ===== Reader page: main cover is 16:9, related covers stay novel-poster size ===== */
.reader-main-cover {
  width: min(960px, 100%);
  aspect-ratio: 16 / 9;
  height: auto;
  display: block;
  margin: 22px auto;
  border-radius: 24px;
  object-fit: cover;
  object-position: center center;
  background: #130f1c;
  box-shadow: 0 20px 50px rgba(0,0,0,.25);
}

.related-novels {
  width: 100%;
  max-width: 1280px;
  margin: 34px auto 0;
  padding: 0 24px;
  box-sizing: border-box;
}

.comment-section {
  max-width: 1280px;
  margin: 0 auto;
  padding: 0 24px;
  box-sizing: border-box;
}

.related-novel-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 22px;
  align-items: start;
}

.related-novel-card {
  min-width: 0;
}

.related-novel-card img {
  width: 100%;
  aspect-ratio: 2 / 3;
  height: auto;
  object-fit: cover;
  border-radius: 13px;
  display: block;
  background: #20172c;
}

.related-novel-card b {
  display: block;
  margin-top: 10px;
  line-height: 1.35;
}

.related-novel-card span,
.related-novel-card small {
  display: block;
  font-size: 13px;
  margin-top: 4px;
  color: var(--dim);
}

@media (max-width: 1150px) {
  .related-novel-grid {
    grid-template-columns: repeat(4, minmax(0, 1fr));
  }
}

@media (max-width: 900px) {
  .reader-main-cover {
    width: 100%;
    border-radius: 18px;
    margin: 18px auto;
  }

  .related-novel-grid {
    grid-template-columns: repeat(3, minmax(0, 1fr));
    gap: 16px;
  }
}

@media (max-width: 600px) {
  .related-novel-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
    gap: 14px;
  }
}


/* ===== Bookmarks page grid ===== */
.bookmarks-page .bookmarks-grid {
  width: 100%;
  display: grid;
  grid-template-columns: repeat(6, minmax(0, 1fr));
  gap: 22px;
  align-items: start;
}
.bookmarks-page .bookmarks-grid .novel-card img {
  width: 100%;
  aspect-ratio: 2 / 3;
  height: auto;
  object-fit: cover;
  display: block;
  border-radius: 13px;
}
@media (max-width: 1150px) {
  .bookmarks-page .bookmarks-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); }
}
@media (max-width: 900px) {
  .bookmarks-page .bookmarks-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 16px; }
}
@media (max-width: 600px) {
  .bookmarks-page .bookmarks-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
}

/* ===== Home page upgrade: featured, sections, authors, member box, SEO ===== */
.home-hero {
  display:grid;
  grid-template-columns:minmax(0,1.08fr) minmax(320px,.92fr);
  gap:30px;
  align-items:stretch;
  margin:34px 0 28px;
  padding:28px;
  border:1px solid var(--border);
  border-radius:28px;
  background:
    radial-gradient(circle at top left, rgba(201,168,76,.16), transparent 34%),
    linear-gradient(135deg, rgba(26,23,38,.96), rgba(45,16,64,.72));
  box-shadow:0 24px 70px rgba(0,0,0,.32);
  overflow:hidden;
}
.home-hero-copy {
  display:flex;
  flex-direction:column;
  justify-content:center;
  min-height:360px;
}
.home-hero-copy h1 {
  font-family:'Crimson Pro',serif;
  font-size:clamp(38px,5vw,68px);
  line-height:1.02;
  margin:16px 0 14px;
  color:#fff8ea;
}
.home-hero-copy p {
  color:var(--muted);
  font-size:17px;
  line-height:1.85;
  max-width:680px;
}
.home-hero-meta {
  display:flex;
  flex-wrap:wrap;
  gap:10px;
  margin:14px 0 2px;
}
.home-hero-meta span {
  display:inline-flex;
  align-items:center;
  min-height:30px;
  padding:6px 12px;
  border-radius:999px;
  background:rgba(255,255,255,.06);
  border:1px solid rgba(255,255,255,.08);
  color:var(--gold2);
  font-size:13px;
  font-weight:700;
}
.home-hero-cover {
  display:block;
  position:relative;
  min-height:360px;
  border-radius:24px;
  overflow:hidden;
  background:#19111f;
  box-shadow:0 18px 55px rgba(0,0,0,.38);
}
.home-hero-cover img,
.home-hero-placeholder {
  width:100%;
  height:100%;
  min-height:360px;
  display:grid;
  place-items:center;
  object-fit:cover;
  font-size:82px;
}
.home-section {
  margin:34px 0;
}
.home-category-grid {
  display:grid;
  grid-template-columns:repeat(6,minmax(0,1fr));
  gap:14px;
}
.home-category-card {
  min-height:96px;
  display:flex;
  flex-direction:column;
  justify-content:center;
  gap:8px;
  padding:18px;
  border-radius:18px;
  background:linear-gradient(145deg, rgba(26,23,38,.96), rgba(255,255,255,.035));
  border:1px solid var(--border);
  transition:.2s ease;
}
.home-category-card:hover {
  transform:translateY(-3px);
  border-color:rgba(201,168,76,.38);
}
.home-category-card b {
  color:#fff4df;
}
.home-category-card small {
  color:var(--muted);
}
.home-novel-grid {
  grid-template-columns:repeat(6,minmax(0,1fr));
}
.author-grid {
  display:grid;
  grid-template-columns:repeat(4,minmax(0,1fr));
  gap:16px;
}
.author-card {
  display:grid;
  grid-template-columns:64px minmax(0,1fr);
  gap:14px;
  align-items:start;
  padding:18px;
  border-radius:20px;
  background:rgba(26,23,38,.88);
  border:1px solid var(--border);
  height:auto;
}
.author-card form,
.author-card > .btn {
  grid-column:1/-1;
  margin:0;
}
.author-card .btn {
  width:100%;
  justify-content:center;
  padding:9px 14px;
}
.author-avatar {
  width:64px;
  height:64px;
  border-radius:22px;
  display:grid;
  place-items:center;
  color:#1a1200;
  background:linear-gradient(135deg,var(--gold),var(--gold2));
  font-weight:900;
  font-size:28px;
}
.author-card b {
  display:block;
  overflow-wrap:break-word;
  word-break:break-word;
  white-space:normal;
  line-height:1.4;
}
.author-card small {
  display:block;
  color:var(--muted);
  margin-top:5px;
  font-size:13px;
}
.home-member-box {
  display:flex;
  justify-content:space-between;
  align-items:center;
  gap:22px;
  margin:36px 0;
  padding:26px;
  border-radius:26px;
  border:1px solid rgba(201,168,76,.18);
  background:linear-gradient(135deg,var(--wine),#6b1565,#2d8b7a);
  box-shadow:0 18px 50px rgba(0,0,0,.25);
}
.home-member-box h2,
.home-seo-text h2 {
  margin:10px 0 8px;
  font-family:'Crimson Pro',serif;
  font-size:32px;
}
.home-member-box p {
  margin:0;
  color:#f4dfca;
  line-height:1.7;
}
.continue-list {
  display:grid;
  grid-template-columns:repeat(4,74px);
  gap:10px;
}
.continue-list a {
  display:grid;
  gap:7px;
  text-align:center;
  color:#fff;
  font-size:12px;
}
.continue-list img {
  width:74px;
  aspect-ratio:2/3;
  object-fit:cover;
  border-radius:10px;
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.continue-list span {
  overflow:hidden;
  text-overflow:ellipsis;
  white-space:nowrap;
}
.home-seo-text {
  margin:38px 0 10px;
  padding:28px;
  border-radius:24px;
  background:rgba(255,255,255,.035);
  border:1px solid var(--border);
}
.home-seo-text p {
  color:var(--muted);
  line-height:1.9;
  margin:0;
}

@media(max-width:1150px) {
  .home-category-grid,
  .home-novel-grid {
    grid-template-columns:repeat(4,minmax(0,1fr));
  }
  .author-grid {
    grid-template-columns:repeat(2,minmax(0,1fr));
  }
}
@media(max-width:900px) {
  .home-hero {
    grid-template-columns:1fr;
    padding:20px;
  }
  .home-hero-copy,
  .home-hero-cover,
  .home-hero-cover img,
  .home-hero-placeholder {
    min-height:260px;
  }
  .home-category-grid {
    grid-template-columns:repeat(3,minmax(0,1fr));
    gap:16px;
  }
  .home-novel-grid {
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:16px;
  }
  .home-member-box {
    display:block;
  }
  .continue-list {
    margin-top:18px;
  }
}
@media(max-width:600px) {
  .home-hero {
    margin-top:20px;
    border-radius:20px;
  }
  .home-hero-copy h1 {
    font-size:36px;
  }
  .home-category-grid,
  .author-grid {
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:14px;
  }
  .home-novel-grid {
    grid-template-columns:repeat(2,minmax(0,1fr));
    gap:12px;
  }
  .home-category-card {
    min-height:86px;
    padding:14px;
  }
  .author-card {
    grid-template-columns:52px 1fr;
    padding:14px;
  }
  .author-avatar {
    width:52px;
    height:52px;
    border-radius:18px;
    font-size:22px;
  }
  .continue-list {
    grid-template-columns:repeat(2,74px);
  }
  .home-member-box,
  .home-seo-text {
    padding:20px;
    border-radius:20px;
  }
}

/* หน้าแรก: นิยายมาใหม่แบบรายการ List */
.home-latest-list {
  display:grid;
  grid-template-columns:repeat(2,minmax(0,1fr));
  gap:14px;
}
.home-latest-item {
  display:grid;
  grid-template-columns:86px minmax(0,1fr);
  gap:14px;
  align-items:center;
  min-height:126px;
  padding:14px;
  border-radius:18px;
  background:rgba(26,23,38,.88);
  border:1px solid var(--border);
  box-shadow:0 12px 32px rgba(0,0,0,.18);
  transition:.2s ease;
}
.home-latest-item:hover {
  transform:translateY(-3px);
  border-color:rgba(201,168,76,.35);
}
.home-latest-item img {
  width:86px;
  aspect-ratio:2/3;
  object-fit:cover;
  border-radius:12px;
  background:#20172c;
  box-shadow:0 10px 24px rgba(0,0,0,.28);
}
.home-latest-item b {
  display:block;
  color:#fff4df;
  font-size:18px;
  line-height:1.35;
  margin-bottom:6px;
}
.home-latest-item p {
  margin:0 0 7px;
  color:var(--muted);
  line-height:1.55;
  font-size:14px;
  display:-webkit-box;
  -webkit-line-clamp:2;
  -webkit-box-orient:vertical;
  overflow:hidden;
}
.home-latest-item small {
  display:block;
  color:var(--dim);
  font-size:13px;
}
@media(max-width:900px) {
  .home-latest-list {
    grid-template-columns:1fr;
  }
}
@media(max-width:600px) {
  .home-latest-item {
    grid-template-columns:72px minmax(0,1fr);
    padding:12px;
    gap:12px;
  }
  .home-latest-item img {
    width:72px;
  }
  .home-latest-item b {
    font-size:16px;
  }
  .home-latest-item p {
    -webkit-line-clamp:1;
  }
}

/* ===== Categories landing page upgrade ===== */
.cat-home-hero {
  margin: 34px 0 30px;
  min-height: 360px;
  display: grid;
  grid-template-columns: minmax(0, 1.45fr) 360px;
  gap: 24px;
  align-items: stretch;
  border: 1px solid var(--border);
  border-radius: 28px;
  overflow: hidden;
  background:
    radial-gradient(circle at 82% 20%, rgba(201,168,76,.20), transparent 28%),
    linear-gradient(135deg, rgba(139,34,82,.34), rgba(26,23,38,.92) 52%, rgba(12,11,16,.95));
  box-shadow: 0 24px 70px rgba(0,0,0,.34);
}

.cat-home-hero-content {
  padding: 44px 36px;
  display: flex;
  flex-direction: column;
  justify-content: center;
}

.cat-kicker {
  width: fit-content;
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: #ffd987;
  background: rgba(201,168,76,.10);
  border: 1px solid rgba(201,168,76,.22);
  border-radius: 999px;
  padding: 8px 14px;
  font-weight: 800;
  margin-bottom: 18px;
}

.cat-home-hero h1 {
  font-family: 'Crimson Pro', serif;
  font-size: clamp(38px, 5vw, 68px);
  line-height: 1.02;
  letter-spacing: -.8px;
  max-width: 780px;
}

.cat-home-hero p {
  max-width: 720px;
  color: #d0c1ad;
  line-height: 1.85;
  font-size: 16px;
}

.cat-hero-actions {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 20px;
}

.cat-stat-panel {
  display: grid;
  gap: 14px;
  padding: 28px;
  align-content: center;
  background: rgba(255,255,255,.04);
  border-left: 1px solid var(--border);
}

.cat-stat-panel div {
  background: rgba(12,11,16,.44);
  border: 1px solid rgba(255,255,255,.08);
  border-radius: 20px;
  padding: 22px;
}

.cat-stat-panel b {
  display: block;
  color: var(--gold2);
  font-size: 34px;
  line-height: 1;
}

.cat-stat-panel span {
  display: block;
  color: var(--muted);
  margin-top: 8px;
}

.cat-feature-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 18px;
}

.cat-feature-card,
.cat-directory-card,
.cat-latest-item,
.cat-seo-box {
  background: rgba(26,23,38,.88);
  border: 1px solid var(--border);
  box-shadow: 0 16px 38px rgba(0,0,0,.22);
}

.cat-feature-card {
  min-height: 190px;
  border-radius: 24px;
  padding: 22px;
  display: flex;
  flex-direction: column;
  justify-content: space-between;
  transition: .2s;
}

.cat-feature-card:hover,
.cat-directory-card:hover,
.cat-latest-item:hover {
  transform: translateY(-4px);
  border-color: rgba(201,168,76,.34);
}

.cat-feature-icon,
.cat-directory-icon {
  width: 48px;
  height: 48px;
  display: grid;
  place-items: center;
  border-radius: 16px;
  color: var(--gold2);
  background: linear-gradient(135deg, rgba(139,34,82,.55), rgba(201,168,76,.14));
  font-size: 24px;
}

.cat-feature-card small {
  color: #f0b4d0;
  margin-top: 18px;
}

.cat-feature-card b {
  display: block;
  font-size: 22px;
  margin: 6px 0;
}

.cat-feature-card p,
.cat-card-desc {
  color: var(--muted);
  margin: 0;
  line-height: 1.65;
}

.cat-directory-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 18px;
}

.cat-directory-card {
  border-radius: 22px;
  padding: 18px;
  transition: .2s;
}

.cat-directory-main {
  display: grid;
  grid-template-columns: 52px minmax(0, 1fr) 24px;
  gap: 14px;
  align-items: center;
}

.cat-directory-main h3 {
  margin: 0 0 4px;
  font-size: 20px;
}

.cat-directory-main p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.cat-child-list {
  display: flex;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.cat-child-list a {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 999px;
  padding: 7px 11px;
  font-size: 13px;
  background: rgba(255,255,255,.035);
}

.cat-child-list a:hover {
  color: var(--gold2);
  border-color: rgba(201,168,76,.32);
}

.cat-child-list small {
  color: var(--gold);
}

.cat-card-desc {
  margin-top: 14px;
  padding-top: 14px;
  border-top: 1px solid var(--border);
}

.cat-latest-list {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 14px;
}

.cat-latest-item {
  display: grid;
  grid-template-columns: 78px minmax(0, 1fr);
  gap: 14px;
  align-items: center;
  border-radius: 18px;
  padding: 12px;
  transition: .2s;
}

.cat-latest-item img {
  width: 78px;
  aspect-ratio: 2 / 3;
  object-fit: cover;
  border-radius: 12px;
  background: #20172c;
}

.cat-latest-item b {
  display: block;
  line-height: 1.35;
  margin-bottom: 5px;
}

.cat-latest-item span,
.cat-latest-item small {
  display: block;
  color: var(--muted);
  font-size: 13px;
  margin-top: 3px;
}

.cat-seo-box {
  border-radius: 24px;
  padding: 28px;
  margin: 34px 0 10px;
  background:
    radial-gradient(circle at top left, rgba(201,168,76,.13), transparent 30%),
    rgba(26,23,38,.88);
}

.cat-seo-box h2 {
  font-family: 'Crimson Pro', serif;
  font-size: 32px;
}

.cat-seo-box p {
  color: var(--muted);
  line-height: 1.9;
  margin: 0;
}

@media(max-width:1050px) {
  .cat-home-hero {
    grid-template-columns: 1fr;
  }

  .cat-stat-panel {
    grid-template-columns: repeat(3, 1fr);
    border-left: 0;
    border-top: 1px solid var(--border);
  }

  .cat-feature-grid,
  .cat-directory-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}

@media(max-width:700px) {
  .cat-home-hero-content,
  .cat-stat-panel,
  .cat-seo-box {
    padding: 22px;
  }

  .cat-stat-panel,
  .cat-feature-grid,
  .cat-directory-grid,
  .cat-latest-list {
    grid-template-columns: 1fr;
  }

  .cat-home-hero h1 {
    font-size: 38px;
  }
}

/* ===== Final fix: ลดขนาด Hero หน้าแรก ไม่ให้ภาพกินพื้นที่เยอะ ===== */
.home-hero {
  min-height: auto !important;
  max-height: none !important;
  padding: 22px !important;
  margin: 24px 0 26px !important;
}

.home-hero-copy {
  min-height: 300px !important;
}

.home-hero-copy h1 {
  font-size: clamp(34px, 4.4vw, 58px) !important;
  line-height: 1.06 !important;
  margin: 12px 0 12px !important;
}

.home-hero-copy p {
  font-size: 16px !important;
  line-height: 1.75 !important;
  max-width: 640px !important;
}

.home-hero-cover {
  min-height: 300px !important;
  max-height: 330px !important;
  height: 330px !important;
}

.home-hero-cover img,
.home-hero-placeholder {
  min-height: 0 !important;
  height: 100% !important;
  max-height: 330px !important;
  object-fit: cover !important;
  object-position: center center !important;
}

@media(max-width:900px) {
  .home-hero {
    padding: 18px !important;
  }

  .home-hero-copy {
    min-height: auto !important;
  }

  .home-hero-cover {
    height: 260px !important;
    min-height: 260px !important;
    max-height: 260px !important;
  }

  .home-hero-cover img,
  .home-hero-placeholder {
    max-height: 260px !important;
  }
}

@media(max-width:600px) {
  .home-hero-copy h1 {
    font-size: 32px !important;
  }

  .home-hero-cover {
    height: 220px !important;
    min-height: 220px !important;
    max-height: 220px !important;
  }

  .home-hero-cover img,
  .home-hero-placeholder {
    max-height: 220px !important;
  }
}


/* Auth helper links */
.auth-note { color: var(--muted); line-height: 1.7; margin-top: -4px; }
.auth-links { margin-top: 14px; color: var(--gold2); }
.auth-links a { color: var(--gold2); font-weight: 800; }
.auth-links a:hover { text-decoration: underline; }
.success-alert { background: rgba(45,160,90,.18); border-color: rgba(45,160,90,.42); color: #d8ffe6; }

/* ===== Admin Email / SMTP Settings ===== */
.email-settings-page .settings-head p {
  max-width: 760px;
}
.mail-card-highlight {
  border-color: rgba(93, 134, 255, .22) !important;
  background: linear-gradient(180deg, rgba(93,134,255,.08), rgba(36,40,58,.92)) !important;
}
.email-settings-form .settings-info.full {
  grid-column: 1 / -1;
  margin: 0;
}
.mail-feature-grid {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  padding: 20px;
}
.mail-feature-grid > div {
  background: #1c2130;
  border: 1px solid rgba(255,255,255,.09);
  border-radius: 14px;
  padding: 18px;
  min-height: 140px;
}
.mail-feature-grid i {
  width: 42px;
  height: 42px;
  display: grid;
  place-items: center;
  border-radius: 12px;
  background: rgba(93,134,255,.16);
  color: #7db5ff;
  font-size: 19px;
  margin-bottom: 12px;
}
.mail-feature-grid b {
  display: block;
  color: #f7f7ff;
  margin-bottom: 7px;
}
.mail-feature-grid span {
  display: block;
  color: #9aa7c7;
  font-size: 13px;
  line-height: 1.55;
}
.email-settings-page input[type="password"] {
  letter-spacing: 2px;
}
@media(max-width: 1050px) {
  .mail-feature-grid {
    grid-template-columns: repeat(2, minmax(0, 1fr));
  }
}
@media(max-width: 640px) {
  .mail-feature-grid {
    grid-template-columns: 1fr;
    padding: 16px;
  }
}

/* ===== Emergency layout fix: prevent hero/cover from overflowing to the right ===== */
html,
body {
  max-width: 100%;
  overflow-x: hidden !important;
}

body img {
  max-width: 100%;
}

main {
  width: 100%;
  max-width: 1280px;
  overflow: hidden;
}

.home-hero {
  width: 100% !important;
  max-width: 100% !important;
  min-width: 0 !important;
  grid-template-columns: minmax(0, 1.12fr) minmax(0, .88fr) !important;
  overflow: hidden !important;
}

.home-hero-copy,
.home-hero-cover {
  min-width: 0 !important;
  max-width: 100% !important;
}

.home-hero-cover {
  position: relative !important;
  display: block !important;
  width: 100% !important;
  overflow: hidden !important;
  flex: none !important;
}

.home-hero-cover img,
.home-hero-placeholder {
  position: static !important;
  display: block !important;
  width: 100% !important;
  max-width: 100% !important;
  height: 100% !important;
  object-fit: cover !important;
  object-position: center center !important;
}

.catbar {
  width: 100%;
  max-width: 100%;
  overflow-x: auto !important;
  overflow-y: hidden;
  flex-wrap: nowrap !important;
  scrollbar-width: none !important;
  -ms-overflow-style: none !important;
}

.catbar::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
  height: 0 !important;
}

.catbar a {
  flex: 0 0 auto;
}

@media (max-width: 900px) {
  main {
    padding-left: 16px;
    padding-right: 16px;
  }

  .home-hero {
    grid-template-columns: 1fr !important;
  }
}

/* ===== Fix live search dropdown layout =====
   ป้องกันผลค้นหาไหลออกมาเป็นรูปใหญ่ทับหน้าเว็บ */
.topnav {
  overflow: visible !important;
  z-index: 9999 !important;
}

.search.live-search {
  position: relative !important;
  overflow: visible !important;
  flex: 0 0 380px;
  z-index: 10000 !important;
}

.search.live-search input {
  min-width: 0;
}

.search-suggest {
  position: absolute !important;
  top: calc(100% + 10px) !important;
  right: 0 !important;
  left: auto !important;
  width: min(480px, calc(100vw - 32px)) !important;
  max-height: 70vh !important;
  overflow-y: auto !important;
  overflow-x: hidden !important;
  scrollbar-width: none !important;
  display: none !important;
  padding: 12px !important;
  border: 1px solid rgba(255,255,255,.15) !important;
  border-radius: 28px !important;
  background: rgba(18,15,25,.98) !important;
  box-shadow: 0 24px 70px rgba(0,0,0,.55) !important;
  backdrop-filter: blur(18px) !important;
  z-index: 99999 !important;
}

.search-suggest.show {
  display: block !important;
}

.search-suggest::-webkit-scrollbar {
  display: none !important;
  width: 0 !important;
}

.suggest-item {
  display: grid !important;
  grid-template-columns: 58px minmax(0, 1fr) !important;
  align-items: center !important;
  gap: 10px !important;
  width: 100% !important;
  padding: 8px !important;
  border-radius: 18px !important;
  color: var(--text) !important;
  text-decoration: none !important;
}

.suggest-item:hover {
  background: rgba(255,255,255,.07) !important;
}

.suggest-item img {
  width: 58px !important;
  min-width: 58px !important;
  max-width: 58px !important;
  height: 78px !important;
  max-height: 78px !important;
  display: block !important;
  object-fit: cover !important;
  object-position: center !important;
  border-radius: 14px !important;
  background: rgba(255,255,255,.06) !important;
}

.suggest-item span {
  display: block !important;
  min-width: 0 !important;
  overflow: hidden !important;
}

.suggest-item b {
  display: block !important;
  margin-bottom: 3px !important;
  color: #fff6e8 !important;
  font-size: 14px !important;
  line-height: 1.3 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.suggest-item small {
  display: block !important;
  color: var(--muted) !important;
  font-size: 12px !important;
  line-height: 1.35 !important;
  white-space: nowrap !important;
  overflow: hidden !important;
  text-overflow: ellipsis !important;
}

.suggest-empty {
  padding: 14px 12px !important;
  color: var(--muted) !important;
  font-size: 14px !important;
  text-align: center !important;
}

.suggest-all {
  display: block !important;
  margin-top: 6px !important;
  padding: 10px 12px !important;
  border-radius: 18px !important;
  color: var(--gold2) !important;
  text-align: center !important;
  font-weight: 700 !important;
  font-size: 13px !important;
  background: rgba(201,168,76,.08) !important;
}

@media (max-width: 900px) {
  /* ช่องค้นหาบนมือถือ: แสดง เต็มพื้นที่กลาง ระหว่าง logo กับ actions */
  .search.live-search {
    display: flex !important;
    flex: 1 1 0 !important;
    width: auto !important;
    min-width: 0 !important;
  }

  /* dropdown บนมือถือ: เต็มความกว้างหน้าจอ ชิดซ้าย */
  /* dropdown มือถือ: fixed เต็มจอ ไม่ถูก clip โดย topnav */
  .search-suggest {
    position: fixed !important;
    left: 8px !important;
    right: 8px !important;
    top: 78px !important; /* topnav 68px + gap 10px */
    width: auto !important;
    min-width: unset !important;
    border-radius: 18px !important;
    max-height: calc(100dvh - 90px) !important;
  }

  /* suggest-item ลดขนาดรูปและ font เล็กลงนิดเดียวบนมือถือ */
  .suggest-item img {
    width: 48px !important;
    min-width: 48px !important;
    max-width: 48px !important;
    height: 65px !important;
    max-height: 65px !important;
  }

  .suggest-item b {
    font-size: 13px !important;
  }

  .suggest-item small {
    font-size: 11px !important;
  }
}

/* ===== App Download Banner ===== */
.app-download-banner {
  margin: 40px 0 0;
  padding: 0 36px;
}

.app-banner-inner {
  display: flex;
  align-items: center;
  gap: 24px;
  background: linear-gradient(135deg, rgba(139,40,80,.35) 0%, rgba(30,20,50,.9) 100%);
  border: 1px solid rgba(201,168,76,.2);
  border-radius: 24px;
  padding: 28px 32px;
}

.app-banner-icon {
  font-size: 48px;
  color: var(--gold);
  flex-shrink: 0;
  line-height: 1;
}

.app-banner-text {
  flex: 1;
  min-width: 0;
}

.app-banner-text h3 {
  margin: 0 0 6px;
  font-size: 20px;
  color: #fff;
}

.app-banner-text p {
  margin: 0;
  color: var(--muted);
  font-size: 14px;
}

.app-banner-btns {
  display: flex;
  gap: 12px;
  flex-shrink: 0;
  flex-wrap: wrap;
}

.app-store-btn {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  padding: 10px 20px;
  border-radius: 14px;
  font-weight: 600;
  font-size: 15px;
  text-decoration: none;
  transition: all .2s;
  white-space: nowrap;
}

.app-store-btn i {
  font-size: 26px;
  flex-shrink: 0;
}

.app-store-btn span {
  display: flex;
  flex-direction: column;
  line-height: 1.2;
}

.app-store-btn small {
  font-size: 11px;
  font-weight: 400;
  opacity: .8;
}

.app-store-btn.playstore {
  background: #01875f;
  color: #fff;
}

.app-store-btn.playstore:hover {
  background: #017a56;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(1,135,95,.35);
}

.app-store-btn.appstore {
  background: #111;
  color: #fff;
  border: 1px solid rgba(255,255,255,.12);
}

.app-store-btn.appstore:hover {
  background: #1c1c1e;
  transform: translateY(-2px);
  box-shadow: 0 8px 20px rgba(0,0,0,.4);
}

@media (max-width: 900px) {
  .app-download-banner {
    padding: 0 16px;
    margin: 28px 0 0;
  }

  .app-banner-inner {
    flex-direction: column;
    text-align: center;
    padding: 24px 20px;
    gap: 16px;
  }

  .app-banner-icon {
    font-size: 40px;
  }

  .app-banner-btns {
    justify-content: center;
    width: 100%;
  }

  .app-store-btn {
    flex: 1;
    justify-content: center;
    min-width: 130px;
  }
}

/* ========================================================
   Novel Detail Page  (GoodNovel-style hero layout)
   ======================================================== */

/* Wrapper */
.nd-wrap {
  max-width: 1280px;
  margin: 36px auto;
  padding: 0 24px;
}

/* ---- Hero two-column grid ---- */
.nd-hero {
  display: grid;
  grid-template-columns: 320px minmax(0, 460px);
  gap: 36px;
  align-items: flex-start;
  padding: 36px 0 28px;
}

/* ---- Cover ---- */
.nd-cover-col {
  flex-shrink: 0;
}
.nd-cover {
  width: 100%;
  aspect-ratio: 3 / 4;
  border-radius: 16px;
  object-fit: cover;
  display: block;
  box-shadow: 0 16px 48px rgba(0,0,0,.55), 0 4px 12px rgba(0,0,0,.35);
}
.nd-cover-placeholder {
  background: linear-gradient(135deg,#2d1040,#8b2252);
  display: flex;
  align-items: center;
  justify-content: center;
}

/* ---- Info column ---- */
.nd-info-col {
  display: flex;
  flex-direction: column;
  gap: 10px;
}

/* Tags row */
.nd-tags {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  align-items: center;
}
.nd-tag {
  display: inline-flex;
  align-items: center;
  padding: 5px 14px;
  border-radius: 99px;
  font-size: 13px;
  font-weight: 600;
}
.nd-tag-cat {
  background: rgba(176,48,104,.22);
  color: #f0b4d0;
  border: 1px solid rgba(176,48,104,.45);
}
.nd-tag-cat:hover { background: rgba(176,48,104,.35); }
.nd-tag-date {
  color: var(--muted);
  font-size: 13px;
  font-weight: 400;
}

/* Title */
.nd-title {
  font-size: clamp(20px, 3vw, 30px);
  font-weight: 800;
  line-height: 1.3;
  margin: 4px 0 0;
  color: var(--text);
}

/* Author row */
.nd-author-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 14px;
}
.nd-label { color: var(--muted); }
.nd-author-link, .nd-author-name {
  color: var(--gold2);
  font-weight: 600;
}
.nd-author-link:hover { text-decoration: underline; }
.nd-badge {
  display: inline-block;
  padding: 3px 10px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 700;
}
.nd-badge-done {
  background: rgba(99,214,140,.15);
  color: #63d68c;
  border: 1px solid rgba(99,214,140,.35);
}

/* Language / age row */
.nd-meta-row {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  color: var(--muted);
}
.nd-age-badge {
  background: var(--card);
  border: 1px solid var(--border);
  padding: 2px 9px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 700;
  color: var(--text);
}

/* Divider */
.nd-divider {
  border: none;
  border-top: 1px solid var(--border);
  margin: 4px 0;
}

/* Stars + rating */
.nd-stats-row { display: flex; flex-direction: column; gap: 6px; }
.nd-rating-block {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.nd-rating-score {
  font-size: 28px;
  font-weight: 800;
  color: var(--gold2);
  line-height: 1;
}
.nd-stars { display: flex; gap: 1px; }
.nd-star {
  font-size: 22px;
  line-height: 1;
}
.nd-star-full  { color: #f6c64a; }
.nd-star-half  { color: #f6c64a; opacity: .55; }
.nd-star-empty { color: #4a4050; }
.nd-rating-count {
  font-size: 13px;
  color: var(--muted);
}

/* KPI pills row */
.nd-kpi-row {
  display: flex;
  gap: 24px;
  align-items: flex-end;
}
.nd-kpi {
  display: flex;
  flex-direction: column;
  align-items: center;
}
.nd-kpi-value {
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  line-height: 1.1;
}
.nd-kpi-label {
  font-size: 12px;
  color: var(--muted);
  margin-top: 1px;
}

/* Action buttons */
.nd-action-btns {
  display: flex;
  align-items: center;
  gap: 12px;
  flex-wrap: wrap;
  margin-top: 6px;
}
.nd-btn-read {
  min-width: 120px;
  justify-content: center;
  font-size: 17px;
  padding: 12px 32px;
  background: linear-gradient(135deg, #e82a85, #c0206c);
  border-radius: 99px;
  color: #fff;
  font-weight: 700;
  letter-spacing: .5px;
  transition: opacity .15s;
  text-decoration: none;
  display: inline-flex;
  align-items: center;
}
.nd-btn-read:hover { opacity: .88; }
.nd-btn-lib {
  font-size: 14px;
  padding: 11px 20px;
  border-radius: 99px;
  border: 2px solid rgba(201,168,76,.4);
  color: var(--gold2);
  background: transparent;
}
.nd-btn-lib:hover { border-color: var(--gold); }

/* Share row */
.nd-share-row {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
  margin-top: 4px;
}
.nd-share-label {
  font-size: 13px;
  color: var(--muted);
  margin-right: 2px;
}
.nd-share-btn {
  width: 38px;
  height: 38px;
  border-radius: 50%;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  border: none;
  cursor: pointer;
  transition: transform .15s, opacity .15s;
  text-decoration: none;
}
.nd-share-btn svg { width: 18px; height: 18px; }
.nd-share-btn:hover { transform: translateY(-2px); opacity: .9; }
.nd-share-fb { background: #1877f2; color: #fff; }
.nd-share-x  { background: #000; color: #fff; }
.nd-share-wa { background: #25d366; color: #fff; }
.nd-share-rd { background: #ff4500; color: #fff; }
.nd-share-copy { background: var(--card); color: var(--gold); border: 1px solid var(--border); }

/* Toolbar */
.nd-toolbar {
  display: flex;
  gap: 10px;
  flex-wrap: wrap;
  margin: 16px 0;
}

/* Description block */
.nd-description {
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: 16px;
  padding: 20px 24px;
  margin-top: 8px;
  color: var(--text);
}

/* ---- Responsive ---- */
@media (max-width: 680px) {
  .nd-hero {
    grid-template-columns: 1fr;
    gap: 20px;
  }
  .nd-cover {
    width: 180px;
    margin: 0 auto;
  }
  .nd-cover-col { text-align: center; }
  .nd-title { font-size: 20px; }
  .nd-rating-score { font-size: 22px; }
  .nd-kpi-row { gap: 16px; }
  .nd-action-btns { flex-direction: column; align-items: stretch; }
  .nd-btn-read, .nd-btn-lib { text-align: center; justify-content: center; }
}

/* ========================================================
   Lightmode overrides for nd-* novel detail elements
   ======================================================== */
.lightmode .nd-wrap,
.lightmode .nd-hero,
.lightmode .nd-info-col { color: #24180f; }
.lightmode .nd-title { color: #1a0e06; }
.lightmode .nd-tag-cat {
  background: rgba(176,48,104,.12);
  color: #8b2252;
  border-color: rgba(176,48,104,.3);
}
.lightmode .nd-tag-date,
.lightmode .nd-label,
.lightmode .nd-rating-count,
.lightmode .nd-kpi-label,
.lightmode .nd-share-label,
.lightmode .nd-meta-row { color: #6b5040; }
.lightmode .nd-author-link,
.lightmode .nd-author-name { color: #8b2252; }
.lightmode .nd-rating-score { color: #a0700a; }
.lightmode .nd-kpi-value { color: #1a0e06; }
.lightmode .nd-divider { border-color: rgba(0,0,0,.12); }
.lightmode .nd-age-badge {
  background: #e8ddd0;
  border-color: rgba(0,0,0,.15);
  color: #24180f;
}
.lightmode .nd-btn-lib {
  border-color: rgba(139,34,82,.4);
  color: #8b2252;
}
.lightmode .nd-share-copy {
  background: #e8ddd0;
  color: #8b2252;
  border-color: rgba(0,0,0,.15);
}
.lightmode .nd-description {
  background: #fff;
  border-color: rgba(0,0,0,.1);
  color: #24180f;
}
.lightmode .nd-toolbar .btn {
  border-color: rgba(139,34,82,.35);
  color: #8b2252;
}
.lightmode .rating-box {
  background: rgba(0,0,0,.04);
  border-color: rgba(139,34,82,.2);
  color: #24180f;
}
.lightmode .rating-box b { color: #a0700a; }
.lightmode .rating-box p { color: #6b5040; }
