/* ===========================================================
   KnowHow Center — Soft UI (Light theme, minimal, rounded)
   Primary ปรับได้จากหน้า "ตั้งค่าธีม" (inject ผ่าน :root ใน layout)
   =========================================================== */
:root{
  /* ฟอนต์ + สีหลัก (layout จะ override ค่าเหล่านี้ตามการตั้งค่า) */
  --font-main:'Prompt','Kanit','Noto Sans Thai','Sarabun',Tahoma,sans-serif;
  --brand:#2445a7;          /* Primary */
  --brand-d:#1d3a8c;        /* Primary เข้ม (hover) */
  --brand-soft:#e8efff;     /* Primary อ่อน (active/hover bg) */
  --btn-bg:var(--brand);    /* สีปุ่มหลัก = Primary (เพิ่ม/สร้าง) */

  /* typography (ปรับได้จากตั้งค่าธีม) */
  --font-size:15px; --font-weight:400; --h1-size:24px; --sidebar-font:14px;

  /* พื้นหลัง + พื้นผิว */
  --bg:#f5f7fb; --panel:#ffffff; --sidebar:#ffffff; --topbar-bg:#ffffff;
  /* ข้อความ */
  --ink:#0f172a; --ink-2:#334155; --muted:#64748b; --light:#94a3b8;
  /* เส้น/ขอบ */
  --line:#e5e7eb; --line-soft:#eef2f7;

  /* โทนสถานะ (soft tone) */
  --green:#16a34a; --green-bg:#dcfce7; --amber:#d97706; --amber-bg:#fef3c7;
  --red:#dc2626; --red-bg:#fee2e2; --gray:#64748b; --gray-bg:#f1f5f9;
  --blue:#2563eb; --blue-bg:#dbeafe; --slate:#475569; --slate-bg:#eef2f7;

  /* รัศมีขอบมน + เงานุ่ม */
  --r-xs:8px; --r-sm:10px; --r-md:12px; --r-lg:16px; --r-xl:20px;
  --radius:14px;
  --shadow:0 8px 22px rgba(15,23,42,.045);
  --shadow-soft:0 6px 18px rgba(15,23,42,.035);
}
*{box-sizing:border-box}
html,body{margin:0;padding:0;overflow-x:clip}
/* ===== Scrollbar กลางตามธีม — thumb Primary โปร่ง → ทึบตอน hover · track อ่อน (ทุกหน้า ผูก --brand) ===== */
:root{scrollbar-width:thin;scrollbar-color:color-mix(in srgb, var(--brand) 45%, #fff) transparent}
::-webkit-scrollbar{width:11px;height:11px}
::-webkit-scrollbar-track{background:color-mix(in srgb, var(--brand) 8%, transparent)}
::-webkit-scrollbar-thumb{background:color-mix(in srgb, var(--brand) 45%, #fff);border-radius:8px;border:2px solid transparent;background-clip:padding-box}
::-webkit-scrollbar-thumb:hover{background:var(--brand);background-clip:padding-box}
::-webkit-scrollbar-corner{background:transparent}
body{
  font-family:var(--font-main);
  background:var(--bg);color:var(--ink);
  font-size:var(--font-size);line-height:1.5;font-weight:var(--font-weight);
  letter-spacing:-.012em;
  -webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;
  text-rendering:geometricPrecision;
}
a{color:var(--brand);text-decoration:none}
a:hover{text-decoration:underline}

/* ---------- Layout ---------- */
.app{display:flex;min-height:100vh}
.sidebar{
  width:320px;background:var(--sidebar);color:var(--ink-2);flex-shrink:0;
  display:flex;flex-direction:column;position:sticky;top:0;height:100vh;overflow:hidden;
  border-right:1px solid var(--line);transition:width .2s ease, transform .2s ease;
}
.sb-backdrop{display:none}
.sidebar .brand{padding:9px 12px 8px;border-bottom:1px solid var(--line-soft);overflow:hidden;flex-shrink:0}
.sidebar .brand-full{display:block;text-decoration:none}
.sidebar .brand-full img{max-width:100%;width:auto;max-height:75px;height:auto;display:block;margin:2px auto;border-radius:10px}
.sidebar .brand-name{display:flex;flex-direction:column;gap:1px}
.sidebar .brand b{color:var(--ink);font-size:16px;line-height:1.2;font-weight:700;letter-spacing:-.025em}
.sidebar .brand small{display:block;color:var(--light);font-size:11px;font-weight:400}
.sidebar .brand-mini{display:none;width:42px;height:42px;margin:0 auto;background:var(--brand);border-radius:13px;place-items:center;font-size:20px;color:#fff;overflow:hidden}
.sidebar .brand-mini img{width:100%;height:100%;object-fit:cover}
.nav{padding:8px 14px 18px;flex:1;position:relative;overflow-y:auto;min-height:0}
.nav .group{font-size:10px;text-transform:uppercase;letter-spacing:.07em;color:#94a3b8;padding:9px 5px 4px;font-weight:600}
.nav .group:first-child{padding-top:8px}
.nav a{display:flex;align-items:center;gap:13px;padding:5px 8px;border-radius:11px;color:#334155;font-size:var(--sidebar-font);margin-bottom:1px;font-weight:400;min-height:35px;line-height:1}
.nav a:hover{background:color-mix(in srgb, var(--brand-soft) 55%, #fff);text-decoration:none;color:var(--brand)}
.nav a:hover .ic{color:var(--brand)}
.nav a.active{background:var(--brand-soft);color:var(--brand);font-weight:500}
.nav a .ic{width:20px;flex:0 0 20px;font-size:16px;color:#64748b;display:flex;align-items:center;justify-content:center}
.nav a.active .ic{color:var(--brand)}
.nav a .lbl{flex:1;min-width:0}
.nav a .badge{margin-left:auto;background:var(--red);color:#fff;font-size:11px;padding:1px 7px;border-radius:10px;font-weight:600;flex:0 0 auto}
/* ===== แถบเครื่องมือเมนู (ยุบ/ขยายทั้งหมด) — ลอยมุมขวาบน เสมอ Section แรก ===== */
.nav-tools{position:absolute;top:6px;right:12px;z-index:2}
.nav-tool-btn{display:inline-grid;place-items:center;width:28px;height:28px;border:1px solid var(--line-soft);background:#fff;border-radius:8px;color:#64748b;cursor:pointer;font-size:14px;transition:.15s}
.nav-tool-btn:hover{color:var(--brand);border-color:var(--brand);background:var(--brand-soft)}
.app.sb-collapsed .nav-tools{display:none}
/* ===== หมวดงาน 2 ชั้น (collapsible category) ===== */
.nav-cat{margin-bottom:3px}
.nav-cat-head{display:flex;align-items:center;gap:13px;width:100%;border:0;background:transparent;cursor:pointer;padding:5px 8px;border-radius:11px;color:#334155;font-size:var(--sidebar-font);font-weight:400;min-height:35px;line-height:1;font-family:inherit;text-align:left}
.nav-cat-head:hover{background:color-mix(in srgb, var(--brand-soft) 55%, #fff);color:var(--brand)}
.nav-cat-head:hover .ic{color:var(--brand)}
.nav-cat-head .ic{width:20px;flex:0 0 20px;font-size:16px;color:#64748b;display:flex;align-items:center;justify-content:center}
.nav-cat-head .lbl{flex:1;min-width:0;text-align:left;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.nav-cat-caret{font-size:12px;color:#94a3b8;transition:transform .2s;flex:0 0 auto}
.nav-cat.open>.nav-cat-head .nav-cat-caret{transform:rotate(180deg)}
.nav-cat.open>.nav-cat-head{color:var(--ink)}
.nav-cat-body{max-height:0;overflow:hidden;transition:max-height .26s ease}
.nav-cat.open>.nav-cat-body{max-height:800px}
.nav-cat-body .nav-sub{margin-left:12px;padding-left:13px;border-left:1.5px solid var(--line-soft)}
.nav-cat-body .nav-sub .ic{font-size:16px}
/* โหมดย่อ (icon-only): ซ่อน caret + แสดงลูกตลอด (ไอคอน) */
.app.sb-collapsed .nav-cat-head .lbl,
.app.sb-collapsed .nav-cat-head .nav-cat-caret{display:none}
.app.sb-collapsed .nav-cat-head{justify-content:center;padding:9px 0}
.app.sb-collapsed .nav-cat-body{max-height:none!important}
.app.sb-collapsed .nav-cat-body .nav-sub{margin-left:0;padding-left:0;border-left:0}

.main{flex:1;min-width:0;display:flex;flex-direction:column}
.topbar{height:58px;background:var(--topbar-bg);border-bottom:1px solid var(--line);display:flex;align-items:center;padding:0 22px;gap:14px;position:sticky;top:0;z-index:20}
.topbar .page-title{font-size:16px;font-weight:600;letter-spacing:-.025em}
.topbar .spacer{flex:1}
.topbar .tb-icon{position:relative;width:38px;height:38px;border-radius:11px;display:grid;place-items:center;color:var(--slate);font-size:18px}
/* สถานะเช็กชื่อบน Topbar */
.ci-pill{display:inline-flex;align-items:center;gap:7px;height:38px;padding:0 14px;border-radius:11px;font-size:13px;font-weight:700;text-decoration:none;white-space:nowrap;border:1px solid transparent;transition:.15s}
.ci-pill i{font-size:16px}
.ci-pill:hover{filter:brightness(.96);transform:translateY(-1px)}
.ci-pill-pending{background:var(--red-bg);color:#b91c1c}
.ci-pill-in{background:var(--green-bg);color:#15803d}
.ci-pill-out{background:var(--slate-bg);color:var(--slate)}
@media(max-width:680px){ .ci-pill .ci-pill-txt{display:none} .ci-pill{padding:0 11px} }
.topbar .tb-icon:hover{background:var(--gray-bg);text-decoration:none}
.topbar .tb-icon .dot{position:absolute;top:5px;right:5px;min-width:17px;height:17px;background:var(--red);color:#fff;font-size:10px;border-radius:9px;display:grid;place-items:center;padding:0 4px;font-weight:600}
.topbar button.tb-icon{border:0;background:none;cursor:pointer;font-family:inherit}
.topbar button.tb-icon.active{background:var(--brand-soft);color:var(--brand)}

/* ถาดข้อความ/แจ้งเตือน/อนุมัติ (Topbar tray dropdown) */
.dd-menu.tray-menu{width:min(380px,calc(100vw - 28px));padding:0;overflow:hidden}
.tray-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:13px 14px;border-bottom:1px solid var(--line-soft);background:linear-gradient(180deg,#fff,#f8fafc)}
.tray-head b{font-size:14px;color:var(--ink);font-weight:700}
.tray-head small{display:block;color:var(--muted);font-size:11.5px;margin-top:1px}
.tray-pill{min-width:26px;height:24px;border-radius:999px;padding:0 8px;background:var(--brand);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;flex:0 0 auto}
.tray-body{max-height:380px;overflow-y:auto}
.tray-empty{padding:26px 16px;text-align:center;color:var(--muted);font-size:13px}
.tray-empty i{display:block;font-size:32px;margin-bottom:8px;color:#94a3b8}
.dd-menu.tray-menu .tray-row{display:flex;gap:10px;padding:11px 13px;border-bottom:1px solid var(--line-soft);text-decoration:none;color:inherit;border-radius:0;width:auto;align-items:flex-start;font-weight:400}
.dd-menu.tray-menu .tray-row:hover{background:var(--gray-bg)}
.dd-menu.tray-menu .tray-row:last-child{border-bottom:0}
.tray-av{width:40px;height:40px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#4f6ef0);color:#fff;display:grid;place-items:center;font-weight:700;font-size:14px;flex:0 0 40px}
.tray-ic{width:40px;height:40px;border-radius:13px;background:var(--amber-bg);color:var(--amber);display:grid;place-items:center;font-size:19px;flex:0 0 40px}
.tray-ic.blue{background:var(--blue-bg);color:var(--blue)}
.tray-main{min-width:0;flex:1}
.tray-title{font-size:13px;font-weight:700;color:var(--ink);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.tray-text{margin-top:2px;color:var(--slate);font-size:12.2px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}
.tray-meta{margin-top:5px;display:flex;align-items:center;gap:7px;flex-wrap:wrap;color:#94a3b8;font-size:11.5px}
.tray-tag{display:inline-flex;align-items:center;max-width:180px;height:20px;border-radius:999px;padding:0 8px;background:var(--brand-soft);color:var(--brand);font-size:10.5px;font-weight:700;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.tray-foot{padding:10px 14px;border-top:1px solid var(--line-soft);background:#f8fafc;text-align:center}
.dd-menu.tray-menu .tray-foot a{display:inline;width:auto;padding:0;color:var(--brand);font-weight:700;font-size:12.5px;background:none}
.tray-unread{margin-left:8px;align-self:center;min-width:20px;height:20px;border-radius:999px;background:var(--brand);color:#fff;font-size:10.5px;font-weight:700;display:inline-flex;align-items:center;justify-content:center;padding:0 6px;flex:0 0 auto}
.user-chip{display:flex;align-items:center;gap:10px;padding:6px 8px;border-radius:11px;cursor:pointer}
.user-chip:hover{background:var(--gray-bg)}
.avatar{width:34px;height:34px;border-radius:50%;background:var(--brand);color:#fff;display:grid;place-items:center;font-weight:600;font-size:14px;overflow:hidden}
.avatar.sm{width:24px;height:24px;font-size:11px}
.avatar.xs{width:20px;height:20px;font-size:10px}
.avatar img,.tray-av img,.cc-av img{width:100%;height:100%;object-fit:cover;display:block;border-radius:inherit}
/* กัน FOUC (กระพริบ): รูปโปรไฟล์ Timeline/สายอนุมัติหน้าบิล — สไตล์หลักอยู่ใน _bill_styles ท้าย body (ไม่ render-blocking) จึงตั้งขนาดวิกฤตไว้ใน head */
.bl-flow-dot{overflow:hidden}
.bl-flow-ava{width:36px;height:36px;border-radius:50%;object-fit:cover;display:block}
.s2av{overflow:hidden}
.s2av img{width:100%;height:100%;object-fit:cover;display:block}
/* thumbnail ทีมงาน (วงกลมซ้อนกัน) */
.team-avs{display:flex;align-items:center}
.team-av{width:30px;height:30px;border-radius:50%;margin-left:-8px;border:2px solid #fff;background:linear-gradient(135deg,var(--brand),#4f6ef0);color:#fff;font-size:11px;font-weight:700;display:grid;place-items:center;overflow:hidden;box-shadow:0 1px 3px rgba(15,23,42,.18)}
.team-av:first-child{margin-left:0}
.team-av img{width:100%;height:100%;object-fit:cover}
.team-av.more{background:#e2e8f0;color:#475569}
.user-chip .meta{font-size:13px;line-height:1.2}
.user-chip .meta small{color:var(--muted)}
.content{padding:22px 26px;max-width:100%;width:100%;margin:0;overflow-x:hidden}
/* กันเนื้อหา/รูป/ตารางล้นจอแนวนอน (Width=100% เสมอ) */
.main{max-width:100%;min-width:0}
.content img,.content video,.content canvas,.content iframe{max-width:100%}

/* ---------- Bootstrap Icons alignment ---------- */
.bi{line-height:1;vertical-align:-.125em}
.btn .bi{vertical-align:-.1em}
.page-head h1 .bi,.card .card-head h3 .bi{vertical-align:-.12em;margin-right:2px}
.badge .bi{vertical-align:-.05em}

/* ---------- Hamburger ---------- */
.hamburger{width:40px;height:40px;border-radius:11px;border:1px solid var(--line);background:#fff;cursor:pointer;
  display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;flex-shrink:0}
.hamburger:hover{background:var(--gray-bg)}
.hamburger span{width:18px;height:2px;background:var(--ink-2);border-radius:2px}

/* ---------- Topbar project selector ---------- */
.proj-switch{flex-shrink:0}
.proj-pill{display:flex;align-items:center;gap:9px;max-width:300px;padding:8px 13px;border-radius:22px;
  background:var(--brand-soft);color:var(--brand);border:1px solid transparent;cursor:pointer;font-family:inherit;
  font-weight:600;font-size:13.5px;min-height:40px}
.proj-pill:hover{filter:brightness(.97)}
.proj-pill .proj-ic{font-size:15px}
.proj-pill .proj-name{white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:210px}
.proj-pill .proj-caret{opacity:.7;font-size:11px}
.proj-menu{left:0;right:auto;width:320px;max-height:70vh;overflow:auto;padding:8px}
.proj-search-wrap{padding:4px 4px 8px}
.proj-search{width:100%;padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-size:13.5px;font-family:inherit}
.proj-search:focus{outline:none;border-color:var(--brand)}
.proj-list{display:flex;flex-direction:column;gap:2px}
.proj-item{display:flex;align-items:center;justify-content:space-between;gap:10px;width:100%;text-align:left;
  background:none;border:0;cursor:pointer;padding:9px 11px;border-radius:10px;font-family:inherit;font-size:13.5px;color:var(--ink)}
.proj-item:hover{background:var(--gray-bg)}
.proj-item.on{background:var(--brand-soft);color:var(--brand)}
.proj-item .chk{color:var(--brand);font-weight:700}
/* Thumbnail รูปโครงการใน Topbar */
.proj-thumb{width:26px;height:26px;border-radius:7px;overflow:hidden;display:inline-grid;place-items:center;background:#eef2ff;color:var(--brand);flex:0 0 26px}
.proj-thumb img{width:100%;height:100%;object-fit:cover}
.proj-thumb.ph{font-size:14px}
.proj-thumb.lg{width:36px;height:36px;border-radius:9px;flex:0 0 36px}
.proj-item{align-items:flex-start}
.proj-item .proj-thumb.lg{margin-top:1px}
.proj-item .proj-item-text{flex:1;min-width:0;display:flex;flex-direction:column;gap:1px;line-height:1.25}
.proj-item .proj-item-text b{display:block;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:13.5px}
.proj-item .pi-code{font-size:11px;font-weight:600;color:var(--brand);letter-spacing:.02em}
.proj-item .pi-meta{font-size:11.5px;color:var(--muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:4px}
.proj-item .chk{align-self:center}

/* ---------- Sidebar collapse (desktop) ---------- */
.app.sb-collapsed .sidebar{width:74px}
.app.sb-collapsed .sidebar .brand{padding:14px 8px}
.app.sb-collapsed .sidebar .brand-full{display:none}
.app.sb-collapsed .sidebar .brand-mini{display:grid}
.app.sb-collapsed .nav .group,
.app.sb-collapsed .nav a .lbl,
.app.sb-collapsed .nav a .badge{display:none}
.app.sb-collapsed .nav a{justify-content:center;padding:9px 0}
.app.sb-collapsed .nav a.active{position:relative}

/* ---------- Search box ---------- */
.search-form{display:flex;gap:8px;align-items:center}
.search-form input{padding:9px 12px;border:1px solid var(--line);border-radius:10px;font-family:inherit;font-size:14px;min-width:200px;background:#fff}
.search-form input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}
@media (max-width:560px){ .search-form input{min-width:0;width:130px} }

/* ---------- Responsive grid helpers ---------- */
.grid{display:grid;gap:20px}
.grid.c2{grid-template-columns:1fr 1fr}
.grid.c2-wide{grid-template-columns:1.5fr 1fr}
.grid.c2-wider{grid-template-columns:1.6fr 1fr}
@media (max-width:1000px){ .grid.c2,.grid.c2-wide,.grid.c2-wider{grid-template-columns:1fr} }

/* ---------- Dropdown ---------- */
.dd{position:relative}
.dd-menu{position:absolute;right:0;top:calc(100% + 6px);background:#fff;border:1px solid var(--line);border-radius:14px;box-shadow:var(--shadow);min-width:210px;padding:7px;display:none;z-index:50}
.dd-menu.open{display:block}
.dd-menu a,.dd-menu button{display:flex;width:100%;align-items:center;gap:10px;padding:9px 11px;border-radius:10px;color:var(--ink);font-size:13px;background:none;border:0;cursor:pointer;text-align:left;font-weight:500;font-family:inherit}
.dd-menu a:hover,.dd-menu button:hover{background:var(--gray-bg);text-decoration:none}
.dd-menu .div{height:1px;background:var(--line-soft);margin:5px 4px}

/* ---------- Cards / Panels ---------- */
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-soft)}
.card .card-head{padding:15px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;gap:12px}
.card .card-head h3{margin:0;font-size:15px;font-weight:600;letter-spacing:-.02em}
.card .card-body{padding:18px}
.page-head{display:flex;align-items:center;gap:13px;margin-bottom:20px;flex-wrap:wrap}
.page-head h1{margin:0;font-size:var(--h1-size);font-weight:700;letter-spacing:-.035em}
.page-head .spacer{flex:1}

/* KPI grid */
.kpi-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(210px,1fr));gap:14px;margin-bottom:18px}
.kpi{background:var(--panel);border:1px solid var(--line);border-radius:var(--r-lg);padding:16px 18px;box-shadow:var(--shadow)}
.kpi .label{color:var(--muted);font-size:12.5px;display:flex;align-items:center;gap:8px;font-weight:500}
.kpi .value{font-size:27px;font-weight:700;margin-top:8px;letter-spacing:-.045em;line-height:1.05}
.kpi .ic{width:32px;height:32px;border-radius:10px;display:grid;place-items:center;font-size:17px}
/* KPI ที่คลิกเพื่อกรองได้ */
a.kpi{text-decoration:none;color:inherit;display:block;transition:.15s;cursor:pointer}
.kpi-filter a.kpi:hover{border-color:var(--brand);box-shadow:0 6px 18px rgba(36,69,167,.12);transform:translateY(-1px)}
.kpi-filter a.kpi.on{border-color:var(--brand);box-shadow:0 0 0 2px var(--brand) inset}
.kpi-filter a.kpi.on .value{color:var(--brand)}

/* ---------- Tables ---------- */
.table-wrap{overflow-x:auto}
table.tbl{width:100%;border-collapse:collapse;font-size:13.5px}
table.tbl th{text-align:left;padding:10px 12px;border-bottom:1px solid var(--line);color:var(--muted);font-weight:600;font-size:11.5px;letter-spacing:.035em;white-space:nowrap;text-transform:uppercase}
table.tbl td{padding:10px 12px;border-bottom:1px solid var(--line-soft);vertical-align:middle}
table.tbl tbody tr:hover td{background:#f8fafc}
table.tbl .num{text-align:right;font-variant-numeric:tabular-nums}
table.tbl tfoot th{border-top:1px solid var(--line);border-bottom:0;color:var(--ink)}

/* ---------- Badges (soft tone) ---------- */
.badge{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;border-radius:20px;font-size:11.5px;font-weight:600;letter-spacing:-.01em}
.badge.green{background:var(--green-bg);color:#15803d}
.badge.amber{background:var(--amber-bg);color:#b45309}
.badge.red{background:var(--red-bg);color:#b91c1c}
.badge.blue{background:var(--blue-bg);color:#1d4ed8}
.badge.gray{background:var(--gray-bg);color:#475569}
.badge.slate{background:var(--slate-bg);color:#334155}

/* ---------- Buttons ---------- */
.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 15px;border-radius:11px;border:1px solid transparent;font-size:14px;font-weight:600;cursor:pointer;background:var(--btn-bg);color:#fff;transition:.15s;font-family:inherit;letter-spacing:-.01em;min-height:35px;line-height:1}
.btn:hover{background:var(--brand-d);text-decoration:none;color:#fff}
.btn.ghost{background:#fff;color:var(--ink-2);border-color:var(--line)}
.btn.ghost:hover{background:var(--gray-bg);color:var(--ink)}
.btn.green{background:var(--green)}.btn.green:hover{background:#15803d}
.btn.red{background:var(--red)}.btn.red:hover{background:#b91c1c}
.btn.amber{background:var(--amber)}.btn.amber:hover{background:#b45309}
/* ===== ปุ่มมาตรฐานตามชนิด: เพิ่ม/สร้าง=brand · แก้ไข=brand-soft · ลบ/ล้าง=danger ===== */
.btn.add,.btn-add{background:var(--brand);color:#fff}
.btn.add:hover,.btn-add:hover{background:var(--brand-d);color:#fff}
.btn.edit,.btn-edit{background:var(--brand-soft);color:var(--brand);border-color:color-mix(in srgb,var(--brand) 20%,transparent)}
.btn.edit:hover,.btn-edit:hover{background:color-mix(in srgb,var(--brand-soft) 72%,var(--brand) 14%);color:var(--brand)}
.btn.edit .ic,.btn-edit .ic{color:var(--brand)}
.btn.del,.btn-del{background:var(--red);color:#fff}
.btn.del:hover,.btn-del:hover{background:#b91c1c;color:#fff}
.btn.sm{padding:6px 10px;font-size:12.5px;min-height:30px;border-radius:9px}
.btn.block{width:100%;justify-content:center}
.btn-row{display:flex;gap:10px;flex-wrap:wrap}

/* ---------- Select2 (ค้นหาในกล่องเลือก) ---------- */
.select2-container--default .select2-selection--single{height:38px;border:1px solid var(--line)!important;border-radius:11px;display:flex;align-items:center;padding:0 8px;font-family:inherit}
.select2-container--default .select2-selection--single .select2-selection__rendered{line-height:36px;color:var(--ink);padding:0}
.select2-container--default .select2-selection--single .select2-selection__arrow{height:36px}
.select2-container--default .select2-search--dropdown .select2-search__field{border:1px solid var(--line);border-radius:9px;padding:7px 9px}
.select2-dropdown{border-color:var(--line);border-radius:12px;box-shadow:var(--shadow);overflow:hidden}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--brand)}
.select2-container{z-index:1600}

/* ---------- Checkbox / Radio (เล็ก ทันสมัย) ---------- */
/* checkbox/radio = native (มาตรฐานเบราว์เซอร์) · 16px ลงตัวที่ซูม 1.5× (=24) ลด shimmer · ใช้ accent-color ตามธีม */
input[type=checkbox],input[type=radio]{width:16px;height:16px;min-height:0;flex:0 0 auto;accent-color:var(--brand);cursor:pointer;margin:0}

/* Modal กลาง (ฟอร์มเพิ่ม/แก้ไขข้อมูล) */
.data-modal-bg{display:none;position:fixed;inset:0;background:rgba(15,23,42,.55);z-index:1500;padding:24px;overflow-y:auto}
.data-modal-bg.show{display:block}
.data-modal{width:min(1100px,100%);margin:0 auto;background:var(--bg);border-radius:18px;box-shadow:0 30px 90px rgba(15,23,42,.34);overflow:hidden}
.data-modal-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 20px;background:#fff;border-bottom:1px solid var(--line);position:sticky;top:0;z-index:2}
.data-modal-head b{font-size:18px;color:var(--ink)}
.data-modal-body{padding:18px 20px;max-height:calc(100vh - 130px);overflow-y:auto}
.data-modal-body .page-head{display:none}
.data-modal-loading{padding:50px;text-align:center;color:var(--muted)}

/* SweetAlert ต้องอยู่เหนือ Modal ทุกชั้น (กันจมหลัง Modal) */
.swal2-container{z-index:2147483646!important}

/* เมนูจัดการแถวตาราง (kebab dropdown) */
.rowmenu{position:relative;display:inline-block}
.rowmenu-btn{width:32px;height:32px;border:1px solid var(--line);border-radius:9px;background:#fff;color:var(--slate);cursor:pointer;display:grid;place-items:center;font-size:16px}
.rowmenu-btn:hover{background:var(--gray-bg);color:var(--brand)}
.rowmenu-pop{position:fixed;display:none;min-width:180px;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);padding:6px;z-index:1600;top:0;left:0}
.rowmenu-pop.open{display:block}
.rowmenu-pop a,.rowmenu-pop button{display:flex;width:100%;align-items:center;gap:10px;padding:9px 11px;border-radius:9px;background:none;border:0;text-align:left;font-family:inherit;font-size:13px;font-weight:500;color:var(--ink);cursor:pointer;text-decoration:none}
.rowmenu-pop a:hover,.rowmenu-pop button:hover{background:var(--gray-bg)}
.rowmenu-pop form{margin:0}
.rowmenu-pop .danger,.rowmenu-pop .danger:hover{color:var(--red)}
.rowmenu-pop .div{height:1px;background:var(--line-soft);margin:4px 6px}
.rowmenu-pop i{width:16px;text-align:center}

/* Toggle chips (เลือกหลายรายการ เช่น สิทธิ์หน้า) */
.acc-wrap{display:flex;flex-direction:column;gap:6px}
.acc-cat{font-size:11.5px;font-weight:700;color:var(--muted);margin-top:8px;text-transform:uppercase;letter-spacing:.3px}
.acc-cat:first-child{margin-top:0}
.acc-grid{display:flex;flex-wrap:wrap;gap:8px}
.acc-chip{display:inline-flex;align-items:center;gap:8px;padding:7px 12px;border:1px solid var(--line);border-radius:10px;cursor:pointer;font-size:12.5px;font-weight:500;color:var(--ink-2);background:#fff;user-select:none;transition:.12s}
.acc-chip:hover{border-color:var(--brand)}
.acc-chip input{display:none}
.acc-chip .bx{width:16px;height:16px;border:1.5px solid var(--line);border-radius:5px;display:grid;place-items:center;color:#fff;font-size:10px;flex:0 0 auto}
.acc-chip.on,.acc-chip:has(input:checked){background:var(--brand-soft);border-color:var(--brand);color:var(--brand)}
.acc-chip.on .bx,.acc-chip:has(input:checked) .bx{background:var(--brand);border-color:var(--brand)}
.acc-chip.on .bx::before,.acc-chip:has(input:checked) .bx::before{content:'\2713'}

/* Select2 avatar thumbnail */
.s2av{display:inline-grid;place-items:center;width:24px;height:24px;border-radius:50%;background:linear-gradient(135deg,var(--brand),#4f6ef0);color:#fff;font-size:11px;font-weight:700;flex:0 0 auto;overflow:hidden}
.s2av img{width:100%;height:100%;object-fit:cover;display:block}
.s2opt{display:flex;align-items:center;gap:9px}
.s2opt small{color:var(--muted);font-weight:400}
.s2info{display:flex;align-items:center;gap:9px;min-width:0;overflow:hidden}
.s2info>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.select2-results__option .s2opt{justify-content:space-between}
.s2-add{flex:0 0 auto;display:inline-flex;align-items:center;gap:4px;border:1px solid var(--brand);background:#fff;color:var(--brand);border-radius:8px;padding:3px 10px;font-size:11.5px;font-weight:600;cursor:pointer;line-height:1.5}
.s2-add:hover{background:var(--brand);color:#fff}

/* ---------- Forms ---------- */
.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px 18px}
.field{display:flex;flex-direction:column;gap:6px}
.field.full{grid-column:1/-1}
.field label{font-size:12.5px;font-weight:500;color:var(--ink-2)}
.field .hint{font-size:12px;color:var(--muted)}
.field input,.field select,.field textarea{padding:10px 13px;border:1.5px solid var(--line);border-radius:12px;font-size:13.5px;font-family:inherit;background:var(--panel,#fff);color:var(--ink);width:100%;min-height:42px;transition:border-color .15s,box-shadow .15s,background .15s}
.field input:hover,.field select:hover,.field textarea:hover{border-color:var(--line-soft);background:var(--bg)}
.field input:focus,.field select:focus,.field textarea:focus{outline:none;border-color:var(--brand);background:var(--panel,#fff);box-shadow:0 0 0 3px var(--brand-soft)}
/* ANTI-SHAKE (ทั้งระบบ): ล็อกความสูง input/select เป็นค่าคงที่ แทน min-height ที่แกว่งรอบเส้น 42px
   → กันอาการฟอร์ม "สั่น" ตอน hover/focus ทุกหน้า/ทุก Modal (textarea + checkbox/radio ยกเว้น) */
.field input:not([type=checkbox]):not([type=radio]),.field select{height:42px}
.field input::placeholder,.field textarea::placeholder{color:var(--light)}
/* checkbox/radio ต้องเล็กเสมอ แม้อยู่ใน .field (กันกฎ .field input ขยายใหญ่) */
.field input[type=checkbox],.field input[type=radio]{width:16px;height:16px;min-height:0;flex:0 0 auto;accent-color:var(--brand)}
.field textarea{resize:vertical;min-height:80px}
.field .err{color:var(--red);font-size:12.5px}
.field input.has-err,.field select.has-err{border-color:var(--red)}

/* ---------- Alerts ---------- */
.alert{padding:12px 15px;border-radius:13px;margin-bottom:18px;font-size:14px;display:flex;gap:10px;align-items:center}
.alert.success{background:var(--green-bg);color:#166534;border:1px solid #86efac}
.alert.error{background:var(--red-bg);color:#991b1b;border:1px solid #fca5a5}
.alert.info{background:var(--blue-bg);color:#1e40af;border:1px solid #93c5fd}

/* ---------- Auth ---------- */
.auth-wrap{min-height:100vh;display:grid;place-items:center;background:linear-gradient(135deg,#16224a 0%,var(--brand) 100%);padding:20px}
.auth-card{background:#fff;border-radius:20px;padding:38px 36px;width:100%;max-width:410px;box-shadow:0 25px 70px rgba(15,23,42,.30)}
.auth-card .logo-big{width:56px;height:56px;background:var(--brand);border-radius:16px;display:grid;place-items:center;font-size:30px;margin-bottom:16px;color:#fff}
.auth-card h1{margin:0 0 4px;font-size:22px;font-weight:700;letter-spacing:-.03em}
.auth-card p.sub{color:var(--muted);margin:0 0 24px;font-size:14px}

/* ---------- Timeline ---------- */
.timeline{list-style:none;margin:0;padding:0}
.timeline li{display:flex;gap:14px;padding-bottom:18px;position:relative}
.timeline li:before{content:'';position:absolute;left:13px;top:26px;bottom:0;width:2px;background:var(--line)}
.timeline li:last-child:before{display:none}
.timeline .tl-dot{width:28px;height:28px;border-radius:50%;flex-shrink:0;display:grid;place-items:center;font-size:13px;color:#fff;z-index:1;font-weight:600}
.timeline .tl-body{font-size:13.5px}
.timeline .tl-body .when{color:var(--muted);font-size:12px;margin-top:2px}

/* ---------- Chat ---------- */
.chat{display:grid;grid-template-columns:280px 1fr;height:calc(100vh - 58px - 44px);background:#fff;border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}
.chat .conv-list{border-right:1px solid var(--line);overflow-y:auto}
.chat .conv{display:flex;gap:11px;padding:12px 14px;border-bottom:1px solid var(--line-soft);cursor:pointer;align-items:center}
.chat .conv:hover{background:var(--gray-bg);text-decoration:none}
.chat .conv.active{background:var(--brand-soft)}
.chat .conv .meta{min-width:0;flex:1}
.chat .conv .meta b{display:block;font-size:14px;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}
.chat .conv .meta small{color:var(--muted);font-size:12.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}
.chat .conv .unread{background:var(--red);color:#fff;font-size:11px;border-radius:10px;padding:1px 7px;font-weight:600}
.chat .conv-main{display:flex;flex-direction:column;min-width:0}
.chat .conv-head{padding:14px 18px;border-bottom:1px solid var(--line);font-weight:600}
.chat .msgs{flex:1;overflow-y:auto;padding:18px;display:flex;flex-direction:column;gap:10px;background:#f8fafc}
.chat .msg{max-width:70%;padding:9px 13px;border-radius:14px;font-size:13.5px}
.chat .msg.me{align-self:flex-end;background:var(--brand);color:#fff;border-bottom-right-radius:4px}
.chat .msg.them{align-self:flex-start;background:#fff;border:1px solid var(--line);border-bottom-left-radius:4px}
.chat .msg .who{font-size:11.5px;font-weight:600;margin-bottom:2px;opacity:.85}
.chat .msg .when{font-size:10.5px;opacity:.7;margin-top:3px;text-align:right}
.chat .composer{padding:12px;border-top:1px solid var(--line);display:flex;gap:10px}
.chat .composer input{flex:1;padding:11px 15px;border:1px solid var(--line);border-radius:22px;font-size:14px;font-family:inherit}
.chat .composer input:focus{outline:none;border-color:var(--brand)}
.chat .empty-chat{display:grid;place-items:center;color:var(--muted);height:100%}

/* ---------- Floating Action Button (FAB) ---------- */
.fab-wrap{position:fixed;right:26px;bottom:26px;z-index:80;width:max-content}
.fab-wrap > .fab,.fab-wrap > .fab-circle{position:relative;right:auto;bottom:auto;margin-left:auto}
.fab{width:56px;height:56px;border-radius:50%;background:var(--brand);color:#fff;border:0;cursor:pointer;
  font-size:26px;display:grid;place-items:center;box-shadow:0 12px 28px rgba(36,69,167,.4);transition:.2s}
.fab:hover{background:var(--brand-d);transform:translateY(-2px)}
.fab.open{transform:rotate(45deg)}
/* ปุ่มรวมหลายรายการ (hamburger ≡) ไม่หมุน — ใช้ไฮไลต์แทน */
.fab.fab-multi.open{transform:none;background:var(--brand-d)}
.fab-circle.fab-multi.open{background:var(--brand-d)}
/* เมนูเด้งขึ้นด้านบนปุ่ม (absolute) — ปุ่มหลักอยู่กับที่เสมอ */
.fab-menu{position:absolute;right:0;bottom:calc(100% + 14px);display:none;flex-direction:column;gap:10px;align-items:flex-end}
.fab-menu.show{display:flex}
.fab-item{display:flex;align-items:center;gap:10px;text-decoration:none;animation:fabIn .18s ease;border:0;background:none;padding:0;margin:0;font:inherit;cursor:pointer}
.fab-item:hover{text-decoration:none}
.fab-item .lbl{background:#fff;color:var(--ink);font-size:13px;font-weight:600;padding:7px 12px;border-radius:10px;box-shadow:var(--shadow);white-space:nowrap}
.fab-item .ic{width:46px;height:46px;border-radius:50%;background:#fff;color:var(--brand);display:grid;place-items:center;font-size:20px;box-shadow:0 8px 20px rgba(15,23,42,.14)}
@keyframes fabIn{from{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}

/* FAB วงกลม — ปุ่มเพิ่มเฉพาะหน้า (ไอคอน +) มีป้ายชื่อตอน hover */
.fab-circle{position:fixed;right:26px;bottom:26px;z-index:80;width:58px;height:58px;border-radius:50%;
  border:0;outline:0;cursor:pointer;padding:0;-webkit-appearance:none;appearance:none;
  background:var(--brand);color:#fff;display:grid;place-items:center;font-size:26px;
  box-shadow:0 12px 28px rgba(36,69,167,.4);text-decoration:none;transition:.2s}
.fab-circle:focus-visible{box-shadow:0 12px 28px rgba(36,69,167,.4),0 0 0 3px rgba(36,69,167,.35)}
.fab-circle:hover{background:var(--brand-d);transform:translateY(-2px);color:#fff;text-decoration:none}
.fab-circle .fab-tip{position:absolute;right:70px;top:50%;transform:translateY(-50%) translateX(6px);
  background:#fff;color:var(--ink);font-size:13px;font-weight:600;padding:7px 12px;border-radius:10px;
  box-shadow:var(--shadow);white-space:nowrap;opacity:0;pointer-events:none;transition:.15s}
.fab-circle:hover .fab-tip{opacity:1;transform:translateY(-50%) translateX(0)}
@media (max-width:560px){
  .fab-circle{right:16px;bottom:16px}
  .fab-circle .fab-tip{display:none}
}

/* ---------- E-Form กระดาษเอกสาร (รายละเอียด/พิมพ์) ---------- */
.eform-paper{background:#fff;line-height:1.65;color:#1f2937}
.eform-paper table{border-collapse:collapse;width:100%;margin:8px 0}
.eform-paper td,.eform-paper th{border:1px solid #94a3b8;padding:5px 8px}
.eform-paper img{max-width:100%}
.eform-paper h1,.eform-paper h2,.eform-paper h3{margin:.4em 0}

/* ---------- Toast (realtime แจ้งเตือน) ---------- */
.toast-wrap{position:fixed;right:26px;bottom:96px;z-index:90;display:flex;flex-direction:column;gap:10px;max-width:330px}
.toast{display:flex;gap:11px;align-items:flex-start;background:#fff;border:1px solid var(--line);border-left:4px solid var(--brand);
  border-radius:13px;padding:12px 14px;box-shadow:var(--shadow);text-decoration:none;color:var(--ink);animation:toastIn .25s ease;transition:opacity .3s,transform .3s}
.toast:hover{text-decoration:none;transform:translateX(-3px)}
.toast.hide{opacity:0;transform:translateX(24px)}
.toast .t-ic{font-size:20px;line-height:1.2}
.toast .t-body{font-size:13.5px;line-height:1.4}
.toast .t-body small{color:var(--muted)}
@keyframes toastIn{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}
@media (max-width:880px){ .toast-wrap{right:14px;left:14px;bottom:88px;max-width:none} }

/* ---------- Org position (hero + glass) ---------- */
.glass-card{background:rgba(255,255,255,.62);backdrop-filter:blur(16px) saturate(1.2);-webkit-backdrop-filter:blur(16px) saturate(1.2);border:1px solid rgba(255,255,255,.7);box-shadow:0 12px 34px rgba(31,45,90,.10)}
.pos-hero{position:relative;border-radius:18px;padding:18px 20px;margin-bottom:18px;overflow:hidden;background:linear-gradient(135deg,rgba(36,69,167,.92),rgba(59,86,179,.82));color:#fff;box-shadow:0 14px 40px rgba(31,45,90,.22)}
.pos-hero.pos-hero-brand{background:
  radial-gradient(130% 150% at 0% 0%, rgba(255,255,255,.26), transparent 52%),
  radial-gradient(120% 130% at 100% 120%, rgba(0,0,0,.26), transparent 60%),
  linear-gradient(135deg, color-mix(in srgb, var(--brand,#2445a7) 84%, #000) 0%, var(--brand,#2445a7) 50%, color-mix(in srgb, var(--brand,#2445a7) 80%, #fff) 100%);
  box-shadow:0 16px 44px color-mix(in srgb, var(--brand,#2445a7) 40%, transparent)}
.pos-hero::after{content:'';position:absolute;width:220px;height:220px;border-radius:50%;background:rgba(255,255,255,.12);top:-90px;right:-40px}
.pos-hero .ph-top{display:flex;align-items:center;gap:14px;position:relative;z-index:1}
.pos-hero .ph-ic{width:52px;height:52px;border-radius:15px;background:rgba(255,255,255,.18);display:grid;place-items:center;font-size:24px;border:1px solid rgba(255,255,255,.35)}
.pos-hero h2{margin:0;font-size:20px;font-weight:700;letter-spacing:-.02em}
.pos-hero .ph-sub{font-size:12.5px;color:rgba(255,255,255,.85);margin-top:2px}
.pos-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-top:16px;position:relative;z-index:1}
.pos-stat{background:rgba(255,255,255,.16);border:1px solid rgba(255,255,255,.25);border-radius:13px;padding:11px 12px;text-align:center}
.pos-stat .v{font-size:20px;font-weight:700;line-height:1.1}
.pos-stat .l{font-size:11px;color:rgba(255,255,255,.85);margin-top:4px}
@media(max-width:560px){.pos-stats{grid-template-columns:repeat(2,1fr)}}

/* ---------- Misc ---------- */
.muted{color:var(--muted)}
.empty{text-align:center;padding:46px 20px;color:var(--muted)}
.empty .big{font-size:38px;margin-bottom:8px}
.progress{height:8px;background:var(--gray-bg);border-radius:6px;overflow:hidden}
.progress > span{display:block;height:100%;background:var(--green)}
.chips{display:flex;gap:8px;flex-wrap:wrap}
.chip{background:var(--gray-bg);color:var(--slate);padding:4px 11px;border-radius:16px;font-size:12.5px}
.thumb-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:10px}
.thumb-grid img{width:100%;height:110px;object-fit:cover;border-radius:11px;border:1px solid var(--line)}
.section-title{font-size:12.5px;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin:24px 0 10px;font-weight:600}
hr.sep{border:0;border-top:1px solid var(--line-soft);margin:20px 0}
.tag-line{display:flex;gap:10px;align-items:center;flex-wrap:wrap;color:var(--muted);font-size:13px}
code{background:var(--gray-bg);padding:2px 7px;border-radius:6px;color:#475569;font-size:12.5px}

/* ===== Responsive: Desktop / Tablet (Tab S11) / Mobile (S25) ===== */
@media (max-width:1024px){
  .sidebar{position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);z-index:120;width:268px}
  .app.sb-open .sidebar{transform:translateX(0);box-shadow:0 10px 40px rgba(15,23,42,.25)}
  /* บนจอเล็ก ใช้ drawer เต็มป้าย ไม่ใช้โหมดย่อไอคอน */
  .app.sb-collapsed .sidebar{width:268px}
  .app.sb-collapsed .sidebar .brand-full{display:block}
  .app.sb-collapsed .sidebar .brand-mini{display:none}
  .app.sb-collapsed .nav .group,
  .app.sb-collapsed .nav a .lbl,
  .app.sb-collapsed .nav a .badge{display:revert}
  .app.sb-collapsed .nav a{justify-content:flex-start;padding:8px 11px}
  .sb-backdrop{position:fixed;inset:0;background:rgba(15,23,42,.45);z-index:110}
  .app.sb-open .sb-backdrop{display:block}
  .topbar-title{display:none}
}
/* Card Status จำนวนคอลัมน์ตาม breakpoint มาตรฐาน (ทับ inline/page repeat(N) ทุกการ์ดสถานะทั้งระบบ) */
/* 992px+ : 4–6 คอลัมน์ (auto จาก base ของแต่ละหน้า) */
@media (max-width:991px){ .kpi-grid,.tmm-stats,.emp-cards,.cc-stats,.pt-summary,.pos-stats,.sa-cards{grid-template-columns:repeat(4,minmax(0,1fr))!important} } /* Tablet แนวนอน 768–991 = 4 */

/* ===========================================================
   ACL / Approval picker (สิทธิ์ & สายอนุมัติ) — COMPONENT กลาง
   ใช้ซ้ำทุกงานที่มีสิทธิ์/สายอนุมัติ (บิล, เอกสาร, Topbar ฯลฯ)
   โครงเดียวกับป็อปอัปสิทธิ์บน Topbar: เซ็กเมนต์ + ติ๊ก Role (สี + ชื่อ + Lv)
   มาร์กอัป: .kh-acl-seg > .kh-acl-seg-btn(.on)
            .kh-acl-list > label.kh-acl-rolechk > input + .kh-acl-dot + .kh-acl-rname + [.kh-acl-lock] + small.kh-acl-lv
   =========================================================== */
.kh-acl-seg{display:flex;gap:6px;background:var(--gray-bg,#f1f5f9);border-radius:10px;padding:4px;margin-top:4px}
.kh-acl-seg-btn{flex:1;border:0;background:transparent;border-radius:8px;padding:8px 6px;font:inherit;font-size:12.5px;font-weight:600;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;transition:.15s}
.kh-acl-seg-btn:hover{color:var(--ink-2)}
.kh-acl-seg-btn.on{background:var(--panel,#fff);color:var(--brand);box-shadow:0 1px 3px rgba(15,23,42,.1)}
/* ===== Segmented Control (Toggle) มาตรฐานกลาง — .kh-seg (radio) · ช่องที่เลือก = พื้น Primary ตัวอักษรขาว =====
   มาร์กอัป: <div class="kh-seg"><label class="kh-seg-btn"><input type="radio" name="x" value="a" checked><span><i class="bi bi-..."></i> ป้าย</span></label> ...</div>
   ใช้ได้ทุกหน้าที่มีตัวเลือกแบบ 2-3 โหมด (auto/manual, เปิด/ปิด, ฯลฯ) — ไม่ใช้ native control = ไม่ shimmer ตอนซูมเศษ */
.kh-seg{display:inline-flex;gap:4px;background:var(--gray-bg,#f1f5f9);border:1px solid var(--line);border-radius:13px;padding:4px}
.kh-seg-btn{position:relative;cursor:pointer;margin:0}
.kh-seg-btn>input{position:absolute;width:1px;height:1px;opacity:0;margin:0;pointer-events:none}
.kh-seg-btn>span{display:flex;align-items:center;gap:6px;padding:8px 16px;border-radius:10px;font-size:12.5px;font-weight:600;color:var(--muted);white-space:nowrap;transition:color .18s,background .18s,box-shadow .18s}
.kh-seg-btn:hover>span{color:var(--ink-2,#475569)}
.kh-seg-btn:has(input:checked)>span{background:var(--brand);color:#fff;box-shadow:0 4px 12px rgba(36,69,167,.28)}
.kh-seg-btn:has(input:disabled){opacity:.5;pointer-events:none}
/* ไม่ตั้ง scroll ของตัวเอง (กัน scroll ซ้อน scroll ในโมดัล → hover แล้วพริบ) ปล่อยให้ parent ที่ scroll ได้จัดการ
   ถ้าต้องการจำกัดความสูง ให้ครอบด้วย .kh-acl-list--scroll แทน (ใช้ในบริบทที่ไม่ได้อยู่ในกล่อง scroll อยู่แล้ว) */
.kh-acl-list{margin-top:10px}
.kh-acl-list--scroll{max-height:260px;overflow-y:auto;scrollbar-gutter:stable}
.kh-acl-rolechk{display:flex!important;align-items:center;gap:9px;margin:0!important;padding:8px 10px;border-radius:9px;cursor:pointer;font-size:13.5px;font-weight:400;transition:background-color .12s ease}
.kh-acl-rolechk:hover{background:var(--gray-bg,#f1f5f9)}
.kh-acl-rolechk input{margin:0;width:auto!important;flex:0 0 auto;accent-color:var(--brand)}
.kh-acl-rolechk.is-locked{opacity:.85;cursor:not-allowed}
.kh-acl-dot{width:10px;height:10px;border-radius:50%;flex:0 0 auto}
.kh-acl-rname{flex:1;min-width:0;font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}
.kh-acl-lock{color:var(--light);font-size:12px;flex:0 0 auto}
.kh-acl-lv{flex:0 0 auto;font-size:11.5px;font-weight:600;color:var(--muted);background:var(--gray-bg,#f1f5f9);border-radius:999px;padding:2px 9px;white-space:nowrap}
.kh-acl-hint{font-size:11px;color:var(--muted);margin-top:6px;display:flex;align-items:flex-start;gap:5px;line-height:1.5}
/* ===== ค้นหาที่อยู่อัตโนมัติ (dropdown ผลลัพธ์) — กลาง ใช้ร่วม addrSearch/addrPick (footer.php) ===== */
.addr-results{position:absolute;top:100%;left:0;right:0;background:var(--panel,#fff);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);max-height:280px;overflow-y:auto;z-index:40;display:none;margin-top:4px}
.addr-results.show{display:block}
.addr-item{padding:9px 12px;cursor:pointer;font-size:13px;border-bottom:1px solid var(--line-soft)}
.addr-item:last-child{border-bottom:0}
.addr-item:hover{background:var(--brand-soft)}
.addr-item small{color:var(--muted)}
@media (max-width:767px){ .kpi-grid,.tmm-stats,.emp-cards,.cc-stats,.pt-summary,.pos-stats,.sa-cards{grid-template-columns:repeat(3,minmax(0,1fr))!important} } /* Tablet 576–767 = 3 */
@media (max-width:575px){ .kpi-grid,.tmm-stats,.emp-cards,.cc-stats,.pt-summary,.pos-stats,.sa-cards{grid-template-columns:repeat(2,minmax(0,1fr))!important} } /* มือถือทั่วไป 361–575 = 2 */
@media (max-width:360px){ .kpi-grid,.tmm-stats,.emp-cards,.cc-stats,.pt-summary,.pos-stats,.sa-cards{grid-template-columns:1fr!important} } /* มือถือเล็ก ≤360 = 1 */
@media (max-width:768px){
  .form-grid{grid-template-columns:1fr}
  .chat{grid-template-columns:1fr;height:auto}
  .chat .conv-list{max-height:40vh}
  .chat .msgs{min-height:46vh}
  .content{padding:16px 14px}
  .user-meta{display:none}
  .topbar{padding:0 14px;gap:10px}
  .proj-pill{max-width:180px}
  .proj-pill .proj-name{max-width:104px}
  .proj-menu{width:min(92vw,320px)}
}
/* Topbar กันล้นจอบนมือถือ — ย่อ gap/ไอคอน/พิลล์ ให้พอดีเสมอ */
@media (max-width:575px){
  .topbar{gap:5px;padding:0 8px}
  .topbar .dd,.topbar .user-chip{min-width:0}
  .topbar .tb-icon{width:34px;height:34px;font-size:16px}
  .proj-pill{max-width:130px}
  .proj-pill .proj-name{max-width:64px}
  .user-chip .proj-caret{display:none}
  .dd-menu{max-width:92vw}
}
@media (max-width:400px){
  .topbar{gap:3px}
  .topbar .tb-icon{width:31px;height:31px;font-size:15px}
  .proj-pill{max-width:108px;padding-left:6px;padding-right:6px}
  .proj-pill .proj-name{max-width:48px}
}
@media (max-width:480px){
  .page-head h1{font-size:20px}
  .fab-wrap{right:16px;bottom:16px}
  .kpi-grid{gap:10px}
  .kpi{padding:12px 13px}
  .kpi .value{font-size:22px}
  .kpi .label{font-size:11.5px}
}

/* ===== Responsive Table: มือถือแนวตั้ง ไม่ใช้ scrollbar แนวนอน → แสดงแบบการ์ดย่อ ===== */
@media (max-width:680px){
  .table-wrap{overflow-x:visible}
  table.tbl{font-size:13px}
  table.tbl,table.tbl tbody{display:block;width:100%}
  table.tbl thead{position:absolute;width:1px;height:1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap}
  table.tbl tbody tr{display:block;border:1px solid var(--line);border-radius:14px;padding:10px 12px;margin-bottom:10px;box-shadow:var(--shadow)}
  table.tbl tbody tr:hover td{background:transparent}
  table.tbl td{display:flex;justify-content:space-between;align-items:center;gap:12px;border:0;padding:6px 0;text-align:right}
  table.tbl td.num{text-align:right}
  table.tbl td:not(:last-child){border-bottom:1px dashed var(--line-soft)}
  /* ป้ายกำกับคอลัมน์ (กำหนด data-label ในเซลล์เพื่อให้แสดงชื่อหัวข้อ) */
  table.tbl td[data-label]::before{content:attr(data-label);font-size:11px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.03em;text-align:left;flex:0 0 auto}
  /* เซลล์หลัก (คอลัมน์แรก) ให้เด่นเต็มแถว */
  table.tbl td.cell-main{justify-content:flex-start;text-align:left;font-weight:600;border-bottom:1px solid var(--line-soft);padding-bottom:8px;margin-bottom:2px}
  table.tbl td.cell-main::before{display:none}
  /* แถวเมนูจัดการ (≡) ชิดขวา */
  table.tbl td .rowmenu{margin-left:auto}
  table.tbl tfoot{display:block}
  table.tbl tfoot tr{display:flex;justify-content:space-between;padding:8px 2px}
  table.tbl tfoot th{border:0;padding:0}
}

/* ============================================================
   ธีมแสดงผล (รายบุคคล): โหมดสว่าง/มืด · สกิน · รูปแบบ Sidebar
   ค่าจาก users.ui_theme_mode / ui_skin / ui_sidebar → body[data-*]
   ============================================================ */

/* ---------- DARK MODE ---------- */
[data-theme="dark"]{
  --bg:#0e1320; --panel:#161d2e; --sidebar:#141a29; --topbar-bg:#141a29;
  --ink:#e9eef8; --ink-2:#c6cfe1; --muted:#94a1b8; --light:#6b7689;
  --line:#293349; --line-soft:#212a3c;
  --brand-soft:rgba(125,160,255,.16);
  --green-bg:rgba(22,163,74,.20); --amber-bg:rgba(217,119,6,.22); --red-bg:rgba(220,38,38,.20);
  --blue-bg:rgba(37,99,235,.24); --gray-bg:#1c2435; --slate-bg:#1c2435;
  --shadow:0 10px 26px rgba(0,0,0,.50); --shadow-soft:0 6px 18px rgba(0,0,0,.42);
}
/* พื้นผิวที่ฮาร์ดโค้ดสีขาวใน app.css → ใช้พื้นผิวมืด */
[data-theme="dark"] .hamburger,
[data-theme="dark"] .search-form input,
[data-theme="dark"] .dd-menu,
[data-theme="dark"] .btn.ghost,
[data-theme="dark"] .data-modal-head,
[data-theme="dark"] .rowmenu-btn,
[data-theme="dark"] .rowmenu-pop,
[data-theme="dark"] .acc-chip,
[data-theme="dark"] .s2-add,
[data-theme="dark"] .field input,
[data-theme="dark"] .field select,
[data-theme="dark"] .field textarea,
[data-theme="dark"] .proj-search,
[data-theme="dark"] .auth-card,
[data-theme="dark"] .chat,
[data-theme="dark"] .chat .msg.them,
[data-theme="dark"] .fab-item .lbl,
[data-theme="dark"] .fab-item .ic,
[data-theme="dark"] .toast{ background:var(--panel); color:var(--ink); }
[data-theme="dark"] .tray-head{ background:var(--panel); }
[data-theme="dark"] .tray-foot,
[data-theme="dark"] .chat .msgs{ background:#10151f; }
[data-theme="dark"] table.tbl tbody tr:hover td{ background:rgba(255,255,255,.04); }
[data-theme="dark"] .s2-add,
[data-theme="dark"] .fab-item .ic{ color:var(--brand); }
/* โมดอล/อินพุตในหน้าต่างๆ (page-level) — override ด้วย specificity ที่สูงกว่า */
[data-theme="dark"] .p-modal,
[data-theme="dark"] .sa-modal,
[data-theme="dark"] .ci-modal,
[data-theme="dark"] .data-modal,
[data-theme="dark"] .p-modal-head,
[data-theme="dark"] .p-modal-foot,
[data-theme="dark"] .mf-box,
[data-theme="dark"] .sa-input,
[data-theme="dark"] .sa-select,
[data-theme="dark"] .sa-textarea,
[data-theme="dark"] .p-logo-prev,
[data-theme="dark"] .p-file{ background:var(--panel); color:var(--ink); border-color:var(--line); }
[data-theme="dark"] .eform-paper{ background:#fff; color:#1f2937; } /* เอกสาร A4 คงพื้นขาวเพื่อการพิมพ์ */

/* ---------- SKIN: Glassmorphism ---------- */
[data-skin="glass"]{ --glass-bg:rgba(255,255,255,.55); --glass-line:rgba(255,255,255,.6); --glass-blur:blur(13px); }
[data-skin="glass"][data-theme="dark"]{ --glass-bg:rgba(38,46,74,.5); --glass-line:rgba(255,255,255,.14); }
[data-skin="glass"] body{ background:linear-gradient(135deg,#a8c0ff 0%,#d9a7ff 50%,#ffd1a8 100%); background-attachment:fixed; }
[data-skin="glass"][data-theme="dark"] body{ background:linear-gradient(135deg,#1e2a55 0%,#3b1f5e 55%,#52294a 100%); background-attachment:fixed; }
[data-skin="glass"] .sidebar,
[data-skin="glass"] .topbar,
[data-skin="glass"] .card,
[data-skin="glass"] .kpi,
[data-skin="glass"] .dd-menu,
[data-skin="glass"] .p-modal,
[data-skin="glass"] .sa-modal,
[data-skin="glass"] .ci-modal{
  background:var(--glass-bg)!important; backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur);
  border:1px solid var(--glass-line);
}
[data-skin="glass"] .content,[data-skin="glass"] .main{ background:transparent; }
@media(max-width:680px){ [data-skin="glass"] .sidebar,[data-skin="glass"] .topbar,[data-skin="glass"] .card,[data-skin="glass"] .kpi{ backdrop-filter:blur(7px);-webkit-backdrop-filter:blur(7px); } }

/* ---------- SKIN: Soft UI / Neumorphism ---------- */
[data-skin="soft"]{ --bg:#eef1f7; --panel:#eef1f7; --sidebar:#eef1f7; --topbar-bg:#eef1f7; --line:#e0e5ef; --line-soft:#e6eaf2;
  --soft-d:rgba(174,182,201,.65); --soft-l:#ffffff; }
[data-skin="soft"][data-theme="dark"]{ --bg:#11161f; --panel:#11161f; --sidebar:#11161f; --topbar-bg:#11161f; --line:#1e2633; --line-soft:#1a212c;
  --soft-d:rgba(0,0,0,.55); --soft-l:rgba(48,58,78,.45); }
[data-skin="soft"] .card,
[data-skin="soft"] .kpi,
[data-skin="soft"] .p-modal,
[data-skin="soft"] .sa-modal,
[data-skin="soft"] .ci-modal{
  background:var(--panel); border:0!important;
  box-shadow:6px 6px 14px var(--soft-d), -6px -6px 14px var(--soft-l);
}
[data-skin="soft"] .field input,
[data-skin="soft"] .field select,
[data-skin="soft"] .field textarea{ border:0; background:var(--panel); box-shadow:inset 3px 3px 7px var(--soft-d), inset -3px -3px 7px var(--soft-l); }
[data-skin="soft"] .sidebar{ border-right:0; }
[data-skin="soft"] .topbar{ border-bottom:0; box-shadow:0 4px 14px var(--soft-d); }

/* ---------- SIDEBAR LAYOUT ---------- */
/* flush = ค่าเริ่มต้น (ไม่ต้องทำอะไร) */
[data-sidebar="float"] .sidebar{
  margin:12px 0 12px 12px; height:calc(100vh - 24px); border-radius:18px;
  border:1px solid var(--line); box-shadow:var(--shadow); overflow:hidden;
}
[data-sidebar="float"] .sidebar .brand{ border-radius:18px 18px 0 0; flex:0 0 auto; }
/* แก้บั๊ก: การ์ดลอยตัด overflow ทำให้เมนูเลื่อนไม่ได้ → ให้ .nav เลื่อนแทน (brand ค้างบน) */
[data-sidebar="float"] .nav{ overflow-y:auto; min-height:0; }
@media(max-width:680px){ [data-sidebar="float"] .sidebar{ margin:0; height:100vh; border-radius:0; } }
/* collapsed = ตั้ง sb-collapsed ที่ .app ฝั่งเซิร์ฟเวอร์แล้ว (ใช้ CSS ย่อเดิม) */

/* ---------- SweetAlert2 — สไตล์ Soft Minimal (ทั้งเว็บ) ---------- */
.swal2-popup{ background:var(--panel)!important; color:var(--ink)!important; border-radius:20px!important; box-shadow:0 30px 80px rgba(15,23,42,.32)!important; padding:26px 24px 22px!important; }
.swal2-title{ color:var(--ink)!important; font-size:19px!important; font-weight:700!important; padding:2px 8px 0!important; }
.swal2-html-container,.swal2-content{ color:var(--ink-2)!important; font-size:14px!important; line-height:1.6!important; margin:4px 4px 0!important; }
.swal2-close{ color:var(--muted)!important; }
.swal2-close:hover{ color:var(--red)!important; }
/* ไอคอน: วงกลมสีอ่อนตามประเภท + เครื่องหมายสีเข้ม */
.swal2-icon{ width:64px!important; height:64px!important; border:0!important; margin:6px auto 14px!important; position:relative; }
.swal2-icon .swal2-icon-content{ font-size:36px!important; font-weight:700!important; }
.swal2-icon.swal2-success{ background:var(--green-bg)!important; }
.swal2-icon.swal2-success .swal2-success-ring{ border-color:transparent!important; }
.swal2-icon.swal2-success [class^=swal2-success-line]{ background-color:#15803d!important; }
.swal2-icon.swal2-error{ background:var(--red-bg)!important; color:#b91c1c!important; }
.swal2-icon.swal2-error [class^=swal2-x-mark-line]{ background-color:#dc2626!important; }
.swal2-icon.swal2-warning{ background:var(--amber-bg)!important; border-color:transparent!important; color:#d97706!important; }
.swal2-icon.swal2-info{ background:var(--blue-bg)!important; border-color:transparent!important; color:#185fa5!important; }
.swal2-icon.swal2-question{ background:var(--brand-soft)!important; border-color:transparent!important; color:var(--brand)!important; }
/* ปุ่ม: มุมโค้ง มินิมอล (คงสีปุ่มยืนยันตามที่ส่งมา ไม่ override bg) */
.swal2-actions{ gap:10px!important; margin-top:18px!important; }
.swal2-styled{ border-radius:11px!important; font-size:14px!important; font-weight:600!important; padding:10px 22px!important; box-shadow:none!important; margin:0!important; transition:.15s; }
.swal2-styled.swal2-cancel{ background:var(--gray-bg,#f1f5f9)!important; color:var(--ink-2)!important; }
.swal2-styled:hover{ filter:brightness(.97); }
.swal2-styled:focus{ box-shadow:0 0 0 3px var(--brand-soft)!important; }
.swal2-timer-progress-bar{ background:var(--brand-soft)!important; }
.swal2-footer{ border-top-color:var(--line-soft)!important; color:var(--muted)!important; }
/* ช่องกรอกใน SweetAlert — ทันสมัย มินิมอล */
.swal2-input,.swal2-textarea,.swal2-select,.swal2-file{ background:var(--bg)!important; color:var(--ink)!important; border:1.5px solid var(--line)!important; border-radius:12px!important; box-shadow:none!important; font-size:14px!important; transition:.15s; }
.swal2-textarea{ min-height:110px!important; padding:11px 13px!important; }
.swal2-input{ height:44px!important; padding:0 13px!important; }
.swal2-input:focus,.swal2-textarea:focus,.swal2-select:focus{ border-color:var(--brand)!important; box-shadow:0 0 0 3px var(--brand-soft)!important; outline:none!important; }
.swal2-input::placeholder,.swal2-textarea::placeholder{ color:var(--light)!important; }
.swal2-input-label,.swal2-label{ color:var(--ink-2)!important; font-size:13px!important; }
.swal2-validation-message{ background:var(--bg)!important; color:var(--ink-2)!important; border-radius:10px!important; }
/* Glass / Soft ให้ popup เข้ากับสกิน */
[data-skin="glass"] .swal2-popup{ background:var(--glass-bg)!important; backdrop-filter:var(--glass-blur); -webkit-backdrop-filter:var(--glass-blur); border:1px solid var(--glass-line)!important; }
[data-skin="soft"] .swal2-popup{ box-shadow:6px 6px 16px var(--soft-d), -6px -6px 16px var(--soft-l)!important; }

/* ============================================================
   Select2 (มาตรฐานกลาง) — ผูกธีม + thumbnail ในตัวเลือก
   ใช้กับทุก <select class="s2"> · option ใส่ data-img / data-photo เพื่อโชว์รูป
   ============================================================ */
.s2opt{display:flex;align-items:center;gap:8px;min-width:0}
.s2info{display:flex;align-items:center;gap:8px;min-width:0;overflow:hidden}
.s2info>span{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.s2opt small{color:var(--muted)}
.s2tree{color:var(--muted)}
.s2tree-parent{font-weight:500}
.s2tree-child{color:var(--ink-2)}
.s2-caret{display:inline-block;width:16px;text-align:center;color:var(--muted);font-weight:700;font-size:13px;cursor:pointer;transition:transform .15s;border-radius:4px;vertical-align:middle}
.s2-caret:hover{background:var(--brand-soft);color:var(--brand)}
.s2-caret.open{transform:rotate(90deg)}
.s2-caret.empty{visibility:hidden;cursor:default}
.s2av{width:26px;height:26px;border-radius:50%;background:var(--brand-soft);color:var(--brand);font-size:11px;font-weight:700;display:grid;place-items:center;flex:0 0 26px;overflow:hidden;border:1px solid var(--line-soft)}
.s2av img{width:100%;height:100%;object-fit:cover;display:block}
.s2av.sm{width:20px;height:20px;flex:0 0 20px;font-size:10px}
.s2av.lg{width:38px;height:38px;flex:0 0 38px;font-size:15px}
.s2person{align-items:center;gap:10px;justify-content:flex-start}
/* การ์ดบุคคล (2 บรรทัด) ชิดซ้ายเสมอ — กัน rule space-between ของ .s2opt ในผลลัพธ์ */
.select2-results__option .s2opt.s2person{justify-content:flex-start}
.s2info.col{display:flex;flex-direction:column;align-items:flex-start;gap:1px;min-width:0;text-align:left}
.s2person .s2info.col{flex:1 1 auto}
.s2top{font-size:11px;color:var(--muted);line-height:1.2}
.s2name{font-weight:600;color:var(--ink);line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}
.s2name small{font-weight:400;color:var(--muted)}
.s2sub{font-size:11px;color:var(--muted);line-height:1.25;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}
.select2-results__option .s2person{padding:2px 0}
/* กล่อง select2 ให้เข้ากับ input ของระบบ */
.select2-container{z-index:2147483646}
.select2-container--default .select2-selection--single{
  height:auto!important;min-height:42px;border:1px solid var(--line)!important;border-radius:10px!important;
  background:var(--panel)!important;padding:4px 6px;display:flex;align-items:center
}
.select2-container--default .select2-selection--single .select2-selection__rendered{color:var(--ink)!important;line-height:1.5!important;padding-left:4px}
.select2-container--default .select2-selection--single .select2-selection__arrow{height:40px!important}
.select2-container--default .select2-selection--single .select2-selection__placeholder{color:var(--light)!important}
.select2-container--default.select2-container--focus .select2-selection--single,
.select2-container--default.select2-container--open .select2-selection--single{border-color:var(--brand)!important;box-shadow:0 0 0 3px var(--brand-soft)!important}
.select2-dropdown{background:var(--panel)!important;border:1px solid var(--line)!important;border-radius:10px!important;box-shadow:var(--shadow)!important;overflow:hidden}
.select2-search--dropdown .select2-search__field{background:var(--bg)!important;color:var(--ink)!important;border:1px solid var(--line)!important;border-radius:8px!important;padding:7px 9px}
.select2-results__option{color:var(--ink-2)!important;padding:7px 10px}
.select2-results>.select2-results__options{max-height:500px!important}
.select2-container--default .select2-results__option--highlighted[aria-selected]{background:var(--brand)!important;color:#fff!important}
.select2-container--default .select2-results__option--highlighted .s2opt small,
.select2-container--default .select2-results__option--highlighted .s2av{color:#fff!important}
.select2-container--default .select2-results__option[aria-selected=true]{background:var(--brand-soft)!important;color:var(--ink)!important}
.select2-container--default .select2-selection--multiple{border:1px solid var(--line)!important;border-radius:10px!important;background:var(--panel)!important;min-height:42px}
.select2-container--default .select2-selection--multiple .select2-selection__choice{display:inline-flex;align-items:center;border-radius:14px;background:var(--brand-soft)!important;border-color:var(--brand-soft)!important;color:var(--ink)!important}
/* dark mode: ปุ่ม clear/arrow มองเห็น */
[data-theme="dark"] .select2-selection__clear{color:var(--muted)!important}
