/* Mu WebShop — ธีมดำ-ทอง ให้เข้ากับหน้า landing (มิวซีซั่น6) */

/* ฟอนต์โฮสต์ในเครื่อง (ไม่ดึงจาก Google — โหลดเร็ว/ใช้ได้แม้เน็ตช้า) */
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/kanit-300-thai.woff2') format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 300;
  font-display: swap;
  src: url('fonts/kanit-300-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/kanit-400-thai.woff2') format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 400;
  font-display: swap;
  src: url('fonts/kanit-400-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/kanit-500-thai.woff2') format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 500;
  font-display: swap;
  src: url('fonts/kanit-500-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/kanit-600-thai.woff2') format('woff2');
  unicode-range: U+02D7, U+0303, U+0331, U+0E01-0E5B, U+200C-200D, U+25CC;
}
@font-face {
  font-family: 'Kanit';
  font-style: normal;
  font-weight: 600;
  font-display: swap;
  src: url('fonts/kanit-600-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}
@font-face {
  font-family: 'Oxanium';
  font-style: normal;
  font-weight: 200 800;
  font-display: swap;
  src: url('fonts/oxanium-var-latin.woff2') format('woff2');
  unicode-range: U+0000-00FF, U+0131, U+0152-0153, U+02BB-02BC, U+02C6, U+02DA, U+02DC, U+2000-206F, U+20AC, U+2122, U+2212, U+FEFF, U+FFFD;
}

:root {
  --ws-primary: #b8892f;
  --ws-secondary: #d6b56f;
  --ws-accent: #8f6a2b;
  --ws-bg-dark: #050608;
  --ws-bg-soft: #0c0f15;
  --ws-card: rgba(18, 20, 26, 0.88);
  --ws-card-solid: #12141a;
  --ws-panel: #0e1117;
  --ws-glass-border: rgba(214, 181, 111, 0.22);
  --ws-border: rgba(214, 181, 111, 0.3);
  --ws-text: #f3f0e8;
  --ws-muted: #b3ab9b;
  --ws-green: #58c878;
  --ws-red: #ff5a6e;
  --ws-font: 'Kanit', tahoma, verdana, arial, sans-serif;
  --ws-font-heading: 'Oxanium', 'Kanit', sans-serif;
}

* {
  box-sizing: border-box;
}

body.ws-body {
  margin: 0;
  padding: 0;
  font-family: var(--ws-font);
  font-size: 13px;
  color: var(--ws-text);
  background: linear-gradient(180deg, var(--ws-bg-dark) 0%, var(--ws-bg-soft) 100%) fixed;
  background-color: var(--ws-bg-dark);
  -webkit-user-select: none;
  user-select: none;
}

body.ws-body input,
body.ws-body textarea,
body.ws-body select,
body.ws-body .ws-login-box input {
  -webkit-user-select: text;
  user-select: text;
}

.ws-shell {
  display: flex;
  min-height: 100vh;
}

/* ===== เมนูซ้าย — การ์ดดำขอบทองแบบเมนูหน้า landing ===== */
.ws-sidebar {
  width: 230px;
  flex-shrink: 0;
  background: linear-gradient(180deg, rgba(10, 12, 16, 0.96) 0%, rgba(7, 8, 11, 0.98) 100%);
  border-right: 1px solid var(--ws-glass-border);
  display: flex;
  flex-direction: column;
}

.ws-brand {
  padding: 16px 14px 12px;
  border-bottom: 1px solid var(--ws-glass-border);
  background: transparent;
  text-align: center;
}

.ws-brand h1 {
  margin: 0;
  font-family: var(--ws-font-heading);
  font-size: 17px;
  font-weight: 800;
  letter-spacing: 1px;
  color: var(--ws-secondary);
  text-shadow: 0 0 14px rgba(214, 181, 111, 0.45);
  text-transform: uppercase;
}

.ws-brand p {
  margin: 4px 0 0;
  font-size: 11px;
  letter-spacing: 3px;
  color: var(--ws-muted);
  text-transform: uppercase;
}

.ws-nav {
  flex: 1;
  padding: 12px 10px;
  overflow-y: auto;
  display: flex;
  flex-direction: column;
  gap: 7px;
}

.ws-nav a {
  display: block;
  padding: 9px 12px;
  background: rgba(18, 20, 26, 0.88);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  color: #ffffff !important;
  text-decoration: none !important;
  font-family: var(--ws-font);
  font-size: 13px;
  font-weight: 500;
  line-height: 1.3;
  transition: 0.25s ease;
}

.ws-nav a:hover,
.ws-nav a.ws-active {
  color: var(--ws-secondary) !important;
  background: rgba(184, 137, 47, 0.18);
  border-color: var(--ws-primary);
  box-shadow: 0 4px 18px rgba(184, 137, 47, 0.22);
}

.ws-nav a.ws-active {
  background: rgba(184, 137, 47, 0.26);
}

.ws-nav hr {
  border: none;
  border-top: 1px dashed rgba(214, 181, 111, 0.25);
  margin: 5px 4px;
}

.ws-nav .ws-admin a,
.ws-nav a.ws-admin {
  color: #ffd9a0 !important;
  font-style: italic;
}

.ws-sidebar-footer {
  padding: 10px 12px;
  border-top: 1px solid var(--ws-glass-border);
}

.ws-lang-picker {
  display: flex;
  flex-direction: column;
  gap: 4px;
}

.ws-lang-picker__label {
  font-size: 10px;
  font-weight: 600;
  color: var(--ws-muted);
  text-transform: uppercase;
  letter-spacing: 0.08em;
}

.ws-lang-picker__form {
  margin: 0;
}

.ws-lang-picker__select {
  width: 100%;
}

.ws-sidebar-footer select,
.ws-lang-picker__select {
  width: 100%;
  font-family: var(--ws-font);
  font-size: 12px;
  font-weight: 500;
  color: var(--ws-text);
  background: var(--ws-panel);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  padding: 4px 6px;
}

/* ===== ส่วนหลัก ===== */
.ws-main {
  flex: 1;
  display: flex;
  flex-direction: column;
  min-width: 0;
  background: transparent;
}

.ws-topbar {
  background: rgba(10, 12, 16, 0.92);
  border-bottom: 1px solid var(--ws-glass-border);
  padding: 10px 24px;
  display: flex;
  align-items: center;
  justify-content: space-between;
  font-family: var(--ws-font);
  font-size: 13px;
  color: var(--ws-text);
}

.ws-topbar-right {
  display: flex;
  align-items: center;
  gap: 12px;
}

.ws-settings-top {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208 !important;
  font-weight: 600;
  padding: 5px 14px;
  border: 1px solid var(--ws-accent);
  border-radius: 3px;
  text-decoration: none;
  transition: 0.2s ease;
}

.ws-settings-top:hover {
  filter: brightness(1.12);
  box-shadow: 0 0 14px rgba(184, 137, 47, 0.45);
}

.ws-settings-top--active {
  outline: 2px solid var(--ws-secondary);
  outline-offset: 1px;
}

.ws-credits-badge {
  background: rgba(18, 20, 26, 0.9);
  color: var(--ws-secondary);
  font-weight: 600;
  padding: 5px 14px;
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
}

.ws-credits-badge b {
  color: #ffe9b0;
}

/* ===== หน้า ตั้งค่าร้าน / ฟอร์มแอดมิน ===== */
.ws-settings {
  max-width: 720px;
  background: var(--ws-card);
  border: 1px solid var(--ws-glass-border);
  border-radius: 4px;
  padding: 20px 24px;
}

.ws-settings-section {
  margin: 0 0 22px;
  padding: 0 0 18px;
  border-bottom: 1px solid rgba(214, 181, 111, 0.15);
}

.ws-settings-section:last-of-type {
  border-bottom: none;
}

.ws-settings-subtitle {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ws-secondary);
}

.ws-settings-list--inline {
  display: flex;
  flex-wrap: wrap;
  gap: 8px 20px;
}

.ws-settings-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(200px, 1fr));
  gap: 10px 16px;
}

.ws-settings-cat-table {
  width: 100%;
  max-width: 520px;
  border-collapse: collapse;
  font-size: 12px;
}

.ws-settings-cat-table th,
.ws-settings-cat-table td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(214, 181, 111, 0.15);
  text-align: left;
  vertical-align: middle;
}

.ws-settings-cat-table th {
  font-weight: 600;
  background: rgba(184, 137, 47, 0.12);
  color: var(--ws-secondary);
}

.ws-settings-cat-id {
  width: 4.5em;
  white-space: nowrap;
}

.ws-settings-cat-input {
  width: 100%;
  max-width: 280px;
  box-sizing: border-box;
}

.ws-settings-cat-show {
  width: 5em;
  text-align: center;
}

.ws-im-image-file-block {
  margin: 0 0 14px;
  padding: 10px 12px;
  background: var(--ws-panel);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
}

.ws-im-image-file-block .ws-im-input--wide {
  width: 100%;
  max-width: 320px;
  box-sizing: border-box;
}

.ws-im-check--clear-img {
  display: block;
  margin-top: 8px;
}

.ws-im-thumb--missing {
  outline: 2px dashed var(--ws-red);
  outline-offset: 1px;
  opacity: 0.85;
}

.ws-im-thumb--broken {
  display: none !important;
}

.ws-im-preview .ws-im-thumb--missing + .ws-im-missing-label,
.ws-im-preview:has(.ws-im-thumb--broken) .ws-im-missing-label {
  display: block;
}

.ws-settings-field {
  display: flex;
  flex-direction: column;
  gap: 4px;
  font-size: 12px;
}

.ws-settings-field-label {
  font-weight: 600;
  line-height: 1.3;
  color: var(--ws-text);
}

.ws-settings-field input[type="number"],
.ws-settings-field input[type="text"] {
  width: 100%;
  max-width: 140px;
  padding: 4px 6px;
  box-sizing: border-box;
}

.ws-settings-check-row {
  display: flex;
  align-items: center;
  gap: 8px;
  font-size: 13px;
  cursor: pointer;
}

.ws-settings-title {
  margin: 0 0 8px;
  font-family: var(--ws-font-heading);
  font-size: 17px;
  font-weight: 700;
  color: var(--ws-secondary);
  text-shadow: 0 0 10px rgba(214, 181, 111, 0.3);
}

.ws-settings-lead {
  margin: 0 0 16px;
  line-height: 1.5;
  color: var(--ws-muted);
}

.ws-settings-list {
  list-style: none;
  margin: 0 0 12px;
  padding: 0;
}

.ws-settings-list li {
  margin: 0 0 8px;
}

.ws-settings-list label {
  display: flex;
  align-items: center;
  gap: 8px;
  cursor: pointer;
  font-size: 13px;
}

.ws-settings-list input[type="checkbox"] {
  width: 16px;
  height: 16px;
  cursor: pointer;
  accent-color: var(--ws-primary);
}

.ws-settings-hint {
  margin: 0 0 16px;
  color: var(--ws-muted);
  font-size: 12px;
}

.ws-settings-hint--important {
  color: #ffd9a0;
  background: rgba(184, 137, 47, 0.12);
  border: 1px solid var(--ws-border);
  padding: 8px 10px;
  border-radius: 3px;
}

.ws-im-image-diag {
  font-size: 12px;
}

.ws-im-image-diag a {
  word-break: break-all;
}

.ws-settings-msg--warn {
  background: rgba(184, 137, 47, 0.14);
  border-color: var(--ws-primary);
  color: #ffd9a0;
}

.ws-settings-actions {
  margin-top: 8px;
}

.ws-settings-btn-save {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208;
  border: 1px solid var(--ws-accent);
  border-radius: 3px;
  padding: 7px 18px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--ws-font);
  font-size: 13px;
  transition: 0.2s ease;
}

.ws-settings-btn-save:hover {
  filter: brightness(1.12);
  box-shadow: 0 0 14px rgba(184, 137, 47, 0.45);
}

.ws-settings-msg {
  padding: 8px 12px;
  margin: 0 0 12px;
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  background: var(--ws-card);
}

.ws-settings-msg--ok {
  background: rgba(88, 200, 120, 0.12);
  border-color: var(--ws-green);
  color: #8ef0b4;
}

.ws-settings-msg--err {
  background: rgba(255, 90, 110, 0.12);
  border-color: var(--ws-red);
  color: #ff9aab;
}

.ws-wh-inline-warn {
  max-width: 400px;
  margin: 0 0 12px;
  padding: 10px 12px;
  font-size: 0.9rem;
  line-height: 1.45;
}

/* ===== จัดการไอเทมแอดมิน ===== */
.ws-im-admin {
  max-width: 1200px;
}

.ws-im-toolbar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 10px 12px;
  margin: 0 0 14px;
}

.ws-im-search-form {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 8px;
  flex: 1;
  min-width: 200px;
}

.ws-im-search-input {
  min-width: 160px;
  padding: 4px 8px;
  font-size: 12px;
  border: 1px solid var(--ws-glass-border);
}

.ws-im-select {
  padding: 4px 6px;
  font-size: 12px;
  border: 1px solid var(--ws-glass-border);
}

.ws-im-count {
  font-size: 12px;
  color: var(--ws-muted);
  white-space: nowrap;
}

.ws-im-btn {
  display: inline-block;
  padding: 6px 12px;
  font-size: 12px;
  font-weight: 600;
  text-decoration: none;
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  background: var(--ws-card-solid);
  color: var(--ws-text);
  cursor: pointer;
  font-family: var(--ws-font);
  transition: 0.2s ease;
}

.ws-im-btn:hover {
  border-color: var(--ws-primary);
  color: var(--ws-secondary);
  background: rgba(184, 137, 47, 0.15);
}

.ws-im-btn--primary {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208;
  border-color: var(--ws-accent);
}

.ws-im-btn--primary:hover {
  filter: brightness(1.12);
  color: #1a1208;
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
}

.ws-im-btn--ghost {
  background: transparent;
}

.ws-im-btn--danger {
  background: #7a1f2b;
  color: #ffffff;
  border-color: var(--ws-red);
  margin-top: 12px;
}

.ws-im-btn--danger:hover {
  background: #93202f;
  color: #ffffff;
}

.ws-im-layout {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-start;
  gap: 16px;
}

.ws-im-list-panel {
  flex: 1 1 420px;
  min-width: 0;
  max-height: 70vh;
  overflow: auto;
  border: 1px solid var(--ws-glass-border);
  border-radius: 4px;
  background: var(--ws-card);
}

.ws-im-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
}

.ws-im-table th,
.ws-im-table td {
  padding: 6px 8px;
  border-bottom: 1px solid rgba(214, 181, 111, 0.12);
  text-align: left;
}

.ws-im-table th {
  background: #1a1d24;
  color: var(--ws-secondary);
  font-weight: 600;
  position: sticky;
  top: 0;
  z-index: 1;
}

.ws-im-row--active {
  background: rgba(184, 137, 47, 0.2);
}

.ws-im-row:hover {
  background: rgba(184, 137, 47, 0.1);
}

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

.ws-im-muted {
  color: var(--ws-muted);
  font-size: 11px;
}

.ws-im-link {
  font-weight: 600;
}

.ws-im-edit-panel {
  flex: 1 1 340px;
  min-width: 300px;
  max-width: 480px;
  border: 1px solid var(--ws-glass-border);
  border-radius: 4px;
  background: var(--ws-card);
  padding: 14px 16px;
  max-height: 85vh;
  overflow-y: auto;
  box-sizing: border-box;
}

.ws-im-edit-panel--empty {
  display: flex;
  align-items: center;
  justify-content: center;
  min-height: 200px;
}

.ws-im-hint {
  margin: 0;
  font-size: 13px;
  color: var(--ws-muted);
  text-align: center;
}

.ws-im-section-label {
  margin: 0 0 8px;
  font-size: 13px;
  font-weight: 600;
  color: var(--ws-secondary);
}

.ws-im-preview {
  margin: 0 0 10px;
  text-align: center;
}

.ws-im-categories {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin: 0 0 12px;
  padding: 8px;
  background: var(--ws-panel);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
}

.ws-im-cat {
  display: inline-block;
  padding: 4px 10px;
  font-size: 11px;
  font-weight: 600;
  text-decoration: none;
  color: var(--ws-text);
  background: var(--ws-card-solid);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  transition: 0.2s ease;
}

.ws-im-cat:hover {
  border-color: var(--ws-primary);
  color: var(--ws-secondary);
}

.ws-im-cat--active {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208;
  border-color: var(--ws-accent);
}

.ws-im-cat-title {
  margin: 0 0 10px;
  font-size: 14px;
  font-weight: 600;
  color: var(--ws-secondary);
}

.ws-im-col-img {
  width: 36px;
  text-align: center;
}

.ws-im-thumb,
.ws-im-thumb-sm,
.ws-im-thumb-lg {
  image-rendering: pixelated;
  vertical-align: middle;
}

.ws-im-thumb-sm {
  max-width: 28px;
  max-height: 28px;
}

.ws-im-thumb {
  max-width: 64px;
  max-height: 64px;
}

.ws-im-thumb-lg {
  max-width: 96px;
  max-height: 96px;
  display: block;
  margin: 0 auto;
}

.ws-im-preview-box {
  text-align: center;
  margin: 0 0 12px;
  padding: 10px;
  background: #0a0c10;
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  box-shadow: inset 0 0 16px rgba(0, 0, 0, 0.6);
}

.ws-im-preview-hint {
  margin: 6px 0 0;
  font-size: 11px;
  color: var(--ws-muted);
}

.ws-im-empty--prompt {
  padding: 24px 16px;
  text-align: center;
  color: var(--ws-muted);
}

.ws-im-delete-all-form {
  display: inline;
}

.ws-im-import-zone {
  margin-top: 20px;
  padding: 12px 14px;
  border: 1px solid rgba(91, 140, 255, 0.4);
  border-radius: 3px;
  background: rgba(91, 140, 255, 0.08);
  font-size: 12px;
}

.ws-im-import-zone summary {
  cursor: pointer;
  font-weight: 600;
  color: #8ab4ff;
}

.ws-im-import-form .ws-im-input--wide {
  width: 100%;
  max-width: 42rem;
  box-sizing: border-box;
}

.ws-im-import-options {
  margin: 10px 0;
  padding: 8px 10px;
  border: 0;
}

.ws-im-import-undo {
  margin-top: 16px;
  padding-top: 14px;
  border-top: 1px solid rgba(91, 140, 255, 0.3);
}

.ws-im-import-undo-title {
  margin: 0 0 8px;
  font-size: 13px;
  color: #8ab4ff;
}

.ws-im-import-undo-seed {
  margin-top: 12px;
}

.ws-im-import-undo-seed summary {
  cursor: pointer;
  font-weight: 600;
  color: #ff9aab;
}

.ws-im-danger-zone {
  margin-top: 20px;
  padding: 12px 14px;
  border: 1px solid rgba(255, 90, 110, 0.45);
  border-radius: 3px;
  background: rgba(255, 90, 110, 0.08);
  font-size: 12px;
}

.ws-im-danger-zone summary {
  cursor: pointer;
  font-weight: 600;
  color: #ff9aab;
}

.ws-im-delete-confirm-input {
  display: block;
  margin: 8px 0;
  padding: 4px 8px;
  width: 100%;
  max-width: 200px;
  border: 1px solid var(--ws-glass-border);
  font-size: 12px;
}

.ws-im-inline-2 {
  display: flex;
  align-items: center;
  gap: 4px;
}

.ws-im-inline-2 input {
  width: 48px;
}

.ws-im-radio-group {
  margin: 10px 0 0;
  font-size: 12px;
  line-height: 1.6;
}

.ws-im-radio-group label {
  display: inline-block;
  margin-right: 10px;
  cursor: pointer;
}

.ws-im-form-actions {
  display: flex;
  flex-wrap: wrap;
  gap: 10px;
  align-items: center;
  margin-top: 8px;
}

.ws-im-delete-form {
  border-top: 1px solid rgba(214, 181, 111, 0.15);
  margin-top: 14px;
  padding-top: 4px;
}

/* ===== เนื้อหา ===== */
.ws-content {
  flex: 1;
  padding: 24px 30px;
  overflow-x: auto;
  background: transparent;
}

.ws-footer {
  text-align: center;
  padding: 8px;
  font-size: 12px;
  font-family: var(--ws-font);
  color: var(--ws-muted);
  background: rgba(10, 12, 16, 0.92);
  border-top: 1px solid var(--ws-glass-border);
}

.ws-footer a {
  color: var(--ws-secondary);
  text-decoration: none;
  border-bottom: 1px dashed var(--ws-primary);
}

.ws-content fieldset,
fieldset.ws-card {
  background: var(--ws-card);
  border: 1px solid var(--ws-glass-border);
  border-radius: 4px;
  padding: 10px;
  margin-bottom: 12px;
  max-width: 100%;
  color: var(--ws-text);
}

.ws-content fieldset legend,
fieldset.ws-card legend {
  font-weight: 600;
  font-family: var(--ws-font-heading);
  color: var(--ws-secondary);
  padding: 0 6px;
  letter-spacing: 0.5px;
}

.mu_style2 {
  font-family: var(--ws-font);
  color: var(--ws-text) !important;
}

.ws-content p,
.ws-content td,
.ws-content tr,
.ws-content li,
.ws-content ul {
  color: var(--ws-text);
  font-family: var(--ws-font);
  font-size: 12px;
}

.ws-content a:link,
.ws-content a:visited {
  color: var(--ws-secondary);
  text-decoration: none;
}

.ws-content a:hover {
  color: #ffe9b0;
  border-bottom: 1px dashed var(--ws-primary);
}

.ws-content input,
.ws-content select,
.ws-content textarea {
  font-family: var(--ws-font);
  font-size: 12px;
  font-weight: 500;
  color: var(--ws-text);
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  background: var(--ws-panel);
  padding: 3px 6px;
}

.ws-content input:focus,
.ws-content select:focus,
.ws-content textarea:focus {
  outline: none;
  border-color: var(--ws-primary);
  box-shadow: 0 0 8px rgba(184, 137, 47, 0.35);
}

.ws-content input[type="submit"],
.ws-content button {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208;
  border: 1px solid var(--ws-accent);
  font-weight: 600;
  cursor: pointer;
}

.ws-content input[type="submit"]:hover,
.ws-content button:hover {
  filter: brightness(1.12);
  box-shadow: 0 0 12px rgba(184, 137, 47, 0.4);
}

.itemblock {
  border-right: 1px solid #222222;
  border-bottom: 1px solid #222222;
  border-left: 1px solid #bbbbbb;
  border-top: 1px solid #bbbbbb;
  background: #777777;
}

/* หน้าแรก: บัญชีซ้าย + คลังขวา (table layout — fieldset ใน .ws-content กว้าง 100% ทำให้ flex ตกบรรทัด) */
.ws-home-top,
table.ws-home-layout.ws-home-top {
  display: table;
  width: auto;
  max-width: 100%;
  margin: 0 0 14px;
  border-collapse: separate;
  border-spacing: 0;
}

.ws-home-top > tbody > tr > td.ws-home-account,
.ws-home-top > tr > td.ws-home-account,
td.ws-home-account {
  vertical-align: top;
  padding: 0;
  width: auto;
}

.ws-home-top > tbody > tr > td.ws-home-warehouse,
.ws-home-top > tr > td.ws-home-warehouse,
td.ws-home-warehouse {
  vertical-align: top;
  padding: 0 0 0 14px;
  width: auto;
}

/* รองรับ markup แบบ div (เก่า) */
div.ws-home-top {
  display: flex;
  flex-wrap: nowrap;
  align-items: flex-start;
  gap: 10px 14px;
}

div.ws-home-top .ws-home-account,
div.ws-home-top .ws-home-warehouse {
  flex: 0 0 auto;
  max-width: none;
}

.ws-content .ws-home-top fieldset,
.ws-home-top fieldset {
  max-width: none !important;
  width: auto !important;
}

.ws-home-account-box {
  width: 280px;
  max-width: 100%;
  margin: 0 !important;
  padding: 6px 10px 8px !important;
  background: var(--ws-card) !important;
  border: 1px solid var(--ws-glass-border) !important;
  box-sizing: border-box;
}

.ws-home-account-table {
  width: 100%;
}

.ws-home-sms {
  width: 100%;
  max-width: 620px;
  margin-bottom: 12px;
  box-sizing: border-box;
}

.ws-home-note {
  width: 100%;
  max-width: 620px;
  margin-bottom: 10px;
  box-sizing: border-box;
}

.ws-home-note__body {
  text-align: justify;
  font-size: 12px;
  line-height: 1.5;
}

.ws-home-feedback {
  text-align: center;
  margin-top: 4px;
}

.ws-wh-fieldset {
  display: block;
  width: auto;
  max-width: none;
  margin: 0 !important;
  padding: 6px 10px 8px;
  border: 1px solid var(--ws-glass-border);
  background: var(--ws-card);
  box-sizing: border-box;
}

.ws-wh-fieldset__body {
  padding: 2px 0 0;
  text-align: left;
  overflow: hidden;
}

.ws-wh-grid-wrap {
  display: inline-block;
  vertical-align: top;
  line-height: 0;
  max-height: calc(32px * 15 + 4px);
  overflow: hidden;
}

/* ซ่อนแถว 16+ ถ้า HTML เก่าหรือ DB คลังยาวกว่าเกม */
.ws-wh-grid-wrap .ws-wh-grid tbody tr:nth-child(n + 16) {
  display: none !important;
  height: 0 !important;
  line-height: 0 !important;
  visibility: hidden !important;
}

.ws-wh-grid {
  border-collapse: collapse;
  background-color: #777777;
  border: 1px solid rgba(214, 181, 111, 0.4);
  table-layout: fixed;
}

.ws-wh-grid tbody {
  display: table-row-group;
}

.ws-wh-grid tr {
  height: 32px;
  max-height: 32px;
}

.ws-wh-grid td.itemblock {
  width: 32px;
  height: 32px;
  min-width: 32px;
  min-height: 32px;
  box-sizing: border-box;
}

.ws-wh-row-label {
  width: 26px;
  min-width: 26px;
  max-width: 26px;
  padding: 0 4px !important;
  font-size: 10px;
  line-height: 1.2;
  vertical-align: middle;
  background: #666666 !important;
  color: #eeeeee;
}

/* ช่องจอง — ไอเทมยังไม่อยู่ในร้าน / ไม่มีรูป */
.ws-wh-grid td.ws-wh-slot-occupied {
  background: #222222 !important;
  border-color: #111111 #666666 #666666 #111111;
  cursor: not-allowed;
  padding: 0 !important;
}

.ws-wh-occupied-inner {
  box-sizing: border-box;
  display: block;
  margin: 0;
  overflow: hidden;
  pointer-events: none;
}

/* ผู้เล่น: ทึบดำ + ข้อความสีแดงกลางช่อง (แบบ +level บนไอเทม) */
.ws-wh-occupied-inner--user {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #000000 !important;
  border: 1px solid #1a1a1a;
}

.ws-wh-occupied-label {
  font-family: tahoma, verdana, sans-serif;
  font-size: 11px;
  font-weight: bold;
  font-variant: normal;
  color: #ff2222;
  line-height: 1.15;
  text-align: center;
  word-break: break-word;
  padding: 1px 2px;
}

/* แอดมินดูคลัง: รหัส type-id สีแดง */
.ws-wh-occupied-inner--admin {
  display: flex;
  align-items: center;
  justify-content: center;
  background: #1a1a1a !important;
  border: 1px solid #333333;
}

.ws-wh-item-code {
  font-family: tahoma, verdana, sans-serif;
  font-size: 11px;
  font-weight: bold;
  color: #ff2222;
  line-height: 1.1;
  text-align: center;
  word-break: break-all;
}

/* แจ้งเตือนคลังต้องว่างก่อนซื้อ/รับไอเทม */
.ws-wh-guard-overlay {
  display: none;
  position: fixed;
  inset: 0;
  z-index: 99999;
  align-items: center;
  justify-content: center;
  background: rgba(0, 0, 0, 0.78);
  padding: 16px;
  box-sizing: border-box;
}

.ws-wh-guard-modal {
  max-width: 420px;
  width: 100%;
  background: linear-gradient(180deg, #16181f 0%, #0c0e13 100%);
  border: 2px solid var(--ws-red);
  border-radius: 8px;
  box-shadow: 0 8px 32px rgba(0, 0, 0, 0.75), 0 0 24px rgba(255, 90, 110, 0.25);
  padding: 20px 18px 16px;
  text-align: center;
  font-family: var(--ws-font);
  color: var(--ws-text);
}

.ws-wh-guard-icon {
  display: inline-flex;
  align-items: center;
  justify-content: center;
  width: 52px;
  height: 52px;
  margin: 0 auto 10px;
  border-radius: 50%;
  background: var(--ws-red);
  color: #ffffff;
  font-size: 32px;
  font-weight: bold;
  line-height: 1;
  box-shadow: 0 0 0 4px rgba(214, 181, 111, 0.6);
}

.ws-wh-guard-title {
  margin: 0 0 8px;
  font-size: 17px;
  font-weight: 600;
  color: #ff9aab;
}

.ws-wh-guard-message {
  margin: 0 0 16px;
  font-size: 14px;
  font-weight: 500;
  color: var(--ws-text);
  line-height: 1.45;
}

.ws-wh-guard-close {
  cursor: pointer;
  min-width: 120px;
  padding: 8px 20px;
  font-size: 13px;
  font-weight: 600;
  color: #ffffff;
  background: var(--ws-red);
  border: 1px solid #93202f;
  border-radius: 4px;
}

.ws-wh-guard-close:hover {
  filter: brightness(1.1);
}

.cl2 {
  text-align: center;
  border: 1px solid var(--ws-glass-border);
  background-color: var(--ws-card-solid) !important;
  color: var(--ws-text) !important;
}

.thetop {
  width: 330px;
  max-width: 100%;
  background-color: var(--ws-card-solid);
  border: 1px solid var(--ws-glass-border);
  color: var(--ws-text);
}

.ws-content .ws-item-cat {
  cursor: pointer;
  color: var(--ws-text) !important;
  text-decoration: underline;
  font-family: var(--ws-font);
  font-size: 12px;
  line-height: 1.7;
}

.ws-content .ws-item-cat:hover {
  color: var(--ws-secondary) !important;
  background-color: rgba(184, 137, 47, 0.15);
}

.ws-content .ws-item-cats table td {
  vertical-align: top;
  padding-right: 12px;
}

.ws-content #item_content {
  min-height: 80px;
}

.ws-content #item_content fieldset {
  background-color: var(--ws-card);
  border: 1px solid var(--ws-glass-border);
}

.ws-content #item_content .eachl a {
  cursor: pointer;
  text-decoration: underline;
  color: var(--ws-secondary);
}

.ws-content #item_content tr:hover {
  background-color: rgba(184, 137, 47, 0.12);
}

.ws-item-list-table .ws-im-col-img {
  width: 40px;
  text-align: center;
  vertical-align: middle;
  padding: 4px 6px !important;
}

.ws-item-list-table .ws-im-thumb-sm {
  display: block;
  margin: 0 auto;
}

/* ===== หน้าล็อกอิน ===== */
body.ws-login-page {
  background: linear-gradient(180deg, var(--ws-bg-dark) 0%, var(--ws-bg-soft) 100%) fixed;
  background-color: var(--ws-bg-dark);
  color: var(--ws-text);
}

body.ws-login-page .ws-login-header {
  width: 100%;
  background: rgba(10, 12, 16, 0.92);
  color: var(--ws-secondary);
  font-family: var(--ws-font-heading);
  font-size: 15px;
  font-weight: 700;
  letter-spacing: 0.5px;
  padding: 10px 14px;
  border-bottom: 1px solid var(--ws-glass-border);
  text-shadow: 0 0 12px rgba(214, 181, 111, 0.35);
}

body.ws-login-page .ws-login-footer {
  font-weight: 500;
  font-size: 12px;
  font-family: var(--ws-font);
  color: var(--ws-muted);
  text-align: center;
}

body.ws-login-page .ws-login-footer a {
  color: var(--ws-secondary);
  text-decoration: underline;
}

body.ws-login-page .ws-login-box {
  max-width: 340px;
  margin: 0 auto;
  min-height: 180px;
  display: flex;
  align-items: center;
  justify-content: center;
  color: var(--ws-text);
}

body.ws-login-page .ws-login-box,
body.ws-login-page .ws-login-box * {
  color: var(--ws-text);
}

body.ws-login-page .ws-login-box a {
  color: var(--ws-secondary);
  text-decoration: underline;
}

body.ws-login-page .ws-login-form {
  padding: 0;
  margin: 0;
}

body.ws-login-page .ws-login-fieldset {
  width: 300px;
  margin: 0;
  padding: 18px 18px 14px;
  border: 1px solid var(--ws-glass-border);
  border-radius: 4px;
  background: var(--ws-card);
  box-shadow: 0 14px 44px rgba(0, 0, 0, 0.6), 0 0 24px rgba(184, 137, 47, 0.12);
}

body.ws-login-page .ws-login-title {
  margin: 0 0 12px;
  padding: 0 0 10px;
  border-bottom: 1px solid var(--ws-glass-border);
  font-size: 15px;
  font-weight: 700;
  font-family: var(--ws-font-heading);
  color: var(--ws-secondary);
  text-align: center;
  text-shadow: 0 0 12px rgba(214, 181, 111, 0.35);
}

body.ws-login-page .ws-login-table {
  width: 100%;
}

body.ws-login-page .ws-login-table td {
  font-family: var(--ws-font) !important;
  font-size: 13px !important;
  font-weight: 500 !important;
}

body.ws-login-page .ws-login-box label,
body.ws-login-page .ws-login-box td {
  color: var(--ws-text);
}

body.ws-login-page .ws-login-box input[type="text"],
body.ws-login-page .ws-login-box input[type="password"] {
  background: var(--ws-panel) !important;
  border: 1px solid var(--ws-glass-border);
  border-radius: 3px;
  color: var(--ws-text) !important;
  font-family: var(--ws-font);
  padding: 5px 8px !important;
}

body.ws-login-page .ws-login-box input[type="text"]:focus,
body.ws-login-page .ws-login-box input[type="password"]:focus {
  outline: none;
  border-color: var(--ws-primary);
  box-shadow: 0 0 8px rgba(184, 137, 47, 0.35);
}

body.ws-login-page .ws-login-box input[type="checkbox"] {
  accent-color: var(--ws-primary);
}

body.ws-login-page .ws-login-box input[type="submit"] {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
  color: #1a1208 !important;
  border: 1px solid var(--ws-accent);
  border-radius: 3px;
  font-family: var(--ws-font);
  font-weight: 600;
  padding: 5px 18px;
  cursor: pointer;
  transition: 0.2s ease;
}

body.ws-login-page .ws-login-box input[type="submit"]:hover {
  filter: brightness(1.12);
  box-shadow: 0 0 14px rgba(184, 137, 47, 0.45);
}

.ws-item-opt-wing-hint {
  color: #ff9aab;
  font-size: 12px;
  margin-left: 6px;
  white-space: nowrap;
  font-weight: normal;
}

/* หน้าซื้อไอเทม — พรีวิวรูปในตำแหน่งเดิม (หัวตาราง) กว้าง 400px สูงตามรูป */
.ws-item-buy-fieldset {
  width: 400px;
  max-width: 400px;
  box-sizing: border-box;
}

.ws-item-buy-header-row td {
  background-color: #1a1d24;
  vertical-align: top;
}

.ws-item-buy-header-name {
  padding: 6px 8px 8px;
}

.ws-item-buy-header-meta {
  padding: 8px 6px;
  min-width: 120px;
}

.ws-item-buy-cat-link {
  font-size: 11px;
  font-family: var(--ws-font);
  font-variant: normal;
}

.ws-item-buy-group-list {
  margin: 6px 0 0;
  font-size: 10px;
  color: var(--ws-muted);
  line-height: 1.35;
}

.ws-item-buy-inline-preview {
  margin: 8px auto 0;
  padding: 8px;
  background: #0a0c10;
  border: 1px solid var(--ws-glass-border);
  box-shadow: inset 0 0 12px rgba(0, 0, 0, 0.6);
  text-align: center;
  line-height: 0;
}

.ws-item-buy-inline-preview .ws-item-buy-preview-img {
  display: block;
  margin: 0 auto;
  width: auto;
  height: auto;
  max-width: 100%;
  image-rendering: pixelated;
  filter: drop-shadow(0 2px 6px rgba(0, 0, 0, 0.7));
}

.ws-item-buy-preview-img--group {
  display: inline-block;
  margin: 3px;
  vertical-align: middle;
}

.ws-item-buy-preview-group {
  line-height: 0;
  text-align: center;
}

.ws-item-buy-preview-empty {
  display: block;
  font-size: 10px;
  line-height: 1.3;
  color: var(--ws-muted);
  padding: 4px 0;
}

/* ===== ล้างสีพื้นสว่างที่ฝัง inline มากับโมดูลเก่า (itemadder, viewlog, casino, serial ฯลฯ) ===== */
.ws-content fieldset[style*="#DDDDDD" i],
.ws-content fieldset[style*="#EEEEEE" i],
.ws-content fieldset[style*="#CCCCCC" i],
.ws-content legend[style*="#DDDDDD" i],
.ws-content legend[style*="#EEEEEE" i],
.ws-content table[style*="#DDDDDD" i],
.ws-content table[style*="#EEEEEE" i],
.ws-content td[style*="#DDDDDD" i],
.ws-content td[style*="#EEEEEE" i],
.ws-content div[style*="#DDDDDD" i],
.ws-content div[style*="#EEEEEE" i],
.ws-content textarea[style*="#DDDDDD" i],
.ws-content textarea[style*="#EEEEEE" i] {
  background-color: var(--ws-card-solid) !important;
  color: var(--ws-text) !important;
}

/* กรอบดำ inline (border:1px solid #000000) มองไม่เห็นบนพื้นมืด — เปลี่ยนเป็นขอบทอง */
.ws-content fieldset[style*="#000000" i],
.ws-content legend[style*="#000000" i],
.ws-content table[style*="#000000" i],
.ws-content td[style*="#000000" i],
.ws-content textarea[style*="#000000" i] {
  border-color: var(--ws-glass-border) !important;
}

/* ปุ่ม submit ที่ฝังสีสว่าง inline — บังคับเป็นปุ่มทองของธีม
   (ยกเว้นปุ่มที่ใช้ background-image เช่น รูปไอเทมในคลัง) */
.ws-content input[type="submit"][style]:not([style*="background-image"]),
.ws-content input[type="button"][style]:not([style*="background-image"]) {
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%) !important;
  color: #1a1208 !important;
  border: 1px solid var(--ws-accent) !important;
}

/* ช่องไอเทมในคลัง — โชว์รูปบนพื้นช่องเดิม คงสีตัวเลข +level ตาม inline */
.ws-content .ws-wh-grid td.itemblock input[type="button"][style*="background-image"] {
  background-color: #777779 !important;
}

/* ตัวอักษรสีเข้ม inline บนพื้นมืด */
.ws-content [style*="color:#990000" i],
.ws-content [style*="color: #990000" i] {
  color: #ff9aab !important;
}

.ws-content select[style*="color: #000000" i],
.ws-content select[style*="color:#000000" i],
.ws-content td[style*="color: #000000" i],
.ws-content td[style*="color:#000000" i],
.ws-content span[style*="color: #000000" i],
.ws-content span[style*="color:#000000" i],
.ws-content input[style*="color: #111111" i],
.ws-content input[style*="color:#111111" i] {
  color: var(--ws-text) !important;
}

.ws-content [style*="color:#555" i],
.ws-content [style*="color: #555" i],
.ws-content [style*="color:#333" i],
.ws-content [style*="color: #333" i] {
  color: var(--ws-muted) !important;
}

/* กล่องของหน้า นำเข้า XML คลัง (สไตล์ฝังในโมดูล) */
.ws-content .ws-whxml-box {
  background: var(--ws-card) !important;
  border-color: var(--ws-glass-border) !important;
}

.ws-content .ws-whxml-box--clear {
  border-color: rgba(255, 90, 110, 0.5) !important;
}

.ws-content .ws-whxml-btn-clear {
  color: #ff9aab !important;
  background: #7a1f2b !important;
  border: 1px solid var(--ws-red) !important;
}

/* แถวรายการไอเทม (สไตล์ .eachl ฝังในโมดูล) */
.ws-content .eachl {
  border-bottom-color: rgba(214, 181, 111, 0.18) !important;
}

@media (max-width: 768px) {
  .ws-shell {
    flex-direction: column;
  }
  .ws-sidebar {
    width: 100%;
  }
}

/* ============================================================
   ร้านไอเทม (redesign) — รายการการ์ด + นับถอยหลังเวลาขาย
   ============================================================ */

.ws-shop {
  max-width: 720px;
}

.ws-shop-hero {
  background: linear-gradient(135deg, rgba(184, 137, 47, 0.14), rgba(18, 20, 26, 0.92));
  border: 1px solid var(--ws-glass-border);
  border-radius: 14px;
  padding: 18px 22px;
  margin-bottom: 16px;
}

.ws-shop-hero-title {
  margin: 0 0 6px;
  font-family: var(--ws-font-heading);
  font-size: 22px;
  font-weight: 700;
  letter-spacing: 1px;
  color: var(--ws-secondary);
  text-transform: uppercase;
}

.ws-shop-hero-note {
  margin: 0 0 8px;
  font-size: 13px;
  line-height: 1.6;
  color: var(--ws-muted);
}

.ws-shop-hero-rate {
  display: inline-block;
  margin: 0;
  padding: 4px 12px;
  border-radius: 999px;
  font-size: 12px;
  color: var(--ws-secondary);
  background: rgba(184, 137, 47, 0.12);
  border: 1px solid var(--ws-glass-border);
  cursor: help;
}

.ws-shop-cats {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 18px;
}

.ws-shop-cat-pill {
  display: inline-block;
  padding: 7px 14px;
  border-radius: 999px;
  border: 1px solid var(--ws-glass-border);
  background: var(--ws-card);
  color: var(--ws-text) !important;
  font-size: 13px;
  text-decoration: none !important;
  transition: border-color 0.15s ease, background 0.15s ease, color 0.15s ease;
}

.ws-shop-cat-pill:hover {
  border-color: var(--ws-secondary);
  color: var(--ws-secondary) !important;
}

.ws-shop-cat-pill--active {
  background: linear-gradient(135deg, var(--ws-primary), var(--ws-accent));
  border-color: var(--ws-secondary);
  color: #14100a !important;
  font-weight: 600;
}

.ws-shop-content {
  min-height: 60px;
}

.ws-shop-panel {
  background: var(--ws-card);
  border: 1px solid var(--ws-glass-border);
  border-radius: 14px;
  padding: 16px 18px;
  margin-bottom: 18px;
  max-width: 640px;
}

.ws-shop-panel-title {
  margin: 0 0 12px;
  font-family: var(--ws-font-heading);
  font-size: 16px;
  font-weight: 700;
  letter-spacing: 0.8px;
  color: var(--ws-secondary);
  text-transform: uppercase;
  border-bottom: 1px solid var(--ws-glass-border);
  padding-bottom: 10px;
}

.ws-shop-list {
  display: flex;
  flex-direction: column;
  gap: 8px;
}

.ws-shop-row {
  display: flex;
  flex-shrink: 0; /* กันแถวถูกบีบเมื่อลิสต์จำกัดความสูง (โดยเฉพาะแถวที่มี overflow:hidden จาก Ribbon) */
  align-items: center;
  gap: 14px;
  padding: 10px 14px;
  border-radius: 12px;
  border: 1px solid rgba(214, 181, 111, 0.12);
  background: rgba(10, 12, 17, 0.65);
  color: var(--ws-text) !important;
  text-decoration: none !important;
  transition: border-color 0.15s ease, background 0.15s ease, transform 0.1s ease;
}

.ws-shop-row:hover {
  border-color: var(--ws-secondary);
  background: rgba(184, 137, 47, 0.1);
  transform: translateX(2px);
}

.ws-shop-row--dim {
  opacity: 0.5;
}

/* ไอเทมรอวางขาย — ผู้เล่นเห็นรายการ (จาง + รูปขาวดำ) พร้อมนับถอยหลังถึงเวลาเริ่มขาย */
.ws-shop-row--upcoming {
  opacity: 0.65;
}

.ws-shop-row--upcoming .ws-shop-thumb {
  filter: grayscale(0.7);
}

.ws-shop-row--upcoming:hover {
  opacity: 0.85;
}

.ws-shop-row-num {
  flex: 0 0 auto;
  width: 26px;
  font-family: var(--ws-font-heading);
  font-size: 12px;
  color: var(--ws-muted);
  text-align: right;
}

.ws-shop-thumb {
  flex: 0 0 auto;
  width: 64px;
  height: 64px;
  display: flex;
  align-items: center;
  justify-content: center;
  border-radius: 10px;
  background: radial-gradient(circle at 50% 40%, rgba(214, 181, 111, 0.12), rgba(5, 6, 8, 0.9));
  border: 1px solid rgba(214, 181, 111, 0.18);
  overflow: hidden;
}

.ws-shop-thumb-img {
  max-width: 56px;
  max-height: 56px;
  object-fit: contain;
  image-rendering: pixelated;
}

.ws-shop-thumb--group {
  flex-direction: column;
  font-family: var(--ws-font-heading);
  font-size: 18px;
  font-weight: 700;
  color: var(--ws-secondary);
}

.ws-shop-thumb--group small {
  font-size: 10px;
  font-weight: 400;
  color: var(--ws-muted);
}

.ws-shop-row-main {
  flex: 1 1 auto;
  min-width: 0;
  display: flex;
  flex-direction: column;
  gap: 3px;
}

.ws-shop-row-name {
  font-size: 14.5px;
  font-weight: 500;
  color: var(--ws-text);
  line-height: 1.35;
}

.ws-shop-row:hover .ws-shop-row-name {
  color: var(--ws-secondary);
}

.ws-shop-row-sub {
  font-size: 12px;
  color: var(--ws-muted);
}

.ws-shop-row-price {
  flex: 0 0 auto;
  font-family: var(--ws-font-heading);
  font-size: 13.5px;
  font-weight: 700;
  color: var(--ws-secondary);
  text-align: right;
  white-space: nowrap;
}

.ws-shop-row-price small {
  font-weight: 400;
  font-size: 11px;
  color: var(--ws-muted);
}

.ws-shop-empty {
  margin: 8px 0;
  padding: 18px;
  text-align: center;
  font-size: 13.5px;
  color: var(--ws-muted);
  border: 1px dashed rgba(214, 181, 111, 0.25);
  border-radius: 12px;
}

.ws-shop-empty--start {
  max-width: 640px;
}

/* นับถอยหลัง */
.ws-shop-timer {
  display: inline-flex;
  align-items: center;
  gap: 4px;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 500;
  color: #ffd98a;
  background: rgba(184, 137, 47, 0.16);
  border: 1px solid rgba(214, 181, 111, 0.35);
}

.ws-shop-timer--upcoming {
  color: #9fd2ff;
  background: rgba(80, 150, 220, 0.14);
  border-color: rgba(120, 180, 240, 0.35);
}

.ws-shop-timer--ended {
  color: var(--ws-red);
  background: rgba(255, 90, 110, 0.1);
  border-color: rgba(255, 90, 110, 0.3);
}

.ws-shop-countdown {
  font-variant-numeric: tabular-nums;
}

.ws-shop-countdown-banner {
  max-width: 640px;
  margin: 0 0 12px;
  padding: 12px 18px;
  border-radius: 12px;
  font-size: 14px;
  color: #ffd98a;
  background: linear-gradient(135deg, rgba(184, 137, 47, 0.2), rgba(18, 20, 26, 0.92));
  border: 1px solid rgba(214, 181, 111, 0.4);
}

.ws-shop-countdown-banner .ws-shop-countdown {
  font-family: var(--ws-font-heading);
  font-size: 17px;
  letter-spacing: 0.5px;
  color: var(--ws-secondary);
}

.ws-shop-countdown-banner-label {
  color: var(--ws-muted);
  margin-right: 6px;
}

.ws-shop-countdown-banner--upcoming {
  color: #9fd2ff;
  border-color: rgba(120, 180, 240, 0.4);
  background: linear-gradient(135deg, rgba(80, 150, 220, 0.16), rgba(18, 20, 26, 0.92));
}

.ws-shop-countdown-banner--ended {
  color: var(--ws-red);
  border-color: rgba(255, 90, 110, 0.4);
  background: linear-gradient(135deg, rgba(255, 90, 110, 0.12), rgba(18, 20, 26, 0.92));
}

.ws-shop-countdown-banner--ended .ws-shop-countdown {
  color: var(--ws-red);
}

/* ป้ายสถานะเวลาขาย (แอดมิน) */
.ws-sched-badge {
  display: inline-block;
  padding: 2px 10px;
  border-radius: 999px;
  font-size: 11.5px;
  font-weight: 500;
  white-space: nowrap;
}

.ws-sched-badge--always {
  color: var(--ws-muted);
  background: rgba(179, 171, 155, 0.1);
  border: 1px solid rgba(179, 171, 155, 0.3);
}

.ws-sched-badge--live {
  color: var(--ws-green);
  background: rgba(88, 200, 120, 0.1);
  border: 1px solid rgba(88, 200, 120, 0.35);
}

.ws-sched-badge--upcoming {
  color: #9fd2ff;
  background: rgba(80, 150, 220, 0.12);
  border: 1px solid rgba(120, 180, 240, 0.35);
}

.ws-sched-badge--ended {
  color: var(--ws-red);
  background: rgba(255, 90, 110, 0.1);
  border: 1px solid rgba(255, 90, 110, 0.35);
}

input.ws-sched-input,
.ws-settings input[type="datetime-local"] {
  color-scheme: dark;
  background: var(--ws-panel);
  color: var(--ws-text);
  border: 1px solid var(--ws-border);
  border-radius: 8px;
  padding: 6px 10px;
  font-family: var(--ws-font);
  font-size: 13px;
}

/* หน้าไอเทมขายย้อนหลัง (แอดมิน) */
.ws-history-day {
  margin: 0 0 22px;
  background: var(--ws-card);
  border: 1px solid var(--ws-glass-border);
  border-radius: 14px;
  padding: 14px 18px;
}

.ws-history-day-title {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 0 0 12px;
  font-family: var(--ws-font-heading);
  font-size: 15.5px;
  font-weight: 700;
  letter-spacing: 0.5px;
  color: var(--ws-secondary);
  border-bottom: 1px solid var(--ws-glass-border);
  padding-bottom: 10px;
}

.ws-history-day-count {
  font-family: var(--ws-font);
  font-size: 11.5px;
  font-weight: 400;
  color: var(--ws-muted);
  padding: 2px 10px;
  border-radius: 999px;
  border: 1px solid rgba(179, 171, 155, 0.3);
}

.ws-history-table {
  width: 100%;
}

/* รายการไอเทมแบบเลื่อน 4 แถว + วนลูป */
.ws-shop-list--scroll {
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: none; /* Firefox */
  -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 88%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 88%, transparent 100%);
}

.ws-shop-list--scroll::-webkit-scrollbar {
  display: none; /* Chrome/Edge */
}

.ws-shop-scroll-hint {
  margin: 10px 0 0;
  text-align: center;
  font-size: 11.5px;
  color: var(--ws-muted);
  user-select: none;
}

/* ตารางรางวัลกิจกรรม: เลื่อน 4 แถว + วนลูป */
.ws-ev-table-wrap--scroll {
  overflow-y: auto;
  overscroll-behavior: contain;
  scrollbar-width: none;
  -ms-overflow-style: none;
  -webkit-mask-image: linear-gradient(180deg, #000 0%, #000 90%, transparent 100%);
  mask-image: linear-gradient(180deg, #000 0%, #000 90%, transparent 100%);
}

.ws-ev-table-wrap--scroll::-webkit-scrollbar {
  display: none;
}

.ws-ev-table-wrap--scroll .ws-ev-reward-table th {
  position: sticky;
  top: 0;
  z-index: 2;
  background: #1a1d24;
}

/* รูปไอเทมในตารางรางวัลกิจกรรม — ใหญ่ขึ้น มีกรอบแบบหน้าร้าน */
.ws-ev-reward-table .ws-im-col-img {
  width: 76px;
  padding: 8px 6px !important;
}

.ws-ev-reward-table .ws-im-thumb-sm {
  display: block;
  margin: 0 auto;
  max-width: 56px;
  max-height: 56px;
  width: auto;
  height: auto;
  padding: 5px;
  border-radius: 10px;
  background: radial-gradient(circle at 50% 40%, rgba(214, 181, 111, 0.12), rgba(5, 6, 8, 0.9));
  border: 1px solid rgba(214, 181, 111, 0.18);
}

/* แถบตั้งเวลาขายหลายรายการ (แอดมิน) */
.ws-im-bulk-bar {
  margin: 0 0 12px;
  padding: 12px 14px;
  border-radius: 12px;
  background: rgba(184, 137, 47, 0.08);
  border: 1px solid var(--ws-glass-border);
}

.ws-im-bulk-title {
  display: block;
  margin-bottom: 2px;
  color: var(--ws-secondary);
  font-size: 13.5px;
}

.ws-im-bulk-hint {
  display: block;
  margin-bottom: 10px;
  font-size: 11.5px;
  color: var(--ws-muted);
}

.ws-im-bulk-fields {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 10px;
}

.ws-im-bulk-field {
  display: flex;
  flex-direction: column;
  gap: 3px;
  font-size: 11.5px;
  color: var(--ws-muted);
}

.ws-im-col-check {
  width: 30px;
  text-align: center;
}

.ws-im-col-check input[type="checkbox"],
#ws-im-check-all {
  width: 15px;
  height: 15px;
  accent-color: var(--ws-primary);
  cursor: pointer;
}

/* ช่องเลือกรายวันในหน้าไอเทมขายย้อนหลัง */
.ws-hist-day-check {
  display: inline-flex;
  align-items: center;
  cursor: pointer;
}

.ws-hist-day-check input[type="checkbox"],
.ws-hist-sel,
#ws-hist-check-all {
  width: 15px;
  height: 15px;
  accent-color: var(--ws-primary);
  cursor: pointer;
}

/* ป้ายนับถอยหลัง "เหลือเวลาซื้อ" — เรืองแสงแดงกระพริบ เร่งให้รีบซื้อ */
@keyframes ws-timer-glow {
  0%, 100% {
    box-shadow: 0 0 4px rgba(255, 60, 70, 0.45), 0 0 10px rgba(255, 60, 70, 0.25);
    border-color: rgba(255, 90, 100, 0.55);
    background: rgba(160, 20, 30, 0.28);
  }
  50% {
    box-shadow: 0 0 12px rgba(255, 70, 80, 0.95), 0 0 26px rgba(255, 50, 60, 0.55);
    border-color: rgba(255, 140, 150, 1);
    background: rgba(220, 35, 50, 0.4);
  }
}

@keyframes ws-timer-text-blink {
  0%, 100% {
    color: #ffaab1;
    text-shadow: 0 0 6px rgba(255, 70, 80, 0.55), 0 0 16px rgba(255, 50, 60, 0.35);
  }
  50% {
    color: #ffffff;
    text-shadow: 0 0 8px rgba(255, 90, 100, 1), 0 0 20px rgba(255, 60, 70, 0.85), 0 0 36px rgba(255, 40, 55, 0.55);
  }
}

/* ข้อความ "เหลือเวลาซื้อ" — ไม่มีกรอบ/พื้นหลัง เรืองแสงแดงกระจายกระพริบ */
.ws-shop-timer--live {
  color: #ffaab1;
  background: none;
  border: none;
  padding: 0;
  font-weight: 700;
  animation: ws-timer-text-blink 1.1s ease-in-out infinite;
}

/* แบนเนอร์นับถอยหลังในหน้าซื้อ — โทนแดงเร่งด่วนเหมือนกัน */
.ws-shop-countdown-banner--live {
  color: #ffc4c9;
  border-color: rgba(255, 90, 100, 0.55);
  background: linear-gradient(135deg, rgba(180, 25, 40, 0.3), rgba(18, 20, 26, 0.92));
  animation: ws-timer-glow 1.1s ease-in-out infinite;
}

.ws-shop-countdown-banner--live .ws-shop-countdown {
  color: #ffffff;
  animation: ws-timer-text-blink 1.1s ease-in-out infinite;
}

/* Ribbon มุมการ์ด "จำกัดเวลาขาย" — เรืองแสงกระพริบ เฉพาะไอเทมจำกัดเวลา
   สี/ข้อความตั้งได้ในหน้าจัดการไอเทม (ตัวแปร --rb-* ฝังใน style ของแถว) */
@keyframes ws-ribbon-glow {
  0%, 100% {
    box-shadow: 0 0 6px var(--rb-glow, rgba(60, 230, 130, 0.5)), 0 0 14px var(--rb-glow-weak, rgba(40, 210, 110, 0.3));
    filter: brightness(1);
  }
  50% {
    box-shadow: 0 0 14px var(--rb-glow-strong, rgba(80, 255, 150, 0.95)), 0 0 30px var(--rb-glow, rgba(50, 230, 120, 0.6));
    filter: brightness(1.18);
  }
}

@keyframes ws-ribbon-shine {
  0%   { transform: translateX(-120%) skewX(-20deg); }
  60%, 100% { transform: translateX(220%) skewX(-20deg); }
}

.ws-shop-row--limited {
  position: relative;
  overflow: hidden;
}

.ws-shop-row--limited .ws-shop-row-num {
  visibility: hidden;
}

.ws-shop-ribbon {
  position: absolute;
  top: 16px;
  left: -44px;
  width: 164px;
  padding: 4px 0;
  transform: rotate(-45deg);
  text-align: center;
  font-family: var(--ws-font-heading);
  font-size: 10px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--rb-text, #04190c);
  text-shadow: 0 1px 0 rgba(255, 255, 255, 0.25);
  background: linear-gradient(180deg, var(--rb-light, #7dffae) 0%, var(--rb, #2ee37e) 45%, var(--rb-dark, #14b85c) 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.7);
  border-bottom: 1px solid rgba(0, 0, 0, 0.45);
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.4);
  pointer-events: none;
  z-index: 2;
}

/* แสงวิ่งผ่าน Ribbon ให้ดูพรีเมียมเหมือนป้ายกิจกรรม */
.ws-shop-ribbon::after {
  content: "";
  position: absolute;
  top: 0;
  left: 0;
  width: 45%;
  height: 100%;
  background: linear-gradient(90deg, rgba(255, 255, 255, 0) 0%, rgba(255, 255, 255, 0.65) 50%, rgba(255, 255, 255, 0) 100%);
  animation: ws-ribbon-shine 2.4s ease-in-out infinite;
}

/* ขอบการ์ดไอเทมจำกัดเวลา — เน้นสีเดียวกับ Ribbon ให้สะดุดตา */
.ws-shop-row--limited {
  border-color: var(--rb-border, rgba(46, 227, 126, 0.35));
}

.ws-shop-row--limited:hover {
  border-color: var(--rb-border-hover, rgba(80, 255, 150, 0.7));
}

/* ป้ายตัวอย่าง Ribbon ในหน้าจัดการไอเทม */
.ws-im-ribbon-preview {
  display: inline-block;
  margin: 4px 0;
  padding: 5px 18px;
  border-radius: 4px;
  font-family: var(--ws-font-heading);
  font-size: 11px;
  font-weight: 700;
  letter-spacing: 0.04em;
  color: var(--rb-text, #04190c);
  background: linear-gradient(180deg, var(--rb-light, #7dffae) 0%, var(--rb, #2ee37e) 45%, var(--rb-dark, #14b85c) 100%);
  border-top: 1px solid rgba(255, 255, 255, 0.7);
  border-bottom: 1px solid rgba(0, 0, 0, 0.45);
  box-shadow: 0 1px 6px rgba(0, 0, 0, 0.4);
}

.ws-im-ribbon-fields {
  display: flex;
  flex-wrap: wrap;
  align-items: flex-end;
  gap: 14px;
  margin-top: 10px;
}

.ws-im-ribbon-fields .ws-settings-field {
  margin: 0;
}

.ws-im-ribbon-color-input {
  width: 64px;
  height: 34px;
  padding: 2px;
  border: 1px solid rgba(214, 181, 111, 0.3);
  border-radius: 8px;
  background: rgba(10, 12, 17, 0.65);
  cursor: pointer;
}

/* ยอดขายไอเทม + รายชื่อผู้ซื้อ (หน้าแอดมิน ไอเทมขายย้อนหลัง) */
.ws-sales-zone {
  margin: 18px 0 26px;
}

.ws-sales-item {
  margin: 8px 0;
  border: 1px solid rgba(214, 181, 111, 0.16);
  border-radius: 12px;
  background: rgba(10, 12, 17, 0.65);
  overflow: hidden;
}

.ws-sales-item[open] {
  border-color: rgba(214, 181, 111, 0.4);
}

.ws-sales-summary {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 10px 14px;
  cursor: pointer;
  list-style: none;
}

.ws-sales-summary::-webkit-details-marker {
  display: none;
}

.ws-sales-summary::after {
  content: "\25BE";
  margin-left: auto;
  color: var(--ws-muted);
  transition: transform 0.15s ease;
}

.ws-sales-item[open] .ws-sales-summary::after {
  transform: rotate(180deg);
}

.ws-sales-summary:hover {
  background: rgba(184, 137, 47, 0.08);
}

.ws-sales-thumb {
  flex: 0 0 auto;
  width: 44px;
  height: 44px;
  display: flex;
  align-items: center;
  justify-content: center;
}

.ws-sales-thumb img {
  max-width: 44px;
  max-height: 44px;
}

.ws-sales-name {
  font-size: 14px;
  font-weight: 600;
  color: var(--ws-text);
  display: flex;
  flex-direction: column;
  gap: 2px;
  min-width: 0;
}

.ws-sales-badge {
  flex: 0 0 auto;
  padding: 3px 12px;
  border-radius: 999px;
  font-size: 12px;
  font-weight: 700;
  color: #1a1208;
  background: linear-gradient(180deg, var(--ws-secondary) 0%, var(--ws-primary) 100%);
}

.ws-sales-last {
  flex: 0 0 auto;
  font-size: 11.5px;
  color: var(--ws-muted);
}

.ws-sales-table {
  margin: 0 14px 14px;
  width: calc(100% - 28px);
}

.ws-sales-count-link {
  font-weight: 700;
  color: var(--ws-secondary) !important;
  text-decoration: underline !important;
}
