body{-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}:root{--react-pdf-annotation-layer:1;--annotation-unfocused-field-background:url('data:image/svg+xml;charset=utf-8,<svg width="1" height="1" xmlns="http://www.w3.org/2000/svg"><rect width="100%" height="100%" style="fill:rgba(0,54,255,.13)"/></svg>');--input-focus-border-color:Highlight;--input-focus-outline:1px solid Canvas;--input-unfocused-border-color:#0000;--input-disabled-border-color:#0000;--input-hover-border-color:#000;--link-outline:none}@media screen and (forced-colors:active){:root{--input-focus-border-color:CanvasText;--input-unfocused-border-color:ActiveText;--input-disabled-border-color:GrayText;--input-hover-border-color:Highlight;--link-outline:1.5px solid LinkText}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .textWidgetAnnotation :is(input,textarea):required{outline:1.5px solid selectedItem}.annotationLayer .linkAnnotation:hover{-webkit-backdrop-filter:invert(100%);backdrop-filter:invert(100%)}}.annotationLayer{left:0;pointer-events:none;position:absolute;top:0;transform-origin:0 0;z-index:3}.annotationLayer[data-main-rotation="90"] .norotate{transform:rotate(270deg) translateX(-100%)}.annotationLayer[data-main-rotation="180"] .norotate{transform:rotate(180deg) translate(-100%,-100%)}.annotationLayer[data-main-rotation="270"] .norotate{transform:rotate(90deg) translateY(-100%)}.annotationLayer canvas{height:100%;position:absolute;width:100%}.annotationLayer section{box-sizing:border-box;margin:0;pointer-events:auto;position:absolute;text-align:left;text-align:initial;transform-origin:0 0}.annotationLayer .linkAnnotation{outline:none;outline:var(--link-outline)}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a{font-size:1em;height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer :is(.linkAnnotation,.buttonWidgetAnnotation.pushButton)>a:hover{background:#ff0;box-shadow:0 2px 10px #ff0;opacity:.2}.annotationLayer .textAnnotation img{cursor:pointer;height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input,.annotationLayer .choiceWidgetAnnotation select,.annotationLayer .textWidgetAnnotation :is(input,textarea){background-image:url('data:image/svg+xml;charset=utf-8,<svg width="1" height="1" xmlns="http://www.w3.org/2000/svg"><rect width="100%" height="100%" style="fill:rgba(0,54,255,.13)"/></svg>');background-image:var(--annotation-unfocused-field-background);border:2px solid #0000;border:2px solid var(--input-unfocused-border-color);box-sizing:border-box;font:calc(9px*var(--scale-factor)) sans-serif;height:100%;margin:0;vertical-align:top;width:100%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:required,.annotationLayer .choiceWidgetAnnotation select:required,.annotationLayer .textWidgetAnnotation :is(input,textarea):required{outline:1.5px solid red}.annotationLayer .choiceWidgetAnnotation select option{padding:0}.annotationLayer .buttonWidgetAnnotation.radioButton input{border-radius:50%}.annotationLayer .textWidgetAnnotation textarea{resize:none}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input[disabled],.annotationLayer .choiceWidgetAnnotation select[disabled],.annotationLayer .textWidgetAnnotation :is(input,textarea)[disabled]{background:none;border:2px solid #0000;border:2px solid var(--input-disabled-border-color);cursor:not-allowed}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input:hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .textWidgetAnnotation :is(input,textarea):hover{border:2px solid #000;border:2px solid var(--input-hover-border-color)}.annotationLayer .buttonWidgetAnnotation.checkBox input:hover,.annotationLayer .choiceWidgetAnnotation select:hover,.annotationLayer .textWidgetAnnotation :is(input,textarea):hover{border-radius:2px}.annotationLayer .choiceWidgetAnnotation select:focus,.annotationLayer .textWidgetAnnotation :is(input,textarea):focus{background:none;border:2px solid Highlight;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) :focus{background-color:initial;background-image:none}.annotationLayer .buttonWidgetAnnotation.checkBox :focus{border:2px solid Highlight;border:2px solid var(--input-focus-border-color);border-radius:2px;outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.radioButton :focus{border:2px solid Highlight;border:2px solid var(--input-focus-border-color);outline:1px solid Canvas;outline:var(--input-focus-outline)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before,.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{background-color:CanvasText;content:"";display:block;position:absolute}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after,.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{height:80%;left:45%;width:1px}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:before{transform:rotate(45deg)}.annotationLayer .buttonWidgetAnnotation.checkBox input:checked:after{transform:rotate(-45deg)}.annotationLayer .buttonWidgetAnnotation.radioButton input:checked:before{border-radius:50%;height:50%;left:30%;top:20%;width:50%}.annotationLayer .textWidgetAnnotation input.comb{font-family:monospace;padding-left:2px;padding-right:0}.annotationLayer .textWidgetAnnotation input.comb:focus{width:103%}.annotationLayer .buttonWidgetAnnotation:is(.checkBox,.radioButton) input{-webkit-appearance:none;appearance:none}.annotationLayer .popupTriggerArea{height:100%;width:100%}.annotationLayer .fileAttachmentAnnotation .popupTriggerArea{position:absolute}.annotationLayer .popupWrapper{font-size:calc(9px*var(--scale-factor));min-width:calc(180px*var(--scale-factor));pointer-events:none;position:absolute;width:100%}.annotationLayer .popup{word-wrap:break-word;background-color:#ff9;border-radius:calc(2px*var(--scale-factor));box-shadow:0 calc(2px*var(--scale-factor)) calc(5px*var(--scale-factor)) #888;cursor:pointer;font:message-box;margin-left:calc(5px*var(--scale-factor));max-width:calc(180px*var(--scale-factor));padding:calc(6px*var(--scale-factor));pointer-events:auto;position:absolute;white-space:normal}.annotationLayer .popup>*{font-size:calc(9px*var(--scale-factor))}.annotationLayer .popup h1{display:inline-block}.annotationLayer .popupDate{display:inline-block;margin-left:calc(5px*var(--scale-factor))}.annotationLayer .popupContent{border-top:1px solid #333;margin-top:calc(2px*var(--scale-factor));padding-top:calc(2px*var(--scale-factor))}.annotationLayer .richText>*{font-size:calc(9px*var(--scale-factor));white-space:pre-wrap}.annotationLayer .caretAnnotation,.annotationLayer .circleAnnotation svg ellipse,.annotationLayer .fileAttachmentAnnotation,.annotationLayer .freeTextAnnotation,.annotationLayer .highlightAnnotation,.annotationLayer .inkAnnotation svg polyline,.annotationLayer .lineAnnotation svg line,.annotationLayer .polygonAnnotation svg polygon,.annotationLayer .polylineAnnotation svg polyline,.annotationLayer .squareAnnotation svg rect,.annotationLayer .squigglyAnnotation,.annotationLayer .stampAnnotation,.annotationLayer .strikeoutAnnotation,.annotationLayer .underlineAnnotation{cursor:pointer}.annotationLayer section svg{height:100%;left:0;position:absolute;top:0;width:100%}.annotationLayer .annotationTextContent{color:#0000;height:100%;opacity:0;pointer-events:none;position:absolute;-webkit-user-select:none;user-select:none;width:100%}.annotationLayer .annotationTextContent span{display:inline-block;width:100%}:root{--react-pdf-text-layer:1;--highlight-bg-color:#b400aa;--highlight-selected-bg-color:#006400}@media screen and (forced-colors:active){:root{--highlight-bg-color:Highlight;--highlight-selected-bg-color:ButtonText}}[data-main-rotation="90"]{transform:rotate(90deg) translateY(-100%)}[data-main-rotation="180"]{transform:rotate(180deg) translate(-100%,-100%)}[data-main-rotation="270"]{transform:rotate(270deg) translateX(-100%)}.textLayer{-webkit-text-size-adjust:none;-moz-text-size-adjust:none;text-size-adjust:none;forced-color-adjust:none;inset:0;line-height:1;overflow:hidden;position:absolute;text-align:left;text-align:initial;transform-origin:0 0;z-index:2}.textLayer :is(span,br){color:#0000;cursor:text;margin:0;position:absolute;transform-origin:0 0;white-space:pre}.textLayer span.markedContent{height:0;top:0}.textLayer .highlight{background-color:#b400aa;background-color:var(--highlight-bg-color);border-radius:4px;margin:-1px;padding:1px}.textLayer .highlight.appended{position:static}.textLayer .highlight.begin{border-radius:4px 0 0 4px}.textLayer .highlight.end{border-radius:0 4px 4px 0}.textLayer .highlight.middle{border-radius:0}.textLayer .highlight.selected{background-color:#006400;background-color:var(--highlight-selected-bg-color)}.textLayer br::selection{background:#0000}.textLayer .endOfContent{cursor:default;display:block;inset:100% 0 0;position:absolute;-webkit-user-select:none;user-select:none;z-index:-1}.textLayer .endOfContent.active{top:0}.tiny-action{align-items:center;background:linear-gradient(180deg,#fff,#f1f5f9);border:1px solid #94a3b859;border-radius:6px;color:#334155;cursor:pointer;display:inline-flex;font-size:.62rem;font-weight:500;gap:.25rem;line-height:1.05;padding:.3rem .55rem;position:relative;transition:background .18s,box-shadow .18s,transform .15s,border-color .18s;-webkit-user-select:none;user-select:none}.tiny-action:before{border-radius:inherit;box-shadow:0 0 0 0 #3b82f659;content:"";inset:0;opacity:0;position:absolute;transition:box-shadow .35s,opacity .35s}.tiny-action:hover{background:linear-gradient(180deg,#fff,#e2e8f0);box-shadow:0 2px 6px -2px #0000001f,0 4px 12px -4px #0000001f}.tiny-action:active{background:#e2e8f0;transform:translateY(1px)}.tiny-action:focus-visible{outline:2px solid #3b82f6;outline-offset:2px}.tiny-action.primary{border-color:#3b82f68c;color:#1d4ed8}.tiny-action.primary:hover{border-color:#3b82f6}.tiny-action.danger{border-color:#ef44448c;color:#dc2626}.tiny-action.danger:hover{border-color:#ef4444}.tiny-action.danger:before{box-shadow:0 0 0 3px #ef444459}.tiny-action.success{border-color:#22c55e8c;color:#166534}.tiny-action.success:hover{border-color:#16a34a}.tiny-action.disabled,.tiny-action:disabled{cursor:not-allowed;filter:grayscale(.3);opacity:.45}.tiny-action+.tiny-action{margin-left:.25rem}.tiny-action-group{align-items:center;display:flex;flex-wrap:nowrap;gap:.3rem}.tiny-action.icon-only{padding:.3rem}.tiny-action.icon-only span.label{display:none}@media (max-width:1150px){.tiny-action-group{flex-wrap:wrap;row-gap:.35rem}}:root{--wp-bg:#f7f9fc;--wp-card-bg:#fff;--wp-border:#e3e8ef;--wp-primary:#3b82f6;--wp-primary-hover:#2563eb;--wp-success:#10b981;--wp-warning:#f59e0b;--wp-danger:#ef4444;--wp-text-dark:#1f2937;--wp-text-light:#6b7280}.workplans-wrapper{background:#f7f9fc;background:var(--wp-bg);padding:24px}.workplans-toolbar{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:16px}.workplans-table .ant-table-thead>tr>th{background:linear-gradient(135deg,#f0f4f9,#e6eef7);font-weight:600}.workplans-table .ant-table-tbody>tr:hover>td{background:#f1f7ff!important}.wp-progress-cell{min-width:180px}.wp-progress-bar-wrapper{cursor:pointer}.wp-progress-bar-wrapper .ant-progress-bg{background:linear-gradient(90deg,#3b82f6,#6366f1,#8b5cf6)}.wp-progress-overdue .ant-progress-bg{background:linear-gradient(90deg,#ef4444,#f59e0b)}.wp-status-tag{background:#e5e7eb;border-radius:10px;color:#1f2937;color:var(--wp-text-dark);font-size:12px;padding:2px 6px}.wp-status-tag.completed{background:#d1fae5;color:#065f46}.wp-status-tag.overdue{background:#fee2e2;color:#991b1b}.wp-status-tag.dueSoon{background:#ffedd5;color:#9a3412}.wp-status-tag.active{background:#e0e7ff;color:#1e3a8a}.wp-inline-edit-block{display:flex;flex-direction:column;gap:6px}.wp-inline-edit-actions{display:flex;gap:8px}.wp-modal .ant-modal-content{border-radius:12px}.wp-attach-btn{min-width:90px}.wp-bulk-info{color:#6b7280;color:var(--wp-text-light);font-size:12px}@media (max-width:900px){.workplans-table .ant-table{font-size:12px}.wp-progress-cell{min-width:140px}}.wp-row-overdue td{background:#fff5f5!important}.wp-row-duesoon td{background:#fffaf0!important}.leave-overtime-page{width:100%}.leave-overtime-header{align-items:center;display:flex;gap:12px;justify-content:space-between;padding:12px 12px 8px}.leave-overtime-title{color:var(--text-primary);font-size:16px;font-weight:600}.leave-overtime-actions{display:flex;flex-wrap:wrap;gap:8px}@media (max-width:768px){.leave-overtime-header{align-items:stretch;flex-direction:column;padding:12px 12px 8px}.leave-overtime-actions{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr}}.native-fullscreen-modal{padding:0!important}.native-fullscreen-modal .ant-modal{margin:0!important;max-width:100vw!important;padding-bottom:0!important;top:0!important;width:100vw!important}.native-fullscreen-modal .ant-modal-content{border-radius:0;height:100vh}.native-fullscreen-modal .ant-modal-header{background:#fff;border-radius:0;position:-webkit-sticky;position:sticky;top:0;z-index:1}.native-fullscreen-modal .ant-modal-close{top:12px}.native-fullscreen-modal .ant-modal-body{-webkit-overflow-scrolling:touch;height:calc(100vh - 56px);overflow:auto;padding:12px}.m-shell{background:var(--bg-primary);color:var(--text-primary);min-height:100vh}.m-topbar{align-items:center;background:var(--bg-secondary);border-bottom:1px solid var(--border-color);display:flex;gap:12px;justify-content:space-between;padding:12px 14px;position:-webkit-sticky;position:sticky;top:0;z-index:10}.m-brand{display:flex;flex-direction:column;gap:2px;min-width:0}.m-brandName{color:var(--text-secondary);font-size:12px;font-weight:600}.m-brandName,.m-pageTitle{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.m-pageTitle{font-size:16px;font-weight:700}.m-homeLink{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:999px;color:var(--primary-color);font-size:13px;font-weight:600;padding:6px 10px;text-decoration:none}.m-content{margin:0 auto;max-width:520px;padding:14px}.m-card{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.m-cardPad{padding:14px}.m-h2{font-size:16px;font-weight:700;margin:0 0 10px}.m-muted{color:var(--text-secondary);font-size:12px;line-height:1.5}.m-grid{grid-gap:12px;display:grid;gap:12px;grid-template-columns:1fr 1fr}.m-tile{color:inherit;display:flex;flex-direction:column;gap:8px;text-decoration:none}.m-tileTitle{font-weight:700}.m-tileDesc{color:var(--text-secondary);font-size:12px;line-height:1.4}.m-tileIcon{align-items:center;background:var(--badge-bg);border:1px solid var(--border-color);border-radius:12px;color:var(--primary-color);display:flex;font-weight:800;height:38px;justify-content:center;width:38px}.m-section{display:flex;flex-direction:column;gap:10px}.m-divider{background:var(--border-color);height:1px;margin:12px 0}.m-form{gap:12px}.m-field,.m-form{display:flex;flex-direction:column}.m-field{gap:6px}.m-label{color:var(--text-secondary);font-size:12px;font-weight:700}.m-input,.m-select,.m-textarea{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:14px;padding:10px}.m-textarea{min-height:92px;resize:vertical}.m-row{display:flex;gap:10px}.m-row>div{flex:1 1}.m-list{gap:10px}.m-item,.m-list{display:flex;flex-direction:column}.m-item{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-md);gap:4px;padding:12px}.m-itemTitle{font-size:13px;font-weight:700}.m-itemMeta{color:var(--text-secondary);font-size:12px}.m-alert{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:var(--radius-md);color:var(--text-primary);font-size:13px;line-height:1.5;padding:10px 12px}.m-alertErr{background:#dc262614;border-color:#dc262659}.m-home{display:flex;flex-direction:column;gap:14px}.m-homeHero{padding:18px 6px 8px;text-align:left}.m-homeBrandRow{gap:10px;margin-bottom:12px}.m-homeBrandRow,.m-homeLogo{align-items:center;display:flex}.m-homeLogo{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:10px;height:34px;justify-content:center;width:34px}.m-homeBrand,.m-homeLogo{color:var(--primary-color)}.m-homeBrand{font-size:14px;font-weight:700}.m-homeTitle{color:var(--primary-color);font-size:34px;font-weight:800;letter-spacing:.5px;line-height:1.08}.m-homeSub{color:var(--text-primary);font-size:18px;font-weight:800;margin-top:10px}.m-homeSectionTitle{color:var(--primary-color);font-size:12px;font-weight:700;margin-top:4px}.m-homeTiles{grid-gap:10px;display:grid;gap:10px;grid-template-columns:repeat(4,minmax(0,1fr))}.m-homeTile{border:1px solid var(--border-color);border-radius:var(--radius-lg);color:inherit;flex-direction:column;gap:8px;padding:12px 8px;text-decoration:none}.m-homeTile,.m-homeTileIcon{align-items:center;background:var(--bg-secondary);display:flex}.m-homeTileIcon{border:1px solid var(--border-color);border-radius:12px;color:var(--primary-color);font-size:16px;font-weight:900;height:44px;justify-content:center;width:44px}.m-homeTileTitle{color:var(--text-primary);font-size:12px;font-weight:800;text-align:center;white-space:nowrap}.m-homeDivider{background:var(--border-color);height:1px;margin:4px 0}.m-homeOverview{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);padding:14px}.m-homeOverviewTitle{color:var(--primary-color);font-size:16px;font-weight:900;margin:0 0 10px}.m-homeKpis{align-items:flex-end;display:flex;flex-wrap:wrap;gap:12px}.m-homeKpi{flex:1 1;min-width:92px}.m-homeKpiLabel{color:var(--text-secondary);font-size:12px;font-weight:700}.m-homeKpiValue{color:var(--primary-color);font-size:16px;font-weight:900;margin-top:4px}.m-homeProgress{margin-top:12px}.m-homeProgressHead{align-items:center;display:flex;justify-content:space-between;margin-bottom:8px}.m-homeProgressLabel{font-weight:800}.m-homeProgressHint,.m-homeProgressLabel{color:var(--text-secondary);font-size:12px}.m-homeProgressBar{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:999px;height:6px;overflow:hidden}.m-homeProgressFill{background:var(--primary-color);height:100%}.m-homeProgressFoot{color:var(--text-secondary);font-size:11px;margin-top:8px}.m-homeBigNums,.m-homeProgressFoot{display:flex;justify-content:space-between}.m-homeBigNums{gap:12px;margin-top:14px}.m-homeBigNum{flex:1 1}.m-homeBigValue{color:var(--primary-color);font-size:40px;font-weight:900;line-height:1}.m-homeBigLabel{color:var(--primary-color);font-size:12px;font-weight:800;margin-top:10px}.m-homeFooter{color:var(--text-secondary);font-size:11px;margin-top:16px}@media (max-width:360px){.m-homeTiles{grid-template-columns:repeat(2,minmax(0,1fr))}.m-homeTitle{font-size:28px}.m-grid{grid-template-columns:1fr}}.App{text-align:center}.App-logo{height:40vmin;pointer-events:none}@media (prefers-reduced-motion:no-preference){.App-logo{animation:App-logo-spin 20s linear infinite}}.App-header{align-items:center;background-color:#282c34;color:#fff;display:flex;flex-direction:column;font-size:calc(10px + 2vmin);justify-content:center;min-height:100vh}.App-link{color:#61dafb}@keyframes App-logo-spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.app-layout{background:var(--bg-primary)}.app-layout,.app-sidebar{display:flex;height:100vh;overflow:hidden}.app-sidebar{background:var(--bg-secondary);box-shadow:2px 0 12px #0000000d;flex-direction:column;padding:24px 16px;transition:transform .2s ease,box-shadow .2s ease;width:250px;z-index:20}.app-content{flex:1 1;height:100vh;overflow-x:hidden;overflow-y:auto;padding:32px}.app-main{background:var(--bg-secondary);border-radius:16px;box-shadow:0 4px 24px #0000000d;min-height:100%;padding:32px}.app-mobile-header{align-items:center;display:none;gap:12px;margin-bottom:16px}.app-mobile-menu-button{background:var(--bg-secondary);border:none;border-radius:8px;box-shadow:0 2px 8px #00000014;color:var(--text-primary);cursor:pointer;font-size:20px;padding:8px 12px}.app-mobile-title{color:var(--text-primary);font-size:16px;font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.app-sidebar-backdrop{background:#00000059;inset:0;position:fixed;z-index:15}@media (max-width:768px){.app-layout{position:relative}.app-sidebar{height:100vh;left:0;padding:20px 12px;position:fixed;top:0;transform:translateX(-100%)}.app-sidebar.is-open{transform:translateX(0)}.app-sidebar.is-closed{transform:translateX(-100%)}.app-content,.app-main{padding:16px}.app-main{border-radius:12px}.app-mobile-header{display:flex}}:root{--bg-primary:#f9fafb;--bg-secondary:#fff;--bg-tertiary:#f3f4f6;--bg-elevated:#fff;--text-primary:#111827;--text-secondary:#6b7280;--text-inverse:#fff;--border-color:#e5e7eb;--border-strong:#d1d5db;--primary-color:#2563eb;--primary-color-hover:#1d4ed8;--primary-color-active:#1e40af;--brand-primary:#1d4ed8;--danger-color:#dc2626;--danger-color-hover:#b91c1c;--warning-color:#d97706;--success-color:#16a34a;--info-color:#0284c7;--radius-xs:3px;--radius-sm:6px;--radius-md:10px;--radius-lg:16px;--shadow-sm:0 1px 2px #0000000f,0 1px 3px #00000014;--shadow-md:0 4px 12px #00000014;--shadow-lg:0 8px 28px #0000001f;--focus-ring:0 0 0 3px #2563eb59;--transition-base:.18s cubic-bezier(.4,0,.2,1);--secondary-button-bg:#e5e7eb;--table-header-bg:#f1f5f9;--badge-bg:#eef2ff}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#273549;--bg-elevated:#1e293b;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--border-color:#334155;--border-strong:#475569;--primary-color:#3b82f6;--primary-color-hover:#2563eb;--primary-color-active:#1d4ed8;--brand-primary:#60a5fa;--secondary-button-bg:#334155;--table-header-bg:#233044;--badge-bg:#1e3a8a;--shadow-sm:0 1px 2px #0009,0 1px 3px #00000073;--shadow-md:0 4px 14px #0000008c;--shadow-lg:0 8px 32px #0009;--focus-ring:0 0 0 3px #60a5fa73}body{-webkit-font-smoothing:antialiased;background-color:#f9fafb;background-color:var(--bg-primary);color:#111827;color:var(--text-primary);font-size:14px;line-height:1.5;transition:background-color .35s,color .35s}.layout{background-color:var(--card-bg-color);border-right-color:#e5e7eb;border-right-color:var(--border-color)}.form-card,.settings-card,.stat-card,.table-card{background-color:var(--card-bg-color);box-shadow:0 4px 12px #0000000d}h2{color:var(--header-color)}.table-header{background-color:var(--bg-color);color:var(--subtext-color)}.table-cell,.table-header{border-bottom-color:#e5e7eb;border-bottom-color:var(--border-color)}.table-cell,input{color:var(--text-color)}input{background-color:var(--bg-color);border-color:#e5e7eb;border-color:var(--border-color)}.btn,button{align-items:center;background:#2563eb;background:var(--primary-color);border:1px solid #0000;border-radius:6px;border-radius:var(--radius-sm);color:#fff;color:var(--text-inverse);cursor:pointer;display:inline-flex;font-family:inherit;font-size:14px;font-weight:500;gap:.4rem;line-height:1.2;padding:.55rem .95rem;transition:background .18s cubic-bezier(.4,0,.2,1),box-shadow .18s cubic-bezier(.4,0,.2,1),transform .18s cubic-bezier(.4,0,.2,1),border-color .18s cubic-bezier(.4,0,.2,1);transition:background var(--transition-base),box-shadow var(--transition-base),transform var(--transition-base),border-color var(--transition-base)}.btn:hover,button:hover{background:#1d4ed8;background:var(--primary-color-hover)}.btn:active,button:active{background:#1e40af;background:var(--primary-color-active)}.btn:focus-visible,button:focus-visible{box-shadow:0 0 0 3px #2563eb59;box-shadow:var(--focus-ring);outline:none}.btn-secondary{background:#e5e7eb;background:var(--secondary-button-bg);border-color:#e5e7eb;border-color:var(--border-color);color:#111827;color:var(--text-primary)}.btn-secondary:hover{background:#dfe3e7}[data-theme=dark] .btn-secondary:hover{background:#3b4756}.btn-danger{background:#dc2626;background:var(--danger-color)}.btn-danger:hover{background:#b91c1c;background:var(--danger-color-hover)}.btn-outline{background:#0000;border-color:#e5e7eb;border-color:var(--border-color);color:#111827;color:var(--text-primary)}.btn-outline:hover{background:#f3f4f6;background:var(--bg-tertiary)}.btn-small{font-size:12px;padding:.4rem .7rem}.btn-large{font-size:15px;padding:.75rem 1.25rem}.badge{background:#eef2ff;background:var(--badge-bg);border-radius:999px;color:#2563eb;color:var(--primary-color);display:inline-block;font-size:12px;font-weight:500;line-height:1.3;padding:2px 8px}.badge-success{background:#16a34a1f;color:#16a34a;color:var(--success-color)}.badge-danger{background:#dc262626;color:#dc2626;color:var(--danger-color)}.badge-warning{background:#d977062e;color:#d97706;color:var(--warning-color)}.badge-info{background:#0284c726;color:#0284c7;color:var(--info-color)}.badge-neutral{background:#f3f4f6;background:var(--bg-tertiary);color:#6b7280;color:var(--text-secondary)}[data-theme=dark] .badge-neutral{background:#334155}.table-wrapper{overflow-x:auto;width:100%}table.data-table{border-collapse:collapse;font-size:13px;width:100%}table.data-table thead th{background:#f1f5f9;background:var(--table-header-bg);color:#6b7280;color:var(--text-secondary);font-weight:600;padding:10px 12px;position:-webkit-sticky;position:sticky;text-align:left;top:0;z-index:2}table.data-table tbody td,table.data-table thead th{border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--border-color)}table.data-table tbody td{color:#111827;color:var(--text-primary);padding:9px 12px}table.data-table tbody tr:hover{background:#f3f4f6;background:var(--bg-tertiary)}[data-theme=dark] table.data-table tbody tr:hover{background:#314158}table.data-table tbody tr:last-child td{border-bottom:none}.panel{background:#fff;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 4px 12px #00000014;box-shadow:var(--shadow-md);padding:24px 28px}.panel-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:18px}.panel-title{font-size:18px;font-weight:600;margin:0}.toolbar{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:16px}.toolbar input,.toolbar select{background:#fff;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);color:#111827;color:var(--text-primary);padding:6px 10px;transition:border-color .18s cubic-bezier(.4,0,.2,1),background .18s cubic-bezier(.4,0,.2,1);transition:border-color var(--transition-base),background var(--transition-base)}.toolbar input:focus,.toolbar select:focus{border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb59;box-shadow:var(--focus-ring);outline:none}form .form-grid{grid-gap:14px;display:grid;gap:14px}label.form-field{color:#6b7280;color:var(--text-secondary);display:flex;flex-direction:column;font-size:13px;font-weight:500;gap:4px}label.form-field input,label.form-field select,label.form-field textarea{background:#fff;background:var(--bg-secondary);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:6px;border-radius:var(--radius-sm);font-family:inherit;font-size:13px;padding:8px 10px;resize:vertical}label.form-field input:focus,label.form-field select:focus,label.form-field textarea:focus{border-color:#2563eb;border-color:var(--primary-color);box-shadow:0 0 0 3px #2563eb59;box-shadow:var(--focus-ring);outline:none}.modal-backdrop{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000073;display:flex;inset:0;justify-content:center;padding:20px;position:fixed;z-index:1000}.modal{animation:modalIn .35s cubic-bezier(.22,1,.36,1);background:#fff;background:var(--bg-elevated);border:1px solid #e5e7eb;border:1px solid var(--border-color);border-radius:16px;border-radius:var(--radius-lg);box-shadow:0 8px 28px #0000001f;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;gap:14px;max-width:520px;padding:28px 30px 24px;width:100%}@keyframes modalIn{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}.modal h3{font-size:18px;font-weight:600;margin:0 0 4px}.modal .actions{display:flex;gap:12px;justify-content:flex-end;margin-top:4px}.muted{color:#6b7280;color:var(--text-secondary)}.spacer{flex:1 1}.text-danger{color:#dc2626;color:var(--danger-color)}.text-right{text-align:right}::-webkit-scrollbar{height:10px;width:10px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--bg-tertiary)}::-webkit-scrollbar-thumb{background:#cbd5e1;border:2px solid #f3f4f6;border:2px solid var(--bg-tertiary);border-radius:20px}[data-theme=dark] ::-webkit-scrollbar-thumb{background:#475569;border-color:#f3f4f6;border-color:var(--bg-tertiary)}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.button-primary-action{background:#2563eb;background:var(--primary-color);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:13px;font-weight:500;padding:8px 12px;transition:background .2s ease,box-shadow .2s ease}.button-primary-action:hover{background:#1d4ed8;background:var(--primary-color-hover);box-shadow:0 2px 6px #00000026}.button-primary-action:active{background:#1e40af;background:var(--primary-color-active)}
/*# sourceMappingURL=main.17987f23.css.map*/