:root:root{--bs-primary:#7c3aed;--bs-primary-rgb:124,58,237;--bs-link-color:#7c3aed;--bs-link-color-rgb:124,58,237;--bs-link-hover-color:#6d28d9;--bs-body-bg:#f5f2fc;--bs-body-color:#2c2342;--bs-body-font-family:"Sarabun","Segoe UI",system-ui,-apple-system,sans-serif;--sidebar-w:250px;--grad:linear-gradient(135deg,#7c3aed,#a855f7);--grad-hover:linear-gradient(135deg,#6d28d9,#9333ea);--violet-soft:#f3eefe;--violet-border:#ebe4fb;--shadow-violet:0 8px 24px rgba(124,58,237,0.14)}body{font-family:var(--bs-body-font-family);background:radial-gradient(1200px 600px at 100% -10%,#efe7fd 0,transparent 55%),radial-gradient(900px 500px at -10% 110%,#ece4fc 0,transparent 50%),var(--bs-body-bg);background-attachment:fixed}.btn{transition:transform .16s ease,box-shadow .16s ease,background-color .16s ease,background-image .16s ease;border-radius:9px;font-weight:600}.btn:active{transform:translateY(0)}.btn-primary{--bs-btn-bg:#7c3aed;--bs-btn-border-color:#7c3aed;--bs-btn-hover-bg:#6d28d9;--bs-btn-hover-border-color:#6d28d9;--bs-btn-active-bg:#5b21b6;background-image:var(--grad);border:none;box-shadow:0 4px 12px rgba(124,58,237,.28)}.btn-primary:hover{background-image:var(--grad-hover);transform:translateY(-1px);box-shadow:0 7px 18px rgba(124,58,237,.38)}.btn-outline-primary{--bs-btn-color:#7c3aed;--bs-btn-border-color:#c9b6f5;--bs-btn-hover-bg:#7c3aed;--bs-btn-hover-border-color:#7c3aed}.btn-outline-danger:hover,.btn-outline-secondary:hover,.btn-success:hover{transform:translateY(-1px)}.app-shell{display:flex;min-height:100dvh}.app-sidebar{width:var(--sidebar-w);flex-shrink:0;background:#fff;border-right:1px solid var(--violet-border);display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100dvh;box-shadow:2px 0 18px rgba(80,40,140,.04)}.app-sidebar .brand{padding:20px 18px;background:var(--grad);color:#fff}.app-sidebar .brand .fw-bold,.app-sidebar .brand .small,.app-sidebar .brand .text-primary{color:#fff!important}.app-sidebar .brand .small{opacity:.85}.app-sidebar .nav-link{display:flex;align-items:center;gap:11px;color:#4a3a6b;font-weight:500;border-radius:10px;padding:10px 12px;margin-bottom:3px;transition:background .18s ease,color .18s ease,transform .18s ease}.app-sidebar .nav-link:hover{background:var(--violet-soft);color:#6d28d9;transform:translateX(3px)}.app-sidebar .nav-link.active{background:var(--grad);color:#fff;box-shadow:0 5px 14px rgba(124,58,237,.32)}.app-sidebar .nav-link.active i{color:#fff}.app-sidebar .nav-link i{font-size:1.1rem}.app-sidebar .group-label{font-size:.7rem;font-weight:700;text-transform:uppercase;letter-spacing:.04em;color:#a99cc4;padding:14px 12px 4px}.app-main{flex:1 1;min-width:0}.app-content{max-width:1080px;margin:0 auto;padding:28px 26px 64px;animation:fadeInUp .4s ease both}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:none}}@media (max-width:860px){.app-shell{flex-direction:column}.app-sidebar{position:static;width:100%;height:auto}.app-sidebar .sidebar-nav{display:flex;flex-wrap:wrap;gap:4px}.app-sidebar .group-label{width:100%}.app-content{padding:18px 14px 48px}}.card{border:1px solid var(--violet-border);border-radius:14px;box-shadow:0 2px 10px rgba(80,40,140,.06)}.card-header{background:linear-gradient(180deg,#faf8ff,#f5f0fe);border-bottom:1px solid var(--violet-border);font-weight:600;color:#4a3a6b}.lift{transition:transform .2s ease,box-shadow .2s ease}.lift:hover{transform:translateY(-4px);box-shadow:var(--shadow-violet)}.icon-chip{display:inline-flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--grad);color:#fff;font-size:1.25rem;box-shadow:0 6px 14px rgba(124,58,237,.3)}.table{--bs-table-hover-bg:#f6f1fe}.table>:not(caption)>*>*{padding:.6rem .8rem}.table-light,.table>thead.table-light th{--bs-table-bg:#f3edfe;--bs-table-color:#5b21b6;border-color:var(--violet-border)}.form-label{font-weight:600;font-size:.9rem;margin-bottom:.3rem;color:#4a3a6b}.form-control:focus,.form-select:focus{border-color:#b794f4;box-shadow:0 0 0 .2rem rgba(124,58,237,.18)}.badge{font-weight:600;padding:.4em .65em;border-radius:7px;letter-spacing:.01em}.modal-content{border:none;border-radius:16px;overflow:hidden;box-shadow:0 24px 60px rgba(60,30,110,.28)}.modal-header{background:var(--grad);color:#fff;border-bottom:none}.modal-header .modal-title{color:#fff;font-weight:700}.modal-header .btn-close{filter:invert(1) grayscale(1) brightness(2)}h1{font-size:1.6rem;font-weight:700;color:#3a2766}@media (prefers-reduced-motion:reduce){*,.app-content,.app-sidebar .nav-link,.btn,.lift{animation:none!important;transition:none!important}}.print-doc{background:#fff;color:#000;max-width:1100px;margin:0 auto;padding:16px;font-size:13px}.print-doc .doc-title{text-align:center;font-weight:700;font-size:16px;margin-bottom:6px}.print-doc .doc-sub{display:flex;justify-content:space-around;margin-bottom:8px;font-weight:600}.print-doc table.form{width:100%;border-collapse:collapse;table-layout:fixed}.print-doc table.form td,.print-doc table.form th{border:1px solid #000;padding:3px 5px;vertical-align:top;font-size:12px;word-wrap:break-word}.print-doc table.form th{text-align:center;font-weight:700;background:#fff}.print-doc .day-cell{text-align:center;font-weight:700;writing-mode:vertical-rl;transform:rotate(180deg);white-space:nowrap;width:26px}.print-doc .num{text-align:center}.print-doc table.form td.count-col,.print-doc table.form th.count-col{padding:3px 2px;text-align:center;white-space:nowrap}.print-doc .sign-area{margin-top:18px}.print-doc .sign-row{display:flex;justify-content:space-between;gap:8px;text-align:center;margin-top:26px}.print-doc .sign-row>div{flex:1 1}.print-doc .cert-line{margin-top:10px}@media print{@page{size:A4 landscape;margin:8mm}body{background:#fff}.no-print{display:none!important}.print-doc{max-width:none;padding:0}}