@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,:before,:after,::backdrop{--tw-rotate-x:initial;--tw-rotate-y:initial;--tw-rotate-z:initial;--tw-skew-x:initial;--tw-skew-y:initial;--tw-border-style:solid;--tw-blur:initial;--tw-brightness:initial;--tw-contrast:initial;--tw-grayscale:initial;--tw-hue-rotate:initial;--tw-invert:initial;--tw-opacity:initial;--tw-saturate:initial;--tw-sepia:initial;--tw-drop-shadow:initial;--tw-drop-shadow-color:initial;--tw-drop-shadow-alpha:100%;--tw-drop-shadow-size:initial}}}@layer theme{:root,:host{--font-sans:ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji";--font-mono:ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace;--radius-lg:.5rem;--radius-xl:.75rem;--shadow-xs:0 1px 2px 0 #0000000d;--shadow-sm:0 1px 3px 0 #0000001a, 0 1px 2px -1px #0000001a;--shadow-md:0 4px 6px -1px #0000001a, 0 2px 4px -2px #0000001a;--shadow-lg:0 10px 15px -3px #0000001a, 0 4px 6px -4px #0000001a;--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4, 0, .2, 1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,:after,:before,::backdrop{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}html,:host{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif, system-ui, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol", "Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,samp,pre{font-family:var(--default-mono-font-family,ui-monospace, SFMono-Regular, Menlo, Monaco, Consolas, "Liberation Mono", "Courier New", monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}ol,ul,menu{list-style:none}img,svg,video,canvas,audio,iframe,embed,object{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,select,optgroup,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab, red, red)){::placeholder{color:color-mix(in oklab, currentcolor 50%, transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit{padding-block:0}::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-day-field{padding-block:0}::-webkit-datetime-edit-hour-field{padding-block:0}::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-millisecond-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button{height:auto}::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.collapse{visibility:collapse}.visible{visibility:visible}.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.transform{transform:var(--tw-rotate-x,) var(--tw-rotate-y,) var(--tw-rotate-z,) var(--tw-skew-x,) var(--tw-skew-y,)}.border{border-style:var(--tw-border-style);border-width:1px}.break-all{word-break:break-all}.italic{font-style:italic}.filter{filter:var(--tw-blur,) var(--tw-brightness,) var(--tw-contrast,) var(--tw-grayscale,) var(--tw-hue-rotate,) var(--tw-invert,) var(--tw-saturate,) var(--tw-sepia,) var(--tw-drop-shadow,)}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}}:root{--bg:#f7f7f5;--bg-2:#eeeeec;--surface:#fff;--surface-elev:#fdfdfc;--border:#e8e8e4;--border-strong:#d4d4d0;--text:#1a1a1a;--text-2:#404040;--muted:#737373;--muted-2:#a3a3a3;--primary:#1e3a5f;--primary-2:#2a5286;--primary-3:#3b6ba5;--primary-soft:#eef3f9;--primary-soft-2:#dde7f3;--accent:#c2410c;--success:#166534;--success-soft:#dcfce7;--warn:#a16207;--warn-soft:#fef3c7;--danger:#b91c1c;--danger-soft:#fee2e2;--radius:6px;--radius-lg:8px;--radius-xl:10px;--shadow-xs:0 1px 0 #00000005;--shadow-sm:0 1px 2px #1414140a;--shadow-md:0 2px 8px #1414140a, 0 1px 2px #14141408;--shadow-lg:0 8px 24px #1414140f, 0 2px 6px #1414140a;--gap:14px;--pad:14px;--row-pad:12px;--font-base:13px;--font-sm:12px;--font-lg:14.5px}*,:before,:after{box-sizing:border-box}html,body{margin:0;padding:0}body{background:var(--bg);color:var(--text);font-family:IBM Plex Sans Thai,IBM Plex Sans,system-ui,sans-serif;font-size:var(--font-base);-webkit-font-smoothing:antialiased;letter-spacing:-.005em;background-image:radial-gradient(at 0 0,#2a52860a,#0000 50%),radial-gradient(at 100% 0,#c2410c06,#0000 50%);min-height:100vh;line-height:1.55}.mono{font-family:IBM Plex Mono,monospace;font-size:.92em}.muted{color:var(--muted)}.small{font-size:var(--font-sm)}.strong{color:var(--text);font-weight:600}button{font-family:inherit;font-size:inherit}.app{grid-template-columns:248px 1fr;min-height:100vh;display:grid}.sidebar{color:#b8c0cc;background:#1c2536;border-right:1px solid #2a3447;flex-direction:column;height:100vh;padding:20px 14px;display:flex;position:sticky;top:0}.brand{border-bottom:1px solid #ffffff0f;align-items:center;gap:11px;margin-bottom:8px;padding:4px 8px 20px;display:flex}.brand-mark{background:linear-gradient(135deg,#3b6ba5,#5a8bc7);border-radius:6px;place-items:center;width:36px;height:36px;display:grid}.brand-title{color:#fff;letter-spacing:-.01em;font-size:14px;font-weight:600;line-height:1.25}.brand-sub{color:#8b94a3;letter-spacing:.06em;text-transform:uppercase;margin-top:1px;font-size:10.5px;font-weight:500}.nav{flex-direction:column;flex:1;gap:1px;padding-top:8px;display:flex}.nav-label{color:#6b7280;text-transform:uppercase;letter-spacing:.08em;padding:14px 10px 8px;font-size:10.5px;font-weight:600}.nav-item{color:#b8c0cc;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:5px;align-items:center;gap:11px;padding:9px 11px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff0a}.nav-item.active{color:#fff;background:#ffffff14;font-weight:600}.nav-item.active:before{content:"";background:#5a8bc7;border-radius:0 2px 2px 0;width:3px;position:absolute;top:8px;bottom:8px;left:-14px}.nav-item svg{opacity:.7;stroke-width:1.8px;flex-shrink:0}.nav-item.active svg{opacity:1}.nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:20px;margin-left:auto;padding:1px 7px;font-size:10.5px;font-weight:600}.nav-group{flex-direction:column;display:flex}.nav-group-toggle{width:100%}.nav-sub{border-left:1px solid #ffffff14;flex-direction:column;gap:1px;margin:2px 0 4px 14px;padding-left:22px;display:flex}.nav-sub-item{padding:7px 11px;font-size:13px}.nav-sub-item .nav-sub-bullet{background:#ffffff40;border-radius:50%;flex-shrink:0;width:6px;height:6px}.nav-sub-item.active .nav-sub-bullet{background:#5a8bc7}.nav-sub-item.active:before{display:none}.sidebar-foot{border-top:1px solid #ffffff0f;margin-top:8px;padding:14px 10px 4px}.foot-line{color:#b8c0cc;font-size:11px;font-weight:500}.foot-line.muted{color:#6b7280;margin-top:2px;font-weight:400}.main{flex-direction:column;min-width:0;display:flex}.topbar{z-index:10;background:#ffffffad;border-bottom:1px solid #e2e8f0b3;justify-content:space-between;align-items:center;padding:14px 32px;display:flex;position:sticky;top:0}.page-title{color:var(--text);letter-spacing:-.015em;font-size:19px;font-weight:600}.page-date{color:var(--muted);margin-top:1px;font-size:12.5px}.topbar-r{align-items:center;gap:10px;display:flex}.iconbtn{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text-2);border-radius:6px;place-items:center;transition:all .15s;display:grid;position:relative}.iconbtn:hover{background:var(--bg);border-color:var(--border-strong)}.iconbtn-dot{background:var(--danger);border:2px solid #fff;border-radius:50%;width:8px;height:8px;position:absolute;top:7px;right:7px}.iconbtn-badge{background:var(--danger);color:#fff;border:2px solid #fff;border-radius:999px;place-items:center;min-width:17px;height:17px;padding:0 4px;font-size:10px;font-weight:700;line-height:1;display:grid;position:absolute;top:-5px;right:-5px}.role-switcher{position:relative}.role-btn{border:1px solid var(--border);background:var(--surface);cursor:pointer;border-radius:6px;align-items:center;gap:10px;min-height:36px;padding:5px 12px;transition:all .15s;display:flex}.role-btn:hover{background:var(--bg);border-color:var(--border-strong)}.role-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.role-text{flex-direction:column;align-items:flex-start;line-height:1.2;display:flex}.role-l1{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;font-size:10.5px}.role-l2{color:var(--text);font-size:13px;font-weight:600}.role-menu{border:1px solid var(--border);min-width:240px;box-shadow:var(--shadow-md);z-index:20;background:#fff;border-radius:10px;padding:6px;position:absolute;top:calc(100% + 6px);right:0}.role-menu-head{color:var(--muted);text-transform:uppercase;letter-spacing:.06em;padding:6px 10px;font-size:11px}.role-menu-item{cursor:pointer;width:100%;color:var(--text);background:0 0;border:0;border-radius:6px;align-items:center;gap:10px;padding:8px 10px;font-size:13px;display:flex}.role-menu-item:hover{background:var(--bg-2)}.role-menu-item.active{background:var(--primary-soft);color:var(--primary-2);font-weight:600}.user-menu{position:relative}.user-chip{cursor:pointer;font:inherit;color:inherit;text-align:left;background:0 0;border:1px solid #0000;border-radius:8px;align-items:center;gap:10px;padding:4px 8px;transition:background .15s,border-color .15s;display:flex}.user-chip:hover,.user-chip[aria-expanded=true]{background:var(--bg);border-color:var(--border)}.user-caret{color:var(--muted);flex-shrink:0;transition:transform .15s}.user-chip[aria-expanded=true] .user-caret{transform:rotate(180deg)}.avatar{background:var(--primary-2);color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:grid}.user-info{line-height:1.25}.user-name{font-size:13px;font-weight:600}.user-role{color:var(--muted);align-items:center;font-size:11.5px;display:flex}.user-dropdown{min-width:220px}.role-menu-sep{background:var(--border);height:1px;margin:5px 6px}.role-menu-item.role-menu-danger{color:var(--danger)}.role-menu-item.role-menu-danger:hover{color:#b91c1c;background:#fee2e2}.content{width:100%;max-width:1440px;padding:28px 32px 60px}.page-grid{gap:var(--gap);grid-template-columns:minmax(0,1fr);display:grid}.page-grid>*{min-width:0}.hero{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);justify-content:space-between;align-items:center;padding:28px 32px;display:flex;position:relative;overflow:hidden}.hero:before{content:"";pointer-events:none;background:radial-gradient(circle at 100% 0,#2a528614,#0000 50%),radial-gradient(circle at 0 100%,#c2410c0a,#0000 50%);position:absolute;inset:0}.hero-l,.hero-r{z-index:1;position:relative}.hero-greet{color:var(--text);letter-spacing:-.02em;font-size:24px;font-weight:600}.hero-sub{color:var(--muted);margin-top:4px;font-size:13.5px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg)}.card-head{padding:var(--pad) var(--pad) calc(var(--pad) - 4px);justify-content:space-between;align-items:flex-start;display:flex}.card-title{font-size:var(--font-lg);color:var(--text);letter-spacing:-.015em;margin:0;font-weight:600}.card-sub{color:var(--muted);margin-top:3px;font-size:12.5px}.card-body{padding:4px var(--pad) var(--pad)}.two-col{gap:var(--gap);grid-template-columns:1fr 1fr;display:grid}.three-col{gap:var(--gap);grid-template-columns:1fr 1fr 1fr;display:grid}.kpi-grid{gap:var(--gap);grid-template-columns:repeat(4,1fr);display:grid}.stat{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--pad)}.stat:hover{border-color:var(--border-strong)}.stat-label{color:var(--muted);font-size:12.5px;font-weight:500}.stat-value{align-items:baseline;gap:6px;margin-top:8px;display:flex}.stat-num{color:var(--text);letter-spacing:-.03em;font-family:IBM Plex Mono,monospace;font-size:30px;font-weight:600}.stat-unit{color:var(--muted);font-size:13px}.stat-hint{color:var(--muted);margin-top:6px;font-size:11.5px}.balance-grid{gap:var(--gap);grid-template-columns:repeat(4,1fr);display:grid}.balance-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--pad)}.balance-card.primary{background:linear-gradient(135deg, var(--primary) 0%, var(--primary-2) 100%);color:#fff;border-color:#0000;position:relative;overflow:hidden}.balance-card.primary:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff14,#0000 70%);width:180px;height:180px;position:absolute;top:-40px;right:-40px}.balance-card.primary>*{z-index:1;position:relative}.balance-card.primary .bc-label{color:#ffffffbf}.balance-card.primary .bc-foot{color:#ffffffb3}.balance-card.primary .bc-bar{background:#ffffff2e}.balance-card.primary .bc-bar-fill{background:#fff}.bc-label{color:var(--muted);font-size:12.5px;font-weight:500}.bc-value{align-items:baseline;gap:6px;margin:8px 0 12px;display:flex}.bc-num{letter-spacing:-.03em;font-family:IBM Plex Mono,monospace;font-size:36px;font-weight:600;line-height:1}.bc-num.accent{color:var(--accent)}.bc-unit{opacity:.75;font-size:13px}.bc-bar{background:var(--bg-2);border-radius:3px;height:5px;overflow:hidden}.bc-bar-fill{background:var(--primary-2);border-radius:3px;height:100%}.bc-foot{color:var(--muted);margin-top:10px;font-size:11.5px}.btn{cursor:pointer;letter-spacing:-.005em;border:0;border-radius:6px;align-items:center;gap:7px;padding:9px 16px;font-size:13.5px;font-weight:500;transition:all .15s;display:inline-flex}.btn-sm{border-radius:5px;padding:6px 12px;font-size:12.5px}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--text);color:#fff}.btn-primary:hover:not(:disabled){background:#000}.btn-ghost{background:var(--surface);color:var(--text-2);border:1px solid var(--border)}.btn-ghost:hover:not(:disabled){background:var(--bg);border-color:var(--border-strong)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#991b1b}.btn-danger-outline{background:var(--surface);color:var(--danger);border:1px solid #fecaca}.btn-danger-outline:hover{background:var(--danger-soft)}.btn-success{background:var(--success);color:#fff}.btn-success:hover{background:#14532d}.link-btn{color:var(--primary-2);cursor:pointer;background:0 0;border:0;padding:0;font-size:13px;font-weight:600}.link-btn:hover{text-decoration:underline}.link-btn.danger{color:var(--danger)}.pill{white-space:nowrap;letter-spacing:.01em;border-radius:999px;padding:3px 10px;font-size:11.5px;font-weight:600;display:inline-block}.type-badge{background:#fff9;border:1px solid;border-radius:6px;align-items:center;gap:6px;padding:2px 9px;font-size:12px;font-weight:500;display:inline-flex}.type-icon{border-radius:50%;width:6px;height:6px}.urgent-pill{color:#b91c1c;text-transform:uppercase;letter-spacing:.04em;background:#fee2e2;border-radius:4px;padding:1px 7px;font-size:10.5px;font-weight:700}.req-list,.approval-list{flex-direction:column;gap:8px;display:flex}.req-row{padding:var(--row-pad);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);grid-template-columns:200px 1fr auto;align-items:center;gap:16px;display:grid}.req-row:hover{border-color:var(--border-strong);background:var(--surface-elev)}.req-id{color:var(--muted);font-family:IBM Plex Mono,monospace;font-size:12px}.req-title{color:var(--text);font-size:14px;font-weight:600}.req-meta{color:var(--muted);margin-top:2px;font-size:12.5px}.req-row-r{align-items:center;gap:10px;display:flex}.appr-row{padding:var(--row-pad);border:1px solid var(--border);border-radius:var(--radius);background:var(--surface);grid-template-columns:auto 1fr auto;align-items:flex-start;gap:14px;display:grid}.appr-main{min-width:0}.appr-head{align-items:center;gap:8px;display:flex}.appr-detail{flex-wrap:wrap;align-items:center;gap:10px;margin-top:4px;display:flex}.appr-reason{color:var(--text-2);margin-top:6px;font-size:12.5px;font-style:italic}.appr-actions{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.bar-list{flex-direction:column;gap:12px;margin:0;padding:0;list-style:none;display:flex}.bar-list li{grid-template-columns:180px 1fr 100px;align-items:center;gap:12px;display:grid}.bar-l{color:var(--text-2);font-size:13px}.bar-l.small{font-size:12px}.bar-bar{background:var(--bg-2);border-radius:4px;height:8px;overflow:hidden}.bar-fill{border-radius:4px;height:100%;transition:width .4s}.bar-r{color:var(--muted);text-align:right;font-family:IBM Plex Mono,monospace;font-size:12.5px}.req-form-wrap{gap:var(--gap);grid-template-columns:1fr 320px;display:grid}.req-form-body,.form-aside{gap:var(--gap);flex-direction:column;display:flex}.aside-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--pad)}.aside-title{color:var(--muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:10px;font-size:12px;font-weight:600}.aside-row{border-bottom:1px dashed var(--border);justify-content:space-between;align-items:center;padding:6px 0;font-size:13px;display:flex}.aside-row:last-child{border-bottom:0}.rule-card{background:#fffbeb;border-color:#fde68a}.rule-list{color:var(--text-2);flex-direction:column;gap:8px;margin:0;padding:0;font-size:12.5px;list-style:none;display:flex}.rule-list li:before{content:"•";color:#a16207;margin-right:6px;font-weight:700}.req-stepper{padding:16px var(--pad);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);margin-bottom:var(--gap);align-items:center;gap:12px;display:flex}.step{flex:1;align-items:center;gap:10px;display:flex}.step+.step:before{content:"";background:var(--border);width:30px;height:2px;margin-right:10px}.step-num{background:var(--bg-2);width:28px;height:28px;color:var(--muted);border-radius:50%;flex-shrink:0;place-items:center;font-size:13px;font-weight:600;display:grid}.step.active .step-num{background:var(--primary-2);color:#fff}.step.done .step-num{background:var(--success);color:#fff}.step-label{color:var(--muted);font-size:13.5px}.step.active .step-label{color:var(--text);font-weight:600}.type-grid{grid-template-columns:repeat(5,1fr);gap:12px;display:grid}.type-card{border:1px solid var(--border);background:var(--surface);border-radius:var(--radius-xl);text-align:center;cursor:pointer;padding:18px 14px 16px;transition:border-color .18s,transform .15s,box-shadow .18s,background .18s;position:relative;overflow:hidden;box-shadow:0 1px 2px #0000000a}.type-card:hover{border-color:var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card:hover{border-color:color-mix(in srgb, var(--c) 45%, var(--border))}}.type-card:hover{background:var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card:hover{background:color-mix(in srgb, var(--c) 4%, var(--surface))}}.type-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.type-card.active{border-color:var(--c);background:var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card.active{background:color-mix(in srgb, var(--c) 8%, var(--surface))}}.type-card.active{box-shadow:0 0 0 3px var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card.active{box-shadow:0 0 0 3px color-mix(in srgb, var(--c) 15%, transparent)}}.type-card.active:after{content:"✓";background:var(--c);color:#fff;border-radius:50%;place-items:center;width:18px;height:18px;font-size:11px;font-weight:700;line-height:1;display:grid;position:absolute;top:9px;right:10px}.tc-icon{background:var(--c);border-radius:14px;place-items:center;width:48px;height:48px;margin:0 auto 11px;font-size:24px;display:grid}@supports (color:color-mix(in lab, red, red)){.tc-icon{background:color-mix(in srgb, var(--c) 12%, var(--surface))}}.tc-icon{border:1px solid var(--c)}@supports (color:color-mix(in lab, red, red)){.tc-icon{border:1px solid color-mix(in srgb, var(--c) 16%, var(--border))}}.tc-icon{transition:background .18s,border-color .18s}.type-card:hover .tc-icon,.type-card.active .tc-icon{background:var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card:hover .tc-icon,.type-card.active .tc-icon{background:color-mix(in srgb, var(--c) 18%, #fff)}}.type-card:hover .tc-icon,.type-card.active .tc-icon{border-color:var(--c)}@supports (color:color-mix(in lab, red, red)){.type-card:hover .tc-icon,.type-card.active .tc-icon{border-color:color-mix(in srgb, var(--c) 32%, var(--border))}}.tc-label{color:var(--text);font-size:13.5px;font-weight:600}.type-card.active .tc-label{color:var(--c)}.tc-rule{color:var(--muted);margin-top:5px;font-size:11.5px;line-height:1.4}.form-row{margin-bottom:14px}.form-2col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.form-3col{grid-template-columns:1fr 1fr 1fr;gap:14px;display:grid}.form-label{color:var(--text-2);margin-bottom:6px;font-size:12.5px;font-weight:600;display:block}.req-star{color:var(--danger);margin-left:3px}.form-hint{color:var(--muted);margin-top:4px;font-size:11.5px}.inp{border:1px solid var(--border);background:var(--surface);width:100%;color:var(--text);border-radius:6px;padding:8px 11px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.inp:focus{border-color:var(--primary-2);box-shadow:0 0 0 3px var(--primary-soft);outline:0}.inp.ta{resize:vertical;min-height:70px}.inp-sm{width:auto;padding:6px 10px;font-size:12.5px}.seg{border:1px solid var(--border);background:var(--bg);border-radius:7px;gap:2px;padding:3px;display:inline-flex}.seg-btn{cursor:pointer;color:var(--text-2);background:0 0;border:0;border-radius:5px;padding:6px 12px;font-size:12.5px}.seg-btn.active{background:var(--surface);color:var(--primary-2);box-shadow:var(--shadow-sm);font-weight:600}.calc-info{background:var(--primary-soft);color:var(--primary-2);border-radius:6px;align-items:center;gap:8px;margin-bottom:14px;padding:9px 12px;font-size:13px;display:flex}.form-foot{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;margin-top:18px;padding-top:14px;display:flex}.halfday-range{grid-template-columns:1fr 1fr;gap:14px;display:grid}.hr-col{flex-direction:column;gap:6px;display:flex}.hr-label{color:var(--muted);font-size:12px}.upload-drop{border:2px dashed var(--border-strong);text-align:center;cursor:pointer;color:var(--text-2);background:var(--bg);border-radius:8px;padding:22px;transition:border-color .15s,background .15s}.upload-drop:hover{border-color:var(--primary-2);background:var(--primary-soft)}.file-list{flex-direction:column;gap:6px;margin:10px 0 0;padding:0;list-style:none;display:flex}.file-list li{background:var(--bg);border-radius:6px;align-items:center;gap:10px;padding:8px 12px;font-size:13px;display:flex}.review{background:var(--bg);border-radius:8px;padding:6px 16px}.review-row{border-bottom:1px dashed var(--border);grid-template-columns:140px 1fr;gap:14px;padding:10px 0;display:grid}.review-row:last-child{border-bottom:0}.rev-l{color:var(--muted);font-size:12.5px}.rev-r{color:var(--text);font-size:13.5px}.flow-preview{background:var(--primary-soft);border:1px solid var(--primary-soft-2);border-radius:10px;margin-top:18px;padding:16px}.fp-title{color:var(--primary-2);margin-bottom:12px;font-size:12.5px;font-weight:600}.fp-steps{flex-wrap:wrap;align-items:center;gap:8px;margin:0;padding:0;list-style:none;display:flex}.fp-step{border:1px solid var(--primary-soft-2);background:#fff;border-radius:999px;align-items:center;gap:8px;padding:7px 13px;display:flex}.fp-num{background:var(--primary-2);color:#fff;border-radius:50%;place-items:center;width:20px;height:20px;font-size:11px;font-weight:600;display:grid}.fp-label{color:var(--text);font-size:12.5px;font-weight:500}.fp-arrow{color:var(--primary-3);font-weight:600}.success-wrap{justify-content:center;padding:40px 0;display:flex}.success-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-xl);text-align:center;max-width:480px;box-shadow:var(--shadow-lg);padding:40px}.success-tick{background:var(--success-soft);width:72px;height:72px;color:var(--success);border-radius:50%;place-items:center;margin:0 auto 18px;font-size:32px;font-weight:700;display:grid}.success-title{color:var(--text);font-size:22px;font-weight:700}.success-sub{color:var(--muted);margin:4px 0 18px}.success-meta{background:var(--bg);border-radius:8px;justify-content:center;align-items:center;gap:10px;margin-bottom:14px;padding:12px;font-size:13px;display:flex}.success-actions{justify-content:center;gap:10px;display:flex}.approval-page{gap:var(--gap);grid-template-columns:380px 1fr;display:grid}.appr-list-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-direction:column;max-height:calc(100vh - 110px);display:flex;overflow:hidden}.appr-list-head{padding:14px var(--pad);border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;display:flex}.appr-list-title{font-size:14px;font-weight:700}.chip{background:var(--surface);border:1px solid var(--border);cursor:pointer;border-radius:999px;padding:4px 11px;font-size:11.5px;font-weight:500;transition:all .15s}.chip:hover{background:var(--bg)}.chip.active{background:var(--text);color:#fff;border-color:var(--text)}.appr-list2{flex:1;margin:0;padding:6px;list-style:none;overflow-y:auto}.appr-item{cursor:pointer;border-radius:7px;align-items:flex-start;gap:10px;padding:10px;display:flex}.appr-item:hover{background:var(--bg)}.appr-item.active{background:var(--primary-soft)}.ai-main{flex:1;min-width:0}.ai-top{align-items:center;gap:6px;font-size:13px;display:flex}.ai-sub{align-items:center;gap:6px;margin-top:2px;display:flex}.ai-meta{color:var(--muted);margin-top:3px;font-size:12px}.appr-detail-col{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--pad)}.ad-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;margin-bottom:16px;padding-bottom:16px;display:flex}.ad-id{color:var(--muted);font-family:IBM Plex Mono,monospace;font-size:12px}.ad-title{margin:2px 0;font-size:19px;font-weight:700}.ad-head-r{flex-direction:column;align-items:flex-end;gap:8px;display:flex}.ad-grid{border-bottom:1px solid var(--border);grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:16px;padding-bottom:16px;display:grid}.ad-cell .ad-l{color:var(--muted);margin-bottom:3px;font-size:11.5px}.ad-cell .ad-r{font-size:13.5px}.ad-section{border-bottom:1px solid var(--border);grid-template-columns:200px 1fr;gap:16px;padding:14px 0;display:grid}.ad-section .ad-l{color:var(--muted);font-size:12.5px;font-weight:600}.reason-box{background:var(--bg);border-left:3px solid var(--primary-2);color:var(--text-2);border-radius:4px;padding:12px 14px;font-style:italic}.ad-action-box{background:var(--bg);border-radius:8px;margin-top:14px;padding:14px}.ad-actions{justify-content:flex-end;gap:8px;margin-top:4px;display:flex}.timeline{margin:0;padding:0;list-style:none}.tl-step{gap:14px;padding:8px 0;display:flex;position:relative}.tl-step+.tl-step:before{content:"";background:var(--border);width:2px;height:24px;position:absolute;top:-16px;left:11px}.tl-step.done+.tl-step:before{background:var(--success)}.tl-marker{background:var(--bg-2);width:24px;height:24px;color:var(--muted);border-radius:50%;flex-shrink:0;place-items:center;display:grid}.tl-step.done .tl-marker{background:var(--success);color:#fff}.tl-step.current .tl-marker{background:var(--primary-2);color:#fff}.tl-label{font-size:13.5px;font-weight:600}.tl-by{color:var(--muted);margin-top:2px;font-size:12px}.tl-note{color:var(--text-2);margin-top:2px;font-size:12.5px;font-style:italic}.hist-page{gap:var(--gap);flex-direction:column;display:flex}.hist-filters{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;display:flex}.hist-tabs{flex-wrap:wrap;gap:4px;display:flex}.tab{background:var(--surface);border:1px solid var(--border);cursor:pointer;color:var(--text-2);border-radius:999px;padding:6px 14px;font-size:12.5px;font-weight:500}.tab:hover{background:var(--bg)}.tab.active{background:var(--text);color:#fff;border-color:var(--text)}.dt{border-collapse:collapse;width:100%}.dt thead th{text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.06em;border-bottom:1px solid var(--border);padding:12px;font-size:11px;font-weight:600}.dt tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:12px;font-size:13px}.dt tbody tr:last-child td{border-bottom:0}.dt tbody tr:hover{background:var(--bg)}.td-clip{text-overflow:ellipsis;white-space:nowrap;max-width:240px;overflow:hidden}.report-toolbar{padding:12px var(--pad);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);flex-wrap:wrap;justify-content:space-between;gap:12px;display:flex}.rt-l,.rt-r{flex-wrap:wrap;align-items:center;gap:12px;display:flex}.rt-title{flex-direction:column;line-height:1.25;display:flex}.rt-eyebrow{text-transform:uppercase;letter-spacing:.08em;color:var(--muted);font-size:10.5px;font-weight:600}.rt-heading{color:var(--text);letter-spacing:-.015em;font-size:16px;font-weight:600}.pcard{background:linear-gradient(140deg, var(--pc), var(--pc));position:relative;overflow:hidden}@supports (color:color-mix(in lab, red, red)){.pcard{background:linear-gradient(140deg, var(--pc), color-mix(in srgb, var(--pc) 80%, #000))}}.pcard{border:1px solid var(--pc)}@supports (color:color-mix(in lab, red, red)){.pcard{border:1px solid color-mix(in srgb, var(--pc) 55%, #000)}}.pcard{border-radius:var(--radius-xl);color:#fff;padding:14px 16px 15px;transition:box-shadow .2s,transform .2s,filter .2s;box-shadow:0 1px 2px #0000000f}.pcard:hover{box-shadow:var(--shadow-md);filter:brightness(1.07);transform:translateY(-2px)}.type-kpi-grid{gap:var(--gap);grid-template-columns:repeat(auto-fit,minmax(155px,1fr));display:grid}.pcard-label{color:#ffffffeb;letter-spacing:.01em;margin-bottom:12px;font-size:12.5px;font-weight:600}.pcard-num{color:#fff;letter-spacing:-.03em;font-family:IBM Plex Mono,monospace;font-size:28px;font-weight:600;line-height:1}.pcard-num small{color:#fffc;font-size:13px;font-weight:500}.pcard-sub{color:#ffffffd1;margin-top:7px;font-size:11.5px}.donut-row{flex-wrap:wrap;align-items:center;gap:26px;display:flex}.donut-wrap{flex-shrink:0;position:relative}.donut-center{pointer-events:none;flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.donut-num{color:var(--text);letter-spacing:-.03em;font-family:IBM Plex Mono,monospace;font-size:27px;font-weight:600}.donut-cap{color:var(--muted);margin-top:2px;font-size:11px}.legend{flex-direction:column;flex:1;gap:16px;min-width:190px;margin:0;padding:0;list-style:none;display:flex}.legend li{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.legend-dot{border-radius:3px;flex-shrink:0;width:10px;height:10px;display:inline-block}.legend-name{color:var(--text);font-size:13.5px;font-weight:600}.legend-pct{margin-left:auto;font-family:IBM Plex Mono,monospace;font-size:17px;font-weight:700}.legend-val{color:var(--muted);flex-basis:100%;padding-left:18px;font-size:11.5px}.prop-list{flex-direction:column;gap:15px;margin:0;padding:0;list-style:none;display:flex}.prop-list li{grid-template-columns:1fr 48px;grid-template-areas:"head head""track pct";align-items:center;gap:5px 12px;display:grid}.prop-head{grid-area:head;justify-content:space-between;align-items:baseline;gap:8px;display:flex}.prop-name{color:var(--text);align-items:center;gap:6px;font-size:13px;font-weight:600;display:flex}.prop-dot{border-radius:50%;flex-shrink:0;width:8px;height:8px;display:inline-block}.prop-val{color:var(--muted);white-space:nowrap;font-size:12px}.prop-val strong{color:var(--text)}.prop-track{background:var(--bg-2);border-radius:5px;grid-area:track;height:9px;overflow:hidden}.prop-fill{border-radius:5px;height:100%;transition:width .6s}.prop-pct{text-align:right;grid-area:pct;font-family:IBM Plex Mono,monospace;font-size:13px;font-weight:700}.mchart{flex-direction:column;display:flex}.mbars{border-bottom:1px solid var(--border);grid-template-columns:repeat(12,1fr);align-items:end;gap:7px;height:190px;padding-top:10px;display:grid}.mbar-col{flex-direction:column;align-items:center;min-width:0;height:100%;display:flex}.mbar-val{color:var(--muted);height:14px;font-family:IBM Plex Mono,monospace;font-size:10px;line-height:14px}.mbar-track{flex-direction:column;flex:1;justify-content:flex-end;width:100%;max-width:30px;display:flex}.mbar-stack{border-radius:5px 5px 0 0;flex-direction:column;width:100%;transition:height .6s;display:flex;overflow:hidden}.mbar-col:hover .mbar-stack{filter:brightness(1.08)}.mbar-col.dim{opacity:.32}.mbar-col.dim .mbar-val{opacity:0}.mseg{width:100%}.mbar-x{color:var(--muted);margin-top:7px;font-size:10.5px}.grp-list{flex-direction:column;gap:15px;margin:0;padding:0;list-style:none;display:flex}.grp-head{justify-content:space-between;align-items:baseline;gap:8px;margin-bottom:6px;display:flex}.grp-name{color:var(--text);text-overflow:ellipsis;white-space:nowrap;align-items:center;gap:7px;min-width:0;font-size:13px;font-weight:600;display:flex;overflow:hidden}.grp-tag{color:var(--primary-2);background:var(--primary-soft);border-radius:4px;padding:1px 6px;font-size:10px;font-weight:600}.grp-share{color:var(--muted);white-space:nowrap;flex-shrink:0;font-size:12px}.grp-track{grid-template-columns:1fr auto;align-items:center;gap:10px;display:grid}.grp-barwrap{background:var(--bg-2);border-radius:7px;height:14px;overflow:hidden}.grp-bar{min-width:2px;height:100%;transition:width .6s;display:flex}.gseg{height:100%}.grp-num{color:var(--muted);white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:11.5px}.chart-legend{border-top:1px solid var(--border);flex-wrap:wrap;gap:18px;margin-top:14px;padding-top:12px;display:flex}.chart-legend span{color:var(--muted);align-items:center;gap:7px;font-size:12px;font-weight:500;display:inline-flex}.calc-note{grid-template-columns:repeat(2,1fr);gap:12px 22px;margin:0;padding:0;list-style:none;display:grid}.calc-note li{color:var(--text-2);gap:10px;font-size:13px;line-height:1.55;display:flex}.calc-note li b{color:var(--text);font-weight:600}.calc-note .ci{width:22px;height:22px;color:var(--primary-2);background:var(--primary-soft);border-radius:6px;flex-shrink:0;place-items:center;font-size:12px;font-weight:700;display:grid}@media (max-width:760px){.calc-note{grid-template-columns:1fr}}.year-cal{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;width:100%;display:grid}.mini-month{background:var(--surface);border:1px solid var(--border);border-radius:8px;min-width:0;padding:10px;overflow:hidden}.mm-title{color:var(--text);margin-bottom:10px;font-size:13px;font-weight:600}.mm-head{grid-template-columns:repeat(7,1fr);gap:2px;margin-bottom:4px;display:grid}.mm-wh{color:var(--muted);text-align:center;padding:2px 0;font-size:10px;font-weight:500}.mm-wh.we{color:var(--muted-2)}.mm-grid{grid-template-columns:repeat(7,1fr);gap:2px;display:grid}.mm-cell{aspect-ratio:1;cursor:pointer;color:var(--text-2);background:0 0;border:0;border-radius:4px;place-items:center;padding:0;font-family:inherit;font-size:11.5px;font-weight:500;display:grid}.mm-cell:hover{background:var(--bg)}.mm-cell.empty{cursor:default}.mm-cell.we{color:var(--muted-2)}.mm-cell.today{box-shadow:inset 0 0 0 1.5px var(--text);font-weight:700}.mm-cell.hol{font-weight:600}.mm-cell.hol-public{color:#b91c1c;background:#fee2e2}.mm-cell.hol-special{color:#a16207;background:#fef3c7}.mm-cell.hol-custom{color:#1d4ed8;background:#dbeafe}.modal-backdrop{z-index:100;background:#0f172a73;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--radius-lg);width:100%;max-width:480px;box-shadow:var(--shadow-lg);flex-direction:column;max-height:90vh;display:flex}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:flex-start;gap:12px;padding:18px 20px;display:flex}.modal-title{color:var(--text);font-size:16px;font-weight:600}.modal-body{padding:18px 20px;overflow-y:auto}.modal-foot{border-top:1px solid var(--border);background:var(--bg);border-radius:0 0 var(--radius-lg) var(--radius-lg);align-items:center;gap:8px;padding:14px 20px;display:flex}.empty{text-align:center;color:var(--muted);padding:40px}.empty-title{color:var(--text);margin-bottom:4px;font-size:15px;font-weight:600}.tswitch{vertical-align:middle;width:38px;height:22px;display:inline-block;position:relative}.tswitch input{opacity:0;width:0;height:0}.tswitch .slider{cursor:pointer;background:#cbd5e1;border-radius:22px;transition:background .2s;position:absolute;inset:0}.tswitch .slider:before{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:transform .2s;position:absolute;top:3px;left:3px;box-shadow:0 1px 3px #00000040}.tswitch input:checked+.slider{background:var(--primary-2)}.tswitch input:checked+.slider:before{transform:translate(16px)}.tswitch input:disabled+.slider{opacity:.5;cursor:not-allowed}.tswitch.hr input:checked+.slider{background:#7c2d12}.tswitch.admin input:checked+.slider{background:#0f172a}.role-tile{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:var(--pad);position:relative;overflow:hidden}.role-tile.themed{background:linear-gradient(135deg, var(--c) 0%, var(--c) 100%)}@supports (color:color-mix(in lab, red, red)){.role-tile.themed{background:linear-gradient(135deg, var(--c) 0%, color-mix(in srgb, var(--c) 75%, #000) 100%)}}.role-tile.themed{color:#fff;border-color:#0000}.role-tile.themed:after{content:"";pointer-events:none;background:radial-gradient(circle,#ffffff1f,#0000 70%);width:180px;height:180px;position:absolute;top:-40px;right:-40px}.role-tile>*{z-index:1;position:relative}.role-tile .rt-label{color:var(--muted);font-size:12.5px;font-weight:500}.role-tile.themed .rt-label{color:#ffffffc7}.role-tile .rt-value{align-items:baseline;gap:6px;margin:10px 0 12px;display:flex}.role-tile .rt-num{letter-spacing:-.03em;color:var(--text);font-family:IBM Plex Mono,monospace;font-size:36px;font-weight:600;line-height:1}.role-tile.themed .rt-num{color:#fff}.role-tile .rt-unit{color:var(--muted);font-size:13px}.role-tile.themed .rt-unit{color:#ffffffbf}.role-tile .rt-bar{background:var(--bg-2);border-radius:3px;height:5px;overflow:hidden}.role-tile.themed .rt-bar{background:#ffffff2e}.role-tile .rt-bar-fill{background:var(--c);border-radius:3px;height:100%;transition:width .4s}.role-tile.themed .rt-bar-fill{background:#fff}.role-tile .rt-foot{color:var(--muted);margin-top:10px;font-size:11.5px}.role-tile.themed .rt-foot{color:#ffffffa6}.role-table tr td{vertical-align:middle;padding:14px 12px}.role-table .emp-cell{align-items:center;gap:12px;min-width:0;display:flex}.role-table .emp-avatar{color:#fff;border-radius:50%;flex-shrink:0;place-items:center;width:36px;height:36px;font-size:13px;font-weight:600;display:grid}.role-table .emp-name{color:var(--text);font-size:13.5px;font-weight:600}.role-table .emp-sub{color:var(--muted);margin-top:2px;font-size:12px}.role-pill{background:var(--surface);border:1px solid var(--border);border-radius:999px;align-items:center;gap:7px;padding:4px 12px;font-size:12.5px;font-weight:500;display:inline-flex}.role-pill .dot{border-radius:50%;flex-shrink:0;width:8px;height:8px}.chip-bar{flex-wrap:wrap;align-items:center;gap:6px;display:flex}.chip-bar .chip-label{color:var(--muted);margin-right:4px;font-size:12px;font-weight:500}@media (max-width:1100px){.register-layout{grid-template-columns:1fr!important}}@media print{.sidebar,.topbar,.no-print{display:none!important}.app{display:block}.content{max-width:none;padding:0}body{background:#fff}.card{box-shadow:none;border:1px solid #999}.print-page{max-width:800px;margin:0 auto;padding:28px}}.print-page{border:1px solid var(--border);background:#fff;max-width:820px;margin:24px auto;padding:40px 56px;font-family:IBM Plex Sans Thai,sans-serif}.print-head{text-align:center;border-bottom:2px solid #000;margin-bottom:24px;padding-bottom:18px}.print-head h1{margin:0;font-size:22px;font-weight:700}.print-head h2{color:var(--text-2);margin:4px 0 0;font-size:16px;font-weight:600}.print-section{margin-bottom:18px}.print-row{border-bottom:1px dashed #ccc;grid-template-columns:160px 1fr;padding:6px 0;font-size:13.5px;display:grid}.print-sign{grid-template-columns:repeat(2,1fr);gap:60px;margin-top:40px;display:grid}.print-sign div{text-align:center;border-top:1px solid #000;padding-top:60px;font-size:13.5px}@media (max-width:1280px){.year-cal{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (max-width:900px){.app{grid-template-columns:220px 1fr}.balance-grid,.kpi-grid{grid-template-columns:repeat(2,1fr)}.type-grid{grid-template-columns:repeat(3,1fr)}.req-form-wrap,.approval-page,.year-cal,.two-col{grid-template-columns:1fr}.mbars{gap:4px}.mbar-x{font-size:9.5px}}.menu-toggle{border:1px solid var(--border);background:var(--surface);cursor:pointer;width:36px;height:36px;color:var(--text-2);border-radius:6px;flex-shrink:0;place-items:center;display:none}.menu-toggle:hover{background:var(--bg);border-color:var(--border-strong)}.mobile-backdrop{display:none}@media (max-width:900px){.menu-toggle{display:grid}}@media (max-width:768px){.app{grid-template-columns:1fr}.content{padding:16px}.topbar{padding:12px 16px}.two-col,.three-col{grid-template-columns:1fr}.type-grid,.ad-grid{grid-template-columns:repeat(2,1fr)}.form-2col,.form-3col{grid-template-columns:1fr}.sidebar{z-index:60;width:270px;transition:transform .2s;position:fixed;inset:0 auto 0 0;transform:translate(-100%);box-shadow:4px 0 24px #00000040}.sidebar.open{transform:translate(0)}.mobile-backdrop{z-index:55;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#0f172a73;display:block;position:fixed;inset:0}.app.mobile-open{overflow:hidden}}.cal-nav{align-items:center;gap:6px;display:flex}.cal-grid{grid-template-columns:repeat(7,minmax(0,1fr));gap:4px;display:grid}.cal-dow-row{margin-bottom:4px}.cal-dow{text-align:center;color:var(--muted);text-transform:uppercase;letter-spacing:.04em;padding:4px 0;font-size:11.5px;font-weight:600}.cal-dow.off{color:var(--danger);opacity:.65}.cal-cell{background:var(--surface-elev);border:1px solid var(--border);border-radius:var(--radius);flex-direction:column;gap:3px;min-height:74px;padding:5px 6px;display:flex}.cal-cell.blank{background:0 0;border-color:#0000}.cal-cell.off{background:var(--bg-2)}.cal-cell.today{border-color:var(--primary-2);box-shadow:inset 0 0 0 1px var(--primary-2)}.cal-cell.today .cal-daynum{background:var(--primary);color:#fff;border-radius:999px;justify-content:center;align-items:center;width:20px;height:20px;display:inline-flex}.cal-cell-head{justify-content:space-between;align-items:center;gap:4px;min-height:20px;display:flex}.cal-daynum{color:var(--text-2);font-size:12px;font-weight:600;line-height:1}.cal-cell.off .cal-daynum{color:var(--muted-2)}.cal-holiday{color:var(--danger);white-space:nowrap;text-overflow:ellipsis;min-width:0;font-size:10px;line-height:1.2;overflow:hidden}.cal-marks{flex-direction:column;gap:2px;display:flex}.cal-mark{color:var(--mk);background:var(--mk);align-items:center;gap:4px;font-size:10.5px;font-weight:600;display:flex}@supports (color:color-mix(in lab, red, red)){.cal-mark{background:color-mix(in srgb, var(--mk) 10%, transparent)}}.cal-mark{border:1px solid var(--mk)}@supports (color:color-mix(in lab, red, red)){.cal-mark{border:1px solid color-mix(in srgb, var(--mk) 35%, transparent)}}.cal-mark{white-space:nowrap;border-radius:4px;padding:1px 5px;line-height:1.5;text-decoration:none;overflow:hidden}.cal-mark:hover{background:var(--mk)}@supports (color:color-mix(in lab, red, red)){.cal-mark:hover{background:color-mix(in srgb, var(--mk) 18%, transparent)}}.cal-mark.pending{opacity:.75;border-style:dashed}.cal-mark-label{text-overflow:ellipsis;min-width:0;overflow:hidden}.cal-mark-part{opacity:.85;margin-left:auto;font-weight:500}.cal-half{border:1.5px solid var(--mk);border-radius:999px;flex:none;width:10px;height:10px}.cal-half.full{background:var(--mk)}.cal-half.morning{background:linear-gradient(to bottom, var(--mk) 50%, transparent 50%)}.cal-half.afternoon{background:linear-gradient(to top, var(--mk) 50%, transparent 50%)}.cal-legend{border-top:1px solid var(--border);color:var(--muted);flex-wrap:wrap;align-items:center;gap:6px 14px;margin-top:12px;padding-top:10px;font-size:11.5px;display:flex}.cal-lg{align-items:center;gap:5px;display:inline-flex}.cal-lg-sep{background:var(--border-strong);width:1px;height:14px}.cal-dot{border-radius:999px;width:8px;height:8px}.cal-pending-demo{border:1px dashed var(--muted);opacity:.75;border-radius:4px;width:14px;height:10px}@media (max-width:760px){.cal-cell{min-height:56px;padding:4px}.cal-mark-label,.cal-mark-part{display:none}.cal-mark{justify-content:center;padding:2px}}.scan-summary{flex-wrap:wrap;gap:8px;margin-bottom:12px;display:flex}.scan-chip{border:1px solid var(--border);background:var(--surface-elev);color:var(--text-2);box-shadow:var(--shadow-xs);border-radius:999px;align-items:center;gap:7px;padding:5px 12px;font-size:12px;display:inline-flex}.scan-chip strong{font-variant-numeric:tabular-nums;font-size:13px}.scan-chip .dot{border-radius:999px;flex:none;width:8px;height:8px}.scan-wrap{border:1px solid var(--border);border-radius:var(--radius-lg);background:var(--surface);box-shadow:var(--shadow-sm);flex-direction:column;display:flex;overflow:hidden}.scan-scroll{min-width:0;max-height:580px;overflow:auto}.scan-table{border-collapse:separate;border-spacing:0;width:100%;font-size:12.5px}.scan-table thead th{background:var(--surface);border-bottom:1px solid var(--border-strong);text-align:left;color:var(--muted);text-transform:uppercase;letter-spacing:.07em;white-space:nowrap;padding:10px 12px;font-size:10.5px;font-weight:600}.scan-scroll .scan-table thead th{z-index:2;position:sticky;top:0}.scan-scroll .scan-table thead th:after{content:"";background:var(--border-strong);height:1px;position:absolute;bottom:-1px;left:0;right:0}.scan-table tbody td{border-bottom:1px solid var(--border);vertical-align:middle;padding:9px 12px}.scan-table tbody tr:last-child td{border-bottom:0}.scan-table tbody tr{transition:background .1s}.scan-table tbody tr:hover td{background:var(--primary-soft)}.scan-person{align-items:center;gap:10px;display:flex}.scan-name{font-weight:600;line-height:1.3}.scan-code{color:var(--muted);font-family:IBM Plex Mono,monospace;font-size:11px}.scan-group-chip{background:var(--bg-2);color:var(--text-2);white-space:nowrap;text-overflow:ellipsis;border-radius:999px;max-width:180px;padding:2px 9px;font-size:11px;display:inline-block;overflow:hidden}.scan-date{white-space:nowrap;font-weight:500}.scan-dow{color:var(--muted-2);font-size:11px}.scan-shift{color:var(--muted);white-space:nowrap;font-family:IBM Plex Mono,monospace;font-size:11.5px}.time-chip{font-variant-numeric:tabular-nums;background:var(--bg-2);min-width:56px;color:var(--text-2);border-radius:6px;justify-content:center;align-items:center;padding:3px 9px;font-family:IBM Plex Mono,monospace;font-size:12px;display:inline-flex}.time-chip.warn{color:#92400e;background:#fef3c7;font-weight:600}.time-chip.none{border:1px dashed var(--border-strong);color:var(--muted-2);background:0 0}.scan-pill{white-space:nowrap;border-radius:999px;align-items:center;gap:6px;padding:2px 10px;font-size:12px;font-weight:500;display:inline-flex}.scan-pill .dot{border-radius:999px;flex:none;width:7px;height:7px}.scan-note{margin-top:3px;font-size:11px;line-height:1.45}.scan-empty{text-align:center;color:var(--muted);padding:36px 0}.scan-table td.t-num,.scan-table th.t-num{text-align:center;font-variant-numeric:tabular-nums}.scan-table td.t-right,.scan-table th.t-right{text-align:right}.scan-table td.t-strong{font-weight:700}.scan-table .t-actions{white-space:nowrap}.scan-sub{color:var(--muted);margin-top:1px;font-size:11.5px}.scan-reason{text-overflow:ellipsis;white-space:nowrap;max-width:260px;color:var(--text-2);overflow:hidden}.shift-timeline{flex-direction:column;gap:6px;display:flex}.shift-row{border:1px solid var(--border);border-radius:var(--radius);background:var(--surface-elev);align-items:center;gap:12px;padding:8px 12px;display:flex}.shift-row.current{border-color:var(--primary-2);background:var(--primary-soft)}.shift-when{flex-wrap:wrap;flex:1;align-items:center;gap:8px;min-width:0;display:flex}.shift-date{font-size:12.5px;font-weight:600}.shift-time{font-variant-numeric:tabular-nums;font-family:IBM Plex Mono,monospace;font-size:13px}.shift-tag{border-radius:999px;padding:1px 7px;font-size:10.5px;font-weight:600}.shift-tag.cur{background:var(--primary);color:#fff}.shift-tag.fut{background:var(--warn-soft);color:var(--warn)}.scan-section{margin-bottom:18px}.scan-section-head{border-bottom:1px solid var(--border);align-items:baseline;gap:10px;margin-bottom:8px;padding:2px 2px 7px;display:flex}.scan-section-head.exec{border-bottom:2px solid #7f1d1d}.scan-section-title{color:var(--text);font-size:13.5px;font-weight:600}.scan-section-head.exec .scan-section-title{color:#7f1d1d}.scan-foot{border-top:1px solid var(--border);background:var(--surface-elev);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:9px 14px;display:flex}.scan-foot-info{color:var(--muted);font-variant-numeric:tabular-nums;font-size:12px}.scan-foot-info strong{color:var(--text-2);font-weight:600}.scan-pager{align-items:center;gap:4px;display:flex}.scan-pg-btn{border:1px solid var(--border);background:var(--surface);min-width:30px;height:30px;color:var(--text-2);font-variant-numeric:tabular-nums;cursor:pointer;border-radius:6px;justify-content:center;align-items:center;padding:0 9px;font-size:12.5px;transition:all .12s;display:inline-flex}.scan-pg-btn:hover:not(:disabled){background:var(--bg);border-color:var(--border-strong)}.scan-pg-btn.active{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.scan-pg-btn:disabled{opacity:.4;cursor:default}.scan-pg-gap{color:var(--muted-2);padding:0 4px;font-size:12px}.scan-pg-size{border:1px solid var(--border);background:var(--surface);height:30px;color:var(--text-2);cursor:pointer;border-radius:6px;padding:0 8px;font-size:12.5px}@property --tw-rotate-x{syntax:"*";inherits:false}@property --tw-rotate-y{syntax:"*";inherits:false}@property --tw-rotate-z{syntax:"*";inherits:false}@property --tw-skew-x{syntax:"*";inherits:false}@property --tw-skew-y{syntax:"*";inherits:false}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-blur{syntax:"*";inherits:false}@property --tw-brightness{syntax:"*";inherits:false}@property --tw-contrast{syntax:"*";inherits:false}@property --tw-grayscale{syntax:"*";inherits:false}@property --tw-hue-rotate{syntax:"*";inherits:false}@property --tw-invert{syntax:"*";inherits:false}@property --tw-opacity{syntax:"*";inherits:false}@property --tw-saturate{syntax:"*";inherits:false}@property --tw-sepia{syntax:"*";inherits:false}@property --tw-drop-shadow{syntax:"*";inherits:false}@property --tw-drop-shadow-color{syntax:"*";inherits:false}@property --tw-drop-shadow-alpha{syntax:"<percentage>";inherits:false;initial-value:100%}@property --tw-drop-shadow-size{syntax:"*";inherits:false}
