/* ================================================================
   YG ORIGINZ — MEDIEVAL GOLD THEME
   Global stylesheet — ครอบคลุมทุกหน้า ยกเว้น /market/
   ================================================================ */

/* ── CSS Variables ─────────────────────────────────────────── */
:root {
  --g-bg:           #0b0907;
  --g-bg-panel:     #15110d;
  --g-bg-card:      rgba(33, 24, 17, 0.94);
  --g-border:       rgba(201, 155, 82, 0.22);
  --g-border-hover: #d8b06a;
  --g-purple:       #d8b06a;
  --g-purple-deep:  #be8a39;
  --g-purple-glow:  rgba(201, 155, 82, 0.35);
  --g-text:         #f4ead7;
  --g-text-muted:   #c5b293;
  --g-text-sub:     #a08060;
  --g-gold:         #fbbf24;
  --g-green:        #34d399;
  --g-red:          #f87171;
}

/* ── Animations ────────────────────────────────────────────── */
@keyframes g-bgmove {
  0%   { background-position: 0% 50%; }
  50%  { background-position: 100% 50%; }
  100% { background-position: 0% 50%; }
}

@keyframes g-glow {
  0%, 100% { text-shadow: 0 0 10px rgba(201,155,82,.5), 0 0 20px rgba(190,138,57,.3); }
  50%       { text-shadow: 0 0 20px rgba(201,155,82,.9), 0 0 40px rgba(190,138,57,.6); }
}

@keyframes g-pulse {
  0%   { box-shadow: 0 0 0 0   rgba(201,155,82,.6); }
  70%  { box-shadow: 0 0 0 12px rgba(201,155,82,0);  }
  100% { box-shadow: 0 0 0 0   rgba(201,155,82,0);  }
}

@keyframes g-shimmer {
  0%, 100% { opacity: .3; }
  50%       { opacity: 1;  }
}

@keyframes g-float {
  0%, 100% { transform: translateY(0);    }
  50%       { transform: translateY(-6px); }
}

/* ── Body & Background ─────────────────────────────────────── */
html body {
  background: linear-gradient(-45deg, #0b0907, #15110d, #100c08, #0b0907) !important;
  background-size: 400% 400% !important;
  animation: g-bgmove 18s ease infinite !important;
  color: var(--g-text) !important;
  font-family: 'Segoe UI', 'Trebuchet MS', sans-serif;
}

html body::before {
  content: "";
  position: fixed;
  top: 0; left: 0;
  width: 100%; height: 100%;
  background: radial-gradient(ellipse at 30% 0%, rgba(190,138,57,.12) 0%, transparent 65%),
              radial-gradient(ellipse at 80% 80%, rgba(201,155,82,.07) 0%, transparent 55%);
  pointer-events: none;
  z-index: 0;
}

html body .content-wrapper,
html body .layout-page {
  background: transparent !important;
}

/* ── Navbar ────────────────────────────────────────────────── */
html body .layout-navbar,
html body .bg-navbar-theme,
html body nav.layout-navbar {
  background: rgba(16, 11, 8, 0.96) !important;
  background-color: rgba(16, 11, 8, 0.96) !important;
  border-bottom: 1px solid rgba(201,155,82,.28) !important;
  box-shadow: 0 2px 20px rgba(190,138,57,.25) !important;
  backdrop-filter: blur(12px);
}

/* override Sneat badge classes inside navbar */
html body .layout-navbar .badge,
html body .layout-navbar .badge.bg-light,
html body .layout-navbar span.badge {
  background: rgba(33, 24, 17, 0.92) !important;
  background-color: rgba(33, 24, 17, 0.92) !important;
  color: #ffffff !important;
  border: 1px solid rgba(201,155,82,.45) !important;
  box-shadow: 0 0 8px rgba(201,155,82,.15) !important;
}

html body .layout-navbar .navbar-nav-link,
html body .layout-navbar .nav-link {
  color: #ffffff !important;
}

/* ── Sidebar ───────────────────────────────────────────────── */
html body .layout-menu,
html body .bg-menu-theme,
html body aside.layout-menu {
  background: rgba(12, 9, 5, 0.97) !important;
  background-color: rgba(12, 9, 5, 0.97) !important;
  border-right: 1px solid rgba(201,155,82,.2) !important;
  box-shadow: inset -2px 0 20px rgba(190,138,57,.08) !important;
}

html body .layout-menu .app-brand-text,
html body aside .app-brand-text {
  color: #ffffff !important;
  text-shadow: 0 0 18px rgba(201,155,82,.6) !important;
  letter-spacing: 2px;
  animation: g-glow 3s ease-in-out infinite;
  font-weight: 900;
}

html body .menu-vertical .menu-item > .menu-link {
  color: #ffffff !important;
  background: transparent !important;
  transition: all .25s ease;
  position: relative;
}

html body .menu-vertical .menu-item > .menu-link::before {
  content: "";
  position: absolute;
  left: 0; top: 50%;
  transform: translateY(-50%);
  width: 3px; height: 0;
  background: linear-gradient(180deg, #d8b06a, #be8a39);
  border-radius: 2px;
  transition: height .25s ease;
}

html body .menu-vertical .menu-item.active > .menu-link::before { height: 24px; }

html body .menu-vertical .menu-item.active > .menu-link,
html body .bg-menu-theme .menu-inner > .menu-item.active > .menu-link {
  background: rgba(201,155,82,.18) !important;
  background-color: rgba(201,155,82,.18) !important;
  color: #ffffff !important;
  border-left: 3px solid #d8b06a !important;
  box-shadow: inset 0 0 12px rgba(201,155,82,.12) !important;
}

html body .menu-vertical .menu-item > .menu-link:hover,
html body .bg-menu-theme .menu-inner .menu-item .menu-link:not(.active):hover {
  background: rgba(201,155,82,.1) !important;
  background-color: rgba(201,155,82,.1) !important;
  color: #ffffff !important;
}

html body .menu-vertical .menu-icon { color: #d8b06a !important; }
html body .menu-inner-shadow        { background: linear-gradient(180deg, rgba(201,155,82,.15), transparent) !important; }
html body .menu-header-text         { color: rgba(255,255,255,.4) !important; letter-spacing: 1px; }

html body .layout-menu .menu-sub .menu-link {
  color: rgba(255,255,255,.7) !important;
  background: transparent !important;
}
html body .layout-menu .menu-sub .menu-item.active > .menu-link {
  color: #ffffff !important;
}

/* Sneat active indicator dots — override สีม่วง → ทอง */
html body .bg-menu-theme .menu-sub > .menu-item > .menu-link::before {
  background-color: rgba(201,155,82,.5) !important;
}
html body .bg-menu-theme .menu-sub > .menu-item.active > .menu-link:not(.menu-toggle)::before {
  background-color: #d8b06a !important;
  box-shadow: 0 0 0 2px rgba(33,24,17,.97) !important;
}
html body .bg-menu-theme .menu-inner > .menu-item.active::before {
  background: #d8b06a !important;
}
html body .bg-menu-theme .menu-inner .menu-sub > .menu-item.active .menu-icon {
  color: #d8b06a !important;
}
html body .bg-menu-theme .menu-inner .menu-item.open > .menu-link,
html body .bg-menu-theme .menu-inner .menu-item.open > .menu-toggle {
  background: rgba(33,24,17,.7) !important;
  background-color: rgba(33,24,17,.7) !important;
}

/* ── Card ──────────────────────────────────────────────────── */
.card {
  background: var(--g-bg-card) !important;
  border: 1px solid var(--g-border) !important;
  box-shadow: 0 6px 24px rgba(0,0,0,.45), 0 0 0 1px rgba(201,155,82,.08) !important;
  border-radius: 18px;
  transition: all .3s ease;
  backdrop-filter: blur(6px);
}

.card:hover {
  border-color: rgba(201,155,82,.45) !important;
  box-shadow: 0 10px 32px rgba(190,138,57,.28) !important;
  transform: translateY(-3px);
}

.card-header {
  background: linear-gradient(135deg, rgba(201,155,82,.14), rgba(190,138,57,.1)) !important;
  border-bottom: 1px solid var(--g-border) !important;
  color: #f0d39e !important;
  font-weight: 700;
}

.card-title { color: #f0d39e !important; }

.card-body {
  color: var(--g-text);
  background: transparent !important;
}

/* ── Headings ──────────────────────────────────────────────── */
h1, h2, h3, h4, h5, h6 {
  color: #f0d39e !important;
  letter-spacing: .4px;
}

.page-title {
  font-size: 2rem;
  font-weight: 900;
  background: linear-gradient(135deg, #f0d39e, #d8b06a, #be8a39);
  -webkit-background-clip: text;
  color: transparent !important;
  animation: g-glow 3s ease-in-out infinite;
}

/* ── Table ─────────────────────────────────────────────────── */
.table { color: var(--g-text); }

.table thead th {
  background: linear-gradient(135deg, rgba(190,138,57,.3), rgba(201,155,82,.2)) !important;
  color: #f0d39e !important;
  border-bottom: 2px solid rgba(201,155,82,.35) !important;
  font-weight: 700;
  letter-spacing: .3px;
}

.table tbody tr {
  border-bottom: 1px solid rgba(201,155,82,.12) !important;
  transition: background .2s;
}

.table tbody tr:hover {
  background: rgba(201,155,82,.08) !important;
}

.table tbody td {
  color: var(--g-text);
  border-color: rgba(201,155,82,.12) !important;
}

.table-bordered > :not(caption) > * > * {
  border-color: rgba(201,155,82,.15) !important;
}

/* DataTables */
.dataTables_wrapper .dataTables_paginate .paginate_button {
  color: var(--g-text) !important;
}
.dataTables_wrapper .dataTables_length select,
.dataTables_wrapper .dataTables_filter input {
  background: rgba(33,24,17,.9) !important;
  color: #f0d39e !important;
  border: 1px solid var(--g-border) !important;
  border-radius: 8px;
}
.dataTables_wrapper .dataTables_info { color: var(--g-text-muted) !important; }
div.dataTables_wrapper div.dataTables_paginate ul.pagination { margin-top: 8px; }

/* ── Forms ─────────────────────────────────────────────────── */
.form-control,
.form-select {
  background: rgba(33, 24, 17, 0.9) !important;
  color: #f0d39e !important;
  border: 1px solid rgba(201,155,82,.35) !important;
  border-radius: 10px;
  transition: all .25s;
}

.form-control::placeholder { color: rgba(201,155,82,.45) !important; }

.form-control:focus,
.form-select:focus {
  background: rgba(33, 24, 17, 0.96) !important;
  color: #f4ead7 !important;
  border-color: #d8b06a !important;
  box-shadow: 0 0 0 3px rgba(201,155,82,.2) !important;
}

.form-label {
  color: #f0d39e !important;
  font-weight: 600;
}

.input-group-text {
  background: rgba(190,138,57,.2) !important;
  border-color: rgba(201,155,82,.35) !important;
  color: #f0d39e !important;
}

/* ── Buttons ───────────────────────────────────────────────── */
.btn { transition: all .25s ease; font-weight: 600; position: relative; overflow: hidden; }

.btn::after {
  content: "";
  position: absolute;
  inset: 0;
  background: linear-gradient(90deg, transparent, rgba(255,255,255,.12), transparent);
  transform: translateX(-100%);
  transition: transform .5s;
}
.btn:hover::after { transform: translateX(100%); }

.btn-primary {
  background: linear-gradient(135deg, #be8a39, #d8b06a) !important;
  border: none !important;
  color: #1f1409 !important;
  box-shadow: 0 4px 18px rgba(190,138,57,.45) !important;
}
.btn-primary:hover { filter: brightness(1.12); transform: translateY(-2px); }

.btn-secondary {
  background: rgba(201,155,82,.15) !important;
  border: 1px solid rgba(201,155,82,.35) !important;
  color: #f0d39e !important;
}
.btn-secondary:hover { background: rgba(201,155,82,.25) !important; }

.btn-success {
  background: linear-gradient(135deg, #16a34a, #22c55e) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(34,197,94,.4) !important;
}
.btn-success:hover { filter: brightness(1.1); transform: translateY(-2px); }

.btn-danger {
  background: linear-gradient(135deg, #dc2626, #ef4444) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(220,38,38,.4) !important;
}
.btn-danger:hover { filter: brightness(1.1); transform: translateY(-2px); }

.btn-warning {
  background: linear-gradient(135deg, #d97706, #fbbf24) !important;
  border: none !important;
  color: #1a0d00 !important;
  box-shadow: 0 4px 16px rgba(245,158,11,.4) !important;
}
.btn-warning:hover { filter: brightness(1.1); transform: translateY(-2px); }

.btn-info {
  background: linear-gradient(135deg, #0284c7, #38bdf8) !important;
  border: none !important;
  color: #fff !important;
  box-shadow: 0 4px 16px rgba(14,165,233,.4) !important;
}
.btn-info:hover { filter: brightness(1.1); transform: translateY(-2px); }

.btn-outline-primary {
  border-color: #d8b06a !important;
  color: #d8b06a !important;
}
.btn-outline-primary:hover {
  background: linear-gradient(135deg, #be8a39, #d8b06a) !important;
  color: #1f1409 !important;
}

/* ── Badge ─────────────────────────────────────────────────── */
.badge { font-weight: 600; border-radius: 8px; }

.badge.bg-primary   { background: linear-gradient(135deg, #be8a39, #d8b06a) !important; color: #1f1409 !important; }
.badge.bg-success   { background: linear-gradient(135deg, #16a34a, #22c55e) !important; }
.badge.bg-danger    { background: linear-gradient(135deg, #dc2626, #ef4444) !important; }
.badge.bg-warning   { background: linear-gradient(135deg, #d97706, #fbbf24) !important; color: #1a0d00 !important; }
.badge.bg-info      { background: linear-gradient(135deg, #0284c7, #38bdf8) !important; }
.badge.bg-secondary { background: rgba(201,155,82,.2) !important; color: #f0d39e !important; border: 1px solid rgba(201,155,82,.35) !important; }

/* ── Alert ─────────────────────────────────────────────────── */
.alert {
  border-radius: 14px;
  backdrop-filter: blur(6px);
  border: 1px solid;
}
.alert-success { background: rgba(34,197,94,.12) !important;  border-color: rgba(34,197,94,.4) !important;  color: #86efac !important; }
.alert-danger  { background: rgba(239,68,68,.12) !important;  border-color: rgba(239,68,68,.4) !important;  color: #fca5a5 !important; }
.alert-warning { background: rgba(245,158,11,.12) !important; border-color: rgba(245,158,11,.4) !important; color: #fcd34d !important; }
.alert-info    { background: rgba(190,138,57,.12) !important; border-color: rgba(201,155,82,.4) !important; color: #f0d39e !important; }
.alert-light   { background: rgba(201,155,82,.06) !important; border-color: var(--g-border) !important; color: var(--g-text-muted) !important; }

/* ── Modal ─────────────────────────────────────────────────── */
.modal-content {
  background: linear-gradient(160deg, #1e1408, #150f06) !important;
  border: 1px solid rgba(201,155,82,.3) !important;
  box-shadow: 0 0 40px rgba(190,138,57,.4) !important;
  backdrop-filter: blur(12px);
}
.modal-header {
  background: linear-gradient(135deg, rgba(190,138,57,.2), rgba(201,155,82,.12)) !important;
  border-bottom: 1px solid var(--g-border) !important;
}
.modal-title { color: #f0d39e !important; font-weight: 700; }
.modal-footer { border-top: 1px solid var(--g-border) !important; }
.modal-backdrop { background: rgba(0,0,0,.7) !important; }
.btn-close { filter: invert(1) brightness(.75); }

/* ── Dropdown ──────────────────────────────────────────────── */
.dropdown-menu {
  background: rgba(20, 14, 10, 0.97) !important;
  border: 1px solid rgba(201,155,82,.3) !important;
  box-shadow: 0 8px 30px rgba(0,0,0,.5) !important;
  backdrop-filter: blur(12px);
  border-radius: 14px;
}
.dropdown-item          { color: var(--g-text) !important; transition: .2s; }
.dropdown-item:hover    { background: rgba(201,155,82,.14) !important; color: #f0d39e !important; }
.dropdown-item.active   { background: rgba(201,155,82,.22) !important; color: #f0d39e !important; }
.dropdown-divider       { border-color: var(--g-border) !important; }

/* ── Nav Pills / Tabs ──────────────────────────────────────── */
.nav-pills .nav-link              { color: var(--g-text) !important; border-radius: 10px; transition: .2s; }
.nav-pills .nav-link:hover        { background: rgba(201,155,82,.14) !important; color: #f0d39e !important; }
.nav-pills .nav-link.active       { background: linear-gradient(135deg, #be8a39, #d8b06a) !important; color: #1f1409 !important; box-shadow: 0 4px 16px rgba(190,138,57,.45) !important; }

.nav-tabs .nav-link               { color: var(--g-text-muted) !important; border: 1px solid transparent; transition: .2s; }
.nav-tabs .nav-link:hover         { border-color: var(--g-border) !important; color: #f0d39e !important; }
.nav-tabs .nav-link.active        { background: rgba(201,155,82,.14) !important; border-color: rgba(201,155,82,.35) rgba(201,155,82,.35) transparent !important; color: #f0d39e !important; }
.nav-tabs { border-bottom-color: rgba(201,155,82,.2) !important; }

/* ── Pagination ────────────────────────────────────────────── */
.page-link {
  background: rgba(33,24,17,.9) !important;
  border: 1px solid var(--g-border) !important;
  color: #f0d39e !important;
  border-radius: 8px;
  margin: 0 2px;
  transition: .2s;
}
.page-link:hover    { background: rgba(201,155,82,.18) !important; color: #fff !important; }
.page-item.active .page-link { background: linear-gradient(135deg,#be8a39,#d8b06a) !important; border-color: #d8b06a !important; box-shadow: 0 0 12px rgba(201,155,82,.5) !important; color: #1f1409 !important; }
.page-item.disabled .page-link { background: rgba(201,155,82,.04) !important; color: var(--g-text-sub) !important; }

/* ── Text Utilities ────────────────────────────────────────── */
.text-muted     { color: var(--g-text-muted) !important; }
.text-secondary { color: var(--g-text-muted) !important; }
.text-primary   { color: #d8b06a !important; }
.text-success   { color: var(--g-green)  !important; }
.text-danger    { color: var(--g-red)    !important; }
.text-warning   { color: var(--g-gold)   !important; }
.text-info      { color: #60a5fa        !important; }
.text-white     { color: #f4ead7        !important; }
.text-light     { color: var(--g-text)  !important; }

/* ── SweetAlert2 ───────────────────────────────────────────── */
.swal2-popup {
  background: linear-gradient(160deg, #1e1408, #150f06) !important;
  border: 1px solid rgba(201,155,82,.3) !important;
  color: var(--g-text) !important;
}
.swal2-title   { color: #f0d39e !important; }
.swal2-content { color: var(--g-text) !important; }
.swal2-confirm { background: linear-gradient(135deg, #be8a39, #d8b06a) !important; color: #1f1409 !important; }
.swal2-cancel  { background: rgba(201,155,82,.15) !important; color: #f0d39e !important; border: 1px solid var(--g-border) !important; }

/* ── Scrollbar ─────────────────────────────────────────────── */
::-webkit-scrollbar       { width: 8px; height: 8px; }
::-webkit-scrollbar-track { background: rgba(201,155,82,.06); border-radius: 10px; }
::-webkit-scrollbar-thumb { background: linear-gradient(180deg, #be8a39, #d8b06a); border-radius: 10px; }
::-webkit-scrollbar-thumb:hover { background: linear-gradient(180deg, #a06820, #c8922a); }

/* ── Dashboard-specific overrides ─────────────────────────── */
/* quick-action-panel (dashboard) */
.quick-action-panel {
  background: linear-gradient(145deg, #1e1208, #281808) !important;
  border: 1px solid rgba(201,155,82,.3) !important;
  box-shadow: 0 8px 32px rgba(0,0,0,.4), 0 0 0 1px rgba(201,155,82,.1) !important;
}
.quick-action-panel .qa-header { color: #f0d39e; }

/* char-table (dashboard) */
.char-table { background: rgba(33,24,17,.85) !important; border-color: rgba(201,155,82,.25) !important; }
.char-table td { border-bottom-color: rgba(201,155,82,.12) !important; color: var(--g-text); }
.char-table .label { background: linear-gradient(135deg, #5a3a10, #3a2008) !important; color: #f0d39e !important; }

/* character-card (dashboard) */
.character-card,
.card.char-card {
  background: linear-gradient(160deg, #2a1a0a 0%, #201408 100%) !important;
}
.character-card.active { border-color: #d8b06a !important; box-shadow: 0 0 0 3px rgba(201,155,82,.2), 0 8px 24px rgba(190,138,57,.3) !important; }
.character-card table td { border-bottom-color: rgba(201,155,82,.12) !important; }
.character-card .char-name  { color: #f0d39e !important; }
.character-card .char-sub   { color: var(--g-text-muted) !important; }
.character-card table td.label { color: #d8b06a !important; }

/* logs-card / logs-table (dashboard) */
.logs-card { background: rgba(33,24,17,.8) !important; border-color: rgba(201,155,82,.2) !important; }
.characters-wrapper { background: linear-gradient(145deg, #15110d, #211508, #100c08) !important; border-color: rgba(201,155,82,.3) !important; }

/* btn-action-lg history (dashboard) */
.btn-action-lg.btn-history {
  background: rgba(201,155,82,.12) !important;
  border: 1px solid rgba(201,155,82,.3) !important;
  color: #f0d39e !important;
}
.btn-action-lg.btn-history:hover { background: rgba(201,155,82,.22) !important; }

/* ── Generic Dark Panel Utilities ──────────────────────────── */
.dark-panel {
  background: linear-gradient(145deg, var(--g-bg-panel), #100c08) !important;
  border: 1px solid var(--g-border) !important;
  border-radius: 20px;
  box-shadow: 0 8px 30px rgba(0,0,0,.4) !important;
}

.panel-title {
  font-weight: 700;
  background: linear-gradient(90deg, #f0d39e, #d8b06a);
  -webkit-background-clip: text;
  color: transparent !important;
}

.section-divider {
  border-color: rgba(201,155,82,.2) !important;
}

/* ── Progress ──────────────────────────────────────────────── */
.progress {
  background: rgba(201,155,82,.12) !important;
  border-radius: 20px;
}
.progress-bar {
  background: linear-gradient(90deg, #be8a39, #d8b06a) !important;
}

/* ── List Group ────────────────────────────────────────────── */
.list-group-item {
  background: var(--g-bg-card) !important;
  border-color: var(--g-border) !important;
  color: var(--g-text) !important;
}
.list-group-item:hover    { background: rgba(201,155,82,.1) !important; }
.list-group-item.active   { background: linear-gradient(135deg, rgba(190,138,57,.3), rgba(201,155,82,.2)) !important; border-color: rgba(201,155,82,.4) !important; }

/* ── Accordion ─────────────────────────────────────────────── */
.accordion-item { background: var(--g-bg-card) !important; border-color: var(--g-border) !important; }
.accordion-button {
  background: rgba(33,24,17,.9) !important;
  color: #f0d39e !important;
  box-shadow: none !important;
}
.accordion-button:not(.collapsed) {
  background: rgba(201,155,82,.14) !important;
  color: #f0d39e !important;
}
.accordion-body { color: var(--g-text); }

/* ── Tooltip ───────────────────────────────────────────────── */
.tooltip-inner {
  background: linear-gradient(145deg, #2a1a0a, #3a2010);
  border: 1px solid rgba(201,155,82,.4);
  color: #f4ead7;
  border-radius: 10px;
  box-shadow: 0 4px 14px rgba(0,0,0,.5);
}
.bs-tooltip-top .tooltip-arrow::before { border-top-color: rgba(201,155,82,.5) !important; }

/* ── Input Group ───────────────────────────────────────────── */
.input-group > .form-control { border-right: none !important; }
.input-group > .input-group-text { border-left: none !important; }

/* ── Misc Bootstrap overrides ──────────────────────────────── */
.border        { border-color: var(--g-border) !important; }
.border-bottom { border-bottom-color: var(--g-border) !important; }
.border-top    { border-top-color: var(--g-border) !important; }
hr             { border-color: rgba(201,155,82,.18) !important; opacity: 1; }

.bg-white, .bg-light { background: var(--g-bg-card) !important; }

small, .small  { color: var(--g-text-muted); }

/* ── Glow Utilities ────────────────────────────────────────── */
.glow-purple { box-shadow: 0 0 20px rgba(201,155,82,.4) !important; }
.text-glow   { color: #f0d39e; animation: g-glow 2.5s ease-in-out infinite; }
.pulse-ring  { animation: g-pulse 2.5s infinite; }
.float-anim  { animation: g-float 3s ease-in-out infinite; }

/* ── Responsive ────────────────────────────────────────────── */
@media (max-width: 768px) {
  body::before { opacity: .5; }
}

/* ================================================================
   ITEM TOOLTIP — ใช้ร่วมกันทุกหน้า (character, spending, lucky_charm ฯลฯ)
   วิธีใช้: ดู pages/includes/_tooltip.php
   ================================================================ */
#inv-tooltip {
  display:        none;
  position:       fixed;
  z-index:        9999;
  min-width:      180px;
  max-width:      300px;
  padding:        10px 14px;
  background:     #000000dd;
  color:          #fff;
  border-radius:  8px;
  box-shadow:     0 0 10px rgba(255,0,255,0.3);
  font-family:    "Sarabun", sans-serif;
  font-size:      13px;
  line-height:    1.6;
  pointer-events: none;
  text-align:     center;
}

/* ── Tooltip content classes (จาก renderTooltipHTML.php) ── */
.yg-tooltip .item-name   { font-weight: 700; margin-bottom: 4px; }
.yg-tooltip .grad-purple { color: #d8b06a; }
.yg-tooltip .item-req,
.yg-tooltip .item-class,
.yg-tooltip .item-tribe,
.yg-tooltip .item-zone,
.yg-tooltip .item-sex,
.yg-tooltip .item-type   { font-size: 12px; color: #9ca3af; }
.yg-tooltip .option       { font-size: 12px; }
.yg-tooltip .option-purple{ color: #60a5fa; }
.yg-tooltip .option-green { color: #34d399; }
.yg-tooltip .option-yellow{ color: #fbbf24; }
.yg-tooltip .option-pink  { color: #f472b6; }
.yg-tooltip .option-blue  { color: #60a5fa; }
.yg-tooltip .item-des {
  margin-top:  6px;
  padding-top: 6px;
  border-top:  1px solid #444;
  color:       #aaa;
  font-size:   11px;
  text-align:  left;
}
