/* SO! HR — Sociology CI, light theme */
:root{
  --bg:#F6F4EC;          /* light cream */
  --panel:#FFFFFF;
  --ink:#16130F;
  --muted:#6E6A60;
  --line:#E7E3D6;
  --blue:#2F5BFF;
  --blue-soft:#EAF0FF;
  --orange:#FF6A2B;
  --orange-soft:#FFEEE4;
  --green:#1E9E6A;
  --green-soft:#E6F6EE;
  --red:#E0483B;
  --red-soft:#FCEBE9;
  --amber:#E0A21B;
  --amber-soft:#FCF3DD;
  --radius:16px;
  --shadow:0 1px 2px rgba(20,19,15,.04),0 8px 28px rgba(20,19,15,.05);
}
*{box-sizing:border-box}
body{
  margin:0;background:var(--bg);color:var(--ink);
  font-family:"Poppins","IBM Plex Sans Thai","Anuphan",system-ui,sans-serif;
  font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased;
}
.num,.stat-val,td.num{font-variant-numeric:tabular-nums}
h1,h2,h3,.brand-name,.kpi{font-family:"Poppins","IBM Plex Sans Thai",sans-serif}
a{color:var(--blue);text-decoration:none}
.shell{display:flex;min-height:100vh}

/* sidebar */
.side{width:248px;flex:0 0 248px;background:var(--panel);border-right:1px solid var(--line);
  position:fixed;top:0;bottom:0;left:0;display:flex;flex-direction:column;padding:18px 14px}
.brand{display:flex;align-items:center;gap:10px;padding:6px 8px 18px}
.brand .logo{width:38px;height:38px;border-radius:11px;background:var(--ink);color:#fff;
  display:grid;place-items:center;font-weight:700;font-family:"Poppins";font-size:18px}
.brand-name{font-weight:700;font-size:17px;letter-spacing:-.3px}
.brand-sub{font-size:11px;color:var(--muted);letter-spacing:.12em;text-transform:uppercase}
.nav{flex:1;min-height:0;overflow-y:auto;overscroll-behavior:contain;margin:0 -4px;padding:0 4px}
.nav::-webkit-scrollbar{width:6px}
.nav::-webkit-scrollbar-thumb{background:var(--line);border-radius:10px}
.nav-group{font-size:10.5px;letter-spacing:.1em;color:var(--muted);
  padding:15px 10px 6px;font-weight:700;position:sticky;top:0;background:var(--panel);z-index:1}
.nav-group:first-child{padding-top:4px}
.nav a{display:flex;align-items:center;gap:10px;padding:8px 11px;border-radius:10px;
  color:var(--ink);font-size:13.5px;margin-bottom:1px;position:relative}
.nav a:hover{background:var(--bg)}
.nav a.active{background:var(--blue-soft);color:var(--blue);font-weight:600}
.nav a.active::before{content:"";position:absolute;left:-4px;top:8px;bottom:8px;width:3px;border-radius:3px;background:var(--blue)}
.nav a .ico{width:18px;text-align:center;opacity:.9;flex:0 0 auto}
.nav a .badge{margin-left:auto;background:var(--orange);color:#fff;border-radius:20px;
  font-size:11px;padding:1px 7px;font-weight:600}
.side-foot{margin-top:auto;padding:12px 10px;border-top:1px solid var(--line);font-size:12px;color:var(--muted)}
.side-foot .who{color:var(--ink);font-weight:600;font-size:13px}

/* main */
.main{margin-left:248px;flex:1;padding:26px 34px 90px;max-width:1180px}
.topbar{display:flex;align-items:center;gap:14px;margin-bottom:22px}
.topbar h1{font-size:24px;margin:0;letter-spacing:-.5px}
.topbar .crumb{font-size:13px;color:var(--muted)}
.pill{margin-left:auto;display:inline-flex;align-items:center;gap:7px;background:var(--green-soft);
  color:var(--green);font-size:12px;font-weight:600;padding:6px 12px;border-radius:30px}
.pill .dot{width:7px;height:7px;border-radius:50%;background:var(--green)}
.role-tag{background:var(--orange-soft);color:var(--orange);font-size:11px;font-weight:700;
  padding:3px 9px;border-radius:30px;text-transform:uppercase;letter-spacing:.08em}

/* cards & grid */
.grid{display:grid;gap:16px}
.g4{grid-template-columns:repeat(4,1fr)}
.g3{grid-template-columns:repeat(3,1fr)}
.g2{grid-template-columns:repeat(2,1fr)}
.card{background:var(--panel);border:1px solid var(--line);border-radius:var(--radius);
  padding:20px;box-shadow:var(--shadow)}
.card h3{margin:0 0 14px;font-size:15px;letter-spacing:-.2px}
.card .sub{font-size:12.5px;color:var(--muted);margin:-8px 0 16px}

/* stat */
.stat{display:flex;flex-direction:column;gap:6px}
.stat .label{font-size:12px;color:var(--muted);letter-spacing:.02em}
.stat .stat-val{font-size:30px;font-weight:700;letter-spacing:-1px;line-height:1;font-family:"Poppins"}
.stat .unit{font-size:13px;color:var(--muted);font-weight:500}
.accent-blue{border-top:3px solid var(--blue)}
.accent-orange{border-top:3px solid var(--orange)}
.accent-green{border-top:3px solid var(--green)}
.accent-amber{border-top:3px solid var(--amber)}

/* leave balance bars */
.bal{display:flex;flex-direction:column;gap:14px}
.bal-row .bhead{display:flex;justify-content:space-between;font-size:13.5px;margin-bottom:6px}
.bal-row .bhead b{font-family:"Poppins"}
.track{height:9px;background:var(--bg);border-radius:20px;overflow:hidden}
.track>span{display:block;height:100%;border-radius:20px;background:var(--blue)}
.bal-row.a .track>span{background:var(--blue)}
.bal-row.p .track>span{background:var(--orange)}
.bal-row.s .track>span{background:var(--green)}

/* table */
table{width:100%;border-collapse:collapse;font-size:13.5px}
th{text-align:left;font-size:11.5px;letter-spacing:.06em;text-transform:uppercase;color:var(--muted);
  font-weight:600;padding:10px 12px;border-bottom:1px solid var(--line)}
td{padding:11px 12px;border-bottom:1px solid var(--line)}
tr:last-child td{border-bottom:0}
tbody tr:hover{background:var(--bg)}
td.num,th.num{text-align:right}

/* status chips */
.chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;
  padding:3px 10px;border-radius:30px}
.chip.pending{background:var(--amber-soft);color:var(--amber)}
.chip.approved{background:var(--green-soft);color:var(--green)}
.chip.rejected{background:var(--red-soft);color:var(--red)}
.chip.annual{background:var(--blue-soft);color:var(--blue)}
.chip.personal{background:var(--orange-soft);color:var(--orange)}
.chip.sick{background:var(--green-soft);color:var(--green)}

/* forms & buttons */
label.f{display:block;font-size:13px;color:var(--muted);margin:0 0 6px;font-weight:500}
input,select,textarea{width:100%;padding:10px 12px;border:1px solid var(--line);border-radius:10px;
  font-family:inherit;font-size:14px;background:#fff;color:var(--ink)}
input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue);box-shadow:0 0 0 3px var(--blue-soft)}
.row{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}
.field{margin-bottom:14px}
.btn{display:inline-flex;align-items:center;gap:8px;background:var(--ink);color:#fff;border:0;
  padding:11px 18px;border-radius:11px;font-family:inherit;font-size:14px;font-weight:600;cursor:pointer}
.btn:hover{opacity:.9}
.btn.blue{background:var(--blue)}.btn.orange{background:var(--orange)}
.btn.green{background:var(--green)}.btn.ghost{background:#fff;color:var(--ink);border:1px solid var(--line)}
.btn.sm{padding:7px 13px;font-size:13px}
.btn.danger{background:var(--red)}
.inline-form{display:inline}

/* misc */
.kv{display:grid;grid-template-columns:170px 1fr;gap:10px 16px;font-size:14px}
.kv .k{color:var(--muted)}
.kv .v{font-weight:500}
.flash{padding:12px 16px;border-radius:11px;margin-bottom:18px;font-size:14px;font-weight:500}
.flash.ok{background:var(--green-soft);color:var(--green)}
.flash.error{background:var(--red-soft);color:var(--red)}
.empty{color:var(--muted);font-size:14px;padding:30px;text-align:center}
.section-title{font-size:13px;color:var(--muted);text-transform:uppercase;letter-spacing:.08em;
  font-weight:600;margin:30px 0 12px}
.avatar{width:54px;height:54px;border-radius:14px;background:var(--blue-soft);color:var(--blue);
  display:grid;place-items:center;font-weight:700;font-size:20px;font-family:"Poppins"}
.mt{margin-top:16px}.mb{margin-bottom:16px}
.flex{display:flex;align-items:center;gap:12px}
.spacer{flex:1}
/* hamburger + overlay (ซ่อนบนจอใหญ่) */
.hamb{display:none;background:var(--panel);border:1px solid var(--line);border-radius:10px;
  width:40px;height:40px;font-size:20px;cursor:pointer;color:var(--ink);flex:0 0 auto;line-height:1}
.side-overlay{display:none;position:fixed;inset:0;background:rgba(20,19,15,.45);z-index:65}
.side-overlay.show{display:block}
.topbar-head{min-width:0}

@media(max-width:920px){
  .side{transform:translateX(-100%);width:280px;z-index:70;transition:transform .25s ease;
    box-shadow:0 0 40px rgba(0,0,0,.18)}
  .side.open{transform:none}
  .main{margin-left:0;padding:16px 16px 88px}
  .hamb{display:flex;align-items:center;justify-content:center}
  .topbar{gap:10px}
  .topbar h1{font-size:20px}
  .topbar .pill{padding:5px 10px;font-size:11px}
  .g4,.g3,.g2{grid-template-columns:1fr 1fr}
  /* ตารางกว้างให้เลื่อนแนวนอนภายในการ์ด */
  .card{overflow-x:auto;-webkit-overflow-scrolling:touch}
  table{min-width:480px}
}
@media(max-width:560px){
  .g4,.g3,.g2{grid-template-columns:1fr}
  .topbar .role-tag{display:none}
  .main{padding:14px 12px 88px}
}

/* ===== org chart ===== */
.orgscroll{overflow-x:auto;padding:14px 4px 30px}
.orgchart{display:inline-block;min-width:100%}
.orgchart ul{display:flex;justify-content:center;padding-top:22px;position:relative;margin:0;list-style:none}
.orgchart li{position:relative;padding:22px 10px 0;display:flex;flex-direction:column;align-items:center}
/* connectors */
.orgchart li::before,.orgchart li::after{content:"";position:absolute;top:0;width:50%;height:22px;border-top:2px solid var(--line)}
.orgchart li::before{left:0;border-right:2px solid var(--line)}
.orgchart li::after{right:0}
.orgchart li:only-child::before,.orgchart li:only-child::after{display:none}
.orgchart li:first-child::before,.orgchart li:last-child::after{border:0}
.orgchart li:last-child::before{border-right:2px solid var(--line);border-radius:0 6px 0 0}
.orgchart li:first-child::after{border-radius:6px 0 0 0}
.orgchart ul ul::before{content:"";position:absolute;top:0;left:50%;height:22px;border-left:2px solid var(--line)}
.orgchart>ul>li::before,.orgchart>ul>li::after{display:none}
.orgchart>ul{padding-top:0}
/* node card */
.orgcard{background:#fff;border:1px solid var(--line);border-radius:14px;padding:12px 14px;
  box-shadow:var(--shadow);min-width:172px;text-align:center;position:relative;border-top:3px solid var(--blue)}
.orgcard.me{border-color:var(--orange);border-top-color:var(--orange);box-shadow:0 0 0 3px var(--orange-soft)}
.orgcard.boss{border-top-color:var(--ink)}
.orgcard .oav{width:42px;height:42px;border-radius:11px;background:var(--blue-soft);color:var(--blue);
  display:grid;place-items:center;font-weight:700;font-family:"Poppins";font-size:17px;margin:0 auto 8px}
.orgcard.me .oav{background:var(--orange-soft);color:var(--orange)}
.orgcard .onm{font-weight:700;font-size:14px;line-height:1.25}
.orgcard .opos{font-size:12px;color:var(--muted);margin-top:2px}
.orgcard .odept{display:inline-block;margin-top:8px;font-size:10.5px;font-weight:600;letter-spacing:.04em;
  padding:2px 9px;border-radius:30px;background:var(--bg);color:var(--muted)}
.orgcard .ohc{position:absolute;top:-9px;right:-9px;background:var(--ink);color:#fff;font-size:11px;
  font-weight:600;padding:2px 8px;border-radius:30px;font-family:"Poppins"}
.dept-grid .dept-col h4{margin:0 0 10px;font-size:14px;display:flex;align-items:center;gap:8px}
.dept-grid .dept-col h4 .cnt{margin-left:auto;font-size:12px;color:var(--muted);font-weight:500}
.dept-grid .pers{display:flex;align-items:center;gap:10px;padding:8px 0;border-bottom:1px solid var(--line);font-size:13.5px}
.dept-grid .pers:last-child{border-bottom:0}
.dept-grid .pers .mini{width:30px;height:30px;border-radius:9px;background:var(--blue-soft);color:var(--blue);
  display:grid;place-items:center;font-weight:700;font-size:13px;font-family:"Poppins"}
.dept-grid .pers .mgrtag{margin-left:auto;font-size:10.5px;color:var(--muted)}

/* ===== print documents ===== */
@media screen{ .doc-wrap{padding:30px;background:#cfcabc;min-height:100vh} }
.paper{background:#fff;max-width:760px;margin:0 auto;padding:64px 70px;box-shadow:0 6px 30px rgba(0,0,0,.18);
  font-family:"IBM Plex Sans Thai",serif;color:#1a1a1a;line-height:1.85}
.paper .lh{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--ink);
  padding-bottom:16px;margin-bottom:30px}
.paper .lh .co{font-family:"Poppins";font-weight:700;font-size:20px}
.paper .lh .co small{display:block;font-family:"IBM Plex Sans Thai";font-weight:400;font-size:12.5px;color:#555;margin-top:3px}
.paper h2{text-align:center;font-size:19px;margin:10px 0 26px;letter-spacing:.5px}
.paper .body p{margin:0 0 14px;text-indent:0}
.paper .sign{margin-top:60px;text-align:right}
.paper .sign .line{display:inline-block;border-top:1px dotted #888;width:240px;text-align:center;padding-top:8px;font-size:14px}
.docbar{position:fixed;top:16px;right:24px;display:flex;gap:10px;z-index:10}
.slip table{font-size:14px}
.slip td{border:0;padding:7px 0}
.slip .tot{border-top:2px solid var(--ink);font-weight:700;font-size:16px}
@media print{ .docbar{display:none} .doc-wrap{padding:0;background:#fff} .paper{box-shadow:none;margin:0;max-width:100%} }

/* ===== เหรียญตรา / Badge (ใช้ร่วมกันหลายหน้า) ===== */
.medals{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:10px}
.medal{display:flex;gap:11px;align-items:flex-start;border:1px solid var(--line);
  border-radius:13px;padding:11px 12px;background:var(--panel);position:relative;overflow:hidden}
.medal::before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px}
.medal .m-ico{font-size:24px;line-height:1;flex:none}
.medal .m-name{font-weight:700;font-size:13.5px;line-height:1.2}
.medal .m-desc{font-size:11px;color:var(--muted);margin-top:3px;line-height:1.3}
.medal.bronze::before{background:#C58A4B}
.medal.silver::before{background:#9AA3AD}
.medal.gold::before{background:var(--amber)}
.medal.legend::before{background:linear-gradient(180deg,#7C3AED,#E0A21B)}
.medal.gold{background:linear-gradient(135deg,var(--amber-soft),var(--panel))}
.medal.legend{background:linear-gradient(135deg,#F3ECFF,var(--panel))}
.medal .m-auto{font-size:9.5px;font-weight:700;color:var(--muted);
  background:var(--bg);border-radius:20px;padding:1px 7px;margin-left:auto;flex:none}

/* ===== leaderboard + feed (recognition + vote) ===== */
.lead{display:flex;flex-direction:column;gap:8px}
.lrow{display:flex;align-items:center;gap:14px;padding:11px 14px;border:1px solid var(--line);border-radius:12px}
.lrow.champ{background:linear-gradient(135deg,var(--amber-soft),#fff);border-color:var(--amber)}
.lrow .rank{font-size:20px;width:30px;text-align:center;font-weight:700;font-family:"Poppins"}
.lrow .linfo{flex:1;min-width:0}
.lrow .lname{font-weight:600}
.champ-tag{background:var(--amber);color:#fff;font-size:10.5px;font-weight:700;padding:2px 9px;border-radius:20px;margin-left:6px}
.lrow .ldept{font-size:12px;color:var(--muted)}
.lrow .lstars{font-weight:700;font-family:"Poppins";color:var(--amber);font-size:17px}
.kfeed{display:flex;flex-direction:column;gap:8px}
.kf{font-size:13px;background:var(--bg);border-radius:10px;padding:9px 12px}
.kmsg{color:var(--muted);font-size:12.5px;margin-top:3px;font-style:italic}
