/* Happy Toilet — โทนสีฟ้า gradient + เหลือง accent (soft UI) */
:root {
  --ht-bg: #f0f5ff;
  --ht-brand-top: #66a6ff;
  --ht-brand-mid: #4facfe;
  --ht-brand-bottom: #1976d2;
  --ht-ink: #2c3e50;
  --ht-ink-muted: #7f8c8d;
  --ht-accent: #ffd54f;
  --ht-accent-dark: #fbc02d;
  --ht-card-bg: rgba(255, 255, 255, 0.96);
  --ht-card-border: rgba(102, 166, 255, 0.18);
  --ht-card-radius: 0.875rem;
}

body.ht-app {
  background-color: var(--ht-bg);
  color: var(--ht-ink);
  font-size: 18px;
  background-image:
    radial-gradient(ellipse 90% 60% at 50% -20%, rgba(102, 166, 255, 0.22), transparent 58%),
    radial-gradient(ellipse 55% 45% at 100% 0%, rgba(79, 172, 254, 0.14), transparent 52%),
    radial-gradient(ellipse 50% 40% at 0% 100%, rgba(25, 118, 210, 0.08), transparent 48%),
    linear-gradient(180deg, #f0f5ff 0%, #eef3fb 100%);
}

html.dark {
  color-scheme: dark;
}

.dark body.ht-app {
  --ht-card-bg: rgba(17, 30, 52, 0.82);
  --ht-card-border: rgba(102, 166, 255, 0.16);
  background-color: #0a1628;
  color: #e2e8f0;
  background-image:
    radial-gradient(ellipse 100% 65% at 50% -20%, rgba(102, 166, 255, 0.16), transparent 55%),
    radial-gradient(ellipse 70% 50% at 100% 10%, rgba(41, 118, 210, 0.1), transparent 48%),
    radial-gradient(ellipse 60% 45% at 0% 90%, rgba(25, 118, 210, 0.08), transparent 50%),
    linear-gradient(180deg, #0c1929 0%, #081220 100%);
}

.dark body.ht-app ::selection {
  background-color: rgba(102, 166, 255, 0.32);
  color: #f8fafc;
}

/* การ์ด — มุมโค้งใหญ่ เงานุ่ม glass (ยกเว้น navbar) */
body.ht-app .shadow-card,
body.ht-app .shadow-happy:not(nav.ht-nav) {
  border-radius: var(--ht-card-radius);
}

body.ht-app .shadow-card {
  border-color: var(--ht-card-border) !important;
  background: var(--ht-card-bg) !important;
  backdrop-filter: blur(10px);
  box-shadow:
    0 4px 20px -6px rgba(41, 118, 210, 0.12),
    0 12px 40px -16px rgba(25, 118, 210, 0.14),
    inset 0 1px 0 rgba(255, 255, 255, 0.75);
}

.dark .shadow-card,
.dark .shadow-happy {
  box-shadow:
    0 4px 20px rgba(0, 0, 0, 0.35),
    0 0 0 1px rgba(102, 166, 255, 0.1),
    0 16px 48px -12px rgba(0, 0, 0, 0.45);
}

/* แถบนำทาง — gradient ฟ้า แบบเรียบ ไม่มีขอบ/มุมโค้ง */
nav.ht-nav {
  background: linear-gradient(135deg, var(--ht-brand-top) 0%, var(--ht-brand-mid) 48%, var(--ht-brand-bottom) 100%) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: 0 2px 12px -4px rgba(25, 118, 210, 0.35);
}

.dark nav.ht-nav {
  background: linear-gradient(135deg, #1e4d8c 0%, #1565c0 45%, #0d47a1 100%) !important;
  border: none !important;
  border-radius: 0 !important;
  box-shadow: 0 2px 16px -4px rgba(0, 0, 0, 0.45);
}

nav.ht-nav > div > div > a,
nav.ht-nav > div > div > button,
nav.ht-nav > div > div > details > summary {
  border: none !important;
  border-radius: 0 !important;
  box-shadow: none !important;
}

/* ลิงก์ใน navbar — ขาวบนพื้นฟ้า / เมนู active = ข้อความเข้มบนพื้นขาว */
nav.ht-nav > div > div > a.text-sm,
nav.ht-nav > div > div > details > summary {
  color: #ffffff !important;
  text-shadow: 0 1px 2px rgba(13, 71, 161, 0.28);
  transition: color 0.15s ease, background-color 0.15s ease, text-shadow 0.15s ease;
}

nav.ht-nav > div > div > a.text-sm:hover,
nav.ht-nav > div > div > a.text-sm:focus-visible,
nav.ht-nav > div > div > details > summary:hover,
nav.ht-nav > div > div > details > summary:focus-visible {
  color: #0d47a1 !important;
  background-color: rgba(255, 255, 255, 0.94) !important;
  text-shadow: none;
  font-weight: 600;
}

nav.ht-nav > div > div > a.text-sm.bg-sky-100,
nav.ht-nav > div > div > a.text-sm.shadow-sm,
nav.ht-nav > div > div > details > summary.bg-sky-100,
nav.ht-nav > div > div > details > summary.shadow-sm {
  color: #0d47a1 !important;
  background-color: rgba(255, 255, 255, 0.96) !important;
  text-shadow: none;
  font-weight: 600;
  box-shadow: inset 0 0 0 1px rgba(255, 255, 255, 0.65) !important;
}

nav.ht-nav > div > div > a.text-sm.bg-sky-100:hover,
nav.ht-nav > div > div > a.text-sm.shadow-sm:hover,
nav.ht-nav > div > div > details > summary.bg-sky-100:hover,
nav.ht-nav > div > div > details > summary.shadow-sm:hover {
  color: #0a3d91 !important;
  background-color: #ffffff !important;
}

nav.ht-nav > div > div > a.text-amber-700 {
  color: #fff8e1 !important;
  text-shadow: 0 1px 2px rgba(13, 71, 161, 0.28);
}

nav.ht-nav > div > div > a.text-amber-700:hover,
nav.ht-nav > div > div > a.text-amber-700:focus-visible {
  color: #0d47a1 !important;
  background-color: rgba(255, 255, 255, 0.94) !important;
  text-shadow: none;
  font-weight: 600;
}

nav.ht-nav > div > div > a.text-sm svg,
nav.ht-nav > div > div > details > summary svg {
  color: inherit;
}

nav.ht-nav > div > div > a.text-sm:hover svg,
nav.ht-nav > div > div > a.text-sm:focus-visible svg,
nav.ht-nav > div > div > a.text-sm.bg-sky-100 svg,
nav.ht-nav > div > div > details > summary:hover svg,
nav.ht-nav > div > div > details > summary.bg-sky-100 svg {
  color: inherit !important;
}

nav.ht-nav #ht-theme-toggle {
  border: none !important;
  border-radius: 0 !important;
  background-color: transparent !important;
  color: #ffffff !important;
  text-shadow: 0 1px 2px rgba(13, 71, 161, 0.28);
  box-shadow: none !important;
  transition: color 0.15s ease, background-color 0.15s ease, text-shadow 0.15s ease;
}

nav.ht-nav #ht-theme-toggle:hover,
nav.ht-nav #ht-theme-toggle:focus-visible {
  color: #0d47a1 !important;
  background-color: rgba(255, 255, 255, 0.94) !important;
  text-shadow: none;
  border: none !important;
}

nav.ht-nav a.ht-nav-brand,
nav.ht-nav a.ht-nav-brand span {
  color: #ffffff !important;
}

nav.ht-nav a.ht-nav-brand .ht-nav-tagline {
  color: rgba(255, 243, 205, 0.95) !important;
}

/* ปุ่ม CTA หลัก — เหลือง accent */
.ht-btn-cta {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  gap: 0.5rem;
  border-radius: 1rem;
  background: linear-gradient(135deg, #ffe082 0%, #ffd54f 52%, #fbc02d 100%);
  color: #2c3e50 !important;
  font-weight: 600;
  box-shadow: 0 2px 6px -1px rgba(251, 192, 45, 0.2), 0 1px 2px rgba(44, 62, 80, 0.06);
  transition: box-shadow 0.15s ease, background 0.15s ease;
}

.ht-btn-cta:hover {
  background: linear-gradient(135deg, #ffecb3 0%, #ffe082 48%, #ffd54f 100%);
  box-shadow: 0 3px 10px -2px rgba(251, 192, 45, 0.26), 0 1px 3px rgba(44, 62, 80, 0.08);
}

.ht-btn-cta:focus-visible {
  outline: none;
  box-shadow:
    0 2px 6px -1px rgba(251, 192, 45, 0.2),
    0 0 0 2px rgba(255, 255, 255, 0.9),
    0 0 0 4px rgba(255, 213, 79, 0.35);
}

.ht-btn-cta:disabled {
  opacity: 0.5;
  cursor: not-allowed;
  transform: none;
}

.dark .ht-btn-cta {
  color: #1a2a3a !important;
}

/* การ์ดสถิติ — ไฮไลต์ gradient ฟ้า */
.ht-stat-hero {
  background: linear-gradient(145deg, #66a6ff 0%, #4facfe 55%, #1976d2 100%) !important;
  border-color: rgba(255, 255, 255, 0.22) !important;
  color: #ffffff;
  box-shadow:
    0 12px 40px -12px rgba(25, 118, 210, 0.45),
    inset 0 1px 0 rgba(255, 255, 255, 0.28);
}

.ht-stat-hero .text-sky-600\/90,
.ht-stat-hero .text-sky-600,
.ht-stat-hero .text-sky-500\/85 {
  color: rgba(255, 255, 255, 0.88) !important;
}

.ht-stat-hero .text-3xl,
.ht-stat-hero .text-xl {
  color: #ffffff !important;
}

.dark .ht-stat-hero {
  background: linear-gradient(145deg, #1e4d8c 0%, #1565c0 55%, #0d47a1 100%) !important;
  border-color: rgba(102, 166, 255, 0.22) !important;
}

/* แถบผู้รายงาน */
.ht-reporter-bar {
  border-color: rgba(102, 166, 255, 0.22) !important;
  background: linear-gradient(
    90deg,
    rgba(255, 255, 255, 0.95) 0%,
    rgba(238, 244, 255, 0.92) 50%,
    rgba(255, 251, 235, 0.88) 100%
  ) !important;
  backdrop-filter: blur(8px);
}

.dark .ht-reporter-bar {
  border-color: rgba(102, 166, 255, 0.14);
  background: linear-gradient(
    90deg,
    rgba(10, 22, 40, 0.96) 0%,
    rgba(21, 56, 120, 0.28) 50%,
    rgba(10, 22, 40, 0.96) 100%
  );
}

/* ฟุตเตอร์ */
.dark footer[role='contentinfo'].ht-site-footer,
.dark .ht-site-footer {
  border-color: rgba(102, 166, 255, 0.12);
}

footer[role='contentinfo'].ht-site-footer,
.ht-site-footer {
  border-color: rgba(102, 166, 255, 0.16);
}

/* เมนูแบบเลื่อนลง (แอดมิน) */
.dark nav.ht-nav details.admin-nav-dd > div.absolute {
  box-shadow:
    0 20px 50px -12px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(102, 166, 255, 0.12);
}

nav.ht-nav details.admin-nav-dd > div.absolute {
  border-radius: 0.625rem !important;
  border-color: rgba(102, 166, 255, 0.2) !important;
  box-shadow: 0 16px 48px -12px rgba(25, 118, 210, 0.22);
}

/* หัวเรื่องหลัก */
body.ht-app h1,
body.ht-app h2:not(.sr-only) {
  font-family: 'Kanit', 'Sarabun', system-ui, sans-serif;
  line-height: 1.35;
  word-break: break-word;
  overflow-wrap: anywhere;
}

body.ht-app h1 {
  color: var(--ht-ink);
}

.dark body.ht-app h1 {
  color: #f1f5f9;
}

/* ตาราง — หัวตารางโทนฟ้าอ่อน */
body.ht-app thead tr.bg-sky-50\/80 {
  background: linear-gradient(180deg, rgba(238, 244, 255, 0.95) 0%, rgba(220, 233, 255, 0.85) 100%) !important;
}

.dark body.ht-app thead tr.bg-sky-50\/80 {
  background: linear-gradient(180deg, rgba(30, 51, 84, 0.92) 0%, rgba(20, 38, 66, 0.9) 100%) !important;
  color: #cbd5e1 !important;
}

/* ตาราง — แถวสรุป / ส่วนท้าย ในโหมดมืด */
.dark body.ht-app tfoot tr.bg-sky-50\/60 {
  background: rgba(30, 51, 84, 0.55) !important;
}

/* SweetAlert */
.swal2-popup {
  font-family: 'Sarabun', system-ui, sans-serif !important;
  border-radius: 0.75rem !important;
  border: 1px solid rgba(102, 166, 255, 0.22) !important;
}

.swal2-title {
  font-family: 'Kanit', 'Sarabun', system-ui, sans-serif !important;
  color: var(--ht-ink) !important;
}

.swal2-confirm {
  background: linear-gradient(135deg, #ffe082 0%, #ffd54f 52%, #fbc02d 100%) !important;
  color: #2c3e50 !important;
  border-radius: 1rem !important;
  font-weight: 600 !important;
  box-shadow: 0 6px 20px -4px rgba(251, 192, 45, 0.45) !important;
}

.swal2-cancel {
  border-radius: 1rem !important;
}

.dark .swal2-popup {
  background: linear-gradient(165deg, #1a2f4d 0%, #0f172a 100%) !important;
  color: #e2e8f0 !important;
  border: 1px solid rgba(102, 166, 255, 0.18) !important;
  box-shadow:
    0 24px 48px -12px rgba(0, 0, 0, 0.55),
    0 0 0 1px rgba(102, 166, 255, 0.06) !important;
}

.dark .swal2-html-container,
.dark .swal2-title {
  color: #f1f5f9 !important;
}

.dark .swal2-timer-progress-bar {
  background: rgba(102, 166, 255, 0.28) !important;
}

.dark .swal2-confirm {
  color: #1a2a3a !important;
}
