/* ── 粉圓體 (jf-openhuninn 2.1) — 託管於 R2 ──────────────── */
@font-face {
  font-family: 'jf-openhuninn';
  src: url('https://img.ininla.com/fonts/jf-openhuninn-2.1.woff2') format('woff2'),
       url('https://img.ininla.com/fonts/jf-openhuninn-2.1.ttf')   format('truetype');
  font-weight: 400;
  font-style: normal;
  font-display: swap;
}

/* ── Design tokens ─────────────────────────────────────────── */
:root {
  --bg:          #111318;
  --surface:     #1c1f26;
  --card:        #22262f;
  --card-hover:  #282d38;
  --border:      #2e3340;
  --accent:      #c8a020;
  --accent-h:    #e5b830;
  --text:        #e4e6ed;
  --muted:       #6e7585;
  --danger:      #e05252;
  --radius:      .6rem;
  --radius-lg:   1rem;
  --shadow:      0 2px 12px rgba(0,0,0,.4);
  --shadow-lg:   0 6px 28px rgba(0,0,0,.55);
  --trans:       .15s ease;
}

/* ── Base ────────────────────────────────────────────────────── */
*, *::before, *::after { box-sizing: border-box; }

html { scroll-behavior: smooth; }

body {
  margin: 0;
  background: var(--bg);
  color: var(--text);
  font-family: 'jf-openhuninn', -apple-system, BlinkMacSystemFont, 'Segoe UI', 'PingFang TC', 'Microsoft JhengHei', system-ui, sans-serif;
  font-size: 15px;
  line-height: 1.6;
  min-height: 100vh;
  display: flex;
  flex-direction: column;
}

a { color: var(--accent); text-decoration: none; }
a:hover { color: var(--accent-h); }

/* ── Navbar ──────────────────────────────────────────────────── */
.sp-nav {
  background: rgba(17,19,24,.92);
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  z-index: 1000;
  height: 68px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 0 1.25rem;
  gap: 1rem;
}

.sp-brand {
  display: flex;
  align-items: center;
  flex-shrink: 0;
}
.sp-logo {
  width: auto;
  max-width: 160px;
  object-fit: contain;
  /* 拉亮 logo（避免在深底上看起來暗） */
  filter: brightness(1.55) saturate(1.25) contrast(1.08) drop-shadow(0 0 6px rgba(255,204,90,.25));
  transition: filter var(--trans);
}
.sp-brand:hover .sp-logo {
  filter: brightness(1.75) saturate(1.35) contrast(1.1) drop-shadow(0 0 10px rgba(255,204,90,.45));
}

.sp-nav-links {
  display: flex;
  gap: .25rem;
  flex: 1;
  justify-content: center;
}
.sp-nav-link {
  padding: .4rem .9rem;
  border-radius: var(--radius);
  color: var(--text);
  font-size: .92rem;
  font-weight: 600;
  transition: color var(--trans), background var(--trans);
  white-space: nowrap;
}
.sp-nav-link:hover {
  color: var(--accent);
  background: rgba(200,160,32,.1);
}
.sp-nav-link.active {
  color: #111;
  background: var(--accent);
}

/* 右側區塊：按鈕 + 漢堡 */
.sp-nav-right {
  display: flex;
  align-items: center;
  gap: .5rem;
  flex-shrink: 0;
}
.sp-nav-btns {
  display: flex;
  align-items: center;
  gap: .5rem;
}

.btn-upload {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .38rem .9rem;
  background: var(--accent);
  color: #111 !important;
  border-radius: var(--radius);
  font-size: .875rem;
  font-weight: 600;
  transition: background var(--trans), transform var(--trans);
  white-space: nowrap;
}
.btn-upload:hover { background: var(--accent-h); transform: translateY(-1px); }

.btn-ghost {
  padding: .38rem .85rem;
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .875rem;
  transition: color var(--trans), border-color var(--trans);
  white-space: nowrap;
}
.btn-ghost:hover { color: var(--text); border-color: #555; }

/* 管理員 / 版主用：頭部「有 X 待審核」與「後台」按鈕 */
.btn-pending {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .38rem .85rem;
  background: rgba(232,62,140,.15);
  color: #ff8fc1 !important;
  border: 1px solid rgba(232,62,140,.45);
  border-radius: var(--radius);
  font-size: .85rem; font-weight: 700;
  white-space: nowrap;
  transition: all var(--trans);
  animation: btn-pending-pulse 2.4s ease-in-out infinite;
}
.btn-pending:hover {
  background: #e83e8c; color: #fff !important; border-color: #e83e8c;
  transform: translateY(-1px);
}
.btn-pending i { font-size: .92rem; }
@keyframes btn-pending-pulse {
  0%, 100% { box-shadow: 0 0 0 0 rgba(232,62,140,0); }
  50%      { box-shadow: 0 0 0 4px rgba(232,62,140,.18); }
}

.btn-staff {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .38rem .9rem;
  background: rgba(200,160,32,.15);
  color: var(--accent) !important;
  border: 1px solid var(--accent);
  border-radius: var(--radius);
  font-size: .88rem; font-weight: 700;
  white-space: nowrap;
  box-shadow: 0 0 0 0 rgba(200,160,32,0);
  transition: all var(--trans);
}
.btn-staff:hover {
  background: var(--accent);
  color: #111 !important;
  box-shadow: 0 2px 10px rgba(200,160,32,.35);
}

.btn-my {
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .38rem .85rem;
  background: transparent;
  color: var(--text) !important;
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .85rem; font-weight: 600;
  white-space: nowrap;
  transition: all var(--trans);
}
.btn-my:hover { border-color: #555; color: var(--accent) !important; }

/* 使用者下拉選單 */
.user-menu { position: relative; display: inline-block; }
.user-menu > summary {
  list-style: none;
  display: inline-flex; align-items: center; gap: .35rem;
  padding: .38rem .85rem;
  background: transparent;
  color: var(--text);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .88rem; font-weight: 600;
  cursor: pointer; user-select: none;
  white-space: nowrap;
  transition: all var(--trans);
}
.user-menu > summary::-webkit-details-marker { display: none; }
.user-menu > summary > i:first-child { color: var(--accent); font-size: 1rem; }
.user-menu > summary:hover { border-color: var(--accent); }
.user-menu[open] > summary { border-color: var(--accent); background: rgba(200,160,32,.06); }
.user-menu-chev { font-size: .7rem; color: var(--muted); transition: transform var(--trans); }
.user-menu[open] .user-menu-chev { transform: rotate(180deg); color: var(--accent); }

.user-menu-list {
  position: absolute; top: calc(100% + .5rem); right: 0;
  z-index: 200;
  min-width: 220px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: 0 8px 24px rgba(0,0,0,.4);
  padding: .35rem;
  display: flex; flex-direction: column; gap: .15rem;
}
.user-menu-item {
  display: flex; align-items: center; gap: .65rem;
  padding: .55rem .65rem;
  border-radius: calc(var(--radius) - 2px);
  color: var(--text);
  text-decoration: none;
  transition: background var(--trans), color var(--trans);
}
.user-menu-item:hover { background: var(--card); }
.user-menu-item > i { color: var(--accent); font-size: 1rem; width: 1.1rem; text-align: center; }
.user-menu-item.danger { color: #e87575; }
.user-menu-item.danger > i { color: #e87575; }
.user-menu-item.danger:hover { background: rgba(224,82,82,.1); }
.umi-text { display: flex; flex-direction: column; line-height: 1.25; }
.umi-text > span { font-size: .88rem; font-weight: 600; }
.umi-text > small { color: var(--muted); font-size: .72rem; }
@media (max-width: 640px) {
  .user-menu-list { right: -.5rem; min-width: 200px; }
}

/* 會員資料頁 */
.profile-page {
  max-width: 720px; margin: 1.5rem auto 3rem; padding: 0 1rem;
}
.profile-page-title {
  font-size: 1.25rem; font-weight: 700;
  display: flex; align-items: center; gap: .5rem;
  margin: 0 0 1.25rem;
}
.profile-page-title i { color: var(--accent); }

.profile-section-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.25rem;
  margin-bottom: 1rem;
}
.psc-title {
  display: flex; align-items: center;
  font-size: .85rem; font-weight: 700; letter-spacing: .04em;
  color: var(--muted);
  margin-bottom: .85rem;
  padding-bottom: .55rem;
  border-bottom: 1px solid var(--border);
}

.profile-dl { display: grid; grid-template-columns: 1fr; gap: .55rem; margin: 0; }
.profile-dl > div { display: flex; gap: .8rem; align-items: baseline; }
.profile-dl dt { color: var(--muted); font-size: .82rem; min-width: 5.5rem; margin: 0; }
.profile-dl dd { color: var(--text); font-size: .92rem; margin: 0; flex: 1; }

.profile-stats-row { display: grid; grid-template-columns: repeat(2, 1fr); gap: .65rem; }
.profile-stat {
  display: flex; flex-direction: column; align-items: center; gap: .15rem;
  padding: .9rem .5rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text); text-decoration: none;
  transition: all var(--trans);
}
.profile-stat:hover { border-color: var(--accent); color: var(--accent); }
.ps-num { font-size: 1.4rem; font-weight: 800; }
.ps-label { font-size: .78rem; color: var(--muted); }

.profile-phone-current {
  display: flex; align-items: center; gap: .85rem;
  padding: .65rem .85rem;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-bottom: .55rem;
}
.profile-phone-current > i { color: #84c79d; font-size: 1.5rem; }
.ppc-num { font-size: 1rem; font-weight: 700; color: var(--text); font-family: ui-monospace, monospace; }
.ppc-when { color: var(--muted); font-size: .75rem; margin-top: .15rem; }

/* ── 私人電話 SMS 驗證（upload + profile 共用） ─────────── */
.phone-verify-badge {
  display: inline-flex; align-items: center;
  padding: .1rem .55rem;
  border-radius: 2rem;
  font-size: .7rem; font-weight: 700; letter-spacing: .04em;
  margin-left: .35rem;
}
.phone-verify-badge.unverified {
  background: rgba(232,176,74,.15); color: #f4c065;
  border: 1px solid rgba(232,176,74,.4);
}
.phone-verify-badge.pending {
  background: rgba(200,160,32,.15); color: var(--accent);
  border: 1px solid rgba(200,160,32,.4);
}
.phone-verify-badge.verified {
  background: rgba(109,190,140,.15); color: #84c79d;
  border: 1px solid rgba(109,190,140,.4);
}
.phone-verify-row { display: flex; gap: .5rem; align-items: stretch; }
.phone-verify-row .iti { flex: 1; }
.phone-verify-row #phoneInput { width: 100%; }
.btn-verify, .btn-verify-edit {
  background: var(--accent); color: #111;
  border: 0; border-radius: var(--radius);
  padding: 0 1rem;
  font-size: .85rem; font-weight: 700;
  cursor: pointer; white-space: nowrap;
  display: inline-flex; align-items: center; gap: .35rem;
  transition: filter var(--trans);
}
.btn-verify:hover, .btn-verify-edit:hover { filter: brightness(1.1); }
.btn-verify:disabled { opacity: .55; cursor: not-allowed; }
.btn-verify-edit {
  background: transparent; color: var(--muted);
  border: 1px solid var(--border);
}
.btn-verify-edit:hover { color: var(--text); border-color: #555; filter: none; }
.phone-verify-box {
  margin-top: .65rem;
  padding: .85rem 1rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  font-size: .85rem;
}
.pvb-inst { display: flex; gap: .4rem; color: var(--text); margin-bottom: .65rem; align-items: flex-start; }
.pvb-inst > i { color: var(--accent); margin-top: .15rem; flex-shrink: 0; }
.pvb-inst strong { color: var(--accent); }
.pvb-card {
  display: flex; flex-direction: column; gap: .3rem;
  background: var(--surface); border: 1px dashed var(--border);
  border-radius: var(--radius); padding: .55rem .85rem;
  margin-bottom: .55rem;
}
.pvb-row { display: flex; align-items: center; gap: .6rem; }
.pvb-label { color: var(--muted); font-size: .75rem; min-width: 4.5rem; }
.pvb-value {
  color: var(--accent); font-weight: 700;
  font-family: ui-monospace, monospace;
  font-size: 1rem; letter-spacing: .04em;
  flex: 1; word-break: break-all;
}
.pvb-status {
  color: var(--muted); font-size: .8rem; margin: 0;
  display: flex; align-items: center; gap: .4rem;
}
.pvb-status.ok   { color: #84c79d; }
.pvb-status.fail { color: var(--danger); }

/* SMS QR Code 與 sms: 直連 */
.pvb-qr-block {
  display: flex; gap: 1rem; align-items: stretch;
  margin: .55rem 0;
  padding: .85rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
}
.pvb-qr-wrap {
  flex-shrink: 0;
  width: 132px; height: 132px;
  background: #fff;
  border-radius: 8px;
  padding: 6px;
  display: flex; align-items: center; justify-content: center;
}
.pvb-qr-wrap img { width: 100%; height: 100%; display: block; }
.pvb-qr-side {
  flex: 1; min-width: 0;
  display: flex; flex-direction: column; gap: .35rem;
  justify-content: center;
}
.pvb-qr-title { color: var(--text); font-weight: 700; margin: 0; display: inline-flex; align-items: center; gap: .35rem; }
.pvb-qr-title i { color: var(--accent); }
.pvb-sms-link {
  display: inline-flex; align-items: center; gap: .35rem;
  background: #06C755; color: #fff !important;
  padding: .5rem .9rem;
  border-radius: var(--radius);
  font-size: .85rem; font-weight: 700;
  text-decoration: none;
  align-self: flex-start;
  transition: filter var(--trans);
}
.pvb-sms-link:hover { filter: brightness(1.1); }
.pvb-qr-hint { color: var(--muted); font-size: .72rem; margin: 0; line-height: 1.45; }

@media (max-width: 480px) {
  .pvb-qr-block { flex-direction: column; align-items: center; gap: .65rem; }
  .pvb-qr-side { align-items: center; text-align: center; }
  .pvb-sms-link { align-self: center; padding: .65rem 1.4rem; }
}
.pvb-spinner {
  display: inline-block; width: 12px; height: 12px;
  border: 2px solid var(--border); border-top-color: var(--accent);
  border-radius: 50%;
  animation: pvb-spin .8s linear infinite;
}
@keyframes pvb-spin { to { transform: rotate(360deg); } }
.iti--inline-dropdown .iti__country-list { background: var(--surface); color: var(--text); border: 1px solid var(--border); }
.iti__country-list .iti__active { background: rgba(200,160,32,.15); }
.iti__country:hover { background: var(--card); }
.iti__selected-dial-code { color: var(--text); }

/* 上架頁：已驗證電話的唯讀顯示 + 未驗證的引導卡 */
.verified-phone-display {
  display: flex; align-items: center; gap: .65rem;
  background: rgba(109,190,140,.08);
  border: 1px solid rgba(109,190,140,.3);
  padding: .6rem .85rem;
  border-radius: var(--radius);
}
.verified-phone-display > i { color: #84c79d; font-size: 1.1rem; }
.verified-phone-display code {
  font-family: ui-monospace, monospace;
  font-size: 1rem; font-weight: 700; color: var(--text);
  background: transparent;
}
.verified-phone-field .field-hint { margin-top: .45rem; }

.needverify-card {
  background: var(--surface);
  border: 1px solid rgba(232,176,74,.4);
  border-radius: var(--radius-lg);
  padding: 2rem 1.5rem;
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: .55rem;
}
.needverify-card > i {
  font-size: 2.6rem; color: #f4c065;
  margin-bottom: .35rem;
}
.needverify-card h4 { margin: 0; font-size: 1.15rem; font-weight: 700; }
.needverify-card p {
  color: var(--muted); font-size: .88rem; line-height: 1.6;
  margin: 0; max-width: 420px;
}

/* 漢堡按鈕：只在手機顯示 */
.nav-toggle {
  display: none;
  background: none; border: none;
  color: var(--text); font-size: 1.4rem;
  cursor: pointer; padding: .2rem .3rem;
  line-height: 1;
}

/* ── Mobile ───────────────────── */
@media (max-width: 767px) {
  .sp-nav {
    flex-wrap: wrap;
    height: auto;
    padding: .6rem 1rem;
  }

  /* 第一行：logo 左、漢堡右 */
  .sp-brand        { order: 1; }
  .sp-nav-right    { order: 2; margin-left: auto; }
  .sp-nav-links    { order: 3; width: 100%; justify-content: flex-start; display: none; padding-top: .4rem; }

  .nav-toggle      { display: flex; align-items: center; }
  .sp-nav-btns     { display: none; }

  /* 展開後顯示 */
  .sp-nav.open .sp-nav-links { display: flex; flex-direction: column; gap: .1rem; }

  /* 按鈕水平排在 X 的左邊（compact） */
  .sp-nav.open .sp-nav-btns {
    display: flex;
    flex-direction: row;
    align-items: center;
    gap: .35rem;
  }
  .sp-nav.open .sp-nav-btns .btn-upload,
  .sp-nav.open .sp-nav-btns .btn-ghost {
    padding: .3rem .65rem;
    font-size: .78rem;
  }
}

/* ── Content wrapper ─────────────────────────────────────────── */
#content { flex: 1; }

/* ── Home page ───────────────────────────────────────────────── */
.home-hero {
  text-align: center;
  padding: 1.25rem 1rem .75rem;
}
.home-hero h1 {
  font-size: clamp(1.4rem, 3vw, 2rem);
  font-weight: 700;
  letter-spacing: -.5px;
  margin-bottom: .3rem;
}
.home-hero p { color: var(--muted); font-size: .9rem; margin: 0; }

.cat-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 1rem;
  max-width: 1100px;
  margin: 0 auto;
  padding: 0 1rem 1rem;
}
@media (max-width: 600px) {
  .cat-grid { grid-template-columns: 1fr; max-width: 360px; }
  .cat-card { height: 300px; }
}

.cat-card {
  border-radius: 1.25rem;
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--trans), box-shadow var(--trans);
  position: relative;
  display: flex;
  flex-direction: column;
  height: clamp(300px, calc(100vh - 265px), 520px);
  background-size: cover;
  background-position: center top;
}
.cat-card:hover { transform: translateY(-5px); box-shadow: var(--shadow-lg); }

.cat-card-overlay {
  position: absolute; inset: 0;
  background: linear-gradient(to top, rgba(0,0,0,.78) 0%, rgba(0,0,0,.2) 55%, rgba(0,0,0,.05) 100%);
  transition: opacity var(--trans);
}

.cat-card-inner {
  position: relative;
  margin-top: auto;
  padding: 1.5rem;
  display: flex; flex-direction: column; gap: .3rem;
}
.cat-name { font-size: 1.6rem; font-weight: 800; color: #fff; letter-spacing: -.3px; text-shadow: 0 1px 6px rgba(0,0,0,.5); }
.cat-sub  { font-size: .8rem; color: rgba(255,255,255,.65); }

.cat-arrow {
  position: absolute; bottom: 1.5rem; right: 1.5rem;
  color: rgba(255,255,255,.7);
  font-size: 1.1rem;
  opacity: 0;
  transform: translateX(-4px);
  transition: opacity var(--trans), transform var(--trans);
}
.cat-card:hover .cat-arrow { opacity: 1; transform: translateX(0); }

/* ── Category page ───────────────────────────────────────────── */
.cat-page {
  max-width: 1400px;
  margin: 0 auto;
  padding: 1rem 1rem 3rem;
}

/* Tag bar */
.tag-bar-wrap {
  margin-bottom: 1rem;
}

/* 手機展開按鈕：電腦版完全隱藏 */
.tag-bar-toggle {
  display: none !important;
  align-items: center; gap: .5rem;
  width: 100%;
  padding: .55rem .9rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text);
  font-size: .9rem;
  cursor: pointer;
  transition: border-color var(--trans);
}
.tag-bar-toggle:hover { border-color: #555; }
.toggle-chevron { margin-left: auto; transition: transform .2s; font-size: .8rem; color: var(--muted); }
.tag-bar-toggle.open .toggle-chevron { transform: rotate(180deg); }

.tag-bar {
  display: flex;
  flex-wrap: wrap;
  gap: .4rem;
  padding: .75rem 0 1rem;
  border-bottom: 1px solid var(--border);
}

@media (max-width: 767px) {
  .tag-bar-toggle { display: flex !important; margin-bottom: .5rem; }
  .tag-bar {
    display: none;
    padding: .6rem 0 .75rem;
    border-bottom: none;
    border-top: 1px solid var(--border);
  }
  .tag-bar.open { display: flex; }
}
.county-tag {
  padding: .32rem .95rem;
  border-radius: 2rem;
  font-size: .84rem; font-weight: 600;
  background: var(--card);
  color: var(--text);
  border: 1px solid var(--border);
  cursor: pointer;
  transition: all var(--trans);
  white-space: nowrap;
}
.county-tag:hover {
  color: var(--accent);
  border-color: var(--accent);
  background: rgba(200,160,32,.1);
}
.county-tag.active {
  background: var(--accent);
  color: #111;
  border-color: var(--accent);
  font-weight: 700;
  box-shadow: 0 0 0 1px rgba(200,160,32,.45);
}

/* Search bar */
.cat-search {
  display: flex; align-items: center;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: 0 .5rem 0 .85rem;
  margin-bottom: 1rem;
  gap: .5rem;
  position: relative;
}
.cat-search > i { color: var(--muted); font-size: 1rem; }
.cat-search input {
  flex: 1; background: transparent; border: 0; outline: 0;
  color: var(--text); font-size: .92rem;
  padding: .65rem 0;
}
.cat-search input::placeholder { color: var(--muted); }
.cat-search-clear {
  width: 1.6rem; height: 1.6rem; border-radius: 50%;
  display: inline-flex; align-items: center; justify-content: center;
  color: var(--muted); background: var(--surface);
  text-decoration: none; font-size: .7rem;
  transition: all var(--trans);
}
.cat-search-clear:hover { color: var(--text); background: var(--border); }
.cat-search-btn {
  background: var(--accent); color: #111;
  border: 0; border-radius: calc(var(--radius) - 2px);
  padding: .45rem 1rem;
  font-size: .85rem; font-weight: 700;
  cursor: pointer;
  transition: filter var(--trans);
}
.cat-search-btn:hover { filter: brightness(1.1); }

/* Infinite scroll sentinel + end note */
.cat-load-sentinel {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  padding: 2rem 1rem;
  color: var(--muted); font-size: .85rem;
}
.cat-load-sentinel .spinner i {
  display: inline-block;
  animation: cat-spin 1s linear infinite;
}
@keyframes cat-spin { from { transform: rotate(0); } to { transform: rotate(360deg); } }
.cat-load-end {
  text-align: center; color: var(--muted);
  font-size: .8rem; padding: 1.5rem 1rem;
}

/* Page header */
.cat-page-header {
  display: flex; align-items: center; gap: .75rem;
  margin-bottom: 1rem;
}
.cat-page-header h4 { margin: 0; font-weight: 700; font-size: 1.1rem; }
.badge-county {
  padding: .25rem .65rem;
  border-radius: 2rem;
  background: rgba(200,160,32,.15);
  color: var(--accent);
  font-size: .78rem;
  font-weight: 600;
}
.count-label { color: var(--muted); font-size: .8rem; margin-left: auto; }

/* Post grid */
.post-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(170px, 1fr));
  gap: .875rem;
}
@media (max-width: 480px) {
  .post-grid { grid-template-columns: repeat(2, 1fr); gap: .6rem; }
}

.post-card {
  background: var(--card);
  border-radius: var(--radius);
  overflow: hidden;
  cursor: pointer;
  transition: transform var(--trans), box-shadow var(--trans), background var(--trans);
  display: block;
  color: var(--text) !important;
  text-decoration: none !important;
}
.post-card:hover { transform: translateY(-3px); box-shadow: var(--shadow); background: var(--card-hover); }

.post-thumb-wrap {
  position: relative;
  aspect-ratio: 3/4;
  overflow: hidden;
  background: var(--surface);
}
.post-thumb-wrap img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s ease;
}
.post-card:hover .post-thumb-wrap img { transform: scale(1.04); }

.post-thumb-placeholder {
  width: 100%; height: 100%;
  display: flex; align-items: center; justify-content: center;
  color: var(--border); font-size: 2rem;
}

.post-info {
  padding: .5rem .6rem .55rem;
}
.post-title {
  font-size: .82rem;
  font-weight: 600;
  white-space: nowrap;
  overflow: hidden;
  text-overflow: ellipsis;
  margin-bottom: .2rem;
  color: var(--text);
}
.post-meta {
  font-size: .72rem;
  color: var(--muted);
  display: flex; gap: .35rem; align-items: center;
}
.post-meta-dot { color: var(--border); }

/* Empty state */
.empty-state {
  grid-column: 1/-1;
  text-align: center;
  padding: 4rem 1rem;
  color: var(--muted);
}
.empty-state i { font-size: 3rem; margin-bottom: .75rem; display: block; opacity: .4; }

/* ── Skeleton loading ────────────────────────────────────────── */
@keyframes shimmer {
  0%   { background-position: -600px 0; }
  100% { background-position:  600px 0; }
}
.skeleton {
  background: linear-gradient(90deg, var(--card) 25%, var(--card-hover) 50%, var(--card) 75%);
  background-size: 600px 100%;
  animation: shimmer 1.4s infinite linear;
  border-radius: var(--radius);
}
.skeleton-card { background: var(--card); border-radius: var(--radius); overflow: hidden; }
.skeleton-thumb { aspect-ratio: 3/4; }
.skeleton-line  { height: .7rem; margin: .5rem .6rem .2rem; border-radius: 4px; }
.skeleton-line.short { width: 60%; height: .6rem; margin-bottom: .55rem; }

/* ── Post detail ─────────────────────────────────────────────── */
.post-detail { max-width: 900px; margin: 0 auto; padding: 1.5rem 1rem 3rem; }

.breadcrumb-sp { display: flex; gap: .4rem; align-items: center; font-size: .82rem; color: var(--muted); margin-bottom: 1.25rem; flex-wrap: wrap; }
.breadcrumb-sp a { color: var(--muted); }
.breadcrumb-sp a:hover { color: var(--text); }
.breadcrumb-sp .sep { color: var(--muted); }
.breadcrumb-sp .current { color: var(--text); }

.post-detail h2 { font-size: 1.5rem; font-weight: 700; margin-bottom: .4rem; }
.post-detail-meta { color: var(--muted); font-size: .85rem; margin-bottom: 1.5rem; display: flex; gap: .75rem; flex-wrap: wrap; align-items: center; }
.meta-author-private { display: inline-flex; align-items: center; gap: .35rem; }
.meta-private-tag {
  background: rgba(109,190,140,.15); color: #84c79d;
  border: 1px solid rgba(109,190,140,.4);
  padding: .1rem .5rem; border-radius: 2rem;
  font-size: .68rem; font-weight: 700; letter-spacing: .04em;
}

.gallery-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .5rem;
  margin-bottom: 1.5rem;
}
@media (max-width: 500px) { .gallery-grid { grid-template-columns: repeat(2, 1fr); } }

.gallery-item {
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
  cursor: zoom-in;
  background: var(--surface);
}
.gallery-item img { width: 100%; height: 100%; object-fit: cover; transition: transform .3s; }
.gallery-item:hover img { transform: scale(1.05); }

/* ── Album Grid ──────────────────────────────────────────────── */
.album-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .4rem;
  margin-bottom: 1.5rem;
}
.album-thumb {
  aspect-ratio: 1;
  overflow: hidden;
  border-radius: var(--radius);
  cursor: zoom-in;
  background: var(--surface);
}
.album-thumb img {
  width: 100%; height: 100%;
  object-fit: cover;
  display: block;
  transition: transform .3s;
}
.album-thumb:hover img { transform: scale(1.06); }

/* ── Lightbox ────────────────────────────────────────────────── */
.lb-backdrop {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.93);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.lb-backdrop.open { opacity: 1; pointer-events: all; }

.lb-img-wrap {
  max-width: 90vw; max-height: 88vh;
  display: flex; align-items: center; justify-content: center;
}
.lb-img-wrap img {
  max-width: 88vw; max-height: 85vh;
  border-radius: var(--radius);
  object-fit: contain;
  user-select: none;
  cursor: grab;
}
.lb-img-wrap img:active { cursor: grabbing; }

.lb-close {
  position: fixed; top: 1rem; right: 1rem;
  background: rgba(255,255,255,.15); color: #fff;
  border: none; border-radius: 50%;
  width: 2.4rem; height: 2.4rem;
  font-size: 1rem; cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--trans);
}
.lb-close:hover { background: rgba(255,255,255,.3); }

.lb-nav {
  position: fixed; top: 50%; transform: translateY(-50%);
  background: rgba(255,255,255,.12); color: #fff;
  border: none; border-radius: 50%;
  width: 3rem; height: 3rem; font-size: 1.1rem;
  cursor: pointer; display: flex; align-items: center; justify-content: center;
  transition: background var(--trans);
}
.lb-nav:hover { background: rgba(255,255,255,.25); }
.lb-prev { left: 1rem; }
.lb-next { right: 1rem; }

.lb-counter {
  position: fixed; bottom: 1.25rem; left: 50%; transform: translateX(-50%);
  color: rgba(255,255,255,.6); font-size: .85rem;
}

/* ── 簡介卡片 (post.php) ────────────────────────────── */
.profile-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.1rem 1.25rem;
  margin-top: 1rem;
  box-shadow: var(--shadow);
}
.profile-card-head {
  display: flex; align-items: center; justify-content: space-between;
  padding-bottom: .8rem; margin-bottom: .9rem;
  border-bottom: 1px solid var(--border);
}
.profile-nick {
  display: flex; align-items: center; gap: .5rem;
  font-size: 1.15rem; font-weight: 700; color: var(--text);
}
.profile-nick i { color: var(--accent); font-size: 1.4rem; }
.profile-cup {
  background: rgba(232,62,140,.12);
  color: #ff8fc1;
  padding: .25rem .7rem;
  border-radius: 2rem;
  font-size: .82rem; font-weight: 600;
}

.profile-stats {
  display: grid; grid-template-columns: repeat(4, 1fr); gap: .5rem;
  margin-bottom: .9rem;
}
.profile-stats .stat {
  background: var(--card); border-radius: var(--radius);
  padding: .55rem .7rem;
  display: flex; flex-direction: column; gap: .15rem;
}
.stat-label { color: var(--muted); font-size: .72rem; display: flex; align-items: center; gap: .25rem; }
.stat-label i { color: var(--accent); }
.stat-val { color: var(--text); font-size: 1rem; font-weight: 700; }
.stat-val small { color: var(--muted); font-weight: 400; font-size: .75rem; margin-left: .15rem; }
@media (max-width: 540px) {
  .profile-stats { grid-template-columns: repeat(2, 1fr); }
}

.profile-row { margin-bottom: .85rem; }
.profile-row:last-child { margin-bottom: 0; }
.profile-row-label {
  display: flex; align-items: center; gap: .35rem;
  font-size: .85rem; font-weight: 600;
  color: var(--text);
  margin-bottom: .45rem;
}
.profile-row-label i { color: var(--accent); }
.profile-row-wont i { color: var(--danger); }
.profile-row-can i  { color: #6dbe8c; }

.profile-plans {
  display: flex; flex-direction: column; gap: .4rem;
}
.plan-row {
  display: inline-flex; align-items: center; gap: .5rem;
  background: var(--card);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  padding: .55rem .85rem;
  font-size: .9rem;
  flex-wrap: wrap;
}
.plan-type {
  background: rgba(200,160,32,.15); color: var(--accent);
  padding: .15rem .55rem; border-radius: 2rem;
  font-size: .75rem; font-weight: 700; letter-spacing: .02em;
}
.plan-sessions { color: var(--text); font-weight: 600; }
.plan-sep { color: var(--border); }
.plan-amt { color: var(--accent); font-weight: 700; font-size: 1rem; }
.plan-duration { color: var(--muted); font-size: .85rem; display: inline-flex; align-items: center; gap: .25rem; }
.plan-duration i { color: var(--accent); }

.profile-tags { display: flex; flex-wrap: wrap; gap: .35rem; }
.profile-tag {
  display: inline-flex; align-items: center; gap: .25rem;
  padding: .25rem .65rem;
  border-radius: 2rem;
  font-size: .78rem;
  border: 1px solid var(--border);
  position: relative;
}
.profile-tag-wont { background: rgba(224,82,82,.08); color: #e87575; border-color: rgba(224,82,82,.25); }
.profile-tag-can  { background: rgba(109,190,140,.1); color: #84c79d; border-color: rgba(109,190,140,.28); }

/* 使用者自填的標籤：虛線邊框 + 鉛筆小圖示 */
.profile-tag-custom { border-style: dashed; }
.tag-custom-mark { font-size: .65rem; opacity: .7; }

/* 管理員 / 版主才會看到的 ×（移除） + +（升級）按鈕 */
.tag-remove,
.tag-promote {
  display: inline-flex; align-items: center; justify-content: center;
  width: 1.05rem; height: 1.05rem;
  border-radius: 50%;
  border: 0;
  background: rgba(255,255,255,.06);
  color: inherit;
  font-size: .8rem; line-height: 1;
  cursor: pointer; padding: 0;
  transition: background var(--trans);
}
.tag-remove { font-size: .9rem; }
.tag-promote { font-weight: 700; color: #f4c065; background: rgba(244,192,101,.18); }
.tag-remove:hover  { background: rgba(224,82,82,.35); color: #fff; }
.tag-promote:hover { background: #f4c065; color: #111; }

.post-body {
  background: var(--surface);
  border-radius: var(--radius);
  padding: 1rem 1.25rem;
  color: var(--text);
  font-size: .9rem;
  line-height: 1.8;
  margin-top: 1rem;
}
/* Markdown rendered content (Vditor.preview output) */
.post-body.vditor-reset { color: var(--text); font-size: .92rem; }
.post-body.vditor-reset h1,
.post-body.vditor-reset h2,
.post-body.vditor-reset h3,
.post-body.vditor-reset h4 {
  color: var(--text); margin: 1rem 0 .5rem; font-weight: 700; line-height: 1.4;
}
.post-body.vditor-reset h1 { font-size: 1.5rem; }
.post-body.vditor-reset h2 { font-size: 1.25rem; }
.post-body.vditor-reset h3 { font-size: 1.1rem; }
.post-body.vditor-reset p  { margin: .5rem 0; }
.post-body.vditor-reset a  { color: var(--accent); text-decoration: underline; }
.post-body.vditor-reset code {
  background: var(--card); color: var(--accent);
  padding: .1rem .35rem; border-radius: 3px; font-size: .85em;
}
.post-body.vditor-reset pre {
  background: var(--card); border: 1px solid var(--border);
  padding: .75rem 1rem; border-radius: var(--radius); overflow-x: auto;
}
.post-body.vditor-reset blockquote {
  border-left: 3px solid var(--accent);
  margin: .75rem 0; padding: .25rem 1rem;
  color: var(--muted); background: var(--card);
}
.post-body.vditor-reset ul,
.post-body.vditor-reset ol { padding-left: 1.5rem; margin: .5rem 0; }
.post-body.vditor-reset li { margin: .15rem 0; }
.post-body.vditor-reset hr { border: none; border-top: 1px solid var(--border); margin: 1rem 0; }
.post-body.vditor-reset img { max-width: 100%; border-radius: var(--radius); }
.post-body.vditor-reset table {
  border-collapse: collapse; margin: .75rem 0; font-size: .85rem;
}
.post-body.vditor-reset th,
.post-body.vditor-reset td {
  border: 1px solid var(--border); padding: .4rem .75rem;
}
.post-body.vditor-reset th { background: var(--card); }

/* ── Auth forms ──────────────────────────────────────────────── */
.auth-wrap { max-width: 440px; margin: 3rem auto; padding: 0 1rem; }
.auth-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 2rem 2.5rem;
  position: relative;
}
.auth-card h3 { font-weight: 700; margin-bottom: .3rem; font-size: 1.4rem; }
.auth-sub { color: var(--muted); font-size: .875rem; margin-bottom: 1.5rem; }

/* Tab buttons top-right */
.auth-tabs {
  position: absolute;
  top: 1.25rem; right: 1.25rem;
  display: flex;
  background: var(--card);
  border-radius: 2rem;
  padding: 3px;
  gap: 2px;
}
.auth-tab {
  padding: .3rem .9rem;
  border-radius: 2rem;
  font-size: .82rem;
  color: var(--muted);
  transition: all var(--trans);
  font-weight: 500;
}
.auth-tab:hover { color: var(--text); }
.auth-tab.active { background: var(--accent); color: #111; font-weight: 700; }

/* Field with icon */
.field-group { margin-bottom: 1rem; }
.field-wrap { position: relative; }
.field-icon {
  position: absolute;
  left: .85rem; top: 50%;
  transform: translateY(-50%);
  color: var(--muted);
  font-size: .95rem;
  pointer-events: none;
}
.form-control.has-icon { padding-left: 2.4rem; }

.form-label { color: var(--muted); font-size: .85rem; margin-bottom: .3rem; }
.form-control, .form-select {
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: .55rem .85rem;
  transition: border-color var(--trans);
}
.form-control:focus, .form-select:focus {
  border-color: var(--accent) !important;
  box-shadow: 0 0 0 3px rgba(200,160,32,.15) !important;
  outline: none;
}
.form-control::placeholder { color: var(--muted); }
.form-select option { background: var(--card); }

.btn-primary-sp {
  width: 100%;
  padding: .65rem;
  background: var(--accent);
  color: #111;
  font-weight: 700;
  border: none;
  border-radius: var(--radius);
  cursor: pointer;
  font-size: 1rem;
  transition: background var(--trans), transform var(--trans);
}
.btn-primary-sp:hover { background: var(--accent-h); transform: translateY(-1px); }
.btn-primary-sp:disabled { opacity: .5; cursor: not-allowed; transform: none; }

.auth-alt { text-align: center; color: var(--muted); font-size: .85rem; margin-top: 1.25rem; }
.auth-alt a { color: var(--accent); }

/* Gender selector */
.gender-group { display: flex; gap: .6rem; }
.gender-opt { flex: 1; }
.gender-opt input { display: none; }
.gender-opt span {
  display: flex; align-items: center; justify-content: center; gap: .35rem;
  padding: .55rem .5rem;
  border-radius: var(--radius);
  border: 1px solid var(--border);
  background: var(--card);
  color: var(--muted);
  font-size: .88rem;
  cursor: pointer;
  transition: all var(--trans);
}
.gender-opt input:checked + span {
  border-color: var(--accent);
  background: rgba(200,160,32,.12);
  color: var(--accent);
  font-weight: 600;
}
.gender-opt span:hover { border-color: #555; color: var(--text); }

/* 18+ checkbox */
.age18-check {
  display: flex; align-items: flex-start; gap: .6rem;
  color: var(--muted); font-size: .85rem; cursor: pointer; line-height: 1.5;
  margin-top: .25rem;
}
.age18-check input { accent-color: var(--accent); width: 16px; height: 16px; margin-top: 2px; flex-shrink: 0; cursor: pointer; }
.age18-check strong { color: var(--text); }

/* ── Upload page ─────────────────────────────────────────────── */
.upload-wrap { max-width: 720px; margin: 0 auto; padding: 1.5rem 1rem 3rem; }
.upload-wrap h3 { font-weight: 700; margin-bottom: 1.75rem; }

.form-section {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.5rem;
  margin-bottom: 1rem;
}
.form-section-title {
  font-size: .78rem;
  font-weight: 700;
  letter-spacing: .08em;
  text-transform: uppercase;
  color: var(--muted);
  margin-bottom: 1rem;
}

#dropzone {
  border: 2px dashed var(--border);
  border-radius: var(--radius-lg);
  padding: 2.5rem 1rem;
  text-align: center;
  cursor: pointer;
  transition: border-color var(--trans), background var(--trans);
  background: var(--bg);
}
#dropzone:hover, #dropzone.drag-over {
  border-color: var(--accent);
  background: rgba(200,160,32,.05);
}
#dropzone i { font-size: 2.2rem; color: var(--muted); }
#dropzone p { color: var(--muted); font-size: .875rem; margin: .4rem 0 0; }
#dropzone .hint { font-size: .75rem; color: var(--border); margin-top: .2rem; }
#dropzone.has-images { display: none; }

#previewGrid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: .6rem;
  margin-top: .75rem;
}
@media (max-width: 480px) { #previewGrid { grid-template-columns: repeat(3, 1fr); } }

.preview-cell {
  position: relative;
  aspect-ratio: 1;
  border-radius: var(--radius);
  overflow: hidden;
  background: var(--card);
}
.preview-cell img { width: 100%; height: 100%; object-fit: cover; display: block; }
.preview-cell .uploading-overlay {
  position: absolute; inset: 0;
  background: rgba(0,0,0,.5);
  display: flex; align-items: center; justify-content: center;
}
.preview-cell .btn-remove {
  position: absolute; top: .3rem; right: .3rem;
  width: 1.7rem; height: 1.7rem;
  background: rgba(0,0,0,.7);
  color: #fff; border: none;
  border-radius: 50%;
  font-size: .8rem; line-height: 1;
  cursor: pointer;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--trans);
  z-index: 2;
}
.preview-cell .btn-remove:hover { background: var(--danger); }
.preview-cell.add-more {
  border: 2px dashed var(--border);
  background: var(--bg);
  display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 1.6rem;
  cursor: pointer; transition: border-color var(--trans), color var(--trans);
}
.preview-cell.add-more:hover { border-color: var(--accent); color: var(--accent); }

/* Alerts */
.alert-sp {
  padding: .8rem 1rem;
  border-radius: var(--radius);
  font-size: .88rem;
  margin-bottom: 1rem;
}
.alert-sp.error   { background: rgba(224,82,82,.12); border: 1px solid rgba(224,82,82,.3); color: #f08080; }
.alert-sp.success { background: rgba(50,180,100,.12); border: 1px solid rgba(50,180,100,.3); color: #6dbe8c; }

/* ── Footer ──────────────────────────────────────────────────── */
.sp-footer {
  background: var(--surface);
  border-top: 1px solid var(--border);
  padding: 1rem;
  text-align: center;
  font-size: .78rem;
  color: var(--muted);
}

/* ── Transitions for SPA ─────────────────────────────────────── */
#content { transition: opacity .1s ease; }
#content.loading { opacity: .4; pointer-events: none; }

/* ── My Posts page ──────────────────────────────────────────── */
.mine-page { max-width: 900px; margin: 0 auto; padding: 1.25rem 1rem 3rem; }
.mine-head {
  display: flex; align-items: center; gap: .75rem;
  margin-bottom: 1.25rem;
}
.mine-head h3 { margin: 0; font-size: 1.15rem; font-weight: 700; display: flex; align-items: center; gap: .5rem; }
.mine-head h3 i { color: var(--accent); }
.mine-count { color: var(--muted); font-size: .85rem; }
.mine-new { margin-left: auto; }

.mine-list { display: flex; flex-direction: column; gap: .75rem; }
.mine-card {
  display: flex; gap: 1rem;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: .85rem;
  transition: border-color var(--trans);
}
.mine-card:hover { border-color: #555; }
.mine-card-deleted { opacity: .65; }
.mine-thumb-link { flex-shrink: 0; }
.mine-thumb {
  width: 110px; height: 110px;
  border-radius: var(--radius);
  overflow: hidden; background: var(--card);
}
.mine-thumb img { width: 100%; height: 100%; object-fit: cover; display: block; }
.mine-thumb .post-thumb-placeholder {
  width: 100%; height: 100%; display: flex; align-items: center; justify-content: center;
  color: var(--muted); font-size: 2rem;
}
.mine-info { flex: 1; min-width: 0; display: flex; flex-direction: column; gap: .35rem; }
.mine-info-head { display: flex; align-items: center; gap: .6rem; flex-wrap: wrap; }
.mine-title {
  font-weight: 700; color: var(--text); font-size: 1rem;
  white-space: nowrap; overflow: hidden; text-overflow: ellipsis; max-width: 28ch;
}
.mine-meta { color: var(--muted); font-size: .8rem; display: flex; flex-wrap: wrap; gap: .35rem; }
.mine-meta-dot { color: var(--border); }
.mine-actions { display: flex; gap: .5rem; margin-top: auto; padding-top: .35rem; flex-wrap: wrap; align-items: center; }
.mine-btn {
  display: inline-flex; align-items: center; gap: .3rem;
  padding: .35rem .75rem;
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius);
  color: var(--text); font-size: .8rem; font-weight: 600;
  cursor: pointer; text-decoration: none;
  transition: all var(--trans);
}
.mine-btn-edit:hover    { border-color: var(--accent); color: var(--accent); }
.mine-btn-delete:hover  { border-color: var(--danger); color: var(--danger); }
.mine-btn-restore { color: #84c79d; border-color: rgba(109,190,140,.4); }
.mine-btn-restore:hover { background: rgba(109,190,140,.12); border-color: #84c79d; }
.mine-deleted-note {
  display: inline-flex; align-items: center; gap: .35rem;
  color: #f4c065; font-size: .76rem;
  padding: .25rem .55rem;
  background: rgba(244,192,101,.08);
  border: 1px solid rgba(244,192,101,.3);
  border-radius: 2rem;
}
.mine-deleted-note i { font-size: .8rem; }
.mine-deleted-sub { color: var(--muted); font-size: .7rem; margin-left: .15rem; }

@media (max-width: 540px) {
  .mine-thumb { width: 84px; height: 84px; }
  .mine-title { max-width: 20ch; }
}

/* ── Upload page skeleton (用於成功 / 表單兩種 branch） ───── */
.upload-wrap { max-width: 720px; margin: 1.5rem auto 3rem; padding: 0 1rem; }
.upload-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1.75rem;
  box-shadow: var(--shadow);
}
.upload-title {
  font-size: 1.4rem; font-weight: 800; margin: 0 0 1.5rem;
  display: flex; align-items: center; gap: .6rem;
}
.upload-row { display: grid; grid-template-columns: 1fr 1fr; gap: 1rem; }
@media (max-width: 540px) { .upload-row { grid-template-columns: 1fr; } }

.upload-success { text-align: center; padding: 2.5rem 1rem; }
.upload-success i { font-size: 3rem; color: #6dbe8c; display: block; margin-bottom: .75rem; }
.upload-success h4 { font-size: 1.25rem; font-weight: 700; margin: 0 0 .5rem; }
.upload-success p  { color: var(--muted); margin: 0; }

/* ── Post Status Banner (admin/mod view of non-active posts) ── */
.post-status-banner {
  display: flex; align-items: center; gap: .55rem;
  padding: .7rem 1rem;
  border-radius: var(--radius);
  margin-bottom: 1rem;
  font-size: .88rem; font-weight: 600;
  border: 1px solid var(--border);
}
.post-status-banner.status-pending  { background: rgba(232,176,74,.12); color: #f4c065; border-color: rgba(232,176,74,.35); }
.post-status-banner.status-hidden   { background: rgba(140,140,140,.12); color: #b8b8b8; border-color: rgba(140,140,140,.35); }
.post-status-banner.status-deleted  { background: rgba(224,82,82,.12);  color: #e87575; border-color: rgba(224,82,82,.35); }
.post-status-banner i { font-size: 1rem; }

/* ── Post Admin Panel (前台管理員快速操作) ────────────────── */
.post-admin-panel {
  border: 1px solid var(--border);
  border-radius: var(--radius);
  margin-top: 1rem;
  background: var(--surface);
  overflow: hidden;
}
.post-admin-panel > summary {
  list-style: none;
  display: flex; align-items: center; gap: .5rem;
  padding: .7rem 1rem;
  cursor: pointer;
  font-size: .9rem; font-weight: 700;
  color: var(--text);
  user-select: none;
}
.post-admin-panel > summary::-webkit-details-marker { display: none; }
.post-admin-panel > summary > i:first-child { color: var(--accent); }
.post-admin-role {
  background: rgba(200,160,32,.18); color: var(--accent);
  padding: .15rem .55rem; border-radius: 2rem;
  font-size: .68rem; font-weight: 700; letter-spacing: .04em;
}
.summary-chevron { margin-left: auto; color: var(--muted); transition: transform var(--trans); }
.post-admin-panel[open] .summary-chevron { transform: rotate(180deg); }
.post-admin-actions {
  display: flex; flex-wrap: wrap; gap: .5rem;
  padding: .5rem 1rem 1rem;
  border-top: 1px solid var(--border);
}
.post-admin-actions .adm-btn { display: inline-flex; align-items: center; gap: .3rem; }
.adm-btn-link {
  margin-left: auto;
  background: transparent; color: var(--muted);
  border: 1px solid var(--border);
  padding: .35rem .75rem; border-radius: var(--radius);
  font-size: .78rem; text-decoration: none;
  display: inline-flex; align-items: center; gap: .3rem;
  transition: all var(--trans);
}
.adm-btn-link:hover { color: var(--accent); border-color: var(--accent); }
.post-admin-meta {
  display: flex; flex-wrap: wrap; gap: .75rem 1.25rem;
  padding: .55rem 1rem .85rem;
  font-size: .75rem; color: var(--muted);
  border-top: 1px dashed var(--border);
}
.post-admin-meta code {
  background: var(--card); padding: .1rem .35rem;
  border-radius: .25rem; font-size: .72rem; color: var(--text);
}

/* ── Post Actions ───────────────────────────────────────────── */
.post-actions {
  display: flex; gap: .75rem; margin-top: 1.5rem; flex-wrap: wrap;
}

/* ── Contact Dialog ─────────────────────────────────────────── */
.btn-contact {
  display: flex; align-items: center; gap: .6rem;
  padding: .72rem 1.75rem;
  background: linear-gradient(135deg, #e83e8c, #c0166a);
  color: #fff; font-size: .95rem; font-weight: 700;
  border: none; border-radius: 2rem; line-height: 1.5;
  cursor: pointer;
  box-shadow: 0 4px 16px rgba(232,62,140,.35);
  transition: transform var(--trans), box-shadow var(--trans);
}
.btn-contact:hover { transform: translateY(-2px); box-shadow: 0 6px 24px rgba(232,62,140,.5); }

.contact-backdrop {
  position: fixed; inset: 0; z-index: 9998;
  background: rgba(0,0,0,.7);
  backdrop-filter: blur(6px);
  display: flex; align-items: center; justify-content: center;
  opacity: 0; pointer-events: none;
  transition: opacity .2s;
}
.contact-backdrop.open { opacity: 1; pointer-events: all; }

.contact-dialog {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 2rem 1.75rem 2.25rem;
  max-width: 360px; width: 90%;
  position: relative;
  transform: translateY(16px);
  transition: transform .2s;
}
.contact-backdrop.open .contact-dialog { transform: translateY(0); }

.contact-close {
  position: absolute; top: .9rem; right: .9rem;
  background: var(--card); border: none; border-radius: 50%;
  width: 2rem; height: 2rem;
  color: var(--muted); cursor: pointer; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
  transition: background var(--trans), color var(--trans);
}
.contact-close:hover { background: var(--border); color: var(--text); }

.contact-body {
  text-align: center;
  display: flex; flex-direction: column; align-items: center; gap: .6rem;
}
.contact-body h4 { margin: .25rem 0 0; font-size: 1.15rem; }
.contact-body p  { color: var(--muted); font-size: .875rem; margin: 0; }

.contact-hint { color: var(--text) !important; font-weight: 600; font-size: .9rem !important; }

.qr-wrap {
  background: #fff;
  border-radius: var(--radius);
  padding: .5rem;
  margin: .25rem 0;
}
.qr-img { display: block; width: 200px; height: 200px; }

.contact-id { font-size: .85rem !important; }

.btn-line {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .5rem 1.25rem;
  background: #06C755; color: #fff;
  border-radius: 2rem; font-size: .875rem; font-weight: 600;
  transition: opacity var(--trans);
  margin-top: .25rem;
}
.btn-line:hover { opacity: .85; color: #fff; }

.btn-report {
  display: flex; align-items: center; gap: .5rem;
  padding: .72rem 1.75rem;
  background: var(--card);
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 2rem;
  font-size: .95rem; font-weight: 700; line-height: 1.5;
  cursor: pointer;
  transition: all var(--trans);
}
.btn-report:hover { color: var(--danger); border-color: var(--danger); background: rgba(224,82,82,.08); }

.btn-viewers {
  display: flex; align-items: center; gap: .5rem;
  padding: .72rem 1.75rem;
  background: var(--card);
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 2rem;
  font-size: .95rem; font-weight: 700; line-height: 1.5;
  text-decoration: none;
  transition: all var(--trans);
}
.btn-viewers:hover { color: var(--accent); border-color: var(--accent); background: rgba(200,160,32,.08); }
.btn-viewers span {
  background: var(--accent); color: #111;
  font-size: .72rem; font-weight: 700;
  padding: .1rem .45rem; border-radius: 2rem;
  line-height: 1.4;
}

/* 貼文者自己的操作按鈕（編輯 / 刪除 / 還原） */
.btn-owner {
  display: inline-flex; align-items: center; gap: .4rem;
  padding: .72rem 1.4rem;
  background: var(--card);
  color: var(--muted);
  border: 1px solid var(--border);
  border-radius: 2rem;
  font-size: .9rem; font-weight: 600; line-height: 1.5;
  cursor: pointer; text-decoration: none;
  transition: all var(--trans);
}
.btn-owner-edit:hover    { color: var(--accent); border-color: var(--accent); background: rgba(200,160,32,.08); }
.btn-owner-delete:hover  { color: var(--danger); border-color: var(--danger); background: rgba(224,82,82,.08); }
.btn-owner-restore { color: #84c79d; border-color: rgba(109,190,140,.4); }
.btn-owner-restore:hover { background: rgba(109,190,140,.12); border-color: #84c79d; }

/* btn-viewers 也可以是 <button>（dialog 觸發），需處理原生 button 樣式差異 */
button.btn-viewers { cursor: pointer; font-family: inherit; }

/* ── Viewers List ───────────────────────────────────────────── */
.viewers-dialog {
  max-width: 460px !important; width: 92%;
  max-height: 80vh;
  padding: 1.5rem !important;
  overflow: hidden !important;
  display: flex; flex-direction: column;
}
.viewers-body {
  flex-direction: column !important;
  align-items: stretch !important;
  gap: 0 !important;
  text-align: left !important;
  padding: 0 !important;
  max-height: 100%;
  overflow: hidden;
}
.viewers-head { text-align: center; padding-bottom: .85rem; border-bottom: 1px solid var(--border); margin-bottom: .25rem; }
.viewers-head i { font-size: 2rem; color: var(--accent); display: block; margin-bottom: .35rem; }
.viewers-head h4 { margin: 0; font-size: 1.1rem; font-weight: 700; }
.viewers-loading { color: var(--muted); text-align: center; padding: 1.5rem 0; }

.viewers-dialog .viewers-list {
  overflow-y: auto;
  padding-right: .25rem;
  max-height: 50vh;
}
.viewer-report-btn {
  background: transparent;
  border: 1px solid rgba(224,82,82,.35);
  color: #e87575;
  padding: .15rem .5rem;
  border-radius: 2rem;
  font-size: .72rem; font-weight: 600;
  cursor: pointer;
  display: inline-flex; align-items: center; gap: .2rem;
  transition: all var(--trans);
}
.viewer-report-btn:hover { background: rgba(224,82,82,.15); color: #fff; }

.viewers-list {
  display: flex; flex-direction: column; gap: 0;
}
.viewer-row {
  display: flex; align-items: center; gap: .85rem;
  padding: .75rem 0;
  border-bottom: 1px solid var(--border);
}
.viewer-avatar {
  width: 2.25rem; height: 2.25rem; flex-shrink: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #e87040);
  color: #111; font-weight: 700; font-size: .9rem;
  display: flex; align-items: center; justify-content: center;
}
.viewer-info { flex: 1; display: flex; align-items: center; gap: .6rem; min-width: 0; }
.viewer-nick { font-weight: 600; font-size: .92rem; }
.viewer-gender { font-size: .8rem; color: var(--muted); }
.viewer-time { font-size: .78rem; color: var(--muted); white-space: nowrap; }

.btn-danger-sp {
  padding: .6rem 1.75rem;
  background: var(--danger); color: #fff;
  border: none; border-radius: var(--radius);
  font-weight: 700; cursor: pointer;
  transition: opacity var(--trans);
}
.btn-danger-sp:hover { opacity: .85; }

/* Report options */
.report-options { display: flex; flex-direction: column; gap: .4rem; width: 100%; text-align: left; }
.report-opt { display: flex; align-items: center; gap: .6rem; cursor: pointer; }
.report-opt input { accent-color: var(--danger); width: 15px; height: 15px; }
.report-opt span  { font-size: .88rem; color: var(--muted); }
.report-opt:has(input:checked) span { color: var(--text); }

/* ── Comments ───────────────────────────────────────────────── */
.comments-wrap {
  max-width: 900px; margin: 2rem auto 3rem;
  padding: 0 1rem;
}
.comments-title {
  font-size: 1rem; font-weight: 700;
  display: flex; align-items: center; gap: .5rem;
  padding-bottom: .75rem;
  border-bottom: 1px solid var(--border);
  margin-bottom: 1rem;
}
.comments-title span {
  background: var(--card); color: var(--muted);
  font-size: .75rem; padding: .15rem .55rem;
  border-radius: 2rem; font-weight: 500;
}
.no-comments { color: var(--muted); font-size: .875rem; text-align: center; padding: 1.5rem 0; }

.comment-item {
  padding: .75rem 0;
}
.comment-item > .comment-row {
  display: flex; gap: .75rem;
}
.comment-item + .comment-item { border-top: 1px solid var(--border); }
.comment-item.new { animation: fadeIn .3s ease; }
@keyframes fadeIn { from { opacity: 0; transform: translateY(6px); } to { opacity: 1; } }

/* 巢狀回覆縮排 */
.comment-children {
  margin-left: 2.5rem;
  margin-top: .25rem;
  padding-left: .75rem;
  border-left: 2px solid var(--border);
}
@media (max-width: 540px) {
  .comment-children { margin-left: 1rem; padding-left: .55rem; }
}
/* 太深時就不再縮排（cap at 5） */
.comment-item.depth-5 .comment-children { margin-left: 0; padding-left: .35rem; }

.comment-avatar {
  width: 2rem; height: 2rem; flex-shrink: 0;
  border-radius: 50%;
  background: linear-gradient(135deg, var(--accent), #e87040);
  color: #111; font-weight: 700; font-size: .85rem;
  display: flex; align-items: center; justify-content: center;
}
.comment-content { flex: 1; min-width: 0; }
.comment-head { display: flex; align-items: center; gap: .5rem; flex-wrap: wrap; }
.comment-nick  { font-size: .85rem; font-weight: 700; }
.comment-time  { font-size: .75rem; color: var(--muted); }
.comment-body  { margin: .35rem 0 0; font-size: .88rem; color: var(--text); word-break: break-word; line-height: 1.6; }
.comment-body p:last-child { margin-bottom: 0; }
.comment-body p:first-child { margin-top: 0; }

.comment-redacted-mark {
  display: inline-flex; align-items: center; gap: .2rem;
  font-size: .68rem; font-weight: 700;
  color: #f4c065;
  background: rgba(244,192,101,.12);
  border: 1px solid rgba(244,192,101,.35);
  padding: .05rem .4rem; border-radius: 2rem;
}

.comment-actions { margin-top: .35rem; }
.comment-reply-btn {
  background: transparent; border: 0; padding: .15rem .4rem;
  color: var(--muted); font-size: .78rem;
  cursor: pointer; border-radius: var(--radius);
  display: inline-flex; align-items: center; gap: .25rem;
  transition: color var(--trans), background var(--trans);
}
.comment-reply-btn:hover { color: var(--accent); background: rgba(200,160,32,.08); }

/* 已遮蔽留言 */
.comment-item.is-hidden .comment-body {
  opacity: .55;
  font-style: italic;
}
.comment-hidden-mark {
  display: inline-flex; align-items: center; gap: .2rem;
  font-size: .68rem; font-weight: 700;
  color: #b8b8b8;
  background: rgba(140,140,140,.15);
  border: 1px solid rgba(140,140,140,.35);
  padding: .05rem .4rem; border-radius: 2rem;
}

/* 管理員：留言下拉操作選單 */
.comment-admin-menu {
  position: relative; display: inline-block;
  margin-left: .15rem;
}
.comment-admin-menu > summary {
  list-style: none;
  display: inline-flex; align-items: center;
  width: 1.5rem; height: 1.5rem;
  border-radius: 50%;
  color: var(--muted);
  cursor: pointer;
  background: transparent;
  justify-content: center;
  transition: all var(--trans);
}
.comment-admin-menu > summary::-webkit-details-marker { display: none; }
.comment-admin-menu > summary:hover { background: var(--card); color: var(--text); }
.comment-admin-menu[open] > summary { background: var(--card); color: var(--accent); }

.comment-admin-menu-list {
  position: absolute; top: calc(100% + .25rem); right: 0;
  z-index: 50;
  min-width: 200px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  padding: .25rem;
  display: flex; flex-direction: column; gap: .1rem;
}
.comment-admin-menu-list button {
  display: flex; align-items: center; gap: .5rem;
  background: transparent; border: 0; cursor: pointer;
  padding: .45rem .65rem;
  font-size: .82rem; text-align: left;
  color: var(--text);
  border-radius: calc(var(--radius) - 2px);
  transition: background var(--trans), color var(--trans);
}
.comment-admin-menu-list button:hover { background: var(--card); }
.comment-admin-menu-list button.danger { color: #e87575; }
.comment-admin-menu-list button.danger:hover { background: rgba(224,82,82,.12); }
.comment-admin-menu-list button i { font-size: .9rem; color: var(--muted); }
.comment-admin-menu-list button.danger i { color: #e87575; }

/* 內嵌回覆表單 */
.comment-form-reply {
  margin: .5rem 0 .25rem;
  flex-direction: column;
  align-items: stretch;
  gap: .35rem;
}
.reply-form-actions { display: flex; gap: .4rem; justify-content: flex-end; }
.reply-submit {
  background: var(--accent); color: #111; border: 0;
  padding: .35rem 1rem; border-radius: var(--radius);
  font-size: .8rem; font-weight: 700; cursor: pointer;
}
.reply-submit:hover { filter: brightness(1.1); }
.reply-cancel {
  background: transparent; color: var(--muted); border: 1px solid var(--border);
  padding: .35rem 1rem; border-radius: var(--radius);
  font-size: .8rem; cursor: pointer;
}
.reply-cancel:hover { color: var(--text); border-color: #555; }

.comment-form  { display: flex; gap: .6rem; margin-top: 1rem; align-items: flex-end; }
.comment-input {
  flex: 1;
  background: var(--card) !important;
  border: 1px solid var(--border) !important;
  color: var(--text) !important;
  border-radius: var(--radius) !important;
  padding: .6rem .85rem;
  resize: none; font-size: .9rem; line-height: 1.5;
  transition: border-color var(--trans);
}
.comment-input:focus { border-color: var(--accent) !important; outline: none; }
.comment-submit {
  padding: .6rem 1.25rem;
  background: var(--accent); color: #111;
  border: none; border-radius: var(--radius);
  font-weight: 700; cursor: pointer; white-space: nowrap;
  transition: background var(--trans);
}
.comment-submit:hover { background: var(--accent-h); }
.comment-submit:disabled { opacity: .5; cursor: not-allowed; }

.comment-login-hint {
  margin-top: 1rem; font-size: .875rem;
  color: var(--muted); text-align: center;
}

/* ── Age Gate ────────────────────────────────────────────────── */
#ageGate {
  position: fixed; inset: 0; z-index: 99999;
  background: rgba(0,0,0,.92);
  display: flex; align-items: center; justify-content: center;
  backdrop-filter: blur(8px);
  -webkit-backdrop-filter: blur(8px);
}
.age-gate-box {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 1.25rem;
  padding: 2.5rem 2rem;
  max-width: 420px;
  width: 90%;
  text-align: center;
  box-shadow: var(--shadow-lg);
}
.age-gate-logo {
  height: 60px; width: auto;
  margin-bottom: 1.25rem;
}
.age-gate-title {
  font-size: 1.5rem; font-weight: 800;
  margin-bottom: .5rem;
}
.age-gate-sub {
  color: var(--muted); font-size: .9rem;
  line-height: 1.7; margin-bottom: 1.75rem;
}
.age-gate-sub strong { color: var(--text); }
.age-gate-actions { display: flex; flex-direction: column; gap: .75rem; margin-bottom: 1.25rem; }
.age-btn {
  padding: .75rem 1.5rem;
  border-radius: var(--radius);
  font-size: 1rem; font-weight: 700;
  border: none; cursor: pointer;
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  transition: transform var(--trans), opacity var(--trans);
}
.age-btn:hover { transform: translateY(-1px); opacity: .9; }
.age-btn-yes { background: var(--accent); color: #111; }
.age-btn-no  { background: var(--card); color: var(--muted); border: 1px solid var(--border); }
.age-remember {
  display: flex; align-items: center; justify-content: center; gap: .5rem;
  color: var(--muted); font-size: .82rem; cursor: pointer;
}
.age-remember input { accent-color: var(--accent); width: 15px; height: 15px; cursor: pointer; }

/* ── Lightbox ────────────────────────────────────────────────── */
.lightbox {
  position: fixed; inset: 0; z-index: 9999;
  background: rgba(0,0,0,.92);
  display: flex; align-items: center; justify-content: center;
  cursor: zoom-out;
}
.lightbox img {
  max-width: 95vw; max-height: 95vh;
  border-radius: var(--radius);
  box-shadow: var(--shadow-lg);
}

/* ── Upload Quota（上架頁面配額顯示）─────────────────────── */
.upload-quota {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 1rem 1.25rem;
  margin-bottom: 1.5rem;
}
.upload-quota-title {
  font-size: .8rem; font-weight: 700; color: var(--muted);
  letter-spacing: .04em; margin-bottom: .75rem;
  display: flex; align-items: center; gap: .4rem;
}
.upload-quota-grid {
  display: grid; grid-template-columns: repeat(3, 1fr); gap: .65rem;
}
.upload-quota-card {
  background: var(--card); border: 1px solid var(--border);
  border-radius: var(--radius); padding: .75rem;
  text-align: center;
}
.upload-quota-cat { font-size: .82rem; color: var(--muted); margin-bottom: .25rem; }
.upload-quota-stat { font-size: 1.1rem; font-weight: 700; }
.upload-quota-stat span { color: var(--accent); }
.upload-quota-pending { font-size: .68rem; color: var(--accent); margin-top: .25rem; }
@media (max-width: 480px) {
  .upload-quota-grid { grid-template-columns: repeat(3, 1fr); gap: .4rem; }
  .upload-quota-card { padding: .5rem .3rem; }
}

/* ════════════════════════════════════════════════════════════
   ── Admin Panel ──────────────────────────────────────────── */
.adm-wrap {
  display: flex; min-height: calc(100vh - 68px);
  max-width: 1280px; margin: 0 auto; padding: 0 1rem;
  gap: 1.5rem; align-items: flex-start;
}

/* Sidebar */
.adm-sidebar {
  width: 200px; flex-shrink: 0;
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.25rem .75rem;
  position: sticky; top: 80px;
  display: flex; flex-direction: column; gap: .25rem;
  margin-top: 1.5rem;
}
.adm-sidebar-title {
  font-size: .72rem; font-weight: 700; letter-spacing: .08em;
  color: var(--muted); text-transform: uppercase;
  padding: 0 .5rem .75rem; border-bottom: 1px solid var(--border);
  margin-bottom: .5rem;
  display: flex; align-items: center; gap: .5rem;
}
.adm-nav-link {
  display: flex; align-items: center; gap: .6rem;
  padding: .6rem .75rem; border-radius: var(--radius);
  color: var(--muted); font-size: .875rem; font-weight: 500;
  text-decoration: none; transition: all var(--trans);
  position: relative;
}
.adm-nav-link:hover { background: var(--card); color: var(--text); }
.adm-nav-link.active { background: rgba(200,160,32,.12); color: var(--accent); font-weight: 700; }
.adm-nav-link .adm-badge {
  margin-left: auto; background: var(--danger); color: #fff;
  font-size: .68rem; font-weight: 700;
  padding: .1rem .4rem; border-radius: 2rem; line-height: 1.5;
}
.adm-sidebar-foot {
  margin-top: auto; padding-top: 1rem; border-top: 1px solid var(--border);
  font-size: .78rem; color: var(--muted); padding-left: .5rem;
}
.adm-role-pill {
  display: inline-block; font-size: .65rem; font-weight: 700;
  padding: .1rem .45rem; border-radius: 2rem;
  background: rgba(200,160,32,.15); color: var(--accent);
  margin-left: .35rem; vertical-align: middle;
}
.adm-role-pill.mod { background: rgba(99,179,237,.15); color: #63b3ed; }

/* Main area */
.adm-main {
  flex: 1; min-width: 0; padding: 1.5rem 0 3rem;
}
.adm-section-title {
  font-size: 1.15rem; font-weight: 800; margin-bottom: 1.25rem;
  display: flex; align-items: center; gap: .6rem;
}

/* Stat cards */
.adm-stats {
  display: grid; grid-template-columns: repeat(auto-fill,minmax(150px,1fr));
  gap: .85rem; margin-bottom: 2rem;
}
.adm-stat-card {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); padding: 1.1rem 1rem;
  display: flex; flex-direction: column; gap: .35rem;
}
.adm-stat-label { font-size: .75rem; color: var(--muted); font-weight: 500; }
.adm-stat-value { font-size: 1.7rem; font-weight: 800; line-height: 1; }
.adm-stat-sub   { font-size: .72rem; color: var(--muted); }
.adm-stat-card.accent .adm-stat-value { color: var(--accent); }
.adm-stat-card.danger .adm-stat-value { color: var(--danger); }
.adm-stat-card.green  .adm-stat-value { color: #6dbe8c; }

/* Filter bar */
.adm-filter-bar {
  display: flex; gap: .5rem; flex-wrap: wrap; margin-bottom: 1rem; align-items: center;
}
.adm-filter-btn {
  padding: .35rem .9rem; border-radius: 2rem;
  background: var(--card); border: 1px solid var(--border);
  color: var(--muted); font-size: .82rem; font-weight: 600;
  cursor: pointer; text-decoration: none; transition: all var(--trans);
}
.adm-filter-btn:hover,
.adm-filter-btn.active { background: var(--accent); color: #111; border-color: var(--accent); }
.adm-search {
  margin-left: auto;
  display: flex; gap: .4rem; align-items: center;
}
.adm-search input {
  background: var(--card); border: 1px solid var(--border);
  color: var(--text); padding: .35rem .75rem; border-radius: var(--radius);
  font-size: .85rem; width: 180px; outline: none;
  transition: border-color var(--trans);
}
.adm-search input:focus { border-color: var(--accent); }
.adm-search button {
  background: var(--accent); color: #111; border: none;
  padding: .35rem .85rem; border-radius: var(--radius);
  font-weight: 700; font-size: .82rem; cursor: pointer;
}

/* Table */
.adm-table-wrap {
  background: var(--surface); border: 1px solid var(--border);
  border-radius: var(--radius-lg); overflow: hidden;
}
.adm-table {
  width: 100%; border-collapse: collapse; font-size: .83rem;
}
.adm-table th {
  background: var(--card); color: var(--muted);
  font-size: .72rem; font-weight: 700; letter-spacing: .05em;
  text-transform: uppercase; padding: .65rem 1rem;
  text-align: left; border-bottom: 1px solid var(--border);
}
.adm-table td {
  padding: .7rem 1rem; border-bottom: 1px solid var(--border);
  vertical-align: middle;
}
.adm-table tr:last-child td { border-bottom: none; }
.adm-table tr:hover td { background: rgba(255,255,255,.02); }
.adm-table a { color: var(--accent); text-decoration: none; }
.adm-table a:hover { text-decoration: underline; }

/* Status pills */
.status-pill {
  display: inline-flex; align-items: center;
  padding: .15rem .55rem; border-radius: 2rem;
  font-size: .7rem; font-weight: 700; white-space: nowrap;
}
.status-pill.active  { background: rgba(109,190,140,.15); color: #6dbe8c; }
.status-pill.hidden  { background: rgba(200,160,32,.15);  color: var(--accent); }
.status-pill.deleted { background: rgba(224,82,82,.15);   color: var(--danger); }
.status-pill.pending  { background: rgba(224,82,82,.15);  color: var(--danger); }
.status-pill.reviewed { background: rgba(109,190,140,.15);color: #6dbe8c; }
.status-pill.dismissed{ background: var(--card);          color: var(--muted); }

/* Gender pill */
.gender-pill { font-size: .75rem; color: var(--muted); }

/* Role select */
.adm-role-select {
  background: var(--card); border: 1px solid var(--border);
  color: var(--text); border-radius: var(--radius);
  padding: .25rem .5rem; font-size: .8rem; cursor: pointer;
}
.adm-role-select:focus { outline: none; border-color: var(--accent); }

/* Action buttons */
.adm-act-btns { display: flex; gap: .35rem; flex-wrap: wrap; }
.adm-btn {
  padding: .25rem .65rem; border-radius: var(--radius);
  font-size: .75rem; font-weight: 700; cursor: pointer;
  border: none; transition: opacity var(--trans); white-space: nowrap;
}
.adm-btn:hover { opacity: .8; }
.adm-btn-hide    { background: rgba(200,160,32,.2); color: var(--accent); }
.adm-btn-restore { background: rgba(109,190,140,.2); color: #6dbe8c; }
.adm-btn-del     { background: rgba(224,82,82,.2);   color: var(--danger); }
.adm-btn-view    { background: var(--card); color: var(--muted); text-decoration: none; display: inline-flex; align-items: center; }
.adm-btn-resolve { background: rgba(109,190,140,.2); color: #6dbe8c; }
.adm-btn-dismiss { background: var(--card); color: var(--muted); }

/* Pagination */
.adm-pagination {
  display: flex; gap: .4rem; justify-content: center; margin-top: 1.25rem; flex-wrap: wrap;
}
.adm-page-btn {
  padding: .3rem .7rem; border-radius: var(--radius);
  background: var(--card); border: 1px solid var(--border);
  color: var(--muted); font-size: .82rem; text-decoration: none; transition: all var(--trans);
}
.adm-page-btn:hover,
.adm-page-btn.active { background: var(--accent); color: #111; border-color: var(--accent); }

/* Empty state */
.adm-empty {
  text-align: center; padding: 3rem 1rem; color: var(--muted);
  font-size: .9rem;
}
.adm-empty i { font-size: 2.5rem; display: block; margin-bottom: .75rem; opacity: .4; }

/* Reason map */
.reason-tag {
  font-size: .72rem; padding: .1rem .45rem; border-radius: 2rem;
  background: var(--card); color: var(--muted); white-space: nowrap;
}

/* Mobile admin */
@media (max-width: 768px) {
  .adm-wrap { flex-direction: column; padding: 0 .75rem; }
  .adm-sidebar { width: 100%; position: static; margin-top: 1rem;
    flex-direction: row; flex-wrap: wrap; gap: .35rem; padding: .75rem; }
  .adm-sidebar-title, .adm-sidebar-foot { display: none; }
  .adm-nav-link { font-size: .78rem; padding: .4rem .65rem; }
  .adm-table th:nth-child(n+4),
  .adm-table td:nth-child(n+4) { display: none; }
  .adm-search { margin-left: 0; }
}
