@import "https://fonts.googleapis.com/css2?family=Kanit:wght@300;400;500;600;700&family=Inter:wght@400;500;600;700&display=swap";:root{--color-bg:#faf8f3;--color-surface:#fff;--color-border:#e8e2d6;--color-text-main:#2b2722;--color-text-sub:#6b6358;--color-accent:#c2410c;--color-accent-soft:#fdeee7;--color-success:#4d7c4d;--color-success-soft:#edf7ed;--color-warning:#b8860b;--color-warning-soft:#fdf7e7;--color-danger:#a13d3d;--color-danger-soft:#fdf2f2;--color-info-soft:#f0f7ff;--color-info-text:#1d4ed8;--space-xs:8px;--space-sm:16px;--space-md:24px;--space-lg:32px;--radius:12px;--shadow-rest:0 1px 3px #2b27220d, 0 1px 2px #2b27220d;--shadow-hover:0 4px 12px #2b272214, 0 2px 4px #2b27220a;--font-display:"Kanit", sans-serif;--font-body:"Kanit", sans-serif}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--color-bg);color:var(--color-text-main);font-family:var(--font-body);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;line-height:1.6}h1,h2,h3,h4,h5,h6{font-family:var(--font-display);color:var(--color-text-main);font-weight:500}.app-container{min-height:100vh;display:flex}.sidebar{background-color:var(--color-surface);border-right:1px solid var(--color-border);width:260px;padding:var(--space-lg) var(--space-sm);z-index:10;flex-direction:column;height:100vh;display:flex;position:fixed;top:0;left:0}.sidebar-logo{align-items:center;gap:var(--space-xs);padding:0 var(--space-xs) var(--space-lg) var(--space-xs);border-bottom:1px solid var(--color-border);margin-bottom:var(--space-lg);display:flex}.sidebar-logo h2{color:var(--color-accent);font-size:1.25rem;font-weight:600}.sidebar-menu{gap:var(--space-xs);flex-direction:column;list-style:none;display:flex}.sidebar-item{align-items:center;gap:var(--space-sm);padding:12px var(--space-sm);border-radius:var(--radius);color:var(--color-text-sub);cursor:pointer;min-height:44px;font-weight:500;text-decoration:none;transition:all .15s;display:flex}.sidebar-item:hover{background-color:var(--color-bg);color:var(--color-text-main);border-color:var(--color-border)}.sidebar-item.active{background-color:var(--color-accent-soft);color:var(--color-accent)}.main-content{padding:var(--space-lg);flex:1;width:calc(100% - 260px);max-width:100%;margin-left:260px}.modal-overlay{-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:100;padding:var(--space-sm);background-color:#2b272266;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);width:100%;max-width:600px;animation:.2s modalFadeIn;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a}@keyframes modalFadeIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.modal-header{padding:var(--space-md) var(--space-md) var(--space-sm) var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.modal-header h3{font-size:1.25rem;font-weight:600}.modal-close-btn{color:var(--color-text-sub);cursor:pointer;background:0 0;border:none;border-radius:50%;justify-content:center;align-items:center;width:32px;height:32px;transition:all .15s;display:flex}.modal-close-btn:hover{background-color:var(--color-bg);color:var(--color-text-main)}.modal-body{padding:var(--space-md);max-height:70vh;overflow-y:auto}.modal-footer{padding:var(--space-sm) var(--space-md) var(--space-md) var(--space-md);border-top:1px solid var(--color-border);justify-content:flex-end;gap:var(--space-sm);display:flex}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-rest);margin-bottom:var(--space-md);padding:28px;transition:box-shadow .15s,border-color .15s}.card:hover{box-shadow:var(--shadow-hover);border-color:#c2410c33}.card-title{margin-bottom:var(--space-md);border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:center;padding-bottom:12px;font-size:1.15rem;font-weight:500;display:flex}.card-title-text{align-items:center;gap:var(--space-xs);display:flex}.form-group{margin-bottom:var(--space-sm);gap:var(--space-xs);flex-direction:column;display:flex}.form-group label{color:var(--color-text-main);font-size:.9rem;font-weight:500}.form-group label span{color:var(--color-accent)}.form-control{font-family:var(--font-body);border:1px solid var(--color-border);border-radius:var(--radius);background-color:var(--color-surface);color:var(--color-text-main);outline:none;width:100%;max-width:100%;min-height:44px;padding:10px 14px;font-size:.95rem;transition:border-color .15s,box-shadow .15s}select.form-control{text-overflow:ellipsis;white-space:nowrap;max-width:100%;overflow:hidden}.form-control:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px var(--color-accent-soft)}.form-control::placeholder{color:var(--color-text-sub)}.form-row{gap:var(--space-sm);grid-template-columns:1fr 1fr;display:grid}.switch-container{align-items:center;gap:var(--space-sm);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:44px;display:flex}.switch-input{display:none}.switch-track{background-color:var(--color-border);border-radius:12px;width:48px;height:24px;transition:background-color .15s;position:relative}.switch-thumb{background-color:#fff;border-radius:50%;width:18px;height:18px;transition:transform .15s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #0003}.switch-input:checked+.switch-track{background-color:var(--color-success)}.switch-input:checked+.switch-track .switch-thumb{transform:translate(24px)}.btn{font-family:var(--font-body);justify-content:center;align-items:center;gap:var(--space-xs);border-radius:var(--radius);cursor:pointer;-webkit-user-select:none;user-select:none;border:1px solid #0000;min-height:44px;padding:10px 20px;font-size:.95rem;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background-color:var(--color-accent);color:#fff}.btn-primary:hover{background-color:#a8380a}.btn-secondary{background-color:var(--color-surface);border-color:var(--color-border);color:var(--color-text-main)}.btn-secondary:hover{background-color:var(--color-bg);border-color:var(--color-border)}.btn-danger{background-color:var(--color-danger-soft);color:var(--color-danger);border-color:#a13d3d33}.btn-danger:hover{background-color:var(--color-danger);color:#fff}.btn-sm{border-radius:8px;min-height:32px;padding:6px 12px;font-size:.85rem}.badge{font-family:var(--font-body);white-space:nowrap;border-radius:9999px;justify-content:center;align-items:center;padding:4px 10px;font-size:.8rem;font-weight:600;display:inline-flex}.badge-primary{background-color:var(--color-accent-soft);color:var(--color-accent)}.badge-success{background-color:var(--color-success-soft);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-soft);color:var(--color-warning)}.badge-danger{background-color:var(--color-danger-soft);color:var(--color-danger)}.badge-info{background-color:var(--color-info-soft);color:var(--color-info-text)}.table-container{border:1px solid var(--color-border);border-radius:var(--radius);background-color:var(--color-surface);overflow-x:auto}.table{border-collapse:collapse;text-align:left;width:100%;font-size:.95rem}.table th{background-color:var(--color-bg);color:var(--color-text-main);padding:var(--space-sm);border-bottom:1px solid var(--color-border);white-space:nowrap;font-weight:600}.table td{padding:var(--space-sm);border-bottom:1px solid var(--color-border);color:var(--color-text-main)}.table tr:last-child td{border-bottom:none}.table tr:hover td{background-color:#faf8f380}.table tr.vacant-highlight td{background-color:var(--color-danger-soft)}.table tr.vacant-highlight:hover td{background-color:#fcebeb}.text-danger-bold{color:var(--color-danger);font-weight:700}.filter-row{gap:var(--space-sm);margin-bottom:var(--space-md);flex-wrap:wrap;align-items:center;display:flex}.search-input-wrapper{flex:1;min-width:250px;position:relative}.skeleton{background:linear-gradient(90deg,#f0eae1 25%,#e8e2d6 50%,#f0eae1 75%) 0 0/200% 100%;border-radius:8px;animation:1.5s infinite skeletonLoading}.skeleton-text{height:18px;margin-bottom:12px}.skeleton-title{width:40%;height:24px;margin-bottom:20px}.skeleton-card{height:180px;margin-bottom:var(--space-md)}@keyframes skeletonLoading{0%{background-position:200% 0}to{background-position:-200% 0}}.grid-cols-2{gap:var(--space-md);grid-template-columns:1fr 1fr;display:grid}.grid-cols-3{gap:var(--space-md);grid-template-columns:repeat(3,1fr);display:grid}.grid-cols-1-2{gap:var(--space-md);grid-template-columns:1fr 2fr;display:grid}.page-header{margin-bottom:var(--space-lg);padding-bottom:var(--space-sm);border-bottom:2px solid var(--color-border);justify-content:space-between;align-items:center;display:flex}.page-title h1{color:var(--color-text-main);font-size:1.75rem;font-weight:600}.page-title p{color:var(--color-text-sub);font-size:.95rem}.profile-grid{gap:var(--space-lg);grid-template-columns:1fr 2fr;display:grid}.profile-sidebar,.profile-main{gap:var(--space-md);flex-direction:column;display:flex}.info-list{gap:var(--space-sm);flex-direction:column;list-style:none;display:flex}.info-item{border-bottom:1px dashed var(--color-border);justify-content:space-between;padding-bottom:8px;display:flex}.info-item:last-child{border-bottom:none;padding-bottom:0}.info-label{color:var(--color-text-sub);font-size:.9rem}.info-value{color:var(--color-text-main);text-align:right;font-weight:500}.stat-card-grid{gap:var(--space-md);margin-bottom:var(--space-lg);grid-template-columns:repeat(3,1fr);display:grid}.stat-card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-rest);align-items:center;gap:var(--space-md);padding:24px;display:flex}.stat-icon{border-radius:var(--radius);background-color:var(--color-accent-soft);width:48px;height:48px;color:var(--color-accent);justify-content:center;align-items:center;display:flex}.stat-icon.vacant{background-color:var(--color-danger-soft);color:var(--color-danger)}.stat-icon.quota{background-color:var(--color-success-soft);color:var(--color-success)}.stat-info{flex-direction:column;display:flex}.stat-value{font-size:1.75rem;font-weight:600;line-height:1.2}.stat-label{color:var(--color-text-sub);font-size:.85rem}.recharts-custom-tooltip{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius);box-shadow:var(--shadow-hover);padding:12px;font-size:.85rem}.recharts-custom-tooltip-title{margin-bottom:4px;font-weight:600}@media (width<=1024px){.profile-grid{grid-template-columns:1fr}}@media (width<=768px){.sidebar{width:64px;padding:var(--space-md) var(--space-xs)}.sidebar-logo h2{display:none}.sidebar-logo{padding-bottom:var(--space-md);justify-content:center}.sidebar-item span{display:none}.sidebar-item{justify-content:center}.main-content{width:calc(100% - 64px);padding:var(--space-sm);margin-left:64px}.grid-cols-2,.grid-cols-3,.grid-cols-1-2,.stat-card-grid,.form-row{grid-template-columns:1fr}.table-responsive-cards thead{display:none}.table-responsive-cards tbody,.table-responsive-cards tr,.table-responsive-cards td{width:100%;display:block}.table-responsive-cards tr{margin-bottom:var(--space-sm);border:1px solid var(--color-border);border-radius:var(--radius);background-color:var(--color-surface);padding:var(--space-sm)}.table-responsive-cards td{text-align:right;border-bottom:1px dashed var(--color-border);padding:8px 0 8px 50%;position:relative}.table-responsive-cards td:last-child{border-bottom:none}.table-responsive-cards td:before{content:attr(data-label);text-align:left;width:45%;color:var(--color-text-sub);font-weight:600;position:absolute;left:0}}@media (prefers-reduced-motion:reduce){.card,.btn,.sidebar-item,.modal-content,.switch-track,.switch-thumb,.skeleton{transition:none!important;animation:none!important}}.org-tree-container{border-radius:var(--radius);border:1px dashed var(--color-border);background-color:#faf8f3;flex-direction:column;align-items:center;gap:24px;width:100%;margin-top:16px;padding:32px 16px;display:flex;overflow-x:auto}.org-tree-row{justify-content:center;gap:32px;width:100%;display:flex;position:relative}.org-tree-col{flex-direction:column;align-items:center;display:flex;position:relative}.org-line-vert{background-color:var(--color-border);width:2px}.org-line-horiz{background-color:var(--color-border);height:2px;position:absolute;top:-12px}.org-branches-row{justify-content:center;gap:40px;width:max-content;margin:0 auto;padding-top:16px;display:flex;position:relative}.org-branches-row:before{content:"";background-color:var(--color-border);width:2px;height:16px;position:absolute;top:0;left:50%;transform:translate(-50%)}.org-branch{flex-direction:column;align-items:center;padding-top:16px;display:flex;position:relative}.org-branch:before,.org-branch:after{content:"";background-color:var(--color-border);width:50%;height:2px;position:absolute;top:0}.org-branch:before{left:0}.org-branch:after{right:0}.org-branch:first-child:before,.org-branch:last-child:after,.org-branch:only-child:before,.org-branch:only-child:after{display:none}.org-branch-card-vert{background-color:var(--color-border);z-index:1;width:2px;height:16px;position:absolute;top:0;left:50%;transform:translate(-50%)}.org-tree-card{border-radius:var(--radius);background-color:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-rest);text-align:center;flex-direction:column;justify-content:center;align-items:center;gap:4px;min-width:240px;max-width:300px;min-height:86px;padding:16px 20px;transition:all .15s;display:flex;position:relative}.org-tree-card:not(.vacant-card){cursor:pointer}.org-tree-card:not(.vacant-card):hover{border-color:var(--color-accent);box-shadow:var(--shadow-hover);transform:translateY(-2px)}.org-tree-card.director{color:#fff;background-color:#00082f;border-color:#00082f}.org-tree-card.director h4,.org-tree-card.director p{color:#fff!important}.org-tree-card.deputy{color:#fff;background-color:#1e40af;border-color:#1e40af}.org-tree-card.deputy h4,.org-tree-card.deputy p{color:#fff!important}.org-tree-card.department{color:#1e3a8a;background-color:#dbeafe;border-color:#93c5fd;width:310px;min-height:100px;padding:16px}.org-tree-card.department h4{font-size:.95rem;font-weight:600;line-height:1.3;color:#1e3a8a!important}.org-tree-card.department p{font-size:.85rem;font-weight:500;color:#1d4ed8!important}.org-tree-card.vacant-card{background-color:#fef3c7;border-style:dashed;border-color:#f59e0b}.org-tree-card.vacant-card h4{color:#b45309}.org-tree-card h4{color:var(--color-text-main);margin-bottom:2px;font-size:.95rem;font-weight:600}.org-tree-card p{color:var(--color-text-sub);font-size:.85rem}.org-quota-box{border:1px solid var(--color-accent);color:var(--color-accent);background-color:#fff;border-radius:4px;margin-top:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.org-tree-card.director .org-quota-box,.org-tree-card.deputy .org-quota-box{color:#1e40af;background-color:#fff;border-color:#fff}.org-tree-card.department .org-quota-box{color:#1e40af;background-color:#fff;border-color:#1e40af}.org-staff-list{text-align:left;border-left:2px solid #e8e2d6;flex-direction:column;align-self:flex-start;gap:6px;width:100%;margin-top:12px;padding:10px 0 10px 14px;font-size:.85rem;list-style:none;display:flex}.org-staff-item{color:var(--color-text-main);cursor:pointer;padding:2px 0 2px 4px;transition:all .15s;position:relative}.org-staff-item:not(.vacant){font-weight:500}.org-staff-item:not(.vacant):hover{color:var(--color-accent);transform:translate(2px)}.org-staff-item.vacant{color:#b45309;cursor:default;font-style:italic}.searchable-dropdown-item:hover{background-color:var(--color-bg)!important;color:var(--color-accent)!important}.profile-avatar-container{margin:var(--space-md) 0;flex-direction:column;align-items:center;width:100%;display:flex}.avatar-image-wrapper{border:3px solid var(--color-border);width:120px;height:120px;box-shadow:var(--shadow-sm);background-color:var(--color-bg);border-radius:50%;transition:all .3s;position:relative;overflow:hidden}.avatar-image-wrapper:hover{border-color:var(--color-accent);box-shadow:var(--shadow-md);transform:translateY(-2px)}.avatar-image{object-fit:cover;width:100%;height:100%}.avatar-placeholder{width:100%;height:100%;color:var(--color-text-sub);background-color:var(--color-bg-sub);justify-content:center;align-items:center;display:flex}.avatar-upload-overlay{cursor:pointer;opacity:.8;background-color:#00000080;justify-content:center;align-items:center;height:36px;transition:all .2s;display:flex;position:absolute;bottom:0;left:0;right:0}.avatar-image-wrapper:hover .avatar-upload-overlay{opacity:1;background-color:#000000bf}.avatar-spinner{z-index:2;background-color:#ffffffb3;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.animate-spin{animation:1s linear infinite spin}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}
