/* === ฟอนต์ LINE Seed Sans TH จาก CDN === */
@import url('https://cdn.jsdelivr.net/gh/lazywasabi/thai-web-fonts@7.5.0/fonts/LINESeedSansTH/LINESeedSansTH.css');
@import url("https://cdnjs.cloudflare.com/ajax/libs/animate.css/4.1.1/animate.min.css");


:root{
  --bg-start:#0b0714;
  --bg-mid:#1c1130;
  --bg-end:#4b1e7a;
  --accent:#8b5cf6;
  --accent-2:#a78bfa;
  --text:#e9e8ef;
  --muted:#b7b4c7;
  --card-bg: rgba(18, 14, 30, .55);
  --border: rgba(255,255,255,.12);
  --radius: 20px;
  --shadow: 0 20px 60px rgba(7, 4, 17, .6);
  --ring: 0 0 0 3px rgba(139, 92, 246, .25);
}

*{box-sizing:border-box}
html,body{height:100%}
body {
  margin:0;
  font-family: 'LINE Seed Sans TH';
  color: var(--text);
  background:
    radial-gradient(1200px 800px at 15% 20%, rgba(139,92,246,.25), transparent 60%),
    radial-gradient(1000px 700px at 85% 80%, rgba(167,139,250,.18), transparent 60%),
    linear-gradient(145deg, var(--bg-start), var(--bg-mid) 55%, var(--bg-end));
  overflow: hidden;
  padding-top: 70px; /* ปรับตามความสูงจริงของ navbar */
}

/* overlay ลายกริดนุ่ม ๆ */
.grid-overlay::before{
  content:"";
  position: fixed;
  inset: 0;
  background-image:
    linear-gradient(to right, rgba(255,255,255,.04) 1px, transparent 1px),
    linear-gradient(to bottom, rgba(255,255,255,.04) 1px, transparent 1px);
  background-size: 28px 28px;
  mask-image: radial-gradient(circle at center, #000 40%, transparent 75%);
  pointer-events: none;
}
/* เกล็ดแกรนูลหรู ๆ */
.noise::after{
  content:"";
  position: fixed; inset:0;
  background: url("data:image/svg+xml;utf8,\
  <svg xmlns='http://www.w3.org/2000/svg' width='128' height='128' viewBox='0 0 128 128'>\
    <filter id='n'><feTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='2' stitchTiles='stitch'/></filter>\
    <rect width='100%' height='100%' filter='url(%23n)' opacity='0.035'/>\
  </svg>") repeat;
  pointer-events:none;
  mix-blend-mode: overlay;
}

.page-wrap{
  position: relative;
  min-height: 100%;
  display: grid;
  place-items: center;
  padding: 32px 16px;
}

/* การ์ดแบบ glassmorphism */
.auth-card{
  width: 100%;
  max-width: 460px;
  background: var(--card-bg);
  border: 1px solid var(--border);
  border-radius: var(--radius);
  box-shadow: var(--shadow);
  backdrop-filter: blur(14px);
  -webkit-backdrop-filter: blur(14px);
  overflow: hidden;
}
.auth-header{ padding: 28px 28px 8px; text-align:center; }
.brand{ display:flex; align-items:center; justify-content:center; gap:12px; }
.brand-badge{
  width:44px; height:44px; border-radius:12px;
  background: conic-gradient(from 210deg at 50% 50%, var(--accent), var(--accent-2), var(--accent));
  box-shadow: 0 6px 22px rgba(139,92,246,.35), inset 0 0 18px rgba(255,255,255,.18);
}
.brand-name{ font-weight: 700; letter-spacing:.2px; font-size: 20px; }
.auth-title{ margin-top: 12px; font-size: 22px; font-weight: 600; }
.auth-sub{ color: var(--muted); font-size: 14px; }

.auth-body{ padding: 24px 28px 8px; }
.auth-footer{ padding: 8px 28px 28px; color: var(--muted); font-size: 12px; text-align:center; }

.form-label{ color:#eae7fb; font-weight:500; font-size: 13px; }
.form-control{
  background: rgba(255,255,255,.06);
  border: 1px solid rgba(255,255,255,.12);
  color: var(--text);
  padding: 12px;
  border-radius: 14px;
  transition: box-shadow .2s, border-color .2s, background-color .2s;
}
.form-control::placeholder{ color: rgba(233,232,239,.55); }
.form-control:focus{
  background: rgba(255,255,255,.09);
  color: var(--text);
  border-color: rgba(139,92,246,.6);
  box-shadow: var(--ring);
}
.input-icon{
  position: absolute; left: 14px; top: 50%; transform: translateY(-50%);
  font-size: 18px; color: rgba(255,255,255,.7);
}
.toggle-pass{
  position: absolute; right: 12px; top: 50%; transform: translateY(-50%);
  background: transparent; border: 0; color: rgba(255,255,255,.8); font-size:18px;
}
.toggle-pass:focus{ outline: none; }

.btn-gradient{
  display:inline-flex; align-items:center; justify-content:center; gap:8px;
  width:100%;
  padding: 12px 16px;
  border-radius: 14px;
  border: 1px solid rgba(255,255,255,.12);
  color: #120E1E;
  font-weight: 700;
  background: linear-gradient(145deg, #a78bfa, #7c4dff 55%, #5b31cf);
  box-shadow: 0 8px 20px rgba(124,77,255,.35), inset 0 0 0 0 rgba(255,255,255,.2);
  transition: transform .06s ease, box-shadow .2s ease, filter .2s ease;
}
.btn-gradient:hover{ filter: brightness(1.05); box-shadow: 0 10px 26px rgba(124,77,255,.45); }
.btn-gradient:active{ transform: translateY(1px); }

.helper-row{
  display:flex; align-items:center; justify-content:space-between;
  gap:10px; margin: 10px 2px 16px;
  font-size: 13px; color: var(--muted);
}
.form-check-input{
  background-color: rgba(255,255,255,.06);
  border-color: rgba(255,255,255,.18);
}
.form-check-input:checked{
  background-color: var(--accent);
  border-color: var(--accent);
  box-shadow: var(--ring);
}

/* Alert โทนดาร์ก */
.alert-danger{
  background: rgba(255,77,77,.12);
  color: #ffd1d1;
  border-color: rgba(255,77,77,.25);
  border-radius: 12px;
}

/* ลิขสิทธิ์เล็ก ๆ ลอยล่าง */
.copyright{
  position: fixed; bottom: 12px; left: 50%; transform: translateX(-50%);
  font-size: 12px; color: rgba(255,255,255,.6);
  text-align:center; padding: 6px 10px; border-radius: 999px;
  background: rgba(0,0,0,.18); backdrop-filter: blur(6px);
  border: 1px solid rgba(255,255,255,.08);
}

/* --- FIX: align icon/toggle perfectly in inputs --- */
.field {
  position: relative;
  margin-bottom: 1.25rem;
}

.field .form-label {
  display: block;
  margin-bottom: .25rem;
  font-size: 13px;
  color: #eae7fb;
}

.field .form-control {
  height: 52px;
  padding-left: 44px;
  padding-right: 44px;
  border-radius: 14px;
}

/* icon ซ้าย */
.field .input-icon {
  position: absolute;
  top: 0;
  bottom: 0;
  left: 12px;
  display: flex;
  align-items: center;
  pointer-events: none;
  color: rgba(255,255,255,.8);
  font-size: 18px;
}

/* toggle ตาขวา */
.field .toggle-pass {
  position: absolute;
  top: 0;
  bottom: 0;
  right: 12px;
  display: flex;
  align-items: center;
  background: transparent;
  border: none;
  color: rgba(255,255,255,.8);
  font-size: 18px;
  cursor: pointer;
}

.bi{ line-height: 1; vertical-align: middle; } /* กัน baseline เพี้ยนข้ามเบราว์เซอร์ */

/* ========= ICON ALIGN FIX (drop-in override) ========= */

/* 1) ใช้ .field เป็น wrapper ของแต่ละช่อง */
.field{ position: relative; }

/* 2) ล็อกมิติและ line-height ของ input ให้คงที่ */
.field .form-control{
  box-sizing: border-box;
  height: 52px;                  /* ปรับได้ 48–54 */
  line-height: 1.2;              /* กัน baseline เพี้ยน */
  padding-left: 48px !important; /* เผื่อพื้นที่ไอคอนซ้าย */
  padding-right: 48px !important;/* เผื่อปุ่มตา (eye) ขวา */
}

/* 3) จัดกึ่งกลางแนวตั้งด้วย flex เต็มความสูง */
.field .input-icon,
.field .toggle-pass{
  position: absolute;
  inset-block: 0;              /* top:0; bottom:0; รองรับ writing-mode */
  display: flex;
  align-items: center;
  justify-content: center;
  width: 36px;                 /* ความกว้างพื้นที่ไอคอน */
  font-size: 18px;
  color: rgba(255,255,255,.82);
  line-height: 1;              /* กันการเด้งตาม baseline */
}

/* 4) จัดตำแหน่งซ้าย/ขวา */
.field .input-icon{ left: 10px; pointer-events: none; }
.field .toggle-pass{
  right: 8px;
  background: transparent;
  border: 0;
  padding: 0;
  cursor: pointer;
  z-index: 2;                  /* ให้อยู่เหนือ input เสมอ */
}

/* 5) ไอคอนภายในให้ชิดศูนย์จริง ๆ */
.field .toggle-pass i,
.field .input-icon i{ display:inline-block; vertical-align: middle; line-height: 1; }

/* 6) กัน style อื่น ๆ มาทับ */
.bi{ line-height: 1; vertical-align: middle; }


/* responsive */
@media (max-width: 420px){
  .auth-card{ max-width: 94vw; }
  .brand-name{ font-size: 18px; }
  .auth-title{ font-size: 20px; }
}


/* === NAV (ม่วง-ดำ glass) === */
.app-nav{
  background: linear-gradient(145deg, rgba(18,14,30,.65), rgba(26,18,46,.55));
  backdrop-filter: blur(10px);
  -webkit-backdrop-filter: blur(10px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.app-nav .navbar-brand{
  color:#fff;
  display:flex; align-items:center; gap:10px;
}
.app-nav .brand-dot{
  width:12px; height:12px; border-radius:50%;
  background: radial-gradient(circle at 40% 40%, #a78bfa, #7c4dff 60%, #5b31cf);
  box-shadow: 0 0 12px rgba(124,77,255,.65);
}
.app-nav .nav-link{
  color: #d7d3ee;
  margin-right:.25rem;
}
.app-nav .nav-link:hover, .app-nav .nav-link.active{
  color:#fff;
  text-shadow: 0 0 6px rgba(167,139,250,.35);
}
.navbar-toggler{ border-color: rgba(255,255,255,.25); }

/* === Title === */
.page-title{
  color:#fff; font-weight:700;
  text-shadow: 0 6px 26px rgba(17, 10, 36, .45);
}

/* === KPI Cards === */
.kpi-card{
  background: linear-gradient(160deg, rgba(255,255,255,.06), rgba(255,255,255,.03));
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  padding: 18px 20px;
  box-shadow: 0 18px 40px rgba(7,4,17,.35);
}
.kpi-card.kpi-alt{
  background: linear-gradient(160deg, rgba(167,139,250,.1), rgba(255,255,255,.03));
}
.kpi-head{ color:#cfc9ff; font-size:14px; margin-bottom:8px; }
.kpi-value{
  font-weight: 800; font-size: clamp(22px, 3.5vw, 32px);
  color:#ffffff;
  text-shadow: 0 8px 28px rgba(124,77,255,.35);
}

/* === “กระจก” การ์ดตาราง === */
.glass-card{
  background: rgba(18,14,30,.55);
  border: 1px solid rgba(255,255,255,.12);
  border-radius: 18px;
  overflow: hidden;
  box-shadow: 0 20px 60px rgba(7,4,17,.5);
  backdrop-filter: blur(10px);
}
.glass-card-header{
  padding: 14px 18px;
  font-weight: 600;
  color:#e9e8ef;
  border-bottom: 1px solid rgba(255,255,255,.08);
  background: linear-gradient(145deg, rgba(139,92,246,.12), rgba(255,255,255,.03));
  backdrop-filter: blur(10px);
}

/* === ตารางธีมดาร์ก === */
.theme-table{
  --tbl-border: rgba(255,255,255,.06);
  color:#eae7fb;
}
.theme-table thead th{
  background: rgba(255,255,255,.04);
  color:#dcd7ff;
  border-bottom: 1px solid var(--tbl-border);
}
.theme-table tbody tr{
  border-color: var(--tbl-border);
}
.theme-table tbody tr:hover{
  background: rgba(139,92,246,.08);
}

/* Badge ประเภท */
.bg-type-deposit{
  background: linear-gradient(145deg, #22c55e, #16a34a);
}
.bg-type-withdraw{
  background: linear-gradient(145deg, #38bdf8, #0ea5e9);
}

/* Badge สถานะ */
.badge.status-success{
  background: linear-gradient(145deg, #10b981, #059669);
}
.badge.status-pending{
  background: linear-gradient(145deg, #f59e0b, #d97706);
}
.badge.status-failed{
  background: linear-gradient(145deg, #ef4444, #b91c1c);
}

/* ==== NAV (purple-black glass) ==== */
.app-nav{
  background: linear-gradient(145deg, rgba(18,14,30,.70), rgba(26,18,46,.55));
  backdrop-filter: blur(12px);
  -webkit-backdrop-filter: blur(12px);
  border-bottom: 1px solid rgba(255,255,255,.08);
}
.app-nav .navbar-brand{
  color:#fff;
}
.app-nav .brand-dot{
  width:12px; height:12px; border-radius:50%;
  background: radial-gradient(circle at 40% 40%, #a78bfa, #7c4dff 60%, #5b31cf);
  box-shadow: 0 0 12px rgba(124,77,255,.65);
}
.app-nav .nav-link{
  color:#d7d3ee;
}
.app-nav .nav-link:hover,
.app-nav .nav-link.active{
  color:#fff;
  text-shadow:0 0 6px rgba(167,139,250,.35);
  background: #ffffff33;
  border-radius: 10px;
}

/* ปุ่มสลับภาษา / เมนูขวา */
.app-nav .dropdown-menu{
  background: rgba(18,14,30,.95);
  border:1px solid rgba(255,255,255,.12);
}
.app-nav .dropdown-item{
  color:#e9e8ef;
}
.app-nav .dropdown-item:hover{
  background: rgba(139,92,246,.18);
}


.text-muted {
    --bs-text-opacity: 1;
    color: rgb(210 210 210 / 73%) !important;
}

/* แคปซูลแสดงยอดเงิน */
.balance-pill{
  display:inline-block;
  padding:6px 10px;
  border-radius:999px;
  background: linear-gradient(145deg, rgba(139,92,246,.20), rgba(255,255,255,.06));
  border:1px solid rgba(255,255,255,.12);
  color:#e9e8ef;
  font-weight:600;
  font-size: 12px;
  box-shadow: 0 6px 16px rgba(7,4,17,.35);
}

/* ปุ่มเรียงแถวเดียว + ระยะห่างสวย ๆ */
.actions-row{
  display:flex;
  gap:.75rem;
  align-items:center;
  flex-wrap:nowrap;
}

/* ให้ปุ่มมีความสูงเท่ากันและจัดกึ่งกลางแนวตั้ง */
.btn-pill{
  display:inline-flex;
  align-items:center;
  justify-content:center;
  height:44px;            /* ปรับได้ตามใจ */
  padding:0 18px;
  border-radius:999px;
  white-space:nowrap;      /* กันตัดบรรทัด */
}

/* กันกรณีธีมตั้งปุ่มให้กว้างเต็มบรรทัด */
.btn-gradient, .btn-outline-info{
  width:auto !important;
}

.app-nav .nav-link {
    font-size: 14px;
}

/* --- Scroll fix (override) --- */
html, body {
  min-height: 100%;
  height: auto;
}

/* เปิดสกรอลแนวตั้ง ปิดสกรอลแนวนอน */
body {
  overflow-y: auto !important;
  overflow-x: hidden;
  -webkit-overflow-scrolling: touch; /* iOS ลื่นขึ้น */
}

/* ให้เลเยอร์พื้นหลังไม่บังการสกรอล/คลิก และไปอยู่ด้านหลัง */
.grid-overlay::before,
.noise::after {
  z-index: -1;          /* อยู่หลัง content */
  pointer-events: none; /* ไม่กินสกรอล/คลิก */
  position: fixed;      /* คงที่เป็นฉากหลัง */
  inset: 0;
}

/* ถ้าเคยใช้คอนเทนเนอร์เต็มจอ ปรับเป็นใช้พื้นที่อย่างยืดหยุ่น */
.page-wrap{
  min-height: 100dvh;   /* แทน 100vh แก้ปัญหา mobile browser chrome */
  height: auto;
}

/* ตารางยาวให้สกรอลภายในกล่อง ไม่ดันทั้งหน้า (ถ้าต้องการ) */
.table-responsive{
  overflow: auto;
  /* max-height: 70vh;  // เปิดถ้าต้องการจำกัดความสูงตาราง */
}

.bg-type-deposit  { background: rgba(76,175,80,.2);  color:#8be28f; }
.bg-type-withdraw { background: rgba(244,67,54,.2);  color:#ff8a80; }
.bg-type-transfer { background: rgba(33,150,243,.2); color:#90caf9; }

.datepicker {
    background: rgba(255, 255, 255, .06) !important;
    border: 1px solid rgba(255, 255, 255, .12) !important;
    color: var(--text) !important;
    padding: 12px !important;
    border-radius: 14px !important;
    transition: box-shadow .2s, border-color .2s, background-color .2s !important;
}

.datepicker-dropdown {
    top: 0;
    left: 0;
    background-color: #1e1331 !important;
}

.form-select{
  background: #22143863 !important;
  color: #fff !important;
}

.modal {
  backdrop-filter: blur(5px);
}

/* Red Theme */
/* ==== THEME OVERRIDES: Red-Dark ==== */
/* วางต่อท้ายไฟล์เดิม เพื่อเปลี่ยนเป็นโทนแดงทั้งหมด */

:root{
  /* ฉากหลังแดงเข้ม */
  --bg-start:#12070a;   /* very dark red */
  --bg-mid:#2a0c12;     /* deep maroon */
  --bg-end:#5e1420;     /* wine red */
  /* โทนแอ็กเซนต์หลัก */
  --accent:#ef4444;     /* red-500 */
  --accent-2:#f87171;   /* red-400 */
  /* สีข้อความเดิมโอเคแล้ว */
  --text:#e9e8ef;
  --muted:#d1cbd6;
  --card-bg: rgba(20, 10, 12, .55);
  --border: rgba(255,255,255,.12);
  --shadow: 0 20px 60px rgba(8, 3, 5, .6);
  --ring: 0 0 0 3px rgba(239, 68, 68, .25);
}

/* พื้นหลังไล่สี + กลุ่มแสง เปลี่ยนโทนม่วง -> แดง */
body{
  background:
    radial-gradient(1200px 800px at 15% 20%, rgba(239,68,68,.22), transparent 60%),
    radial-gradient(1000px 700px at 85% 80%, rgba(248,113,113,.16), transparent 60%),
    linear-gradient(145deg, var(--bg-start), var(--bg-mid) 55%, var(--bg-end)) !important;
}

/* โลโก้แบรนด์ (จุดเรือง) โทนแดง */
.app-nav .brand-dot{
  background: radial-gradient(circle at 40% 40%, var(--accent-2), var(--accent) 60%, #b91c1c);
  box-shadow: 0 0 12px rgba(239,68,68,.65);
}

/* Navbar glass โทนแดงนิด ๆ */
.app-nav{
  background: linear-gradient(145deg, rgba(25,10,12,.70), rgba(35,12,16,.55)) !important;
  border-bottom: 1px solid rgba(255,255,255,.08);
}

/* ลิงก์เมนู: โฮเวอร์/แอคทีฟเรืองแดง */
.app-nav .nav-link{
  color:#f0e8ee !important;
}
.app-nav .nav-link:hover,
.app-nav .nav-link.active{
  color:#fff !important;
  text-shadow:0 0 6px rgba(248,113,113,.35);
  background:#ffffff22;
  border-radius:10px;
}

/* ดรอปดาวน์เมนูโทนแดง */
.app-nav .dropdown-menu{
  background: rgba(25,10,12,.95) !important;
  border:1px solid rgba(255,255,255,.12);
}
.app-nav .dropdown-item{ color:#efecef; }
.app-nav .dropdown-item:hover{ background: rgba(239,68,68,.18); }

/* แบรนด์แบดจ์ (กรอบโลโก้เล็ก) */
.brand-badge{
  background: conic-gradient(from 210deg at 50% 50%, var(--accent), var(--accent-2), var(--accent)) !important;
  box-shadow: 0 6px 22px rgba(239,68,68,.35), inset 0 0 18px rgba(255,255,255,.18) !important;
}

/* ปุ่มหลักไล่สีโทนแดง */
.btn-gradient{
  color: #1a0b0d !important;
  background: linear-gradient(145deg, var(--accent-2), var(--accent) 55%, #b91c1c) !important;
  box-shadow: 0 8px 20px rgba(239,68,68,.35), inset 0 0 0 0 rgba(255,255,255,.2) !important;
}
.btn-gradient:hover{ filter:brightness(1.05); box-shadow:0 10px 26px rgba(239,68,68,.45) !important; }

/* ฟอร์มโฟกัสเป็นสีแดง */
.form-control:focus{
  border-color: rgba(239,68,68,.6) !important;
  box-shadow: var(--ring) !important;
}

/* แคปซูลแสดงยอดเงิน โทนแดง */
.balance-pill{
  background: linear-gradient(145deg, rgba(239,68,68,.20), rgba(255,255,255,.06)) !important;
  border:1px solid rgba(255,255,255,.12) !important;
  color:#ffeef0 !important;
}

/* เฮดเดอร์ของการ์ดกระจก ใส่แดงอุ่น ๆ */
.glass-card-header{
  background: linear-gradient(145deg, rgba(239,68,68,.12), rgba(255,255,255,.03)) !important;
}

/* ตาราง: โฮเวอร์แถวโทนแดง */
.theme-table thead th{
  color:#ffe8ea !important;
}
.theme-table tbody tr:hover{
  background: rgba(239,68,68,.10) !important;
}

/* KPI โทนแดง */
.kpi-card.kpi-alt{
  background: linear-gradient(160deg, rgba(239,68,68,.10), rgba(255,255,255,.03)) !important;
}
.kpi-value{ text-shadow: 0 8px 28px rgba(239,68,68,.35) !important; }

/* Alert อิงแดง (เดิมก็แดง นิ่มลงเล็กน้อย) */
.alert-danger{
  background: rgba(239,68,68,.12) !important;
  color: #ffe1e1 !important;
  border-color: rgba(239,68,68,.28) !important;
}

/* Datepicker/Select โทนฉากหลังแดงเข้ม */
.datepicker-dropdown{ background-color:#1c0d10 !important; }
.form-select{ background:#2a0f16a3 !important; color:#fff !important; }

/* ====== ส่วนที่เคย hard-coded สีม่วง ให้บังคับเป็นแดง ====== */

/* เส้นแสงในหัวข้อใหญ่ */
.page-title{ text-shadow: 0 6px 26px rgba(40, 9, 12, .45) !important; }

/* เงา/เรืองแสงม่วงเดิม -> แดง */
.kpi-value,
.brand-badge,
.btn-gradient{
  text-shadow: none;
}

/* hover ของตารางที่อิง rgba(139,92,246,...) -> rgba(239,68,68,...) */
.theme-table tbody tr:hover{
  background: rgba(239,68,68,.10) !important;
}

/* ถ้ามีที่ไหนอ้างอิงสีม่วงตรง ๆ ให้จับเปลี่ยนทั้งหมด */
*[style*="124,77,255"],
*[style*="#7c4dff"],
*[style*="#5b31cf"],
*[style*="#a78bfa"]{
  /* กันสีม่วงหลงเหลือจาก inline-style */
  color: var(--accent) !important;
  border-color: var(--accent) !important;
}

/* ปรับไอคอนในช่องกรอกให้กลมกลืน */
.field .input-icon,
.field .toggle-pass{
  color: rgba(255,255,255,.85) !important;
}

/* ปุ่ม outline ของ bootstrap info ให้คงโทนแดงเมื่อใช้ร่วม */
.btn-outline-info{
  border-color: rgba(239,68,68,.55) !important;
  color:#ffdede !important;
}
.btn-outline-info:hover{
  background: rgba(239,68,68,.18) !important;
}

/* ปุ่มสลับภาษา/เมนูขวา hover โทนแดง */
.app-nav .dropdown-item:hover{
  background: rgba(239,68,68,.18) !important;
}
