:root {
  --bg: #f7f4ef;
  --panel: #fffaf3;
  --panel-2: #fff;
  --text: #2f241c;
  --muted: #77685d;
  --line: #e8d8c6;
  --brand: #9b4b24;
  --brand-2: #c78245;
  --brand-dark: #5d2711;
  --success: #1f8a55;
  --danger: #b42318;
  --warning: #a16207;
  --shadow: 0 18px 45px rgba(64, 38, 20, .12);
  --radius: 18px;
  --reader-size: 20px;
  --reader-width: 780px;
  color-scheme: light;
}

[data-theme="dark"] {
  --bg: #18120e;
  --panel: #211914;
  --panel-2: #291f19;
  --text: #f5eadc;
  --muted: #c5ad99;
  --line: #3d2c23;
  --brand: #f1a15e;
  --brand-2: #bf7141;
  --brand-dark: #f4c18c;
  --shadow: 0 18px 45px rgba(0, 0, 0, .35);
  color-scheme: dark;
}

* { box-sizing: border-box; }
html { scroll-behavior: smooth; }
body {
  margin: 0;
  font-family: Inter, system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;
  background: radial-gradient(circle at top left, rgba(199,130,69,.18), transparent 42%), var(--bg);
  color: var(--text);
  line-height: 1.6;
}

a { color: inherit; text-decoration: none; }
button, input, select, textarea { font: inherit; }
button { cursor: pointer; }
img { max-width: 100%; display: block; }

.site-shell { min-height: 100vh; display: flex; flex-direction: column; }
.container { width: min(1180px, calc(100% - 32px)); margin: 0 auto; }

.topbar {
  background: var(--brand-dark);
  color: #fff7eb;
  font-size: 14px;
}
.topbar-inner {
  min-height: 36px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 16px;
}
.topbar-links { display: flex; gap: 14px; flex-wrap: wrap; }

.main-header {
  position: sticky;
  top: 0;
  z-index: 50;
  background: rgba(255, 250, 243, .92);
  backdrop-filter: blur(16px);
  border-bottom: 1px solid var(--line);
}
[data-theme="dark"] .main-header { background: rgba(33, 25, 20, .92); }
.header-inner {
  min-height: 76px;
  display: grid;
  grid-template-columns: auto 1fr auto;
  align-items: center;
  gap: 18px;
}
.brand {
  display: inline-flex;
  align-items: center;
  gap: 12px;
  min-width: 220px;
}
.brand-logo { width: 44px; height: 44px; border-radius: 14px; box-shadow: var(--shadow); }
.brand-name { font-size: 24px; font-weight: 900; letter-spacing: -.04em; }
.brand-tagline { display: block; font-size: 12px; color: var(--muted); margin-top: -4px; }

.search-box {
  position: relative;
  max-width: 460px;
  margin: 0 auto;
  width: 100%;
}
.search-box input {
  width: 100%;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  border-radius: 999px;
  padding: 12px 44px 12px 18px;
  outline: none;
  box-shadow: 0 8px 24px rgba(64, 38, 20, .06);
}
.search-box svg { position: absolute; right: 16px; top: 50%; transform: translateY(-50%); color: var(--muted); }
.search-results {
  position: absolute;
  top: calc(100% + 8px);
  left: 0;
  right: 0;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 16px;
  box-shadow: var(--shadow);
  overflow: hidden;
  display: none;
  z-index: 90;
}
.search-results.active { display: block; }
.search-result-item { padding: 12px 14px; border-bottom: 1px solid var(--line); }
.search-result-item:last-child { border-bottom: 0; }
.search-result-item:hover { background: rgba(199,130,69,.12); }

.header-actions { display: flex; align-items: center; gap: 10px; }
.icon-btn, .btn {
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  border-radius: 999px;
  padding: 10px 14px;
  min-height: 42px;
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 8px;
  transition: transform .15s ease, box-shadow .15s ease, background .15s ease;
}
.icon-btn:hover, .btn:hover { transform: translateY(-1px); box-shadow: 0 10px 22px rgba(64, 38, 20, .12); }
.btn-primary { background: linear-gradient(135deg, var(--brand), var(--brand-2)); color: white; border: 0; }
.btn-danger { color: #fff; background: var(--danger); border: 0; }
.btn-muted { background: rgba(119,104,93,.1); }
.btn-small { min-height: 34px; padding: 7px 11px; font-size: 13px; }
.btn-wide { width: 100%; }

.navbar {
  background: var(--panel);
  border-bottom: 1px solid var(--line);
}
.nav-inner { display: flex; align-items: center; gap: 8px; overflow-x: auto; padding: 10px 0; }
.nav-item, .genre-toggle {
  white-space: nowrap;
  color: var(--muted);
  padding: 9px 12px;
  border-radius: 999px;
  border: 0;
  background: transparent;
}
.nav-item:hover, .genre-toggle:hover { color: var(--brand-dark); background: rgba(199,130,69,.12); }
.genre-menu { position: relative; }
.genre-panel {
  display: none;
  position: absolute;
  top: calc(100% + 10px);
  left: 0;
  width: min(780px, 92vw);
  background: var(--panel-2);
  border: 1px solid var(--line);
  box-shadow: var(--shadow);
  border-radius: 18px;
  padding: 16px;
  z-index: 80;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 8px;
}
.genre-menu:hover .genre-panel, .genre-menu:focus-within .genre-panel { display: grid; }
.genre-chip { padding: 9px 10px; border-radius: 12px; color: var(--muted); }
.genre-chip:hover { color: var(--text); background: rgba(199,130,69,.12); }

main { flex: 1; padding: 26px 0 54px; }
.hero {
  display: grid;
  grid-template-columns: minmax(0, 1.2fr) minmax(280px, .8fr);
  gap: 24px;
  align-items: stretch;
  margin-bottom: 28px;
}
.hero-card {
  position: relative;
  overflow: hidden;
  border-radius: 28px;
  border: 1px solid var(--line);
  background: linear-gradient(135deg, rgba(93,39,17,.95), rgba(155,75,36,.88)), url('../img/bg-pattern.svg');
  min-height: 320px;
  color: #fff7eb;
  padding: clamp(24px, 5vw, 48px);
  box-shadow: var(--shadow);
}
.hero-card h1 { margin: 0 0 12px; font-size: clamp(34px, 6vw, 66px); line-height: .98; letter-spacing: -.06em; }
.hero-card p { margin: 0 0 22px; max-width: 640px; color: rgba(255,247,235,.86); font-size: 18px; }
.hero-meta { display: flex; gap: 10px; flex-wrap: wrap; margin: 18px 0 0; }
.badge {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  border-radius: 999px;
  padding: 6px 10px;
  background: rgba(199,130,69,.14);
  color: var(--brand-dark);
  font-size: 13px;
  font-weight: 700;
}
.hero-card .badge { color: #fff7eb; background: rgba(255,255,255,.16); }

.panel {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
}
.panel-pad { padding: 20px; }
.section-title {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 12px;
  margin: 0 0 16px;
}
.section-title h2, .section-title h3 { margin: 0; letter-spacing: -.03em; }
.divider { height: 1px; background: var(--line); margin: 16px 0; }

.layout { display: grid; grid-template-columns: minmax(0, 1fr) 320px; gap: 24px; align-items: start; }
.story-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 16px; }
.story-card {
  display: grid;
  grid-template-columns: 112px minmax(0, 1fr);
  gap: 14px;
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 18px;
  padding: 12px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.story-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.cover { width: 112px; aspect-ratio: 3/4; border-radius: 14px; object-fit: cover; border: 1px solid var(--line); background: #ead1b9; }
.story-card h3 { margin: 0 0 6px; line-height: 1.25; font-size: 17px; }
.story-desc { margin: 8px 0; color: var(--muted); font-size: 14px; display: -webkit-box; -webkit-line-clamp: 3; -webkit-box-orient: vertical; overflow: hidden; }
.meta-line { display: flex; gap: 10px; flex-wrap: wrap; color: var(--muted); font-size: 13px; }
.card-actions { display: flex; gap: 8px; flex-wrap: wrap; margin-top: 10px; }

.list { display: grid; gap: 10px; }
.hot-item, .chapter-row, .comment-row, .admin-row {
  background: var(--panel-2);
  border: 1px solid var(--line);
  border-radius: 14px;
  padding: 12px;
}
.hot-item { display: grid; grid-template-columns: auto 1fr auto; gap: 10px; align-items: center; }
.rank { width: 30px; height: 30px; border-radius: 10px; background: rgba(155,75,36,.12); color: var(--brand-dark); display: inline-flex; align-items: center; justify-content: center; font-weight: 900; }

.story-detail {
  display: grid;
  grid-template-columns: 240px minmax(0, 1fr);
  gap: 24px;
}
.story-cover-large { width: 100%; border-radius: 22px; border: 1px solid var(--line); box-shadow: var(--shadow); background: #ead1b9; }
.story-heading h1 { margin: 0 0 10px; font-size: clamp(28px, 5vw, 44px); line-height: 1.08; letter-spacing: -.05em; }
.info-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 10px; margin: 18px 0; }
.info-cell { padding: 12px; border: 1px solid var(--line); border-radius: 14px; background: var(--panel-2); }
.info-cell b { display: block; font-size: 12px; color: var(--muted); text-transform: uppercase; letter-spacing: .06em; margin-bottom: 3px; }
.tags { display: flex; gap: 8px; flex-wrap: wrap; margin: 12px 0; }
.tag { border: 1px solid var(--line); border-radius: 999px; padding: 6px 10px; color: var(--muted); background: var(--panel-2); font-size: 13px; }
.summary { font-size: 16px; color: var(--muted); }
.story-toolbar { display: flex; gap: 10px; flex-wrap: wrap; margin: 16px 0; }
.tabs { display: flex; gap: 8px; border-bottom: 1px solid var(--line); margin-bottom: 14px; }
.tab-btn { border: 0; background: transparent; padding: 12px 14px; color: var(--muted); border-bottom: 3px solid transparent; }
.tab-btn.active { color: var(--brand-dark); border-color: var(--brand); font-weight: 800; }
.tab-panel { display: none; }
.tab-panel.active { display: block; }
.chapter-row { display: grid; grid-template-columns: 1fr auto; gap: 10px; align-items: center; }
.chapter-title { font-weight: 800; }
.chapter-time { color: var(--muted); font-size: 13px; }

.reader-wrap { width: min(var(--reader-width), calc(100% - 32px)); margin: 0 auto; }
.reader-head { text-align: center; padding: 24px 0; }
.reader-head h1 { margin: 0; font-size: clamp(26px, 5vw, 42px); line-height: 1.1; letter-spacing: -.04em; }
.reader-controls { display: flex; align-items: center; justify-content: center; gap: 10px; flex-wrap: wrap; margin-top: 14px; }
.reader-content {
  background: var(--panel);
  border: 1px solid var(--line);
  border-radius: 24px;
  box-shadow: var(--shadow);
  padding: clamp(20px, 4vw, 44px);
  font-family: Georgia, "Times New Roman", serif;
  font-size: var(--reader-size);
  line-height: 1.9;
}
.reader-content p { margin: 0 0 1.2em; }
.reader-nav { display: flex; align-items: center; justify-content: space-between; gap: 12px; margin-top: 18px; }

.gate {
  background: linear-gradient(135deg, rgba(255,250,243,.96), rgba(255,255,255,.9));
  border: 1px solid var(--line);
  border-radius: 26px;
  box-shadow: var(--shadow);
  padding: clamp(22px, 4vw, 36px);
  text-align: center;
}
[data-theme="dark"] .gate { background: linear-gradient(135deg, rgba(33,25,20,.96), rgba(41,31,25,.9)); }
.gate h2 { margin: 0 0 8px; font-size: clamp(26px, 5vw, 40px); letter-spacing: -.04em; }
.gate p { color: var(--muted); margin: 0 auto 16px; max-width: 680px; }
.affiliate-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; margin: 20px 0; text-align: left; }
.affiliate-card {
  display: grid;
  grid-template-columns: 74px 1fr;
  gap: 12px;
  align-items: center;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-2);
  padding: 14px;
  transition: transform .15s ease, box-shadow .15s ease;
}
.affiliate-card:hover { transform: translateY(-2px); box-shadow: var(--shadow); }
.affiliate-card img { width: 74px; height: 74px; border-radius: 16px; background: rgba(199,130,69,.1); }
.affiliate-card h3 { margin: 0 0 4px; font-size: 16px; }
.affiliate-card p { margin: 0 0 10px; font-size: 13px; }
.unlock-status { margin: 12px 0 0; font-weight: 800; color: var(--warning); }
.unlock-status.done { color: var(--success); }
.notice-box { border: 1px dashed var(--line); background: rgba(199,130,69,.1); border-radius: 16px; padding: 12px; color: var(--muted); font-size: 14px; }

.footer { border-top: 1px solid var(--line); background: var(--panel); padding: 26px 0; color: var(--muted); }
.footer-inner { display: flex; justify-content: space-between; gap: 20px; flex-wrap: wrap; }

.admin-layout { display: grid; grid-template-columns: 300px minmax(0, 1fr); gap: 20px; align-items: start; }
.form-grid { display: grid; gap: 12px; }
.form-grid label { display: grid; gap: 5px; color: var(--muted); font-size: 13px; }
.form-grid input, .form-grid textarea, .form-grid select {
  width: 100%;
  border: 1px solid var(--line);
  border-radius: 12px;
  background: var(--panel-2);
  color: var(--text);
  padding: 10px 12px;
  outline: none;
}
.form-grid textarea { min-height: 88px; resize: vertical; }
.table-wrap { overflow-x: auto; }
.admin-table { width: 100%; border-collapse: collapse; min-width: 820px; }
.admin-table th, .admin-table td { border-bottom: 1px solid var(--line); padding: 10px; text-align: left; vertical-align: top; }
.admin-table th { font-size: 12px; text-transform: uppercase; letter-spacing: .05em; color: var(--muted); background: rgba(199,130,69,.08); }
.status-pill { display: inline-flex; align-items: center; border-radius: 999px; padding: 4px 8px; font-size: 12px; font-weight: 800; }
.status-active { background: rgba(31,138,85,.14); color: var(--success); }
.status-paused { background: rgba(162,98,7,.14); color: var(--warning); }
.admin-toolbar { display: flex; flex-wrap: wrap; gap: 10px; margin: 14px 0; }
.codebox { width: 100%; min-height: 220px; font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; font-size: 12px; }

.test-layout { display: grid; grid-template-columns: 360px minmax(0, 1fr); gap: 20px; align-items: start; }
.test-chapter-row {
  width: 100%;
  text-align: left;
  display: grid;
  grid-template-columns: minmax(0, 1fr) auto;
  align-items: center;
  gap: 10px;
  border: 1px solid var(--line);
  background: var(--panel-2);
  color: var(--text);
  border-radius: 14px;
  padding: 12px;
}
.test-chapter-row:hover, .test-chapter-row.active { background: rgba(199,130,69,.14); border-color: rgba(155,75,36,.35); }
.test-chapter-row small { color: var(--muted); }
.affiliate-grid-single { grid-template-columns: minmax(0, 680px); justify-content: center; }
.notice-box code { word-break: break-all; color: var(--text); font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace; }

.empty { color: var(--muted); padding: 14px; border: 1px dashed var(--line); border-radius: 14px; }
.hidden { display: none !important; }

@media (max-width: 980px) {
  .header-inner { grid-template-columns: 1fr auto; }
  .search-box { grid-column: 1 / -1; max-width: none; order: 3; }
  .hero, .layout, .story-detail, .admin-layout, .test-layout { grid-template-columns: 1fr; }
  .story-grid { grid-template-columns: 1fr; }
  .story-cover-large { max-width: 260px; }
  .affiliate-grid { grid-template-columns: 1fr; }
}

@media (max-width: 620px) {
  .container { width: min(100% - 20px, 1180px); }
  .topbar-inner, .footer-inner { flex-direction: column; align-items: flex-start; padding: 8px 0; }
  .brand { min-width: 0; }
  .brand-name { font-size: 20px; }
  .header-actions .btn span { display: none; }
  .genre-panel { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .story-card { grid-template-columns: 88px minmax(0, 1fr); }
  .cover { width: 88px; }
  .info-grid { grid-template-columns: 1fr; }
  .chapter-row { grid-template-columns: 1fr; }
  .reader-nav { flex-direction: column; }
  .reader-nav .btn { width: 100%; }
}

.auth-user {
  opacity: .92;
  font-weight: 700;
}
.topbar-button {
  border: 1px solid rgba(255,255,255,.24);
  background: rgba(255,255,255,.1);
  color: #fff7eb;
  border-radius: 999px;
  padding: 3px 10px;
  min-height: 26px;
}
.topbar-button:hover { background: rgba(255,255,255,.18); }
.auth-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 420px;
  gap: 20px;
  align-items: start;
}
.auth-card {
  width: min(760px, 100%);
  margin: 0 auto;
}
.auth-card h1 {
  margin: 8px 0 10px;
  font-size: clamp(30px, 5vw, 48px);
  line-height: 1.05;
  letter-spacing: -.05em;
}
.auth-card p { color: var(--muted); }
.auth-table { min-width: 360px; }
.auth-table code {
  font-family: ui-monospace, SFMono-Regular, Menlo, Consolas, monospace;
  background: rgba(199,130,69,.12);
  border-radius: 8px;
  padding: 2px 6px;
}
@media (max-width: 980px) {
  .auth-layout { grid-template-columns: 1fr; }
}


/* Chapter affiliate lock management */
.lock-admin-panel {
  margin-top: 18px;
  padding: 16px;
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(199,130,69,.07);
}
.bulk-grid {
  display: grid;
  grid-template-columns: 1.5fr repeat(3, minmax(120px, 1fr));
  gap: 12px;
  margin: 14px 0;
}
.inline-check {
  display: inline-flex;
  align-items: center;
  gap: 8px;
  color: var(--muted);
  font-size: 13px;
}
.inline-check input {
  width: 18px;
  height: 18px;
  accent-color: var(--brand);
}
.chapter-lock-table td:nth-child(1) { min-width: 170px; }
.chapter-lock-table td:nth-child(3) { min-width: 260px; }
.chapter-row-right {
  display: inline-flex;
  align-items: center;
  gap: 10px;
  flex-shrink: 0;
}
.chapter-lock-state {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 800;
  white-space: nowrap;
}
.chapter-lock-state.is-locked {
  color: #7a2e0e;
  background: rgba(199,130,69,.18);
}
.chapter-lock-state.is-open {
  color: var(--success);
  background: rgba(31,138,85,.12);
}
@media (max-width: 980px) {
  .bulk-grid { grid-template-columns: 1fr; }
  .chapter-row-right { align-items: flex-end; flex-direction: column; gap: 4px; }
}

/* Taxonomy / author management */
.nav-item.active { color: var(--brand-dark); background: rgba(199,130,69,.15); font-weight: 800; }
.compact-panel { width: min(420px, 92vw); grid-template-columns: repeat(2, minmax(0, 1fr)); }
.taxonomy-section { margin-bottom: 24px; }
.taxonomy-grid {
  display: grid;
  grid-template-columns: repeat(3, minmax(0, 1fr));
  gap: 12px;
}
.taxonomy-list { display: grid; gap: 10px; }
.taxonomy-card {
  display: grid;
  gap: 4px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-2);
  padding: 12px;
}
.taxonomy-card:hover { box-shadow: var(--shadow); transform: translateY(-1px); }
.taxonomy-card span { color: var(--brand-dark); font-weight: 800; font-size: 13px; }
.taxonomy-card small { color: var(--muted); }
.author-grid { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 14px; }
.author-card {
  display: grid;
  grid-template-columns: 82px minmax(0, 1fr);
  gap: 14px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-2);
  padding: 14px;
}
.author-card img, .author-profile > img {
  width: 82px;
  height: 82px;
  border-radius: 22px;
  border: 1px solid var(--line);
  background: rgba(199,130,69,.12);
  object-fit: cover;
}
.author-card h2 { margin: 0 0 4px; font-size: 20px; letter-spacing: -.03em; }
.author-card p { margin: 8px 0 0; color: var(--muted); }
.author-profile {
  display: grid;
  grid-template-columns: 104px minmax(0, 1fr);
  gap: 20px;
  align-items: center;
}
.author-profile > img { width: 104px; height: 104px; }
.author-profile h1 { margin: 4px 0 10px; font-size: clamp(34px, 5vw, 56px); line-height: 1.05; letter-spacing: -.06em; }
.taxonomy-admin-grid {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 16px;
  align-items: start;
}
.mini-admin-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: rgba(199,130,69,.06);
  padding: 14px;
}
.mini-admin-card h3 { margin: 0 0 12px; }
.compact-form { margin-bottom: 12px; }
.compact-table { min-width: 520px; }
.story-class-form {
  display: grid;
  grid-template-columns: repeat(2, minmax(0, 1fr));
  gap: 12px;
}
.story-class-form button { align-self: end; }
@media (max-width: 980px) {
  .taxonomy-grid, .author-grid, .taxonomy-admin-grid, .story-class-form { grid-template-columns: 1fr; }
  .author-profile { grid-template-columns: 1fr; }
}
@media (max-width: 620px) {
  .compact-panel { grid-template-columns: 1fr; }
  .author-card { grid-template-columns: 64px minmax(0, 1fr); }
  .author-card img { width: 64px; height: 64px; border-radius: 18px; }
}

/* Ranking, fanpage and account modules */
.muted-inline { color: var(--muted); font-size: 12px; font-weight: 400; }
.stats-strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0, 1fr));
  gap: 14px;
  margin: 0 0 24px;
}
.stat-card {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 16px;
  display: grid;
  gap: 2px;
  min-height: 86px;
  box-shadow: 0 10px 24px rgba(64, 38, 20, .06);
}
.stat-card b { font-size: 28px; line-height: 1; letter-spacing: -.04em; color: var(--brand-dark); }
.stat-card span { color: var(--muted); font-size: 13px; }
.ranking-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 340px;
  gap: 24px;
  align-items: start;
  margin-top: 24px;
}
.ranking-table td:nth-child(1) { width: 70px; }
.ranking-table td:nth-child(3), .ranking-table td:nth-child(4), .ranking-table td:nth-child(5), .ranking-table td:nth-child(6), .ranking-table td:nth-child(7) { white-space: nowrap; }
.fanpage-box {
  border: 1px solid var(--line);
  border-radius: var(--radius);
  background: var(--panel-2);
  padding: 14px;
}
.fanpage-box p { margin: 0 0 12px; color: var(--muted); font-size: 14px; }
.fanpage-box iframe { border-radius: 14px; background: rgba(199,130,69,.08); margin-bottom: 12px; }
.mini-stats {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin: 10px 0;
}
.mini-stats span {
  border: 1px solid var(--line);
  border-radius: 999px;
  background: rgba(199,130,69,.08);
  color: var(--muted);
  font-size: 12px;
  padding: 4px 8px;
}
.account-hero {
  display: grid;
  grid-template-columns: minmax(0, 1fr) minmax(360px, .8fr);
  gap: 20px;
  align-items: center;
  margin-bottom: 24px;
}
.account-hero h1 {
  margin: 6px 0;
  font-size: clamp(34px, 5vw, 56px);
  line-height: 1.05;
  letter-spacing: -.06em;
}
.account-hero p { color: var(--muted); margin: 0; }
.account-stats { display: grid; grid-template-columns: repeat(2, minmax(0, 1fr)); gap: 12px; }
.account-layout {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 380px;
  gap: 24px;
  align-items: start;
}
.account-tabs { overflow-x: auto; }
.account-story-row {
  display: grid;
  grid-template-columns: 74px minmax(0, 1fr);
  gap: 12px;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-2);
  padding: 12px;
  margin-bottom: 10px;
}
.account-story-row img {
  width: 74px;
  aspect-ratio: 3/4;
  border-radius: 12px;
  border: 1px solid var(--line);
  object-fit: cover;
}
.account-story-row small { display: block; color: var(--muted); margin-top: 3px; }
@media (max-width: 980px) {
  .stats-strip, .ranking-grid, .account-hero, .account-layout { grid-template-columns: 1fr; }
  .account-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
}
@media (max-width: 620px) {
  .stats-strip, .account-stats { grid-template-columns: 1fr; }
  .account-story-row { grid-template-columns: 58px minmax(0, 1fr); }
  .account-story-row img { width: 58px; }
}

/* V7 account dropdown, publishing workspace and category shelves */
.account-menu { position: relative; }
.account-menu-panel {
  position: absolute;
  top: calc(100% + 10px);
  right: 0;
  width: min(260px, 86vw);
  display: none;
  z-index: 120;
  padding: 10px;
  border: 1px solid var(--line);
  border-radius: 18px;
  background: var(--panel-2);
  box-shadow: var(--shadow);
}
.account-menu.open .account-menu-panel { display: grid; gap: 6px; }
.account-menu-panel a, .account-menu-panel button {
  width: 100%;
  border: 0;
  border-radius: 12px;
  background: transparent;
  color: var(--text);
  text-align: left;
  padding: 10px 12px;
}
.account-menu-panel a:hover, .account-menu-panel button:hover { background: rgba(199,130,69,.12); }
.account-menu-head {
  display: grid;
  gap: 2px;
  padding: 10px 12px;
  border-bottom: 1px solid var(--line);
  margin-bottom: 4px;
}
.account-menu-head small { color: var(--muted); }
.home-category-block { display: grid; gap: 26px; margin-top: 30px; }
.category-shelf {
  border: 1px solid var(--line);
  border-radius: 24px;
  padding: 22px;
  background: radial-gradient(circle at top left, rgba(199,130,69,.18), transparent 32%), var(--panel);
  box-shadow: var(--shadow);
}
.category-shelf-head {
  display: flex;
  align-items: end;
  justify-content: space-between;
  gap: 16px;
  margin-bottom: 16px;
}
.category-shelf-head h2 { margin: 0; font-size: clamp(28px, 4vw, 44px); line-height: 1; letter-spacing: -.05em; }
.category-shelf-head a { color: var(--brand); font-weight: 800; }
.shelf-eyebrow { color: var(--muted); font-size: 13px; font-weight: 800; text-transform: uppercase; letter-spacing: .08em; }
.compact-story-grid {
  display: grid;
  grid-template-columns: repeat(5, minmax(0, 1fr));
  gap: 14px;
}
.compact-story-tile {
  display: grid;
  gap: 8px;
  min-width: 0;
}
.tile-cover-wrap {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  border-radius: 16px;
  border: 1px solid var(--line);
  background: rgba(199,130,69,.1);
}
.tile-cover-wrap img { width: 100%; height: 100%; object-fit: cover; }
.tile-cover-wrap em {
  position: absolute;
  top: 8px;
  left: 8px;
  border-radius: 7px;
  background: rgba(31,138,85,.88);
  color: #fff;
  font-size: 11px;
  font-style: normal;
  font-weight: 900;
  padding: 3px 6px;
}
.compact-story-tile strong { line-height: 1.25; display: -webkit-box; -webkit-line-clamp: 2; -webkit-box-orient: vertical; overflow: hidden; }
.compact-story-tile small, .tile-meta { color: var(--muted); font-size: 12px; }
.publish-form { grid-template-columns: repeat(2, minmax(0, 1fr)); align-items: start; }
.publish-form .span-2, .span-2 { grid-column: 1 / -1; }
.manage-story-row {
  display: grid;
  grid-template-columns: 84px minmax(0, 1fr);
  gap: 12px;
  align-items: start;
  border: 1px solid var(--line);
  border-radius: 16px;
  background: var(--panel-2);
  padding: 12px;
  margin-bottom: 10px;
}
.manage-story-row img {
  width: 84px;
  aspect-ratio: 3/4;
  border-radius: 12px;
  border: 1px solid var(--line);
  object-fit: cover;
  background: rgba(199,130,69,.1);
}
.manage-story-row small { display: block; color: var(--muted); margin-top: 4px; }
.editor-shell {
  border: 1px solid var(--line);
  border-radius: 16px;
  overflow: hidden;
  background: var(--panel-2);
}
.editor-toolbar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  padding: 10px;
  border-bottom: 1px solid var(--line);
  background: rgba(199,130,69,.08);
}
.editor-toolbar button {
  border: 1px solid var(--line);
  border-radius: 10px;
  background: var(--panel-2);
  color: var(--text);
  padding: 7px 10px;
}
.editor-toolbar button:hover { background: rgba(199,130,69,.16); }
.rich-editor {
  min-height: 340px;
  padding: 22px;
  outline: none;
  color: var(--text);
  font-family: Georgia, "Times New Roman", serif;
  font-size: 19px;
  line-height: 1.9;
}
.rich-editor h2 { font-family: inherit; font-size: 30px; line-height: 1.25; margin: 18px 0 10px; }
.rich-editor blockquote { border-left: 4px solid var(--brand); margin: 16px 0; padding: 8px 14px; background: rgba(199,130,69,.09); color: var(--muted); }
.reader-content h2 { font-size: calc(var(--reader-size) * 1.45); line-height: 1.35; }
.reader-content blockquote { border-left: 4px solid var(--brand); margin: 20px 0; padding: 8px 18px; background: rgba(199,130,69,.09); color: var(--muted); }
.reader-content ul, .reader-content ol { padding-left: 1.4em; }
@media (max-width: 1100px) { .compact-story-grid { grid-template-columns: repeat(4, minmax(0, 1fr)); } }
@media (max-width: 820px) { .compact-story-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } .publish-form { grid-template-columns: 1fr; } }
@media (max-width: 560px) { .compact-story-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } .manage-story-row { grid-template-columns: 62px minmax(0, 1fr); } .manage-story-row img { width: 62px; } }

/* V8 mobile-first responsive fixes */
html, body { width: 100%; max-width: 100%; }
body { overflow-x: hidden; }
.site-shell { width: 100%; max-width: 100%; overflow-x: hidden; }
.mobile-menu-btn { display: none; }
.mobile-nav-backdrop { display: none; }
.header-actions { min-width: 0; }
.account-menu .btn span {
  max-width: 140px;
  overflow: hidden;
  text-overflow: ellipsis;
  white-space: nowrap;
}

@media (max-width: 980px) {
  body.mobile-nav-open { overflow: hidden; }
  .container { width: min(100% - 20px, 1180px); }
  main { padding: 16px 0 38px; }
  .topbar { display: none; }
  .main-header { position: sticky; top: 0; }
  .header-inner {
    min-height: auto;
    display: grid;
    grid-template-columns: minmax(0, 1fr) auto;
    gap: 10px;
    padding: 10px 0;
  }
  .brand {
    min-width: 0;
    gap: 9px;
    overflow: hidden;
  }
  .brand-logo { width: 38px; height: 38px; border-radius: 12px; flex: 0 0 auto; }
  .brand-name {
    display: block;
    max-width: 46vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 18px;
  }
  .brand-tagline {
    max-width: 46vw;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
    font-size: 10px;
  }
  .search-box {
    grid-column: 1 / -1;
    order: 3;
    max-width: none;
  }
  .search-box input { min-height: 44px; padding: 10px 42px 10px 14px; }
  .header-actions {
    justify-content: flex-end;
    gap: 6px;
    min-width: 0;
  }
  .mobile-menu-btn { display: inline-flex; }
  .icon-btn {
    width: 40px;
    min-width: 40px;
    min-height: 40px;
    padding: 0;
  }
  .header-actions > a.btn:not(.btn-primary) { display: none; }
  .header-actions > .btn-primary { display: none; }
  .account-menu .btn {
    min-height: 40px;
    padding: 8px 10px;
    max-width: 112px;
  }
  .account-menu .btn span {
    display: inline !important;
    max-width: 74px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .account-menu-panel {
    position: fixed;
    top: 72px;
    right: 10px;
    width: min(280px, calc(100vw - 20px));
  }
  .navbar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(86vw, 330px);
    height: 100dvh;
    z-index: 180;
    border-right: 1px solid var(--line);
    border-bottom: 0;
    background: var(--panel);
    transform: translateX(-105%);
    transition: transform .2s ease;
    box-shadow: var(--shadow);
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  body.mobile-nav-open .navbar { transform: translateX(0); }
  .mobile-nav-backdrop {
    position: fixed;
    inset: 0;
    z-index: 170;
    background: rgba(47,36,28,.45);
    backdrop-filter: blur(2px);
  }
  body.mobile-nav-open .mobile-nav-backdrop { display: block; }
  .nav-inner {
    width: 100%;
    display: grid;
    gap: 6px;
    overflow: visible;
    padding: 16px 12px 28px;
  }
  .nav-inner::before {
    content: "Menu";
    display: block;
    color: var(--muted);
    font-size: 12px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .12em;
    padding: 4px 10px 8px;
  }
  .nav-item,
  .genre-toggle {
    width: 100%;
    text-align: left;
    border-radius: 12px;
    padding: 11px 12px;
    background: var(--panel-2);
    border: 1px solid var(--line);
    color: var(--text);
  }
  .genre-menu { width: 100%; }
  .genre-panel,
  .compact-panel {
    position: static;
    width: 100%;
    display: none;
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 8px;
    margin-top: 6px;
    box-shadow: none;
    border-radius: 14px;
  }
  .genre-menu:hover .genre-panel { display: none; }
  .genre-menu.open .genre-panel { display: grid; }
  .genre-chip { padding: 10px 12px; border-radius: 10px; background: rgba(199,130,69,.08); }
  .hero { gap: 14px; margin-bottom: 18px; }
  .hero-card { min-height: 260px; border-radius: 20px; }
  .panel-pad { padding: 14px; }
  .layout { gap: 16px; }
  .section-title { align-items: flex-start; flex-direction: column; gap: 8px; }
  .section-title .btn, .section-title a { align-self: flex-start; }
  .story-grid { gap: 12px; }
  .story-card {
    grid-template-columns: 82px minmax(0, 1fr);
    gap: 10px;
    padding: 10px;
    border-radius: 16px;
  }
  .cover { width: 82px; border-radius: 12px; }
  .story-card h3 { font-size: 15px; }
  .story-desc { -webkit-line-clamp: 2; font-size: 13px; }
  .meta-line { gap: 6px; font-size: 12px; }
  .card-actions .btn { min-height: 34px; padding: 7px 10px; font-size: 13px; }
  .tags { gap: 6px; }
  .tag, .badge { font-size: 12px; padding: 5px 8px; }
  .hot-item { grid-template-columns: auto minmax(0, 1fr); }
  .hot-item > :last-child { grid-column: 2; justify-self: start; }
  .story-detail { gap: 16px; }
  .story-cover-large { max-width: 210px; justify-self: center; }
  .story-toolbar .btn { flex: 1 1 140px; }
  .tabs { overflow-x: auto; white-space: nowrap; }
  .tab-btn { padding: 10px 12px; }
  .affiliate-card { grid-template-columns: 58px minmax(0, 1fr); padding: 12px; }
  .affiliate-card img { width: 58px; height: 58px; border-radius: 12px; }
  .reader-wrap { width: min(100% - 20px, var(--reader-width)); }
  .reader-content { border-radius: 18px; line-height: 1.85; }
  .admin-layout,
  .test-layout,
  .ranking-grid,
  .account-layout,
  .account-hero,
  .auth-layout { gap: 16px; }
  .admin-toolbar .btn,
  .admin-toolbar button { flex: 1 1 150px; }
  .table-wrap { width: 100%; overflow-x: auto; -webkit-overflow-scrolling: touch; }
  .admin-table { min-width: 680px; }
  .form-grid input,
  .form-grid textarea,
  .form-grid select { min-height: 44px; }
  .category-shelf { padding: 16px; border-radius: 18px; }
  .category-shelf-head { align-items: flex-start; flex-direction: column; gap: 8px; }
  .category-shelf-head h2 { font-size: 30px; }
  .compact-story-grid {
    display: flex;
    overflow-x: auto;
    gap: 12px;
    padding: 2px 2px 8px;
    scroll-snap-type: x proximity;
    -webkit-overflow-scrolling: touch;
  }
  .compact-story-tile {
    flex: 0 0 132px;
    scroll-snap-align: start;
  }
  .publish-form { grid-template-columns: 1fr; }
  .rich-editor { min-height: 260px; padding: 16px; font-size: 18px; }
  .editor-toolbar { overflow-x: auto; flex-wrap: nowrap; }
  .editor-toolbar button { white-space: nowrap; }
  .account-stats { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .footer { padding: 20px 0 calc(20px + env(safe-area-inset-bottom)); }
}

@media (max-width: 430px) {
  .container { width: min(100% - 16px, 1180px); }
  .brand-name, .brand-tagline { max-width: 38vw; }
  .account-menu .btn { max-width: 92px; }
  .account-menu .btn span { max-width: 54px; }
  .story-card { grid-template-columns: 72px minmax(0, 1fr); }
  .cover { width: 72px; }
  .story-desc { display: none; }
  .card-actions .btn { flex: 1 1 auto; }
  .compact-story-tile { flex-basis: 118px; }
  .account-stats { grid-template-columns: 1fr; }
  .reader-controls .btn, .reader-controls button { flex: 1 1 42%; }
}
.mobile-nav-close-btn { display: none; }
@media (max-width: 980px) {
  .mobile-nav-close-btn {
    display: flex;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 44px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--brand), var(--brand-2));
    color: #fff;
    padding: 10px 12px;
    font-weight: 900;
  }
  .nav-inner::before { display: none; }
}


/* V9: stronger tablet/mobile navigation and readable action labels */
.icon-btn .action-label { display: inline; font-size: 13px; font-weight: 800; line-height: 1; }
.icon-btn { white-space: nowrap; }
@media (min-width: 981px) {
  .mobile-menu-btn { display: none !important; }
}
@media (max-width: 980px) {
  .mobile-menu-btn { display: inline-flex !important; }
  .topbar { display: none !important; }
  .header-actions {
    display: flex;
    align-items: center;
    justify-content: flex-end;
    gap: 6px;
    flex-wrap: nowrap;
  }
  .icon-btn {
    width: auto !important;
    min-width: 44px !important;
    min-height: 40px;
    padding: 0 10px !important;
    gap: 6px;
    border-radius: 999px;
  }
  .theme-toggle-btn { min-width: 58px !important; }
  .account-menu .btn {
    min-height: 40px;
    padding: 8px 10px;
    max-width: 120px;
  }
  .account-menu .btn span {
    display: inline !important;
    max-width: 82px;
    overflow: hidden;
    text-overflow: ellipsis;
    white-space: nowrap;
  }
  .navbar {
    position: fixed;
    inset: 0 auto 0 0;
    width: min(86vw, 330px);
    height: 100dvh;
    z-index: 180;
    border-right: 1px solid var(--line);
    border-bottom: 0;
    background: var(--panel);
    transform: translateX(-105%);
    transition: transform .2s ease;
    box-shadow: var(--shadow);
    overflow-y: auto;
    overscroll-behavior: contain;
  }
  body.mobile-nav-open .navbar { transform: translateX(0); }
  .mobile-nav-backdrop {
    position: fixed;
    inset: 0;
    z-index: 170;
    background: rgba(47,36,28,.45);
    backdrop-filter: blur(2px);
  }
  body.mobile-nav-open .mobile-nav-backdrop { display: block; }
  .nav-inner {
    width: 100%;
    display: grid;
    gap: 6px;
    overflow: visible;
    padding: 16px 12px 28px;
  }
  .mobile-nav-close-btn {
    display: flex !important;
    align-items: center;
    justify-content: space-between;
    width: 100%;
    min-height: 44px;
    border: 0;
    border-radius: 14px;
    background: linear-gradient(135deg, var(--brand), var(--brand-2));
    color: #fff;
    padding: 10px 12px;
    font-weight: 900;
  }
  .nav-item,
  .genre-toggle {
    width: 100%;
    text-align: left;
    border-radius: 12px;
    padding: 11px 12px;
    background: var(--panel-2);
    border: 1px solid var(--line);
    color: var(--text);
  }
  .genre-menu { width: 100%; }
  .genre-panel,
  .compact-panel {
    position: static;
    width: 100%;
    display: none;
    grid-template-columns: 1fr;
    gap: 6px;
    padding: 8px;
    margin-top: 6px;
    box-shadow: none;
    border-radius: 14px;
  }
  .genre-menu:hover .genre-panel { display: none; }
  .genre-menu.open .genre-panel { display: grid; }
}
@media (max-width: 430px) {
  .brand-name, .brand-tagline { max-width: 34vw; }
  .icon-btn .action-label { font-size: 12px; }
  .icon-btn { padding: 0 8px !important; }
  .theme-toggle-btn .theme-action-label { max-width: 28px; overflow: hidden; }
  .account-menu .btn { max-width: 102px; }
  .account-menu .btn span { max-width: 62px; }
}

/* V9: admin account management */
.role-pill {
  display: inline-flex;
  align-items: center;
  border-radius: 999px;
  padding: 4px 8px;
  font-size: 12px;
  font-weight: 800;
  background: rgba(199,130,69,.14);
  color: var(--brand-dark);
}
.user-admin-grid {
  display: grid;
  grid-template-columns: minmax(0, 1fr) 320px;
  gap: 18px;
  align-items: start;
}
.user-admin-table select,
.user-admin-table input[type="checkbox"] { accent-color: var(--brand); }
.user-admin-actions { display: flex; flex-wrap: wrap; gap: 8px; }
.user-admin-note { margin-top: 12px; }
@media (max-width: 980px) {
  .user-admin-grid { grid-template-columns: 1fr; }
  .user-admin-actions .btn { flex: 1 1 140px; }
}

/* V10: mobile fix for login/register/account forms */
html, body { max-width: 100%; overflow-x: hidden; }
main[data-main].container,
.auth-layout,
.auth-layout > *,
.auth-card,
.auth-card.panel,
.form-grid,
.form-grid label,
.table-wrap { min-width: 0; max-width: 100%; }
.auth-layout { width: 100%; }
.auth-card { width: 100%; }
.auth-layout > aside { min-width: 0; overflow: hidden; }
.form-grid input,
.form-grid textarea,
.form-grid select {
  width: 100%;
  max-width: 100%;
  min-width: 0;
}
.form-grid button[type="submit"],
.auth-card .btn,
.auth-layout .btn {
  max-width: 100%;
  white-space: normal;
  text-align: center;
  justify-content: center;
}
.auth-card h1,
.auth-card p,
.auth-card label,
.unlock-status { overflow-wrap: anywhere; }

@media (max-width: 600px) {
  main[data-main].container {
    width: 100%;
    padding: 14px 10px 22px;
    margin: 0 auto;
  }
  .auth-layout {
    display: block;
    grid-template-columns: none;
  }
  .auth-layout > * + * { margin-top: 14px; }
  .auth-card.panel,
  .auth-layout > aside.panel {
    border-radius: 18px;
    box-shadow: 0 10px 28px rgba(64, 38, 20, .10);
  }
  .auth-card.panel-pad,
  .auth-layout > aside.panel-pad { padding: 16px; }
  .auth-card h1 {
    font-size: clamp(28px, 8vw, 36px);
    line-height: 1.12;
    letter-spacing: -.045em;
  }
  .auth-card p { font-size: 15px; }
  .auth-card .form-grid { gap: 10px; }
  .auth-card .form-grid input,
  .auth-card .form-grid select,
  .auth-card .form-grid textarea {
    min-height: 52px;
    font-size: 16px;
    padding: 12px 14px;
    border-radius: 14px;
  }
  .auth-card .form-grid button[type="submit"] {
    width: 100%;
    min-height: 52px;
    padding: 12px 14px;
    border-radius: 999px;
  }
  .auth-card .btn-wide { width: 100%; }
  .auth-layout .table-wrap {
    width: 100%;
    max-width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
  }
  .auth-table { min-width: 560px; }
}

@media (max-width: 380px) {
  main[data-main].container { padding-left: 8px; padding-right: 8px; }
  .auth-card.panel-pad,
  .auth-layout > aside.panel-pad { padding: 14px; }
  .auth-card h1 { font-size: 28px; }
}

/* V11: universal portrait-phone overflow and card-fit fixes
   Goal: every visible box must shrink/wrap inside 320px-480px portrait screens. */
@media (max-width: 700px) and (orientation: portrait) {
  html, body,
  .site-shell,
  [data-main],
  .container,
  .layout,
  .layout > *,
  .panel,
  .panel-pad,
  .story-detail,
  .story-heading,
  .story-toolbar,
  .tabs,
  .tab-panel,
  .list,
  .chapter-row,
  .hot-item,
  .fanpage-box,
  .story-grid,
  .story-card,
  .category-shelf,
  .account-layout,
  .auth-layout,
  .ranking-grid,
  .admin-layout,
  .test-layout,
  .taxonomy-grid,
  .author-grid,
  .taxonomy-admin-grid,
  .story-class-form {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  body {
    overflow-x: hidden !important;
  }

  .container,
  main[data-main].container {
    width: 100% !important;
    max-width: 100vw !important;
    padding-left: max(10px, env(safe-area-inset-left)) !important;
    padding-right: max(10px, env(safe-area-inset-right)) !important;
    margin-left: auto !important;
    margin-right: auto !important;
  }

  main[data-main].container {
    padding-top: 14px !important;
    padding-bottom: 34px !important;
  }

  .layout,
  .story-detail,
  .auth-layout,
  .ranking-grid,
  .account-layout,
  .account-hero,
  .admin-layout,
  .test-layout,
  .taxonomy-admin-grid,
  .story-class-form {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 14px !important;
  }

  .panel,
  .story-card,
  .chapter-row,
  .hot-item,
  .fanpage-box,
  .category-shelf,
  .account-story-row,
  .manage-story-row,
  .author-card,
  .taxonomy-card,
  .info-cell,
  .comment-row,
  .admin-row {
    width: 100% !important;
    max-width: 100% !important;
    overflow: visible !important;
  }

  .panel-pad {
    padding: 14px !important;
    border-radius: 18px !important;
  }

  h1, h2, h3, h4,
  .story-heading h1,
  .section-title h2,
  .section-title h3,
  .chapter-title,
  .hot-item strong,
  .story-card h3,
  .compact-story-tile strong,
  .taxonomy-card strong,
  .author-card h2,
  .meta-line,
  .summary,
  .notice-box,
  .fanpage-box p,
  .btn,
  .badge,
  .tag,
  small,
  p,
  a,
  span {
    overflow-wrap: anywhere;
    word-break: normal;
  }

  .story-cover-large {
    width: min(72vw, 220px) !important;
    max-width: min(72vw, 220px) !important;
    margin: 0 auto 14px !important;
    border-radius: 18px !important;
  }

  .story-heading h1 {
    font-size: clamp(25px, 7.4vw, 34px) !important;
    line-height: 1.14 !important;
    letter-spacing: -.045em !important;
    margin-bottom: 10px !important;
  }

  .tags,
  .meta-line,
  .story-toolbar,
  .card-actions,
  .mini-stats,
  .admin-toolbar,
  .header-actions {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .tags,
  .meta-line,
  .story-toolbar,
  .card-actions,
  .mini-stats,
  .admin-toolbar {
    display: flex !important;
    flex-wrap: wrap !important;
  }

  .tag,
  .badge {
    max-width: 100% !important;
    white-space: normal !important;
    line-height: 1.35 !important;
  }

  .info-grid,
  .stats-strip,
  .account-stats {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  .story-toolbar {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .story-toolbar .btn,
  .card-actions .btn,
  .reader-controls .btn,
  .reader-controls button,
  .admin-toolbar .btn,
  .admin-toolbar button,
  .fanpage-box .btn,
  .btn-wide {
    width: 100% !important;
    min-width: 0 !important;
    max-width: 100% !important;
    white-space: normal !important;
    text-align: center !important;
    justify-content: center !important;
    line-height: 1.3 !important;
  }

  .tabs {
    display: grid !important;
    grid-template-columns: repeat(3, minmax(0, 1fr)) !important;
    gap: 0 !important;
    overflow: visible !important;
    white-space: normal !important;
    border-bottom: 1px solid var(--line) !important;
  }

  .tab-btn {
    min-width: 0 !important;
    width: 100% !important;
    padding: 10px 5px !important;
    font-size: 14px !important;
    line-height: 1.25 !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .chapter-row {
    display: grid !important;
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 14px !important;
    border-radius: 16px !important;
  }

  .chapter-row > span:first-child,
  .chapter-title,
  .chapter-time {
    display: block !important;
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .chapter-row-right {
    width: 100% !important;
    max-width: 100% !important;
    display: flex !important;
    flex-direction: row !important;
    align-items: center !important;
    justify-content: space-between !important;
    justify-self: stretch !important;
    gap: 8px !important;
  }

  .chapter-lock-state {
    flex: 0 1 auto !important;
    max-width: 58% !important;
    white-space: normal !important;
    text-align: center !important;
  }

  .hot-item {
    display: grid !important;
    grid-template-columns: auto minmax(0, 1fr) !important;
    gap: 10px !important;
    align-items: start !important;
  }

  .hot-item > span:nth-child(2),
  .hot-item > span:nth-child(2) strong,
  .hot-item > span:nth-child(2) small {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .hot-item > span:last-child {
    grid-column: 2 !important;
    justify-self: start !important;
    margin-top: 2px !important;
  }

  .rank {
    flex: 0 0 auto !important;
  }

  .story-card {
    display: grid !important;
    grid-template-columns: 72px minmax(0, 1fr) !important;
    gap: 10px !important;
    padding: 10px !important;
  }

  .story-card > div,
  .story-card h3,
  .story-card .meta-line,
  .story-card .card-actions {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .cover {
    width: 72px !important;
    max-width: 72px !important;
    border-radius: 12px !important;
  }

  .story-desc {
    display: -webkit-box !important;
    -webkit-line-clamp: 2 !important;
    -webkit-box-orient: vertical !important;
    overflow: hidden !important;
  }

  .section-title {
    display: flex !important;
    flex-direction: column !important;
    align-items: stretch !important;
    gap: 8px !important;
  }

  .section-title > * {
    min-width: 0 !important;
    max-width: 100% !important;
  }

  .fanpage-box iframe {
    display: block !important;
    width: 100% !important;
    max-width: 100% !important;
    min-width: 0 !important;
    height: 150px !important;
  }

  .fanpage-box .btn {
    padding-left: 10px !important;
    padding-right: 10px !important;
  }

  .category-shelf {
    padding: 14px !important;
    border-radius: 18px !important;
  }

  .category-shelf-head {
    min-width: 0 !important;
    flex-direction: column !important;
    align-items: stretch !important;
  }

  .category-shelf-head h2 {
    font-size: clamp(26px, 8vw, 34px) !important;
    line-height: 1.08 !important;
  }

  .compact-story-grid {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: auto !important;
    overflow-y: visible !important;
  }

  .compact-story-tile {
    flex: 0 0 min(132px, 42vw) !important;
    min-width: 0 !important;
  }

  .table-wrap {
    max-width: 100% !important;
    min-width: 0 !important;
    overflow-x: auto !important;
    -webkit-overflow-scrolling: touch !important;
  }

  .admin-table,
  .compact-table,
  .auth-table {
    max-width: none !important;
  }
}

@media (max-width: 380px) and (orientation: portrait) {
  .container,
  main[data-main].container {
    padding-left: 8px !important;
    padding-right: 8px !important;
  }

  .panel-pad {
    padding: 12px !important;
  }

  .story-cover-large {
    width: min(68vw, 200px) !important;
    max-width: min(68vw, 200px) !important;
  }

  .story-toolbar {
    grid-template-columns: minmax(0, 1fr) !important;
  }

  .tab-btn {
    font-size: 13px !important;
    padding-left: 4px !important;
    padding-right: 4px !important;
  }

  .chapter-row,
  .hot-item,
  .story-card {
    padding: 10px !important;
  }

  .fanpage-box iframe {
    height: 136px !important;
  }
}

/* V12: mobile reading screen - app-like, compact, no audio control. */
.reader-mobile-progress,
.reader-mobile-topbar,
.reader-mobile-bottom,
.reader-next-cta { display: none; }

@media (max-width: 700px) and (orientation: portrait) {
  body.reader-page {
    background: #f7efd8 !important;
    color: #5f5145 !important;
    overflow-x: hidden !important;
  }

  body.reader-page .site-shell {
    width: 100% !important;
    max-width: 100vw !important;
    background: #f7efd8 !important;
  }

  body.reader-page [data-header],
  body.reader-page [data-nav],
  body.reader-page [data-footer] {
    display: none !important;
  }

  body.reader-page main[data-main].container,
  body.reader-page main[data-main] {
    width: 100% !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding: 0 !important;
    background: #f7efd8 !important;
  }

  .reader-mobile-progress {
    display: block !important;
    position: sticky;
    top: 0;
    z-index: 80;
    height: 4px;
    width: 100%;
    background: rgba(117, 83, 54, .16);
  }

  .reader-mobile-progress span {
    display: block;
    height: 100%;
    background: #e52328;
    box-shadow: 0 1px 8px rgba(229, 35, 40, .35);
  }

  .reader-mobile-topbar {
    display: grid !important;
    grid-template-columns: 34px minmax(0, 1fr) minmax(92px, 34%);
    gap: 10px;
    align-items: center;
    position: sticky;
    top: 4px;
    z-index: 79;
    min-height: 52px;
    padding: 7px max(12px, env(safe-area-inset-right)) 7px max(12px, env(safe-area-inset-left));
    border-bottom: 1px solid rgba(120, 90, 60, .16);
    background: rgba(251, 245, 226, .96);
    backdrop-filter: blur(12px);
    box-shadow: 0 3px 14px rgba(85, 61, 39, .08);
  }

  .reader-mobile-back {
    width: 34px;
    height: 34px;
    border-radius: 99px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    color: #2b201a;
    font-size: 34px;
    line-height: 1;
    text-decoration: none;
  }

  .reader-mobile-topbar strong,
  .reader-mobile-topbar span {
    min-width: 0;
    overflow: hidden;
    display: -webkit-box;
    -webkit-box-orient: vertical;
    text-overflow: ellipsis;
    line-height: 1.25;
  }

  .reader-mobile-topbar strong {
    -webkit-line-clamp: 1;
    font-size: 15px;
    font-weight: 900;
    color: #2d241e;
  }

  .reader-mobile-topbar span {
    -webkit-line-clamp: 2;
    font-size: 13px;
    color: #7a6b5e;
  }

  .reader-wrap {
    width: 100% !important;
    max-width: 100vw !important;
    margin: 0 !important;
    padding: 0 0 calc(104px + env(safe-area-inset-bottom)) !important;
  }

  .reader-head {
    padding: 12px 18px 4px !important;
    text-align: left !important;
  }

  .reader-head .meta-line {
    display: none !important;
  }

  .reader-head h1 {
    font-size: 18px !important;
    line-height: 1.25 !important;
    letter-spacing: -.02em !important;
    color: #3f3028 !important;
    margin: 0 !important;
  }

  .reader-controls {
    display: none !important;
    margin: 10px 0 0 !important;
    padding: 10px !important;
    border: 1px solid rgba(120, 90, 60, .18);
    border-radius: 16px;
    background: rgba(255,255,255,.42);
    box-shadow: none !important;
  }

  .reader-controls.is-open {
    display: grid !important;
    grid-template-columns: repeat(2, minmax(0, 1fr)) !important;
    gap: 8px !important;
  }

  .reader-controls .btn,
  .reader-controls button {
    width: 100% !important;
    border-radius: 14px !important;
    padding: 10px 8px !important;
    font-size: 14px !important;
  }

  .reader-content {
    width: 100% !important;
    max-width: 100vw !important;
    border: 0 !important;
    border-radius: 0 !important;
    box-shadow: none !important;
    background: #f7efd8 !important;
    padding: 12px max(22px, env(safe-area-inset-right)) 20px max(22px, env(safe-area-inset-left)) !important;
    color: #67594d !important;
    font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Arial, sans-serif !important;
    font-size: clamp(22px, 6.4vw, 27px) !important;
    line-height: 1.72 !important;
    letter-spacing: .01em;
  }

  .reader-content p {
    margin: 0 0 1.15em !important;
    overflow-wrap: break-word !important;
  }

  .reader-content h1,
  .reader-content h2,
  .reader-content h3 {
    color: #3a2b22 !important;
    line-height: 1.25 !important;
  }

  .reader-next-cta {
    display: flex !important;
    justify-content: center;
    padding: 24px 22px 90px;
    background: #f7efd8;
  }

  .reader-next-cta a {
    width: min(100%, 540px);
    min-height: 58px;
    border-radius: 14px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    text-decoration: none;
    background: #e52328;
    color: #fff;
    font-size: 18px;
    font-weight: 900;
    text-transform: uppercase;
    letter-spacing: .05em;
    box-shadow: 0 18px 34px rgba(229, 35, 40, .24);
  }

  .reader-nav {
    display: none !important;
  }

  .reader-mobile-bottom {
    display: grid !important;
    grid-template-columns: repeat(4, minmax(0, 1fr));
    gap: 2px;
    position: fixed;
    z-index: 100;
    left: max(10px, env(safe-area-inset-left));
    right: max(10px, env(safe-area-inset-right));
    bottom: max(10px, env(safe-area-inset-bottom));
    min-height: 70px;
    padding: 10px 8px;
    border: 1px solid rgba(120, 90, 60, .18);
    border-radius: 22px;
    background: rgba(255, 253, 247, .96);
    box-shadow: 0 10px 28px rgba(42, 31, 22, .18);
    backdrop-filter: blur(14px);
  }

  .reader-mobile-bottom a,
  .reader-mobile-bottom button,
  .reader-mobile-bottom .disabled {
    min-width: 0;
    border: 0;
    background: transparent;
    color: #6a5a4e;
    text-decoration: none;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    gap: 3px;
    font: inherit;
    text-align: center;
  }

  .reader-mobile-bottom span:not(.disabled) {
    font-size: 24px;
    line-height: 1;
    font-weight: 800;
  }

  .reader-mobile-bottom small {
    font-size: 11px;
    line-height: 1.15;
    font-weight: 750;
    overflow-wrap: normal;
  }

  .reader-mobile-bottom .disabled {
    opacity: .35;
  }

  .reader-mobile-bottom button[data-mobile-settings] span {
    width: 44px;
    height: 44px;
    border-radius: 999px;
    display: inline-flex;
    align-items: center;
    justify-content: center;
    background: #e52328;
    color: #fff;
    box-shadow: 0 8px 18px rgba(229, 35, 40, .26);
  }

  .reader-page .gate {
    margin: 16px max(14px, env(safe-area-inset-right)) calc(98px + env(safe-area-inset-bottom)) max(14px, env(safe-area-inset-left)) !important;
    padding: 18px 14px !important;
    border-radius: 20px !important;
    background: rgba(255,253,247,.94) !important;
  }

  .reader-page .gate h2 {
    font-size: 24px !important;
    line-height: 1.2 !important;
  }

  .reader-page .affiliate-grid {
    grid-template-columns: minmax(0, 1fr) !important;
    gap: 10px !important;
  }

  .reader-page .affiliate-card {
    grid-template-columns: 58px minmax(0, 1fr) !important;
    padding: 10px !important;
    border-radius: 16px !important;
  }

  .reader-page .affiliate-card img {
    width: 58px !important;
    height: 58px !important;
  }

  .reader-page .unlock-status,
  .reader-page .notice-box {
    max-width: 100% !important;
    overflow-wrap: anywhere !important;
  }
}

@media (max-width: 380px) and (orientation: portrait) {
  .reader-content {
    padding-left: 18px !important;
    padding-right: 18px !important;
    font-size: clamp(21px, 6.1vw, 25px) !important;
    line-height: 1.68 !important;
  }

  .reader-mobile-bottom {
    left: 8px;
    right: 8px;
    border-radius: 18px;
    min-height: 66px;
  }

  .reader-mobile-bottom small {
    font-size: 10px;
  }
}

/* Backend/MySQL administration */
.admin-server-hero {
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 24px;
}

.admin-server-hero h1 { margin: 8px 0; }

.admin-api-status {
  min-height: 24px;
  margin: 14px 0;
  padding: 10px 14px;
  border-radius: 10px;
  background: rgba(127, 127, 127, 0.08);
}

.admin-api-status.is-success {
  color: #087a35;
  background: rgba(8, 122, 53, 0.08);
}

.admin-api-status.is-error {
  color: #a01818;
  background: rgba(160, 24, 24, 0.08);
}

.admin-db-layout {
  align-items: start;
}

.admin-rules-grid {
  display: grid;
  grid-template-columns: minmax(280px, 420px) minmax(0, 1fr);
  gap: 20px;
  align-items: start;
}

.affiliate-card-button {
  width: 100%;
  text-align: left;
  color: inherit;
  font: inherit;
  cursor: pointer;
}

.affiliate-card-button:disabled {
  opacity: 0.65;
  cursor: wait;
}

@media (max-width: 980px) {
  .admin-server-hero {
    flex-direction: column;
  }

  .admin-rules-grid {
    grid-template-columns: 1fr;
  }
}
